欢迎访问移动开发之家(rcyd.net),关注移动开发教程。移动开发之家  移动开发问答|  每日更新
页面位置 : > > > 内容正文

AndroidonMeasure与onDraw及自定义属性使用示例,

来源: 开发者 投稿于  被查看 26102 次 评论:48

AndroidonMeasure与onDraw及自定义属性使用示例,


目录
  • 1.自定义View简介
  • 2.构造方法
  • 3.onMeasure()
  • 4.onDraw()
  • 5.onTouch()
  • 6.自定义属性
    • 6.1在res下的values下面新建attrs.xml
    • 6.2在布局中使用
    • 6.3在自定义View中获取属性

1.自定义View简介

自定义view可以被认为是继承自View,系统没有的效果(ImageView,TextView,Button),extents View,extents ViewGrop

2.构造方法

继承View。View有四个构造方法,下面讲述四个构造方法什么时候调用:

第一个构造方法会在代码中new的时候调用

TextView textView = new TextView(this);

public TextView(Context context) {
        super(context);
    }

第二个构造方法在布局layout中使用(调用)

<com.zrc.view_java_demo_01.TextView android:layout_width="match_parent" android:layout_height="match_parent"/>

 public TextView(Context context, @Nullable AttributeSet attrs) {
        super(context, attrs);
    }

第三个构造方法在布局layout中使用(调用),但是会有style

调用 <com.zrc.view_java_demo_01.TextView style="@style/defualt"/>

<style name="defualt" > <item name="android:layout_width">wrap_content</item> <item name="android:layout_height">wrap_content</item> <item name="android:textColor">@color/colorAccent</item> </style>
 public TextView(Context context, @Nullable AttributeSet attrs, int defStyleAttr) {
        super(context, attrs, defStyleAttr);
    }

还有第四个构造方法,在用到时候,再做说明,在这里就不再展开。

3.onMeasure()

获取宽高的模式

int widthSize = MeasureSpec.getMode(widthMeasureSpec); //获取前两位
int heightSize = MeasureSpec.getMode(heightMeasureSpec);

获取宽高的值,指定控件的宽高

 int widthSize = MeasureSpec.getSize(widthMeasureSpec); //获取后面30位
 int heightSize = MeasureSpec.getSize(heightMeasureSpec);

MeasureSpec.AT_MOST:在布局中指定了wrap_content

MeasureSpec.EXACTLY: 在布局中特定的值 100dp match_parent fill_parent

MeasureSpec.UNSPECIFIED:尽可能的大,很少用到。listview,Scrollview 在测量子布局时候会用UNSPECIFIED

Scrollview+ListView会出现显示不全的现象?

widthMeasureSpec widthMeasureSpec : 会包含两个信息是一个32位的值,第一个信息是模式:2位 值:30位

4.onDraw()

 /**
     * 用于绘制
     * */
    @Override
    protected void onDraw(Canvas canvas) {
        super.onDraw(canvas);
        //画文本
        canvas.drawText();
        //画弧
        canvas.drawArc();
        //画圆
        canvas.drawCircle();
    }

5.onTouch()

    /**
     * 处理用户交互的,手指触摸等等(事件分发事件拦截)
     * */
    @Override
    public boolean onTouchEvent(MotionEvent event) {
        switch (event.getAction()){
            case MotionEvent.ACTION_DOWN:
                //手指按下
                Log.e("TAG","手指按下");
                break;
            case MotionEvent.ACTION_MOVE:
                //手指移动
                Log.e("TAG","手指移动");
                break;
            case MotionEvent.ACTION_UP:
                //手指抬起
                Log.e("TAG","手指抬起");
                break;
        }
        return super.onTouchEvent(event);
    }

6.自定义属性

自定义属性就是用来配置的,android:text = "Darren"是系统自定义属性

6.1在res下的values下面新建attrs.xml

<!-- name 属性名称
         format 格式: string 文字  color:颜色
                       dimension 宽高 字体大小 integer 数字
                       reference 资源(drawable)
          -->
        <attr name="text" format="string"/>
        <attr name="textColor" format="color"/>
        <attr name="textSize" format="dimension"/>
        <attr name="maxLength" format="integer"/>
        <attr name="background" format="reference|color"/>
        <!-- 枚举 -->
        <attr name="inputType">
            <enum name="number" value="1"/>
            <enum name="text" value="2"/>
            <enum name="password" value="3"/>
        </attr>
    </declare-styleable>

6.2在布局中使用

声明命名空间,然后在自己的自定义View中使用

xmlns:app="http://schemas.android.com/apk/res-auto"
<com.zrc.view_java_demo_01.TextView
        app:text="Darren"
        app:textColor="@color/colorAccent"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"/>

6.3在自定义View中获取属性

 // 获取自定义属性
 TypedArray array = context.obtainStyledAttributes(attrs, R.styleable.TextView);
 mText = array.getString(R.styleable.TextView_text);
 mTextColor = array.getColor(R.styleable.TextView_textColor,mTextColor);
  mTextSize = array.getDimensionPixelSize(R.styleable.TextView_textSize,mTextSize);
 // 回收
 array.recycle();

到此这篇关于Android onMeasure与onDraw及自定义属性使用示例的文章就介绍到这了,更多相关Android onMeasure内容请搜索3672js教程以前的文章或继续浏览下面的相关文章希望大家以后多多支持3672js教程!

您可能感兴趣的文章:
  • Android 重写ViewGroup 分析onMeasure()和onLayout()方法
  • Android View.onMeasure方法详解及实例
  • Android ListView 和ScroolView 出现onmeasure空指针的解决办法
  • Android 中View.onDraw(Canvas canvas)的使用方法
  • Android 通过onDraw实现在View中绘图操作的示例

用户评论