7 // Author: Tobias Glaesser <tobi.web@gmx.de>, (C) 2003
9 // Copyright: See COPYING file that comes with this distribution
13 #ifndef SUPERTUX_LEVEL_H
14 #define SUPERTUX_LEVEL_H
19 #include "lispreader.h"
23 /** This type holds meta-information about a level-subset.
24 It could be extended to handle manipulation of subsets. */
29 static void create(const std::string& subset_name);
30 void load(char *subset);
36 std::string description;
41 void parse(lisp_object_t* cursor);
44 #define LEVEL_NAME_MAX 20
56 texture_type img_bkgd;
60 std::string song_title;
61 std::string bkgd_image;
62 std::string particle_system;
63 unsigned int* bg_tiles[15]; /* Tiles in the background */
64 unsigned int* ia_tiles[15]; /* Tiles which can interact in the game (solids for example)*/
65 unsigned int* fg_tiles[15]; /* Tiles in the foreground */
71 int bkgd_bottom_green;
77 std::vector<BadGuyData> badguy_data;
79 /** Will the Level structure with default values */
82 /** Cleanup the level struct from allocated tile data and such */
85 /** Load data for this level:
86 Returns -1, if the loading of the level failed. */
87 int load(const std::string& subset, int level);
89 /** Load data for this level:
90 Returns -1, if the loading of the level failed. */
91 int load(const std::string& filename);
98 void save(const char* subset, int level);
100 /** Edit a piece of the map! */
101 void change(float x, float y, int tm, unsigned int c);
103 /** Resize the level to a new width */
104 void change_size (int new_width);
106 /** Return the id of the tile at position x/y */
107 unsigned int gettileid(float x, float y);
111 void load_image(texture_type* ptexture, std::string theme, const char * file, int use_alpha);
114 #endif /*SUPERTUX_LEVEL_H*/