public ValueDelta(EndianBinaryReader reader) { m_Start = reader.ReadSingle(); m_Stop = reader.ReadSingle(); }
private static void ReadStringValue(StringBuilder sb, List <ClassMember> members, EndianBinaryReader reader, ref int i) { var member = members[i]; var level = member.Level; var varTypeStr = member.Type; var varNameStr = member.Name; object value = null; var append = true; var align = (member.Flag & 0x4000) != 0; switch (varTypeStr) { case "SInt8": value = reader.ReadSByte(); break; case "UInt8": value = reader.ReadByte(); break; case "short": case "SInt16": value = reader.ReadInt16(); break; case "UInt16": case "unsigned short": value = reader.ReadUInt16(); break; case "int": case "SInt32": value = reader.ReadInt32(); break; case "UInt32": case "unsigned int": case "Type*": value = reader.ReadUInt32(); break; case "long long": case "SInt64": value = reader.ReadInt64(); break; case "UInt64": case "unsigned long long": value = reader.ReadUInt64(); break; case "float": value = reader.ReadSingle(); break; case "double": value = reader.ReadDouble(); break; case "bool": value = reader.ReadBoolean(); break; case "string": append = false; var str = reader.ReadAlignedString(); sb.AppendFormat("{0}{1} {2} = \"{3}\"\r\n", (new string('\t', level)), varTypeStr, varNameStr, str); i += 3; break; case "vector": case "staticvector": case "set": { if ((members[i + 1].Flag & 0x4000) != 0) { align = true; } append = false; sb.AppendFormat("{0}{1} {2}\r\n", (new string('\t', level)), varTypeStr, varNameStr); sb.AppendFormat("{0}{1} {2}\r\n", (new string('\t', level + 1)), "Array", "Array"); var size = reader.ReadInt32(); sb.AppendFormat("{0}{1} {2} = {3}\r\n", (new string('\t', level + 1)), "int", "size", size); var vector = GetMembers(members, level, i); i += vector.Count - 1; vector.RemoveRange(0, 3); for (int j = 0; j < size; j++) { sb.AppendFormat("{0}[{1}]\r\n", (new string('\t', level + 2)), j); int tmp = 0; ReadStringValue(sb, vector, reader, ref tmp); } break; } case "map": { if ((members[i + 1].Flag & 0x4000) != 0) { align = true; } append = false; sb.AppendFormat("{0}{1} {2}\r\n", (new string('\t', level)), varTypeStr, varNameStr); sb.AppendFormat("{0}{1} {2}\r\n", (new string('\t', level + 1)), "Array", "Array"); var size = reader.ReadInt32(); sb.AppendFormat("{0}{1} {2} = {3}\r\n", (new string('\t', level + 1)), "int", "size", size); var map = GetMembers(members, level, i); i += map.Count - 1; map.RemoveRange(0, 4); var first = GetMembers(map, map[0].Level, 0); map.RemoveRange(0, first.Count); var second = map; for (int j = 0; j < size; j++) { sb.AppendFormat("{0}[{1}]\r\n", (new string('\t', level + 2)), j); sb.AppendFormat("{0}{1} {2}\r\n", (new string('\t', level + 2)), "pair", "data"); int tmp1 = 0; int tmp2 = 0; ReadStringValue(sb, first, reader, ref tmp1); ReadStringValue(sb, second, reader, ref tmp2); } break; } case "TypelessData": { append = false; var size = reader.ReadInt32(); reader.ReadBytes(size); i += 2; sb.AppendFormat("{0}{1} {2}\r\n", (new string('\t', level)), varTypeStr, varNameStr); sb.AppendFormat("{0}{1} {2} = {3}\r\n", (new string('\t', level)), "int", "size", size); break; } default: { append = false; sb.AppendFormat("{0}{1} {2}\r\n", (new string('\t', level)), varTypeStr, varNameStr); var @class = GetMembers(members, level, i); @class.RemoveAt(0); i += @class.Count; for (int j = 0; j < @class.Count; j++) { ReadStringValue(sb, @class, reader, ref j); } break; } } if (append) { sb.AppendFormat("{0}{1} {2} = {3}\r\n", (new string('\t', level)), varTypeStr, varNameStr, value); } if (align) { reader.AlignStream(4); } }
private static object ReadValue(List <ClassMember> members, EndianBinaryReader reader, ref int i) { var member = members[i]; var level = member.Level; var varTypeStr = member.Type; object value; var align = (member.Flag & 0x4000) != 0; switch (varTypeStr) { case "SInt8": value = reader.ReadSByte(); break; case "UInt8": value = reader.ReadByte(); break; case "short": case "SInt16": value = reader.ReadInt16(); break; case "UInt16": case "unsigned short": value = reader.ReadUInt16(); break; case "int": case "SInt32": value = reader.ReadInt32(); break; case "UInt32": case "unsigned int": case "Type*": value = reader.ReadUInt32(); break; case "long long": case "SInt64": value = reader.ReadInt64(); break; case "UInt64": case "unsigned long long": value = reader.ReadUInt64(); break; case "float": value = reader.ReadSingle(); break; case "double": value = reader.ReadDouble(); break; case "bool": value = reader.ReadBoolean(); break; case "string": value = reader.ReadAlignedString(); i += 3; break; case "vector": case "staticvector": case "set": { if ((members[i + 1].Flag & 0x4000) != 0) { align = true; } var size = reader.ReadInt32(); var list = new List <object>(size); var vector = GetMembers(members, level, i); i += vector.Count - 1; vector.RemoveRange(0, 3); for (int j = 0; j < size; j++) { int tmp = 0; list.Add(ReadValue(vector, reader, ref tmp)); } value = list; break; } case "map": { if ((members[i + 1].Flag & 0x4000) != 0) { align = true; } var size = reader.ReadInt32(); var dic = new List <KeyValuePair <object, object> >(size); var map = GetMembers(members, level, i); i += map.Count - 1; map.RemoveRange(0, 4); var first = GetMembers(map, map[0].Level, 0); map.RemoveRange(0, first.Count); var second = map; for (int j = 0; j < size; j++) { int tmp1 = 0; int tmp2 = 0; dic.Add(new KeyValuePair <object, object>(ReadValue(first, reader, ref tmp1), ReadValue(second, reader, ref tmp2))); } value = dic; break; } case "TypelessData": { var size = reader.ReadInt32(); value = reader.ReadBytes(size); i += 2; break; } default: { var @class = GetMembers(members, level, i); @class.RemoveAt(0); i += @class.Count; var obj = new ExpandoObject(); var objdic = (IDictionary <string, object>)obj; for (int j = 0; j < @class.Count; j++) { var classmember = @class[j]; var name = classmember.Name; objdic[name] = ReadValue(@class, reader, ref j); } value = obj; break; } } if (align) { reader.AlignStream(4); } return(value); }
public static void ReadClassStruct(StringBuilder sb, List <ClassMember> members, EndianBinaryReader reader) { for (int i = 0; i < members.Count; i++) { var member = members[i]; var level = member.Level; var varTypeStr = member.Type; var varNameStr = member.Name; object value = null; var align = (member.Flag & 0x4000) != 0; var append = true; if (member.alignBefore) { reader.AlignStream(4); } switch (varTypeStr) { case "SInt8": value = reader.ReadSByte(); break; case "UInt8": value = reader.ReadByte(); break; case "short": case "SInt16": value = reader.ReadInt16(); break; case "UInt16": case "unsigned short": value = reader.ReadUInt16(); break; case "int": case "SInt32": value = reader.ReadInt32(); break; case "UInt32": case "unsigned int": case "Type*": value = reader.ReadUInt32(); break; case "long long": case "SInt64": value = reader.ReadInt64(); break; case "UInt64": case "unsigned long long": value = reader.ReadUInt64(); break; case "float": value = reader.ReadSingle(); break; case "double": value = reader.ReadDouble(); break; case "bool": value = reader.ReadBoolean(); break; case "string": append = false; var str = reader.ReadAlignedString(); sb.AppendFormat("{0}{1} {2} = \"{3}\"\r\n", (new string('\t', level)), varTypeStr, varNameStr, str); i += 3; //skip break; case "Array": { append = false; if ((members[i - 1].Flag & 0x4000) != 0) { align = true; } sb.AppendFormat("{0}{1} {2}\r\n", (new string('\t', level)), varTypeStr, varNameStr); var size = reader.ReadInt32(); sb.AppendFormat("{0}{1} {2} = {3}\r\n", (new string('\t', level)), "int", "size", size); var array = ReadArray(members, level, i); for (int j = 0; j < size; j++) { sb.AppendFormat("{0}[{1}]\r\n", (new string('\t', level + 1)), j); ReadClassStruct(sb, array, reader); } i += array.Count + 1; //skip break; } case "TypelessData": { append = false; var size = reader.ReadInt32(); reader.ReadBytes(size); i += 2; sb.AppendFormat("{0}{1} {2}\r\n", (new string('\t', level)), varTypeStr, varNameStr); sb.AppendFormat("{0}{1} {2} = {3}\r\n", (new string('\t', level)), "int", "size", size); break; } default: append = false; if (align) { align = false; SetAlignBefore(members, level, i + 1); } sb.AppendFormat("{0}{1} {2}\r\n", (new string('\t', level)), varTypeStr, varNameStr); break; } if (append) { sb.AppendFormat("{0}{1} {2} = {3}\r\n", (new string('\t', level)), varTypeStr, varNameStr, value); } if (align) { reader.AlignStream(4); } } }
public ClipMuscleConstant(EndianBinaryReader reader, int[] version) { m_DeltaPose = new HumanPose(reader, version); m_StartX = new xform(reader, version); if (version[0] > 5 || (version[0] == 5 && version[1] >= 5))//5.5 and up { m_StopX = new xform(reader, version); } m_LeftFootStartX = new xform(reader, version); m_RightFootStartX = new xform(reader, version); if (version[0] < 5)//5.0 down { m_MotionStartX = new xform(reader, version); m_MotionStopX = new xform(reader, version); } m_AverageSpeed = version[0] > 5 || (version[0] == 5 && version[1] >= 4) ? (object)reader.ReadVector3() : (object)reader.ReadVector4();//5.4 and up m_Clip = new Clip(reader, version); m_StartTime = reader.ReadSingle(); m_StopTime = reader.ReadSingle(); m_OrientationOffsetY = reader.ReadSingle(); m_Level = reader.ReadSingle(); m_CycleOffset = reader.ReadSingle(); m_AverageAngularSpeed = reader.ReadSingle(); int numIndices = reader.ReadInt32(); m_IndexArray = reader.ReadInt32Array(numIndices); if (version[0] < 4 || (version[0] == 4 && version[1] < 3)) //4.3 down { int numAdditionalCurveIndexs = reader.ReadInt32(); var m_AdditionalCurveIndexArray = new List <int>(numAdditionalCurveIndexs); for (int i = 0; i < numAdditionalCurveIndexs; i++) { m_AdditionalCurveIndexArray.Add(reader.ReadInt32()); } } int numDeltas = reader.ReadInt32(); m_ValueArrayDelta = new List <ValueDelta>(numDeltas); for (int i = 0; i < numDeltas; i++) { m_ValueArrayDelta.Add(new ValueDelta(reader)); } if (version[0] > 5 || (version[0] == 5 && version[1] >= 3))//5.3 and up { m_ValueArrayReferencePose = reader.ReadSingleArray(reader.ReadInt32()); } m_Mirror = reader.ReadBoolean(); m_LoopTime = reader.ReadBoolean(); m_LoopBlend = reader.ReadBoolean(); m_LoopBlendOrientation = reader.ReadBoolean(); m_LoopBlendPositionY = reader.ReadBoolean(); m_LoopBlendPositionXZ = reader.ReadBoolean(); if (version[0] > 5 || (version[0] == 5 && version[1] >= 5))//5.5 and up { m_StartAtOrigin = reader.ReadBoolean(); } m_KeepOriginalOrientation = reader.ReadBoolean(); m_KeepOriginalPositionY = reader.ReadBoolean(); m_KeepOriginalPositionXZ = reader.ReadBoolean(); m_HeightFromFeet = reader.ReadBoolean(); reader.AlignStream(4); }
public StateConstant(EndianBinaryReader reader, int[] version) { int numTransistions = reader.ReadInt32(); m_TransitionConstantArray = new TransitionConstant[numTransistions]; for (int i = 0; i < numTransistions; i++) { m_TransitionConstantArray[i] = new TransitionConstant(reader, version); } int numBlendIndices = reader.ReadInt32(); m_BlendTreeConstantIndexArray = new int[numBlendIndices]; for (int i = 0; i < numBlendIndices; i++) { m_BlendTreeConstantIndexArray[i] = reader.ReadInt32(); } if (version[0] < 5) //5.0 down { int numInfos = reader.ReadInt32(); m_LeafInfoArray = new LeafInfoConstant[numInfos]; for (int i = 0; i < numInfos; i++) { m_LeafInfoArray[i] = new LeafInfoConstant(reader); } } int numBlends = reader.ReadInt32(); m_BlendTreeConstantArray = new BlendTreeConstant[numBlends]; for (int i = 0; i < numBlends; i++) { m_BlendTreeConstantArray[i] = new BlendTreeConstant(reader, version); } m_NameID = reader.ReadUInt32(); m_PathID = reader.ReadUInt32(); if (version[0] >= 5) //5.0 and up { m_FullPathID = reader.ReadUInt32(); } m_TagID = reader.ReadUInt32(); if (version[0] >= 5) //5.0 and up { m_SpeedParamID = reader.ReadUInt32(); m_MirrorParamID = reader.ReadUInt32(); m_CycleOffsetParamID = reader.ReadUInt32(); } if (version[0] > 2017 || (version[0] == 2017 && version[1] >= 2)) //2017.2 and up { var m_TimeParamID = reader.ReadUInt32(); } m_Speed = reader.ReadSingle(); m_CycleOffset = reader.ReadSingle(); m_IKOnFeet = reader.ReadBoolean(); if (version[0] >= 5) //5.0 and up { m_WriteDefaultValues = reader.ReadBoolean(); } m_Loop = reader.ReadBoolean(); m_Mirror = reader.ReadBoolean(); reader.AlignStream(4); }
public SkeletonMaskElement(EndianBinaryReader reader) { m_PathHash = reader.ReadUInt32(); m_Weight = reader.ReadSingle(); }
public Human(EndianBinaryReader reader, int[] version) { m_RootX = new xform(reader, version); m_Skeleton = new Skeleton(reader, version); m_SkeletonPose = new SkeletonPose(reader, version); m_LeftHand = new Hand(reader); m_RightHand = new Hand(reader); if (version[0] < 2018 || (version[0] == 2018 && version[1] < 2)) //2018.2 down { int numHandles = reader.ReadInt32(); m_Handles = new List <Handle>(numHandles); for (int i = 0; i < numHandles; i++) { m_Handles.Add(new Handle(reader, version)); } int numColliders = reader.ReadInt32(); m_ColliderArray = new List <Collider>(numColliders); for (int i = 0; i < numColliders; i++) { m_ColliderArray.Add(new Collider(reader, version)); } } int numIndexes = reader.ReadInt32(); m_HumanBoneIndex = new List <int>(numIndexes); for (int i = 0; i < numIndexes; i++) { m_HumanBoneIndex.Add(reader.ReadInt32()); } int numMasses = reader.ReadInt32(); m_HumanBoneMass = new List <float>(numMasses); for (int i = 0; i < numMasses; i++) { m_HumanBoneMass.Add(reader.ReadSingle()); } if (version[0] < 2018 || (version[0] == 2018 && version[1] < 2)) //2018.2 down { int numColliderIndexes = reader.ReadInt32(); m_ColliderIndex = new List <int>(numColliderIndexes); for (int i = 0; i < numColliderIndexes; i++) { m_ColliderIndex.Add(reader.ReadInt32()); } } m_Scale = reader.ReadSingle(); m_ArmTwist = reader.ReadSingle(); m_ForeArmTwist = reader.ReadSingle(); m_UpperLegTwist = reader.ReadSingle(); m_LegTwist = reader.ReadSingle(); m_ArmStretch = reader.ReadSingle(); m_LegStretch = reader.ReadSingle(); m_FeetSpacing = reader.ReadSingle(); m_HasLeftHand = reader.ReadBoolean(); m_HasRightHand = reader.ReadBoolean(); m_HasTDoF = reader.ReadBoolean(); reader.AlignStream(4); }