コード例 #1
0
        public void CopyAnims(AnimationsContainer omf_1, AnimationsContainer omf_2, List <string> list)
        {
            omf_1.RecalcAnimNum();

            short new_count = (short)omf_1.AnimsCount;

            for (int i = 0; i < omf_2.Anims.Count; i++)
            {
                AnimVector anim = omf_2.Anims[i];

                for (int ii = 0; ii < list.Count; ii++)
                {
                    if (anim.MotionName == list[ii])
                    {
                        omf_1.AddAnim(anim);

                        AnimationParams anim_param = omf_2.AnimsParams[i];

                        anim_param.MotionID = new_count;

                        if ((omf_1.bone_cont.OGF_V != omf_2.bone_cont.OGF_V) && omf_1.bone_cont.OGF_V == 3)
                        {
                            anim_param.MarksCount = 0;
                            anim_param.m_marks    = null;
                        }

                        omf_1.AddAnimParams(anim_param);
                        new_count++;
                    }
                }
            }

            omf_1.RecalcAnimNum();
            omf_1.RecalcAllAnimIndex();
        }
コード例 #2
0
        public void CopyAnims(AnimationsContainer omf_1, AnimationsContainer omf_2)
        {
            //bool omf_1.bone_cont.OGF_V != omf_2.bone_cont.OGF_V
            omf_1.RecalcAnimNum();

            foreach (AnimVector anim in omf_2.Anims)
            {
                omf_1.AddAnim(anim);
            }

            short b = (short)omf_1.AnimsCount;

            foreach (AnimationParams anim_param in omf_2.AnimsParams)
            {
                anim_param.MotionID = b;

                if ((omf_1.bone_cont.OGF_V != omf_2.bone_cont.OGF_V) && omf_1.bone_cont.OGF_V == 3)
                {
                    anim_param.MarksCount = 0;
                    anim_param.m_marks    = null;
                }

                omf_1.AddAnimParams(anim_param);
                b++;
            }

            omf_1.RecalcAnimNum();
            omf_1.RecalcAllAnimIndex();
        }
コード例 #3
0
        public AnimationsContainer OpenOMF(string filename)
        {
            using (BinaryReader reader = new BinaryReader(File.Open(filename, FileMode.Open)))
            {
                AnimationsContainer omf_file = new AnimationsContainer(reader, this);
                //Загрузка костей
                omf_file.bone_cont = new BoneContainer(reader, this);
                //Загрузка параметров анимаций
                omf_file.AnimsParamsCount = reader.ReadInt16();
                //Проверка
                if (omf_file.AnimsCount != omf_file.AnimsParamsCount)
                {
                    return(null);
                }

                for (int i = 0; i < omf_file.AnimsParamsCount; i++)
                {
                    AnimationParams anm_p = new AnimationParams(reader, this, omf_file.bone_cont.OGF_V);
                    omf_file.AddAnimParams(anm_p);
                }

                return(omf_file);
            }
        }