主頁 > 移動端開發 > App復雜影片實作——Rive保姆級教程

App復雜影片實作——Rive保姆級教程

2023-04-24 09:41:21 移動端開發

作者:京東物流 沈明亮

在App開發程序中,如果想實作影片效果,可以粗略分為兩種方式,一種是直接用代碼撰寫,像平移、旋轉等簡單的影片效果,都可以這么干,如果稍微復雜點,就會對開發工程師的數學功底、圖形影像學功底有很高的要求,

另一種方式,可以讓UI同學配合,一次性出多張圖片或者直接出一張GIF圖,通過短時間內快速輪播圖片的方式來實作復雜影片效果,這種方式真正實作起來還是有挺多問題的,比如缺少對影片程序的控制、圖片尺寸的適配等等,那么,有沒有更好的解決方案呢?

有的,Rive,

簡介

Rive是專門為簡化影片的實作而生的,設計師可以在其官網通過拖拉拽實作各種復雜影片效果,設計完畢后匯出影片檔案,工程師可以在App里直接匯入此檔案,配合相應的SDK即可實作,

其官網有詳細的開發檔案,同時也有自己的社區資源,我們可以直接從社區里下載別人設計好的影片效果進行學習,另外特別重要的是,Rive支持跨平臺,同時支持Android、iOS、Flutter、JS、React、C++等等,本文以Flutter的實作為例介紹,

一個完整的例子

  1. 登陸Rive官網進行設計,并匯出相應的影片檔案,Rive的影片檔案是以.riv結尾,

本文示例是從官網的社區里找的一個個人比較喜歡的動效,

  1. 依次運行下面的命令,引入rive sdk,

  1. 將匯出的.riv檔案放到資源目錄下,并修改pubspec.yaml檔案,

  1. 加載影片檔案并展示的核心代碼:

核心代碼就這么多,對于代碼中的標注詳細說明下:

  • 標注1的地方,主要作用是獲取狀態機控制器,fromArtboard 方法有兩個引數,第二個引數是狀態機的名稱,這個名稱需要和UI同學協商好,一旦確定好名稱就不允許設計同學再改了,對應于設計面板界面的左下角,如下圖:

  • 標注2的地方,本例的影片是根據“數值”的變化而變化的,findInput的入參同樣需要和UI同學協商好,一旦設計時把這個名字改了,代碼里也別忘了進行相應的修改,也在設計面板的左下角,在狀態機名稱的右邊,如下圖:

完整的代碼如下,大家可以按步驟自己操作體驗下,

class RiveDemo extends StatefulWidget {
  const RiveDemo({Key? key}) : super(key: key);

  @override
  State<RiveDemo> createState() => _RiveDemoState();
}

class _RiveDemoState extends State<RiveDemo> {
  /// 狀態機控制器
  StateMachineController? controller;
  /// 控制輸入數值
  SMIInput<double>? valueController;
  ///畫板,配合Rive widget 使用,展示影片效果,
  Artboard? riveArtboard;
  Timer? timer;

  @override
  void initState() {
    super.initState();
    //加載
    rootBundle.load('asset/rives/rive_demo.riv').then((value) async {
      final file = RiveFile.import(value);
      final artboard = file.mainArtboard;
      //1
      controller = StateMachineController.fromArtboard(artboard, 'TreeMachine');
      if (controller != null) {
        setState(() {
          artboard.addController(controller!);
          //2
          valueController = controller!.findInput('input');
          valueController!.value = https://www.cnblogs.com/jingdongkeji/archive/2023/04/23/-4;
        });
      }

      riveArtboard = artboard;
    });
  }

  @override
  void dispose() {
    controller?.dispose();
    stopAnimation();
    super.dispose();
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: const Text('Rive Demo'),
      ),
      backgroundColor: Colors.white,
      body: Center(
        child: riveArtboard == null ? const CircularProgressIndicator() : Rive(artboard: riveArtboard!),
      ),
      floatingActionButton: SizedBox(
        height: 50,
        child: Row(
          mainAxisAlignment: MainAxisAlignment.end,
          children: [
            TextButton(
              onPressed: () {
                startAnimation();
              },
              child: const Text('start'),
            ),
            TextButton(
              onPressed: () {
                stopAnimation();
              },
              child: const Text('stop'),
            ),
            TextButton(
              onPressed: () {
                resetAnimation();
              },
              child: const Text('reset'),
            ),
          ],
        ),
      ),
    );
  }

  /// 開始影片
  void startAnimation() {
    if (timer != null) {
      return;
    }
    timer = Timer.periodic(const Duration(milliseconds: 60), (timer) {
      valueController?.value += 0.5;
    });
  }

  /// 停止影片
  void stopAnimation() {
    timer?.cancel();
    timer = null;
  }

  /// 重置影片
  void resetAnimation() {
    stopAnimation();
    valueController?.value = https://www.cnblogs.com/jingdongkeji/archive/2023/04/23/0;
  }
}

