android自定义控件 onMeasure() 测量尺寸

上次讲的自定义控件刷新点屏幕的任意地方都会刷新,而且在xml里自定义控件下面放一个textview的话,这个TextView是显示不出来的,不只这个,以前的几个自定义控件都是

为什么呢?今天来讲下onMeasure()

在自定义刷新控件的基础上重写onMeasure方法

根据上一篇自定义组件修改

注释在代码里

[html] view plaincopy

  1. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  2. android:orientation="vertical"
  3. android:layout_width="fill_parent"
  4. android:layout_height="wrap_content"
  5. >
  6. <xue.test.CusView3
  7. android:id="@+id/cusview3"
  8. android:layout_width="wrap_content"
  9. android:layout_height="wrap_content"
  10. >
  11. </xue.test.CusView3>
  12. <TextView
  13. android:layout_width="wrap_content"
  14. android:layout_height="wrap_content"
  15. android:text="我终于出现了" />
  16. </LinearLayout>

这里的TextView无法显示,想要显示的话,要测量控件的大小

[java] view plaincopy

  1. public class CusView3 extends View {
  2. private int color = 0;
  3. private String text = "点击我刷新";
  4. private Paint mPaint;
  5. private int mAscent;
  6. public CusView3(Context context, AttributeSet attrs) {
  7. super(context, attrs);
  8. mPaint = new Paint();
  9. mPaint.setStyle(Style.FILL);
  10. mPaint.setTextSize(35.0f);
  11. setPadding(20, 60, 0, 0); //设置padding
  12. }
  13. @Override
  14. protected void onDraw(Canvas canvas) {
  15. super.onDraw(canvas);
  16. if (color > 2) {
  17. color = 0;
  18. }
  19. switch (color) {
  20. case 0:
  21. mPaint.setColor(Color.GREEN);
  22. break;
  23. case 1:
  24. mPaint.setColor(Color.RED);
  25. break;
  26. case 2:
  27. mPaint.setColor(Color.BLUE);
  28. break;
  29. default:
  30. break;
  31. }
  32. canvas.drawText(text, getPaddingLeft(), getPaddingTop(), mPaint);
  33. }
  34. public void changeColor() {
  35. color++;
  36. }
  37. /**
  38. * 比onDraw先执行
  39. *
  40. * 一个MeasureSpec封装了父布局传递给子布局的布局要求,每个MeasureSpec代表了一组宽度和高度的要求。
  41. * 一个MeasureSpec由大小和模式组成
  42. * 它有三种模式:UNSPECIFIED(未指定),父元素部队自元素施加任何束缚,子元素可以得到任意想要的大小;
  43. *              EXACTLY(完全),父元素决定自元素的确切大小,子元素将被限定在给定的边界里而忽略它本身大小;
  44. *              AT_MOST(至多),子元素至多达到指定大小的值。
  45. *
  46. *   它常用的三个函数:   
  47. * 1.static int getMode(int measureSpec):根据提供的测量值(格式)提取模式(上述三个模式之一)
  48. * 2.static int getSize(int measureSpec):根据提供的测量值(格式)提取大小值(这个大小也就是我们通常所说的大小)
  49. * 3.static int makeMeasureSpec(int size,int mode):根据提供的大小值和模式创建一个测量值(格式)
  50. */
  51. @Override
  52. protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
  53. setMeasuredDimension(measureWidth(widthMeasureSpec), measureHeight(heightMeasureSpec));
  54. }
  55. private int measureWidth(int measureSpec) {
  56. int result = 0;
  57. int specMode = MeasureSpec.getMode(measureSpec);
  58. int specSize = MeasureSpec.getSize(measureSpec);
  59. if (specMode == MeasureSpec.EXACTLY) {
  60. // We were told how big to be
  61. result = specSize;
  62. } else {
  63. // Measure the text
  64. result = (int) mPaint.measureText(text) + getPaddingLeft() + getPaddingRight();
  65. if (specMode == MeasureSpec.AT_MOST) {
  66. // Respect AT_MOST value if that was what is called for by
  67. // measureSpec
  68. result = Math.min(result, specSize);// 60,480
  69. }
  70. }
  71. return result;
  72. }
  73. private int measureHeight(int measureSpec) {
  74. int result = 0;
  75. int specMode = MeasureSpec.getMode(measureSpec);
  76. int specSize = MeasureSpec.getSize(measureSpec);
  77. mAscent = (int) mPaint.ascent();
  78. if (specMode == MeasureSpec.EXACTLY) {
  79. // We were told how big to be
  80. result = specSize;
  81. } else {
  82. // Measure the text (beware: ascent is a negative number)
  83. result = (int) (-mAscent + mPaint.descent()) + getPaddingTop() + getPaddingBottom();
  84. if (specMode == MeasureSpec.AT_MOST) {
  85. // Respect AT_MOST value if that was what is called for by
  86. // measureSpec
  87. result = Math.min(result, specSize);
  88. }
  89. }
  90. return result;
  91. }
  92. }

效果图

代码 http://download.csdn.net/detail/ethan_xue/4178423

时间: 2024-10-18 10:23:09

android自定义控件 onMeasure() 测量尺寸的相关文章

