[4]Cocos2d-x之什么是锚点

总结:

什么是锚点?我们知道Layer,Scene,Sprite,创建它们的时候可以添加一张图,此时我们就把这个图当作一个2维坐标,底部为x轴,高为y轴,设置setAnchorPoint(0,0)代表锚点在坐标(图片)的左下角,即x=0,y=0,使用锚点时可以理解为节点的x,y最大值都为1,设置锚点值相当于设置xy值。

一、锚点的设置

//Layer认锚点值为(0,0)是因为ignoreAnchorPointForPosition=true;
//Node锚点值是(0.5,0.5),ignoreAnchorPointForPosition=false。

node->setAnchorPoint( Vec2 (0.5,0.5)); //认为中心
node->setAnchorPoint( Vec2 (0,0));       //左下角
node->setAnchorPoint( Vec2 (0,1));       //左上角
node->setAnchorPoint( Vec2 (1,0));       //右下角
node->setAnchorPoint( Vec2 (1,1));        //右上角
如上可以看到一个Node或其子类(Scene、Sprite)锚点的设置方法及锚点在Node的位置。

二、锚点的影响
锚点的设置会影响:
位置(position):节点设置的位置即锚点所在位置。
auto scene = Scene ::create();
Size s = Director ::getInstance()->getWinSize();
auto parent = Sprite ::create("HelloWorld.png");
parent->setAnchorPoint( Vec2 (0,0));
parent->setPosition(2*s.width/4,2*s.height/4);//锚点所在位置
旋转(rotation):以锚点为圆心旋转
子节点的添加(addChild): 子节点的锚点总是在父节点左下角,所以设置父节点的锚点不会影响子节点。
动作:对RotateBy、MoveBy等动作的影响,RotateBy会让节点以锚点为中心旋转,MoveBy以锚点为起始运行到指定地点。

所以,当我们添加一个节点时,对节点的位置或相关动作设置都与锚点有关系。

三、测试例子:

auto s = Director ::getInstance()->getWinSize();

auto defaultSprite = Sprite ::create( "pk.png");
auto modifySprite = Sprite ::create( "pk.png");

              defaultSprite->setColor( Color3B ::GRAY);
              modifySprite->setColor( Color3B ::GREEN);
//设置精灵位置
              defaultSprite->setPosition( Vec2 (s.width/4,s.height/2));
              modifySprite->setPosition( Vec2 (3*s.width / 4,s.height / 2));

               auto smallDefaultPk = Sprite ::create( "pk.png");
               auto smallModifyPk = Sprite ::create( "pk.png");
               //设置大小
              smallDefaultPk->setScale(0.5f);           
              smallModifyPk->setScale(0.5f);
//设置子精灵,子精灵位于父精灵的左下角
              defaultSprite->addChild(smallDefaultPk);
              modifySprite->addChild(smallModifyPk);

               this ->addChild(defaultSprite);
               this ->addChild(modifySprite);
//旋转动作,2秒,360度
               auto a1 = RotateBy ::create(2,360);
               auto a2 = ScaleBy::create(2,2);
               auto action1 = RepeatForever::create(Sequence::create(a1,a2,a2->reverse(),nullptr));
               auto action2 = RepeatForever ::create( Sequence::create(a1->clone(),nullptr ));
               //锚点:只对scale、rotation、skew有效
              modifySprite->setAnchorPoint( Vec2 (0.5,0.5)); //认为中心
              modifySprite->setAnchorPoint( Vec2 (0,0));        //左下角
              modifySprite->setAnchorPoint( Vec2 (0,1));        //左上角
              modifySprite->setAnchorPoint( Vec2 (1,0));        //右下角
              modifySprite->setAnchorPoint( Vec2 (1,1));         //右上角

              defaultSprite->setAnchorPoint( Vec2 (1,0));
              defaultSprite->setSkewX(20);              //设置倾斜
//执行动作
              defaultSprite->runAction(action1);
              modifySprite->runAction(action2);

相关文章

    本文实践自 RayWenderlich、Ali Hafizji 的文章《...
Cocos-code-ide使用入门学习地点:杭州滨江邮箱:appdevzw@1...
第一次開始用手游引擎挺激动!!!进入正题。下载资源1:从C...
    Cocos2d-x是一款强大的基于OpenGLES的跨平台游戏开发...
1.  来源 QuickV3sample项目中的2048样例游戏,以及最近《...
   Cocos2d-x3.x已经支持使用CMake来进行构建了,这里尝试...