1        打开 - 内置T32  Cocos2dx-3.2一个专案

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvdG90b3R1enVvcXVhbg==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">

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

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

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

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

4        项目文件夹结构例如以下:

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvdG90b3R1enVvcXVhbg==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">

编写公共的头文件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()截图例如以下:

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvdG90b3R1enVvcXVhbg==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">

版权声明:本文博客原创文章,博客,未经同意,不得转载。

2.cocos2dx 3.2在语法的差异,lambada使用表达式和function和bind使用功能的更多相关文章

  1. python2.+进化至python3.+ 语法变动差异(不定期更新)

    1.输出 python2.+ 输出: print "" python3.+ 输出: print ("") 2.打开文件 python2.+ 打开文件: file ...

  2. VB.NET与C# 语法show差异

    学习VB.NET后发现,VB.NET与C#的语法基本的不同在两个部分,这两部分搞通了,那就游刃有余,迎刃而解了. 现将其对照总结例如以下: 一.实体部分 (与VB相比.在C#和VB.NET中,实体的使 ...

  3. MySQL基本语法(一):和SQL Server语法的差异小归纳

    html { font-family: sans-serif } body { margin: 0 } article,aside,details,figcaption,figure,footer,h ...

  4. 2.cocos2dx 3.2中语法的不同之处,lambada表达式的使用和function和bind函数的使用

    1        打开建好的T32  Cocos2dx-3.2的一个项目 2        设置Cocos显示窗口的位置是在AppDelegate.cpp中: 3  设置自适应窗口大小的代码是在上面的 ...

  5. informix(南大通用)sql语法的差异

    1.create view  444(...)  as select ...from... 2.insert into select.......union  select     不支持 请分开写 ...

  6. NetworkComms V2版本与V3版本语法的差异

    NetworkComms网络通信框架序言 NetworkComms通信框架中V3版本是一次重要的升级,底层做了诸多改变,但语法上与V2版本相比,差不并不大. 监听端口: V3中 IPEndPoint ...

  7. Kotlin语法(函数和lambda表达式)

    三.函数和lambda表达式 1. 函数声明 fun double(x: Int): Int { } 函数参数是用 Pascal 符号定义的 name:type.参数之间用逗号隔开,每个参数必须指明类 ...

  8. Cocos2d-x v3.0 新的事件调度方法 lambda表达式的使用

    欢迎添� Cocos2d-x 交流群: 193411763 转载请注明原文出处:http://blog.csdn.net/u012945598/article/details/24603251 Coc ...

  9. Java 8新特性:新语法方法引用和Lambda表达式及全新的Stream API

    新语法 方法引用Method references Lambda语法 Lambda语法在AndroidStudio中报错 Stream API 我正参加2016CSDN博客之星的比赛 希望您能投下宝贵 ...

随机推荐

  1. JAVA学习课第二十八届(多线程(七))- 停止-threaded多-threaded面试题

    主密钥 /*  * wait 和 sleep 差别?  * 1.wait能够指定时间也能够不指定  * sleep必须指定时间  * 2.在同步中,对CPU的运行权和锁的处理不同  * wait释放运 ...

  2. 【转】QT样式表 (QStyleSheet)

    作者:刘旭晖 Raymond 转载请注明出处Email:colorant@163.comBLOG:http://blog.csdn.net/colorant/ 除了子类化Style类,使用QT样式表( ...

  3. 重新想象 Windows 8 Store Apps (31) - 加密解密: 哈希算法, 对称算法

    原文:重新想象 Windows 8 Store Apps (31) - 加密解密: 哈希算法, 对称算法 [源码下载] 重新想象 Windows 8 Store Apps (31) - 加密解密: 哈 ...

  4. 主机Window不能访问该虚拟机Linux Samba文件服务提供了一个文件夹

    我最近遇到一个问题.虚拟机Linux中间Samba服务常开.主办"\\192.168.229.200" (我的虚拟机Linux址)訪问不了Share文件夹(/var/test),并 ...

  5. 让c#的exe只要被修改就无法运行,支持混淆和数字证书

    原文:让c#的exe只要被修改就无法运行,支持混淆和数字证书 首先用sdk的sn工具或者makecert工具生成公钥和密钥,推荐makecert,做自己的证书,我做了一个受信任的根证书放在受信任的根证 ...

  6. HDU 4391 Paint The Wall 段树(水

    意甲冠军: 特定n多头排列.m操作 以下是各点的颜色 以下m一种操纵: 1 l r col 染色 2 l r col 问间隔col色点 == 通的操作+区间内最大最小颜色数的优化,感觉非常不科学... ...

  7. S2SH新手框架结构的准备工作只需要导入这些文件

    实习北京最近一直在某公司.时间很冲突,总想着有事找东西坐,思想,做事先成套我吧 一套完整的东西想好主题,术去实现了,在学校尽管说是学了J2EE,可是确实没学到东西,Struts2+Hibernate不 ...

  8. jQuery整理笔记9----函数形式发展

    在一些照片中使用演示样本.插入.样式文件下载:点我进入下载 过去在开发过程中关于table方面的jquery应用不过局限于使用jquery操作table添加一行.删除一列等等操作.今天整理的跟过去用的 ...

  9. Effective C++ -- 继承和面向对象设计

    32.确保你的public继承了模is-a关系 public继承意味着is-a关系(里氏替换原则),一切适用于基类也适用于派生类. 矩形继承正方形问题: 可实施与矩形的操作无法实施与正方形 在编程领域 ...

  10. 每天的学习经验:SharePoint 2013 定义自己添加的产品清单。Callout菜单项、文档关注、SharePoint服务机端对象模型查询

    前言: 前一段时间一直都比較忙.没有什么时间进行总结,刚好节前项目上线.同一时候趁着放假能够好好的对之前遇到的一些问题进行总结. 主要内容有使用SharePoint服务端对象模型进行查询.为Share ...