예제 #1
0
        private byte[] ReadColorPBR1(BinaryReader reader, int version)
        {
            BinaryList color = new BinaryList();

            color.Add(2); // colorType

            if (version < 4)
            {
                color.AddRange(reader.ReadBytes(16)); // mainColor1
                color.AddAll(1f, 1f, 1f, 1f);         // specColor1
                color.Add(0f);                        // specular1
                color.Add(0f);                        // smooth1
            }
            else
            {
                int colorType = reader.ReadInt32(); // colorType
                if (colorType != 0)
                {
                    // mainColor1, specColor1, specular1, smooth1
                    color.AddRange(reader.ReadBytes(40));
                }
                else
                {
                    color.AddAll(1f, 1f, 1f, 1f); // mainColor1
                    color.AddAll(1f, 1f, 1f, 1f); // specColor1
                    color.Add(0f);                // specular1
                    color.Add(0f);                // smooth1
                }
            }

            return(color.ToArray());
        }
예제 #2
0
        private byte[] ReadColorAlloyHSVOffset(BinaryReader reader, int version)
        {
            BinaryList color = new BinaryList();

            color.Add(5); // colorType

            if (version < 4)
            {
                reader.ReadBytes(16);

                color.AddAll(0f, 1f, 1f, 1f); // hsv offset + alpha
                color.Add(0f);                // metallic
                color.Add(0.562f);            // smooth
            }
            else
            {
                int colorType = reader.ReadInt32(); // colorType
                if (colorType != 0)
                {
                    if (version < 6)
                    {
                        reader.ReadBytes(16);
                        color.AddAll(0f, 1f, 1f, 1f); // hsv offset + alpha
                    }
                    else
                    {
                        // offset_h, offset_s, offset_v
                        color.AddRange(reader.ReadBytes(12));

                        if (version == 7)
                        {
                            reader.ReadBoolean();
                            color.Add(reader.ReadSingle()); // alpha
                        }
                        else if (version >= 8)
                        {
                            color.Add(reader.ReadSingle()); // alpha
                        }
                        else
                        {
                            color.Add(1f); // alpha
                        }
                    }

                    // metallic, smooth
                    color.AddRange(reader.ReadBytes(8));
                }
                else
                {
                    color.AddAll(0f, 1f, 1f, 1f); // hsv offset + alpha
                    color.Add(0f);                // metallic
                    color.Add(0.562f);            // smooth
                }
            }

            return(color.ToArray());
        }
예제 #3
0
        private byte[] ReadColorAlloy(BinaryReader reader, int version)
        {
            BinaryList color = new BinaryList();

            color.Add(4); // colorType

            if (version < 4)
            {
                color.AddRange(reader.ReadBytes(16)); // mainColor

                color.Add(0f);                        // metallic
                color.Add(0f);                        // smooth
            }
            else
            {
                int colorType = reader.ReadInt32(); // colorType
                if (colorType != 0)
                {
                    // mainColor, metallic, smooth
                    color.AddRange(reader.ReadBytes(24));
                }
                else
                {
                    color.AddAll(1f, 1f, 1f, 1f); // mainColor
                    color.Add(0f);                // metallic
                    color.Add(0f);                // smooth
                }
            }

            return(color.ToArray());
        }
예제 #4
0
        private byte[] ReadColorPBR2(BinaryReader reader, int version)
        {
            BinaryList color = new BinaryList();

            color.Add(3); // colorType

            if (version < 4)
            {
                color.AddRange(reader.ReadBytes(16)); // mainColor1

                color.AddAll(1f, 1f, 1f, 1f);         // specColor1
                color.Add(0f);                        // specular1
                color.Add(0f);                        // smooth1

                color.AddAll(1f, 1f, 1f, 1f);         // mainColor2
                color.AddAll(1f, 1f, 1f, 1f);         // specColor2
                color.Add(0f);                        // specular2
                color.Add(0f);                        // smooth2
            }
            else
            {
                int colorType = reader.ReadInt32(); // colorType
                if (colorType != 0)
                {
                    // mainColor1, specColor1, specular1
                    // smooth1, mainColor2, specColor2
                    color.AddRange(reader.ReadBytes(72));

                    if (version >= 5)
                    {
                        color.Add(reader.ReadSingle()); // specular2
                    }
                    else
                    {
                        color.Add(0f);              // specular2
                    }
                    color.Add(reader.ReadSingle()); // smooth2
                }
                else
                {
                    color.AddAll(1f, 1f, 1f, 1f); // mainColor1
                    color.AddAll(1f, 1f, 1f, 1f); // specColor1
                    color.Add(0f);                // specular1
                    color.Add(0f);                // smooth1

                    color.AddAll(1f, 1f, 1f, 1f); // mainColor2
                    color.AddAll(1f, 1f, 1f, 1f); // specColor2
                    color.Add(0f);                // specular2
                    color.Add(0f);                // smooth2
                }
            }

            return(color.ToArray());
        }
예제 #5
0
        private byte[] ReadColorHair(BinaryReader reader, int version)
        {
            BinaryList color = new BinaryList();

            color.Add(1); // colorType

            if (version < 4)
            {
                color.AddRange(reader.ReadBytes(16));    // mainColor
                color.AddAll(0.75f, 0.75f, 0.75f, 1.0f); // cuticleColor
                color.Add(6f);                           // cuticleExp
                color.AddAll(0.75f, 0.75f, 0.75f, 1.0f); // fresnelColor
                color.Add(0.3f);                         // fresnelExp
            }
            else
            {
                reader.ReadInt32(); // colorType >> 1

                // mainColor, cuticleColor, cuticleExp, fresnelColor, fresnelExp
                color.AddRange(reader.ReadBytes(56));
            }

            return(color.ToArray());
        }
