Flutter 中 视频播放器

1,813 阅读2分钟

在 Flutter 中,视频播放器是开发多媒体应用的关键组件。Flutter 提供了多个插件用于视频播放,最常用的有以下几种:

  1. video_player
  2. chewie
  3. flutter_vlc_player

下面详细介绍这些视频播放器插件,并提供示例代码。

1. video_player

video_player 是官方提供的插件,用于播放视频。它支持本地和网络视频的播放,提供了基本的播放控制功能。

安装

pubspec.yaml 文件中添加依赖:

dependencies:
  video_player: ^2.2.7

示例代码

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

void main() => runApp(MyApp());

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      home: VideoPlayerScreen(),
    );
  }
}

class VideoPlayerScreen extends StatefulWidget {
  @override
  _VideoPlayerScreenState createState() => _VideoPlayerScreenState();
}

class _VideoPlayerScreenState extends State<VideoPlayerScreen> {
  late VideoPlayerController _controller;

  @override
  void initState() {
    super.initState();
    _controller = VideoPlayerController.network(
      'https://flutter.github.io/assets-for-api-docs/assets/videos/butterfly.mp4',
    )
      ..initialize().then((_) {
        setState(() {});
        _controller.play();
      });
  }

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

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(title: Text('Video Player')),
      body: Center(
        child: _controller.value.isInitialized
            ? AspectRatio(
                aspectRatio: _controller.value.aspectRatio,
                child: VideoPlayer(_controller),
              )
            : CircularProgressIndicator(),
      ),
      floatingActionButton: FloatingActionButton(
        onPressed: () {
          setState(() {
            _controller.value.isPlaying
                ? _controller.pause()
                : _controller.play();
          });
        },
        child: Icon(
          _controller.value.isPlaying ? Icons.pause : Icons.play_arrow,
        ),
      ),
    );
  }
}

2. Chewie

Chewie 是一个基于 video_player 的高级视频播放器,提供了丰富的自定义功能和更好的用户体验。

安装

pubspec.yaml 文件中添加依赖:

dependencies:
  chewie: ^1.2.2
  video_player: ^2.2.7

示例代码

import 'package:flutter/material.dart';
import 'package:chewie/chewie.dart';
import 'package:video_player/video_player.dart';

void main() => runApp(MyApp());

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      home: ChewieDemo(),
    );
  }
}

class ChewieDemo extends StatefulWidget {
  @override
  _ChewieDemoState createState() => _ChewieDemoState();
}

class _ChewieDemoState extends State<ChewieDemo> {
  late VideoPlayerController _videoPlayerController;
  late ChewieController _chewieController;

  @override
  void initState() {
    super.initState();
    _videoPlayerController = VideoPlayerController.network(
      'https://flutter.github.io/assets-for-api-docs/assets/videos/butterfly.mp4',
    );

    _chewieController = ChewieController(
      videoPlayerController: _videoPlayerController,
      aspectRatio: 16 / 9,
      autoPlay: true,
      looping: true,
    );
  }

  @override
  void dispose() {
    _videoPlayerController.dispose();
    _chewieController.dispose();
    super.dispose();
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(title: Text('Chewie Video Player')),
      body: Center(
        child: Chewie(
          controller: _chewieController,
        ),
      ),
    );
  }
}

3. flutter_vlc_player

flutter_vlc_player 是一个基于 VLC 的视频播放器,支持更多格式和流媒体协议。

安装

pubspec.yaml 文件中添加依赖:

dependencies:
  flutter_vlc_player: ^8.0.0

示例代码

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

void main() => runApp(MyApp());

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      home: VlcPlayerExample(),
    );
  }
}

class VlcPlayerExample extends StatefulWidget {
  @override
  _VlcPlayerExampleState createState() => _VlcPlayerExampleState();
}

class _VlcPlayerExampleState extends State<VlcPlayerExample> {
  late VlcPlayerController _vlcPlayerController;

  @override
  void initState() {
    super.initState();
    _vlcPlayerController = VlcPlayerController.network(
      'https://flutter.github.io/assets-for-api-docs/assets/videos/butterfly.mp4',
      autoPlay: true,
    );
  }

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

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(title: Text('VLC Player')),
      body: Center(
        child: VlcPlayer(
          controller: _vlcPlayerController,
          aspectRatio: 16 / 9,
          placeholder: Center(child: CircularProgressIndicator()),
        ),
      ),
    );
  }
}

总结

Flutter 提供了多种视频播放器插件,每种插件都有其特点和适用场景。video_player 是最基础的播放器插件,适合简单的视频播放需求。Chewie 基于 video_player,提供了更丰富的功能和更好的用户体验。flutter_vlc_player 基于 VLC,支持更多的视频格式和流媒体协议,适用于更复杂的视频播放需求。

选择合适的插件可以根据项目的具体需求来决定。上述示例代码展示了如何使用这些插件实现基本的视频播放功能。