视频融合 hls流如何对接

很多人第一次听到视频融合这个词语吧,尤其是前端开发工程师。 很多IT公司项目都很少做视频融合的功能,那到底如何去对接呢?让我们带着这个疑问去看下面的讲解吧!!!!

接下来我会在V3项目中去讲解如何对接(V2一样的 只是使用方法不同)

问:hls流是什么呢? 答:HLS,英文全称为:HTTP Live Streaming,由苹果公司提出,它是基于Http的流媒体网络传输协议,主要传输TS格式流,最大的特点是安卓、苹果都能兼容,通用性强,而且码流切换流畅,满足不同网络、不同画质的用户播放需要,但是因为该种视频流协议也存在较为致命的缺陷,那就是网络延时太高。主要用于PC和Apple终端的音视频服务。包括一个m3u8的索引文件,TS媒体分片文件和key加密串文件。 问:那我们如何去拉去这个流进行播放呢? 答:看完下面的使用方法就了解了。

接下来我们进入对接吧!

我们首先需要先创建一个video标签来做视频播放窗口载体

xml 复制代码
<template>
  <div class="home">
    <video ref="videoElementRef" id="videoElement" controls muted style="width: 500px; height: 500px; object-fit: fill"></video>
  </div>
</template>

页面出现video载体了 我们使用的是hls.js npm 包 所以我们先下载npm包(下面两种都可) npm install hls.js yarn add hls.js 等待安装中......

安装完后我们需要引入注册

scss 复制代码
import {ref, onBeforeUnmount, onMounted } from 'vue'
import hlsJs from 'hls.js'

const videoUrl = ref('http://kbs-dokdo.gscdn.com/dokdo_300/_definst_/dokdo_300.stream/playlist.m3u8')  // 视频流
const videoElementRef = ref() // 载体
const hlsjs = ref() // 存储体

const hlsshow = () => {
  console.log(videoElementRef.value)
  if (hlsJs.isSupported()) {
    hlsjs.value = new hlsJs() // new一个hls 解析
    hlsjs.value.loadSource(videoUrl.value) //设置播放路径
    hlsjs.value.attachMedia(videoElementRef.value) //解析到video标签上
    hlsjs.value.on(hlsJs.Events.MANIFEST_PARSED, () => {
      videoElementRef.value.play()
      console.log('加载成功')
    })
    hlsjs.value.on(hlsJs.Events.ERROR, (event, data) => {
      // 监听出错事件
      console.log('加载失败')
    })
  } else {
    return
  }
}

const closeVideo = () => {
  if (hlsjs.value && videoElementRef.value) {
    // 销毁  注意  组件销毁时 一定要将流销毁掉
    videoElementRef.value.pause()
    hlsjs.value.destroy()
    hlsjs.value = null
  }
}

onBeforeUnmount(() => {
  closeVideo()
})

onMounted(()=>{
  hlsshow()
})

这样我们的视频就可以正常拉流播放了

相关推荐
转转技术团队11 分钟前
多代理混战?用 PAC(Proxy Auto-Config) 优雅切换代理场景
前端·后端·面试
南囝coding12 分钟前
这几个 Vibe Coding 经验,真的建议学!
前端·后端
gnip25 分钟前
SSE技术介绍
前端·javascript
yinke小琪40 分钟前
JavaScript DOM节点操作(增删改)常用方法
前端·javascript
枣把儿44 分钟前
Vercel 收购 NuxtLabs!Nuxt UI Pro 即将免费!
前端·vue.js·nuxt.js
望获linux1 小时前
【Linux基础知识系列】第四十三篇 - 基础正则表达式与 grep/sed
linux·运维·服务器·开发语言·前端·操作系统·嵌入式软件
爱编程的喵1 小时前
从XMLHttpRequest到Fetch:前端异步请求的演进之路
前端·javascript
喜欢吃豆1 小时前
深入企业内部的MCP知识(三):FastMCP工具转换(Tool Transformation)全解析:从适配到增强的工具进化指南
java·前端·人工智能·大模型·github·mcp
豆苗学前端1 小时前
手把手实现支持百万级数据量、高可用和可扩展性的穿梭框组件
前端·javascript·面试
不见_1 小时前
不想再写周报了?来看看这个吧!
前端·命令行