| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677 |
- using System.Collections;
- using System.Collections.Generic;
- using UnityEngine;
- using UnityEngine.UI;
- using System;
- using Newtonsoft.Json.Linq;
- public class BoxFriendRecommand : MonoBehaviour
- {
- void Awake()
- {
- GetFriendRecommendItemPrefab().SetActive(false);
- }
- void OnEnable()
- {
- Refresh();
- }
- Transform GetFriendRecommendItemParent()
- {
- return transform.Find("ScrollView/Viewport/Content");
- }
- GameObject GetFriendRecommendItemPrefab()
- {
- return GetFriendRecommendItemParent().Find("Item").gameObject;
- }
- void Refresh()
- {
- for (int i = 1; i < GetFriendRecommendItemParent().childCount; i++)
- {
- Destroy(GetFriendRecommendItemParent().GetChild(i).gameObject);
- }
- Action<JArray> cb = delegate (JArray list) {
- for (int i = 1; i < GetFriendRecommendItemParent().childCount; i++)
- {
- Destroy(GetFriendRecommendItemParent().GetChild(i).gameObject);
- }
- if (list.Count > 0)
- {
- foreach (var itemInfo in list)
- {
- int userID = itemInfo.Value<int>("id");
- int avatarID = itemInfo.Value<int>("avatarID");
- string avatarUrl = itemInfo.Value<string>("avatarUrl");
- string nickname = itemInfo.Value<string>("nickname");
- bool online = itemInfo.Value<bool>("online");
- long offlineTime = itemInfo.Value<long>("offlineTime");
- int playCount = itemInfo.Value<int>("playCount");
- GameObject o = Instantiate(GetFriendRecommendItemPrefab(), GetFriendRecommendItemParent());
- o.SetActive(true);
- o.name = userID.ToString();
- RoleMgr.SetAvatarToImage(
- o.transform.Find("Avatar/Sprite").GetComponent<Image>(),
- avatarID, avatarUrl
- );
- o.transform.Find("Name").GetComponent<Text>().text = nickname;
- o.transform.Find("PlayTogether").GetComponent<Text>().text =
- string.Format(
- TextAutoLanguage2.GetTextByKey("friend_record_play-again-count"), playCount
- );
- Button btnYes = o.transform.Find("BtnAdd").GetComponent<Button>();
- btnYes.onClick.RemoveAllListeners();
- btnYes.onClick.AddListener(delegate () {
- AudioMgr.ins.PlayBtn();
- UserPlayer.ins.call("friendComp.requestAddFriend", userID);
- btnYes.interactable = false;
- });
- }
- }
- else
- {
- PopupMgr.ins.ShowTip(TextAutoLanguage2.GetTextByCNKey("没有可推荐的好友"));
- }
- };
- UserPlayer.ins.call("friendComp.getFriendRecommendList", null, cb);
- PopupMgr.ins.ClearAllTip();
- }
- }
|