Android之TableLayout(表格布局)

1.本節(jié)學(xué)習(xí)路線圖

路線圖分析: 從上面的路線圖,可以看出TableLayout的用法還是很簡(jiǎn)單的,無(wú)非就是確定表格的行數(shù),以及使用 那三個(gè)屬性來(lái)設(shè)置每一行中的第某列的元素隱藏,拉伸,或者收縮即可!

2.TableLayout的介紹

相信學(xué)過(guò)HTML的朋友都知道,我們可以通過(guò)< table >< tr >< td >就可以生成一個(gè)HTML的表格, 而Android中也允許我們使用表格的方式來(lái)排列組件,就是行與列的方式,就說(shuō)我們這節(jié)的TableLayout! 但卻不像我們后面會(huì)講到的Android 4.0后引入的GridLayout(網(wǎng)格)布局一樣,直接就可以設(shè)置多少行與多少列郎汪!

3.如何確定行數(shù)與列數(shù)

  • ①如果我們直接往TableLayout中添加組件的話,那么這個(gè)組件將占滿一行3嗌蕖!煞赢!

  • ②如果我們想一行上有多個(gè)組件的話,就要添加一個(gè)TableRow的容器,把組件都丟到里面抛计!

  • ③tablerow中的組件個(gè)數(shù)就決定了該行有多少列,而列的寬度由該列中最寬的單元格決定

  • ④tablerow的layout_width屬性,默認(rèn)是fill_parent的,我們自己設(shè)置成其他的值也不會(huì)生效!U罩吹截! 但是layout_height默認(rèn)是wrapten——content的,我們卻可以自己設(shè)置大小凝危!

  • ⑤整個(gè)表格布局的寬度取決于父容器的寬度(占滿父容器本身)

  • ⑥有多少行就要自己數(shù)啦,一個(gè)tablerow一行,一個(gè)單獨(dú)的組件也一行波俄!多少列則是看tableRow中 的組件個(gè)數(shù),組件最多的就是TableLayout的列數(shù)

4.三個(gè)常用屬性

  • android:collapseColumns:設(shè)置需要被隱藏的列的序號(hào)

  • android:shrinkColumns:設(shè)置允許被收縮的列的列序號(hào)

  • android:stretchColumns:設(shè)置運(yùn)行被拉伸的列的列序號(hào)

以上這三個(gè)屬性的列號(hào)都是從0開始算的,比如shrinkColunmns = "2",對(duì)應(yīng)的是第三列!可以設(shè)置多個(gè),用逗號(hào)隔開比如"0,2",如果是所有列都生效,則用""號(hào)即可除了這三個(gè)常用屬性,還有兩個(gè)屬性,分別就是跳格子以及合并單元格,這和HTML中的Table類似:
android:layout_column="2":表示的就是
跳過(guò)第二個(gè),直接顯示到第三個(gè)格子處,從1開始算的!android:layout_span="4":表示合并*4個(gè)單元格,也就說(shuō)這個(gè)組件占4個(gè)單元格

屬性使用示例:

①collapseColumns(隱藏列)

流程:在TableRow中定義5個(gè)按鈕后,接著在最外層的TableLayout中添加以下屬性: android:collapseColumns = "0,2"蛾默,就是隱藏第一與第三列,代碼如下:

<TableLayout  
    android:id="@+id/TableLayout2"  
    android:layout_width="fill_parent"  
    android:layout_height="wrap_content"  
    android:collapseColumns="0,2" >  

    <TableRow>  

        <Button  
            android:layout_width="wrap_content"  
            android:layout_height="wrap_content"  
            android:text="one" />  

        <Button  
            android:layout_width="wrap_content"  
            android:layout_height="wrap_content"  
            android:text="two" />  

        <Button  
            android:layout_width="wrap_content"  
            android:layout_height="wrap_content"  
            android:text="three" />  

        <Button  
            android:layout_width="wrap_content"  
            android:layout_height="wrap_content"  
            android:text="four" />  

        <Button  
            android:layout_width="wrap_content"  
            android:layout_height="wrap_content"  
            android:text="five" />  
    </TableRow>  
</TableLayout>

運(yùn)行效果圖:

②stretchColumns(拉伸列)

流程:在TableLayout中設(shè)置了四個(gè)按鈕,接著在最外層的TableLayout中添加以下屬性: android:stretchColumns = "1"

設(shè)置第二列為可拉伸列,讓該列填滿這一行所有的剩余空間,代碼如下:

