diff options
-rw-r--r-- | src/components/map_collision.cpp | 2 | ||||
-rw-r--r-- | src/components/map_render.cpp | 2 | ||||
-rw-r--r-- | src/game.h | 2 | ||||
-rw-r--r-- | src/map.cpp | 8 | ||||
-rw-r--r-- | tools/mapedit/CMakeLists.txt | 45 | ||||
-rw-r--r-- | tools/mapedit/src/main.cpp | 54 | ||||
-rw-r--r-- | tools/mapedit/src/map.cpp | 94 | ||||
-rw-r--r-- | tools/mapedit/src/map.h | 44 |
8 files changed, 244 insertions, 7 deletions
diff --git a/src/components/map_collision.cpp b/src/components/map_collision.cpp index f385320..9afa6f8 100644 --- a/src/components/map_collision.cpp +++ b/src/components/map_collision.cpp | |||
@@ -7,7 +7,7 @@ MapCollisionComponent::MapCollisionComponent(const Map& map) : map(map) | |||
7 | addCollision(-6, 0, GAME_WIDTH, Direction::left, (map.getLeftMap() == nullptr) ? Collision::Type::wrap : Collision::Type::teleport); | 7 | addCollision(-6, 0, GAME_WIDTH, Direction::left, (map.getLeftMap() == nullptr) ? Collision::Type::wrap : Collision::Type::teleport); |
8 | addCollision(GAME_WIDTH+6, 0, GAME_WIDTH, Direction::right, (map.getRightMap() == nullptr) ? Collision::Type::reverse : Collision::Type::teleport); | 8 | addCollision(GAME_WIDTH+6, 0, GAME_WIDTH, Direction::right, (map.getRightMap() == nullptr) ? Collision::Type::reverse : Collision::Type::teleport); |
9 | 9 | ||
10 | for (int i=0; i<MAP_WIDTH*(MAP_HEIGHT-1); i++) | 10 | for (int i=0; i<MAP_WIDTH*MAP_HEIGHT; i++) |
11 | { | 11 | { |
12 | int x = i % MAP_WIDTH; | 12 | int x = i % MAP_WIDTH; |
13 | int y = i / MAP_WIDTH; | 13 | int y = i / MAP_WIDTH; |
diff --git a/src/components/map_render.cpp b/src/components/map_render.cpp index d93afe6..6fdfcc3 100644 --- a/src/components/map_render.cpp +++ b/src/components/map_render.cpp | |||
@@ -8,7 +8,7 @@ MapRenderComponent::MapRenderComponent(const Map& map) : screen(GAME_WIDTH, GAME | |||
8 | 8 | ||
9 | Texture tiles("../res/tiles.png"); | 9 | Texture tiles("../res/tiles.png"); |
10 | 10 | ||
11 | for (int i=0; i<MAP_WIDTH*(MAP_HEIGHT-1); i++) | 11 | for (int i=0; i<MAP_WIDTH*MAP_HEIGHT; i++) |
12 | { | 12 | { |
13 | int tile = map.getMapdata()[i]; | 13 | int tile = map.getMapdata()[i]; |
14 | int x = i % MAP_WIDTH; | 14 | int x = i % MAP_WIDTH; |
diff --git a/src/game.h b/src/game.h index a4620d4..1818cec 100644 --- a/src/game.h +++ b/src/game.h | |||
@@ -14,7 +14,7 @@ const int TILE_HEIGHT = 8; | |||
14 | const int GAME_WIDTH = 320; | 14 | const int GAME_WIDTH = 320; |
15 | const int GAME_HEIGHT = 200; | 15 | const int GAME_HEIGHT = 200; |
16 | const int MAP_WIDTH = GAME_WIDTH/TILE_WIDTH; | 16 | const int MAP_WIDTH = GAME_WIDTH/TILE_WIDTH; |
17 | const int MAP_HEIGHT = GAME_HEIGHT/TILE_HEIGHT; | 17 | const int MAP_HEIGHT = GAME_HEIGHT/TILE_HEIGHT - 1; |
18 | 18 | ||
19 | const int FRAMES_PER_SECOND = 60; | 19 | const int FRAMES_PER_SECOND = 60; |
20 | const double SECONDS_PER_FRAME = 1.0 / FRAMES_PER_SECOND; | 20 | const double SECONDS_PER_FRAME = 1.0 / FRAMES_PER_SECOND; |
diff --git a/src/map.cpp b/src/map.cpp index 73eb2b4..6b83442 100644 --- a/src/map.cpp +++ b/src/map.cpp | |||
@@ -50,9 +50,9 @@ Map::Map(const std::string name) | |||
50 | } else if (!xmlStrcmp(node->name, (const xmlChar*) "environment")) | 50 | } else if (!xmlStrcmp(node->name, (const xmlChar*) "environment")) |
51 | { | 51 | { |
52 | xmlChar* key = xmlNodeListGetString(doc, node->xmlChildrenNode, 1); | 52 | xmlChar* key = xmlNodeListGetString(doc, node->xmlChildrenNode, 1); |
53 | mapdata = (int*) malloc(MAP_WIDTH*(MAP_HEIGHT-1)*sizeof(int)); | 53 | mapdata = (int*) malloc(MAP_WIDTH*MAP_HEIGHT*sizeof(int)); |
54 | mapdata[0] = atoi(strtok((char*) key, ",\n")); | 54 | mapdata[0] = atoi(strtok((char*) key, ",\n")); |
55 | for (int i=1; i<(MAP_WIDTH*(MAP_HEIGHT-1)); i++) | 55 | for (int i=1; i<(MAP_WIDTH*MAP_HEIGHT); i++) |
56 | { | 56 | { |
57 | mapdata[i] = atoi(strtok(NULL, ",\n")); | 57 | mapdata[i] = atoi(strtok(NULL, ",\n")); |
58 | } | 58 | } |
@@ -100,8 +100,8 @@ Map::Map(const std::string name) | |||
100 | 100 | ||
101 | Map::Map(const Map& map) | 101 | Map::Map(const Map& map) |
102 | { | 102 | { |
103 | mapdata = (int*) malloc(MAP_WIDTH*(MAP_HEIGHT-1)*sizeof(int)); | 103 | mapdata = (int*) malloc(MAP_WIDTH*MAP_HEIGHT*sizeof(int)); |
104 | memcpy(mapdata, map.mapdata, MAP_WIDTH*(MAP_HEIGHT-1)*sizeof(int)); | 104 | memcpy(mapdata, map.mapdata, MAP_WIDTH*MAP_HEIGHT*sizeof(int)); |
105 | 105 | ||
106 | title = (char*) malloc((MAP_WIDTH+1)*sizeof(char)); | 106 | title = (char*) malloc((MAP_WIDTH+1)*sizeof(char)); |
107 | strncpy(title, map.title, MAP_WIDTH+1); | 107 | strncpy(title, map.title, MAP_WIDTH+1); |
diff --git a/tools/mapedit/CMakeLists.txt b/tools/mapedit/CMakeLists.txt new file mode 100644 index 0000000..9a024c8 --- /dev/null +++ b/tools/mapedit/CMakeLists.txt | |||
@@ -0,0 +1,45 @@ | |||
1 | cmake_minimum_required(VERSION 2.6) | ||
2 | project(AromatherapyMapEditor) | ||
3 | |||
4 | set(CMAKE_MODULE_PATH ${CMAKE_MODULE_PATH} "${AromatherapyMapEditor_SOURCE_DIR}/cmake") | ||
5 | # Set an output directory for our binaries | ||
6 | set(BIN_DIR ${AromatherapyMapEditor_SOURCE_DIR}/bin) | ||
7 | |||
8 | # Bump up warning levels appropriately for clang, gcc & msvc | ||
9 | # Also set debug/optimization flags depending on the build type. IDE users choose this when | ||
10 | # selecting the build mode in their IDE | ||
11 | if (${CMAKE_CXX_COMPILER_ID} STREQUAL "GNU" OR ${CMAKE_CXX_COMPILER_ID} STREQUAL "Clang") | ||
12 | set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wall -Wextra -pedantic -std=c++11") | ||
13 | set(CMAKE_CXX_FLAGS_DEBUG "${CMAKE_CXX_FLAGS} ${CMAKE_CXX_FLAGS_DEBUG} -g") | ||
14 | set(CMAKE_CXX_FLAGS_RELEASE "${CMAKE_CXX_FLAGS} ${CMAKE_CXX_FLAGS_RELEASE} -O2") | ||
15 | elseif (${CMAKE_CXX_COMPILER_ID} STREQUAL "MSVC") | ||
16 | if (CMAKE_CXX_FLAGS MATCHES "/W[0-4]") | ||
17 | string(REGEX REPLACE "/W[0-4]" "/W4" CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS}") | ||
18 | else() | ||
19 | set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} /W4") | ||
20 | endif() | ||
21 | endif() | ||
22 | |||
23 | # Look up SDL2 and add the include directory to our include path | ||
24 | find_package(wxWidgets REQUIRED core base) | ||
25 | include(${wxWidgets_USE_FILE}) | ||
26 | |||
27 | find_package(libxml2 REQUIRED) | ||
28 | |||
29 | set(ALL_LIBS | ||
30 | ${wxWidgets_LIBRARIES} | ||
31 | ${LIBXML2_LIBRARIES} | ||
32 | ) | ||
33 | |||
34 | include_directories( | ||
35 | ${LIBXML2_INCLUDE_DIR} | ||
36 | src | ||
37 | ) | ||
38 | |||
39 | set(CMAKE_BUILD_TYPE Debug) | ||
40 | add_executable(AromatherapyMapEditor | ||
41 | src/main.cpp | ||
42 | src/map.cpp | ||
43 | ) | ||
44 | target_link_libraries(AromatherapyMapEditor ${ALL_LIBS}) | ||
45 | install(TARGETS AromatherapyMapEditor RUNTIME DESTINATION ${BIN_DIR}) | ||
diff --git a/tools/mapedit/src/main.cpp b/tools/mapedit/src/main.cpp new file mode 100644 index 0000000..09be151 --- /dev/null +++ b/tools/mapedit/src/main.cpp | |||
@@ -0,0 +1,54 @@ | |||
1 | #include <wx/wxprec.h> | ||
2 | |||
3 | #ifndef WX_PRECOMP | ||
4 | #include <wx/wx.h> | ||
5 | #endif | ||
6 | |||
7 | #include "map.h" | ||
8 | |||
9 | class MapeditApp : public wxApp { | ||
10 | public: | ||
11 | virtual bool OnInit(); | ||
12 | }; | ||
13 | |||
14 | class MapeditFrame : public wxFrame { | ||
15 | public: | ||
16 | MapeditFrame() : MapeditFrame(Map()) {} | ||
17 | MapeditFrame(Map map); | ||
18 | |||
19 | private: | ||
20 | void OnExit(wxCommandEvent& event); | ||
21 | |||
22 | Map map; | ||
23 | |||
24 | wxDECLARE_EVENT_TABLE(); | ||
25 | }; | ||
26 | |||
27 | wxBEGIN_EVENT_TABLE(MapeditFrame, wxFrame) | ||
28 | EVT_MENU(wxID_EXIT, MapeditFrame::OnExit) | ||
29 | wxEND_EVENT_TABLE() | ||
30 | |||
31 | wxIMPLEMENT_APP(MapeditApp); | ||
32 | |||
33 | bool MapeditApp::OnInit() | ||
34 | { | ||
35 | MapeditFrame* frame = new MapeditFrame(); | ||
36 | frame->Show(true); | ||
37 | return true; | ||
38 | } | ||
39 | |||
40 | MapeditFrame::MapeditFrame(Map map) : wxFrame(NULL, wxID_ANY, "Map Editor", wxPoint(50, 50), wxSize(450, 340)), map(map) | ||
41 | { | ||
42 | wxMenu* menuFile = new wxMenu; | ||
43 | menuFile->Append(wxID_EXIT); | ||
44 | |||
45 | wxMenuBar* menuBar = new wxMenuBar; | ||
46 | menuBar->Append(menuFile, "&File"); | ||
47 | |||
48 | SetMenuBar(menuBar); | ||
49 | } | ||
50 | |||
51 | void MapeditFrame::OnExit(wxCommandEvent& event) | ||
52 | { | ||
53 | Close(true); | ||
54 | } | ||
diff --git a/tools/mapedit/src/map.cpp b/tools/mapedit/src/map.cpp new file mode 100644 index 0000000..52a2096 --- /dev/null +++ b/tools/mapedit/src/map.cpp | |||
@@ -0,0 +1,94 @@ | |||
1 | #include "map.h" | ||
2 | #include <libxml/parser.h> | ||
3 | |||
4 | Map::Map() | ||
5 | { | ||
6 | mapdata = (int*) calloc(MAP_WIDTH * MAP_HEIGHT, sizeof(int)); | ||
7 | } | ||
8 | |||
9 | Map::Map(const std::string filename) | ||
10 | { | ||
11 | xmlDocPtr doc = xmlParseFile(filename.c_str()); | ||
12 | if (doc == nullptr) | ||
13 | { | ||
14 | throw MapLoadException(filename); | ||
15 | } | ||
16 | |||
17 | xmlNodePtr top = xmlDocGetRootElement(doc); | ||
18 | if (top == nullptr) | ||
19 | { | ||
20 | throw MapLoadException(filename); | ||
21 | } | ||
22 | |||
23 | if (xmlStrcmp(top->name, (const xmlChar*) "map-def")) | ||
24 | { | ||
25 | throw MapLoadException(filename); | ||
26 | } | ||
27 | |||
28 | for (xmlNodePtr node = top->xmlChildrenNode; node != NULL; node = node->next) | ||
29 | { | ||
30 | if (!xmlStrcmp(node->name, (const xmlChar*) "name")) | ||
31 | { | ||
32 | xmlChar* key = xmlNodeListGetString(doc, node->xmlChildrenNode, 1); | ||
33 | title = (char*) key; | ||
34 | xmlFree(key); | ||
35 | } else if (!xmlStrcmp(node->name, (const xmlChar*) "environment")) | ||
36 | { | ||
37 | xmlChar* key = xmlNodeListGetString(doc, node->xmlChildrenNode, 1); | ||
38 | mapdata = (int*) malloc(MAP_WIDTH*MAP_HEIGHT*sizeof(int)); | ||
39 | mapdata[0] = atoi(strtok((char*) key, ",\n")); | ||
40 | for (int i=1; i<(MAP_WIDTH*MAP_HEIGHT); i++) | ||
41 | { | ||
42 | mapdata[i] = atoi(strtok(NULL, ",\n")); | ||
43 | } | ||
44 | xmlFree(key); | ||
45 | } else if (!xmlStrcmp(node->name, (const xmlChar*) "leftmap")) | ||
46 | { | ||
47 | xmlChar* key = xmlNodeListGetString(doc, node->xmlChildrenNode, 1); | ||
48 | leftmap = (char*) key; | ||
49 | xmlFree(key); | ||
50 | } else if (!xmlStrcmp(node->name, (const xmlChar*) "rightmap")) | ||
51 | { | ||
52 | xmlChar* key = xmlNodeListGetString(doc, node->xmlChildrenNode, 1); | ||
53 | rightmap = (char*) key; | ||
54 | xmlFree(key); | ||
55 | } | ||
56 | } | ||
57 | |||
58 | xmlFreeDoc(doc); | ||
59 | } | ||
60 | |||
61 | Map::Map(const Map& map) | ||
62 | { | ||
63 | mapdata = (int*) malloc(MAP_WIDTH*MAP_HEIGHT*sizeof(int)); | ||
64 | memcpy(mapdata, map.mapdata, MAP_WIDTH*MAP_HEIGHT*sizeof(int)); | ||
65 | |||
66 | title = map.title; | ||
67 | leftmap = map.leftmap; | ||
68 | rightmap = map.rightmap; | ||
69 | } | ||
70 | |||
71 | Map::Map(Map&& map) : Map() | ||
72 | { | ||
73 | swap(*this, map); | ||
74 | } | ||
75 | |||
76 | Map::~Map() | ||
77 | { | ||
78 | free(mapdata); | ||
79 | } | ||
80 | |||
81 | Map& Map::operator= (Map map) | ||
82 | { | ||
83 | swap(*this, map); | ||
84 | |||
85 | return *this; | ||
86 | } | ||
87 | |||
88 | void swap(Map& first, Map& second) | ||
89 | { | ||
90 | std::swap(first.mapdata, second.mapdata); | ||
91 | std::swap(first.title, second.title); | ||
92 | std::swap(first.leftmap, second.leftmap); | ||
93 | std::swap(first.rightmap, second.rightmap); | ||
94 | } \ No newline at end of file | ||
diff --git a/tools/mapedit/src/map.h b/tools/mapedit/src/map.h new file mode 100644 index 0000000..83244f3 --- /dev/null +++ b/tools/mapedit/src/map.h | |||
@@ -0,0 +1,44 @@ | |||
1 | #ifndef MAP_H | ||
2 | #define MAP_H | ||
3 | |||
4 | #include <string> | ||
5 | #include <exception> | ||
6 | |||
7 | const int TILE_WIDTH = 8; | ||
8 | const int TILE_HEIGHT = 8; | ||
9 | const int GAME_WIDTH = 320; | ||
10 | const int GAME_HEIGHT = 200; | ||
11 | const int MAP_WIDTH = GAME_WIDTH/TILE_WIDTH; | ||
12 | const int MAP_HEIGHT = GAME_HEIGHT/TILE_HEIGHT - 1; | ||
13 | |||
14 | class MapLoadException: public std::exception | ||
15 | { | ||
16 | public: | ||
17 | MapLoadException(std::string mapname) : mapname(mapname) {} | ||
18 | |||
19 | virtual const char* what() const throw() | ||
20 | { | ||
21 | return ("An error occured loading map " + mapname).c_str(); | ||
22 | } | ||
23 | |||
24 | private: | ||
25 | std::string mapname; | ||
26 | }; | ||
27 | |||
28 | class Map { | ||
29 | public: | ||
30 | Map(); | ||
31 | Map(const std::string name); | ||
32 | Map(const Map& map); | ||
33 | Map(Map&& map); | ||
34 | ~Map(); | ||
35 | Map& operator= (Map other); | ||
36 | friend void swap(Map& first, Map& second); | ||
37 | |||
38 | int* mapdata; | ||
39 | std::string title; | ||
40 | std::string leftmap; | ||
41 | std::string rightmap; | ||
42 | }; | ||
43 | |||
44 | #endif | ||