Unity 使用tiledmap解析地图的详细过程

1、先使用tiledmap编辑地图,图层用来刷图块,对象用来定义单个格子的数据

2、为每个图块调属性

3、图块需要单独配置属性的就必须创建对象,并设置值

右键设置属性

4、导出json文件

5、代码如下,详细看相应注释

using SimpleJSON;
using System.Collections;
using System.Collections.Generic;
using UnityEngine;

public class tmx : MonoBehaviour
{
    void Start()
    {
        TextAsset text = Resources.Load<TextAsset>(string.Format("{0}/{1}", Const.CONFIG_TMX_PATH, "map1"));//加载tmx文件
        JSONNode data = JSONNode.Parse(text.text).AsObject;//将tmx文本转化为json对象

        //1、对象层操作
        Dictionary<string, JSONNode> objectsDic = new Dictionary<string, JSONNode>();
        string layers_objects = data["layers"][1]["objects"].ToString();
        JSONArray arr_layers_objects = JSONNode.Parse(layers_objects).AsArray;
        int tilewidth = int.Parse(data["tilewidth"]);//获取格子宽
        int tileheight = int.Parse(data["tileheight"]);//获取格子高
        foreach (var obj in arr_layers_objects)//遍历所有对象层上的对象
        {
            int key_x = obj.Value["x"] / tilewidth;//格子x轴 除以 格子宽得出这个对象在x轴第几个格子内
            int key_y = obj.Value["y"] / tileheight;//格子y轴 除以 格子高 得出这个对象在y轴第几个格子内
            objectsDic[string.Format("{0}-{1}", key_y, key_x)] = obj.Value["properties"];//将对象里的值保存到对应格子内
        }

        //图层
        string layers_data = data["layers"][0]["data"].ToString();//获取图层内的二维数组
        JSONArray arr_layers_data = JSONNode.Parse(layers_data).AsArray;
        JSONNode tileproperties = data["tilesets"][0]["tileproperties"];//获取对应图层二维数组内的格子对象
        //int tilesets = int.Parse(tileproperties["1"]["ID"]);

        int col = int.Parse(data["width"]);//获取横向有多少个格子
        int row = int.Parse(data["height"]);//获取纵向有多少个格子
        float sprite_size = 0.66f;//每个方格64像素+空余2像素
        Vector3 vec = new Vector3(-int.Parse((col / 2).ToString()) * sprite_size, int.Parse((row / 2).ToString()) * sprite_size, 0);
        for (int i = 0; i < row; i++)//从左向右
        {
            for (int j = 0; j < col; j++)//从上到下
            {
                int gid = arr_layers_data[j + i * col] - 1;//获取二维数组里的值
                if (gid == -1)//如果此格子没有刷,则值为-1
                    continue;
                JSONNode Dic_Grid = tileproperties[gid.ToString()];//转换对应的格子对象

                var go = Instantiate(Resources.Load(string.Format("{0}/{1}", Const.PREFAB_PATH, "Grid"))) as GameObject;
                go.name = string.Format("{0}_{1}_{2}", i, j, int.Parse(Dic_Grid["ID"]));//获取格子对象的ID
                go.transform.SetParent(transform);

                if (objectsDic.ContainsKey(string.Format("{0}-{1}", i, j)))
                {
                    var __objectsDic = objectsDic[string.Format("{0}-{1}", i, j)];
                    if (__objectsDic["ROW"] != null && __objectsDic["COL"] != null)
                    {
                        int __col = int.Parse(__objectsDic["COL"]);
                        int __row = int.Parse(__objectsDic["ROW"]);
                        var start = vec + new Vector3(sprite_size * j, -sprite_size * i, 0);
                        var end = vec + new Vector3(sprite_size * (j + __col - 1), -sprite_size * (i + __row - 1), 0);
                        var pos = (start + end) / 2f;
                        go.transform.localPosition = pos;
                        go.GetComponent<SpriteRenderer>().size = new Vector2(go.GetComponent<SpriteRenderer>().size.x * __col + 0.02f * __col - 0.02f, 0.675f * __row + 0.02f * __row - 0.02f);
                    }
                    else if (__objectsDic["ROW"] != null)
                    {
                        var start = vec.y - sprite_size * i;
                        var end = vec.y - sprite_size * (i + int.Parse(__objectsDic["ROW"]) - 1);
                        var y = (start + end) / 2f;
                        go.transform.localPosition = new Vector3(sprite_size * j + vec.x, y, 0);
                    }
                    else if (__objectsDic["COL"] != null)
                    {
                        var start = vec.x + sprite_size * j;
                        var end = vec.x + sprite_size * (j + int.Parse(__objectsDic["COL"]) - 1);
                        var x = (start + end) / 2f;
                        go.transform.localPosition = new Vector3(x, -sprite_size * i + vec.y, 0);
                    }
                    else
                    {
                        go.transform.localPosition = vec + new Vector3(sprite_size * j, -sprite_size * i, 0);
                    }
                }
                //if (Dic_Grid["ROW"] != null && Dic_Grid["COL"] != null)
                //{
                //    var start = vec + new Vector3(sprite_size * j, -sprite_size * i, 0);
                //    var end = vec + new Vector3(sprite_size * (j + int.Parse(Dic_Grid["COL"]) - 1), -sprite_size * (i + int.Parse(Dic_Grid["ROW"]) - 1), 0);
                //    var pos = (start + end) / 2f;
                //    go.transform.localPosition = pos;
                //}
                //else if (Dic_Grid["ROW"] != null)
                //{
                //    var start = vec.y - sprite_size * i;
                //    var end = vec.y - sprite_size * (i + int.Parse(Dic_Grid["ROW"]) - 1);
                //    var y = (start + end) / 2f;
                //    go.transform.localPosition = new Vector3(sprite_size * j + vec.x, y, 0);
                //}
                //else if (Dic_Grid["COL"] != null)
                //{
                //    var start = vec.x + sprite_size * j;
                //    var end = vec.x + sprite_size * (j + int.Parse(Dic_Grid["COL"]) - 1);
                //    var x = (start + end) / 2f;
                //    go.transform.localPosition = new Vector3(x, -sprite_size * i + vec.y, 0);
                //}
                else
                {
                    go.transform.localPosition = vec + new Vector3(sprite_size * j, -sprite_size * i, 0);
                }

            }
        }

        //Debug.Log(int.Parse((5 / 2).ToString()));
    }

