Android 中API之Drawable資源詳解及簡(jiǎn)單實(shí)例
Android 中API之Drawable資源
1、最常用的StateListDrawable
說(shuō)StateListDrawable,很多Android猿可能感到不太熟悉,不過(guò)如果說(shuō)selector選擇器,肯定都會(huì)恍然大悟,不錯(cuò),這兩個(gè)東西就是同一個(gè)~~
它的用途之廣,每個(gè)app必用,下面就寫一個(gè)demo,來(lái)簡(jiǎn)要說(shuō)一下用法。
比如一個(gè)登陸界面,它的輸入框在獲取焦點(diǎn)時(shí)需要更改背景,登陸按鈕在輸入框中有內(nèi)容時(shí),則更改背景顏色,這時(shí)候用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的布局文件中的設(shè)置,如下:
<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的設(shè)置單獨(dú)列出來(lái),是因?yàn)檫@里有個(gè)坑。想要自己定制CheckBox的圖片,只需要給android:button賦值即可,但為賦值之后,沒(méi)辦法設(shè)置padding值,而一般來(lái)說(shuō),CheckBox給的圖片可能會(huì)很小,需要設(shè)置一些padding。如果將selector選擇器設(shè)置給button屬性,再設(shè)置padding,就會(huì)造成下面的問(wèn)題,
對(duì)應(yīng)的xml設(shè)置如下:
<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,另一部分是文字內(nèi)容,想要解決這個(gè)問(wèn)題,按照上面的設(shè)置方式即可。
Java代碼很簡(jiǎn)單,如下:
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); } } }
感謝 閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!
- Android setButtonDrawable()的兼容問(wèn)題解決辦法
- Android DrawableTextView圖片文字居中顯示實(shí)例
- Android中EditText的drawableRight屬性設(shè)置點(diǎn)擊事件
- 關(guān)于Android中drawable必知的一些規(guī)則
- Android 讓自定義TextView的drawableLeft與文本一起居中
- 如何玩轉(zhuǎn)Android矢量圖VectorDrawable
- Android App開(kāi)發(fā)中將View或Drawable轉(zhuǎn)為Bitmap的方法
- Android編程中TextView寬度過(guò)大導(dǎo)致Drawable無(wú)法居中問(wèn)題解決方法
- android中圖形圖像處理之drawable用法分析
相關(guān)文章
Android4.2中全屏或者取消標(biāo)題欄的方法總結(jié)
有的時(shí)候我們會(huì)看到,會(huì)先出現(xiàn)標(biāo)題欄,然后再消失,因?yàn)槲覀冎皇窃赼ctivity的oncreate方法中定義的,其他實(shí)現(xiàn)方法如下,感興趣的朋友可以了解下哈2013-06-06android 動(dòng)態(tài)控制狀態(tài)欄顯示和隱藏的方法實(shí)例
這篇文章主要介紹了2013-12-12Android使用vcard文件的方法簡(jiǎn)單實(shí)例
這篇文章主要介紹了Android使用vcard文件的方法,結(jié)合實(shí)例形式分析了Android針對(duì)vcard文件的打開(kāi)、讀取、寫入等相關(guān)操作技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2016-06-06Android文本視圖TextView實(shí)現(xiàn)聊天室效果
這篇文章主要介紹了Android文本視圖TextView實(shí)現(xiàn)聊天室效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-05-05Android WebView開(kāi)發(fā)之WebView與Native交互
隨著H5的廣泛使用,Android開(kāi)發(fā)過(guò)程中免不了會(huì)使用網(wǎng)頁(yè)來(lái)做展示,那么web與native之間的通信就顯得尤其重要了,其實(shí)際上是JavaScript與java之間的通信。本文將為大家詳細(xì)介紹二者是如何實(shí)現(xiàn)交互的,需要的朋友可以參考一下2021-12-12ScrollView與ListView合用(正確計(jì)算Listview的高度)的問(wèn)題解決
最近做項(xiàng)目中用到ScrollView和ListView一起使用的問(wèn)題,顯示的時(shí)候ListView不能完全正確的顯示,查了好多資料終于成功解決:2013-05-05Android判斷屏幕是橫屏或是豎屏的簡(jiǎn)單實(shí)現(xiàn)方法
這篇文章主要介紹了Android判斷屏幕是橫屏或是豎屏的簡(jiǎn)單實(shí)現(xiàn)方法,是Android應(yīng)用開(kāi)發(fā)中常用的功能,需要的朋友可以參考下2014-07-07Kotlin實(shí)現(xiàn)網(wǎng)絡(luò)圖片下載和保存功能
根據(jù)Android多線程和網(wǎng)絡(luò)編程的知識(shí)講解和案例使用,使用Handler消息機(jī)制實(shí)現(xiàn)網(wǎng)絡(luò)圖片下載,并且保存到模擬器中,強(qiáng)化對(duì)Android多線程編程、網(wǎng)絡(luò)編程和文件讀寫的理解,這篇文章主要介紹了Kotlin實(shí)現(xiàn)網(wǎng)絡(luò)圖片下載和保存功能,需要的朋友可以參考下2023-02-02