1、LinearLayout(线性布局):将布局所包含的控件在线性方向上依次排列。
<1>android:orientation 指定了排列方向(垂直方向(vertical)、水平方向(horizontal))
<2>android:layout_gravity 用于指定控件在布局中的对齐方式(站在子控件的角度)
a.当LinearLayout的排列方向是horizontal时,只有垂直方向上的对齐方式才会生效;
b.当LinearLayout的排列方向是vertical时,只有水平方向上的对齐方式才会生效。
<3>android:weight 允许通过比例的方式来指定控件的大小,在手机屏幕的适配性方面可以起到非常重要的作用
<4>xmlns:android..... 命名控件(和java文件中的import语句功能类似)
<5>android:layout_width 定义当前的布局或者控件的宽度
<6>android:layout_height 定义当前的布局或者控件的高度(宽高值是必须的属性)
<7>android:padding 内边距。当前控件或者布局的内边缘距离里面子控件或者内容的距离,距离值得单位是dp
<8>android:gravity 让当前布局或者控件的内容或者子布局排列的方式(站在父控件的角度)
2、RelativeLayout(相对布局):通过相对定位的方式让控件出现在布局的任何位置。
<1>android:layout_above 表示让一个控件位于另一个控件的上方需要指定相对控件的id的引用
<2>android:layout_below 表示让一个控件位于另一个控件的下方
<3>android:layout_toRightOf 表示让一个控件位于另一个控件的右侧
<4>android:layout_toLeftOf 表示让一个控件位于另一个控件的左侧
<5>当一个控件去引用另一个控件的id时,该控件一定要定义在引用控件的后面,不然会出现找不到id的情况
<6>android:layout_alignLeft 表示让一个控件的左边缘和另一个控件的左边缘对齐
<7>android:layout_alignRight 表示让一个控件的右边缘和另一个控件的右边缘对齐
<8>android:layout_alignTop 表示让一个控件的上边缘和另一个控件的上边缘对齐
<9>android:layout_alignBottom 表示让一个控件的下边缘和另一个控件的下边缘对齐
<10>android:layout_alignBaseline表示和xx基准线对齐(文本对齐)
<11>android:layout_margin 外边距。当前控件或者布局的外边缘距离最近的控件或者布局的距离
a.内边距:主要把控件里边的间距拉大
b.外边距:主要是把控件与控件之间的距离拉大
<12>android:layout_alignParentRight="true" 表示让一个控件与父布局右对齐
<13>android:layout_alignParentBottom="true" 表示让一个控件与父布局下对齐
 
<14>android:layout_alignParentLeft="true" 表示让一个控件与父布局左对齐
<15>android:layout_alignParentTop="true" 表示让一个控件与父布局上对齐
<16>android:layout_centerHorizontal="true" 表示让一个控件在父布局中水平方向上居中
<17>android:layout_centerVertical="true" 表示让一个控件在父布局中垂直方向上居中
<18>android:layout_centerInParent="true 表示让一个控件在父布局的中心
3、FrameLayout(帧布局):直接继承了ViewLayout组件
帧布局容器为每个加入其中的组件创建一个空白的区域(称为一帧),每个子组件占据一帧,这些帧会根据gravity属性执行自动对齐
<1>android:foreground 设置该帧布局容器的前景图像
<2>android:forefroundGravity 定义绘制前景图像的gravity属性
4、TableLayout(表格布局):继承了LinearLayout
在表格布局管理器中,有以下三种行为方式:
<1>Shrinkable:如果某个列被设为Shrinkable,那么该列的所有单元格的宽度可以被收缩,以保证该表格能适应父容器的宽度;
<2>Strechable:如果某个列被设为Strechable,那么该列的所有单元格的宽度可以被拉伸,以保证组件能完全填满表格空余空间;
<3>Collapsed:如果某个列被设为Collapsed,那么该列的所有单元格会被隐藏。
TableLayout继承了LinearLayout,因此它支持LinearLayout所支持的全部XML属性,除此以外,还支持以下属性:
<1>android:collapseColumns setColumnCollapsed(int,boolean) 设置需要被隐藏的列的列序号(从0开始)
<2>android:shrinkColumns setShrinkAllColumns(boolean) 设置允许被收缩的列的列序号(从0开始)
<3>android:stretchColumns setStrechAllColumns(boolean) 设置允许被拉伸的列的列序号(从0开始)
<4>每加入一个TableRow就表示在表格中添加了一行,然后在TableRow中每加入一个控件,就表示在该行中加入了一列(TableRow中的控件不可以指定宽度)
5、GridLayout(网格布局)
<1>android:alignmentMode 设置该布局管理器采用的对齐模式
<2>android:columnCount 设置该网格的列数量
<3>android:columnOrderPreserved 设置该网格容器是否保留列序号
<4>android:rowCount 设置该网格的行数量
<5>android:rowOrderPreserved 设置该网格容器是否保留航序号
<6>android:useDefaultMargins 设置该布局管理器是否使用默认的页边距
<7>android:layout_column 设置该子组件在GridLayout的第几列 
<8>android:layout_columnSpan 设置该子组件在GridLayout横向上跨几列
<9>android:layout_gravity 设置该子组件采用何种方式占据该网格的空间
<10>android:layout_row 设置该子组件在GridLayout的第几行
<11>android:layout_rowSpan 设置该子组件在GridLayout纵向上跨几行
6、AbsoluteLayout(绝对布局):已经过时,官方已经不推荐使用
<1>layout_x 指定该子组件的X坐标
<2>layout_y 指定该子组件的Y坐标

