位置: 编程技术 - 正文

Cocos2dx开发之锚点(cocos2d开发app)

编辑:rootadmin

推荐整理分享Cocos2dx开发之锚点(cocos2d开发app),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:cocos2d-x教程,cocos2dx4.0教程,cocos2d开发app,cocos设置锚点,cocos2d教程,cocos2d开发app,cocos锚点,cocos设置锚点,内容如对您有帮助,希望把文章链接给更多的朋友!

Cocos2dx开发之锚点实例讲解[ ]

锚点概念

由于我们在使用Cocos2dx进行开发时,一般都是在场景中加载精灵来实现的,而精灵上挂载的往往都不是一个点而是一张图片资源,那么我们在场景中设置这个精灵的位置时,对这张资源图片来说是应该把这张图片资源中的哪个点与我们设置的点对齐呢?这里就引出了锚点这个概念,我们通过设置锚点来确定资源图片上哪个点与我们设置位置点对齐。简而言之,锚点确定精灵自己在父节点的加载位置。

几何图形说明

上面的文字描述可能不太容易理解,下面作者发扬严谨的科研风&#;,绘图做以下说明:

假设我们要把一个精灵加载到场景中去,这个精灵上使用的图片资源是一张四边形图片,如下图所示

图 1

OK,当我们使用Cocos2dx下对应的API要给这个精灵设置一个特定的位置时,设置的结果是什么样的呢?这就与我们给定这个精灵的锚点有关,设置不同的锚点,加载结果也会不同。锚点的设置可以根据你的喜好随意设置,但是一般来说常用的锚点有哪些呢?如下图红色圈所表示的——左下角、左上角、右上角、右下角,在Cocos2dx中默认使用的锚点坐标是四边形的几何中心点。

图 2

在Cocos2dx中,我们可以使用setAnchorPoint这个接口来设置锚点,参数是一个cocos2d::CCPoint类型,这个点是(0.0f,0.0f)~(1.0f,1.0f)之间的一个&#;。

锚点Demo演示

我们在下面这个场景中来做测试,首先如下图所示,我们在这个场景中添加一个精灵A作为背景精灵:

加载代码:

// 添加背景资源

cocos2d::CCSprite* pBg = cocos2d::CCSprite::create("wndbg.png");

CC_BREAK_IF( !pBg );

pBg->setPosition(ccp(.0f,.0f));

this->addChild(pBg);

图 3

然后我们在这个精灵上开始增加另外一个精灵B作为测试精灵。

好,我们把测试精灵B的锚点设置为左下角(0.0f,0.0f),然后加载到精灵A之上,如下图所示:

加载代码:

// 加载测试精灵

cocos2d::CCSprite* pTestSprite = cocos2d::CCSprite::create("bubble.png");

CC_BREAK_IF( !pTestSprite );

pTestSprite->setAnchorPoint(ccp(0.0f,0.0f));

pTestSprite->setPosition(ccp(0.0f,0.0f));

pBg->addChild(pTestSprite);

结果展示:

图 4

Cocos2dx开发之锚点(cocos2d开发app)

再看下面,我们把测试精灵B的锚点设置为中间(Cocos2dx中默认锚点也是如此),加载结果:

加载代码:

// 加载测试精灵

cocos2d::CCSprite* pTestSprite = cocos2d::CCSprite::create("bubble.png");

CC_BREAK_IF( !pTestSprite );

pTestSprite->setAnchorPoint(ccp(0.5f,0.5f));

pTestSprite->setPosition(ccp(0.0f,0.0f));

pBg->addChild(pTestSprite);

加载结果如下

图 5

下来呢,再把测试精灵B的锚点设置为右上角(1.0f,1.0f),加载结果如下:

加载代码:

// 加载测试精灵

cocos2d::CCSprite* pTestSprite = cocos2d::CCSprite::create("bubble.png");

CC_BREAK_IF( !pTestSprite );

pTestSprite->setAnchorPoint(ccp(1.0f,1.0f));

