// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
#include "app/globals.h"
+#include "special/sprite_manager.h"
+#include "audio/sound_manager.h"
+#include "app/setup.h"
+#include "gui/button.h"
#include "scene.h"
#include "player.h"
#include "badguy.h"
#include "gameobjs.h"
#include "special.h"
#include "resources.h"
-#include "special/sprite_manager.h"
-#include "audio/sound_manager.h"
-#include "app/setup.h"
#include "door.h"
+#include "badguy_specs.h"
Surface* img_waves[3];
Surface* img_water;
"/sounds/lifeup.wav",
"/sounds/stomp.wav",
"/sounds/kick.wav",
- "/sounds/explosion.wav"
+ "/sounds/explosion.wav",
+ "/sounds/warp.wav",
+ "/sounds/fireworks.wav"
};
+
+Font* gold_text;
+Font* blue_text;
+Font* gray_text;
+Font* yellow_nums;
+Font* white_text;
+Font* white_small_text;
+Font* white_big_text;
+
/* Load graphics/sounds shared between all levels: */
void loadshared()
{
+
+ /* Load global images: */
+ gold_text = new Font(datadir + "/images/fonts/gold.png", Font::TEXT, 16,18);
+ blue_text = new Font(datadir + "/images/fonts/blue.png", Font::TEXT, 16,18,3);
+ white_text = new Font(datadir + "/images/fonts/white.png",
+ Font::TEXT, 16,18);
+ gray_text = new Font(datadir + "/images/fonts/gray.png",
+ Font::TEXT, 16,18);
+ white_small_text = new Font(datadir + "/images/fonts/white-small.png",
+ Font::TEXT, 8,9, 1);
+ white_big_text = new Font(datadir + "/images/fonts/white-big.png",
+ Font::TEXT, 20,22, 3);
+ yellow_nums = new Font(datadir + "/images/fonts/numbers.png",
+ Font::NUM, 32,32);
+
+ Menu::default_font = white_text;
+ Menu::active_font = blue_text;
+ Menu::deactive_font = gray_text;
+ Menu::label_font = white_big_text;
+ Menu::field_font = gold_text;
+
+ Button::info_font = white_small_text;
+
int i;
- sprite_manager = new SpriteManager(datadir + "/supertux.strf");
+ sprite_manager = new SpriteManager(datadir + "/images/supertux.strf");
/* Tuxes: */
smalltux_star = sprite_manager->load("smalltux-star");
- largetux_star = sprite_manager->load("largetux-star");
+ bigtux_star = sprite_manager->load("bigtux-star");
smalltux_gameover = sprite_manager->load("smalltux-gameover");
char img_name[1024];
for (int i = 0; i < GROWING_FRAMES; i++)
- {
- sprintf(img_name, "%s/images/shared/tux-grow-left-%i.png", datadir.c_str(), i+1);
- growingtux_left[i] = new Surface(img_name, false);
-
- sprintf(img_name, "%s/images/shared/tux-grow-right-%i.png", datadir.c_str(), i+1);
- growingtux_right[i] = new Surface(img_name, false);
- }
+ {
+ sprintf(img_name, "%s/images/shared/tux-grow-left-%i.png", datadir.c_str(), i+1);
+ growingtux_left[i] = new Surface(img_name, true);
- 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");
- smalltux.stomp = sprite_manager->load("stomp");
-
- 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");
- largetux.stomp = sprite_manager->load("stomp");
-
- 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");
- firetux.stomp = sprite_manager->load("stomp");
-
- icetux.stand_left = sprite_manager->load("icetux-stand-left");
- icetux.stand_right = sprite_manager->load("icetux-stand-right");
- icetux.walk_left = sprite_manager->load("icetux-walk-left");
- icetux.walk_right = sprite_manager->load("icetux-walk-right");
- icetux.jump_left = sprite_manager->load("icetux-jump-left");
- icetux.jump_right = sprite_manager->load("icetux-jump-right");
- icetux.kick_left = sprite_manager->load("icetux-kick-left");
- icetux.kick_right = sprite_manager->load("icetux-kick-right");
- icetux.skid_right = sprite_manager->load("icetux-skid-right");
- icetux.skid_left = sprite_manager->load("icetux-skid-left");
- icetux.grab_left = sprite_manager->load("icetux-grab-left");
- icetux.grab_right = sprite_manager->load("icetux-grab-right");
- icetux.duck_left = sprite_manager->load("icetux-duck-left");
- icetux.duck_right = sprite_manager->load("icetux-duck-right");
- icetux.stomp = sprite_manager->load("stomp");
+ sprintf(img_name, "%s/images/shared/tux-grow-right-%i.png", datadir.c_str(), i+1);
+ growingtux_right[i] = new Surface(img_name, true);
+ }
+ small_tux = new TuxBodyParts();
+ small_tux->head = NULL;
+ small_tux->body = sprite_manager->load("small-tux-body");
+ small_tux->arms = sprite_manager->load("small-tux-arms");
+ small_tux->feet = NULL;
+
+ big_tux = new TuxBodyParts();
+ big_tux->head = sprite_manager->load("big-tux-head");
+ big_tux->body = sprite_manager->load("big-tux-body");
+ big_tux->arms = sprite_manager->load("big-tux-arms");
+ big_tux->feet = sprite_manager->load("big-tux-feet");
+
+ fire_tux = new TuxBodyParts();
+ fire_tux->head = sprite_manager->load("big-fire-tux-head");
+ fire_tux->body = sprite_manager->load("big-tux-body");
+ fire_tux->arms = sprite_manager->load("big-tux-arms");
+ fire_tux->feet = sprite_manager->load("big-tux-feet");
+
+ ice_tux = new TuxBodyParts();
+ ice_tux->head = sprite_manager->load("big-tux-head");
+ ice_tux->body = sprite_manager->load("big-tux-body");
+ ice_tux->arms = sprite_manager->load("big-tux-arms");
+ ice_tux->feet = sprite_manager->load("big-tux-feet");
+
+ /* Load Bad Guys resources */
+ badguyspecs_manager = new BadGuySpecsManager(datadir + "/badguys.strf");
/* Water: */
img_water = new Surface(datadir + "/images/shared/water.png", false);
img_waves[0] = new Surface(datadir + "/images/shared/waves-0.png",
- true);
+ true);
img_waves[1] = new Surface(datadir + "/images/shared/waves-1.png",
- true);
+ true);
+
img_waves[2] = new Surface(datadir + "/images/shared/waves-2.png",
- true);
+ true);
/* Pole: */
img_pole = new Surface(datadir + "/images/shared/pole.png", true);
img_poletop = new Surface(datadir + "/images/shared/poletop.png",
- true);
+ true);
/* Flag: */
img_flag[0] = new Surface(datadir + "/images/shared/flag-0.png",
- true);
+ true);
img_flag[1] = new Surface(datadir + "/images/shared/flag-1.png",
- true);
+ true);
/* Cloud: */
img_cloud[0][0] = new Surface(datadir + "/images/shared/cloud-00.png",
- true);
+ true);
img_cloud[0][1] = new Surface(datadir + "/images/shared/cloud-01.png",
- true);
+ true);
img_cloud[0][2] = new Surface(datadir + "/images/shared/cloud-02.png",
- true);
+ true);
img_cloud[0][3] = new Surface(datadir + "/images/shared/cloud-03.png",
- true);
+ true);
img_cloud[1][0] = new Surface(datadir + "/images/shared/cloud-10.png",
- true);
+ true);
img_cloud[1][1] = new Surface(datadir + "/images/shared/cloud-11.png",
- true);
+ true);
img_cloud[1][2] = new Surface(datadir + "/images/shared/cloud-12.png",
- true);
+ true);
img_cloud[1][3] = new Surface(datadir + "/images/shared/cloud-13.png",
- true);
-
-
- /* Bad guys: */
- load_badguy_gfx();
+ true);
/* Upgrades: */
load_special_gfx();
door = sprite_manager->load("door");
for (int i = 0; i < DOOR_OPENING_FRAMES; i++)
{
- sprintf(img_name, "%s/images/shared/door-%i.png", datadir.c_str(), i+1);
- door_opening[i] = new Surface(img_name, false);
+ sprintf(img_name, "%s/images/shared/door-%i.png", datadir.c_str(), i+1);
+ door_opening[i] = new Surface(img_name, true);
}
/* Distros: */
img_distro[0] = new Surface(datadir + "/images/tilesets/coin1.png",
- true);
+ true);
img_distro[1] = new Surface(datadir + "/images/tilesets/coin2.png",
- true);
+ true);
img_distro[2] = new Surface(datadir + "/images/tilesets/coin3.png",
- true);
+ true);
img_distro[3] = new Surface(datadir + "/images/tilesets/coin2.png",
- true);
+ true);
/* Tux life: */
Send a mail to me: neoneurone@users.sf.net, if you have another opinion. :)
*/
for (i = 0; i < NUM_SOUNDS; i++)
- SoundManager::get()->add_sound(SoundManager::get()->load_sound(datadir + soundfilenames[i]),i);
+ SoundManager::get
+ ()->add_sound(SoundManager::get
+ ()->load_sound(datadir + soundfilenames[i]),i);
/* Herring song */
- herring_song = SoundManager::get()->load_music(datadir + "/music/SALCON.MOD");
- level_end_song = SoundManager::get()->load_music(datadir + "/music/leveldone.mod");
+ herring_song = SoundManager::get
+ ()->load_music(datadir + "/music/SALCON.MOD");
+ level_end_song = SoundManager::get
+ ()->load_music(datadir + "/music/leveldone.mod");
}
-
/* Free shared data: */
void unloadshared(void)
{
+ /* Free global images: */
+ delete gold_text;
+ delete white_text;
+ delete blue_text;
+ delete gray_text;
+ delete white_small_text;
+ delete white_big_text;
+ delete yellow_nums;
+
int i;
free_special_gfx();
- free_badguy_gfx();
delete img_water;
for (i = 0; i < 3; i++)
delete tux_life;
+ delete small_tux;
+ delete big_tux;
+ delete fire_tux;
+ delete ice_tux;
+
for (int i = 0; i < GROWING_FRAMES; i++)
{
delete growingtux_left[i];