百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

HLS视频拉流播放

yuyutoo 2025-01-06 16:13 4 浏览 0 评论

1、安装Hls

Vue.js是一个适用于构建用户界面的渐进型框架,它的流行程度已经在现代Web应用开发领域中得到了广泛的认可。而HLS(HTTP Live Streaming)则是一种广泛应用于视频流媒体传输的协议,可以将一个长时间的视频分解为一个个小的TS(Transport Stream)片段进行传输,客户端也可以根据网络状况切换不同的码率。本文将结合Vue.js和HLS协议实现一个Vue Hls的例子。

首先,我们需要在Vue项目中引入hls.js,HLS.js是一个开源的JavaScript库,它实现了解析HLS流并支持HTML5类型的视频播放器。我们可以通过npm install命令安装,也可以在index.html文件中直接引入。下面是通过npm安装示例代码

npm install hls.js --save

2、接着,在Vue项目中构建视频播放器组件,并在其中使用hls.js进行视频流的播放。下面是相关的代码实现:

<script>
import Hls from 'hls.js';
export default { 
    name: 'VueHlsPlayer', 
    props: { 
        url: { 
            type: String, 
            required: true 
        } 
    }, 
    data() { 
        return { 
            hls: null, 
            src: '' 
        } 
    }, 
    mounted() { 
        if (Hls.isSupported()) {
             this.hls = new Hls(); 
             this.hls.loadSource(this.url); 
             this.hls.attachMedia(this.$refs.video); 
             this.hls.on(Hls.Events.MANIFEST_PARSED, () => { this.$refs.video.play(); }); 
        } 
        else if (
            this.$refs.video.canPlayType('application/vnd.apple.mpegurl')) 
            { 
                this.$refs.video.src = this.url; 
                this.$refs.video.addEventListener('loadedmetadata', () => { 
                    this.$refs.video.play(); }); 
            } 
            this.src = this.url;
         }, 
        destroyed() { 
            if (this.hls) {
                 this.hls.destroy();
            } 
        } 
    } 
</script>

在上述代码中,我们首先引入了Hls.js库,并且在Vue组件中定义了一个video标签,然后通过mounted钩子函数实现了视频的加载、播放和销毁。具体地说,如果浏览器支持Hls,我们就创建一个新的Hls实例,然后通过loadSource方法加载视频源文件。之后,我们通过attachMedia方法将video元素绑定到Hls实例上。最后,在ManifestParsed事件触发后,我们可以调用video元素的play方法开始播放视频。如果浏览器不支持Hls,则通过video元素的src属性来加载视频资源,当元数据加载完成后,也调用video元素的play方法来启动视频。

领C++音视频学习资料→「链接」

最后,我们可以在Vue应用中使用VueHlsPlayer组件来实现视频的播放。下面是示例代码:

    <VueHlsPlayer :url="url" />
</template>
<script>
import VueHlsPlayer from '@/components/VueHlsPlayer.vue';
export default {
    name: 'App',
    components: {
        VueHlsPlayer
    },
    data() {
        return {
            url: 'http://example.com/path/to/video.m3u8'
        }
    }
}
</script>

通过上述代码即可实现Vue.js和HLS协议的结合,以实现视频流的播放。当然,具体的应用场景和流程取决于实际开发需求,但可以肯定的是,本文所提供的示例代码可以作为一个很好的参考,帮助你更好地理解Vue.js和HLS协议的结合。

3、遍历渲染多个视频播放

<template>
  <div class="monitorWarp">
    <div class="monitorItem">
      <div class="item" v-for="(item, index) in videoList" :key="index">
        <video
          :ref="['videoElement' + index]"
          controls
          muted
          preload="auto"
          style="width:100%;height:100%; fit:fill;"
        ></video>
      </div>
    </div>
  </div>
</template>
<script>
import { getRealMonitor } from "../api.js";
import Hls from "hls.js";
export default {
  data() {
    return {
      videoList: []
    };
  },
  created() {},
  computed: {},
  mounted() {
    this.RealMonitor();
   
  },
  methods: {
    RealMonitor() {
      getRealMonitor(this.params).then(res => {
        console.log(res, "实时监控");
        this.videoList = res.result;
        this.videoList.forEach((item, index) => {
          console.log(item);
          this.showVideo(item, "videoElement" + index);
        });
      });
    },
    showVideo(url, refId) {
      console.log(url, refId, "节点");
      let video = refId; //定义挂载点
      this.hlsjs = new Hls();
      this.hlsjs.loadSource(url);
      this.hlsjs.attachMedia(video);
      this.hlsjs.on(Hls.Events.MANIFEST_PARSED, () => {
        video.play();
      });
      this.hlsjs.on(Hls.Events.ERROR, (event, data) => {
        console.log(event, data);
        // 监听出错事件
        console.log("加载失败");
      });
    }
  }
};
</script>
<style lang="less" scoped>
.monitorWarp {
  .monitorItem {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    .item {
      width: 224px;
      height: 168px;
      background-color: #143354;
      margin-top: 2px;
      border: solid 2px #2677f1;
    }
  }
}
</style>

4、vue+原生

通过上述代码即可实现Vue.js和HLS协议的结合,以实现视频流的播放。当然,具体的应用场景和流程取决于实际开发需求,但可以肯定的是,本文所提供的示例代码可以作为一个很好的参考,帮助你更好地理解Vue.js和HLS协议的结合。

相关推荐

网站制作的流程是什么呢?简单大概的流程

关注我!了解更多网站建设的小干货~如今,随着网络时代的全面到来,网站在人们的生活和工作中发挥着极其重要的作用。网站制作的发展使更多的人加入了这个行业。如果你想掌握网站制作的知识,你可以在学校或网上学习...

一款谷歌(Google)打造的广告网页设计制作软件

GoogleWebDesigner是由谷歌(Google)打造的一款广告网页设计制作软件,它能够帮助从事于广告网页设计工作或是有这方面需求的用户更加有效快速的进行完成相关的行业设计工作,软件可以支...

普通网站如何制作一个网站?

对行外人来讲,在预备做一个网站项目时,最想了解的无非就是网站制作的悉数流程。网站制作是要有计划的,事先策划好才能更快更好的完成。网站的几个基本组成元素:域名+空间+程序+模板+维护经验+日常管理.网站...

用纯Python就能写一个漂亮的网页,再见HTML

再见HTML!用纯Python就能写一个漂亮的网页我们在写一个网站或者一个网页界面的时候,需要学习很多东西,对小白来说很困难!比如我要做一个简单的网页交互:天啊,听听头都大呢!其实我就给老板做一个...

HTML表单4(form的action、method属性)——零基础自学网页制作

表单的工作过程表单的信息发送与处理过程可以简单的进行图示,如下图。以注册会员为例,用户在自己的电脑上打开相应的注册表单页面填写信息,完成填写后点击提交按钮,也就是图中1所示过程。这时浏览器会将这些信息...

官网网站设计网页制作模板建站前端自适应响应式网站仿站门户

案例背景航科慧联无人机搜索雷达能够在多种天气下检测到无人机的入侵、并获得目标的距离、方向和高度等具体信息,是无人机反制作战中的关键设备。航科慧联无人机搜索雷达能够在多种天气下检测到无人机的入侵、并获得...

软网推荐:在线制作软件图标

在制作PPT演示、软件、网页或其他程序时,我们往往需要用到一些个性化的图标。现在,即便是不安装任何软件,也可以上网在线制作自己需要的图标。首先访问如下制作网址:http://www.rw-design...

自定义跳转的h5网页如何制作?

文章来源:墨鹊微站...

网页如何制作?这几点要知道

这是一个个性张扬的时代,也是一个动手能力和动脑能力都比较强的时代,因此很多人对于能够自己动手完成的东西,都不太想假手于人。于是网页制作成了各大搜索引擎里面排名比较靠前的关键词之一。想要知道网页如何制作...

手机端网站简单制作教程,怎么快速制作一个移动端的网站

想要创建一个手机端的网站,需要有域名、已经完成网站页面的开发设计,零基础朋友不懂代码技术,直接在线套用乔拓云里面的网站模板来开发是比较简单可行的,进入乔拓云网,复制网站模板编辑网站的内容,注册域名后绑...

几张动图教你轻松了解Dreamweaver做网页

施老师:当今可是互联网时代,人们的生活、社交离不开互联网,那么不管你是网页设计师,还是销售达人,还是个体户,总必不可少的要在网上呈现一些页面给客户看,这个就是让你做网页,而Dreamweaver是做网...

用Deepseek制作网页版的汉诺塔游戏保姆级教程

在deepseek中输入:“帮我做一个网页版的汉诺塔演示游戏,游戏包含2层、3层、4层、5层的汉诺塔游戏演示,制作自动求解演示按钮,点击按钮就可以生成出步数,同时自动演示最优解动画。”...

JS制作网页版计算器

大家晚上好,我是洁哥,抱歉今天有点晚了,但是洁哥不会缺席哦,今天我们来看一个JS实现网页版计算器的例题,先来看一看出来的效果吧(123+123=246)(123-123=0)(123*123=1512...

网页制作流程哪几步

在数字化时代,网页制作成为企业和个人展示形象、传递信息的重要方式。但是,许多人对于网页制作的流程仍感到困扰。为了解决这一问题,我们将深入探讨网页制作的关键步骤,助您更好地理解和应用这一过程。第一步:需...

这4个设计技巧,教你做好个人网页制作

随着互联网发展,个人建站已经不是什么稀奇事,学生、求职者、插画师、摄影师、作家……都可以制作个人网站,用来展示自身形象,或者吸引粉丝。那么如何做好个人网站呢?在不懂设计和技术知识的情况下,个人网页制作...

取消回复欢迎 发表评论: