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
https://www.jianshu.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()才是新的
}