public void FromPmxVertex(PmxVertex vertex) { Position = vertex.Position; Normal = vertex.Normal; UV = vertex.UV; for (int i = 0; i < 4; i++) { UVA[i] = vertex.UVA[i]; } for (int j = 0; j < 4; j++) { Weight[j] = vertex.Weight[j]; } EdgeScale = vertex.EdgeScale; Deform = vertex.Deform; SDEF = vertex.SDEF; C0 = vertex.C0; R0 = vertex.R0; R1 = vertex.R1; RW = vertex.RW; VertexMorphIndex = vertex.VertexMorphIndex; UVMorphIndex = vertex.UVMorphIndex; for (int k = 0; k < UVAMorphIndex.Length; k++) { UVAMorphIndex[k] = vertex.UVAMorphIndex[k]; } SDEFIndex = vertex.SDEFIndex; QDEFIndex = vertex.QDEFIndex; SoftBodyPosIndex = vertex.SoftBodyPosIndex; SoftBodyNormalIndex = vertex.SoftBodyNormalIndex; FromID(vertex); }
// Token: 0x06000280 RID: 640 RVA: 0x00013D04 File Offset: 0x00011F04 public void FromPmxVertex(PmxVertex vertex) { this.Position = vertex.Position; this.Normal = vertex.Normal; this.UV = vertex.UV; for (int i = 0; i < 4; i++) { this.UVA[i] = vertex.UVA[i]; } for (int j = 0; j < 4; j++) { this.Weight[j] = vertex.Weight[j]; this.Weight[j].RefBone = null; } this.EdgeScale = vertex.EdgeScale; this.Deform = vertex.Deform; this.SDEF = vertex.SDEF; this.C0 = vertex.C0; this.R0 = vertex.R0; this.R1 = vertex.R1; this.RW0 = vertex.RW0; this.RW1 = vertex.RW1; this.VertexMorphIndex = vertex.VertexMorphIndex; this.UVMorphIndex = vertex.UVMorphIndex; for (int k = 0; k < this.UVAMorphIndex.Length; k++) { this.UVAMorphIndex[k] = vertex.UVAMorphIndex[k]; } this.SDEFIndex = vertex.SDEFIndex; this.QDEFIndex = vertex.QDEFIndex; this.SoftBodyPosIndex = vertex.SoftBodyPosIndex; this.SoftBodyNormalIndex = vertex.SoftBodyNormalIndex; }
public PmxVertex(PmxVertex vertex) : this() { FromPmxVertex(vertex); }
// Token: 0x0600013C RID: 316 RVA: 0x0000EEDE File Offset: 0x0000D0DE public void FromPmxFace(PmxFace f) { this.V0 = f.V0; this.V1 = f.V1; this.V2 = f.V2; }
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 void FromPmxFace(PmxFace f) { V0 = f.V0; V1 = f.V1; V2 = f.V2; }
// Token: 0x060000B9 RID: 185 RVA: 0x0000D684 File Offset: 0x0000B884 public float RequireVersion(out bool isQDEF, out bool isExMorph, out bool isExJoint, out bool isSoftBody) { Func <bool> func = delegate() { bool result2 = false; for (int i = 0; i < this.VertexList.Count; i++) { PmxVertex pmxVertex = this.VertexList[i]; bool flag2 = pmxVertex.Deform == PmxVertex.DeformType.QDEF; if (flag2) { result2 = true; break; } } return(result2); }; Func <bool> func2 = delegate() { bool result2 = false; for (int i = 0; i < this.MorphList.Count; i++) { PmxMorph pmxMorph = this.MorphList[i]; bool flag2 = pmxMorph.IsFlip || pmxMorph.IsImpulse; if (flag2) { result2 = true; break; } } return(result2); }; Func <bool> func3 = delegate() { bool result2 = false; for (int i = 0; i < this.JointList.Count; i++) { PmxJoint pmxJoint = this.JointList[i]; bool flag2 = pmxJoint.Kind > PmxJoint.JointKind.Sp6DOF; if (flag2) { result2 = true; break; } } return(result2); }; Func <bool> func4 = () => this.SoftBodyList.Count > 0; isQDEF = func(); isExMorph = func2(); isExJoint = func3(); isSoftBody = func4(); float result = 2f; bool flag = isQDEF | isExMorph | isExJoint | isSoftBody; if (flag) { result = 2.1f; } return(result); }
// 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); } } }