mirror of
https://github.com/EsotericSoftware/spine-runtimes.git
synced 2026-03-26 22:49:01 +08:00
[unity] Handle invalid SkeletonAnimation property behavior.
This commit is contained in:
parent
613b098b53
commit
5be75c9f6d
@ -76,33 +76,40 @@ namespace Spine.Unity {
|
|||||||
[SerializeField]
|
[SerializeField]
|
||||||
[SpineAnimation]
|
[SpineAnimation]
|
||||||
private string _animationName;
|
private string _animationName;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Setting this property sets the animation of the skeleton. If invalid, it will store the animation name for the next time the skeleton is properly initialized.
|
||||||
|
/// Getting this property gets the name of the currently playing animation. If invalid, it will return the last stored animation name set through this property.</summary>
|
||||||
public string AnimationName {
|
public string AnimationName {
|
||||||
get {
|
get {
|
||||||
if (!valid) {
|
if (!valid) {
|
||||||
Debug.LogWarning("You tried access AnimationName but the SkeletonAnimation was not valid. Try checking your Skeleton Data for errors.");
|
return _animationName;
|
||||||
return null;
|
} else {
|
||||||
|
TrackEntry entry = state.GetCurrent(0);
|
||||||
|
return entry == null ? null : entry.Animation.Name;
|
||||||
}
|
}
|
||||||
|
|
||||||
TrackEntry entry = state.GetCurrent(0);
|
|
||||||
return entry == null ? null : entry.Animation.Name;
|
|
||||||
}
|
}
|
||||||
set {
|
set {
|
||||||
if (_animationName == value)
|
if (_animationName == value)
|
||||||
return;
|
return;
|
||||||
_animationName = value;
|
_animationName = value;
|
||||||
|
|
||||||
if (!valid) {
|
if (string.IsNullOrEmpty(value)) {
|
||||||
Debug.LogWarning("You tried to change AnimationName but the SkeletonAnimation was not valid. Try checking your Skeleton Data for errors.");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (string.IsNullOrEmpty(value))
|
|
||||||
state.ClearTrack(0);
|
state.ClearTrack(0);
|
||||||
else
|
} else {
|
||||||
state.SetAnimation(0, value, loop);
|
TrySetAnimation(value, loop);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
TrackEntry TrySetAnimation (string animationName, bool animationLoop) {
|
||||||
|
var animationObject = skeletonDataAsset.GetSkeletonData(false).FindAnimation(animationName);
|
||||||
|
if (animationObject != null)
|
||||||
|
return state.SetAnimation(0, animationObject, animationLoop);
|
||||||
|
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
/// <summary>Whether or not <see cref="AnimationName"/> should loop. This only applies to the initial animation specified in the inspector, or any subsequent Animations played through .AnimationName. Animations set through state.SetAnimation are unaffected.</summary>
|
/// <summary>Whether or not <see cref="AnimationName"/> should loop. This only applies to the initial animation specified in the inspector, or any subsequent Animations played through .AnimationName. Animations set through state.SetAnimation are unaffected.</summary>
|
||||||
public bool loop;
|
public bool loop;
|
||||||
|
|
||||||
@ -150,22 +157,21 @@ namespace Spine.Unity {
|
|||||||
#if UNITY_EDITOR
|
#if UNITY_EDITOR
|
||||||
if (!string.IsNullOrEmpty(_animationName)) {
|
if (!string.IsNullOrEmpty(_animationName)) {
|
||||||
if (Application.isPlaying) {
|
if (Application.isPlaying) {
|
||||||
state.SetAnimation(0, _animationName, loop);
|
TrackEntry startingTrack = TrySetAnimation(_animationName, loop);
|
||||||
|
if (startingTrack != null)
|
||||||
|
Update(0);
|
||||||
} else {
|
} else {
|
||||||
// Assume SkeletonAnimation is valid for skeletonData and skeleton. Checked above.
|
// Assume SkeletonAnimation is valid for skeletonData and skeleton. Checked above.
|
||||||
var animationObject = skeletonDataAsset.GetSkeletonData(false).FindAnimation(_animationName);
|
var animationObject = skeletonDataAsset.GetSkeletonData(false).FindAnimation(_animationName);
|
||||||
if (animationObject != null)
|
if (animationObject != null)
|
||||||
animationObject.PoseSkeleton(skeleton, 0f);
|
animationObject.PoseSkeleton(skeleton, 0f);
|
||||||
}
|
}
|
||||||
Update(0);
|
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
if (!string.IsNullOrEmpty(_animationName)) {
|
if (!string.IsNullOrEmpty(_animationName)) {
|
||||||
var animationObject = skeletonDataAsset.GetSkeletonData(false).FindAnimation(_animationName);
|
TrackEntry startingTrack = TrySetAnimation(_animationName, loop);
|
||||||
if (animationObject != null) {
|
if (startingTrack != null)
|
||||||
state.SetAnimation(0, animationObject, loop);
|
|
||||||
Update(0);
|
Update(0);
|
||||||
}
|
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user