转自:http://www.2cto.com/kf/201207/144656.html

  蒙板,局部高亮可点的用处大多是在新手引导的时候,引导玩家一步一步的走游戏的操作流程。

  之前写了一个cocos2d-iphone的版本,因为设置成圆角的,比较美观,如果不用圆角,可以直接把Sprite改成layercolor,这个版本的缺点是每步都需要美术出一个资源(如果每步的点击区域大小不一样的话),现在这个版本是直接设置大小即可。

  这个版本的设计思路是,用layercolor,先把高亮的区域设置好了,然后在layercolor的四个角加上一个小圆角的sprite,这样就不用每步都需要美术出资源了。可以随意的设置高亮区域的大小。本来想直接不用sprite,直接找个方法设置layercolor的圆角的,没找到合适的方法,如果大家有比较合适的更简便的方法,欢迎拍砖。

  原理是:渲染的时候,使用异步混合渲染。ccBlendFunc

  不多说,直接上代码

  为了获取点击事件,所以继承了 CCTargetedTouchDelegate,把touch的权限设置为最高。

//.h
#ifndef Good_PlayGuide_h
#define Good_PlayGuide_h #include "cocos2d.h" using namespace cocos2d; class PlayerGuide:public CCSprite , public CCTargetedTouchDelegate
{
public:
PlayerGuide();
virtual ~PlayerGuide(); virtual bool init();
virtual void onEnter();
virtual void onExit(); virtual bool ccTouchBegan(CCTouch *touch, CCEvent *event);
virtual void ccTouchMoved(CCTouch *touch, CCEvent *event);
virtual void ccTouchEnded(CCTouch *touch, CCEvent *event); void onSetSpriteAndPosition(float width,float height,CCPoint point);
CCLayerColor *m_layer; // color layer
float m_layerWidth; //layer width
float m_layerHeight; // layer height
CCRenderTexture *m_pTarget; // render texture
};
#endif

