flv(直播流视频播放)踩坑

最近项目开发中用flv加载的直播视频流遇到了如下几个问题,现进行记录学习
1、出现组件销毁后,视频流依然在进行拉流
2、出现断流和卡顿

项目场景:

flv格式的直播流通过flv.js依赖进行实时直播播放


问题描述:

1、出现组件销毁后,视频流依然在进行拉流
2、出现断流和卡顿

组件销毁后,视频流一直在加载
在这里插入图片描述
第一次未连接上直播流后,未进行重连操作,导致视频无法播放,页面报错
在这里插入图片描述


原因分析:

1、由于销毁组件的时候没有正确的销毁视频实例,导致一直在拉流
2、没有监听视频流的断连、断流、卡顿的情况,并进一步进行销毁视频实例并重新进行视频流请求操作

解决方案:

对于第一个问题
1、在destroy生命周期内进行视频实例的关闭、停止加载、销毁等一系列操作进行手动销毁
2、如不能正常销毁,请检查flv.js是否为最新版本,新版本的flv.js解决了视频销毁后,依然拉流的问题

flv项目地址

github:bilibili / flv.js

gitCode/flv.js

在这里插入图片描述
对于第二个问题
监听到视频返回的断流卡顿的错误信息后,进行视频实例销毁并重新创建实例连接视频
在这里插入图片描述

本文章参考来源:https://blog.csdn.net/HJFQC/article/details/109626836

  • 2
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
要使用ExoPlayer播放FLV格式的直播,你需要进行一些额外的配置。以下是一个示例代码: 首先,在你的Android项目的 build.gradle 文件中添加以下依赖项: ```groovy implementation 'com.google.android.exoplayer:exoplayer-core:2.15.1' implementation 'com.google.android.exoplayer:exoplayer-ui:2.15.1' implementation 'com.google.android.exoplayer:extension-rtmp:2.15.1' implementation 'com.google.android.exoplayer:extension-ffmpeg:2.15.1' ``` 接下来,在你的Activity或Fragment中使用以下代码来播放FLV格式的直播: ```java import android.net.Uri; import android.os.Bundle; import androidx.appcompat.app.AppCompatActivity; import com.google.android.exoplayer2.ExoPlayer; import com.google.android.exoplayer2.SimpleExoPlayer; import com.google.android.exoplayer2.source.MediaSource; import com.google.android.exoplayer2.source.ProgressiveMediaSource; import com.google.android.exoplayer2.ui.PlayerView; import com.google.android.exoplayer2.upstream.DefaultDataSourceFactory; import com.google.android.exoplayer2.upstream.DefaultHttpDataSourceFactory; import com.google.android.exoplayer2.upstream.DefaultHttpDataSource; public class MainActivity extends AppCompatActivity { private static final String RTMP_URL = "your_rtmp_url_here"; private SimpleExoPlayer player; private PlayerView playerView; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); playerView = findViewById(R.id.player_view); // 创建ExoPlayer实例 player = new SimpleExoPlayer.Builder(this).build(); // 设置播放器视图 playerView.setPlayer(player); // 创建媒体资源 MediaSource mediaSource = buildMediaSource(Uri.parse(RTMP_URL)); // 准备播放 player.prepare(mediaSource); // 开始播放 player.setPlayWhenReady(true); } private MediaSource buildMediaSource(Uri uri) { DefaultDataSourceFactory dataSourceFactory = new DefaultDataSourceFactory(this, "exoplayer"); // 使用DefaultHttpDataSourceFactory来处理RTMP DefaultHttpDataSource.Factory httpDataSourceFactory = new DefaultHttpDataSource.Factory() .setAllowCrossProtocolRedirects(true) .setUserAgent("exoplayer"); dataSourceFactory.setHttpDataSourceFactory(httpDataSourceFactory); // 创建ProgressiveMediaSource.Builder来构建媒体资源 ProgressiveMediaSource.Factory mediaSourceFactory = new ProgressiveMediaSource.Factory(dataSourceFactory); // 设置扩展选项以支持FLV格式 mediaSourceFactory.setCustomCacheKey(RTMP_URL); mediaSourceFactory.setLoadErrorHandlingPolicy(new ExoPlayerLoadErrorHandlingPolicy()); // 创建媒体资源 return mediaSourceFactory.createMediaSource(uri); } @Override protected void onDestroy() { super.onDestroy(); // 释放资源 player.release(); } } ``` 请将 `your_rtmp_url_here` 替换为你要播放的RTMP地址。 在这个示例中,我们创建了一个ExoPlayer实例,并将其与一个PlayerView关联起来。然后,我们构建了一个媒体资源,并通过使用 `ProgressiveMediaSource.Builder` 来设置扩展选项以支持FLV格式。最后,我们准备播放并开始播放。 为了支持处理RTMP,我们使用了 `DefaultHttpDataSource.Factory` 来处理HTTP请求。这里设置了一些选项,如允许跨域重定向和自定义用户代理。 为了处理加载错误,我们创建了一个自定义的 `ExoPlayerLoadErrorHandlingPolicy` 类,你需要根据你的需求进行相应的实现。 请注意,这只是一个简单的示例代码,你可以根据你的具体需求进行相应的修改和扩展。 希望这个示例能帮助到你!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值