cocos2d-android - 1.地图动态加载原理(世界地图的实现)

1.前言

       最近需要使用cocos2d实现一个小程序,但是由于地图太大,导致在load地图的时候栈被撑爆了,所以只能研究一下怎样能够实现地图的动态加载,从而减小内存压力。
       在查了很多的资料后发现,其实实现的思路已经很清晰了,所以重新实现了一遍。

2.原理

1.总思路

       原理上,屏幕只占了地图的一小部分,屏幕所占的位置被刷新,而地图的大部分地方不被刷新,当屏幕移动时,前方的区域新增,后方的区域移除。这种是最理想的一种方式。
cocos2d-android - 1.地图动态加载原理(世界地图的实现)_第1张图片

2.动态刷新地图思路

       在实际情况中,我们需要将地图栅格化了才能方便的实现地图的动态加载,栅格化就是如下的意思。
cocos2d-android - 1.地图动态加载原理(世界地图的实现)_第2张图片
将地图分割成多个小格,这样在通过动态加载小格实现动态加载。
cocos2d-android - 1.地图动态加载原理(世界地图的实现)_第3张图片
                            图3
蓝色的框体为显示的屏幕。在移动过程中,只要刷新被蓝色框覆盖的小格就可以实现地图的部分加载。

3.实现过程

1.无缝加载地图

在我们拿到n块地图后,如何让地图无缝的拼接在一起是第一个问题。

cocos2d-android - 1.地图动态加载原理(世界地图的实现)_第4张图片
通过上图我们可以得出,当我们的地图行列编码为图上所示时,各瓦片地图的坐标为其行列的的值乘以像素的数量。

2.屏幕边缘检测

1.获得屏幕对角点

通过图3可知,我们必须了解到屏幕的4条边各处在什么位置,这样才能了解到屏幕显示的瓦片地图的区域,通过简化,我们需要知道屏幕对角的两个点所处的位置。即图上这两点的位置。
cocos2d-android - 1.地图动态加载原理(世界地图的实现)_第5张图片

2.计算屏幕对角点所处行列
假设屏幕对角坐标如下所示:
cocos2d-android - 1.地图动态加载原理(世界地图的实现)_第6张图片
同过这样的计算能够得到他们所处的行列

raw = y/150;//y坐标除以瓦片的竖向高度取摩
col = x/300;//x坐标除以瓦片的横向高度取摩

aRaw = 30/150;
aCol = 50/300;

bRaw = 280/150;
bCol = 850/300;

A点处在瓦片(0,0)上,B点处在(2,1)上。
由此可再知道如下的结论:黑色边框所处的内部,是我们需要显示的部分,红色部分是我们不需要的。
需要的内容加载到地图上,不需要的内容若还在地图上则去掉,若不在地图上则无需理会。
cocos2d-android - 1.地图动态加载原理(世界地图的实现)_第7张图片

3.地图加载时机

cocos2d-android支持线程刷新部件,所以启动一个线程并且不断的检测屏幕位置,刷新新的瓦片,移除旧的瓦片即可。

你可能感兴趣的:(cocos2d)