在Cocos 2d-x中绘制六边形网格

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了在Cocos 2d-x中绘制六边形网格相关的知识,希望对你有一定的参考价值。

所以我即将在Cocos2D-X创建一个Hexagon网格游戏。我需要它来响应触摸,当用户触摸六边形时,我将触发一些动画和动作。

我想知道哪个是更好的方法来实现这一目标。使用CCTMXTiledMap创建六角形平铺地图,或者自己绘制六边形网格?

在自定义绘图解决方案中,CCDrawNode是绘制六边形的更好方法吗?

任何建议,将不胜感激。

答案

我最终使用CCDrawNode自己绘制六边形,这样我就可以获得所需的六边形触摸空间,而且我无需进行任何额外的计算来检查六角形是否被触及。

这是算法:

Hexagon::Hexagon(float hexagonWidth, float hexagonHeight, Color4F fillColor)
{
    float width = hexagonWidth;
    float height = hexagonHeight;

    _drawNode = CCDrawNode::create();
    Point vertices[6] = {
        Point( 0.f, height/2 ),
        Point( width*1/4, height ),
        Point( width*3/4, height ),
        Point( width, height/2 ),
        Point( width*3/4, 0.f ),
        Point( width*1/4, 0.f )
    };

    Color4F borderColor = {0.0f, 0.0f, 1.0f, 1.0f};
    _drawNode->drawPolygon(vertices, 6, fillColor, 0.f, borderColor);
    _drawNode->setAnchorPoint(Point(0.5, 0.5));
}
另一答案

试试这个代码 -

CCMenu  *myMenu =   CCMenu::create();
    myMenu->setPosition(CCPointZero);
    this->addChild(myMenu);

    int leftMargin  =   20;
    int topMargin   =   500;

    int index   =   0;
    for (int i=0; i<5; i++) {
        leftMargin  =   150;
        if (i%2 != 0) {
            leftMargin  =   leftMargin-(100/2);
        }
        for (int j=0; j<5; j++) {


            CCMenuItemImage *hexImg =   CCMenuItemImage::create("hexagon_new.png", "hexagon_new.png", this, menu_selector(Hexagon::clickOnHex));
            hexImg->setRotation(90);
            hexImg->setPosition(ccp(leftMargin, topMargin));
            hexImg->setTag(index);
            hexImg->setScale(115/hexImg->getContentSize().width);
            myMenu->addChild(hexImg);
            index++;
            leftMargin  += 100;
        }
        topMargin   -=  82;
    }

用户触摸六边形动画的功能是 -

void Hexagon::clickOnHex(CCObject *sender){
    CCMenuItemImage *tempHex    =   (CCMenuItemImage *)sender;
    CCRotateBy *rotateBy        =   CCRotateBy::create(0.5, 360);
    tempHex->runAction(rotateBy);
    CCLOG("HEX CLICKED");
}

做动画你想要的。

这是我用过的图像。

hexagon image

以上是关于在Cocos 2d-x中绘制六边形网格的主要内容,如果未能解决你的问题,请参考以下文章

绘制多边形网格时的 Opengl 性能问题

(转)quick-cocos2d-x图片资源加密(续)

Unity - 绘制正五边形网格

(转)quick-cocos2d-x图片资源加密

quick-cocos2d-x学习笔记—定时器

使用VS插件在VS2012/2013上编辑和调试Quick-Cocos2d-x的Lua代码