Android布局的相对性

不常接触Android布局的同学可能会为一个问题犯糊涂,即该属性是相对于父容器还是相对于子元素,还是只对自己有效,下面我们根据一个例子来简单理一下布局相对性的思路。

 

  1. <?xml version="1.0" encoding="utf-8"?> 
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
  3.     android:layout_width="fill_parent" 
  4.     android:layout_height="fill_parent" 
  5.     android:orientation="vertical" > 
  6.  
  7.     <!-- 
  8.         以下的LinearLayout 中 android:layout_gravity="center", 
  9.         相对于其父容器重力方向,所以水平居中 
  10.     --> 
  11.  
  12.     <LinearLayout 
  13.         android:id="@+id/linearLayout1" 
  14.         android:layout_width="200dip" 
  15.         android:layout_height="60dip" 
  16.         android:layout_gravity="center" 
  17.         android:background="#00ff00" 
  18.         android:orientation="horizontal" > 
  19.  
  20.         <TextView 
  21.             android:id="@+id/textView1" 
  22.             android:layout_width="wrap_content" 
  23.             android:layout_height="wrap_content" 
  24.             android:layout_marginRight="2dip" 
  25.             android:background="#ff0000" 
  26.             android:text="TextA" /> 
  27.  
  28.         <TextView 
  29.             android:id="@+id/textView2" 
  30.             android:layout_width="wrap_content" 
  31.             android:layout_height="wrap_content" 
  32.             android:background="#ff0000" 
  33.             android:text="TextB" /> 
  34.     </LinearLayout> 
  35.  
  36.     <!-- 
  37. 以下的LinearLayout 中android:gravity="bottom" 
  38. 表示该LinearLayout的子View相对于LinearLayout是居底部的 
  39.  
  40.     --> 
  41.  
  42.     <LinearLayout 
  43.         android:id="@+id/linearLayout2" 
  44.         android:layout_width="200dip" 
  45.         android:layout_height="60dip" 
  46.         android:layout_gravity="center" 
  47.         android:layout_marginTop="5dip" 
  48.         android:background="#ffff00" 
  49.         android:gravity="bottom" 
  50.         android:orientation="horizontal" > 
  51.  
  52.         <TextView 
  53.             android:id="@+id/TextView03" 
  54.             android:layout_width="wrap_content" 
  55.             android:layout_height="wrap_content" 
  56.             android:layout_marginRight="2dip" 
  57.             android:background="#ff0000" 
  58.             android:text="TextA" /> 
  59.  
  60.         <TextView 
  61.             android:id="@+id/TextView04" 
  62.             android:layout_width="wrap_content" 
  63.             android:layout_height="wrap_content" 
  64.             android:background="#ff0000" 
  65.             android:text="TextB" /> 
  66.     </LinearLayout> 
  67.  
  68. </LinearLayout> 

这里对应的效果图贴上

该图分别对应了布局文件中的两个布局思路介绍

  1. 相对于父元素
  2. 相对于子元素

由此我们也来发现以下一般规律:

对于android:layout_xxx开始的属性一般用于“自身”及“相对于父元素”,如android:layout_gravity="center",相对于父容器居中

而对于android:xxx开始的属性则一般作用域子元素,如android:orientation="vertical",其子元素居中

 

当然,以上只是根据命名方式做的一般性猜测,对于有些属性,如android:layout_marginRight,其相对于父元素或兄弟元素,android:layout_height="60dip"则只对自身有效