首页 > 其他分享 >三方库的基本使用

三方库的基本使用

时间:2024-09-11 11:53:47浏览次数:7  
标签:三方 基本 播放 动画 使用 animationItem ohpm ohos lottie

三方库是开发者对系统能力的封装和拓展,可以实现代码复用,提升开发效率。

一、三方库的获取

        1、访问Gitee开源社区

        在Gitee中,搜索OpenHarmony-TPC仓库,在tpc_resource中对三方库进行了资源汇总,可以供开发者参考。可通过扫码获取地址。Gitee三方库链接地址

        

        2、OpenHarmony三方库中心仓

        进入OpenHarmony三方库中心仓,根据类型或者直接搜索寻找需要的三方库。可通过扫码获取地址。OpenHarmony三方库中心仓

        

二、三方库分类

        常用的三方库可以分为UI、动画、网络、图片、多媒体、数据存储、安全、工具等。

        1、Gitee中三方库分类概览

             

  • UI库:
    • @ohos/textlayoutbuilder:可以定制任一样式的文本构建工具,包括字体间距、大小、颜色、富文本高亮显示等。
    • @ohos/roundedimageview:可以生成圆角矩形、或者椭圆形等图片形状。
  • 网络库:
    • @ohos/axios:可以运行在node.js 和浏览器中,基于Axios 原库v1.3.4版本进行适配,并沿用其现有用法和特性。
  • 动画库:
    • @ohos/lottie:可以解析Adobe After Effects软件通过Bodymovin插件导出的json格式的动画,并在移动设备上进行本地渲染。
    • @ohos/svg:可以解析SVG图片并渲染到页面上。

三、三方库使用实例(@ohos/lottie) 

        1、安装ohpm

        OHPM CLI 作为鸿蒙生态三方库的包管理工具,支持OpenHarmony共享包的发布、安装和依赖管理。在HarmonyOS开发官网搜索“ohpm使用指导”,根据电脑的配置,选择安装合适的ohpm。

        

        (1)下载ohpm工具包

                ohpm下载链接地址

        

        (2)初始化ohpm

                解压文件,进入“ohpm/bin”目录,打开命令行工具,执行如下指令初始化ohpm

                注:初始化ohpm前,需先完成node.js环境变量配置。

                        注意文件路径:D:\commandline-tools-windows-2.0.0.2\command-line-tools\ohpm\bin,一定要是ohpm下的bin

        

                Windows环境下执行:

init.bat

                Linux/macOS环境下执行:

./init

        (3)将ohpm配置到环境变量中 

                 Windows环境:在此电脑 > 属性 > 高级系统设置 > 高级 > 环境变量中,将ohpm命令行工具的bin目录配置到系统或者用户的PATH变量中;

                macOS环境:打开终端工具,执行以下命令

export OHPM_HOME=/home/xx/Downloads/ohpm  #本处路径请替换为ohpm的安装路径
export PATH=${OHPM_HOME}/bin:${PATH}

        (4)检测安装是否成功 

ohpm -v

        终端输出为版本号(如:0.6.10),则表示安装成功。

        

        其他配置,参考ohpm指导 

 2、@ohos/lottie是什么

        @ohos/lottie是基于lottie-web开发,集成在三方库社区内的开源版本,是HarmonyOS系统中复杂动画的一种解决方案。

        动画是传达想法和创造更好的用户交互体验的工具,常见使用动画的场景如下:

  • 启动动画:APP logo动画的播放。
  • 加载动画:网络请求的loading动画。
  • 上下拉刷新动画:请求更多资源时的刷新动画。
  • 按钮动画:切换按钮、编辑按钮、播放按钮等按钮的切换过渡动画。
  • 视图转场动画:一些场景的转场添加动画能够提升用户体验。

        @ohos/lottie提供了使用JSON动画文件的解决方案,开发者可以在原生应用中像使用静态图像一样使用动画,而不用关注动画的实现过程,并且@ohos/lottie具有一套完整的API控制动画的行为,可以让动画更具有交互性。接下来将介绍@ohos/lottie的安装和基本使用。

         

3、@ohos/lottie的安装与卸载

        (1)安装@ohos/lottie

        通过ohpm执行对应的指令,将lottie安装到项目中。

ohpm install @ohos/lottie

        (2)卸载@ohos/lottie

        通过ohpm执行卸载指令,将lottie从项目中删除,其程序包和配置信息将会从项目中移除。

ohpm uninstall @ohos/lottie

        4、使用@ohos/lottie 

        (1)@ohos/lottie的引入

        通过import指令在项目中引入@ohos/lottie到文件中。

