- added new extro background
[supertux.git] / src / resources.cpp
index ed01dc6..64a60cf 100644 (file)
@@ -1,3 +1,22 @@
+//  $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"
@@ -6,6 +25,7 @@
 #include "special.h"
 #include "resources.h"
 #include "sprite_manager.h"
+#include "setup.h"
 
 Surface* img_waves[3]; 
 Surface* img_water;
@@ -14,11 +34,12 @@ Surface* img_poletop;
 Surface* img_flag[2];
 Surface* img_cloud[2][4];
 
-Surface* img_box_full;
-Surface* img_box_empty;
 Surface* img_red_glow;
 
+MusicRef herring_song;
+
 SpriteManager* sprite_manager = 0;
+MusicManager* music_manager = 0;
 
 /* Load graphics/sounds shared between all levels: */
 void loadshared()
@@ -26,168 +47,58 @@ 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[0] = new Surface(datadir + "/images/shared/bigtux-right-0.png",
-               USE_ALPHA);
-
-  bigtux_right[1] = new Surface(datadir + "/images/shared/bigtux-right-1.png",
-               USE_ALPHA);
-
-  bigtux_right[2] = new Surface(datadir + "/images/shared/bigtux-right-2.png",
-               USE_ALPHA);
-
-  bigtux_right_jump = new Surface(datadir + "/images/shared/bigtux-right-jump.png", USE_ALPHA);
-
-  bigtux_left[0] = new Surface(datadir + "/images/shared/bigtux-left-0.png",
-               USE_ALPHA);
-
-  bigtux_left[1] = new Surface(datadir + "/images/shared/bigtux-left-1.png",
-               USE_ALPHA);
-
-  bigtux_left[2] = new Surface(datadir + "/images/shared/bigtux-left-2.png",
-               USE_ALPHA);
-
-  bigtux_left_jump = new Surface(datadir + "/images/shared/bigtux-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);
-
-  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_right = new Surface(datadir +
-               "/images/shared/ducktux-right.png",
-               USE_ALPHA);
-
-  ducktux_left = new Surface(datadir +
-               "/images/shared/ducktux-left.png",
-               USE_ALPHA);
-
-  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",
@@ -254,16 +165,16 @@ void loadshared()
                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);
 
 
@@ -285,49 +196,18 @@ void loadshared()
     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");
 }
 
 
 /* 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[i];
-      delete bigtux_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];
@@ -338,6 +218,7 @@ void unloadshared(void)
   for (i = 0; i < 2; i++)
     delete img_flag[i];
 
+  delete img_red_glow;
   for (i = 0; i < 4; i++)
     {
       delete img_distro[i];
@@ -345,11 +226,15 @@ void unloadshared(void)
       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 */