tencent cloud

文档反馈

Android & iOS & Mac

最后更新时间:2023-01-29 16:06:34

    功能描述

    通过设置单聊和群聊的消息接收选项,可以实现类似消息免打扰的功能。
    IM SDK 支持三种类型的消息接收选项,消息接收选项在 V2TIMReceiveMessageOpt 中定义:

    消息接收选项 功能描述
    V2TIM_RECEIVE_MESSAGE 在线时正常接收消息,离线时接收离线推送通知
    V2TIM_NOT_RECEIVE_MESSAGE 在线和离线都不接收消息
    V2TIM_RECEIVE_NOT_NOTIFY_MESSAGE 在线时正常接收消息,离线时不接收离线推送通知
    说明:

    消息接收选项仅增强版 SDK 5.3.425 及以上版本支持。

    设置不同的 V2TIMReceiveMessageOpt 可以实现群消息免打扰:

    完全不接收消息
    消息接收选项设置为 V2TIM_NOT_RECEIVE_MESSAGE 后,单聊/群聊的任何消息都收不到,会话列表也不会更新。

    接收消息但不提醒,在会话列表界面显示小圆点(不显示未读数)

    1. 消息接收选项设置为 V2TIM_RECEIVE_NOT_NOTIFY_MESSAGE
    2. 当单聊/群聊收到新消息,会话列表需要更新时,通过会话 V2TIMConversation 中的 unreadCount (Android / iOS & Mac / Windows) 获取到消息未读数。
    3. 根据 V2TIMConversationrecvOpt (Android / iOS & Mac / Windows) 判断获取到的消息接收选项为 V2TIM_RECEIVE_NOT_NOTIFY_MESSAGE 时显示小红点而非消息未读数。
    说明:

    此方式需使用 unreadCount 功能,仅适用于好友工作群(Work)、陌生人社交群(Public)和社群(Community),直播群(AVChatRoom)、临时会议群(Meeting)暂不支持。群组类型详见 群组介绍

    设置单聊的消息接收选项

    您可以调用 setC2CReceiveMessageOpt(Android / iOS & Mac / Windows) 设置单聊的消息接收选项。
    您可通过参数 userIDList 设置一批用户,但一次最大允许设置 30 个用户。

    注意:

    该接口调用频率被限制为单个用户 1 秒内最多调用 5 次。

    示例代码如下:

    // 设置在线和离线都不接收消息
    List<String> userList = new ArrayList<>();
    userList.add("user1");
    userList.add("user2");
    V2TIMManager.getMessageManager().setC2CReceiveMessageOpt(userList, V2TIMMessage.V2TIM_NOT_RECEIVE_MESSAGE, new V2TIMCallback() {
       @Override
       public void onSuccess() {
           Log.i("imsdk", "success");
       }
        @Override
       public void onError(int code, String desc) {
           Log.i("imsdk", "failure, code:" + code + ", desc:" + desc);
       }
    });
    

    获取单聊的消息接收选项

    您可以通过调用 getC2CReceiveMessageOpt(Android / iOS & Mac / Windows) 获取单聊的消息接收选项。

    示例代码如下:

    List<String> userList = new ArrayList<>();
    userList.add("user1");
    userList.add("user2");
    V2TIMManager.getMessageManager().getC2CReceiveMessageOpt(userList, new V2TIMValueCallback<List<V2TIMReceiveMessageOptInfo>>() {
       @Override
       public void onSuccess(List<V2TIMReceiveMessageOptInfo> v2TIMReceiveMessageOptInfos) {
           for (int i = 0; i < v2TIMReceiveMessageOptInfos.size(); i++){
               V2TIMReceiveMessageOptInfo info = v2TIMReceiveMessageOptInfos.get(i);
               Log.i("imsdk", "userId: " + info.getUserID() ", receiveOpt: " + info.getC2CReceiveMessageOpt());
           }
       }
        @Override
       public void onError(int code, String desc) {
           Log.i("imsdk", "failure, code:" + code + ", desc:" + desc);
       }
    });
    

    设置群聊的消息接收选项

    您可以调用 setGroupReceiveMessageOpt(Android / iOS & Mac / Windows) 设置群聊的消息接收选项。

    示例代码如下:

    // 设置在线和离线都不接收消息
    String groupID = "groupID";
    V2TIMManager.getMessageManager().setGroupReceiveMessageOpt(groupID, V2TIMMessage.V2TIM_NOT_RECEIVE_MESSAGE, new V2TIMCallback() {
       @Override
       public void onSuccess() {
           Log.i("imsdk", "success");
       }
        @Override
       public void onError(int code, String desc) {
           Log.i("imsdk", "failure, code:" + code + ", desc:" + desc);
       }
    });
    

    获取群聊的消息接收选项

    您可以调用 getGroupsInfo(Android / iOS & Mac / Windows) 获得群资料 V2TIMGroupInfo 对象列表,对象的 recvOpt 字段表示群组的消息接收选项。

    示例代码如下:

    List<String> groupIDList = new ArrayList<>();
    groupIDList.add("groupID1");
    groupIDList.add("groupID2");
    V2TIMManager.getGroupManager().getGroupsInfo(groupIDList, new V2TIMValueCallback<List<V2TIMGroupInfoResult>>() {
       @Override
       public void onSuccess(List<V2TIMGroupInfoResult> v2TIMGroupProfileResults) {
           for (V2TIMGroupInfoResult result : v2TIMGroupProfileResults) {
               V2TIMGroupInfo info = result.getGroupInfo();
               Log.i("imsdk", "recvOpt: " + info.getRecvOpt());
           }
       }
        @Override
       public void onError(int code, String desc) {
           Log.i("imsdk", "failure, code:" + code + ", desc:" + desc);
       }
    });
    

    联系我们

    联系我们,为您的业务提供专属服务。

    技术支持

    如果你想寻求进一步的帮助,通过工单与我们进行联络。我们提供7x24的工单服务。

    7x24 电话支持