Android 中API之Drawable资源详解及简单实例
发布时间 - 2026-01-11 00:55:35 点击率:次Android 中API之Drawable资源

1、最常用的StateListDrawable
说StateListDrawable,很多Android猿可能感到不太熟悉,不过如果说selector选择器,肯定都会恍然大悟,不错,这两个东西就是同一个~~
它的用途之广,每个app必用,下面就写一个demo,来简要说一下用法。
比如一个登陆界面,它的输入框在获取焦点时需要更改背景,登陆按钮在输入框中有内容时,则更改背景颜色,这时候用selector选择器,那就方便多了,效果如下:
EditText的背景xml如下:
<?xml version="1.0" encoding="utf-8"?> <selector xmlns:android="http://schemas.android.com/apk/res/android" > <item android:state_focused="true" android:drawable="@drawable/et_focus"/> <item android:state_focused="false" android:drawable="@drawable/et_unfocus"/> </selector>
<?xml version="1.0" encoding="utf-8"?> <shape xmlns:android="http://schemas.android.com/apk/res/android" > <corners android:radius="2dp"/> <stroke android:width="1px" android:color="#f85355" /> </shape>
<?xml version="1.0" encoding="utf-8"?> <shape xmlns:android="http://schemas.android.com/apk/res/android" > <corners android:radius="2dp"/> <stroke android:width="1px" android:color="#c9caca" /> </shape>
提交TextView的背景xml如下:
<?xml version="1.0" encoding="utf-8"?> <selector xmlns:android="http://schemas.android.com/apk/res/android" > <item android:state_enabled="true" android:drawable="@drawable/btn_enable"/> <item android:state_enabled="false" android:drawable="@drawable/btn_unenable"/> </selector>
<?xml version="1.0" encoding="utf-8"?> <shape xmlns:android="http://schemas.android.com/apk/res/android" > <corners android:radius="5dp"/> <solid android:color="#f85355"/> </shape>
<?xml version="1.0" encoding="utf-8"?> <shape xmlns:android="http://schemas.android.com/apk/res/android" > <corners android:radius="5dp"/> <solid android:color="#c9caca"/> </shape>
CheckBox的xml如下:
<?xml version="1.0" encoding="utf-8"?> <selector xmlns:android="http://schemas.android.com/apk/res/android" > <item android:state_checked="true" android:drawable="@drawable/icon_shopping_selected"/> <item android:state_checked="false" android:drawable="@drawable/icon_shopping_unselected"/> </selector>
icon_shopping_selected和icon_shopping_unselected是2张图片,下面是CheckBox在activity的布局文件中的设置,如下:
<CheckBox
android:id="@+id/cb"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginLeft="20dp"
android:checked="true"
android:button="@null"
android:drawableLeft="@drawable/cb_agree"
android:padding="20dp" />
之所以把CheckBox的设置单独列出来,是因为这里有个坑。想要自己定制CheckBox的图片,只需要给android:button赋值即可,但为赋值之后,没办法设置padding值,而一般来说,CheckBox给的图片可能会很小,需要设置一些padding。如果将selector选择器设置给button属性,再设置padding,就会造成下面的问题,
对应的xml设置如下:
<CheckBox
android:id="@+id/cb"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginLeft="20dp"
android:checked="true"
android:button="@drawable/cb_agree"
android:padding="20dp"
android:background="#00ff00"/>
造成这种情况的原因是,CheckBox是由两部分组成的,一部分是图片ImageView,另一部分是文字内容,想要解决这个问题,按照上面的设置方式即可。
Java代码很简单,如下:
public class StateListDrawableActivity extends Activity{
private TextView mSubmit;
private EditText mPhoneView;
private EditText mPassword;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_state_list_drawable);
mPhoneView = (EditText) findViewById(R.id.et_phone);
mPassword = (EditText) findViewById(R.id.et_password);
BaseTextWatcher watcher = new BaseTextWatcher();
watcher.addEditText(mPhoneView,mPassword);
mSubmit = (TextView) findViewById(R.id.tv_state_list_drawable);
}
class BaseTextWatcher implements TextWatcher{
private ArrayList<EditText> list = new ArrayList<EditText>();
public void addEditText(EditText...ets){
for(int i=0;i<ets.length;i++){
ets[i].addTextChangedListener(this);
list.add(ets[i]);
}
}
@Override
public void beforeTextChanged(CharSequence s, int start, int count,
int after) {
// TODO Auto-generated method stub
}
@Override
public void onTextChanged(CharSequence s, int start, int before,
int count) {
// TODO Auto-generated method stub
}
@Override
public void afterTextChanged(Editable s) {
for(EditText et:list){
String text = et.getText().toString().trim();
if(TextUtils.isEmpty(text)){
return;
}
}
mSubmit.setEnabled(true);
}
}
}
感谢 阅读,希望能帮助到大家,谢谢大家对本站的支持!
# Android
# Drawable
# Drawable使用方法
# Android setButtonDrawable()的兼容问题解决办法
# Android DrawableTextView图片文字居中显示实例
# Android中EditText的drawableRight属性设置点击事件
# 关于Android中drawable必知的一些规则
# Android 让自定义TextView的drawableLeft与文本一起居中
# 如何玩转Android矢量图VectorDrawable
# Android App开发中将View或Drawable转为Bitmap的方法
# Android编程中TextView宽度过大导致Drawable无法居中问题解决方法
# android中图形图像处理之drawable用法分析
# 选择器
# 输入框
# 就会
# 是因为
# 有个
# 那就
# 不太
# 是由
# 中有
# 只需
# 没办法
# 这两个
# 希望能
# 很简单
# 这种情况
# 如果说
# 要给
# 谢谢大家
# 恍然大悟
# 两部分
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?
Win10如何卸载预装Edge扩展_Win10卸载Edge扩展教程【方法】
原生JS实现图片轮播切换效果
Laravel如何实现数据导出到CSV文件_Laravel原生流式输出大数据量CSV【方案】
Laravel如何编写单元测试和功能测试?(PHPUnit示例)
如何快速生成凡客建站的专业级图册?
Laravel中的Facade(门面)到底是什么原理
Laravel怎么实现观察者模式Observer_Laravel模型事件监听与解耦开发【指南】
佐糖AI抠图怎样调整抠图精度_佐糖AI精度调整与放大细化操作【攻略】
文字头像制作网站推荐软件,醒图能自动配文字吗?
如何确保西部建站助手FTP传输的安全性?
Laravel如何使用Eloquent进行子查询
独立制作一个网站多少钱,建立网站需要花多少钱?
深圳网站制作培训,深圳哪些招聘网站比较好?
Laravel如何使用软删除(Soft Deletes)功能_Eloquent软删除与数据恢复方法
rsync同步时出现rsync: failed to set times on “xxxx”: Operation not permitted
Laravel Vite是做什么的_Laravel前端资源打包工具Vite配置与使用
Win11怎么查看显卡温度 Win11任务管理器查看GPU温度【技巧】
详解jQuery中的事件
iOS中将个别页面强制横屏其他页面竖屏
EditPlus中的正则表达式 实战(1)
Laravel如何实现全文搜索功能?(Scout和Algolia示例)
浅谈redis在项目中的应用
,在苏州找工作,上哪个网站比较好?
深圳防火门网站制作公司,深圳中天明防火门怎么编码?
Laravel如何从数据库删除数据_Laravel destroy和delete方法区别
Win11任务栏卡死怎么办 Windows11任务栏无反应解决方法【教程】
海南网站制作公司有哪些,海口网是哪家的?
如何在香港免费服务器上快速搭建网站?
如何快速选择适合个人网站的云服务器配置?
Win11搜索栏无法输入_解决Win11开始菜单搜索没反应问题【技巧】
千库网官网入口推荐 千库网设计创意平台入口
Linux网络带宽限制_tc配置实践解析【教程】
使用Dockerfile构建java web环境
佛山企业网站制作公司有哪些,沟通100网上服务官网?
非常酷的网站设计制作软件,酷培ai教育官方网站?
学生网站制作软件,一个12岁的学生写小说,应该去什么样的网站?
如何在 Telegram Web View(iOS)中防止键盘遮挡底部输入框
Laravel如何实现事件和监听器?(Event & Listener实战)
详解jQuery中基本的动画方法
javascript日期怎么处理_如何格式化输出
移动端脚本框架Hammer.js
网站制作大概要多少钱一个,做一个平台网站大概多少钱?
如何在云主机上快速搭建多站点网站?
Laravel如何升级到最新版本?(升级指南和步骤)
在线ppt制作网站有哪些软件,如何把网页的内容做成ppt?
中国移动官方网站首页入口 中国移动官网网页登录
EditPlus中的正则表达式实战(6)
JavaScript中的标签模板是什么_它如何扩展字符串功能
利用python获取某年中每个月的第一天和最后一天

