微信小程序直播live-player和live-pusher踩坑记录

2024-01-11 05:38

本文主要是介绍微信小程序直播live-player和live-pusher踩坑记录,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

实现一个直播小程序踩坑汇总记录

  • 踩坑点记录
    • 1、关于live-player
      • 1)live-player 全屏问题
      • 2)在全屏后的live-player上加视图,安卓机无法展示的问题
      • 3)解决live-player放在scroll-view上的问题
      • 4)live-player上下滑动漏出黑底问题
    • 2、关于live-pusher
      • 1)live-pusher上下滑动漏出黑底问题
      • 2)live-pusher 禁止使用摄像头问题
      • 3)live-pusher推流之后自动黑屏问题

最近做了一个微信小程序版的直播小程序,期间遇到了很多问题,在此汇总记录一下,希望可以帮助到你们

如何实现小程序中的live-player或live-pusher组件展现在scrollview上?

踩坑点记录

1、关于live-player

微信小程序对live-player的介绍如下:
官方文档

必须有相关类目的资质才可以使用<live-player><live-pusher>组件,这个问题就不多说了,这里可能遇到的问题是后续提交版本的时候有可能被拒,拒绝理由是不符合资质(其实已经成功提交过N个版本了),这里不用着急,去和审核人员交流一下就行,表明原因,这个时候一般会通过的。

在这个<live-player>组件上有不少坑,下面我会分别介绍一下这个组件上我遇到的问题

1)live-player 全屏问题

在官方文档这个页面,并没有介绍全屏的实现方式,只提了一下bindfullscreenchange这个全屏变化监听方法,当时自以为实现横屏观看的方式就是需要调整orientation参数,然后实现横竖屏观看……然后走了很长的弯路才发现原来实现全屏的方法是在API中:API官文地址

wxml live-player 组件写法:

<live-player src="{{item.url}}" mode="live" autoplay binderror="error" style="height:100%;width:100%;"bindfullscreenchange="fullscreenchangemethod" id="live-player-id" />

注意:重点是id="live-player-id" 这个属性,下一步要在js中根据这个id来获取到livePlayer的上下文,拿到这个上下文之后赋值给一个变量,然后就可以通过该变量来调用全屏和退出全屏方法,这是官方文档中就有的方法,不是很复杂。

(1)JS中创建 live-player 上下文 LivePlayerContext 对象。

let player = wx.createLivePlayerContext('live-player-id', this);

(2)通过(1)创建的LivePlayerContext来调用 全屏

player.requestFullScreen()

(3) 通过(1)创建的LivePlayerContext来调用 退出全屏

player.exitFullScreen()

因为orientation这个属性,在这个地方费了很大劲,因为需求不仅只有一个直播流(有多个流这个需求,是后面诸多问题的根本原因),有可能有好多直播流,当多个live-player都放在同一个页面,这个时候再去控制某个流去横竖屏,简直就是灾难,不过当使用了API之后,这个问题算是解决了。。。

2)在全屏后的live-player上加视图,安卓机无法展示的问题

直播全屏后,需要在界面上加些按钮,于是就想到了cover-view ,官方对此组件的介绍是:

a、覆盖在原生组件之上的文本视图。
b、可覆盖的原生组件包括 map、video、canvas、camera、live-player、live-pusher
c、只支持嵌套 cover-view、cover-image,可在 cover-view 中使用 button。组件属性的长度单位默认为px,2.4.0起支持传入单位(rpx/px)。

cover-view可以覆盖到live_player上,这不就妥妥的嘛,正好第一节里有可以监听全屏变化的事件,只要设置一个标志,全屏时展示,非全屏时隐藏,正好可以实现,于是:

wxml 代码:

<live-player src="{{item.url}}" mode="live" autoplay binderror="error" style="height:100%;width:100%;" bindfullscreenchange="fullscreenchange" id="live-player-id" /><cover-view wx:if='{{showToolBtn}}' style="position:absolute;width:80rpx;height:80rpx;" bindtap="cancleFullScreen"><cover-image src="/resource/fullScreen.png"></cover-image>
</cover-view>

