zoukankan      html  css  js  c++  java
  • 谈谈layout-weight

    在进行开发工程中,由于业务的需要我们经常会使用到权重的应用,但是大家有没有知道权重是怎么进行计算的,下面我们看下两个布局的表现形式:

    此时的代码是这样的:

    <Button
        android:background="#fff000"
        android:layout_weight="1"
        android:layout_width="match_parent"
        android:layout_height="match_parent"/>
    
    <Button
        android:layout_weight="2"
        android:layout_width="match_parent"
        android:layout_height="match_parent"/>
    

    然而当我们将android:layout_height="match_parent"换成android:layout_height="wrap_content",页面的布局将会发出变化:

    两者的结果正好相反,大家有么知道为什么呢?其中weight在进行权重的划分时候,经过两次计算:
    第一次是 总高度-两个按钮占有的高度=剩下的高度
    第二次是 剩下的高度乘以权重之比+加上按钮本身的高度=最后显示的高度

    按照上述例子进行说明:
    总高度是L match_parent 时候 高度是L wrap_content 时候 高度相对于是0

    第一种情况进行计算:剩下的高度=L-(L+L)=-L ;最后的高度:-L/3+L = 2L/3 ,-2L/3+L = 1L/3
    第二种情况进行计算:剩下的高度=L-(0+0)=L ;最后的高度:1L/3+0 = L/3 ,L2/3+L = 2L/3

    这样大家就知道为什么了吧 。

  • 相关阅读:
    微信支付接口之心酸
    分页之辛酸史
    谈谈面试经历
    Linux(Ubuntu 14.0)
    Android(Xamarin)之旅(五)
    css:befor :after 伪元素的妙用
    js设计模式-代理模式
    html页面元素命名参考
    html5-meta标签和搜索引擎
    iframe框架加载完成后执行函数
  • 原文地址:https://www.cnblogs.com/zpfwin/p/8545365.html
Copyright © 2011-2022 走看看