视频播放方案

news2024/9/21 22:41:14

video插件播放m3u8格式视频(存原生)

这里使用原生的javascript实现m3u8格式视频播放。

使用了包括video.min.js库和HLS插件。

1-基础使用

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>Video.js HLS Example</title>
  	<!-- add dependency -->
    <link href="https://vjs.zencdn.net/7.7.6/video-js.css" rel="stylesheet" />
    <script src="https://vjs.zencdn.net/7.7.6/video.min.js"></script>
    <script src="https://cdn.jsdelivr.net/npm/videojs-contrib-hls@5.15.0/dist/videojs-contrib-hls.min.js"></script>
</head>
<body>
  	<!-- create viedo element -->
    <video 
    	id="my-video"
      class="video-js" 
      width="1280" 
      height="720"
    	data-setup='{"autoplay": true, "controls": false, "preload": "auto", "fluid": false, "controlBar": false}'
    >
    	<source src="#" type="application/x-mpegURL">
    </video>
    <script>
      var url = 'https://36689.live-vod.cdn.aodianyun.com/m3u8/0x0/aqes_36689.aqes0.1628058327/aqes_36689.aqes0.1628058327.m3u8';
      // 页面加载完毕后执行播放逻辑,在之前可以异步获取视频播放url
      window.onload = function() {
        var player = videojs('my-video');
        player.src({src: url, type: 'application/x-mpegURL'})
      	player.play();
      }
    </script>
</body>
</html>

在上面代码中,首先引入了video.min.js库和对应的播放器样式video-js.css,还引入了videojs-contrib-hls.min.js库(引入顺序考虑优先放到页面加载之前)。

之后,创建一个video标签,并指定source的src属性为一个占位地址,如果不给一个占位地址,在后面动态赋值src时会导致游览器报错;这里关于视频播放的一些配置放到了data-setup中(json的格式),具体含义如下:

  • autoplay:是否自动播放
  • controls:是否现实进度条操作栏
  • preload:设置为auto,表示自动加载视频
  • fluid:是否自适应父容器大小
  • controlBar: 设置为false,表示不显示控制栏目

注意:

autoplay属性需要在用户与页面进行过交互后才能生效,以保护用户体验和隐私。因此,如果需要实现完全自动播放,可以考虑使用其他解决方案,例如在用户点击页面时触发播放。

最后,使用JavaScript代码创建一个videojs的实例,并动态给予视频播放地址,再调用play()方法开始播放视频。

需要注意的是,HLS插件需要在支持MSE(Media Source Extensions)和HLS的浏览器中才能正常工作。如果浏览器不支持这些功能,可以考虑使用其他的插件或库来播放m3u8视频格式。

2-如何切换播放地址

在每次切换播放下一个视频时,一定需要销毁上一个播放实例,即使用 player.dispose() 方法。

player.dispose() 该方法会销毁videojs实例以及其相关的DOM元素和事件监听器,从而将视频播放器还原为初始状态。

按实际情况判断,一般有两种情况需要进行播放实例销毁,一是视频需要切换的时候(用户主动执行的操作的情况);二是视频播放完成的时候。

第一种情况只需要监听用户进行对应的按钮操作的时候即可,比较简单。

第二种情况可以在视频播放之后,添加监听player播放实例上ended事件,再该事件中去执行播放的销毁。

// ...
    <script>
      var url = 'https://36689.live-vod.cdn.aodianyun.com/m3u8/0x0/aqes_36689.aqes0.1628058327/aqes_36689.aqes0.1628058327.m3u8';
      // 页面加载完毕后执行播放逻辑,在之前可以异步获取视频播放url
      window.onload = function() {
        var player = videojs('my-video');
        player.src({src: url, type: 'application/x-mpegURL'})
      	player.play();
        
        // 监听播放完成事件,执行播放实例销毁
        player.on('ended', function() {
        	player.dispose();
        });
      }
    </script>
// ...

3-如何通过player实例控制视频基础操作

// ...
    <script>
    	var player = videojs('my-video');
    	player.play(); // 自动播放
      player.currentTime(10); // 快进到10秒
      player.currentTime(player.currentTime() - 5); // 快退5秒
      player.pause(); // 暂停播放
    </script>
// ...

上面的代码中,通过设置播放实例下currentTime方法实现播放的快进和快退,该方法接受一个参数,表示设置的时间点,如果不传参数,表示获取当前视频播放的时间点。

currentTime方法再不接受参数的时候,可以实现快退的方法。

设置pause的方法可以实现视频暂停的方法。

4-如何实现完全自动播放的功能

在HTML5标准中,自动播放的行为是被禁止的,如果播放器被设置为自动播放,则会被浏览器禁止。这是出于用户体验和减轻带宽压力等方面的考虑。

