LinearLayout线性布局

作用 :

线性布局会将容器中的组件一个一个排列起来, LinearLayout可以控制组件横向或者纵向排列,

通过android:orientation属性控制;



不换行属性 :

线性布局中的组件不会自动换行, 如果组件一个一个排列到尽头之后, 剩下的组件就不会显示出来;


常用属性:

(1)基线对齐

xml属性 : android:baselineAligned;

设置方法 : setBaselineAligned(boolean
b)
;

作用 : 如果该属性为false, 就会阻止该布局管理器与其子元素的基线对齐;

2)设分隔条

xml属性 : android:divider;

设置方法 : setDividerDrawable(Drawable);

作用 :
设置垂直布局时两个按钮之间的分隔条;

(3)对齐方式(控制内部子元素)

xml属性 : android:gravity;

设置方法 : setGravity(int);

作用 : 设置布局管理器内组件(子元素)的对齐方式,

支持的属性 :

top, bottom,
left, right,center_vertical(垂直方向居中), center_horizontal(水平方向居中),fill_vertical(垂直方向拉伸), fill_horizontal(水平方向拉伸),center,
fill,clip_vertical, clip_horizontal可以同时指定多种对齐方式
: 如 left|center_vertical
左侧垂直居中;

(4)权重最小尺寸

xml属性 : android:measureWithLargestChild;

设置方法 : setMeasureWithLargestChildEnable(boolean
b)
;

作用
: 该属性为true的时候, 所有带权重的子元素都会具有最大子元素的最小尺寸;

(5)
排列方式

xml属性 : android:orientation;

设置方法 : setOrientation(int i);

作用
: 设置布局管理器内组件排列方式, 设置为horizontal(水平),vertical(垂直),
默认为垂直排列;


LinearLayout子元素控制

LinearLayout的子元素,
即LinearLayout中的组件, 都受到LinearLayout.LayoutParams控制,
因此LinearLayout包含的子元素可以执行下面的属性.

(1)对齐方式

xml属性 : android:layout_gravity;

作用
: 指定该元素在LinearLayout(父容器)的对齐方式, 也就是该组件本身的对齐方式, 注意要与android:gravity区分,
;

(2)所占权重

xml属性 : android:layout_weight;

作用
: 指定该元素在LinearLayout(父容器)中所占的权重, 例如都是1的情况下,
那个方向(LinearLayout的orientation方向)长度都是一样的;


控制子元素排列 与 在父元素中排列

控制本身元素属性与子元素属性
:

设备组件本身属性 带layout的属性是设置本身组件属性, 例如 android:layout_gravity设置的是本身的对其方式;

设置子元素属性 : 不带layout的属性是设置其所包含的子元素, 例如android:gravity 设置的是该容器子组件的对齐方式;

LayoutParams属性 :
所有的布局管理器都提供了相应的LayoutParams内部类, 这些内部类用于控制该布局本身, 如 对齐方式 layout_gravity, 所占权重
layout_weight, 这些属性用于设置本元素在父容器中的对齐方式;

容器属性 :
在android:后面没有layout的属性基本都是容器属性, android:gravity作用是指定指定本元素包含的子元素的对齐方式,
只有容器才支持这个属性;


常见用法

(1)
获取LinearLayout的宽高

a. 组件外无法获取组件宽高

下面的两种情况都是针对 View.getHeight() 和 View.getWidth()
方法
:

组件外无法获取 : 调用View.getHeight()View.getWidth()方法 是获取不到组件的宽度和高度的,
这两个方法返回的是0, Android的运行机制决定了无法在组件外部使用getHeight()和getWidth()方法获取宽度和高度;

组件内可以获取 : 在自定义的类中可以在View的类中通过调用这两个方法获取该View子类组件的宽和高;

b. 组件外部获取View对象宽高方法

外部获取 : 使用View.getMeasuredWidth()View.getMeasuredHeight()方法可以获取组件的宽和高,
在调用这个方法之前, 必须先调用View.measure()方法, 才可以,
否则也获取不到组件的宽高;

注意(特例) : 如果组件宽度或高度设置为 fill_parent, 使用
getMeasuredHeight() 等方法获取宽度和高度的时候, 并且组件中含有子元素时,
所获取的实际值是这些组件所占的最小宽度和最小高度.(没看懂)

View view = getLayoutInflater().inflate(R.layout.main, null);

LinearLayout layout = (LinearLayout) view.findViewById(R.id.linearlayout);

//调用测量方法, 调用了该方法之后才能通过getMeasuredHeight()等方法获取宽高

layout.measure(0, 0);

//获取宽度

int width = layout.getMeasuredWidth();

//获取高度

int height = layout.getMeasuredHeight();

c.
获取布局文件中组件的宽高

从LayoutParams中获取 :
调用View.getLayoutParams().width 和 View.getLayoutParams().height 获取宽高, 如果宽高被设定为
fill_parent, match_parent, warp_content 时, 这两个两边直接回返回 FILL_PARENT, MATCH_PARENT,
WARP_CONTENT常量值;

规律 : 从View.getLayoutParams()中获取 width, height
值, 在布局xml文件中设置的是什么, 获取的时候就得到的是什么;

(2)
在LinearLayout中添加分隔线

a.
使用ImageView添加(低版本3.0以下)

垂直布局 横向宽度填满 : 如果布局是vertical,
那么设置一个ImageView宽度fill_parent, 高度2dp, 设置一个背景色;

水平布局 纵向高度填满 : 如果布局时horizontal,
那么设置一个ImageView宽度2dp, 高度fill_parent, 设置一个背景色;

<ImageView

android:layout_width="fill_parent"

android:layout_height="2dp"

