HarmonyOS NEXT实战:图片放大和缩小

简介: 本示例通过绑定捏合手势(PinchGesture),实现用两个手指捏合放大和缩小图片的功能。使用Image组件显示图片,并通过scale属性控制缩放比例。绑定2指触发的捏合手势,在onActionUpdate事件中动态调整图片缩放值,达到交互式缩放效果。

目标:通过两个手指捏合放大和缩小图片

知识点:
捏合手势(PinchGesture)用于触发捏合手势,触发捏合手势的最少手指为2指,最大为5指,最小识别距离为5vp。
接口

PinchGesture(value?:{
   fingers?:number, distance?:number})

捏合手势用于触发捏合手势事件,拥有两个可选参数:

  1. fingers:用于声明触发捏合手势所需要的最少手指数量,最小值为2,最大值为5,默认值为2。触发手势手指可以多于fingers数目,但只有先落下的与fingers相同数目的手指参与手势计算。
  2. distance:用于声明触发捏合手势的最小距离,单位为vp,默认值为5。说明:取值范围:[0, +∞),当识别距离的值小于等于0时,会被转化为默认值。

API15新增:
isFingerCountLimited
是否检查触摸屏幕的手指数量。若触摸屏幕的手指数量不等于设置的触发捏合的最少手指数(即上述fingers参数),手势将不会被识别。只有当触摸屏幕的手指数等于设置的触发捏合手势的最小手指数,并且滑动距离满足阈值要求时,手势才能被成功识别(只有先落下的两根手指参与手势计算,若抬起其中的一个,手势识别失败)。对于已经成功识别的手势,后续改变触摸屏幕的手指数量,将不会触发onActionUpdate事件,但可以触发onActionEnd事件。默认值:false。

事件

onActionStart(event:(event: GestureEvent) => void)    //Pinch手势识别成功回调。
onActionUpdate(event:(event: GestureEvent) => void)    //Pinch手势移动过程中回调。
onActionEnd(event:(event: GestureEvent) => void)    //Pinch手势识别成功,手指抬起后触发回调。
onActionCancel(event: () => void)    //Pinch手势识别成功,接收到触摸取消事件触发回调。

属性
tag:设置Pinch手势标志,用于自定义手势判定时区分绑定的手势。
allowedTypes:设置Pinch手势支持的事件输入源。

实战:ImageEnlargementReductionDemoPage

@Entry
@Component
struct ImageEnlargementReductionDemoPage {
   
  @State scaleValue: number = 1;
  @State pinchValue: number = 1;
  @State pinchX: number = 0;
  @State pinchY: number = 0;

