1:獲取TextView文本寬度
new Paint().measureText(),返回的總是過小,仔細一看textSize=14px
使用TextView.getPaint().getTextSize = 42px(14sp *3 fontScale)正常
2:被吞噬的符號
在使用正則替換指定數據塊的時候,會用到Matcher
類。
Matcher.appendReplacement()
會把數據源中\ $這兩種字符過濾掉
源碼的細節如下:
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;
}
}
所以我們在轉換前,需要提前把\ $轉義掉
打開任意第三方app
今天遇到個需求,類似淘寶復制口令到第三方app傳播。
如何知道包名呢?我們可以在豌豆莢里面搜索app,比如微信,搜出來后超鏈接http://www.wandoujia.com/apps/com.tencent.mm
,后面的com.tencent.mm
就是包名
可以通過羅列用戶已安裝app的列表,對比包名一致就是目標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圖設置View的background屬性時,View的padding會被替換成.9圖的padding
http://www.lxweimin.com/p/4432b19ec6cd
InputFilter 過濾EditText輸入
比如下文實現了過濾空格和換行符,值得注意的是,返回null表示接受用戶輸入,返回""表示過濾當前敲入的鍵符
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超出最大高度后可滾動
高度wrap_content,添加android:maxHeight
,如果要顯示滾動欄,則添加android:scrollbars="vertical"
最后在代碼里,添加滾動手勢tvContent.setMovementMethod(new ScrollingMovementMethod());
缺點:沒有filing手勢
8.0 Activity沒設背景色導致黑屏閃爍的問題
解決辦法:
- 根節點加背景顏色
<FrameLayout android:layout_width="match_parent" android:layout_height="match_parent" android:background="@color/bg_color">
- theme里面windowBackground設置透明
<item name="android:windowBackground">@android:color/transparent</item>
Unexpected namespace prefix "app" found for tag
自定義包名不要以android開頭。
自動伸縮布局
<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="擴充,最多一行"
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;
調用
if (mImageTakeIconRes >0) {
mAdapter.setImageTakeIconRes(mImageTakeIconRes);
}
此時系統提示危險行為,R.xx.id,有可能是負數,此時的if判斷失效,導致賦值無法生效
正確的辦法,使用包裝值類型
public @DrawableRes Integer mImageTakeIconRes = null;
判斷非空即可
if (mImageTakeIconRes !=null) {
mAdapter.setImageTakeIconRes(mImageTakeIconRes);
}
覆蓋Activity默認動畫
項目中默認使用側滑過場動畫,如果某個頁面要改alpha漸變的話, 需要做兩步
注意覆蓋位置
1:入場
public static void start(Context context) {
Intent intent = new Intent(context, XLShortMenuActivity.class);
context.startActivity(intent);
XLBaseActivity.alphaTrans(context);
}
2:出場
@Override
public void finish() {
super.finish();
alphaTransOut();
}
SingleTask
- 失效
使用startActivityForResult的時候,singleTask不起作用(棧前的Activity未被彈出)。
解決辦法是使用startActivity。因為既然決定彈出當前的Activity,那也沒必要監聽startActivityForResult了 - getIntent() 數據是老的
SingleTask時,Activity已存在的時候,會走onNewIntent,不做操作,拿getIntent()的數據是老的,解決辦法是調用setIntent
賦值
@Override
protected void onNewIntent(Intent intent) {
super.onNewIntent(intent);
setIntent(intent);
//此時getIntent()才是新的
}