cc.Node.坐标空间

简介:

坐标空间


1.cc.Vec2

cc.vec2二维向量坐标,表结构(x:120,y:120);

cc.v2(x,y)创建一个二维向量

方法:

cc.pSub向量相减

cc.pAdd向量相加

cc.pLength向量长度

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
     onLoad:  function  () {
     //创建vec2对象
     var  wpos =  new  cc.Vec2(100,100);
     console.log(wpos);
     //创建vec2对象
     wpos = cc.v2(200,500);
     console.log(wpos);
     //创建一个点 属于坐标
     wpos = cc.p(300,300);
     console.log(wpos);
     //向量用法 比如一个起点和终点 怎么算出向量?
     var  src = cc.p(10,10);
     var  dts = cc.p(100,100);
     //这个向量就是目的地减去起点
     var  dir = cc.pSub(dts,src);
     console.log(dir);
     //求这个向量等长度 当前坐标到原点距离
     var  len = cc.pLength(dir)
     console.log(len);
     
     },




2.cc.Size/cc.Rect

cc.Size包含宽度和高度信息等对象,{width:100,height:100}

new cc.Size(w,h)和cc.size(w,h)来创建大小对象.


cc.Recv(矩形)new cc.Rect(x,y,w,h)和cc.rect(x,y,w,h)创建对象

常用方法:

contains(Point):判断一个点是否在矩形内

intersects:两个矩形是否相交





坐标系

1世界(屏幕)坐标系:

也称为屏幕坐标系,他的原点是屏幕的左下角,

水平向右是x, 竖直向上是y。




2.节点坐标系也叫相对坐标