但在某些情况下,我们仍然希望实现自动播放,因此可以考虑下面的实现方法。

一、用户操作触发自动播放:

可以监听页面加载完成事件,在页面加载完成后触发播放按钮的点击事件,从而触发自动播放。示例代码如下:

var player = videojs('my-video');
player.ready(function() {
  var promise = player.play();
  if (promise !== undefined) {
    promise.then(function() {
      // 自动播放成功
    }).catch(function(error) {
      // 自动播放失败,需要用户手动触发播放
      player.on('play', function() {
        player.play();
      });
    });
  }
});

二、Muted自动播放

可以将视频设置为静音,从而规避浏览器自动播放的限制。示例代码如下:

var player = videojs('my-video');
player.muted(true);
player.play();

需要注意的是,静音自动播放可能会被用户感知到,并影响用户体验。

三、自动播放和手动播放切换(不适用)

可以通过监听用户的操作,从而判断是否需要自动播放。例如,在用户第一次点击播放按钮后,取消静音并自动播放。示例代码如下:

var player = videojs('my-video');
player.on('play', function() {
  player.muted(false);
  player.off('play'); //取消对播放的监听
});
player.play();

四、直接修改游览器声音设置

在最新的谷歌游览器中,找到设置 > 隐私和安全 > 网站设置 > 声音(更多设置里面)

之后在允许播放声音中添加需要自动播放的网址。
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/509128.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

MYSQL高级语句

实验用表 create table location (Region char(20),Store_Name char(20)); insert into location values(East,Boston); insert into location values(East,New York); insert into location values(West,Los Angeles); insert into location values(West,Houston); location…

如何解决请求参数为JSON时,采用IO流读取,只能请求一次的问题?

如何解决请求参数为JSON时&#xff0c;采用IO流读取&#xff0c;只能请求一次的问题&#xff1f; 一、错误演示1. 创建项目&#xff0c;添加所需依赖2. 配置redis环境3. 写一个简单的测试请求4. 写一个拦截器&#xff0c;拦截请求5. WebConfig 注册拦截器6. 测试请求 二、问题解…

vue问题

一、路由 hash模式&#xff08;location.hash hashchange 事件&#xff09; hash 模式的实现方式就是通过监听 URL 中的 hash 部分的变化&#xff0c;触发haschange事件&#xff0c;页面做出不同的响应。但是 hash 模式下&#xff0c;URL 中会带有 #&#xff0c;不太美观。 h…

【多线程初阶三】简单了解wait和notify方法~

目录 &#x1f31f;1、wait() &#x1f31f;2、notify() &#x1f31f;1、wait() &#xff08;1&#xff09;wait()方法与notify()方法都是Object类中的方法。 &#xff08;2&#xff09;wait()是让线程等待一段时间&#xff0c;死等——>状态WAITING:没有时间限制的等待.…

MySQL 高级(进阶) SQL 语句一

一、高级SQL语句&#xff08;进阶查询&#xff09; 先准备2个表 一个location表&#xff1a; use kgc; create table location (Region char(20),Store_Name char(20)); insert into location values(East,Boston); insert into location values(East,New York); insert int…

如何判断CRM软件的好坏?2023年CRM系统排行榜前三名是什么?

CRM客户管理系统经过20余年的发展&#xff0c;收获了越来越多企业的认可&#xff0c;成为企业数字化转型必不可少的一环。很多企业都有上线CRM软件的计划&#xff0c;但精准的找到一款适合自身的产品十分不易&#xff0c;今天我们就来盘点2023年CRM软件排行榜。 一、CRM的含义…

Intellij中使用Spotless 格式化代码

Spotless简介 在一些大型项目或开源项目&#xff0c;由于开发人员太多&#xff0c;导致各个代码格式不统一。会让整体项目的代码可读性变差。统一代码格式使用maven中的Spotless插件就是不错的选择。 Spotless 是一个代码格式化工具&#xff0c;它有以下功能&#xff1a; 支…

300. 最长递增子序列

300. 最长递增子序列 给你一个整数数组 nums &#xff0c;找到其中最长严格递增子序列的长度。 子序列 是由数组派生而来的序列&#xff0c;删除&#xff08;或不删除&#xff09;数组中的元素而不改变其余元素的顺序。例如&#xff0c;[3,6,2,7] 是数组 [0,3,1,6,2,2,7] 的子…

tp6 对接阿里云短信

1、获取AccessKey ID,AccessKey Secret&#xff0c;第一次会提示需要创建 2、添加签名 3、创建模板 composer版本太老了&#xff0c;可能会导致下载失败&#xff0c;建议升级下版本 官方提供的最新依赖版本&#xff0c;我的会报错&#xff0c;下载不了&#xff0c;提示用2.0.…

