vue项目中使用m3u8格式播放大视频

这篇具有很好参考价值的文章主要介绍了vue项目中使用m3u8格式播放大视频。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

一、背景

网站中播放大视频时经常卡顿,无法顺利播放,在查找解决方案时发现很多文章建议使用m3u8流媒体播放代替MP4播放,做了下测试,现总结记录下测试过程中遇到的问题与解决办法。

二、测试实现

1.使用ffmpeg做视频转换

1)下载ffmpeg

 FFmpeg github

2)在环境变量path中加入配置,以便在控制台使用指令

vue 播放m3u8,音视频

3)使用指令将MP4格式视频转为m3u8格式

ffmpeg.exe -i video.mp4 -hls_time 60 -hls_list_size 0 -f hls a.m3u8

上述指令中 -i video.mp4 表示输入视频源为video.MP4(此处已用指令打开视频所目录),-hls_time 60表示视频分割时长为60秒(为了保证画面连贯帧数切出的视频长度会有几秒的波动范围),-hls_list_size 0表示保留所有的分割片段(如果不加这段指令默认只保留5个片段),-f hls表示使用hls流协议输出视频(通常情况可以不添加此段指令,一般是自动检测输入文件,并根据输出文件的文件扩展名判定输出格式),a.m3u8表示将切割视频的索引以此名字文件输出。

指令执行完毕后会输出一个a.m3u8的索引文件和若干个 ts视频文件

*在使用指令转换完后发现视频整体大小变小了很多,将2G左右的MP4视频转成200M左右的小视频片段,画质和音频播放起来也没有特别大的体感差异,暂不明白具体原理,试用一段时间看是否有坑。

2.VUE项目使用

1)项目安装videojs视频播放库及其流媒体传输协议支持

npm install --save video.js

npm install --save videojs-contrib-hls

在需要播放视频的页面中引入videojs及对应的样式文件

import videojs from "video.js";

import "video.js/dist/video-js.css";

video-js.css样式文件无法通过vscode的自动补齐找到,不设置样式时页面会显示下方的配置信息

vue 播放m3u8,音视频

 

示例代码:

<template>
  <q-page padding>
    <div class="row">
      <div class="col-6">
        <video id="myVideo" class="video-js vjs-default-skin vjs-fluid"></video>
      </div>
    </div>
  </q-page>
</template>

<script>
import { defineComponent } from "vue";
import videojs from "video.js";
import "video.js/dist/video-js.css";

function options(src, type) {
  return {
    autoplay: true,
    muted: false,
    loop: false,
    controls: true,
    preload: "auto",
    fluid: true,
    sources: [
      {
        type,
        src,
      },
    ],
    notSupportedMessage: "视频资源无法加载",
    textTrackDisplay: false,
  };
}

export default defineComponent({
  name: "PageIndex",

  mounted() {
    this.$nextTick(() => {
      this.getVideo();
    });
  },

  data() {
    return {
      attachmentLink: "http://localhost/resource/demo.m3u8",
      srctype: "application/x-mpegURL",
      attachmentLink1: "http://localhost/resourc/1-引言.mp4",
      srctype1: "video/mp4",
    };
  },
  methods: {
    getVideo() {
      let player = videojs("myVideo", options(this.attachmentLink, this.srctype), () => {
        //player.play();
        player.on("loadstart", function () {
          console.log("Start load video");
        });
        player.on("play", function () {
          console.log("Play video");
        });
        player.on("pause", function () {
          console.log("Pause video");
        });
        player.on("ended", function () {
          console.log("Video end");
        });
      });
    },
  },
});
</script>

三、问题

1.如果m3u8视频无法正常播放,可以查看是否允许此类MIME Type

.m3u8

vue 播放m3u8,音视频

 .ts

vue 播放m3u8,音视频

 2.将视频播放封装成组件时遇到重复调用异常及布局错位问题

1)重复调用视频组件时需要将固定id改为动态拼接id,且在创建新的播放器实体前判断下对应实体是否已经创建并及时释放掉旧资源。要注意id和资源释放,防止videojs()创建播放器实体时出现重复实体导致报错。 我用了Quasar的框架,有beforeDestroy()的生命周期函数,其他框架里可能有有对应的函数。

vue 播放m3u8,音视频

vue 播放m3u8,音视频 

vue 播放m3u8,音视频

 2)vjs-fluid的自适应是根据上层div容器的宽高改变的,封装为组件后要注意定义video上层div容器的高度,否则会出现video自适应完高度后撑爆上层容器,在父页面盖住了其他内容

我给上层div定义了一个宽度和高度来避免撑爆容器的问题,使用16:9的固定宽高和vjs-16-9样式是因为vjs-fluid在定义完div的宽度后自适应出的控件大小会出现黑边,后续可以研究下是否有更好的解决方案。

