Android移动应用开发指南之六种布局详解

作者:Icy?Hunter 时间:2022-09-10 06:23:44 

LinearLayout

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
   android:layout_width="match_parent"
   android:layout_height="match_parent"
   android:orientation="vertical"
   android:dividerPadding="200dp"
   >

<LinearLayout
       android:layout_width="100dp"
       android:layout_height="0dp"
       android:background="#ff0000"
       android:layout_weight="1"
       />
   <View
       android:layout_width="match_parent"
       android:layout_height="1dp"
       android:background="#ff000000"
       />
   <LinearLayout
       android:layout_width="100dp"
       android:layout_height="0dp"
       android:background="#ffff00"
       android:layout_weight="1"
       />

<LinearLayout
       android:layout_width="200dp"
       android:layout_height="00dp"
       android:layout_weight="1"
       android:background="#00ffff" />
</LinearLayout>

orientation设置排列方式

layout_weight设置权重(感觉和弹性盒子差不多)

Android移动应用开发指南之六种布局详解

RelativeLayout

顾名思义,相对元素布局

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
   android:layout_height="match_parent"
   android:layout_width="match_parent"
   android:padding="10dp"
   >
   <RelativeLayout
       android:id="@+id/rl1"
       android:layout_width="100dp"
       android:layout_height="100dp"
       android:background="#ff0000"
       android:layout_centerInParent="true"
       />
   <RelativeLayout
       android:layout_margin="0dp"
       android:layout_width="100dp"
       android:layout_height="100dp"
       android:background="#00ff00"
       android:layout_toLeftOf="@+id/rl1"
       />

</RelativeLayout>

Android移动应用开发指南之六种布局详解

FrameLayout

<?xml version="1.0" encoding="utf-8"?>
<FrameLayout
   android:layout_width="match_parent"
   android:layout_height="match_parent"
   xmlns:android="http://schemas.android.com/apk/res/android">

<FrameLayout
       android:layout_width="400dp"
       android:layout_height="400dp"
       android:background="#ff0000"
       />
   <FrameLayout
       android:layout_width="300dp"
       android:layout_height="300dp"
       android:background="#ffff00"
       android:foreground="@drawable/a"
       />

<FrameLayout
       android:layout_width="200dp"
       android:layout_height="200dp"
       android:background="#00ff00"/>

</FrameLayout>

Android移动应用开发指南之六种布局详解

简单来说,就是可以叠一起的布局

TableLayout

<?xml version="1.0" encoding="utf-8"?>
<TableLayout
   xmlns:android="http://schemas.android.com/apk/res/android"
   android:collapseColumns=""

android:layout_width="match_parent"
   android:layout_height="match_parent"
   >
   <Button
       android:layout_width="wrap_content"
       android:layout_height="wrap_content"
       android:text="第1个"
       />
   <TableRow>
       <Button
           android:layout_width="wrap_content"
           android:layout_height="wrap_content"
           android:text="第一个"
           />

<Button
           android:layout_width="wrap_content"
           android:layout_height="wrap_content"
           android:text="第二个"
           />
   </TableRow>

<TableRow>
       <Button
           android:layout_width="wrap_content"
           android:layout_height="wrap_content"
           android:text="第一个"
           />
   </TableRow>

</TableLayout>

Android移动应用开发指南之六种布局详解

可以看成类似excel的表格一样的布局

通常结合< TableRow >一起使用

GridLayout

网格布局

<?xml version="1.0" encoding="utf-8"?>
<GridLayout
   xmlns:android="http://schemas.android.com/apk/res/android"
   android:layout_width="match_parent"
   android:layout_height="match_parent"
   android:orientation="horizontal"
   android:columnCount="3"
   >
   <Button
       android:layout_width="wrap_content"
       android:layout_height="wrap_content"
       android:layout_row="0"
       android:layout_column="1"
       android:text="第一个"
       />

<Button
       android:layout_width="wrap_content"
       android:layout_height="wrap_content"
       android:text="第二个"
       />
   <Button
       android:layout_width="wrap_content"
       android:layout_height="wrap_content"
       android:text="第三个"
       android:layout_columnSpan="3"
       />
</GridLayout>

