国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

????? ?? ??? / LinearLayout(線(xiàn)性布局)

LinearLayout(線(xiàn)性布局)

本節(jié)引言

本節(jié)開(kāi)始講Android中的布局,Android中有六大布局,分別是: LinearLayout(線(xiàn)性布局),RelativeLayout(相對(duì)布局),TableLayout(表格布局) FrameLayout(幀布局),AbsoluteLayout(絕對(duì)布局),GridLayout(網(wǎng)格布局) 而今天我們要講解的就是第一個(gè)布局,LinearLayout(線(xiàn)性布局),我們屏幕適配的使用 用的比較多的就是LinearLayout的weight(權(quán)重屬性),在這一節(jié)里,我們會(huì)詳細(xì)地解析 LinearLayout,包括一些基本的屬性,Weight屬性的使用,以及比例如何計(jì)算,另外還 會(huì)說(shuō)下一個(gè)用的比較少的屬性:android:divider繪制下劃線(xiàn)!


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

    1.jpg


2.weight(權(quán)重)屬性詳解:

①最簡(jiǎn)單用法:

如圖:

2.png

實(shí)現(xiàn)代碼:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"    
    xmlns:tools="http://schemas.android.com/tools"    
    android:id="@+id/LinearLayout1"    
    android:layout_width="match_parent"    
    android:layout_height="match_parent"    
    android:orientation="horizontal">    
        
    <LinearLayout    
        android:layout_width="0dp"    
        android:layout_height="fill_parent"    
        android:background="../style/images/android-tutorial-linearlayout.html"     
        android:layout_weight="1"/>    
       
        
    <LinearLayout    
        android:layout_width="0dp"    
        android:layout_height="fill_parent"    
        android:background="../style/images/android-tutorial-linearlayout.html"     
        android:layout_weight="2"/>    
        
</LinearLayout>

要實(shí)現(xiàn)第一個(gè)的1:1的效果,只需要分別把兩個(gè)LinearLayout的weight改成1和1就可以了 用法歸納: 按比例劃分水平方向:將涉及到的View的android:width屬性設(shè)置為0dp,然后設(shè)置為android weight屬性設(shè)置比例即可;類(lèi)推,豎直方向,只需設(shè)android:height為0dp,然后設(shè)weight屬性即可! 大家可以自己寫(xiě)個(gè)豎直方向的等比例劃分的體驗(yàn)下簡(jiǎn)單用法!

②weight屬性詳解:

當(dāng)然,如果我們不適用上述那種設(shè)置為0dp的方式,直接用wrap_content和match_parent的話(huà), 則要接著解析weight屬性了,分為兩種情況,wrap_content與match_parent!另外還要看 LinearLayout的orientation是水平還是豎直,這個(gè)決定哪個(gè)方向等比例劃分

1)wrap_content比較簡(jiǎn)單,直接就按比例的了

3.png

實(shí)現(xiàn)代碼:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"    
    xmlns:tools="http://schemas.android.com/tools"    
    android:id="@+id/LinearLayout1"    
    android:layout_width="match_parent"    
    android:layout_height="match_parent"  
    android:orientation="horizontal" >    
    
    <TextView    
        android:layout_weight="1"    
        android:layout_width="wrap_content"    
        android:layout_height="fill_parent"    
        android:text="one"     
        android:background="../style/images/android-tutorial-linearlayout.html"    
     />    
     <TextView    
        android:layout_weight="2"    
        android:layout_width="wrap_content"    
        android:layout_height="fill_parent"    
        android:text="two"     
        android:background="../style/images/android-tutorial-linearlayout.html"    
     />    
     <TextView    
        android:layout_weight="3"    
        android:layout_width="wrap_content"    
        android:layout_height="fill_parent"    
        android:text="three"     
        android:background="../style/images/android-tutorial-linearlayout.html"    
     />    
    
</LinearLayout>

2)match_parent(fill_parent):這個(gè)則需要計(jì)算了

我們寫(xiě)這段簡(jiǎn)單的代碼:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"    
    xmlns:tools="http://schemas.android.com/tools"    
    android:id="@+id/LinearLayout1"    
    android:layout_width="match_parent"    
    android:layout_height="match_parent" >    
    
    <TextView    
        android:layout_weight="1"    
        android:layout_width="fill_parent"    
        android:layout_height="fill_parent"    
        android:text="one"     
        android:background="../style/images/android-tutorial-linearlayout.html"    
     />    
     <TextView    
        android:layout_weight="2"    
        android:layout_width="fill_parent"    
        android:layout_height="fill_parent"    
        android:text="two"     
        android:background="../style/images/android-tutorial-linearlayout.html"    
     />    
     <TextView    
        android:layout_weight="3"    
        android:layout_width="fill_parent"    
        android:layout_height="fill_parent"    
        android:text="three"     
        android:background="../style/images/android-tutorial-linearlayout.html"    
     />    
    
