zoukankan      html  css  js  c++  java
  • 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 _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 ");

    }

     

    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 ");

    }

     

    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()截图例如以下:


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

  • 相关阅读:
    遭遇:“传入的表格格式数据流(TDS)远程过程调用(RPC)协议流不正确” 错误
    JS控制form表单action去向
    easyui form 提交问题,纠结了很久,有点诡异
    easyui的tab加载页面中的form重复提交
    AJAX POST请求中参数以form data和request payload形式在servlet中的获取方式
    $.AJAX参数提交及后台获取方式
    多条件判断语句case
    条件判断语句if
    条件测试和捕获信号
    向脚本传递参数
  • 原文地址:https://www.cnblogs.com/bhlsheji/p/4747828.html
Copyright © 2011-2022 走看看