※※※摘自http://www.cnblogs.com/salam/archive/2010/10/20/1856793.html

LinearLayout是线性布局控件,它包含的子控件将以横向或竖向的方式排列,按照相对位置来排列所有的widgets或者其他的containers,超过边界时,某些控件将缺失或消失。因此一个垂直列表的每一行只会有一个widget或者是container,而不管他们有多宽,而一个水平列表将会只有一个行高(高度为最高子控件的高度加上边框高度)。LinearLayout保持其所包含的widget或者是container之间的间隔以及互相对齐(相对一个控件的右对齐、中间对齐或者左对齐)。

API说明

xml属性

android:baselineAligned:是否允许用户调整它内容的基线。

android:baselineAlignedChildIndex:当一个线性布局与另一个布局是按基线对齐的一部分,它可以指定其内容的基线对齐方式。

android:gravity:指定如何在该对象中放置此对象的内容(x/y坐标值)。

android:orientation:设置它内容的对其方向(横向/竖向)。

最重要是我们可以利用为布局里的组件分配权值,让其填充剩余空白

LinearLayout还支持为其包含的widget或者是container指定填充权值。好处就是允许其包含的widget或者是container可以填充屏幕上的剩余空间。这也避免了在一个大屏幕中,一串widgets或者是containers挤成一堆的情况,而是允许他们放大填充空白。剩余的空间会按这些widgets或者是containers指定的权值比例分配屏幕。默认的 weight 值为0,表示按照widgets或者是containers实际大小来显示,若高于0的值,则将Container剩余可用空间分割,分割大小具体取决于每一个widget或者是container的layout_weight及该权值在所有widgets或者是containers中的比例。例如,如果有三个文本框,其中两个指定的权值为1,那么,这两个文本框将等比例地放大,并填满剩余的空间,而第三个文本框不会放大,按实际大小来显示。如果前两个文本框的取值一个为2,一个为1,显示第三个文本框后剩余的空间的2/3给权值为2的,1/3大小给权值为1的。也就是权值越大,重要度越大。

如果LinearLayout包含子LinearLayout,子LinearLayout之间的权值越大的,重要度则越小。如果有LinearLayout A包含LinearLayout C,D,C的权值为2,D的权值为1,则屏幕的2/3空间分给权值为1的D,1/3分给权值为2的C。在LinearLayout嵌套的情况下,子LinearLayout必须要设置权值,否则默认的情况是未设置权值的子LinearLayout占据整个屏幕。

最新文章

  1. Spring任务调度之Timer
  2. php : 基础(5)
  3. SpringHttpInvoker解析3-客户端实现
  4. php上传常见文件类型对应的$_FILES["file"]["type"](转)
  5. 开源CMS赏析
  6. Extjs 3.0 htmleditor实现插入图片功能
  7. Runtime —— 从应用场景说起
  8. jQuery源码学习:Sizzle
  9. solr5.5索引mysql数据(新手总结)
  10. 华为机试题【10】-求数字基root
  11. 软件工程作业-(third)
  12. MUI 实用教程
  13. Java多线程、线程池和线程安全整理
  14. IIS 错误:处理程序“PageHandlerFactory-Integrated”在其模块列表中有一个错误模块“ManagedPipelineHandler”
  15. datatables出现横向滚动条
  16. 和我一起打造个简单搜索之SpringDataElasticSearch关键词高亮
  17. shell脚本中的逻辑判断 文件目录属性判断 if特殊用法 case判断
  18. ubuntu-12.04.4-alternate-i386安装
  19. wpf XAML 设计器异常,提示NullReferenceException 未将对象引用设置到对象例
  20. 取消word中所有超链接

热门文章

  1. C++中int转为char 以及int 转为string和string 转int和字符串的split
  2. <关于并发框架>Java原生线程池原理及Guava与之的补充
  3. [Ctsc2000]冰原探险
  4. mysql官网下载链接——绿色版&安装版
  5. web前端调优
  6. python处理数据的风骚操作[pandas 之 groupby&agg]
  7. Ubuntu 16 下面的文件比较工具 Meld
  8. scala学习手记40 - 使用case类
  9. HTML5 canvas之基础篇(一)
  10. Strust2遇到的问题