Learning Cocos2d-x for WP8(6)——场景切换和场景过渡效果
原文:Learning Cocos2d-x for WP8(6)——场景切换和场景过渡效果
C#(wp7)兄弟篇 Learning Cocos2d-x for XNA(6)——场景切换和场景过渡效果
工程文件:SceneTransitionTest.h和SceneTransitionTestc.cpp
开始菜单
添加背景和菜单按钮素材至Assets中


SceneTransitionTest.h
在SceneTransitionTest.h中添加两个Class(SceneTransitionTestScene和SceneTransitionTestLayer)分别用于Scene和Layer。
核心代码
class SceneTransitionTestScene:public CCScene
{
public:
SceneTransitionTestScene();
~SceneTransitionTestScene(); virtual void onEnter();
}; class SceneTransitionTestLayer:public CCLayer
{
public:
SceneTransitionTestLayer();
~SceneTransitionTestLayer(); void btnStartClickCallback(CCObject* pSender);//开始按钮
void btnSettingClickCallback(CCObject* pSender);//设置按钮
void btnRecordClickCallback(CCObject* pSender);//纪录按钮
void btnHelpClickCallback(CCObject* pSender);//帮助按钮
};
SceneTransitionTest.cpp
SceneTransitionTestScene::onEnter()中主要添加Layer值Scene中
SceneTransitionTestLayer::SceneTransitionTestLayer()中实现背景、菜单按钮的添加。
核心代码
//------------------------------------
//
//SceneTransitionTestLayer
//
//------------------------------------
SceneTransitionTestLayer::SceneTransitionTestLayer()
{
CCDirector::sharedDirector()->setDeviceOrientation(ccDeviceOrientation::kCCDeviceOrientationPortrait);//设置朝向,竖屏
//背景
CCSprite* pBackground=CCSprite::spriteWithFile("img_background.png");
pBackground->setAnchorPoint(ccp(,)); //设置锚点在图片右上角
pBackground->setPosition(ccp(,));
this->addChild(pBackground,-); //菜单按钮
char strBtnMenuItemSprite[]="btn_Menu.png";
CCSprite* btnStartNormal=CCSprite::spriteWithFile(strBtnMenuItemSprite,CCRectMake(,*,,));
CCSprite* btnStartSelected=CCSprite::spriteWithFile(strBtnMenuItemSprite,CCRectMake(,*,,));
CCSprite* btnSettingNormal =CCSprite::spriteWithFile(strBtnMenuItemSprite,CCRectMake(,*,,));
CCSprite* btnSettingSelected =CCSprite::spriteWithFile(strBtnMenuItemSprite,CCRectMake(,*,,));
CCSprite* btnRecordNormal =CCSprite::spriteWithFile(strBtnMenuItemSprite,CCRectMake(,*,,));
CCSprite* btnRecordSelected =CCSprite::spriteWithFile(strBtnMenuItemSprite,CCRectMake(,*,,));
CCSprite* btnHelpNormal =CCSprite::spriteWithFile(strBtnMenuItemSprite,CCRectMake(,*,,));
CCSprite* btnHelpSelected =CCSprite::spriteWithFile(strBtnMenuItemSprite,CCRectMake(,*,,)); CCMenuItemSprite* btnStart=CCMenuItemSprite::itemFromNormalSprite(btnStartNormal,btnStartSelected,this,menu_selector(SceneTransitionTestLayer::btnStartClickCallback));
CCMenuItemSprite* btnSetting=CCMenuItemSprite::itemFromNormalSprite(btnSettingNormal,btnSettingSelected,this,menu_selector(SceneTransitionTestLayer::btnSettingClickCallback));
CCMenuItemSprite* btnRecord=CCMenuItemSprite::itemFromNormalSprite(btnRecordNormal,btnRecordSelected,this,menu_selector(SceneTransitionTestLayer::btnRecordClickCallback));
CCMenuItemSprite* btnHelp=CCMenuItemSprite::itemFromNormalSprite(btnHelpNormal,btnHelpSelected,this,menu_selector(SceneTransitionTestLayer::btnHelpClickCallback)); CCMenu* menu=CCMenu::menuWithItems(btnStart,btnSetting,btnRecord,btnHelp,NULL);
menu->alignItemsVertically();
this->addChild(menu,);
} SceneTransitionTestLayer::~SceneTransitionTestLayer()
{} void SceneTransitionTestLayer::btnStartClickCallback(CCObject* sender)
{} void SceneTransitionTestLayer::btnSettingClickCallback(CCObject* sender)
{} void SceneTransitionTestLayer::btnRecordClickCallback(CCObject* sender)
{} void SceneTransitionTestLayer::btnHelpClickCallback(CCObject* sender)
{} //------------------------------------
//
//SceneTransitionTestScene
//
//------------------------------------
SceneTransitionTestScene::SceneTransitionTestScene()
{} SceneTransitionTestScene::~SceneTransitionTestScene()
{} void SceneTransitionTestScene::onEnter()
{
CCScene::onEnter();
CCLayer* pStartPageLayer=new SceneTransitionTestLayer();
this->addChild(pStartPageLayer);
pStartPageLayer->release();
}
此部分代码实现主要实现Menu菜单
运行显示效果

