【CocosCreator入门】CocosCreator组件 | TiledMap(地图)组件

news2024/10/5 13:56:13

       Cocos Creator是一款流行的游戏开发引擎,具有丰富的组件和工具,其中TiledMap组件可以帮助开发者快速创建、加载和渲染地图。


目录

一、组件介绍

二、组件属性

三、脚本控制

3.1加载地图

3.2渲染地图

四、详细说明

五、关闭裁剪

六、节点遮挡


一、组件介绍

        TiledMap是基于Tiled地图编辑器的,Tiled是一款开源、跨平台的2D地图编辑器。Tiled支持多种地图格式,包括CSV、XML、JSON等。TiledMap组件会将Tiled地图编辑器编辑好的地图数据解析并渲染到游戏画面上。 在TiledMap组件中,地图数据主要分为两部分:地图属性和图块集。地图属性是指整个地图的一些基本信息,例如地图的大小、图块的大小等。图块集则是指地图中使用到的所有图块,每个图块都有自己的属性和位置信息。TiledMap组件会根据这些信息创建一个地图对象,并按照一定的规则将图块渲染到地图上。

二、组件属性

属性功能说明
Tmx Asset指定 .tmx 格式的地图资源

三、脚本控制

3.1加载地图

       在Cocos Creator中,可以通过以下代码来加载地图:

cc.resources.load('maps/map1', cc.TiledMapAsset, function (err, mapAsset) {
    if (err) {
        cc.error(err.message || err);
        return;
    }
    // 加载成功后,创建TiledMap组件
    var mapNode = new cc.Node();
    var tiledMap = mapNode.addComponent(cc.TiledMap);
    tiledMap.tmxAsset = mapAsset;
    // 将地图节点添加到场景中
    cc.director.getScene().addChild(mapNode);
});

       在以上代码中,首先使用cc.resources.load方法加载地图资源,其中maps/map1是地图资源的路径,cc.TiledMapAsset表示要加载的资源类型。在加载成功后,创建一个新的节点,并添加TiledMap组件,并将TiledMap组件的tmxAsset属性设置为加载成功的地图资源。最后将这个节点添加到场景中即可。

3.2渲染地图

       在TiledMap组件中,可以使用以下方法来获取地图上的图块:

var layer = tiledMap.getLayer('layer1');
var tile = layer.getTiledTileAt(0, 0, true);

       在以上代码中,首先获取TiledMap组件中名为layer1的图层对象,然后使用getTiledTileAt方法获取该图层上坐标为(0,0)的图块。最后,可以对这个图块进行一些操作,例如修改它的位置或旋转角度等。

四、详细说明

       添加 TiledMap 组件之后,从 资源管理器 中拖拽一个 .tmx 格式的地图资源到 Tmx Asset 属性上就可以在场景中看到地图的显示了。

       在 TiledMap 组件中添加了 Tmx Asset 属性后,会在节点中自动添加与地图中的 Layer 对应的节点。这些节点都添加了 TiledLayer 组件。请勿删除这些 Layer 节点中的 TiledLayer 组件。

       TiledMap 组件不支持 mapLoaded 回调,在 start 函数中可正常使用 TiledMap 组件。

五、关闭裁剪

cc.macro.ENABLE_TILEDMAP_CULLING = false;

       如果需要旋转地图或者把地图置于 3D 相机中,则需要关闭裁剪。另外,如果地图块不是非常多,如小于 5000 块,那么关闭裁剪还能减少 CPU 的运算负担,GPU 直接使用缓存进行渲染。

六、节点遮挡

       在游戏中,一些节点可能会遮挡住其他节点,导致被遮挡的节点无法正常显示。对于地图来说,当地图上有多个图层叠加时,可能会出现这种情况。为了解决这个问题,TiledMap组件提供了一些节点遮挡的功能,可以让被遮挡的节点暂时不显示,等到遮挡它的节点不再遮挡时再显示出来。

       在TiledMap组件中,可以使用以下方法来设置节点遮挡:

