Android: Tools
阅读数:143 评论数:0
跳转到新版页面分类
python/Java
正文
作用
xmlns:tools="http://schemas.android.com/tools"
大致有三种主要功能:
(1)xml中的错误处理,减少或者避免黄线提示,让代码更清爽,让编译少报错。
(2)xml预览,可以随心所欲的定制预览视图。
(3)资源压缩,压缩资源文件,降低APK体积。
错误处理属性
1、tools:ignore
让Lint工具(Lint是Android的代码扫描工具)在检查代码时忽略指定的错误。
RTL(Right To Left)
2、tools:targetApi
同java代码中的@TargetApi注解,指明某个控制只在指定的API及更高的版本中生效,这样,在使用Lint检测时就不会因minSdkVersion低于控件出一的版本而报错。
3、tools:locale
指明resources中元素的语言类型,避免拼写检查或者Lint检查时报错,这两都只是默认的语言类型是英文 es。
xml视图预览相关属性
以下属性在xml中定义之后,只在预览时会展示,正式部署之后并不会展示。
1、tools:xxx替代android:xxx
将view的任意属性值的android前缀替换为tools之后,就可以实现预览效果。以tools为命名空间的属性值只在预览时有效。另外,在预览时,如果同时有tools:xxx和android:xxx,则优先展示tools:xxx的预览效果。
2、tools:context
声明该布局文件默认关联的activity。声明之后会在布局编辑器或者预览界面中开启一些与该activity相关的特性。
3、tools:itemCount
在RecyclerView节点中设置该属性之后,会指定在预览界面中绘制几个条目。
4、tools:layout
声明在预览时将哪个布局文件填充到该Fragment。
5、tools:listitem, tools:listheader, tools:listfooter
声明AdapterView在预览界面中所展示的条目、头布局、脚布局。
6、tools:showIn
声明该布局文件将会被哪个布局通过<include>引用,声明之后,在对应的文件中不要忘了用<include>引用。
7、tools:menu
声明在预览界面中AppBar将展示哪些菜单。
8、tools:minValue, tools:maxValue
为NumberPicker设置预览时的最小值和最大值。
9、tools:openDrawer
在预览界面中将DrawerLayout打开。
10、@tools:sample/*
为View设置占位文本或图片,这其实就是系统设置的一堆字符串和图片资源,当你想设置预览文本或者预览图片时,如果不想自己去定义,直接引用这些系统预置的字符串和图片就可以了。
资源压缩相关属性
开启资源压缩时,在module的build.gradle文件作如下修改:
android {
buildTypes {
release {
shrinkResources true //开启资源压缩。minifyEnabled 也必须为true,否则编译不通过
minifyEnabled true //开启代码混淆/压缩
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
}
}
}
1、tools:shrinkMode
指明构建工具在压缩资源时使用哪种模式。
2、tools:keep
使用资源压缩去除未使用的资源时,该属性将允许你指明哪些资源可以被保留。
3、tools:discard
当使用资源压缩工具去除一些无用资源时,使用该属性可以指一华夏幸福需要手动删除的资源。