Cocos2dx&Lua - UI显示优化之如何解决解析大量json文件

       GUIReader中有个widgetFromJsonFile的方法,此方法是用于解析json文件(cocostudio生成的UI的)并返回该文件的父节点(Widget),然后便于进一步的UI操作(如获得各种子类进行填充数据作显示等)。


       那么这时候问题就来了,当需要在一个页面或一个控件(尤其是翻页、列表等)中,需要加载入大量的节点(均是由单独json解析得到的),这种大量加载将会使手机非常痛苦(一个30K左右的,在加载数量达到50个左右时,就会卡住在2~3秒)。


       所以,这里需要得到优化。

       其实优化的思路蛮简单,首先找到问题:既然时间是花在解析大量json文件中,也就是说,这里的解析的json是与你当前需要显示的数据集合一一对应的,简单来说:造成卡的原因就是你有几个数据就解析几次json(很多人都会这样操作,因为他们把解析后的widget类直接进行数据填充)。这在之后得到优化之后你会觉得这是非常不应该的做法。


       所以,我们很容易得到一个结论:要解除这种解析1个json文件后才能填充数据并进行被添加的绑定操作!


       思路: 只解析当前页面(或控件,尤其是翻页)能显示的最少子节点数量(这在现在看来是必须的,因为同一个子节点只能有1个根节点),然后将解析后的节点(widget)统一放在某一数据结构中(队列或数组等按需自定);(这里要讲解一下:假如某游戏有一个十连抽招募功能,每次招募会在一个页面显示十张卡牌,这里的显示最优化就是这样:在登陆时加载10个卡牌的节点类放在一数据结构中,在每次招募过后,我们需解析接下来显示界面的json(这里不建议将十张静态加入这里,因为这样这个文件会变大,跟之前数据跟UI操作被绑定是一样的),所以这里每次显示都从那数据结构中遍历获取并填充数据加入页面中)。优化过后,举个例子:这里假如一个玩家点十连抽10次,我只是解析了:1个页面的json * 10 + 十张卡牌的json,而不是(1个页面json+十张卡牌json)*10;


       时间得到优化的代价就是付出了一定内存空间,当然,这是绝对值得的。

       

       后续我会写一些实现以帮助大家更好地理清这里的思路。



你可能感兴趣的:(Cocos2d-x,数据结构与算法)