Compose 适配 - 响应式排版 自适应布局
一、概念
基于可用空间而非设备类型来设计自适应布局,实现设备无关性和动态适配性,避免硬编码,以不同形态布局更好的展示内容。
二、区分可用空间 WindowSizeClasses


传统根据屏幕大小和方向做适配的方式已不再适用,APP的显示方式还可能是:手机平板的分屏、ChormeOS的窗口可调整大小、折叠设备的屏幕形态切换等显示方式,因此需要根据可用显示空间做适配。
窗口尺寸类(Window size classes)将可用的显示区域分别在宽高上划分为紧凑型(Compact)、中等型(Medium)和扩展型(Expanded),由于垂直滚动的普遍性,可用宽度通常比可用高度更为重要。
最新版本
implementation("androidx.compose.material3.adaptive:adaptive:1.1.0-alpha02")
@Composable
fun Demo(windowWidthSizeClass: WindowWidthSizeClass = currentWindowAdaptiveInfo().windowSizeClass.windowWidthSizeClass
) {//【方式一】分别加载不同界面when(windowWidthSizeClass) {WindowWidthSizeClass.COMPACT -> { CompactScreen() }WindowWidthSizeClass.MEDIUM -> { MediumScreen() }WindowWidthSizeClass.EXPANDED -> { ExpandedScreen() }}//【方式二】直接将状态传递AdapterScreen(windowWidthSizeClass)
}
三、自适应布局
官方文章
3.1 自适应导航 NavigationSuiteScaffold
导航在小窗口上(例如手机)一般位于界面底部,在展开窗口上(例如平板)一般位于界面侧边。
NavigationSuiteScaffold 会根据 WindowSizeClass 显示适当的导航方式,包括在运行时窗口大小发生变化时动态更改界面。当宽或高较小、或处于桌上模式会显示在底部,其他情况显示在侧边。
implementation("androidx.compose.material3:material3-adaptive-navigation-suite")
3.2 列表详情布局
3.3 辅助窗格布局
四、响应式排版
参考文章


