+// $Id$
+//
+// SuperTux - A Jump'n Run
+// Copyright (C) 2003 Tobias Glaesser <tobi.web@gmx.de>
+//
+// This program 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 (at your option) any later version.
+//
+// This program 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 this program; if not, write to the Free Software
+// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+
#include "globals.h"
#include "scene.h"
#include "player.h"
#include "special.h"
#include "resources.h"
#include "sprite_manager.h"
+#include "setup.h"
Surface* img_waves[3];
Surface* img_water;
Surface* img_flag[2];
Surface* img_cloud[2][4];
-Surface* img_box_full;
-Surface* img_box_empty;
-Surface* img_red_glow;
+MusicRef herring_song;
+MusicRef level_end_song;
SpriteManager* sprite_manager = 0;
+MusicManager* music_manager = 0;
/* Load graphics/sounds shared between all levels: */
void loadshared()
int i;
sprite_manager = new SpriteManager(datadir + "/supertux.strf");
+ music_manager = new MusicManager();
+ music_manager->enable_music(use_music);
/* Tuxes: */
- smalltux_stand_left = new Surface(datadir + "/images/shared/smalltux-left-6.png", USE_ALPHA);
- smalltux_stand_right = new Surface(datadir + "/images/shared/smalltux-right-6.png", USE_ALPHA);
-
- smalltux_jump_left = new Surface(datadir + "/images/shared/smalltux-jump-left.png", USE_ALPHA);
- smalltux_jump_right = new Surface(datadir + "/images/shared/smalltux-jump-right.png", USE_ALPHA);
-
- tux_right.resize(8);
- tux_right[0] = new Surface(datadir + "/images/shared/smalltux-right-1.png", USE_ALPHA);
- tux_right[1] = new Surface(datadir + "/images/shared/smalltux-right-2.png", USE_ALPHA);
- tux_right[2] = new Surface(datadir + "/images/shared/smalltux-right-3.png", USE_ALPHA);
- tux_right[3] = new Surface(datadir + "/images/shared/smalltux-right-4.png", USE_ALPHA);
- tux_right[4] = new Surface(datadir + "/images/shared/smalltux-right-5.png", USE_ALPHA);
- tux_right[5] = new Surface(datadir + "/images/shared/smalltux-right-6.png", USE_ALPHA);
- tux_right[6] = new Surface(datadir + "/images/shared/smalltux-right-7.png", USE_ALPHA);
- tux_right[7] = new Surface(datadir + "/images/shared/smalltux-right-8.png", USE_ALPHA);
-
- tux_left.resize(8);
- tux_left[0] = new Surface(datadir + "/images/shared/smalltux-left-1.png", USE_ALPHA);
- tux_left[1] = new Surface(datadir + "/images/shared/smalltux-left-2.png", USE_ALPHA);
- tux_left[2] = new Surface(datadir + "/images/shared/smalltux-left-3.png", USE_ALPHA);
- tux_left[3] = new Surface(datadir + "/images/shared/smalltux-left-4.png", USE_ALPHA);
- tux_left[4] = new Surface(datadir + "/images/shared/smalltux-left-5.png", USE_ALPHA);
- tux_left[5] = new Surface(datadir + "/images/shared/smalltux-left-6.png", USE_ALPHA);
- tux_left[6] = new Surface(datadir + "/images/shared/smalltux-left-7.png", USE_ALPHA);
- tux_left[7] = new Surface(datadir + "/images/shared/smalltux-left-8.png", USE_ALPHA);
-
- firetux_right[0] = new Surface(datadir + "/images/shared/firetux-right-0.png", USE_ALPHA);
- firetux_right[1] = new Surface(datadir + "/images/shared/firetux-right-1.png", USE_ALPHA);
- firetux_right[2] = new Surface(datadir + "/images/shared/firetux-right-2.png", USE_ALPHA);
-
- firetux_left[0] = new Surface(datadir + "/images/shared/firetux-left-0.png", USE_ALPHA);
- firetux_left[1] = new Surface(datadir + "/images/shared/firetux-left-1.png", USE_ALPHA);
- firetux_left[2] = new Surface(datadir + "/images/shared/firetux-left-2.png", USE_ALPHA);
-
-
- cape_right[0] = new Surface(datadir + "/images/shared/cape-right-0.png",
- USE_ALPHA);
-
- cape_right[1] = new Surface(datadir + "/images/shared/cape-right-1.png",
- USE_ALPHA);
-
- cape_left[0] = new Surface(datadir + "/images/shared/cape-left-0.png",
- USE_ALPHA);
-
- cape_left[1] = new Surface(datadir + "/images/shared/cape-left-1.png",
- USE_ALPHA);
-
- bigtux_right = sprite_manager->load("largetux-walk-right");
- bigtux_left = sprite_manager->load("largetux-walk-left");
-
- bigtux_left_jump = sprite_manager->load("largetux-jump-left");
- bigtux_right_jump = sprite_manager->load("largetux-jump-right");
-
- bigcape_right[0] = new Surface(datadir + "/images/shared/bigcape-right-0.png",
- USE_ALPHA);
-
- bigcape_right[1] = new Surface(datadir + "/images/shared/bigcape-right-1.png",
- USE_ALPHA);
-
- bigcape_left[0] = new Surface(datadir + "/images/shared/bigcape-left-0.png",
- USE_ALPHA);
-
- bigcape_left[1] = new Surface(datadir + "/images/shared/bigcape-left-1.png",
- USE_ALPHA);
-
- bigfiretux_right[0] = new Surface(datadir + "/images/shared/bigfiretux-right-0.png",
- USE_ALPHA);
-
- bigfiretux_right[1] = new Surface(datadir + "/images/shared/bigfiretux-right-1.png",
- USE_ALPHA);
-
- bigfiretux_right[2] = new Surface(datadir + "/images/shared/bigfiretux-right-2.png",
- USE_ALPHA);
-
- bigfiretux_right_jump = new Surface(datadir + "/images/shared/bigfiretux-right-jump.png", USE_ALPHA);
-
- bigfiretux_left[0] = new Surface(datadir + "/images/shared/bigfiretux-left-0.png",
- USE_ALPHA);
-
- bigfiretux_left[1] = new Surface(datadir + "/images/shared/bigfiretux-left-1.png",
- USE_ALPHA);
-
- bigfiretux_left[2] = new Surface(datadir + "/images/shared/bigfiretux-left-2.png",
- USE_ALPHA);
-
- bigfiretux_left_jump = new Surface(datadir + "/images/shared/bigfiretux-left-jump.png", USE_ALPHA);
-
- bigcape_right[0] = new Surface(datadir + "/images/shared/bigcape-right-0.png",
- USE_ALPHA);
-
- bigcape_right[1] = new Surface(datadir + "/images/shared/bigcape-right-1.png",
- USE_ALPHA);
-
- bigcape_left[0] = new Surface(datadir + "/images/shared/bigcape-left-0.png",
- USE_ALPHA);
-
- bigcape_left[1] = new Surface(datadir + "/images/shared/bigcape-left-1.png",
- USE_ALPHA);
-
-
- ducktux_left = sprite_manager->load("largetux-duck-left");
- ducktux_right = sprite_manager->load("largetux-duck-right");
-
- skidtux_right = new Surface(datadir +
- "/images/shared/skidtux-right.png",
- USE_ALPHA);
-
- skidtux_left = new Surface(datadir +
- "/images/shared/skidtux-left.png",
- USE_ALPHA);
-
- duckfiretux_right = new Surface(datadir +
- "/images/shared/duckfiretux-right.png",
- USE_ALPHA);
-
- duckfiretux_left = new Surface(datadir +
- "/images/shared/duckfiretux-left.png",
- USE_ALPHA);
-
- skidfiretux_right = new Surface(datadir +
- "/images/shared/skidfiretux-right.png",
- USE_ALPHA);
-
- skidfiretux_left = new Surface(datadir +
- "/images/shared/skidfiretux-left.png",
- USE_ALPHA);
-
-
- /* Boxes: */
-
- img_box_full = new Surface(datadir + "/images/shared/box-full.png",
- IGNORE_ALPHA);
- img_box_empty = new Surface(datadir + "/images/shared/box-empty.png",
- IGNORE_ALPHA);
-
+ smalltux_star = sprite_manager->load("smalltux-star");
+ largetux_star = sprite_manager->load("largetux-star");
+ smalltux_gameover = sprite_manager->load("smalltux-gameover");
+
+ smalltux.stand_left = sprite_manager->load("smalltux-stand-left");
+ smalltux.stand_right = sprite_manager->load("smalltux-stand-right");
+ smalltux.walk_left = sprite_manager->load("smalltux-walk-left");
+ smalltux.walk_right = sprite_manager->load("smalltux-walk-right");
+ smalltux.jump_left = sprite_manager->load("smalltux-jump-left");
+ smalltux.jump_right = sprite_manager->load("smalltux-jump-right");
+ smalltux.kick_left = sprite_manager->load("smalltux-kick-left");
+ smalltux.kick_right = sprite_manager->load("smalltux-kick-right");
+ smalltux.skid_left = sprite_manager->load("smalltux-skid-left");
+ smalltux.skid_right = sprite_manager->load("smalltux-skid-right");
+ smalltux.grab_left = sprite_manager->load("smalltux-grab-left");
+ smalltux.grab_right = sprite_manager->load("smalltux-grab-right");
+
+ largetux.stand_left = sprite_manager->load("largetux-stand-left");
+ largetux.stand_right = sprite_manager->load("largetux-stand-right");
+ largetux.walk_left = sprite_manager->load("largetux-walk-left");
+ largetux.walk_right = sprite_manager->load("largetux-walk-right");
+ largetux.jump_left = sprite_manager->load("largetux-jump-left");
+ largetux.jump_right = sprite_manager->load("largetux-jump-right");
+ largetux.kick_left = sprite_manager->load("largetux-kick-left");
+ largetux.kick_right = sprite_manager->load("largetux-kick-right");
+ largetux.skid_right = sprite_manager->load("largetux-skid-right");
+ largetux.skid_left = sprite_manager->load("largetux-skid-left");
+ largetux.grab_left = sprite_manager->load("largetux-grab-left");
+ largetux.grab_right = sprite_manager->load("largetux-grab-right");
+ largetux.duck_left = sprite_manager->load("largetux-duck-left");
+ largetux.duck_right = sprite_manager->load("largetux-duck-right");
+
+ firetux.stand_left = sprite_manager->load("firetux-stand-left");
+ firetux.stand_right = sprite_manager->load("firetux-stand-right");
+ firetux.walk_left = sprite_manager->load("firetux-walk-left");
+ firetux.walk_right = sprite_manager->load("firetux-walk-right");
+ firetux.jump_left = sprite_manager->load("firetux-jump-left");
+ firetux.jump_right = sprite_manager->load("firetux-jump-right");
+ firetux.kick_left = sprite_manager->load("firetux-kick-left");
+ firetux.kick_right = sprite_manager->load("firetux-kick-right");
+ firetux.skid_right = sprite_manager->load("firetux-skid-right");
+ firetux.skid_left = sprite_manager->load("firetux-skid-left");
+ firetux.grab_left = sprite_manager->load("firetux-grab-left");
+ firetux.grab_right = sprite_manager->load("firetux-grab-right");
+ firetux.duck_left = sprite_manager->load("firetux-duck-left");
+ firetux.duck_right = sprite_manager->load("firetux-duck-right");
/* Water: */
-
-
img_water = new Surface(datadir + "/images/shared/water.png", IGNORE_ALPHA);
img_waves[0] = new Surface(datadir + "/images/shared/waves-0.png",
/* Upgrades: */
load_special_gfx();
- /* Weapons: */
- img_red_glow = new Surface(datadir + "/images/shared/red-glow.png",
- USE_ALPHA);
-
/* Distros: */
- img_distro[0] = new Surface(datadir + "/images/shared/distro-0.png",
+ img_distro[0] = new Surface(datadir + "/images/tilesets/coin1.png",
USE_ALPHA);
- img_distro[1] = new Surface(datadir + "/images/shared/distro-1.png",
+ img_distro[1] = new Surface(datadir + "/images/tilesets/coin2.png",
USE_ALPHA);
- img_distro[2] = new Surface(datadir + "/images/shared/distro-2.png",
+ img_distro[2] = new Surface(datadir + "/images/tilesets/coin3.png",
USE_ALPHA);
- img_distro[3] = new Surface(datadir + "/images/shared/distro-3.png",
+ img_distro[3] = new Surface(datadir + "/images/tilesets/coin2.png",
USE_ALPHA);
sounds[i] = load_sound(datadir + soundfilenames[i]);
/* Herring song */
- herring_song = load_song(datadir + "/music/SALCON.MOD");
+ herring_song = music_manager->load_music(datadir + "/music/SALCON.MOD");
+ level_end_song = music_manager->load_music(datadir + "/music/tux-leveldone.mod");
}
/* Free shared data: */
void unloadshared(void)
{
- delete sprite_manager;
-
int i;
free_special_gfx();
-
- for (i = 0; i < 3; i++)
- {
- delete tux_right[i];
- delete tux_left[i];
- }
-
- delete bigtux_right_jump;
- delete bigtux_left_jump;
-
- for (i = 0; i < 2; i++)
- {
- delete cape_right[i];
- delete cape_left[i];
- delete bigcape_right[i];
- delete bigcape_left[i];
- }
-
- delete ducktux_left;
- delete ducktux_right;
-
- delete skidtux_left;
- delete skidtux_right;
-
free_badguy_gfx();
- delete img_box_full;
- delete img_box_empty;
-
delete img_water;
for (i = 0; i < 3; i++)
delete img_waves[i];
delete img_cloud[1][i];
}
+ delete tux_life;
+
for (i = 0; i < NUM_SOUNDS; i++)
free_chunk(sounds[i]);
- /* free the herring song */
- free_music( herring_song );
+ delete sprite_manager;
+ sprite_manager = 0;
+ delete music_manager;
+ music_manager = 0;
}
/* EOF */