当前位置: 首页 > news >正文

Android开发系列(六)Jetpack Compose之Box

    Box是一个用来组合和控制子元素布局的组件。它可以在一个矩形区域内排列一个或多个子元素,并根据所提供的参数来控制它们的位置、大小和样式。

   Box的功能类似传统的FrameLayout。

   下面通过示例了解Box的使用方法,首先看一个最简单的示例,如下所示

    这里定义两个Box,是一对父子关系。父Box的大小为整个屏幕的大小,子Box是一个正方向,边长为100dp。

   由于父Box将contentAlignment设置为Center,也就是内容为中间对齐,因此子Box显示在中间。

   Box可以设置子控件的对齐方式,子控件也可以设置它在Box中的对齐方式,如下所示。


@Composable
fun BoxSample() {Box {Box(Modifier.fillMaxSize().background(Color.Cyan))Box(Modifier.matchParentSize().padding(top = 20.dp, bottom = 20.dp).background(Color.Yellow))Box(Modifier.matchParentSize().padding(40.dp).background(Color.Magenta))Box(Modifier.align(Alignment.Center).size(300.dp, 300.dp).background(Color.Green))Box(Modifier.align(Alignment.TopStart).size(150.dp, 150.dp).background(Color.Red))Box(Modifier.align(Alignment.BottomEnd).size(150.dp, 150.dp).background(Color.Blue))}}

    该示例的效果如下图所示。

   从该实例可以看到,在子Box也可以通过修改align显示在Box中的不同位置。

BoxWithConstraints

    

BoxWithConstraints 是 Jetpack Compose 中的一个组件,用于根据父容器的尺寸限制来调整自身的尺寸和布局。

BoxWithConstraints 可以接收一个 lambda 表达式,lambda 表达式中可以根据父容器的尺寸限制来设置子组件的尺寸和布局。比如,可以在 lambda 表达式中使用 ConstraintLayout 来实现复杂的布局。

使用 BoxWithConstraints 组件的一个常见用例是根据屏幕的尺寸限制来调整界面的布局。比如,在移动设备上,可以根据屏幕的宽度和高度来自动调整界面的布局。

 下面通过示例说明BoxWithConstraints的用法,分以下2种情况。

1、最大高度小于长方形高度的两边

    由于最大高度为180,长方形高度为100,180 < 100 *2,因此走第1个分支,只显示1个Box。

2、最大高度大于长方形高度的2倍

由于最大高度为220,长方形高度为100,220 > 100 *2,因此走第2个分支,显示2个Box。

示例代码已上传到github,地址如下

示例代码工程地址 

http://www.lryc.cn/news/378768.html

相关文章:

  • 51单片机STC89C52RC——4.1 独立按键(数码管显示按键值)
  • 解决双击bootstrap.bat没有生成b2.exe文件
  • AI穿戴设备是未来手机的终结者?中国AI商业化的未来预测
  • FPGA+Nvidia Orin NX+AI 异构视频图像处理开发平台在高端医疗和工业检测的应用,支持定制,支持国产化
  • 2000-2023年各省名义GDP、实际GDP、GDP平减指数数据(含原始数据+计算过程+计算结果)(以2000年为基期)
  • python学习—字典(Dictionary)
  • 鸿蒙开发:【组件启动规则(FA模型)】
  • 网络编程5----初识http
  • “用友审批+民生付款”,YonSuite让企业发薪更准时
  • EtherCAT扫盲,都是知识点
  • 开发中遇到的错误 - @SpringBootTest 注解爆红
  • 数据仓库的实际应用示例-广告投放平台为例
  • Beyond VL了解学习
  • AI音乐革命:创意产业的新篇章
  • python从入门到精通1:注释
  • CountDownLatch(应对并发问题的工具类)
  • HarmonyOS开发知识 :扩展修饰器,实现节流、防抖、权限申请
  • 自然语言NLP的基础处理
  • 带颜色的3D点云数据发布到ros1中(通过rviz显示)python、C++
  • python学习—列表和元组
  • c++题目_水仙花数
  • 使用 Iceberg、Tabular 和 MinIO 构建现代数据架构
  • jnp.linalg.norm
  • 20240621在飞凌的OK3588-C开发板的Buildroot系统中集成i2ctool工具
  • ARM32开发--存储器介绍
  • Web服务器
  • 大语言模型-Transformer
  • POI:接收上传上来的excel,解析并导入到数据库
  • 网页的CSS和JavaScript文件没有自动更新, 解决办法
  • Go语言 获取服务器资源磁盘Disk情况