设置屏幕朝向deviceOrientation
默认下是横屏显示,该属性有四个值
kCCDeviceOrientationLandscapeLeft 始终朝向设备左侧
kCCDeviceOrientationLandscapeRight 始终朝向设备右侧
kCCDeviceOrientationPortrait 、kCCDeviceOrientationPortraitUpsideDown 始终朝向设备下侧
现在我们要它竖屏显示
CCDirector::sharedDirector()->setDeviceOrientation(ccDeviceOrientation::kCCDeviceOrientationPortrait);//设置朝向,竖屏
设置背景图
我们用CCSprite实现,其中涉及到anchorPoint(锚点),简单的讲,默认下,cocos2d-x识别图片的position是以图片的中心为基准的,这点为锚点,我们可以设置锚点的位置,符合我们的需求。
pBackground->setAnchorPoint(ccp(,));//设置锚点在图片右上角
pBackground->setPosition(ccp(,));
当然,你也可以不修改anchorPoint,默认锚点(图片中心),实现图片位置。
addChild方法,使用了addChild(CCNode child, int zOrder)
其中zOrder为坐标轴的Z方向。其目的是同层中显示的顺序(遮挡)。
cocos2d提供的访问顺序是Z-Order为负值的子节点->自身节点->Z-Order为正值的子节点。
“设置”页面
SceneTransitionTest.h
同样在SceneTransitionTest.h中添加两类(SettingScene和SettingLayer)用于Scene和Layer。
核心代码
//-----------------------------------------
//
//SettingScene
//
//-----------------------------------------
class SettingScene:public CCScene
{
public:
SettingScene();
~SettingScene(); virtual void onEnter();
}; class SettingLayer:public CCLayer
{
public:
SettingLayer();
~SettingLayer(); public:
void MenuItemSoundCallback(CCObject* pSender);//音效Toggle
void MenuItemBackgroundCallback(CCObject* pSender);//背景Toggle
void BtnGoBackCallback(CCObject* pSender);//返回按钮
};
SceneTransitionTest.cpp
SettingScene::onEnter()中实现Layer加载至Scene
SettingLayer::SettingLayer()实现界面背景和菜单的设置
核心代码
//------------------------------------
//
//SettingLayer
//
//------------------------------------ SettingLayer::SettingLayer()
{
//背景
CCSprite* pBackground=CCSprite::spriteWithFile("img_background.png");
pBackground->setAnchorPoint(ccp(,)); //设置锚点在图片右上角
pBackground->setPosition(ccp(,));
this->addChild(pBackground,-); //菜单
CCMenuItemLabel* pMenuItemSoundTitle=CCMenuItemLabel::itemWithLabel(CCLabelBMFont::labelWithString("音效","fonts/YaHeiChinese.fnt"));
pMenuItemSoundTitle->setScale(2.0f);//放大2.0倍
pMenuItemSoundTitle->setIsEnabled(false);
pMenuItemSoundTitle->setColor(ccc3(,,));//字体颜色
CCMenuItemToggle* pMenuItemSound=CCMenuItemToggle::itemWithTarget(this,
menu_selector(SettingLayer::MenuItemSoundCallback),
CCMenuItemFont::itemFromString("On"),
CCMenuItemFont::itemFromString("Off"),
NULL);
CCMenuItemLabel* pMenuItemBackgroundTitle=CCMenuItemLabel::itemWithLabel(CCLabelBMFont::labelWithString("背景","fonts/YaHeiChinese.fnt"));
pMenuItemBackgroundTitle->setScale(2.0f);//放大2.0倍
pMenuItemBackgroundTitle->setIsEnabled(false);
pMenuItemBackgroundTitle->setColor(ccc3(,,));//字体颜色
CCMenuItemToggle* pMenuItemBackground=CCMenuItemToggle::itemWithTarget(this,
menu_selector(SettingLayer::MenuItemBackgroundCallback),
CCMenuItemSprite::itemFromNormalSprite(CCSprite::spriteWithFile("bg_Sea1Mini.png"),CCSprite::spriteWithFile("bg_Sea1Mini.png")),
CCMenuItemSprite::itemFromNormalSprite(CCSprite::spriteWithFile("bg_Sea2Mini.jpg"),CCSprite::spriteWithFile("bg_Sea2Mini.jpg")),
NULL); CCMenu* menu=CCMenu::menuWithItems(pMenuItemSoundTitle,pMenuItemSound,pMenuItemBackgroundTitle,pMenuItemBackground,NULL);
menu->alignItemsVerticallyWithPadding();
this->addChild(menu,); //返回按钮
CCSize s=CCDirector::sharedDirector()->getWinSize();
CCLabelTTF* pGoBack=CCLabelTTF::labelWithString("Go Back","fonts/YaHeiChinese.fnt",);
pGoBack->setColor(ccc3(,,));
CCMenuItemLabel* btnGoBack=CCMenuItemLabel::itemWithLabel(pGoBack,this,menu_selector(SettingLayer::BtnGoBackCallback));
CCMenu* menuGoBack=CCMenu::menuWithItem(btnGoBack);
menuGoBack->setPosition(s.width/,);
this->addChild(menuGoBack);
} SettingLayer::~SettingLayer()
{} void SettingLayer::MenuItemSoundCallback(CCObject* sender)
{} void SettingLayer::MenuItemBackgroundCallback(CCObject* sender)
{} void SettingLayer::BtnGoBackCallback(CCObject* sender)
{} //------------------------------------
//
//SettingScene
//
//------------------------------------ SettingScene::SettingScene()
{} SettingScene::~SettingScene()
{} void SettingScene::onEnter()
{
CCScene::onEnter();
CCLayer* pLayer=new SettingLayer();
this->addChild(pLayer);
pLayer->release();
}
运行显示效果

