tencent cloud

即时通信 IM

动态与公告
产品动态
公告
产品简介
产品概述
基本概念
应用场景
功能介绍
账号系统
用户资料与关系链
消息管理
群组相关
公众号系统
音视频通话 Call
使用限制
购买指南
计费概述
价格说明
购买指引
续费指引
停服说明
退费说明
开发指引
Demo 专区
开通服务
体验 Demo
快速跑通
下载中心
SDK & Demo 源码
更新日志
聊天互动(含 UI)
TUIKit 组件介绍
快速开始
全功能接入
单功能接入
AI 集成
构建基础界面
更多特性
定义外观
国际化界面语言
推送服务(Push)
服务概述
名词解释
开通服务
快速跑通
厂商通道
数据统计
排查工具
客户端 API
服务端 API
推送回调
高级功能
更新日志
错误码
常见问题
智能客服
功能概述
快速入门
集成指引
管理员操作手册
客服操作手册
更多实践
直播间搭建
AI 聊天机器人方案
超大娱乐协作社群
Discord 实现指南
游戏内集成 Chat 指南
类 WhatsApp Channel 搭建方案
发送红包
Chat 应对防火墙限制相关
无 UI 集成
快速开始
集成 SDK
初始化
登录登出
消息相关
会话相关
群组相关
社群话题
用户管理
离线推送
云端搜索
本地搜索
公众号
客户端 API
JavaScript
Android
iOS & macOS
Swift
Flutter
Electron
Unity
React Native
C 接口
C++
服务端 API
生成 UserSig
REST API
第三方回调
控制台指南
新版控制台介绍
创建并升级应用
基本配置
功能配置
账号管理
群组管理
公众号管理
回调配置
用量统计
资源包查看指南
实时监控
开发辅助工具
访问管理
高级功能
常见问题
uni-app 常见问题
购买相关问题
SDK 相关问题
账号鉴权相关问题
用户资料与关系链相关问题
消息相关问题
群组相关问题
直播群相关问题
昵称头像相关问题
协议与认证
服务等级协议
安全合规认证
IM 政策
隐私政策
数据隐私和安全协议
平滑迁移方案
平滑迁移完整版
平滑迁移简化版
错误码
联系我们

Unity

PDF
聚焦模式
字号
最后更新时间: 2024-02-06 18:01:42

功能描述

用户可以设置和获取个人的昵称、头像、签名等资料信息,也可以获取到陌生人的资料信息。

关系链事件监听器

目前提供的关系链事件如下:
监听器
解释
SetOnAddFriendCallback
设置添加好友的回调。
SetOnDeleteFriendCallback
设置删除好友的回调。
SetUpdateFriendProfileCallback
设置更新好友资料的回调。
SetFriendAddRequestCallback
设置好友添加请求的回调。
SetFriendApplicationListDeletedCallback
设置好友申请被删除的回调。
SetFriendApplicationListReadCallback
设置好友申请已读的回调。
SetFriendBlackListAddedCallback
设置黑名单新增的回调。
SetFriendBlackListDeletedCallback
设置黑名单删除的回调。
当不想再接收关系链事件时,可调用相同回调函数传入 null 移除关系链事件监听器。
注意:
只有预先设置好关系链事件监听器,才能正常接收到下文中的各种事件通知。

用户资料管理

查询和修改自己的资料

您可以调用 ProfileGetUserProfileList (Details) 接口查询个人资料,其中参数 friendship_getprofilelist_param_identifier_array 需填入自己的 UserID。
您可以调用 ProfileModifySelfUserProfile (Details) 接口修改个人资料。
示例代码如下:
// 获取个人资料
FriendShipGetProfileListParam param = new FriendShipGetProfileListParam
{
friendship_getprofilelist_param_identifier_array = new List<string>
{
"self_user_id"
}
};
TIMResult res = TencentIMSDK.ProfileGetUserProfileList(param, (int code, string desc, List<UserProfile> profile, string user_data)=>{
// 处理异步逻辑
});

// 设置个人资料
UserProfileItem param = new UserProfileItem{
user_profile_item_nick_name = "new_nick_name"
};
TIMResult res = TencentIMSDK.ProfileGetUserProfileList(param, (int code, string desc, string user_data)=>{
// 处理异步逻辑
});


查询非好友用户资料

您可以调用 ProfileGetUserProfileList (Details) 接口查询非好友资料,其中参数 friendship_getprofilelist_param_identifier_array 填入非好友的 UserID 即可。
说明:
不能修改非好友的资料。

查询和修改好友资料

您可以调用 FriendshipGetFriendsInfo (Details) 接口查询指定的好友资料,从回调信息中通过 FriendInfoGetResultfriendship_friend_info_get_result_relation_type 字段可以得到该用户与自己的关系:
relation
与自己的关系
TIMFriendshipRelationType.kTIMFriendshipRelationType_None
表示不是好友。
TIMFriendshipRelationType.kTIMFriendshipRelationType_BothFriend
表示互为好友。
TIMFriendshipRelationType.kTIMFriendshipRelationType_InMyFriendList
表示对方在我的好友列表中。
TIMFriendshipRelationType.kTIMFriendshipRelationType_InOtherFriendList
表示我在对方的好友列表中。
// 获取好友信息
TIMResult res = TencentIMSDK.FriendshipGetFriendsInfo(friend_userids, (int code, string desc, List<FriendInfoGetResult> result, string user_data)=>{
// 处理异步逻辑
});
您可以调用 FriendshipModifyFriendProfile (Details) 接口修改好友备注等资料。
// 设置好友信息
FriendshipModifyFriendProfileParam param = new FriendshipModifyFriendProfileParam
{
friendship_modify_friend_profile_param_identifier = "friend_userid",
friendship_modify_friend_profile_param_item = new FriendProfileItem
{
friend_profile_item_remark = "nickname" // 好友备注
}
};
TIMResult res = TencentIMSDK.FriendshipModifyFriendProfile(param, (int code, string desc, string user_data)=>{
// 处理异步逻辑
});

常见问题

增强版获取用户资料为什么不是最新的?

增强版 SDK 中用户资料的更新分好友和陌生人两种情况:
好友资料:由于好友资料更新时,后台会主动向 SDK 发送系统通知,因此好友资料可以实时更新。
陌生人资料:陌生人资料更新时,由于没有好友关系,后台无法向 SDK 发送系统通知,因此无法实时更新;为了避免每次获取用户资料都向后台发起网络请求,SDK 增加了缓存逻辑,对同一个用户主动向后台拉取资料的时间间隔为 10 分钟。

帮助和支持

本页内容是否解决了您的问题?

填写满意度调查问卷,共创更好文档体验。

文档反馈