  build() {
   
    Stack({
    alignContent: Alignment.Top }) {
   
      Image('https://pica.zhimg.com/v2-764199c9470ff436082f35610f1f81f4_1440w.jpg')
        .width('100%')
          // 在组件上绑定缩放比例,可以通过修改缩放比例来实现组件的缩小或者放大
        .scale({
    x: this.scaleValue, y: this.scaleValue, z: 1 })
        .gesture(
          // 在组件上绑定2指触发的捏合手势
          PinchGesture({
    fingers: 2 })
            .onActionStart((event: GestureEvent | undefined) => {
   
              console.info('Pinch start');
            })
              // 当捏合手势触发时,可以通过回调函数获取缩放比例,从而修改组件的缩放比例
            .onActionUpdate((event: GestureEvent | undefined) => {
   
              if (event) {
   
                this.scaleValue = this.pinchValue * event.scale;
                this.pinchX = event.pinchCenterX;
                this.pinchY = event.pinchCenterY;
              }
            })
            .onActionEnd(() => {
   
              this.pinchValue = this.scaleValue;
              console.info('Pinch end');
            })
        )

      Text('图片放大缩小Demo')
        .fontColor(Color.Orange)
        .fontSize(24)
    }
    .width('100%')
    .height('100%')
  }
}
目录
相关文章
|
4月前
|
容器
HarmonyOS NEXT仓颉开发语言实战案例:外卖App
仓颉语言实战分享,教你如何用仓颉开发外卖App界面。内容包括页面布局、导航栏自定义、搜索框实现、列表模块构建等,附完整代码示例。轻松掌握Scroll、List等组件使用技巧,提升HarmonyOS应用开发能力。
|
3月前
|
移动开发 前端开发 JavaScript
鸿蒙NEXT时代你所不知道的全平台跨端框架:CMP、Kuikly、Lynx、uni-app x等
本篇基于当前各大活跃的跨端框架的现状,对比当前它们的情况和未来的可能,帮助你在选择框架时更好理解它们的特点和差异。
312 0
|
4月前
|
安全 API 开发工具
【HarmonyOS NEXT】一键扫码功能
这些Kit为我们应用开发提升了极大地效率。很多简单的功能,如果不需要太深的定制化需求,直接调用kit提供的API就可以实现,在android或者ios上需要很多代码才能实现的功能效果。
119 0
HarmonyOS NEXT仓颉开发语言实战案例:电影App
周末好!本文分享使用仓颉语言重构ArkTS实现的电影App案例,对比两者在UI布局、组件写法及语法差异。内容包括页面结构、列表分组、分类切换与电影展示等。通过代码演示仓颉在HarmonyOS开发中的应用。##仓颉##ArkTS##HarmonyOS开发
|
4月前
|
容器
HarmonyOS NEXT仓颉开发语言实战案例:健身App
本期分享一个健身App首页的布局实现,顶部采用Stack容器实现重叠背景与偏移效果,列表部分使用List结合Scroll实现可滚动内容。代码结构清晰,适合学习HarmonyOS布局技巧。
HarmonyOS NEXT仓颉开发语言实战案例:小而美的旅行App
本文分享了一个旅行App首页的设计与实现,使用List容器搭配Row、Column布局完成个人信息、功能列表及推荐模块的排版,详细展示了HarmonyOS下的界面构建技巧。
|
18天前
|
存储 缓存 5G
鸿蒙 HarmonyOS NEXT端云一体化开发-云存储篇
本文介绍用户登录后获取昵称、头像的方法,包括通过云端API和AppStorage两种方式,并实现上传头像至云存储及更新用户信息。同时解决图片缓存问题,添加上传进度提示,支持自动登录判断,提升用户体验。
90 0
|
18天前
|
存储 负载均衡 数据库
鸿蒙 HarmonyOS NEXT端云一体化开发-云函数篇
本文介绍基于华为AGC的端云一体化开发流程,涵盖项目创建、云函数开通、应用配置及DevEco集成。重点讲解云函数的编写、部署、调用与传参,并涉及环境变量设置、负载均衡、重试机制与熔断策略等高阶特性,助力开发者高效构建稳定云端服务。
178 0
鸿蒙 HarmonyOS NEXT端云一体化开发-云函数篇
|
18天前
|
存储 JSON 数据建模
鸿蒙 HarmonyOS NEXT端云一体化开发-云数据库篇
云数据库采用存储区、对象类型、对象三级结构,支持灵活的数据建模与权限管理,可通过AGC平台或本地项目初始化,实现数据的增删改查及端侧高效调用。
50 0
|
18天前
|
存储 开发者 容器
鸿蒙 HarmonyOS NEXT星河版APP应用开发-ArkTS面向对象及组件化UI开发使用实例
本文介绍了ArkTS语言中的Class类、泛型、接口、模块化、自定义组件及状态管理等核心概念,并结合代码示例讲解了对象属性、构造方法、继承、静态成员、访问修饰符等内容,同时涵盖了路由管理、生命周期和Stage模型等应用开发关键知识点。
150 0
鸿蒙 HarmonyOS NEXT星河版APP应用开发-ArkTS面向对象及组件化UI开发使用实例