android 布局中 layout_gravity、gravity、orientation、layout_weight

线性布局中,有 4 个及其重要的参数,直接决定元素的布局和位置,这四个参数是

android:layout_gravity ( 是本元素相对于父元素的重力方向 )

android:gravity (是本元素所有子元素的重力方向)

android:orientation (线性布局以列或行来显示内部子元素)

android:layout_weight (线性布局内子元素对未占用空间【水平或垂直】分配权重值,其值越小,权重越大。

前提是子元素 设置了 android:layout_width = "fill_parent" 属性(水平方向)

或 android:layout_height = "fill_parent" 属性(垂直方向)

如果某个子元素的 android:layout_width = "wrap_content"

           android:layout_height =" wrap_content”

则 android:layout_weight 的设置值 对该方向上空间的分配刚好相反。

下面以一个简单例子来说明这 4个参数

 1 <? xml version = "1.0" encoding = "utf-8" ?>
 2
 3 < LinearLayout xmlns:android = "http://schemas.android.com/apk/res/android"
 4
 5                            android:layout_height = "200dp"
 6
 7                            android:layout_width = "200dp"
 8
 9                            android:background = "#AABBCC"
10
11                            android:orientation= "horizontal"
12
13                            android:layout_gravity= "center" >
14
15                            < TextView android:text = "ONE"
16
17                                                android:background = "#aa0000"
18
19                                                android:layout_height = "wrap_content"
20
21                                                android:layout_width = "wrap_content"
22
23                                                android:layout_margin = "1dp" />
24
25                             < TextView android:text = "TWO"
26
27                                                android:background = "#aa0000"
28
29                                                android:layout_height = "wrap_content"
30
31                                                android:layout_width = "wrap_content"
32
33                                                android:layout_margin = "1dp" />
34
35 </ LinearLayout >

说明:在上面的例子中,根布局是LinearLayout, 其包含有2 个TextView 视图,为了对参数 android:layout_gravity有直观的了解,对根布局 LinearLayout 特意加了 3 个参数

android:layout_height = "200dp"

android:layout_width   = "200dp"

android:background     = "#AABBCC"

为布局指定了固定的宽度和高度,以及背景颜色,上面的例子运行后效果如下图:

说明:对LinearLayout 中的参数android:layout_gravity 来说,其意义是指定本布局相对于父布局的重力方向,由于该布局的已经是根布局,其父布局是整个屏幕,那么该参数设置的是相对于屏幕的位置,可以换不同的参数top|bottom|left|right 等等参数来试验。

现在增加参数 android:gravity = "bottom|right" 完整 XML 如下,看看效果

 1 <? xml version = "1.0" encoding = "utf-8" ?>
 2
 3 < LinearLayout xmlns:android = "http://schemas.android.com/apk/res/android"
 4
 5                       android:layout_height = "200dp"
 6
 7                       android:layout_width = "200dp"
 8
 9                       android:background = "#AABBCC"
10
11                       android:orientation="horizontal"
12
13                       android:layout_gravity= "center"
14
15                       android:gravity = "bottom|right " >
16
17                       < TextView android:text = "ONE"
18
19                                      android:background = "#aa0000"
20
21                                      android:layout_height = "wrap_content"
22
23                                      android:layout_width = "wrap_content"
24
25                                      android:layout_margin = "1dp" />
26
27                       < TextView android:text = "TWO"
28
29                                      android:background = "#aa0000"
30
31                                      android:layout_height = "wrap_content"
32
33                                      android:layout_width = "wrap_content"
34
35                                      android:layout_margin = "1dp" />
36
37 </ LinearLayout >

通过改变android:gravity 参数的值可以看到实际效果。

参数 android:orientation= " horizontal " 决定了每个子元素各占一列,如果

参数 android:orientation= " vertical " , 则每个子元素各占一行,也就是从上到下排列了。

对于 LinearLayout 布局的子元素,给每个子元素加上参数 android:layout_weight

看看效果

 1 <? xml version = "1.0" encoding = "utf-8" ?>
 2
 3 < LinearLayout xmlns:android = "http://schemas.android.com/apk/res/android"
 4
 5                       android:layout_height = "200dp"
 6
 7                       android:layout_width = "200dp"
 8
 9                       android:background = "#AABBCC"
10
11                       android:layout_gravity = "center"
12
13                       android:gravity = "bottom|right"
14
15                       android:orientation = "horizontal" >
16
17                       < TextView android:text = "ONE"
18
19                                      android:background = "#aa0000"
20
21                                      android:layout_height = "wrap_content"
22
23                                      android:layout_width = "wrap_content"
24
25                                      android:layout_margin = "1dp"
26
27                                      android:layout_weight = "1" />
28
29                       < TextView android:text = "TWO"
30
31                                      android:background = "#aa0000"
32
33                                      android:layout_height = "wrap_content"
34
35                                      android:layout_width = "wrap_content"
36
37                                      android:layout_margin = "1dp"
38
39                                      android:layout_weight = "2" />
40
41 </ LinearLayout >

Text 为ONE 的权重为1 ,但明显占的宽度比TWO 的小,百思不得其解,后来得知,如果把TextView 的参数android:layout_width = "wrap_content" 全部修改为 android:layout_width = "fill_parent", 则 ok ,代码如下

 1 <? xml version = "1.0" encoding = "utf-8" ?>
 2
 3 < LinearLayout xmlns:android = "http://schemas.android.com/apk/res/android"
 4
 5                       android:layout_height = "200dp"
 6
 7                       android:layout_width = "200dp"
 8
 9                       android:background = "#AABBCC"
10
11                       android:layout_gravity = "center"
12
13                       android:gravity = "bottom|right"
14
15                       android:orientation = "horizontal" >
16
17                       < TextView android:text = "ONE"
18
19                                      android:background = "#aa0000"
20
21                                      android:layout_height = "wrap_content"
22
23                                      android:layout_width = " fill_parent "
24
25                                      android:layout_margin = "1dp"
26
27                                      android:layout_weight = "1" />
28
29                       < TextView android:text = "TWO"
30
31                                      android:background = "#aa0000"
32
33                                      android:layout_height = "wrap_content"
34
35                                      android:layout_width = " fill_parent "
36
37                                      android:layout_margin = "1dp"
38
39                                      android:layout_weight = "2" />
40
41 </ LinearLayout >

android 布局中 layout_gravity、gravity、orientation、layout_weight,布布扣,bubuko.com

时间: 2024-11-02 23:37:25

android 布局中 layout_gravity、gravity、orientation、layout_weight的相关文章

android 布局中 layout_gravity、gravity、orientation、layout_weight【转】

线性布局中,有 4 个及其重要的参数,直接决定元素的布局和位置,这四个参数是 android:layout_gravity  ( 是本元素相对于父元素的重力方向 ) android:gravity        (是本元素所有子元素的重力方向) android:orientation    (线性布局以列或行来显示内部子元素) android:layout_weight  (线性布局内子元素对未占用空间[水平或垂直]分配权重值,其值越小,权重越大. 前提是子元素 设置了 android:layo

安卓开发技巧一:深入理解Android布局中Layout_weight的属性

今天开始将要为大家介绍一些安卓开发过程将要用到的一些技巧,这些技巧全部来自网络搜集,或者自己在企业做项目的时候总结出来的,利用这些技巧将会对我们开发带来非常方便的便捷性. 先来记录一下这一段时间的技巧目录,方便大家以后方便查阅(大概有不到三十种的技巧总结,大概每周分享两个技巧,笔者将尽可能写的详细,以及提供实例源码): 安卓开发技巧一:深入理解Android布局中Layout_weight的属性 安卓开发技巧二:自定义日志工具类 安卓开发技巧三:Activity的启动模式 安卓开发技巧四:分享一

Android 布局中的include标签使用

Android 布局中的include标签使用 最近在布局时,有好多页面都是有共同特点的,比如标题:一个同样的样式! 如下图所示: 如果给每个页面都单独的写一个标题的布局那就太麻烦了,如果能写一个标题布局,其它页面重用该多好! 这个时候,<include> 就隆重登场了! 写一个标题的布局 title.xml: <?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:an

android布局中使用include及需注意点

在android布局中,使用include,将另一个xml文件引入,可作为布局的一部分,但在使用include时,需注意以下问题: 一.使用include引入 如现有标题栏布局block_header.xml,代码如下: <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/layout_header" android:layout

从零开始学android开发-布局中 layout_gravity、gravity、orientation、layout_weight

线性布局中,有 4 个及其重要的参数,直接决定元素的布局和位置,这四个参数是 android:layout_gravity ( 是本元素相对于父元素的重力方向 ) android:gravity (是本元素所有子元素的重力方向) android:orientation (线性布局以列或行来显示内部子元素) android:layout_weight (线性布局内子元素对未占用空间[水平或垂直]分配权重值,其值越小,权重越大. 前提是子元素 设置了 android:layout_width = "

Android布局中 android:layout_gravity=&quot;bottom&quot;为何不起作用?

在android布局时我们有时会需要将位于LinearLayout布局中的控件放在布局底部,或者是同时想将几个控件底部对齐,此时我们自然会想到使用 android:layout_gravity="bottom" 将控件放在该线性布局底部,但是,但是这样是行不通的,这个问题今天也困扰了我很长时间,以为是自己其他地方布局搞错了或者其他地方搞错了才会出现这种情况,最后没办法查资料才发现以下规律: 在 LinearLayout布局时: 当总布局为水平布局时 即当 android:orienta

Android 布局中 如何使控件居中

首先要分两种不同情况,在两种不同的布局方式下:LinearLayout 和RelativeLayout 1. LinearLayout a). android:layout_gravity="center_horizontal"表示该布局在父布局里水平居中,此时其父布局必须拥有android:orientation="vertical"属性: b). android:layout_gravity="center_vertical"表示该布局在父布

【转】在Android布局中使用include和merge标签

内容转自:http://fengweipeng1208.blog.163.com/blog/static/21277318020138229754135/ 在我们开发android布局时,经常会有很多的布局是相同的,这个时候我们可以通过<include/>和<merge/>标签实现将复杂的布局包含在需要的布局中,减少重复代码的编写. 1. 创建一个可以重复使用的布局: 如下代码描述在应用中每个acitivity都出现的顶栏titlebar.xml 1 <FrameLayout

android布局中显示隐藏动画

android 在布局中提供属性,能简单的添加动画效果,如下: <LinearLayout ... animateLayoutChanges="true" ... /> 当对布局中的view添加删除,隐藏或显示, 都会有一个淡入淡出,和位移动画. 除了在XML布局文件中使用animateLayoutChanges 属性.也可以创建 LayoutTransition 对象通过 setLayoutTransition() 方法设置进去.源码如下: private ViewGro