3.1 流式布局 FlowRow
流式布局能实时响应屏幕可用空间进行重排界面。
@Composable
fun AdapterScreen(windowWidthSizeClass: WindowWidthSizeClass = currentWindowAdaptiveInfo().windowSizeClass.windowWidthSizeClass
) {FlowRow(modifier = Modifier.fillMaxSize(),horizontalArrangement = Arrangement.Center,verticalArrangement = Arrangement.Center,maxItemsInEachRow = 3 可用空间再大一行也只有3个子元素) {//大型组件作为第一个直接放Big()//对紧凑型来说,小型组件横着放,放不下会自动换行(效果图横着显示2个)//对中等型和展开型来说,用容器 FlowColumn 包裹小型组件使之成为一个整体//充分利用纵向空间,在容器中竖着放,放不下会自动换列(效果图竖着显示两个)if(windowWidthSizeClass == WindowWidthSizeClass.COMPACT) {Small()Small()} else {FlowColumn {Small()Small()}}//中型组件同理小型组件if(windowWidthSizeClass == WindowWidthSizeClass.COMPACT) {Medium()Medium()} else {FlowColumn {Medium()Medium()}}}
}
3.2 保持子元素内部动画状态 movableContentOf()
当流式布局进行重排的时候,子元素的动画会被打断(重新启动)。借助可移动内容 (Movable content)可以在子元素被移动的时候不丢失动画状态。
val smallContent = remember {movableContentOf {Small()Small()}
}FlowRow {if (windowSizeClass == WindowWidthSizeClass.Compact) {smallContent()} else {FlowColumn { smallContent() }}
}
3.3 子元素位移动画 Modifier.animateBounds()
当流式布局进行重排的时候,子元素是瞬间移动的,没有流畅自然的感觉。最外层使用 LookaheadScope 包裹能够让 Compose 在布局变化时执行中间测量过程,并告知子元素这些中间状态。使用 Modifier.animateBounds() 构建一个自定义的 Modifier 传递给子元素,构建时可以指定 boundsTransform 参数到自定义的 spring 规范从而定制动画的运行方式。
最新版本
implementation("androidx.compose.animation:animation:1.8.0-beta01")
//自定义动画
val boundsTransform = { _: Rect, _: Rect->spring(dampingRatio = Spring.DampingRatioNoBouncy,stiffness = Spring.StiffnessMedium,visibilityThreshold = Rect.VisibilityThreshold)
}//最外层包裹一下
LookaheadScope {//单独创建 Modifier 方便多次传参给子元素val MyModifier = Modifier.animateBounds(lookaheadScope = this@LookaheadScope,boundsTransform = boundsTransform)val smallContent = remember {movableContentOf {small(modifier = MyModifier) //将自定义的 Modifier 传递给子元素small(modifier = MyModifier)}}FlowRow {if (windowSizeClass == WindowWidthSizeClass.Compact) {smallContent()} else {FlowColumn { smallContent() }}}
}
相关文章:
Compose 适配 - 响应式排版 自适应布局
一、概念 基于可用空间而非设备类型来设计自适应布局,实现设备无关性和动态适配性,避免硬编码,以不同形态布局更好的展示内容。 二、区分可用空间 WindowSizeClasses 传统根据屏幕大小和方向做适配的方式已不再适用,APP的显示方式…...
光储充智能协调控制系统的设计与应用研究
摘要 随着化石能源枯竭与环境污染问题加剧,构建高效、稳定的新能源系统成为能源转型的关键。本文针对光伏发电间歇性、储能系统充放电效率及充电桩动态负荷分配等技术挑战,提出一种基于智能协调管理的光储充一体化解决方案。通过多源数据融合与优化控制算…...
UE4 踩坑记录
1、Using git status to determine working set for adaptive non-unity build 我删除了一个没用的资源,结果就报这个错,原因就是这条命令导致的, 如果这个项目是git项目, ue编译时会优先通过 git status检查哪些文件被修改&#…...
C语言超详细指针知识(一)
通过前面一段学习C语言的学习,我们了解了数组,函数,操作符等相关知识,今天我们将要进行指针学习,这是C语言中较难的一个部分,我将带你由浅入深慢慢学习。 1.内存与地址 在正式学习指针前,我们首…...
《算法笔记》3.3小节——入门模拟->图形输出
1036 跟奥巴马一起编程 #include <iostream> #include <cmath> using namespace std;int main() {int n,m;char c;cin>>n>>c;for (int i 0; i < n; i) {cout<<c;}cout<<endl;m round(1.0*n/2)-2;//round里面不能直接写n/2,…...
【深入浅出 Git】:从入门到精通
这篇文章介绍下版本控制器。 【深入浅出 Git】:从入门到精通 Git是什么Git的安装Git的基本操作建立本地仓库配置本地仓库认识工作区、暂存区、版本库的概念添加文件添加文件到暂存区提交文件到版本库提交文件演示 理解.git目录中的文件HEAD指针与暂存区objects对象 …...
在gitee上创建仓库——拉取到本地---添加文件---提交
2025/04/11/yrx0203 1-创建仓库 2-填写信息 3-创建完成后把仓库地址复制下来 4-在电脑上创建1个空的文件夹,进入这个文件夹,鼠标右击打开git bash 5-粘贴刚才复制的仓库的地址,回车 这样仓库就被拉取完成了 6-把本地的这个文件夹初始化…...
小刚说C语言刷题——第21讲 一维数组
在日常生活中,我们经常输入一组数据。例如输入一个班30名学生的语文成绩,或者输入一组商品的价格。这个时候,我们如何输入一组类型相同的数据呢?这里我们就要用到数组。 1.数组的概念 所谓数组就是一组相同类型数据的集合。数组中…...
芯片同时具备Wi-Fi、蓝牙、Zigbee,MAC地址会打架吗?
目录 【MAC 地址简介】 【MAC、Wi-Fi MAC、Bluetooth MAC的关系】 【以乐鑫ESP32-C6为例分析MAC】 【MAC 地址简介】 MAC(Media Access Control)地址是设备的物理地址,在全球范围内唯一标识每个网络接口。它是一个 48 比特(6 字…...
Kotlin 学习-方法和参数类型
/*** kotlin 的方法有三种* */fun main() {/*** 方法一* 1.普通类的成员方法申明与调用* (1)需要先构建出实例对象,才能访问成员方法* (2)实例对象的构建只需要在类名后面加上()* */Person().test()/*** 方法二&#x…...
基于风力水力和蓄电池的低频率差联合发电系统simulink建模与仿真
目录 1.课题概述 2.系统仿真结果 3.核心程序与模型 4.系统原理简介 4.1 风力发电 4.2 风力发电 4.3 蓄电池原理 4.4 蓄电池对系统稳定性分析 5.完整工程文件 1.课题概述 基于风力水力和蓄电池的低频率差联合发电系统simulink建模与仿真。模型包括风力发电模块…...
Harmony实战之简易计算器
前言 臭宝们,在学会上一节的基础知识之后,我们来实战一下。 预备知识 我们需要用到的知识点有: Column组件Row组件Link装饰器button组件TextInput组件State装饰器 最终效果图 代码实现 index页面(首页) /** * program: * * descriptio…...
【Ansible自动化运维】四、ansible应用部署:加速开发到生产的流程
在软件开发的生命周期中,从开发到生产的应用部署过程往往是复杂且容易出错的。手动部署不仅效率低下,还可能引入人为错误,导致系统故障。Ansible 作为一款强大的自动化工具,能够显著简化应用部署流程,提高部署的准确性…...
Spring MVC 国际化机制详解(MessageSource 接口体系)
Spring MVC 国际化机制详解(MessageSource 接口体系) 1. 核心接口与实现类详解 接口/类名描述功能特性适用场景MessageSource核心接口,定义消息解析能力支持参数化消息(如{0}占位符)所有国际化场景的基础接口Resource…...
(十五)安卓开发中不同类型的view之间继承关系详解
在安卓开发中,View 是所有 UI 组件的基类,不同类别的 View 通过继承关系扩展和特化功能,以满足多样化的界面需求。以下将详细讲解常见 View 类别的继承关系,并结合代码示例和使用场景进行说明。 1. View 继承关系: java.lang.Obj…...
美团Leaf分布式ID生成器:雪花算法原理与应用
📖 前言 在分布式系统中,全局唯一ID生成是保证数据一致性的核心技术之一。传统方案(如数据库自增ID、UUID)存在性能瓶颈或无序性问题,而美团开源的Leaf框架提供了高可用、高性能的分布式ID解决方案。本文重点解析Leaf…...
文件IO5(JPEG图像原理与应用)
JPEG图像原理与应用 ⦁ 基本概念 JPEG(Joint Photographic Experts Group)指的是联合图像专家组,是国际标准化组织ISO制订并于1992年发布的一种面向连续色调静止图像的压缩编码标准,所以也被称为JPEG标准。 同样,JP…...
P8682 [蓝桥杯 2019 省 B] 等差数列
题目描述 思路 让求包含这n个整数的最短等差数列,既让包含这几个数,项数最少,若项数最少,肯定不能添加小于最小的和大于最大的,而且让项数最小,公差得大 等差数列的公差aj - ai / j - i; 这又是一个等差数…...
DFS中return的作用
DFS中return的作用 在深度优先搜索(DFS)算法中,return语句有几个重要作用: 主要作用 终止当前递归分支:当找到解决方案或确定当前路径无效时,return会结束当前递归调用,返回到上一层。 传递结果:在有返回…...
Java 8 响应式编程:用函数式风格优雅地处理异步流
引言:响应式编程是什么? 响应式编程(Reactive Programming)是一种异步编程范式,它允许你以流的方式处理数据流和事件流,强调数据的流动与变化。通过响应式编程,你可以以声明式的方式构建应用&a…...
《Vue3学习手记》
下面进入Vue3的学习,以下代码中都有很详细的注释,代码也比较清晰易懂: Vue3 index.html是入口文件 Vue3通过createApp函数创建一个应用实例 main.ts: // Vue3中通过createApp函数创建应用实例 // 引入createApp用于创建应用 import { crea…...
批量给文件编排序号,支持数字序号及时间日期序号编排文件
当我们需要对文件进行编号的时候,我们可以通过这个工具来帮我们完成,它可以支持从 001 到 100 甚至更多的数字序号编号。也可以支持按照日期、时间等方式对文件进行编号操作。这是一种操作简单,处理起来也非常的高效文件编排序号的方法。 工作…...
LLM_基于OpenAI的极简RAG
一、RAG主要流程 #mermaid-svg-gXjcqQe5kyb41Yz2 {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-gXjcqQe5kyb41Yz2 .error-icon{fill:#552222;}#mermaid-svg-gXjcqQe5kyb41Yz2 .error-text{fill:#552222;stroke:#55…...
Dynamics365 ExportPdfTemplateExportWordTemplate两个Action调用的body构造
这两天在用ExportPdfTemplate做pdf导出功能时,遇到了如下问题InnerException : Microsoft.OData.ODataException: An unexpected StartArray node was found when reading from the JSON reader. A PrimitiveValue node was expected. 我的场景是使用power automate…...
Java 程序调试与生产问题排查工具Arthas
好的,以下是修改后的博客内容,将公司信息替换为通用的占位符: 深入探索 Arthas:Java 程序调试与生产问题排查的利器 在 Java 开发中,调试和诊断问题往往是一个复杂且耗时的过程。Arthas(Alibaba Java Dia…...
day26图像处理OpenCV
文章目录 一、OpenCV1.介绍2.下载3.图像的表示4.图像的基本操作4.1图片读取或创建4.1.1读取4.1.2创建 4.2创建窗口4.3显示图片4.3.1设置读取的图片4.3.2设置显示多久4.3.3释放 4.4.保存图片4.5图片切片(剪裁)4.6图片大小调节 5.在图像中绘值5.1绘制直线5…...
国际物流怎么找客户?选择适合自己的企业拓客平台
在国际物流行业,获客一直是企业发展的核心难题。无论是跨境电商、传统外贸,还是国际货代,找到精准的客户资源并高效转化,是决定企业能否抢占市场蓝海的关键。今天,我们就来聊聊如何选择一个真正适合的国际物流拓客平台…...
2025年Y1大型游乐设施修理证报考要求
Y1大型游乐设施修理证是从事大型游乐设施维修、保养的必备资质,由国家市场监督管理总局颁发。报考需满足以下条件: 1. 基本条件 年龄:18周岁以上,60周岁以下; 学历:初中及以上文化程度; 健康…...
第四十六篇 人力资源管理数据仓库架构设计与高阶实践
声明:文章内容仅供参考,需仔细甄别。文中技术名称属相关方商标,仅作技术描述;代码示例为交流学习用途;案例数据已脱敏,技术推荐保持中立;法规解读仅供参考,请以《网络安全法》《数据…...
分布式ID生成算法:雪花算法和UUID
在分布式系统中,生成全局唯一ID是核心需求之一。雪花算法和UUID是两种广泛使用的解决方案。 1. 雪花算法 工作原理 分布式ID生成器:由Twitter开源,专为分布式系统设计。组成结构(64位二进制): 符号位&…...
