(client) chore:运行定义内联加载
This commit is contained in:
@ -6,6 +6,7 @@ using System.Text;
|
|||||||
using System.Xml.Linq;
|
using System.Xml.Linq;
|
||||||
using Configs;
|
using Configs;
|
||||||
using UnityEngine;
|
using UnityEngine;
|
||||||
|
using Object = System.Object;
|
||||||
|
|
||||||
namespace Data
|
namespace Data
|
||||||
{
|
{
|
||||||
@ -141,7 +142,7 @@ namespace Data
|
|||||||
if (string.IsNullOrEmpty(className))
|
if (string.IsNullOrEmpty(className))
|
||||||
continue;
|
continue;
|
||||||
// Debug.Log("1");
|
// Debug.Log("1");
|
||||||
var def = LoadDefineClass(element);
|
var def = LoadDefineClass(element,element.Name.ToString());
|
||||||
if (def == null)
|
if (def == null)
|
||||||
continue;
|
continue;
|
||||||
// Debug.Log("2");
|
// Debug.Log("2");
|
||||||
@ -152,9 +153,8 @@ namespace Data
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private Define LoadDefineClass(XElement defineDoc)
|
private Define LoadDefineClass(XElement defineDoc,string className)
|
||||||
{
|
{
|
||||||
var className = defineDoc.Name.ToString();
|
|
||||||
var assembly = Assembly.GetExecutingAssembly();
|
var assembly = Assembly.GetExecutingAssembly();
|
||||||
|
|
||||||
Type type;
|
Type type;
|
||||||
@ -206,8 +206,14 @@ namespace Data
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (define.Init(defineDoc)) return define;
|
if (define.Init(defineDoc)) return define;
|
||||||
// 获取类的所有字段(不包括私有字段)
|
DefaultInitDefine(define,defineDoc, type);
|
||||||
var fields = type.GetFields(BindingFlags.Public | BindingFlags.Instance | BindingFlags.NonPublic);
|
|
||||||
|
return define;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void DefaultInitDefine(Define define,XElement defineDoc,Type defineType)
|
||||||
|
{
|
||||||
|
var fields = defineType.GetFields(BindingFlags.Public | BindingFlags.Instance | BindingFlags.NonPublic);
|
||||||
|
|
||||||
// 遍历字段并尝试从 XElement 中赋值
|
// 遍历字段并尝试从 XElement 中赋值
|
||||||
foreach (var field in fields)
|
foreach (var field in fields)
|
||||||
@ -217,8 +223,11 @@ namespace Data
|
|||||||
if (element != null)
|
if (element != null)
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
// 将子元素的值转换为目标类型并赋值
|
Object value;
|
||||||
var value = Convert.ChangeType(element.Value, field.FieldType);
|
if (IsFieldTypeInheritedFrom(field, typeof(Define)))
|
||||||
|
value = LoadDefineClass(element, field.FieldType.Name);
|
||||||
|
else
|
||||||
|
value = Convert.ChangeType(element.Value, field.FieldType);
|
||||||
field.SetValue(define, value);
|
field.SetValue(define, value);
|
||||||
}
|
}
|
||||||
catch (Exception ex)
|
catch (Exception ex)
|
||||||
@ -226,8 +235,6 @@ namespace Data
|
|||||||
Debug.LogWarning($"Error setting field {field.Name}: {ex.Message}");
|
Debug.LogWarning($"Error setting field {field.Name}: {ex.Message}");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return define;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -278,5 +285,23 @@ namespace Data
|
|||||||
|
|
||||||
return sb.ToString();
|
return sb.ToString();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// 检查字段的类型是否继承自指定的类
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="field">字段信息</param>
|
||||||
|
/// <param name="baseType">要检查的基类类型</param>
|
||||||
|
/// <returns>如果字段的类型是基类或其派生类,则返回 true</returns>
|
||||||
|
public static bool IsFieldTypeInheritedFrom(FieldInfo field, Type baseType)
|
||||||
|
{
|
||||||
|
// 获取字段的类型
|
||||||
|
var fieldType = field.FieldType;
|
||||||
|
// 如果字段的类型为 null 或不是基类的派生类,则返回 false
|
||||||
|
if (!baseType.IsAssignableFrom(fieldType))
|
||||||
|
return false;
|
||||||
|
|
||||||
|
// 如果字段的类型直接是基类或其派生类,则返回 true
|
||||||
|
return fieldType != baseType && baseType.IsAssignableFrom(fieldType);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
Reference in New Issue
Block a user