2.cocos2dx 3.2中语法的不同之处,lambada表达式的使用和function和bind函数的使用
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 #define #include USING_NS_CC; #define //因为3.2版本中输出日志不建议使用CCLog,而是使用log,为了还想 //使用原来风格的CCLog做如下定义 #define #endif |
|
编写:TBack.h |
|
#ifndef #define #include //注意这时候不是CCLayer了,而是Layer了 class { public: CREATE_FUNC(TBack); bool }; #endif |
|
编写TBack.cpp |
|
#include bool { Layer::init(); //设置zorder setLocalZOrder(100); Menu* MenuItemImage* [](Ref*){ Director::getInstance()->popScene(); }); menu->addChild(item); //注意,这里的没有回调函数了,而是用lambada表达是来替换掉了。 item->setPosition(winSize.width / 2 -item->getBoundingBox().size.width item->getBoundingBox().size.height / 2 -winSize.height addChild(menu); return } |
|
编写:TMenu.h |
|
#ifndef #define #include class { public: CREATE_FUNC(TMenu); bool bool }; #endif |
|
编写TMenu.cpp |
|
#include #include #include static constchar* "T01CPP11", }; bool { Layer::init(); Menu* addChild(menu); for (inti = 0; { MenuItemFont* MenuItem* int Layer* if (title[i] =="T01CPP11") { l = } if (l) { TBack*b = Scene*s = s->addChild(b); s->addChild(l); Director::getInstance()->pushScene(s); } }); menu->addChild(item); item->setTag(1000 +i); } menu->alignItemsVertically(); // 触摸 auto #if 0 ev->onTouchBegan = [](Touch*,Event*){ return }; #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, setPositionY(getPositionY() +touch->getDelta().y); }; _eventDispatcher->addEventListenerWithSceneGraphPriority(ev,this); return } bool { return } |
|
编写:T01CPP11.h |
|
#ifndef #define #include class { public: CREATE_FUNC(T01CPP11); bool void }; #endif |
|
编写:T01CPP11.cpp(主要介绍lambada表达式) |
|
#include void { CCLog("foo is called\n"); } void { CCLog("%d,%c,%f",n,c,f); } void { CCLog("mFoo is called"); } //关于lambda表达式 bool { Layer::init(); { auto int CCLog("i = %d",i); } //最简单的lambada表达式是只要一个中括号和一个大括号 //[]捕获列表 //{}函数体 //1.捕获列表,可以放变量名,这里可以用来传递函数体内定义的变量 { int auto int } //2.捕获列表,可以捕获多个变量 { int auto int } // 3.捕获列表,有引用和传值两种方式,传值不可以改变,引用可以改变,并且改变外部的变量值 { int auto int } //4.捕获列表,可以定义mutable类型的lambada,能改变传值的捕获参数, //但是不能改变外部的变量值 { int auto int CCLog("p = %d,q = %d,s = %d",p, } //5.捕获列表,可以用=或者&捕获所有变量,=指传值,&表示引用 { int //用&的时候,所有的都可以调用了,[&,p]:表示除了p不能被使用,其它的都可以被使用 auto return }; } //稍微复杂点的lambda表达式 { auto auto } //小括号中的是参数列表,参数列表和捕获列表区别在于,参数列表的参数由调用方决定, //捕获列表由定义方决定,所以更加灵活 //更加复杂的lambada表达是,有返回值,返回值一般都省略 { //->int表示返回值是int类型的 auto } //总结:auto func = [](){} { auto } return } |
|
// T01CPP11.cpp中使用使用function和bind函数的案例: |
|
#include void { CCLog("foo is called\n"); } void { CCLog("%d,%c,%f",n,c,f); } void { CCLog("mFoo is called"); } //关于lambda表达式 bool { Layer::init(); //std::function; //std::bind //函数指针类型 std::function<void()>func = func(); //成员函数指针的赋值和调用 { //注意在::域作用符后面加上* void(T01CPP11::*FuncPtr)() = &T01CPP11::mFoo; //调用成员函数的时候加上this (this->*FuncPtr)(); } //bind的功能,就是把一个具体函数,编程std::function对象 //bind可以把具体函数和std::function形式完全改变,比如参数数量的改变 { std::function<void()>func = 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, std::placeholders::_3,std::placeholders::_2,std::placeholders::_1); func(1.0f, } // 也可以同时改变参数个数和顺序 { std::function<void(float,char)> 100, std::placeholders::_2,std::placeholders::_1); func(4.0f, } //也可以绑定成员函数 { std::function<void()>func = func(); } //下面的运行结果是:lambada is called { std::function<void()> std::function<void(int)> CCLog("lambada iscalled"); },10,std::placeholders::_1); func1(100); } return } |
|
修改AppDelegate.cpp |
|
A添加头文件: #include #include B:修改:applicationDidFinishLaunching()截图如下: |
2.cocos2dx 3.2中语法的不同之处,lambada表达式的使用和function和bind函数的使用的更多相关文章
- 2.cocos2dx 3.2在语法的差异,lambada使用表达式和function和bind使用功能
1 打开 - 内置T32 Cocos2dx-3.2一个专案 watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvdG90b3R1enVvcXVhb ...
- 网络通讯中 bind函数的作用
面向连接的网络应用程序分为客户端和服务器端.服务器端的执行流程一般为4步,客户端程序相对简单,一般需要两个步骤. 服务器端执行流程4步如下: (1)调用socket函数,建立一个套接字,该套接字用于接 ...
- cocos2dx 3.7中 AppDelegate.h的class TestController;这种写法的具体意思不太明白,只能猜是类似于外部定义的东西。
cocos2dx 3.7中 AppDelegate.h的class TestController;这种写法的具体意思不太明白,只能猜是类似于外部定义的东西.
- 解决cocos2dx在Xcode中运行时报:convert: iCCP: known incorrect sRGB profile 的问题
解决cocos2dx在Xcode中运行时报:convert: iCCP: known incorrect sRGB profile 的问题 本文的实践来源是参照了两个帖子完成的: http://dis ...
- cocos2d-x 3.0rc2中读取sqlite文件
cocos2d-x 3.0rc2中读取sqlite文件的方式,在Android中直接读取软件内的会失败.须要复制到可写的路径下 sqlite3* dbFile = NULL; std::string ...
- ios怎样实现快速将显卡中数据读出压缩成视频在cocos2dx扩展开发中
如果解决ios怎样实现快速将显卡中数据读出压缩成视频在cocos2dx扩展开发中 手机平台性能是个关键问题. 压缩视频分成3个步骤: 读取显卡数据, 使用编码器压缩,保存文件. 使用libav 压缩的 ...
- Cocos2d-x游戏开发中的消息机制:CCNotificationCenter的使用
在HTML5游戏开发中,js可以使用Event对象的addEventListener(添加事件监听).dispatchEvent(触发事件)实现监听机制,如果在coocos2d-x中,去实现这种机制该 ...
- JavaScript 中语法规范及调试
JavaScript 中语法规范及调试 版权声明:未经博主授权,内容严禁分享转载 JavaScript 开发环境 JavaScript 脚本可以使用任意一款纯文本编辑器进行编程开发. 常见的前端开发编 ...
- 深入分析Cocos2d-x 2.0中的“纹理”
对CCImage的绘制是通过CCTexture2D来实现的(OPENGL es)通过纹理绘制到某个面. (本文中所提到的方法在cocos2d2.0中部分有调整,请应用时候具体察看源码)1. 首先来了解 ...
随机推荐
- 深入java多线程一
涉及到 1.线程的启动(start) 2.线程的暂停(suspend()和resume()) 3.线程的停止(interrupt与异常停止,interrupt与睡眠中停止,stop(),return) ...
- “百度杯”CTF比赛 九月场_再见CMS(齐博cms)
题目在i春秋ctf大本营 又是一道cms的题,打开御剑一通乱扫,发现后台登录地址,访问一看妥妥的齐博cms 记得以前很久以前利用一个注入通用漏洞,这里我贴上链接,里面有原理与利用方法详细说明: 齐博c ...
- [ZJOI 2008]泡泡堂BNB
Description 题库链接 双方 \(n\) 人,给出每人的战斗力,赢一场加 \(2\) 分,平局 \(1\) 分,失败不得分.求最大和最小的得分. \(1\leq n\leq 100000\) ...
- hihocoder 1419 重复旋律4
描述 小Hi平时的一大兴趣爱好就是演奏钢琴.我们知道一个音乐旋律被表示为长度为 N 的数构成的数列.小Hi在练习过很多曲子以后发现很多作品中的旋律有重复的部分. 我们把一段旋律称为(k,l)-重复的, ...
- [HAOI2007]上升序列
Description 对于一个给定的S={a1,a2,a3,…,an},若有P={ax1,ax2,ax3,…,axm},满足(x1 < x2 < … < xm)且( ax1 < ...
- bzoj1293[SCOI2009]生日礼物 尺取法
1293: [SCOI2009]生日礼物 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 2838 Solved: 1547[Submit][Stat ...
- VLAN的划分
VLAN划分是指逻辑上把网络资源和网络用户按照一定的原则进行划分,把一个物理上实际的网络划分成多个小的逻辑网络.设计VLAN的最初目的是隔离局域网的广播,不让它去影响网络带宽.VLAN与传统的LAN相 ...
- Union和Union All 的区别
Union和Union All 的区别: Union 是对结果集进行并集操作,不包括重复行,同时进行默认规则的排序: Union All,对两个结果集进行并集操作,包括重复行,不进行排序: Inter ...
- Cisco动态路由配置
前言: 学完静态路由配置,该学动态路由.所以 学习完后来做终结. 准备: PC:192.168.1.10 R1:fa0/0 192.168.1.1 fa0/1 1.1.12.1 R2: fa0/0 1 ...
- sqlserver 查询 inner join 同一表2次 只出一条查询结果
inner join T_MTN_MobileNumber k on 1=1 and k.hddm='01' inner join (select a.hdxx+','+b.hdxx as hdxx ...