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

【Compose multiplatform教程17】【组件】BoxWithConstraints组件

查看全部组件 icon-default.png?t=O83Ahttps://blog.csdn.net/b275518834/article/details/144751353

BoxWithConstraints

功能说明:它是 Jetpack Compose 中的关键布局组件,能够精准捕捉自身所在容器的尺寸约束信息,通过获取最大宽度和最大高度这两个关键属性,为开发者开启一扇通往自适应布局世界的大门。开发者得以依据这些尺寸数据,灵动地调整内部子组件的布局策略、样式呈现乃至显示逻辑。无论是在屏幕尺寸多变的移动设备上,还是应对不同分辨率的桌面端,都能确保界面元素有条不紊地排列,合理利用每一寸空间,实现从紧凑小屏到宽敞大屏的完美适配。

示例场景:以一款阅读类应用为例,当用户在手机上打开书籍详情页面时,BoxWithConstraints 可以根据屏幕的实际宽度,判断若宽度较窄,就将书籍封面图片、书名、作者等信息纵向排列,确保文字清晰可读,各元素不拥挤;而当应用运行在平板等大屏设备上,一旦检测到较大的 maxWidth 和 maxHeight,便可将封面图片放大置于左侧,书名、作者、简介等信息以合适的字体和间距横向排列在右侧,充分利用大屏优势,提升视觉体验。再如在社交分享界面,若 maxWidth 有限,分享按钮与取消按钮会紧凑排列在底部,文案区域自适应变窄;若处于宽屏状态,按钮间距拉大,文案区域舒展,还可适时展示相关的热门话题标签,让分享功能更加醒目、易用,完美契合不同设备形态下的用户需求。

package org.lxz.project.compose.demoimport androidx.compose.foundation.layout.*
import androidx.compose.material.Button
import androidx.compose.material.Text
import androidx.compose.runtime.Composable
import androidx.compose.ui.Alignment
import androidx.compose.ui.Modifier
import androidx.compose.ui.unit.Dp
import androidx.compose.ui.unit.dp
object BoxWithConstraintsDemo {private val elementPadding: Dp = 8.dp@Composablefun boxWithConstraintsExample() {// 使用BoxWithConstraints组件作为外层容器,使其占满可用空间BoxWithConstraints(modifier = Modifier.fillMaxSize()) {// 获取BoxWithConstraints组件所在容器的最大可用宽度val maxWidth = this.maxWidth// 获取BoxWithConstraints组件所在容器的最大可用高度val maxHeight = this.maxHeight// 展示获取到的最大宽度和最大高度信息(可以用于调试或者根据其做进一步决策)Text(text = "Max Width: ${maxWidth.value} dp, Max Height: ${maxHeight.value} dp",modifier = Modifier.padding(16.dp).offset(y = 15.dp))// 根据宽高比来决定采用水平排列还是垂直排列布局方式if (maxWidth > maxHeight) {// 宽度大于高度,采用水平排列(Row)布局Row(modifier = Modifier// 让Row组件占满整个可用空间.fillMaxSize()// 设置子组件在水平方向上的内边距为16.dp,使布局看起来更美观.padding(horizontal = 16.dp),horizontalArrangement = Arrangement.SpaceEvenly) {// 第一个子组件,宽度占比可根据需求调整,这里示例设为总宽度的1/3Text(text = "Left Text",modifier = Modifier.width(maxWidth / 3).padding(elementPadding))// 第二个子组件,占剩余宽度空间,通过weight实现按比例分配空间Column(modifier = Modifier// 设置权重为1f,表示占剩余的水平空间比例.weight(1f)// 让Column组件在垂直方向上占满可用空间.fillMaxHeight().padding(elementPadding)) {Text(text = "Top Text in Middle Column", modifier = Modifier.padding(elementPadding))Button(onClick = { /* 处理按钮点击事件 */ },modifier = Modifier.padding(elementPadding)) {Text(text = "Click Me", modifier = Modifier.padding(elementPadding))}Text(text = "Bottom Text in Middle Column", modifier = Modifier.padding(elementPadding))}// 第三个子组件,宽度同样占总宽度的1/3Text(text = "Right Text",modifier = Modifier.width(maxWidth / 3).padding(elementPadding))}} else {// 高度大于宽度,采用垂直排列(Column)布局Column(modifier = Modifier// 让Column组件占满整个可用空间.fillMaxSize()// 设置子组件在垂直方向上的内边距为16.dp,使布局更美观.padding(vertical = 16.dp),verticalArrangement = Arrangement.SpaceEvenly) {// 第一个子组件,高度占比可根据需求调整,这里示例设为总高度的1/3Text(text = "Top Text",modifier = Modifier.height(maxHeight / 3).padding(elementPadding))// 第二个子组件,占剩余高度空间,通过weight实现按比例分配空间Row(modifier = Modifier// 设置权重为1f,表示占剩余的垂直空间比例.weight(1f)// 让Row组件在水平方向上占满可用空间.fillMaxWidth().padding(elementPadding)) {Text(text = "Left Text in Middle Row", modifier = Modifier.padding(elementPadding))Button(onClick = { /* 处理按钮点击事件 */ },modifier = Modifier.padding(elementPadding)) {Text(text = "Click Me", modifier = Modifier.padding(elementPadding))}Text(text = "Right Text in Middle Row", modifier = Modifier.padding(elementPadding))}// 第三个子组件,高度同样占总高度的1/3Text(text = "Bottom Text",modifier = Modifier.height(maxHeight / 3).padding(elementPadding))}}}}
}

运行效果

