使用Aliplayer在微信中播放视频的正确姿势

简介: 沐钦分享下利用aliplayer在微信中播放视频的操作方式和效果

本文作者:沐钦

微信播放最大坑

h5页面分享到微信上播放视频,最大的坑就是在Android手机上,X5浏览器会劫持Video标签用播放器弹出全屏播放,处于最上层,覆盖DOM元素,而且播放完毕时,会出现广告视频,比如:

image

同层播放

X5浏览器为了解决覆盖DOM元素的问题,提出了一个同层播放的概念,通俗一点讲就是视频播放还是要弹出全屏的,但是视频可以不覆盖DOM元素,可以和视频在同一层,虽然这方案有点别扭,但总算解决了覆盖DOM元素的问题,特别是对于H5直播来说非常重要。

同层播放的实现

虽然X5提供了一些属性可以用于同层播放的设置,但是还是有一些细节需要处理:

  • X5弹出全屏播放时,需要订阅resize和全屏事件,对于video以及容器大小的调整
  • 点击微信顶部的返回按钮时,退出全屏播放时,需要订阅退出全屏事件,根据业务实际情况处理,比如有的场景需要关闭当前页面,给用户一种退出当前页面的体验。
  • 设置视频的显示位置, 比如全屏直播视频要全屏显示,普通的播放视频在左上角显示,点击全屏按钮时,又要居中显示。

很多细节的东西需要处理, Aliplayer播放器在最新发布的版本中支持了X5浏览器的h5的同层播放,并且很多细节的东西帮助实现了,下面使用Aliplayer实现了两个例子:

点播视频H5Demo
全屏直播H5LiveDemo

点播视频

视频点播的一般的布局是上半部分为视频播放区域,下半部分为播放列表和评论区域,在Android 微信上的播放效果如下:
image

代码可以参考点播视频H5Demo

创建播放器

通过 x5_video_position和 x5_type属性指定视频的显示位置和启用H5同层播放

var player = new Aliplayer({
            id: 'J_prismPlayer',
            autoplay: true,
            isLive:false,
            playsinline:true,
            controlBarVisibility:'always',
            source:"",
            useH5Prism:true,
            x5_video_position:'top', //指定视频在上部显示
            x5_type:'h5' //声明启用同层H5播放器,支持的值:h5
        });
AI 代码解读

弹出全屏播放时的处理

这里主要分两种情况:

  • 在点击播放按钮开始播放时,微信劫持视频弹出全屏播放,这时候Aliplayer也会触发全屏事件,在这里调用取消全屏方法。注:播放器以后会实现这个逻辑
  • 用户点击Controlbar上的全屏按钮时,这个时候也会触发全屏事件,在这里可以调整视频为居中显示。

上面两种情况的处理有点不一样的

this._firstFullscreen = true;
        let that = this;
        this.player.on('requestFullScreen',(e)=>{
            if(that._firstFullscreen)
            {
                that.player.cancelFullScreen();
                that._firstFullscreen = false;
            }
            else
            {
                let video=$(that.player.el()).find('video');
                video.addClass('center');
            }
        });
AI 代码解读

视频居中的样式

video.center
{
    object-position:50% 50% !important;
}
AI 代码解读

退出全屏时恢复视频顶部播放

退出全屏的时候会出发事件,在事件里移除居中的样式

this.player.on('cancelFullScreen',(e)=>{
            let video=$(that.player.el()).find('video');
            video.removeClass('center');
        })
AI 代码解读

直播全屏播放

直播场景下会把视频充满整个屏幕,在上面显示评论、点赞、主播和观众信息等,比如:
image

代码可以参考全屏直播H5LiveDemo

创建播放器

通过x5_fullscreen和 x5_type属性指定视频全屏播放和启用H5同层播放,另外需要去掉Controlbar,要通过skinLayout自定义UI。

var player = new Aliplayer({
            id: 'J_prismPlayer',
            autoplay: true,
            isLive:true,
            playsinline:true,
            controlBarVisibility:'always',
            source:"",
            useH5Prism:true,
            x5_fullscreen:true, //全屏播放
            x5_type:'h5', //声明启用同层H5播放器,支持的值:h5
            skinLayout:[
             {name:"bigPlayButton", align:"blabs", x:"70", y:"150"},
             {name: "H5Loading", align: "cc"}
             ]
        });
AI 代码解读

弹出全屏播放时的处理

在点击播放按钮开始播放时,微信劫持视频弹出全屏播放,这时候Aliplayer也会触发全屏事件,在这里调用取消全屏方法,并且调整评论、点赞等的布局。

var that = this;
       this.player.on('requestFullScreen',(e)=>{
           that.adjustLayout(true);
           that.player.cancelFullScreen();
       });
AI 代码解读

改变视频显示方式

全屏播放视频默认是平铺的,如果想不平铺可以设置object-fit的样式为contain或其它

