美文网首页
微信小程序多个视频组件同时播放

微信小程序多个视频组件同时播放

作者: AbnerZhang | 来源:发表于2020-12-19 09:44 被阅读0次

    首先说一下我的应用场景, 在小程序中会有多个页面存在视频组件的情况, 为了防止视频播放时多个视频组件同时播放的情况,现记录一下方案:

    一. 可以在需要视频播放的地方弄一个视频播放的按钮, 当视频播放的时候再初始化视频组件, 保证整个应用内只有一个视频组件(视频组件的位置需要计算), 整个方法只是理论下的情况;

    二. 在app.js中 设置两个对象, currentVideoId(播放视频组件的id)和videoContext(当前播放视频的对象, 通过wx.createVideoContext方法获得), 在页面的js中控制, 保证video组件绑定play方法:

     <video src="url" bindplay="play"></video>

    在play方法中实现即可:

    var id = e.currentTarget.id;

          if (id != null) {

            if (app.currentVideoId != id) {

              if (app.videoContext != null) {

                app.videoContext.stop();

                console.warn("暂停");

              }

              app.currentVideoId = id;

              app.videoContext = wx.createVideoContext(id);

            }

          }

    因为currentVideoId 和videoContext是唯一的对象, 方法中播放监听事件会暂停之前的播放, 然后再赋值, 等下次video播放监听进来的时候, 会进行判断

    三. 包含富文本组件的视频组件同时播放的情况

    依据上面的例子, 当自定义富文本组件中包含多个video组件时也用上面的方法会产生错误, 虽然log会显示将执行视频暂停或者停止播放, 但是没有效果, 查看视频api, 提示

    图1

    根据api显示, id为video组件的id, 还有一个"Object this", 但是依据上面的api使用, 直接用id确实可以获取video对象, 但是api解释中提示, "在自定义组件下,当前组件实例的this,以操作组件内 video组件", 在自定义组件中, 要加this, 所以总结: 在上面api使用中, 如果video在pages页面中, wx.createVideoContext参数只写id没有问题, 但是当video在自定义组件中, 要必须加this, 才能正确返回VideoContext对象;

    相关文章

      网友评论

          本文标题:微信小程序多个视频组件同时播放

          本文链接:https://www.haomeiwen.com/subject/rxdfnktx.html