StateListDrawable可以根据View的不同状态,更换不同的背景
可以应用如EditText,Button等中,以Button为例
系统中默认的按钮被按下的颜色和未点击时的颜色不一样,该种实现可以用Java代码和XML实现
以Java代码:
//……前面对Button的声明略去
okBtn.setBackgroundDrawable(addStateDrawable(this, R.drawable.btn_normal, R.drawable.btn_selected, R.drawable.btn_selected));
cancelBtn.setBackgroundDrawable(addStateDrawable(this, R.drawable.btn_normal, R.drawable.btn_selected, R.drawable.btn_selected));
//……对应主要的代码
//当对应的View处于不同的状态时,对应的bacdground跟着变化
private StateListDrawable addStateDrawable(Context context, int idNormal, int idPressed, int idFocused) {
StateListDrawable sd = new StateListDrawable();
Drawable normal = idNormal == -1 ? null : context.getResources().getDrawable(idNormal);
Drawable pressed = idPressed == -1 ? null : context.getResources().getDrawable(idPressed);
Drawable focus = idFocused == -1 ? null : context.getResources().getDrawable(idFocused);
//注意该处的顺序,只要有一个状态与之相配,背景就会被换掉
//所以不要把大范围放在前面了,如果sd.addState(new[]{},normal)放在第一个的话,就没有什么效果了
sd.addState(new int[]{android.R.attr.state_enabled, android.R.attr.state_focused}, focus);
sd.addState(new int[]{android.R.attr.state_pressed, android.R.attr.state_enabled}, pressed);
sd.addState(new int[]{android.R.attr.state_focused}, focus);
sd.addState(new int[]{android.R.attr.state_pressed}, pressed);
sd.addState(new int[]{android.R.attr.state_enabled}, normal);
sd.addState(new int[]{}, normal);
return sd;
}
xml方式实现时,可以先了解下对应xml的语法
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android"
android:constantSize=["true" | "false"]
android:dither=["true" | "false"]
android:variablePadding=["true" | "false"] >
<item
android:drawable="@[package:]drawable/drawable_resource"
android:state_pressed=["true" | "false"]
android:state_focused=["true" | "false"]
android:state_selected=["true" | "false"]
android:state_active=["true" | "false"]
android:state_checkable=["true" | "false"]
android:state_checked=["true" | "false"]
android:state_enabled=["true" | "false"]
android:state_window_focused=["true" | "false"] />
</selector>
下面对应的具体实例,由于是做背景用,该xml将放于/res/drawable下面(StateList中第一个匹配当前状态的item会被使用。因此,如果第一个item没有任何状态特性的话,那么它将每次都被使用,这也是为什么默认的值必须总是在最后)
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:state_pressed="true" android:drawable="@drawable/btn_selected"/>
<item android:state_focused="true" android:drawable="@drawable/btn_selected"/>
<item android:state_enabled="true" android:drawable="@drawable/btn_normal"/>
<item android:drawable="@drawable/btn_normal" />
</selector>
在Button的xml中进行加载:
<Button
android:id="@+id/canel"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/btn_cancel"
android:layout_margin="10dip"
android:layout_weight="1"
android:textColor="#ffffffff"
android:textSize="15sp"
android:background="@drawable/button_drawable"
/>
或在java代码中加载:
okBtn.setBackgroundDrawable(R.drawable.button_drawable);
效果都一样。
分享到:
相关推荐
web登录虚拟桌面必备组件:VMware-Horizon-View-HTML-Access_x64-2.2.0-1404668
Json数据转化工具,谷歌浏览器扩展应用,JSONView-for-Chrome-master
VMware-Horizon-View-Client-x86-2.3.3-1745122.exe版本
jsonview-for-chrome-master.zipjsonview-for-chrome-master.zipjsonview-for-chrome-master.zip
VMware-Horizon-View-HTML-Access-4.10.0-10935101
HDFView,安装直接可用,可以查看HDF5,HDF等等格式文件;查看Tensorflow保存的参数等等,
JSONView-for-Chrome-master.rar
JSONView-for-Chrome-master chrome 浏览器的 显示json 插件
sublime-view-in-browser-5137b93.zip 让Sublime Text2支持浏览器中预览 http://www.imququ.com/post/view_sublime-text-2_file_in_browser.html
适合不能联网或联网安装失败不成功的情况,需要安装vscode view-in-browser插件的前端童靴下载。 安装时运行CMD 进入dos命令行 运行命令code --install-extension koppt.vscode-view-in-browser-1.0.5.vsix 即可
velocity-tools-view-2.0-beta1.jar, 供大家使用
JSONView-for-Chrome.zip, chrome浏览器JSON插件,好用的,另带安装步骤
HDFView-3.1.4-win10_64-vs16,可以打开,读取,查看hdf格式文件
自定义View---三种事件的触发、自定义View属性
jsonview-1.1.0-fx jsonview-1.1.0-fx 火狐插件火狐插件
VMware-viewagent-direct-connection-x86_64-6.1.0-2509221
keras H5文件打开工具3.1.0版本,亲测安装成功,可以直接打开模型文件,查看模型结构和参数,安装之前最好装一个VS2015
使用单张图片为View设置带点击效果的背景 - Java - 下载.zip