使用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
        });

弹出全屏播放时的处理

这里主要分两种情况:

  • 在点击播放按钮开始播放时,微信劫持视频弹出全屏播放,这时候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');
            }
        });

视频居中的样式

video.center
{
    object-position:50% 50% !important;
}

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

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

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

直播全屏播放

直播场景下会把视频充满整个屏幕,在上面显示评论、点赞、主播和观众信息等,比如:
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"}
             ]
        });

弹出全屏播放时的处理

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

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

改变视频显示方式

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

video{
    object-fit: contain !important;
}

微信返回时关闭页面

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

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

视频显示模式和位置

如果"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%;
}

效果
image

目录
相关文章
|
Android开发 iOS开发
Android - 安卓设备在微信中播放视频结束后出现广告的解决办法
Android - 安卓设备在微信中播放视频结束后出现广告的解决办法
383 0
|
3月前
|
消息中间件 人工智能 Java
抖音微信爆款小游戏大全:免费休闲/竞技/益智/PHP+Java全筏开源开发
本文基于2025年最新行业数据,深入解析抖音/微信爆款小游戏的开发逻辑,重点讲解PHP+Java双引擎架构实战,涵盖技术选型、架构设计、性能优化与开源生态,提供完整开源工具链,助力开发者从理论到落地打造高留存、高并发的小游戏产品。
|
4月前
|
小程序 JavaScript API
uni-halo + 微信小程序开发实录:我的第一个作品诞生记
这篇文章介绍了使用uni-halo框架进行微信小程序开发的过程,包括选择该框架的原因、开发目标以及项目配置和部署的步骤。
190 0
uni-halo + 微信小程序开发实录:我的第一个作品诞生记
|
10月前
|
自然语言处理 搜索推荐 小程序
微信公众号接口:解锁公众号开发的无限可能
微信公众号接口是微信官方提供的API,支持开发者通过编程与公众号交互,实现自动回复、消息管理、用户管理和数据分析等功能。本文深入探讨接口的定义、类型、优势及应用场景,如智能客服、内容分发、电商闭环等,并介绍开发流程和工具,帮助运营者提升用户体验和效率。未来,随着微信生态的发展,公众号接口将带来更多机遇,如小程序融合、AI应用等。
|
7月前
|
小程序 前端开发 Android开发
小程序微信分享功能如何开发?开放平台已绑定仍不能使用的问题?-优雅草卓伊凡
小程序微信分享功能如何开发?开放平台已绑定仍不能使用的问题?-优雅草卓伊凡
1502 29
小程序微信分享功能如何开发?开放平台已绑定仍不能使用的问题?-优雅草卓伊凡
|
JSON 小程序 JavaScript
uni-app开发微信小程序的报错[渲染层错误]排查及解决
uni-app开发微信小程序的报错[渲染层错误]排查及解决
3125 7
|
6月前
|
监控 数据可视化 数据处理
微信养号脚本,全自动插件,AUTOJS开发版
这是一套自动化微信养号工具,包含主脚本`wechat_auto.js`与配置文件`config.json`。主脚本实现自动浏览朋友圈、随机阅读订阅号文章及搜索指定公众号三大功能,支持自定义滚动次数、阅读时长等参数。代码通过随机化操作间隔模拟真实用户行为,具备完善的错误处理和日志记录功能。配套UI模块提供可视化操作界面,可实时监控任务状态与运行日志,便于调整参数设置。控制器部分扩展了批量数据处理能力,如学生信息的增删改查操作,适用于多场景应用。下载地址:https://www.pan38.com/share.php?code=n6cPZ 提取码:8888(仅供学习参考)。
|
小程序 JavaScript 前端开发
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
2795 1
|
10月前
|
人工智能 开发框架 机器人
AstrBot:轻松将大模型接入QQ、微信等消息平台,打造多功能AI聊天机器人的开发框架,附详细教程
AstrBot 是一个开源的多平台聊天机器人及开发框架,支持多种大语言模型和消息平台,具备多轮对话、语音转文字等功能。
5632 38
AstrBot:轻松将大模型接入QQ、微信等消息平台,打造多功能AI聊天机器人的开发框架,附详细教程
|
9月前
|
人工智能 自然语言处理 小程序
技术小白如何利用DeepSeek半小时开发微信小程序?
通过通义灵码的“AI程序员”功能,即使没有编程基础也能轻松创建小程序或网页。借助DeepSeek V3和R1满血版模型,用户只需用自然语言描述需求,就能自动生成代码并优化程序。例如,一个文科生仅通过描述需求就成功开发了一款记录日常活动的微信小程序。此外,通义灵码还提供智能问答模式,帮助用户解决开发中的各种问题,极大简化了开发流程,让普通人的开发体验更加顺畅。
2737 11
技术小白如何利用DeepSeek半小时开发微信小程序?