Android 控件布局常用属性

来源:互联网 发布:遇事不要慌,知乎 编辑:程序博客网 时间:2024/05/18 23:27

RelativeLayout用到的一些重要的属性: 

 

    第一类:属性值为true或false 
    android:layout_centerHrizontal  水平居中 
     android:layout_centerVertical   垂直居中 
    android:layout_centerInparent    相对于父元素完全居中 
    android:layout_alignParentBottom 贴紧父元素的下边缘 
    android:layout_alignParentLeft   贴紧父元素的左边缘 
    android:layout_alignParentRight  贴紧父元素的右边缘 
    android:layout_alignParentTop    贴紧父元素的上边缘 
    android:layout_alignWithParentIfMissing  如果对应的兄弟元素找不到的话就以父元素做参照物 

    第二类:属性值必须为id的引用名“@id/id-name” 
    android:layout_below      在某元素的下方 
    android:layout_above      在某元素的的上方 
    android:layout_toLeftOf   在某元素的左边 
    android:layout_toRightOf  在某元素的右边 

    android:layout_alignTop   本元素的上边缘和某元素的的上边缘对齐 
    android:layout_alignLeft  本元素的左边缘和某元素的的左边缘对齐 
    android:layout_alignBottom 本元素的下边缘和某元素的的下边缘对齐 
    android:layout_alignRight  本元素的右边缘和某元素的的右边缘对齐 

    第三类:属性值为具体的像素值,如30dip,40px 
   android:layout_marginBottom             离某元素底边缘的距离 
   android:layout_marginLeft                  离某元素左边缘的距离 
    android:layout_marginRight                离某元素右边缘的距离 
   android:layout_marginTop                  离某元素上边缘的距离 


EditText的android:hint 

设置EditText为空时输入框内的提示信息。 

android:gravity  
android:gravity属性是对该view内容的限定.比如一个button上面的text. 你可以设置该text 在view的靠左,靠右等位置.以button为例,android:gravity="right"则button上面的文字靠右 

android:layout_gravity 
android:layout_gravity是用来设置该view相对与起父view 的位置.比如一个button 在linearlayout里,你想把该button放在靠左、靠右等位置就可以通过该属性设置.以button为例,android:layout_gravity="right"则button靠右 

android:layout_alignParentRight
 
使当前控件的右端和父控件的右端对齐。这里属性值只能为true或false,默认false。 

android:scaleType: 
android:scaleType是控制图片如何resized/moved来匹对ImageView的size。ImageView.ScaleType/ android:scaleType值的意义区别: 

CENTER /center  按图片的原来size居中显示,当图片长/宽超过View的长/宽,则截取图片的居中部分显示 

CENTER_CROP / centerCrop  按比例扩大图片的size居中显示,使得图片长(宽)等于或大于View的长(宽) 

CENTER_INSIDE / centerInside  将图片的内容完整居中显示,通过按比例缩小或原来的size使得图片长/宽等于或小于View的长/宽 

FIT_CENTER / fitCenter  把图片按比例扩大/缩小到View的宽度,居中显示 

FIT_END / fitEnd   把图片按比例扩大/缩小到View的宽度,显示在View的下部分位置 

FIT_START / fitStart  把图片按比例扩大/缩小到View的宽度,显示在View的上部分位置 

FIT_XY / fitXY  把图片不按比例扩大/缩小到View的大小显示 

MATRIX / matrix 用矩阵来绘制,动态缩小放大图片来显示。 

** 要注意一点,Drawable文件夹里面的图片命名是不能大写的。

 

 