var layer = tiledMap.getLayer('layer1');
layer.enableCulling = true;

       在以上代码中,首先获取TiledMap组件中名为layer1的图层对象,然后将该图层的enableCulling属性设置为true。这样,当该图层上的某个节点被其他节点遮挡时,该节点会暂时不显示。等到遮挡它的节点不再遮挡时,该节点会再次显示出来。

       除了上述方法外,TiledMap组件还提供了其他一些节点遮挡的相关方法,例如:

  • setCullingDirty(): 设置节点遮挡脏标记,可以强制更新节点遮挡状态。
  • isCullingEnabled(): 获取该图层是否启用了节点遮挡功能。
  • setCullingBlockSize(size: cc.Size): 设置节点遮挡块的大小。
  • setCullingPadding(padding: cc.Rect): 设置节点遮挡块的内边距。
  • setCullingBorder(border: number): 设置节点遮挡边框的大小。

       总之,TiledMap组件是Cocos Creator中用于创建、加载和渲染地图的组件之一。它基于Tiled地图编辑器,可以快速创建和编辑地图,并在游戏中进行渲染。在使用TiledMap组件时,需要先将TiledMap组件添加到场景中,然后加载地图资源,并将TiledMap组件的tmxAsset属性设置为加载成功的地图资源。最后,可以使用TiledMap组件提供的方法来获取地图上的图块并进行一些操作。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/589550.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Linux中与进程间通信相关的内核数据结构

【摘要】本文详细讲述了Linux内核中与进程间通信概念相关的内核数据结构及其内在联系。 九、进程间通信(IPC)相关数据结构 9.1 ipc_namespace 从内核版本2.6.19开始,IPC机制已经能够意识到命名空间的存在,但管理IPC命名空间比较简单,因为它…

VR教育:让教育“可视化”,开启元宇宙教学之路

放眼世界,有不少高等教育学校都已经开始了元宇宙教学之路,为了从根本上解决目前课堂教学中存在的问题,进一步提高课堂教学质量,VR教育就可以很好地完善这些方面。 传统教育并不能让学生很好地沉浸在真实知识环境中,在一…

连锁门店运营管理系统有哪些功能?该如何选购?

连锁门店运营管理过程中,面临诸多难题,比如不同门店分布在不同地区,管理分散;各门店的人员管理、绩效考核、销售数据等工作进行困难;很难保证产品和服务的标准化管控。 连锁店只有不断适应市场变化,趁早选择…

不用运算符的加法运算

一.不用运算符的加法 1.题目描述 设计一个函数把两个数字相加。不得使用 或者其他算术运算符。 力扣:力扣 2.问题分析 1.知识预备 注意:下面所有的结论的进位是考虑二进制的进位,因为我们使用的位运算符,是针对二进制进行的. 结论一:在不考虑进位的情况下,其无…

【group by】mysql分组查询的案例和原理

