线性布局,是日常开发中最常用的布局,具备水平方向和垂直方式。本来是想几个布局一起讲解的,后来发现篇幅太长了,所以就单独介绍每一个布局的使用,并且伴随源码一起分析,这篇文章将会非常详细介绍LinearLayout,让我们充分了解LinearLayout的各种奇特的属性和功能,还有一些是我们平常很少使用的,充分了解后,我们可能会发现新大陆哦。
布局属性
- android:orientation:垂直(vertical)和水平(horizontal),默认horizontal。
- android:gravity:内部控件对齐方式,常用属性值有center、center_vertical、center_horizontal、top、bottom、left、right等。
- android:baselineAligned:Boolean类型属性,如果等于true,那么就会开启以baseline作为对齐的方式。
- android:baselineAlignedChildIndex:这个是和android:baselineAligned配合使用,是以第一个子控件作为基准,但是这个子控件必须是TextView才生效。
- android:weightSum:这个是配合子控件使用,默认是-1,如果这里设置大于0的值,那么子控件的layout_weight就是用来平分weightSum,如果是默认-1,weightSum就等于子控件layout_weight的总和,通常是不设置。
- android:measureWithLargestChild:这个值是Boolean类型,如果是ture,所有的子控件都是设置为子控件中最大的控件的大小。
- android:divider:使用Drawable设置分割线的样式。
- android:showDividers:设置分割线显示的位置,属性值有none、beginning、middle、end,(这里缺少说明)
- android:dividerPadding:分割线两边的padding。
Child View 布局属性
- android:layout_gravity:子控件在LinearLayout中的位置控制。
- android:layout_weight:权重,用于设定子控件占据LinearLayout的比例,这个属性非常实用,比如3个控件需要平局父控件,那么三个子控件都设置为1即可。如果希望其他子控件正常显示,其中一个控件占据父控件剩余的空间,那么只设置这个控件为1即可。
- android:layout_height:可以设置match_parent、wrap_content,或者直接写具体的大小dp。
- android:layout_width:可以设置match_parent、wrap_content,或者直接写具体的大小dp。
使用
基准线对齐
Boolean类型属性,如果等于true,那么就会开启以baseline作为对齐的方式,默认是true。如果设置了android:gravity="center_vertical"
,这个属性就失效了。
android:measureWithLargestChild
这个值是Boolean类型,如果是ture,该属性为true的时候, 所有带权重的子元素都会具有最大子元素的尺寸,但是使用是需要注意,父控件必须设置android:layout_width="wrap_content"
。
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical">
<TextView android:layout_margin="5dp"
android:textColor="@android:color/black"
android:text="android:measureWithLargestChild=true"
android:layout_width="wrap_content"
android:layout_height="wrap_content"/>
<LinearLayout android:layout_margin="5dp"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="horizontal"
android:measureWithLargestChild="true">
<TextView android:textSize="30sp"
android:background="@android:color/holo_red_dark"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="1"
android:text="AB"/>
<TextView android:textSize="30sp"
android:background="@android:color/holo_green_dark"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="1"
android:text="ABCDEF"/>
<TextView android:textSize="30sp"
android:background="@android:color/holo_blue_dark"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="1"
android:text="A "/>
</LinearLayout>
<TextView android:layout_margin="5dp"
android:textColor="@android:color/black"
android:text="android:measureWithLargestChild=false"
android:layout_width="wrap_content"
android:layout_height="wrap_content"/>
<LinearLayout
android:layout_margin="5dp"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="horizontal">
<TextView android:textSize="30sp"
android:background="@android:color/holo_red_dark"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="1"
android:text="AB"/>
<TextView android:textSize="30sp"
android:background="@android:color/holo_green_dark"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="1"
android:text="ABCDEF"/>
<TextView android:textSize="30sp"
android:background="@android:color/holo_blue_dark"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="1"
android:text="A "/>
</LinearLayout>
</LinearLayout>
分割线
分割线需要用drawable编写,当布局是水平方向,<size android:width
起作用,决定分割线的宽度,android:dividerPadding
作用于上下的padding。当布局是垂直布局,<size android:height
起作用,决定分割线的宽度,android:dividerPadding
作用于左右的padding。
linear_divider.xml
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android">
<size android:width="20dp" android:height="40dp"/>
<solid android:color="@color/colorPrimary"/>
</shape>
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical">
<LinearLayout android:layout_margin="5dp"
android:showDividers="middle"
android:background="@android:color/holo_red_dark"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal"
android:divider="@drawable/linear_divider"
android:dividerPadding="5dp">
<TextView android:textSize="30sp"
android:layout_width="wrap_content"
android:layout_height="50dp"
android:text="AB"/>
<TextView android:textSize="30sp"
android:layout_width="wrap_content"
android:layout_height="50dp"
android:text="ABCDEF"/>
<TextView android:textSize="30sp"
android:layout_width="wrap_content"
android:layout_height="50dp"
android:text="A "/>
</LinearLayout>
<LinearLayout android:layout_margin="5dp"
android:showDividers="middle"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical"
android:background="@android:color/holo_red_dark"
android:divider="@drawable/linear_divider"
android:dividerPadding="50dp">
<TextView android:textSize="30sp"
android:layout_width="wrap_content"
android:layout_height="50dp"
android:text="AB"/>
<TextView android:textSize="30sp"
android:layout_width="wrap_content"
android:layout_height="50dp"
android:text="ABCDEF"/>
<TextView android:textSize="30sp"
android:layout_width="wrap_content"
android:layout_height="50dp"
android:text="A "/>
</LinearLayout>
</LinearLayout>
android:weight
如果设置该属性,那么和layout_height或layout_width就会有冲突,建议设置为0dp,当然不设置为0也有其意义,但是计算方式比较复杂,并不建议这么设置,也不好理解。
第1行:用于设定子控件占据LinearLayout的比例,这个属性非常实用,比如3个控件需要平局父控件,那么三个子控件都设置为1即可。
第2行:如果希望其他子控件正常显示,其中一个控件占据父控件剩余的空间,那么只设置这个控件为1即可。
第3行:android:weightSum
是指所有带有android:weight
的总和等于weightSum值,如果weightSum设置10,其中一个控件设置为5,那么代表这个控件占据剩余空间的1/2。
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical">
<LinearLayout android:layout_margin="5dp"
android:showDividers="middle"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal">
<TextView android:textSize="30sp"
android:layout_weight="1"
android:background="@android:color/holo_red_dark"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:text="AB"/>
<TextView android:textSize="30sp"
android:layout_weight="1"
android:background="@android:color/holo_green_dark"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:text="ABCDEF"/>
<TextView android:textSize="30sp"
android:background="@android:color/holo_blue_dark"
android:layout_weight="1"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:text="A "/>
</LinearLayout>
<LinearLayout android:layout_margin="5dp"
android:showDividers="middle"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal">
<TextView android:textSize="30sp"
android:layout_weight="1"
android:background="@android:color/holo_red_dark"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="AB"/>
<TextView android:textSize="30sp"
android:background="@android:color/holo_green_dark"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="ABCDEF"/>
<TextView android:textSize="30sp"
android:background="@android:color/holo_blue_dark"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="A "/>
</LinearLayout>
<LinearLayout android:layout_margin="5dp"
android:weightSum="10"
android:background="@android:color/holo_orange_light"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal">
<TextView android:textSize="30sp"
android:background="@android:color/holo_red_dark"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="AB"/>
<TextView android:textSize="30sp"
android:background="@android:color/holo_green_dark"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="AB"/>
<TextView android:textSize="30sp"
android:layout_weight="5"
android:background="@android:color/holo_blue_dark"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:text="AB"/>
</LinearLayout>
</LinearLayout>