你的位置:首页 > 操作系统

[操作系统]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.

  该资源文件放在res/values目录下,内容如下:

<??><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.  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 ="http://schemas.android.com/apk/res/android"  ="http://schemas.android.com/tools"  ="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信息