[转]Android中的android:layout_width和android:width

 

android:width 其实是定义控件上面的文本(TextView) 的宽度,当然这个宽度也是和 android:layout_width 配合起来作用的,如果 android:layout_width="fill_parent" 的话,那么设置 android:width 是没有意义的


android:layout_width 其实是可以实现 android:width 的效果的,我觉得这应该是为什么在 android 实例中看不到有人用 android:width 的原因吧。


若还要讲讲两者的区别的话,那就是:
android:width 的值,一般是 "100dp" 这样的数值;
android:layout_width 的值,一般是"fill_parent","wrap_content","match_parent".当然,它也可以像前者一样,设置数值的.


带"layout"的属性是指整个控件而言的,是与父控件之间的关系,如 layout_gravity 在父控件中的对齐方式, layout_margin 是级别相同的控件之间的间隙等等;

不带"layout" 的属性是指控件中文本的格式,如gravity是指文本的对齐方式等等,而其中文本的格式又受制约于它的控件在父控件中的属性.


借用一位大牛的示例:http://zhangcong170.iteye.com/blog/423173

    1. <?xml version="1.0" encoding="utf-8"?>    
    2. <!--     
    3.     <LinearLayout>    
    4.     线性版面配置,在这个标签中,所有元件都是按由上到下的排队排成的    
    5.  -->    
    6. <LinearLayout     
    7.     xmlns:android="http://schemas.android.com/apk/res/android"    
    8.     android:orientation="vertical"     
    9.     android:layout_width="fill_parent"    
    10.     android:layout_height="fill_parent">    
    11.    <!-- android:orientation="vertical" 表示竖直方式对齐    
    12.         android:orientation="horizontal"表示水平方式对齐    
    13.         android:layout_width="fill_parent"定义当前视图在屏幕上 可以消费的宽度,fill_parent即填充整个屏幕。    
    14.         android:layout_height="wrap_content":随着文字栏位的不同 而改变这个视图的宽度或者高度。有点自动设置框度或者高度的意思    
    15.                   
    16.         layout_weight 用于给一个线性布局中的诸多视图的重要度赋值。    
    17.           
    18.         所有的视图都有一个layout_weight值,默认为零,意思是需要显示    
    19.         多大的视图就占据多大的屏幕空 间。若赋一个高于零的值,则将父视    
    20.         图中的可用空间分割,分割大小具体取决于每一个视图的layout_weight    
    21.         值以及该值在当前屏幕布局的整体 layout_weight值和在其它视图屏幕布    
    22.         局的layout_weight值中所占的比率而定。    
    23.           
    24.         举个例子:比如说我们在 水平方向上有一个文本标签和两个文本编辑元素。    
    25.         该文本标签并无指定layout_weight值,所以它将占据需要提供的最少空间。    
    26.         如果两个文本编辑元素每一个的layout_weight值都设置为1,则两者平分    
    27.         在父视图布局剩余的宽度(因为我们声明这两者的重要度相等)。如果两个     
    28.         文本编辑元素其中第一个的layout_weight值设置为1,而第二个的设置为2,    
    29.         则剩余空间的三分之二分给第一个,三分之一分给第二个(数值越小,重要    
    30.         度越高)。    
    31.     -->    
    32.     <LinearLayout    
    33.     android:orientation="horizontal"    
    34.     android:layout_width="fill_parent"    
    35.     android:layout_height="fill_parent"    
    36.     android:layout_weight="1">    
    37.     <TextView    
    38.         android:text="red"    
    39.         android:gravity="center_horizontal"    
    40.         android:background="#aa0000"    
    41.         android:layout_width="wrap_content"    
    42.         android:layout_height="fill_parent"    
    43.         android:layout_weight="1"/>    
    44.         
    45.     <TextView    
    46.         android:text="green"    
    47.         android:gravity="center_horizontal"    
    48.         android:background="#00aa00"    
    49.         android:layout_width="wrap_content"    
    50.         android:layout_height="fill_parent"    
    51.         android:layout_weight="1"/>    
    52.         
    53.     <TextView    
    54.         android:text="blue"    
    55.         android:gravity="center_horizontal"    
    56.         android:background="#0000aa"    
    57.         android:layout_width="wrap_content"    
    58.         android:layout_height="fill_parent"    
    59.         android:layout_weight="1"/>    
    60.         
    61.     <TextView    
    62.         android:text="yellow"    
    63.         android:gravity="center_horizontal"    
    64.         android:background="#aaaa00"    
    65.         android:layout_width="wrap_content"    
    66.         android:layout_height="fill_parent"    
    67.         android:layout_weight="1"/>    
    68.             
    69.     </LinearLayout>    
    70.         
    71.     <LinearLayout    
    72.     android:orientation="vertical"    
    73.     android:layout_width="fill_parent"    
    74.     android:layout_height="fill_parent"    
    75.     android:layout_weight="2">    
    76.         
    77.     <TextView    
    78.         android:text="row one"    
    79.         android:textSize="15pt"    
    80.         android:layout_width="fill_parent"    
    81.         android:layout_height="wrap_content"    
    82.         android:layout_weight="1"/>    
    83.         
    84.     <TextView    
    85.         android:text="row two"    
    86.         android:textSize="15pt"    
    87.         android:layout_width="fill_parent"    
    88.         android:layout_height="wrap_content"    
    89.         android:layout_weight="1"/>    
    90.         
    91.     <TextView    
    92.         android:text="row three"    
    93.         android:textSize="15pt"    
    94.         android:layout_width="fill_parent"    
    95.         android:layout_height="wrap_content"    
    96.         android:layout_weight="1"/>    
    97.         
    98.     <TextView    
    99.         android:text="row four"    
    100.         android:textSize="15pt"    
    101.         android:layout_width="fill_parent"    
    102.         android:layout_height="wrap_content"    
    103.         android:layout_weight="1"/>    
    104.             
    105.     </LinearLayout>    
    106.             
    107. </LinearLayout>   
原文地址:https://www.cnblogs.com/ZhuRenWang/p/4815189.html