你真的了解weight和weightSum嗎毙玻?

注意:本文原創(chuàng)豌蟋,轉(zhuǎn)載請注明出處。歡迎關(guān)注我的 簡書 桑滩。
** 本篇文章已授權(quán)微信公眾號 guolin_blog (郭霖)獨(dú)家發(fā)布*

看到本文的標(biāo)題梧疲,很多童鞋會一臉不屑的說,這有什么不了解的运准。不就是通過weight來給子布局按比例來分配空間嘛幌氮!好,這個(gè)答案也對也不對胁澳。 此時(shí)有人會疑惑了该互,為什么也對也不對? 我先來舉兩個(gè)最常見的例子:


<?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:gravity="center"
    android:orientation="horizontal">

    <Button
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_weight="1"
        android:text="A" />

    <Button
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_weight="1"
        android:text="B" />

</LinearLayout>


<?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:gravity="center"
    android:orientation="horizontal">

    <Button
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_weight="1"
        android:text="A" />

    <Button
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_weight="1"
        android:text="B" />

</LinearLayout>
Paste_Image.png

這兩個(gè)例子都能實(shí)現(xiàn)上圖的效果韭畸。那么問題來了宇智,這兩個(gè)方式有什么區(qū)別嗎? 眼尖的童鞋立馬會說:當(dāng)然有區(qū)別胰丁,一個(gè) android:layout_width 是0随橘, 另一個(gè)是 wrap_content。 那么這兩個(gè)有什么區(qū)別嗎锦庸? 為什么實(shí)現(xiàn)的效果是一樣的机蔗? 我還要問一句,真的是一樣嗎?

如果對這個(gè)問題有所疑惑蜒车,那么兔子哥將帶領(lǐng)大家來深入了解一下weight和weightSum讳嘱,并通過閱讀本篇文章幔嗦,做到知其然酿愧,并且知其所以然。

什么是weight和weightSum

某位偉人曾經(jīng)說過邀泉,要對某個(gè)知識點(diǎn)深入了解嬉挡,最好的切入點(diǎn)就是仔細(xì)閱讀知識點(diǎn)的定義。至于這位偉人是誰汇恤,什么庞钢?想不起來了?不用想了因谎,就是這篇博文的作者基括,兔子哥大人也! ~~~好了财岔,扯了這么多廢話风皿!我們還是先步入正題,先看看Google是怎么給 android:layout_weight 和 android:weightSum來定義的:

Layout Weight

LinearLayout also supports assigning a weight to individual children with the android:layout_weight
attribute. This attribute assigns an "importance" value to a view in terms of how much space it should occupy on the screen. A larger weight value allows it to expand to fill any remaining space in the parent view. Child views can specify a weight value, and then any remaining space in the view group is assigned to children in the proportion of their declared weight. Default weight is zero.

大體意思就是匠璧,android:layout_weight 這個(gè)屬性代表了一個(gè)“重要性”的值桐款,這個(gè)值的大小代表了該控件能在屏幕中占據(jù)多大的空間。這個(gè)值越大夷恍,表明該控件可以在父控件中占據(jù)較多的“剩余”空間魔眨。默認(rèn)的weight是0。
在這里酿雪,大家一定要注意“剩余”兩個(gè)字遏暴!大家往往容易忽略這一點(diǎn),導(dǎo)致出現(xiàn)了很多問題指黎。舉個(gè)例子:水平方向布局的父類有三個(gè)子類拓挥,父類總的寬度是100,子類的寬度分別是10袋励,20侥啤,30。 那么 android:layout_weight 這個(gè)屬性的目的茬故,就是瓜分剩余的 100 - 10 - 20 - 30盖灸,也就是剩余的40的使用權(quán)。沒錯磺芭! 就是android:layout_weight 這個(gè)屬性 僅僅決定 哪個(gè)子類能瓜分到更多的40的部分赁炎!

android:weightSum

Defines the maximum weight sum. If unspecified, the sum is computed by adding the layout_weight of all of the children.