showToolBtn 变量是监听到全屏的时候设置为true,退出全屏置为false

iOS手机运行: 功能、界面都非常完美
安卓手机运行:无法展示,cover-view 上的所有东西都出不来

错误原因:没有采用末尾标签</live-player>进行嵌套

正确代码:

<live-player src="{{item.url}}" mode="live" autoplay binderror="error" style="height:100%;width:100%;" bindfullscreenchange="fullscreenchange" id="live-player-id"><cover-view wx:if='{{showToolBtn}}' style="position:absolute;width:80rpx;height:80rpx;" bindtap="cancleFullScreen"><cover-image src="/resource/fullScreen.png"></cover-image></cover-view>
</live-player>

解决思路来源:来源

此时运行,就能适配安卓手机了,perfect…

3)解决live-player放在scroll-view上的问题

前面提到过,因为需求是可能会有多个直播流,而且是未知个数,所以就需要用可以滑动的方式去摆放N多个live-player,此时,自然而然的就想到了scroll-view,用scroll-view去放,不就可以滑动了嘛~
但是:看官文介绍
在这里插入图片描述
尴尬…如果我没记错的话,这里应该写着<live-player><live-pusher>同样不支持嵌套,结果我写这篇文章的时候再去看就更新了 ???……
但是当时我看的是scroll-view 不支持嵌套,我的做法是先放到view上,然后scroll-view再嵌套view,这样就能加载出来,并且可以滑动了

4)live-player上下滑动漏出黑底问题

在这个地方我遇到的问题是在scroll-view上渲染live-player,某些情况下(一般是推流设备进行过横竖屏转换之后)live-player可以上下滑动,有视频画面的地方滑上去之后露出黑色的一部分,初始我以为是scroll-view上放置live-player的原因,后来查资料发现不放在scroll-view上也会出现这个问题。
网上百度资料没有找到相关解决办法,官方论坛有一篇文章,但是官方没有给出答复

后面我的解决办法是禁止<live-player>滑动手势,一般需求下,应该是没问题的,但是我的需求是有多个<live-player>的时候可以滑动,加上这个属性之后,就没法左右滑动了,所以这个办法在我的需求中不太实用,现在这个问题还在寻找解决办法中

记:有文章说,可以在live-player上面覆盖一层透明的cover-view,不让用户扒拉就行了,不失为一种办法,但个人感觉不太好,所以暂时不采纳,有想看的老铁可以看这里:博文

代码示例:

//加上catchtouchmove就相当于阻止了滑动手势,但是点击手势是不受影响的
<live-player catchtouchmove style="width:70px;height:100px;" />

2、关于live-pusher

1)live-pusher上下滑动漏出黑底问题

同第4条的<live-player>可滑动问题,一般情况下,一台设备只能同时有一个<live-pusher>,所以他不存在左右滑动的需求,可以加上此属性,禁止滑动

<live-pusher catchtouchmove style="width:70px;height:100px;" />

2)live-pusher 禁止使用摄像头问题

有些时候推流的时候不需要推画面,只需要推声音,这个时候可以直接设置live-pusher中的enable-camera属性,千万不要设置隐藏live-pusher,隐藏之后会造成推流无效问题,因为推流的组件都让你干掉了,它还怎么推……😂

如果无效,请仔细检查代码:
enable :bool类型

<live-pusher enable-camera="{{enable}}" />

3)live-pusher推流之后自动黑屏问题

这个问题我没遇到过,但是搜资料的时候发现好多人出现了这个问题,而且没有正儿八经的解决答案,只遇到了一个说已经解决了,但没贴出解决办法,本人正积极联系当事人,争取获得解决方案,后续会更新文章

这篇关于微信小程序直播live-player和live-pusher踩坑记录的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/593328

相关文章

java中pdf模版填充表单踩坑实战记录(itextPdf、openPdf、pdfbox)

