消息正在输入
更新时间: 2024/03/14 17:08:35
网易云信即时通讯 NIM iOS SDK 中的NIMQChatMessageManager
协议,提供方法发送“频道消息正在输入事件”。接收方需先订阅发送消息的频道中的该事件,并实现相应代理方法,才能在消息输入方发送该事件后,接收到该事件。
前提条件
发送方和接收方都在频道内,即频道对两者都可见, 且发送方拥有发送频道消息权限(即NIMQChatPermissionType
枚举下的NIMQChatPermissionTypeSendMsg
)。
实现流程
流程概览
下图可能因为网络问题而显示异常。如显示异常,一般尝试刷新当前页面即可正常显示。
流程说明
本节仅对上图中标为橙色的流程进行说明,其他流程请参考相关文档。例如:
-
接收方实现
onRecvTypingEvent:
回调方法监听正在输入事件(NIMQChatMessageTypingEvent
)。 -
接收方调用
subscribeChannel:completion:
方法,调用时将入参NIMQChatSubscribeType
设为NIMQChatSubscribeTypeChannelTypingEvent
,实现对频道消息正在输入事件的订阅。如果断线重连,SDK 会自动再次订阅频道消息正在输入事件。但如果用户调用
logout
方法切断与圈组服务端的连或销毁 SDK 实例后重建实例,那么用户需要再度调subscribeChannel
方法重新订阅该事件。 -
发送方调用
sendMessageTypingEvent:completion:
方法发送频道消息正在输入事件。发送该事件后,SDK 触发用户A在
onRecvTypingEvent
方法中设置的回调,将NIMQChatMessageTypingEvent
投递至用户A。该方法有调用频率上限,目前为 3,000 ms 一次。
示例代码
//************************用户A设置正在输入事件监听回调************************/
[[NIMSDK sharedSDK].qchatMessageManager addDelegate:self];
- (void)onRecvSystemNotification:(NIMQChatReceiveSystemNotificationResult *)result
{
}
//************************用户A订阅某频道正在输入事件************************/
//服务器Id
long serviceId = 2114708;
//频道Id
long channelId = 233479;
NIMQChatSubscribeChannelParam *subscibeParam = [[NIMQChatSubscribeChannelParam alloc] init];
subscibeParam.subscribeType = NIMQChatSubscribeTypeChannelTypingEvent;
subscibeParam.operationType = NIMQChatSubscribeOperationTypeSubscribe;
NIMQChatChannelIdInfo *channelIdInfo = [[NIMQChatChannelIdInfo alloc] init];
channelIdInfo.serverId = serverId;
channelIdInfo.channelId = channelId;
subscibeParam.targets = @[channelIdInfo];
[[NIMSDK sharedSDK].qchatChannelManager subscribeChannel:subscibeParam completion:^(NSError * _Nullable error) {
//code
}];
//************************用户B发送正在输入事件************************/
NIMQChatMessageTypingEvent *event = [[NIMQChatMessageTypingEvent alloc] init];
event.channelId = channelId;
event.serverId = serverId;
[[NIMSDK sharedSDK].qchatMessageManager sendMessageTypingEvent:event completion:^(NSError * _Nullable error, NIMQChatMessageTypingEvent * _Nullable result) {
//code
}];