作用 :

线性布局会将容器中的组件一个一个排列起来, LinearLayout可以控制组件横向或者纵向排列,

通过android:orientation属性控制;


不换行属性 :

线性布局中的组件不会自动换行, 如果组件一个一个排列到尽头之后, 剩下的组件就不会显示出来;


常用属性:

(1)基线对齐

xml属性 : android:baselineAligned;

设置方法 : setBaselineAligned(boolean
b)
;

作用 : 如果该属性为false, 就会阻止该布局管理器与其子元素的基线对齐;

2)设分隔条

xml属性 : android:divider;

设置方法 : setDividerDrawable(Drawable);

作用 :
设置垂直布局时两个按钮之间的分隔条;

(3)对齐方式(控制内部子元素)

xml属性 : android:gravity;

设置方法 : setGravity(int);

作用 : 设置布局管理器内组件(子元素)的对齐方式,

支持的属性 :

top, bottom,
left, right,center_vertical(垂直方向居中), center_horizontal(水平方向居中),fill_vertical(垂直方向拉伸), fill_horizontal(水平方向拉伸),center,
fill,clip_vertical, clip_horizontal可以同时指定多种对齐方式
: 如 left|center_vertical
左侧垂直居中;

(4)权重最小尺寸

xml属性 : android:measureWithLargestChild;

设置方法 : setMeasureWithLargestChildEnable(boolean
b)
;

作用
: 该属性为true的时候, 所有带权重的子元素都会具有最大子元素的最小尺寸;

(5)
排列方式

xml属性 : android:orientation;

设置方法 : setOrientation(int i);

作用
: 设置布局管理器内组件排列方式, 设置为horizontal(水平),vertical(垂直),
默认为垂直排列;


LinearLayout子元素控制

LinearLayout的子元素,
即LinearLayout中的组件, 都受到LinearLayout.LayoutParams控制,
因此LinearLayout包含的子元素可以执行下面的属性.

(1)对齐方式

xml属性 : android:layout_gravity;

作用
: 指定该元素在LinearLayout(父容器)的对齐方式, 也就是该组件本身的对齐方式, 注意要与android:gravity区分,
;

(2)所占权重

xml属性 : android:layout_weight;

作用
: 指定该元素在LinearLayout(父容器)中所占的权重, 例如都是1的情况下,
那个方向(LinearLayout的orientation方向)长度都是一样的;


控制子元素排列 与 在父元素中排列

控制本身元素属性与子元素属性
:

设备组件本身属性 带layout的属性是设置本身组件属性, 例如 android:layout_gravity设置的是本身的对其方式;

设置子元素属性 : 不带layout的属性是设置其所包含的子元素, 例如android:gravity 设置的是该容器子组件的对齐方式;

LayoutParams属性 :
所有的布局管理器都提供了相应的LayoutParams内部类, 这些内部类用于控制该布局本身, 如 对齐方式 layout_gravity, 所占权重
layout_weight, 这些属性用于设置本元素在父容器中的对齐方式;

容器属性 :
在android:后面没有layout的属性基本都是容器属性, android:gravity作用是指定指定本元素包含的子元素的对齐方式,
只有容器才支持这个属性;


常见用法

(1)
获取LinearLayout的宽高

a. 组件外无法获取组件宽高

下面的两种情况都是针对 View.getHeight() 和 View.getWidth()
方法
:

组件外无法获取 : 调用View.getHeight()View.getWidth()方法 是获取不到组件的宽度和高度的,
这两个方法返回的是0, Android的运行机制决定了无法在组件外部使用getHeight()和getWidth()方法获取宽度和高度;

组件内可以获取 : 在自定义的类中可以在View的类中通过调用这两个方法获取该View子类组件的宽和高;

b. 组件外部获取View对象宽高方法

