From 266370578135dca270729e8a70252e776ed22898 Mon Sep 17 00:00:00 2001
From: chai <215380520@qq.com>
Date: Fri, 12 May 2023 13:52:37 +0800
Subject: + litjson
---
.../Scripts/Unit/Characters/CharacterInfo.cs | 125 ++++++++++++++-------
1 file changed, 84 insertions(+), 41 deletions(-)
(limited to 'WorldlineKeepers/Assets/Scripts/Unit')
diff --git a/WorldlineKeepers/Assets/Scripts/Unit/Characters/CharacterInfo.cs b/WorldlineKeepers/Assets/Scripts/Unit/Characters/CharacterInfo.cs
index 950b7ae..62dd830 100644
--- a/WorldlineKeepers/Assets/Scripts/Unit/Characters/CharacterInfo.cs
+++ b/WorldlineKeepers/Assets/Scripts/Unit/Characters/CharacterInfo.cs
@@ -11,43 +11,8 @@ namespace WK
public class CharacterStatsCollection
{
-
- }
-
- public class CharacterBuffsCollection
- {
-
- }
-
- public class CharacterPerksCollection
- {
-
- }
-
- ///
- /// 角色当前状态
- ///
- public class CharacterInfo
- {
-
- ///
- /// 角色当前所有属性
- ///
private List m_Stats;
-
- public CharacterStatsCollection stats { get { return m_AllStats; } }
- private CharacterStatsCollection m_AllStats;
-
- ///
- /// 角色当前所有buff
- ///
- private List m_Buffs;
-
- ///
- /// 角色当前所有被动
- ///
- private List m_Perks;
-
+ public List stats { get { return m_Stats; } }
public CharacterStats this[string statsUID]
{
get
@@ -56,10 +21,9 @@ namespace WK
{
return null;
}
- return GetStats(statsUID);
+ return GetStats(statsUID);
}
}
-
public CharacterStats GetStats(string statsUID)
{
for (int i = 0; i < m_Stats.Count; ++i)
@@ -72,7 +36,7 @@ namespace WK
return null;
}
- public bool HasStats(string statsUID)
+ public bool HasStats(string statsUID)
{
for (int i = 0; i < m_Stats.Count; ++i)
{
@@ -83,12 +47,91 @@ namespace WK
}
return false;
}
+ }
+
+ public class CharacterBuffsCollection
+ {
+ private List m_Buffs;
+ public List buffs { get { return m_Buffs; } }
+
+ public Buff this[string buffUID]
+ {
+ get
+ {
+ return GetBuff(buffUID);
+ }
+ }
- public bool HasBuff(string buffUID)
+ public Buff GetBuff(string buffUID)
{
- return false;
+ if (m_Buffs == null)
+ return null;
+ for(int i = 0; i < m_Buffs.Count; ++i)
+ {
+ if (m_Buffs[i].uid == buffUID)
+ {
+ return m_Buffs[i];
+ }
+ }
+ return null;
+ }
+
+ public bool HasBuff(string buffUID)
+ {
+ return GetBuff(buffUID) != null;
+ }
+
+ }
+
+ public class CharacterPerksCollection
+ {
+ private List m_Perks;
+ public List perks { get { return m_Perks; } }
+
+ public PerkBase this[string buffUID]
+ {
+ get
+ {
+ return GetBuff(buffUID);
+ }
+ }
+
+ public PerkBase GetBuff(string buffUID)
+ {
+ if (m_Perks == null)
+ return null;
+ for (int i = 0; i < m_Perks.Count; ++i)
+ {
+ if (m_Perks[i].uid == buffUID)
+ {
+ return m_Perks[i];
+ }
+ }
+ return null;
}
+ public bool HasBuff(string buffUID)
+ {
+ return GetBuff(buffUID) != null;
+ }
+
+ }
+
+ ///
+ /// 角色当前状态
+ ///
+ public class CharacterInfo
+ {
+
+ public CharacterStatsCollection stats { get { return m_Stats; } }
+ private CharacterStatsCollection m_Stats;
+
+ public CharacterBuffsCollection buffs { get { return m_Buffs; } }
+ private CharacterBuffsCollection m_Buffs;
+
+ public CharacterPerksCollection perks { get { return m_Perks; } }
+ public CharacterPerksCollection m_Perks;
+
}
}
--
cgit v1.1-26-g67d0