《java中pdf模版填充表单踩坑实战记录(itextPdf、openPdf、pdfbox)》:本文主要介绍java中pdf模版填充表单踩坑的相关资料,OpenPDF、iText、PDFBox是三... 目录准备Pdf模版方法1:itextpdf7填充表单(1)加入依赖(2)代码(3)遇到的问题方法2:pd

Zabbix在MySQL性能监控方面的运用及最佳实践记录

《Zabbix在MySQL性能监控方面的运用及最佳实践记录》Zabbix通过自定义脚本和内置模板监控MySQL核心指标(连接、查询、资源、复制),支持自动发现多实例及告警通知,结合可视化仪表盘,可有效... 目录一、核心监控指标及配置1. 关键监控指标示例2. 配置方法二、自动发现与多实例管理1. 实践步骤

Spring Boot 结合 WxJava 实现文章上传微信公众号草稿箱与群发

《SpringBoot结合WxJava实现文章上传微信公众号草稿箱与群发》本文将详细介绍如何使用SpringBoot框架结合WxJava开发工具包,实现文章上传到微信公众号草稿箱以及群发功能,... 目录一、项目环境准备1.1 开发环境1.2 微信公众号准备二、Spring Boot 项目搭建2.1 创建

golang程序打包成脚本部署到Linux系统方式

《golang程序打包成脚本部署到Linux系统方式》Golang程序通过本地编译(设置GOOS为linux生成无后缀二进制文件),上传至Linux服务器后赋权执行,使用nohup命令实现后台运行,完... 目录本地编译golang程序上传Golang二进制文件到linux服务器总结本地编译Golang程序

使用Docker构建Python Flask程序的详细教程

《使用Docker构建PythonFlask程序的详细教程》在当今的软件开发领域,容器化技术正变得越来越流行,而Docker无疑是其中的佼佼者,本文我们就来聊聊如何使用Docker构建一个简单的Py... 目录引言一、准备工作二、创建 Flask 应用程序三、创建 dockerfile四、构建 Docker

在Spring Boot中集成RabbitMQ的实战记录

《在SpringBoot中集成RabbitMQ的实战记录》本文介绍SpringBoot集成RabbitMQ的步骤,涵盖配置连接、消息发送与接收,并对比两种定义Exchange与队列的方式:手动声明(... 目录前言准备工作1. 安装 RabbitMQ2. 消息发送者(Producer)配置1. 创建 Spr

java向微信服务号发送消息的完整步骤实例

《java向微信服务号发送消息的完整步骤实例》:本文主要介绍java向微信服务号发送消息的相关资料,包括申请测试号获取appID/appsecret、关注公众号获取openID、配置消息模板及代码... 目录步骤1. 申请测试系统2. 公众号账号信息3. 关注测试号二维码4. 消息模板接口5. Java测试

k8s上运行的mysql、mariadb数据库的备份记录(支持x86和arm两种架构)

《k8s上运行的mysql、mariadb数据库的备份记录(支持x86和arm两种架构)》本文记录在K8s上运行的MySQL/MariaDB备份方案,通过工具容器执行mysqldump,结合定时任务实... 目录前言一、获取需要备份的数据库的信息二、备份步骤1.准备工作(X86)1.准备工作(arm)2.手

SpringBoot3应用中集成和使用Spring Retry的实践记录

《SpringBoot3应用中集成和使用SpringRetry的实践记录》SpringRetry为SpringBoot3提供重试机制,支持注解和编程式两种方式,可配置重试策略与监听器,适用于临时性故... 目录1. 简介2. 环境准备3. 使用方式3.1 注解方式 基础使用自定义重试策略失败恢复机制注意事项

Python UV安装、升级、卸载详细步骤记录

《PythonUV安装、升级、卸载详细步骤记录》:本文主要介绍PythonUV安装、升级、卸载的详细步骤,uv是Astral推出的下一代Python包与项目管理器,主打单一可执行文件、极致性能... 目录安装检查升级设置自动补全卸载UV 命令总结 官方文档详见:https://docs.astral.sh/