鸿蒙平台使用 `video_thumbnail` 插件指南

插件介绍

video_thumbnail 是一个用于生成视频缩略图的 Flutter 插件,支持在鸿蒙平台上使用。本项目基于 video_thumbnail 开发,提供了简单易用的 API 来从视频文件或 URL 中生成高质量的缩略图。

该插件适用于需要展示视频预览图、实现视频列表缩略图或提供视频截图功能的应用场景。

安装与使用

安装方式

在引用的项目中,pubspec.yamldependencies 新增配置:

yaml 复制代码
dependencies:
  video_thumbnail_ohos:
    git:
      url: "https://atomgit.com/openharmony-sig/fluttertpc_video_thumbnail.git"
      path: "ohos"

执行命令安装依赖:

bash 复制代码
flutter pub get

权限配置

2.2.1 在 entry 目录下的module.json5中添加权限

打开 entry/src/main/module.json5,添加:

diff 复制代码
...
"requestPermissions": [
+  {
+    "name": "ohos.permission.READ_IMAGEVIDEO",
+    "reason": "$string:EntryAbility_label",
+    "usedScene": {
+      "abilities": [
+        "EntryAbility"
+      ],
+      "when":"inuse"
+    }
+  }
]
2.2.2 在 entry 目录下的string.json添加申请以上权限的原因

打开 entry/src/main/resources/base/element/string.json,添加:

diff 复制代码
...
{
  "string": [
+    {
+      "name": "EntryAbility_label",
+      "value": "video_thumbnail_ohos_example"
+    }
  ]
}

基本使用示例

以下是一个简单的使用示例,展示如何在鸿蒙平台上使用 video_thumbnail 插件生成视频缩略图:

dart 复制代码
import 'dart:async';
import 'dart:typed_data';

import 'package:flutter/material.dart';
import 'dart:io';

import 'package:video_thumbnail_ohos/video_thumbnail_ohos.dart';
import 'package:image_picker/image_picker.dart';
import 'package:path_provider/path_provider.dart';

Future<ThumbnailResult> genThumbnail(ThumbnailRequest r) async {
  Uint8List bytes;
  final Completer<ThumbnailResult> completer = Completer();
  if (r.thumbnailPath != null) {
    final thumbnailPath = await VideoThumbnailOhos.thumbnailFile(
        video: r.video,
        headers: {
          "USERHEADER1": "user defined header1",
          "USERHEADER2": "user defined header2",
        },
        thumbnailPath: r.thumbnailPath,
        imageFormat: r.imageFormat,
        maxHeight: r.maxHeight,
        maxWidth: r.maxWidth,
        timeMs: r.timeMs,
        quality: r.quality);

    print("thumbnail file is located: $thumbnailPath");

    final file = File(thumbnailPath);
    bytes = file.readAsBytesSync();
  } else {
    bytes = await VideoThumbnailOhos.thumbnailData(
        video: r.video,
        headers: {
          "USERHEADER1": "user defined header1",
          "USERHEADER2": "user defined header2",
        },
        imageFormat: r.imageFormat,
        maxHeight: r.maxHeight,
        maxWidth: r.maxWidth,
        timeMs: r.timeMs,
        quality: r.quality);
  }

  int _imageDataSize = bytes.length;
  print("image size: $_imageDataSize");

  final _image = Image.memory(bytes);
  _image.image
      .resolve(ImageConfiguration())
      .addListener(ImageStreamListener((ImageInfo info, bool _) {
    completer.complete(ThumbnailResult(
      image: _image,
      dataSize: _imageDataSize,
      height: info.image.height,
      width: info.image.width,
    ));
  }));
  return completer.future;
}

核心 API 说明

API 名称 描述 返回值 鸿蒙支持
thumbnailData 从视频中生成缩略图数据 Future<Uint8List> yes
thumbnailFile 从视频中生成缩略图文件 Future<String> yes

API 参数说明

thumbnailData Parameters
参数名称 描述 类型 鸿蒙支持
video 视频文件路径或 URL String partially
headers 网络资源的 HTTP 头 Map<String, String>? yes
imageFormat 输出图像格式 ImageFormat yes
maxHeight 最大高度(0 表示原始分辨率) int yes
maxWidth 最大宽度(0 表示原始分辨率) int yes
timeMs 从指定毫秒位置生成缩略图 int yes
quality 图像质量(0-100,PNG 格式忽略) int yes
thumbnailFile Parameters
参数名称 描述 类型 鸿蒙支持
video 视频文件路径或 URL String partially
headers 网络资源的 HTTP 头 Map<String, String>? yes
thumbnailPath 缩略图文件存储路径(null 表示存储在视频文件所在目录) String yes
imageFormat 输出图像格式 ImageFormat yes
maxHeight 最大高度(0 表示原始分辨率) int yes
maxWidth 最大宽度(0 表示原始分辨率) int yes
timeMs 从指定毫秒位置生成缩略图 int yes
quality 图像质量(0-100,PNG 格式忽略) int yes

约束与限制

兼容性

在以下版本中已测试通过:

Flutter: 3.7.12-ohos-1.0.6; SDK: 5.0.0(12); IDE: DevEco Studio: 5.0.13.200; ROM: 5.1.0.120 SP3;

遗留问题

  • ohos 端 video_thumbnail thumbnailFile 和 thumbnailData 使用在线视频生成缩略图文件无效: issue#2

总结

video_thumbnail 插件提供了一种简单高效的方式来生成视频缩略图,适用于各种需要视频预览的应用场景。该插件具有以下优点:

  1. 简单易用 :提供了简洁的 API,只需调用 thumbnailDatathumbnailFile 方法即可生成视频缩略图。
  2. 跨平台支持:基于原始插件开发,支持在鸿蒙平台上使用。
  3. 功能丰富:支持自定义图像格式、分辨率、质量等参数。
  4. 性能优异:直接调用系统底层 API,生成缩略图的效率高。

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.csdn.net

相关推荐
南村群童欺我老无力.3 分钟前
Flutter 框架跨平台鸿蒙开发 - 打造安全可靠的密码生成器,支持强度检测与历史记录
flutter·华为·typescript·harmonyos
鸣弦artha1 小时前
Flutter 框架跨平台鸿蒙开发——Flutter引擎层架构概览
flutter·架构·harmonyos
时光慢煮2 小时前
基于 Flutter × OpenHarmony 图书馆管理系统之构建搜索栏
flutter·华为·开源·openharmony
鸣弦artha4 小时前
Flutter框架跨平台鸿蒙开发——StatelessWidget基础
flutter·华为·harmonyos
夜雨声烦丿4 小时前
Flutter 框架跨平台鸿蒙开发 - 打造习惯打卡应用,连续天数统计与热力图展示
flutter·华为·harmonyos
南村群童欺我老无力.5 小时前
Flutter 框架跨平台鸿蒙开发 - 开发二维码生成器与扫描器
flutter·华为·typescript·harmonyos
南村群童欺我老无力.5 小时前
Flutter 框架跨平台鸿蒙开发 - 喝水提醒应用开发指南
flutter·华为·harmonyos
奋斗的小青年!!5 小时前
Flutter开发鸿蒙应用实战:位置分享组件的跨平台实现
flutter·harmonyos·鸿蒙
鸣弦artha5 小时前
Flutter框架跨平台鸿蒙开发——Embedding层架构概览
flutter·embedding·harmonyos
御承扬5 小时前
鸿蒙原生系列之懒加载分组列表
华为·harmonyos·懒加载·鸿蒙ndk ui