Android移动应用开发指南之六种布局详解

可以看成TableLayout升级版?

ConstraintLayout

约束布局

这个应该是最强的布局了

创建布局默认的就是这个了。

Android移动应用开发指南之六种布局详解

打开design模式,然后随便拖几个按钮进去

Android移动应用开发指南之六种布局详解

点击魔术棒建立约束。

ok完成布局了。

代码也自动生成好了:

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
   xmlns:app="http://schemas.android.com/apk/res-auto"
   xmlns:tools="http://schemas.android.com/tools"
   android:layout_width="match_parent"
   android:layout_height="match_parent">

<Button
       android:id="@+id/button"
       android:layout_width="wrap_content"
       android:layout_height="wrap_content"
       android:layout_marginStart="246dp"
       android:layout_marginTop="107dp"
       android:text="按钮"
       app:layout_constraintStart_toStartOf="parent"
       app:layout_constraintTop_toTopOf="parent" />

<Button
       android:id="@+id/button3"
       android:layout_width="wrap_content"
       android:layout_height="wrap_content"
       android:layout_marginEnd="172dp"
       android:layout_marginBottom="125dp"
       android:text="Button"
       app:layout_constraintBottom_toBottomOf="parent"
       app:layout_constraintEnd_toEndOf="parent" />

<Button
       android:id="@+id/button4"
       android:layout_width="wrap_content"
       android:layout_height="wrap_content"
       android:layout_marginStart="115dp"
       android:text="Button"
       app:layout_constraintBottom_toBottomOf="parent"
       app:layout_constraintStart_toStartOf="parent"
       app:layout_constraintTop_toTopOf="parent" />
</androidx.constraintlayout.widget.ConstraintLayout>

我们开个虚拟机运行一下:

Android移动应用开发指南之六种布局详解

只能说,差不太多,微调一下差不多就能用了。

也能够设置各个组件的属性值颜色字体等等。

这用起来就像是墨刀一样。

参考

https://www.bilibili.com/video/BV1Jb4y187C4/?p=25&spm_id_from=pageDriver&vd_source=f57738ab6bbbbd5fe07aae2e1fa1280f

来源:https://blog.csdn.net/qq_52785473/article/details/126979334

标签:android,移动应用开发,布局
0
投稿

猜你喜欢

  • java开发分布式服务框架Dubbo原理机制详解

    2023-01-04 19:53:01
  • C#反射调用dll文件中的方法操作泛型与属性字段

    2022-09-15 03:24:04
  • c#将list类型转换成DataTable方法示例

    2023-06-27 12:02:08
  • Java Annotation注解相关原理代码总结

    2023-11-18 02:13:57
  • Java CompletableFuture实现多线程异步编排

    2023-07-22 22:57:02
  • Java实现单链表基础操作

    2021-08-07 13:46:04
  • C#中的IEnumerable接口深入研究

    2022-04-06 11:13:42
  • java关键字final使用方法详解

    2023-11-28 22:38:04
  • Android中Webview打开网页的同时发送HTTP头信息方法

    2022-05-19 20:01:28
  • C语言数据结构之二叉树详解

    2021-08-18 20:56:41
  • Java聊天室之解决连接超时问题

    2021-06-07 16:30:54
  • Java生成含字母和数字的6位随机字符串

    2023-04-02 02:28:58
  • java实现二叉树的创建及5种遍历方法(总结)

    2022-03-14 09:00:28
  • 详解Java回环屏障CyclicBarrier

    2022-08-30 15:02:09
  • Android利用传感器实现微信摇一摇功能

    2023-07-12 05:05:18
  • Unity实现弹球打砖块游戏

    2021-09-24 16:13:08
  • SpringBoot 使用 FTP 操作文件的过程(删除、上传、下载文件)

    2021-07-26 10:40:05
  • java递归菜单树转换成pojo对象

    2022-08-12 04:04:40
  • 如何利用反射生成 MyBatisPlus中QueryWrapper动态条件

    2021-10-20 14:59:40
  • Java设计模式之备忘录模式实现对象状态的保存和恢复

    2023-08-28 15:22:27
  • asp之家 软件编程 m.aspxhome.com