這個(gè)就很好理解了,weightSum定義了weight 總和的最大值。如果 android:weightSum 沒有定義徙垫,那么默認(rèn)值就是通過各個(gè)子類的 layout_weight 累加得到讥裤。

工作原理

講了這么多,舉個(gè)例子來說明一下姻报。


<?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:gravity="center"
    android:orientation="horizontal"
    android:weightSum="1">

    <Button
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_weight="0.5"
        android:text="@string/hello_world" />

</LinearLayout>

效果如下圖:

Paste_Image.png

內(nèi)部的計(jì)算原理是:
Button的寬度 = Button 的 width + Button的weight ***** 父布局(LinearLayout)的寬度 / weightSum
上面的例子己英,也就是 Button的寬度 = 0 + 0.5 *** LinearLayout的寬度 / 1 = 0.5 * LinearLayout的寬度
也就是Button的寬度將占屏幕的一半。

Google官方例子

結(jié)合上面的知識再看一下 Google的例子 吴旋,可能體會的更加深刻损肛。

首先看實(shí)現(xiàn)的效果:

Paste_Image.png

如果讓大家自己來實(shí)現(xiàn)這個(gè)效果的話,相信很多童鞋會采用相對布局荣瑟,將send按鈕位于屏幕最下方治拿,然后上面的三個(gè)EditText從上往下依次排列。但是message的EditText要鋪滿剩余的空間笆焰,這個(gè)怎么實(shí)現(xiàn)劫谅? 有的童鞋會不屑的說了,這有什么難的嚷掠,把message的高度設(shè)置match_parent并且位于subject和send之間即可捏检。代碼如下:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:paddingLeft="16dp"
    android:paddingRight="16dp">

    <EditText
        android:id="@+id/et_to"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:hint="@string/to" />

    <EditText
        android:id="@+id/et_subject"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_below="@id/et_to"
        android:hint="@string/subject" />

    <EditText
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:layout_above="@+id/btn_send"
        android:layout_below="@id/et_subject"
        android:gravity="top"
        android:hint="@string/message" />

    <Button
        android:id="@+id/btn_send"
        android:layout_width="100dp"
        android:layout_height="wrap_content"
        android:layout_alignParentBottom="true"
        android:layout_alignParentRight="true"
        android:layout_gravity="right"
        android:text="@string/send" />
</RelativeLayout>


但是如果采用本文講解的weight可能會更加的簡單。這個(gè)布局關(guān)鍵的一點(diǎn)是message要鋪滿subject與send之間的區(qū)域叠国。問題是如何實(shí)現(xiàn)鋪滿呢未檩? 對了! 本文講解的 weight 的核心就是瓜分父布局剩余的空間粟焊。全部瓜分不就是鋪滿嘛冤狡! 那么代碼也就出來了:


<?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:paddingLeft="16dp"
    android:paddingRight="16dp"
    android:orientation="vertical" >
    <EditText
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:hint="@string/to" />
    <EditText
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:hint="@string/subject" />
    <EditText
        android:layout_width="match_parent"
        android:layout_height="0dp"
        android:layout_weight="1"
        android:gravity="top"
        android:hint="@string/message" />
    <Button
        android:layout_width="100dp"
        android:layout_height="wrap_content"
        android:layout_gravity="right"
        android:text="@string/send" />
</LinearLayout>

著重看一下message的布局:


<EditText
       android:layout_width="match_parent"
       android:layout_height="0dp"
       android:layout_weight="1"
       android:gravity="top"
       android:hint="@string/message" />

沒錯,采用了極為巧妙的方法项棠。其他的子布局都不設(shè)置 layout_weight悲雳, 也就是默認(rèn)是0 。 那么message將獲取全部的剩余空間香追,實(shí)現(xiàn)了鋪滿的效果合瓢。

后記

