Fragments XML conversion improvements and field names update

This commit is contained in:
dexy 2021-12-12 02:29:11 +11:00
parent 4550ac6eb4
commit 2a63329490
3 changed files with 126 additions and 193 deletions

View File

@ -1135,31 +1135,23 @@ namespace CodeWalker.GameFiles
} }
// structure data // structure data
public float UnkFloat1 { get; set; } public Vector3 ProjectionRow1 { get; set; }
public float UnkFloat2 { get; set; }
public float UnkFloat3 { get; set; }
public uint UnkUint1 = 0x7f800001; // 0x7f800001 public uint UnkUint1 = 0x7f800001; // 0x7f800001
public float UnkFloat5 { get; set; } public Vector3 ProjectionRow2 { get; set; }
public float UnkFloat6 { get; set; }
public float UnkFloat7 { get; set; }
public uint UnkUint2 = 0x7f800001; // 0x7f800001 public uint UnkUint2 = 0x7f800001; // 0x7f800001
public float UnkFloat9 { get; set; } public Vector3 ProjectionRow3 { get; set; }
public float UnkFloat10 { get; set; }
public float UnkFloat11 { get; set; }
public uint UnkUint3 = 0x7f800001; // 0x7f800001 public uint UnkUint3 = 0x7f800001; // 0x7f800001
public float UnkFloat13 { get; set; } public float UnkFloat13 { get; set; } //offset? Vector2
public float UnkFloat14 { get; set; } public float UnkFloat14 { get; set; } //offset?
public float UnkFloat15 { get; set; } public float UnkFloat15 { get; set; } //scale? sum of this and above often gives integers eg 1, 6
public float UnkFloat16 { get; set; } public float UnkFloat16 { get; set; } //(as above, Vector2)
public VertexDeclaration VertexDeclaration { get; set; } = new VertexDeclaration(); //this all equates to VertexTypePNCTT public VertexDeclaration VertexDeclaration { get; set; } = new VertexDeclaration(); //this all equates to VertexTypePNCTT
public float UnkFloat17 { get; set; } public float Thickness { get; set; } //probably
public ushort UnkUshort1 = 2; //2 public ushort UnkUshort1 = 2; //2
public ushort Flags { get; set; }//512, 768, 1280 etc ... flags public ushort Flags { get; set; }//512, 768, 1280 etc ... flags
public float UnkFloat18 { get; set; } public float UnkFloat18 { get; set; } //another scale in UV space..?
public float UnkFloat19 { get; set; } public float UnkFloat19 { get; set; } //(as above, Vector2)
public float UnkFloat20 { get; set; } public Vector3 Tangent { get; set; }
public float UnkFloat21 { get; set; }
public float UnkFloat22 { get; set; }
public uint UnkUint4 = 0x7f800001; // 0x7f800001 public uint UnkUint4 = 0x7f800001; // 0x7f800001
public byte FlagsLo { get { return (byte)((Flags >> 0) & 0xFF); } } public byte FlagsLo { get { return (byte)((Flags >> 0) & 0xFF); } }
@ -1170,31 +1162,23 @@ namespace CodeWalker.GameFiles
public override void Read(ResourceDataReader reader, params object[] parameters) public override void Read(ResourceDataReader reader, params object[] parameters)
{ {
// read structure data // read structure data
this.UnkFloat1 = reader.ReadSingle(); this.ProjectionRow1 = reader.ReadVector3();
this.UnkFloat2 = reader.ReadSingle();
this.UnkFloat3 = reader.ReadSingle();
this.UnkUint1 = reader.ReadUInt32(); this.UnkUint1 = reader.ReadUInt32();
this.UnkFloat5 = reader.ReadSingle(); this.ProjectionRow2 = reader.ReadVector3();
this.UnkFloat6 = reader.ReadSingle();
this.UnkFloat7 = reader.ReadSingle();
this.UnkUint2 = reader.ReadUInt32(); this.UnkUint2 = reader.ReadUInt32();
this.UnkFloat9 = reader.ReadSingle(); this.ProjectionRow3 = reader.ReadVector3();
this.UnkFloat10 = reader.ReadSingle();
this.UnkFloat11 = reader.ReadSingle();
this.UnkUint3 = reader.ReadUInt32(); this.UnkUint3 = reader.ReadUInt32();
this.UnkFloat13 = reader.ReadSingle(); this.UnkFloat13 = reader.ReadSingle();
this.UnkFloat14 = reader.ReadSingle(); this.UnkFloat14 = reader.ReadSingle();
this.UnkFloat15 = reader.ReadSingle(); this.UnkFloat15 = reader.ReadSingle();
this.UnkFloat16 = reader.ReadSingle(); this.UnkFloat16 = reader.ReadSingle();
this.VertexDeclaration.Read(reader); this.VertexDeclaration.Read(reader);
this.UnkFloat17 = reader.ReadSingle(); this.Thickness = reader.ReadSingle();
this.UnkUshort1 = reader.ReadUInt16(); this.UnkUshort1 = reader.ReadUInt16();
this.Flags = reader.ReadUInt16(); this.Flags = reader.ReadUInt16();
this.UnkFloat18 = reader.ReadSingle(); this.UnkFloat18 = reader.ReadSingle();
this.UnkFloat19 = reader.ReadSingle(); this.UnkFloat19 = reader.ReadSingle();
this.UnkFloat20 = reader.ReadSingle(); this.Tangent = reader.ReadVector3();
this.UnkFloat21 = reader.ReadSingle();
this.UnkFloat22 = reader.ReadSingle();
this.UnkUint4 = reader.ReadUInt32(); this.UnkUint4 = reader.ReadUInt32();
//if (UnkUint1 != 0x7f800001) //if (UnkUint1 != 0x7f800001)
@ -1213,79 +1197,59 @@ namespace CodeWalker.GameFiles
public override void Write(ResourceDataWriter writer, params object[] parameters) public override void Write(ResourceDataWriter writer, params object[] parameters)
{ {
// write structure data // write structure data
writer.Write(this.UnkFloat1); writer.Write(this.ProjectionRow1);
writer.Write(this.UnkFloat2);
writer.Write(this.UnkFloat3);
writer.Write(this.UnkUint1); writer.Write(this.UnkUint1);
writer.Write(this.UnkFloat5); writer.Write(this.ProjectionRow2);
writer.Write(this.UnkFloat6);
writer.Write(this.UnkFloat7);
writer.Write(this.UnkUint2); writer.Write(this.UnkUint2);
writer.Write(this.UnkFloat9); writer.Write(this.ProjectionRow3);
writer.Write(this.UnkFloat10);
writer.Write(this.UnkFloat11);
writer.Write(this.UnkUint3); writer.Write(this.UnkUint3);
writer.Write(this.UnkFloat13); writer.Write(this.UnkFloat13);
writer.Write(this.UnkFloat14); writer.Write(this.UnkFloat14);
writer.Write(this.UnkFloat15); writer.Write(this.UnkFloat15);
writer.Write(this.UnkFloat16); writer.Write(this.UnkFloat16);
this.VertexDeclaration.Write(writer); this.VertexDeclaration.Write(writer);
writer.Write(this.UnkFloat17); writer.Write(this.Thickness);
writer.Write(this.UnkUshort1); writer.Write(this.UnkUshort1);
writer.Write(this.Flags); writer.Write(this.Flags);
writer.Write(this.UnkFloat18); writer.Write(this.UnkFloat18);
writer.Write(this.UnkFloat19); writer.Write(this.UnkFloat19);
writer.Write(this.UnkFloat20); writer.Write(this.Tangent);
writer.Write(this.UnkFloat21);
writer.Write(this.UnkFloat22);
writer.Write(this.UnkUint4); writer.Write(this.UnkUint4);
} }
public void WriteXml(StringBuilder sb, int indent) public void WriteXml(StringBuilder sb, int indent)
{ {
YftXml.ValueTag(sb, indent, "Flags", Flags.ToString()); YftXml.ValueTag(sb, indent, "Flags", Flags.ToString());
YftXml.ValueTag(sb, indent, "UnkFloat1", FloatUtil.ToString(UnkFloat1)); YftXml.OpenTag(sb, indent, "Projection");
YftXml.ValueTag(sb, indent, "UnkFloat2", FloatUtil.ToString(UnkFloat2)); YftXml.WriteRawArrayContent(sb, new Matrix3x3() { Row1 = ProjectionRow1, Row2 = ProjectionRow2, Row3 = ProjectionRow3 }.ToArray(), indent + 1, FloatUtil.ToString, 3);
YftXml.ValueTag(sb, indent, "UnkFloat3", FloatUtil.ToString(UnkFloat3)); YftXml.CloseTag(sb, indent, "Projection");
YftXml.ValueTag(sb, indent, "UnkFloat5", FloatUtil.ToString(UnkFloat5));
YftXml.ValueTag(sb, indent, "UnkFloat6", FloatUtil.ToString(UnkFloat6));
YftXml.ValueTag(sb, indent, "UnkFloat7", FloatUtil.ToString(UnkFloat7));
YftXml.ValueTag(sb, indent, "UnkFloat9", FloatUtil.ToString(UnkFloat9));
YftXml.ValueTag(sb, indent, "UnkFloat10", FloatUtil.ToString(UnkFloat10));
YftXml.ValueTag(sb, indent, "UnkFloat11", FloatUtil.ToString(UnkFloat11));
YftXml.ValueTag(sb, indent, "UnkFloat13", FloatUtil.ToString(UnkFloat13)); YftXml.ValueTag(sb, indent, "UnkFloat13", FloatUtil.ToString(UnkFloat13));
YftXml.ValueTag(sb, indent, "UnkFloat14", FloatUtil.ToString(UnkFloat14)); YftXml.ValueTag(sb, indent, "UnkFloat14", FloatUtil.ToString(UnkFloat14));
YftXml.ValueTag(sb, indent, "UnkFloat15", FloatUtil.ToString(UnkFloat15)); YftXml.ValueTag(sb, indent, "UnkFloat15", FloatUtil.ToString(UnkFloat15));
YftXml.ValueTag(sb, indent, "UnkFloat16", FloatUtil.ToString(UnkFloat16)); YftXml.ValueTag(sb, indent, "UnkFloat16", FloatUtil.ToString(UnkFloat16));
YftXml.ValueTag(sb, indent, "UnkFloat17", FloatUtil.ToString(UnkFloat17)); YftXml.ValueTag(sb, indent, "Thickness", FloatUtil.ToString(Thickness));
YftXml.ValueTag(sb, indent, "UnkFloat18", FloatUtil.ToString(UnkFloat18)); YftXml.ValueTag(sb, indent, "UnkFloat18", FloatUtil.ToString(UnkFloat18));
YftXml.ValueTag(sb, indent, "UnkFloat19", FloatUtil.ToString(UnkFloat19)); YftXml.ValueTag(sb, indent, "UnkFloat19", FloatUtil.ToString(UnkFloat19));
YftXml.ValueTag(sb, indent, "UnkFloat20", FloatUtil.ToString(UnkFloat20)); YftXml.SelfClosingTag(sb, indent, "Tangent " + FloatUtil.GetVector3XmlString(Tangent));
YftXml.ValueTag(sb, indent, "UnkFloat21", FloatUtil.ToString(UnkFloat21));
YftXml.ValueTag(sb, indent, "UnkFloat22", FloatUtil.ToString(UnkFloat22));
VertexDeclaration.WriteXml(sb, indent, "Layout"); VertexDeclaration.WriteXml(sb, indent, "Layout");
} }
public void ReadXml(XmlNode node) public void ReadXml(XmlNode node)
{ {
Flags = (ushort)Xml.GetChildUIntAttribute(node, "Flags", "value"); Flags = (ushort)Xml.GetChildUIntAttribute(node, "Flags", "value");
UnkFloat1 = Xml.GetChildFloatAttribute(node, "UnkFloat1", "value"); var proj = Xml.GetChildRawFloatArray(node, "Projection");
UnkFloat2 = Xml.GetChildFloatAttribute(node, "UnkFloat2", "value"); if ((proj?.Length ?? 0) == 9)
UnkFloat3 = Xml.GetChildFloatAttribute(node, "UnkFloat3", "value"); {
UnkFloat5 = Xml.GetChildFloatAttribute(node, "UnkFloat5", "value"); ProjectionRow1 = new Vector3(proj[0], proj[1], proj[2]);
UnkFloat6 = Xml.GetChildFloatAttribute(node, "UnkFloat6", "value"); ProjectionRow2 = new Vector3(proj[3], proj[4], proj[5]);
UnkFloat7 = Xml.GetChildFloatAttribute(node, "UnkFloat7", "value"); ProjectionRow3 = new Vector3(proj[6], proj[7], proj[8]);
UnkFloat9 = Xml.GetChildFloatAttribute(node, "UnkFloat9", "value"); }
UnkFloat10 = Xml.GetChildFloatAttribute(node, "UnkFloat10", "value");
UnkFloat11 = Xml.GetChildFloatAttribute(node, "UnkFloat11", "value");
UnkFloat13 = Xml.GetChildFloatAttribute(node, "UnkFloat13", "value"); UnkFloat13 = Xml.GetChildFloatAttribute(node, "UnkFloat13", "value");
UnkFloat14 = Xml.GetChildFloatAttribute(node, "UnkFloat14", "value"); UnkFloat14 = Xml.GetChildFloatAttribute(node, "UnkFloat14", "value");
UnkFloat15 = Xml.GetChildFloatAttribute(node, "UnkFloat15", "value"); UnkFloat15 = Xml.GetChildFloatAttribute(node, "UnkFloat15", "value");
UnkFloat16 = Xml.GetChildFloatAttribute(node, "UnkFloat16", "value"); UnkFloat16 = Xml.GetChildFloatAttribute(node, "UnkFloat16", "value");
UnkFloat17 = Xml.GetChildFloatAttribute(node, "UnkFloat17", "value"); Thickness = Xml.GetChildFloatAttribute(node, "Thickness", "value");
UnkFloat18 = Xml.GetChildFloatAttribute(node, "UnkFloat18", "value"); UnkFloat18 = Xml.GetChildFloatAttribute(node, "UnkFloat18", "value");
UnkFloat19 = Xml.GetChildFloatAttribute(node, "UnkFloat19", "value"); UnkFloat19 = Xml.GetChildFloatAttribute(node, "UnkFloat19", "value");
UnkFloat20 = Xml.GetChildFloatAttribute(node, "UnkFloat20", "value"); Tangent = Xml.GetChildVector3Attributes(node, "Tangent");
UnkFloat21 = Xml.GetChildFloatAttribute(node, "UnkFloat21", "value");
UnkFloat22 = Xml.GetChildFloatAttribute(node, "UnkFloat22", "value");
VertexDeclaration.ReadXml(node.SelectSingleNode("Layout")); VertexDeclaration.ReadXml(node.SelectSingleNode("Layout"));
} }
} }
@ -1308,22 +1272,7 @@ namespace CodeWalker.GameFiles
} }
[TypeConverter(typeof(ExpandableObjectConverter))] public class Window [TypeConverter(typeof(ExpandableObjectConverter))] public class Window
{ {
public float UnkFloat1 { get; set; } public Matrix Projection { get; set; } //NOTE: M44 is not actually part of this matrix, what actually is it? the value needs to be 1.0 for projection to be correct, but file contains other values. maybe some scaling factor?
public float UnkFloat2 { get; set; }
public float UnkFloat3 { get; set; }
public float UnkFloat4; // 0
public float UnkFloat5 { get; set; }
public float UnkFloat6 { get; set; }
public float UnkFloat7 { get; set; }
public float UnkFloat8; // 0
public float UnkFloat9 { get; set; }
public float UnkFloat10 { get; set; }
public float UnkFloat11 { get; set; }
public float UnkFloat12; // 0
public float UnkFloat13 { get; set; }
public float UnkFloat14 { get; set; }
public float UnkFloat15 { get; set; }
public float UnkFloat16 { get; set; }
public uint UnkUint1 { get; set; } = 0x56475743; // "VGWC" vehicle glass window C..? public uint UnkUint1 { get; set; } = 0x56475743; // "VGWC" vehicle glass window C..?
public ushort ItemID { get; set; } public ushort ItemID { get; set; }
public ushort UnkUshort1 { get; set; } public ushort UnkUshort1 { get; set; }
@ -1373,22 +1322,7 @@ namespace CodeWalker.GameFiles
public void Read(ResourceDataReader reader) public void Read(ResourceDataReader reader)
{ {
UnkFloat1 = reader.ReadSingle(); Projection = reader.ReadMatrix();
UnkFloat2 = reader.ReadSingle();
UnkFloat3 = reader.ReadSingle();
UnkFloat4 = reader.ReadSingle();
UnkFloat5 = reader.ReadSingle();
UnkFloat6 = reader.ReadSingle();
UnkFloat7 = reader.ReadSingle();
UnkFloat8 = reader.ReadSingle();
UnkFloat9 = reader.ReadSingle();
UnkFloat10 = reader.ReadSingle();
UnkFloat11 = reader.ReadSingle();
UnkFloat12 = reader.ReadSingle();
UnkFloat13 = reader.ReadSingle();
UnkFloat14 = reader.ReadSingle();
UnkFloat15 = reader.ReadSingle();
UnkFloat16 = reader.ReadSingle();
UnkUint1 = reader.ReadUInt32(); //0x56475743 "VGWC" UnkUint1 = reader.ReadUInt32(); //0x56475743 "VGWC"
ItemID = reader.ReadUInt16(); ItemID = reader.ReadUInt16();
UnkUshort1 = reader.ReadUInt16(); UnkUshort1 = reader.ReadUInt16();
@ -1513,22 +1447,7 @@ namespace CodeWalker.GameFiles
} }
public void Write(ResourceDataWriter writer) public void Write(ResourceDataWriter writer)
{ {
writer.Write(UnkFloat1); writer.Write(Projection);
writer.Write(UnkFloat2);
writer.Write(UnkFloat3);
writer.Write(UnkFloat4);
writer.Write(UnkFloat5);
writer.Write(UnkFloat6);
writer.Write(UnkFloat7);
writer.Write(UnkFloat8);
writer.Write(UnkFloat9);
writer.Write(UnkFloat10);
writer.Write(UnkFloat11);
writer.Write(UnkFloat12);
writer.Write(UnkFloat13);
writer.Write(UnkFloat14);
writer.Write(UnkFloat15);
writer.Write(UnkFloat16);
writer.Write(UnkUint1); writer.Write(UnkUint1);
writer.Write(ItemID); writer.Write(ItemID);
writer.Write(UnkUshort1); writer.Write(UnkUshort1);
@ -1567,19 +1486,9 @@ namespace CodeWalker.GameFiles
YftXml.ValueTag(sb, indent, "UnkUshort1", UnkUshort1.ToString()); YftXml.ValueTag(sb, indent, "UnkUshort1", UnkUshort1.ToString());
YftXml.ValueTag(sb, indent, "UnkUshort4", UnkUshort4.ToString()); YftXml.ValueTag(sb, indent, "UnkUshort4", UnkUshort4.ToString());
YftXml.ValueTag(sb, indent, "UnkUshort5", UnkUshort5.ToString()); YftXml.ValueTag(sb, indent, "UnkUshort5", UnkUshort5.ToString());
YftXml.ValueTag(sb, indent, "UnkFloat1", FloatUtil.ToString(UnkFloat1)); YftXml.OpenTag(sb, indent, "Projection");
YftXml.ValueTag(sb, indent, "UnkFloat2", FloatUtil.ToString(UnkFloat2)); YftXml.WriteRawArrayContent(sb, Projection.ToArray(), indent + 1, FloatUtil.ToString, 4);
YftXml.ValueTag(sb, indent, "UnkFloat3", FloatUtil.ToString(UnkFloat3)); YftXml.CloseTag(sb, indent, "Projection");
YftXml.ValueTag(sb, indent, "UnkFloat5", FloatUtil.ToString(UnkFloat5));
YftXml.ValueTag(sb, indent, "UnkFloat6", FloatUtil.ToString(UnkFloat6));
YftXml.ValueTag(sb, indent, "UnkFloat7", FloatUtil.ToString(UnkFloat7));
YftXml.ValueTag(sb, indent, "UnkFloat9", FloatUtil.ToString(UnkFloat9));
YftXml.ValueTag(sb, indent, "UnkFloat10", FloatUtil.ToString(UnkFloat10));
YftXml.ValueTag(sb, indent, "UnkFloat11", FloatUtil.ToString(UnkFloat11));
YftXml.ValueTag(sb, indent, "UnkFloat13", FloatUtil.ToString(UnkFloat13));
YftXml.ValueTag(sb, indent, "UnkFloat14", FloatUtil.ToString(UnkFloat14));
YftXml.ValueTag(sb, indent, "UnkFloat15", FloatUtil.ToString(UnkFloat15));
YftXml.ValueTag(sb, indent, "UnkFloat16", FloatUtil.ToString(UnkFloat16));
YftXml.ValueTag(sb, indent, "UnkFloat17", FloatUtil.ToString(UnkFloat17)); YftXml.ValueTag(sb, indent, "UnkFloat17", FloatUtil.ToString(UnkFloat17));
YftXml.ValueTag(sb, indent, "UnkFloat18", FloatUtil.ToString(UnkFloat18)); YftXml.ValueTag(sb, indent, "UnkFloat18", FloatUtil.ToString(UnkFloat18));
YftXml.ValueTag(sb, indent, "CracksTextureTiling", FloatUtil.ToString(CracksTextureTiling)); YftXml.ValueTag(sb, indent, "CracksTextureTiling", FloatUtil.ToString(CracksTextureTiling));
@ -1601,19 +1510,7 @@ namespace CodeWalker.GameFiles
UnkUshort1 = (ushort)Xml.GetChildUIntAttribute(node, "UnkUshort1", "value"); UnkUshort1 = (ushort)Xml.GetChildUIntAttribute(node, "UnkUshort1", "value");
UnkUshort4 = (ushort)Xml.GetChildUIntAttribute(node, "UnkUshort4", "value"); UnkUshort4 = (ushort)Xml.GetChildUIntAttribute(node, "UnkUshort4", "value");
UnkUshort5 = (ushort)Xml.GetChildUIntAttribute(node, "UnkUshort5", "value"); UnkUshort5 = (ushort)Xml.GetChildUIntAttribute(node, "UnkUshort5", "value");
UnkFloat1 = Xml.GetChildFloatAttribute(node, "UnkFloat1", "value"); Projection = Xml.GetChildMatrix(node, "Projection");
UnkFloat2 = Xml.GetChildFloatAttribute(node, "UnkFloat2", "value");
UnkFloat3 = Xml.GetChildFloatAttribute(node, "UnkFloat3", "value");
UnkFloat5 = Xml.GetChildFloatAttribute(node, "UnkFloat5", "value");
UnkFloat6 = Xml.GetChildFloatAttribute(node, "UnkFloat6", "value");
UnkFloat7 = Xml.GetChildFloatAttribute(node, "UnkFloat7", "value");
UnkFloat9 = Xml.GetChildFloatAttribute(node, "UnkFloat9", "value");
UnkFloat10 = Xml.GetChildFloatAttribute(node, "UnkFloat10", "value");
UnkFloat11 = Xml.GetChildFloatAttribute(node, "UnkFloat11", "value");
UnkFloat13 = Xml.GetChildFloatAttribute(node, "UnkFloat13", "value");
UnkFloat14 = Xml.GetChildFloatAttribute(node, "UnkFloat14", "value");
UnkFloat15 = Xml.GetChildFloatAttribute(node, "UnkFloat15", "value");
UnkFloat16 = Xml.GetChildFloatAttribute(node, "UnkFloat16", "value");
UnkFloat17 = Xml.GetChildFloatAttribute(node, "UnkFloat17", "value"); UnkFloat17 = Xml.GetChildFloatAttribute(node, "UnkFloat17", "value");
UnkFloat18 = Xml.GetChildFloatAttribute(node, "UnkFloat18", "value"); UnkFloat18 = Xml.GetChildFloatAttribute(node, "UnkFloat18", "value");
CracksTextureTiling = Xml.GetChildFloatAttribute(node, "CracksTextureTiling", "value"); CracksTextureTiling = Xml.GetChildFloatAttribute(node, "CracksTextureTiling", "value");
@ -2216,7 +2113,7 @@ namespace CodeWalker.GameFiles
public float Unknown_1Ch { get; set; } public float Unknown_1Ch { get; set; }
public ulong ArticulatedBodyTypePointer { get; set; } public ulong ArticulatedBodyTypePointer { get; set; }
public ulong ChildrenUnkFloatsPointer { get; set; } public ulong ChildrenUnkFloatsPointer { get; set; }
public Vector3 Unknown_30h { get; set; } public Vector3 PositionOffset { get; set; }
public uint Unknown_3Ch { get; set; } = 0x7fc00001; // 0x7f800001, 0x7fc00001 public uint Unknown_3Ch { get; set; } = 0x7fc00001; // 0x7f800001, 0x7fc00001
public Vector3 Unknown_40h { get; set; } public Vector3 Unknown_40h { get; set; }
public uint Unknown_4Ch { get; set; } = 0x7fc00001; // 0x7f800001, 0x7fc00001 public uint Unknown_4Ch { get; set; } = 0x7fc00001; // 0x7f800001, 0x7fc00001
@ -2291,7 +2188,7 @@ namespace CodeWalker.GameFiles
this.Unknown_1Ch = reader.ReadSingle(); this.Unknown_1Ch = reader.ReadSingle();
this.ArticulatedBodyTypePointer = reader.ReadUInt64(); this.ArticulatedBodyTypePointer = reader.ReadUInt64();
this.ChildrenUnkFloatsPointer = reader.ReadUInt64(); this.ChildrenUnkFloatsPointer = reader.ReadUInt64();
this.Unknown_30h = reader.ReadVector3(); this.PositionOffset = reader.ReadVector3();
this.Unknown_3Ch = reader.ReadUInt32(); this.Unknown_3Ch = reader.ReadUInt32();
this.Unknown_40h = reader.ReadVector3(); this.Unknown_40h = reader.ReadVector3();
this.Unknown_4Ch = reader.ReadUInt32(); this.Unknown_4Ch = reader.ReadUInt32();
@ -2490,7 +2387,7 @@ namespace CodeWalker.GameFiles
writer.Write(this.Unknown_1Ch); writer.Write(this.Unknown_1Ch);
writer.Write(this.ArticulatedBodyTypePointer); writer.Write(this.ArticulatedBodyTypePointer);
writer.Write(this.ChildrenUnkFloatsPointer); writer.Write(this.ChildrenUnkFloatsPointer);
writer.Write(this.Unknown_30h); writer.Write(this.PositionOffset);
writer.Write(this.Unknown_3Ch); writer.Write(this.Unknown_3Ch);
writer.Write(this.Unknown_40h); writer.Write(this.Unknown_40h);
writer.Write(this.Unknown_4Ch); writer.Write(this.Unknown_4Ch);
@ -2535,7 +2432,7 @@ namespace CodeWalker.GameFiles
YftXml.ValueTag(sb, indent, "Unknown14", FloatUtil.ToString(Unknown_14h)); YftXml.ValueTag(sb, indent, "Unknown14", FloatUtil.ToString(Unknown_14h));
YftXml.ValueTag(sb, indent, "Unknown18", FloatUtil.ToString(Unknown_18h)); YftXml.ValueTag(sb, indent, "Unknown18", FloatUtil.ToString(Unknown_18h));
YftXml.ValueTag(sb, indent, "Unknown1C", FloatUtil.ToString(Unknown_1Ch)); YftXml.ValueTag(sb, indent, "Unknown1C", FloatUtil.ToString(Unknown_1Ch));
YftXml.SelfClosingTag(sb, indent, "Unknown30 " + FloatUtil.GetVector3XmlString(Unknown_30h)); YftXml.SelfClosingTag(sb, indent, "PositionOffset " + FloatUtil.GetVector3XmlString(PositionOffset));
YftXml.SelfClosingTag(sb, indent, "Unknown40 " + FloatUtil.GetVector3XmlString(Unknown_40h)); YftXml.SelfClosingTag(sb, indent, "Unknown40 " + FloatUtil.GetVector3XmlString(Unknown_40h));
YftXml.SelfClosingTag(sb, indent, "Unknown50 " + FloatUtil.GetVector3XmlString(Unknown_50h)); YftXml.SelfClosingTag(sb, indent, "Unknown50 " + FloatUtil.GetVector3XmlString(Unknown_50h));
YftXml.SelfClosingTag(sb, indent, "DampingLinearC " + FloatUtil.GetVector3XmlString(DampingLinearC)); YftXml.SelfClosingTag(sb, indent, "DampingLinearC " + FloatUtil.GetVector3XmlString(DampingLinearC));
@ -2610,7 +2507,7 @@ namespace CodeWalker.GameFiles
Unknown_14h = Xml.GetChildFloatAttribute(node, "Unknown14", "value"); Unknown_14h = Xml.GetChildFloatAttribute(node, "Unknown14", "value");
Unknown_18h = Xml.GetChildFloatAttribute(node, "Unknown18", "value"); Unknown_18h = Xml.GetChildFloatAttribute(node, "Unknown18", "value");
Unknown_1Ch = Xml.GetChildFloatAttribute(node, "Unknown1C", "value"); Unknown_1Ch = Xml.GetChildFloatAttribute(node, "Unknown1C", "value");
Unknown_30h = Xml.GetChildVector3Attributes(node, "Unknown30"); PositionOffset = Xml.GetChildVector3Attributes(node, "PositionOffset");
Unknown_40h = Xml.GetChildVector3Attributes(node, "Unknown40"); Unknown_40h = Xml.GetChildVector3Attributes(node, "Unknown40");
Unknown_50h = Xml.GetChildVector3Attributes(node, "Unknown50"); Unknown_50h = Xml.GetChildVector3Attributes(node, "Unknown50");
DampingLinearC = Xml.GetChildVector3Attributes(node, "DampingLinearC"); DampingLinearC = Xml.GetChildVector3Attributes(node, "DampingLinearC");
@ -2714,15 +2611,67 @@ namespace CodeWalker.GameFiles
var rootgrps = 0; var rootgrps = 0;
if (Groups?.data_items != null) if (Groups?.data_items != null)
{ {
foreach (var grp in Groups.data_items) for (int i = 0; i < Groups.data_items.Length; i++)
{ {
var grp = Groups.data_items[i];
grpnames.Add(grp.Name); grpnames.Add(grp.Name);
if (grp.ParentIndex == 255) if (grp.ParentIndex == 255)
{ {
rootgrps++; rootgrps++;
} }
//else if (grp.ParentGroupIndex >= Groups.data_items.Length)
//{ }//testing
////just testing
//var childGroupIndex = grp.ChildGroupIndex;
//var childGroupCount = grp.ChildGroupCount;
//var childIndex = grp.ChildIndex;
//var childCount = grp.ChildCount;
grp.ChildGroupIndex = 255;
grp.ChildGroupCount = 0;
grp.ChildIndex = 255;
grp.ChildCount = 0;
bool childfound = false;
for(int ii = 0; ii < Groups.data_items.Length; ii++)
{
var grp2 = Groups.data_items[ii];
if (grp2.ParentIndex == i)
{
grp.ChildGroupCount++;
if (childfound == false)
{
grp.ChildGroupIndex = (byte)ii;
childfound = true;
}
}
}
childfound = false;
var childrencount = Children?.data_items?.Length ?? 0;
for (int ii = 0; ii < childrencount; ii++)
{
var child = Children.data_items[ii];
if (child == null) continue;
if (child.GroupIndex == i)
{
grp.ChildCount++;
if (childfound == false)
{
grp.ChildIndex = (byte)ii;
childfound = true;
}
}
}
////just testing
//if (grp.ChildGroupIndex != childGroupIndex)
//{ }
//if (grp.ChildGroupCount != childGroupCount)
//{ }
//if (grp.ChildIndex != childIndex)
//{ }
//if (grp.ChildCount != childCount)
//{ }
} }
} }
@ -3997,12 +3946,12 @@ namespace CodeWalker.GameFiles
public float LatchStrength { get; set; } public float LatchStrength { get; set; }
public float Mass { get; set; } public float Mass { get; set; }
public float Unknown_48h; // 0x00000000 public float Unknown_48h; // 0x00000000
public byte UnkByte4C { get; set; } public byte ChildGroupIndex { get; set; } //index of the first child group of this group, 255 if no children - calc on XML import! (from ParentIndex)
public byte ParentIndex { get; set; } public byte ParentIndex { get; set; } //index of the parent group.
public byte Index { get; set; } public byte ChildIndex { get; set; } //index of first BoundComposite child, AND fragment child - calc on XML import! (from FragPhysTypeChild.GroupIndex)
public byte ChildCount { get; set; } public byte ChildCount { get; set; } //number of BoundComposite children, AND fragment children - calc on XML import! (from FragPhysTypeChild.GroupIndex)
public byte GroupCount { get; set; } public byte ChildGroupCount { get; set; } //number of groups with this as the direct parent - calc on XML import! (from ParentIndex)
public byte UnkByte51 { get; set; } = 255; //0xFF public byte UnkByte51 { get; set; } = 255; //0xFF (always)
public byte GlassWindowIndex { get; set; }//GlassWindows index public byte GlassWindowIndex { get; set; }//GlassWindows index
public byte GlassFlags { get; set; }//flags: 1=?, 2=glass, 4=?, ... public byte GlassFlags { get; set; }//flags: 1=?, 2=glass, 4=?, ...
public float MinDamageForce { get; set; } public float MinDamageForce { get; set; }
@ -4041,11 +3990,11 @@ namespace CodeWalker.GameFiles
this.LatchStrength = reader.ReadSingle(); this.LatchStrength = reader.ReadSingle();
this.Mass = reader.ReadSingle(); this.Mass = reader.ReadSingle();
this.Unknown_48h = reader.ReadSingle(); this.Unknown_48h = reader.ReadSingle();
this.UnkByte4C = reader.ReadByte(); this.ChildGroupIndex = reader.ReadByte();
this.ParentIndex = reader.ReadByte(); this.ParentIndex = reader.ReadByte();
this.Index = reader.ReadByte(); this.ChildIndex = reader.ReadByte();
this.ChildCount = reader.ReadByte(); this.ChildCount = reader.ReadByte();
this.GroupCount = reader.ReadByte(); this.ChildGroupCount = reader.ReadByte();
this.UnkByte51 = reader.ReadByte(); this.UnkByte51 = reader.ReadByte();
this.GlassWindowIndex = reader.ReadByte(); this.GlassWindowIndex = reader.ReadByte();
this.GlassFlags = reader.ReadByte(); this.GlassFlags = reader.ReadByte();
@ -4164,11 +4113,11 @@ namespace CodeWalker.GameFiles
writer.Write(LatchStrength); writer.Write(LatchStrength);
writer.Write(Mass); writer.Write(Mass);
writer.Write(Unknown_48h); writer.Write(Unknown_48h);
writer.Write(UnkByte4C); writer.Write(ChildGroupIndex);
writer.Write(ParentIndex); writer.Write(ParentIndex);
writer.Write(Index); writer.Write(ChildIndex);
writer.Write(ChildCount); writer.Write(ChildCount);
writer.Write(GroupCount); writer.Write(ChildGroupCount);
writer.Write(UnkByte51); writer.Write(UnkByte51);
writer.Write(GlassWindowIndex); writer.Write(GlassWindowIndex);
writer.Write(GlassFlags); writer.Write(GlassFlags);
@ -4190,12 +4139,7 @@ namespace CodeWalker.GameFiles
public void WriteXml(StringBuilder sb, int indent) public void WriteXml(StringBuilder sb, int indent)
{ {
YftXml.StringTag(sb, indent, "Name", YftXml.XmlEscape(Name.ToString())); YftXml.StringTag(sb, indent, "Name", YftXml.XmlEscape(Name.ToString()));
YftXml.ValueTag(sb, indent, "Index", Index.ToString());
YftXml.ValueTag(sb, indent, "ParentIndex", ParentIndex.ToString()); YftXml.ValueTag(sb, indent, "ParentIndex", ParentIndex.ToString());
YftXml.ValueTag(sb, indent, "UnkByte4C", UnkByte4C.ToString());
YftXml.ValueTag(sb, indent, "ChildCount", ChildCount.ToString());
YftXml.ValueTag(sb, indent, "GroupCount", GroupCount.ToString());
YftXml.ValueTag(sb, indent, "UnkByte51", UnkByte51.ToString());
YftXml.ValueTag(sb, indent, "GlassWindowIndex", GlassWindowIndex.ToString()); YftXml.ValueTag(sb, indent, "GlassWindowIndex", GlassWindowIndex.ToString());
YftXml.ValueTag(sb, indent, "GlassFlags", GlassFlags.ToString()); YftXml.ValueTag(sb, indent, "GlassFlags", GlassFlags.ToString());
YftXml.ValueTag(sb, indent, "Strength", FloatUtil.ToString(Strength)); YftXml.ValueTag(sb, indent, "Strength", FloatUtil.ToString(Strength));
@ -4227,12 +4171,7 @@ namespace CodeWalker.GameFiles
public void ReadXml(XmlNode node) public void ReadXml(XmlNode node)
{ {
Name = new FragPhysNameStruct_s(Xml.GetChildInnerText(node, "Name")); Name = new FragPhysNameStruct_s(Xml.GetChildInnerText(node, "Name"));
Index = (byte)Xml.GetChildUIntAttribute(node, "Index", "value");
ParentIndex = (byte)Xml.GetChildUIntAttribute(node, "ParentIndex", "value"); ParentIndex = (byte)Xml.GetChildUIntAttribute(node, "ParentIndex", "value");
UnkByte4C = (byte)Xml.GetChildUIntAttribute(node, "UnkByte4C", "value");
ChildCount = (byte)Xml.GetChildUIntAttribute(node, "ChildCount", "value");
GroupCount = (byte)Xml.GetChildUIntAttribute(node, "GroupCount", "value");
UnkByte51 = (byte)Xml.GetChildUIntAttribute(node, "UnkByte51", "value");
GlassWindowIndex = (byte)Xml.GetChildUIntAttribute(node, "GlassWindowIndex", "value"); GlassWindowIndex = (byte)Xml.GetChildUIntAttribute(node, "GlassWindowIndex", "value");
GlassFlags = (byte)Xml.GetChildUIntAttribute(node, "GlassFlags", "value"); GlassFlags = (byte)Xml.GetChildUIntAttribute(node, "GlassFlags", "value");
Strength = Xml.GetChildFloatAttribute(node, "Strength", "value"); Strength = Xml.GetChildFloatAttribute(node, "Strength", "value");

View File

@ -209,7 +209,7 @@ namespace CodeWalker.Rendering
{ {
fragtransforms = phys.OwnerFragPhysLod.FragTransforms?.Matrices; fragtransforms = phys.OwnerFragPhysLod.FragTransforms?.Matrices;
fragtransformid = phys.OwnerFragPhysIndex; fragtransformid = phys.OwnerFragPhysIndex;
fragoffset = new Vector4(phys.OwnerFragPhysLod.Unknown_30h, 0.0f); fragoffset = new Vector4(phys.OwnerFragPhysLod.PositionOffset, 0.0f);
switch (phys.BoneTag) //right hand side wheel flip! switch (phys.BoneTag) //right hand side wheel flip!

View File

@ -2938,23 +2938,23 @@ namespace CodeWalker.Rendering
for (int i = 0; i < f.GlassWindows.data_items.Length; i++) for (int i = 0; i < f.GlassWindows.data_items.Length; i++)
{ {
var gw = f.GlassWindows.data_items[i]; var gw = f.GlassWindows.data_items[i];
var projt = new Vector3(gw.UnkFloat1, gw.UnkFloat2, gw.UnkFloat3);//row0? or row3? maybe investigate more var projt = gw.ProjectionRow1;//row0? or row3? maybe investigate more
var proju = new Vector3(gw.UnkFloat5, gw.UnkFloat6, gw.UnkFloat7);//row1 of XYZ>UV projection var proju = gw.ProjectionRow2;//row1 of XYZ>UV projection
var projv = new Vector3(gw.UnkFloat9, gw.UnkFloat10, gw.UnkFloat11);//row2 of XYZ>UV projection var projv = gw.ProjectionRow3;//row2 of XYZ>UV projection
//var unk01 = new Vector2(gw.UnkFloat13, gw.UnkFloat14);//offset? //var unk01 = new Vector2(gw.UnkFloat13, gw.UnkFloat14);//offset?
//var unk02 = new Vector2(gw.UnkFloat15, gw.UnkFloat16);//scale? sum of this and above often gives integers eg 1, 6 //var unk02 = new Vector2(gw.UnkFloat15, gw.UnkFloat16);//scale? sum of this and above often gives integers eg 1, 6
//var thick = gw.UnkFloat17; //thickness of the glass //var thick = gw.Thickness; //thickness of the glass
//var unkuv = new Vector2(gw.UnkFloat18, gw.UnkFloat19); //another scale in UV space..? //var unkuv = new Vector2(gw.UnkFloat18, gw.UnkFloat19); //another scale in UV space..?
//var tangt = new Vector3(gw.UnkFloat20, gw.UnkFloat21, gw.UnkFloat22);//direction of surface tangent //var tangt = gw.Tangent;//direction of surface tangent
//var bones = f.Drawable?.Skeleton?.Bones?.Items; //todo: use bones instead? //var bones = f.Drawable?.Skeleton?.Bones?.Items; //todo: use bones instead?
var grp = gw.Group; var grp = gw.Group;
var grplod = gw.GroupLOD; var grplod = gw.GroupLOD;
var xforms = grplod?.FragTransforms?.Matrices; var xforms = grplod?.FragTransforms?.Matrices;
var xoffs = Vector3.Zero; var xoffs = Vector3.Zero;
if ((grp != null) && (xforms != null) && (grp.Index < xforms.Length) && (grplod != null)) if ((grp != null) && (xforms != null) && (grp.ChildIndex < xforms.Length) && (grplod != null))
{ {
var xform = xforms[grp.Index]; var xform = xforms[grp.ChildIndex];
xoffs = xform.TranslationVector + grplod.Unknown_30h; xoffs = xform.TranslationVector + grplod.PositionOffset;
} }
var m = new Matrix(); var m = new Matrix();
m.Row1 = new Vector4(projt, 0); m.Row1 = new Vector4(projt, 0);
@ -2981,17 +2981,11 @@ namespace CodeWalker.Rendering
for (int i = 0; i < f.VehicleGlassWindows.Windows.Length; i++) for (int i = 0; i < f.VehicleGlassWindows.Windows.Length; i++)
{ {
var vgw = f.VehicleGlassWindows.Windows[i]; var vgw = f.VehicleGlassWindows.Windows[i];
var projt = new Vector3(vgw.UnkFloat1, vgw.UnkFloat2, vgw.UnkFloat3);//row1
var proju = new Vector3(vgw.UnkFloat5, vgw.UnkFloat6, vgw.UnkFloat7);//row2
var projv = new Vector3(vgw.UnkFloat9, vgw.UnkFloat10, vgw.UnkFloat11);//row3
var projw = new Vector3(vgw.UnkFloat13, vgw.UnkFloat14, vgw.UnkFloat15);//row4
//var grp = vgw.Group; //var grp = vgw.Group;
//var grplod = vgw.GroupLOD; //var grplod = vgw.GroupLOD;
var m = new Matrix(); var m = vgw.Projection;
m.Row1 = new Vector4(projt, 0); m.M44 = 1.0f;
m.Row2 = new Vector4(proju, 0); m.Transpose();
m.Row3 = new Vector4(projv, 0);
m.Row4 = new Vector4(projw, 1);
m.Invert();//ouch m.Invert();//ouch
var min = (new Vector3(0, 0, 0)); var min = (new Vector3(0, 0, 0));
var max = (new Vector3(vgw.ShatterMapWidth, vgw.ItemDataCount, 1)); var max = (new Vector3(vgw.ShatterMapWidth, vgw.ItemDataCount, 1));