uniapp video播放视频 悬浮在屏幕无法滑动
创始人
2024-11-04 19:35:16
0

背景:

在uniapp中,需要使用标签进行播放动态src的视频。

1.在开发的时候,运行到浏览器,vedio标签正常;(使用HbuildX运行,运行 -->运行到浏览器)。

2.但是在打包成原生App,安装.apk后缀的应用程序,vedio播放视频就不正常。(使用HbuildX打包,发行 --> 原生App-云打包)。

问题截图:

问题描述:在App上,视频停在屏幕上,在页面中不会跟随页面滚动而滚动。

问题分析:

1.研究

2.给对应的video标签添加上对应的css样式,是否是样式问题;

3.查看uniapp框架。因为在谷歌浏览器播放视频都是正常的,到手机上不正常,查看uniapp框架相关。

4.搜索相关博客,解决问题。

一、video标签

官网:点击跳转官网

1.基本用法属性:

  • id: 给视频标签一个唯一的 ID。
  • class: 用于样式控制。
  • src: 视频的 URL,可以是本地路径或者网络地址。
  • controls: 显示默认的视频控件。
  • autoplay: 自动播放视频。
  • loop: 循环播放视频。
  • muted: 静音播放视频

 2.事件监听

  • @start: 监听视频播放事件。
  • @pause: 监听视频暂停事件。
  • @finish: 监听视频播放结束事件。

备注:浏览uniapp框架下的video标签,发现没有属性能够控制其保持在电子屏幕不动。、

进一步说明这个是手机端才有的Bug 

二、video标签的css样式

在某些情况下,视频可能会被固定在屏幕上,而不是随着页面滚动。这可能是由于视频元素的层级或样式问题。可以尝试以下方法:

确保视频的样式设置正确,使其能够随着页面滚动。

   

在某些设备上,硬件加速或渲染层可能导致视频渲染问题。可以尝试禁用硬件加速或调整渲染层设置: 

   

备注:

我使用了对应的css样式,但是问题没有解决。 

三、uniapp框架下的video标签

查看了uniapp框架下的video标签,但是没有对应的属性能够解决问题。

四、vedio原生组件层级高于前端组件

意思是: 

1.Video是属于原生组件的,层级是最高的,无法被其他内容所覆盖,当然也不会跟着div的overflow-y:scroll进行滑动,只会一直浮在表层,挡住其他元素。

2.部分组件如map、video、textarea、canvas通过原生控件实现,原生组件层级高于前端组件(类似flash层级高于div)。

为了能正常覆盖原生组件,设计了cover-view。


uni官网的官方文档:点击跳转官网

cover-view使用示例:

//cover-view标签得在

cover-view使用的问题:

uni-app 原生APP 模式下 video 层级过高,页面滚动后会覆盖自定义顶部 tabbar和自定义底部菜单,很多人都只是说 cover-view 覆盖,但是cover-view必须在video里面才是有效的,cover-view 在原生app里面无法嵌套内容 。

vue页面层级覆盖解决方案: 点击跳转官网

三种方式对比: 

1.cover-view

更适合在视频上边添加某些组件,比如播放按钮或者什么功能。

cover-view或者cover-image,放在video标签内使用,子绝父相

2.plus.nativeObj.view

这个是安卓的原生写法,看了很多资料,发现是能解决相当多种类的问题,但是毕竟原生语法会难一些,在时间不够的情况下很难去学好怎么使用原生语言满足当前的需求,但如果时间充足且有条件的基础下可以采用这个方法 。

plus.nativeObj.View()  绘制原生画布,有点击事件。不属于dom,可以覆盖webview和各种原生控件

plus.nativeObj.view官方文档。因为偏原生组件,较复杂,可自行选择学习

Html5产业联盟。关于video标签的相关文档

3.subNVue

subNVue是原生渲染的nvue子窗体,把一个nvue页面以半屏的方式覆盖在vue页面上

subnvue 创建原生子窗体,放在当前页面下,放好位置即可。

首先创建nvue文件。最好放入同级。

在 pages.json 中,新增了 subNVues 节点,配置 subNVue 子窗体的相关属性。

在 pages.json 中增加完配置,也写好了 subNVue 子窗体,接下来就是在 vue/nvue 页面中使用了。

uni-app subNVue 原生子窗体开发指南

参考博客:参考博客 

五、video标签一个解决办法 

最后在网上参考了其他人的一份解决方案,刚好解决此问题。

封装一个组件,利用iframe实现:

//MyVideo组件 //自行封装一个组件,利用iframe实现    

使用方式:

在其他页面调用注册此封装的组件,并传递视频资源src 

//其它页面调用 

 写在最后,我们这里只是简单的在App端播放视频,且动态赋值src。如果还有其它复杂的布局内部嵌套video标签也是不成功的,例如:

相关内容

热门资讯

五分钟关于!如何下载wepok... 五分钟关于!如何下载wepoker安装包(透视)好像是真的挂,必赢教程(有挂透视)-哔哩哔哩1、任何...
开挂透视!WePoKer辅助挂... >>您好:WePoKer辅助挂怎么下载软件加扣扣群确实是有挂的,很多玩家在这款游戏中打牌都会发现很多...
透视实锤!wepoker俱乐部... 透视实锤!wepoker俱乐部辅助,wepoker辅助辅助,积累教程(有挂秘诀)-哔哩哔哩在进入we...
透视代打!wepoker免费透... 透视代打!wepoker免费透视(透视)真是有挂,普及教程(有挂测试)-哔哩哔哩1、进入到wepok...
第1分钟透视!竞技联盟破解版最... 第1分钟透视!竞技联盟破解版最新版(透视)竟然是有挂,教你教程(证实有挂)-哔哩哔哩1、起透看视 竞...
脚本辅助!wepoker发牌的... wepoker系统发牌规律是一款可以让一直输的玩家,快速成为一个“必胜”的ai辅助神器,有需要的用户...
透视黑科技!wepoker有没... 透视黑科技!wepoker有没有挂,hhpoker辅助软件是真的么,教材教程(有挂技术)-哔哩哔哩1...
透视最新!wepoker提高好... 透视最新!wepoker提高好牌率(透视)本来是有挂,专业教程(有挂存在)-哔哩哔哩在进入wepok...
透视规律!智星菠萝透视,wer... 透视规律!智星菠萝透视,werplan怎么辅助,方针教程(有挂助手)-哔哩哔哩1、任何werplan...
开挂透视!wepoker开挂辅... >>您好:wepoker有什么技巧软件加扣扣群确实是有挂的,很多玩家在这款游戏中打牌都会发现很多用户...