1        打开建好的T32  Cocos2dx-3.2的一个项目

2        设置Cocos显示窗口的位置是在AppDelegate.cpp中:

3  设置自适应窗口大小的代码是在上面的代码后面紧接着就添加:

glview->setDesignResolutionSize(480,320, ResolutionPolicy::EXACT_FIT);

3        cocos2d-x-3.2项目案例(3.2版本之后都去掉了CC前缀)

4        项目目录结构如下:

编写公共的头文件T32.h

#ifndef
_T32_H__

#define
_T32_H__

#include
"cocos2d.h"

USING_NS_CC;

#define
winSize Director::getInstance()->getWinSize()

//因为3.2版本中输出日志不建议使用CCLog,而是使用log,为了还想

//使用原来风格的CCLog做如下定义

#define
CCLog cocos2d::log

#endif
// !_T32_H__

编写:TBack.h

#ifndef
__TBack_H__

#define
__TBack_H__

#include
"T32.h"

//注意这时候不是CCLayer了,而是Layer了

class
TBack :public
Layer

{

public:

CREATE_FUNC(TBack);

bool
init();

};

#endif

编写TBack.cpp

#include
"TBack.h"

bool
TBack::init()

{

Layer::init();

//设置zorder

setLocalZOrder(100);

Menu*
menu = Menu::create();

MenuItemImage*
item = MenuItemImage::create("CloseNormal.png","CloseSelected.png",

[](Ref*){

Director::getInstance()->popScene();

});

menu->addChild(item);

//注意,这里的没有回调函数了,而是用lambada表达是来替换掉了。

item->setPosition(winSize.width / 2 -item->getBoundingBox().size.width
/ 2,

item->getBoundingBox().size.height / 2 -winSize.height
/ 2);

addChild(menu);

return
true;

}

编写:TMenu.h

#ifndef
__TMenu_H__

#define
__TMenu_H__

#include
"T32.h"

class
TMenu : public
Layer

{

public:

CREATE_FUNC(TMenu);

bool
init();

bool
TouchBegan(Touch*,
Event*);

};

#endif

编写TMenu.cpp

#include
"TMenu.h"

#include
"TBack.h"

#include
"T01CPP11.h"

static constchar*
title[] = {

"T01CPP11",

};

bool
TMenu::init()

{

Layer::init();

Menu*
menu = Menu::create();

addChild(menu);

for (inti = 0;
i < sizeof(title) /
sizeof(*title); ++i)

{

MenuItemFont*
item = MenuItemFont::create(title[i], [](Ref*sender){

MenuItem*
item = (MenuItem*)sender;

int
i = item->getTag() - 1000;

Layer*
l = NULL;

if (title[i] =="T01CPP11")

{

l =
T01CPP11::create();

}

if (l)

{

TBack*b =
TBack::create();

Scene*s =
Scene::create();

s->addChild(b);

s->addChild(l);

Director::getInstance()->pushScene(s);

}

});

menu->addChild(item);

item->setTag(1000 +i);

}

menu->alignItemsVertically();

// 触摸

auto
ev = EventListenerTouchOneByOne::create();

#if 0

ev->onTouchBegan = [](Touch*,Event*){

return
true;

};

#endif

//下面两行代码是相同的

//ev->onTouchBegan = std::bind(&TMenu::TouchBegan, this, std::placeholders::_1, std::placeholders::_2);

ev->onTouchBegan =CC_CALLBACK_2(TMenu::TouchBegan,this);

ev->onTouchMoved = [&](Touch*touch,
Event*){

setPositionY(getPositionY() +touch->getDelta().y);

};

_eventDispatcher->addEventListenerWithSceneGraphPriority(ev,this);

return
true;

}

bool
TMenu::TouchBegan(/*TMEnu* this, */Touch*,Event*)

{

return
true;

}

编写:T01CPP11.h

#ifndef
__T01CPP11_H__

#define
__T01CPP11_H__

#include
"T32.h"

class
T01CPP11:public
Layer

{

public:

CREATE_FUNC(T01CPP11);

bool
init();

void
mFoo();

};

#endif

编写:T01CPP11.cpp(主要介绍lambada表达式)

#include
"T01CPP11.h"

void
foo()

{

CCLog("foo is called\n");

}

void
funArg3(int n,charc,float
f)

{

CCLog("%d,%c,%f",n,c,f);

}

void
T01CPP11::mFoo()

{

CCLog("mFoo is called");

}

//关于lambda表达式

bool
T01CPP11::init()