</LinearLayout>

運(yùn)行效果圖:

4.png

這個(gè)時(shí)候就會(huì)有疑問(wèn)了,怎么會(huì)這樣,這比例是2:1吧,那么three去哪了?代碼里面明明有 three的啊,還設(shè)置了3的,而1和2的比例也不對(duì)耶,1:2:3卻變成了2:1:0,怎么會(huì)這樣呢? 答:這里其實(shí)沒(méi)那么簡(jiǎn)單的,還是需要我們計(jì)算的,網(wǎng)上給出的算法有幾種,這里就給出筆者 覺(jué)得比較容易理解的一種:step 1:個(gè)個(gè)都是fill_parent,但是屏幕只有一個(gè)啦,那么1 - 3 = - 2 fill_parentstep 2:依次比例是1/6,2/6,3/6step 3:先到先得,先分給one,計(jì)算: 1 - 2 * (1/6) = 2/3 fill_parent           接著到two,計(jì)算: 1 - 2 * (2/6) = 1/3 fill_parent           最后到three,計(jì)算 1 - 2 * (3/6) = 0 fill_parentstep 4:所以最后的結(jié)果是:one占了兩份,two占了一份,three什么都木有 以上就是為什么three沒(méi)有出現(xiàn)的原因了,或許大家看完還是有點(diǎn)蒙,沒(méi)事,我們舉多幾個(gè)例子試試就知道了!

比例為:1:1:1

5.png

按照上面的計(jì)算方法算一次,結(jié)果是:1/3   1/3   1/3,沒(méi)錯(cuò)

接著我們?cè)僭囅?2:3:4

6.png

計(jì)算結(jié)果:5/9   3/9   1/9,對(duì)比效果圖,5:3:1,也沒(méi)錯(cuò),所以這個(gè)計(jì)算方法你可得mark下了!

③Java代碼中設(shè)置weight屬性:

setLayoutParams(new LayoutParams(LayoutParams.FILL_PARENT,     
        LayoutParams.WRAP_CONTENT, 1));

3.為L(zhǎng)inearLayout設(shè)置分割線(xiàn)

很多界面開(kāi)發(fā)中都會(huì)設(shè)置一些下劃線(xiàn),或者分割線(xiàn),從而使得界面更加整潔美觀,比如下面的酷狗 音樂(lè)的注冊(cè)頁(yè)面:

7.jpg

對(duì)于這種線(xiàn),我們通常的做法有兩種①直接在布局中添加一個(gè)view,這個(gè)view的作用僅僅是顯示出一條線(xiàn),代碼也很簡(jiǎn)單:

<View  
    android:layout_width="match_parent"  
    android:layout_height="1px"  
    android:background="../style/images/android-tutorial-linearlayout.html" />

這個(gè)是水平方向上的黑線(xiàn),當(dāng)然你也可以改成其他顏色,或者使用圖片

20682772.jpg

②第二種則是使用LinearLayout的一個(gè)divider屬性,直接為L(zhǎng)inearLayout設(shè)置分割線(xiàn) 這里就需要你自己準(zhǔn)備一張線(xiàn)的圖片了 1)android:divider設(shè)置作為分割線(xiàn)的圖片 2)android:showDividers設(shè)置分割線(xiàn)的位置,none(無(wú)),begining(開(kāi)始),end(結(jié)束),middle(每?jī)蓚€(gè)組件間) 3)dividerPadding設(shè)置分割線(xiàn)的Padding

使用示例:

8.jpg

實(shí)現(xiàn)代碼:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  
    xmlns:tools="http://schemas.android.com/tools"  
    android:id="@+id/LinearLayout1"  
    android:layout_width="match_parent"  
    android:layout_height="match_parent"  
    android:divider="@drawable/ktv_line_div"  
    android:orientation="vertical"  
    android:showDividers="middle"  
    android:dividerPadding="10dp"  
    tools:context="com.jay.example.linearlayoutdemo.MainActivity" >  
  
    <Button  
        android:layout_width="wrap_content"  
        android:layout_height="wrap_content"  
        android:text="按鈕1" />  
  
    <Button  
        android:layout_width="wrap_content"  
        android:layout_height="wrap_content"  
        android:text="按鈕2" />  
  
    <Button  
        android:layout_width="wrap_content"  
        android:layout_height="wrap_content"  
        android:text="按鈕3" />  
  
</LinearLayout>

4.LinearLayout的簡(jiǎn)單例子:

9.jpg

