Android开发学习笔记之详解五大布局

  1. 11

  2. 12 android:layout_width=“fill_parent”>

  3. 13

  4. 14

  5. 15 <LinearLayout android:id=“@+id/linearLayout1”

  6. 16

  7. 17 android:layout_height=“fill_parent”

  8. 18

  9. 19 android:layout_width=“fill_parent”

  10. 20

  11. 21 android:gravity=“right”>

  12. 22 <Button android:id=“@+id/button2”

  13. 23

  14. 24 android:text=“Button”

  15. 25

  16. 26 android:layout_width=“wrap_content”

  17. 27

  18. 28 android:layout_height=“wrap_content”>

  19. 29 <Button android:text=“Button”

  20. 30

  21. 31 android:id=“@+id/button1”

  22. 32

  23. 33 android:layout_width=“wrap_content”

  24. 34

  25. 35 android:layout_height=“wrap_content”>

  26. 36

  27. 37

复制代码

最外层布局为垂直线性布局,宽度为整个屏幕(fill_parent),高度为刚好适合子控件(wrap_content)。然后依次添加一个EditText,一个水平布局的LinearLayout,在这个线性布局里面,摆放两个Button,该线性布局的gravity属性设置为”right”,所以里面的两个Button靠右显示。

二,TableLayout(表格布局)

把子元素放入到行与列中

不显示行、列或是单元格边界线

单元格不能横跨行,如HTML中一样

表格布局模型以行列的形式管理子控件,每一行为一个TableRow的对象,当然也可以是一个View的对象。TableRow可以添加子控件,每添加一个为一列。

android:layout_colum官方解释:The index of the column in which this child should be,也即是设置该控件在TableRow中所处的列。

android:layout_span官方解释:Defines how many columns this child should span,也即是设置该控件所跨越的列数。

android:collapseColumns官方解释:The 0 based index of the columns to collapse. The column indices must be separated by a comma: 1, 2, 5.也即是将TableLayout里面指定的列隐藏,若有多列需要隐藏,请用逗号将需要隐藏的列序号隔开。

android:stretchColumns官方解释:The 0 based index of the columns to stretch. The column indices must be separated by a comma: 1, 2, 5. You can stretch all columns by using the value “*” instead. Note that a column can be marked stretchable and shrinkable at the same time.也即是设置指定的列为可伸展的列,可伸展的列会尽量伸展以填满所有可用的空间,若有多列需要设置为可伸展,请用逗号将需要伸展的列序号隔开。

android:shrinkColumns官方解释:The 0 based index of the columns to shrink. The column indices must be separated by a comma: 1, 2, 5. You can shrink all columns by using the value “*” instead. 设置指定的列为可收缩的列。当可收缩的列太宽以至于让其他列显示不全时,会纵向延伸空间。当需要设置多列为可收缩时,将列序号用逗号隔开。

下面用一个例子简单说明TableLayout的用法:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

  1. 01 <?xml version="1.0" encoding="utf-8"?>

  2. 02 <TableLayout xmlns:android=“http://schemas.android.com/apk/res/android”

  3. 03 android:layout_width=“fill_parent”

  4. 04 android:layout_height=“fill_parent”

  5. 05 android:stretchColumns=“1”>

  6. 06

  7. 07 <TextView

  8. 08 android:layout_column=“1”

  9. 09 android:padding=“3dip” android:text=“Row1”/>

  10. 10 <TextView

  11. 11 android:text=“1”

  12. 12 android:gravity=“right”

  13. 13 android:padding=“3dip” />

  14. 14

  15. 15 <View

  16. 16 android:layout_height=“2dip”

  17. 17 android:background=“#FF909090” />

  18. 18

  19. 19 <TextView

  20. 20 android:text=“*”

  21. 21 android:padding=“3dip” />

  22. 22 <TextView

  23. 23 android:text=“Row12”

  24. 24 android:padding=“3dip” />

  25. 25 <TextView

  26. 26 android:text=“2”

  27. 27 android:gravity=“right”

  28. 28 android:padding=“3dip” />

  29. 29

  30. 30 <View

  31. 31 android:layout_height=“2dip”

  32. 32 android:background=“#FF909090” />

  33. 33

  34. 34 <TextView

  35. 35 android:layout_column=“1”

  36. 36 android:text=“Row13”

  37. 37 android:padding=“3dip” />

  38. 38

  39. 39

