位置: IT常识 - 正文

uniappvideo避坑指南(H5、小程序、app)(uniapp cover-view)

编辑:rootadmin
uniappvideo避坑指南(H5、小程序、app) 今天写下这篇文章已是蓄谋已久了,背景是年初接到项目需求开发基于H5运行的视频学习平台,以及后来uniapp转小程序app开发。相信开发过uniapp的video应该或多或少都遇到过一些坑,开场就不多说了,直接上干货。

推荐整理分享uniappvideo避坑指南(H5、小程序、app)(uniapp cover-view),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:uniapp实战视频教程,uniapp开发视频,uniapp video组件,uniapp videojs,uniapp实战视频教程,uniapp videojs,uniapp使用video.js,uniapp使用video.js,内容如对您有帮助,希望把文章链接给更多的朋友!

项目要求用户不得拖动进度条,由播放进度触发对应事件

首先说说uniappH5使用video

H5是基于浏览器运行,那么浏览器平台就是我们需要考虑的兼容问题,就像我们之前写pc端的时候对IE的多年奋战一样,给大家列举一下现在市上使用率比较高的浏览器平台

QQ浏览器=>360浏览器=>UC浏览器=>谷歌浏览器(这个如果不是开发者应该使用率不多)等等

 就拿我们常见使用的浏览器举例把:

QQ、UC、360浏览器等常见平台都会在渲染video标签时劫持播放器,渲染内置可脱离网页进行播放,严重与项目需求不符,无论用何种方法都绕不开,

百度浏览器目前未发现劫持事件,但是运行百度时切入后台,过一段时间在切回浏览器项目是会白屏浏览器bug,无法绕开

开发H5如果需要背景和我一样的要注意及时和经理商量商量了

其次在说说app

各位开发者应该都知道video层级的问题,既然我们的需求是不然用户拖动进度条,那么就得考虑如何实现,我的思路是覆盖元素dom遮罩层,自己写播放控件,cover-view、cover-image是我们所需的救星,官方简介部分组件如map、video、textarea、canvas通过原生控件实现,原生组件层级高于前端组件(类似flash层级高于div)。为了能正常覆盖原生组件,设计了cover-view。

发现了光,但是开发一般发现video在全屏时cover-view不生效了,翻阅文档原理是app.vue页面video全屏不支持,得采用元素nvue页面写法

video全屏后,如何自行绘制界面?比如加个标题、加个分享按钮

app端 2.1.5 以上nvue页面的video也可以通过cover-view来绘制界面覆盖元素

继续我们的开发过程,完成在app端覆盖自定义播放组件,新的问题出现了,获取播放进度

uniappvideo避坑指南(H5、小程序、app)(uniapp cover-view)

@timeupdate="onTimeupdate"官方播放进度变化事件通过e.detail.currentTime获取进度赋值给initial-time达到保存进度,进入页面跳转到上传播放位置,但是发现nvue设置完毕后卡顿,timeupdate发现官方介绍说触发频率是250毫秒一次 ,且initial-time是实时推进的,打个比方timeupdate获取到的时间是4秒出发4次之后才是5秒,等于initial-time会被赋值4次,难,想办法,定义2个变量,一个进入页面赋值initial-time跳转到对应位置,一个通过timeupdate获取当前比方时间,ok了,

播放下一个视频时问题又来了,initial-time直接去上一个视频的e.detail.currentTime播放时间直接跳转了,需求无法完成,换思路,还是改用.vue页面的方式写吧,起码e.detail.currentTime是正常的,那我们全屏的时候怎么办呢,videoContext.seek()跳转到指定播放位置,采用timeupdate事件监听播放进度变化,超过3秒就不是正常播放,为用户手动拖拽进度条

this.videoTime = parseInt(e.detail.duration)if((currenttime - this.curCourse.Progress > 3 || currenttime - this.curCourse.Progress < -1) && this.plan.FinishedExam!== 1 && this.plan.FinishedCourses !== 1){this.videoContext.seek(this.curCourse.Progress)}else{this.videoRealTime = currenttimeif(this.videoRealTime > this.curCourse.Progress){this.curCourse.Progress = this.videoRealTime}}

这个大家应该能看懂把,变量在data中自行定义

实现效果达到预期,不足的是用户拖拽进度条,在使用seek()拖回来时video会触发@waiting事件加载,视频会卡顿一下。

打包交给测试,测试反馈播放视频会不定期闪退,我懵逼了。这怎么搞,没遇到过啊

开始因为是测试的手机太垃圾,死鸭子说你手机不行换手机测测,测试哄骗公司大大小小5,6个小姐姐的手机在测,现象一样,都是播放视频不定期会闪退。