android:background="#F00"/>

b.
使用xml属性添加(3.0以上版本)

设置LinearLayout标签的
android:showDividers属性,
该属性有四个值 :

none :不显示分隔线;

beginning : 在LinearLayout开始处显示分隔线;

middle : 在LinearLayout中每两个组件之间显示分隔线;

end : 在LinearLayout结尾处显示分隔线;

设置android:divider属性, 这个属性的值是一个Drawable的id;

c.
使用代码添加(3.0以上版本)

设置显示分隔线样式 :
linearLayout.setShowDividers(), 设置android:showDividers属性;

设置分隔线图片 :
linearLayout.setDividerDrawable(), 设置android:divider属性;

时间: 2024-11-09 15:43:59

LinearLayout线性布局的相关文章

2.2.1 LinearLayout(线性布局)

本节引言 本节开始讲Android中的布局,Android中有六大布局,分别是: LinearLayout(线性布局),RelativeLayout(相对布局),TableLayout(表格布局) FrameLayout(帧布局),AbsoluteLayout(绝对布局),GridLayout(网格布局) 而今天我们要讲解的就是第一个布局,LinearLayout(线性布局),我们屏幕适配的使用 用的比较多的就是LinearLayout的weight(权重属性),在这一节里,我们会详细地解析 L

布局Layouts之LinearLayout线性布局

从Hello world!开始,我们一直都是在一种布局下学习的,当然,对于基础内容的学习,还是没有任何问题的!但-- 在Android开发中UI设计也是十分重要的,当用户使用一个App时,最先感受到的不是这款软件的功能是否强大,而是界面设计是否赏心悦目,用户体验是否良好.也可以这样说,有一个好的界面设计去吸引用户的使用,才能让更多的用户体验到软件功能的强大. 那么,Android中几种常用布局则显得至关重要.各个布局既可以单独使用,也可以嵌套使用,我们应该在实际应用中应灵活变通. 第2章.Lin

android 59 LinearLayout 线性布局

##常见的布局* LinearLayout 线性布局线性布局往左右拉是拉不动的,> 线性布局的朝向 vertical|horizontal> 线性布局的权重 weight 和 0dip一起使用 <?xml version="1.0" encoding="utf-8"?> <!-- 线性布局控件自上而下整齐的排列 --> <LinearLayout xmlns:android="http://schemas.andr

布局Layouts之LinearLayout线性布局(转)

从Hello world!开始,我们一直都是在一种布局下学习的,当然,对于基础内容的学习,还是没有任何问题的!但—— 在Android开发中UI设计也是十分重要的,当用户使用一个App时,最先感受到的不是这款软件的功能是否强大,而是界面设计是否赏心悦目,用户体验是否良好.也可以这样说,有一个好的界面设计去吸引用户的使用,才能让更多的用户体验到软件功能的强大. 那么,Android中几种常用布局则显得至关重要.各个布局既可以单独使用,也可以嵌套使用,我们应该在实际应用中应灵活变通. LinearL

Android基础入门教程——2.2.1 LinearLayout(线性布局)

Android基础入门教程--2.2.1 LinearLayout(线性布局) 标签(空格分隔): Android基础入门教程 本节引言: 本节开始讲Android中的布局,Android中有六大布局,分别是: LinearLayout(线性布局),RelativeLayout(相对布局),TableLayout(表格布局) FrameLayout(帧布局),AbsoluteLayout(绝对布局),GridLayout(网格布局) 而今天我们要讲解的就是第一个布局,LinearLayout(线

New UI-布局之LinearLayout(线性布局)详解

New UI-布局之LinearLayout(线性布局)详解  --转载请注明出处:coder-pig,欢迎转载,请勿用于商业用途! 小猪Android开发交流群已建立,欢迎大家加入,无论是新手,菜鸟,大神都可以,小猪一个人的 力量毕竟是有限的,写出来的东西肯定会有很多纰漏不足,欢迎大家指出,集思广益,让小猪的博文 更加的详尽,帮到更多的人,O(∩_∩)O谢谢! 小猪Android开发交流群:小猪Android开发交流群群号:421858269 新Android UI实例大全目录:http://

android学习——LinearLayout线性布局

LinearLayout线性布局 LinearLayout是一种线型的布局方式.LinearLayout布局容器内的组件一个挨着一个地排列起来:不仅可以控制个组件横向排列,也可控制各组件纵向排列.通过orientation属性设置线性排列的方向是垂直(vertical)还是纵向(horizontal). 我们下面通过XML布局和Java代码布局两种方式分别举例: 一.XML方式布局 1.创建一个空白Activity 2.打开“res/layout/activity_main.xml”文件,修改成

Android精通:View与ViewGroup,LinearLayout线性布局,RelativeLayout相对布局,ListView列表组件

UI的描述 对于Android应用程序中,所有用户界面元素都是由View和ViewGroup对象构建的.View是绘制在屏幕上能与用户进行交互的一个对象.而对于ViewGroup来说,则是一个用于存放其他View和ViewGroup对象的布局容器! Android为我们提供了View和ViewGroup的两个子类的集合,提供常用的一些输入控件(比如按钮,图片和文本域等)和各种各样的布局模式(比如线程布局,相对布局,绝对布局,帧布局,表格布局等). 用户界面布局 在你APP软件上的,用户界面上显示

Android中LinearLayout线性布局

android:orientation="vertical"垂直线性布局,"horizontal"水平线性布局 android:gravity="top"(buttom.left.right.center_vertical.fill_vertical.center_horizontal.fill_horizontal.center.fill.clip_vertical.clip_horizontal)控制布局中控件的对齐方式.如果是没有子控件的控