这篇博文包括的内容:
1、TableLayout简介
2、TableLayout行列数的确定
3、TableLayout可设置的属性详解
4、一个包含4个TableLayout布局的实例及效果图
一、Tablelayout简介 Tablelayout类以行和列的形式对控件进行管理,每一行为一个TableRow对象,或一个View控件。 当为TableRow对象时,可在TableRow下添加子控件,默认情况下,每个子控件占据一列。 当为View时,该View将独占一行。 二、TableLayout行列数的确定 TableLayout的行数由开发人员直接指定,即有多少个TableRow对象(或View控件),就有多少行。
TableLayout的列数等于含有最多子控件的TableRow的列数。如第一TableRow含2个子控件,第二个TableRow含3个,第三个TableRow含4个,那么该TableLayout的列数为4.
三、TableLayout可设置的属性详解 TableLayout可设置的属性包括全局属性及单元格属性。
1、全局属性也即列属性,有以下3个参数:
android:stretchColumns 设置可伸展的列。该列可以向行方向伸展,最多可占据一整行。
android:shrinkColumns 设置可收缩的列。当该列子控件的内容太多,已经挤满所在行,那么该子控件的内容将往列方向显示。
android:collapseColumns 设置要隐藏的列。
示例:
android:stretchColumns='0' 第0列可伸展
android:shrinkColumns='1,2' 第1,2列皆可收缩
android:collapseColumns='*' 隐藏所有行
说明:列可以同时具备stretchColumns及shrinkColumns属性,若此,那么当该列的内容N多时,将“多行”显示其内容。(这里不是真正的多行,而是系统根据需要自动调节该行的layout_height)
2、单元格属性,有以下2个参数:
android:layout_column 指定该单元格在第几列显示
android:layout_span 指定该单元格占据的列数(未指定时,为1)
示例:
android:layout_column='1' 该控件显示在第1列
android:layout_span='2' 该控件占据2列
说明:一个控件也可以同时具备这两个特性。
四、一个包含4个TableLayout布局的实例及效果图

<?xml version='1.0' encoding='utf-8'?><LinearLayout xmlns:android='http://schemas.android.com/apk/res/android'android:orientation='vertical'android:layout_width='fill_parent'android:layout_height='fill_parent'android:padding='3dip'><!-- 第1个TableLayout,用于描述表中的列属性。第0列可伸展,第1列可收缩,第2列被隐藏--><TextViewandroid:text='表1:全局设置:列属性设置'android:layout_height='wrap_content'android:layout_width='wrap_content'android:textSize='15sp'android:background='#7f00ffff'/><TableLayoutandroid:id='@+id/table1'android:layout_width='fill_parent'android:layout_height='wrap_content'android:stretchColumns='0'android:shrinkColumns='1'android:collapseColumns='2'android:padding='3dip'><TableRow><Button android:text='该列可伸展'/><Button android:text='该列可收缩'/><Button android:text='我被隐藏了'/></TableRow><TableRow><TextView android:text='我向行方向伸展,我可以很长 '/><TextView android:text='我向列方向收缩,我可以很深'/></TableRow></TableLayout><!-- 第2个TableLayout,用于描述表中单元格的属性,包括:android:layout_column 及android:layout_span--><TextViewandroid:text='表2:单元格设置:指定单元格属性设置'android:layout_height='wrap_content'android:layout_width='wrap_content'android:textSize='15sp'android:background='#7f00ffff'/><TableLayoutandroid:id='@+id/table2'android:layout_width='fill_parent'android:layout_height='wrap_content'android:padding='3dip'><TableRow><Button android:text='第0列'/><Button android:text='第1列'/><Button android:text='第2列'/></TableRow><TableRow><TextView android:text='我被指定在第1列' android:layout_column='1'/></TableRow><TableRow><TextViewandroid:text='我跨1到2列,不信你看!'android:layout_column='1'android:layout_span='2'/></TableRow></TableLayout><!-- 第3个TableLayout,使用可伸展特性布局--><TextViewandroid:text='表3:应用一,非均匀布局'android:layout_height='wrap_content'android:layout_width='wrap_content'android:textSize='15sp'android:background='#7f00ffff'/><TableLayoutandroid:id='@+id/table3'android:layout_width='fill_parent'android:layout_height='wrap_content'android:stretchColumns='*'android:padding='3dip'><TableRow><Button android:text='一' ></Button><Button android:text='两字'></Button><Button android:text='三个字' ></Button></TableRow></TableLayout><!-- 第4个TableLayout,使用可伸展特性,并指定每个控件宽度一致,如1dip--><TextViewandroid:text='表4:应用二,均匀布局'android:layout_height='wrap_content'android:layout_width='wrap_content'android:textSize='15sp'android:background='#7f00ffff'/><TableLayoutandroid:id='@+id/table4'android:layout_width='fill_parent'android:layout_height='wrap_content'android:stretchColumns='*'android:padding='3dip'><TableRow><Button android:text='一' android:layout_width='1dip'></Button><Button android:text='两字' android:layout_width='1dip'></Button><Button android:text='三个字' android:layout_width='1dip'></Button></TableRow></TableLayout></LinearLayout>
说明:第4TableLayout里的均匀布局的均匀效果是有限的。其有限性体现在,当该行有N列,则每列的控件内容不能多于1/N运行效果图:(如图1



0 0
原创粉丝点击