当前位置:网站首页>Come, come, let you understand how Cocos Creator reads and writes JSON files
Come, come, let you understand how Cocos Creator reads and writes JSON files
2022-08-05 06:42:00 【Boyi creates the game circle】
前言
在游戏开发过程中,Reading configuration files is essential,而使用JSONIt is more common to do configuration files,This article focuses on telling you howCocos CreatorRead and parse in developmentJSONdata files and how to write themJSON文件.
一、JSON简介
1. 什么是JSON
JSON的英文全称是JavaScript Object Notation,即JavaScript对象表示法.
2. JSON的特点
是一种轻量级的文本数据交换格式,类似XML,但是比XML更小、更快、更易解析.使用JavaScript语法来描述数据对象,JSPrograms can generate native ones without a parserJavaScript对象.独立于语言和平台,Most current programming languages are supportedJSON.
3. JSON的语法
JSON语法是JavaScript语法的子集,具有以下规则:
数据在名称/值对中
数据由逗号分隔
大括号保存对象
中括号保存数组
二、如何解析JSON文件
1. 关键原则
Curly brackets represent objects,中括号代表数组;
2. How to read?
Cocos Creator提供了cc.load.loadResto specifically load at resources 目录下的文件,所以提前把JSON文件放到 asserts/resources 目录下即可.先来一个简单的JSON文件,如下:
1. `// box2dDemo.json`
2. `{`
3. `"engine": "Box2D",`
4. `"version": "2.3.1"`
5. `}`
读取/解析代码如下:
1. `cc.loader.loadRes('box2dDemo.json', function(err, object) {`
2. `if(err) {`
3. `console.log(err);`
4. `return;`
5. `}`
6. `// 读取的数据返回在object中,这是一个拥有2个元素的对象`
7. `let engine = object.engine; // engine = box2D`
8. `let ver = object.version; // ver = 2.3.1`
9. `});`
是不是很简单?实际使用的JSONConfiguration is often a bit more complicated than this,So let's give it nowJSONThe file adds some elements,如下:
1. `// box2dDemo.json`
2. `{`
3. `"engine": "Box2D",`
4. `"version": "2.3.1",`
5. `"bodies":`
6. `[`
7. `{`
8. `"name": "root",`
9. `"body":`
10. `{`
11. `"type": "static",`
12. `"gravityScale": 0.2`
13. `}`
14. `},`
15. `{`
16. `"name": "aa1",`
17. `"body":`
18. `{`
19. `"type": "static",`
20. `"gravityScale": 0.2`
21. `}`
22. `}`
23. `],`
24. `"joints":`
25. `[`
26. `{`
27. `"bodyA": "root",`
28. `"bodyB": "aa1",`
29. `"lowerAngle": 0.5,`
30. `"enableLimit": true`
31. `},`
32. `{`
33. `"bodyA": "aa1",`
34. `"bodyB": "aa2",`
35. `"lowerAngle": -0.5,`
36. `"enableLimit": true`
37. `}`
38. `]`
39. `}`
We define a parsing function in our code called readJson,并且把解析出来的JSON数据保存起来,实现代码如下:
1. `readJson: function() {`
2. `this.box2d = {}; // 存储解析出来的JSON数据`
3. `varself= this;`
4. `cc.loader.loadRes('box2dDemo.json', function(err, object) {`
5. `if(err) {`
6. `console.log(err);`
7. `return;`
8. `}`
9. `let engine = object.engine; // engine = box2D`
10. `let ver = object.version; // ver = 2.3.1`
11. `let bodies = object.bodies; // bodies是个数组`
12. `let joints = object.joints; // joints是个数组`
13. `// It needs to be used in advance outside the callbackself代替this`
14. `self.box2d = object; // box2d是整个对象`
15. `// 将循环2次,因为bodies是个拥有2个对象的数组`
16. `for(let x=0; x < bodies.length; x++) {`
17. `let root = bodies[x]; // root是个对象`
18. `let root_name = root.name; // 第1次循环root_name = root`
19. `let type = root.body.type; // type = static`
20. `let gravity = root.body.gravityScale; // gravity = 0.2`
21. `}`
22. `});`
23. `},`
3. Cocos Creator读取JSON文件注意事项
creator读取jsonA hole in the file(Errors that may result from manipulation of text content) 使用creator中的 cc.loader.loadRes( url, cc.RawAsset, ( err, res )=>{ } )After reading the game file, it was found that there was an error when entering the game for the second time.Summarize this question now:For dynamically loaded resources,The second read reads directly from the cache,So if the read is a text data,Modified text data,那么相应的,The modified text data will be read in the next read data.For example, text data is an array[1,2,3],After the first read, the last bit of data is deleted and becomes [1,2],Then the next read will be[1,2].为了不出现这种情况,Data can be serialized and deserialized,Use it after deep copying it.
4. JSONRead generic code examples
1. `cc.loader.load(cc.url.raw('resources/data.json'), function(err,res){`
2. `if(err) {`
3. `cc.log(err);`
4. `}else{`
5. `let list=res;`
6. `cc.log("load:");`
7. `cc.log("list:"+list.name);`
8. `}`
9. `});`
10. `// louadRes()方法,默认路径就是resources`
11. `cc.loader.loadRes('data', function(err,res){`
12. `if(err) {`
13. `cc.log(err);`
14. `}else{`
15. `let list=res;`
16. `cc.log("loadRes:");`
17. `cc.log("list:"+list.sex);`
18. `}`
19. `});`
注意:When using the above code it also reports that the file does not exist orDownload text failed的错,Then check to see if there are two in the resource managerresources文件夹,One of them was newly built recently,Another may have been previously created but deleted,But not completely removed,因为cocos creatorThe resources inside are all uniquely identifieduuid,所以,also have to findE:\Projects\你的项目\library\uuid-to-mtime.json这个文件,Find the previous one insideresources文件uuid,Cut to a text file first,然后保存uuid-to-mtime.json,重启软件,See if you can get in,If not, cut it outuuid复制回去,再重启就可以了.
三、Json文件的写入
1. `// writeToFile()写入数据到文件,存储格式为xml,不是Json格式`
2. `if(cc.sys.isNative) {`
3. `cc.log("Path:"+jsb.fileUtils.getWritablePath()); cc.log( jsb.fileUtils.writeToFile({"new":"value"},jsb.fileUtils.getWritablePath()+'data.json'));`
4. `cc.log("fullPathForFilename:"+jsb.fileUtils.fullPathForFilename("resources/data.json"));`
5. `}`
6. `// writeStringToFile()写入数据到文件,存储格式为json,读取数据用load()方法`
7. `cc.log("writeStringToFile:"+jsb.fileUtils.writeStringToFile('{"a":"b","c":"d"}', jsb.fileUtils.getWritablePath()+'kk.json'));`
8. `cc.log("getValueMapFromFile:"+JSON.stringify(jsb.fileUtils.getValueMapFromFile(jsb.fileUtils.getWritablePath()+"kk.json")));`
`var`
9. `arry=JSON.stringify(jsb.fileUtils.getStringFromFile(jsb.fileUtils.getWritablePath()+"kk.json"));`
10. `cc.log("arry:"+arry);`
11. `cc.loader.load(jsb.fileUtils.getWritablePath()+"kk.json", function(err,res){`
12. `if(err) {`
13. `cc.log(err);`
14. `}else{`
15. `let list=res;`
16. `cc.log("list:"+list.a);`
17. `}`
18. `});`
边栏推荐
- Dry!Teach you to use industrial raspberries pie combining CODESYS configuration EtherCAT master station
- Detailed explanation of ten solutions across domains (summary)
- 教您简单几步实现工业树莓派正确安装RS232转USB驱动
- markdown editor template
- NAT experiment
- input detailed file upload
- User and user group management, file permission management
- DevOps - Understanding Learning
- Q 2020, the latest senior interview Laya soul, do you know?
- 产品学习资料
猜你喜欢
Unity realizes first-person roaming (nanny-level tutorial)
Alibaba Cloud Video on Demand
ALC实验
NAT实验
干货!教您使用工业树莓派结合CODESYS配置EtherCAT主站
Cloud Computing Basics - Study Notes
Network wiring and digital-to-system conversion
transport layer protocol
One-arm routing experiment and three-layer switch experiment
路由器和静态路由的配置
随机推荐
Programmers should understand I/O this way
用户和用户组管理、文件权限管理
Vim tutorial: vimtutor
BIO, NIO, AIO practical study notes (easy to understand theory)
The use of three parameters of ref, out, and Params in Unity3D
单臂路由实验和三层交换机实验
Problems encountered in installing Yolo3 target detection module in Autoware
What is Alibaba Cloud Express Beauty Station?
NAT experiment
What should I do if the SSL certificate prompts that it is expired or invalid?
flink cdc 目前支持Gauss数据库源吗
LeetCode practice and self-comprehension record (1)
Autoware--Beike Tianhui rfans lidar uses the camera & lidar joint calibration file to verify the fusion effect of point cloud images
DevOps process demo (practical record)
初识网页与浏览器
逻辑卷创建
input detailed file upload
Successful indie developers deal with failure & imposters
H5开发调试-Fiddler手机抓包
Into the pre-service, thought they play so flowers