1:獲取TextView文本寬度
new Paint().measureText(),返回的總是過小,仔細(xì)一看textSize=14px
使用TextView.getPaint().getTextSize = 42px(14sp *3 fontScale)正常
2:被吞噬的符號(hào)
在使用正則替換指定數(shù)據(jù)塊的時(shí)候,會(huì)用到Matcher類。
Matcher.appendReplacement()會(huì)把數(shù)據(jù)源中\(zhòng) $這兩種字符過濾掉
源碼的細(xì)節(jié)如下:
for (int i = 0; i < s.length(); i++) {
char c = s.charAt(i);
if (c == '\\' && !escape) {
escape = true;
} else if (c == '$' && !escape) {
dollar = true;
} else if (c >= '0' && c <= '9' && dollar) {
buffer.append(group(c - '0'));
dollar = false;
} else {
buffer.append(c);
dollar = false;
escape = false;
}
}
所以我們?cè)谵D(zhuǎn)換前,需要提前把\ $轉(zhuǎn)義掉
打開任意第三方app
今天遇到個(gè)需求,類似淘寶復(fù)制口令到第三方app傳播。
如何知道包名呢?我們可以在豌豆莢里面搜索app,比如微信,搜出來后超鏈接http://www.wandoujia.com/apps/com.tencent.mm,后面的com.tencent.mm就是包名
可以通過羅列用戶已安裝app的列表,對(duì)比包名一致就是目標(biāo)app。
下面是完整打開代碼
/**
* 打開第三方app
*
* @param context
* @param packageName 包名,可去豌豆莢獲得
* @return
*/
public static boolean openApp(Context context, String packageName) {
Intent mainIntent = new Intent(Intent.ACTION_MAIN, null);
mainIntent.addCategory(Intent.CATEGORY_LAUNCHER);
PackageManager mPackageManager = context.getPackageManager();
List<ResolveInfo> mAllApps = mPackageManager.queryIntentActivities(mainIntent, 0);
for (ResolveInfo res : mAllApps) {
String pkg = res.activityInfo.packageName;
String cls = res.activityInfo.name;
if (TextUtils.equals(pkg, packageName)) {
ComponentName componentName = new ComponentName(pkg, cls);
Intent intent = new Intent();
intent.setComponent(componentName);
intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
context.startActivity(intent);
return true;
}
}
return false;
}
View的Padding失效
在用.9圖設(shè)置View的background屬性時(shí),View的padding會(huì)被替換成.9圖的padding
http://www.itdecent.cn/p/4432b19ec6cd

InputFilter 過濾EditText輸入
比如下文實(shí)現(xiàn)了過濾空格和換行符,值得注意的是,返回null表示接受用戶輸入,返回""表示過濾當(dāng)前敲入的鍵符
private class MyInputFilter implements InputFilter {
/**
* @param charSequence
* @param start
* @param end
* @param dst
* @param dstart
* @param dend
* @return 返回Null 不過濾,,返回""替換
*/
@Override
public CharSequence filter(CharSequence charSequence, int start, int end, Spanned dst, int dstart, int dend) {
//刪除空格符不用過濾
if (charSequence.length() < 1) {
return null;
}
//半角、全角空格、換行符過濾
if (charSequence.equals(" ") || charSequence.equals(" ") || charSequence.equals("\n")) {
return "";
} else {
return null;
}
}
}
TextView超出最大高度后可滾動(dòng)
高度wrap_content,添加android:maxHeight,如果要顯示滾動(dòng)欄,則添加android:scrollbars="vertical"
最后在代碼里,添加滾動(dòng)手勢(shì)tvContent.setMovementMethod(new ScrollingMovementMethod());
缺點(diǎn):沒有filing手勢(shì)
8.0 Activity沒設(shè)背景色導(dǎo)致黑屏閃爍的問題
解決辦法:
- 根節(jié)點(diǎn)加背景顏色
<FrameLayout android:layout_width="match_parent" android:layout_height="match_parent" android:background="@color/bg_color"> - theme里面windowBackground設(shè)置透明
<item name="android:windowBackground">@android:color/transparent</item>
Unexpected namespace prefix "app" found for tag
自定義包名不要以android開頭。
自動(dòng)伸縮布局

<TableLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:shrinkColumns="0">
<TableRow
android:layout_width="wrap_content"
android:layout_height="wrap_content">
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_vertical"
android:ellipsize="end"
android:maxLines="1"
android:text="擴(kuò)充,最多一行"
android:textSize="14sp"/>
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginLeft="10dp"
android:text="跟在第一列后面,固定寬度"/>
</TableRow>
</TableLayout>
DrawableRes值使用
初始化
public @DrawableRes int mImageTakeIconRes = -1;
調(diào)用
if (mImageTakeIconRes >0) {
mAdapter.setImageTakeIconRes(mImageTakeIconRes);
}
此時(shí)系統(tǒng)提示危險(xiǎn)行為,R.xx.id,有可能是負(fù)數(shù),此時(shí)的if判斷失效,導(dǎo)致賦值無法生效
正確的辦法,使用包裝值類型
public @DrawableRes Integer mImageTakeIconRes = null;
判斷非空即可
if (mImageTakeIconRes !=null) {
mAdapter.setImageTakeIconRes(mImageTakeIconRes);
}
覆蓋Activity默認(rèn)動(dòng)畫
項(xiàng)目中默認(rèn)使用側(cè)滑過場(chǎng)動(dòng)畫,如果某個(gè)頁面要改alpha漸變的話, 需要做兩步
注意覆蓋位置
1:入場(chǎng)
public static void start(Context context) {
Intent intent = new Intent(context, XLShortMenuActivity.class);
context.startActivity(intent);
XLBaseActivity.alphaTrans(context);
}
2:出場(chǎng)
@Override
public void finish() {
super.finish();
alphaTransOut();
}
SingleTask
- 失效
使用startActivityForResult的時(shí)候,singleTask不起作用(棧前的Activity未被彈出)。
解決辦法是使用startActivity。因?yàn)榧热粵Q定彈出當(dāng)前的Activity,那也沒必要監(jiān)聽startActivityForResult了 - getIntent() 數(shù)據(jù)是老的
SingleTask時(shí),Activity已存在的時(shí)候,會(huì)走onNewIntent,不做操作,拿getIntent()的數(shù)據(jù)是老的,解決辦法是調(diào)用setIntent賦值
@Override
protected void onNewIntent(Intent intent) {
super.onNewIntent(intent);
setIntent(intent);
//此時(shí)getIntent()才是新的
}