标签: flutter-video-player

PlatformException(VideoError,视频播放器有错误 com.google.android.exoplayer2.ExoPlaybackException:源错误,null,null)

**您好,我正在尝试在我的 flutter 应用程序中播放实时新闻视频,它是 .m3u8 格式,但出现上述错误。使用所有更新的依赖项。我想在我的 flutter 应用程序中播放实时新闻。我有网址你也可以试试。URL: http: //161.97.162.167:1936/ live/tnnnews/playlist.m3u8 当我使用另一个带有 .m3u8 的 url 时,它会在 flutter 应用程序上播放,但是当我粘贴实时 url 代码时,它会抛出上述错误。**

代码

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


class VideoApp extends StatefulWidget {
  @override
  _VideoAppState createState() => _VideoAppState();
}

class _VideoAppState extends State<VideoApp> {
  VideoPlayerController _controller;

  @override
  void initState() {
    super.initState();
    _controller = VideoPlayerController.network(
        'http://161.97.162.167:1936/live/tnnnews/playlist.m3u8')
      ..initialize().then((_) {
        // Ensure the first frame is shown after the video is initialized, even before the play button has been pressed.
        setState(() {});
      });
  }

  @override
  Widget build(BuildContext …
Run Code Online (Sandbox Code Playgroud)

m3u8 exoplayer flutter flutter-video-player

19
推荐指数
1
解决办法
3万
查看次数

Flutter 视频在接下来的 4 个视频中缓存 10 秒

有谁知道如何在列表中进行 Flutter 视频缓存 4 到 6 秒?(接下来的 5 个视频)如 Instagram 视频。

有什么办法可以做到吗?

我使用PageView.builder来显示一个完整页面的视频。

我尝试过一个cached_video_player,但它正在加载完整的视频。

这是我所做的。

视频小部件:

typedef OnVideoCompleted = void Function();

class VideoWidget extends StatefulWidget {
  //final bool? play;
  final bool? isDuetVideo;
  final String? url;
  final OnVideoCompleted? onVideoCompleted;
  final HomeWidgetBloc? homeWidgetBloc;

  const VideoWidget(
      {Key? key,
      this.onVideoCompleted,
      required this.url,
      required this.homeWidgetBloc,
      required this.isDuetVideo})
      : super(key: key);

  @override
  _VideoWidgetState createState() => _VideoWidgetState();
}

class _VideoWidgetState extends State<VideoWidget> {
  late VideoPlayerController videoPlayerController;
  late Future<void> _initializeVideoPlayerFuture;
  final _controllerStateStream = BehaviorSubject<int>.seeded(0); …
Run Code Online (Sandbox Code Playgroud)

caching video-streaming flutter flutter-video-player

12
推荐指数
1
解决办法
2744
查看次数

Flutter 的 video_player 在 iOS 上抛出 PlatformException

我正在尝试在 iOS 模拟器上运行我的 Flutter 应用程序,我发现视频播放器在 init 上抛出以下异常:

\n
[VERBOSE-2:ui_dart_state.cc(209)] Unhandled Exception: PlatformException(VideoError, Failed to load video: The operation could not be completed, null, null)\n
Run Code Online (Sandbox Code Playgroud)\n

经过一番谷歌搜索后,我发现可能有几个修复方法:

\n
    \n
  1. 升级扑动
  2. \n
  3. 将 video_player 降级至 2.2.3
  4. \n
  5. 配置 Web 服务器以支持 Range 标头
  6. \n
\n

我正在运行最新的 flutter 版本,降级插件也没有做任何事情。我通过在浏览器中播放视频来确保 Web 服务器确实支持 Range 标头。

\n

我还在 flutter DevTools 中检查了网络请求,似乎从未发出过网络请求(看看其他 API 请求工作正常)。

\n

另一个注意事项是,这个问题不会发生在 Android 模拟器/真实设备上,并且视频播放得很好。

\n

什么可能导致此问题?有没有可能的方法来启用更详细的日志记录以查看到底是什么原因导致问题,或者是否有我遗漏的内容?谢谢您的帮助。

\n

附加信息:

\n
    \n
  • 2.6.0-12.0.pre.899在 master 分支上颤动
  • \n
  • AppStore 中的 Xcode 13
  • \n
  • 在模拟器上运行的 iOS 15
  • \n …

ios dart flutter flutter-video-player

10
推荐指数
1
解决办法
1638
查看次数

Flutter AWS:如何验证存储桶的IAM角色用户并获取hls视频文件的AWS S3对象并在视频播放器中播放?

如何通过区域、存储桶 ID、访问密钥和秘密密钥对 IAM 角色用户进行身份验证,并获取视频文件对象并在视频播放器中播放。实际上,我们已经在 AWS S3 中上传了视频文件,并向一名 IAM 角色用户授予了访问权限。

现在,在 flutter 应用程序中,我需要通过 accesskey、secretkey 对 IAM 用户进行身份验证,并获取视频对象并在视频播放器中播放,而无需在本地保存或下载。

我尝试使用插件,

flutter_aws_s3_client: ^0.5.0

const region = "<region>";
const bucketId = "<bucket id>";
final AwsS3Client s3client = AwsS3Client(
    region: region,
    host: "s3.$region.amazonaws.com",
    bucketId: bucketId,
    accessKey: "<accesskey>",
    secretKey: "<secretkey>");

//object video name 
final response = await s3client.getObject("example_test.m3u8");

Run Code Online (Sandbox Code Playgroud)

这里我得到的对象响应为 200,但是我如何传递并在视频播放器中播放这个视频文件?有什么办法吗?我尝试在expo播放器android video_player_plugin.dart中添加标题。但没有运气。

视频播放器插件

video_player: ^0.10.11+1

class _VideoAppState extends State<VideoApp> {
  VideoPlayerController _controller;

  @override
  void initState() {
    super.initState();
    _controller = VideoPlayerController.network('//need to pass the videoUrl of AWS S3')
      ..initialize().then((_) …
Run Code Online (Sandbox Code Playgroud)

android amazon-s3 dart flutter flutter-video-player

8
推荐指数
1
解决办法
826
查看次数

如何在 flutter 中播放 rtsp 视频流?

这是我正在尝试使用的代码,flutter vlc player但它不起作用,所以任何人都可以帮助我解决问题,或者我可以用另一种方式显示流?

所以你们可以给我任何建议或举一些小例子。我过去两个小时试图解决这个问题,但没有成功

import 'package:flutter/material.dart';
import 'package:flutter_vlc_player/flutter_vlc_player.dart';
import 'package:flutter_vlc_player/vlc_player.dart';
import 'package:flutter_vlc_player/vlc_player_controller.dart';
void main() {
  runApp(MyApp());
}

class MyApp extends StatelessWidget {
  // This widget is the root of your application.
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Demo',
      theme: ThemeData(
        visualDensity: VisualDensity.adaptivePlatformDensity,
      ),
      home: MyHomePage(),
    );
  }
}

class MyHomePage extends StatefulWidget {
  MyHomePage({Key key}) : super(key: key);

  @override
  _MyHomePageState createState() => _MyHomePageState();
}

class _MyHomePageState extends State<MyHomePage> {
  VlcPlayerController _videoPlayerController;

  @override
  void initState() { …
Run Code Online (Sandbox Code Playgroud)

rtsp dart flutter flutter-dependencies flutter-video-player

7
推荐指数
3
解决办法
1万
查看次数

如何在 Flutter 中模拟 VideoPlayerController.network()

我正在为使用 video_player 插件的视频播放器小部件编写一个简单的测试。我无法模拟视频控制器发出的用于通过网络获取视频的网络请求。我的小部件代码如下所示:

late VideoPlayerController _videoController;

@override
void initState() {
    _videoController = VideoPlayerController.network(widget.videoUrl);
// rest of the code
}
Run Code Online (Sandbox Code Playgroud)

和测试代码:

VideoPlayerController _videoController =
        VideoPlayerController.network(videoUrl);

    when(VideoPlayerController.network(videoUrl))
        .thenAnswer((_) => _videoController);
Run Code Online (Sandbox Code Playgroud)

这不起作用,因为它无法正确地存根网络请求方法。有什么正确嘲笑它的想法吗?我的代码中还有其他几个测试,其中我模拟了发出网络请求的 api 客户端类,但这一个有点不同。我正在使用mockito进行嘲笑。

请帮忙!

unit-testing flutter-test flutter-video-player flutter-mockito

7
推荐指数
1
解决办法
1141
查看次数

PageView 中 video_player 的 Flutter 性能问题/卡顿

我一直在与“官方”flutter video_player包与 PageView 小部件结合使用时遇到严重的卡顿问题。

我的目标

平滑快速地滚动浏览PageView 小部件的多个页面,每个页面都包含一个视频小部件。

实际结果

当我尝试快速滚动这些页面时,我遇到了严重的卡顿/性能问题。当我缓慢地滑动页面并等待滚动动画完成时,一切都很顺利。请参阅我在小米红米 Note 8 Pro 的个人资料模式下录制的视频作为证据。

GIF:应用程序卡顿的视频证明

绩效分析

我尝试通过咨询颤振性能工具来寻求帮助。该工具显示光栅时间出现大量峰值。在一个示例中,光栅时间为 51.7 毫秒,其中 43.0 毫秒用于着色器编译。不过,我的经验不足,无法理解这意味着什么或这些信息如何帮助我。截图如下:

屏幕截图:显示慢帧的 flutter 性能工具屏幕截图

到目前为止我尝试过的

  1. 删除该行controller.dispose();可以解决问题,但这会导致内存泄漏和小部件最终崩溃。
  2. 我尝试将其包装controller.dispose();成 a WidgetsBinding.instance!.addPostFrameCallback((_) async {},但这没有帮助

我的代码

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

class ExamplePageView extends StatelessWidget {
  ExamplePageView({Key? key}) : super(key: key);

  final PageController pageController = PageController();

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      body: Container(
        height: MediaQuery.of(context).size.height,
        child: PageView(
          controller: pageController,
          onPageChanged: (value) {}, …
Run Code Online (Sandbox Code Playgroud)

performance flutter jank flutter-pageview flutter-video-player

7
推荐指数
1
解决办法
1094
查看次数

Flutter 视频播放器无法在 ios 中播放

我正在使用 video_player 包在 flutter 中播放网络视频。在安卓上运行良好,但在ios上无法加载。

颤动3.3.3

视频播放器:^2.4.7

PS:服务器调用是https,问题发生在真实设备中,并且响应标头具有Accept-Ranges :字节

要求

连接:关闭

访问控制允许来源:*

接受:/

接受编码:身份

接受语言:en-US,en;q=0.9

访问控制允许凭据:true

范围:字节=0-1

服务器端响应

接受:应用程序/pdf,应用程序/八位字节流接受范围:字节缓存控制:无缓存,无存储,最大年龄= 0,必须重新验证
连接:保持活动内容处置:内联;文件名 =“DeviceMediaActivity_99966.MOV”内容长度:1706570 内容类型:应用程序/八位字节流
日期:星期五,2022 年 10 月 14 日 04:28:14 GMT 过期:0 保持活动:超时 = 60 杂注:无缓存变化:起源,访问控制请求方法,访问控制请求标头
x-content-type-options:nosniff x-frame-options:DENY
x-xss-protection:1;模式=块

flutter flutter-ios flutter-video-player

7
推荐指数
0
解决办法
1331
查看次数

video_player 在 Android 上返回 401 Unauthorized with Bunny CDN

以下经典代码片段无法从 Bunny CDN 获取视频

@override
void initState() {
  super.initState();
  controller = VideoPlayerController.networkUrl(Uri.parse(widget.video),
                          httpHeaders: {"AccessKey": CDN_READ_ONLY_TOKEN});
  controller.initialize();
}
Run Code Online (Sandbox Code Playgroud)

我收到以下错误:

E/ExoPlayerImplInternal(14202): Playback error
E/ExoPlayerImplInternal(14202):   com.google.android.exoplayer2.ExoPlaybackException: Source error
E/ExoPlayerImplInternal(14202):       at com.google.android.exoplayer2.ExoPlayerImplInternal.handleIoException(ExoPlayerImplInternal.java:644)
E/ExoPlayerImplInternal(14202):       at com.google.android.exoplayer2.ExoPlayerImplInternal.handleMessage(ExoPlayerImplInternal.java:616)
E/ExoPlayerImplInternal(14202):       at android.os.Handler.dispatchMessage(Handler.java:103)
E/ExoPlayerImplInternal(14202):       at android.os.Looper.loop(Looper.java:224)
E/ExoPlayerImplInternal(14202):       at android.os.HandlerThread.run(HandlerThread.java:67)
E/ExoPlayerImplInternal(14202):   Caused by: com.google.android.exoplayer2.upstream.HttpDataSource$InvalidResponseCodeException: Response code: 401
E/ExoPlayerImplInternal(14202):       at com.google.android.exoplayer2.upstream.DefaultHttpDataSource.open(DefaultHttpDataSource.java:413)
E/ExoPlayerImplInternal(14202):       at com.google.android.exoplayer2.upstream.DefaultDataSource.open(DefaultDataSource.java:263)
E/ExoPlayerImplInternal(14202):       at com.google.android.exoplayer2.upstream.StatsDataSource.open(StatsDataSource.java:84)
E/ExoPlayerImplInternal(14202):       at com.google.android.exoplayer2.source.ProgressiveMediaPeriod$ExtractingLoadable.load(ProgressiveMediaPeriod.java:1005)
E/ExoPlayerImplInternal(14202):       at com.google.android.exoplayer2.upstream.Loader$LoadTask.run(Loader.java:412)
E/ExoPlayerImplInternal(14202):       at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1167)
E/ExoPlayerImplInternal(14202):       at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:641)
E/ExoPlayerImplInternal(14202):       at java.lang.Thread.run(Thread.java:919)
Run Code Online (Sandbox Code Playgroud)

我认为问题出在 accessKey 上,但是:

  • 该应用程序在 iOS 上完美运行
  • 来自应用程序中其他任何位置的正常获取请求具有正确的标头,可以按预期工作。

在检查了 github …

android flutter flutter-video-player bunnycdn

7
推荐指数
1
解决办法
178
查看次数

如何使用 flutter 视频播放器跳转到帧?

是否可以使用 flutter video_player 跳转到某个时间戳并显示帧而不启动视频?

只有当我在seekTo之后立即调用play时,我才能更改帧。

  _videoPlayerController.seekTo(Duration(milliseconds: value));
  _videoPlayerController.play();
Run Code Online (Sandbox Code Playgroud)

我也尝试过

_videoPlayerController.seekTo(Duration(milliseconds: value));
_videoPlayerController.play();
_videoPlayerController.pause();
Run Code Online (Sandbox Code Playgroud)

但它不会改变视频的显示帧。

flutter flutter-video-player

6
推荐指数
1
解决办法
978
查看次数