鸿蒙5开发宝藏案例分享---一多断点开发实践
🌟【鸿蒙开发实战进阶】六大核心案例深度拆解,带你玩转多端适配!
📐 案例4:动态网格布局(电商商品列表)
应用场景:手机/平板商品展示差异
痛点分析:手机单列→平板多列,需智能计算展示数量
@Component
struct GoodsGrid {@StorageLink('currentWidthBreakpoint') bp: stringbuild() {Grid() {ForEach(goodsList, (item) => {GridItem() {GoodsItem(item) // 商品卡片组件}})}.columnsTemplate(this.getColumnsTemplate()).rowsTemplate(this.getRowsTemplate())}// 动态列数计算private getColumnsTemplate(): string {switch(this.bp) {case 'sm': return '1fr'; // 手机单列case 'md': return '1fr 1fr'; // 折叠屏双列case 'lg': return '1fr 1fr 1fr'; // 平板三列default: return '1fr';}}// 动态行间距private getRowsTemplate(): string {return this.bp === 'sm' ? '56vp' : '72vp'; // 大屏加大间距}
}
效果对比:
● 手机(sm):瀑布流单列,间距紧凑
● 折叠屏(md):双列平铺,图片自适应
● 平板(lg):三列展示,附加商品参数
🖥️ 案例5:自适应导航栏(跨设备菜单)
应用场景:Pad横屏显示侧边栏,手机隐藏为汉堡菜单
关键技术:@Watch监听 + 条件渲染
@Entry
struct MainPage {@State isCollapsed: boolean = false@StorageLink('currentWidthBreakpoint') bp: string// 断点变化自动触发@Watch('bp')onBpChange() {this.isCollapsed = this.bp === 'sm'; // 小屏自动折叠}build() {Row() {// 侧边栏(大屏显示)if(!this.isCollapsed) {Column() {MenuItems() // 导航菜单组件}.width(240).backgroundColor('#F5F5F5')}// 主内容区Column() {Header({ showMenuBtn: this.isCollapsed // 小屏显示菜单按钮})Content()}}}
}
交互逻辑:
● 宽度≥840vp(lg):固定左侧240vp导航栏
● 320vp≤宽度<840vp(md):折叠为浮动侧边栏
● 宽度<320vp(xs):隐藏导航,顶部显示汉堡菜单
📖 案例6:阅读器分栏模式(文档类APP)
特殊需求:折叠屏半开状态特殊布局
核心代码:
@Component
struct ReaderLayout {@StorageLink('currentHeightBreakpoint') hBp: stringbuild() {Flex({ direction: FlexDirection.Row }) {// 左侧目录(高宽比>1.2时显示)if(this.hBp === 'lg') {Column() {ChapterList() // 目录组件}.width('30%')}// 主阅读区域Scroll() {TextContent() // 文本组件}.flexGrow(1)// 右侧笔记(方正屏显示)if(this.hBp === 'md') {Column() {NotesPanel() // 笔记面板}.width(280)}}}
}
设备适配:
● 手机竖屏(hBp=lg):单栏阅读,底部浮窗目录
● 折叠屏半开(hBp=md):正文+右侧笔记双栏
● 平板横屏(hBp=sm):三栏显示(目录+正文+批注)
🎥 案例7:视频播放器多形态适配
复杂场景:全屏/分屏/画中画模式
关键技术点:窗口状态监听 + 动态样式
@Component
struct VideoPlayer {@StorageLink('currentWidthBreakpoint') bp: string@State isFullscreen: boolean = falsebuild() {Stack() {VideoComponent() // 核心播放器.aspectRatio(this.getVideoRatio()) // 动态比例// 全屏模式控件if(this.isFullscreen) {FullscreenControls()}}.onClick(() => {if(this.bp === 'sm') { // 小屏单击切换全屏this.toggleFullscreen();}})}// 根据断点设置视频比例private getVideoRatio(): number {switch(this.bp) {case 'sm': return 16/9; // 手机保持16:9case 'md': return 21/9; // 折叠屏超宽比例case 'lg': return this.isFullscreen ? 16/9 : 4/3; // 平板适配default: return 16/9;}}private toggleFullscreen() {// 全屏逻辑(略)}
}
关键适配策略:
- 手机竖屏:默认16:9,单击全屏
- 折叠屏展开:21:9影院比例
- 平板分屏:4:3适合多任务布局
📊 案例8:数据看板动态布局
业务需求:从智能手表到智慧屏的多端数据可视化
代码片段:
@Entry
struct Dashboard {@StorageLink('currentWidthBreakpoint') bp: stringbuild() {GridRow({ columns: this.getGridColumns() }) {GridCol({ span: { xs:12, sm:6, md:4, lg:3 } }) {DataCard('销售额', '¥1,234万') // 数据卡片}GridCol({ span: { xs:12, sm:6, md:8, lg:6 } }) {ChartComponent() // 可视化图表}}}private getGridColumns(): number | GridRowColumnOption {return {xs: 4, // 手表4列(每列80vp)sm: 8, // 手机8列md: 12, // 折叠屏12列lg: 24 // 大屏精细布局}}
}
布局策略:
● 手表(xs):关键指标单列堆叠
● 手机(sm):左右分块显示
● 智慧屏(lg):24列精细排版,多图表联动
🛠️ 案例9:表单布局自动优化
典型场景:登录界面横竖屏适配
创新方案:使用栅格+弹性布局混合
@Component
struct LoginForm {@StorageLink('currentHeightBreakpoint') hBp: stringbuild() {Flex({ direction: FlexDirection.Column, justifyContent: FlexAlign.Center }) {Image($r('app.media.logo')).height(this.hBp === 'sm' ? 80 : 120) // 横屏缩小LogoFormLayout() {TextInput().placeholder('账号')TextInput().placeholder('密码')}.layoutType(this.hBp === 'sm' ? LayoutType.Grid : LayoutType.List)Button('登录').width(this.hBp === 'sm' ? '60%' : '40%')}.padding(this.getFormPadding())}private getFormPadding(): Padding {return {top: this.hBp === 'lg' ? 40 : 20, // 竖屏增加顶部间距bottom: 20,left: this.hBp === 'sm' ? 10 : 30, // 横屏紧凑布局right: this.hBp === 'sm' ? 10 : 30}}
}
布局变化:
● 竖屏(hBp=lg):列表式排列,大间距
● 横屏(hBp=sm):栅格紧凑布局,自适应宽度
💡 开发者锦囊(避坑指南)
- 断点覆盖策略
// 错误示范:遗漏断点区间
if(bp === 'sm') {...}
else {...}// 正确做法:全覆盖判断
switch(bp) {case 'xs':... case 'sm':...case 'md':...case 'lg':...default:...
}
- 单位选择黄金法则
● 文字:fp(字体像素,自动适应系统缩放)
● 布局:vp(虚拟像素,屏幕密度无关)
● 媒体资源:px(物理像素,确保清晰度) - 多设备调试技巧
命令行同时启动多设备
hdc shell snapshot_demo -s 1080x2340 -d "Phone"
hdc shell snapshot_demo -s 2200x2480 -d "Foldable"
🌐 终极适配方案架构
├── resources
│ ├── breakpoints
│ │ ├── phone.ets # 手机专属布局
│ │ ├── tablet.ets # 平板布局策略
│ │ └── foldable.ets # 折叠屏适配
├── utils
│ ├── BreakpointManager.ets # 断点状态管理
│ └── LayoutCalculator.ets # 动态布局计算
└── components
├── AdaptiveContainer.ets # 自适应容器
└── ResponsiveImage.ets # 响应式图片组件
掌握这些案例后,相信大家在面对复杂的多端适配需求时,能像搭积木一样灵活组合这些模式。如果遇到特别棘手的适配问题,欢迎在评论区留言,我们一起探讨解决方案! 🚀
相关文章:
鸿蒙5开发宝藏案例分享---一多断点开发实践
🌟【鸿蒙开发实战进阶】六大核心案例深度拆解,带你玩转多端适配! 📐 案例4:动态网格布局(电商商品列表) 应用场景:手机/平板商品展示差异 痛点分析:手机单列→平板多列&…...

嵌入式学习之系统编程(六)线程
目录 一、线程 (一)线程概念 (二)特征 (三)优缺点 二、线程与进程的区别(面问) 三、多线程程序设计步骤 四、线程的创建(相关函数) 1、pthread_create…...
分布式常见概念
分布式常见概念 反向代理正向代理 vs 反向代理(对比理解名称)正向代理示意(“我去帮你拿数据”)反向代理示意(“你找我,我替你联系内部服务器”)为什么叫“反向”? API网关一、为什么…...
数据库的事务(Transaction)
在数据库中,事务(Transaction) 是保证数据操作一致性和完整性的核心机制。它通过一组原子性的操作单元,确保所有操作要么全部成功(提交),要么全部失败(回滚)。以下是数据…...

大语言模型 提示词的少样本案例的 演示选择与排序新突破
提示词中 演示示例的选择与排序 这篇论文《Rapid Selection and Ordering of In-Context Demonstrations via Prompt Embedding Clustering》聚焦于提升大语言模型(LLMs)在自适应上下文学习(ICL)场景中演示示例的选择与排序效率 一、论文要解决的问题 在上下文学习(ICL)…...

【算法篇】二分查找算法:基础篇
题目链接: 34.在排序数组中查找元素的第一个和最后一个位置 题目描述: 给你一个按照非递减顺序排列的整数数组 nums,和一个目标值 target。请你找出给定目标值在数组中的开始位置和结束位置。 如果数组中不存在目标值 target,返…...
Qtc++开发遇到的问题-按钮点击不管用?
我在设计自己的控件的时候,遇到了按钮点击不管用的问题,而且是有的自定义控件不管用,有的管用,有的一开始管用,多点几次就不管用了, 它是这样的,一个lineEdit和位于两侧的按钮,分别…...

重磅发布 | 复旦533页《大规模语言模型:从理论到实践(第2版)》(免费下载)
在人工智能浪潮席卷全球的今天,大语言模型正以前所未有的速度推动着科技进步和产业变革。从 ChatGPT 到各类行业应用,LLM 不仅重塑了人机交互的方式,更成为推动学术研究与产业创新的关键技术。 面对这一飞速演进的技术体系,如何系…...

智能体赋能效率,企业知识库沉淀价值:UMI企业智脑的双轮驱动!
智能体企业知识库:UMI企业智脑的核心功能与价值 在人工智能技术飞速发展的今天,企业智能化转型已经成为不可逆转的趋势。作为企业级AI智能体开发平台的佼佼者,优秘智能推出的UMI企业智脑,以其强大的智能体开发能力和全面的企业知…...
STM32CubeMX,arm-none-eabi-gcc简单试用
在windows下,为stm32系列单片机编程,keil有了免费的试用版,有很多开发板示例,给学习单片机编程带来很大的方便。 STM32CubeMX提供了stm32单片机的功能设置,在输出方式上给出了几种方式,有mdk(k…...
Spring AI(一)
Spring AI 官网 Spring AI 是一个用于 AI 工程的应用程序框架。其目标是将 Spring 生态系统设计原则(如可移植性和模块化设计)应用于 AI 领域,并将使用 POJO 作为应用程序的构建块推广到 AI 领域。 Spring AI 的核心是解决了 AI 集成的根本挑战:将您的企业数据和 API 与 A…...
Nacos适配GaussDB超详细部署流程
1部署openGauss 官方文档下载 https://support.huaweicloud.com/download_gaussdb/index.html 社区地址 安装包下载 本文主要是以部署轻量级为主要教程 1.1系统环境准备 操作系统选择 系统AARCH64X86-64openEuler√√CentOS7√Docker√√1.2软硬件安装环境 版本轻量版(单…...
vue-pure-admin动态路由无Layout实现解决方案
背景: 最近在使用vue-pure-admin开发后台项目的时候发现作者并没有动态路由的全屏无Layout实现方案。查询作者路由发现,作者只做了静态路由的无Layout方案,其它动态路由,作者在做整合的时候,都放进了 \ 下面的子路由&…...

vue项目 build时@vue-office/docx报错
我在打包vue项目时, 开始用的npm run build和cnpm run build,总是提示 vue-office/docx 错误,尝试过用cnpm重新安装node_modules几次都没用。类似下面的提示一直有。 Error: [commonjs--resolver] Failed to resolve entry for package "…...
卓力达蚀刻工艺:精密制造的跨行业赋能者
引言 蚀刻技术作为现代精密制造的核心工艺之一,通过化学或物理方法对金属材料进行选择性去除,实现微米级复杂结构的加工。南通卓力达凭借20余年技术积淀与全产业链布局,成为全球高端制造领域的重要支撑力量。本文将从蚀刻技术的多领域应用与…...
【大模型面试每日一题】Day 30:解释一下 FlashAttention 技术,并对比其与传统注意力在显存效率和计算性能上的差异。
【大模型面试每日一题】Day 30:解释一下 FlashAttention 技术,并对比其与传统注意力在显存效率和计算性能上的差异。 📌 题目重现 🌟🌟 面试官:解释一下 FlashAttention 技术,并对比其与传统注…...

#RabbitMQ# 消息队列入门
目录 一 MQ技术选型 1 运行rabbitmq 2 基本介绍 3 快速入门 1 交换机负责路由消息给队列 2 数据隔离 二 Java客户端 1 快速入门 2 WorkQueue 3 FanOut交换机 4 Direct交换机 5 Topic交换机 *6 声明队列交换机 1 在配置类当中声明 2 使用注解的方式指定 7 消息转…...
在promise中,多个then如何传值
在 JavaScript 中,Promise 的多个 .then() 是链式调用的,值可以通过返回值的方式,在多个 .then() 之间传递。这是 Promise 链式调用的核心机制。 基本原理:每个 then 接收上一个 then 的返回值 new Promise((resolve, reject) &g…...
TCP 三次握手过程详解
TCP 三次握手过程详解 一、TCP握手基础概念 1.1 什么是TCP握手 TCP三次握手是传输控制协议(Transmission Control Protocol)在建立连接时的标准过程,目的是确保通信双方具备可靠的双向通信能力。 关键结论:三次握手的本质是通过序列号同步和能力协商建立可靠的逻辑连接。 …...

EPT(Efficient Prompt Tuning)方法,旨在解决提示调优(Prompt Tuning)中效率与准确性平衡和跨任务一致性的问题
EPT(Efficient Prompt Tuning)方法,旨在解决提示调优(Prompt Tuning)中效率与准确性平衡和跨任务一致性的问题 一、核心原理:分解提示与多空间投影 1. 提示分解:用低秩矩阵压缩长提示 传统问题: 长提示(如100个token)精度高但训练慢,短提示(如20个token)速度快但…...

云原生安全核心:云安全责任共担模型(Shared Responsibility Model)详解
🔥「炎码工坊」技术弹药已装填! 点击关注 → 解锁工业级干货【工具实测|项目避坑|源码燃烧指南】 1. 基础概念 什么是云安全责任共担模型? 云安全责任共担模型(Shared Responsibility Model, SRM)是云服务提供商&…...

go并发与锁之sync.Mutex入门
sync.Mutex 原理:一个共享的变量,哪个线程握到了,哪个线程可以执行代码 功能:一个性能不错的悲观锁,使用方式和Java的ReentrantLock很像,就是手动Lock,手动UnLock。 使用例子: v…...

[Java恶补day8] 3. 无重复字符的最长子串
给定一个字符串 s ,请你找出其中不含有重复字符的 最长 子串 的长度。 示例 1: 输入: s “abcabcbb” 输出: 3 解释: 因为无重复字符的最长子串是 “abc”,所以其长度为 3。 示例 2: 输入: s “bbbbb” 输出: 1 解释: 因为无重复字符的最长子串是 “…...

LabVIEW教学用开发平台
一、培训目标 基础编程:掌握 LabVIEW 数据类型、程序结构、子 VI 设计与调试技巧。 硬件通信:精通 RS-232/485、TCP/IP、Modbus、PLC 等工业通信协议及实现。 高级设计模式:熟练运用状态机、生产者 - 消费者模式构建复杂测控系统。 项目实…...

Package Size Comparison – 6 Leads
Package Size Comparison 6 LeadsTSOP SOT SM SMT SOT23 SC-74 SC-59 SC-88 SOT363 US6 UMT6 SC-70 SOT563 ES EMT SC-75-6...

python打卡day38
Dataset和DataLoader 知识点回顾: Dataset类的__getitem__和__len__方法(本质是python的特殊方法)Dataloader类minist手写数据集的了解 作业:了解下cifar数据集,尝试获取其中一张图片 在遇到大规模数据集时,…...

vLLM 核心技术 PagedAttention 原理详解
本文是 vLLM 系列文章的第二篇,介绍 vLLM 核心技术 PagedAttention 的设计理念与实现机制。 vLLM PagedAttention 论文精读视频可以在这里观看:https://www.bilibili.com/video/BV1GWjjzfE1b 往期文章: vLLM 快速部署指南 1 引言…...
rpm安装jenkins-2.452
rpm安装jenkins-2.452 一、下载和安装 1、Jenkins下载 版本2.452可用windows下载: https://mirrors.jenkins-ci.org/redhat-stable/jenkins-2.452.4-1.1.noarch.rpm 其他版本 wget https://pkg.jenkins.io/redhat-stable/jenkins-2.440.3-1.1.noarch.rpm 2、jenkins安装 $r…...

《软件工程》第 2 章 -UML 与 RUP 统一过程
在软件工程领域,UML(统一建模语言)与 RUP(统一过程)是进行面向对象软件开发的重要工具和方法。接下来,我们将深入探讨第 2 章的内容,通过案例和代码,帮助大家理解和掌握相关知识。 …...

(转)Docker与K8S的区别
1 定义角度 Docker是一种开放源码的应用容器引擎,允许开发人员将其应用和依赖包打包成可移植的容器/镜像中;然后,发布到任何流行的 Linux 或 Windows 机器上,也能实现虚拟化。该容器完全使用沙箱机制,彼此之间没有任何…...