總結

像本例中的影片效果,如果用代碼來撰寫,時間成本會很大很大,如果靠圖片的堆積,實作起來也很麻煩,而且由于圖片的數量增多,安裝包的體積也會增加很多,但是用rive,實作起來卻很方便,可能唯一的成本就是設計師同學的學習成本,

Rive不僅支持本地影片檔案的加載,還可以將影片檔案放到服務器上,利用RiveAnimation.network方法進行加載,更多的使用示例可以參考:
https://github.com/rive-app/rive-flutter/tree/master/example

轉載請註明出處,本文鏈接:https://www.uj5u.com/yidong/551011.html

標籤:其他

上一篇:Android Studio的安裝及環境配置

下一篇:返回列表

標籤雲
其他(157972) Python(38094) JavaScript(25389) Java(17988) C(15215) 區塊鏈(8259) C#(7972) AI(7469) 爪哇(7425) MySQL(7140) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4559) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2430) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1959) Web開發(1951) HtmlCss(1923) python-3.x(1918) 弹簧靴(1913) C++(1910) xml(1889) PostgreSQL(1873) .NETCore(1854) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 【從零開始擼一個App】Dagger2

    Dagger2是一個IOC框架,一般用于Android平臺,第一次接觸的朋友,一定會被搞得暈頭轉向。它延續了Java平臺Spring框架代碼碎片化,注解滿天飛的傳統。嘗試將各處代碼片段串聯起來,理清思緒,真不是件容易的事。更不用說還有各版本細微的差別。 與Spring不同的是,Spring是通過反射 ......

    uj5u.com 2020-09-10 06:57:59 more
  • Flutter Weekly Issue 66

    新聞 Flutter 季度調研結果分享 教程 Flutter+FaaS一體化任務編排的思考與設計 詳解Dart中如何通過注解生成代碼 GitHub 用對了嗎?Flutter 團隊分享如何管理大型開源專案 插件 flutter-bubble-tab-indicator A Flutter librar ......

    uj5u.com 2020-09-10 06:58:52 more
  • Proguard 常用規則

    介紹 Proguard 入口,如何查看輸出,如何使用 keep 設定入口以及使用實體,如何配置壓縮,混淆,校驗等規則。

    ......

    uj5u.com 2020-09-10 06:59:00 more
  • Android 開發技術周報 Issue#292

    新聞 Android即將獲得類AirDrop功能:可向附近設備快速分享檔案 谷歌為安卓檔案管理應用引入可安全隱藏資料的Safe Folder功能 Android TV新主界面將顯示電影、電視節目和應用推薦內容 泄露的Android檔案暗示了傳說中的谷歌Pixel 5a與折疊屏新機 谷歌發布Andro ......

    uj5u.com 2020-09-10 07:00:37 more
  • AutoFitTextureView Error inflating class

    報錯: Binary XML file line #0: Binary XML file line #0: Error inflating class xxx.AutoFitTextureView 解決: <com.example.testy2.AutoFitTextureView android: ......

    uj5u.com 2020-09-10 07:00:41 more
  • 根據Uri,Cursor沒有獲取到對應的屬性

    Android: 背景:呼叫攝像頭,拍攝視頻,指定保存的地址,但是回傳的Cursor檔案,只有名稱和大小的屬性,沒有其他諸如時長,連ID屬性都沒有 使用 cursor.getInt(cursor.getColumnIndexOrThrow(MediaStore.Video.Media.DURATIO ......

    uj5u.com 2020-09-10 07:00:44 more
  • Android連載29-持久化技術

    一、持久化技術 我們平時所使用的APP產生的資料,在記憶體中都是瞬時的,會隨著斷電、關機等丟失資料,因此android系統采用了持久化技術,用于存盤這些“瞬時”資料 持久化技術包括:檔案存盤、SharedPreference存盤以及資料庫存盤,還有更復雜的SD卡記憶體儲。 二、檔案存盤 最基本存盤方式, ......

    uj5u.com 2020-09-10 07:00:47 more
  • Android Camera2Video整合到自己專案里

    背景: Android專案里呼叫攝像頭拍攝視頻,原本使用的 MediaStore.ACTION_VIDEO_CAPTURE, 后來因專案需要,改成了camera2 1.Camera2Video 官方demo有點問題,下載后,不能直接整合到專案 問題1.多次拍攝視頻崩潰 問題2.雙擊record按鈕, ......

    uj5u.com 2020-09-10 07:00:50 more
  • Android 開發技術周報 Issue#293

    新聞 谷歌為Android TV開發者提供多種新功能 Android 11將自動填表功能整合到鍵盤輸入建議中 谷歌宣布Android Auto即將支持更多的導航和數字停車應用 谷歌Pixel 5只有XL版本 搭載驍龍765G且將比Pixel 4更便宜 [圖]Wear OS將迎來重磅更新:應用啟動時間 ......

    uj5u.com 2020-09-10 07:01:38 more
  • 海豚星空掃碼投屏 Android 接收端 SDK 集成 六步驟

    掃碼投屏,開放網路,獨占設備,不需要額外下載軟體,微信掃碼,發現設備。支持標準DLNA協議,支持倍速播放。視頻,音頻,圖片投屏。好點意思。還支持自定義基于 DLNA 擴展的操作動作。好像要收費,沒體驗。 這里簡單記錄一下集成程序。 一 跟目錄的build.gradle添加私有mevan倉庫 mave ......

    uj5u.com 2020-09-10 07:01:43 more
最新发布
  • App復雜影片實作——Rive保姆級教程

    在App開發程序中,如果想實作影片效果,可以粗略分為兩種方式。一種是直接用代碼撰寫,像平移、旋轉等簡單的影片效果,都可以這么干,如果稍微復雜點,就會對開發工程師的數學功底、圖形影像學功底有很高的要求。 ......

    uj5u.com 2023-04-24 09:41:21 more
  • Android Studio的安裝及環境配置

    Android Studio的安裝及環境配置 安裝jdk 下載及安裝Android Studio 下載官網:https://developer.android.google.cn/studio/ 往下滑: 建議下載到除C盤以外的盤: 下載好安裝程式之后 雙擊安裝:一路next,install And ......

    uj5u.com 2023-04-24 09:40:43 more
  • 京東小程式接入ARVR的技術方案和性能調優

    京東小程式是一個開放技術平臺,正在被越來越多的頭部品牌選擇,用于站內私域流量的營銷和運營。諸如各種榷訓、奢侈品等品牌對ARVR有較多的訴求,希望京東小程式引擎提供一些底層能力,疊加品牌自主的個性化開發和定制,以支持更加豐富的場景和玩法,比如AR試妝、試戴等。 ......

    uj5u.com 2023-04-24 09:40:18 more
  • Android Studio的安裝及環境配置

    Android Studio的安裝及環境配置 安裝jdk 下載及安裝Android Studio 下載官網:https://developer.android.google.cn/studio/ 往下滑: 建議下載到除C盤以外的盤: 下載好安裝程式之后 雙擊安裝:一路next,install And ......

    uj5u.com 2023-04-24 09:33:25 more
  • 語言錄制兼容長按跟點擊錄制

    錄音需求中,往往有兩種常規操作。 長按基本實作流程: 監聽觸摸事件,按下時錄制,抬起時停止。 點擊基本流程: 點擊開始錄制,在次點擊停止錄制 但是凡事有絕對,如果需要同時支持長按錄制抬起結束跟點擊錄制在次點擊結束呢?面對如此無理的需求,從技術層面上怎么如絲滑般去兼容呢。 需要兩者兼容,只能從觸摸事件 ......

    uj5u.com 2023-04-23 07:55:05 more
  • 語言錄制兼容長按跟點擊錄制

    錄音需求中,往往有兩種常規操作。 長按基本實作流程: 監聽觸摸事件,按下時錄制,抬起時停止。 點擊基本流程: 點擊開始錄制,在次點擊停止錄制 但是凡事有絕對,如果需要同時支持長按錄制抬起結束跟點擊錄制在次點擊結束呢?面對如此無理的需求,從技術層面上怎么如絲滑般去兼容呢。 需要兩者兼容,只能從觸摸事件 ......

    uj5u.com 2023-04-23 07:54:42 more
  • Swift CustomStringConvertible 協議的使用

    一、前言 先看一下Swift標準庫中對CustomStringConvertible協議的定義 public protocol CustomStringConvertible { /// A textual representation of this instance. /// /// Calli ......

    uj5u.com 2023-04-22 08:07:46 more
  • Viu聯合華為HMS生態,共創影音娛樂新體驗

    華為HMS生態攜手流媒體平臺Viu,為海外消費者打造精品移動娛樂應用體驗,并助力提升流量變現能力。Viu在中東非、東南亞等16個國家及地區提供廣告合作和付費會員服務,支持優質視頻內容高清點播和直播。自2019年起,Viu在中東非區域與華為HMS生態開展一系列緊密合作,并在2022年實作47%的用戶增 ......

    uj5u.com 2023-04-22 08:07:39 more
  • Android事件分發-基礎原理和場景分析

    和其他平臺類似,Android 中 View 的布局是一個樹形結構,各個 ViewGroup 和 View 是按樹形結構嵌套布局的,從而會出現用戶觸摸的位置坐標可能會落在多個 View 的范圍內,這樣就不知道哪個 View 來回應這個事件,為了解決這一問題,就出現了事件分發機制。 ......

    uj5u.com 2023-04-22 08:07:26 more
  • Swift CustomStringConvertible 協議的使用

    一、前言 先看一下Swift標準庫中對CustomStringConvertible協議的定義 public protocol CustomStringConvertible { /// A textual representation of this instance. /// /// Calli ......

    uj5u.com 2023-04-22 08:07:08 more