起初看到这个,你的想法是什么,这小子想干嘛呢???
这个要领是在一个多月前做多线程游戏的时候想到的,最初是中南的一位伴侣提出来的。最近的博客总是在“炒剩饭”,一些新学的对象也老是来不及作总结,不外以为这个想法确实不错,所以也才拿出来再与各人探讨一下,说不定尚有更好的要领。
我们所玩的一些场景不动2D的游戏,往往需要构建一些舆图,如泡泡堂,坦克大战等等。
而在舆图构建的时候,我们往往回收的是用一个数组将所需的舆图生存起来,可是做到厥后,需要的舆图多了,生存的效率往往也就偏低了,并且还会淹灭大多的代码去填数组。
在一个记事本中把你想要做的舆图生存起来,看上去也越发直观,简捷。利用IO流举办字节读取是堕落率相对较低的,所以我们的舆图中理论上可以存在256种元素(一个byte占8位)。虽然,我们或者不需要这么多,a-z加上1到9就完全可以满意我们的日常需求了。
最开始的时候,有人问到,既然是OOP,为什么不消工具来生存我们的舆图元素?原因很简朴,我们操纵byte数据的效率要高于操纵工具自己。
好的,闲话不多说,要领如下:
首先,我们需要一个ArrayList来生存数据,有什么用呢?继承看你就知道了
//建设舆图数组来生存数据
ArrayList<Byte> MapList=new ArrayList<Byte>();
查察本栏目
Java代码
/** * 将记事本中的数据读入到数组傍边 * @param mapName 记事本的文件名 * @return 获得的字节数组 */ public int[][] createMap(String mapName){ File file=new File(mapName); //建设舆图数组 int map[][]=null; if(file.exists()){ try{ InputStream in=new FileInputStream(file); //建设与文件沟通巨细的字节数组 byte content[]=new byte[in.available()]; //读取字节数组 in.read(content); //将内容添加到行列傍边 for(int i=0;i<content.length;i++){ MapList.add(content[i]); } //移除回车符 for(int i=0;i<MapList.size();i++){ if(MapList.get(i)==10){ MapList.remove(i); } } //移除换行符 for(int i=0;i<MapList.size();i++){ if(MapList.get(i)==13){ MapList.remove(i); } } //封装字节内容 String string=new String(content); String arr[]=string.split("\r\n"); //存入数组傍边 int index=0; map=new int[arr.length][arr[0].length()]; for(int i=0;i<map.length;i++){ for(int j=0;j<map[i].length;j++{ map[i][j]=MapList.get(index)-48; index++; } } in.close(); }catch(Exception e){ e.printStackTrace(); } }else{ System.out.println("文件不存在"); } return map; }
较量要害的步调是移除回车换行字符,这两个字符是我们看不到的,只有在打印的时候才会发明他们,
莫名其妙的多出个10跟13,起初我也是以为烦闷,任何要领虽然都要测试一下,本身做个记事当舆图试一下吧。