import lottie from '@ohos/lottie'

        (2) 构建Canvas画布

        @ohos/lottie解析JSON动画文件的数据需要基于Canvas 画布进行2D渲染,所以在加载JSON动画之前,要先初始化渲染上下文,并在画面中创建Canvas画布区域,将对应的渲染上下文renderingContext传递给Canvas。

// 初始化渲染上下文  
private renderingSettings: RenderingContextSettings = new RenderingContextSettings(true) // 设置开启抗锯齿
private renderingContext: CanvasRenderingContext2D = new CanvasRenderingContext2D(this.renderingSettings)  // 创建2D渲染上下文
// renderingContext为构建的上下文

        (3)准备JSON文件

        准备JSON文件,即动画的源数据,文件中描述了动画的具体路径。 

        (4)关联画布

// 创建Canvas画布,并绑定renderingContext   
Canvas(this.renderingContext)
  ...

        (5)加载JSON动画

        加载JSON动画需要用到loadAnimation方法,在方法中需配置相应的初始设置,包括渲染上下文、渲染方式以及JSON动画资源的路径等。可以直接使用lottie.loadAnimation方法,也可以用一个animationItem实例来接收返回的animationItem对象。

// 用animationItem实例接收
// 加载动画,传入之前定义的Canvas、上下文、JSON文件
let animationItem = lottie.loadAnimation({
            container: this.renderingContext,            // 渲染上下文
            renderer: 'canvas',                          // 渲染方式
            loop: true,                                  // 是否循环播放,默认true
            autoplay: true,                              // 是否自动播放,默认true
            path: 'common/lottie/data.json',             // json路径
          })     
 
    lottie.loadAnimation({                               // 或者直接使用
            container: this.renderingContext,            // 渲染上下文
            renderer: 'canvas',                          // 渲染方式
            loop: true,                                  // 是否循环播放,默认true
            autoplay: true,                              // 是否自动播放,默认true
            path: 'common/lottie/data.json',             // json路径
          })

        (6)控制动画

        @ohos/lottie内封装了包括状态控制,进度控制,播放设置控制和属性控制等多个API,用户可以利用这些API完成对动画的控制,实现更加灵活的交互效果。 

// 播放、暂停、停止、销毁  可以使用lottie,也可以使用animationItem实例进行控制
lottie.play();        // 从目前停止的帧开始播放
lottie.stop();        // 停止播放,回到第0帧
lottie.pause();       // 暂停该动画,在当前帧停止并保持
lottie.togglePause(); // 切换暂停/播放状态
lottie.destroy();     // 删除该动画,移除相应的元素标签等。在unmount的时候,需要调用该方法

// 播放进度控制
animationItem.goToAndStop(value, isFrame); // 跳到某个时刻/帧并停止。isFrame(默认false)指示value表示帧还是时间(毫秒)
animationItem.goToAndPlay(value, isFrame); // 跳到某个时刻/帧并进行播放
animationItem.goToAndStop(30, true);       // 例:跳转到第30帧并停止
animationItem.goToAndPlay(300);            // 例:跳转到第300毫秒并播放

// 控制帧播放
animationItem.setSegment(5,15);             // 限定动画资源播放时的整体帧范围,即设置动画片段
animationItem.resetSegments(5,15);          // 重置播放的动画片段
animationItem.playSegments(arr, forceFlag); // arr可以包含两个数字或者两个数字组成的数组,forceFlag表示是否立即强制播放该片段
animationItem.playSegments([10,20], false); // 例:播放完之前的片段,播放10-20帧
animationItem.playSegments([[5,15],[20,30]], true); //例: 直接播放5-15帧和20-30帧

// 动画基本属性控制
lottie.setSpeed(speed);         // 设置播放速度,speed为1表示正常速度
lottie.setDirection(direction); // 设置播放方向,1表示正向播放,-1表示反向播放

// 获取动画帧数属性
animationItem.getDuration();    //获取动画时长

        (7)事件订阅 

        在一些特殊场景下,比如开始加载动画或者动画播放结束时,可能需要执行相应的操作,在@ohos/lottie中提供了事件订阅和取消订阅的功能,当触发对应的event,会执行传入的回调函数,用户可以在回调函数中完成要实现的功能。

// 订阅事件
animationItem.addEventListener(event,function(){
    // TODO something
})

// 取消订阅事件
animationItem.removeEventListener(event,function(){
    // TODO something
})

        常见的event事件类型如下:

// event事件类型
'enterFrame'   // 每进入一帧就会触发
'loopComplete' // 当前循环下播放(循环播放/非循环播放)结束时触发
'complete'     // 播放完成时触发
'segmentStart' // 播放指定片段时触发,playSegments、resetSegments等方法刚开始播放指定片段时会发出,如果playSegments播放多个片段,多个片段最开始都会触发。
'destroy'      // 销毁动画时触发
'data_ready'   // 数据准备完成
'DOMLoaded'    // 动画相关dom已经被添加
'error'        // 出现错误
'data_failed'  // 数据加载失败
  ...

 

标签:三方,基本,播放,动画,使用,animationItem,ohpm,ohos,lottie
From: https://blog.csdn.net/sinat_34896766/article/details/141885605

相关文章

  • 如何使用初始化种子和迭代函数生成列表
    本篇阅读的代码实现使用一个初始化种子和迭代函数,通过嵌套函数对初始化种子进行迭代,最终生成一个列表。1、unfold函数接受迭代函数,并初始化种子,产生列表。对函数fn进行迭代化处理,必须始终返回包含两个元素的列表[value,nextSeed],或者返回False以终止构建器函数。2、函数的u......
  • vue3 中使用 icon 图标的 3 种方案
    1.element-iconElementPlus提供了一套常用的图标集合。1.1.安装#选择一个你喜欢的包管理器#NPM$npminstall@element-plus/icons-vue#Yarn$yarnadd@element-plus/icons-vue#pnpm$pnpminstall@element-plus/icons-vue#选择一个你喜欢的包管理器1.2.......
  • QT使用定时器事件驱动完成定时播报效果
    widget.h#ifndefWIDGET_H#defineWIDGET_H#include<QWidget>#include<QObject>#include<QPushButton>#include<QLineEdit>#include<QLabel>#include<QTimer>#include<QString>#include<QTime>#include......
  • 使用线性规划优化库存管理:理论与实践应用1——基础版
    目录写在开头1.场景背景2.问题描述3.模型设定3.1需求预测和现有库存3.2补货和存储成本3.3仓库容量限制3.4安全库存要求3.5目标4.目标函数与约束条件4.1目标函数4.2约束条件5.Python实现5.1Python代码5.2整体思路介绍5.3输出结果6.模型的扩展性6.1多......
  • 使用PyTorch Lightning力量精简空间分析
    大家好,随着人工智能热潮的全面兴起,PyTorchLightning库正在获得越来越多的关注。其特别突出的地方在于简化复杂的机器学习操作,即使对于非开发者也是如此。深度学习和部分机器学习中的许多挑战性方面,如多GPU训练和实验跟踪,都由该框架自动处理,同时保持了PyTorch的灵活性和高效性......
  • (5-1)绘制饼状图:绘制基本的饼状图(绘制简易的饼状图+修饰饼状图+突出显示某个饼状图的部
    饼状图常用于数据统计和分析领域,通常分为2D与3D饼状图。饼状图显示一个数据系列(数据系列:在图表中绘制的相关数据点,这些数据源自数据表的行或列。在现实应用中,经常使用饼状图来展示数据分析的结果,这样可以更加直观的展示数据分析结果。在本节的内容中,将详细讲解使用Python绘制......
  • .NET 6.0 + WPF 使用 Prism 框架实现导航
    前言Prism一个开源的框架,专门用于开发可扩展、模块化和可测试的企业级XAML应用程序,适用于WPF(WindowsPresentationFoundation)和XamarinForms等平台。Prism基于MVVM(Model-View-ViewModel)设计模式,提供一套丰富的工具和库,能够实现模块化、依赖注入、导航和事件聚合等功能......
  • 使用第三方库(Senparc)完成小程序支付
    1.添加第三方库,如下图:2.支付代码:///<summary>///支付///</summary>///<paramname="model"></param>///<returns></returns>[Route("Pay")]publicWeixinJsPaySignaturePay(PayRequestmodel){stringtimeSt......
  • x-cmd pkg | duf - `df` 命令的现代化替代品, 用于查看磁盘空间使用情况和磁盘文件系统
    目录简介用户首次快速实验指南技术特点竞品和相关项目进一步探索简介Duf(DiskUsage/FreeUtility)是一个磁盘分析工具。其直观的输出和多样化的自定义选项,帮助用户更好地管理和优化存储资源。用户首次快速实验指南对于首次使用Duf的用户,可以参考下面的链接,快速......
  • OpenCV结构分析与形状描述符(17)判断轮廓是否为凸多边形的函数isContourConvex()的使用
    操作系统:ubuntu22.04OpenCV版本:OpenCV4.9IDE:VisualStudioCode编程语言:C++11算法描述测试轮廓的凸性。该函数测试输入的轮廓是否为凸的。轮廓必须是简单的,即没有自相交。否则,函数的输出是不确定的。cv::isContourConvex函数是OpenCV提供的一个用于判断轮廓是否......