{

Layer::init();

{

auto
func = []{return 1; };

int
i = func();

CCLog("i = %d",i);

}

//最简单的lambada表达式是只要一个中括号和一个大括号

//[]捕获列表

//{}函数体

//1.捕获列表,可以放变量名,这里可以用来传递函数体内定义的变量

{

int
v = 100;

auto
func = [v]{returnv; };

int
x = func();

}

//2.捕获列表,可以捕获多个变量

{

int
p = 100, q = 200;

auto
func = [p, q]{returnp +
q; };

int
s = func();

}

// 3.捕获列表,有引用和传值两种方式,传值不可以改变,引用可以改变,并且改变外部的变量值

{

int
p = 100, q = 200;

auto
func = [p, &q]{q++; return
p + q; };

int
s = func();

}

//4.捕获列表,可以定义mutable类型的lambada,能改变传值的捕获参数,

//但是不能改变外部的变量值

{

int
p = 100, q = 200;

auto
func = [p, q]()mutable{p++;q++;
return p +
q; };

int
s = func();

CCLog("p = %d,q = %d,s = %d",p,
q, s);

}

//5.捕获列表,可以用=或者&捕获所有变量,=指传值,&表示引用

{

int
p = 100, q = 200;

//用&的时候,所有的都可以调用了,[&,p]:表示除了p不能被使用,其它的都可以被使用

auto
func = [&]{

return
p + q;

};

}

//稍微复杂点的lambda表达式

{

auto
add = [](int v1,int
v2){returnv1 +
v2; };

auto
a = add(1 , 2);

}

//小括号中的是参数列表,参数列表和捕获列表区别在于,参数列表的参数由调用方决定,

//捕获列表由定义方决定,所以更加灵活

//更加复杂的lambada表达是,有返回值,返回值一般都省略

{

//->int表示返回值是int类型的

auto
add = [](int v1,int
v2)->int{returnv1 +
v2; };

}

//总结:auto func = [](){}

{

auto
func = [](){};

}

return
true;

}

// T01CPP11.cpp中使用使用function和bind函数的案例:

#include
"T01CPP11.h"

void
foo()

{

CCLog("foo is called\n");

}

void
funArg3(int n,charc,float
f)

{

CCLog("%d,%c,%f",n,c,f);

}

void
T01CPP11::mFoo()

{

CCLog("mFoo is called");

}

//关于lambda表达式

bool
T01CPP11::init()

{

Layer::init();

//std::function;

//std::bind

//函数指针类型

std::function<void()>func =
foo;

func();

//成员函数指针的赋值和调用

{

//注意在::域作用符后面加上*

void(T01CPP11::*FuncPtr)() = &T01CPP11::mFoo;

//调用成员函数的时候加上this

(this->*FuncPtr)();

}

//bind的功能,就是把一个具体函数,编程std::function对象

//bind可以把具体函数和std::function形式完全改变,比如参数数量的改变

{

std::function<void()>func =
std::bind(funArg3, 100,'c', 0.1f);

func();

}

//也可以改变参数顺序

{

//其中

//_1:表示function<void(float, char, int)>括号中的第一个参数

//_2:表示function<void(float, char, int)>括号中的第二个参数

//_3:表示function<void(float, char, int)>括号中的第三个参数

//后面3个占位符分别在funArg3中的顺序,而又用标记来代表上面括号中参数的的位置

std::function<void(float,char,
int)> func =
std::bind(funArg3,

std::placeholders::_3,std::placeholders::_2,std::placeholders::_1);

func(1.0f,
'd', 2000);

}

// 也可以同时改变参数个数和顺序

{

std::function<void(float,char)>
func = std::bind(funArg3,

100, std::placeholders::_2,std::placeholders::_1);

func(4.0f,
'x');

}

//也可以绑定成员函数

{

std::function<void()>func =
std::bind(&T01CPP11::mFoo,this);

func();

}

//下面的运行结果是:lambada is called

{

std::function<void()>
func = [](){};

std::function<void(int)>
func1 = std::bind([](int,
int){

CCLog("lambada iscalled");

},10,std::placeholders::_1);

func1(100);

}

return
true;

}

修改AppDelegate.cpp

A添加头文件:

#include
"TMenu.h"

#include
"TBack.h"

B:修改:applicationDidFinishLaunching()截图如下:

