谈谈安卓几种布局

   我们都知道安卓中有六大布局:线性布局(LinearLayout)相对布局(RelativeLayout)绝对布局(AbsoluteLayout)表格布局(TableLayout)网格布局(GridLayout )帧(FrameLayout)。其实还有一个约束布局(ConstraintLayout),约束布局是相对布局的加强版,他以功能强大性能优减少嵌套可视化著称的,可也有代码复用性差难维护缺点。帧布局就是一层一层向上摆放的布局,重叠的元素上层会遮挡下层。默认子元素都是堆叠在左上角,可调整子元素位置。表格布局就是按照行列方式布局组件。网格布局和表格布局有点类似,不过它功能更多,也更加好用。绝对布局是按照绝对坐标来布局组件因适配性差现在基本废弃了。

下面就剩线性布局和相对布局了,这两个也是我们用的最多两种布局。小伙伴们在平时开发中是不是经常遇到这样问题,感觉明明各个控件属性都设置好了就是不生效达不到预期效果(这里指两种布局多成嵌套使用)尤其是改别人写的bug更是抓狂。其实还是没有把两种布局属性理解透彻掌握熟悉,线性布局他是按照垂直或者水平方向布局的组件,重点要掌握的是先设置好orientation属性,以及权重这个概念,很多人对权重一直朦朦胧胧,我们下篇博客专门讲解这个给你个万能公式直接使用。相对布局,顾名思义他是相对其它组件的布局方式。是根据其他控件id相对位置来排放的,如果把这些属性设置在线性布局他当时不生效。所以小伙伴们遇到问题,不要急 认真排查一遍缕清布局结构 一定能解决的。

下面附上一些资料,这是我看其他人总结的挺全的,供大家参考

线性布局常用属性:

 android:orientation:可以设置布局的方向,以列或行来显示。
 android:gravity:用来控制组件的对齐方式,相对于父元素的重力方向。
              layout_weight:控制各个组件在布局中的相对大小,对未占用空间水平或垂直分配权值。

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

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

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

android:layout_weight 子元素对未占用空间水平或垂直分配权重值


当 android:orientation="vertical"  时, 只有水平方向的设置才起作用,垂直方向的设置不起作用。即:left,right,center_horizontal 是生效的。!!!!

当 android:orientation="horizontal" 时, 只有垂直方向的设置才起作用,水平方向的设置不起作用。即:top,bottom,center_vertical 是生效的。!!!!


android:layout_gravity 和 android:gravity 的区别

android:gravity对元素本身起作用-本身元素显示在什么位置

android:layout_gravity相对与它的父元素-元素显示在父元素的什么位置。

如:Button控件

android:layout_gravity 表示button在界面上的位置

android:gravity表示button上的字在button上的位置。

可选值[多选时用“|”分开] 

top、bottom、left、right、center_vertical、fill_vertical、center_horizontal、fill_horizontal、center、fill、clip_vertical。

top 将对象放在其容器的顶部,不改变其大小. 

bottom 将对象放在其容器的底部,不改变其大小. 

left将对象放在其容器的左侧,不改变其大小. 

right将对象放在其容器的右侧,不改变其大小. 

center_vertical 将对象纵向居中,不改变其大小. 

垂直对齐方式:垂直方向上居中对齐。 

fill_vertical 必要的时候增加对象的纵向大小,以完全充满其容器. 垂直方向填充 

center_horizontal 将对象横向居中,不改变其大小水平对齐方式:水平方向上居中对齐 

fill_horizontal 必要的时候增加对象的横向大小,以完全充满其容器. 水平方向填充 

center 将对象横纵居中,不改变其大小. 

fill 必要的时候增加对象的横纵向大小,以完全充满其容器. 

clip_vertical 附加选项,用于按照容器的边来剪切对象的顶部和/或底部的内容. 剪切基于其纵向对齐设置:顶部对齐时,剪切底部;底部对齐时剪切顶部;除此之外剪切顶部和底部.垂直方向裁剪