實(shí)現(xiàn)代碼如下:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"    
    xmlns:tools="http://schemas.android.com/tools"    
    android:id="@+id/LinearLayout1"    
    android:layout_width="fill_parent"    
    android:layout_height="fill_parent"    
    android:orientation="vertical"    
    tools:context=".MainActivity" >    
        
    <TextView    
        android:layout_width="wrap_content"    
        android:layout_height="wrap_content"    
        android:text="請(qǐng)輸入要保存的電話(huà)號(hào)碼"/>    
    <EditText    
        android:layout_width="fill_parent"    
        android:layout_height="wrap_content"/>    
    <LinearLayout    
        android:layout_width="fill_parent"    
        android:layout_height="wrap_content"    
        android:orientation="horizontal"    
        android:gravity="right">    
        <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="清空"/>    
    </LinearLayout>    
</LinearLayout>

5.注意事項(xiàng):

使用Layout_gravity的一個(gè)很重要的問(wèn)題!!! 問(wèn)題內(nèi)容: 在一個(gè)LinearLayout的水平方向中布置兩個(gè)TextView,想讓一個(gè)左,一個(gè)右,怎么搞? 或許你會(huì)脫口而出:"gravity設(shè)置一個(gè)left,一個(gè)right就可以啦!" 真的這么簡(jiǎn)單?你試過(guò)嗎?寫(xiě)個(gè)簡(jiǎn)單的Layout你就會(huì)發(fā)現(xiàn),事與愿違了: 代碼如下:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  
    xmlns:tools="http://schemas.android.com/tools"  
    android:layout_width="match_parent"  
    android:layout_height="match_parent"  
    android:orientation="horizontal"  
    tools:context="com.jay.example.getscreendemo.MainActivity" >  
  
    <TextView  
        android:layout_width="wrap_content"  
        android:layout_height="200dp"  
        android:layout_gravity="left"  
        android:background="../style/images/android-tutorial-linearlayout.html"  
        android:gravity="center"  
        android:text="O(∩_∩)O哈哈~" />  
  
    <TextView  
        android:layout_width="wrap_content"  
        android:layout_height="200dp"  
        android:layout_gravity="right"  
        android:background="../style/images/android-tutorial-linearlayout.html"  
        android:gravity="center"  
        android:text="(*^__^*) 嘻嘻……" />  
  
</LinearLayout>

運(yùn)行結(jié)果圖:

10.jpg

看到這里你會(huì)說(shuō):哎呀,真的不行耶,要不在外層LinearLayout加個(gè)gravity=left的屬性,然后設(shè)置第二個(gè) TextView的layout_gravity為right,恩,好我們?cè)囈幌?

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  
    xmlns:tools="http://schemas.android.com/tools"  
    android:layout_width="match_parent"  
    android:layout_height="match_parent"  
    android:orientation="horizontal"  
    android:gravity="left"  
    tools:context="com.jay.example.getscreendemo.MainActivity" >  
  
    <TextView  
        android:layout_width="wrap_content"  
        android:layout_height="200dp"  
        android:background="../style/images/android-tutorial-linearlayout.html"  
        android:gravity="center"  
        android:text="O(∩_∩)O哈哈~" />  
  
    <TextView  
        android:layout_width="wrap_content"  
        android:layout_height="200dp"  
        android:layout_gravity="right"  
        android:background="../style/images/android-tutorial-linearlayout.html"  
        android:gravity="center"  
        android:text="(*^__^*) 嘻嘻……" />  
  
</LinearLayout>

結(jié)果還是一樣:

12.jpg

好吧,沒(méi)轍了,怎么辦好?

當(dāng) android:orientation="vertical" 時(shí), 只有水平方向的設(shè)置才起作用,垂直方向的設(shè)置不起作用。 即:left,right,center_horizontal 是生效的。 當(dāng) android:orientation="horizontal" 時(shí), 只有垂直方向的設(shè)置才起作用,水平方向的設(shè)置不起作用。 即:top,bottom,center_vertical 是生效的。

然而,這方法好像并沒(méi)有什么卵用。比如: 如果只能豎直方向設(shè)置左右對(duì)齊的話(huà),就會(huì)出現(xiàn)下面的效果:

13.jpg

這顯然不是我們要的結(jié)果把! 綜上,要么按照上述給出的規(guī)則來(lái)布局,不過(guò)對(duì)于這種情況還是使用相對(duì)布局RelativeLayout把! 網(wǎng)上沒(méi)給出具體的原因,都是說(shuō)這樣改有人說(shuō)這個(gè)和orientation的優(yōu)先級(jí)有關(guān) ,暫且先mark下來(lái)吧,后續(xù)如果知道原因的話(huà)再解釋!前面屏幕適配也說(shuō)過(guò)了,布局還是建議使用 RelativeLayout!