uniapp h5 vue3 m3u8 和 mp4 外链视频播放

m3u8视频播放

使用mui-playerhls.js

  1. 安装
    npm install mui-player hls.js
    
    我的版本是"hls.js": "^1.5.17""mui-player": "^1.8.1"
  2. 使用
    页面标签:
    在这里插入图片描述
    引用:
    在这里插入图片描述
    点击目录播放视频:
    在这里插入图片描述
    m3u8视频播放:
    在这里插入图片描述
mp = null;
// isPlay 是否未播放完
// m3u8播放url
// chapter 播放课程信息
m3u8Play(isPlay, url, chapter) {const courseInfo = chapter?.courseware;// 学习的时间let studyHour = 0;// 未播放完if (isPlay) {studyHour = chapter?.coursewareStudyHour?.hours;}this.$nextTick(() => {this.mp = new MuiPlayer({container: document.getElementById('mui-player'),src: url, // 获取当前章节的视频URLparse: {type: 'hls',loader: Hls,config: {debug: false}},pageHead: false})this.mp.on('ready', () => {const video = this.mp.video();video.addEventListener('play', (e) => {// 点击开始播放 续播video.currentTime = studyHour;})video.addEventListener('timeupdate', (e) => {if (isPlay && e.target.currentTime.toFixed(0) % 5 === 0) {this.addStudyHourFun(courseInfo.coursewareId, e.target.currentTime.toFixed(0))}console.log('播放中', e.target.currentTime,  e.target.currentTime.toFixed(0))})video.addEventListener('pause', (e) => {// 暂停播放if (isPlay) {// 记录学习时长this.addStudyHourFun(courseInfo.coursewareId, e.target.currentTime.toFixed(0))}})})})
}

mp4外链视频播放

使用原生video播放:

<video class="course-video" :src="url" :initial-time="initialTime":enable-progress-gesture="false"  @timeupdate="videoPlay($event)"@error="videoErrorCallback($event)" controls @pause="pauseVideo($event)"></video>

逻辑代码:

// 初始值
initialTime = 0;
// 播放视频
lastSecond = -1;
// 暂停时长
stopTime = 0;
// 当前选播 播放时长(总时长)
durationSecord = 0;
// 是否进行学习记录
addStudyHour = true;
videoPlay(ev) {// 播放视频
}videoErrorCallback(e): void {uni.showToast({icon: 'error',title: e.target.errMsg || '视频加载错误'})
}pauseVideo(ev) {console.log('暂停',  this.stopTime, courseInfo)
}

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

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

相关文章

php项目流水线flow的创建能部署与使用

在云服务器平台上使用 PHP 项目创建、配置、部署和使用流水线&#xff0c;可以通过阿里云 DevOps 服务来自动化 CI/CD&#xff08;持续集成与持续交付&#xff09;流程。以下是详细的步骤和指导&#xff0c;帮助你完成 PHP 项目的流水线设置和部署。 ### 1. 创建流水线 #### …

借助 AI 工具,共享旅游-卡-项目助力年底增收攻略

年底了&#xff0c;大量的商家都在开始筹备搞活动&#xff0c;接下来的双十二、元旦、春节、开门红、寒假&#xff0c;各种活动&#xff0c;目的就是为了拉动新客户。 距离过年还有56 天&#xff0c;如何破局&#xff1f; 1、销售渠道 针对旅游卡项目&#xff0c;主要销售渠道…

软件工程——期末复习(3)

一、题目类(老师重点提到过的题目) 1、高可靠性是否意味着高可用性&#xff1f;试举例证明自己的观点&#xff1f; 答&#xff1a;高可靠性不意味着高可用性 可靠性说明系统已经准备好&#xff0c;马上可以使用&#xff1b;可用性是系统可以无故障的持续运行&#xff0c;是一…

程序员需要具备哪些知识?

程序员需要掌握的知识广泛而深厚&#xff0c;这主要取决于具体从事的领域和技术方向。不过&#xff0c;有些核心知识是共通的&#xff0c;就像建房子的地基一样&#xff0c;下面来讲讲这些关键领域&#xff1a; 1. 编程语言&#xff1a; 无论你是搞前端、后端、移动开发还是嵌…

[Blender]从零开始的blender导入PMX模型教程

一、前言 最近正在接触3D打印&#xff0c;目前我发现&#xff0c;在开源的模型市场上3D的人物模型非常有限并且部分还维持收费。所以就有了一个想法&#xff0c;能不能自己制作3D打印的人物模型。目前虽然开源的3D打印人物模型比较少&#xff0c;但是以PMX开源的人物模型却非常…

C#与PLC通讯时,数据读取和写入浮点数,字节转换问题(ModbusTCP)

在与PLC进行通讯时&#xff0c;会发现一个问题&#xff0c;浮点数1.2接收过来后&#xff0c;居然变成了两个16位的整数。 经过一系列的分析&#xff0c;这是因为在PLC存储浮点数时32位&#xff0c;我们接收过来的数据会变成两个16位的高低字节&#xff0c;而且我们进行下发数据…

替代FTP最佳跨网文件传输解决方案——FileLink

在传统的企业文件传输中&#xff0c;FTP&#xff08;文件传输协议&#xff09;曾因其便捷性和高效性被广泛应用。然而&#xff0c;其固有的安全漏洞、对大文件传输支持的局限性、易受网络攻击等问题&#xff0c;已逐渐暴露出FTP在现代企业环境下的不足。针对这一问题&#xff0…