场景切换
CCDirector中的三个方法
void CCDirector::pushScene(CCScene *pScene)
终止正在运行的场景,把它放到暂停场景的堆栈(内存)中去,新的场景将被执行。由于将场景放置内存中,场景并没有release。
void CCDirector::popScene(void)
将经过pushScene的场景从堆栈(内存)中pop出来执行(前提是堆栈内存中存在场景)。
void CCDirector::replaceScene(CCScene *pScene)
用一个新的场景去替换掉正在运行的场景,正在运行的场景将被终止。
开始菜单“设置”按钮添加事件处理,pushScene切换场景(页面)。
void SceneTransitionTestLayer::btnSettingClickCallback(CCObject* sender)
{
CCScene* pSettingScene=new SettingScene();
CCDirector::sharedDirector()->pushScene(pSettingScene);
}
“设置”页面返回添加事件处理,popScene切换场景(页面)。
void SettingLayer::BtnGoBackCallback(CCObject* sender)
{
CCDirector::sharedDirector()->popScene();
}
执行,点击“设置”,会跳转到“设置”页面,同样再点击“返回”按钮时,可实现返回之前的页面(场景)。
同样,你可在replaceScene实现同样的效果。
场景切换特效

CCTransitionFade, //渐隐效果
CCTransitionFadeTR, //碎片效果
CCTransitionJumpZoom, //跳动效果
CCTransitionMoveInL, //从左向右移动
CCTransitionPageTurn, //翻页效果
CCTransitionRadialCCW, //钟摆效果
CCTransitionRotoZoom,//涡轮效果
CCTransitionSceneOriented,//
CCTransitionShrinkGrow, //渐远效果
CCTransitionSlideInL, //左移
CCTransitionSplitCols,//上下移动
CCTransitionTurnOffTiles//
CCTransitionScene : CCScene 基类
CCRotoZoomTransition 旋转缩小切换
CCJumpZoomTransition 缩小后跳跃切换
CCSlideInLTransition 从左向右切换
CCSlideInRTransition 从右向左切换
CCSlideInTTransition 从上向下切换
CCSlideInBTransition 从下向上切换
CCShrinkGrowTransition 逐渐缩小切换
CCFlipXTransition 已x中间为轴平面式旋转切换
CCFlipYTransition 已y中间为轴平面式旋转切换
CCFlipAngularTransition 侧翻式旋转切换
CCZoomFlipXTransition 缩小后x为轴旋转切换
CCZoomFlipYTransition 缩小后y为轴旋转切换
CCZoomFlipAngularTransition 缩小侧翻式旋转切换
CCFadeTransition 逐渐变暗切换
CCCrossFadeTransition 逐渐变暗切换2
CCTurnOffTilesTransition 随机方块覆盖切换
CCSplitColsTransition 三条上下分开切换
CCSplitRowsTransition 三条左右分开切换
CCFadeTRTransition 小方块大方块式切换左下到右上眩!
CCFadeBLTransition 小方块大方块式切换右上到左下眩!
CCFadeUpTransition 百叶窗从下向上
CCFadeDownTransition 百叶窗从上向下
CCTransitionRotoZoom : CCTransitionScene 旋转进入
CCTransitionJumpZoom : CCTransitionScene 跳动进入
CCTransitionMoveInL : CCTransitionScene<CCTransitionEaseScene> 从左侧进入
CCTransitionMoveInR : CCTransitionMoveInL 从右侧进入
CCTransitionMoveInT : CCTransitionMoveInL 从顶部进入
CCTransitionMoveInB : CCTransitionMoveInL 从底部进入
CCTransitionSlideInL :
CCTransitionScene<CCTransitionEaseScene> 从左侧滑入
CCTransitionSlideInR : CCTransitionSlideInL 从右侧滑入
CCTransitionSlideInB : CCTransitionSlideInL 从顶部滑入
CCTransitionSlideInT : CCTransitionSlideInL 从底部滑入
CCTransitionShrinkGrow : CCTransitionScene<CCTransitionEaseScene> 交替进入
CCTransitionFlipX : CCTransitionSceneOriented x轴翻入(左右)
CCTransitionFlipY : CCTransitionSceneOriented y轴翻入(上下)
CCTransitionFlipAngular : CCTransitionSceneOriented 左上右下轴翻入
CCTransitionZoomFlipX : CCTransitionSceneOriented x轴翻入放大缩小效果(左右)
CCTransitionZoomFlipY : CCTransitionSceneOriented y轴翻入放大缩小效果(上下)
CCTransitionZoomFlipAngular :CCTransitionSceneOriented 左上右下轴翻入放大缩小效果
CCTransitionFade : CCTransitionScene 变暗变亮进入
CCTransitionCrossFade : CCTransitionScene 渐变进入
CCTransitionTurnOffTiles : CCTransitionScene<CCTransitionEaseScene> 小方格消失进入
CCTransitionSplitCols : CCTransitionScene<CCTransitionEaseScene> 竖条切换进入
CCTransitionSplitRows : CCTransitionSplitCols 横条切换进入
CCTransitionFadeTR : CCTransitionScene<CCTransitionEaseScene> 小方格右上角显示进入
CCTransitionFadeBL : CCTransitionFadeTR 小方格左下角显示进入
CCTransitionFadeUp : CCTransitionFadeTR 横条向上显示进入
CCTransitionFadeDown : CCTransitionFadeTR 横条向下显示进入
修改开始菜单“设置”按钮事件处理,添加CCTransitionZoomFlipX作为场景切换特效的过渡效果。
void SceneTransitionTestLayer::btnSettingClickCallback(CCObject* sender)
{
CCScene* pSettingScene=new SettingScene();
CCScene* transSettingScene=CCTransitionFlipX::transitionWithDuration(1.2f,pSettingScene,tOrientation::kOrientationLeftOver);//场景切换特效
CCDirector::sharedDirector()->pushScene(transSettingScene);
}
运行,点击“设置”按钮,场景切换添加了转场效果。


