首页 技术 正文
技术 2022年11月15日
0 收藏 511 点赞 3,444 浏览 7074 个字

|   版权声明:本文为博主原创文章,未经博主允许不得转载。

  Scene场景也是cocos2dx中必不可少的元素,游戏中通常我们需要构建不同的场景(至少一个),游戏里关卡、版块的切换也就是一个一个场景的切换,就像在电影中变换舞台和场地一样。场景的一个重要的作用就是流程控制的作用,我们可以通过Director的一系列方法控制游戏中不同的场景的自由切换。下面是Director控制场景的常用方法:

runWithScene( Scene *scene )
/*启动游戏,并运行scene场景。本方法在主程序第一次启动主场景的时候调用。如果已有正在运行的场景则不能调用该方法;会调用pushScene-->startAnimation。*/
pushScene( Scene *scene )
/*将当前运行中的场景暂停并压入到代码执行场景栈中,再将传入的scene设置为当前运行场景,只有存在正在运行的场景时才调用该方法;*/
replaceScene( Scene *scene )
/*直接使用传入的scene替换当前场景来切换画面,当前场景被释放。这是切换场景时最常用的方法。*/
popScene()
/*释放当前场景,再从代码执行场景中弹出栈顶的场景,并将其设置为当前运行场景。如果栈为空,直接结束应用。和PushScene结对使用 */
end()
//释放和终止执行场景,同时退出应用
pause()
//暂停当前运行场景中的所有计时器和动作,场景仍然会显示在屏幕上
resume()
//恢复当前运行场景的所有计时器和动作,场景仍然会显示在屏幕上

  

  同时场景是层的容器,包含了所有需要显示的游戏元素。通常,当我们需要完成一个场景时候,会创建一个Scene的子类,并在子类中实现我们需要的功能。比如,我们可以在子类的初始化中载入游戏资源,为场景添加层,启动音乐播放 等等。

  Scene来是Node的一个子类。和Node相比,Scene只是添加了一个特性,它拥有自己的锚点,位置在运行窗口屏幕的正中央。除此之外,再也没有额外的功能,只是一个抽象的概念

新建,运行一个场景的方法:

使用AppDelegate类中的applicationDidFinishLaunching函数中调用上一步定义的方法,并使用导演类的runWithScene方法运行场景,如下

Scene* MyGame::createScene()
{
//新建场景的实例
auto scene = Scene::create();
//定义布景层
auto layer = MyGame::create();
//将布景层加入场景
scene->addChild(layer);
//返回场景类
return scene;
}
// create a scene. it's an autorelease object
auto scene = MyGame::createScene();// run
director->runWithScene(scene);

场景的切换:

首先我们建立一个要切换新的Scene:

StartGame.h

#ifndef _START_GAME_SCENE_H_
#define _START_GAME_SCENE_H_
#include "cocos2d.h"class MyGameBegin : public cocos2d::Layer
{
public:
static cocos2d::Scene* createScene();
virtual bool init();
void startMenuItemback(cocos2d::Ref* pSender);
CREATE_FUNC(MyGameBegin);
};
#endif //_START_GAME_SCENE_H_

StartGame.cpp

#include "Startgame.h"
USING_NS_CC;Scene* MyGameBegin::createScene()
{
auto startScene = Scene::create();
auto startLayer = MyGameBegin::create();
startScene->addChild(startLayer);
return startScene;
}
bool MyGameBegin::init()
{
if (!Layer::init())
{
return false;
}
Size startSize = Director::getInstance()->getVisibleSize();
Vec2 startOrigin = Director::getInstance()->getVisibleOrigin();
auto startSprite = Sprite::create("bg2.png");
startSprite->setPosition(Vec2(startSize.width / 2 + startOrigin.x, startOrigin.y + startSize.height / 2));
float xs = startSize.width / startSprite->getContentSize().width;
float ys = startSize.height / startSprite->getContentSize().height;
startSprite->setScale(xs, ys);
this->addChild(startSprite);return true;
}

MyGameScene.h

#ifndef _MYGAME_SCENE_H_
#define _MYGAME_SCENE_H_
#include "cocos2d.h"class MyGame : public cocos2d::Layer
{
public:
static cocos2d::Scene* createScene();
virtual bool init();
void startMenuItemback(cocos2d::Ref* pSender); //start的回调函数,在这里切换场景
void helpMenuItemback(cocos2d::Ref* pSender);//点击start的回调函数
void exitMenuItemback(cocos2d::Ref* pSender);//点击start的回调函数
CREATE_FUNC(MyGame);
};
#endif // _MYGAME_SCENE_H_

MyGameScene.cpp