<TableLayout    
    android:id="@+id/TableLayout2"    
    android:layout_width="fill_parent"    
    android:layout_height="wrap_content"    
    android:stretchColumns="1" >    
    
    <TableRow>    
    
        <Button    
            android:layout_width="wrap_content"    
            android:layout_height="wrap_content"    
            android:text="one" />    
    
        <Button    
            android:layout_width="wrap_content"    
            android:layout_height="wrap_content"    
            android:text="two" />    
    
        <Button    
            android:layout_width="wrap_content"    
            android:layout_height="wrap_content"    
            android:text="three" />    
    
        <Button    
            android:layout_width="wrap_content"    
            android:layout_height="wrap_content"    
            android:text="four" />                 
    </TableRow>    
</TableLayout>  

運(yùn)行效果圖:

③shrinkColumns(收縮列)

步驟:這里為了演示出效果,設(shè)置了5個(gè)按鈕和一個(gè)文本框,在最外層的TableLayout中添加以下屬性: android:shrinkColumns = "1"

設(shè)置第二個(gè)列為可收縮列,代碼如下:

<TableLayout  
    android:id="@+id/TableLayout2"  
    android:layout_width="fill_parent"  
    android:layout_height="wrap_content"  
    android:shrinkColumns="1" >  

    <TableRow>  

        <Button  
            android:layout_width="wrap_content"  
            android:layout_height="wrap_content"  
            android:text="one" />  

        <Button  
            android:layout_width="wrap_content"  
            android:layout_height="wrap_content"  
            android:text="two" />  

        <Button  
            android:layout_width="wrap_content"  
            android:layout_height="wrap_content"  
            android:text="three" />  

        <Button  
            android:layout_width="wrap_content"  
            android:layout_height="wrap_content"  
            android:text="four" />  

        <Button  
            android:layout_width="wrap_content"  
            android:layout_height="wrap_content"  
            android:text="five" />  

        <TextView  
            android:layout_width="wrap_content"  
            android:layout_height="wrap_content"  
            android:text="文本XX" />  
    </TableRow>  
</TableLayout>

運(yùn)行截圖:

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末弟断,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子趴生,更是在濱河造成了極大的恐慌,老刑警劉巖昏翰,帶你破解...
    沈念sama閱讀 212,686評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件苍匆,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡棚菊,警方通過(guò)查閱死者的電腦和手機(jī)浸踩,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,668評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)统求,“玉大人检碗,你說(shuō)我怎么就攤上這事÷肓冢” “怎么了折剃?”我有些...
    開封第一講書人閱讀 158,160評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)像屋。 經(jīng)常有香客問(wèn)我怕犁,道長(zhǎng),這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,736評(píng)論 1 284
  • 正文 為了忘掉前任奏甫,我火速辦了婚禮戈轿,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘阵子。我一直安慰自己思杯,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,847評(píng)論 6 386
  • 文/花漫 我一把揭開白布挠进。 她就那樣靜靜地躺著色乾,像睡著了一般。 火紅的嫁衣襯著肌膚如雪奈梳。 梳的紋絲不亂的頭發(fā)上杈湾,一...
    開封第一講書人閱讀 50,043評(píng)論 1 291
  • 那天,我揣著相機(jī)與錄音攘须,去河邊找鬼漆撞。 笑死,一個(gè)胖子當(dāng)著我的面吹牛于宙,可吹牛的內(nèi)容都是我干的浮驳。 我是一名探鬼主播,決...
    沈念sama閱讀 39,129評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼捞魁,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼至会!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起谱俭,我...
    開封第一講書人閱讀 37,872評(píng)論 0 268
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤奉件,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后昆著,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體县貌,經(jīng)...
    沈念sama閱讀 44,318評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,645評(píng)論 2 327
  • 正文 我和宋清朗相戀三年凑懂,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了煤痕。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,777評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡接谨,死狀恐怖摆碉,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情脓豪,我是刑警寧澤巷帝,帶...
    沈念sama閱讀 34,470評(píng)論 4 333
  • 正文 年R本政府宣布,位于F島的核電站跑揉,受9級(jí)特大地震影響锅睛,放射性物質(zhì)發(fā)生泄漏埠巨。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,126評(píng)論 3 317
  • 文/蒙蒙 一现拒、第九天 我趴在偏房一處隱蔽的房頂上張望辣垒。 院中可真熱鬧,春花似錦印蔬、人聲如沸勋桶。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,861評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)例驹。三九已至,卻和暖如春退唠,著一層夾襖步出監(jiān)牢的瞬間鹃锈,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,095評(píng)論 1 267
  • 我被黑心中介騙來(lái)泰國(guó)打工瞧预, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留屎债,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,589評(píng)論 2 362
  • 正文 我出身青樓垢油,卻偏偏與公主長(zhǎng)得像盆驹,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子滩愁,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,687評(píng)論 2 351

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