[轉]android自定義控件 一個帶圖片和文字的按鈕


本文轉自:http://www.cnblogs.com/delia/archive/2012/03/09/2387934.html

 

今天和大家分享下組合控件的使用。很多時候android自定義控件並不能滿足需求,如何做呢?很多方法,可以自己繪制一個,可以通過繼承基礎控件來重寫某些環節,當然也可以將控件組合成一個新控件,這也是最方便的一個方法。今天就來介紹下如何使用組合控件,將通過兩個實例來介紹。第一個實現一個帶圖片和文字的按鈕,如圖所示:

整個過程可以分四步走。第一步,定義一個layout,實現按鈕內部的布局。代碼如下:

 
  1. <?xmlversion="1.0"encoding="utf-8"?> 
  2. <LinearLayoutxmlns:android="http://schemas.android.com/apk/res/android" 
  3.     android:orientation="horizontal" 
  4.     android:layout_width="fill_parent" 
  5.     android:layout_height="fill_parent" 
  6.     > 
  7. <ImageView 
  8.     android:layout_width="wrap_content" 
  9.     android:layout_height="wrap_content" 
  10.     android:id="@+id/iv" 
  11.     android:src="@drawable/confirm" 
  12.     android:paddingTop="5dip" 
  13.     android:paddingBottom="5dip" 
  14.     android:paddingLeft="40dip" 
  15.     android:layout_gravity="center_vertical" 
  16.     /> 
  17. <TextView 
  18.     android:layout_width="wrap_content" 
  19.     android:layout_height="wrap_content" 
  20.     android:text="確定" 
  21.     android:textColor="#000000" 
  22.     android:id="@+id/tv" 
  23.     android:layout_marginLeft="8dip" 
  24.     android:layout_gravity="center_vertical" 
  25.     /> 
  26. </LinearLayout> 

