Android自定義控制元件系列之基礎篇
一、概述
在android開發中很多UI控制元件往往需要進行定製以滿足應用的需要或達到更加的效果,接下來就通過一個系列來介紹自定義控制元件,這裡更多是通過一些案例逐步去學習,本系列有一些典型的應用,掌握好了大家也可去創新開發出一些更好的UI,本次先通過簡單案例掌握一些基礎知識——如何在自定義控制元件中定義屬性.
二、實現定製一個簡單RadioButton
1、編寫型別MRadioButton 擴充套件RadioButton
public class MRadioButton extends RadioButton { … }
2、在MRadioButton類中,定製屬性
我們可以在控制元件中定義自己的屬性,可以定義多個屬性,但必須封裝提供set/get方法,也就是按規範寫。如mValue屬性,像下面程式碼
private String mValue; public String getmValue() { return mValue; } public void setmValue(String mValue) { this.mValue = mValue; }
3、為定製的屬性編寫attrs.xml資源
該資原始檔放在res/values目錄下,內容如下:
<?xml version="1.0" encoding="utf-8"?> <resources> <declare-styleable name="MRadioButton"> <! – 屬性名稱--> <attr name="value" format="string" /> </declare-styleable> </resources>
4、在MRadioButton類中定義建構函式,初始化屬性
public MRadioButton(Context context) { super(context); } public MRadioButton(Context context, AttributeSet attrs, int defStyle) { super(context, attrs, defStyle); } public MRadioButton(Context context, AttributeSet attrs) { super(context, attrs); //從attrs.xml中載入一個名字叫’ .MRadioButton’的declare-styleable資源 TypedArray tArray = context.obtainStyledAttributes(attrs, R.styleable.MRadioButton); //將屬性value與類中的屬性mValue關聯 this.mValue = tArray.getString(R.styleable.MRadioButton_value); //回收tArray物件 tArray.recycle(); }
5、在MainActivity中佈局檔案中新增MRadioButton元件,如下所示
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" xmlns:jereh="http://schemas.android.com/apk/res/com.jereh. view" android:layout_width="match_parent" android:layout_height="match_parent" tools:context="com.example.zdyview.MainActivity" > <com.itc.zidingyiview.MRadioButton android:layout_width="match_parent" android:layout_height="match_parent" android:id="@+id/mrb" jereh:value="hello" /> </RelativeLayout>
6、MainActivity程式碼:
public class MainActivity extends Activity { private MRadioButton rb; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); rb=(MRadioButton)super.findViewById(R.id.mrb); rb.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { Toast.makeText(MainActivity.this, rb.getmValue(),Toast.LENGTH_LONG).show(); } }); } }
當點選單選按鈕會顯示hello資訊
相關文章
- Android 自定義View基礎(一)AndroidView
- Android 自定義 View 之入門篇AndroidView
- android基礎學習-android篇day12-UI基礎控制元件(上)AndroidUI控制元件
- android基礎學習-android篇day13-UI基礎控制元件(下)AndroidUI控制元件
- 【Android】自定義樹形控制元件Android控制元件
- 【Android自定義View】繪圖之文字篇(三)AndroidView繪圖
- 【Android自定義View】繪圖之Path篇(二)AndroidView繪圖
- Flutter 之 自定義控制元件Flutter控制元件
- SpringBoot基礎系列之自定義配置源使用姿勢例項演示Spring Boot
- Android開發之自定義隨機驗證碼控制元件Android隨機控制元件
- js基礎之定義篇1.0JS
- Gradle系列之Android Gradle基礎配置GradleAndroid
- Android面試之Java 基礎篇Android面試Java
- Android自定義控制元件之區域性圖片放大鏡–BiggerViewAndroid控制元件View
- Android自定義控制元件之區域性圖片放大鏡--BiggerViewAndroid控制元件View
- 【朝花夕拾】Android自定義View篇之(十)TouchSlop及VelocityTrackerAndroidView
- Android View篇之自定義驗證碼輸入框AndroidView
- Android 控制元件架構與自定義控制元件詳解Android控制元件架構
- Android 自定義 View 之 LeavesLoadingAndroidView
- Android自定義View--翻書控制元件(一)AndroidView控制元件
- Android自定義控制元件(神級)+MediaRecoder錄音Android控制元件
- Android自定義多宮格解鎖控制元件Android控制元件
- Android自定義控制元件 帶文字提示的SeekBarAndroid控制元件
- 【朝花夕拾】Android自定義View篇之(八)多點觸控AndroidView
- 【朝花夕拾】Android自定義View篇之(四)自定義View的三種實現方式及自定義屬性詳解AndroidView
- android基礎學習-android篇day14-UI基礎控制元件綜合案例——點餐系統AndroidUI控制元件
- Android自定義View之捲尺AndroidView
- 【Android繪圖】繪圖之基礎篇(一)Android繪圖
- 前端【小程式】06-小程式基礎篇【自定義元件】前端元件
- Gradle For Android (一) 基礎定義與依賴管理篇GradleAndroid
- WebSocket系列之基礎知識入門篇Web
- 【朝花夕拾】Android自定義View篇之(十一)View的滑動,彈性滑動與自定義PagerViewAndroidView
- 自定義View之簽到足跡控制元件View控制元件
- Android 自定義 View 實戰之 PuzzleViewAndroidView
- Android自定義view之emoji鍵盤AndroidView
- Android自定義View之Canvas的使用AndroidViewCanvas
- 【朝花夕拾】Android自定義View篇之(五)Android事件分發及傳遞機制AndroidView事件
- 自定義控制元件ViewPager控制元件Viewpager
- 自定義Switch控制元件控制元件