记录一下腾讯云即时通信IM(无UI集成)、TRTC做文字、语音、图片、实时音视频聊天遇到的问题

本文主要是介绍记录一下腾讯云即时通信IM(无UI集成)、TRTC做文字、语音、图片、实时音视频聊天遇到的问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 简单记录一下通讯IM和TRTC的一些坑:(有其他坑再补充......)
    • isReady() 一直返回false
    • SDK_READY监听有时候会不触发
    • getConversationList拉取会话,消息数据里的cloudCustomData经常会丢
    • 移动端发图片消息总是卡顿
    • im里的信令消息,不会触发MESSAGE_RECEIVED监听
    • vue3项目创建trtc对象 TRTC.create()
    • trtc.startRemoteVideo拉取对方画面,多了一个播放/暂停按钮,或者显示了一个弹窗
    • TRTCCalling官方不维护了,vue2的项目估计都是用的TRTCCalling
    • 移动端设备没法获取扬声器
    • 没有来电提示音的api

吐槽一下,有些文档太垃圾了,写的不清不楚的,也没有示例,要不就是各种引导你去买TUICallKit,
然后遇到问题,在技术群反馈效果一般,提工单效果一般,腾讯工单的回复总是答非所问,就是找售后技术支持有点用,那遇到问题好像是腾讯的技术帮忙看的,其他的感觉都像是不懂技术的客服,答非所问。


用vue3做的h5移动端网页无UI集成开发的,大概的聊天页面功能是这样的,文字、图片、录音、实时音视频
在这里插入图片描述

简单记录一下通讯IM和TRTC的一些坑:(有其他坑再补充…)

isReady() 一直返回false

它是检测SDK 是否 ready,因为im调用login必须是已经ready的状态

ready主要就是用来创建im实例,然后注册日志、插件、im事件监听
在这里插入图片描述
login呢,是登录IM的,但是文档说ready必须在登录之前,所以我想在执行完ready之后用isReady去获取一下状态,然后再去调login

SDK_READY监听有时候会不触发

接上一个isReady不好使的问题,我想去存储一个ready状态变量,所以就在SDK_READY监听里去改变状态,结果它有时候就不执行。这个莫得办法,就没管,ready和login都是异步执行的,目前生产环境也没啥问题

getConversationList拉取会话,消息数据里的cloudCustomData经常会丢

做会话列表getConversationList拉会话,每个会话里它会返回你最新的一条消息,然后我发消息设置的自定义参数cloudCustomData总是丢失。这个莫得办法

移动端发图片消息总是卡顿

用手机拍照发图片消息,调完sendMessage发送总是很慢,因为现在的手机拍照像素都高,随便拍一个照片都是2、3M,我一开始以为是createImageMessage创建图片消息的时候没压缩导致的,后来问腾讯客服说是他们的api默认会压缩图片。这个莫得办法,借鉴过TUICallKit demo源码,它是在消息状态是unSend的时候,用progress做了个进度条,,问题是我的消息列表拿不到unSend这个状态,没思路,再想想

im里的信令消息,不会触发MESSAGE_RECEIVED监听

MESSAGE_RECEIVED是监听消息的,比如你发消息或者别人给你发消息就会触发这个监听。
但是发信令通信(打语音/视频通话)之后,im的messageList里会自动添加信令消息,但是不会触发MESSAGE_RECEIVED监听,也不会自动显示到messageList,需要刷新页面去重新getMessageList拉消息才会显示出来。 这个我是给list组件设置的key,然后去改变key值,实现页面局部刷新,list组件里会getMessageList,重新拉列表

而且信令消息也没文档,你也不知道它返回的是个啥?actionType、businessID: 1,鬼知道你这字段代表啥意思啊
在这里插入图片描述


后来问了售后技术支持才知道,businessID: 1就表示信令消息,actionType是通话的状态,还少一个actionType = 5 超时无应答 【真无语了,还是我测试的时候发现有个5】

在这里插入图片描述


vue3项目创建trtc对象 TRTC.create()

创建一个 TRTC 对象,用于实现进房、预览、推流、拉流等功能。

在vue3项目里得使用const trtc = markRaw(TRTC.create()),其他的定义方式可能会有问题
我一开始是直接 const trtc = TRTC.create()。 后来就有些监听事件不触发,莫名其妙的

trtc.startRemoteVideo拉取对方画面,多了一个播放/暂停按钮,或者显示了一个弹窗

在这里插入图片描述

web开发的话会有这个问题,其他语言开发不知道,使用trtc.startRemoteVideo()去拉取对方画面,有可能会触发浏览器自动播放限制策略

简单来说就是startRemoteVideo会往你的页面里插入一个video然后去显示对端视频画面,自动播放video,然后有些浏览器可能不让你去自动播放video,需要用户主动去点击触发。这个问过腾讯技术了,说是就这样,这已经是他们处理过的了。或者可以去自定义那个弹窗,但是那个播放/暂停按钮去不掉。这个莫得办法

