當前位置: 首頁>>代碼示例>>C#>>正文


C# Skeleton.SetToSetupPose方法代碼示例

本文整理匯總了C#中Spine.Skeleton.SetToSetupPose方法的典型用法代碼示例。如果您正苦於以下問題:C# Skeleton.SetToSetupPose方法的具體用法?C# Skeleton.SetToSetupPose怎麽用?C# Skeleton.SetToSetupPose使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在Spine.Skeleton的用法示例。


在下文中一共展示了Skeleton.SetToSetupPose方法的4個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。

示例1: ExtractAnimation

	static AnimationClip ExtractAnimation (string name, SkeletonData skeletonData, Dictionary<int, List<string>> slotLookup, bool bakeIK, SendMessageOptions eventOptions, AnimationClip clip = null) {
		var animation = skeletonData.FindAnimation(name);

		var timelines = animation.Timelines;

		if (clip == null) {
			clip = new AnimationClip();
		} else {
			clip.ClearCurves();
			AnimationUtility.SetAnimationEvents(clip, new AnimationEvent[0]);
		}

#if UNITY_5

#else
		AnimationUtility.SetAnimationType(clip, ModelImporterAnimationType.Generic);
#endif

		clip.name = name;

		Skeleton skeleton = new Skeleton(skeletonData);

		List<int> ignoreRotateTimelineIndexes = new List<int>();

		if (bakeIK) {
			foreach (IkConstraint i in skeleton.IkConstraints) {
				foreach (Bone b in i.Bones) {
					int index = skeleton.FindBoneIndex(b.Data.Name);
					ignoreRotateTimelineIndexes.Add(index);
					BakeBone(b, animation, clip);
				}
			}
		}

		foreach (Bone b in skeleton.Bones) {
			if (b.Data.InheritRotation == false) {
				int index = skeleton.FindBoneIndex(b.Data.Name);

				if (ignoreRotateTimelineIndexes.Contains(index) == false) {
					ignoreRotateTimelineIndexes.Add(index);
					BakeBone(b, animation, clip);
				}
			}
		}

		foreach (Timeline t in timelines) {
			skeleton.SetToSetupPose();

			if (t is ScaleTimeline) {
				ParseScaleTimeline(skeleton, (ScaleTimeline)t, clip);
			} else if (t is TranslateTimeline) {
				ParseTranslateTimeline(skeleton, (TranslateTimeline)t, clip);
			} else if (t is RotateTimeline) {
				//bypass any rotation keys if they're going to get baked anyway to prevent localEulerAngles vs Baked collision
				if (ignoreRotateTimelineIndexes.Contains(((RotateTimeline)t).BoneIndex) == false)
					ParseRotateTimeline(skeleton, (RotateTimeline)t, clip);
			} else if (t is AttachmentTimeline) {
				ParseAttachmentTimeline(skeleton, (AttachmentTimeline)t, slotLookup, clip);
			} else if (t is EventTimeline) {
				ParseEventTimeline((EventTimeline)t, clip, eventOptions);
			}

		}

		var settings = AnimationUtility.GetAnimationClipSettings(clip);
		settings.loopTime = true;
		settings.stopTime = Mathf.Max(clip.length, 0.001f);

		SetAnimationSettings(clip, settings);

		clip.EnsureQuaternionContinuity();

		EditorUtility.SetDirty(clip);

		return clip;
	}
開發者ID:wenhaoisbad,項目名稱:kxsm,代碼行數:76,代碼來源:SkeletonBaker.cs

示例2: ParseScaleTimeline

	static void ParseScaleTimeline (Skeleton skeleton, ScaleTimeline timeline, AnimationClip clip) {
		var boneData = skeleton.Data.Bones[timeline.BoneIndex];
		var bone = skeleton.Bones[timeline.BoneIndex];

		AnimationCurve xCurve = new AnimationCurve();
		AnimationCurve yCurve = new AnimationCurve();
		AnimationCurve zCurve = new AnimationCurve();

		float endTime = timeline.Frames[(timeline.FrameCount * 3) - 3];

		float currentTime = timeline.Frames[0];

		List<Keyframe> xKeys = new List<Keyframe>();
		List<Keyframe> yKeys = new List<Keyframe>();

		xKeys.Add(new Keyframe(timeline.Frames[0], timeline.Frames[1] * boneData.ScaleX, 0, 0));
		yKeys.Add(new Keyframe(timeline.Frames[0], timeline.Frames[2] * boneData.ScaleY, 0, 0));

		int listIndex = 1;
		int frameIndex = 1;
		int f = 3;
		float[] frames = timeline.Frames;
		skeleton.SetToSetupPose();
		float lastTime = 0;
		while (currentTime < endTime) {
			int pIndex = listIndex - 1;
			float curveType = timeline.GetCurveType(frameIndex - 1);

			if (curveType == 0) {
				//linear
				Keyframe px = xKeys[pIndex];
				Keyframe py = yKeys[pIndex];

				float time = frames[f];
				float x = frames[f + 1] * boneData.ScaleX;
				float y = frames[f + 2] * boneData.ScaleY;

				float xOut = (x - px.value) / (time - px.time);
				float yOut = (y - py.value) / (time - py.time);

				px.outTangent = xOut;
				py.outTangent = yOut;

				xKeys.Add(new Keyframe(time, x, xOut, 0));
				yKeys.Add(new Keyframe(time, y, yOut, 0));

				xKeys[pIndex] = px;
				yKeys[pIndex] = py;

				currentTime = time;

				timeline.Apply(skeleton, lastTime, currentTime, null, 1);

				lastTime = time;
				listIndex++;
			} else if (curveType == 1) {
				//stepped
				Keyframe px = xKeys[pIndex];
				Keyframe py = yKeys[pIndex];

				float time = frames[f];
				float x = frames[f + 1] * boneData.ScaleX;
				float y = frames[f + 2] * boneData.ScaleY;

				float xOut = float.PositiveInfinity;
				float yOut = float.PositiveInfinity;

				px.outTangent = xOut;
				py.outTangent = yOut;

				xKeys.Add(new Keyframe(time, x, xOut, 0));
				yKeys.Add(new Keyframe(time, y, yOut, 0));

				xKeys[pIndex] = px;
				yKeys[pIndex] = py;

				currentTime = time;

				timeline.Apply(skeleton, lastTime, currentTime, null, 1);

				lastTime = time;
				listIndex++;
			} else if (curveType == 2) {
				//bezier
				Keyframe px = xKeys[pIndex];
				Keyframe py = yKeys[pIndex];

				float time = frames[f];

				int steps = Mathf.FloorToInt((time - px.time) / bakeIncrement);

				for (int i = 1; i <= steps; i++) {
					currentTime += bakeIncrement;
					if (i == steps)
						currentTime = time;

					timeline.Apply(skeleton, lastTime, currentTime, null, 1);

					px = xKeys[listIndex - 1];
					py = yKeys[listIndex - 1];
//.........這裏部分代碼省略.........
開發者ID:wenhaoisbad,項目名稱:kxsm,代碼行數:101,代碼來源:SkeletonBaker.cs

示例3: ParseRotateTimeline

	static void ParseRotateTimeline (Skeleton skeleton, RotateTimeline timeline, AnimationClip clip) {
		var boneData = skeleton.Data.Bones[timeline.BoneIndex];
		var bone = skeleton.Bones[timeline.BoneIndex];

		AnimationCurve curve = new AnimationCurve();

		float endTime = timeline.Frames[(timeline.FrameCount * 2) - 2];

		float currentTime = timeline.Frames[0];

		List<Keyframe> keys = new List<Keyframe>();

		float rotation = timeline.Frames[1] + boneData.Rotation;

		keys.Add(new Keyframe(timeline.Frames[0], rotation, 0, 0));

		int listIndex = 1;
		int frameIndex = 1;
		int f = 2;
		float[] frames = timeline.Frames;
		skeleton.SetToSetupPose();
		float lastTime = 0;
		float angle = rotation;
		while (currentTime < endTime) {
			int pIndex = listIndex - 1;
			float curveType = timeline.GetCurveType(frameIndex - 1);

			if (curveType == 0) {
				//linear
				Keyframe pk = keys[pIndex];

				float time = frames[f];

				rotation = frames[f + 1] + boneData.Rotation;
				angle += Mathf.DeltaAngle(angle, rotation);
				float r = angle;

				float rOut = (r - pk.value) / (time - pk.time);

				pk.outTangent = rOut;

				keys.Add(new Keyframe(time, r, rOut, 0));

				keys[pIndex] = pk;

				currentTime = time;

				timeline.Apply(skeleton, lastTime, currentTime, null, 1);

				lastTime = time;
				listIndex++;
			} else if (curveType == 1) {
				//stepped

				Keyframe pk = keys[pIndex];

				float time = frames[f];

				rotation = frames[f + 1] + boneData.Rotation;
				angle += Mathf.DeltaAngle(angle, rotation);
				float r = angle;

				float rOut = float.PositiveInfinity;

				pk.outTangent = rOut;

				keys.Add(new Keyframe(time, r, rOut, 0));

				keys[pIndex] = pk;

				currentTime = time;

				timeline.Apply(skeleton, lastTime, currentTime, null, 1);

				lastTime = time;
				listIndex++;
			} else if (curveType == 2) {
				//bezier
				Keyframe pk = keys[pIndex];

				float time = frames[f];

				timeline.Apply(skeleton, lastTime, currentTime, null, 1);
				skeleton.UpdateWorldTransform();

				rotation = frames[f + 1] + boneData.Rotation;
				angle += Mathf.DeltaAngle(angle, rotation);
				float r = angle;

				int steps = Mathf.FloorToInt((time - pk.time) / bakeIncrement);

				for (int i = 1; i <= steps; i++) {
					currentTime += bakeIncrement;
					if (i == steps)
						currentTime = time;

					timeline.Apply(skeleton, lastTime, currentTime, null, 1);
					skeleton.UpdateWorldTransform();
					pk = keys[listIndex - 1];

//.........這裏部分代碼省略.........
開發者ID:wenhaoisbad,項目名稱:kxsm,代碼行數:101,代碼來源:SkeletonBaker.cs

示例4: ParseColorTimeline

    static void ParseColorTimeline(Skeleton skeleton, ColorTimeline timeline, Dictionary<int, List<string>> slotLookup, AnimationClip clip)
    {
        var slotData = skeleton.Data.Slots[timeline.SlotIndex];
        var slot = skeleton.Slots[timeline.SlotIndex];

        AnimationCurve rCurve = new AnimationCurve();
        AnimationCurve gCurve = new AnimationCurve();
        AnimationCurve bCurve = new AnimationCurve();
        AnimationCurve aCurve = new AnimationCurve();

        float endTime = timeline.Frames[(timeline.FrameCount * 5) - 5];

        float currentTime = timeline.Frames[0];

        List<Keyframe> rKeys = new List<Keyframe>();
        List<Keyframe> gKeys = new List<Keyframe>();
        List<Keyframe> bKeys = new List<Keyframe>();
        List<Keyframe> aKeys = new List<Keyframe>();

        rKeys.Add(new Keyframe(timeline.Frames[0], timeline.Frames[1] * slotData.R, 0, 0));
        gKeys.Add(new Keyframe(timeline.Frames[0], timeline.Frames[2] * slotData.G, 0, 0));
        bKeys.Add(new Keyframe(timeline.Frames[0], timeline.Frames[3] * slotData.B, 0, 0));
        aKeys.Add(new Keyframe(timeline.Frames[0], timeline.Frames[4] * slotData.A, 0, 0));

        int listIndex = 1;
        int frameIndex = 1;
        int f = 5;
        float[] frames = timeline.Frames;
        skeleton.SetToSetupPose();
        float lastTime = 0;
        while (currentTime < endTime) {
            int pIndex = listIndex - 1;
            float curveType = timeline.GetCurveType(frameIndex - 1);

            if (curveType == 0) {
                //linear
                Keyframe cr = rKeys[pIndex];
                Keyframe cg = gKeys[pIndex];
                Keyframe cb = bKeys[pIndex];
                Keyframe ca = aKeys[pIndex];

                float time = frames[f];
                float r = frames[f + 1] * slotData.R;
                float g = frames[f + 2] * slotData.G;
                float b = frames[f + 3] * slotData.B;
                float a = frames[f + 4] * slotData.A;

                float rOut = (r - cr.value) / (time - cr.time);
                float gOut = (g - cg.value) / (time - cg.time);
                float bOut = (b - cb.value) / (time - cb.time);
                float aOut = (a - ca.value) / (time - ca.time);

                cr.outTangent = rOut;
                cg.outTangent = gOut;
                cb.outTangent = bOut;
                ca.outTangent = aOut;

                rKeys.Add(new Keyframe(time, r, rOut, 0));
                gKeys.Add(new Keyframe(time, g, gOut, 0));
                bKeys.Add(new Keyframe(time, b, bOut, 0));
                aKeys.Add(new Keyframe(time, a, aOut, 0));

                rKeys[pIndex] = cr;
                gKeys[pIndex] = cg;
                bKeys[pIndex] = cb;
                aKeys[pIndex] = ca;

                currentTime = time;

                timeline.Apply(skeleton, lastTime, currentTime, null, 1);

                lastTime = time;
                listIndex++;
            } else if (curveType == 1) {
                //stepped
                Keyframe cr = rKeys[pIndex];
                Keyframe cg = gKeys[pIndex];
                Keyframe cb = bKeys[pIndex];
                Keyframe ca = aKeys[pIndex];

                float time = frames[f];
                float r = frames[f + 1] * slotData.R;
                float g = frames[f + 2] * slotData.G;
                float b = frames[f + 3] * slotData.B;
                float a = frames[f + 4] * slotData.A;

                float rOut = float.PositiveInfinity;
                float gOut = float.PositiveInfinity;
                float bOut = float.PositiveInfinity;
                float aOut = float.PositiveInfinity;

                cr.outTangent = rOut;
                cg.outTangent = gOut;
                cb.outTangent = bOut;
                ca.outTangent = aOut;

                rKeys.Add(new Keyframe(time, r, rOut, 0));
                gKeys.Add(new Keyframe(time, g, gOut, 0));
                bKeys.Add(new Keyframe(time, b, bOut, 0));
                aKeys.Add(new Keyframe(time, a, aOut, 0));
//.........這裏部分代碼省略.........
開發者ID:mob-naito,項目名稱:spine-runtimes,代碼行數:101,代碼來源:SkeletonBaker.cs


注:本文中的Spine.Skeleton.SetToSetupPose方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。