怎么办,解决呀。代码没问题呀,初步闪退为内存消耗搞导致的,面向百度把

https://ask.dcloud.net.cn/question/117091

https://ask.dcloud.net.cn/question/66095

video高阶组件重新按照官方进行修改,发现怎么都不管用,

后来一直沿着这个思路百度优化,终于找到这篇文章,可以运行动态查看当前手机内存情况各位有时间组件研究一下把,问题找到了,但是解决方案?没有!!!

根本没有任何一篇文章说相似我的bug,只能自己摸索了。

距离测试反馈的闪退bug已经4天了,依然没有解决,emo了!!!

中间有想过是不是视频地址的编码问题或者是https等等,一一pas

就在刚刚突然想到nvue页面开发是基于原生渲染的性能更好,说干就干,开整

实际与预期一至,个人见解是nvue有更好的性能处理不vue页面更快,但是nvue缺点也是无奈,各位只能自己去摸索了,但是刚刚我们提到的e.detail.currentTime应该怎么办呢,个人解决方案 放弃initial-time调用保存的播放进度 在play事件里利用seek方法给拉过去

onplay(e){ //当开始/继续播放时触发play事件,这里的clStatus 是我自己定义的播放开始还是暂停的标识console.log(this.clStatus,'onplay')if(this.clStatus === 2){this.videoContext.seek(this.curCourse.Progress)this.clStatus = 1this.videoContext.play()}

到此bug优化完成,其实video里面还是有很多坑。这里我就不一样解释了 ,如果大家有一些见解欢迎和我一起探讨,后期个人一会去话一些时间去写一个可以自定义进度条的video播放器,我相信很多项目是有这样的需求的。但是uniapp插件目前还没有这方面的实例

创作不易,转载请注明出处谢谢

本文链接地址:https://www.jiuchutong.com/zhishi/284099.html 转载请保留说明!

上一篇:fsg_3202.exe是什么进程 有什么用处 fsg_3202进程查询(fs209e是什么意思)

下一篇:Windows7系统更改家庭组的密码的方法(win7系统修改)

  • c# listview(C# listview 填写字符)

    c# listview(C# listview 填写字符)

  • 小米5手环什么时候发布(小米5手环什么时候上市时间)

    小米5手环什么时候发布(小米5手环什么时候上市时间)

  • 取消了gprs会影响什么(关掉gprs还可以上网吗)

    取消了gprs会影响什么(关掉gprs还可以上网吗)

  • 提醒软件有病毒继续安装吗(提示有病毒的软件真的有病毒吗)

    提醒软件有病毒继续安装吗(提示有病毒的软件真的有病毒吗)

  • 荣耀带v和不带v的区别(荣耀v系列是不是旗舰系列)

    荣耀带v和不带v的区别(荣耀v系列是不是旗舰系列)

  • 电信机顶盒连不上网络(电信机顶盒连不上电视怎么回事)

    电信机顶盒连不上网络(电信机顶盒连不上电视怎么回事)

  • 小米手机在哪下载东西(小米手机在哪下载软件安装)

    小米手机在哪下载东西(小米手机在哪下载软件安装)

  • 华为新手机自带的膜需要换吗(华为新手机自带好多软件)

    华为新手机自带的膜需要换吗(华为新手机自带好多软件)

  • ripv1和ripv2的区别(ripv1的配置与使用)

    ripv1和ripv2的区别(ripv1的配置与使用)

  • 苹果11自动旋转怎么设置(苹果11自动旋转屏幕失灵)

    苹果11自动旋转怎么设置(苹果11自动旋转屏幕失灵)

  • vivo手机音量突然变小(vivo手机音量突然变小,一会变大)

    vivo手机音量突然变小(vivo手机音量突然变小,一会变大)

  • 京东调货一般多长时间(京东调货一般多少钱)

    京东调货一般多长时间(京东调货一般多少钱)

  • oppor9m电池多少毫安(oppor9km电池容量)

    oppor9m电池多少毫安(oppor9km电池容量)

  • 冬天苹果手机充电充不进去是怎么回事(冬天苹果手机充不上电了怎么解决)

    冬天苹果手机充电充不进去是怎么回事(冬天苹果手机充不上电了怎么解决)

  • cpu的主频指的是什么(主频最高的cpu排行)

    cpu的主频指的是什么(主频最高的cpu排行)

  • 个人热点拉黑怎么恢复(个人热点拉黑怎么拉回来)

    个人热点拉黑怎么恢复(个人热点拉黑怎么拉回来)

  • 电脑开始菜单不见了(电脑开始菜单不见了没法关机)

    电脑开始菜单不见了(电脑开始菜单不见了没法关机)

  • OPPO k5怎么设置个人热点(oppok5怎么设置返回键)

    OPPO k5怎么设置个人热点(oppok5怎么设置返回键)

  • 华为荣耀7怎么装双卡(华为荣耀7怎么装卡)

    华为荣耀7怎么装双卡(华为荣耀7怎么装卡)

  • 怎么消除苹果手机软件更新红点(怎么消除苹果手机重要安全更新提示)

    怎么消除苹果手机软件更新红点(怎么消除苹果手机重要安全更新提示)

  • iphone11pro max美版支持双卡双待吗(iphone11promax美版和国行的区别)

    iphone11pro max美版支持双卡双待吗(iphone11promax美版和国行的区别)

  • 微信朋友圈如何私密留言(微信朋友圈如何只发文字不发图片)

    微信朋友圈如何私密留言(微信朋友圈如何只发文字不发图片)

  • 腾讯会员怎么申请退款(腾讯会员怎么申请退款安卓手机)

    腾讯会员怎么申请退款(腾讯会员怎么申请退款安卓手机)

  • vceal00是什么机型(vce-aloo是什么手机型号)

    vceal00是什么机型(vce-aloo是什么手机型号)

  • 华为nova5和p30哪个性价比高(华为p30和nova5i)

    华为nova5和p30哪个性价比高(华为p30和nova5i)

  • iphone7p电池容量多大(iphone7p电池容量70要换吗)

    iphone7p电池容量多大(iphone7p电池容量70要换吗)

  • 内存分配理解(内存分配理解是什么)

    内存分配理解(内存分配理解是什么)

  • React 18 特性(react 16新特性)

    React 18 特性(react 16新特性)

  • 增值税发票税控开票软件
  • 变更税务所怎么操作
  • 可税前扣除的费用有哪些
  • 市政绿化工程的施工方案
  • 研发产品成功入库账务处理
  • 营业收入大于资产总计和主营业务收入之和什么原因
  • 金蝶怎么反结账上月的凭证
  • 发票代码有误什么意思
  • 小规模纳税人涉税风险
  • 减免税控盘增值税纳税申报
  • 普通发票申请表怎么填写
  • 外国专家工资个税
  • 增值税普票没有税率怎么回事
  • 有限责任公司减资的法律规定
  • 借款合同法律规定的表述
  • 理财产品收益交税
  • 分公司帮总公司付款怎么做分录
  • 人工服务费发票
  • 物业会计科目设置
  • 企业可以用当月的进项票抵扣上月的销项吗?
  • win10回退到以前版本失败
  • 买手机5000预算
  • 腾讯手游助手如何隐藏鼠标
  • 在php中,字符串有哪些表示形式
  • 怎么扣除税费
  • 应付税款法账务处理
  • 微软发布windows
  • 社保退休金计算方法
  • 免抵退税务处理
  • 整体租赁经营模式是什么
  • php获取useragent
  • php require include
  • html visit
  • 固态硬盘最新接口
  • 美丽的大中华
  • 卡拉公路
  • 一键部署源码
  • 出售长期股权投资的交易费用
  • javascript百炼成仙免费
  • mysql8绿色版
  • mongo db数据库
  • phpcms二次开发教程
  • 第一次购买金税盘会计分录
  • 印花税可以年底报一次
  • 为什么结转材料成本差异
  • 需要做审计有哪些行业
  • 金蝶软件中怎么让以前年度损益调整在利润表中取不到数
  • 支付给职工以及为职工支付的现金增加说明什么
  • 研发人员工资计入什么科目
  • 短期借款如何记账
  • 预付账款属于资产项目吗
  • 现金收账凭证
  • 增值税专用发票使用规定 最新
  • 金税盘系统可以添加2个账号?
  • sql语句优化总结
  • windows下mysql 5.7版本中修改编码为utf-8的方法步骤
  • ubuntu系统启动过程
  • 昂达主板插线安装图解
  • win8旗舰版官方下载
  • win7装vmware
  • 高手养成计划 小说
  • starting windows
  • macos 网速慢
  • sharedprem.exe - sharedprem是什么进程 有什么作用
  • linux7.2 sudo权限配置
  • win7系统垃圾手动清理
  • windows boot.ini文件
  • python上传文件到网站
  • python 入门
  • 安卓下载手游
  • 每天一篇小练笔主题
  • javascript var
  • js super方法
  • jquery mobile grid
  • 河南省发票查询真伪
  • 国税发票真伪查询手机怎么查
  • 发票打印机设备设置
  • 杭州汽车摇号中签率多少
  • 社保扣费为什么忽高忽低
  • 医生兼职取酬违反什么纪律
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设