Android自定义控件系列七:详解onMeasure()方法中如何测量一个控件尺寸(一)

转载请注明出处:http://blog.csdn.net/cyp331203/article/details/45027641 自定义view/viewgroup要重写的几个方法:onMeasure(),onLayout(),onDraw().(不熟悉的话可以查看专栏的前几篇文章:Android自定义控件系列二:自定义开关按钮(一)). 今天的任务就是详细研究一下protected void onMeasure(int widthMeasureSpec, int heightMeasureSpe

Android自定义控件系列八:详解onMeasure()(二)--利用onMeasure测量来实现图片拉伸永不变形,解决屏幕适配问题

上一篇文章详细讲解了一下onMeasure/measure方法在Android自定义控件时的原理和作用,参看博文:Android自定义控件系列七:详解onMeasure()方法中如何测量一个控件尺寸(一),今天就来真正实践一下,让这两个方法大显神威来帮我们搞定图片的屏幕适配问题. 请尊重原创劳动成果,转载请注明出处:http://blog.csdn.net/cyp331203/article/details/45038329,非允许请勿用于商业或盈利用途,违者必究. 使用ImageView会遇到

android自定义控件系列教程----视图的测量和布局

前面说点什么 当我们的一个视图界面绘制在android屏幕上面的时候其实都必须经过这几步measure. layout.draw这几个阶段,我们可以在view类里面看到这几个函数,然后里面有几个函数是onmeasure.onlayout.ondraw这几个函数是我们重写控件需要注意的这几个函数,下面我们就来讲讲这几个函数的功能和作用. onMeasure 正如这个函数的名子一样就是测量,所有的图示其实系统在绘制之前都不知道它到底有多大的,所以在很多时候我们在初始化界面oncreate的时候直接去

android 自定义控件---圆形方向盘

在做Android平台开发的时候,经常会遇到安卓原生控件无法满足需求的情况,安卓允许开发者去继承已经存在的控件或者实现你自己的控件. 先来看一下效果图 采用直接集成View类,重写onDrow方法绘制. 下面附上主要代码. 1 新建一个类CircleView 继承自View 1 package com.lennon.view; 2 3 import android.content.Context; 4 import android.graphics.Canvas; 5 import androi

Android自定义控件_View的绘制流程

每一个View/ViewGroup的显示都会经过三个过程:1.measure过程(测量View显示的大小,位置):2.layout过程(布局view的位置):3.draw过程(上一篇文章说到的通过canvas绘制到界面上显示,形成了各色的View) 下面分析一下各个过程:measure过程: 因为DecorView实际上是派生自FrameLayout的类,也即一个ViewGroup实例,该ViewGroup内部的ContentViews又是一个ViewGroup实例,依次内嵌View或ViewG

Android自定义控件系列二:自定义开关按钮(一)

这一次我们将会实现一个完整纯粹的自定义控件,而不是像之前的组合控件一样,拿系统的控件来实现:计划分为三部分:自定义控件的基本部分,自定义控件的触摸事件的处理和自定义控件的自定义属性: 下面就开始第一部分的编写,本次以一个定义的开关按钮为例,下面就开始吧: 先看看效果,一个点击开关按钮,实现点击切换开关状态: 为了能够讲解清晰,还是来一些基本的介绍. 首先需要明确的就是自定义控件还是继承自View这个类,Google在View这个类里面提供了相当多的方法供我们使用,使用这些方法我们可以实现相当多的

Android学习(十)—— Android自定义控件

Android自定义控件 安卓在使用中大多数使用已有的一些控件,用法比较简单,还有一部分是比较复杂的.用户自己想的控件,这些就需要进行自定义控件,今天就来简单说一下自定义控件. 1.绘制过程 创建一个类,继承View类 onMeasure()方法,测量计算视图的大小 onLayout()方法,设置视图在屏幕中显示的位置 onDraw()方法,绘制视图 以上就是自定义控件的绘制过程. 2.主要内容解释 measure操作 用于计算视图的大小,即视图的宽度和长度.在view中定义为final类型,要

Android自定义控件之滑动开关

自定义开关控件 Android自定义控件一般有三种方式 1.继承Android固有的控件,在Android原生控件的基础上,进行添加功能和逻辑. 2.继承ViewGroup,这类自定义控件是可以往自己的布局里面添加其他的子控件的. 3.继承View,这类自定义控件没有跟原生的控件有太多的相似的地方,也不需要在自己的肚子里添加其他的子控件. ToggleView自定义开关控件表征上没有跟Android原生的控件有什么相似的地方,而且在滑动的效果上也没有沿袭Android原生的地方,所以我们的自定义

一起来学习Android自定义控件1

概述 Android已经为我们提供了大量的View供我们使用,但是可能有时候这些组件不能满足我们的需求,这时候就需要自定义控件了.自定义控件对于初学者总是感觉是一种复杂的技术.因为里面涉及到的知识点会比较多.但是任何复杂的技术后面都是一点点简单知识的积累.通过对自定义控件的学习去可以更深入的掌握android的相关知识点,所以学习android自定义控件是很有必要的.记得以前学习总是想着去先理解很多知识点,然后再来学着自定义控件,但是每次写自定义控件的时候总是不知道从哪里下手啊.后来在学习的过程