COCOS2D-X锚点的理解

COCOS2D-X锚点的理解,第1张

概述Cocos2d-x :什么是锚点?(简单点说:锚点就是图片的原点) 将一个节点添加到父节点里面时,需要设置其在父节点上的位置,本质上是设置节点的锚点在父节点坐标系上的位置。 anchor point 究竟是怎么回事? 之所以造成不容易理解的是因为我们平时看待一个图片是 以图片的中心点 这一个维度来决定图片的位置的。而在cocos2d中决定一个 图片的位置是由两个维度 一个是 position  另

Cocos2d-x :什么是锚点?(简单点说:锚点就是图片的原点)

将一个节点添加到父节点里面时,需要设置其在父节点上的位置,本质上是设置节点的锚点在父节点坐标系上的位置。

anchor point 究竟是怎么回事? 之所以造成不容易理解的是因为我们平时看待一个图片是 以图片的中心点 这一个维度来决定图片的位置的。而在cocos2d中决定一个 图片的位置是由两个维度 一个是 position 另外一个是anchor point。只要我们搞清楚他们的关系,自然就迎刃而解。

默认情况下,anchor point在图片的中心位置(0.5,0.5),取值在01之间的好处就是,锚点不会和具体物体的大小耦合,也即不用关注物件大小,而应取其对应比率,如果把锚点改成(00),则进行放置位置时,以图片左下角作为起始点

也就是说,把position设置成(x,y)时,画到屏幕上需要知道:到底图片上的哪个点放在屏幕的(x,y)上,而anchor point就是这个放置的点,anchor point是可以超过图片边界的,比如下例中的(-1,-1),表示从超出图片左下角一个宽和一个高的地方放置到屏幕的(0,0)位置(向右上偏移10个点才开始到图片的左下角,可以认为向右上偏移了10个点的空白区域)


他们的关系是这样的(假设actualposition.x,actualposition.y是真实图片位置的中点):

actualposition.x = position.x + wIDth*(0.5 - anchor_point.x); acturalposition.y = position.y + height*(0.5 - anchor_point.y)

actualposition 是sprite实际上在屏幕显示的位置, poistion是 程序设置的, achor_point也是程序设置的。


具体看下面的例子一:

[HTML]view plaincopy CCSprite*sprite=[CCSpritespritewithfile:@"blackSquare.png"]; sprite.position=ccp(0,0); sprite.anchorPoint=ccp(0,248); margin:0px!important; padding:0px 3px 0px 10px!important"> [selfaddChild:sprite];
具体效果如下:

anchorpoint锚点解析(转)" >

根据上面的公式: 假设精灵的wIDth = height = 10.

actualposition.x = 0 + 10*(0.5 - 0) = 5; actualposition.y = 0 + 10*(0.5 - 0) = 5;

(5,5) 这个结果正是现在图片中心的在屏幕上的实际位置。

如果以左下角(Opengl坐标系的原点)为参照,就是把图片的原点锚在了屏幕坐标的原点上

例子 二:

copy sprite.anchorPoint=ccp(-1,-1);

anchorpoint锚点解析(转)" >

根据上面的公式: 假设精灵的wIDth = height = 10.

坐标方向是opengl的方向(原点在左下角,x向左,y向上为正)

actualposition.x = 0 + 10*(0.5 - (-1)) = 15; actualposition.y = 0 + 10*(0.5 - (-1)) = 15;

(15,15) 这个结果正是现在图片中心的在屏幕上的实际位置。

如果以左下角(Opengl坐标系的原点)为参照,就是把图片的(-10,-10)这个点锚在了屏幕的原点(即图片的原点锚在了屏幕坐标的(10,10)上)

例子三

copy sprite.anchorPoint=ccp(1,1); sprite.position=ccp(sprite.contentSize.wIDth,sprite.contentSize.height); [selfaddChild:sprite];

anchorpoint锚点解析(转)" >


actualposition.x = 10 + 10*(0.5 - (1)) = 5; actualposition.y = 10 + 10*(0.5 - (1)) = 5;

就是把图片的(10,10)这个点锚在了屏幕坐标的(10,10)上


//-------------------------------------------------------

上面是一篇讲述的比较详细的文章,自己也总结了一下:锚点其实就是图片的原点。如何去理解这一点?假设锚点是(0.5,0.5),也就是图片的中心处,我们将这个点看成图片原点,图片是以这个点位起点的,然后跟position去结合。

如:锚点(0.5 ,0.5)

sprite.position=ccp(0,sprite.contentSize.height/2);

我们将图片的原点(锚点)放到ccp(0,sprite.contentSize.height/2)这个位置,也就是图片在屏幕上的位置。

总结

以上是内存溢出为你收集整理的COCOS2D-X锚点的理解全部内容,希望文章能够帮你解决COCOS2D-X锚点的理解所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://www.outofmemory.cn/web/1058185.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-25
下一篇 2022-05-25

发表评论

登录后才能评论

评论列表(0条)

保存