Android开发之LinearLayout布局详解

Android开发之LinearLayout布局详解

        LinaerLayout又被称为线性布局,是Android界面开发中常用的一种容器视图控件。可以使用XML布局文件配置和代码动态创建两种方式来使用LinearLayout。使用LinearLayout可以十分轻松的布局出横向或者纵向线性堆叠界面,并且,嵌套使用LinearLayout也可以方便的布局出复杂的平面组合布局,通常情况下,ScrollView会与LinearLayout进行结合使用。在iOS9中推出的UIStackView、在watchOS开发中使用和核心布局模型Group与LinearLayout的思路十分一致,可见这种线性堆叠的布局方式在一定场景下十分有优势。

        使用代码动态创建LinearLayout示例如下:

 @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        //创建对象
        LinearLayout linearLayout = new LinearLayout(this);
        linearLayout.setBackgroundColor(Color.WHITE);
        setContentView(linearLayout);
        //设置布局方向 
        /*
          支持水平和竖直两种
          public static final int HORIZONTAL = 0;  水平线性布局
          public static final int VERTICAL = 1;    竖直线性布局
        */
        linearLayout.setOrientation(LinearLayout.VERTICAL);
        //设置显示分割线的模式
        /*
          public static final int SHOW_DIVIDER_NONE = 0; 不显示分割线
          public static final int SHOW_DIVIDER_BEGINNING = 1;  在开始处显示分割线
          public static final int SHOW_DIVIDER_MIDDLE = 2;  在子视图之间显示分割线
          public static final int SHOW_DIVIDER_END = 4;   在结束尾部显示分割线
        */
        linearLayout.setShowDividers(LinearLayout.SHOW_DIVIDER_MIDDLE);
        //设置分割线Drawable
        linearLayout.setDividerDrawable(ResourcesCompat.getDrawable(getResources(),R.drawable.line,null));
    }

LinearLayout中常用属性与方法,列举如下:

//获取分割线Drawable对象
Drawable getDividerDrawable ()
//获取分割线的padding值
int getDividerPadding ()
//获取子视图布局模式
int getGravity ()
//获取线性布局方向
int getOrientation ()
//获取展示分割线模式
int getShowDividers ()
//获取布局权重和
float getWeightSum ()
//设置是否允许计量最大子元素 与权重有关
boolean isMeasureWithLargestChildEnabled ()
//设置分割线Drawable
void setDividerDrawable (Drawable divider)
//设置分割线padding值
void setDividerPadding (int padding)
//设置子视图布局模式
/*
可选参数
AXIS_CLIP   //原始对齐
AXIS_PULL_AFTER  
AXIS_PULL_BEFORE
AXIS_SPECIFIED
AXIS_X_SHIFT
AXIS_Y_SHIFT
BOTTOM   //下对齐
CENTER   //居中对齐
CENTER_HORIZONTAL // 水平居中对齐
CENTER_VERTICAL   // 竖直居中对齐
CLIP_HORIZONTAL
CLIP_VERTICAL
DISPLAY_CLIP_HORIZONTAL
DISPLAY_CLIP_VERTICAL
END  //末尾对齐
FILL //充满
FILL_HORIZONTAL //水平充满
FILL_VERTICAL   //竖直充满
HORIZONTAL_GRAVITY_MASK
LEFT   //左对齐
NO_GRAVITY //空模式
RELATIVE_HORIZONTAL_GRAVITY_MASK
RELATIVE_LAYOUT_DIRECTION
RIGHT  //右对齐
START  //起始对齐
TOP   //上对齐
VERTICAL_GRAVITY_MASK
*/
void setGravity (int gravity)
//设置水平布局模式
void setHorizontalGravity (int horizontalGravity)
//设置布局方向
void setOrientation (int orientation)
//设置竖直布局模式
void setVerticalGravity (int verticalGravity)
//设置布局权重和
/*
当布局容器内子视图是通过权重来计算所占比例时 这个值表示权重总和
*/
void setWeightSum (float weightSum)
//设置子视图的触摸事件是否延迟执行
/*
这个属性用于类型ScrollView,ListView可以滑动的视图中,避免手势冲突
*/
boolean shouldDelayChildPressedState ()

专注技术,热爱生活,交流技术,也做朋友。 ——珲少 QQ群:435043639

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏超然的博客

深入了解——CSS3新增属性

写过 CSS 的人应该对 CSS 选择器不陌生,我们所定义的 CSS 属性之所以能应用到相应的节点上,就是因为 CSS 选择器模式。参考下述代码:

881
来自专栏C/C++基础

CSS中常见的长度单位

注意: (1)字体的尺寸指的是什么? 字体大小是指字在屏幕或印刷介质上表现出来的大小,将每个字看作方块,按方块的对角线长度计算大小。

1572
来自专栏我分享我快乐

web前端设计基础单词表

A align 对齐 active 激活 absolute 绝对 alpha 图像通道 animate 动画 animation 动画片 alert 提醒 ad...

3948
来自专栏GIS讲堂

Arcgis for JavaSctipt之常用Layer详解

概述:Arcgis for Javasctipt中常见的layer有动态图层(ArcGISDynamicMapServiceLayer

1695
来自专栏云加头条

Android图像处理-像素化的原理及实现

像素化(Pixelization),又称马赛克,是图像处理中非常常见的技术,现阶段已经成为了一种创作手段。本文首先会讲解像素化的实现原理,接着会给出Java版的...

5221
来自专栏前端知识分享

第167天:canvas绘制柱状图

2423
来自专栏前端知识分享

第103天:CSS3中Flex布局(伸缩布局)详解

Flex是Flexible Box的缩写,意为”弹性布局”,用来为盒状模型提供最大的灵活性。

951
来自专栏哈雷彗星撞地球

iOS下使状态栏颜色与H5中背景色一致

iOS 中有的页面也能会内嵌WebView,然后WebView中用H5做了一个导航,而iOS 中状态栏的颜色很难调整的与H5中导航颜色一致。如下图所示:

1594
来自专栏互联网杂技

30+有用的CSS代码片段

在一篇文章中收集所有的CSS代码片段几乎是不可能的事情,但是我们这里列出了一些相对于其他的更有用的代码片段,不要被这些代码的长度所吓到,因为它们都很容易实现,并...

3986
来自专栏lonelydawn的前端猿区

canvas星空的2d绘制示例

一切尽在注释里: <!DOCTYPE html> <html> <head>     <meta charset="utf-8"></meta>     <t...

2149

扫码关注云+社区

领取腾讯云代金券