`
modabobo
  • 浏览: 508326 次
文章分类
社区版块
存档分类
最新评论

cocos2d-x 2.2.0 图片选中聚焦 ,图片描边 CCClippingNode 实现

 
阅读更多

效果如下图

左边箭头是x方向翻转的,右边箭头有旋转和缩放action。大概实现方法:用箭头作为遮罩层,底图是一个绘制的矩形,得到一个黄色箭头背景。在用schedule跟随要聚焦箭头动作。这个在电视端用遥控器上下左右选择聚焦有点用。希望这个是对同学们有帮助,谢谢。






代码

#include "HelloWorldScene.h"

USING_NS_CC;

CCScene* HelloWorld::scene()
{
    // 'scene' is an autorelease object
    CCScene *scene = CCScene::create();
    
    // 'layer' is an autorelease object
    HelloWorld *layer = HelloWorld::create();

    // add layer as a child to scene
    scene->addChild(layer);

    // return the scene
    return scene;
}

// on "init" you need to initialize your instance
bool HelloWorld::init()
{
    //////////////////////////////
    // 1. super init first
    if ( !CCLayer::init() )
    {
        return false;
    }
    
    CCSize visibleSize = CCDirector::sharedDirector()->getVisibleSize();
  
    
    CCSprite *stencil = CCSprite::create("f1.png");
    stencil->setFlipX(true);
    
    CCClippingNode *clipper = CCClippingNode::create();
    clipper->setAlphaThreshold(0.005f);
    clipper->setAnchorPoint(ccp(0.5, 0.5));
    clipper->setPosition( ccp(visibleSize.width / 2 - 50, visibleSize.height / 2 - 50) );
    clipper->setStencil(stencil);
    
    this->addChild(clipper,0,cliper_tag);
    
    CCNode *content = shape(stencil->getContentSize());
    clipper->addChild(content,0,content_tag);
    
    CCSprite *updata = CCSprite::create("f1.png");
    updata->setFlipX(true);
    updata->setPosition( ccp(visibleSize.width / 2 - 50, visibleSize.height / 2 - 50) );
    this->addChild(updata,1,spr1_tag);
    
    
    CCSprite *updata2 = CCSprite::create("f2.png");
    updata2->setPosition( ccp(visibleSize.width / 2 + 50, visibleSize.height / 2 - 50) );
    updata2->runAction(CCRepeatForever::create(CCSequence::create(CCScaleTo::create(0.5, 1.3),CCRotateBy::create(2, 90),CCScaleTo::create(0.5, 1),NULL)));
    
    this->addChild(updata2,1,spr2_tag);
    
    
    this->setTouchEnabled(true);
    return true;
}

CCDrawNode* HelloWorld::shape(CCSize size)
{
    CCDrawNode *shape = CCDrawNode::create();
    static CCPoint shapedate[4];
    shapedate[0] = ccp(-(size.width / 2), -(size.height / 2));
    shapedate[1] = ccp((size.width / 2), -(size.height / 2));
    shapedate[2] = ccp((size.width / 2), (size.height / 2));
    shapedate[3] = ccp(-(size.width / 2), (size.height / 2));
    
    static ccColor4F yellow = {1, 1, 0, 1};
    shape->drawPolygon(shapedate, 4, yellow, 0, yellow);
    return shape;
}

void HelloWorld::setshaper(int tag){
    
    this->unschedule(schedule_selector(HelloWorld::cliperupdate));
    
    current_tag = tag;
    
    CCSprite* sp = (CCSprite*) this->getChildByTag(tag);
    CCClippingNode *clipper = (CCClippingNode*)this->getChildByTag(cliper_tag);
    
    CCSprite *stencil = CCSprite::createWithTexture(sp->getTexture());
    stencil->setFlipX(sp->isFlipX());
    stencil->setFlipY(sp->isFlipY());
    stencil->setScale(sp->getScale());
    stencil->setRotation(sp->getRotation());
    clipper->setStencil(stencil);
    clipper->setPosition(sp->getPosition());
    
    
    clipper->removeChildByTag(content_tag);
    clipper->addChild(shape(sp->getContentSize()),0,content_tag);
    
    
    
    this->schedule(schedule_selector(HelloWorld::cliperupdate), 0.05);
    
}

void HelloWorld::cliperupdate(float dt){
    
    CCSprite* sp = (CCSprite*) this->getChildByTag(current_tag);
    CCClippingNode *clipper = (CCClippingNode*)this->getChildByTag(cliper_tag);
    clipper->setPosition(sp->getPosition());
    
    CCSprite *stencil = (CCSprite*)clipper->getStencil();
    stencil->setFlipX(sp->isFlipX());
    stencil->setFlipY(sp->isFlipY());
    stencil->setScale(sp->getScale());
    stencil->setRotation(sp->getRotation());
    
    CCSprite *content = (CCSprite*)clipper->getChildByTag(content_tag);
    content->setScale(sp->getScale());
    content->setRotation(sp->getRotation());
    
    
}


bool HelloWorld::ccTouchBegan(cocos2d::CCTouch *pTouch, cocos2d::CCEvent *pEvent){
    
    
    
    CCPoint location = this->convertTouchToNodeSpace(pTouch);
    if (this->getChildByTag(spr1_tag)->boundingBox().containsPoint(location)) {
        setshaper(spr1_tag);
    }
    
    if (this->getChildByTag(spr2_tag)->boundingBox().containsPoint(location)) {
        setshaper(spr2_tag);
    }

    return true;
    
}
void HelloWorld::ccTouchMoved(cocos2d::CCTouch *pTouch, cocos2d::CCEvent *pEvent){
    
}
void HelloWorld::ccTouchEnded(cocos2d::CCTouch *pTouch, cocos2d::CCEvent *pEvent){
    
}

void HelloWorld::registerWithTouchDispatcher(void){
    CCDirector::sharedDirector()->getTouchDispatcher()->addTargetedDelegate(this, 0, false);
}
void HelloWorld::onEnter(){
    CCLayer::onEnter();
}
void HelloWorld::onExit(){
    CCLayer::onExit();
}

void HelloWorld::menuCloseCallback(CCObject* pSender)
{
#if (CC_TARGET_PLATFORM == CC_PLATFORM_WINRT) || (CC_TARGET_PLATFORM == CC_PLATFORM_WP8)
	CCMessageBox("You pressed the close button. Windows Store Apps do not implement a close button.","Alert");
#else
    CCDirector::sharedDirector()->end();
#if (CC_TARGET_PLATFORM == CC_PLATFORM_IOS)
    exit(0);
#endif
#endif
}

demo工程在这里下载 狂点我


分享到:
评论

相关推荐

    Cocos2d-x实战:JS卷——Cocos2d-JS开发

    资源名称:Cocos2d-x实战:JS卷——Cocos2d-JS开发内容简介:本书是介绍Cocos2d-x游戏编程和开发技术书籍,介绍了使用Cocos2d-JS中核心类、瓦片地图、物理引擎、音乐音效、数据持久化、网络通信、性能优化、多平台...

    cocos2d-x-2.1.5

    cocos2d-x-2.1.5

    cocos2d-x事件类

    在使用cocos2d-x开发游戏的过程中,为了实现逻辑和显示相分离。 在下通宵了一个晚上,写出了该事件类。 谨记,该事件只能用于cocos2d-x中。 事件发送者需要继承EventDispatcher类 事件接收者需要继承EventHandle类...

    大富翁手机游戏开发实战基于Cocos2d-x3.2引擎

    资源名称:大富翁手机游戏开发实战基于Cocos2d-x3.2引擎内容简介:李德国编著的《大富翁手机游戏开发实战(基于 Cocos2d-x3.2引擎)》使用Cocos2d-x游戏引擎技术,带领读者一步一步从零开始进行大富翁移动游戏的开发...

    Cocos2d-x高级开发教程

    Cocos2d-x是移动跨平台开发最流行的游戏引擎,而本书是一本很全面的、比较‘接地气’的游戏开发教程。书中汇聚了热门手机游戏《捕鱼达人》开发的实战经验,作者从最基础的内容开始,逐步深入地介绍了Cocos2d-x的相关...

    cocos2d-x-2.2.0.zip 完整版包

    cocos2dx 历史版本 cocos2d-x-2.2.0 完整版包,有用到老版本的可以尝试下载。新项目开发建议使用较新版本的 cocos2dx

    cocos2d-x-3.2旧版引擎下载

    cocos2d-x-3.2下载,不多说。或者可以下载另一个资源 cocos引擎老版本集合(cocos2d-x-2.2.1 - 3.5) http://download.csdn.net/download/crazymagicdc/9982656

    cocos2d-x实战项目

    cocos2d-x实战项目 01.cocos2d-x原理及环境配置.rar 03.cocostudio使用方法及UI控制.rar 04.XML文件读取与骨骼动画.rarcocos2d-x实战项目 01.cocos2d-x原理及环境配置.rar 03.cocostudio使用方法及UI控制.rar 04.XML...

    Cocos2D-X游戏开发技术精解

    资源名称:Cocos2D-X游戏开发技术精解内容简介:Cocos2D-X是一款支持多平台的 2D手机游戏引擎,支持iOS、Android、BlackBerry等众多平台。当前,很多移动平台流行的游戏,都是基于Cocos2D-X开发的。 《Cocos2D-X...

    经典版本 方便下载 源码 旧版本 3.8 官网找不到了 cocos2d-x-3.8.zip

    经典版本 方便下载 源码 旧版本 3.8 官网找不到了 cocos2d-x-3.8.zip

    精通COCOS2D-X游戏开发 基础卷_2016.4-P399-13961841.pdf

    精通COCOS2D-X游戏开发 精通COCOS2D-X游戏开发 精通COCOS2D-X游戏开发 精通COCOS2D-X游戏开发 精通COCOS2D-X游戏开发

    Cocos2D-X游戏开发技术精解.pdf

    《Cocos2D-X游戏开发技术精解》详细介绍如何使用Cocos2D-X引擎开发自己的移动平台游戏。全书共15章,主要内容包括:Cocos2D-X引擎简介;如何建立跨平台的开发环境;引擎的核心模块——渲染框架;如何实现动态画面和...

    cocos2d-x-3.0 类图

    这是我重新弄的cocos2d-x-3.0的类图.之前别人兄台弄的,有些不全面,有些地方错误.我这个可以说是最新的了.每个类添加了中文的详细注解,同时也添加了中文的类名称翻译.这样对cocos2d-x-3.0的框架比较好上手. 有兴趣的...

    Cocos2d-x 3.x游戏开发实战pdf含目录

    Cocos2d-x 3.x游戏开发实战pdf含目录,内容详细,强烈推荐给大家。

    Cocos2d-x游戏编程——C++篇 .iso

    Cocos2d-x游戏编程——C++篇(电子工业出版社,徐飞 著)书本配套的光盘代码,

    cocos2d-x windows vs2010配置

    Cocos2d-x windows vs2010 配置图文详解

    Cocos2d-x实战 JS卷 Cocos2d-JS开发

    Cocos2d-x实战 JS卷 Cocos2d-JS开发 PDF 电子书完整版本

    cocos2d-x 动画工具 Flash2Cocos2d-x 1.3

    cocos2d-x 动画工具 Flash2Cocos2d-x 1.3

    cocos2d-x 3.0

    cocos2d-x 3.0 人物行走 . 包里有代码和 图片资源.

    cocos2d-x开发者文档(中文)2015-01-30

    因为最近在学cocos2d-x,找了半天在网上也找不到一个离线的文档,于是自己抽空做了一个,全部内容提取自cocos2d-x中文官网的文档页http://cn.cocos2d-x.org/article 目前只提取了cocos2d-x部分内容。因为内容比较多...

Global site tag (gtag.js) - Google Analytics