使用ReactNative加载Svga动画支持三端【Android/IOS/Harmony】

这是一款使用ReactNative加载Svga动画的播放器插件 Android/ios/harmony三端统一

版本:latest

为了方便大家使用,我基于自己原先封装的RN-HarmonySvgaPlayer的插件https://github.com/yrjwcharm/react-native-ohos-svgaplayer扩展了其他另外两端支持android/ios ,弥补了之前还需要额外安装其他两端的SvgaPlayer库的弊端,现在统一使用新库名 @yrjwcharm/react-native-svga-player

@yrjwcharm/react-native-svga-player

!TIP Github 地址

安装与使用

npm
bash 复制代码
npm install @yrjwcharm/react-native-svga-player
yarn
bash 复制代码
yarn add @yrjwcharm/react-native-svga-player

下面的代码展示了这个库的基本使用场景:

!WARNING 使用时 import RNSvgaPlayer from '@yrjwchram/react-native-svga-player'

js 复制代码
import React from "react";
import { View, Dimensions, StyleSheet } from "react-native";
import RNSvgaPlayer from '@yrjwcharm/react-native-svga-player'

export function App() {
  return (
   <RNSvgaPlayer
    source="https://raw.githubusercontent.com/yyued/SVGAPlayer-iOS/master/SVGAPlayer/Samples/Goddess.svga"
        style={{
          width: 300,
          height: 150,
        }}
      />
  );
}

const styles = StyleSheet.create({
   container: {
    flex: 1,
    justifyContent: "flex-start",
    alignItems: "center",
  },
});

更多详情用法参考 三端Svga动画统一使用点击这里

android/ios 自动Link编译就行 ios 需要pod install

目前 HarmonyOS 暂不支持 AutoLink,所以 Link 步骤需要手动配置。

1、执行 package.json里的 codegen脚本命令 yarn codegen

js 复制代码
  "scripts": {
    "codegen": "react-native codegen-harmony --cpp-output-path ./harmony/entry/src/main/cpp/generated --rnoh-module-path ./harmony/entry/oh_modules/@rnoh/react-native-openharmony --no-safety-check"
  }

2.执行完codegen以后 会在 harmony工程 entry/src/main/cpp/generated下生成对应的头文件,该库默认有三个文件,特别注意生成的RNOHGeneratedPackage.h文件

3、接下来使用 DevEco Studio 打开项目里的 HarmonyOS 工程 harmony

  • 1.在工程根目录的 oh-package.json5 添加 overrides 字段
json 复制代码
{
  ...
  "overrides": {
    "@rnoh/react-native-openharmony": "file:../libs/react_native_openharmony_release.har",
  }
}
  • 2.引入原生端代码 ,目前有两种方法:

      1. 通过 har 包引入(在 IDE 完善相关功能后该方法会被遗弃,目前首选此方法);
      1. 直接链接源码。

方法一:通过 har 包引入(推荐)

!TIP har 包位于三方库安装路径的 harmony 文件夹下。

打开 entry/oh-package.json5,添加以下依赖

json 复制代码
"dependencies": {
    "@rnoh/react-native-openharmony": "file:../libs/react_native_openharmony_release.har",
    "@react-native-ohos/react-native-svga-player": "file:../../node_modules/react-native-ohos-svgaplayer/harmony/svgaplayer.har",
  },

点击右上角的 sync 按钮

或者在终端执行:

bash 复制代码
cd entry
ohpm install

方法二:直接链接源码

!TIP 从react-native-ohos-svga-player获取到svgaplayer源码文件,直接在harmony工程中通过File->New->Import->Import Module导入即可 主工程entry/oh-package.json5中添加

json 复制代码
"dependencies": {
    "@rnoh/react-native-openharmony": "file:../libs/react_native_openharmony_release.har",
    "@react-native-ohos/react-native-svga-player": "file:../svgaplayer",

  }
  • 3.打开 entry/src/main/cpp/PackageProvider.cpp,添加:

    diff 复制代码
    #include "RNOH/PackageProvider.h"
    #include "SamplePackage.h"
    + #include "generated/RNOHGeneratedPackage.h"
    
    using namespace rnoh;
    
    std::vector<std::shared_ptr<Package>> PackageProvider::getPackages(Package::Context ctx) {
        return {
          std::make_shared<SamplePackage>(ctx),
    +     std::make_shared<RNOHGeneratedPackage>(ctx),
    
        };
    }
  • 4.在 ArkTs 侧引入 SvgaPlayerView 组件

找到 function buildCustomRNComponent() ,一般位于 entry/src/main/ets/pages/index.etsentry/src/main/ets/rn/LoadBundle.ets,添加:

diff 复制代码
  ...
+ import { SvgaPlayerView } from '@react-native-ohos/react-native-svga-player';

  @Builder
export function buildCustomRNComponent(ctx: ComponentBuilderContext) {
  ...
+  if (ctx.componentName === SvgaPlayerView.NAME) {
+     SvgaPlayerView({
+       ctx: ctx.rnComponentContext,
+       tag: ctx.tag,
+     })
+   }
    ...
  }
  ...
    1. !TIP 本库使用了混合方案,需要添加组件名。

entry/src/main/ets/pages/index.etsentry/src/main/ets/rn/LoadBundle.ets 找到常量 arkTsComponentNames 在其数组里添加组件名

diff 复制代码
const arkTsComponentNames: Array<string> = [
  SampleView.NAME,
  GeneratedSampleView.NAME,
  PropsDisplayer.NAME,
+ SvgaPlayerView.NAME
  ];

运行

点击右上角的 sync 按钮

或者在终端执行:

bash 复制代码
cd entry
ohpm install

然后编译、运行即可。

兼容三端Android、iOS、Harmony的 Svga动画 demo示例 -> https://github.com/yrjwcharm/react-native-ohos/tree/feature/react-native-svga-player

开源不易,希望您可以动一动小手点点小⭐⭐
👴希望大家如有好的需求踊跃提交,如有问题请提交issue,空闲时间会扩充与修复优化

开源协议

本项目基于 The MIT License (MIT) ,请自由地享受和参与开源。

相关推荐
峥嵘life1 小时前
Android getprop 属性限制详解:User 版本属性获取问题分析
android·开发语言·python·学习
人月神话-Lee1 小时前
【图像处理】Core Image 与 GPU 渲染管线——让滤镜飞起来
图像处理·人工智能·ios·chatgpt·ai编程·swift·gpu
一航jason2 小时前
Speed Tools:一套低侵入的 Android 插件化 + 动态换肤 + 字体切换框架
android·插件化·组件化·换肤
李斯维3 小时前
Jetpack 可观察数据容器 LiveData 的入门与基础使用
android·android jetpack
问心无愧05134 小时前
ctf show web入门261
android·前端·笔记
alexhilton4 小时前
车载系统中的可扩展UI:从UI嵌入到系统窗口编排
android·kotlin·android jetpack
Cloud_Shy6184 小时前
解读《Effective Python 3rd Edition》:从练气到老魔(第一章 Item 4 - 6)
android·数据库·论文阅读·python
therese_100864 小时前
安卓面试题
android
码云骑士4 小时前
Android Launcher启动过程
android
Java面试题总结5 小时前
MySQL EXISTS 详解:存在性判断、NOT EXISTS 与实战示例
android·数据库·mysql