vue 播放m3u8,音视频

 四、总结

上述是在项目改动中遇到的问题及其解决措施,做下记录汇总以便后续回顾,如果其他人遇到类似问题也可以作个参考。文章来源地址https://www.toymoban.com/news/detail-708919.html

到了这里,关于vue项目中使用m3u8格式播放大视频的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • uniapp的H5项目使用videojs播放m3u8类型视频

    uniapp项目,运行在手机浏览器端,需要播放m3u8类型视频。在网上找了好久教程,记录一下实现过程。 参考了:uni-app npm方式引入video.js教程 支持H5播放m3u8、mp4等格式视频文件_npm video.js_wang_9909的博客-CSDN博客 以及videojs官网。 1、安装videojs 2、在main.js中加以下三行代码 3、页面

    2024年02月07日
    浏览(28)
  • vue2 使用 vue-video-player 播放m3u8 流地址视频

    安装插件  : 注意需要引入  videojs-contrib-hls ,否则无法播放hls流文件  main.js 引入 代码内引入: 注意点:    1.type: \\\'application/x-mpegURL\\\' ,否则无法播放流文件  2.aspectRatio: \\\'16:9\\\',  宽高比需要进行设置, 若没有进行设置,会出现黑边过高或者过宽的问题 常用API方法:

    2024年02月07日
    浏览(33)
  • video.js 播放m3u8、flv、rtmp、RTS格式视频

     第一种方案(只适用m3u8格式): 属性 说明    options: {                     autoplay: true, // 设置自动播放                     muted: true, // 设置了它为true,才可实现自动播放,同时视频也被静音 (Chrome66及以上版本,禁止音视频的自动播放)                     prelo

    2024年02月12日
    浏览(49)
  • vue3播放m3u8视频(videoJS)

    需要同时导入videoJS以及相关的CSS 以下时项目使用中自己封装的组件,用起来也很简单,需要的可以对照自取 UI框架为 ant-design-vue

    2024年02月03日
    浏览(30)
  • vue使用vue-video-player实现web视频直播展示m3u8格式

    最近有一个需求,就是web展示摄像头的实时画面,mentor让我先探索探索,所以我先测试一些小demo。 这里边个人想了一下啊,还是比较复杂的,包含推流和拉流等操作,还有延迟的问题要解决。 自己主要负责前端,所以先用vue-video-player播放了一下本地的视频,熟悉一下功能,

    2023年04月22日
    浏览(39)
  • 前端vue播放m3u8、flv、mp4视频的方法

    安装依赖 npm install video.js --save // 视频播放器插件 npm install videojs-contrib-hls --save // 播放hls流插件 页面引入插件 页面中的使用 简介:flv.js是 HTML5 Flash 视频(FLV)播放器,纯原生 JavaScript 开发,没有用到 Flash。由 bilibili 网站开源。 开源地址: https://github.com/Bilibili/flv.js/ 安装依

    2024年02月13日
    浏览(41)
  • 使用ffmpeg将视频转成HLS(m3u8)格式

      HLS (HTTP Live Streaming)是苹果推出的视频流协议,HLS格式的视频包含一个m3u8文本文件,以及众多的.ts的视频片段,而m3u8文本文件的作用就是将这些ts片段索引起来。 因为HLS协议是将视频切分成很多小的ts片段,这些小片段很适合放到cdn上,有很多视频文章都使用了hls格式传

    2024年02月13日
    浏览(35)
  • 使用video.js完成hls/m3u8格式的视频播放

    近期项目中,需要播放视频,最开始给了个测试接口是hls格式的,查了一下,使用了video.js插件来进行播放。后期又改成了flv视频,这里简单记录一下。 1. 下载video.js插件,以及contrib-hls播放插件,页面引入,这两个插件,以及样式     这里好像涉及到版本问题,高版本的v

    2024年02月14日
    浏览(24)
  • uniapp m3u8格式视频加载

    uniapp一:mui-player:三方  h5 web app   uniapp 使用 mui-player 插件播放 m3u8/flv 视频流_翘翘红的博客-CSDN博客 uniapp 开发的h5项目,需要播放m3u8/flv后缀的视频,网上有很多视频插件,但是样式和效果不尽如人意,博主最后选择mui-player插件: 定制化稍微强一点以及有官方文档可以阅

    2024年02月12日
    浏览(30)
  • uniapp 直播拉流 播放m3u8 视频

    在百度中找啦n多个方法 没有解决啦 巨气人 发现hls.js hls.js不需要任何播放器,它可以直接在标准HTML 元素上运行。 安装第三方库 在uniapp页面显示 如果想要应用在自己的页面中 直接c v 就ok啦 要是有人问推流为啥没有 不要问 问就是不会!!!

    2024年02月12日
    浏览(32)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包