Scene 场景。

是一个抽象的概念,仅被用作Node(节点)的一个子类.

Scene (场景)和Node(节点)几乎相同,不同的是Scene的默认锚点在屏幕的中心.

关于场景,不得不提的是场景之间的切换!效果挺炫的!下面看看33种切换效果,可以根据需要选择和扩展。

#ifndef __SceneTest__
#define __SceneTest__ #include "cocos2d.h"
USING_NS_CC;
class SceneTest : public Layer
{
public:
static Scene* createScene();
CREATE_FUNC(SceneTest);
virtual bool init();
bool onToucheBegans(Touch* touch,Event* ev);
}; class SceneConfig
{
public:
static SceneConfig* getInstance();
int getIndex();
void setIndex(int index);
std::string getBg();
protected:
private: }; #endif

SceneTest.h

#include "SceneTest.h"

static const char s_bg1[]="background1.png";
static const char s_bg2[]="HelloWorld.png";
#define str(name) #name
#define CL(classname) [](){auto scene = classname ::create(1.2f , SceneTest::createScene());log(str(classname));return scene;}
#define CLN(classname) [](){auto scene = classname ::create(1.2f , SceneTest::createScene(),false);log(str(classname));return scene;}
#define CLS(classname) [](){auto scene = classname ::create(1.2f , SceneTest::createScene(),ccc3(255, 0, 0));log(str(classname));return scene;}
#define CLM(classname) [](){auto scene = classname ::create(1.2f , SceneTest::createScene(),TransitionScene::Orientation::LEFT_OVER);log(str(classname));return scene;} static std::function<Scene*()> createFunctions[] = {
CL(TransitionJumpZoom),//作用: 创建一个跳动的过渡动画
CL(TransitionProgressRadialCCW), // 作用: 创建一个扇形条形式的过渡动画, 逆时针方向
CL(TransitionProgressRadialCW),// 作用: 创建一个扇形条形式的过渡动画, 顺时针方向
CL(TransitionProgressHorizontal),// 作用: 创建一个水平条形式的过渡动画
CL(TransitionProgressVertical),// 作用: 创建一个垂直条形式的过渡动画
CL(TransitionProgressInOut),// 作用: 创建一个由里向外扩展的过渡动画
CL(TransitionProgressOutIn),// 作用: 创建一个由外向里扩展的过渡动画
CL(TransitionCrossFade),// 作用:创建一个逐渐透明的过渡动画
CL(TransitionFadeTR),// 作用:创建一个部落格过渡动画, 从左下到右上
CL(TransitionFadeBL),// 作用:创建一个部落格过渡动画, 从右上到左下
CL(TransitionFadeUp),// 作用:创建一个从下到上,条形折叠的过渡动画
CL(TransitionFadeDown),// 作用:创建一个从上到下,条形折叠的过渡动画
CL(TransitionTurnOffTiles),// 作用:创建一个随机方格消失的过渡动画
CL(TransitionSplitRows),// 作用:创建一个分行划分切换的过渡动画
CL(TransitionSplitCols), // 作用:创建一个分列划分切换的过渡动画
CL(TransitionShrinkGrow),// 创建一个放缩交替的过渡动画
CL(TransitionRotoZoom),// 创建一个旋转放缩交替的过渡动画
CL(TransitionMoveInL),// 作用:创建一个从左边推入覆盖的过渡动画
CL(TransitionMoveInR),// 作用:创建一个从右边推入覆盖的过渡动画
CL(TransitionMoveInB),// 作用:创建一个从下边推入覆盖的过渡动画
CL(TransitionMoveInT),// 作用:创建一个从上边推入覆盖的过渡动画
CL(TransitionSlideInL),// 作用:创建一个从左侧推入并顶出旧场景的过渡动画
CL(TransitionSlideInR),// 作用:创建一个从右侧推入并顶出旧场景的过渡动画
CL(TransitionSlideInT), // 作用:创建一个从顶部推入并顶出旧场景的过渡动画
CL(TransitionSlideInB),// 作用:创建一个从下部推入并顶出旧场景的过渡动画
CLN(TransitionPageTurn),// 作用:创建一个翻页的过渡动画
CLS(TransitionFade),// 作用:创建一个逐渐过渡到目标颜色的切换动画
CLM(TransitionFlipX),// 作用:创建一个x轴反转的切换动画
CLM(TransitionFlipY),// 作用:创建一个Y轴反转的切换动画
CLM(TransitionFlipAngular),// 作用:创建一个带有反转角切换动画
CLM(TransitionZoomFlipX),// 作用:创建一个带有缩放的x轴反转切换的动画
CLM(TransitionZoomFlipY),// 作用:创建一个带有缩放的Y轴反转切换的动画
CLM(TransitionZoomFlipAngular)// 作用:创建一个带有缩放 ,反转角切换的动画
}; Scene* SceneTest::createScene()
{
auto scene = Scene::create();
auto layer = SceneTest::create();
scene->addChild(layer);
return scene;
} bool SceneTest::init()
{
auto sprite = Sprite::create(SceneConfig::getInstance()->getBg());
Size visibleSize = Director::getInstance()->getVisibleSize();
Vec2 origin = Director::getInstance()->getVisibleOrigin();
sprite->setPosition(Vec2(visibleSize.width/ + origin.x, visibleSize.height/ + origin.y));
this->addChild(sprite, );
auto eventListener = EventListenerTouchOneByOne::create();
eventListener->onTouchBegan = CC_CALLBACK_2(SceneTest::onToucheBegans,this);
this->_eventDispatcher->addEventListenerWithSceneGraphPriority(eventListener,this);
return true;
}
#define MAX_LAYER (sizeof(createFunctions) / sizeof(createFunctions[0]))
bool SceneTest::onToucheBegans(Touch* touch,Event* ev)
{
auto idx = SceneConfig::getInstance()->getIndex();
idx++;
idx = idx%MAX_LAYER;
SceneConfig::getInstance()->setIndex(idx);
auto reScene = createFunctions[idx]();
Director::getInstance()->setDepthTest(false);
Director::getInstance()->replaceScene(reScene);
return true;
} static SceneConfig* config;
static int _index;
SceneConfig* SceneConfig::getInstance()
{
if( !config )
{
config = new SceneConfig();
_index = ;
}
return config;
} int SceneConfig::getIndex()
{
return _index;
} void SceneConfig::setIndex(int index)
{
_index = index;
}
std::string SceneConfig::getBg()
{
auto index = _index;
if( index% > )
{
return s_bg1;
}
else
{
return s_bg2;
}
}