// cpp
#include <iostream>
#include "PlayerGuide.h" PlayerGuide::PlayerGuide()
{
m_layerWidth = 0.0f;
m_layerHeight = 0.0f;
} PlayerGuide::~PlayerGuide()
{ } bool PlayerGuide::init()
{
if (!CCSprite::init()) {
return false;
} return true;
} void PlayerGuide::onEnter()
{
//since v2.0
// CCDirector::sharedDirector()->getTouchDispatcher()->addTargetedDelegate(this, -201, true);
//当进入这个对象时,设置touch事件的响应权限,menu的响应级别是-128,我们要获取比这个要高的权限,(设置的数值越低,权限越高)
CCTouchDispatcher::sharedDispatcher()->addTargetedDelegate(this, -, true);
CCSprite::onEnter();
} void PlayerGuide::onExit()
{
//since v2.0
   // CCDirector::sharedDirector()->getTouchDispatcher()->removeDelegate(this);
   //退出时,把touch响应的事件 移除
CCTouchDispatcher::sharedDispatcher()->removeDelegate(this);
CCSprite::onExit();
}
#pragma mark --------------------------setSpriteAndPosition---------------------------- /*******************************************************************************
*@param width 设置高亮区域的宽度,height 高亮区域的高度,point 设置layer的position
*
*
*******************************************************************************/ void PlayerGuide::onSetSpriteAndPosition(float width,float height, CCPoint point)
{
if (width != && height != ) {
m_layerWidth = width;
m_layerHeight = height;
m_layer = CCLayerColor::layerWithColorWidthHeight(ccc4(0x00, 0x00, 0x00, 0xff), width, height);
m_layer->retain();
ccBlendFunc ccb = {GL_ZERO,GL_ONE_MINUS_SRC_ALPHA}; m_layer->setBlendFunc(ccb);
m_layer->setPosition(point); CCSprite *topright = CCSprite::spriteWithFile("yourfile");//自己设置圆角的小图,如果不需要圆角,可以直接把sprite去掉
topright->getTexture()->setAliasTexParameters();
ccBlendFunc cbf = {GL_ONE,GL_ONE_MINUS_DST_ALPHA};
topright->setBlendFunc(cbf);
topright->setPosition(ccp(m_layer->getContentSize().width - topright->getContentSize().width/,m_layer->getContentSize().height - topright->getContentSize().height/));
topright->setOpacity(*0.5);
m_layer->addChild(topright,); CCSprite *topleft = CCSprite::spriteWithFile(IMG_PATH(IMAGE_PLAYERGUIDE_ROUNDED));
topleft->getTexture()->setAliasTexParameters();
ccBlendFunc cbf1 = {GL_ONE,GL_ONE_MINUS_DST_ALPHA};
topleft->setBlendFunc(cbf1);
topleft->setPosition(ccp(topleft->getContentSize().width/,m_layer->getContentSize().height - topleft->getContentSize().height/));
topleft->setOpacity(*0.5);
topleft->setFlipX(true);
m_layer->addChild(topleft,); CCSprite *buttomleft = CCSprite::spriteWithFile(IMG_PATH(IMAGE_PLAYERGUIDE_ROUNDED));
buttomleft->getTexture()->setAliasTexParameters();
ccBlendFunc cbf2 = {GL_ONE,GL_ONE_MINUS_DST_ALPHA};
buttomleft->setBlendFunc(cbf2);
buttomleft->setPosition(ccp(buttomleft->getContentSize().width/,buttomleft->getContentSize().height/));
buttomleft->setOpacity(*0.5);
buttomleft->setFlipX(true);
buttomleft->setFlipY(true);
m_layer->addChild(buttomleft,); CCSprite *buttomright = CCSprite::spriteWithFile(IMG_PATH(IMAGE_PLAYERGUIDE_ROUNDED));
buttomright->getTexture()->setAliasTexParameters();
ccBlendFunc cbf3 = {GL_ONE,GL_ONE_MINUS_DST_ALPHA};
buttomright->setBlendFunc(cbf3);
buttomright->setPosition(ccp(m_layer->getContentSize().width - buttomleft->getContentSize().width/,buttomright->getContentSize().height/));
buttomright->setOpacity(*0.5);
buttomright->setFlipY(true);
m_layer->addChild(buttomright,);
} CCSize s = CCDirector::sharedDirector()->getWinSize(); m_pTarget = CCRenderTexture::renderTextureWithWidthAndHeight(s.width, s.height);
ccBlendFunc ccb1 = {GL_SRC_ALPHA,GL_ONE_MINUS_SRC_ALPHA};
m_pTarget->getSprite()->setBlendFunc(ccb1);
m_pTarget->clear(0.0f, 0.0f, 0.0f, 0.5f); m_pTarget->setPosition(ccp(s.width/,s.height/)); this->addChild(m_pTarget); m_pTarget->begin();
if (width != && height != ) {
m_layer->visit();
} m_pTarget->end();
} bool PlayerGuide::ccTouchBegan(cocos2d::CCTouch *touch, cocos2d::CCEvent *event)
{
CCPoint touchpoint = touch->locationInView(touch->view());
touchpoint = CCDirector::sharedDirector()->convertToGL(touchpoint); if (m_layerWidth != && m_layerHeight != ) {
//如果点击高亮区域,则响应下层的区域
CCRect rect = m_layer->boundingBox();
if (CCRect::CCRectContainsPoint(rect, touchpoint)) {
return false;
} return true;
} void PlayerGuide::ccTouchMoved(cocos2d::CCTouch *touch, cocos2d::CCEvent *event)
{ } void PlayerGuide::ccTouchEnded(cocos2d::CCTouch *touch, cocos2d::CCEvent *event)
{ }

cocos2d-x之蒙板,局部高亮可点,CCRenderTexture的更多相关文章

  1. PS日记二(调色:色阶,曲线,色相/饱和度,色彩平衡,蒙板)

    基础知识一:在PS操作中为什么要复制图层(ctrl+J)? 答:复制图层主要是为了 备份原图层,在副本中进行操作 如果说你副本弄坏了,还有原来的PS复制图层一方面是保全原图.二是因为图层是ps操作的基 ...

  2. WPF弹出带蒙板的消息框

    效果图 思路 拿到父级窗体的内容,放入一个容器里,再在容器里放入一个半透明层.将整个容器赋给父级窗体的内容. 关闭时反向操作. 代码 消息窗弹出时 /// <summary> /// 弹出 ...

  3. SVG 2D入门9 - 蒙板

    SVG支持的蒙板 SVG支持多种蒙板特效,使用这些特性,我们可以做出很多很炫的效果.至于中文中把mask叫做"蒙板"还是"遮罩"就不去区分了,这里都叫做蒙板吧. ...

  4. NeHe OpenGL教程 第二十课:蒙板

    转自[翻译]NeHe OpenGL 教程 前言 声明,此 NeHe OpenGL教程系列文章由51博客yarin翻译(2010-08-19),本博客为转载并稍加整理与修改.对NeHe的OpenGL管线 ...

  5. 利用 js 实现弹出蒙板(model)功能

    关于 js 实现一个简单的蒙板功能(model) 思路: 创建一个蒙板, 设置蒙板的堆叠顺序保证能将其它元素盖住 position: absolute; top: 0; left: 0; displa ...

  6. CLIP PATH (MASK) GENERATOR是一款在线制作生成clip-path路径的工具,可以直接生成SVG代码以及配合Mask制作蒙板。

    CLIP PATH (MASK) GENERATOR是一款在线制作生成clip-path路径的工具,可以直接生成SVG代码以及配合Mask制作蒙板. CLIP PATH (MASK) GENERATO ...

  7. Android 图片合成:添加蒙板效果 不规则相框 透明度渐变效果的实现

    Android 图片合成:添加蒙板效果 不规则相框 透明度渐变效果的实现 暂时还未有时间开发这效果,所以先贴出来. 先贴一张效果图,这是一张手机截屏: 左上方的风景图:背景图片 右上方的人物图:前景图 ...

  8. js动态加载的蒙板弹框

    我们访问一些网站时总会遇到这种点击后,背景像被打上一层模板一样,这个是怎么做到的呢? 它是将这个弹框div独立于页面容器wrap,设置position为absolute,将其水平垂直之后都居中,设置弹 ...

  9. WPF蒙板弹窗

    由于界面设计需要,要给弹窗添加蒙板效果,在百度和google搜索了半天,竟然没有一个满意的方案,最后只能自己想办法实现了一个,原理还是比较简单的,现在分享给大家. 先看一下效果..      原理其实 ...

随机推荐

  1. python学习笔记七--数据操作符

    一.Python表达式操作符及程序:

  2. python学习笔记四--元组

    一.元组: 1. 不可变更的列表 2. 从语法上,她们是编写在小括号里,不是方括号里,列表是编写在方括号里的 3. 圆括号也同时用于表达式,如果想说明这是一个元组,不是表达式,可以在value后,关闭 ...

  3. RabbitMQ消息队列(一): Detailed Introduction 详细介绍(转)

    1. 历史 RabbitMQ是一个由erlang开发的AMQP(Advanced Message Queue )的开源实现.AMQP 的出现其实也是应了广大人民群众的需求,虽然在同步消息通讯的世界里有 ...

  4. Oracle数据导入导出imp/exp sp2-0734:未知的命令开头'imp...解决方法

    Oracle数据导入导出imp/exp sp2-0734:未知的命令开头'imp...解决方法   sp2-0734:未知的命令开头'imp 忽略了剩余行默认分类   www.2cto.com  应该 ...

  5. 【POJ】3468 A Simple Problem with Integers

    这题用线段树轻松解了,重新用树状数组解,关键点是区间更新.公式推导如下:sum[x] = org_sum[x] + delta[1]*x + delta[2]*(x-1) + delta[x]*1   ...

  6. Grunt 初体验

    对于没有接触过类似自动化工具的朋友,对 grunt 也许只是停留在听过阶段,而并没有真正的使用过.今天就从最初级的教程说起.在开始教程之前,需要先确保你已经安装了 node. 下面就开始来讲解 gru ...

  7. 转: 解决MSYS2下的中文乱码问题

    解决方案 新建/usr/bin/win: 12 #!/bin/bash$@ |iconv -f gbk -t utf-8 新建/etc/profile.d/alias.sh: 12345678 ali ...

  8. HNOI2008Cards

    看了一下polya和burnside定理,感觉还行(就是不会证……) 这题用的是burnside ans=在每个置换群下不动的方案数之和除以置换数 这题有个难点在取模 关于对p(p为素数)取模(涉及到 ...

  9. LeetCode Product of Array Except Self (除自身外序列之积)

    题意:给一个序列nums,要求返回一个序列ans,两序列元素个数相同,ans第i个元素就是除了nums[i]之外所有的数相乘之积. 思路:时间O(n),额外空间O(0). 第一次扫一遍,处理nums[ ...

  10. android LayoutInflater和inflate()方法的用法(转载)

    原文出处:http://www.cnblogs.com/top5/archive/2012/05/04/2482328.html 在实际开发中LayoutInflater这个类还是非常有用的,它的作用 ...