一、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屬性可以輕鬆實現各種布局效果,掌握常用屬性值以及一些高級用法,能夠更好地優化布局效果,提高用戶體驗。
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/295311.html
微信掃一掃
支付寶掃一掃