Updates spine test.

This commit is contained in:
James Chen 2013-12-19 21:35:43 +08:00
parent df85ba8fd9
commit cfec4d5b7e
6 changed files with 58 additions and 33 deletions

View File

@ -45,7 +45,8 @@ void _spAtlasPage_createTexture (spAtlasPage* self, const char* path) {
// self->width = texture->getPixelsWide(); // self->width = texture->getPixelsWide();
// self->height = texture->getPixelsHigh(); // self->height = texture->getPixelsHigh();
self->width = texture->getContentSize().width; self->width = texture->getContentSize().width;
self->height = texture->getContentSize().height;} self->height = texture->getContentSize().height;
}
void _spAtlasPage_disposeTexture (spAtlasPage* self) { void _spAtlasPage_disposeTexture (spAtlasPage* self) {
((TextureAtlas*)self->rendererObject)->release(); ((TextureAtlas*)self->rendererObject)->release();
@ -54,8 +55,8 @@ void _spAtlasPage_disposeTexture (spAtlasPage* self) {
char* _spUtil_readFile (const char* path, int* length) { char* _spUtil_readFile (const char* path, int* length) {
ssize_t size; ssize_t size;
char* data = reinterpret_cast<char*>( char* data = reinterpret_cast<char*>(
FileUtils::getInstance()->getFileData( FileUtils::getInstance()->fullPathForFilename(path).c_str(), "r", &size)); FileUtils::getInstance()->getFileData( FileUtils::getInstance()->fullPathForFilename(path).c_str(), "rb", &size));
*length = size; *length = static_cast<int>(size);
return data;} return data;}
/**/ /**/

View File

@ -50,16 +50,23 @@ bool SpineTestLayer::init () {
if (!Layer::init()) return false; if (!Layer::init()) return false;
skeletonNode = CCSkeletonAnimation::createWithFile("spine/spineboy.json", "spine/spineboy.atlas"); skeletonNode = CCSkeletonAnimation::createWithFile("spine/spineboy.json", "spine/spineboy.atlas");
skeletonNode->setMix("walk", "jump", 0.4f); skeletonNode->setMix("walk", "jump", 0.2f);
skeletonNode->setMix("jump", "walk", 0.4f); skeletonNode->setMix("jump", "walk", 0.4f);
skeletonNode->setAnimation("walk", true);
skeletonNode->setAnimationListener(this, animationStateEvent_selector(SpineTestLayer::animationStateEvent));
skeletonNode->setAnimation(0, "walk", false);
skeletonNode->addAnimation(0, "jump", false);
skeletonNode->addAnimation(0, "walk", true);
skeletonNode->addAnimation(0, "jump", true, 4);
// skeletonNode->addAnimation(1, "drawOrder", true);
skeletonNode->timeScale = 0.3f; skeletonNode->timeScale = 0.3f;
skeletonNode->debugBones = true; skeletonNode->debugBones = true;
skeletonNode->update(0);
skeletonNode->runAction(RepeatForever::create(Sequence::create(FadeOut::create(1), skeletonNode->runAction(CCRepeatForever::create(CCSequence::create(CCFadeOut::create(1),
FadeIn::create(1), CCFadeIn::create(1),
DelayTime::create(5), CCDelayTime::create(5),
NULL))); NULL)));
Size windowSize = Director::getInstance()->getWinSize(); Size windowSize = Director::getInstance()->getWinSize();
@ -72,11 +79,25 @@ bool SpineTestLayer::init () {
} }
void SpineTestLayer::update (float deltaTime) { void SpineTestLayer::update (float deltaTime) {
if (skeletonNode->states[0]->loop) {
if (skeletonNode->states[0]->time > 2) }
skeletonNode->setAnimation("jump", false);
} else { void SpineTestLayer::animationStateEvent (CCSkeletonAnimation* node, int trackIndex, spEventType type, spEvent* event, int loopCount) {
if (skeletonNode->states[0]->time > 1) spTrackEntry* entry = spAnimationState_getCurrent(node->state, trackIndex);
skeletonNode->setAnimation("walk", true); const char* animationName = (entry && entry->animation) ? entry->animation->name : 0;
switch (type) {
case ANIMATION_START:
log("%d start: %s", trackIndex, animationName);
break;
case ANIMATION_END:
log("%d end: %s", trackIndex, animationName);
break;
case ANIMATION_COMPLETE:
log("%d complete: %s, %d", trackIndex, animationName, loopCount);
break;
case ANIMATION_EVENT:
log("%d event: %s, %s: %d, %f, %s", trackIndex, animationName, event->data->name, event->intValue, event->floatValue, event->stringValue);
break;
} }
} }

View File

@ -44,6 +44,7 @@ public:
virtual bool init (); virtual bool init ();
virtual void update (float deltaTime); virtual void update (float deltaTime);
void animationStateEvent (spine::CCSkeletonAnimation* node, int trackIndex, spEventType type, spEvent* event, int loopCount);
CREATE_FUNC (SpineTestLayer); CREATE_FUNC (SpineTestLayer);
}; };

View File

@ -0,0 +1 @@
1d6f59e3732b50c100af321f566c36be2576714c

View File

@ -1 +1 @@
c22eca8f608170bab4ceb0086e48999fb2e3d32b c89eb3a469e797df40e9f119b16866acc040a9e0

View File

@ -0,0 +1 @@
1d6f59e3732b50c100af321f566c36be2576714c