這個xml實現一個左圖右字的布局,接下來寫一個類繼承LinearLayout,導入剛剛的布局,並且設置需要的方法,從而使的能在代碼中控制這個自定義控件內容的顯示。代碼如下:

 
  1. package com.notice.ib; 
  2.  
  3. import android.content.Context; 
  4. import android.util.AttributeSet; 
  5. import android.view.LayoutInflater; 
  6. import android.widget.ImageView; 
  7. import android.widget.LinearLayout; 
  8. import android.widget.TextView; 
  9.  
  10. publicclass ImageBt extends LinearLayout { 
  11.  
  12.     private ImageView iv; 
  13.     private TextView  tv; 
  14.  
  15.     public ImageBt(Context context) { 
  16.         this(context, null); 
  17.     } 
  18.  
  19.     public ImageBt(Context context, AttributeSet attrs) { 
  20.         super(context, attrs); 
  21.         // 導入布局 
  22.         LayoutInflater.from(context).inflate(R.layout.custombt, this, true); 
  23.         iv = (ImageView) findViewById(R.id.iv); 
  24.         tv = (TextView) findViewById(R.id.tv); 
  25.  
  26.     } 
  27.  
  28.     /**
  29.      * 設置圖片資源
  30.      */ 
  31.     publicvoid setImageResource(int resId) { 
  32.         iv.setImageResource(resId); 
  33.     } 
  34.  
  35.     /**
  36.      * 設置顯示的文字
  37.      */ 
  38.     publicvoid setTextViewText(String text) { 
  39.         tv.setText(text); 
  40.     } 
  41.  

第三步,在需要使用這個自定義控件的layout中加入這控件,只需要在xml中加入即可。方法如下:

 
  1. <RelativeLayout 
  2.          android:orientation="horizontal" 
  3.          android:layout_width="fill_parent" 
  4.          android:layout_height="wrap_content" 
  5.          android:layout_gravity="bottom" 
  6.          > 
  7.          <com.notice.ib.ImageBt 
  8.              android:id="@+id/bt_confirm" 
  9.              android:layout_height="wrap_content" 
  10.              android:layout_width="wrap_content" 
  11.              android:layout_alignParentBottom="true" 
  12.              android:background="@drawable/btbg" 
  13.              android:clickable="true" 
  14.              android:focusable="true" 
  15.              /> 
  16.          <com.notice.ib.ImageBt 
  17.              android:id="@+id/bt_cancel" 
  18.              android:layout_toRightOf="@id/bt_confirm" 
  19.              android:layout_height="wrap_content" 
  20.              android:layout_width="wrap_content" 
  21.              android:layout_alignParentBottom="true" 
  22.              android:background="@drawable/btbg" 
  23.              android:clickable="true" 
  24.              android:focusable="true" 
  25.             /> 
  26.          </RelativeLayout> 

注意的是,控件標簽使用完整的類名即可。為了給按鈕一個點擊效果,你需要給他一個selector背景,這里就不說了。

最后一步,即在activity中設置該控件的內容。當然,在xml中也可以設置,但是只能設置一個,當我們需要兩次使用這樣的控件,並且顯示內容不同時就不行了。在activity中設置也非常簡單,我們在ImageBt這個類中已經寫好了相應的方法,簡單調用即可。代碼如下:

 
  1. publicclass MainActivity extends Activity { 
  2.  
  3.     private ImageBt ib1; 
  4.     private ImageBt ib2; 
  5.  
  6.     /** Called when the activity is first created. */ 
  7.     @Override 
  8.     publicvoid onCreate(Bundle savedInstanceState) { 
  9.         super.onCreate(savedInstanceState); 
  10.         setContentView(R.layout.login); 
  11.  
  12.         ib1 = (ImageBt) findViewById(R.id.bt_confirm); 
  13.         ib2 = (ImageBt) findViewById(R.id.bt_cancel); 
  14.  
  15.         ib1.setTextViewText("確定"); 
  16.         ib1.setImageResource(R.drawable.confirm); 
  17.         ib2.setTextViewText("取消"); 
  18.         ib2.setImageResource(R.drawable.cancel); 
  19.  
  20.         ib1.setOnClickListener(new OnClickListener() { 
  21.  
  22.             @Override 
  23.             publicvoid onClick(View v) { 
  24.                     //在這里可以實現點擊事件 
  25.             } 
  26.         }); 
  27.  
  28.     } 

這樣,一個帶文字和圖片的組合按鈕控件就完成了。這樣梳理一下,使用還是非常簡單的。組合控件能做的事還非常多,主要是在類似上例中的ImageBt類中寫好要使用的方法即可。

再來看一個組合控件,帶刪除按鈕的EidtText。即在用戶輸入后,會出現刪除按鈕,點擊即可取消用戶輸入。

定義方法和上例一樣。首先寫一個自定義控件的布局:

 
  1. <?xmlversion="1.0"encoding="utf-8"?> 
  2. <RelativeLayoutxmlns:android="http://schemas.android.com/apk/res/android" 
  3.     android:layout_width="fill_parent" 
  4.     android:layout_height="fill_parent" 
  5.     > 
  6. <EditText 
  7.     android:id="@+id/et" 
  8.     android:layout_width="fill_parent" 
  9.     android:layout_height="wrap_content" 
  10.     android:singleLine="true" 
  11.     /> 
  12. <ImageButton 
  13.     android:id="@+id/ib" 
  14.     android:visibility="gone" 
  15.     android:src="@drawable/menu_delete" 
  16.     android:layout_width="wrap_content" 
  17.     android:layout_height="wrap_content" 
  18.     android:background="#00000000" 
  19.     android:layout_alignRight="@+id/et"/> 
  20. </RelativeLayout> 

實現輸入框右側帶按鈕效果,注意將按鈕隱藏。然后寫一個EditCancel類,實現刪除用戶輸入功能。這里用到了TextWatch這個接口,監聽輸入框中的文字變化。使用也很簡單,實現他的三個方法即可。看代碼:

 
  1. package com.notice.ce; 
  2.  
  3. import android.content.Context; 
  4. import android.text.Editable; 
  5. import android.text.TextWatcher; 
  6. import android.util.AttributeSet; 
  7. import android.view.LayoutInflater; 
  8. import android.view.View; 
  9. import android.widget.EditText; 
  10. import android.widget.ImageButton; 
  11. import android.widget.LinearLayout; 
  12.  
  13. publicclass EditCancel extends LinearLayout implements EdtInterface { 
  14.  
  15.     ImageButton ib; 
  16.     EditText    et; 
  17.  
  18.     public EditCancel(Context context) { 
  19.         super(context); 
  20.  
  21.     } 
  22.  
  23.     public EditCancel(Context context, AttributeSet attrs) { 
  24.         super(context, attrs); 
  25.         LayoutInflater.from(context).inflate(R.layout.custom_editview, this, true); 
  26.         init(); 
  27.  
  28.     } 
  29.  
  30.     privatevoid init() { 
  31.         ib = (ImageButton) findViewById(R.id.ib); 
  32.         et = (EditText) findViewById(R.id.et); 
  33.         et.addTextChangedListener(tw);// 為輸入框綁定一個監聽文字變化的監聽器 
  34.         // 添加按鈕點擊事件 
  35.         ib.setOnClickListener(new OnClickListener() { 
  36.  
  37.             @Override 
  38.             publicvoid onClick(View v) { 
  39.                 hideBtn();// 隱藏按鈕 
  40.                 et.setText("");// 設置輸入框內容為空 
  41.             } 
  42.         }); 
  43.  
  44.     } 
  45.  
  46.     // 當輸入框狀態改變時,會調用相應的方法 
  47.     TextWatcher tw = new TextWatcher() { 
  48.  
  49.                        @Override 
  50.                        publicvoid onTextChanged(CharSequence s, int start, int before, int count) { 
  51.                            // TODO Auto-generated method stub 
  52.  
  53.                        } 
  54.  
  55.                        @Override 
  56.                        publicvoid beforeTextChanged(CharSequence s, int start, int count, int after) { 
  57.                            // TODO Auto-generated method stub 
  58.  
  59.                        } 
  60.  
  61.                        // 在文字改變后調用 
  62.                        @Override 
  63.                        publicvoid afterTextChanged(Editable s) { 
  64.                            if (s.length() == 0) { 
  65.                                hideBtn();// 隱藏按鈕 
  66.                            } else
  67.                                showBtn();// 顯示按鈕 
  68.                            } 
  69.  
  70.                        } 
  71.  
  72.                    }; 
  73.  
  74.     @Override 
  75.     publicvoid hideBtn() { 
  76.         // 設置按鈕不可見 
  77.         if (ib.isShown()) ib.setVisibility(View.GONE); 
  78.  
  79.     } 
  80.  
  81.     @Override 
  82.     publicvoid showBtn() { 
  83.         // 設置按鈕可見 
  84.         if (!ib.isShown()) ib.setVisibility(View.VISIBLE); 
  85.  
  86.     } 
  87.  
  88.  
  89. interface EdtInterface { 
  90.  
  91.     publicvoid hideBtn(); 
  92.  
  93.     publicvoid showBtn(); 
  94.  

在TextWatch接口的afterTextChanged方法中對文字進行判斷,若長度為0,就隱藏按鈕,否則,顯示按鈕。

另外,實現ImageButton(即那個叉)的點擊事件,刪除輸入框中的內容,並隱藏按鈕。

后面兩步的實現就是加入到實際布局中,就不再寫出來了,和上例的步驟一樣的。最后顯示效果如圖:

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM