91丨国产丨白浆秘 喷水,国产熟妇毛多 A片欧美蜜臀,北京熟妇搡BBBB搡BBBB,国产精品人人做人人爽人人添

  您的位置: 【卓安特保-您身邊的護(hù)衛(wèi)專家】山東卓安安防工程有限公司,電話13361029977 >> 安防資訊 >> 卓安安防 >> Android編程
 閱讀文章

TableLayout(表格布局)

  文章作者:網(wǎng)絡(luò)來源:網(wǎng)絡(luò)轉(zhuǎn)摘瀏覽次數(shù):8060字體:字體顏色
 閱讀權(quán)限:游客身份花費會員幣:0添加時間:2020/4/23 22:12:46提交會員:李漠

本文摘自:https://www.runoob.com/w3cnote/android-tutorial-tablelayout.html

店鋪防盜|卓安特保|山東卓安|聯(lián)網(wǎng)報警|濟(jì)南監(jiān)控安裝|15562629707|13361029977|李田軍

本節(jié)引言:

前面我們已經(jīng)學(xué)習(xí)了平時實際開發(fā)中用得較多的線性布局(LinearLayout)與相對布局(RelativeLayout), 其實學(xué)完這兩個基本就夠用了,筆者在實際開發(fā)中用得比較多的也是這兩個,當(dāng)然作為一個好學(xué)的程序猿, 都是喜歡刨根問題的,所以雖說用得不多,但是還是有必要學(xué)習(xí)一下基本的用法的,說不定哪一天能用得上呢! 你說是吧,學(xué)多點東西沒什么的,又不吃虧!好了,扯淡就扯到這里,開始這一節(jié)的學(xué)習(xí)吧,這一節(jié)我們會學(xué)習(xí) Android中的第三個布局:TableLayout(表格布局)!

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

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


2.TableLayout的介紹

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

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

  • ①如果我們直接往TableLayout中添加組件的話,那么這個組件將占滿一行�。�!
  • ②如果我們想一行上有多個組件的話,就要添加一個TableRow的容器,把組件都丟到里面!
  • ③tablerow中的組件個數(shù)就決定了該行有多少列,而列的寬度由該列中最寬的單元格決定
  • ④tablerow的layout_width屬性,默認(rèn)是fill_parent的,我們自己設(shè)置成其他的值也不會生效�。�! 但是layout_height默認(rèn)是wrapten——content的,我們卻可以自己設(shè)置大��!
  • ⑤整個表格布局的寬度取決于父容器的寬度(占滿父容器本身)
  • ⑥有多少行就要自己數(shù)啦,一個tablerow一行,一個單獨的組件也一行!多少列則是看tableRow中 的組件個數(shù),組件最多的就是TableLayout的列數(shù)

4.三個常用屬性

android:collapseColumns:設(shè)置需要被隱藏的列的序號
android:shrinkColumns:設(shè)置允許被收縮的列的列序號
android:stretchColumns:設(shè)置運行被拉伸的列的列序號

以上這三個屬性的列號都是從0開始算的,比如shrinkColunmns = "2",對應(yīng)的是第三列!
可以設(shè)置多個,用逗號隔開比如"0,2",如果是所有列都生效,則用"*"號即可
除了這三個常用屬性,還有兩個屬性,分別就是跳格子以及合并單元格,這和HTML中的Table類似:

android:layout_column="2":表示的就是跳過第二個,直接顯示到第三個格子處,從1開始算的!
android:layout_span="4":表示合并4個單元格,也就說這個組件占4個單元格

屬性使用示例:

①collapseColumns(隱藏列)

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

運行效果圖:

②stretchColumns(拉伸列)

流程:在TableLayout中設(shè)置了四個按鈕,接著在最外層的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>  

運行效果圖:

③shrinkColumns(收縮列)

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

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

<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>

運行截圖:

從圖中我們可以看到two這個按鈕被擠壓成條條狀,這個就是收縮,為了保證表格能適應(yīng) 父容器的寬度!至于另外兩個屬性就不講解了,用法和HTML相同!有興趣的可以研究下!


5.使用實例

使用TableLayout來完成簡單的登錄界面,運行效果圖如下:

流程解析:

①調(diào)用gravity屬性,設(shè)置為center_vertical,讓布局里面的組件在豎直方向上居中

②將TableLayout中的第一和第四列設(shè)置為可拉伸

③在每個TableRow中添加兩個TextView,用于拉伸填滿該行,這樣可以讓表格水平居中

android:stretchColumns="0,3" 設(shè)置為0.3,是為了讓兩邊都充滿,那么中間部分就可以居中了

詳細(xì)代碼如下:

<TableLayout xmlns:android="http://schemas.android.com/apk/res/android"    
    xmlns:tools="http://schemas.android.com/tools"    
    android:id="@+id/TableLayout1"    
    android:layout_width="match_parent"    
    android:layout_height="match_parent"    
    tools:context=".MainActivity"     
    android:stretchColumns="0,3"    
    android:gravity="center_vertical"    
    android:background="#66FF66"    
    >    
        
    <TableRow>    
        <TextView />    
        <TextView     
            android:layout_width="wrap_content"    
            android:layout_height="wrap_content"    
            android:text="用戶名:"/>    
        <EditText     
            android:layout_width="wrap_content"    
            android:layout_height="wrap_content"    
            android:minWidth="150dp"/>    
        <TextView />    
    </TableRow>    
        
    <TableRow>    
        <TextView />    
        <TextView     
            android:layout_width="wrap_content"    
            android:layout_height="wrap_content"    
            android:text="密  碼:"        
        />    
        <EditText     
            android:layout_width="wrap_content"    
            android:layout_height="wrap_content"    
            android:minWidth="150dp"        
        />    
        <TextView />    
    </TableRow>    
        
    <TableRow>    
        <TextView />    
        <Button     
            android:layout_width="wrap_content"    
            android:layout_height="wrap_content"    
            android:text="登陸"/>    
        <Button    
            android:layout_width="wrap_content"    
            android:layout_height="wrap_content"    
            android:text="退出"/>    
        <TextView />    
    </TableRow>    
        
</TableLayout>

6.發(fā)現(xiàn)的問題

相信大家在使用這個這TableLayout的TableRow的時候會遇到這個警告:

當(dāng)然,程序還是可以運行的,不過或許你是強迫癥患者,看到黃色感嘆號你就不爽的話! 而解決這個警告的方法也是很奇葩的:只要你的TableLayout里面有2個或以上的TableRow就可以了!


本節(jié)小結(jié):

好的,關(guān)于Android的第三個布局:TableLayout就到這里~無非就是五個屬性的使用而已,實際開發(fā) 表格布局我們用的不多,知道簡單的用法就可以了!

·上篇文章:Win10 網(wǎng)上鄰居發(fā)現(xiàn)不了別的電腦
·下篇文章:Android Studio Build Output 欄內(nèi)漢字出現(xiàn)亂碼的解決方案
復(fù)制 】 【 打印
 相關(guān)文章
沒有相關(guān)文章
特別聲明:本站除部分特別聲明禁止轉(zhuǎn)載的專稿外的其他文章可以自由轉(zhuǎn)載,但請務(wù)必注明出處和原始作者。文章版權(quán)歸文章原始作者所有。對于被本站轉(zhuǎn)載文章的個人和網(wǎng)站,我們表示深深的謝意。如果本站轉(zhuǎn)載的文章有版權(quán)問題請聯(lián)系我們,我們盡快予以更正,謝謝。
關(guān)于我們 | 業(yè)務(wù)范圍 | 免責(zé)聲明 | 聯(lián)系我們 | 友情連接
版權(quán)所有 Copyright © 2007 【卓安特保-您身邊的護(hù)衛(wèi)專家】山東卓安安防工程有限公司,電話13361029977 All Rights Reserved.
魯ICP備11024361號-5    頁面執(zhí)行時間:31.25MS
日本无码熟人中文字幕 | 国产午夜福利电影 | 国产在线观看高清无码 | 少妇搡bbbb搡bbbb搡 | 31XX成人网站| 日韩精品在线观看视频在线 | 国产在线观看高清无码 | 国产精品人妻一区二区 | 麻豆一区区三区四区产品精品蜜桃 | 午夜成人片毛片东方影库 | 又爽又黄又刺激A片 | 日韩精品人妻无码一二三蜜臀 | 一本一道久久精品蜜桃 | 在线视频免费91 | 午夜福利视频合集 | 国产一级a毛一级a免费视频 | 蜜桃av秘 无码一区二区 | 久久久久久久久久91 | 日韩精品一区二区无码蜜桃 | 又粗又大又爽又黄的在线播放 | 日韩欧美高清视频在线观看 | 非洲老肥婆大BBBBBB | 风间由美性色一区二区三区_第1集 | 精品少妇高潮乱码久久久久 | 四川W搡BBB搡BBB搡按摩 | 欧性猛交XXXX乱大交 | 亚洲无码在线免费 | 久久日韩乱码一二三四区别 | 亚洲伊人久久水牛影视 | 亚洲一区二区精品 | 国产AV无码精品又大又粗双胞胎 | 中文无码AV一区二区三区 | 成年免费A级毛片免费看无码 | 无码毛片在线播放 | 国产熟女乱子伦露脸视频com | 古装妇婬A片AA毛A片 | 亚洲无码高清电影 | 国产精品秘 入口久久熟女沈阳 | 亚洲一级av无码毛片精品 | 贵州丰满少妇一级毛片 | 成人性生交大片免费看无码app |