OpenHarmony - ArkUI(ETS) 自定义图片查看组件 原创 精华
作者:王国菊
前言
日常开发中,经常会遇到一些图片查看的需求,此时有的用户习惯放大图片来看,那么在ets中如何实现呢?今日分享的组件由subsampling-scale-image-view+swiper来实现深度缩放视图、图像显示、手势平移缩放双击等。
项目说明
本组件界面搭建基于ArkUI中TS扩展的声明式开发范式,官网官方文档地址:基于TS扩展的声明式开发范式1、基于TS扩展的声明式开发范式2
工具版本:DevEco Studio 3.0 Beta2
SDK版本:3.0.0.1(API Version 7 Beta2)
主要功能
- 双击放大图片
- 如果图片已经是放大状态,双击恢复原图大小
- 点击下方缩略图列表,可查看对应图片
- 可旋转查看图片,每次旋转90度
- 点击箭头可查看上一组缩略视图和下一组缩略视图
效果展示
OpenHarmony npm包
OpenHarmony js/ts三方库使用的是OpenHarmony npm包,它是在传统的npm包的基础上,定义了OpenHarmony npm共享包特定的工程结构和配置文件,支持OpenHarmony页面组件相关API、资源的调用。通过OpenHarmony npm包,您可以实现多个模块或者多个工程共享OpenHarmony页面、资源等相关代码。
OpenHarmony npm共享包的实现依赖于npm,因此您需要了解和掌握npm的基础功能和机制,可通过npm官方文档进行了解
如何安装OpenHarmony npm包
设置 OpenHarmony推荐的npm专用仓库(如果使用DevEco Studio 3.0 Beta3及以上版本的命令行窗口,则可忽略此步骤)
在命令行工具中,执行如下命令进行安装,如安装subsampling-scale-image-view三方库,依赖包会存储在工程的node_modules目录下@ohos\subsampling-scale-image-view下。
在package.json中会自动添加如下依赖:
subsampling-scale-image-view组件目录结构
使用说明
主要用到的接口
接口 | 描述 |
---|---|
setZoomEnabled(zoomEnabled: boolean) | 设置图片是否可缩放 |
public setPanEnabled(panEnabled: boolean) | 设置图片是否可平移 |
public setMaxScale(maxScale: number) | 设置图片最大缩放比 |
public setOrientation(degrees: number) | 设置图片旋转角度 |
public getSWidth() | 获取图片高度 |
public getSHeight() | 获取图片高度 |
public setSingleTapListener(listener: OnSingleTapListener) | 单击图片监听器 |
public setLongPressListener(listener: OnLongPressListener) | 长按图片监听器 |
public setDoubleTapListener(listener: OnDoubleTapListener) | 双击图片监听器 |
设置图片资源
接口使用案例
轮播区域使用Stack布局
点击旋转按钮,每次旋转90度
项目源码
https://gitee.com/YiRanRuMeng/open-harmony-image-view/tree/master
总结
此组件主要实现深度缩放视图、图像显示、手势平移缩放双击等。
- subsampling-scale-image-view:深度缩放视图、图像显示、手势平移缩放双。
- swiper图片轮播。
- setOrientation设置旋转角度。
更多原创内容请关注:中软国际 HarmonyOS 技术团队
入门到精通、技巧到案例,系统化分享HarmonyOS开发技术,欢迎投稿和订阅,让我们一起携手前行共建鸿蒙生态。
图片的查看确实是很重要的一环。
很实用
国菊老师真棒(๑•̀ㅂ•́)و✧
怎么项目源码访问受限了呢?@国菊老师
有时间的时候可以看看 可以正常访问了 感谢反馈