在HarmonyOS ArkTS ArkUI-X 5.0及以上版本中,手势开发全攻略:
在 HarmonyOS 应用开发中,手势交互是连接用户与设备的核心纽带。ArkTS 框架提供了丰富的手势处理能力,既支持点击、长按、拖拽等基础单一手势的精细控制,也能通过多种绑定策略解决父子组件的手势竞争问题。本文将结合官方开发文档,从单一手势特性、绑定方法原理到实战场景,为开发者构建完整的手势开发知识体系。
一、七大核心单一手势的深度解析
(一)基础交互:点击与长按手势
- 点击手势(TapGesture)
-
- 通过
count
参数支持单 / 双击(如count: 2
),fingers
可定义多指触发(如三指点击)。 - 案例:双击切换文本状态
- 通过
typescript
@Component
export struct antion {@State isDouble: boolean = falsebuild() {Column() {Text(this.isDouble ? '双击触发' : '单击触发').gesture(TapGesture({ count: 2 }) //count: 点击次数.onAction(() => {this.isDouble = true}),)}}
}
- 长按手势(LongPressGesture)
-
repeat
参数控制是否持续触发(如文件多选场景),duration
可缩短至 300ms 提升灵敏度。- 案例:长按渐变背景色
typescript
@Component
export struct antion {@State color: string = '#000000';build() {Column() {Column().width(100).height(100).backgroundColor(this.color).gesture(LongPressGesture({ repeat: true }).onAction(() => this.color = `#${Math.random().toString(16).slice(2, 8)}`))}}
(二)空间交互:拖动、捏合与旋转
- 拖动手势(PanGesture)
-
direction
限定滑动方向(如Horizontal
横向拖动),deltaX/deltaY
实时获取偏移量。- 冲突处理:在
List
组件中使用时,通过distance: 10vp
增大触发阈值避免误触。 - 案例:可拖拽文本“张三”
@Component
export struct antion {@State name: string = '张三'@State offsetX: number = 0@State offsetY: number = 0build() {Column() {Text(this.name).translate({ x: this.offsetX, y: this.offsetY }).gesture(PanGesture().onActionUpdate((event?: GestureEvent) => {if (event) {this.offsetX = event.offsetXthis.offsetY = event.offsetY}}))}}
}
- 捏合手势(PinchGesture)
-
- 基于双指间距变化计算
scale
值,适用于图片缩放(需结合Image
组件的scaleMode
)。 - 案例:双指缩放图片
- 基于双指间距变化计算
typescript
@Component
export struct antion {@State scale1: number = 1.0build() {Column() {Image($r('app.media.background')).scale({ x: this.scale1, y: this.scale1 }).gesture(PinchGesture({fingers:2}) // fingers:number几只手指.onActionUpdate((event: GestureEvent) => {if (event.scale > 0 && event.scale < 2) {this.scale1 = event.scale}})// .onActionEnd(()=>{ }))}}
}
- 旋转手势(RotationGesture)
-
- 通过
deltaAngle
获取实时旋转角度增量,配合rotate
修饰符实现组件旋转。 - 优化点:添加角度吸附(如
Math.round(event.deltaAngle / 45) * 45
)提升交互精度。
- 通过
@Component
export struct antion {@State name: string = '张三'@State imgAngle: number = 0@State preangle: number = 0build() {Column() {Text(this.name).fontSize(30).rotate({ angle: this.imgAngle }).gesture(RotationGesture({fingers: 2}).onActionStart(() => {this.preangle = this.imgAngle}).onActionUpdate((event?: GestureEvent) => {if (event) {this.imgAngle = this.preangle + event.angle}}))}}
}
(三)快捷交互:滑动手势
SwipeGesture依赖滑动速度(默认 > 100vp/s)和方向识别,可组合多个方向(如Left | Right
)。
- 案例:滑动修改名字
typescript
@Component
export struct antion {@State name:string ='张三'build() {Column() {Text(this.name).gesture(SwipeGesture({ direction: SwipeDirection.Vertical}).onAction(() => {this.name = '李四'})).width(100).height(100).backgroundColor(Color.Gray)}}}
二、手势绑定策略:从竞争到协同的三级控制
(一)基础绑定:.gesture()
的独立响应模式
- 特性:子组件手势默认优先级高于父组件,适用于独立控件(如按钮、输入框)。
- 多手势共存:同一组件可同时绑定点击和长按,通过事件类型区分响应。
typescript
@Component
export struct antion {@State name: string = '手势'build() {Column() {Text(this.name)Button('复合手势').gesture(GestureGroup(GestureMode.Exclusive,TapGesture().onAction(() => {this.name = '点击'}),LongPressGesture().onAction(() => {this.name = '长按'})))}}
}
(二)优先级控制:.priorityGesture()
的强制覆盖
- 核心场景:父容器需要拦截子组件手势(如模态弹窗屏蔽底层操作)。
- GestureMask 参数:
-
IgnoreInternal
:完全忽略子组件手势(如全局侧滑菜单)。Normal
:仅提升父组件优先级,允许子组件通过非竞争手势响应。
- 案例:模态框拦截点击
typescript
@Component
export struct antion {@State name: string = '张三'@State showModal: boolean = truebuild() {Column() {Text(this.name).fontSize(32)if (this.showModal) {Column().width('100%').height('100%').backgroundColor('#80808066').priorityGesture(TapGesture().onAction(() => {this.showModal = false}),GestureMask.IgnoreInternal).onAppear(() => {this.name = '模态框拦截点击'})}}.width('100%').height('100%').justifyContent(FlexAlign.Center).backgroundColor('#FFFFFF')}
}
三、手势开发核心挑战与解决方案
(一)手势冲突的三维处理模型
冲突类型 | 解决方案 | 典型场景 |
同组件多手势竞争 | 按事件类型顺序触发(如长按优先点击) | 播放器控制按钮 |
父子组件同类型竞争 |
或 | 列表项滑动与父容器滚动 |
手势与系统交互冲突 |
阻止冒泡 | 自定义滑动冲突系统返回手势 |
(二)性能优化与用户体验平衡
- 参数调优矩阵:
场景 |
|
|
|
游戏操控 | 2vp | 200ms | 80vp/s |
办公应用 | 5vp | 500ms | 120vp/s |
老年人界面 | 10vp | 800ms | 50vp/s |
- 视觉反馈设计:
-
onActionStart
时添加按压态(如缩放时轻微缩小)。onActionUpdate
实时显示操作结果(如拖拽时的半透明预览)。onActionEnd
通过动画平滑过渡(如旋转结束时的弹性效果)。
参考内容:华为手势官方文档
从基础的点击事件到复杂的多级手势联动,ArkTS 通过标准化的手势接口和灵活的绑定策略,为开发者提供了全场景交互的解决方案。在实际开发中,建议遵循 "先单一后组合、先独立后层级" 的原则,通过日志监控(console.log(event)
)和可视化调试工具(如 HarmonyOS DevEco Studio 的实时预览)逐步优化手势逻辑,最终实现精准响应与自然交互的平衡。
相关文章:
在HarmonyOS ArkTS ArkUI-X 5.0及以上版本中,手势开发全攻略:
在 HarmonyOS 应用开发中,手势交互是连接用户与设备的核心纽带。ArkTS 框架提供了丰富的手势处理能力,既支持点击、长按、拖拽等基础单一手势的精细控制,也能通过多种绑定策略解决父子组件的手势竞争问题。本文将结合官方开发文档,…...

MFC内存泄露
1、泄露代码示例 void X::SetApplicationBtn() {CMFCRibbonApplicationButton* pBtn GetApplicationButton();// 获取 Ribbon Bar 指针// 创建自定义按钮CCustomRibbonAppButton* pCustomButton new CCustomRibbonAppButton();pCustomButton->SetImage(IDB_BITMAP_Jdp26)…...

【入坑系列】TiDB 强制索引在不同库下不生效问题
文章目录 背景SQL 优化情况线上SQL运行情况分析怀疑1:执行计划绑定问题?尝试:SHOW WARNINGS 查看警告探索 TiDB 的 USE_INDEX 写法Hint 不生效问题排查解决参考背景 项目中使用 TiDB 数据库,并对 SQL 进行优化了,添加了强制索引。 UAT 环境已经生效,但 PROD 环境强制索…...

Vue3 + Element Plus + TypeScript中el-transfer穿梭框组件使用详解及示例
使用详解 Element Plus 的 el-transfer 组件是一个强大的穿梭框组件,常用于在两个集合之间进行数据转移,如权限分配、数据选择等场景。下面我将详细介绍其用法并提供一个完整示例。 核心特性与用法 基本属性 v-model:绑定右侧列表的值&…...
前端倒计时误差!
提示:记录工作中遇到的需求及解决办法 文章目录 前言一、误差从何而来?二、五大解决方案1. 动态校准法(基础版)2. Web Worker 计时3. 服务器时间同步4. Performance API 高精度计时5. 页面可见性API优化三、生产环境最佳实践四、终极解决方案架构前言 前几天听说公司某个项…...

23-Oracle 23 ai 区块链表(Blockchain Table)
小伙伴有没有在金融强合规的领域中遇见,必须要保持数据不可变,管理员都无法修改和留痕的要求。比如医疗的电子病历中,影像检查检验结果不可篡改行的,药品追溯过程中数据只可插入无法删除的特性需求;登录日志、修改日志…...

遍历 Map 类型集合的方法汇总
1 方法一 先用方法 keySet() 获取集合中的所有键。再通过 gey(key) 方法用对应键获取值 import java.util.HashMap; import java.util.Set;public class Test {public static void main(String[] args) {HashMap hashMap new HashMap();hashMap.put("语文",99);has…...
【Linux】C语言执行shell指令
在C语言中执行Shell指令 在C语言中,有几种方法可以执行Shell指令: 1. 使用system()函数 这是最简单的方法,包含在stdlib.h头文件中: #include <stdlib.h>int main() {system("ls -l"); // 执行ls -l命令retu…...

3.3.1_1 检错编码(奇偶校验码)
从这节课开始,我们会探讨数据链路层的差错控制功能,差错控制功能的主要目标是要发现并且解决一个帧内部的位错误,我们需要使用特殊的编码技术去发现帧内部的位错误,当我们发现位错误之后,通常来说有两种解决方案。第一…...

Debian系统简介
目录 Debian系统介绍 Debian版本介绍 Debian软件源介绍 软件包管理工具dpkg dpkg核心指令详解 安装软件包 卸载软件包 查询软件包状态 验证软件包完整性 手动处理依赖关系 dpkg vs apt Debian系统介绍 Debian 和 Ubuntu 都是基于 Debian内核 的 Linux 发行版ÿ…...
多场景 OkHttpClient 管理器 - Android 网络通信解决方案
下面是一个完整的 Android 实现,展示如何创建和管理多个 OkHttpClient 实例,分别用于长连接、普通 HTTP 请求和文件下载场景。 <?xml version"1.0" encoding"utf-8"?> <LinearLayout xmlns:android"http://schemas…...

8k长序列建模,蛋白质语言模型Prot42仅利用目标蛋白序列即可生成高亲和力结合剂
蛋白质结合剂(如抗体、抑制肽)在疾病诊断、成像分析及靶向药物递送等关键场景中发挥着不可替代的作用。传统上,高特异性蛋白质结合剂的开发高度依赖噬菌体展示、定向进化等实验技术,但这类方法普遍面临资源消耗巨大、研发周期冗长…...
QMC5883L的驱动
简介 本篇文章的代码已经上传到了github上面,开源代码 作为一个电子罗盘模块,我们可以通过I2C从中获取偏航角yaw,相对于六轴陀螺仪的yaw,qmc5883l几乎不会零飘并且成本较低。 参考资料 QMC5883L磁场传感器驱动 QMC5883L磁力计…...
Cesium1.95中高性能加载1500个点
一、基本方式: 图标使用.png比.svg性能要好 <template><div id"cesiumContainer"></div><div class"toolbar"><button id"resetButton">重新生成点</button><span id"countDisplay&qu…...

大型活动交通拥堵治理的视觉算法应用
大型活动下智慧交通的视觉分析应用 一、背景与挑战 大型活动(如演唱会、马拉松赛事、高考中考等)期间,城市交通面临瞬时人流车流激增、传统摄像头模糊、交通拥堵识别滞后等问题。以演唱会为例,暖城商圈曾因观众集中离场导致周边…...

循环冗余码校验CRC码 算法步骤+详细实例计算
通信过程:(白话解释) 我们将原始待发送的消息称为 M M M,依据发送接收消息双方约定的生成多项式 G ( x ) G(x) G(x)(意思就是 G ( x ) G(x) G(x) 是已知的)࿰…...
Java如何权衡是使用无序的数组还是有序的数组
在 Java 中,选择有序数组还是无序数组取决于具体场景的性能需求与操作特点。以下是关键权衡因素及决策指南: ⚖️ 核心权衡维度 维度有序数组无序数组查询性能二分查找 O(log n) ✅线性扫描 O(n) ❌插入/删除需移位维护顺序 O(n) ❌直接操作尾部 O(1) ✅内存开销与无序数组相…...

【HarmonyOS 5.0】DevEco Testing:鸿蒙应用质量保障的终极武器
——全方位测试解决方案与代码实战 一、工具定位与核心能力 DevEco Testing是HarmonyOS官方推出的一体化测试平台,覆盖应用全生命周期测试需求,主要提供五大核心能力: 测试类型检测目标关键指标功能体验基…...
在rocky linux 9.5上在线安装 docker
前面是指南,后面是日志 sudo dnf config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo sudo dnf install docker-ce docker-ce-cli containerd.io -y docker version sudo systemctl start docker sudo systemctl status docker …...

Day131 | 灵神 | 回溯算法 | 子集型 子集
Day131 | 灵神 | 回溯算法 | 子集型 子集 78.子集 78. 子集 - 力扣(LeetCode) 思路: 笔者写过很多次这道题了,不想写题解了,大家看灵神讲解吧 回溯算法套路①子集型回溯【基础算法精讲 14】_哔哩哔哩_bilibili 完…...

python/java环境配置
环境变量放一起 python: 1.首先下载Python Python下载地址:Download Python | Python.org downloads ---windows -- 64 2.安装Python 下面两个,然后自定义,全选 可以把前4个选上 3.环境配置 1)搜高级系统设置 2…...
mongodb源码分析session执行handleRequest命令find过程
mongo/transport/service_state_machine.cpp已经分析startSession创建ASIOSession过程,并且验证connection是否超过限制ASIOSession和connection是循环接受客户端命令,把数据流转换成Message,状态转变流程是:State::Created 》 St…...

安宝特方案丨XRSOP人员作业标准化管理平台:AR智慧点检验收套件
在选煤厂、化工厂、钢铁厂等过程生产型企业,其生产设备的运行效率和非计划停机对工业制造效益有较大影响。 随着企业自动化和智能化建设的推进,需提前预防假检、错检、漏检,推动智慧生产运维系统数据的流动和现场赋能应用。同时,…...

如何在看板中体现优先级变化
在看板中有效体现优先级变化的关键措施包括:采用颜色或标签标识优先级、设置任务排序规则、使用独立的优先级列或泳道、结合自动化规则同步优先级变化、建立定期的优先级审查流程。其中,设置任务排序规则尤其重要,因为它让看板视觉上直观地体…...
IGP(Interior Gateway Protocol,内部网关协议)
IGP(Interior Gateway Protocol,内部网关协议) 是一种用于在一个自治系统(AS)内部传递路由信息的路由协议,主要用于在一个组织或机构的内部网络中决定数据包的最佳路径。与用于自治系统之间通信的 EGP&…...

PPT|230页| 制造集团企业供应链端到端的数字化解决方案:从需求到结算的全链路业务闭环构建
制造业采购供应链管理是企业运营的核心环节,供应链协同管理在供应链上下游企业之间建立紧密的合作关系,通过信息共享、资源整合、业务协同等方式,实现供应链的全面管理和优化,提高供应链的效率和透明度,降低供应链的成…...
ssc377d修改flash分区大小
1、flash的分区默认分配16M、 / # df -h Filesystem Size Used Available Use% Mounted on /dev/root 1.9M 1.9M 0 100% / /dev/mtdblock4 3.0M...
线程同步:确保多线程程序的安全与高效!
全文目录: 开篇语前序前言第一部分:线程同步的概念与问题1.1 线程同步的概念1.2 线程同步的问题1.3 线程同步的解决方案 第二部分:synchronized关键字的使用2.1 使用 synchronized修饰方法2.2 使用 synchronized修饰代码块 第三部分ÿ…...
uni-app学习笔记二十二---使用vite.config.js全局导入常用依赖
在前面的练习中,每个页面需要使用ref,onShow等生命周期钩子函数时都需要像下面这样导入 import {onMounted, ref} from "vue" 如果不想每个页面都导入,需要使用node.js命令npm安装unplugin-auto-import npm install unplugin-au…...

Mybatis逆向工程,动态创建实体类、条件扩展类、Mapper接口、Mapper.xml映射文件
今天呢,博主的学习进度也是步入了Java Mybatis 框架,目前正在逐步杨帆旗航。 那么接下来就给大家出一期有关 Mybatis 逆向工程的教学,希望能对大家有所帮助,也特别欢迎大家指点不足之处,小生很乐意接受正确的建议&…...