summaryrefslogtreecommitdiff
path: root/src/map.cpp
diff options
context:
space:
mode:
authorEugenio Favalli <elvenprogrammer@gmail.com>2004-09-26 13:08:46 +0000
committerEugenio Favalli <elvenprogrammer@gmail.com>2004-09-26 13:08:46 +0000
commit92bbeab96bf61edf9b7caa125ed67e634258383e (patch)
treea95dd426590c8e6208445290fa8b9b47c1a57bcb /src/map.cpp
parente46b2cdbf205d3d2e17266e3168fdbecd5f53222 (diff)
downloadmana-client-92bbeab96bf61edf9b7caa125ed67e634258383e.tar.gz
mana-client-92bbeab96bf61edf9b7caa125ed67e634258383e.tar.bz2
mana-client-92bbeab96bf61edf9b7caa125ed67e634258383e.tar.xz
mana-client-92bbeab96bf61edf9b7caa125ed67e634258383e.zip
*** empty log message ***
Diffstat (limited to 'src/map.cpp')
-rw-r--r--src/map.cpp120
1 files changed, 120 insertions, 0 deletions
diff --git a/src/map.cpp b/src/map.cpp
new file mode 100644
index 00000000..c8fc3612
--- /dev/null
+++ b/src/map.cpp
@@ -0,0 +1,120 @@
+/**
+
+ The Mana World
+ Copyright 2004 The Mana World Development Team
+
+ This file is part of The Mana World.
+
+ The Mana World is free software; you can redistribute it and/or modify
+ it under the terms of the GNU General Public License as published by
+ the Free Software Foundation; either version 2 of the License, or
+ any later version.
+
+ The Mana World is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU General Public License for more details.
+
+ You should have received a copy of the GNU General Public License
+ along with The Mana World; if not, write to the Free Software
+ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+
+*/
+
+#include "map.h"
+#include "log.h"
+#include "being.h"
+
+#include <stdio.h>
+#ifdef WIN32
+#include <windows.h>
+#else
+#include "./Net/win2linux.h"
+#endif
+
+MAP map;
+
+/** Loads a map file */
+bool load_map(char *map_file) {
+ PACKFILE *file = pack_fopen(map_file, "rp");
+ if(!file) {
+ warning(map_file);
+ return false;
+ }
+ pack_fread(&map, sizeof(MAP), file);
+ pack_fclose(file);
+ return true;
+}
+
+
+/** Set walkability flag for a tile */
+void set_walk(short x_c, short y_c, bool walkable) {
+ if(walkable==true)map.tiles[x_c][y_c].data[3] |= 0x0002;
+ else map.tiles[x_c][y_c].data[3] &= 0x00fd;
+}
+
+/** Tell if a tile is walkable or not */
+bool get_walk(short x_c, short y_c) {
+ bool ret = (map.tiles[x_c][y_c].data[3] & 0x0002)>0;
+ if(ret==true) {
+ NODE *node = get_head();
+ while(node && ret==true) {
+ if(get_x(node->coordinates)==x_c && get_y(node->coordinates)==y_c)
+ ret = false;
+ node = node->next;
+ }
+ return ret;
+ } else return false;
+}
+
+/** Tell if a tile is walkable or not (0=walkable,1=not walkable) */
+unsigned char get_path_walk(unsigned short x, unsigned short y) {
+ if(get_walk(x, y))return 0;
+ else return 1;
+}
+
+/** Tell if a tile is animated or not */
+bool get_anim(short x_c, short y_c, char layer) {
+ char temp = map.tiles[x_c][y_c].flags & 0x00C0;
+ temp>>=6;
+ if(abs(temp)==layer)return (map.tiles[x_c][y_c].data[3] & 0x0001)>0;
+ else return false;
+}
+
+/** Set tile ID */
+void set_tile(short x_c, short y_c, char layer, unsigned short id) {
+ if(layer==0) {
+ id <<= 6;
+ map.tiles[x_c][y_c].data[0] = HIBYTE(id);
+ map.tiles[x_c][y_c].data[1] &= 0x003f;
+ map.tiles[x_c][y_c].data[1] |= LOBYTE(id);
+ } else if(layer==1) {
+ id <<= 4;
+ map.tiles[x_c][y_c].data[1] &= 0x00c0;
+ map.tiles[x_c][y_c].data[1] |= HIBYTE(id);
+ map.tiles[x_c][y_c].data[2] &= 0x000f;
+ map.tiles[x_c][y_c].data[2] |= LOBYTE(id);
+ } else if(layer==2) {
+ id <<= 2;
+ map.tiles[x_c][y_c].data[2] &= 0x00f0;
+ map.tiles[x_c][y_c].data[2] |= HIBYTE(id);
+ map.tiles[x_c][y_c].data[3] &= 0x0003;
+ map.tiles[x_c][y_c].data[3] |= LOBYTE(id);
+ }
+}
+
+/** Return tile ID */
+unsigned short get_tile(short x_c, short y_c, char layer) {
+ unsigned short id;
+ if(layer==0) {
+ id = MAKEWORD(map.tiles[x_c][y_c].data[1] & 0x00c0, map.tiles[x_c][y_c].data[0]);
+ id >>= 6;
+ } else if(layer==1) {
+ id = MAKEWORD(map.tiles[x_c][y_c].data[2] & 0x00f0, map.tiles[x_c][y_c].data[1] & 0x003f);
+ id >>= 4;
+ } else if(layer==2) {
+ id = MAKEWORD(map.tiles[x_c][y_c].data[3] & 0x00fc, map.tiles[x_c][y_c].data[2] & 0x000f);
+ id >>=2;
+ }
+ return id;
+}