#include "MyGameScene.h"
#include "StartGame.h" //要包含切换场景的头文件
USING_NS_CC;Scene* MyGame::createScene()
{
auto scene = Scene::create();
auto layer = MyGame::create();
scene->addChild(layer);
return scene;
}bool MyGame::init()
{
if (!Layer::init())
{
return false;
}
Size visibleSize = Director::getInstance()->getVisibleSize();
Vec2 origin = Director::getInstance()->getVisibleOrigin();//设置Sprite
auto bg = Sprite::create("bg1.png");
bg->setPosition(Vec2(visibleSize.width / 2 + origin.x, visibleSize.height / 2 + origin.y));//下面是将图片调节到与窗口同比例的缩放;图片 / 窗口
float xs = visibleSize.width / bg->getContentSize().width;
float ys = visibleSize.height / bg->getContentSize().height;
bg->setScale(xs, ys);
this->addChild(bg,0);auto mouse = Sprite::create("mouse.png");
mouse->setPosition(Vec2(visibleSize.width / 3 + origin.x, visibleSize.height / 4 + origin.y));
mouse->setScale(0.5, 0.5);
this->addChild(mouse, 1);auto hammer = Sprite::create("hammer.png");
hammer->setPosition(Vec2(visibleSize.width / 2.5 + origin.x, visibleSize.height / 2 + origin.y));
hammer->setScale(0.7, 0.7);
this->addChild(hammer);//设置Label
auto label = Label::createWithTTF("Whac-a-mole", "fonts/Marker Felt.ttf", 38);
label->setPosition(Vec2(origin.x + visibleSize.width / 2,
origin.y + visibleSize.height - label->getContentSize().height));
this->addChild(label,1);//设置一个菜单项,
auto start = MenuItemFont::create("Start", CC_CALLBACK_1(MyGame::startMenuItemback, this));
start->setPosition(Vec2(origin.x + visibleSize.width / 2,
(origin.y + visibleSize.height - (visibleSize.height / 2))));auto menu1 = Menu::create(start, NULL);
menu1->setPosition(Vec2(0,0));
this->addChild(menu1);auto help = MenuItemFont::create("Help", CC_CALLBACK_1(MyGame::helpMenuItemback, this));
help->setPosition(Vec2(origin.x + visibleSize.width / 2,
(origin.y + visibleSize.height - (visibleSize.height / 2) - (Help->getContentSize().height*1.5))));
auto menu2 = Menu::create(help, NULL);
menu2->setPosition(Vec2(0, 0));
this->addChild(menu2);auto exit = MenuItemFont::create("Exit", CC_CALLBACK_1(MyGame::exitMenuItemback, this));
exit->setPosition(Vec2(origin.x + visibleSize.width / 2,
(origin.y + visibleSize.height - (visibleSize.height / 2) - ((Exit->getContentSize().height*1.5) * 2))));
auto menu3 = Menu::create(exit, NULL);
menu3->setPosition(Vec2(0, 0));
this->addChild(menu3);return true;
}//replaceScene()切换场景,在回调函数中切换场景
void MyGame::startMenuItemback(Ref* pSender)
{
//这里写回调函数的操作
Director::getInstance()->replaceScene(TransitionJumpZoom::create(2, MyGameBegin::createScene()));
}void MyGame::helpMenuItemback(Ref* pSender)
{
//这里写回调函数的操作
}void MyGame::exitMenuItemback(Ref* pSender)
{
//这里写回调函数的操作
Director::getInstance()->end(); //exit(0);也可以
}

效果图:

开始点击进入游戏:start

Cocos2d-x之Scene

切换的过程中的过渡效果:TransitionJumpZoom::create(time,Scene)

Cocos2d-x之Scene

 

>>场景切换效果函数汇总

TransitionCrossFade::create(time,Scene);
慢慢淡化到另一场景 TransitionFade::create(time,Scene);
本场景变暗消失后另一场景慢慢出现 TransitionFadeBL::create(time,Scene);
本场景右上角到左下角方块消失到另一场景 TransitionFadeDown::create(time,Scene);
本场景从上到下横条消失到另一场景 TransitionFadeTR::create(time,Scene);
本场景左下角到右上角方块消失到另一场景TransitionFadeUp::create(time,Scene);
本场景从下到上横条消失到另一场景TransitionFlipAngular::create(time,Scene,style );
本场景翻转消失到另一场景(斜上方)TransitionFlipX::create(time,Scene,style);
本场景翻转消失到另一场景(X轴)TransitionFlipY::create(time,Scene);
本场景翻转消失到另一场景(Y轴) TransitionJumpZoom::create(time,Scene);
本场景跳动消失后另一场景跳动出现 TransitionMoveInB::create(time,Scene);
另一场景由整体从下面出现 TransitionMoveInL::create(time,Scene);
另一场景由整体从左面出现 TransitionMoveInT::create(time,Scene);
另一场景由整体从上面出现 TransitionMoveInR::create(time,Scene);
另一场景由整体从右面出现 TransitionPageTurn::create(time,Scene,bool);
翻页切换,bool为true是向前翻。 TransitionProgressHorizontal::create(time,Scene);
本场景从左到右消失同时另一场景出现 TransitionProgressInOut::create(time,Scene);
本场景从中间到四周消失同时另一场景出现 TransitionProgressOutIn::create(time,Scene);
本场景从四周到中间消失同时另一场景出现 TransitionProgressRadialCCW::create(time,Scene);
本场景逆时针消失到另一场景 TransitionProgressRadialCW::create(time,Scene);
本场景顺时针消失到另一场景 TransitionProgressVertical::create(time,Scene);
本场景从上到下消失同时另一场景出现 TransitionRotoZoom::create(time,Scene);
本场景旋转消失后另一场景旋转出现 TransitionShrinkGrow::create(time,Scene);
本场景缩小切换到另一场景放大 TransitionSlideInB::create(time,Scene);
本场景向上滑动到另一场景 TransitionSlideInL::create(time,Scene);
本场景向右滑动到另一场景 TransitionSlideInR::create(time,Scene);
本场景向左滑动到另一场景 TransitionSlideInT::create(time,Scene);
本场景向下滑动到另一场景 TransitionSplitCols::create(time,Scene);
本场景三矩形上下消失后另一场景三矩形上下 TransitionSplitRows::create(time,Scene);
本场景三矩形左右消失后另一场景三矩形左右 TransitionTurnOffTiles::create(time,Scene);
本场景小方块消失到另一场景 TransitionZoomFlipAngular::create(time,Scene,style);
本场景翻转消失到另一场景(斜上方) TransitionZoomFlipX::create(time,Scene,style);
本场景翻转消失到另一场景(X轴) TransitionZoomFlipY::create(time,Scene,style);
本场景翻转消失到另一场景(Y轴 )

切换成功:

Cocos2d-x之Scene

相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:8,994
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,507
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,350
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,135
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:7,768
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:4,845