OpenHarmony GIF图像渲染库—ohos-gif-drawable

2024-09-20 21:11:32 浏览数 (2)

简介

本项目是OpenHarmony系统的一款GIF图像渲染库,基于Canvas进行绘制,主要能力如下:

  • 支持播放GIF图片。
  • 支持控制GIF播放/暂停。
  • 支持重置GIF播放动画。
  • 支持调节GIF播放速率。
  • 支持监听GIF所有帧显示完成后的回调。
  • 支持设置显示大小。
  • 支持7种不同的展示类型。
  • 支持设置显示区域背景颜色。

下载安装

代码语言:typescript复制
ohpm install @ohos/gif-drawable

使用说明

1.使用taskpool替代worker,无需额外工程配置

2.在需要展示的位置使用GIFComponent自定义组件

代码语言:typescript复制
import { GIFComponent, ResourceLoader } from '@ohos/gif-drawable'
// gif绘制组件用户属性设置
@State model:GIFComponent.ControllerOptions = new GIFComponent.ControllerOptions();
// 是否自动播放
@State gifAutoPlay:boolean = true;
// 重置GIF播放,每次取反都能生效
@State gifReset:boolean = true;

// 在ARKUI的其他容器组件中添加该组件 如果需要绑定滚动组件内部可见/不可见状态 gif自动暂停开始播放能力,只需要加上bindScroller字段即可。
GIFComponent({model:$model, autoPlay:$gifAutoPlay, resetGif: $gifReset})

3.配置 GIFComponent.ControllerOptions达到更多的效果

代码语言:typescript复制
// 关闭动画			
this.gifAutoPlay = false;
// 销毁上一次资源
this.model.destroy();
// 新创建一个modelx,用于配置用户参数
let modelx = new GIFComponent.ControllerOptions()
modelx
  // 配置回调动画结束监听,和耗时监听	
  .setLoopFinish((loopTime) => {
   this.gifLoopCount  ;
   this.loopHint = '当前gif循环了'   this.gifLoopCount   '次,耗时='   loopTime   'ms'
   })
  // 设置图像和组件的适配类型
  .setScaleType(this.scaleType)
  // 设置播放速率
  .setSpeedFactor(this.speedFactor)
// 加载网络图片,getContext(this)中的this指向page页面或者组件都可以
ResourceLoader.downloadDataWithContext(getContext(this), {
   url: 'https://pic.ibaotu.com/gif/18/17/16/51u888piCtqj.gif!fwpaa70/fw/700'
   }, (sucBuffer) => {
    // 网络资源sucBuffer返回后处理
   modelx.loadBuffer(sucBuffer, () => {
   
   console.log('网络加载解析成功回调绘制!')
    // 开启自动播放   
   this.gifAutoPlay = true;
    // 给组件数据赋新的用户配置参数,达到后续gif动画效果   
   this.model = modelx;
   })
}, (err) => {
   // 用户根据返回的错误信息,进行业务处理(展示一张失败占位图、再次加载一次、加载其他图片等)
})

备注:由于屏幕密度关系,gif图片平移缩放后,不能沾满边缘的整个物理像素,在做像素混合效果时,会有在边缘像素形成边框效果,在web场景和源库软解码也存在相同效果,建议使用硬解码。

接口说明

GIFComponent 自定义组件

方法名

入参

接口描述

GIFComponent({ model: GIFComponent.ControllerOptions, autoPlay: boolean,resetGif:boolean})

model:GIFComponent.ControllerOptions, autoPlay:boolean,resetGif:boolean

自定义GIF渲染组件构造器

GIFComponent.ControllerOptions自定义组件配置

使用方法

入参

接口描述

getFrames()

获取所有解析图像数据帧

setFrames(images?: GIFFrame[])

images?: GIFFrame[]

设置解析图像数据帧集合

getLoopFinish()

获取循环结束最后一帧的回调方法

setLoopFinish(fn:(loopTime?)=>void)

fn:(loopTime?)=>void

设置循环结束最后一帧的回调方法

getScaleType()

获取用户设置组件展示类型