clip_horizontal 附加选项,用于按照容器的边来剪切对象的左侧和/或右侧的内容. 剪切基于其横向对齐设置:左侧对齐时,剪切右侧;右侧对齐时剪切左侧;除此之外剪切左侧和右侧.水平方向裁剪

例子

TextView要让文本垂直/水平居中显示,有两种情况需要考虑:

1、layout_width/layout_height为wrap_content,此时要让TextView在父控件上居中显示,必须设置layout_gravity=”center”。

2、layout_width/layout_height为fill_parent,此时由于TextView已占据父窗体所有空间,必须设置gravity=”center”。

相对布局常用属性

RelativeLayout用到的一些重要的属性:
  第一类:属性值为true或false
  android:layout_centerHrizontal 水平居中
  android:layout_centerVertical 垂直居中
  android:layout_centerInparent 相对于父元素完全居中
  android:layout_alignParentBottom 贴紧父元素的下边缘
  android:layout_alignParentLeft 贴紧父元素的左边缘
  android:layout_alignParentRight 贴紧父元素的右边缘
  android:layout_alignParentTop 贴紧父元素的上边缘
  android:layout_alignWithParentIfMissing 如果对应的兄弟元素找不到的话就以父元素做参照物
  第二类:属性值必须为id的引用名“@id/id-name”
  android:layout_below 在某元素的下方
  android:layout_above 在某元素的的上方
  android:layout_toLeftOf 在某元素的左边
  android:layout_toRightOf 在某元素的右边
  android:layout_alignTop 本元素的上边缘和某元素的的上边缘对齐
  android:layout_alignLeft 本元素的左边缘和某元素的的左边缘对齐
  android:layout_alignBottom 本元素的下边缘和某元素的的下边缘对齐
  android:layout_alignRight 本元素的右边缘和某元素的的右边缘对齐
  第三类:属性值为具体的像素值,如30dip,40px
  android:layout_marginBottom 离某元素底边缘的距离
  android:layout_marginLeft 离某元素左边缘的距离
  android:layout_marginRight 离某元素右边缘的距离
  android:layout_marginTop 离某元素上边缘的距离
  EditText的android:hint
  设置EditText为空时输入框内的提示信息。
  android:gravity
  android:gravity属性是对该view 内容的限定.比如一个button 上面的text. 你可以设置该text 在view的靠左,靠右等位置.以button为例,android:gravity="right"则button上面的文字靠右
  android:layout_gravity
  android:layout_gravity是用来设置该view相对与起父view 的位置.比如一个button 在linearlayout里,你想把该button放在靠左、靠右等位置就可以通过该属性设置.以button为例,android:layout_gravity="right"则button靠右
  android:layout_alignParentRight
  使当前控件的右端和父控件的右端对齐。这里属性值只能为true或false,默认false。
  android:scaleType:
  android:scaleType是控制图片如何resized/moved来匹对ImageView的size。ImageView.ScaleType / android:scaleType值的意义区别:
  CENTER /center 按图片的原来size居中显示,当图片长/宽超过View的长/宽,则截取图片的居中部分显示
  CENTER_CROP / centerCrop 按比例扩大图片的size居中显示,使得图片长(宽)等于或大于View的长(宽)
  CENTER_INSIDE / centerInside 将图片的内容完整居中显示,通过按比例缩小或原来的size使得图片长/宽等于或小于View的长/宽
  FIT_CENTER / fitCenter 把图片按比例扩大/缩小到View的宽度,居中显示
  FIT_END / fitEnd 把图片按比例扩大/缩小到View的宽度,显示在View的下部分位置
  FIT_START / fitStart 把图片按比例扩大/缩小到View的宽度,显示在View的上部分位置
  FIT_XY / fitXY 把图片 不按比例扩大/缩小到View的大小显示
  MATRIX / matrix 用矩阵来绘制,动态缩小放大图片来显示。
  ** 要注意一点,Drawable文件夹里面的图片命名是不能大写的。

猜你喜欢

转载自blog.csdn.net/weixin_54723630/article/details/126072377