【group by】mysql分组查询的案例和原理 【一】group by的使用场景【二】group by的基本语法【1】基本语法【2】常用的聚合函数(1)max函数:取出分组中的最大值(2)avg函数:取出分组中的平均值(3&…

斩获大奖!「智办事绩效」荣获钉钉年度奖项-「含钉量新锐奖」

近日,钉钉发布「含钉量年度奖」榜单,「智办事绩效」凭借与钉钉的深度融合斩获钉钉年度奖项-「含钉量新锐奖」。 ​作为钉钉优质合作伙伴,智办事绩效致力于用数字化、智能化的产品与专业的服务,解决传统绩效管理、人才培养痛点&…

【JOSEF约瑟 JDL-5200A 电流继电器 过负荷或短路启动元件 导轨安装】

名称:电流继电器;品牌:JOSEF约瑟;型号:JDL-5200A触点容量:250V2A;返回时间:≤35ms;整定范围:0.03-19.9A;特点:返回系数高、安装方便。…

前端vue面试题

四、路由 1. Vue-Router 的懒加载如何实现 非懒加载: import List from /components/list.vue const router new VueRouter({routes: [{ path: /list, component: List }] })(1)方案一(常用):使用箭头函数import动态加载 co…

content-visibility:可以提高项目的渲染性能

文章目录 一、前言二、浏览器支持程度三、CSS Containment四、跳过具有 content-visibility 的渲染工作五、关于accessibility的说明六、使用contains-intrinsic-size指定元素的自然大小七、通过content-visibility: hidden隐藏内容八、对下一幅画的交互影响(INP) 一、前言 co…

chatgpt赋能python:Python中*para:使用一个参数解决多个参数

Python中*para:使用一个参数解决多个参数 Python是广泛使用的编程语言之一,它非常灵活,可扩展性强,可以通过许多不同的方式实现编程目标。在Python中,有一种非常有用的特性,那就是使用para来代替多个参数。…

微信小程序原生开发功能合集十六:系统主页实现

本章实现小程序主页开发及对应逻辑处理,实现问卷填报相关功能,实现问卷查看、问卷查看、填报历史等功能的实现。   另外还提供小程序开发基础知识讲解课程,包括小程序开发基础知识、组件封装、常用接口组件使用及常用功能实现等内容,具体如下:    1. CSDN课程: http…

ArcGis系列-java发布GP分析结果(带样式)

1,前言 继上一篇 ArcGis系列-java调用GP分析 ,已经实现了gp工具的发布,调用,轮询,并已经分别保存好发布地图服务所需的矢量数据json,栅格数据tif文件和样式文件 要将gp分析的结果发布为图层供前端展示&am…

模版的分离编译 解决方案

回顾 对于模版,在之前我们就已经讲过,模版不支持分离编译(即声明定义不在同一文件中)。 类中,我们知道,对于代码量比较小的函数,会默认识别成内联函数,增加代码运行的效率&#xf…

【LeetCode 142】环形链表II

思路: 本题需要考虑以下两个问题: 判断链表是否环 如果有环,如何找到这个环的入口 一开始想着使用双指针的办法实现,但是发现没有什么思路,后面看了一些解析,用的快慢指针,两个指针重逢了&a…

IMX6ULL裸机篇之I2C协议

一. IIC实验简介 I2C 是最常用的通信接口,众多的传感器都会提供 I2C 接口来和主控相连。 比如摄像头、 加速度计、触摸屏等。 I.MX6U-ALPHA开发板 使用 I2C1 接口连接了一个距离传感器 AP3216C ,本章我们就来学习如何使用 I.MX6U 的 I2C 接口…

自学网络安全有什么好方法?

一、网络安全学习的误区 1.不要试图以编程为基础去学习网络安全 不要以编程为基础再开始学习网络安全,一般来说,学习编程不但学习周期长,且过渡到网络安全用到编程的用到的编程的关键点不多。一般人如果想要把编程学好再开始学习网络安全往…

深度学习AI编译器-TVM简介

1.为什么需要深度学习编译器 深度学习编译器主要为解决不同框架下训练的模型 部署到指定的某些设备上时所遇到的一系列复杂的问题,即将各种深度学习训练框架的模型 部署到各种硬件所面临的问题; 首先深度学习领域,从训练框架看,当…

C++ 编译过程(附简单实例)

C 编译的四个阶段:预处理、编译、汇编和链接。 这里以 g 为例,用到的文件分别为 mymath.h、mymath.cpp 和 main.cpp ,代码如下: // mymath.h extern int add(int, int);// mymath.cpp #include "mymath.h" // implemen…

攻防世界-web-newscenter

题目描述:打开链接,只有一个搜索框,然后就是一条一条新闻的记录 开启burpsuite,我们在搜索框中随便输入点什么,然后进行搜索,看下抓到的包 这里搜索的时候只有一个search参数,查询到的新闻数也变…

花6个月面过京东软件测试岗,拿个20K不过分吧?

背景介绍 计算机专业,代码能力一般,之前有过两段实习以及一个学校项目经历。第一份实习是大二暑期在深圳的一家互联网公司做软件测试,第二份实习由于大三暑假回国的时间比较短(小于两个月),于是找的实习是在…