TRTCCalling官方不维护了,vue2的项目估计都是用的TRTCCalling

我的项目对端就是vue2+TRTCCalling,现在就是各种bug不断,脑壳疼…
然后vue3还没法用TRTCCalling,因为v3版本把信令内置成一个模块了,而v2版本信令是一个单独的包,没法兼容。
在这里插入图片描述

在这里插入图片描述

移动端设备没法获取扬声器

在这里插入图片描述

没有来电提示音的api

这个我的方案是拨打音视频或者有来电的时候,页面定义一个audio去播放mp3,接听/挂断/超时去停止播放等等。

这篇关于记录一下腾讯云即时通信IM(无UI集成)、TRTC做文字、语音、图片、实时音视频聊天遇到的问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/1123055

相关文章

SpringBoot集成P6Spy的实现示例

《SpringBoot集成P6Spy的实现示例》本文主要介绍了SpringBoot集成P6Spy的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录本节目标P6Spy简介抛出问题集成P6Spy1. SpringBoot三板斧之加入依赖2. 修改

Linux部署中的文件大小写问题的解决方案

《Linux部署中的文件大小写问题的解决方案》在本地开发环境(Windows/macOS)一切正常,但部署到Linux服务器后出现模块加载错误,核心原因是Linux文件系统严格区分大小写,所以本文给大... 目录问题背景解决方案配置要求问题背景在本地开发环境(Windows/MACOS)一切正常,但部署到

MySQL磁盘空间不足问题解决

《MySQL磁盘空间不足问题解决》本文介绍查看空间使用情况的方式,以及各种空间问题的原因和解决方案,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧... 目录查看空间使用情况Binlog日志文件占用过多表上的索引太多导致空间不足大字段导致空间不足表空间碎片太多导致空间不足临时表空间

Mybatis-Plus 3.5.12 分页拦截器消失的问题及快速解决方法

《Mybatis-Plus3.5.12分页拦截器消失的问题及快速解决方法》作为Java开发者,我们都爱用Mybatis-Plus简化CRUD操作,尤其是它的分页功能,几行代码就能搞定复杂的分页查询... 目录一、问题场景:分页拦截器突然 “失踪”二、问题根源:依赖拆分惹的祸三、解决办法:添加扩展依赖四、分页

Java中InputStream重复使用问题的几种解决方案

《Java中InputStream重复使用问题的几种解决方案》在Java开发中,InputStream是用于读取字节流的类,在许多场景下,我们可能需要重复读取InputStream中的数据,这篇文章主... 目录前言1. 使用mark()和reset()方法(适用于支持标记的流)2. 将流内容缓存到字节数组

解决若依微服务框架启动报错的问题

《解决若依微服务框架启动报错的问题》Invalidboundstatement错误通常由MyBatis映射文件未正确加载或Nacos配置未读取导致,需检查XML的namespace与方法ID是否匹配,... 目录ruoyi-system模块报错报错详情nacos文件目录总结ruoyi-systnGLNYpe

springboot项目中集成shiro+jwt完整实例代码

《springboot项目中集成shiro+jwt完整实例代码》本文详细介绍如何在项目中集成Shiro和JWT,实现用户登录校验、token携带及接口权限管理,涉及自定义Realm、ModularRe... 目录简介目的需要的jar集成过程1.配置shiro2.创建自定义Realm2.1 LoginReal

SpringBoot集成Shiro+JWT(Hutool)完整代码示例

《SpringBoot集成Shiro+JWT(Hutool)完整代码示例》ApacheShiro是一个强大且易用的Java安全框架,提供了认证、授权、加密和会话管理功能,在现代应用开发中,Shiro因... 目录一、背景介绍1.1 为什么使用Shiro?1.2 为什么需要双Token?二、技术栈组成三、环境

Java 与 LibreOffice 集成开发指南(环境搭建及代码示例)

《Java与LibreOffice集成开发指南(环境搭建及代码示例)》本文介绍Java与LibreOffice的集成方法,涵盖环境配置、API调用、文档转换、UNO桥接及REST接口等技术,提供... 目录1. 引言2. 环境搭建2.1 安装 LibreOffice2.2 配置 Java 开发环境2.3 配

基于Spring Boot 的小区人脸识别与出入记录管理系统功能

《基于SpringBoot的小区人脸识别与出入记录管理系统功能》文章介绍基于SpringBoot框架与百度AI人脸识别API的小区出入管理系统,实现自动识别、记录及查询功能,涵盖技术选型、数据模型... 目录系统功能概述技术栈选择核心依赖配置数据模型设计出入记录实体类出入记录查询表单出入记录 VO 类(用于