libsuperderpy/src/main.h

310 lines
11 KiB
C
Raw Normal View History

2012-02-28 13:09:12 +01:00
/*! \file main.h
* \brief Headers of main file of SuperDerpy engine.
*
* Contains basic functions shared by all views.
*/
2012-03-04 13:32:42 +01:00
/*
* Copyright (c) Sebastian Krzyszkowiak <dos@dosowisko.net>
*
* 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., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
*/
2012-02-16 15:40:58 +01:00
#ifndef MAIN_H
#define MAIN_H
#include <allegro5/allegro.h>
#include <allegro5/allegro_audio.h>
#include <allegro5/allegro_acodec.h>
#include <allegro5/allegro_image.h>
#include <allegro5/allegro_font.h>
#include <allegro5/allegro_ttf.h>
2012-05-09 10:58:45 +02:00
#include "allegro_utils.h"
2012-02-16 15:40:58 +01:00
2012-05-19 18:09:20 +02:00
/*! \brief Declares variables used by displaying progress bar on loading screen.
* Takes number of loading steps as parameter.
*/
#define PROGRESS_INIT(a) float load_p = 0, load_a = a;
2012-05-19 18:09:20 +02:00
/*! \brief Increments progress of loading. */
#define PROGRESS if (progress) (*progress)(game, load_p+=1/load_a);
struct Game;
2012-02-28 13:09:12 +01:00
/*! \brief Enum of all available gamestates. */
2012-02-16 15:40:58 +01:00
enum gamestate_enum {
2012-03-02 16:52:13 +01:00
GAMESTATE_PAUSE,
2012-02-16 15:40:58 +01:00
GAMESTATE_LOADING,
GAMESTATE_MENU,
GAMESTATE_ABOUT,
GAMESTATE_INTRO,
2012-02-21 23:33:02 +01:00
GAMESTATE_MAP,
GAMESTATE_LEVEL
2012-02-16 15:40:58 +01:00
};
/*! \brief Resources used by moonwalk level placeholder. */
struct Moonwalk {
2012-02-28 23:16:55 +01:00
ALLEGRO_BITMAP *fade_bitmap; /*!< Bitmap used on fade-in and fade-out animations. */
ALLEGRO_BITMAP *image; /*!< Background texture. */
int derpy_frame; /*!< Current frame of Derpy animation. */
int derpy_frame_tmp; /*!< Counter used to slow down Derpy animation. */
double derpy_pos; /*!< Position of Derpy on screen. */
2012-02-22 12:43:14 +01:00
};
2012-05-19 18:09:20 +02:00
/*! \brief Structure representing obstacles and power-ups flying through the level. */
2012-05-19 15:31:41 +02:00
struct Obstacle {
2012-05-19 18:09:20 +02:00
ALLEGRO_BITMAP **bitmap; /*!< Pointer to bitmap used by obstacle. */
float x; /*!< Horizontal position on the screen, in range 0-1. */
float y; /*!< Vertical position on the screen, in range 0-1. */
float speed; /*!< Horizontal speed of obstracle. */
int points; /*!< Number of points given when hit by player. Positive gives HP to power, negative takes it. */
bool hit; /*!< Indicates if this obstacle was already hit by the player or not. */
void (*callback)(struct Game*, struct Obstacle*); /*!< Pointer to function called to update obstacle position, animate it, etc. */
void *data; /*!< Pointer passed to callback function. */
struct Obstacle *prev; /*!< Previous obstacle on the list. */
struct Obstacle *next; /*!< Next obstacle on the list. */
};
2012-04-30 22:15:11 +02:00
2012-05-03 19:42:23 +02:00
struct Spritesheet {
2012-05-19 18:09:20 +02:00
char* name; /*!< Readable name of the spritesheet. */
ALLEGRO_BITMAP* bitmap; /*!< Spritesheet bitmap. */
int rows; /*!< Number of rows in the spritesheet. */
int cols; /*!< Number of columns in the spritesheet. */
int blanks; /*!< Number of blank frames at the end of the spritesheet. */
float speed; /*!< Speed modifier of spritesheet animation. */
float aspect; /*!< Aspect ratio of the frame. */
float scale; /*!< Scale modifier of the frame. */
struct Spritesheet* next; /*!< Next spritesheet in the queue. */
2012-05-03 19:42:23 +02:00
};
/*! \brief Resources used by Level state. */
struct Level {
2012-04-30 22:15:11 +02:00
int current_level; /*!< Level number. */
2012-05-19 18:09:20 +02:00
float speed; /*!< Speed of the player. */
float bg_pos; /*!< Position of the background layer of the scene. */
float st_pos; /*!< Position of the stage layer of the scene. */
float fg_pos; /*!< Position of the foreground layer of the scene. */
float cl_pos; /*!< Position of the clouds layer of the scene. */
float derpy_x; /*!< Horizontal position of Derpy (0-1). */
float derpy_y; /*!< Vertical position of Derpy (0-1). */
float hp; /*!< Player health points (0-1). */
bool handle_input; /*!< When false, player looses control over Derpy. */
bool failed; /*!< Indicates if player failed level. */
float meter_alpha; /*!< Alpha level of HP meter. */
int sheet_rows; /*!< Number of rows in current spritesheet. */
int sheet_cols; /*!< Number of cols in current spritesheet. */
int sheet_pos; /*!< Frame position in current spritesheet. */
int sheet_blanks; /*!< Number of blank frames at the end of current spritesheet. */
float sheet_tmp; /*!< Temporary counter used to slow down spritesheet animation. */
float sheet_speed; /*!< Current speed of Derpy animation. */
float sheet_speed_modifier; /*!< Modifier of speed, specified by current spritesheet. */
float sheet_scale; /*!< Scale modifier of current spritesheet. */
2012-04-09 15:25:56 +02:00
ALLEGRO_SAMPLE *sample; /*!< Sample with background music. */
ALLEGRO_SAMPLE_INSTANCE *music; /*!< Sample instance with background music. */
unsigned int music_pos; /*!< Position of sample instance. Used when pausing game. */
2012-05-19 18:09:20 +02:00
ALLEGRO_BITMAP *background; /*!< Bitmap of the background layer of the scene. */
ALLEGRO_BITMAP *stage; /*!< Bitmap of the stage layer of the scene. */
ALLEGRO_BITMAP *foreground; /*!< Bitmap of the foreground layer of the scene. */
ALLEGRO_BITMAP *clouds; /*!< Bitmap of the clouds layer of the scene. */
ALLEGRO_BITMAP *welcome; /*!< Bitmap of the welcome text (for instance "Level 1: Fluttershy"). */
ALLEGRO_BITMAP **derpy_sheet; /*!< Pointer to active Derpy sprite sheet. */
2012-04-08 23:25:14 +02:00
ALLEGRO_BITMAP *derpy; /*!< Derpy sprite. */
2012-05-19 18:09:20 +02:00
ALLEGRO_BITMAP *meter_bmp; /*!< Bitmap of the HP meter. */
ALLEGRO_BITMAP *meter_image; /*!< Derpy image used in the HP meter. */
2012-05-03 19:42:23 +02:00
struct Spritesheet* derpy_sheets; /*!< List of sprite sheets of Derpy character. */
struct Spritesheet* pony_sheets; /*!< List of sprite sheets of character rescued by Derpy. */
2012-05-01 22:52:30 +02:00
struct {
2012-05-19 18:09:20 +02:00
ALLEGRO_BITMAP *pie; /*!< Pie bitmap. */
ALLEGRO_BITMAP *muffin; /*!< Muffin bitmap. */
} obst_bmps; /*!< Obstacle bitmaps. */
struct Obstacle *obstacles; /*!< List of obstacles being currently rendered. */
struct Moonwalk moonwalk; /*!< Moonwalk placeholder data. */
};
2012-03-07 22:06:19 +01:00
/*! \brief Enum of menu states in Menu and Pause game states. */
enum menustate_enum {
MENUSTATE_MAIN,
MENUSTATE_OPTIONS,
MENUSTATE_CONTROLS,
MENUSTATE_VIDEO,
2012-03-13 12:42:28 +01:00
MENUSTATE_PAUSE,
MENUSTATE_AUDIO
2012-03-07 22:06:19 +01:00
};
2012-02-28 13:09:12 +01:00
/*! \brief Resources used by Menu state. */
2012-02-16 15:40:58 +01:00
struct Menu {
2012-02-28 13:09:12 +01:00
ALLEGRO_BITMAP *menu_fade_bitmap;
ALLEGRO_BITMAP *image;
ALLEGRO_BITMAP *cloud;
ALLEGRO_BITMAP *cloud2;
ALLEGRO_BITMAP *pie;
ALLEGRO_BITMAP *pie_bitmap;
ALLEGRO_BITMAP *pinkcloud_bitmap;
ALLEGRO_BITMAP *pinkcloud;
ALLEGRO_BITMAP *rain;
ALLEGRO_BITMAP *rain_bitmap;
2012-02-28 13:09:12 +01:00
ALLEGRO_BITMAP *mountain;
float cloud_position;
float cloud2_position;
2012-02-16 17:05:16 +01:00
int mountain_position;
2012-02-28 13:09:12 +01:00
ALLEGRO_SAMPLE *sample;
ALLEGRO_SAMPLE *rain_sample;
ALLEGRO_SAMPLE *click_sample;
2012-03-05 21:07:42 +01:00
ALLEGRO_SAMPLE_INSTANCE *music; /*!< Sample instance with background music. */
ALLEGRO_SAMPLE_INSTANCE *rain_sound; /*!< Sample instance with rain sound. */
ALLEGRO_SAMPLE_INSTANCE *click; /*!< Sample instance with click sound. */
2012-02-28 13:09:12 +01:00
ALLEGRO_FONT *font_title;
ALLEGRO_FONT *font_subtitle;
ALLEGRO_FONT *font;
ALLEGRO_FONT *font_selected;
int selected;
2012-03-07 22:06:19 +01:00
enum menustate_enum menustate;
bool loaded;
struct {
bool fullscreen;
int fps;
int width;
int height;
} options;
2012-02-16 15:40:58 +01:00
};
2012-02-28 13:09:12 +01:00
/*! \brief Resources used by Loading state. */
2012-02-16 15:40:58 +01:00
struct Loading {
2012-05-19 18:09:20 +02:00
ALLEGRO_BITMAP *loading_bitmap; /*!< Rendered loading bitmap. */
ALLEGRO_BITMAP *image; /*!< Loading background. */
2012-02-16 15:40:58 +01:00
};
2012-03-02 16:52:13 +01:00
/*! \brief Resources used by Pause state. */
struct Pause {
2012-05-19 18:09:20 +02:00
ALLEGRO_BITMAP *bitmap; /*!< Bitmap with screenshot. */
ALLEGRO_BITMAP *derpy; /*!< Derpy on foreground. */
2012-03-02 16:52:13 +01:00
};
2012-02-28 13:09:12 +01:00
/*! \brief Resources used by About state. */
2012-02-18 06:26:58 +01:00
struct About {
2012-05-19 18:09:20 +02:00
ALLEGRO_BITMAP *fade_bitmap; /*!< Bitmap with screenshot, used in fades. */
ALLEGRO_BITMAP *image; /*!< Background bitmap. */
ALLEGRO_BITMAP *text_bitmap; /*!< Bitmap with scrolled text. */
ALLEGRO_BITMAP *letter; /*!< Paper bitmap. */
ALLEGRO_SAMPLE *sample; /*!< Sample with background music. */
2012-03-05 21:07:42 +01:00
ALLEGRO_SAMPLE_INSTANCE *music; /*!< Sample instance with background music. */
2012-05-19 18:09:20 +02:00
ALLEGRO_FONT *font; /*!< Font used in the text on letter. */
float x; /*!< Horizontal position of the text. */
int fadeloop; /*!< Loop counter used in fades. */
2012-02-18 06:26:58 +01:00
};
2012-02-28 13:09:12 +01:00
/*! \brief Resources used by Map state. */
struct Map {
2012-02-28 13:09:12 +01:00
ALLEGRO_BITMAP *map;
ALLEGRO_BITMAP *background;
ALLEGRO_BITMAP *map_bg;
ALLEGRO_BITMAP *highlight;
ALLEGRO_BITMAP *arrow;
int selected;
int available;
2012-05-19 18:09:20 +02:00
float arrowpos; /*!< Vertical position of the arrow. */
2012-02-28 13:09:12 +01:00
ALLEGRO_SAMPLE *sample;
ALLEGRO_SAMPLE *click_sample;
2012-03-05 21:07:42 +01:00
ALLEGRO_SAMPLE_INSTANCE *music; /*!< Sample instance with background music. */
ALLEGRO_SAMPLE_INSTANCE *click; /*!< Sample instance with click sound. */
};
2012-02-28 13:09:12 +01:00
/*! \brief Resources used by Intro state. */
2012-02-18 04:14:35 +01:00
struct Intro {
int position;
2012-02-18 04:14:35 +01:00
int page;
2012-04-04 00:06:47 +02:00
bool in_animation; /*!< Animation as in page transition animation. */
float anim;
2012-02-28 13:09:12 +01:00
ALLEGRO_BITMAP *table;
ALLEGRO_BITMAP *table_bitmap;
2012-05-01 16:55:39 +02:00
ALLEGRO_BITMAP *frame;
2012-04-04 00:06:47 +02:00
ALLEGRO_BITMAP *animsprites[5];
ALLEGRO_FONT *font;
2012-02-19 20:18:28 +01:00
ALLEGRO_SAMPLE *sample;
2012-03-05 21:07:42 +01:00
ALLEGRO_SAMPLE_INSTANCE *music; /*!< Sample instance with background music. */
2012-03-04 22:02:23 +01:00
ALLEGRO_AUDIO_STREAM *audiostream;
2012-02-18 04:14:35 +01:00
};
2012-02-28 13:09:12 +01:00
/*! \brief Resources used by Game state. */
2012-02-16 15:40:58 +01:00
struct Game {
ALLEGRO_DISPLAY *display;
2012-02-28 13:09:12 +01:00
ALLEGRO_FONT *font;
ALLEGRO_FONT *font_console;
2012-02-16 15:40:58 +01:00
enum gamestate_enum gamestate;
enum gamestate_enum loadstate;
ALLEGRO_EVENT_QUEUE *event_queue;
ALLEGRO_TIMER *timer;
2012-02-17 13:25:06 +01:00
ALLEGRO_BITMAP *console;
2012-02-28 13:09:12 +01:00
bool showconsole;
2012-03-13 12:42:28 +01:00
int fx;
int music;
int voice;
2012-02-28 13:09:12 +01:00
bool fullscreen;
bool debug;
int fps;
int width;
int height;
bool shuttingdown;
bool restart;
2012-02-16 15:40:58 +01:00
struct Menu menu;
struct Loading loading;
2012-02-18 04:14:35 +01:00
struct Intro intro;
2012-02-18 06:26:58 +01:00
struct About about;
struct Map map;
2012-02-22 12:43:14 +01:00
struct Level level;
2012-03-02 16:52:13 +01:00
struct Pause pause;
struct {
2012-03-13 12:42:28 +01:00
ALLEGRO_VOICE *v;
2012-03-05 21:07:42 +01:00
ALLEGRO_MIXER *mixer;
ALLEGRO_MIXER *music;
2012-03-13 12:42:28 +01:00
ALLEGRO_MIXER *voice;
ALLEGRO_MIXER *fx;
} audio;
2012-02-16 15:40:58 +01:00
};
2012-02-28 13:09:12 +01:00
/*! \brief Preloads gamestate set in game->loadstate. */
void PreloadGameState(struct Game *game, void (*progress)(struct Game*, float));
2012-02-28 13:09:12 +01:00
/*! \brief Unloads gamestate set in game->gamestate. */
2012-02-16 15:40:58 +01:00
void UnloadGameState(struct Game *game);
2012-02-28 13:09:12 +01:00
/*! \brief Loads gamestate set in game->loadstate. */
2012-02-16 15:40:58 +01:00
void LoadGameState(struct Game *game);
2012-02-28 13:09:12 +01:00
/*! \brief Print some message on game console.
*
* Draws message on console bitmap, so it'll be displayed when calling DrawConsole.
* If game->debug is true, then it also prints given message on stdout.
* It needs to be called in printf style.
*/
void PrintConsole(struct Game *game, char* format, ...);
2012-02-28 13:09:12 +01:00
/*! \brief Draws console bitmap on screen. */
2012-02-17 13:25:06 +01:00
void DrawConsole(struct Game *game);
2012-02-16 15:40:58 +01:00
2012-05-19 18:09:20 +02:00
/*! \brief Loads bitmap into memory and scales it with software linear filtering. */
2012-03-04 15:57:23 +01:00
ALLEGRO_BITMAP* LoadScaledBitmap(char* filename, int width, int height);
2012-05-19 18:09:20 +02:00
/*! \brief Draws console bitmap on screen. */
2012-03-01 10:49:20 +01:00
float tps(struct Game *game, float t);
2012-03-01 00:37:16 +01:00
2012-05-19 18:09:20 +02:00
/*! \brief Draws frame from current gamestate. */
2012-03-02 16:52:13 +01:00
void DrawGameState(struct Game *game);
2012-05-19 18:09:20 +02:00
/*! \brief Load shared resources. */
int Shared_Load(struct Game *game);
2012-05-19 18:09:20 +02:00
/*! \brief Unload shared resources. */
void Shared_Unload(struct Game *game);
2012-02-26 00:47:41 +01:00
#endif