常用的UI布局
- LinearLayout 线性布局
- RelativeLayout 相对布局
- FrameLayout 帧布局
- TableLayout 表格布局
- AbsoluteLayout 绝对布局
- GridLayout 4.0 版本新特性, 网格布局
布局定义方式
在layout目录下新建一个xml文件,按照布局格式布局。
xml中每个元素的是View或者ViewGroup的子孙类的对象。他就像一颗树一样,根节点只有一个ViewGroup,叶节点都是View对象,分支节点都是ViewGroup
常用布局属性
- xxdp: 占用xx个设备独立像素,常用
- xxsp: 常用语字体大小的标识中。
-
xxpx: 占用xx个像素,不利于屏幕适配,一般不用
-
android:laout_width
和android:layout_height
属性表示该控件的宽度和高度,可取如下值:
wrap_content 控件占用自身大小的空间
match_content 控件占满其父空间,早期版本叫做fill_content android:layout_margin**(Left, Right, Top, Bottom)
设置控件距离其他控件左右上下的间距。android:padding_**(Left, Right, Top, Bottom)
设置控件内容距离空间的左右上下边界的间距。android:layout_gravity
属性用于设置控件在父控件中的对其属性,如left(左对齐)right(右对齐)center(居中)等android:gravity
是设置当前控件的内容在当前控件内部的对其属性,可取值与layout_gravity一样。android:id
为控件指定相应的IDandroid:text
指定控件当中显示的文字,需要注意的是,这里尽量使用strings.xml文件当中的字符串android:textSize
指定控件当中字体的大小android:background
指定该控件所使用的背景色,RGB命名法android:width
指定控件的宽度android:height
指定控件的高度
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 离某元素上边缘的距离