相对于节点的一个坐标,

)ANX`S]BD9JNRSF1Y_VG$6E.png



3.有两种相对节点 原点等查找方式

第一种:使用默认左下角为原点。

第二种:以锚点为原点(后缀带AR)。

creator 默认是使用带AR的,因为他坐标都是以锚点作为原点,

来进行设置, 所以通常使用这种API都要带AR




4.节点坐标和屏幕坐标的相互转换  



节点坐标转屏幕坐标  convertToWorldSpace() convertToWorldSpaceAR()

1
2
3
4
5
6
//将节点坐标转为屏幕坐标
//节点的原点比如说是0,0
//这样就能算出节点等原点所在屏幕坐标
//不带AR是以做下角为原点.
var  wpos =  this .node.convertToWorldSpace(cc.p(0,0));
console.log(wpos); //输出430,270

XJBR@{HOOKKA0~BEROYR8EW.png


1
2
3
4
//如果是以锚点作为锚点方法后面带AR
//这里就是以坐标等锚点为原点了
wpos =  this .node.convertToWorldSpaceAR(cc.p(0,0));
console.log(wpos); //输出480,320



世界坐标转节点坐标  以节点原点(0,0)  convertToNodeSpace()

1
2
3
4
5
//精灵的锚点 作为世界坐标
var  pos = cc.p(480,320);
var  node_pos =  this .node.convertToNodeSpace(pos);
//输出的就是50,50 因为是以节点的(0,0)作为原点等
console.log(node_pos);



世界坐标转节点坐标  以节点的锚点作为原点 convertToNodeSpaceAR()

1
2
3
4
5
6
//精灵的锚点 作为世界坐标 
var  pos = cc.p(480,320);、
//以节点的锚点作为原点
var  node_pos =  this .node.convertToNodeSpaceAR(pos);
//输出的就是0,0 因为是以节点的锚点作为原点等
console.log(node_pos);


总结下: 通常情况下,使用带AR的,因为creator里面

坐标默认是以锚点来设置的。







5.获取在父节点坐标系下的节点包围盒 getBoundingBox()


1
2
3
4
         //获取节点的包围盒,相对于父节点的坐标系的
         var  box =  this .node.getBoundingBox();
         //-25,-25,50,50  
         console.log(box)

蓝色的是子节点

输出的是-25,-25,50,50 x,y坐标是相对于父节点坐标系的

注意:这个父节点坐标系原点是以锚点为参考的。


0J$_${0Q$QO0I]_I6P}SXG7.png







6.获取在世界坐标系下的节点包围盒 getBoundingBoxToWorld()

getBoundingBoxToWorld 返回节点在世界坐标系下的对齐轴向的包围盒


1
2
         box =  this .node.getBoundingBoxToWorld();
         console.log(box);

输出的是 455,295,50,50 因为他的高宽是50,50

根据事件坐标来获取到他这是(以AR锚点为原点)是480,320

但是他的x,y是这个减去高或宽/2,因为他的原点也是锚点.

那么就是455,295





7.触摸事件对象世界坐标与节点坐标转换 convertToNodeSpaceAR()


1
2
3
4
5
6
7
         this .node.on(cc.Node.EventType.TOUCH_START,
             function (t){
                 var  wpos = t.getLocation();
                 //把这个点击转换为节点坐标系
                 wpos =  this .node.convertToNodeSpaceAR(wpos);
                 console.log(wpos);
             }, this );

UJO[0(1A7UJ4FP{14BU$ZW7.png

这样就能获取到这个子节点相对于父亲节点(锚点)的触摸坐标啦、


还有一种更简便的写法 convertTouchToNodeSpaceAR(t)

这个t就是cc.Touch 他不用你在去getLocation() 他内部做了这个操作

1
2
3
               //这里传入的参数是cc.Touch 
                 wposs =  this .node.convertTouchToNodeSpaceAR(t)
                 console.log(wposs);





8 我们现在要把一个子节点的位置移动到相对与父亲的位置.

坐标使用的是世界坐标,600,500,现在就要获取这个

点相对于父节点的位置,也就是以父节点原点来设置这个位置.

1
2
var  node_pos =  this .node.parent.convertToNodeSpaceAR(cc.p(600,500));
                 this .node.setPosition(node_pos);






 本文转自超级极客51CTO博客,原文链接:http://blog.51cto.com/12158490/2064708,如需转载请自行联系原作者





相关文章
|
2月前
|
数据采集 存储 监控
实现自动化数据抓取:使用Node.js操控鼠标点击与位置坐标
本文介绍了如何使用Node.js和Puppeteer实现自动化数据抓取,特别是针对新闻网站“澎湃新闻”。通过设置代理IP、User-Agent和Cookie,提高爬虫的效率和隐蔽性,避免被网站封锁。代码示例展示了如何模拟鼠标点击、键盘输入等操作,抓取并整理新闻数据,适用于需要规避IP限制和突破频率限制的场景。
115 10
|
12天前
|
JavaScript
nodejs安装之npm ERR! code CERT_HAS_EXPIREDnpm ERR! errno CERT_HAS_EXPIRED reason: certificate has expired-证书错误通用问题解决方案-优雅草央千澈
nodejs安装之npm ERR! code CERT_HAS_EXPIREDnpm ERR! errno CERT_HAS_EXPIRED reason: certificate has expired-证书错误通用问题解决方案-优雅草央千澈
|
2月前
|
Web App开发 JavaScript 前端开发
2024年5月node.js安装(winmac系统)保姆级教程
本篇博客为2024年5月版Node.js安装教程,适用于Windows和Mac系统。作者是一名熟悉JavaScript与Vue的大一学生,分享了Node.js的基本介绍、下载链接及简单安装步骤。安装完成后,通过终端命令`node -v`验证版本即可确认安装成功。欢迎关注作者,获取更多技术文章。
39 2
2024年5月node.js安装(winmac系统)保姆级教程
|
2月前
|
存储 JavaScript 搜索推荐
Node框架的安装和配置方法
安装 Node 框架是进行 Node 开发的第一步,通过正确的安装和配置,可以为后续的开发工作提供良好的基础。在安装过程中,需要仔细阅读相关文档和提示,遇到问题及时解决,以确保安装顺利完成。
143 2
|
4月前
|
JavaScript
NodeJs的安装
文章介绍了Node.js的安装步骤和如何创建第一个Node.js应用。包括从官网下载安装包、安装过程、验证安装是否成功,以及使用Node.js监听端口构建简单服务器的示例代码。
NodeJs的安装
|
3月前
|
JavaScript 开发工具 git
已安装nodejs但是安装hexo报错
已安装nodejs但是安装hexo报错
60 2
|
3月前
|
JavaScript 算法 内存技术
如何降低node.js版本(nvm下载安装与使用)
如何降低node.js版本(nvm下载安装与使用)
|
4月前
|
存储 JavaScript 前端开发
Node 版本控制工具 NVM 的安装和使用(Windows)
本文介绍了NVM(Node Version Manager)的Windows版本——NVM for Windows的安装和使用方法,包括如何安装Node.js的特定版本、列出已安装版本、切换使用不同版本的Node.js,以及其他常用命令,以实现在Windows系统上对Node.js版本的便捷管理。
Node 版本控制工具 NVM 的安装和使用(Windows)
|
4月前
|
SQL JavaScript 数据库
sqlite在Windows环境下安装、使用、node.js连接
sqlite在Windows环境下安装、使用、node.js连接
|
3月前
|
Web App开发 JavaScript 前端开发
JavaWeb 22.Node.js_简介和安装
JavaWeb 22.Node.js_简介和安装