2.cocos2dx 3.2中语法的不同之处,lambada表达式的使用和function和bind函数的使用的更多相关文章

  1. 2.cocos2dx 3.2在语法的差异,lambada使用表达式和function和bind使用功能

    1        打开 - 内置T32  Cocos2dx-3.2一个专案 watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvdG90b3R1enVvcXVhb ...

  2. 网络通讯中 bind函数的作用

    面向连接的网络应用程序分为客户端和服务器端.服务器端的执行流程一般为4步,客户端程序相对简单,一般需要两个步骤. 服务器端执行流程4步如下: (1)调用socket函数,建立一个套接字,该套接字用于接 ...

  3. cocos2dx 3.7中 AppDelegate.h的class TestController;这种写法的具体意思不太明白,只能猜是类似于外部定义的东西。

    cocos2dx 3.7中 AppDelegate.h的class TestController;这种写法的具体意思不太明白,只能猜是类似于外部定义的东西.

  4. 解决cocos2dx在Xcode中运行时报:convert: iCCP: known incorrect sRGB profile 的问题

    解决cocos2dx在Xcode中运行时报:convert: iCCP: known incorrect sRGB profile 的问题 本文的实践来源是参照了两个帖子完成的: http://dis ...

  5. cocos2d-x 3.0rc2中读取sqlite文件

    cocos2d-x 3.0rc2中读取sqlite文件的方式,在Android中直接读取软件内的会失败.须要复制到可写的路径下 sqlite3* dbFile = NULL; std::string ...

  6. ios怎样实现快速将显卡中数据读出压缩成视频在cocos2dx扩展开发中

    如果解决ios怎样实现快速将显卡中数据读出压缩成视频在cocos2dx扩展开发中 手机平台性能是个关键问题. 压缩视频分成3个步骤: 读取显卡数据, 使用编码器压缩,保存文件. 使用libav 压缩的 ...

  7. Cocos2d-x游戏开发中的消息机制:CCNotificationCenter的使用

    在HTML5游戏开发中,js可以使用Event对象的addEventListener(添加事件监听).dispatchEvent(触发事件)实现监听机制,如果在coocos2d-x中,去实现这种机制该 ...

  8. JavaScript 中语法规范及调试

    JavaScript 中语法规范及调试 版权声明:未经博主授权,内容严禁分享转载 JavaScript 开发环境 JavaScript 脚本可以使用任意一款纯文本编辑器进行编程开发. 常见的前端开发编 ...

  9. 深入分析Cocos2d-x 2.0中的“纹理”

    对CCImage的绘制是通过CCTexture2D来实现的(OPENGL es)通过纹理绘制到某个面. (本文中所提到的方法在cocos2d2.0中部分有调整,请应用时候具体察看源码)1. 首先来了解 ...

随机推荐

  1. bzoj4896 补退选

    Description X是T大的一名老师,每年他都要教授许多学生基础的C++知识.在T大,每个学生在每学期的开学前都需要选课,每 次选课一共分为三个阶段:预选,正选,补退选:其中"补退选& ...

  2. [SHOI2017]相逢是问候

    Description 信息将你我连结.B君希望以维护一个长度为n的数组,这个数组的下标为从1到n的正整数.一共有m个操作,可以 分为两种:0 l r表示将第l个到第r个数(al,al+1,...,a ...

  3. [AHOI2009]中国象棋

    题目描述 这次小可可想解决的难题和中国象棋有关,在一个N行M列的棋盘上,让你放若干个炮(可以是0个),使得没有一个炮可以攻击到另一个炮,请问有多少种放置方法.大家肯定很清楚,在中国象棋中炮的行走方式是 ...

  4. bzoj 1076: [SCOI2008]奖励关

    Description 你正在玩你最喜欢的电子游戏,并且刚刚进入一个奖励关.在这个奖励关里,系统将依次随机抛出k次宝物,每次你都可以选择吃或者不吃(必须在抛出下一个宝物之前做出选择,且现在决定不吃的宝 ...

  5. 【BZOJ4034】【HAOI2015】树上操作

    题目请自行查阅传送门. 典型的树剖题,线段树维护操作,记一下子树在线段树内范围即可. 时间复杂度:\( O(m \log^{2} n) \) #include <stdio.h> #def ...

  6. [BZOJ]1031 字符加密Cipher(JSOI2007)

    持续划水中…… 感觉BZOJ上AC人数多的基本都是一些模板题,也就是某些算法的裸题.这些题目mark一下到时候回来复习也是不错的选择. Description 喜欢钻研问题的JS同学,最近又迷上了对加 ...

  7. IBM-x3650做RAID5更换硬盘后rebuild步骤分享

    1.按Ctrl+H进入WebBIOS配置 2.点击start 3.点击Drives,对slot5进行配置 4.选择slot5,选择Properties,点击Go按钮 5.选择MakeUnconfGoo ...

  8. Linux学习之CentOS(十四)----磁盘管理之 硬连接与软件连接(转)

    前言 在 Linux 底下的连结档有两种,一种是类似 Windows 的快捷方式功能的文件,可以让你快速的链接到目标文件(或目录),这种是软链接: 另一种则是透过文件系统的 inode 连结来产生新档 ...

  9. 离线合成联想到的--canvas合成水印

    前段时间做了功能模块:用户设置自定义勋章: 实现方式:前端把用户设置的昵称传到后台,后台根据不同用户等级,使用离线合成技术合成不同的勋章返回到前端: 方案算是实现了,但是有点坑就是,后台的离线合成没有 ...

  10. 《剑指offer》全部题目-含Java实现

    1.二维数组中的查找 在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数. publi ...