纯粹直播 1.7.7 |手机版和TV版,聚合六大直播平台,原画播放

纯粹直播是一款开源的应用程序&#xff0c;支持兴趣化主题的游戏直播、户外直播和才艺直播节目。目前可以观看斗鱼、B站、虎牙和抖音等六大直播平台的内容。该应用适配了安卓手机和电视盒子平台使用&#xff0c;并且软件无广告&#xff0c;提供原画质播放体验。 大小&#xff…

汉诺塔(递归)

递归、搜索与回溯算法 文章目录 递归、搜索与回溯算法前言一、递归的思想二、汉诺塔三、为什么可以使用递归思想&#xff1f;四、代码实现 Leetcode汉诺塔 前言 这是记录我学习算法的一个专题&#xff0c;如果你正在备战这类比赛&#xff0c;我想这对你一定有帮助。 一、递归…

【JUC-锁升级】简要版本

锁升级过程 一、偏向锁二、轻量级锁三、重量级锁四、整体流程 为什么不全部使用Synchronized、Lock等重量级锁呢&#xff1f; 重量级锁底层是基于操作系统的互斥锁实现的&#xff0c;涉及到用户态与内核态之间的切换。 一、偏向锁 如果只有一个线程A频繁的访问某一个共享资源…

C++小碗菜之二:软件单元测试

“没有测试的代码重构不能称之为重构&#xff0c;它仅仅是垃圾代码的到处移动” ——Corey Haines 目录 前言 什么是单元测试&#xff1f; 单元测试的组成 单元测试的命名 单元测试的独立性 Google Test 单元测试的环境配置与使用 1. Ubuntu下安装 Google Test 2. 编写…

家庭财务管理系统的设计与实现ssm小程序+论文源码调试讲解

2系统关键技术 2.1 微信小程序 微信小程序&#xff0c;简称小程序&#xff0c;英文名Mini Program&#xff0c;是一种全新的连接用户与服务的方式&#xff0c;可以快速访问、快速传播&#xff0c;并具有良好的使用体验。 小程序的主要开发语言是JavaScript&#xff0c;它与普…

linux运维命令

防火墙相关命令 防火墙规则查看 firewall-cmd --list-all 禁ping firewall-cmd --permanent --add-rich-rulerule protocol valueicmp drop firewall-cmd --reload 执行完以上命令后&#xff0c;通过firewall-cmd --list-all查看规则生效情况 firewall-cmd --list-all 其…

高通---Camera调试流程及常见问题分析

文章目录 一、概述二、Camera配置的整体流程三、Camera的代码架构图四、Camera数据流的传递五、camera debug FAQ 一、概述 在调试camera过程中&#xff0c;经常会遇到各种状况&#xff0c;本篇文章对camera调试的流程进行梳理。对常见问题的提供一些解题思路。 二、Camera配…

HCIA-openGauss_2_1数据库安装部署

本章导读 openGauss是关系型数据库&#xff0c;采用客户端/服务器&#xff0c;单进程多线程架构&#xff0c;支持单机和一主多备部署方式&#xff0c;备机可读&#xff0c;支持双机高可用和读扩展。 本章详细介绍了安装openGauss的环境和安装部署配置、openGauss数据库的连接…

《Tyche: Stochastic In-Context Learning for Medical Image Segmentation》CVPR2024

摘要 这篇论文介绍了一个名为Tyche的模型&#xff0c;它用于医学图像分割任务。Tyche通过使用上下文集来为以前未见过的任务生成随机预测&#xff0c;无需重新训练。该模型解决了两个主要问题&#xff1a;1) 对于大多数新的分割任务&#xff0c;需要重新训练或微调新模型&…

47 基于单片机的书库环境监测

目录 一、主要功能 二、硬件资源 三、程序编程 四、实现现象 一、主要功能 基于51单片机&#xff0c;采用DHT11湿度传感器检测湿度&#xff0c;DS18B20温度传感器检测温度&#xff0c; 采用滑动变阻器连接数模转换器模拟二氧化碳和氧气浓度检测&#xff0c;各项数值通过lc…

NAND闪存行业全面且深入的分析

根据QYResearch调研团队的最新报告“全球NAND闪存市场报告2023-2029”&#xff0c;预计2029年全球NAND闪存市场规模将达到1263亿美元&#xff0c;未来几年年复合增长率&#xff08;CAGR&#xff09;为10.0%。这一预测揭示了NAND闪存市场的强劲增长潜力。 一、市场研究与发展趋…

html-两个div,让一个div跟随另外一个div的高度

在开发的过程中遇到有些场景事这样的&#xff0c;两个div的高度不一致&#xff0c;而且都是动态高度&#xff0c;有的时候div1高&#xff0c;有的时候div2高&#xff0c;如果设置flex的话&#xff0c;那么就会把较矮的元素撑大&#xff0c;但是我想始终都以div1的高度作为基准&…

函数方法不占额外存储空间(内存分区)?

上篇博客说到扩展是不会增加存储空间的&#xff0c;且扩展不能扩展存储属性。既然这样&#xff0c;那我们就能理所应当推断出方法是不占存储空间的&#xff0c;为什么呢&#xff1f; 首先&#xff0c;我们要先了解内存的五大分区&#xff1a;栈&#xff0c;堆&#xff0c;静态…