一、layout_gravity属性介绍
在Android中,ViewGroup是一个非常重要的容器,而内部的子View布局方式则是通过layout_gravity属性来控制的。layout_gravity属性决定了一个子View在父布局中的位置,可以让我们非常方便地实现各种复杂布局效果。
layout_gravity属性的可选值经常跟gravity属性混淆,其实它们之间是有所区别的。layout_gravity属性是针对子View的,而gravity属性则是针对父布局的。
二、常用属性值
1、left:让子View左对齐父布局
<LinearLayout android:layout_width="wrap_content" android:layout_height="wrap_content" android:orientation="vertical"> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Hello World!" android:layout_gravity="left" /> </LinearLayout>
2、right:让子View右对齐父布局
<LinearLayout android:layout_width="wrap_content" android:layout_height="wrap_content" android:orientation="vertical"> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Hello World!" android:layout_gravity="right" /> </LinearLayout>
3、top:让子View顶对齐父布局
<LinearLayout android:layout_width="wrap_content" android:layout_height="wrap_content" android:orientation="vertical"> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Hello World!" android:layout_gravity="top" /> </LinearLayout>
4、bottom:让子View底对齐父布局
<LinearLayout android:layout_width="wrap_content" android:layout_height="wrap_content" android:orientation="vertical"> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Hello World!" android:layout_gravity="bottom" /> </LinearLayout>
5、center_horizontal:让子View水平居中对齐父布局
<LinearLayout android:layout_width="wrap_content" android:layout_height="wrap_content" android:orientation="vertical"> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Hello World!" android:layout_gravity="center_horizontal" /> </LinearLayout>
6、center_vertical:让子View垂直居中对齐父布局
<LinearLayout android:layout_width="wrap_content" android:layout_height="wrap_content" android:orientation="vertical"> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Hello World!" android:layout_gravity="center_vertical" /> </LinearLayout>
三、更高级的用法
1、使用layout_gravity属性实现悬浮按钮效果
<FrameLayout android:layout_width="match_parent" android:layout_height="match_parent"> <ListView android:id="@+id/listview" android:layout_width="match_parent" android:layout_height="match_parent" android:layout_gravity="top" /> <ImageView android:id="@+id/floating_button" android:layout_width="wrap_content" android:layout_height="wrap_content" android:src="@drawable/ic_add_black_24dp" android:layout_gravity="bottom|end" android:padding="16dp" /> </FrameLayout>
2、使用layout_gravity属性实现居中对齐
<LinearLayout android:layout_width="match_parent" android:layout_height="match_parent" android:gravity="center"> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Hello World!" android:layout_gravity="center" /> </LinearLayout>
3、使用layout_gravity属性实现列表布局
<LinearLayout android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical"> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Title" android:textSize="20sp" android:padding="16dp" android:layout_gravity="center_horizontal" /> <View android:layout_width="match_parent" android:layout_height="1dp" android:background="#dddddd" android:layout_marginTop="8dp" android:layout_marginBottom="8dp" /> <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="horizontal" android:padding="16dp"> <ImageView android:layout_width="48dp" android:layout_height="48dp" android:src="@drawable/icon" android:layout_gravity="center_vertical" /> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Name" android:textSize="16sp" android:layout_gravity="center_vertical" android:layout_marginStart="16dp" /> </LinearLayout> </LinearLayout>
四、总结
使用layout_gravity属性可以轻松实现各种布局效果,掌握常用属性值以及一些高级用法,能够更好地优化布局效果,提高用户体验。