常用UI布局的更多相关文章

  1. jquery实现常用UI布局

    tab html <div class="tab"> <ul class="tab-title"> <li class=" ...

  2. 常用前端布局,CSS技巧介绍

    常用前端布局,CSS技巧介绍 对前端常用布局的整理总结,并对其性能优劣,兼容等情况进行介绍 css常用技巧之可变大小正方形的绘制 1:若通过设置width为百分比的方式,则高度不能通过百分比来控制. ...

  3. Android开发 UI布局

    Android开发 UI布局一.线性布局LinearLayout 什么是线性布局? 其实呢,线性布局就是把所有的孩子摆在同一条线上 <?xml version="1.0" e ...

  4. Duilib源码分析(五)UI布局—Layout与各子控件

    接下来,继续分析duilib之UI布局Layout,目前提供的布局有:VerticalLayout.HorizontalLayout.TileLayout.TabLayout.ChildLayout分 ...

  5. iOS-屏幕适配-UI布局

    iOS 屏幕适配:autoResizing autoLayout和sizeClass 一.图片解说 -------------------------------------------------- ...

  6. AppleWatch___学习笔记(二)UI布局和UI控件

    1.UI布局 直接开发,你会发现Apple Watch并不支持AutoLayout,WatchKit里有个类叫做WKInterfaceGroup,乍一看像是UIView,但是这货其实是用来布局的.从 ...

  7. DIV+CSS常用网页布局技巧!

    以下是我整理的DIV+CSS常用网页布局技巧,仅供学习与参考! 第一种布局:左边固定宽度,右边自适应宽度 HTML Markup <div id="left">Left ...

  8. iOS开发~UI布局(三)深入理解autolayout

    一.概要 通过对iOS8界面布局的学习和总结,发现autolayout才是主角,autolayout是iOS6引入的新特性,当时还粗浅的学习了下,可是没有真正应用到项目中.随着iOS设备尺寸逐渐碎片化 ...

  9. iOS开发~UI布局(二)storyboard中autolayout和size class的使用详解

    一.概要:前一篇初步的描述了size class的概念,那么实际中如何使用呢,下面两个问题是我们一定会遇到的: 1.Xcode6中增加了size class,在storyboard中如何使用? 2.a ...

随机推荐

  1. java 几种常见的定时器

    今天闲着没事就总结了一下在java中常用的几种定时器. 主要有3种java.util.Timer, ScheduledExecutorService和quartz 一.Timer 举个简单例子.每隔5 ...

  2. Unity3D脚本中文系列教程(四)

    http://dong2008hong.blog.163.com/blog/static/4696882720140302451146/ Unity3D脚本中文系列教程(三) 送到动画事件. ◆ va ...

  3. yum源万能

    sed -i ‘s|^#baseurl|baseurl| ; s|^mirrorlist|#mirrorlist|’ /etc/yum.repos.d/*

  4. java基础知识回顾之java Thread类--java线程实现常见的两种方式实现Runnable接口(二)

    创建线程的第二中方式: /** *      步骤: 1定义类实现Runnable接口      2.实现Runnable接口中的run方法.      3.通过Thread类建立线程对象,并将Run ...

  5. django如何用orm增加manytomany关系字段(自定义表名)

    不自定义表名的,网上有现成的,但如果自定义之后,则要变通一下了. app_insert = App.objects.get(name=app_name) site_insert = Site.obje ...

  6. Project Euler 75:Singular integer right triangles

    题目链接 原题: It turns out that 12 cm is the smallest length of wire that can be bent to form an integer ...

  7. netty是什么?

    Netty是什么? 相对于Tomcat这种Web Server(顾名思义主要是提供Web协议相关的服务的),Netty是一个Network Server,是处于Web Server更下层的网络框架,也 ...

  8. SSL/TLS/WTLS原理(密钥协商的形象化比喻:验证服务器的身份,用服务器的公钥协商加密格式,然后再加密具体的消息,TCP传递SSL处理后的数据)good

    一 前言 首先要澄清一下名字的混淆: 1 SSL(Secure Socket Layer)是netscape公司设计的主要用于web的安全传输协议.这种协议在WEB上获得了广泛的应用. 2 IETF( ...

  9. Android 显示原理简介

    作者:yearzhu,2011年进入腾讯公司,从事过Web端及移动端的测试工作,喜爱新鲜事物及新技术,目前在SNG开放平台测试组负责的移动互联SDK的测试工作. 现在越来越多的应用开始重视流畅度方面的 ...

  10. [UESTC1059]秋实大哥与小朋友(线段树, 离散化)

    题目链接:http://acm.uestc.edu.cn/#/problem/show/1059 普通线段树+离散化,关键是……离散化后建树和查询都要按照基本法!!!RE了不知道多少次………………我真 ...