复制代码

三、RelativeLayout(相对布局)

相对布局的子控件会根据它们所设置的参照控件和参数进行相对布局。参照控件可以是父控件,也可以是其它子控件,但是被参照的控件必须要在参照它的控件之前定义。下面是一个简单的例子:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

  1. 01 <?xml version="1.0" encoding="utf-8"?>

  2. 02 <?xml version="1.0" encoding="utf-8"?>

  3. 03 <RelativeLayout xmlns:android=“http://schemas.android.com/apk/res/android”

  4. 04 android:layout_width=“fill_parent”

  5. 05 android:layout_height=“fill_parent”

  6. 06 >

  7. 07 <AnalogClock

  8. 08 android:id=“@+id/aclock”

  9. 09 android:layout_width=“wrap_content”

  10. 10 android:layout_height=“wrap_content”

  11. 11 android:layout_centerInParent=“true” />

  12. 12 <DigitalClock

  13. 13 android:id=“@+id/dclock”

  14. 14 android:layout_width=“wrap_content”

  15. 15 android:layout_height=“wrap_content”

  16. 16 android:layout_below=“@id/aclock”

  17. 17 android:layout_alignLeft=“@id/aclock”

  18. 18 android:layout_marginLeft=“40px” />

  19. 19 <TextView

  20. 20 android:layout_width=“wrap_content”

  21. 21 android:layout_height=“wrap_content”

  22. 22 android:text=“当前时间:”

  23. 23 android:layout_toLeftOf=“@id/dclock”

  24. 24 android:layout_alignTop=“@id/aclock”/>

  25. 25

复制代码

四、AbsoluteLayout(绝对布局)

绝对布局的子控件需要指定相对于此坐标布局的横纵坐标值,否则将会像框架布局那样被排在左上角。手机应用需要适应不同的屏幕大小,而这种布局模型不能自适应屏幕尺寸大小,所以应用的相对较少。下面以一个例子简单说明绝对布局:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

  1. 01 <?xml version="1.0" encoding="utf-8"?>

  2. 02 <AbsoluteLayout xmlns:android=“http://schemas.android.com/apk/res/android”

  3. 03 android:layout_width=“fill_parent”

  4. 04 android:layout_height=“fill_parent”

  5. 05 >

  6. 06 <TextView

  7. 07 android:layout_width=“wrap_content”

  8. 08 android:layout_height=“wrap_content”

  9. 09 android:layout_x=“10px”

  10. 10 android:layout_y=“10px” android:text=“Textview”/>

  11. 11 <TextView

  12. 12 android:layout_width=“wrap_content”

  13. 13 android:layout_height=“wrap_content”

  14. 14 android:layout_x=“30px”

  15. 15 android:layout_y=“30px” android:text=“Textview”/>

  16. 16 <TextView

  17. 17 android:layout_width=“wrap_content”

最后

以前一直是自己在网上东平西凑的找,找到的东西也是零零散散,很多时候都是看着看着就没了,时间浪费了,问题却还没得到解决,很让人抓狂。

后面我就自己整理了一套资料,还别说,真香!

资料有条理,有系统,还很全面,我不方便直接放出来,大家可以先看看有没有用得到的地方吧。

系列教程图片

2020Android复习资料汇总.png

flutter

NDK

设计思想开源框架

微信小程序

加入社区》https://bbs.csdn.net/forums/4304bb5a486d4c3ab8389e65ecb71ac0
droid:layout_width=“wrap_content”

最后

以前一直是自己在网上东平西凑的找,找到的东西也是零零散散,很多时候都是看着看着就没了,时间浪费了,问题却还没得到解决,很让人抓狂。

后面我就自己整理了一套资料,还别说,真香!

资料有条理,有系统,还很全面,我不方便直接放出来,大家可以先看看有没有用得到的地方吧。

[外链图片转存中…(img-3IIMkf7q-1725705090459)]

[外链图片转存中…(img-dFYWHEv1-1725705090459)]

[外链图片转存中…(img-6hS3wffD-1725705090459)]

[外链图片转存中…(img-bHWLm157-1725705090460)]

[外链图片转存中…(img-a6C1F0jj-1725705090460)]

[外链图片转存中…(img-zpkxKP9b-1725705090460)]

加入社区》https://bbs.csdn.net/forums/4304bb5a486d4c3ab8389e65ecb71ac0

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值