pTestSprite->setPosition(ccp(0.0f,0.0f));

pBg->addChild(pTestSprite);

加载结果展示:

图 6

NICE,至此,我们可以看到,测试精灵B锚点设置不会影响它在背景精灵上的位置(这个位置只是根据setPosition接口来改变),只会影响测试精灵B本身的资源图片上的哪一点来与这个位置对齐。

=====================================

图层的旋转失败的案例

【 view plaincopy/// anchorPoint getter const CCPoint& CCNode::getAnchorPoint() { return m_obAnchorPoint; } void CCNode::setAnchorPoint(const CCPoint& point) { if( ! point.equals(m_obAnchorPoint)) { m_obAnchorPoint = point; m_obAnchorPointInPoints = ccp(m_obContentSize.width * m_obAnchorPoint.x, m_obContentSize.height * m_obAnchorPoint.y ); m_bTransformDirty = m_bInverseDirty = true; } } 其锚点的坐标&#;是一个相对&#;0~1,其中m_obAnchorPoint表示的是相对锚点坐标,m_obAnchorPointInPoints表示的是锚点在屏幕中的像素坐标,所以对于CCNode的坐标系转换会涉及到多种转换方式。

我们也可以通过设置ignoreAnchorPointForPosition来忽略锚点的作用。

对于图层而言其ignoreAnchorPointForPosition的默认&#;为false,CCSprite默认&#;为true,但是有时候大家会发现,即便咱们设置了图层的ignoreAnchorPointForPosition为false,但是图层的旋转仍然没有按照预定的结果来进行,原因是因为默认CCLayer的图层的大小为CCSize(0,0),所以不管你怎么设置图层的大小始终为(0,0),经过锚点比例进行计算之后其锚点的坐标仍然是(0,0),如下图所示:

但是设置了CCLayer的大小之后,就会发现,咱们设置的锚点就能起到作用了