예제 #6
0
        private void ReadBody(BinaryReader reader, CustomParam chara)
        {
            BinaryList list = new BinaryList();

            // bodyID
            list.Add(reader.ReadInt32());
            // skinColor
            list.AddRange(ReadColorAlloyHSVOffset(reader, chara.version));

            // detailID, detailWeight, underhairID
            list.AddRange(reader.ReadBytes(12));

            // underhairColor
            list.AddRange(ReadColorAlloy(reader, chara.version));

            // tattooID, tattooColor
            list.AddRange(reader.ReadBytes(20));

            // shapeVals
            int shapeCount = reader.ReadInt32();

            list.Add(shapeCount);
            list.AddRange(reader.ReadBytes(shapeCount * 4));

            if (chara.sex == 0)
            {
                // nipID
                list.Add(reader.ReadInt32());
                // nipColor
                list.AddRange(ReadColorAlloyHSVOffset(reader, chara.version));
                // sunburnID, sunburnColor
                list.AddRange(reader.ReadBytes(20));

                if (chara.version >= 3)
                {
                    // nailColor
                    list.AddRange(ReadColorAlloyHSVOffset(reader, chara.version));

                    if (chara.version >= 9)
                    {
                        // manicureColor
                        list.AddRange(ReadColorPBR1(reader, chara.version));
                    }
                    else
                    {
                        // manicureColor
                        list.Add(2);                 // colorType
                        list.AddAll(1f, 1f, 1f, 0f); // mainColor1
                        list.AddAll(1f, 1f, 1f, 1f); // specColor1
                        list.AddAll(0f, 0f);         // specular1, smooth1
                    }

                    // areolaSize, bustSoftness, bustWeight
                    list.AddRange(reader.ReadBytes(12));
                }
                else
                {
                    // nailColor
                    list.Add(5);                 // colorType
                    list.AddAll(0f, 1f, 1f, 1f); // hsv offset + alpha
                    list.AddAll(0f, 0.562f);     // metallic, smooth

                    // manicureColor
                    list.Add(2);                 // colorType
                    list.AddAll(1f, 1f, 1f, 0f); // mainColor1
                    list.AddAll(1f, 1f, 1f, 1f); // specColor1
                    list.AddAll(0f, 0f);         // specular1, smooth1

                    // areolaSize, bustSoftness, bustWeight
                    list.AddAll(0.5f, 0.5f, 0.5f);
                }
            }

            chara.body = list.ToArray();
        }
예제 #7
0
        private void ReadHead(BinaryReader reader, CustomParam chara)
        {
            BinaryList list = new BinaryList();

            // headID, faceTexID, detailID, detailWeight, eyeBrowID
            list.AddRange(reader.ReadBytes(20));

            // eyeBrowColor
            list.AddRange(ReadColorPBR1(reader, chara.version));

            if (chara.version < 4)
            {
                // eyeScleraColor
                byte[] eyeScleraColor = reader.ReadBytes(16);
                // eyeL
                list.Add(reader.ReadInt32());        // eyeID_L
                list.AddRange(eyeScleraColor);       // eyeScleraColorL
                list.AddRange(reader.ReadBytes(16)); // eyeIrisColorL
                list.AddAll(0.0f, 0.5f);             // eyePupilDilationL, eyeEmissiveL

                // eyeR
                list.Add(reader.ReadInt32());        // eyeID_R
                list.AddRange(eyeScleraColor);       // eyeScleraColorR
                list.AddRange(reader.ReadBytes(16)); // eyeIrisColorR
                list.AddAll(0.0f, 0.5f);             // eyePupilDilationR, eyeEmissiveR
            }
            else
            {
                // eyeID_L, eyeScleraColorL, eyeIrisColorL eyePupilDilationL
                list.AddRange(reader.ReadBytes(40));
                if (chara.version >= 10)
                {
                    list.Add(reader.ReadSingle()); // eyeEmissiveL
                }
                else
                {
                    list.Add(0.5f); // eyeEmissiveL
                }

                // eyeID_R, eyeScleraColorR, eyeIrisColorR, eyePupilDilationR
                list.AddRange(reader.ReadBytes(40));

                if (chara.version >= 10)
                {
                    list.Add(reader.ReadSingle()); // eyeEmissiveR
                }
                else
                {
                    list.Add(0.5f); // eyeEmissiveR
                }
            }

            // tattooID, tattooColor
            list.AddRange(reader.ReadBytes(20));

            // shapeVals
            int shapeCount = reader.ReadInt32();

            list.Add(shapeCount);
            list.AddRange(reader.ReadBytes(shapeCount * 4));

            if (chara.sex == 0)
            {
                // eyeLash
                list.Add(reader.ReadInt32());
                list.AddRange(ReadColorPBR1(reader, chara.version));
                // eyeshadow
                list.AddRange(reader.ReadBytes(20));
                // cheek
                list.AddRange(reader.ReadBytes(20));
                // lip
                list.AddRange(reader.ReadBytes(20));
                // mole
                list.AddRange(reader.ReadBytes(20));

                // eyeHighlight
                list.Add(reader.ReadInt32());
                list.AddRange(ReadColorEyeHighlight(reader, chara.version));
            }
            else
            {
                // beard
                list.AddRange(reader.ReadBytes(20));

                if (chara.version >= 2)
                {
                    // eyeHighlightColor
                    list.AddRange(ReadColorEyeHighlight(reader, chara.version));
                }
                else
                {
                    // eyeHighlightColor
                    list.Add(7);                 // colorType
                    list.AddAll(1f, 1f, 1f, 1f); // mainColor1
                    list.AddAll(1f, 1f, 1f, 1f); // specColor1
                    list.AddAll(0f, 0f);         // specular1, smooth1
                }
            }

            chara.head = list.ToArray();
        }