相信閱讀到這里的童鞋們,對文章開頭的問題應(yīng)該已經(jīng)知道答案了透典。如果還有童鞋不知道答案晴楔,可以試著將文章開頭的兩個(gè)Button的內(nèi)容改一下,一個(gè)叫AAAAAAAAA峭咒,一個(gè)叫B税弃。您再看一下效果,可能就明白了凑队。至于那個(gè)也對也不對的問題则果,“不對”的原因是他們要瓜分的是 剩余 空間。本文止。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末西壮,一起剝皮案震驚了整個(gè)濱河市遗增,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌款青,老刑警劉巖做修,帶你破解...
    沈念sama閱讀 216,591評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異可都,居然都是意外死亡缓待,警方通過查閱死者的電腦和手機(jī)蚓耽,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,448評論 3 392
  • 文/潘曉璐 我一進(jìn)店門渠牲,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人步悠,你說我怎么就攤上這事签杈。” “怎么了鼎兽?”我有些...
    開封第一講書人閱讀 162,823評論 0 353
  • 文/不壞的土叔 我叫張陵答姥,是天一觀的道長。 經(jīng)常有香客問我谚咬,道長鹦付,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,204評論 1 292
  • 正文 為了忘掉前任择卦,我火速辦了婚禮敲长,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘秉继。我一直安慰自己祈噪,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,228評論 6 388
  • 文/花漫 我一把揭開白布尚辑。 她就那樣靜靜地躺著辑鲤,像睡著了一般。 火紅的嫁衣襯著肌膚如雪杠茬。 梳的紋絲不亂的頭發(fā)上月褥,一...
    開封第一講書人閱讀 51,190評論 1 299
  • 那天,我揣著相機(jī)與錄音瓢喉,去河邊找鬼宁赤。 笑死,一個(gè)胖子當(dāng)著我的面吹牛灯荧,可吹牛的內(nèi)容都是我干的礁击。 我是一名探鬼主播,決...
    沈念sama閱讀 40,078評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼哆窿!你這毒婦竟也來了链烈?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,923評論 0 274
  • 序言:老撾萬榮一對情侶失蹤挚躯,失蹤者是張志新(化名)和其女友劉穎强衡,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體码荔,經(jīng)...
    沈念sama閱讀 45,334評論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡漩勤,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,550評論 2 333
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了缩搅。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片越败。...
    茶點(diǎn)故事閱讀 39,727評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖硼瓣,靈堂內(nèi)的尸體忽然破棺而出究飞,到底是詐尸還是另有隱情,我是刑警寧澤堂鲤,帶...
    沈念sama閱讀 35,428評論 5 343
  • 正文 年R本政府宣布亿傅,位于F島的核電站,受9級特大地震影響瘟栖,放射性物質(zhì)發(fā)生泄漏葵擎。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,022評論 3 326
  • 文/蒙蒙 一半哟、第九天 我趴在偏房一處隱蔽的房頂上張望酬滤。 院中可真熱鬧,春花似錦镜沽、人聲如沸敏晤。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,672評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽嘴脾。三九已至,卻和暖如春蔬墩,著一層夾襖步出監(jiān)牢的瞬間译打,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,826評論 1 269
  • 我被黑心中介騙來泰國打工拇颅, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留奏司,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,734評論 2 368
  • 正文 我出身青樓樟插,卻偏偏與公主長得像韵洋,于是被迫代替她去往敵國和親竿刁。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,619評論 2 354

推薦閱讀更多精彩內(nèi)容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,077評論 25 707
  • ¥開啟¥ 【iAPP實(shí)現(xiàn)進(jìn)入界面執(zhí)行逐一顯】 〖2017-08-25 15:22:14〗 《//首先開一個(gè)線程搪缨,因...
    小菜c閱讀 6,402評論 0 17
  • afinalAfinal是一個(gè)android的ioc食拜,orm框架 https://github.com/yangf...
    passiontim閱讀 15,429評論 2 45
  • 前言與目錄 上一章 一連半個(gè)月,阿花都不想說話副编,也無心工作负甸。打電話給主編后,李主編很同情痹届,讓她先休假一段時(shí)間呻待,阿花...
    亦農(nóng)閱讀 411評論 8 12
  • 22天的時(shí)間,在還沒有走過時(shí)覺得會好長队腐,今天站在22天的盡頭回望一路走過的點(diǎn)滴蚕捉,隔著屏幕我仿佛又聽到了小伙伴的打卡...
    黃值子閱讀 167評論 1 5