详解如何在Flutter中使用媒体播放器

作者:程序那些事 时间:2021-06-26 01:40:43 

简介

现在的app功能越来越强大,除了基本的图文之外,还需要各种各样的其他的功能,比如视频,和直播。

直播可能会比较复杂,因为涉及到了拉流和推流,需要服务器端的支持,但是视频播放就比较简单了,那么如何在flutter中使用媒体播放器呢?

一起来看看吧。

使用前的准备工作

flutter本身是不支持媒体播放功能的,为了实现这个功能,我们需要使用额外的第三方插件叫做video_player。

首先我们需要向flutter应用中添加video_player。添加起来也非常简单,只需要执行下面的命令即可:

flutter pub add video_player

该命令会向pubspec.xml中添加如下的内容:

dependencies:
 flutter:
   sdk: flutter

video_player: ^2.4.7

添加好依赖包之后,我们还需要为应用添加相应的权限,你确保能够使用影音播放的权限。

如果是在android中,需要向AndroidManifest.xml文件中添加类似下面的内容:

<manifest xmlns:android="http://schemas.android.com/apk/res/android">
   <application ...>

</application>

<uses-permission android:name="android.permission.INTERNET"/>
</manifest>

在IOS中则需要在Info.plist中添加下面的内容:

<key>NSAppTransportSecurity</key>
<dict>
 <key>NSAllowsArbitraryLoads</key>
 <true/>
</dict>

在flutter中使用video_player

video_player中和video播放相关的类叫做VideoPlayerController,在IOS中底层使用的是AVPlayer,在Android中底层使用的是ExoPlayer。

VideoPlayerController有好几种构造方法,我们一起来看看。

VideoPlayerController.asset

asset方法表示video是从应用程序的asset中获取的。

VideoPlayerController.network

network方法表示video是从网络中获取的。

VideoPlayerController.file

file方法表示video是通过'file://${file.path}' 这样的格式来获取的。

还有一个只用在andorid中的方法,表示从contentUri中加载video:

VideoPlayerController.contentUri

为了简单起见,这里我们选择网易上面的一个科教视频,作为要播放的video。

那么我们可以通过 VideoPlayerController.network方法来构建这个controller:

videoPlayerController = VideoPlayerController.network(
     'https://flv.bn.netease.com/1c04bfd72901f0661b486465e09cfdc01754c20db0686786f4e20a5f7d271ba0de6c1177a0da1c4c2d7c367e20ee16d4a90ac7ff4ea664820ba1b401f3e53f135f72cdff855e78ca5fb7849fb6ff7ccb9de1613ad3bfc59db83493b5f18a0a27f15048df6585361cd67c3b37551e10981c40dcdfdb77b7e6.mp4',
   );

在使用video之前,还需要进行初始操作,初始化是调用它的initialize方法,这个方法的作用是打开给定的数据源,并加载它的元数据。

因为initialize方法是一个耗时的操作,所以这个方法返回类型是Future:

Future<void> initialize() async {

我们可以这样使用:

late Future<void> playerFuture;
playerFuture = videoPlayerController.initialize();

有了播放器的Future,我们可以配合flutter中的FutureBuilder一起使用:

body: FutureBuilder(
       future: playerFuture,
       builder: (context, snapshot) {
         if (snapshot.connectionState == ConnectionState.done) {
           return AspectRatio(
             aspectRatio: videoPlayerController.value.aspectRatio,
             child: VideoPlayer(videoPlayerController),
           );
         } else {
           return const Center(
             child: CircularProgressIndicator(),
           );
         }
       },
     ),

在FutureBuilder中,我们通过判断connectionState来判断视频是否加载完毕,如果没有加载完毕,则使用CircularProgressIndicator表示正在加载中。

如果加载完毕之后,就直接展示VideoPlayer组件即可。

因为不同的video有不同的纵横比,为了在flutter界面上完美的展示加载的video,我们将VideoPlayer封装在一个AspectRatio组件中。

最后我们还要添加一个控制装置,用来控制video的暂停和播放:

floatingActionButton: FloatingActionButton(
       onPressed: () {
         setState(() {
           if (videoPlayerController.value.isPlaying) {
             videoPlayerController.pause();
           } else {
             videoPlayerController.play();
           }
         });
       },
       child: Icon(
         videoPlayerController.value.isPlaying ? Icons.pause : Icons.play_arrow,
       ),
     )

这里通过videoPlayerController.value.isPlaying来判断视频是否在播放状态,同时在onPressed方法中调用了setState来调用videoPlayerController.pause或者videoPlayerController.play方法。

来源:https://juejin.cn/post/7215496238626832440

标签:Flutter,媒体,播放器
0
投稿

猜你喜欢

  • 10道springboot常见面试题

    2023-09-02 03:02:22
  • Kotlin基础学习之Deprecated与Suppress注解使用

    2023-01-03 10:50:54
  • Android使用分类型RecyclerView仿各大商城首页

    2021-06-29 12:08:23
  • Android多媒体应用使用MediaPlayer播放音频

    2023-07-08 15:37:52
  • Android开发实现的标准体重计算器功能示例

    2023-01-19 02:56:48
  • javafx tableview鼠标触发更新属性详解

    2022-01-24 23:47:32
  • 详解Android Studio如何导入第三方类库、jar包和so库

    2022-01-04 22:27:54
  • Java实现批量导入excel表格数据到数据库中的方法

    2021-06-22 07:39:49
  • C#基于winform实现音乐播放器

    2021-06-27 14:13:14
  • Android实现单选按钮

    2021-11-20 18:32:53
  • Java实现五子棋游戏的完整代码

    2022-07-01 15:32:34
  • c# RSA非对称加解密及XML&PEM格式互换方案

    2022-07-10 12:19:31
  • SpringBoot日志框架之Log4j2快速入门与参数详解

    2023-11-15 21:17:59
  • Spring容器初始化及问题解决方案

    2023-09-14 08:19:32
  • Android实现调用摄像头拍照与视频功能

    2021-11-22 08:02:28
  • springBoot整合rabbitMQ的方法详解

    2022-08-19 02:28:33
  • Java 判断一个时间是否在另一个时间段内

    2023-02-24 18:44:25
  • 使用spring框架中的组件发送邮件功能说明

    2022-12-29 03:53:55
  • Mybatis在sqlite中无法读写byte[]类问题的解决办法

    2021-08-06 21:06:07
  • Kotlin语言使用WebView示例介绍

    2021-10-14 05:56:21
  • asp之家 软件编程 m.aspxhome.com