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