SceneTest.cpp

点击屏幕看看效果吧。

  CL(TransitionJumpZoom),//作用: 创建一个跳动的过渡动画
CL(TransitionProgressRadialCCW), // 作用: 创建一个扇形条形式的过渡动画, 逆时针方向
CL(TransitionProgressRadialCW),// 作用: 创建一个扇形条形式的过渡动画, 顺时针方向
CL(TransitionProgressHorizontal),// 作用: 创建一个水平条形式的过渡动画
CL(TransitionProgressVertical),// 作用: 创建一个垂直条形式的过渡动画
CL(TransitionProgressInOut),// 作用: 创建一个由里向外扩展的过渡动画
CL(TransitionProgressOutIn),// 作用: 创建一个由外向里扩展的过渡动画
CL(TransitionCrossFade),// 作用:创建一个逐渐透明的过渡动画
CL(TransitionFadeTR),// 作用:创建一个部落格过渡动画, 从左下到右上
CL(TransitionFadeBL),// 作用:创建一个部落格过渡动画, 从右上到左下
CL(TransitionFadeUp),// 作用:创建一个从下到上,条形折叠的过渡动画
CL(TransitionFadeDown),// 作用:创建一个从上到下,条形折叠的过渡动画
CL(TransitionTurnOffTiles),// 作用:创建一个随机方格消失的过渡动画
CL(TransitionSplitRows),// 作用:创建一个分行划分切换的过渡动画
CL(TransitionSplitCols), // 作用:创建一个分列划分切换的过渡动画
CL(TransitionShrinkGrow),// 创建一个放缩交替的过渡动画
CL(TransitionRotoZoom),// 创建一个旋转放缩交替的过渡动画
CL(TransitionMoveInL),// 作用:创建一个从左边推入覆盖的过渡动画
CL(TransitionMoveInR),// 作用:创建一个从右边推入覆盖的过渡动画
CL(TransitionMoveInB),// 作用:创建一个从下边推入覆盖的过渡动画
CL(TransitionMoveInT),// 作用:创建一个从上边推入覆盖的过渡动画
CL(TransitionSlideInL),// 作用:创建一个从左侧推入并顶出旧场景的过渡动画
CL(TransitionSlideInR),// 作用:创建一个从右侧推入并顶出旧场景的过渡动画
CL(TransitionSlideInT), // 作用:创建一个从顶部推入并顶出旧场景的过渡动画
CL(TransitionSlideInB),// 作用:创建一个从下部推入并顶出旧场景的过渡动画
CLN(TransitionPageTurn),// 作用:创建一个翻页的过渡动画
CLS(TransitionFade),// 作用:创建一个逐渐过渡到目标颜色的切换动画
CLM(TransitionFlipX),// 作用:创建一个x轴反转的切换动画
CLM(TransitionFlipY),// 作用:创建一个Y轴反转的切换动画
CLM(TransitionFlipAngular),// 作用:创建一个带有反转角切换动画
CLM(TransitionZoomFlipX),// 作用:创建一个带有缩放的x轴反转切换的动画
CLM(TransitionZoomFlipY),// 作用:创建一个带有缩放的Y轴反转切换的动画
CLM(TransitionZoomFlipAngular)// 作用:创建一个带有缩放 ,反转角切换的动画

Cocos2d-x 3.2 学习笔记(七)Scene And Transition的更多相关文章

  1. (转)Qt Model/View 学习笔记 (七)——Delegate类

    Qt Model/View 学习笔记 (七) Delegate  类 概念 与MVC模式不同,model/view结构没有用于与用户交互的完全独立的组件.一般来讲, view负责把数据展示 给用户,也 ...

  2. Learning ROS for Robotics Programming Second Edition学习笔记(七) indigo PCL xtion pro live

    中文译著已经出版,详情请参考:http://blog.csdn.net/ZhangRelay/article/category/6506865 Learning ROS forRobotics Pro ...

  3. Typescript 学习笔记七:泛型

    中文网:https://www.tslang.cn/ 官网:http://www.typescriptlang.org/ 目录: Typescript 学习笔记一:介绍.安装.编译 Typescrip ...

  4. python3.4学习笔记(七) 学习网站博客推荐

    python3.4学习笔记(七) 学习网站博客推荐 深入 Python 3http://sebug.net/paper/books/dive-into-python3/<深入 Python 3& ...

  5. Go语言学习笔记七: 函数

    Go语言学习笔记七: 函数 Go语言有函数还有方法,神奇不.这有点像python了. 函数定义 func function_name( [parameter list] ) [return_types ...

  6. iOS 学习笔记七 【博爱手把手教你使用2016年gitHub Mac客户端】

    iOS 学习笔记七 [博爱手把手教你使用gitHub客户端] 第一步:首先下载git客户端 链接:https://desktop.github.com 第二步:fork 大神的代码[这里以我的代码为例 ...

  7. 【opencv学习笔记七】访问图像中的像素与图像亮度对比度调整

    今天我们来看一下如何访问图像的像素,以及如何改变图像的亮度与对比度. 在之前我们先来看一下图像矩阵数据的排列方式.我们以一个简单的矩阵来说明: 对单通道图像排列如下: 对于双通道图像排列如下: 那么对 ...

  8. Linux学习笔记(七) 查询系统

    1.查看命令 (1)man 可以使用 man 命令名称 命令查看某个命令的详细用法,其显示的内容如下: NAME:命令名称 SYNOPSIS:语法 DESCRIPTION:说明 OPTIONS:选项 ...

  9. go微服务框架kratos学习笔记七(kratos warden 负载均衡 balancer)

    目录 go微服务框架kratos学习笔记七(kratos warden 负载均衡 balancer) demo demo server demo client 池 dao service p2c ro ...

  10. Java IO学习笔记七:多路复用从单线程到多线程

    作者:Grey 原文地址:Java IO学习笔记七:多路复用从单线程到多线程 在前面提到的多路复用的服务端代码中, 我们在处理读数据的同时,也处理了写事件: public void readHandl ...

随机推荐

  1. vc6编译apache遇到的问题

    在apache的官网上下载了httpd-2.0.65-win32-src,打算了解一下其中的细节,以给目前做的一个项目提供抄袭性的参考.那是一个vc6的工程.用vc6一编译,apr那个工程报错,说什么 ...

  2. [Java基础]java中this和super

    一.this关键字 1.this概念 (参考:http://www.cnblogs.com/xdp-gacl/p/3636071.html)   this是一个引用,它指向自身的这个对象,它的内存分析 ...

  3. 自学日记--JavaScript 001

    1.1输出内容: document.write(); 1.2警告语句: alert(); 1.3确认语句: comfirm(str); 返回值:boolean  确认返回true  取消返回false ...

  4. windows phone 8.1教务在线客户端(后续)

    经过了一番折腾,这个wp教务在线算是告一段落了,其实原理很简单,就是post方式访问登陆页面返回cookie,然后带着这个cookie用get方式继续访问你想要访问并取回内容的页面,而且httpcli ...

  5. postfix启动失败

      [root@localhost pid]# /usr/sbin/postfix start postfix/postfix-script: warning: not owned by postfi ...

  6. RHEL5.8配置NFS服务

    机器配置:4C+16GB 操作系统:RedHat Enterprise Linux 5.8 NFS基础 NFS(Network File System)是Linux系统之间使用最为广泛的文件共享协议, ...

  7. python中re.findall()找到的结果替换

    正则表达式re模块中用findall查找到的是ascii码,所以当比对替换时也需要对应的ascii码才能匹配成功.以下程序是查找文件夹下文件名中含有男.女的文件,并将男替换成1,将女替换成2的程序 # ...

  8. linux OS install oracle database

    #!/bin/bash#Purpose:Create and config oracle install.#Usage:Log on as the superuser('root') #1.creat ...

  9. Windows Server 2008 系统设置集合

    1.禁用IPV6 netsh interface teredo set state disabled netsh interface 6to4 set state disabled netsh int ...

  10. 关于 REST

    REST(Representational State Transfer)是一种轻量级的 Web Service 架构风格,可以翻译成“表述性状态转移”,实现和操作明显比 SOAP 和 XML-RPC ...