FriendshipGetFriendsInfo

功能介绍

获取好友信息

json_get_friends_info_param 建议一次最大 100 个,因为数量过多可能会导致数据包太大被后台拒绝,后台限制数据包最大为 1M。

增强版 SDK 中用户资料的更新分好友和陌生人两种情况:

好友资料:由于好友资料更新时,后台会主动向 SDK 发送系统通知,因此好友资料可以实时更新。

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

参数详解

重载1

参数名称 参数类型 是否必填 描述
json_get_friends_info_param List< string > 搜索参数
callback ValueCallback< List< FriendInfoGetResult > > 异步回调 返回值的json_param的格式为json

重载2

参数名称 参数类型 是否必填 描述
json_get_friends_info_param List< string > 搜索参数
callback ValueCallback< string > 异步回调 返回值的json_param的格式为string

返回模板

TIMResult

调用成功后回调函数参数:
code:int
desc:string
json_param:
'[
    {
      "friendship_friend_info_get_result_error_code": 0,
      "friendship_friend_info_get_result_error_message": "OK",
      "friendship_friend_info_get_result_field_info": {
        "friend_profile_add_source": "",
        "friend_profile_add_time": 0,
        "friend_profile_add_wording": "",
        "friend_profile_custom_string_array": [{
          "friend_profile_custom_string_info_key": "Tag_Profile_Custom_Str",
          "friend_profile_custom_string_info_value": "test3-lamar-value"
        }],
        "friend_profile_group_name_array": [],
        "friend_profile_identifier": "98826",
        "friend_profile_remark": "",
        "friend_profile_user_profile": {
          "user_profile_add_permission": 1,
          "user_profile_birthday": 2000,
          "user_profile_custom_string_array": [{
            "user_profile_custom_string_info_key": "Tag_Profile_Custom_Str",
            "user_profile_custom_string_info_value": "test3-lamar-value"
          }],
          "user_profile_face_url": "test1-www.google.com",
          "user_profile_gender": 2,
          "user_profile_identifier": "98826",
          "user_profile_language": 1000,
          "user_profile_level": 3000,
          "user_profile_location": "shenzhen",
        "user_profile_nick_name": "test change8888",
          "user_profile_role": 4000,
          "user_profile_self_signature": "1111111"
        }
    },
      "friendship_friend_info_get_result_identifier": "98826",
      "friendship_friend_info_get_result_relation_type": 0
  }
]' // Json Key请参考[FriendInfoGetResult]
user_data:string

返回值详解

名称 数值类型 描述
TIMResult TIMResult 调用接口的返回值
code int 值为ERR_SUCC表示成功,其他值表示失败。详情请参考 错误码
desc string 错误描述字符串
json_param string Json字符串,不同的接口,Json字符串不一样 Json Key请参考FriendInfoGetResult
user_data string ImSDK负责透传的用户自定义数据,未做任何处理

代码示例

using UnityEngine;
using UnityEngine.UI;
using com.tencent.im.unity.demo.types;
using UnityEngine.SceneManagement;
using com.tencent.imsdk.unity;
using com.tencent.imsdk.unity.types;
using com.tencent.imsdk.unity.enums;
using System;
using com.tencent.im.unity.demo.utils;
using System.Collections;
using System.Collections.Generic;
using EasyUI.Toast;
public class FriendshipGetFriendsInfo : MonoBehaviour
{
  public List<FriendProfile> UserList = new List<FriendProfile>();
  public HashSet<string> SelectedUser = new HashSet<string>();
  public Text Header;
  public Text Result;

  public Button Submit;
  public Button Copy;

  void Start()
  {
    GameObject.Find("SelectUserLabel").GetComponent<Text>().text = Utils.t("SelectUserLabel");
    FriendshipGetFriendProfileList();
    Header = GameObject.Find("HeaderText").GetComponent<Text>();
    Result = GameObject.Find("ResultText").GetComponent<Text>();
    Submit = GameObject.Find("Submit").GetComponent<Button>();
    Copy = GameObject.Find("Copy").GetComponent<Button>();
    Submit.onClick.AddListener(FriendshipGetFriendsInfoSDK);
    Copy.GetComponentInChildren<Text>().text = Utils.t("Copy");
    Copy.onClick.AddListener(CopyText);
    if (CurrentSceneInfo.info != null)
    {
      Header.text = Utils.IsCn() ? CurrentSceneInfo.info.apiText + " " + CurrentSceneInfo.info.apiName : CurrentSceneInfo.info.apiName;
      Submit.GetComponentInChildren<Text>().text = CurrentSceneInfo.info.apiName;
    }
  }

  void ToggleValueChanged(Toggle change)
  {
    string userID = change.GetComponentInChildren<Text>().text.Split(':')[1];
    if (change.isOn)
    {
      SelectedUser.Add(userID);
    }
    else
    {
      SelectedUser.Remove(userID);
    }
  }

  void GenerateToggle()
  {
    var Parent = GameObject.Find("ToggleContent");
    var Toggler = GameObject.Find("Toggler").GetComponent<Toggle>();
    foreach (FriendProfile user in UserList)
    {
      var obj = Instantiate(Toggler, Parent.transform);
      obj.GetComponentInChildren<Text>().text = "userID:" + user.friend_profile_identifier;
      obj.isOn = false;
      obj.onValueChanged.AddListener(delegate
    {
      ToggleValueChanged(obj);
    });
    }
  }

  void SetUserList(params object[] parameters)
  {
    try
    {
      string text = (string)parameters[1];
      print(text);
      List<FriendProfile> List = Utils.FromJson<List<FriendProfile>>(text);
      UserList.AddRange(List);
      GenerateToggle();
    }
    catch (Exception ex)
    {
      print(ex);
      Toast.Show(Utils.t("getFriendListFailed"));
    }
  }

  public void FriendshipGetFriendProfileList()
  {
    var Users = UserList;
    var cb = Utils.addAsyncStringDataToScreen(SetUserList);
    TIMResult res = TencentIMSDK.FriendshipGetFriendProfileList(cb);
  }

  public void FriendshipGetFriendsInfoSDK()
  {
    List<string> user_list = new List<string>(SelectedUser);
    TIMResult res = TencentIMSDK.FriendshipGetFriendsInfo(user_list, Utils.addAsyncStringDataToScreen(GetResult));
    Result.text = Utils.SynchronizeResult(res);
  }

  void GetResult(params object[] parameters)
  {
    Result.text += (string)parameters[0];
  }

  void CopyText()
  {
    Utils.Copy(Result.text);
  }
  void OnApplicationQuit()
  {
    TencentIMSDK.Uninit();
  }
}

results matching ""

    No results matching ""