Android实现自定义属性

一、自定义ViewGroup

1、onMeasure

决定内部View(子View)的宽度和高度,以及自己的宽度和高度

2、onLayout

决定子View放置的位置

3、onTouchEvent

定义动作

二、自定义属性

在实际的使用自定义Viewgroup时,经常会用到自定义控件的属性。

在res/values文件夹下建立attr.xml文件

1、书写xml文件,定义<attr>中的自定义属性,在<declare-stableable>中声明已经定义的属性

2、使用自定义的属性,在使用时添加命名空间,xmlns:ren="http://schemas.android.com/apk/res/bupt.ren.slidingmenu",然后即可以使用该属性

注:其中bupt.ren.slidingmenu是应用程序的包名,不是view所在的路径。

 

三、使用自定义的ViewGroup和自定义布局属性

1、自定义布局属性

attr.xml中定义如下:

<resources>
    <attr name="rightPadding" format="dimension"></attr>  //定义布局属性
    <declare-styleable name="SlidingMenu"> //定义布局,其中name后必须跟着view的类名
        <attr name="rightPadding"></attr>   //声明属性
    </declare-styleable>
</resources>

2、使用自定义布局属性

使用时,在main.xml定义如下:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    xmlns:ren="http://schemas.android.com/apk/res/bupt.ren.slidingmenu"
    android:layout_width="match_parent"
    android:layout_height="match_parent" >

    <bupt.ren.slidingmenu.view.SlidingMenu
        android:id="@+id/id_menu"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:background="@drawable/img_frame_background"
        ren:rightPadding="80dp" >
    </bupt.ren.slidingmenu.view.SlidingMenu>

</RelativeLayout>

3、自定义ViewGroup

在使用自定义属性时,需要覆写ViewGroup中有2个参数的构造方法,然后通过含有2个参数的构造方法,调用含有3个参数的构造方法。含有3个参数的构造方法负责接收自定义属性。

public SlidingMenu(Context context, AttributeSet attrs, int defStyle)
{
     super(context, attrs, defStyle);
     TypedArray a = context.getTheme().obtainStyledAttributes(attrs,
               R.styleable.SlidingMenu, defStyle, 0);

     int n = a.getIndexCount();
     for (int i = 0; i < n; i++)
     {
          int attr = a.getIndex(i);
          switch (attr)
          {
          case R.styleable.SlidingMenu_rightPadding:
               mMenuRightPadding = a.getDimensionPixelSize(attr,
                         (int) TypedValue.applyDimension(
                                   TypedValue.COMPLEX_UNIT_DIP, 50, context
                                             .getResources().getDisplayMetrics()));
               break;
          }
     } 
     a.recycle();  //需要对TypeArray进行回收
}

获取自定义的属性,其中关键的步骤就是获取mMenuRightPadding这个参数,达到控制控件布局的效果。

得到mMenuRightPadding这个参数后,就可以再ViewGroup中的onMeasure的方法中对子View进行布局的操控。

 

1.转载注明:http://www.cnblogs.com/yuanblog/p/4439186.html

2.本文为个人笔记、心得,可能引用其它文章,所以博客只在私自范围内供大家学习参考。

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。