线性布局与相对布局

  • 线性布局(LinearLayout):该标签下的所有子元素会根据orientation属性的值来决定是按行或者是按列来逐个显示。
  • 相对布局(RelativeLayout),按照各子元素之间的位置关系完成布局。

线性 布局中

 LinearLayout  是一个线性容器 用来包裹基本的显示控件(如:button等)。
 容器也有大小 指定宽度和高度。
 线性容器指的是容器中的控件是一个挨着一个排列的,它有两种排列方式:一种是横向排列  一种是纵向排列,(它的默认排列方式是横向排列)

  横向排列 android:orientation="horizontal"
  纵向排列 android:orientation="vertical"


线性布局中内所有元素的对齐方式:
将所有的子控件水平居中  android:gravity="center_vertical"
将所有的子控件垂直居中  android:gravity="center_horizontal"
将所有的子控件排列到中心 android:gravity="center"
将所有的子控件左对齐      android:gravity="left"
将所有的子控件左对齐     android:gravity="right"
将所有的子控件上对齐     android:gravity="top"
将所有的子控件下对齐    android:gravity="bottom"


<!-- 创建线性布局 -->   
    <LinearLayout 
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:background="#c1d2c3"
        android:orientation="vertical"
        android:gravity="center">
        
     <Button 
          android:layout_width="100dp"
          android:layout_height="50dp"
          android:background="#00e500"
          android:text="button1"/>
     
     
         <Button 
          android:layout_marginTop="20dp"
          android:layout_width="100dp"
          android:layout_height="100dp"
          android:background="#00a2c3"
          android:text="button2"/>
     
    </LinearLayout>

线性布局 如图所示

`

相对 布局中

相对布局对齐方式(子控件相对于父控件,在子控件上设置)
设置相对布局中 单个控件 垂直居中android:layout_centerHorizontal="true"
设置相对布局中 单个控件水平居中android:layout_centerVertical="true"
设置相对布局中 单个控件居中android:layout_centerInParent="true"
设置相对布局中 单个控件 左边对齐android:layout_alignParentLeft="true"
设置相对布局中 单个控件 右边对齐android:layout_alignParentRight="true"
设置相对布局中 单个控件 顶部对齐android:layout_alignParentTop="true"
设置相对布局中 单个控件 底部对齐android:layout_alignParentBottom="true"



android:id="@+id/button_1"     是为控件添加一个身份标识  ID 

android:layout_above="@id/button_1" 是相对布局中 把当前控件放到id为 button_1的上面
android:layout_below="@id/button_1" 是相对布局中 把当前控件放到id为 button_1的下面
android:layout_toLeftOf="@id/button_1"是相对布局中 把当前控件放到id为 button_1的左面
android:layout_toRightOf="@id/button_1"是相对布局中 把当前控件放到id为 button_1的右面





<!-- 创建相对布局 -->
    
    <RelativeLayout 
        android:layout_width="match_parent"
        android:layout_height="match_parent"
      android:background="#d1d2c3"
      android:gravity="center" >
        
      <Button 
          android:id="@+id/button1"
          android:layout_width="100dp"
          android:layout_height="50dp"
          android:background="#00e500"
          android:text="button1" />
        
      <Button
          android:layout_below="@id/button1"
          android:layout_marginTop="20dp"
          android:layout_width="100dp"
          android:layout_height="100dp"
          android:background="#00a2c3"
          android:text="button2"/>

    </RelativeLayout>

相对布局 如图所示

注:上面两个虽视图相同 但其中代码结构不同

match_parent 填充窗体
wrap_content 包裹内容体
例如:android:layout_width="match_parent"        宽度填充窗体
      android:layout_height="wrap_content"       高度包裹内容体

 android:background="#c1d2c3"  设置 背景颜色

android:text="确定"                 设置文字
android:textColor="#000000"         设置文字的颜色
android:textSize="12sp"          设置文字的大小
android:textStyle="bold"             设置字体加粗

android:hint="QQ号/手机号/邮箱"      设置提示文字(输入框中指定的提示语)  
android:textColorHint="#d3d3d3"      设置提示文字的颜色

android:src="@mipmap/picture"        用来加载图片  
  
            

设置外部 间距:
设置控件距离外部的左边 10dp          android:layout_marginLeft="10dp"
设置控件距离外部的右边 10dp          android:layout_marginRight="10dp"
设置控件距离外部的上边 10dp          android:layout_marginTop="10dp"
设置控件距离外部的下边 10dp          android:layout_marginBottom="10dp"
同时设置控件距离外部边距 的上下左右 为10dp    android:layout_marging="10dp"

设置内部间距
设置控件内部所有的内容距离该控件底部10dp    android:paddingBottom="10dp"
设置控件内部所有的内容距离该控件左边10dp    android:paddingLeft="10dp"
设置控件内部所有的内容距离该控件右边10dp    android:paddingRight="10dp"
设置控件内部所有的内容距离该控件顶部10dp    android:paddingTop="10dp"
同时设置 上 下 左 右  的内边距 为10dp      android:padding="10dp"


最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,014评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,796评论 3 386
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,484评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,830评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,946评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,114评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,182评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,927评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,369评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,678评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,832评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,533评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,166评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,885评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,128评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,659评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,738评论 2 351

推荐阅读更多精彩内容