    void Update()
    {

    }
}

到此这篇关于Unity 使用tiledmap解析地图的文章就介绍到这了,更多相关Unity  tiledmap解析地图内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • Unity制作小地图和方向导航

    一.unity方向导航制作 设计要求是方向导航随着鼠标旋转转换方向,效果图如下: 具体的实现方法主要有两个步骤,分别为UI设计和脚本编写.我的设计思路是这个控件分为两层,第一层为东西南北指示层,第二层为图标指示层,这里我的图标采用圆形图标,方向指示这里采用控制图标旋转的方式实现,层级关系如下: 首先创建父节点1,然后在父节点下创建子节点2,3:最后调整好位置. 第二步脚本编写,脚本如下: using UnityEngine; using System.Collections; using Uni

  • 一篇文章教会你用Unity制作网格地图生成组件

    目录 前言 1,创建组建出网格的基本单元 2,编辑网格创建脚本 3,地图生成案例 总结 前言 如果你玩过三国志这种类型的战旗游戏或者模拟城市.部落冲突.海岛奇兵这种模拟经营类的游戏,那么你对网格地图一定不会陌生.在这些游戏中,所有地图场景中的物体都是基于整齐的网格来记录位置等信息.如下图: 如果你还是感知不到什么是网格地图.俄罗斯方块或者贪吃蛇你一定不会陌生,物体的存在是依托于规整的网格地图而存在的. 还是一如既往,本篇文章为零基础小白文,如果你是小萌新,并且对网格地图感兴趣的话,可以学习本片文

  • Unity3D选择本地图片并加载

    本文实例为大家分享了Unity3D选择本地图片并加载的具体代码,供大家参考,具体内容如下 ①找到System.Windows.Forms.dll:在unity的安装目录中找到它,如 E:\ProgramFiles(x86)\Unity\Editor\Data\Mono\lib\mono\2.0 ②设置.NET 2.0集:Untiy默认是.NET 2.0 Subset.在Edit->Project Settings->Player->OtherSettings中修改 ③任意打开一项目,新建

  • Unity 使用tiledmap解析地图的详细过程

    1.先使用tiledmap编辑地图,图层用来刷图块,对象用来定义单个格子的数据 2.为每个图块调属性 3.图块需要单独配置属性的就必须创建对象,并设置值 右键设置属性 4.导出json文件 5.代码如下,详细看相应注释 using SimpleJSON; using System.Collections; using System.Collections.Generic; using UnityEngine; public class tmx : MonoBehaviour { void Sta

  • vue 使用高德地图vue-amap组件过程解析

    这篇文章主要介绍了vue 使用高德地图vue-amap组件过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 首先 npm install -S vue-amap 然后在 main.js import VueAMap from 'vue-amap'; //注意不要和 AMap原始名称覆盖 Vue.use(VueAMap); // 初始化vue-amap VueAMap.initAMapApiLoader({ // 高德的key key: '

  • 浅谈vue-lazyload实现的详细过程

    本文介绍了浅谈vue-lazyload实现的详细过程,分享给大家,也给自己留个笔记 首先 ,在命令行输入npm install vue-lazyload&&cnpm install vue-lazyload 然后,在main.js里引入这个模块. import 'VueLazyload' from 'vue-lazyload' Vue.use(VueLazyload,{ preload:1.3,//预加载的宽高 loading:"img的加载中的显示的图片的路径", e

  • springboot+idea+maven 多模块项目搭建的详细过程(连接数据库进行测试)

    创建之前项目之前 记得改一下 maven  提高下载Pom速度 记得 setting 中要改 maven  改成 阿里云的.具体方法 网上查第一步 搭建parents 项目,为maven项目 ,不为springboot 项目 记得修改groupId 第二步 搭建多个子模块, honor-dao   honor-manager   honor-common记得创建 honor-manager 的时候 要把他的gruopId 改成com.honor.manager 这里爆红的原因是 因为 我做到后面

  • React从插槽、路由、redux的详细过程

    目录 1. React 插槽 2. React 路由 2.1 安装库 2.2 ReactRouter三大组件 2.3 路由其他方法 2.4 重定向组件 2.5 Switch组件 2.6 示例 3. redux 3.1 主要作用 3.2 使用步骤 4. react-redux 4.1 基本概念 内容 清楚React 插槽弄明白React 路由会使用 redux 及 react-redux 1. React 插槽 组建中写入内容,这些内容可以被识别和控制.React需要自己开发支持插槽功能.原理:父

  • vuecli3.0脚手架搭建及不同的打包环境配置vue.config.js的详细过程

    参考文档 https://cli.vuejs.org/zh/ 1.安装 npm install -g @vue/cli 2.检查安装 vue -V 3.创建项目 vue create project_name 出现下图信息 4.上图两种选择方式,第一种是默认的,第二种自己选择配置  这里一般选择第二种自己配置,点击回车键后出现下图信息 5.在上图中选择你需要的模块,上下移动,空格进行确定,下图是测试选择的 6.选好后,敲Enter键,接着选择 7.选择完毕后,一路Enter,到下图 8.模板创建

  • 详解mongoDB主从复制搭建详细过程

    详解mongoDB主从复制搭建详细过程 实验目的搭建mongoDB主从复制 主 192.168.0.4 从 192.168.0.7 mongodb的安装 1: 下载mongodb www.mongodb.org 下载最新的stable版 查看自己服务器 适合哪个种方式下载(wget 不可以的 可以用下面方式下载) wget https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-rhel62-3.0.5.tgz curl -O -L https

  • windows 2008r2+php5.6.28环境搭建详细过程

    安装IIS7 1.打开服务器管理器(开始-计算机-右键-管理-也可以打开),添加角色 直接下一步 勾选Web服务器(IIS),下一步,有个注意事项继续下一步(这里我就不截图了) 勾选ASP.NET会弹出以下窗口添加所需的角色服务,勾选CGI(这里根据个人情况勾选,CGI是必选的,否则PHP不生效的) 然后直接下一步安装即可,需要等待一小会! 此时已安装成功,关闭即可,打开IIS管理器,如下图 将原来的网站删除,添加新网站 网站名称随便起,物理路径即表示你的根路径,我在D盘建立个www文件夹作为根

  • centos 6.9 升级glibc动态库的详细过程

    glibc是gnu发布的libc库,即c运行库,glibc是linux系统中最底层的api,几乎其它任何运行库都会依赖于glibc.glibc除了封装linux操作系统所提供的系统服务外,它本身也提供了许多其它一些必要功能服务的实现.很多linux的基本命令,比如ls,mv,cp, rm, ll,ln等,都得依赖于它,如果操作错误或者升级失败会导致系统命令不能使用,严重的造成系统退出后无法重新进入,所以操作时候需要慎重,升级之前保存好重要资料. 写这篇笔记的目的其实是我在centos 下想要安装

  • Windows10+anacond+GPU+pytorch安装详细过程

    1.查看自己电脑是否匹配GPU版本. 设备管理器查看. 查看官网是否匹配.地址:https://developer.nvidia.com/cuda-gpus  ** 2.进入NVIDIA对电脑版本进行查**看. 如果可以的的话可以自己卸载原来版本,后安装新版本.安装地址https://developer.nvidia.com/cuda-toolkit-archive 接下来,进入NVIDIA安装过程,在这安装过程中,我一开始直接选择的精简安装,但由于VS的原因,导致无法正常安装,于是我换成了自定

随机推荐