Android六大界面布局
来源:互联网 发布:好用的旅游软件知乎 编辑:程序博客网 时间:2024/05/21 15:00
Android六大界面布局方式:
声明Android程序布局有两种方式:
1) 使用XML文件描述界面布局;
2) 在Java代码中通过调用方法进行控制。
我们既可以使用任何一种声明界面布局的方式,也可以同时使用两种方式。
使用XML文件声明有以下3个特点:
- 1) 将程序的表现层和控制层分离;
- 2) 在后期修改用户界面时,无须更改程序的源程序;
- 3) 可通过WYSIWYG可视化工具直接看到所设计的用户界面,有利于加快界面设计的过程。
建议尽量采用XML文件声明界面元素布局。在程序运行时动态添加界面布局会大大降低应用响应速度,但依然可以在必要时动态改变屏幕内容。
六大界面布局方式包括: 线性布局(LinearLayout)、框架布局(FrameLayout)、表格布局(TableLayout)、相对布局(RelativeLayout)、绝对布局(AbsoluteLayout)和网格布局(GridLayout) 。
1. LinearLayout线性布局
LinearLayout容器中的组件一个挨一个排列,通过控制android:orientation属性,可控制各组件是横向排列还是纵向排列。
LinearLayout的常用XML属性及相关方法
其中,gravity属性支持top, left, right, center_vertical, fill_vertical, center_horizontal, fill_horizontal, center, fill, clip_vertical, clip_horizontal。也可以同时指定多种对齐方式的组合。
LinearLayout子元素支持的常用XML属性及方法
2. TableLayout表格布局
TableLayout继承自Linearout,本质上仍然是线性布局管理器。表格布局采用行、列的形式来管理UI组件,并不需要明确地声明包含多少行、多少列,而是通过添加TableRow、其他组件来控制表格的行数和列数。
每向TableLayout中添加一个TableRow就代表一行;
每向TableRow中添加一个一个子组件就表示一列;
如果直接向TableLayout添加组件,那么该组件将直接占用一行;
在表格布局中,可以为单元格设置如下三种行为方式:
- Shrinkable:该列的所有单元格的宽度可以被收缩,以保证该表格能适应父容器的宽度;
- Strentchable:该列所有单元格的宽度可以被拉伸,以保证组件能完全填满表格空余空间;
- Collapsed:如果该列被设置为Collapsed,那么该列的所有单元格会被隐藏;
TableLayout的常用XML属性及方法
3. FrameLayout帧布局
FrameLayout直接继承自ViewGroup组件。帧布局为每个加入其中的组件创建一个空白的区域(称为一帧),每个子组件占据一帧,这些帧会根据gravity属性执行自动对齐。
FrameLayout的常用XM了属性及方法
4. RelativeLayout相对布局
RelativeLayout的XML属性及相关方法说明
为了控制该布局容器的各子组件的布局分布,RelativeLayout提供了一个内部类:RelativeLayout.LayoutParams。
RelativeLayout.LayoutParams里只能设为boolean的XML属性
RelativeLayout.LayoutParams里属性值为其他UI组件ID的XML属性
5. Android 4.0新增的网格布局GridLayout
GridLayout是Android4.0增加的网格布局控件,与之前的TableLayout有些相似,它把整个容器划分为rows × columns个网格,每个网格可以放置一个组件。性能及功能都要比tablelayout好,比如GridLayout布局中的单元格可以跨越多行,而tablelayout则不行,此外,其渲染速度也比tablelayout要快。
GridLayout提供了setRowCount(int)和setColumnCount(int)方法来控制该网格的行和列的数量。
GridLayout常用的XML属性和方法说明
为了控制GridLayout布局容器中各子组件的布局分布,GridLayout提供了一个内部类:GridLayout.LayoutParams,来控制Gridlayout布局容器中子组件的布局分布。
GridLayout.LayoutParams常用的XML属性和方法说明
5. AbsoluteLayout绝对布局
即Android不提供任何布局控制,而是由开发人员自己通过X坐标、Y坐标来控制组件的位置。每个组件都可指定如下两个XML属性:
- layour_x;
- layout_y;
绝对布局已经过时,不应使用或少使用。
界面布局类型的选择和性能优化
首先得明确,界面布局类型的嵌套越多越深越复杂,会使布局实例化变慢,使Activity的展开时间延长。建议尽量减少布局嵌套,尽量减少创建View对象的数量。
1 . 减少布局层次,可考虑用RelativeLayout来代替LinearLayout。通过Relative的相对其他元素的位置来布局,可减少块状嵌套;
2 . 另一种减少布局层次的技巧是使用 <merge />
标签来合并布局;
3 . 重用布局。Android支持在XML中使用 <include />
标签, <include />
通过指定android:layout属性来指定要包含的另一个XML布局。
如:
<code style="padding: 0.3em; font-family: Monaco, Menlo, Consolas, 'Courier New', monospace; border: 0px; display: block; overflow-y: auto;"><span class="tag" style="color: rgb(0, 0, 128);"><<span class="title">include</span> <span class="attribute" style="color: rgb(0, 128, 128);">android:id</span>=<span class="value" style="color: rgb(221, 17, 68);">"@+id/id1"</span> <span class="attribute" style="color: rgb(0, 128, 128);">android:layout</span>=<span class="value" style="color: rgb(221, 17, 68);">"@layout/mylayout"</span>></span><span class="tag" style="color: rgb(0, 0, 128);"><<span class="title">include</span> <span class="attribute" style="color: rgb(0, 128, 128);">android:id</span>=<span class="value" style="color: rgb(221, 17, 68);">"@+id/id2"</span> <span class="attribute" style="color: rgb(0, 128, 128);">android:layout</span>=<span class="value" style="color: rgb(221, 17, 68);">"@layout/mylayout"</span>></span><span class="tag" style="color: rgb(0, 0, 128);"><<span class="title">include</span> <span class="attribute" style="color: rgb(0, 128, 128);">android:id</span>=<span class="value" style="color: rgb(221, 17, 68);">"@+id/id3"</span> <span class="attribute" style="color: rgb(0, 128, 128);">android:layout</span>=<span class="value" style="color: rgb(221, 17, 68);">"@layout/mylayout"</span>></span></code>
- Android六大界面布局
- Android中的六大布局
- Android之六大布局
- 简述Android六大布局
- android 六大布局
- Android中的六大布局
- android的六大布局
- android六大布局简介
- android中的六大布局
- Android 中的六大布局
- Android六大布局
- 简述Android六大布局样式
- Android六大基本布局详解
- Android六大布局的介绍
- Android六大布局的介绍
- Android基础布局之六大布局
- Android界面布局实例
- Android的界面布局
- Histogram of Oriented Gridients(HOG) 方向梯度直方图
- JS日期:根据出生日期 得到周岁年龄
- iOS_iTunesConnect协议更新导致无法构建新版本(协议、税务和银行业务)
- 栈的基本操作
- 【论文笔记】HyperFace: ADeep Multi-task Learning Framework for Face Detection
- Android六大界面布局
- Android常用的框架有哪些
- 基于struts2的文件上传
- 2.8 Spinner 列表选项框
- BITCS2016程序设计 | 3. 扫雷
- Hibernate从入门到精通(七)多对一单向关联映射
- java操作excel(jxl)
- 渗透测试:sqlmap伪静态注入与携带cookie登录认证注入
- rsyslog 解决日志截断不读取问题