Android Studio 下真机调试

文章目录 一、开启真机调试二、断开真机调试 一、开启真机调试 准备USB调试线&#xff0c;一端插在电脑USB接口上&#xff0c;另一端插在手机充电口上。 下面以自己的手机&#xff08;huawei nova 5 &#xff09;为例&#xff1a;点击手机界面上的设置应用。 然后往下找到 【关…

经典神经网络(1)LeNet及其在Fashion-MNIST数据集上的应用

经典神经网络(1)LeNet 1、卷积神经网络LeNet 之前对于Fashion-MNIST服装分类数据集&#xff0c;为了能够应⽤softmax回归和多层感知机&#xff0c;我们⾸先将每个大小为28 28的图像展平为⼀个784维的固定⻓度的⼀维向量&#xff0c;然后⽤全连接层对其进⾏处理&#xff0c;此…

函数式接口的介绍和使用(FunctionInterface)——Consumer,Supplier,Predicate、Function

函数式接口(Functional Interface)就是一个有且仅有一个抽象方法&#xff0c;但是可以有多个非抽象方法的接口。 函数式接口可以被隐式转换为 lambda 表达式。 函数式接口都添加了 FunctionalInterface 注解&#xff0c;这个是jdk1.8才引进的。例如 因为函数式接口里面只是…

【C++】| 01——泛型编程 | 模板

系列文章目录 【C】| 01——泛型编程 | 模板 文章目录 1. 认识泛型编程2. 函数模板1.1 函数模板的语法1.1.1 定义模板1.1.2 应用模板实现函数1.1.3 使用模板函数(实例化)1.1.3.1 隐式使用(实例化)1.1.3.2 显式使用(实例化)1.1.3.3 使用函数模板的注意事项(实例化) 2. 类模板2.…

第1章 Nginx简介

基于 Nginx版本 1.14.2 &#xff0c;Tomcat版本 9.0.0 演示 第1章 Nginx简介 1.1 Nginx发展介绍 Nginx &#xff08;engine x&#xff09; 是一个高性能的Web服务器和反向代理服务器&#xff0c;也可以作为邮件代理服务器。 Nginx 特点是占有内存少&#xff0c;并发处理能力…

南京邮电大学数据库实验二(DBMS的数据库保护)

文章目录 一、实验目的和要求二、实验环境(实验设备)三、实验原理及内容(1) DBMS的数据库保护功能(2) 安全控制中的访问控制机制(3) 事务的提交与回滚(4) 并发控制的锁机制 三、实验内容1.以root账户登录数据库管理系统&#xff0c;创建用户U1和U2&#xff0c;密码自定。2.创建…

Redis 入门教程(简单全面版)

1 安装&#xff1a; 1.1 生产环境安装 注意&#xff1a; 1、如果安装过程有问题可以参考源代码中的 README.md 文件 2、如果服务器只安装一个 redis 通常选择 /usr/local/redis 作为安装目录&#xff0c;如果安装多台则建议带上 服务名称 区分&#xff08;建议带上 服务名称 区…

jvm-狂神课程

一、JVM JVM就是Java虚拟机&#xff0c;Java虚拟机就是JVM 1. JVM位置 1、Java程序&#xff08;跑的环境是在jvm&#xff08;虚拟机&#xff09;跑的&#xff0c;也可以说是在jre上跑的&#xff09;java运行是需要在特定的环境的也就是这个jre这种。 2、jvm&#xff08;也就是…

别不信:这些细节关乎你的物联网设备的命运!

《高并发系统实战派》-- 值得拥有 一、设备接入层网络协议的意义 随着物联网的发展&#xff0c;越来越多的设备需要接入云平台进行远程监控和管理。设备接入层网络协议起到了承担设备接入网络的功能&#xff0c;为物联网平台提供了数据交互的基础。设备接入层网络协议对于物联…

【C++ 入坑指南】(01)学习路线

入门 1. 推荐书籍 《Accelerated C》&#xff0c;《Essential C》二选一精读。《A Tour of C》选读。 《Accelerated C》很适合新手&#xff0c;因为只有短短不到 300 页&#xff0c;在普遍一样的入门书籍里面是一股清流。容易通读完&#xff0c;减少挫败感。就这样的篇幅&am…

【每天学习一点新知识】如何绕过CDN查真实ip

1、什么是CDN 为了防止流量过大网络堵塞&#xff0c;我们就在靠近用户的地方&#xff0c;建一个缓存服务器&#xff0c;把远端的内容复制一份&#xff0c;放在这里&#xff0c;简单来说就是将内容缓存在终端用户附近。 2、怎么绕过cdn找到远端服务器的真实ip呢&#xff1f; &…