直播流前端显示基于vue-videojs实现(PC端显示rtmp协议的流,手机端显示hls协议的流,配不出来你砍死我上铺!!)

前端显示
rtmp视频流仅能在pc端使用,所以我们在手机端使用hls的m3u8的流
假设你已经有自己的视频流了(没有也没事,博客下半部分会教你咋整)

先运行npm下载依赖video-js和vue-video-player

之后在vue中,直接运行下方代码(小白福利:直接新建vue项目将下方代码替换到新建项目自带的helloworld.vue里即可),将stream_video变量更改为自己的视频流,即可使用

ps:如果你有现成直接可用的rtmp和hls协议的流,你粘贴搬运完代码以后应该就可以使用了,如果你没有可供测试的流,请你继续往下看下面的步骤。

<template>
    <section class="video-box">
        <videoPlayer ref="videoPlayer" :options="videoOptions" class="vjs-custom-skin videoPlayer" :playsinline="true" />
    </section>
</template>
<script>
import 'video.js/dist/video-js.css'
import 'vue-video-player/src/custom-theme.css'
import { videoPlayer } from 'vue-video-player'
import 'videojs-flash'
import 'videojs-contrib-hls' //引入才能播放m3u8文件

export default {
    data() {
        // var type_video = 'rtmp/hls';
        // var stream_video = 'rtmp://39.102.46.223:1935/hls/test';
        //pc
        var type_video = 'rtmp/hls';
        var stream_video = 'rtmp://192.168.110.141:1260/livehls/test';
        //phone
        if (this._isMobile()) {
            type_video = 'application/x-mpegURL';
            stream_video = 'http://192.168.110.141/livehls/test.m3u8';
        }
        return {
            videoSrc: '',
            // 视频播放
            videoOptions: {
                playbackRates: [0.7, 1.0, 1.5, 2.0], //播放速度
                autoplay: false, //如果true,浏览器准备好时开始回放。
                muted: false, // 默认情况下将会消除任何音频。
                loop: false, // 导致视频一结束就重新开始。
                preload: 'auto', // 建议浏览器在<video>加载元素后是否应该开始下载视频数据。auto浏览器选择最佳行为,立即开始加载视频(如果浏览器支持)
                language: 'zh-CN',
                aspectRatio: '16:9', // 将播放器置于流畅模式,并在计算播放器的动态大小时使用该值。值应该代表一个比例 - 用冒号分隔的两个数字(例如"16:9""4:3")
                techOrder: ['html5', 'flash'], // 兼容顺序
                sources: [{ // 流配置,数组形式,会根据兼容顺序自动切换
                    type: type_video,
                    src: stream_video
                }, ],
                poster: "", //你的封面地址
                // width: document.documentElement.clientWidth,
                notSupportedMessage: '此视频暂无法播放,请稍后再试', // 允许覆盖Video.js无法播放媒体源时显示的默认信息。
                controlBar: {
                    timeDivider: true,
                    durationDisplay: true,
                    remainingTimeDisplay: false,
                    fullscreenToggle: true //全屏按钮
                }
            }
        }
    },
    components: {
        videoPlayer
    },
    methods: {
        // 判断移动端还是pc端
        _isMobile() {
            let flag = navigator.userAgent.match(/(phone|pad|pod|iPhone|iPod|ios|iPad|Android|Mobile|BlackBerry|IEMobile|MQQBrowser|JUC|Fennec|wOSBrowser|BrowserNG|WebOS|Symbian|Windows Phone)/i)
            return flag;
        },
        qw() {

            console.log(tt);
        }
    },
    mounted: function() {

    }
}
</script>
<style scoped>
.video-box {
    width: 1000px;
    padding: 20px;
}
</style>

如果没有可供测试的流:
在这里插入图片描述
你需要这些文件,请看下方链接下载
https://sunbossrs.coding.net/p/ws-data/d/ws-data/git/raw/master/res/rtmpobswin.txt
并附上视频教程:
来自B站 永恒的耀光SunbossRS 大佬
https://www.bilibili.com/video/BV1x54y1d7ZA?t=173

假设你已经安装完了并且已经按照他的操作做完了
那么恭喜你现在应该已经可以畅行无阻的看来自你本地的rtmp格式的流了

我们目前难点是在手机上播放的hls协议流的解决方案:
首先请您关闭nginx服务和obs推流软件,关闭完以后请继续下方操作
(1)打开你的 \nginx 1.7.11.3 Gryphon\conf\下的nginx-win.conf文件,在21行开始,修改成如下rtmp对象的样子
在这里插入图片描述

#大佬,下方是方便您复制的↓
rtmp{
   server{
      listen 1260;
      chunk_size 4000;
      application livehls {
         live on;
         hls on;
         hls_path ./live;
    
         hls_fragment 3s;
      }
   }
}

(2)下方从90行开始,修改成如下图所示
在这里插入图片描述

#大佬,下方是方便您复制的↓
#creates the http-location for our full-resolution (desktop) HLS stream - "http://my-ip/hls/my-stream-key/index.m3u8"      
location /livehls {
types {
application/vnd.apple.mpegurl m3u8;
video/mp2t ts;
}
alias ./live;
add_header Cache-Control no-cache;
}

(3)可以打开您的obs推流软件了
画面啥也没有你就自己随便在软件中的“来源”那拽点吧,这就不多bb了

点击设置
在这里插入图片描述
按照下方填写
在这里插入图片描述

点击确定,然后点击开始推流
注:如果推流过程中提示
在这里插入图片描述
你需要在进到设置->输出 中,将编码器改为除了硬件(NVENC)之外的其他的
在这里插入图片描述
然后点击确定,再次点击开始推流,看到下方绿了,诶,就完事了,然后先别急,在网页上看之前,最好先拿VLC看一下,啥?你跟我说你不知道啥是VLC?
在这里插入图片描述
VLC啊!看各种视频接各种流都ok的,半人半鱼的美人鱼啊!(请自行百度下载,蟹蟹)
在这里插入图片描述
在这里插入图片描述
点击左上角的媒体,选中打开网络串流,然后输入我们最上方程序中的那两行中的某一个(如下,127.0.0.1可以换成你的ip,两个都试试昂,一个电脑的一个手机的,别跟虎逼是的试了一个另一个不管了)
rtmp://127.0.0.1:1260/livehls/test
http://127.0.0.1/livehls/test.m3u8
在这里插入图片描述
然后点击播放!然后坐等几秒!
PC端:(延时2秒左右)
在这里插入图片描述
手机端:(延时在20秒左右,请忽略我pc和手机的时间为啥差这么多,脑瓜子不好使,开始忘截手机上的图了)
在这里插入图片描述
奥利给兄弟们!

  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值