  1. 整体布局结构
    外层使用 BoxWithConstraints 组件作为基础容器,通过 Modifier.fillMaxSize 使其占满整个可用空间,以便能获取到最外层的尺寸约束信息(maxWidth 和 maxHeight)。

  2. 获取并利用尺寸约束信息
    首先获取了 maxWidth 和 maxHeight,并通过一个简单的 Text 组件展示了这两个尺寸值(同时利用 Modifier.offset 对其在垂直方向做了一点偏移,使其布局更美观)。然后依据 maxWidth 和 maxHeight 的大小比较结果,选择不同的内部布局方式。

  3. 不同布局方式下的子组件处理

    • 水平排列(Row 布局)情况
      • 当宽度大于高度时,使用 Row 组件水平排列子组件,通过 horizontalArrangement = Arrangement.SpaceEvenly 让子组件在水平方向均匀分布,同时利用 Modifier.width 为部分子组件设置特定的宽度占比(如设置第一个和第三个 Text 组件宽度为总宽度的 1/3),中间的 Column 组件通过 Modifier.weight(1f) 占剩余的宽度空间,并且在每个子组件上都添加了 elementPadding 的内边距,保证元素之间有合适间距,避免堆叠。
    • 垂直排列(Column 布局)情况
      • 类似地,当高度大于宽度时,采用 Column 组件垂直排列子组件,通过 verticalArrangement = Arrangement.SpaceEvenly 使子组件在垂直方向均匀分布,利用 Modifier.height 设定部分子组件的高度占比(如设置第一个和第三个 Text 组件高度为总高度的 1/3),中间的 Row 组件通过 Modifier.weight(1f) 占剩余的高度空间,同样为每个子组件添加 elementPadding 的内边距确保布局清晰。
http://www.lryc.cn/news/511669.html

相关文章:

  • 银河麒麟操作系统安装达梦数据库(超详细)
  • Spring源码_05_IOC容器启动细节
  • 科大讯飞在线语音合成(流式版)python版
  • 常见搜索算法汇总
  • vue 中 ref 详解
  • 探索开源项目 kernel:技术的基石与无限可能
  • C 实现植物大战僵尸(二)
  • Vivado - TCL 命令(DPU脚本、v++命令、impl策略)
  • 【JDBC】数据库连接的艺术:深入解析数据库连接池、Apache-DBUtils与BasicDAO
  • hadoop-common的下载位置分享
  • 【机器学习】SVM支持向量机(一)
  • Spring Boot介绍、入门案例、环境准备、POM文件解读
  • 基于Spring Boot + Vue3实现的在线商品竞拍管理系统源码+文档
  • LeetCode--排序算法(堆排序、归并排序、快速排序)
  • 华诺星空 Java 开发工程师笔试题 - 解析
  • QT:一个TCP客户端自动连接的测试模型
  • 关于启动vue项目,出现:Error [ERR_MODULE_NOT_FOUND]: Cannot find module ‘xxx‘此类错误
  • 电路元件与电路基本定理
  • 指针之矢:C 语言内存幽境的精准飞梭
  • uniapp下载打开实现方案,支持安卓ios和h5,下载文件到指定目录,安卓文件管理内可查看到
  • 免费干净!付费软件的平替款!
  • 软路由系统 iStoreOS 中部署 Minecraft 服务器
  • 第 29 章 - ES 源码篇 - 网络 IO 模型及其实现概述
  • 细说STM32F407单片机IIC总线基础知识
  • 从头开始学MyBatis—04缓存、逆向工程、分页插件
  • Artec Space Spider助力剑桥研究团队解码古代社会合作【沪敖3D】
  • 《探索PyTorch计算机视觉:原理、应用与实践》
  • 【C#设计模式(21)——状态模式(State Pattern)】
  • nvm日常使用中常用命令总结
  • 【数据仓库】SparkSQL数仓实践