onMeasure方法简介

onMeasure方法在Android中用于控制布局时确定控件的尺寸。它接收widthMeasureSpec和heightMeasureSpec作为参数,分别代表宽度和高度的测量规格。MeasureSpec包含模式(UNSPECIFIED, EXACTLY, AT_MOST)和大小,影响子视图如何确定其尺寸。在onMeasure中,通常需要根据MeasureSpec的模式计算并设置视图的尺寸,通过调用setMeasuredDimension方法。此过程涉及检查MeasureSpec的模式,如AT_MOST表示最大尺寸,EXACTLY表示精确尺寸,UNSPECIFIED则无限制。" 8690268,1396345,Android NDK开发与Linux动态库.so调用指南,"['Android开发', 'NDK', 'C++', 'JNI', 'Linux动态库']
摘要由CSDN通过智能技术生成

onMeasure方法在控件的父元素正要放置它的子控件时调用.它会问一个问题,“你想要用多大地方啊?”,然后传入两个参数——widthMeasureSpec和heightMeasureSpec.

  它们指明控件可获得的空间以及关于这个空间描述的元数据.
  比返回一个结果要好的方法是你传递View的高度和宽度到setMeasuredDimension方法里.

  接下来的代码片段给出了如何重写onMeasure.注意,调用的本地空方法是来计算高度和宽度的.它们会译解widthHeightSpec和heightMeasureSpec值,并计算出合适的高度和宽度值.

java代码:

  1. @Override
  2. protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {

  3. int measuredHeight = measureHeight(heightMeasureSpec);
  4. int measuredWidth = measureWidth(widthMeasureSpec);
  5. setMeasuredDimension(measuredHeight, measuredWidth);
  6. }

  7. private int measureHeight(int measureSpec) {


  8. // Return measured widget height.
  9. }

  10. private int measureWidth(int measureSpec) {

  11. // Return measured widget width.
  12. }
复制代码


       边界参数——widthMeasureSpec和heightMeasureSpec ,效率的原因以整数的方式传入。

      

     MeasureSpec封装了父布局传递给子布局的布局要求,每个MeasureSpec代表了一组宽度和高度的要求。一个MeasureSpec由大小和模式组成。

    它有三种模式:

                    UNSPECIFIED(未指定),     父元素不对自元素施加任何束缚,子元素可以得到任意想要的大小;

                    EXACTLY(完全),父元素决定自元素的确切大小,子元素将被限定在给定的边界里而忽略它本身大小;

                    AT_MOST(至多),子元素至多达到指定大小的值。

   它常用的三个函数:

    1.static int getMode(int measureSpec):根据提供的测量值(格式)提取模式(上述三个模式之一)

  2.static int getSize(int measureSpec):根据提供的测量值(格式)提取大小值(这个大小也就是我们通常所说的大小)

  3.static int makeMeasureSpec(int size,int mode):根据提供的大小值和模式创建一个测量值(格式)

     这个类的使用呢,通常在view组件的onMeasure方法里面调用但也有少数例外

 

       在它们使用之前,首先要做的是使用MeasureSpec类的静态方法getMode和getSize来译解,如下面的片段所示:

java代码:

  1. int specMode = MeasureSpec.getMode(measureSpec);
  2. int specSize = MeasureSpec.getSize(measureSpec);
复制代码


       依据specMode的值,如果是AT_MOST,specSize 代表的是最大可获得的空间;如果是EXACTLY,specSize 代表的是精确的尺寸;如果是UNSPECIFIED,对于控件尺寸来说,没有任何参考意义。
  当以EXACT方式标记测量尺寸,父元素会坚持在一个指定的精确尺寸区域放置View。在父元素问子元素要多大空间时,AT_MOST指示者会说给我最大的范围。在很多情况下,你得到的值都是相同的。
  在两种情况下,你必须绝对的处理这些限制。在一些情况下,它可能会返回超出这些限制的尺寸,在这种情况下,你可以让父元素选择如何对待超出的View,使用裁剪还是滚动等技术。

  接下来的框架代码给出了处理View测量的典型实现:

java代码:

  1. @Override

  2. protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {

  3. int measuredHeight = measureHeight(heightMeasureSpec);

  4. int measuredWidth = measureWidth(widthMeasureSpec);

  5. setMeasuredDimension(measuredHeight, measuredWidth);

  6. }

  7. private int measureHeight(int measureSpec) {

  8. int specMode = MeasureSpec.getMode(measureSpec);
  9. int specSize = MeasureSpec.getSize(measureSpec);

  10. // Default size if no limits are specified.

  11. int result = 500;
  12. if (specMode == MeasureSpec.AT_MOST){

  13. // Calculate the ideal size of your
  14. // control within this maximum size.
  15. // If your control fills the available
  16. // space return the outer bound.

  17. result = specSize;

  18. else if (specMode == MeasureSpec.EXACTLY){

  19. // If your control can fit within these bounds return that value.
  20. result = specSize;
  21. }

  22. return result;
  23. }

  24. private int measureWidth(int measureSpec) {
  25. int specMode = MeasureSpec.getMode(measureSpec);
  26. int specSize = MeasureSpec.getSize(measureSpec);

  27. // Default size if no limits are specified.
  28. int result = 500;
  29. if (specMode == MeasureSpec.AT_MOST){
  30. // Calculate the ideal size of your control
  31. // within this maximum size.
  32. // If your control fills the available space
  33. // return the outer bound.
  34. result = specSize;


  35. else if (specMode == MeasureSpec.EXACTLY){
  36. // If your control can fit within these bounds return that value.

  37. result = specSize;
  38. }

  39. return result;
  40. }
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值