深入理解Cocos2d-x的anchorPoint锚点和scale缩放之间的配合方式
来源:互联网 发布:选择旅行社的软件 编辑:程序博客网 时间:2024/05/17 01:44
如果你有一个Node在一个盒子里,盒子的锚点在左下角,这个Node一开始的时候是这个样:position=(0, 0), anchorPoint=(0, 0), scale=1
然后更改它的scale让它撑满整个区域:position=(0, 0), anchorPoint=(0, 0), scale=1.09:
这个时候重新设置它的锚点为右上角(1, 1),你认为会发生什么?按照我的理解,我以为应该是这样:position=(0, 0), anchorPoint=(1, 1), scale=1.09
但事实上,它却是这样!!!:position=(0, 0), anchorPoint=(1, 1), scale=1.09
原因在于,一个Node被设置了scale缩放后,其本身的锚点位置并没有变,真实的锚点位置还是相对于原大小的位置,所以你注意我上图中画红点的位置,那就是setAnchorPoint(1, 1)之后真实的锚点位置,然后cocos2d-x以新的锚点位置重新执行了scale(1.09)操作,就变成了上图那个样。
而左边超出盒子的部分,其大小就是缩放比例1.09减去1之后乘以Node的原大小,也即
- (node:getScale() - 1) * node:getContentSize().width
理解了这个,以后就不会踩坑了。
附一个设置锚点也不改变Node位置的方法:
- -- 安全地设置锚点,用于锚点改变后node对象即便设置了scale缩放,其位置也不发生变化
- function setSafeAnchor(node, anchorX, anchorY)
- local diffX = anchorX * node:getContentSize().width * (node:getScaleX() - 1)
- local diffY = anchorY * node:getContentSize().height * (node:getScaleY() - 1)
- node:setAnchorPoint(anchorX, anchorY)
- node:setPositionX(node:getPositionX() + diffX)
- node:setPositionY(node:getPositionY() + diffY)
- end
阅读全文
0 0
- 深入理解Cocos2d-x的anchorPoint锚点和scale缩放之间的配合方式
- 深入理解cocos2d-x的anchorPoint锚点和scale缩放之间的配合方式
- 深入理解Cocos2d-x的anchorPoint锚点和scale缩放之间的配合方式
- cocos2d-x的anchorPoint锚点和scale缩放之间的配合方式
- Cocos2dx 中anchorPoint锚点和scale缩放之间的配合使用
- cocos2d-x中的锚点(AnchorPoint)理解
- cocos2d-x AnchorPoint锚点
- cocos2d-x AnchorPoint锚点
- cocos2d-x AnchorPoint锚点
- cocos2d-x AnchorPoint锚点
- cocos2d-x AnchorPoint锚点
- cocos2d-x AnchorPoint锚点
- cocos2d-x AnchorPoint锚点
- cocos2d-x AnchorPoint锚点
- Cocos2d-x AnchorPoint锚点
- cocos2d-x AnchorPoint锚点
- cocos2d-x AnchorPoint锚点
- 理解Cocos2d里的anchorPoint
- 空间类型和函数不可用于此提供程序,因为未能找到程序集“Microsoft.SqlServer.Types”版本 10 或更高版本。
- 快速排序
- 企业内网建设汇总
- linus 解压压缩
- 50万美元的1PB存储机柜是个什么样子
- 深入理解Cocos2d-x的anchorPoint锚点和scale缩放之间的配合方式
- 第6章 内部类、匿名内部类
- [LeetCode]1. Two Sum
- h5、js最详细的正则检验手机号码
- 一元隐函数及其求导
- 解决全站乱码的过滤器实现-包装类设计模式的应用
- socket-详细分析No buffer space available
- 用ASM直接读取字节码来加载Class的Annotation
- PXE+Kickstart无人值守安装CentOS 7出现DHCP故障解决报告