setScaleType(scaletype: ScaleType)

scaletype: ScaleType

设置组件展示类型

getPositionFinish()

获取帧回调方法

setPositionFinish(position: number, fn: (posTime?) => void)

position: number, fn: (posTime?) => void

设置帧位置和回调方法

getSpeedFactor()

获取当前播放速率

setSpeedFactor(speed: number)

speed: number

设置播放速率

getSeekTo()

获取当前播放某一静态帧

setSeekTo(gifPosition: number)

gifPosition: number

设置显示GIF某一静态帧

loadBuffer(buffer: ArrayBuffer, readyRender: (err?) => void)

buffer: ArrayBuffer, readyRender: (err?) => void

加载一个arraybuffer数据,展示GIF

GIFComponent.ScaleType

展示类型

展示类型描述

ScaleType.FIT_START

显示内容缩放至能全部显示,然后将其放置于自定义组件的左上方

ScaleType.FIT_END

显示内容缩放至能全部显示,然后将其放置于自定义组件的右下方

ScaleType.FIT_CENTER

显示内容缩放至能全部显示,然后将其放置于自定义组件的居中位置

ScaleType.CENTER

不进行缩放,然后将其放置于自定义组件的居中位置

ScaleType.CENTER_CROP

取(内容/自定义组件)的宽高比值的小值进行缩放,缩放至自定义组件大小,然后将其放置于自定义组件的居中位置

ScaleType.FIT_XY

将内容宽度和高度拉伸/压缩至自定义组件的大小

ScaleType.CENTER_INSIDE

当内容宽高任意一个大于自定义组件宽高表现为ScaleType.FIT_CENTER,如果内容都小于自定义组件表现为ScaleType.CENTER

GIFFrame 解析帧数据格式

代码语言:typescript复制
export class GIFFrame {

    // 显示帧 width 宽  height 高 top上边距 left左边距
    dims: { width: number; height: number; top: number; left: number}

    // 当前帧的像素数据指向的颜色数组
    colorTable?: [number, number, number][]

    // 当前帧到下一帧的间隔时长
    delay: number

    // 当前帧绘制要求 0保留 1在上一帧绘制此帧 2恢复画布背景 3.将画布恢复到绘制当前图像之前的先前状态
    disposalType: number

    // Uint8CampedArray颜色转换后的补片信息用于绘制
    patch: Uint8ClampedArray
    
    // 由patch生成的pixelmap图像
    drawPixelMap

    // 当前帧每个像素的颜色表查找索引
    pixels?: number[]

    // 表示透明度的可选颜色索引
    transparentIndex: number
}

约束与限制

在下述版本验证通过:

  • DevEco Studio: 4.1 (4.1.3.414), SDK: API11 (4.1.0.55)
  • DevEco Studio: 4.0 (4.0.3.512), SDK: API10 (4.0.10.9)
  • DevEco Studio: 4.0 Release(4.0.3.413), SDK: API10(4.0.10.3)

目录结构

代码语言:shell复制
|---- ohos-gif-drawable
|     |---- entry  # 示例代码文件夹
			|----pages # 页面测试代码
				|----index.ets #测试文件列表
				|----sample1TestCasePage.ets 		#硬解码GIF范例demo
				|----sample2TestCasePage.ets 		#软解码GIF范例demo
				|----networkLoadTestCasePage.ets	#软解码测试网络文件下载
				|----loadResourceAndRawFilePage.ets #软解码测试工程文件加载
				|----loadStringAndBufferPage.ets	#软解码测试app文件路径加载
|     |---- screenshots #截图
|     |---- library  # ohos-gif-drawble库文件夹
|           |---- src  # ohos-gif-drawble gif解析渲染核心代码
				|---- display #组件展示渲染相关
				|---- parse   #gif解析相关
				|---- utils   #工具方法相关
|           |---- index.ets  # ohos-gif-drawble 对外暴露接口
|     |---- README.MD  # 安装使用方法

写在最后

如果你觉得这篇内容对你还蛮有帮助,我想邀请你帮我三个小忙: