Skip to content

Commit

Permalink
bug, null attachments at slot animation
Browse files Browse the repository at this point in the history
  • Loading branch information
nicloay committed Aug 8, 2014
1 parent 91e4487 commit f83c75e
Showing 1 changed file with 28 additions and 5 deletions.
33 changes: 28 additions & 5 deletions Assets/UnitySpineImporter/Scripts/Editor/Util/SpineUtil.cs
Original file line number Diff line number Diff line change
Expand Up @@ -448,6 +448,15 @@ static void createFolderIfNoExists(string root, string folderName){
Directory.CreateDirectory(path);
}


public static string getFirstAttachmentName(SpineSlotAnimation spineSlotAnimation){
for (int i = 0; i < spineSlotAnimation.attachment.Count; i++) {
if (!string.IsNullOrEmpty( spineSlotAnimation.attachment[i].name))
return spineSlotAnimation.attachment[i].name;
}
return "";
}

public static void addSlotAnimationToClip(AnimationClip clip,
Dictionary<string, SpineSlotAnimation> slotsAnimation,
SpineData spineData,
Expand All @@ -461,11 +470,18 @@ public static void addSlotAnimationToClip(AnimationClip
SpineSlotAnimation slotAnimation = kvp.Value;
if (slotAnimation.attachment != null && slotAnimation.attachment.Count > 0){
Dictionary<string, AnimationCurve> curveByName = new Dictionary<string, AnimationCurve>();


for (int i = 0; i < slotAnimation.attachment.Count; i++) {
bool nullAttachment = false;
SpineSlotAttachmentAnimation anim = slotAnimation.attachment[i];
if (string.IsNullOrEmpty( anim.name))
continue;
if (string.IsNullOrEmpty( anim.name)){
anim.name=getFirstAttachmentName(slotAnimation);
nullAttachment = true;
}

if (anim.name.Equals(""))
continue;
AnimationCurve enableCurve;
if (curveByName.ContainsKey(anim.name)){
enableCurve = curveByName[anim.name];
Expand All @@ -481,7 +497,7 @@ public static void addSlotAnimationToClip(AnimationClip
curveByName.Add(defaultAttachment, defSlotCurve);

if (anim.time !=0.0f){
defSlotCurve.AddKey(KeyframeUtil.GetNew(0, 1, TangentMode.Stepped));
defSlotCurve.AddKey(KeyframeUtil.GetNew(0, nullAttachment ? 0 : 1, TangentMode.Stepped));
defSlotCurve.AddKey(KeyframeUtil.GetNew((float)anim.time, 0, TangentMode.Stepped));
} else {
defSlotCurve.AddKey(KeyframeUtil.GetNew(0, 0, TangentMode.Stepped));
Expand All @@ -490,11 +506,18 @@ public static void addSlotAnimationToClip(AnimationClip
}
}

enableCurve.AddKey(KeyframeUtil.GetNew((float)anim.time, 1, TangentMode.Stepped));
enableCurve.AddKey(KeyframeUtil.GetNew((float)anim.time, nullAttachment ? 0 : 1, TangentMode.Stepped));
if (i< (slotAnimation.attachment.Count - 1)){
SpineSlotAttachmentAnimation nextAnim = slotAnimation.attachment[i+1];
if (!nextAnim.name.Equals(anim.name))
bool nullNextAttachment =false;
if (string.IsNullOrEmpty( nextAnim.name)){
nextAnim.name=getFirstAttachmentName(slotAnimation);
nullNextAttachment = true;
}

if (!nextAnim.name.Equals(anim.name) || nullNextAttachment)
enableCurve.AddKey(KeyframeUtil.GetNew((float)nextAnim.time, 0, TangentMode.Stepped));

}
}
foreach(KeyValuePair<string, AnimationCurve> kvp2 in curveByName){
Expand Down

0 comments on commit f83c75e

Please sign in to comment.