Flutter:视频预览功能

pubspec.yaml

# 复制代码
  media_kit: ^1.2.1                 # Primary package.
  media_kit_video: ^1.3.1          # For video rendering.
  media_kit_libs_video: ^1.0.7     # Native video dependencies.

main.dart 初始化

dart 复制代码
Future<void> main() async {
  runZonedGuarded(() async {
    WidgetsFlutterBinding.ensureInitialized();
    // Necessary initialization for package:media_kit.
    MediaKit.ensureInitialized();
    // 添加错误捕获
    FlutterError.onError = (FlutterErrorDetails details) {};
    await Global.init();
    runApp(const MyApp());
  }, (error, stackTrace) {});
}

使用方式

dart 复制代码
onTap(() {
	// 这里需要播放视频
	Get.to(() => VideoPreview(singleVideo: item.url ?? ''));
})

封装播放器

dart 复制代码
import 'package:flutter/material.dart';
import 'package:get/get.dart';
import 'package:media_kit/media_kit.dart';
import 'package:media_kit_video/media_kit_video.dart';

/*

  视频预览组件
  使用方式:单个视频预览

  onTap(() {
    Get.to(() => VideoPreview(singleVideo: '视频url'));
  })

  注意:需要在 main() 函数中调用 MediaKit.ensureInitialized()

 */

class VideoPreview extends StatefulWidget {
  final String? singleVideo;

  const VideoPreview({
    super.key,
    this.singleVideo,
  });

  @override
  State<VideoPreview> createState() => _VideoPreviewState();
}

class _VideoPreviewState extends State<VideoPreview> {
  // Create a [Player] to control playback.
  late final player = Player();
  // Create a [VideoController] to handle video output from [Player].
  late final controller = VideoController(player);

  @override
  void initState() {
    super.initState();
    // Play a [Media] or [Playlist].
    if (widget.singleVideo != null && widget.singleVideo!.isNotEmpty) {
      player.open(Media(widget.singleVideo!));
    }
  }

  @override
  void dispose() {
    player.dispose();
    super.dispose();
  }

  @override
  Widget build(BuildContext context) {
    if (widget.singleVideo == null || widget.singleVideo!.isEmpty) {
      return const SizedBox();
    }

    return Scaffold(
      backgroundColor: Colors.black,
      appBar: AppBar(
        backgroundColor: Colors.black,
        elevation: 0,
        leading: IconButton(
          icon: const Icon(
            Icons.close,
            color: Colors.white,
            size: 24,
          ),
          onPressed: () => Get.back(),
        ),
      ),
      body: Center(
        child: Video(
          controller: controller,
          controls: MaterialVideoControls,
        ),
      ),
    );
  }
}
相关推荐
子兮曰2 小时前
深入 HTML-in-Canvas:当 Canvas 学会了渲染 DOM,前端图形生态要变天了
前端·javascript·canvas
Lanren的编程日记2 小时前
Flutter 鸿蒙应用数据版本管理实战:版本记录+版本回退+版本对比,实现全链路数据版本控制
flutter·华为·harmonyos
涵涵(互关)3 小时前
GoView各项目文件中的相关语法2
前端·javascript·vue.js
子兮曰3 小时前
别让爬虫白嫖你的导航站了:纯免费,手把手实现加密字体防爬
前端·javascript·后端
非凡ghost4 小时前
可拓浏览器:给手机浏览器装上“外挂“!2W+拓展+AI搜索,玩出无限可能!
windows·智能手机·音视频·firefox
昇腾CANN4 小时前
TileLang-Ascend 算子性能优化方法与实操
开发语言·javascript·性能优化·昇腾·cann
web打印社区4 小时前
2026最新Web静默打印解决方案,无插件无预览,完美替代Lodop
前端·javascript·vue.js·electron·pdf
蜡台5 小时前
H5使用Chrome 权限问题
前端·javascript·chrome
大貔貅喝啤酒5 小时前
接口测试_Postman(详细版)
javascript·测试工具·node.js·自动化·postman
美狐美颜SDK开放平台5 小时前
多场景美颜SDK解决方案:直播APP(iOS/安卓)开发接入详解
android·人工智能·ios·音视频·美颜sdk·第三方美颜sdk·短视频美颜sdk