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

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

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

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

注释在代码里

  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无法显示,想要显示的话,要测量控件的大小

  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

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

  1. android自定义控件onMeasure方法

    1.自定义控件首先定义一个类继承View 有时,Android系统控件无法满足我们的需求,因此有必要自定义View.具体方法参见官方开发文档:http://developer.android.com/ ...

  2. Android自定义控件之基本原理

    前言: 在日常的Android开发中会经常和控件打交道,有时Android提供的控件未必能满足业务的需求,这个时候就需要我们实现自定义一些控件,今天先大致了解一下自定义控件的要求和实现的基本原理. 自 ...

  3. Android View 如何测量

    对于Android View的测量,我们一句话总结为:"给我位置和大小,我就知道您长到那里". 为了让大家更好的理解这个结论,我这里先讲一个日常生活中的小故事:不知道大家玩过&qu ...

  4. Android自定义控件总结

    自定义控件分类: 1.使用系统控件,实现自定义的效果 2.自己定义一个类继承View ,如textView.ImageView等,通过重写相关的方法来实现新的效果 3.自己定义一个类继承ViewGro ...

  5. Android自定义控件之基本原理(一)

    前言: 在日常的Android开发中会经常和控件打交道,有时Android提供的控件未必能满足业务的需求,这个时候就需要我们实现自定义一些控件,今天先大致了解一下自定义控件的要求和实现的基本原理. 自 ...

  6. Android自定义控件之自定义ViewGroup实现标签云

    前言: 前面几篇讲了自定义控件绘制原理Android自定义控件之基本原理(一),自定义属性Android自定义控件之自定义属性(二),自定义组合控件Android自定义控件之自定义组合控件(三),常言 ...

  7. Android自定义控件之自定义属性

    前言: 上篇介绍了自定义控件的基本要求以及绘制的基本原理,本篇文章主要介绍如何给自定义控件自定义一些属性.本篇文章将继续以上篇文章自定义圆形百分比为例进行讲解.有关原理知识请参考Android自定义控 ...

  8. Android自定义控件1

    概述 Android已经为我们提供了大量的View供我们使用,但是可能有时候这些组件不能满足我们的需求,这时候就需要自定义控件了.自定义控件对于初学者总是感觉是一种复杂的技术.因为里面涉及到的知识点会 ...

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

    概述 Android已经为我们提供了大量的View供我们使用,但是可能有时候这些组件不能满足我们的需求,这时候就需要自定义控件了.自定义控件对于初学者总是感觉是一种复杂的技术.因为里面涉及到的知识点会 ...

随机推荐

  1. dans le quartier

    culture /kyltyr/ 文化 une école [ekɔl] un cinéma un musée une église un théâtre  [teɑtr] un opéra  [ɔp ...

  2. JSP——页面三大部分(指令、脚本、动作组件)

    一.JSP简介: JSP(Java Server Pages,Java服务器端页面开发技术) JSP可以实现的技术都可以通过Servlet实现,他们本质上是一样的.但JSP设计的目的在于简化表示层的表 ...

  3. SQL Server配置管理WMI问题

       今天在打开数据库的时候,连接不上.一看错误就知道肯定是SQL Server的服务没开启,所以自然而然的去SQL Server配置管理中去打开,但是打开配置管理器的时候出现了下面的错误:      ...

  4. Could not load type System.ServiceModel.Activation.HttpModule解决办法

    等注册完成后网站就可以打开了. win2008下提示未能从程序集“System.ServiceModel, Version=3.0.0.0问题解决 在Windows Server 2008中的IIS服 ...

  5. 3_Guess Fingers

    3 // // ViewController.swift // Guess Fingers // // Created by ZC on 16/1/8. // Copyright © 2016年 ZC ...

  6. Android Animations动画使用详解

    一.动画类型 Android的animation由四种类型组成:alpha.scale.translate.rotate XML配置文件中 alpha 渐变透明度动画效果 scale 渐变尺寸伸缩动画 ...

  7. break 与continue的区别

    //break是结束整个循环体,continue是结束单次循环 比方说: while(x++ < 10){ if(x == 3) { break; } printf("%d\r\n&q ...

  8. 设计模式的C++实现 2.工厂模式

    工厂模式,实例化对象,用工厂方法取代new操作. 工厂模式基本与简单工厂模式差点儿相同,简单工厂中每次加入一个子类必须在工厂类中加入一个推断分支,这违背了开闭原则.而工厂模式的解决方法是将简单工厂中的 ...

  9. DMA(STM32)

     1.DMA:data memory access //实际的内存存储 注:DMA干活的时候是不须要CPU干涉的 2. ①内存(定义的变量)---外设(寄存器). ②内存---内存 ③外设---外 ...

  10. Codeforces 492B B. Vanya and Lanterns

    Codeforces  492B   B. Vanya and Lanterns 题目链接:http://acm.hust.edu.cn/vjudge/contest/view.action?cid= ...