video{
    object-fit: contain !important;
}
AI 代码解读

微信返回时关闭页面

微信在原来的页面上面打开另一个页面全屏播放视频, 如果正常流程返回时,是返回到程序原来的页面,我希望是返回时直接关闭页面。

this.player.tag.addEventListener("x5videoexitfullscreen",()=>{
      if(WeixinJSBridge)
           WeixinJSBridge.call('closeWindow');
 });
AI 代码解读

视频显示模式和位置

如果"x_video_position"的两个值top和center不能满足要求,可以通过自定义object-fit和object-position属性,进行更灵活的设置视频的显示模式和位置。

object-fit属性

该object-fit CSS属性指定替换元素的内容应该如何适应到其使用的高度和宽度确定的框

可选的值:

  • object-fit: fill;
  • object-fit: contain;
  • object-fit: cover;
  • object-fit: none;
  • object-fit: scale-down;

每个值的效果:
image

object-position属性

object-position CSS属性控制替换内容位置,和background-position属性很类似比如:

css代码

img{
    width: 300px;
    height: 250px;
    border: 1px solid black;
   background-color: silver;
   margin-right: 1em;object-fit: none;
}

#object-position-1 {
   object-position: 10px;
}

#object-position-2 {
   object-position:100%10%;
}
AI 代码解读

效果
image

相关文章
Android - 安卓设备在微信中播放视频结束后出现广告的解决办法
Android - 安卓设备在微信中播放视频结束后出现广告的解决办法
251 0
微信公众号接口:解锁公众号开发的无限可能
微信公众号接口是微信官方提供的API,支持开发者通过编程与公众号交互,实现自动回复、消息管理、用户管理和数据分析等功能。本文深入探讨接口的定义、类型、优势及应用场景,如智能客服、内容分发、电商闭环等,并介绍开发流程和工具,帮助运营者提升用户体验和效率。未来,随着微信生态的发展,公众号接口将带来更多机遇,如小程序融合、AI应用等。
weixin163基于微信小程序的校园二手交易平台系统设计与开发ssm(文档+源码)_kaic
本文介绍了一款基于微信小程序的校园二手物品交易平台的开发与实现。该平台采用Java语言开发服务端,使用MySQL数据库进行数据存储,前端以微信小程序为载体,支持管理员和学生两种角色操作。管理员可管理用户、商品分类及信息、交易记录等,而学生则能注册登录、发布购买商品、参与交流论坛等。系统设计注重交互性和安全性,通过SSM框架优化开发流程,确保高效稳定运行,满足用户便捷交易的需求,推动校园资源共享与循环利用。
weixin168“返家乡”高校暑期社会实践微信小程序设计与开发ssm(文档+源码)_kaic
本文探讨高校暑期社会实践微信小程序的开发与应用,旨在通过信息化手段提升活动管理效率。借助微信小程序技术、SSM框架及MySQL数据库,实现信息共享、流程规范和操作便捷。系统涵盖需求分析、可行性研究、设计实现等环节,确保技术可行、操作简便且经济合理。最终,该小程序可优化活动发布、学生信息管理和心得交流等功能,降低管理成本并提高工作效率。
技术小白如何利用DeepSeek半小时开发微信小程序?
通过通义灵码的“AI程序员”功能,即使没有编程基础也能轻松创建小程序或网页。借助DeepSeek V3和R1满血版模型,用户只需用自然语言描述需求,就能自动生成代码并优化程序。例如,一个文科生仅通过描述需求就成功开发了一款记录日常活动的微信小程序。此外,通义灵码还提供智能问答模式,帮助用户解决开发中的各种问题,极大简化了开发流程,让普通人的开发体验更加顺畅。
834 11
技术小白如何利用DeepSeek半小时开发微信小程序?
微信小程序开发全流程:从注册到上线的完整指南
这篇文章详细记录了微信小程序的完整开发到最终上线的每一个步骤。适合对小程序开发感兴趣的个人开发者或希望了解完整流程的学习者,涵盖了云开发、事件绑定、生命周期管理、组件使用等关键内容。
191 11
AstrBot:轻松将大模型接入QQ、微信等消息平台,打造多功能AI聊天机器人的开发框架,附详细教程
AstrBot 是一个开源的多平台聊天机器人及开发框架,支持多种大语言模型和消息平台,具备多轮对话、语音转文字等功能。
3137 15
AstrBot:轻松将大模型接入QQ、微信等消息平台,打造多功能AI聊天机器人的开发框架,附详细教程
uni-app开发微信小程序的报错[渲染层错误]排查及解决
uni-app开发微信小程序的报错[渲染层错误]排查及解决
1380 7
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
1096 1
微信小程序的开发完整流程是什么?
微信小程序的开发完整流程是什么?
399 7

热门文章

最新文章