diff options
author | chai <chaifix@163.com> | 2020-12-30 20:59:04 +0800 |
---|---|---|
committer | chai <chaifix@163.com> | 2020-12-30 20:59:04 +0800 |
commit | e9ea621b93fbb58d9edfca8375918791637bbd52 (patch) | |
tree | 19ce3b1c1f2d51eda6878c9d0f2c9edc27f13650 /Client/Assembly-CSharp/HatsTab.cs |
+init
Diffstat (limited to 'Client/Assembly-CSharp/HatsTab.cs')
-rw-r--r-- | Client/Assembly-CSharp/HatsTab.cs | 83 |
1 files changed, 83 insertions, 0 deletions
diff --git a/Client/Assembly-CSharp/HatsTab.cs b/Client/Assembly-CSharp/HatsTab.cs new file mode 100644 index 0000000..10f7b3a --- /dev/null +++ b/Client/Assembly-CSharp/HatsTab.cs @@ -0,0 +1,83 @@ +using System; +using System.Collections.Generic; +using UnityEngine; + +public class HatsTab : MonoBehaviour +{ + public ColorChip ColorTabPrefab; + + public SpriteRenderer DemoImage; + + public SpriteRenderer HatImage; + + public SpriteRenderer SkinImage; + + public SpriteRenderer PetImage; + + public FloatRange XRange = new FloatRange(1.5f, 3f); + + public float YStart = 0.8f; + + public float YOffset = 0.8f; + + public int NumPerRow = 4; + + public Scroller scroller; + + private List<ColorChip> ColorChips = new List<ColorChip>(); + + public void OnEnable() + { + PlayerControl.SetPlayerMaterialColors((int)PlayerControl.LocalPlayer.Data.ColorId, this.DemoImage); + PlayerControl.SetHatImage(SaveManager.LastHat, this.HatImage); + PlayerControl.SetSkinImage(SaveManager.LastSkin, this.SkinImage); + PlayerControl.SetPetImage(SaveManager.LastPet, (int)PlayerControl.LocalPlayer.Data.ColorId, this.PetImage); + HatBehaviour[] unlockedHats = DestroyableSingleton<HatManager>.Instance.GetUnlockedHats(); + for (int i = 0; i < unlockedHats.Length; i++) + { + HatBehaviour hat = unlockedHats[i]; + float x = this.XRange.Lerp((float)(i % this.NumPerRow) / ((float)this.NumPerRow - 1f)); + float y = this.YStart - (float)(i / this.NumPerRow) * this.YOffset; + ColorChip colorChip = UnityEngine.Object.Instantiate<ColorChip>(this.ColorTabPrefab, this.scroller.Inner); + colorChip.transform.localPosition = new Vector3(x, y, -1f); + colorChip.Button.OnClick.AddListener(delegate() + { + this.SelectHat(hat); + }); + colorChip.Inner.sprite = hat.MainImage; + this.ColorChips.Add(colorChip); + } + this.scroller.YBounds.max = -(this.YStart - (float)(unlockedHats.Length / this.NumPerRow) * this.YOffset) - 3f; + } + + public void OnDisable() + { + for (int i = 0; i < this.ColorChips.Count; i++) + { + UnityEngine.Object.Destroy(this.ColorChips[i].gameObject); + } + this.ColorChips.Clear(); + } + + public void Update() + { + PlayerControl.SetPlayerMaterialColors((int)PlayerControl.LocalPlayer.Data.ColorId, this.DemoImage); + HatBehaviour hatById = DestroyableSingleton<HatManager>.Instance.GetHatById(SaveManager.LastHat); + for (int i = 0; i < this.ColorChips.Count; i++) + { + ColorChip colorChip = this.ColorChips[i]; + colorChip.InUseForeground.SetActive(hatById.MainImage == colorChip.Inner.sprite); + } + } + + private void SelectHat(HatBehaviour hat) + { + uint idFromHat = DestroyableSingleton<HatManager>.Instance.GetIdFromHat(hat); + SaveManager.LastHat = idFromHat; + PlayerControl.SetHatImage(idFromHat, this.HatImage); + if (PlayerControl.LocalPlayer) + { + PlayerControl.LocalPlayer.RpcSetHat(idFromHat); + } + } +} |