码迷,mamicode.com
首页 > 其他好文 > 详细

【cocos2dx 小技巧】半透明屏蔽罩和弹出框的实现

时间:2014-12-18 09:14:41      阅读:198      评论:0      收藏:0      [点我收藏+]

标签:cocos2dx   遮蔽罩   弹出框   lambda   easebackout   

今天介绍一下,弹出框的和屏蔽罩的小实现~
弹出框主要用到了cocos2dx生命周期里面的OnEnter()函数,就是当Layer被addChild的时候会调用的函数(所以如果把OnEnter的代码加到init里面效果应该也是一样的~)
屏蔽罩的实现是用了MenuItemImage和LayerColor,前者可以设置区域大小并获取点击,后者则可以设置Color4B。 效果图如下:
bubuko.com,布布扣

主要代码:

//ShaderLayer.h
void setClickBgBlock(std::function<void()> block);
std::function<void()> clickBGBlock;     
//ShaderLayer.cpp
auto item = MenuItemImage::create();
item -> setContentSize(visibleSize);
item -> setCallback([&](Ref *pSender){
    //背景图点击时候执行
    if (clickBGBlock != NULL) {
        this -> clickBGBlock();
    }
});

如果对ios中的block不熟悉的话,就搜一下lambda 吧(我觉得就是个匿名函数指针)。然后当MenuItemImage被点击时,就调用clickBGBlock()函数;

//HelloWorldScene.cpp
//屏蔽在popUp上的触摸
auto listener = EventListenerTouchOneByOne::create();
listener -> setSwallowTouches(true);
listener -> onTouchBegan = [](Touch *touch, Event *event){
    auto target = static_cast<Sprite *>(event -> getCurrentTarget());
    Vec2 locationInNode = target->convertToNodeSpace(touch->getLocation());
    Size s = target->getContentSize();
    Rect rect = Rect(0, 0, s.width, s.height);
    if(rect.containsPoint(locationInNode)){
        //这里return true swallowTouches才有效
        return true;
    }
    return false;
};

这一段代码,是通用的,只要在最后面再加一句addEventListenerWithSceneGraphPriority就可以监听触摸控制,(你监听的target的ContentSize内)。

(我总觉得应该还有更简单的方法可以实现这样的功能,如果你知道,请第一时间告知我一声~)
附上代码+图片:http://7sblre.com1.z0.glb.clouddn.com/PopUpAndShaderLayer.zip

欢迎访问我的博客:helkyle.tk

【cocos2dx 小技巧】半透明屏蔽罩和弹出框的实现

标签:cocos2dx   遮蔽罩   弹出框   lambda   easebackout   

原文地址:http://blog.csdn.net/joueu/article/details/41996205

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!