mirror of
https://mirror.ghproxy.com/https://github.com/dexyfex/CodeWalker
synced 2025-01-25 15:02:56 +08:00
Fragments group names reading/writing/packing improvements
This commit is contained in:
parent
82338b6a88
commit
dcfe22ade7
@ -2178,7 +2178,7 @@ namespace CodeWalker.GameFiles
|
|||||||
// reference data
|
// reference data
|
||||||
public FragPhysArticulatedBodyType ArticulatedBodyType { get; set; }
|
public FragPhysArticulatedBodyType ArticulatedBodyType { get; set; }
|
||||||
public float[] ChildrenUnkFloats { get; set; }
|
public float[] ChildrenUnkFloats { get; set; }
|
||||||
public ResourcePointerArray64_s<FragPhysNameStruct_s> GroupNames { get; set; }
|
public FragPhysGroupNamesBlock GroupNames { get; set; }
|
||||||
public ResourcePointerArray64<FragPhysTypeGroup> Groups { get; set; }
|
public ResourcePointerArray64<FragPhysTypeGroup> Groups { get; set; }
|
||||||
public ResourcePointerArray64<FragPhysTypeChild> Children { get; set; }
|
public ResourcePointerArray64<FragPhysTypeChild> Children { get; set; }
|
||||||
public FragPhysArchetype Archetype1 { get; set; }
|
public FragPhysArchetype Archetype1 { get; set; }
|
||||||
@ -2253,8 +2253,8 @@ namespace CodeWalker.GameFiles
|
|||||||
// read reference data
|
// read reference data
|
||||||
this.ArticulatedBodyType = reader.ReadBlockAt<FragPhysArticulatedBodyType>(this.ArticulatedBodyTypePointer);
|
this.ArticulatedBodyType = reader.ReadBlockAt<FragPhysArticulatedBodyType>(this.ArticulatedBodyTypePointer);
|
||||||
this.ChildrenUnkFloats = reader.ReadFloatsAt(this.ChildrenUnkFloatsPointer, this.ChildrenCount);
|
this.ChildrenUnkFloats = reader.ReadFloatsAt(this.ChildrenUnkFloatsPointer, this.ChildrenCount);
|
||||||
this.GroupNames = reader.ReadBlockAt<ResourcePointerArray64_s<FragPhysNameStruct_s>>(this.GroupNamesPointer, this.GroupsCount);
|
|
||||||
this.Groups = reader.ReadBlockAt<ResourcePointerArray64<FragPhysTypeGroup>>(this.GroupsPointer, this.GroupsCount);
|
this.Groups = reader.ReadBlockAt<ResourcePointerArray64<FragPhysTypeGroup>>(this.GroupsPointer, this.GroupsCount);
|
||||||
|
this.GroupNames = reader.ReadBlockAt<FragPhysGroupNamesBlock>(this.GroupNamesPointer, this.GroupsCount, this.Groups?.data_items);
|
||||||
this.Children = reader.ReadBlockAt<ResourcePointerArray64<FragPhysTypeChild>>(this.ChildrenPointer, this.ChildrenCount);
|
this.Children = reader.ReadBlockAt<ResourcePointerArray64<FragPhysTypeChild>>(this.ChildrenPointer, this.ChildrenCount);
|
||||||
this.Archetype1 = reader.ReadBlockAt<FragPhysArchetype>(this.Archetype1Pointer);
|
this.Archetype1 = reader.ReadBlockAt<FragPhysArchetype>(this.Archetype1Pointer);
|
||||||
this.Archetype2 = reader.ReadBlockAt<FragPhysArchetype>(this.Archetype2Pointer);
|
this.Archetype2 = reader.ReadBlockAt<FragPhysArchetype>(this.Archetype2Pointer);
|
||||||
@ -2377,8 +2377,6 @@ namespace CodeWalker.GameFiles
|
|||||||
}
|
}
|
||||||
public override void Write(ResourceDataWriter writer, params object[] parameters)
|
public override void Write(ResourceDataWriter writer, params object[] parameters)
|
||||||
{
|
{
|
||||||
BuildGroupsData();
|
|
||||||
|
|
||||||
// update structure data
|
// update structure data
|
||||||
this.ArticulatedBodyTypePointer = (ulong)(this.ArticulatedBodyType != null ? this.ArticulatedBodyType.FilePosition : 0);
|
this.ArticulatedBodyTypePointer = (ulong)(this.ArticulatedBodyType != null ? this.ArticulatedBodyType.FilePosition : 0);
|
||||||
this.ChildrenUnkFloatsPointer = (ulong)(this.ChildrenUnkFloatsBlock != null ? this.ChildrenUnkFloatsBlock.FilePosition : 0);
|
this.ChildrenUnkFloatsPointer = (ulong)(this.ChildrenUnkFloatsBlock != null ? this.ChildrenUnkFloatsBlock.FilePosition : 0);
|
||||||
@ -2400,16 +2398,6 @@ namespace CodeWalker.GameFiles
|
|||||||
this.ChildrenCount = (byte)(this.Children != null ? this.Children.Count : 0);
|
this.ChildrenCount = (byte)(this.Children != null ? this.Children.Count : 0);
|
||||||
this.ChildrenCount2 = this.ChildrenCount;
|
this.ChildrenCount2 = this.ChildrenCount;
|
||||||
|
|
||||||
if ((Groups?.data_items != null) && (GroupNames != null))
|
|
||||||
{
|
|
||||||
var gnplist = new List<ulong>();
|
|
||||||
foreach (var grp in Groups?.data_items)
|
|
||||||
{
|
|
||||||
gnplist.Add((ulong)grp.FilePosition + 128);//manually write group names pointers as offsets to the groups
|
|
||||||
}
|
|
||||||
GroupNames.data_pointers = gnplist.ToArray();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// write structure data
|
// write structure data
|
||||||
writer.Write(this.VFT);
|
writer.Write(this.VFT);
|
||||||
@ -2664,8 +2652,9 @@ namespace CodeWalker.GameFiles
|
|||||||
|
|
||||||
if (grpnames.Count > 0)
|
if (grpnames.Count > 0)
|
||||||
{
|
{
|
||||||
if (GroupNames == null) GroupNames = new ResourcePointerArray64_s<FragPhysNameStruct_s>();
|
if (GroupNames == null) GroupNames = new FragPhysGroupNamesBlock();
|
||||||
GroupNames.data_items = grpnames.ToArray();
|
GroupNames.data_items = grpnames.ToArray();
|
||||||
|
GroupNames.Groups = Groups?.data_items;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -2712,7 +2701,6 @@ namespace CodeWalker.GameFiles
|
|||||||
}
|
}
|
||||||
if (GroupNames != null)
|
if (GroupNames != null)
|
||||||
{
|
{
|
||||||
GroupNames.ManualPointerOverride = (Groups != null); //we'll just write a set of pointers into the Groups
|
|
||||||
list.Add(GroupNames);
|
list.Add(GroupNames);
|
||||||
}
|
}
|
||||||
return list.ToArray();
|
return list.ToArray();
|
||||||
@ -4200,6 +4188,108 @@ namespace CodeWalker.GameFiles
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
[TypeConverter(typeof(ExpandableObjectConverter))] public class FragPhysGroupNamesBlock : ResourceSystemBlock
|
||||||
|
{
|
||||||
|
|
||||||
|
public override long BlockLength
|
||||||
|
{
|
||||||
|
get { return (data_items?.Length ?? 0) * 8 + 8; }
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public ulong[] data_pointers { get; set; }
|
||||||
|
public FragPhysNameStruct_s[] data_items { get; set; }
|
||||||
|
|
||||||
|
public uint UnkVFT { get; set; } = 1095046985;
|
||||||
|
public uint UnkUint1 { get; set; } = 1;
|
||||||
|
|
||||||
|
|
||||||
|
public FragPhysTypeGroup[] Groups;//for writing purposes
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
public override void Read(ResourceDataReader reader, params object[] parameters)
|
||||||
|
{
|
||||||
|
int numElements = Convert.ToInt32(parameters[0]);
|
||||||
|
Groups = parameters[1] as FragPhysTypeGroup[];
|
||||||
|
|
||||||
|
data_pointers = new ulong[numElements];
|
||||||
|
for (int i = 0; i < numElements; i++)
|
||||||
|
{
|
||||||
|
data_pointers[i] = reader.ReadUInt64();
|
||||||
|
}
|
||||||
|
|
||||||
|
UnkVFT = reader.ReadUInt32();
|
||||||
|
UnkUint1 = reader.ReadUInt32();
|
||||||
|
|
||||||
|
//switch (UnkVFT)
|
||||||
|
//{
|
||||||
|
// case 1095030569:
|
||||||
|
// case 1080035264:
|
||||||
|
// case 1080043424:
|
||||||
|
// case 1080043456:
|
||||||
|
// case 1079473328:
|
||||||
|
// case 1079970608:
|
||||||
|
// case 1079970704:
|
||||||
|
// case 1079985584:
|
||||||
|
// case 1079976016:
|
||||||
|
// case 1080043488:
|
||||||
|
// case 1079992976:
|
||||||
|
// case 1095046985:
|
||||||
|
// case 1095046905:
|
||||||
|
// break;
|
||||||
|
// default:
|
||||||
|
// break;//no hit
|
||||||
|
//}
|
||||||
|
//switch (UnkUint1)
|
||||||
|
//{
|
||||||
|
// case 1:
|
||||||
|
// break;
|
||||||
|
// default:
|
||||||
|
// break;//no hit
|
||||||
|
//}
|
||||||
|
|
||||||
|
data_items = new FragPhysNameStruct_s[numElements];
|
||||||
|
for (int i = 0; i < numElements; i++)
|
||||||
|
{
|
||||||
|
data_items[i] = reader.ReadStructAt<FragPhysNameStruct_s>((long)data_pointers[i]);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public override void Write(ResourceDataWriter writer, params object[] parameters)
|
||||||
|
{
|
||||||
|
|
||||||
|
|
||||||
|
var gnplist = new List<ulong>();
|
||||||
|
foreach (var grp in Groups)
|
||||||
|
{
|
||||||
|
gnplist.Add((ulong)grp.FilePosition + 128);//manually write group names pointers as offsets to the groups
|
||||||
|
}
|
||||||
|
data_pointers = gnplist.ToArray();
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
foreach (var x in data_pointers)
|
||||||
|
{
|
||||||
|
writer.Write(x);
|
||||||
|
}
|
||||||
|
|
||||||
|
writer.Write(UnkVFT);
|
||||||
|
writer.Write(UnkUint1);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
public override string ToString()
|
||||||
|
{
|
||||||
|
return "(Count: " + ((data_items != null) ? data_items.Length : 0).ToString() + ")";
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
[TypeConverter(typeof(ExpandableObjectConverter))] public struct FragPhysNameStruct_s
|
[TypeConverter(typeof(ExpandableObjectConverter))] public struct FragPhysNameStruct_s
|
||||||
{
|
{
|
||||||
// structure data
|
// structure data
|
||||||
|
@ -1542,181 +1542,6 @@ namespace CodeWalker.GameFiles
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
public override string ToString()
|
|
||||||
{
|
|
||||||
return "(Count: " + ((data_items != null) ? data_items.Length : 0).ToString() + ")";
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
[TypeConverter(typeof(ExpandableObjectConverter))] public class ResourcePointerArray64_s<T> : ResourceSystemBlock, IList<T> where T : struct
|
|
||||||
{
|
|
||||||
|
|
||||||
public override long BlockLength
|
|
||||||
{
|
|
||||||
get { return (data_items != null) ? 8 * data_items.Length : 0; }
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
public ulong[] data_pointers { get; set; }
|
|
||||||
public T[] data_items { get; set; }
|
|
||||||
|
|
||||||
public bool ManualPointerOverride = false;//use this to manually write data_pointers
|
|
||||||
|
|
||||||
private ResourceSystemStructBlock<T>[] data_blocks = null;
|
|
||||||
|
|
||||||
|
|
||||||
public ResourcePointerArray64_s()
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
public override void Read(ResourceDataReader reader, params object[] parameters)
|
|
||||||
{
|
|
||||||
int numElements = Convert.ToInt32(parameters[0]);
|
|
||||||
|
|
||||||
data_pointers = reader.ReadUlongsAt((ulong)reader.Position, (uint)numElements);
|
|
||||||
|
|
||||||
data_items = new T[numElements];
|
|
||||||
for (int i = 0; i < numElements; i++)
|
|
||||||
{
|
|
||||||
data_items[i] = reader.ReadStructAt<T>((long)data_pointers[i]);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
public override void Write(ResourceDataWriter writer, params object[] parameters)
|
|
||||||
{
|
|
||||||
// update...
|
|
||||||
if (ManualPointerOverride == false)
|
|
||||||
{
|
|
||||||
var list = new List<ulong>();
|
|
||||||
if (data_blocks != null)
|
|
||||||
{
|
|
||||||
foreach (var x in data_blocks)
|
|
||||||
{
|
|
||||||
list.Add((ulong)x.FilePosition);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
//foreach (var x in data_items)
|
|
||||||
// if (x != null)
|
|
||||||
// data_pointers.Add((uint)x.Position);
|
|
||||||
// else
|
|
||||||
// data_pointers.Add((uint)0);
|
|
||||||
data_pointers = list.ToArray();
|
|
||||||
}
|
|
||||||
|
|
||||||
// write...
|
|
||||||
foreach (var x in data_pointers)
|
|
||||||
writer.Write(x);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
public override IResourceBlock[] GetReferences()
|
|
||||||
{
|
|
||||||
var list = new List<IResourceBlock>();
|
|
||||||
|
|
||||||
if (ManualPointerOverride == false)
|
|
||||||
{
|
|
||||||
var blocks = new List<ResourceSystemStructBlock<T>>();
|
|
||||||
if (data_items != null)
|
|
||||||
{
|
|
||||||
foreach (var x in data_items)
|
|
||||||
{
|
|
||||||
var block = new ResourceSystemStructBlock<T>(new[] { x });
|
|
||||||
blocks.Add(block);
|
|
||||||
list.Add(block);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
data_blocks = blocks.ToArray();
|
|
||||||
//foreach (var x in data_items)
|
|
||||||
// list.Add(x);
|
|
||||||
}
|
|
||||||
|
|
||||||
return list.ToArray();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
public int IndexOf(T item)
|
|
||||||
{
|
|
||||||
throw new NotImplementedException();
|
|
||||||
}
|
|
||||||
|
|
||||||
public void Insert(int index, T item)
|
|
||||||
{
|
|
||||||
throw new NotImplementedException();
|
|
||||||
}
|
|
||||||
|
|
||||||
public void RemoveAt(int index)
|
|
||||||
{
|
|
||||||
//data_items.RemoveAt(index);
|
|
||||||
throw new NotImplementedException();
|
|
||||||
}
|
|
||||||
|
|
||||||
public T this[int index]
|
|
||||||
{
|
|
||||||
get
|
|
||||||
{
|
|
||||||
return data_items[index];
|
|
||||||
}
|
|
||||||
set
|
|
||||||
{
|
|
||||||
throw new NotImplementedException();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void Add(T item)
|
|
||||||
{
|
|
||||||
//data_items.Add(item);
|
|
||||||
throw new NotImplementedException();
|
|
||||||
}
|
|
||||||
|
|
||||||
public void Clear()
|
|
||||||
{
|
|
||||||
throw new NotImplementedException();
|
|
||||||
}
|
|
||||||
|
|
||||||
public bool Contains(T item)
|
|
||||||
{
|
|
||||||
throw new NotImplementedException();
|
|
||||||
}
|
|
||||||
|
|
||||||
public void CopyTo(T[] array, int arrayIndex)
|
|
||||||
{
|
|
||||||
throw new NotImplementedException();
|
|
||||||
}
|
|
||||||
|
|
||||||
public int Count
|
|
||||||
{
|
|
||||||
//get { return data_items.Count; }
|
|
||||||
get { return (data_items != null) ? data_items.Length : 0; }
|
|
||||||
}
|
|
||||||
|
|
||||||
public bool IsReadOnly
|
|
||||||
{
|
|
||||||
get { return false; }
|
|
||||||
}
|
|
||||||
|
|
||||||
public bool Remove(T item)
|
|
||||||
{
|
|
||||||
//return data_items.Remove(item);
|
|
||||||
throw new NotImplementedException();
|
|
||||||
}
|
|
||||||
|
|
||||||
public IEnumerator<T> GetEnumerator()
|
|
||||||
{
|
|
||||||
//return data_items.GetEnumerator();
|
|
||||||
throw new NotImplementedException();
|
|
||||||
}
|
|
||||||
|
|
||||||
System.Collections.IEnumerator System.Collections.IEnumerable.GetEnumerator()
|
|
||||||
{
|
|
||||||
throw new NotImplementedException();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
public override string ToString()
|
public override string ToString()
|
||||||
{
|
{
|
||||||
return "(Count: " + ((data_items != null) ? data_items.Length : 0).ToString() + ")";
|
return "(Count: " + ((data_items != null) ? data_items.Length : 0).ToString() + ")";
|
||||||
|
Loading…
Reference in New Issue
Block a user