您好,登錄后才能下訂單哦!
布局權(quán)重
線性布局支持給個別的子視圖設(shè)定權(quán)重,通過android:layout_weight屬性。就一個視圖在屏幕上占多大的空間而言,這個屬性給其設(shè)定了一個重要的值。一個大的權(quán)重值,允許它擴(kuò)大到填充父視圖中的任何剩余空間。子視圖可以指定一個權(quán)重值,然后視圖組剩余的其他的空間將會分配給其聲明權(quán)重的子視圖。默認(rèn)的權(quán)重是0;
未使用權(quán)重前效果圖:
倆個線性布局組件,代碼如下:
<?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="match_parent" android:orientation="vertical" > <ScrollView android:id="@+id/scrollView_content" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_gravity="center_horizontal" android:orientation="vertical" > <LinearLayout android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center_horizontal" android:orientation="vertical" > <ImageView android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center_horizontal" android:src="@drawable/message_selected" /> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center_horizontal" android:padding="10dp" android:text="測試文字\n測試文字\n測試文字\n測試文字\n測試文字\n測試文字\n測試文字\n測試文字\n測試文字\n " android:textSize="20sp" /> </LinearLayout> </ScrollView> <LinearLayout android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center_horizontal" android:orientation="horizontal" > <Button android:id="@+id/btn1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="嵌套Fragment" /> <Button android:id="@+id/btn2" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="外部Fragment" /> </LinearLayout> </LinearLayout>
仔細(xì)看下和想下就會發(fā)現(xiàn)這有個嚴(yán)重的問題,那就是“測試文字”行數(shù)多有,第二個LinearLayout布局被擠壓或擠出顯示區(qū),如下圖:
解決方法如下,在第一個LinearLayout 中加入權(quán)重android:layout_weight="1",代碼如下:
<?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="match_parent" android:orientation="vertical" > <ScrollView android:id="@+id/scrollView_content" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_gravity="center_horizontal" android:layout_weight="1" android:orientation="vertical" > <LinearLayout android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center_horizontal" android:orientation="vertical" > <ImageView android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center_horizontal" android:src="@drawable/message_selected" /> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center_horizontal" android:padding="10dp" android:text="測試文字\n測試文字\n測試文字\n測試文字\n測試文字\n測試文字\n測試文字\n測試文字\n測試文字\n " android:textSize="20sp" /> </LinearLayout> </ScrollView> <LinearLayout android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center_horizontal" android:orientation="horizontal" > <Button android:id="@+id/btn1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="嵌套Fragment" /> <Button android:id="@+id/btn2" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="外部Fragment" /> </LinearLayout> </LinearLayout>
效果如下圖
這樣就算文字內(nèi)容再長也不會把第二個LinearLayout 擠出顯示區(qū)或擠壓,權(quán)重布局原理:默認(rèn)權(quán)重Layout_weight=0,值小的優(yōu)先布局,故第二個LinearLayout優(yōu)先布局,然后是第一個LinearLayout(設(shè)置權(quán)重值1)填充的方式布滿剩余區(qū)域,原理如圖:圖
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。