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
53 extern texture_type img_bkgd;
56 extern texture_type img_bkgd_tile[2][4];
57 extern texture_type img_solid[4];
58 extern texture_type img_brick[2];
65 std::string song_title;
66 std::string bkgd_image;
67 std::string particle_system;
68 unsigned int* bg_tiles[15]; /* Tiles in the background */
69 unsigned int* ia_tiles[15]; /* Tiles which can interact in the game (solids for example)*/
70 unsigned int* fg_tiles[15]; /* Tiles in the foreground */
78 std::vector<BadGuyData> badguy_data;
80 /** Will the Level structure with default values */
83 /** Cleanup the level struct from allocated tile data and such */
86 /** Load data for this level:
87 Returns -1, if the loading of the level failed. */
88 int load(const char* subset, int level);
90 /** Load data for this level:
91 Returns -1, if the loading of the level failed. */
92 int load(const std::string& filename);
97 void save(const char* subset, int level);
99 /** Edit a piece of the map! */
100 void change(float x, float y, int tm, unsigned int c);
102 /** Resize the level to a new width */
103 void change_size (int new_width);
105 /** Return the id of the tile at position x/y */
106 unsigned int gettileid(float x, float y);
109 void level_load_image(texture_type* ptexture, std::string theme, const char * file, int use_alpha);
110 void level_free_song();
111 void level_free_gfx();
113 #endif /*SUPERTUX_LEVEL_H*/