在HarmonyOS(鸿蒙)中H5页面中的视频不会自动播放

H5页面中的视频不会自动播放

问题现象

ArkWeb(方舟Web)提供了Web组件,用于在应用程序中显示Web页面内容。当应用加载完有视频内容的H5页面时,不会自动播放视频。

背景知识

  • ArkWeb提供了Web组件,Web组件为开发者提供了丰富的控制Web页面能力。
  • onPageBegin网页开始加载时触发该回调,且只在主frame触发,iframe或者frameset的内容加载时不会触发此回调。
  • runJavaScript异步执行JavaScript脚本,并通过回调方式返回脚本执行的结果。runJavaScript需要在loadUrl完成后,比如onPageEnd中调用。
  • mediaPlayGestureAccess方法实现自动播放音视频,默认情况下,设置有声视频播放是否需要用户手动点击,静音视频播放不受该接口管控。如果需要让音视频自动播放,需要将mediaPlayGestureAccess中的参数设置为false。

问题定位

排查代码,在Web组件的onPageBegin方法中未添加对暂停和播放状态的判断,也没有调用mediaPlayGestureAccess方法,并未将参数设置为false。

ArkTS 复制代码
...
Web.create({
    controller: this.webviewController,
    src:this.url
});
Web.darkMode(WebDarkMode.Off);
Web.domStoreageAccess(true);
Web.zoomAccess(true);
Web.javaScriptAccess(true);
Web.mixedMode(MixedMode.All);
Web.cacheMode(cacheMode.None);
Web.onPageBegin(($a3)=>{
    if ($a3) {
        this.loading = false;
        this.onPageBegin($a3.url);
    }
});
...

分析结论

使用Web组件时,在onPageBegin方法中未对视频进行暂停和播放的判断,并将mediaPlayGestureAccess设置为false,导致Web页面中的视频无法自动播放。

修改建议

H5页视频不能自动播放,可以在onPageBegin方法中对视频进行暂停和播放的判断,把mediaPlayGestureAccess设置false就可以自动播放视频了。

ArkTS 复制代码
@State boo: boolean = false;


 Web({
      src: 'https://hqtime.huanqiu.com/article/4EPT4ScnmUR?app=1&ver=1&recommend_image=1&fontSize=normal&isFlat=false&recommend=1',
      controller: this.controller
    })
      .onPageBegin(() => {      
        if (this.boo) { 
        // 为false时,走else自动播放
          this.controller.runJavaScript("window.onload = function() {document.querySelector('video').addEventListener('play', function(event) {event.preventDefault();this.pause();});}")
        } else {
          this.controller.runJavaScript("window.onload = function() {document.querySelector('video').play()}")
        }  
      })
      // 默认不自动播放为true,自动播放为false
      .mediaPlayGestureAccess(this.boo)
      .layoutWeight(1)
      .mixedMode(MixedMode.All)
      .domStorageAccess(true);

背景: 由于在做项目的过程中发现web中的视频不会自动播放,就来查阅资料,发现了 mediaPlayGestureAccess (默认为true), 只用把该属性设置为 false, 就可以了

详情参考属性 mediaPlayGestureAccess

来源: H5页面中的视频不会自动播放


End

相关推荐
枫叶丹48 小时前
【HarmonyOS 6.0】状态栏扩展新特性:点击状态栏图标展开二级菜单的场景动效详解
开发语言·华为·harmonyos
想你依然心痛9 小时前
HarmonyOS 6(API 23)实战:基于悬浮导航、沉浸光感与Face AR & Body AR的“灵犀筑境“——PC端沉浸式AR建筑空间评审系统
华为·ar·harmonyos·悬浮导航·沉浸光感
xmdy58669 小时前
Flutter+开源鸿蒙全域智慧泊车调度管理平台 Day4 订单全流程闭环+支付核验+会员权益+个人中心开发
flutter·开源·harmonyos
前端不太难9 小时前
鸿蒙 App 多端 UI 不一致的原因
ui·状态模式·harmonyos
key_3_feng10 小时前
鸿蒙6.0电子手表高山攀登指标监测功能开发实战
华为·harmonyos
nashane10 小时前
HarmonyOS 6学习:超大分辨率图片压缩与长截图生成优化实践
学习·华为·harmonyos
shaodong112311 小时前
HarmonyOS NEXT 打印机开发实战:基于 Print Kit 全面解析
华为·harmonyos
三声三视11 小时前
Electron + 鸿蒙分布式投屏:PC 端一键推送画面到鸿蒙设备全实战
分布式·electron·harmonyos·鸿蒙·桌面
UnicornDev11 小时前
【Flutter x HarmonyOS 6】魔方计时APP——挑战页面的UI设计
flutter·ui·华为·harmonyos·鸿蒙
三声三视11 小时前
鸿蒙 ArkTS 后台任务全攻略:短时任务、长驻任务与延迟任务实战,告别应用被系统杀掉的困境
华为·harmonyos·鸿蒙