外部获取 : 使用View.getMeasuredWidth()View.getMeasuredHeight()方法可以获取组件的宽和高,
在调用这个方法之前, 必须先调用View.measure()方法, 才可以,
否则也获取不到组件的宽高;

注意(特例) : 如果组件宽度或高度设置为 fill_parent, 使用
getMeasuredHeight() 等方法获取宽度和高度的时候, 并且组件中含有子元素时,
所获取的实际值是这些组件所占的最小宽度和最小高度.(没看懂)

View view = getLayoutInflater().inflate(R.layout.main, null);

LinearLayout layout = (LinearLayout) view.findViewById(R.id.linearlayout);

//调用测量方法, 调用了该方法之后才能通过getMeasuredHeight()等方法获取宽高

layout.measure(0, 0);

//获取宽度

int width = layout.getMeasuredWidth();

//获取高度

int height = layout.getMeasuredHeight();

c.
获取布局文件中组件的宽高

从LayoutParams中获取 :
调用View.getLayoutParams().width 和 View.getLayoutParams().height 获取宽高, 如果宽高被设定为
fill_parent, match_parent, warp_content 时, 这两个两边直接回返回 FILL_PARENT, MATCH_PARENT,
WARP_CONTENT常量值;

规律 : 从View.getLayoutParams()中获取 width, height
值, 在布局xml文件中设置的是什么, 获取的时候就得到的是什么;

(2)
在LinearLayout中添加分隔线

a.
使用ImageView添加(低版本3.0以下)

垂直布局 横向宽度填满 : 如果布局是vertical,
那么设置一个ImageView宽度fill_parent, 高度2dp, 设置一个背景色;

水平布局 纵向高度填满 : 如果布局时horizontal,
那么设置一个ImageView宽度2dp, 高度fill_parent, 设置一个背景色;

<ImageView

android:layout_width="fill_parent"

android:layout_height="2dp"

android:background="#F00"/>

b.
使用xml属性添加(3.0以上版本)

设置LinearLayout标签的
android:showDividers属性,
该属性有四个值 :

none :不显示分隔线;

beginning : 在LinearLayout开始处显示分隔线;

middle : 在LinearLayout中每两个组件之间显示分隔线;

end : 在LinearLayout结尾处显示分隔线;

设置android:divider属性, 这个属性的值是一个Drawable的id;

c.
使用代码添加(3.0以上版本)

设置显示分隔线样式 :
linearLayout.setShowDividers(), 设置android:showDividers属性;

设置分隔线图片 :
linearLayout.setDividerDrawable(), 设置android:divider属性;

最新文章

  1. .NET程序的简单编译原理
  2. Python3 windows如何安装模块 setuptools
  3. linux程序调试命令strace
  4. ios waxpatch lua语法
  5. 2016.8.22 JavaScript入门之三
  6. Mybaits 之根据集合查询和逗号分隔的子查询
  7. 转 awk 使用方法
  8. python堆栈实现
  9. Spring4 IOC详解
  10. LaTeX入门
  11. NAT技术与代理服务器
  12. nodejs,mongodb不同时区问题
  13. JavaScript之对原生JavaScript对象及其原型扩展初探
  14. 安装google 框架
  15. bootstrap手风琴折叠
  16. 记录一次BUG修复-Entity Framwork SaveChanges()失效
  17. Ubuntu修改apt-get源
  18. 怎样删除windows.old文件
  19. 关于spark standalone模式下的executor问题
  20. kafka配置监控和消费者测试

热门文章

  1. Navicat连接腾讯云实例MySQL
  2. linux中部署django项目
  3. VS2017 Nuget服务器搭建,简易版
  4. Java笔记(第七篇 JDBC操作数据库)
  5. formData+ajax文件上传
  6. 记一次 解决 vue 兼容ie11 的问题
  7. 牛客练习赛3 绝对半径 ——k尺取法
  8. 状压dp做题笔记
  9. 报错Too many connections
  10. jquery里把数组转换成json的方法