• Android onMeasure方法介绍


    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类的静态方法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. }
    19. else if (specMode == MeasureSpec.EXACTLY){

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

    23. return result;
    24. }

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

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

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

    39. result = specSize;
    40. }

    41. return result;
    42. }
  • 相关阅读:
    Temporal Action Detection with Structured Segment Networks (ssn)【转】
    ubuntu多版本cuda并存与切换【两个博客链接】
    TURN TAP: Temporal Unit Regression Network for Temporal Action Proposals(ICCV2017)
    CTAP: Complementary Temporal Action Proposal Generation (ECCV2018)
    很实用的HTML5+CSS3注册登录窗体切换效果
    基于js的网页换肤(不需要刷新整个页面,只需替换css文件)
    CSS重置 reset.css
    CSS3制作分步注册表单
    CSS3 3D立体柜子实现
    创建 CSS3 下拉菜单
  • 原文地址:https://www.cnblogs.com/xingmeng/p/2629873.html
Copyright © 2020-2023  润新知