public void FromPmxNode(PmxNode node, bool nonStr = false) { if (!nonStr) { Name = node.Name; NameE = node.NameE; } SystemNode = node.SystemNode; int count = node.ElementList.Count; ElementList.Clear(); ElementList.Capacity = count; for (int i = 0; i < count; i++) { ElementList.Add(node.ElementList[i].Clone()); } FromID(node); }
// Token: 0x06000203 RID: 515 RVA: 0x00011348 File Offset: 0x0000F548 public void FromPmxNode(PmxNode node, bool nonStr) { bool flag = !nonStr; if (flag) { this.Name = node.Name; this.NameE = node.NameE; } this.SystemNode = node.SystemNode; int count = node.ElementList.Count; this.ElementList.Clear(); this.ElementList.Capacity = count; for (int i = 0; i < count; i++) { this.ElementList.Add(node.ElementList[i].Clone()); } }
public Pmx() { Header = new PmxHeader(); ModelInfo = new PmxModelInfo(); VertexList = new List <PmxVertex>(); FaceList = new List <int>(); MaterialList = new List <PmxMaterial>(); BoneList = new List <PmxBone>(); MorphList = new List <PmxMorph>(); NodeList = new List <PmxNode>(); BodyList = new List <PmxBody>(); JointList = new List <PmxJoint>(); SoftBodyList = new List <PmxSoftBody>(); RootNode = new PmxNode(); ExpNode = new PmxNode(); InitializeSystemNode(); FilePath = ""; LoadErrCount = 0; }
// Token: 0x06000202 RID: 514 RVA: 0x00011333 File Offset: 0x0000F533 public PmxNode(PmxNode node, bool nonStr) : this() { this.FromPmxNode(node, nonStr); }
public virtual void FromStream(Stream s, bool id) { Action <Action> action = delegate(Action a) { try { a(); } catch (Exception) { LoadErrCount++; } }; PmxHeader head = new PmxHeader(); head.FromStreamEx(s); Header.FromHeader(head); head.ElementFormat.WithID = id; action(delegate { ModelInfo.FromStreamEx(s, head.ElementFormat); }); int count = 0; action(delegate { count = PmxStreamHelper.ReadElement_Int32(s); }); VertexList.Clear(); VertexList.Capacity = count; for (int k = 0; k < count; k++) { PmxVertex v = new PmxVertex(); action(delegate { v.FromStreamEx(s, head.ElementFormat); }); VertexList.Add(v); } action(delegate { count = PmxStreamHelper.ReadElement_Int32(s); }); FaceList.Clear(); FaceList.Capacity = count; for (int l = 0; l < count; l++) { int ix = 0; action(delegate { ix = PmxStreamHelper.ReadElement_Int32(s, head.ElementFormat.VertexSize, signed: false); }); FaceList.Add(ix); } PmxTextureTable tx = new PmxTextureTable(); action(delegate { tx.FromStreamEx(s, head.ElementFormat); }); action(delegate { count = PmxStreamHelper.ReadElement_Int32(s); }); MaterialList.Clear(); MaterialList.Capacity = count; for (int m = 0; m < count; m++) { PmxMaterial j = new PmxMaterial(); action(delegate { j.FromStreamEx_TexTable(s, tx, head.ElementFormat); }); MaterialList.Add(j); } action(delegate { count = PmxStreamHelper.ReadElement_Int32(s); }); BoneList.Clear(); BoneList.Capacity = count; for (int n = 0; n < count; n++) { PmxBone b = new PmxBone(); action(delegate { b.FromStreamEx(s, head.ElementFormat); }); BoneList.Add(b); } action(delegate { count = PmxStreamHelper.ReadElement_Int32(s); }); MorphList.Clear(); MorphList.Capacity = count; for (int num = 0; num < count; num++) { PmxMorph morph = new PmxMorph(); action(delegate { morph.FromStreamEx(s, head.ElementFormat); }); MorphList.Add(morph); } action(delegate { count = PmxStreamHelper.ReadElement_Int32(s); }); NodeList.Clear(); NodeList.Capacity = count; for (int num2 = 0; num2 < count; num2++) { PmxNode node = new PmxNode(); action(delegate { node.FromStreamEx(s, head.ElementFormat); }); NodeList.Add(node); if (NodeList[num2].SystemNode) { if (NodeList[num2].Name == "Root") { RootNode = NodeList[num2]; } else if (NodeList[num2].Name == "表情") { ExpNode = NodeList[num2]; } } } action(delegate { count = PmxStreamHelper.ReadElement_Int32(s); }); BodyList.Clear(); BodyList.Capacity = count; for (int num3 = 0; num3 < count; num3++) { PmxBody b2 = new PmxBody(); action(delegate { b2.FromStreamEx(s, head.ElementFormat); }); BodyList.Add(b2); } action(delegate { count = PmxStreamHelper.ReadElement_Int32(s); }); JointList.Clear(); JointList.Capacity = count; for (int num4 = 0; num4 < count; num4++) { PmxJoint i = new PmxJoint(); action(delegate { i.FromStreamEx(s, head.ElementFormat); }); JointList.Add(i); } if (head.Ver >= 2.1f) { action(delegate { count = PmxStreamHelper.ReadElement_Int32(s); }); SoftBodyList.Clear(); SoftBodyList.Capacity = count; for (int num5 = 0; num5 < count; num5++) { PmxSoftBody b3 = new PmxSoftBody(); action(delegate { b3.FromStreamEx(s, head.ElementFormat); }); SoftBodyList.Add(b3); } } if (id) { action(delegate { FilePath = PmxStreamHelper.ReadString(s, head.ElementFormat); }); } head.ElementFormat.WithID = false; }
public PmxNode(PmxNode node, bool nonStr = false) : this() { FromPmxNode(node, nonStr); }
// Token: 0x060000B2 RID: 178 RVA: 0x0000CC80 File Offset: 0x0000AE80 public virtual void FromStreamEx(Stream s, PmxElementFormat f) { PmxHeader pmxHeader = new PmxHeader(2.1f); pmxHeader.FromStreamEx(s, null); this.Header.FromHeader(pmxHeader); this.ModelInfo.FromStreamEx(s, pmxHeader.ElementFormat); int num = PmxStreamHelper.ReadElement_Int32(s, 4, true); this.VertexList.Clear(); this.VertexList.Capacity = num; for (int i = 0; i < num; i++) { PmxVertex pmxVertex = new PmxVertex(); pmxVertex.FromStreamEx(s, pmxHeader.ElementFormat); this.VertexList.Add(pmxVertex); } num = PmxStreamHelper.ReadElement_Int32(s, 4, true); this.FaceList.Clear(); this.FaceList.Capacity = num; for (int j = 0; j < num; j++) { int item = PmxStreamHelper.ReadElement_Int32(s, pmxHeader.ElementFormat.VertexSize, false); this.FaceList.Add(item); } PmxTextureTable pmxTextureTable = new PmxTextureTable(); pmxTextureTable.FromStreamEx(s, pmxHeader.ElementFormat); num = PmxStreamHelper.ReadElement_Int32(s, 4, true); this.MaterialList.Clear(); this.MaterialList.Capacity = num; for (int k = 0; k < num; k++) { PmxMaterial pmxMaterial = new PmxMaterial(); pmxMaterial.FromStreamEx_TexTable(s, pmxTextureTable, pmxHeader.ElementFormat); this.MaterialList.Add(pmxMaterial); } num = PmxStreamHelper.ReadElement_Int32(s, 4, true); this.BoneList.Clear(); this.BoneList.Capacity = num; for (int l = 0; l < num; l++) { PmxBone pmxBone = new PmxBone(); pmxBone.FromStreamEx(s, pmxHeader.ElementFormat); this.BoneList.Add(pmxBone); } num = PmxStreamHelper.ReadElement_Int32(s, 4, true); this.MorphList.Clear(); this.MorphList.Capacity = num; for (int m = 0; m < num; m++) { PmxMorph pmxMorph = new PmxMorph(); pmxMorph.FromStreamEx(s, pmxHeader.ElementFormat); this.MorphList.Add(pmxMorph); } num = PmxStreamHelper.ReadElement_Int32(s, 4, true); this.NodeList.Clear(); this.NodeList.Capacity = num; for (int n = 0; n < num; n++) { PmxNode pmxNode = new PmxNode(); pmxNode.FromStreamEx(s, pmxHeader.ElementFormat); this.NodeList.Add(pmxNode); bool systemNode = this.NodeList[n].SystemNode; if (systemNode) { bool flag = this.NodeList[n].Name == "Root"; if (flag) { this.RootNode = this.NodeList[n]; } else { bool flag2 = this.NodeList[n].Name == "表情"; if (flag2) { this.ExpNode = this.NodeList[n]; } } } } num = PmxStreamHelper.ReadElement_Int32(s, 4, true); this.BodyList.Clear(); this.BodyList.Capacity = num; for (int num2 = 0; num2 < num; num2++) { PmxBody pmxBody = new PmxBody(); pmxBody.FromStreamEx(s, pmxHeader.ElementFormat); this.BodyList.Add(pmxBody); } num = PmxStreamHelper.ReadElement_Int32(s, 4, true); this.JointList.Clear(); this.JointList.Capacity = num; for (int num3 = 0; num3 < num; num3++) { PmxJoint pmxJoint = new PmxJoint(); pmxJoint.FromStreamEx(s, pmxHeader.ElementFormat); this.JointList.Add(pmxJoint); } bool flag3 = pmxHeader.Ver >= 2.1f; if (flag3) { num = PmxStreamHelper.ReadElement_Int32(s, 4, true); this.SoftBodyList.Clear(); this.SoftBodyList.Capacity = num; for (int num4 = 0; num4 < num; num4++) { PmxSoftBody pmxSoftBody = new PmxSoftBody(); pmxSoftBody.FromStreamEx(s, pmxHeader.ElementFormat); this.SoftBodyList.Add(pmxSoftBody); } } }