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與文本一起居中
- 如何玩轉Android矢量圖VectorDrawable
- Android App開發(fā)中將View或Drawable轉為Bitmap的方法
- Android編程中TextView寬度過大導致Drawable無法居中問題解決方法
- android中圖形圖像處理之drawable用法分析
相關文章
android 動態(tài)控制狀態(tài)欄顯示和隱藏的方法實例
這篇文章主要介紹了2013-12-12
Android文本視圖TextView實現(xiàn)聊天室效果
這篇文章主要介紹了Android文本視圖TextView實現(xiàn)聊天室效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-05-05
Android WebView開發(fā)之WebView與Native交互
隨著H5的廣泛使用,Android開發(fā)過程中免不了會使用網(wǎng)頁來做展示,那么web與native之間的通信就顯得尤其重要了,其實際上是JavaScript與java之間的通信。本文將為大家詳細介紹二者是如何實現(xiàn)交互的,需要的朋友可以參考一下2021-12-12
ScrollView與ListView合用(正確計算Listview的高度)的問題解決
最近做項目中用到ScrollView和ListView一起使用的問題,顯示的時候ListView不能完全正確的顯示,查了好多資料終于成功解決:2013-05-05
Android判斷屏幕是橫屏或是豎屏的簡單實現(xiàn)方法
這篇文章主要介紹了Android判斷屏幕是橫屏或是豎屏的簡單實現(xiàn)方法,是Android應用開發(fā)中常用的功能,需要的朋友可以參考下2014-07-07
Kotlin實現(xiàn)網(wǎng)絡圖片下載和保存功能
根據(jù)Android多線程和網(wǎng)絡編程的知識講解和案例使用,使用Handler消息機制實現(xiàn)網(wǎng)絡圖片下載,并且保存到模擬器中,強化對Android多線程編程、網(wǎng)絡編程和文件讀寫的理解,這篇文章主要介紹了Kotlin實現(xiàn)網(wǎng)絡圖片下載和保存功能,需要的朋友可以參考下2023-02-02

