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获取某年中每个月的第一天和最后一天