这样,添加场景切换特效的过渡后,使得场景切换不再生硬,显得更炫。
SceneTransitionTest.h完整源码
#ifndef _SCENE_TRANSITION_TEST_
#define _SCENE_TRANSITION_TEST_ #include "cocos2d.h" using namespace cocos2d; class SceneTransitionTestScene:public CCScene
{
public:
SceneTransitionTestScene();
~SceneTransitionTestScene(); virtual void onEnter();
}; class SceneTransitionTestLayer:public CCLayer
{
public:
SceneTransitionTestLayer();
~SceneTransitionTestLayer(); void btnStartClickCallback(CCObject* pSender);//开始按钮
void btnSettingClickCallback(CCObject* pSender);//设置按钮
void btnRecordClickCallback(CCObject* pSender);//纪录按钮
void btnHelpClickCallback(CCObject* pSender);//帮助按钮
}; //-----------------------------------------
//
//SettingScene
//
//-----------------------------------------
class SettingScene:public CCScene
{
public:
SettingScene();
~SettingScene(); virtual void onEnter();
}; class SettingLayer:public CCLayer
{
public:
SettingLayer();
~SettingLayer(); public:
void MenuItemSoundCallback(CCObject* pSender);//音效Toggle
void MenuItemBackgroundCallback(CCObject* pSender);//背景Toggle
void BtnGoBackCallback(CCObject* pSender);//返回按钮
}; #endif
SceneTransitionTest.cpp完整源码
/*www.cnblogs.com/suguoqiang*/
#include "pch.h"
#include "Classes\SceneTransitionTest.h" //------------------------------------
//
//SceneTransitionTestLayer
//
//------------------------------------
SceneTransitionTestLayer::SceneTransitionTestLayer()
{
CCDirector::sharedDirector()->setDeviceOrientation(ccDeviceOrientation::kCCDeviceOrientationPortrait);//设置朝向,竖屏
//背景
CCSprite* pBackground=CCSprite::spriteWithFile("img_background.png");
pBackground->setAnchorPoint(ccp(,));//设置锚点在图片右上角
pBackground->setPosition(ccp(,));
this->addChild(pBackground,-); //菜单按钮
char strBtnMenuItemSprite[]="btn_Menu.png";
CCSprite* btnStartNormal=CCSprite::spriteWithFile(strBtnMenuItemSprite,CCRectMake(,*,,));
CCSprite* btnStartSelected=CCSprite::spriteWithFile(strBtnMenuItemSprite,CCRectMake(,*,,));
CCSprite* btnSettingNormal =CCSprite::spriteWithFile(strBtnMenuItemSprite,CCRectMake(,*,,));
CCSprite* btnSettingSelected =CCSprite::spriteWithFile(strBtnMenuItemSprite,CCRectMake(,*,,));
CCSprite* btnRecordNormal =CCSprite::spriteWithFile(strBtnMenuItemSprite,CCRectMake(,*,,));
CCSprite* btnRecordSelected =CCSprite::spriteWithFile(strBtnMenuItemSprite,CCRectMake(,*,,));
CCSprite* btnHelpNormal =CCSprite::spriteWithFile(strBtnMenuItemSprite,CCRectMake(,*,,));
CCSprite* btnHelpSelected =CCSprite::spriteWithFile(strBtnMenuItemSprite,CCRectMake(,*,,)); CCMenuItemSprite* btnStart=CCMenuItemSprite::itemFromNormalSprite(btnStartNormal,btnStartSelected,this,menu_selector(SceneTransitionTestLayer::btnStartClickCallback));
CCMenuItemSprite* btnSetting=CCMenuItemSprite::itemFromNormalSprite(btnSettingNormal,btnSettingSelected,this,menu_selector(SceneTransitionTestLayer::btnSettingClickCallback));
CCMenuItemSprite* btnRecord=CCMenuItemSprite::itemFromNormalSprite(btnRecordNormal,btnRecordSelected,this,menu_selector(SceneTransitionTestLayer::btnRecordClickCallback));
CCMenuItemSprite* btnHelp=CCMenuItemSprite::itemFromNormalSprite(btnHelpNormal,btnHelpSelected,this,menu_selector(SceneTransitionTestLayer::btnHelpClickCallback)); CCMenu* menu=CCMenu::menuWithItems(btnStart,btnSetting,btnRecord,btnHelp,NULL);
menu->alignItemsVertically();
this->addChild(menu,);
} SceneTransitionTestLayer::~SceneTransitionTestLayer()
{} void SceneTransitionTestLayer::btnStartClickCallback(CCObject* sender)
{} void SceneTransitionTestLayer::btnSettingClickCallback(CCObject* sender)
{
CCScene* pSettingScene=new SettingScene();
CCScene* transSettingScene=CCTransitionFlipX::transitionWithDuration(5.2f,pSettingScene,tOrientation::kOrientationLeftOver);//场景切换特效
CCDirector::sharedDirector()->pushScene(transSettingScene);
} void SceneTransitionTestLayer::btnRecordClickCallback(CCObject* sender)
{} void SceneTransitionTestLayer::btnHelpClickCallback(CCObject* sender)
{} //------------------------------------
//
//SceneTransitionTestScene
//
//------------------------------------
SceneTransitionTestScene::SceneTransitionTestScene()
{} SceneTransitionTestScene::~SceneTransitionTestScene()
{} void SceneTransitionTestScene::onEnter()
{
CCScene::onEnter();
CCLayer* pStartPageLayer=new SceneTransitionTestLayer();
this->addChild(pStartPageLayer);
pStartPageLayer->release();
} //------------------------------------
//
//SettingLayer
//
//------------------------------------ SettingLayer::SettingLayer()
{
//背景
CCSprite* pBackground=CCSprite::spriteWithFile("img_background.png");
pBackground->setAnchorPoint(ccp(,));//设置锚点在图片右上角
pBackground->setPosition(ccp(,));
this->addChild(pBackground,-); //菜单
CCMenuItemLabel* pMenuItemSoundTitle=CCMenuItemLabel::itemWithLabel(CCLabelBMFont::labelWithString("音效","fonts/YaHeiChinese.fnt"));
pMenuItemSoundTitle->setScale(2.0f);//放大2.0倍
pMenuItemSoundTitle->setIsEnabled(false);
pMenuItemSoundTitle->setColor(ccc3(,,));//字体颜色
CCMenuItemToggle* pMenuItemSound=CCMenuItemToggle::itemWithTarget(this,
menu_selector(SettingLayer::MenuItemSoundCallback),
CCMenuItemFont::itemFromString("On"),
CCMenuItemFont::itemFromString("Off"),
NULL);
CCMenuItemLabel* pMenuItemBackgroundTitle=CCMenuItemLabel::itemWithLabel(CCLabelBMFont::labelWithString("背景","fonts/YaHeiChinese.fnt"));
pMenuItemBackgroundTitle->setScale(2.0f);//放大2.0倍
pMenuItemBackgroundTitle->setIsEnabled(false);
pMenuItemBackgroundTitle->setColor(ccc3(,,));//字体颜色
CCMenuItemToggle* pMenuItemBackground=CCMenuItemToggle::itemWithTarget(this,
menu_selector(SettingLayer::MenuItemBackgroundCallback),
CCMenuItemSprite::itemFromNormalSprite(CCSprite::spriteWithFile("bg_Sea1Mini.png"),CCSprite::spriteWithFile("bg_Sea1Mini.png")),
CCMenuItemSprite::itemFromNormalSprite(CCSprite::spriteWithFile("bg_Sea2Mini.jpg"),CCSprite::spriteWithFile("bg_Sea2Mini.jpg")),
NULL); CCMenu* menu=CCMenu::menuWithItems(pMenuItemSoundTitle,pMenuItemSound,pMenuItemBackgroundTitle,pMenuItemBackground,NULL);
menu->alignItemsVerticallyWithPadding();
this->addChild(menu,); //返回按钮
CCSize s=CCDirector::sharedDirector()->getWinSize();
CCLabelTTF* pGoBack=CCLabelTTF::labelWithString("Go Back","fonts/YaHeiChinese.fnt",);
pGoBack->setColor(ccc3(,,));
CCMenuItemLabel* btnGoBack=CCMenuItemLabel::itemWithLabel(pGoBack,this,menu_selector(SettingLayer::BtnGoBackCallback));
CCMenu* menuGoBack=CCMenu::menuWithItem(btnGoBack);
menuGoBack->setPosition(s.width/,);
this->addChild(menuGoBack);
} SettingLayer::~SettingLayer()
{} void SettingLayer::MenuItemSoundCallback(CCObject* sender)
{} void SettingLayer::MenuItemBackgroundCallback(CCObject* sender)
{} void SettingLayer::BtnGoBackCallback(CCObject* sender)
{
//场景切换特效返回
//CCScene* pSceneTransitionTestScene=new SceneTransitionTestScene();
//CCScene* transSceneTransitionTestScene=CCTransitionJumpZoom::transitionWithDuration(1.2f,pSceneTransitionTestScene);
//CCDirector::sharedDirector()->replaceScene(transSceneTransitionTestScene);
CCDirector::sharedDirector()->popScene();
} //------------------------------------
//
//SettingScene
//
//------------------------------------ SettingScene::SettingScene()
{} SettingScene::~SettingScene()
{} void SettingScene::onEnter()
{
CCScene::onEnter();
CCLayer* pLayer=new SettingLayer();
this->addChild(pLayer);
pLayer->release();
}
著作权声明:本文由http://www.cnblogs.com/suguoqiang 原创,欢迎转载分享。请尊重作者劳动,转载时保留该声明和作者博客链接,谢谢!
Learning Cocos2d-x for WP8(6)——场景切换和场景过渡效果的更多相关文章
- cocos2dx3.1从零学习(二)菜单、场景切换、场景传值
转:http://www.it165.net/pro/html/201406/16195.html 回顾一下上一篇的内容,我们已经学会了创建一个新的场景scene,添加sprite和label到层中, ...
- cocos2dx 3.1从零学习(二)——菜单、场景切换、场景传值
回想一下上一篇的内容,我们已经学会了创建一个新的场景scene,加入sprite和label到层中.掌握了定时事件schedule. 我们能够顺利的写出打飞机的主场景框架. 上一篇的内容我练习了七个新 ...
- Cocos2d-X3.0 刨根问底(九)----- 场景切换(TransitionScene)源码分析
上一章我们分析了Scene与Layer相关类的源码,对Cocos2d-x的场景有了初步了解,这章我们来分析一下场景变换TransitionScene源码. 直接看TransitionScene的定义 ...
- Cocos2d-X3.0 刨根问底(九)----- 场景切换(TransitionScene)源代码分析
上一章我们分析了Scene与Layer相关类的源代码,对Cocos2d-x的场景有了初步了解,这章我们来分析一下场景变换TransitionScene源代码. 直接看TransitionScene的定 ...
- Cocos2d-x 学习笔记(3.1) Scene 场景与场景切换
1. Scene 简介 游戏中我们看到/看不到的所有元素都是展示在场景之Scene上. 我们可以把场景比作放在地上的没盖纸箱,层Layer是纸箱里堆放的玻璃,Sprite等元素画在玻璃Layer上,这 ...
- [cocos2d]场景切换以及切换进度显示
本文主要分两个部分叙述,第一是场景切换,第二是场景切换的进度显示. 一.场景切换 参考learn-iphone-and-ipad-cocos2d-game-development 第五章内容 coco ...
- [Cocos2d-x For WP8]Transition 场景切换
在游戏中通常会打完了一关之后就会从当前的场景转换到另外一关的场景了,在Cocos2d-x中是由CCScene类表示一个场景.那么场景(CCScene)是为游戏中的精灵(CCSprite)提供了舞台,场 ...
- cocos2d 场景切换和弹出场景、收回场景
场景弹出收回很简单 用以下代码在任意一个地方显示“设置场景”: [[CCDirector sharedDirector] pushScene:[Settings scene]]; 如果你身处“设置场景 ...
- 【Cocos2d-x 3.x】 场景切换生命周期、背景音乐播放和场景切换原理与源码分析
大部分游戏里有很多个场景,场景之间需要切换,有时候切换的时候会进行背景音乐的播放和停止,因此对这块内容进行了总结. 场景切换生命周期 场景切换用到的函数: bool Setting::init() { ...
随机推荐
- Swift - 在界面上生成81个随机红,灰色圆点(SpriteKit游戏开发)
下面是生成一个“围住神经猫”游戏的初始场景: 1,界面下方会生成9*9共81个圆点,同时圆点内部添加文本标签显示索引 2,默认圆点为灰色,每行随机取两个点变为红色 3,奇数行和偶数行有一定的错位,错位 ...
- 【Ubuntu】升到14,攻克了进入用户后没有菜单条导航栏的问题
控制台还能够进,用ctrl+alt+f1用老账号登录,用sudo adduser test新建立一个名字叫test的帐号 然后就能够进去了,可能是配置文件坏掉了
- 基于visual Studio2013解决面试题之0203栈实现
题目
- Office 2013 正式版 下载地址 带正版验证
万众期待的正式版Office 2013 降临---英文版/中文简体版 英文版软件下载地址: office_professional_plus_2013_x86_dvd en_office_profes ...
- 五种情况下会刷新控件状态(刷新所有子FWinControls的显示)——从DFM读取数据时、新增加子控件时、重新创建当前控件的句柄时、设置父控件时、显示状态被改变时
五种情况下会刷新控件状态(刷新控件状态才能刷新所有子FWinControls的显示): 在TWinControls.PaintControls中,对所有FWinControls只是重绘了边框,而没有整 ...
- setjmp和longjmp函数使用详解
源地址:http://blog.csdn.net/zhuanshenweiliu/article/details/41961975 非局部跳转语句---setjmp和longjmp函数.非局部指的是, ...
- span标签可以使用hide()方法隐藏吗?
/获取li下的span var $span = $('ul.selector li span'); //span对象隐藏 $span.hide(); //或者 $span.css('display', ...
- POJ1291-并查集/dfs
并查集 题意:找出给定的这些话中是否有冲突.若没有则最多有多少句是对的. /* 思路:如果第x句说y是对的,则x,y必定是一起的,x+n,y+n是一起的:反之x,y+n//y,x+n是一起的. 利用并 ...
- codeforces 604B More Cowbell
题目链接:http://codeforces.com/contest/604/problem/B 题意:n个数字,k个盒子,把n个数放入k个盒子中,每个盒子最多只能放两个数字,问盒子容量的最小值是多少 ...
- [Android学习笔记]ShareSDK的使用
ShareSDK使用方便,集成简单,正式客户端开发人员的首选组件 集成步骤,使用说明见官方文档: http://wiki.sharesdk.cn/Android_快速集成指南 记录: 直接使用官方De ...