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视频播放:

js 复制代码
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, // 获取当前章节的视频URL
		        parse: {
		            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播放:

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

逻辑代码:

js 复制代码
// 初始值
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)
}
相关推荐
北极糊的狐1 小时前
狸窝转换器将MP4格式视频转换为以下格式后的大小对比:RM、RMVB、AVI、MKV、WMV、VOB、MOV、FLV、ASF、DAT、3GP、MPG、MPEG
音视频
是Dream呀1 小时前
一个账号调用N个AI模型!从LLM到视频生成的丝滑解决方案
人工智能·大模型·aigc·音视频·deepseek
2501_9159184111 小时前
移动端 HTTPS 抓包实战,多工具组合分析与高效排查指南
数据库·网络协议·ios·小程序·https·uni-app·iphone
雪芽蓝域zzs15 小时前
uni-app 将 base64 图片编码转为 Blob 本地文件路径
网络协议·udp·uni-app
顾北川_野16 小时前
播放PCM音频增益低+单独增强PCM解码的方案
音视频·pcm
Everbrilliant8917 小时前
FFmpeg解码音频数据AudioTrack/OpenSL播放
ffmpeg·音视频·audiotrack·opensl·ffmpeg音频解码播放·decodethread·opensl播放与解码同步
星光一影17 小时前
陪诊陪检系统源码,陪诊小程序,陪诊APP,陪诊服务,家政上门系统,居家护理陪护源码
mysql·小程序·uni-app·php
ivy1598683771518 小时前
JM20329是一款高性能、低功耗的USB桥接芯片,实现串行接口(如SATA、IDE)与USB接口之间的数据转换。
c语言·开发语言·ide·嵌入式硬件·eureka·音视频·视频编解码
温暖名字18 小时前
调用qwen3-omni的api对本地文件生成视频文本描述(批量生成)
python·音视频·qwen·qa问答
太阳人79819 小时前
MIPI D-PHY/C-PHY接收器压力眼图测试介绍
功能测试·嵌入式硬件·音视频·硬件工程