• 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.本文为个人笔记、心得,可能引用其它文章,所以博客只在私自范围内供大家学习参考。

  • 相关阅读:
    django_开发报错
    SpringBoot 前后端数据参数交互
    消息队列学习笔记(一)
    2021年调用工商二维码退款查询接口
    2021年调用工商二维码退款接口
    2021年调用工商二维码生成接口及回调接口demo
    调用工商生成二维码接口文档的坑
    使用hutool工具类转换时间
    微信模板消息推送
    pom文件 spring-boot-maven-plugin 爆红
  • 原文地址:https://www.cnblogs.com/yuanblog/p/4439186.html
Copyright © 2020-2023  润新知