[cpp] view plaincopyvoid LayerIgnoreAnchorPointPos::onEnter() { LayerTest::onEnter(); bool ignore = this->isIgnoreAnchorPointForPosition(); //this->ignoreAnchorPointForPosition(false); //CCSize layerSize = this->getContentSize(); setContentSize(CCDirector::sharedDirector()->getWinSize()); setAnchorPoint(ccp(0.5, 1)); //CCSize layerSize2 = this->getContentSize(); //CCPoint pt = this->getPosition(); //setPosition(ccp(layerSize2.width/2, layerSize2.height/2)); CCSize s = CCDirector::sharedDirector()->getWinSize(); CCLayerColor *l = CCLayerColor::create(ccc4(, 0, 0, ), , ); l->setAnchorPoint(ccp(0.5f, 0.5f)); l->setPosition(ccp( s.width/2, s.height/2)); CCMoveBy *move = CCMoveBy::create(2, ccp(,2)); CCMoveBy * back = (CCMoveBy *)move->reverse(); CCSequence *seq = CCSequence::create(move, back, NULL); l->runAction(CCRepeatForever::create(seq)); this->addChild(l, 0, kLayerIgnoreAnchorPoint); CCSprite *child = CCSprite::create("Images/grossini.png"); l->addChild(child); CCSize lsize = l->getContentSize(); child->setPosition(ccp(lsize.width/2, lsize.height/2)); CCMenuItemFont *item = CCMenuItemFont::create("Toggle ignore anchor point", this, menu_selector(LayerIgnoreAnchorPointPos::onToggle)); CCMenu *menu = CCMenu::create(item, NULL); this->addChild(menu); menu->setPosition(ccp(s.width/2, s.height/2)); //this->setAnchorPoint(ccp(0.5, 0.5)); CCDirector::sharedDirector()->getActionManager()->addAction( CCRepeatForever::create( CCSequence::create(CCRotateBy::create(2, ), CCRotateBy::create(2, -), 0) ), this, false); }

cocos2d出错 -::.:A/art():art/runtime/check_jni.cc:]JNIDETECTEDERRORINAPPLICATION:thereturntypeofCallStaticIntMethodVdoesnotmatchvoidcom.zhongshu.gamebase.GameBase.PayForFee(int,int,java.lang.S

【DEMO】用cocos2d-x3.x写的第一个cocosDemo 真是难以想象为啥变成这样了其实看Demo代码好麻烦,所以之后可能会出几个文章讲解各个部分代码质量我不知道怎么样,没有多少经验,初学者,不喜

<cocos2dx 随记> 关于cocos2dx接Android sdk的一些坑 简单说说UI线程:在Android中,有个非常重要的家伙非常霸道,那就是UI线程。这霸道之一:不能被阻塞。之二:系统对每一个组件的调用都从UI线程分发

标签: cocos2d开发app

本文链接地址:https://www.jiuchutong.com/biancheng/369161.html 转载请保留说明!

上一篇:cocos2d-x windows开发环境配置

下一篇:cocos2d出错(cocos2djs)

  • 企业增值税免税需要备案吗
  • 免税申报表里的免税销售额是不含税
  • 员工产假个税系统改为非正常要更正申报吗?
  • 材料卸车费包含在哪里
  • 工程结算成本和合同成本区别
  • 进项税额转出忘记填在申报表里
  • 发票该如何打印
  • 人力资源公司代招的岗位可以去吗
  • 季度应收账款周转天数是按多少天除
  • 融资性售后回租是什么服务
  • 滞纳金按什么比例算
  • 企业辅助生产车间
  • 税收主要分类方法
  • 年末发票
  • 员工拓展培训进度怎么写
  • 公司购买办公用品计入什么科目
  • 个人所得税必须得交吗
  • 销项税额抵减是怎么回事
  • 对外捐赠视同销售分录
  • 零星费用没有发票报销可以做入工资吗
  • 滴滴打车怎么整
  • 房地产工程质量检测费计入什么科目
  • 企业微信收款的钱怎么提取出来
  • 腾讯电脑管家中蓝牙在哪
  • windows 10 21h1
  • php网页运行原理
  • mac补丁安装步骤
  • php字符串定义
  • php字符串定义
  • 筹建期无形资产土地要摊销吗
  • 政策性搬迁损失扣除年度
  • 清算期间会计科目
  • 微软win11预览版
  • 以摊余成本计量的金融负债
  • 记账凭证账务处理步骤
  • php中session什么意思
  • golang、python、php、c++、c、java、Nodejs性能对比
  • 物流公司挂靠会计处理
  • vue全局引入js文件
  • 命令执行语句
  • 命令行怎么管理员运行
  • python爬虫中数据接口的含义
  • 小微企业所得税优惠政策2023
  • 复式记账法会计名词解释
  • java中空字符怎么表示
  • 物流企业财务流程
  • 国库集中支付发送签收失败
  • php二次开发哪个cms
  • 固定资产升级账务处理
  • 企业所得税是指哪些
  • 小规模纳税人缴纳增值税的会计科目
  • 什么情况下企业亏损但继续生产
  • 先买再卖影响可取现金吗
  • 一般纳税人进项票是普票可以抵扣吗
  • 支付上月采购货款
  • 购置成本由什么构成
  • 公司投资银行理财产品如何做账
  • 企业成立前期的重点工作
  • aspnet数据库访问
  • mysql分区实现
  • mysql忽略大小写设置
  • win8系统一直重启
  • linux,windows
  • OpwareSE2.exe - OpwareSE2是什么进程 有什么用
  • css百分比进度条
  • unity预处理命令
  • unity接收udp
  • javascript如何
  • jq倒计时代码
  • centos6升级到centos8
  • android基础知识点
  • js函数嵌套函数的return
  • Android之Async-http
  • javascript数组去重函数
  • public services翻译
  • 安卓动画不流畅
  • python编写一个模块
  • 退发票操作流程
  • 杭州市各区面积人口排名
  • 2008土地管理办法
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设