mirror of
https://gitlab.com/dosowisko.net/libsuperderpy.git
synced 2025-01-07 15:38:01 +01:00
import Tickle Monster codebase
This commit is contained in:
parent
46827594b4
commit
2e79fe8f7b
13 changed files with 1138 additions and 1152 deletions
|
@ -27,24 +27,24 @@ if(MINGW)
|
||||||
set(LINK_FLAGS -Wl,-subsystem,windows)
|
set(LINK_FLAGS -Wl,-subsystem,windows)
|
||||||
endif(MINGW)
|
endif(MINGW)
|
||||||
|
|
||||||
SET(CMAKE_INSTALL_RPATH "\$ORIGIN/../lib/radioedit:\$ORIGIN/gamestates:\$ORIGIN:\$ORIGIN/../lib:\$ORIGIN/lib:\$ORIGIN/bin")
|
SET(CMAKE_INSTALL_RPATH "\$ORIGIN/../lib/ticklemonster:\$ORIGIN/gamestates:\$ORIGIN:\$ORIGIN/../lib:\$ORIGIN/lib:\$ORIGIN/bin")
|
||||||
|
|
||||||
if(APPLE)
|
if(APPLE)
|
||||||
set(EXECUTABLE "RadioEdit")
|
set(EXECUTABLE "TickleMonster")
|
||||||
else(APPLE)
|
else(APPLE)
|
||||||
set(EXECUTABLE "radioedit")
|
set(EXECUTABLE "ticklemonster")
|
||||||
endif(APPLE)
|
endif(APPLE)
|
||||||
|
|
||||||
add_library("libsuperderpy-radioedit" SHARED ${SRC_LIST})
|
add_library("libsuperderpy-ticklemonster" SHARED ${SRC_LIST})
|
||||||
add_executable(${EXECUTABLE} WIN32 MACOSX_BUNDLE ${EXECUTABLE_SRC_LIST})
|
add_executable(${EXECUTABLE} WIN32 MACOSX_BUNDLE ${EXECUTABLE_SRC_LIST})
|
||||||
|
|
||||||
SET_TARGET_PROPERTIES("libsuperderpy-radioedit" PROPERTIES PREFIX "")
|
SET_TARGET_PROPERTIES("libsuperderpy-ticklemonster" PROPERTIES PREFIX "")
|
||||||
|
|
||||||
include_directories(${ALLEGRO5_INCLUDE_DIR} ${ALLEGRO5_FONT_INCLUDE_DIR} ${ALLEGRO5_TTF_INCLUDE_DIR} ${ALLEGRO5_PRIMITIVES_INCLUDE_DIR} ${ALLEGRO5_AUDIO_INCLUDE_DIR} ${ALLEGRO5_ACODEC_INCLUDE_DIR} ${ALLEGRO5_IMAGE_INCLUDE_DIR})
|
include_directories(${ALLEGRO5_INCLUDE_DIR} ${ALLEGRO5_FONT_INCLUDE_DIR} ${ALLEGRO5_TTF_INCLUDE_DIR} ${ALLEGRO5_PRIMITIVES_INCLUDE_DIR} ${ALLEGRO5_AUDIO_INCLUDE_DIR} ${ALLEGRO5_ACODEC_INCLUDE_DIR} ${ALLEGRO5_IMAGE_INCLUDE_DIR})
|
||||||
|
|
||||||
target_link_libraries(${EXECUTABLE} ${ALLEGRO5_LIBRARIES} ${ALLEGRO5_FONT_LIBRARIES} ${ALLEGRO5_TTF_LIBRARIES} ${ALLEGRO5_PRIMITIVES_LIBRARIES} ${ALLEGRO5_AUDIO_LIBRARIES} ${ALLEGRO5_ACODEC_LIBRARIES} ${ALLEGRO5_IMAGE_LIBRARIES} ${ALLEGRO5_MAIN_LIBRARIES} m dl libsuperderpy-radioedit)
|
target_link_libraries(${EXECUTABLE} ${ALLEGRO5_LIBRARIES} ${ALLEGRO5_FONT_LIBRARIES} ${ALLEGRO5_TTF_LIBRARIES} ${ALLEGRO5_PRIMITIVES_LIBRARIES} ${ALLEGRO5_AUDIO_LIBRARIES} ${ALLEGRO5_ACODEC_LIBRARIES} ${ALLEGRO5_IMAGE_LIBRARIES} ${ALLEGRO5_MAIN_LIBRARIES} m dl libsuperderpy-ticklemonster)
|
||||||
|
|
||||||
target_link_libraries("libsuperderpy-radioedit" ${ALLEGRO5_LIBRARIES} ${ALLEGRO5_FONT_LIBRARIES} ${ALLEGRO5_TTF_LIBRARIES} ${ALLEGRO5_PRIMITIVES_LIBRARIES} ${ALLEGRO5_AUDIO_LIBRARIES} ${ALLEGRO5_ACODEC_LIBRARIES} ${ALLEGRO5_IMAGE_LIBRARIES} ${ALLEGRO5_MAIN_LIBRARIES} m)
|
target_link_libraries("libsuperderpy-ticklemonster" ${ALLEGRO5_LIBRARIES} ${ALLEGRO5_FONT_LIBRARIES} ${ALLEGRO5_TTF_LIBRARIES} ${ALLEGRO5_PRIMITIVES_LIBRARIES} ${ALLEGRO5_AUDIO_LIBRARIES} ${ALLEGRO5_ACODEC_LIBRARIES} ${ALLEGRO5_IMAGE_LIBRARIES} ${ALLEGRO5_MAIN_LIBRARIES} m)
|
||||||
|
|
||||||
if(ALLEGRO5_MAIN_FOUND)
|
if(ALLEGRO5_MAIN_FOUND)
|
||||||
target_link_libraries(${EXECUTABLE} ${ALLEGRO5_MAIN_LIBRARIES})
|
target_link_libraries(${EXECUTABLE} ${ALLEGRO5_MAIN_LIBRARIES})
|
||||||
|
@ -53,4 +53,4 @@ endif(ALLEGRO5_MAIN_FOUND)
|
||||||
add_subdirectory(gamestates)
|
add_subdirectory(gamestates)
|
||||||
|
|
||||||
install(TARGETS ${EXECUTABLE} DESTINATION ${BIN_INSTALL_DIR})
|
install(TARGETS ${EXECUTABLE} DESTINATION ${BIN_INSTALL_DIR})
|
||||||
install(TARGETS "libsuperderpy-radioedit" DESTINATION ${LIB_INSTALL_DIR})
|
install(TARGETS "libsuperderpy-ticklemonster" DESTINATION ${LIB_INSTALL_DIR})
|
||||||
|
|
|
@ -1,16 +1,18 @@
|
||||||
MACRO(GAMESTATE name)
|
MACRO(GAMESTATE name)
|
||||||
|
|
||||||
add_library("libsuperderpy-radioedit-${name}" SHARED "${name}.c")
|
add_library("libsuperderpy-ticklemonster-${name}" SHARED "${name}.c")
|
||||||
|
|
||||||
SET_TARGET_PROPERTIES("libsuperderpy-radioedit-${name}" PROPERTIES PREFIX "")
|
SET_TARGET_PROPERTIES("libsuperderpy-ticklemonster-${name}" PROPERTIES PREFIX "")
|
||||||
|
|
||||||
target_link_libraries("libsuperderpy-radioedit-${name}" ${ALLEGRO5_LIBRARIES} ${ALLEGRO5_FONT_LIBRARIES} ${ALLEGRO5_TTF_LIBRARIES} ${ALLEGRO5_PRIMITIVES_LIBRARIES} ${ALLEGRO5_AUDIO_LIBRARIES} ${ALLEGRO5_ACODEC_LIBRARIES} ${ALLEGRO5_IMAGE_LIBRARIES} m libsuperderpy-radioedit)
|
target_link_libraries("libsuperderpy-ticklemonster-${name}" ${ALLEGRO5_LIBRARIES} ${ALLEGRO5_FONT_LIBRARIES} ${ALLEGRO5_TTF_LIBRARIES} ${ALLEGRO5_PRIMITIVES_LIBRARIES} ${ALLEGRO5_AUDIO_LIBRARIES} ${ALLEGRO5_ACODEC_LIBRARIES} ${ALLEGRO5_IMAGE_LIBRARIES} m libsuperderpy-ticklemonster)
|
||||||
|
|
||||||
install(TARGETS "libsuperderpy-radioedit-${name}" DESTINATION ${LIB_INSTALL_DIR})
|
install(TARGETS "libsuperderpy-ticklemonster-${name}" DESTINATION ${LIB_INSTALL_DIR})
|
||||||
|
|
||||||
ENDMACRO()
|
ENDMACRO()
|
||||||
|
|
||||||
GAMESTATE("dosowisko")
|
GAMESTATE("dosowisko")
|
||||||
GAMESTATE("menu")
|
GAMESTATE("menu")
|
||||||
|
GAMESTATE("info")
|
||||||
|
GAMESTATE("level")
|
||||||
|
|
||||||
GAMESTATE("loading")
|
GAMESTATE("loading")
|
||||||
|
|
|
@ -26,7 +26,7 @@
|
||||||
#include "../timeline.h"
|
#include "../timeline.h"
|
||||||
#include "dosowisko.h"
|
#include "dosowisko.h"
|
||||||
|
|
||||||
int Gamestate_ProgressCount = 3;
|
int Gamestate_ProgressCount = 5;
|
||||||
|
|
||||||
static char* text = "# dosowisko.net";
|
static char* text = "# dosowisko.net";
|
||||||
|
|
||||||
|
|
199
src/gamestates/info.c
Normal file
199
src/gamestates/info.c
Normal file
|
@ -0,0 +1,199 @@
|
||||||
|
/*! \file menu.c
|
||||||
|
* \brief Main Menu view.
|
||||||
|
*/
|
||||||
|
/*
|
||||||
|
* 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.
|
||||||
|
*/
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <math.h>
|
||||||
|
#include <allegro5/allegro_ttf.h>
|
||||||
|
#include <allegro5/allegro_primitives.h>
|
||||||
|
#include "../config.h"
|
||||||
|
#include "../utils.h"
|
||||||
|
#include "../timeline.h"
|
||||||
|
#include "level.h"
|
||||||
|
|
||||||
|
#define TILE_SIZE 20
|
||||||
|
#define MAX_FUN 250.0
|
||||||
|
|
||||||
|
int Gamestate_ProgressCount = 4;
|
||||||
|
|
||||||
|
|
||||||
|
void Gamestate_Draw(struct Game *game, struct LevelResources* data) {
|
||||||
|
|
||||||
|
al_set_target_bitmap(al_get_backbuffer(game->display));
|
||||||
|
|
||||||
|
al_clear_to_color(al_map_rgb(3, 213, 255));
|
||||||
|
|
||||||
|
al_draw_bitmap(data->bg,0, 0,0);
|
||||||
|
al_draw_bitmap(data->buildings,0, 0,0);
|
||||||
|
|
||||||
|
al_draw_filled_rectangle(0, 0, 320, 180, al_map_rgba(0,0,0,64));
|
||||||
|
|
||||||
|
|
||||||
|
DrawCharacter(game, data->monster, al_map_rgb(255,255,255), 0);
|
||||||
|
|
||||||
|
al_draw_bitmap(data->meter,0, 0,0);
|
||||||
|
|
||||||
|
DrawTextWithShadow(data->font, al_map_rgb(255,255,255), game->viewport.width*0.5, 19, ALLEGRO_ALIGN_CENTRE, "You're the TICKLE MONSTER!");
|
||||||
|
DrawTextWithShadow(data->font, al_map_rgb(255,255,255), game->viewport.width*0.5, 29, ALLEGRO_ALIGN_CENTRE, "You tickle kids to ensure they ");
|
||||||
|
DrawTextWithShadow(data->font, al_map_rgb(255,255,255), game->viewport.width*0.5, 39, ALLEGRO_ALIGN_CENTRE, "are raised with proper amounts of fun!");
|
||||||
|
DrawTextWithShadow(data->font, al_map_rgb(255,255,255), game->viewport.width*0.5, 54, ALLEGRO_ALIGN_CENTRE, "Use ARROWS to move and SPACE to tickle!");
|
||||||
|
|
||||||
|
DrawTextWithShadow(data->font, al_map_rgb(255,255,255), game->viewport.width*0.5, 104, ALLEGRO_ALIGN_CENTRE, "Beware - if you give them wrong amount");
|
||||||
|
DrawTextWithShadow(data->font, al_map_rgb(255,255,255), game->viewport.width*0.5, 114, ALLEGRO_ALIGN_CENTRE, "of fun, they turn into fun hating");
|
||||||
|
DrawTextWithShadow(data->font, al_map_rgb(255,255,255), game->viewport.width*0.5, 124, ALLEGRO_ALIGN_CENTRE, "grown ups! Don't let them catch you!");
|
||||||
|
|
||||||
|
DrawTextWithShadow(data->font, al_map_rgb(255,255,255), 5, 162, ALLEGRO_ALIGN_LEFT, "Press ENTER to start!");
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void Gamestate_Logic(struct Game *game, struct LevelResources* data) {
|
||||||
|
|
||||||
|
AnimateCharacter(game, data->monster, 1);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
void* Gamestate_Load(struct Game *game, void (*progress)(struct Game*)) {
|
||||||
|
|
||||||
|
struct LevelResources *data = malloc(sizeof(struct LevelResources));
|
||||||
|
|
||||||
|
data->timer = al_create_timer(1);
|
||||||
|
al_register_event_source(game->_priv.event_queue, al_get_timer_event_source(data->timer));
|
||||||
|
|
||||||
|
data->timeline = TM_Init(game, "main");
|
||||||
|
(*progress)(game);
|
||||||
|
|
||||||
|
data->bg = al_load_bitmap( GetDataFilePath(game, "bg2.png") );
|
||||||
|
data->buildings = al_load_bitmap( GetDataFilePath(game, "buildings.png") );
|
||||||
|
data->hid = al_load_bitmap( GetDataFilePath(game, "hid.png") );
|
||||||
|
data->meter = al_load_bitmap( GetDataFilePath(game, "meter.png") );
|
||||||
|
(*progress)(game);
|
||||||
|
|
||||||
|
data->font_title = al_load_ttf_font(GetDataFilePath(game, "fonts/MonkeyIsland.ttf"),game->viewport.height*0.16,0 );
|
||||||
|
data->font = al_load_ttf_font(GetDataFilePath(game, "fonts/MonkeyIsland.ttf"),12,0 );
|
||||||
|
(*progress)(game);
|
||||||
|
|
||||||
|
data->monster = CreateCharacter(game, "monster");
|
||||||
|
RegisterSpritesheet(game, data->monster, "stand");
|
||||||
|
RegisterSpritesheet(game, data->monster, "tickle");
|
||||||
|
RegisterSpritesheet(game, data->monster, "ticklefail");
|
||||||
|
RegisterSpritesheet(game, data->monster, "fail");
|
||||||
|
RegisterSpritesheet(game, data->monster, "jump");
|
||||||
|
LoadSpritesheets(game, data->monster);
|
||||||
|
(*progress)(game);
|
||||||
|
|
||||||
|
al_set_target_backbuffer(game->display);
|
||||||
|
return data;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void Gamestate_Stop(struct Game *game, struct LevelResources* data) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
void Gamestate_Unload(struct Game *game, struct LevelResources* data) {
|
||||||
|
al_destroy_bitmap(data->bg);
|
||||||
|
al_destroy_bitmap(data->buildings);
|
||||||
|
al_destroy_bitmap(data->meter);
|
||||||
|
al_destroy_font(data->font_title);
|
||||||
|
al_destroy_font(data->font);
|
||||||
|
DestroyCharacter(game, data->monster);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void StartGame(struct Game *game, struct LevelResources *data) {
|
||||||
|
TM_CleanQueue(data->timeline);
|
||||||
|
TM_CleanBackgroundQueue(data->timeline);
|
||||||
|
ChangeSpritesheet(game, data->monster, "stand");
|
||||||
|
ChangeSpritesheet(game, data->suit, "stand");
|
||||||
|
}
|
||||||
|
|
||||||
|
void Gamestate_Start(struct Game *game, struct LevelResources* data) {
|
||||||
|
data->cloud_position = 100;
|
||||||
|
SetCharacterPosition(game, data->monster, 150, 73, 0);
|
||||||
|
|
||||||
|
data->score = 0;
|
||||||
|
data->time = 0;
|
||||||
|
|
||||||
|
data->lost = false;
|
||||||
|
data->tickling = false;
|
||||||
|
data->haskid = false;
|
||||||
|
|
||||||
|
data->movedown = false;
|
||||||
|
data->moveup = false;
|
||||||
|
|
||||||
|
data->markx = 119;
|
||||||
|
data->marky = 2;
|
||||||
|
|
||||||
|
data->soloactive = false;
|
||||||
|
data->soloanim = 0;
|
||||||
|
data->soloflash = 0;
|
||||||
|
data->soloready = 0;
|
||||||
|
|
||||||
|
data->keys.key = 0;
|
||||||
|
data->keys.delay = 0;
|
||||||
|
data->keys.shift = false;
|
||||||
|
data->keys.lastkey = -1;
|
||||||
|
|
||||||
|
data->lightanim=0;
|
||||||
|
|
||||||
|
data->kidSpeed = 0.8;
|
||||||
|
|
||||||
|
data->usage = 0;
|
||||||
|
|
||||||
|
SelectSpritesheet(game, data->monster, "stand");
|
||||||
|
|
||||||
|
//TM_AddQueuedBackgroundAction(data->timeline, &Anim_FixGuitar, TM_AddToArgs(NULL, 1, data), 15*1000, "fix_guitar");
|
||||||
|
//TM_AddQueuedBackgroundAction(data->timeline, &Anim_CowLook, TM_AddToArgs(NULL, 1, data), 5*1000, "cow_look");
|
||||||
|
|
||||||
|
data->kids[0] = NULL;
|
||||||
|
data->kids[1] = NULL;
|
||||||
|
data->kids[2] = NULL;
|
||||||
|
data->kids[3] = NULL;
|
||||||
|
data->kids[4] = NULL;
|
||||||
|
data->kids[5] = NULL;
|
||||||
|
data->destroyQueue = NULL;
|
||||||
|
|
||||||
|
data->kidRate = 100;
|
||||||
|
data->timeTillNextBadguy = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Gamestate_ProcessEvent(struct Game *game, struct LevelResources* data, ALLEGRO_EVENT *ev) {
|
||||||
|
TM_HandleEvent(data->timeline, ev);
|
||||||
|
|
||||||
|
if (ev->type == ALLEGRO_EVENT_KEY_DOWN) {
|
||||||
|
if (ev->keyboard.keycode == ALLEGRO_KEY_ESCAPE) {
|
||||||
|
SwitchGamestate(game, "info", "level");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (ev->keyboard.keycode == ALLEGRO_KEY_ENTER) {
|
||||||
|
SwitchGamestate(game, "info", "level");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
void Gamestate_Pause(struct Game *game, struct LevelResources* data) {
|
||||||
|
TM_Pause(data->timeline);
|
||||||
|
}
|
||||||
|
void Gamestate_Resume(struct Game *game, struct LevelResources* data) {
|
||||||
|
TM_Resume(data->timeline);
|
||||||
|
}
|
||||||
|
void Gamestate_Reload(struct Game *game, struct LevelResources* data) {}
|
84
src/gamestates/info.h
Normal file
84
src/gamestates/info.h
Normal file
|
@ -0,0 +1,84 @@
|
||||||
|
/*! \file menu.h
|
||||||
|
* \brief Main Menu view headers.
|
||||||
|
*/
|
||||||
|
/*
|
||||||
|
* 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <allegro5/allegro.h>
|
||||||
|
#include <allegro5/allegro_font.h>
|
||||||
|
#include <allegro5/allegro_audio.h>
|
||||||
|
|
||||||
|
/*! \brief Resources used by Menu state. */
|
||||||
|
struct LevelResources {
|
||||||
|
ALLEGRO_BITMAP *bg; /*!< Bitmap with lower portion of menu landscape. */
|
||||||
|
ALLEGRO_BITMAP *buildings;
|
||||||
|
ALLEGRO_BITMAP *hid;
|
||||||
|
ALLEGRO_BITMAP *meter;
|
||||||
|
ALLEGRO_BITMAP *busted;
|
||||||
|
|
||||||
|
ALLEGRO_TIMER *timer;
|
||||||
|
|
||||||
|
float kidSpeed;
|
||||||
|
|
||||||
|
int markx, marky;
|
||||||
|
|
||||||
|
int usage;
|
||||||
|
int lightx, lighty, lightanim;
|
||||||
|
|
||||||
|
int soloready, soloanim, soloflash;
|
||||||
|
bool soloactive;
|
||||||
|
|
||||||
|
bool tickling, moveup, movedown, haskid, lost;
|
||||||
|
|
||||||
|
struct Kid {
|
||||||
|
struct Character *character;
|
||||||
|
struct Kid *next, *prev;
|
||||||
|
float speed;
|
||||||
|
bool tickled;
|
||||||
|
bool grownup;
|
||||||
|
int fun;
|
||||||
|
bool happy;
|
||||||
|
bool right;
|
||||||
|
} *kids[6], *destroyQueue, *tickledKid;
|
||||||
|
|
||||||
|
int timeTillNextBadguy, kidRate;
|
||||||
|
|
||||||
|
struct Character *monster;
|
||||||
|
struct Character *suit;
|
||||||
|
struct Character *kid;
|
||||||
|
struct Timeline *timeline;
|
||||||
|
float cloud_position; /*!< Position of bigger cloud. */
|
||||||
|
ALLEGRO_SAMPLE *sample; /*!< Music sample. */
|
||||||
|
ALLEGRO_SAMPLE *click_sample; /*!< Click sound sample. */
|
||||||
|
ALLEGRO_SAMPLE_INSTANCE *laughter; /*!< Sample instance with music sound. */
|
||||||
|
ALLEGRO_SAMPLE_INSTANCE *click; /*!< Sample instance with click sound. */
|
||||||
|
ALLEGRO_FONT *font_title; /*!< Font of "Super Derpy" text. */
|
||||||
|
ALLEGRO_FONT *font; /*!< Font of standard menu item. */
|
||||||
|
int selected; /*!< Number of selected menu item. */
|
||||||
|
|
||||||
|
struct {
|
||||||
|
int key;
|
||||||
|
bool shift;
|
||||||
|
int delay;
|
||||||
|
// workaround for random bogus UP/DOWN events
|
||||||
|
int lastkey;
|
||||||
|
int lastdelay;
|
||||||
|
} keys;
|
||||||
|
|
||||||
|
int score, time;
|
||||||
|
};
|
File diff suppressed because it is too large
Load diff
|
@ -1,5 +1,5 @@
|
||||||
/*! \file level.h
|
/*! \file menu.h
|
||||||
* \brief Playable Level headers.
|
* \brief Main Menu view headers.
|
||||||
*/
|
*/
|
||||||
/*
|
/*
|
||||||
* Copyright (c) Sebastian Krzyszkowiak <dos@dosowisko.net>
|
* Copyright (c) Sebastian Krzyszkowiak <dos@dosowisko.net>
|
||||||
|
@ -18,66 +18,69 @@
|
||||||
* along with this program; if not, write to the Free Software
|
* along with this program; if not, write to the Free Software
|
||||||
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
|
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
*/
|
*/
|
||||||
#include "../main.h"
|
|
||||||
|
|
||||||
|
#include <allegro5/allegro.h>
|
||||||
|
#include <allegro5/allegro_font.h>
|
||||||
|
#include <allegro5/allegro_audio.h>
|
||||||
|
|
||||||
/*! \brief Structure representing one spritesheet for character animation. */
|
/*! \brief Resources used by Menu state. */
|
||||||
struct Spritesheet {
|
struct LevelResources {
|
||||||
char* name; /*!< Name of the spritesheet (used in file paths). */
|
ALLEGRO_BITMAP *bg; /*!< Bitmap with lower portion of menu landscape. */
|
||||||
ALLEGRO_BITMAP* bitmap; /*!< Spritesheet bitmap. */
|
ALLEGRO_BITMAP *buildings;
|
||||||
int rows; /*!< Number of rows in the spritesheet. */
|
ALLEGRO_BITMAP *hid;
|
||||||
int cols; /*!< Number of columns in the spritesheet. */
|
ALLEGRO_BITMAP *hid2;
|
||||||
int blanks; /*!< Number of blank frames at the end of the spritesheet. */
|
ALLEGRO_BITMAP *meter;
|
||||||
float speed; /*!< Speed modifier of spritesheet animation. */
|
ALLEGRO_BITMAP *busted;
|
||||||
float aspect; /*!< Aspect ratio of the frame. */
|
|
||||||
float scale; /*!< Scale modifier of the frame. */
|
ALLEGRO_TIMER *timer;
|
||||||
char* successor; /*!< Name of animation successor. If it's not blank, then animation will be played only once. */
|
|
||||||
struct Spritesheet* next; /*!< Next spritesheet in the queue. */
|
float kidSpeed;
|
||||||
|
|
||||||
|
int markx, marky;
|
||||||
|
|
||||||
|
int usage;
|
||||||
|
int lightx, lighty, lightanim;
|
||||||
|
|
||||||
|
int soloready, soloanim, soloflash;
|
||||||
|
bool soloactive;
|
||||||
|
|
||||||
|
bool tickling, moveup, movedown, haskid, lost, paused;
|
||||||
|
|
||||||
|
struct Kid {
|
||||||
|
struct Character *character;
|
||||||
|
struct Kid *next, *prev;
|
||||||
|
float speed;
|
||||||
|
bool tickled;
|
||||||
|
bool grownup;
|
||||||
|
int fun;
|
||||||
|
bool happy;
|
||||||
|
bool right;
|
||||||
|
} *kids[6], *destroyQueue, *tickledKid;
|
||||||
|
|
||||||
|
int timeTillNextBadguy, kidRate;
|
||||||
|
|
||||||
|
struct Character *monster;
|
||||||
|
struct Character *suit;
|
||||||
|
struct Character *kid;
|
||||||
|
struct Timeline *timeline;
|
||||||
|
float cloud_position; /*!< Position of bigger cloud. */
|
||||||
|
ALLEGRO_SAMPLE *sample; /*!< Music sample. */
|
||||||
|
ALLEGRO_SAMPLE *click_sample; /*!< Click sound sample. */
|
||||||
|
ALLEGRO_SAMPLE_INSTANCE *laughter; /*!< Sample instance with music sound. */
|
||||||
|
ALLEGRO_SAMPLE_INSTANCE *click; /*!< Sample instance with click sound. */
|
||||||
|
ALLEGRO_FONT *font_title; /*!< Font of "Super Derpy" text. */
|
||||||
|
ALLEGRO_FONT *font; /*!< Font of standard menu item. */
|
||||||
|
int selected; /*!< Number of selected menu item. */
|
||||||
|
|
||||||
|
struct {
|
||||||
|
int key;
|
||||||
|
bool shift;
|
||||||
|
int delay;
|
||||||
|
// workaround for random bogus UP/DOWN events
|
||||||
|
int lastkey;
|
||||||
|
int lastdelay;
|
||||||
|
} keys;
|
||||||
|
|
||||||
|
int savedScore, savedTime;
|
||||||
|
int score, time;
|
||||||
};
|
};
|
||||||
|
|
||||||
/*! \brief Structure representing one visible character. */
|
|
||||||
struct Character {
|
|
||||||
char* name; /*!< Name of the character (used in file paths). */
|
|
||||||
struct Spritesheet *spritesheet; /*!< Current spritesheet used by character. */
|
|
||||||
struct Spritesheet *spritesheets; /*!< List of all spritesheets registered to character. */
|
|
||||||
ALLEGRO_BITMAP* bitmap;
|
|
||||||
int pos; /*!< Current spritesheet position. */
|
|
||||||
float pos_tmp; /*!< A counter used to slow down spritesheet animation. */
|
|
||||||
float x; /*!< Horizontal position of character (0 - left, 1 - right side of maximal square). */
|
|
||||||
float y; /*!< Vertical position of character (0 - top, 1 - bottom). */
|
|
||||||
float angle; /*!< Characters display angle (radians). */
|
|
||||||
void* data; /*!< Additional, custom character data (HP etc.). */
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
void SelectSpritesheet(struct Game *game, struct Character *character, char* name);
|
|
||||||
void RegisterSpritesheet(struct Game *game, struct Character *character, char* name);
|
|
||||||
void AdvanceLevel(struct Game *game, int current_level, bool last);
|
|
||||||
/*! \brief Replaces first '?' char in filename with current level number. */
|
|
||||||
char* GetLevelFilename(struct Game *game, char* filename);
|
|
||||||
|
|
||||||
void DrawCharacter(struct Game *game, struct Character *character, ALLEGRO_COLOR tilt, int flags);
|
|
||||||
|
|
||||||
struct Character* CreateCharacter(struct Game *game, char* name);
|
|
||||||
void DestroyCharacter(struct Game *game, struct Character *character);
|
|
||||||
|
|
||||||
void LoadSpritesheets(struct Game *game, struct Character *character);
|
|
||||||
void UnloadSpritesheets(struct Game *game, struct Character *character);
|
|
||||||
|
|
||||||
void AnimateCharacter(struct Game *game, struct Character *character, float speed_modifier);
|
|
||||||
void MoveCharacter(struct Game *game, struct Character *character, float x, float y, float angle);
|
|
||||||
void SetCharacterPosition(struct Game *game, struct Character *character, float x, float y, float angle);
|
|
||||||
|
|
||||||
/*void Level_Passed(struct Game *game);
|
|
||||||
void Level_Pause(struct Game *game);
|
|
||||||
void Level_Resume(struct Game *game);
|
|
||||||
void Level_Draw(struct Game *game);
|
|
||||||
void Level_Logic(struct Game *game);
|
|
||||||
void Level_Preload(struct Game *game, void (*progress)(struct Game*, float));
|
|
||||||
void Level_Unload(struct Game *game);
|
|
||||||
void Level_Load(struct Game *game);
|
|
||||||
void Level_ProcessEvent(struct Game *game, ALLEGRO_EVENT *ev);
|
|
||||||
int Level_Keydown(struct Game *game, ALLEGRO_EVENT *ev);
|
|
||||||
void Level_UnloadBitmaps(struct Game *game);
|
|
||||||
void Level_PreloadBitmaps(struct Game *game, void (*progress)(struct Game*, float));
|
|
||||||
*/
|
|
||||||
|
|
|
@ -25,7 +25,7 @@
|
||||||
void Progress(struct Game *game, struct LoadingResources *data, float p) {
|
void Progress(struct Game *game, struct LoadingResources *data, float p) {
|
||||||
al_set_target_bitmap(al_get_backbuffer(game->display));
|
al_set_target_bitmap(al_get_backbuffer(game->display));
|
||||||
al_draw_bitmap(data->loading_bitmap,0,0,0);
|
al_draw_bitmap(data->loading_bitmap,0,0,0);
|
||||||
al_draw_filled_rectangle(0, game->viewport.height-1, p*game->viewport.width, game->viewport.height, al_map_rgba(128,128,128,128));
|
al_draw_filled_rectangle(0, game->viewport.height/2 - 1, p*game->viewport.width, game->viewport.height/2 + 1, al_map_rgba(128,128,128,128));
|
||||||
}
|
}
|
||||||
|
|
||||||
void Draw(struct Game *game, struct LoadingResources *data, float p) {
|
void Draw(struct Game *game, struct LoadingResources *data, float p) {
|
||||||
|
@ -38,10 +38,12 @@ void* Load(struct Game *game) {
|
||||||
al_clear_to_color(al_map_rgb(0,0,0));
|
al_clear_to_color(al_map_rgb(0,0,0));
|
||||||
|
|
||||||
data->loading_bitmap = al_create_bitmap(game->viewport.width, game->viewport.height);
|
data->loading_bitmap = al_create_bitmap(game->viewport.width, game->viewport.height);
|
||||||
|
data->bg = al_load_bitmap( GetDataFilePath(game, "bg.png") );
|
||||||
|
|
||||||
al_set_target_bitmap(data->loading_bitmap);
|
al_set_target_bitmap(data->loading_bitmap);
|
||||||
al_clear_to_color(al_map_rgb(0,0,0));
|
al_clear_to_color(al_map_rgb(0,0,0));
|
||||||
al_draw_filled_rectangle(0, game->viewport.height-1, game->viewport.width, game->viewport.height, al_map_rgba(32,32,32,32));
|
al_draw_bitmap(data->bg, 0, 0, 0);
|
||||||
|
al_draw_filled_rectangle(0, game->viewport.height/2 - 1, game->viewport.width, game->viewport.height/2 + 1, al_map_rgba(32,32,32,32));
|
||||||
al_set_target_bitmap(al_get_backbuffer(game->display));
|
al_set_target_bitmap(al_get_backbuffer(game->display));
|
||||||
return data;
|
return data;
|
||||||
}
|
}
|
||||||
|
@ -50,5 +52,6 @@ void Start(struct Game *game, struct LoadingResources *data) {}
|
||||||
void Stop(struct Game *game, struct LoadingResources *data) {}
|
void Stop(struct Game *game, struct LoadingResources *data) {}
|
||||||
void Unload(struct Game *game, struct LoadingResources *data) {
|
void Unload(struct Game *game, struct LoadingResources *data) {
|
||||||
al_destroy_bitmap(data->loading_bitmap);
|
al_destroy_bitmap(data->loading_bitmap);
|
||||||
|
al_destroy_bitmap(data->bg);
|
||||||
free(data);
|
free(data);
|
||||||
}
|
}
|
||||||
|
|
|
@ -26,4 +26,5 @@
|
||||||
/*! \brief Resources used by Loading state. */
|
/*! \brief Resources used by Loading state. */
|
||||||
struct LoadingResources {
|
struct LoadingResources {
|
||||||
ALLEGRO_BITMAP *loading_bitmap; /*!< Rendered loading bitmap. */
|
ALLEGRO_BITMAP *loading_bitmap; /*!< Rendered loading bitmap. */
|
||||||
|
ALLEGRO_BITMAP *bg;
|
||||||
};
|
};
|
||||||
|
|
|
@ -27,9 +27,7 @@
|
||||||
#include "../timeline.h"
|
#include "../timeline.h"
|
||||||
#include "menu.h"
|
#include "menu.h"
|
||||||
|
|
||||||
#define SOLO_MIN 20
|
int Gamestate_ProgressCount = 4;
|
||||||
|
|
||||||
int Gamestate_ProgressCount = 5;
|
|
||||||
|
|
||||||
void About(struct Game *game, struct MenuResources* data) {
|
void About(struct Game *game, struct MenuResources* data) {
|
||||||
ALLEGRO_TRANSFORM trans;
|
ALLEGRO_TRANSFORM trans;
|
||||||
|
@ -43,7 +41,7 @@ void About(struct Game *game, struct MenuResources* data) {
|
||||||
al_set_target_backbuffer(game->display);
|
al_set_target_backbuffer(game->display);
|
||||||
al_clear_to_color(al_map_rgb(0,0,170));
|
al_clear_to_color(al_map_rgb(0,0,170));
|
||||||
|
|
||||||
char *header = "RADIO EDIT";
|
char *header = "TICKLE MONSTER";
|
||||||
|
|
||||||
al_draw_filled_rectangle(al_get_display_width(game->display)/2 - al_get_text_width(game->_priv.font_bsod, header)/2 - 4, (int)(al_get_display_height(game->display) * 0.32), 4 + al_get_display_width(game->display)/2 + al_get_text_width(game->_priv.font_bsod, header)/2, (int)(al_get_display_height(game->display) * 0.32) + al_get_font_line_height(game->_priv.font_bsod), al_map_rgb(170,170,170));
|
al_draw_filled_rectangle(al_get_display_width(game->display)/2 - al_get_text_width(game->_priv.font_bsod, header)/2 - 4, (int)(al_get_display_height(game->display) * 0.32), 4 + al_get_display_width(game->display)/2 + al_get_text_width(game->_priv.font_bsod, header)/2, (int)(al_get_display_height(game->display) * 0.32) + al_get_font_line_height(game->_priv.font_bsod), al_map_rgb(170,170,170));
|
||||||
|
|
||||||
|
@ -55,8 +53,8 @@ void About(struct Game *game, struct MenuResources* data) {
|
||||||
al_draw_textf(game->_priv.font_bsod, al_map_rgb(255,255,255), al_get_display_width(game->display)/2 - al_get_text_width(game->_priv.font_bsod, header2)/2, (int)(al_get_display_height(game->display) * 0.32+3*al_get_font_line_height(game->_priv.font_bsod)*1.25), ALLEGRO_ALIGN_LEFT, "%p and system just doesn't know what went wrong.", (void*)game);
|
al_draw_textf(game->_priv.font_bsod, al_map_rgb(255,255,255), al_get_display_width(game->display)/2 - al_get_text_width(game->_priv.font_bsod, header2)/2, (int)(al_get_display_height(game->display) * 0.32+3*al_get_font_line_height(game->_priv.font_bsod)*1.25), ALLEGRO_ALIGN_LEFT, "%p and system just doesn't know what went wrong.", (void*)game);
|
||||||
|
|
||||||
al_draw_text(game->_priv.font_bsod, al_map_rgb(255,255,255), al_get_display_width(game->display)/2, (int)(al_get_display_height(game->display) * 0.32+5*al_get_font_line_height(game->_priv.font_bsod)*1.25), ALLEGRO_ALIGN_CENTRE, "About screen not implemented!");
|
al_draw_text(game->_priv.font_bsod, al_map_rgb(255,255,255), al_get_display_width(game->display)/2, (int)(al_get_display_height(game->display) * 0.32+5*al_get_font_line_height(game->_priv.font_bsod)*1.25), ALLEGRO_ALIGN_CENTRE, "About screen not implemented!");
|
||||||
al_draw_text(game->_priv.font_bsod, al_map_rgb(255,255,255), al_get_display_width(game->display)/2, (int)(al_get_display_height(game->display) * 0.32+6*al_get_font_line_height(game->_priv.font_bsod)*1.25), ALLEGRO_ALIGN_CENTRE, "See http://dosowisko.net/radioedit/");
|
al_draw_text(game->_priv.font_bsod, al_map_rgb(255,255,255), al_get_display_width(game->display)/2, (int)(al_get_display_height(game->display) * 0.32+6*al_get_font_line_height(game->_priv.font_bsod)*1.25), ALLEGRO_ALIGN_CENTRE, "See http://dosowisko.net/ticklemonster/");
|
||||||
al_draw_text(game->_priv.font_bsod, al_map_rgb(255,255,255), al_get_display_width(game->display)/2, (int)(al_get_display_height(game->display) * 0.32+7*al_get_font_line_height(game->_priv.font_bsod)*1.25), ALLEGRO_ALIGN_CENTRE, "Made for Ludum Dare 32");
|
al_draw_text(game->_priv.font_bsod, al_map_rgb(255,255,255), al_get_display_width(game->display)/2, (int)(al_get_display_height(game->display) * 0.32+7*al_get_font_line_height(game->_priv.font_bsod)*1.25), ALLEGRO_ALIGN_CENTRE, "Made for Ludum Dare 33 by Sebastian Krzyszkowiak");
|
||||||
|
|
||||||
al_draw_text(game->_priv.font_bsod, al_map_rgb(255,255,255), al_get_display_width(game->display)/2 - al_get_text_width(game->_priv.font_bsod, header2)/2, (int)(al_get_display_height(game->display) * 0.32+9*al_get_font_line_height(game->_priv.font_bsod)*1.25), ALLEGRO_ALIGN_LEFT, "* Press any key to terminate this error.");
|
al_draw_text(game->_priv.font_bsod, al_map_rgb(255,255,255), al_get_display_width(game->display)/2 - al_get_text_width(game->_priv.font_bsod, header2)/2, (int)(al_get_display_height(game->display) * 0.32+9*al_get_font_line_height(game->_priv.font_bsod)*1.25), ALLEGRO_ALIGN_LEFT, "* Press any key to terminate this error.");
|
||||||
al_draw_text(game->_priv.font_bsod, al_map_rgb(255,255,255), al_get_display_width(game->display)/2 - al_get_text_width(game->_priv.font_bsod, header2)/2, (int)(al_get_display_height(game->display) * 0.32+10*al_get_font_line_height(game->_priv.font_bsod)*1.25), ALLEGRO_ALIGN_LEFT, "* Press any key to destroy all muffins in the world.");
|
al_draw_text(game->_priv.font_bsod, al_map_rgb(255,255,255), al_get_display_width(game->display)/2 - al_get_text_width(game->_priv.font_bsod, header2)/2, (int)(al_get_display_height(game->display) * 0.32+10*al_get_font_line_height(game->_priv.font_bsod)*1.25), ALLEGRO_ALIGN_LEFT, "* Press any key to destroy all muffins in the world.");
|
||||||
|
@ -68,31 +66,43 @@ void About(struct Game *game, struct MenuResources* data) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void DrawMenuState(struct Game *game, struct MenuResources *data) {
|
void DrawMenuState(struct Game *game, struct MenuResources *data) {
|
||||||
|
|
||||||
|
const ALLEGRO_TRANSFORM *tmp_trans = al_get_current_transform();
|
||||||
|
ALLEGRO_TRANSFORM trans, cur_trans;
|
||||||
|
al_copy_transform(&trans, tmp_trans);
|
||||||
|
al_copy_transform(&cur_trans, tmp_trans);
|
||||||
|
al_translate_transform(&trans, (al_get_display_width(game->display) / 320.0) * 100, (al_get_display_height(game->display) / 260.0) * ((180-data->screen_pos) - 48));
|
||||||
|
al_use_transform(&trans);
|
||||||
|
|
||||||
ALLEGRO_FONT *font = data->font;
|
ALLEGRO_FONT *font = data->font;
|
||||||
char* text = malloc(255*sizeof(char));
|
char* text = malloc(255*sizeof(char));
|
||||||
struct ALLEGRO_COLOR color;
|
struct ALLEGRO_COLOR color;
|
||||||
switch (data->menustate) {
|
switch (data->menustate) {
|
||||||
case MENUSTATE_MAIN:
|
case MENUSTATE_MAIN:
|
||||||
DrawTextWithShadow(font, data->selected==0 ? al_map_rgb(255,255,128) : al_map_rgb(255,255,255), game->viewport.width*0.5, game->viewport.height*0.5, ALLEGRO_ALIGN_CENTRE, "Start game");
|
case MENUSTATE_HIDDEN:
|
||||||
DrawTextWithShadow(font, data->selected==1 ? al_map_rgb(255,255,128) : al_map_rgb(255,255,255), game->viewport.width*0.5, game->viewport.height*0.6, ALLEGRO_ALIGN_CENTRE, "Options");
|
if (!data->invisible) {
|
||||||
DrawTextWithShadow(font, data->selected==2 ? al_map_rgb(255,255,128) : al_map_rgb(255,255,255), game->viewport.width*0.5, game->viewport.height*0.7, ALLEGRO_ALIGN_CENTRE, "About");
|
DrawTextWithShadow(font, data->selected==0 ? al_map_rgb(128,255,128) : al_map_rgb(255,255,255), game->viewport.width*0.5, game->viewport.height*0.5, ALLEGRO_ALIGN_CENTRE, "Start game");
|
||||||
DrawTextWithShadow(font, data->selected==3 ? al_map_rgb(255,255,128) : al_map_rgb(255,255,255), game->viewport.width*0.5, game->viewport.height*0.8, ALLEGRO_ALIGN_CENTRE, "Exit");
|
DrawTextWithShadow(font, data->selected==1 ? al_map_rgb(128,255,128) : al_map_rgb(255,255,255), game->viewport.width*0.5, game->viewport.height*0.6, ALLEGRO_ALIGN_CENTRE, "Options");
|
||||||
|
DrawTextWithShadow(font, data->selected==2 ? al_map_rgb(128,255,128) : al_map_rgb(255,255,255), game->viewport.width*0.5, game->viewport.height*0.7, ALLEGRO_ALIGN_CENTRE, "About");
|
||||||
|
DrawTextWithShadow(font, data->selected==3 ? al_map_rgb(128,255,128) : al_map_rgb(255,255,255), game->viewport.width*0.5, game->viewport.height*0.8, ALLEGRO_ALIGN_CENTRE, "Exit");
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
case MENUSTATE_OPTIONS:
|
case MENUSTATE_OPTIONS:
|
||||||
DrawTextWithShadow(font, data->selected==0 ? al_map_rgb(255,255,128) : al_map_rgb(255,255,255), game->viewport.width*0.5, game->viewport.height*0.5, ALLEGRO_ALIGN_CENTRE, "Video settings");
|
DrawTextWithShadow(font, data->selected==0 ? al_map_rgb(128,255,128) : al_map_rgb(255,255,255), game->viewport.width*0.5, game->viewport.height*0.5, ALLEGRO_ALIGN_CENTRE, "Video settings");
|
||||||
DrawTextWithShadow(font, data->selected==1 ? al_map_rgb(255,255,128) : al_map_rgb(255,255,255), game->viewport.width*0.5, game->viewport.height*0.6, ALLEGRO_ALIGN_CENTRE, "Audio settings");
|
DrawTextWithShadow(font, data->selected==1 ? al_map_rgb(128,255,128) : al_map_rgb(255,255,255), game->viewport.width*0.5, game->viewport.height*0.6, ALLEGRO_ALIGN_CENTRE, "Audio settings");
|
||||||
DrawTextWithShadow(font, data->selected==3 ? al_map_rgb(255,255,128) : al_map_rgb(255,255,255), game->viewport.width*0.5, game->viewport.height*0.8, ALLEGRO_ALIGN_CENTRE, "Back");
|
DrawTextWithShadow(font, data->selected==3 ? al_map_rgb(128,255,128) : al_map_rgb(255,255,255), game->viewport.width*0.5, game->viewport.height*0.8, ALLEGRO_ALIGN_CENTRE, "Back");
|
||||||
break;
|
break;
|
||||||
case MENUSTATE_AUDIO:
|
case MENUSTATE_AUDIO:
|
||||||
if (game->config.music) snprintf(text, 255, "Music volume: %d0%%", game->config.music);
|
if (game->config.music) snprintf(text, 255, "Music volume: %d0%%", game->config.music);
|
||||||
else sprintf(text, "Music disabled");
|
else sprintf(text, "Music disabled");
|
||||||
DrawTextWithShadow(font, data->selected==0 ? al_map_rgb(255,255,128) : al_map_rgb(255,255,255), game->viewport.width*0.5, game->viewport.height*0.5, ALLEGRO_ALIGN_CENTRE, text);
|
DrawTextWithShadow(font, data->selected==0 ? al_map_rgb(128,255,128) : al_map_rgb(255,255,255), game->viewport.width*0.5, game->viewport.height*0.5, ALLEGRO_ALIGN_CENTRE, text);
|
||||||
if (game->config.fx) snprintf(text, 255, "Effects volume: %d0%%", game->config.fx);
|
if (game->config.fx) snprintf(text, 255, "Effects volume: %d0%%", game->config.fx);
|
||||||
else sprintf(text, "Effects disabled");
|
else sprintf(text, "Effects disabled");
|
||||||
DrawTextWithShadow(font, data->selected==1 ? al_map_rgb(255,255,128) : al_map_rgb(255,255,255), game->viewport.width*0.5, game->viewport.height*0.6, ALLEGRO_ALIGN_CENTRE, text);
|
DrawTextWithShadow(font, data->selected==1 ? al_map_rgb(128,255,128) : al_map_rgb(255,255,255), game->viewport.width*0.5, game->viewport.height*0.6, ALLEGRO_ALIGN_CENTRE, text);
|
||||||
DrawTextWithShadow(font, data->selected==3 ? al_map_rgb(255,255,128) : al_map_rgb(255,255,255), game->viewport.width*0.5, game->viewport.height*0.8, ALLEGRO_ALIGN_CENTRE, "Back");
|
DrawTextWithShadow(font, data->selected==3 ? al_map_rgb(128,255,128) : al_map_rgb(255,255,255), game->viewport.width*0.5, game->viewport.height*0.8, ALLEGRO_ALIGN_CENTRE, "Back");
|
||||||
break;
|
break;
|
||||||
case MENUSTATE_ABOUT:
|
case MENUSTATE_ABOUT:
|
||||||
|
al_use_transform(&cur_trans);
|
||||||
About(game, data);
|
About(game, data);
|
||||||
break;
|
break;
|
||||||
case MENUSTATE_VIDEO:
|
case MENUSTATE_VIDEO:
|
||||||
|
@ -102,77 +112,24 @@ void DrawMenuState(struct Game *game, struct MenuResources *data) {
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
sprintf(text, "Fullscreen: no");
|
sprintf(text, "Fullscreen: no");
|
||||||
color = data->selected==1 ? al_map_rgb(255,255,128) : al_map_rgb(255,255,255);
|
color = data->selected==1 ? al_map_rgb(128,255,128) : al_map_rgb(255,255,255);
|
||||||
}
|
}
|
||||||
DrawTextWithShadow(font, data->selected==0 ? al_map_rgb(255,255,128) : al_map_rgb(255,255,255), game->viewport.width*0.5, game->viewport.height*0.5, ALLEGRO_ALIGN_CENTRE, text);
|
DrawTextWithShadow(font, data->selected==0 ? al_map_rgb(128,255,128) : al_map_rgb(255,255,255), game->viewport.width*0.5, game->viewport.height*0.5, ALLEGRO_ALIGN_CENTRE, text);
|
||||||
sprintf(text, "Resolution: %dx", data->options.resolution);
|
sprintf(text, "Resolution: %dx", data->options.resolution);
|
||||||
DrawTextWithShadow(font, color, game->viewport.width*0.5, game->viewport.height*0.6, ALLEGRO_ALIGN_CENTRE, text);
|
DrawTextWithShadow(font, color, game->viewport.width*0.5, game->viewport.height*0.6, ALLEGRO_ALIGN_CENTRE, text);
|
||||||
DrawTextWithShadow(font, data->selected==3 ? al_map_rgb(255,255,128) : al_map_rgb(255,255,255), game->viewport.width*0.5, game->viewport.height*0.8, ALLEGRO_ALIGN_CENTRE, "Back");
|
DrawTextWithShadow(font, data->selected==3 ? al_map_rgb(128,255,128) : al_map_rgb(255,255,255), game->viewport.width*0.5, game->viewport.height*0.8, ALLEGRO_ALIGN_CENTRE, "Back");
|
||||||
break;
|
|
||||||
case MENUSTATE_HIDDEN:
|
|
||||||
break;
|
|
||||||
case MENUSTATE_LOST:
|
|
||||||
DrawTextWithShadow(font, al_map_rgb(255,255,255), game->viewport.width*0.5, game->viewport.height*0.5, ALLEGRO_ALIGN_CENTRE, "You lost!");
|
|
||||||
sprintf(text, "Score: %d", data->score);
|
|
||||||
DrawTextWithShadow(font, al_map_rgb(255,255,255), game->viewport.width*0.5, game->viewport.height*0.6, ALLEGRO_ALIGN_CENTRE, text);
|
|
||||||
DrawTextWithShadow(font, al_map_rgb(255,255,128), game->viewport.width*0.5, game->viewport.height*0.8, ALLEGRO_ALIGN_CENTRE, "Back to menu");
|
|
||||||
break;
|
|
||||||
case MENUSTATE_INTRO:
|
|
||||||
DrawTextWithShadow(font, al_map_rgba(0,0,0,64), 46, game->viewport.height*0.5, ALLEGRO_ALIGN_CENTRE, "Evi");
|
|
||||||
DrawTextWithShadow(font, al_map_rgba(0,0,0,64), 51, game->viewport.height*0.5-1, ALLEGRO_ALIGN_CENTRE, "vi");
|
|
||||||
DrawTextWithShadow(font, al_map_rgb(255,255,128), game->viewport.width*0.5, game->viewport.height*0.5, ALLEGRO_ALIGN_CENTRE, "Evil record label representatives want");
|
|
||||||
DrawTextWithShadow(font, al_map_rgba(0,0,0,64), 47, game->viewport.height*0.55, ALLEGRO_ALIGN_CENTRE, "tu");
|
|
||||||
DrawTextWithShadow(font, al_map_rgba(0,0,0,64), 48, game->viewport.height*0.55 - 1, ALLEGRO_ALIGN_CENTRE, "tu");
|
|
||||||
DrawTextWithShadow(font, al_map_rgb(255,255,128), game->viewport.width*0.5, game->viewport.height*0.55, ALLEGRO_ALIGN_CENTRE, "to turn your awesome single into radio edit.");
|
|
||||||
DrawTextWithShadow(font, al_map_rgb(255,255,128), game->viewport.width*0.5, game->viewport.height*0.6, ALLEGRO_ALIGN_CENTRE, "Thankfully, with your facemelting guitar");
|
|
||||||
DrawTextWithShadow(font, al_map_rgb(255,255,128), game->viewport.width*0.5, game->viewport.height*0.65, ALLEGRO_ALIGN_CENTRE, "skills you don't have to give up so easily!");
|
|
||||||
DrawTextWithShadow(font, al_map_rgb(255,255,255), game->viewport.width*0.5, game->viewport.height*0.8, ALLEGRO_ALIGN_CENTRE, "Press ENTER to continue...");
|
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
data->selected=0;
|
data->selected=0;
|
||||||
DrawTextWithShadow(font, data->selected==0 ? al_map_rgb(255,255,128) : al_map_rgb(255,255,255), game->viewport.width*0.5, game->viewport.height*0.5, ALLEGRO_ALIGN_CENTRE, "Not implemented yet");
|
DrawTextWithShadow(font, data->selected==0 ? al_map_rgb(128,255,128) : al_map_rgb(255,255,255), game->viewport.width*0.5, game->viewport.height*0.5, ALLEGRO_ALIGN_CENTRE, "Not implemented yet");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
free(text);
|
free(text);
|
||||||
|
|
||||||
|
al_use_transform(&cur_trans);
|
||||||
}
|
}
|
||||||
|
|
||||||
void AnimateBadguys(struct Game *game, struct MenuResources *data, int i) {
|
|
||||||
struct Badguy *tmp = data->badguys[i];
|
|
||||||
while (tmp) {
|
|
||||||
AnimateCharacter(game, tmp->character, tmp->melting ? 1 : tmp->speed * data->badguySpeed);
|
|
||||||
tmp=tmp->next;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void MoveBadguys(struct Game *game, struct MenuResources *data, int i, float dx) {
|
|
||||||
struct Badguy *tmp = data->badguys[i];
|
|
||||||
while (tmp) {
|
|
||||||
|
|
||||||
if (!tmp->character->spritesheet->kill) {
|
|
||||||
MoveCharacter(game, tmp->character, dx * tmp->speed * data->badguySpeed, 0, 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (tmp->character->dead) {
|
|
||||||
if (tmp->prev) {
|
|
||||||
tmp->prev->next = tmp->next;
|
|
||||||
if (tmp->next) tmp->next->prev = tmp->prev;
|
|
||||||
} else {
|
|
||||||
data->badguys[i] = tmp->next;
|
|
||||||
if (tmp->next) tmp->next->prev = NULL;
|
|
||||||
}
|
|
||||||
struct Badguy *old = tmp;
|
|
||||||
tmp = tmp->next;
|
|
||||||
old->character->dead = true;
|
|
||||||
old->prev = NULL;
|
|
||||||
old->next = data->destroyQueue;
|
|
||||||
if (data->destroyQueue) data->destroyQueue->prev = old;
|
|
||||||
data->destroyQueue = old;
|
|
||||||
} else {
|
|
||||||
tmp = tmp->next;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void ChangeMenuState(struct Game *game, struct MenuResources* data, enum menustate_enum state) {
|
void ChangeMenuState(struct Game *game, struct MenuResources* data, enum menustate_enum state) {
|
||||||
data->menustate=state;
|
data->menustate=state;
|
||||||
|
@ -180,327 +137,78 @@ void ChangeMenuState(struct Game *game, struct MenuResources* data, enum menusta
|
||||||
PrintConsole(game, "menu state changed %d", state);
|
PrintConsole(game, "menu state changed %d", state);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CheckForEnd(struct Game *game, struct MenuResources *data) {
|
|
||||||
int i;
|
|
||||||
bool lost = false;
|
|
||||||
for (i=0; i<4; i++) {
|
|
||||||
struct Badguy *tmp = data->badguys[i];
|
|
||||||
while (tmp) {
|
|
||||||
if (tmp->character->x <= (139-(i*10))-10) {
|
|
||||||
lost = true;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
tmp=tmp->next;
|
|
||||||
}
|
|
||||||
if (lost) break;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (lost) {
|
|
||||||
|
|
||||||
al_stop_sample_instance(data->solo);
|
|
||||||
data->soloactive=false;
|
|
||||||
data->soloanim=0;
|
|
||||||
data->soloflash=0;
|
|
||||||
data->soloready=0;
|
|
||||||
|
|
||||||
al_stop_sample_instance(data->music);
|
|
||||||
al_play_sample_instance(data->end);
|
|
||||||
SelectSpritesheet(game, data->ego, "cry");
|
|
||||||
ChangeMenuState(game, data, MENUSTATE_LOST);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void DrawBadguys(struct Game *game, struct MenuResources *data, int i) {
|
|
||||||
struct Badguy *tmp = data->badguys[i];
|
|
||||||
while (tmp) {
|
|
||||||
DrawCharacter(game, tmp->character, al_map_rgb(255,255,255), 0);
|
|
||||||
tmp=tmp->next;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void Gamestate_Draw(struct Game *game, struct MenuResources* data) {
|
void Gamestate_Draw(struct Game *game, struct MenuResources* data) {
|
||||||
|
|
||||||
al_set_target_bitmap(al_get_backbuffer(game->display));
|
al_set_target_bitmap(al_get_backbuffer(game->display));
|
||||||
|
|
||||||
al_clear_to_color(al_map_rgb(3, 213, 255));
|
al_clear_to_color(al_map_rgb(3, 213, 255));
|
||||||
|
|
||||||
al_draw_bitmap(data->bg,0, 0,0);
|
al_draw_bitmap(data->bg, 0, 0, 0);
|
||||||
|
al_draw_bitmap(data->monster, data->monster_pos, 10, 0);
|
||||||
al_draw_bitmap(data->cloud,game->viewport.width*data->cloud_position/100, 10 ,0);
|
if (!data->starting) {
|
||||||
|
al_draw_bitmap(data->title, 123, 25 - (pow(sin(data->title_pos), 2) * 16) - data->screen_pos, 0);
|
||||||
al_draw_bitmap(data->forest,0, 0,0);
|
|
||||||
|
|
||||||
al_draw_bitmap(data->grass,0, 0,0);
|
|
||||||
|
|
||||||
DrawCharacter(game, data->cow, al_map_rgb(255,255,255), 0);
|
|
||||||
|
|
||||||
al_draw_bitmap(data->speaker,104, 19,0);
|
|
||||||
|
|
||||||
al_draw_bitmap(data->stage,0, 0,0);
|
|
||||||
|
|
||||||
al_draw_bitmap(data->lines, 100, 136,0);
|
|
||||||
|
|
||||||
al_draw_bitmap(data->cable,0,151,0);
|
|
||||||
|
|
||||||
DrawCharacter(game, data->ego, al_map_rgb(255,255,255), 0);
|
|
||||||
|
|
||||||
if (data->menustate == MENUSTATE_HIDDEN) {
|
|
||||||
|
|
||||||
if (!data->soloactive) {
|
|
||||||
if (data->marky == 0) {
|
|
||||||
al_draw_bitmap(data->marksmall, data->markx, 128, 0);
|
|
||||||
} else if (data->marky == 1) {
|
|
||||||
al_draw_bitmap(data->marksmall, data->markx, 140, 0);
|
|
||||||
} else if (data->marky == 2) {
|
|
||||||
al_draw_bitmap(data->markbig, data->markx, 152, 0);
|
|
||||||
} else if (data->marky == 3) {
|
|
||||||
al_draw_bitmap(data->markbig, data->markx, 166, 0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (data->lightanim) {
|
|
||||||
int offset = -5;
|
|
||||||
if (data->lighty == 1) offset = -3;
|
|
||||||
if (data->lighty == 2) offset = 0;
|
|
||||||
if (data->lighty == 3) offset = 4;
|
|
||||||
al_draw_tinted_bitmap(data->light, al_map_rgba(255, 255, 255,rand() % 256 / 50 * 50) , data->lightx - 171 - (data->lighty < 2 ? 1 : 0), 109+(data->lighty*10) - 143 + offset, 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
DrawBadguys(game, data, 0);
|
DrawMenuState(game, data);
|
||||||
DrawBadguys(game, data, 1);
|
|
||||||
DrawBadguys(game, data, 2);
|
|
||||||
DrawBadguys(game, data, 3);
|
|
||||||
|
|
||||||
if (data->menustate != MENUSTATE_HIDDEN) {
|
|
||||||
DrawTextWithShadow(data->font_title, al_map_rgb(255,255,255), game->viewport.width*0.5, game->viewport.height*0.15, ALLEGRO_ALIGN_CENTRE, data->menustate == MENUSTATE_LOST ? "Radio Edited!" : "Radio Edit");
|
|
||||||
DrawMenuState(game, data);
|
|
||||||
} else {
|
|
||||||
char score[255];
|
|
||||||
snprintf(score, 255, "Score: %d", data->score);
|
|
||||||
DrawTextWithShadow(data->font, al_map_rgb(255,255,255), 2, game->viewport.height - 10, ALLEGRO_ALIGN_LEFT, score);
|
|
||||||
|
|
||||||
if ((data->soloready >= SOLO_MIN) && (data->soloanim <= 30)) {
|
|
||||||
DrawTextWithShadow(data->font, al_map_rgb(255,255,255), game->viewport.width*0.5, game->viewport.height*0.15, ALLEGRO_ALIGN_CENTRE, "Press ENTER to play a solo!");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (data->soloflash) {
|
|
||||||
al_draw_filled_rectangle(0, 0, 320, 180, al_map_rgb(255,255,255));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void AddBadguy(struct Game *game, struct MenuResources* data, int i) {
|
|
||||||
struct Badguy *n = malloc(sizeof(struct Badguy));
|
|
||||||
n->next = NULL;
|
|
||||||
n->prev = NULL;
|
|
||||||
n->speed = (rand() % 3) * 0.25 + 1;
|
|
||||||
n->melting = false;
|
|
||||||
n->character = CreateCharacter(game, "badguy");
|
|
||||||
n->character->spritesheets = data->badguy->spritesheets;
|
|
||||||
n->character->shared = true;
|
|
||||||
SelectSpritesheet(game, n->character, "walk");
|
|
||||||
SetCharacterPosition(game, n->character, 320, 108+(i*13), 0);
|
|
||||||
|
|
||||||
if (data->badguys[i]) {
|
|
||||||
struct Badguy *tmp = data->badguys[i];
|
|
||||||
while (tmp->next) {
|
|
||||||
tmp=tmp->next;
|
|
||||||
}
|
|
||||||
tmp->next = n;
|
|
||||||
n->prev = tmp;
|
|
||||||
} else {
|
|
||||||
data->badguys[i] = n;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void Fire(struct Game *game, struct MenuResources *data) {
|
|
||||||
|
|
||||||
if (data->soloactive) return;
|
|
||||||
|
|
||||||
data->lightx = data->markx;
|
|
||||||
data->lighty = data->marky;
|
|
||||||
data->lightanim=1;
|
|
||||||
data->usage=30;
|
|
||||||
|
|
||||||
int num = rand() % 3;
|
|
||||||
if (((al_get_sample_instance_position(data->music) + 20000) / 44118) % 2 == 1) {
|
|
||||||
num += 3;
|
|
||||||
}
|
|
||||||
al_stop_sample_instance(data->chords[num]);
|
|
||||||
al_play_sample_instance(data->chords[num]);
|
|
||||||
PrintConsole(game, "playing chord nr %d", num);
|
|
||||||
|
|
||||||
struct Badguy *tmp = data->badguys[data->marky];
|
|
||||||
while (tmp) {
|
|
||||||
if (!tmp->melting) {
|
|
||||||
if ((data->markx >= tmp->character->x - 9) && (data->markx <= tmp->character->x + 1)) {
|
|
||||||
data->score += 100 * tmp->speed;
|
|
||||||
SelectSpritesheet(game, tmp->character, "melt");
|
|
||||||
data->soloready++;
|
|
||||||
tmp->melting = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
tmp=tmp->next;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void Gamestate_Logic(struct Game *game, struct MenuResources* data) {
|
void Gamestate_Logic(struct Game *game, struct MenuResources* data) {
|
||||||
|
|
||||||
if (data->keys.lastkey == data->keys.key) {
|
data->title_pos += 0.05;
|
||||||
data->keys.delay = data->keys.lastdelay; // workaround for random bugus UP/DOWN events
|
|
||||||
}
|
|
||||||
|
|
||||||
data->cloud_position-=0.1;
|
if (data->starting) {
|
||||||
if (data->cloud_position<-40) { data->cloud_position=100; PrintConsole(game, "cloud_position"); }
|
data->monster_pos -= 6;
|
||||||
AnimateCharacter(game, data->ego, 1);
|
|
||||||
AnimateCharacter(game, data->cow, 1);
|
if (data->monster_pos < -202) {
|
||||||
|
data->starting = false;
|
||||||
|
LoadGamestate(game, "info");
|
||||||
|
LoadGamestate(game, "level");
|
||||||
|
StartGamestate(game, "info");
|
||||||
|
StopGamestate(game, "menu");
|
||||||
|
}
|
||||||
|
|
||||||
|
} else {
|
||||||
|
data->monster_pos += 6;
|
||||||
|
if (data->monster_pos > 0) {
|
||||||
|
data->monster_pos = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (data->menustate == MENUSTATE_HIDDEN) {
|
if (data->menustate == MENUSTATE_HIDDEN) {
|
||||||
|
data->screen_pos -= (180 - data->screen_pos) / 4 + 1;
|
||||||
if ((data->keys.key) && (data->keys.delay < 3)) {
|
if (data->screen_pos < 0) {
|
||||||
|
data->screen_pos = 0;
|
||||||
if (data->keys.key==ALLEGRO_KEY_UP) {
|
data->invisible = false;
|
||||||
data->marky--;
|
|
||||||
int min = 139-(data->marky*10);
|
|
||||||
int step = 10 - (data->markx - min) / ((320-min)/10);
|
|
||||||
data->markx+= step;
|
|
||||||
if (data->marky < 0) {
|
|
||||||
data->markx-=4*step;
|
|
||||||
data->marky = 3;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (data->keys.key==ALLEGRO_KEY_DOWN) {
|
|
||||||
data->marky++;
|
|
||||||
int min = 139-(data->marky*10);
|
|
||||||
int step = 10 - (data->markx - min) / ((320-min)/10);
|
|
||||||
data->markx-= step;
|
|
||||||
if (data->marky > 3) {
|
|
||||||
data->markx+=4*step;
|
|
||||||
data->marky = 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (data->keys.key==ALLEGRO_KEY_LEFT) {
|
|
||||||
int min = 139-(data->marky*10);
|
|
||||||
data->markx-= data->keys.shift ? 5 : 2;
|
|
||||||
if (data->markx < min) data->markx=min;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (data->keys.key==ALLEGRO_KEY_RIGHT) {
|
|
||||||
int max = 320 - al_get_bitmap_width(data->markbig);
|
|
||||||
if (data->marky < 2) max = 320 - al_get_bitmap_width(data->marksmall);
|
|
||||||
data->markx+= data->keys.shift ? 5 : 2;
|
|
||||||
if (data->markx > max) data->markx=max;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ((data->keys.key==ALLEGRO_KEY_SPACE) && (data->usage==0)) {
|
|
||||||
Fire(game, data);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (data->keys.delay == INT_MIN) data->keys.delay = 45;
|
|
||||||
else data->keys.delay += 4;
|
|
||||||
|
|
||||||
} else if (data->keys.key) {
|
|
||||||
data->keys.delay-=3;
|
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
AnimateBadguys(game, data, 0);
|
data->screen_pos += (data->screen_pos) / 4 + 1;
|
||||||
AnimateBadguys(game, data, 1);
|
if (data->screen_pos > 180) {
|
||||||
AnimateBadguys(game, data, 2);
|
data->screen_pos = 180;
|
||||||
AnimateBadguys(game, data, 3);
|
|
||||||
|
|
||||||
MoveBadguys(game, data, 0, -0.17);
|
|
||||||
MoveBadguys(game, data, 1, -0.18);
|
|
||||||
MoveBadguys(game, data, 2, -0.19);
|
|
||||||
MoveBadguys(game, data, 3, -0.2);
|
|
||||||
|
|
||||||
data->timeTillNextBadguy--;
|
|
||||||
if (data->timeTillNextBadguy <= 0) {
|
|
||||||
data->timeTillNextBadguy = data->badguyRate;
|
|
||||||
data->badguyRate -= data->badguyRate * 0.02;
|
|
||||||
if (data->badguyRate < 20) {
|
|
||||||
data->badguyRate = 20;
|
|
||||||
}
|
|
||||||
|
|
||||||
data->badguySpeed+= 0.001;
|
|
||||||
AddBadguy(game, data, rand() % 4);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (data->usage) { data->usage--; }
|
|
||||||
if (data->lightanim) { data->lightanim++;}
|
|
||||||
if (data->lightanim > 25) { data->lightanim = 0; }
|
|
||||||
|
|
||||||
CheckForEnd(game, data);
|
|
||||||
}
|
|
||||||
|
|
||||||
data->soloanim++;
|
|
||||||
if (data->soloanim >= 60) data->soloanim=0;
|
|
||||||
|
|
||||||
if (data->soloactive) {
|
|
||||||
if (al_get_sample_instance_position(data->solo) >= 163840) {
|
|
||||||
PrintConsole(game, "BLAAAST");
|
|
||||||
data->soloflash = 6;
|
|
||||||
data->soloactive=false;
|
|
||||||
data->badguySpeed+=0.5;
|
|
||||||
data->badguyRate += 20;
|
|
||||||
|
|
||||||
int i;
|
|
||||||
for (i=0; i<4; i++) {
|
|
||||||
struct Badguy *tmp = data->badguys[i];
|
|
||||||
while (tmp) {
|
|
||||||
if ((!tmp->melting) && (!tmp->character->dead)) {
|
|
||||||
data->score += 100 * tmp->speed;
|
|
||||||
SelectSpritesheet(game, tmp->character, "melt");
|
|
||||||
tmp->melting = true;
|
|
||||||
}
|
|
||||||
tmp=tmp->next;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (data->soloflash) data->soloflash--;
|
|
||||||
|
|
||||||
data->keys.lastkey = data->keys.key;
|
|
||||||
data->keys.lastdelay = data->keys.delay;
|
|
||||||
|
|
||||||
TM_Process(data->timeline);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void* Gamestate_Load(struct Game *game, void (*progress)(struct Game*)) {
|
void* Gamestate_Load(struct Game *game, void (*progress)(struct Game*)) {
|
||||||
|
|
||||||
struct MenuResources *data = malloc(sizeof(struct MenuResources));
|
struct MenuResources *data = malloc(sizeof(struct MenuResources));
|
||||||
|
|
||||||
data->timeline = TM_Init(game, "main");
|
|
||||||
(*progress)(game);
|
|
||||||
|
|
||||||
data->options.fullscreen = game->config.fullscreen;
|
data->options.fullscreen = game->config.fullscreen;
|
||||||
data->options.fps = game->config.fps;
|
data->options.fps = game->config.fps;
|
||||||
data->options.width = game->config.width;
|
data->options.width = game->config.width;
|
||||||
data->options.height = game->config.height;
|
data->options.height = game->config.height;
|
||||||
data->options.resolution = game->config.width / 320;
|
data->options.resolution = game->config.width / 320;
|
||||||
if (game->config.height / 180 < data->options.resolution) data->options.resolution = game->config.height / 180;
|
if (game->config.height / 180 < data->options.resolution) data->options.resolution = game->config.height / 180;
|
||||||
|
(*progress)(game);
|
||||||
|
|
||||||
data->bg = al_load_bitmap( GetDataFilePath(game, "bg.png") );
|
data->bg = al_load_bitmap( GetDataFilePath(game, "bg.png") );
|
||||||
data->forest = al_load_bitmap( GetDataFilePath(game, "forest.png") );
|
data->monster = al_load_bitmap( GetDataFilePath(game, "monster.png") );
|
||||||
data->grass = al_load_bitmap( GetDataFilePath(game, "grass.png") );
|
data->title = al_load_bitmap( GetDataFilePath(game, "title.png") );
|
||||||
data->speaker = al_load_bitmap( GetDataFilePath(game, "speaker.png") );
|
(*progress)(game);
|
||||||
data->stage = al_load_bitmap( GetDataFilePath(game, "stage.png") );
|
|
||||||
data->cloud = al_load_bitmap( GetDataFilePath(game, "cloud.png") );
|
data->sample = al_load_sample( GetDataFilePath(game, "monster.flac") );
|
||||||
data->lines = al_load_bitmap( GetDataFilePath(game, "lines.png") );
|
|
||||||
data->cable = al_load_bitmap( GetDataFilePath(game, "cable.png") );
|
|
||||||
data->marksmall = al_load_bitmap( GetDataFilePath(game, "mark-small.png") );
|
|
||||||
data->markbig = al_load_bitmap( GetDataFilePath(game, "mark-big.png") );
|
|
||||||
data->light = al_load_bitmap( GetDataFilePath(game, "light.png") );
|
|
||||||
data->sample = al_load_sample( GetDataFilePath(game, "menu.flac") );
|
|
||||||
data->click_sample = al_load_sample( GetDataFilePath(game, "click.flac") );
|
data->click_sample = al_load_sample( GetDataFilePath(game, "click.flac") );
|
||||||
data->quit_sample = al_load_sample( GetDataFilePath(game, "quit.flac") );
|
|
||||||
data->end_sample = al_load_sample( GetDataFilePath(game, "end.flac") );
|
|
||||||
data->solo_sample = al_load_sample( GetDataFilePath(game, "solo.flac") );
|
|
||||||
(*progress)(game);
|
(*progress)(game);
|
||||||
|
|
||||||
data->music = al_create_sample_instance(data->sample);
|
data->music = al_create_sample_instance(data->sample);
|
||||||
|
@ -511,277 +219,66 @@ void* Gamestate_Load(struct Game *game, void (*progress)(struct Game*)) {
|
||||||
al_attach_sample_instance_to_mixer(data->click, game->audio.fx);
|
al_attach_sample_instance_to_mixer(data->click, game->audio.fx);
|
||||||
al_set_sample_instance_playmode(data->click, ALLEGRO_PLAYMODE_ONCE);
|
al_set_sample_instance_playmode(data->click, ALLEGRO_PLAYMODE_ONCE);
|
||||||
|
|
||||||
data->quit = al_create_sample_instance(data->quit_sample);
|
|
||||||
al_attach_sample_instance_to_mixer(data->quit, game->audio.fx);
|
|
||||||
al_set_sample_instance_playmode(data->quit, ALLEGRO_PLAYMODE_ONCE);
|
|
||||||
|
|
||||||
data->solo = al_create_sample_instance(data->solo_sample);
|
|
||||||
al_attach_sample_instance_to_mixer(data->solo, game->audio.fx);
|
|
||||||
al_set_sample_instance_playmode(data->solo, ALLEGRO_PLAYMODE_ONCE);
|
|
||||||
|
|
||||||
data->end = al_create_sample_instance(data->end_sample);
|
|
||||||
al_attach_sample_instance_to_mixer(data->end, game->audio.fx);
|
|
||||||
al_set_sample_instance_playmode(data->end, ALLEGRO_PLAYMODE_ONCE);
|
|
||||||
|
|
||||||
int i;
|
|
||||||
for (i=0; i<6; i++) {
|
|
||||||
char name[] = "chords/0.flac";
|
|
||||||
name[7] = '1' + i;
|
|
||||||
data->chord_samples[i] = al_load_sample( GetDataFilePath(game, name) );
|
|
||||||
|
|
||||||
data->chords[i] = al_create_sample_instance(data->chord_samples[i]);
|
|
||||||
al_attach_sample_instance_to_mixer(data->chords[i], game->audio.fx);
|
|
||||||
al_set_sample_instance_playmode(data->chords[i], ALLEGRO_PLAYMODE_ONCE);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!data->click_sample){
|
if (!data->click_sample){
|
||||||
fprintf(stderr, "Audio clip sample not loaded!\n" );
|
fprintf(stderr, "Audio clip sample not loaded!\n" );
|
||||||
exit(-1);
|
exit(-1);
|
||||||
}
|
}
|
||||||
(*progress)(game);
|
(*progress)(game);
|
||||||
|
|
||||||
data->font_title = al_load_ttf_font(GetDataFilePath(game, "fonts/MonkeyIsland.ttf"),game->viewport.height*0.16,0 );
|
|
||||||
data->font = al_load_ttf_font(GetDataFilePath(game, "fonts/MonkeyIsland.ttf"),game->viewport.height*0.05,0 );
|
data->font = al_load_ttf_font(GetDataFilePath(game, "fonts/MonkeyIsland.ttf"),game->viewport.height*0.05,0 );
|
||||||
(*progress)(game);
|
|
||||||
|
|
||||||
data->ego = CreateCharacter(game, "ego");
|
|
||||||
RegisterSpritesheet(game, data->ego, "stand");
|
|
||||||
RegisterSpritesheet(game, data->ego, "fix");
|
|
||||||
RegisterSpritesheet(game, data->ego, "fix2");
|
|
||||||
RegisterSpritesheet(game, data->ego, "fix3");
|
|
||||||
RegisterSpritesheet(game, data->ego, "play");
|
|
||||||
RegisterSpritesheet(game, data->ego, "cry");
|
|
||||||
LoadSpritesheets(game, data->ego);
|
|
||||||
|
|
||||||
data->cow = CreateCharacter(game, "cow");
|
|
||||||
RegisterSpritesheet(game, data->cow, "stand");
|
|
||||||
RegisterSpritesheet(game, data->cow, "chew");
|
|
||||||
RegisterSpritesheet(game, data->cow, "look");
|
|
||||||
LoadSpritesheets(game, data->cow);
|
|
||||||
|
|
||||||
data->badguy = CreateCharacter(game, "badguy");
|
|
||||||
RegisterSpritesheet(game, data->badguy, "walk");
|
|
||||||
RegisterSpritesheet(game, data->badguy, "melt");
|
|
||||||
LoadSpritesheets(game, data->badguy);
|
|
||||||
(*progress)(game);
|
|
||||||
|
|
||||||
al_set_target_backbuffer(game->display);
|
al_set_target_backbuffer(game->display);
|
||||||
return data;
|
return data;
|
||||||
}
|
}
|
||||||
|
|
||||||
void DestroyBadguys(struct Game *game, struct MenuResources* data, int i) {
|
|
||||||
struct Badguy *tmp = data->badguys[i];
|
|
||||||
if (!tmp) {
|
|
||||||
tmp = data->destroyQueue;
|
|
||||||
data->destroyQueue = NULL;
|
|
||||||
}
|
|
||||||
while (tmp) {
|
|
||||||
DestroyCharacter(game, tmp->character);
|
|
||||||
struct Badguy *old = tmp;
|
|
||||||
tmp = tmp->next;
|
|
||||||
free(old);
|
|
||||||
if ((!tmp) && (data->destroyQueue)) {
|
|
||||||
tmp = data->destroyQueue;
|
|
||||||
data->destroyQueue = NULL;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
data->badguys[i] = NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
void Gamestate_Stop(struct Game *game, struct MenuResources* data) {
|
void Gamestate_Stop(struct Game *game, struct MenuResources* data) {
|
||||||
al_stop_sample_instance(data->music);
|
//al_stop_sample_instance(data->music);
|
||||||
|
|
||||||
int i;
|
|
||||||
for (i=0; i<4; i++) {
|
|
||||||
DestroyBadguys(game, data, i);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void Gamestate_Unload(struct Game *game, struct MenuResources* data) {
|
void Gamestate_Unload(struct Game *game, struct MenuResources* data) {
|
||||||
if (game->config.fx) {
|
al_stop_sample_instance(data->music);
|
||||||
al_clear_to_color(al_map_rgb(0,0,0));
|
|
||||||
DrawConsole(game);
|
|
||||||
al_flip_display();
|
|
||||||
al_play_sample_instance(data->quit);
|
|
||||||
al_rest(0.3);
|
|
||||||
int i;
|
|
||||||
for (i=0;i<50; i++) {
|
|
||||||
al_rest(0.05);
|
|
||||||
ALLEGRO_KEYBOARD_STATE kb;
|
|
||||||
al_get_keyboard_state(&kb);
|
|
||||||
if (al_key_down(&kb, ALLEGRO_KEY_ESCAPE)) return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
al_destroy_bitmap(data->bg);
|
al_destroy_bitmap(data->bg);
|
||||||
al_destroy_bitmap(data->cloud);
|
al_destroy_bitmap(data->title);
|
||||||
al_destroy_bitmap(data->grass);
|
al_destroy_bitmap(data->monster);
|
||||||
al_destroy_bitmap(data->forest);
|
|
||||||
al_destroy_bitmap(data->stage);
|
|
||||||
al_destroy_bitmap(data->speaker);
|
|
||||||
al_destroy_bitmap(data->lines);
|
|
||||||
al_destroy_bitmap(data->cable);
|
|
||||||
al_destroy_bitmap(data->light);
|
|
||||||
al_destroy_bitmap(data->marksmall);
|
|
||||||
al_destroy_bitmap(data->markbig);
|
|
||||||
al_destroy_font(data->font_title);
|
|
||||||
al_destroy_font(data->font);
|
al_destroy_font(data->font);
|
||||||
al_destroy_sample_instance(data->music);
|
//al_destroy_sample_instance(data->music);
|
||||||
al_destroy_sample_instance(data->click);
|
al_destroy_sample_instance(data->click);
|
||||||
al_destroy_sample_instance(data->end);
|
//al_destroy_sample(data->sample);
|
||||||
al_destroy_sample_instance(data->quit);
|
|
||||||
al_destroy_sample_instance(data->solo);
|
|
||||||
al_destroy_sample(data->sample);
|
|
||||||
al_destroy_sample(data->click_sample);
|
al_destroy_sample(data->click_sample);
|
||||||
al_destroy_sample(data->quit_sample);
|
|
||||||
al_destroy_sample(data->end_sample);
|
|
||||||
al_destroy_sample(data->solo_sample);
|
|
||||||
int i;
|
|
||||||
for (i=0; i<6; i++) {
|
|
||||||
al_destroy_sample_instance(data->chords[i]);
|
|
||||||
al_destroy_sample(data->chord_samples[i]);
|
|
||||||
}
|
|
||||||
DestroyCharacter(game, data->ego);
|
|
||||||
DestroyCharacter(game, data->cow);
|
|
||||||
DestroyCharacter(game, data->badguy);
|
|
||||||
TM_Destroy(data->timeline);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO: refactor to single Enqueue_Anim
|
|
||||||
bool Anim_CowLook(struct Game *game, struct TM_Action *action, enum TM_ActionState state) {
|
|
||||||
struct MenuResources *data = action->arguments->value;
|
|
||||||
if (state == TM_ACTIONSTATE_START) {
|
|
||||||
ChangeSpritesheet(game, data->cow, "look");
|
|
||||||
TM_AddQueuedBackgroundAction(data->timeline, &Anim_CowLook, TM_AddToArgs(NULL, 1, data), 54*1000, "cow_look");
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
void StartGame(struct Game *game, struct MenuResources *data) {
|
void StartGame(struct Game *game, struct MenuResources *data) {
|
||||||
TM_CleanQueue(data->timeline);
|
|
||||||
TM_CleanBackgroundQueue(data->timeline);
|
|
||||||
ChangeSpritesheet(game, data->ego, "play");
|
|
||||||
ChangeSpritesheet(game, data->cow, "chew");
|
|
||||||
ChangeMenuState(game,data,MENUSTATE_HIDDEN);
|
ChangeMenuState(game,data,MENUSTATE_HIDDEN);
|
||||||
al_play_sample_instance(data->chords[0]);
|
data->starting = true;
|
||||||
}
|
|
||||||
|
|
||||||
bool Anim_FixGuitar(struct Game *game, struct TM_Action *action, enum TM_ActionState state) {
|
|
||||||
struct MenuResources *data = action->arguments->value;
|
|
||||||
if (state == TM_ACTIONSTATE_START) {
|
|
||||||
ChangeSpritesheet(game, data->ego, "fix");
|
|
||||||
TM_AddQueuedBackgroundAction(data->timeline, &Anim_FixGuitar, TM_AddToArgs(NULL, 1, data), 30*1000, "fix_guitar");
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void Gamestate_Start(struct Game *game, struct MenuResources* data) {
|
void Gamestate_Start(struct Game *game, struct MenuResources* data) {
|
||||||
data->cloud_position = 100;
|
|
||||||
SetCharacterPosition(game, data->ego, 22, 107, 0);
|
|
||||||
SetCharacterPosition(game, data->cow, 35, 88, 0);
|
|
||||||
|
|
||||||
data->score = 0;
|
data->title_pos = 0;
|
||||||
|
data->screen_pos = 180;
|
||||||
|
data->invisible = true;
|
||||||
|
data->monster_pos = -202;
|
||||||
|
data->starting = false;
|
||||||
|
|
||||||
data->markx = 119;
|
ChangeMenuState(game,data,MENUSTATE_HIDDEN);
|
||||||
data->marky = 2;
|
|
||||||
|
|
||||||
data->soloactive = false;
|
|
||||||
data->soloanim = 0;
|
|
||||||
data->soloflash = 0;
|
|
||||||
data->soloready = 0;
|
|
||||||
|
|
||||||
data->keys.key = 0;
|
|
||||||
data->keys.delay = 0;
|
|
||||||
data->keys.shift = false;
|
|
||||||
data->keys.lastkey = -1;
|
|
||||||
|
|
||||||
data->lightanim=0;
|
|
||||||
|
|
||||||
data->badguySpeed = 1.2;
|
|
||||||
|
|
||||||
data->usage = 0;
|
|
||||||
|
|
||||||
SelectSpritesheet(game, data->ego, "stand");
|
|
||||||
SelectSpritesheet(game, data->cow, "chew");
|
|
||||||
ChangeMenuState(game,data,MENUSTATE_MAIN);
|
|
||||||
TM_AddQueuedBackgroundAction(data->timeline, &Anim_FixGuitar, TM_AddToArgs(NULL, 1, data), 15*1000, "fix_guitar");
|
|
||||||
TM_AddQueuedBackgroundAction(data->timeline, &Anim_CowLook, TM_AddToArgs(NULL, 1, data), 5*1000, "cow_look");
|
|
||||||
al_play_sample_instance(data->music);
|
al_play_sample_instance(data->music);
|
||||||
al_rest(0.01); // poor man's synchronization
|
|
||||||
|
|
||||||
data->badguys[0] = NULL;
|
|
||||||
data->badguys[1] = NULL;
|
|
||||||
data->badguys[2] = NULL;
|
|
||||||
data->badguys[3] = NULL;
|
|
||||||
data->destroyQueue = NULL;
|
|
||||||
|
|
||||||
data->badguyRate = 100;
|
|
||||||
data->timeTillNextBadguy = 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void Gamestate_ProcessEvent(struct Game *game, struct MenuResources* data, ALLEGRO_EVENT *ev) {
|
void Gamestate_ProcessEvent(struct Game *game, struct MenuResources* data, ALLEGRO_EVENT *ev) {
|
||||||
TM_HandleEvent(data->timeline, ev);
|
|
||||||
|
|
||||||
if ((data->menustate == MENUSTATE_ABOUT) && (ev->type == ALLEGRO_EVENT_KEY_DOWN)) {
|
if ((data->menustate == MENUSTATE_ABOUT) && (ev->type == ALLEGRO_EVENT_KEY_DOWN)) {
|
||||||
ChangeMenuState(game, data, MENUSTATE_MAIN);
|
ChangeMenuState(game, data, MENUSTATE_MAIN);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (data->menustate == MENUSTATE_HIDDEN) {
|
|
||||||
|
|
||||||
if (ev->type == ALLEGRO_EVENT_KEY_DOWN) {
|
|
||||||
|
|
||||||
switch (ev->keyboard.keycode) {
|
|
||||||
case ALLEGRO_KEY_UP:
|
|
||||||
case ALLEGRO_KEY_DOWN:
|
|
||||||
case ALLEGRO_KEY_LEFT:
|
|
||||||
case ALLEGRO_KEY_RIGHT:
|
|
||||||
case ALLEGRO_KEY_SPACE:
|
|
||||||
if (data->keys.key != ev->keyboard.keycode) {
|
|
||||||
data->keys.key = ev->keyboard.keycode;
|
|
||||||
data->keys.delay = INT_MIN;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case ALLEGRO_KEY_ESCAPE:
|
|
||||||
Gamestate_Stop(game, data);
|
|
||||||
Gamestate_Start(game, data);
|
|
||||||
break;
|
|
||||||
case ALLEGRO_KEY_LSHIFT:
|
|
||||||
case ALLEGRO_KEY_RSHIFT:
|
|
||||||
data->keys.shift = true;
|
|
||||||
break;
|
|
||||||
case ALLEGRO_KEY_ENTER:
|
|
||||||
if ((!data->soloactive) && (data->soloready >= SOLO_MIN)) {
|
|
||||||
data->soloready = 0;
|
|
||||||
al_play_sample_instance(data->solo);
|
|
||||||
data->soloactive = true;
|
|
||||||
data->badguySpeed-=0.5;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
data->keys.key = 0;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
} else if (ev->type == ALLEGRO_EVENT_KEY_UP) {
|
|
||||||
switch (ev->keyboard.keycode) {
|
|
||||||
case ALLEGRO_KEY_LSHIFT:
|
|
||||||
case ALLEGRO_KEY_RSHIFT:
|
|
||||||
data->keys.shift = false;
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
if (ev->keyboard.keycode == data->keys.key) {
|
|
||||||
data->keys.key = 0;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (ev->type != ALLEGRO_EVENT_KEY_DOWN) return;
|
if (ev->type != ALLEGRO_EVENT_KEY_DOWN) return;
|
||||||
|
|
||||||
|
if (data->starting) return;
|
||||||
|
|
||||||
if (ev->keyboard.keycode==ALLEGRO_KEY_UP) {
|
if (ev->keyboard.keycode==ALLEGRO_KEY_UP) {
|
||||||
data->selected--;
|
data->selected--;
|
||||||
if ((data->selected == 2) && ((data->menustate==MENUSTATE_VIDEO) || (data->menustate==MENUSTATE_OPTIONS) || (data->menustate==MENUSTATE_AUDIO))) {
|
if ((data->selected == 2) && ((data->menustate==MENUSTATE_VIDEO) || (data->menustate==MENUSTATE_OPTIONS) || (data->menustate==MENUSTATE_AUDIO))) {
|
||||||
|
@ -807,7 +304,7 @@ void Gamestate_ProcessEvent(struct Game *game, struct MenuResources* data, ALLEG
|
||||||
case MENUSTATE_MAIN:
|
case MENUSTATE_MAIN:
|
||||||
switch (data->selected) {
|
switch (data->selected) {
|
||||||
case 0:
|
case 0:
|
||||||
ChangeMenuState(game,data,MENUSTATE_INTRO);
|
StartGame(game, data);
|
||||||
break;
|
break;
|
||||||
case 1:
|
case 1:
|
||||||
ChangeMenuState(game,data,MENUSTATE_OPTIONS);
|
ChangeMenuState(game,data,MENUSTATE_OPTIONS);
|
||||||
|
@ -820,6 +317,9 @@ void Gamestate_ProcessEvent(struct Game *game, struct MenuResources* data, ALLEG
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
case MENUSTATE_HIDDEN:
|
||||||
|
ChangeMenuState(game,data,MENUSTATE_MAIN);
|
||||||
|
break;
|
||||||
case MENUSTATE_AUDIO:
|
case MENUSTATE_AUDIO:
|
||||||
text = malloc(255*sizeof(char));
|
text = malloc(255*sizeof(char));
|
||||||
switch (data->selected) {
|
switch (data->selected) {
|
||||||
|
@ -921,13 +421,6 @@ void Gamestate_ProcessEvent(struct Game *game, struct MenuResources* data, ALLEG
|
||||||
break;
|
break;
|
||||||
case MENUSTATE_ABOUT:
|
case MENUSTATE_ABOUT:
|
||||||
break;
|
break;
|
||||||
case MENUSTATE_INTRO:
|
|
||||||
StartGame(game, data);
|
|
||||||
break;
|
|
||||||
case MENUSTATE_LOST:
|
|
||||||
Gamestate_Stop(game,data);
|
|
||||||
Gamestate_Start(game,data);
|
|
||||||
break;
|
|
||||||
default:
|
default:
|
||||||
UnloadGamestate(game, "menu");
|
UnloadGamestate(game, "menu");
|
||||||
return;
|
return;
|
||||||
|
@ -942,8 +435,7 @@ void Gamestate_ProcessEvent(struct Game *game, struct MenuResources* data, ALLEG
|
||||||
ChangeMenuState(game,data,MENUSTATE_MAIN);
|
ChangeMenuState(game,data,MENUSTATE_MAIN);
|
||||||
break;
|
break;
|
||||||
case MENUSTATE_HIDDEN:
|
case MENUSTATE_HIDDEN:
|
||||||
Gamestate_Stop(game,data);
|
UnloadGamestate(game, "menu");
|
||||||
Gamestate_Start(game,data);
|
|
||||||
break;
|
break;
|
||||||
case MENUSTATE_VIDEO:
|
case MENUSTATE_VIDEO:
|
||||||
ChangeMenuState(game,data,MENUSTATE_OPTIONS);
|
ChangeMenuState(game,data,MENUSTATE_OPTIONS);
|
||||||
|
@ -951,15 +443,10 @@ void Gamestate_ProcessEvent(struct Game *game, struct MenuResources* data, ALLEG
|
||||||
case MENUSTATE_AUDIO:
|
case MENUSTATE_AUDIO:
|
||||||
ChangeMenuState(game,data,MENUSTATE_OPTIONS);
|
ChangeMenuState(game,data,MENUSTATE_OPTIONS);
|
||||||
break;
|
break;
|
||||||
case MENUSTATE_INTRO:
|
|
||||||
ChangeMenuState(game,data,MENUSTATE_MAIN);
|
|
||||||
break;
|
|
||||||
case MENUSTATE_LOST:
|
|
||||||
Gamestate_Stop(game,data);
|
|
||||||
Gamestate_Start(game,data);
|
|
||||||
break;
|
|
||||||
default:
|
default:
|
||||||
UnloadGamestate(game, "menu");
|
ChangeMenuState(game,data,MENUSTATE_HIDDEN);
|
||||||
|
data->selected = -1;
|
||||||
|
data->title_pos = 0;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -25,70 +25,30 @@
|
||||||
|
|
||||||
/*! \brief Enum of menu states in Menu and Pause game states. */
|
/*! \brief Enum of menu states in Menu and Pause game states. */
|
||||||
enum menustate_enum {
|
enum menustate_enum {
|
||||||
|
MENUSTATE_HIDDEN,
|
||||||
MENUSTATE_MAIN,
|
MENUSTATE_MAIN,
|
||||||
MENUSTATE_OPTIONS,
|
MENUSTATE_OPTIONS,
|
||||||
MENUSTATE_VIDEO,
|
MENUSTATE_VIDEO,
|
||||||
MENUSTATE_AUDIO,
|
MENUSTATE_AUDIO,
|
||||||
MENUSTATE_HIDDEN,
|
MENUSTATE_ABOUT
|
||||||
MENUSTATE_ABOUT,
|
|
||||||
MENUSTATE_LOST,
|
|
||||||
MENUSTATE_INTRO,
|
|
||||||
// FIXME: menustate abuse eeeeew
|
|
||||||
};
|
};
|
||||||
|
|
||||||
/*! \brief Resources used by Menu state. */
|
/*! \brief Resources used by Menu state. */
|
||||||
struct MenuResources {
|
struct MenuResources {
|
||||||
ALLEGRO_BITMAP *bg; /*!< Bitmap with lower portion of menu landscape. */
|
ALLEGRO_BITMAP *bg;
|
||||||
ALLEGRO_BITMAP *cloud; /*!< Bitmap with bigger cloud. */
|
ALLEGRO_BITMAP *monster; /*!< Bitmap with bigger cloud. */
|
||||||
ALLEGRO_BITMAP *grass;
|
ALLEGRO_BITMAP *title;
|
||||||
ALLEGRO_BITMAP *forest;
|
|
||||||
ALLEGRO_BITMAP *stage;
|
|
||||||
ALLEGRO_BITMAP *speaker;
|
|
||||||
ALLEGRO_BITMAP *lines;
|
|
||||||
ALLEGRO_BITMAP *cable;
|
|
||||||
ALLEGRO_BITMAP *light;
|
|
||||||
|
|
||||||
ALLEGRO_BITMAP *marksmall;
|
double title_pos;
|
||||||
ALLEGRO_BITMAP *markbig;
|
int screen_pos;
|
||||||
int markx, marky;
|
bool invisible;
|
||||||
|
int monster_pos;
|
||||||
|
bool starting;
|
||||||
|
|
||||||
float badguySpeed;
|
|
||||||
|
|
||||||
ALLEGRO_SAMPLE *chord_samples[6];
|
|
||||||
ALLEGRO_SAMPLE_INSTANCE *chords[6];
|
|
||||||
// 0-2: low; 3-5: high
|
|
||||||
|
|
||||||
int usage;
|
|
||||||
int lightx, lighty, lightanim;
|
|
||||||
|
|
||||||
int soloready, soloanim, soloflash;
|
|
||||||
bool soloactive;
|
|
||||||
|
|
||||||
struct Badguy {
|
|
||||||
struct Character *character;
|
|
||||||
struct Badguy *next, *prev;
|
|
||||||
float speed;
|
|
||||||
bool melting;
|
|
||||||
} *badguys[4], *destroyQueue;
|
|
||||||
|
|
||||||
int timeTillNextBadguy, badguyRate;
|
|
||||||
|
|
||||||
struct Character *ego;
|
|
||||||
struct Character *cow;
|
|
||||||
struct Character *badguy;
|
|
||||||
struct Timeline *timeline;
|
|
||||||
float cloud_position; /*!< Position of bigger cloud. */
|
|
||||||
ALLEGRO_SAMPLE *sample; /*!< Music sample. */
|
ALLEGRO_SAMPLE *sample; /*!< Music sample. */
|
||||||
ALLEGRO_SAMPLE *click_sample; /*!< Click sound sample. */
|
ALLEGRO_SAMPLE *click_sample; /*!< Click sound sample. */
|
||||||
ALLEGRO_SAMPLE *quit_sample;
|
|
||||||
ALLEGRO_SAMPLE *end_sample;
|
|
||||||
ALLEGRO_SAMPLE *solo_sample;
|
|
||||||
ALLEGRO_SAMPLE_INSTANCE *music; /*!< Sample instance with music sound. */
|
ALLEGRO_SAMPLE_INSTANCE *music; /*!< Sample instance with music sound. */
|
||||||
ALLEGRO_SAMPLE_INSTANCE *click; /*!< Sample instance with click sound. */
|
ALLEGRO_SAMPLE_INSTANCE *click; /*!< Sample instance with click sound. */
|
||||||
ALLEGRO_SAMPLE_INSTANCE *quit;
|
|
||||||
ALLEGRO_SAMPLE_INSTANCE *solo;
|
|
||||||
ALLEGRO_SAMPLE_INSTANCE *end;
|
|
||||||
ALLEGRO_FONT *font_title; /*!< Font of "Super Derpy" text. */
|
|
||||||
ALLEGRO_FONT *font; /*!< Font of standard menu item. */
|
ALLEGRO_FONT *font; /*!< Font of standard menu item. */
|
||||||
int selected; /*!< Number of selected menu item. */
|
int selected; /*!< Number of selected menu item. */
|
||||||
enum menustate_enum menustate; /*!< Current menu page. */
|
enum menustate_enum menustate; /*!< Current menu page. */
|
||||||
|
@ -100,14 +60,4 @@ struct MenuResources {
|
||||||
int resolution;
|
int resolution;
|
||||||
} options; /*!< Options which can be changed in menu. */
|
} options; /*!< Options which can be changed in menu. */
|
||||||
|
|
||||||
struct {
|
|
||||||
int key;
|
|
||||||
bool shift;
|
|
||||||
int delay;
|
|
||||||
// workaround for random bogus UP/DOWN events
|
|
||||||
int lastkey;
|
|
||||||
int lastdelay;
|
|
||||||
} keys;
|
|
||||||
|
|
||||||
int score;
|
|
||||||
};
|
};
|
||||||
|
|
14
src/main.c
14
src/main.c
|
@ -78,7 +78,7 @@ int main(int argc, char **argv){
|
||||||
srand(time(NULL));
|
srand(time(NULL));
|
||||||
|
|
||||||
al_set_org_name("Super Derpy");
|
al_set_org_name("Super Derpy");
|
||||||
al_set_app_name("Radio Edit");
|
al_set_app_name("Tickle Monster");
|
||||||
|
|
||||||
if(!al_init()) {
|
if(!al_init()) {
|
||||||
fprintf(stderr, "failed to initialize allegro!\n");
|
fprintf(stderr, "failed to initialize allegro!\n");
|
||||||
|
@ -158,8 +158,8 @@ int main(int argc, char **argv){
|
||||||
|
|
||||||
PrintConsole(&game, "Viewport %dx%d", game.viewport.width, game.viewport.height);
|
PrintConsole(&game, "Viewport %dx%d", game.viewport.width, game.viewport.height);
|
||||||
|
|
||||||
ALLEGRO_BITMAP *icon = al_load_bitmap(GetDataFilePath(&game, "icons/radioedit.png"));
|
ALLEGRO_BITMAP *icon = al_load_bitmap(GetDataFilePath(&game, "icons/ticklemonster.png"));
|
||||||
al_set_window_title(game.display, "Radio Edit");
|
al_set_window_title(game.display, "Tickle Monster vs Suits");
|
||||||
al_set_display_icon(game.display, icon);
|
al_set_display_icon(game.display, icon);
|
||||||
al_destroy_bitmap(icon);
|
al_destroy_bitmap(icon);
|
||||||
|
|
||||||
|
@ -233,7 +233,7 @@ int main(int argc, char **argv){
|
||||||
free(gamestate);
|
free(gamestate);
|
||||||
|
|
||||||
char libname[1024] = {};
|
char libname[1024] = {};
|
||||||
snprintf(libname, 1024, "libsuperderpy-%s-loading" LIBRARY_EXTENTION, "radioedit");
|
snprintf(libname, 1024, "libsuperderpy-%s-loading" LIBRARY_EXTENTION, "ticklemonster");
|
||||||
void *handle = dlopen(libname, RTLD_NOW);
|
void *handle = dlopen(libname, RTLD_NOW);
|
||||||
if (!handle) {
|
if (!handle) {
|
||||||
FatalError(&game, true, "Error while initializing loading screen %s", dlerror());
|
FatalError(&game, true, "Error while initializing loading screen %s", dlerror());
|
||||||
|
@ -293,11 +293,11 @@ int main(int argc, char **argv){
|
||||||
al_stop_timer(game._priv.timer);
|
al_stop_timer(game._priv.timer);
|
||||||
// TODO: take proper game name
|
// TODO: take proper game name
|
||||||
char libname[1024];
|
char libname[1024];
|
||||||
snprintf(libname, 1024, "libsuperderpy-%s-%s" LIBRARY_EXTENTION, "radioedit", tmp->name);
|
snprintf(libname, 1024, "libsuperderpy-%s-%s" LIBRARY_EXTENTION, "ticklemonster", tmp->name);
|
||||||
tmp->handle = dlopen(libname,RTLD_NOW);
|
tmp->handle = dlopen(libname,RTLD_NOW);
|
||||||
if (!tmp->handle) {
|
if (!tmp->handle) {
|
||||||
//PrintConsole(&game, "Error while loading gamestate \"%s\": %s", tmp->name, dlerror());
|
//PrintConsole(&game, "Error while loading gamestate \"%s\": %s", tmp->name, dlerror());
|
||||||
FatalError(&game, true, "Error while loading gamestate \"%s\": %s", tmp->name, dlerror());
|
FatalError(&game, false, "Error while loading gamestate \"%s\": %s", tmp->name, dlerror());
|
||||||
|
|
||||||
tmp->pending_load = false;
|
tmp->pending_load = false;
|
||||||
tmp->pending_start = false;
|
tmp->pending_start = false;
|
||||||
|
@ -423,7 +423,7 @@ int main(int argc, char **argv){
|
||||||
} else if ((ev.type == ALLEGRO_EVENT_KEY_DOWN) && (game.config.debug) && (ev.keyboard.keycode == ALLEGRO_KEY_F12)) {
|
} else if ((ev.type == ALLEGRO_EVENT_KEY_DOWN) && (game.config.debug) && (ev.keyboard.keycode == ALLEGRO_KEY_F12)) {
|
||||||
ALLEGRO_PATH *path = al_get_standard_path(ALLEGRO_USER_DOCUMENTS_PATH);
|
ALLEGRO_PATH *path = al_get_standard_path(ALLEGRO_USER_DOCUMENTS_PATH);
|
||||||
char filename[255] = { };
|
char filename[255] = { };
|
||||||
snprintf(filename, 255, "RadioEdit_%ld_%ld.png", time(NULL), clock());
|
snprintf(filename, 255, "TickleMonster_%ld_%ld.png", time(NULL), clock());
|
||||||
al_set_path_filename(path, filename);
|
al_set_path_filename(path, filename);
|
||||||
al_save_bitmap(al_path_cstr(path, ALLEGRO_NATIVE_PATH_SEP), al_get_backbuffer(game.display));
|
al_save_bitmap(al_path_cstr(path, ALLEGRO_NATIVE_PATH_SEP), al_get_backbuffer(game.display));
|
||||||
PrintConsole(&game, "Screenshot stored in %s", al_path_cstr(path, ALLEGRO_NATIVE_PATH_SEP));
|
PrintConsole(&game, "Screenshot stored in %s", al_path_cstr(path, ALLEGRO_NATIVE_PATH_SEP));
|
||||||
|
|
|
@ -237,7 +237,7 @@ void FatalError(struct Game *game, bool fatal, char* format, ...) {
|
||||||
al_set_target_backbuffer(game->display);
|
al_set_target_backbuffer(game->display);
|
||||||
al_clear_to_color(al_map_rgb(0,0,170));
|
al_clear_to_color(al_map_rgb(0,0,170));
|
||||||
|
|
||||||
char *header = "RADIO EDIT";
|
char *header = "TICKLE MONSTER";
|
||||||
|
|
||||||
al_draw_filled_rectangle(al_get_display_width(game->display)/2 - al_get_text_width(game->_priv.font_bsod, header)/2 - 4, (int)(al_get_display_height(game->display) * 0.32), 4 + al_get_display_width(game->display)/2 + al_get_text_width(game->_priv.font_bsod, header)/2, (int)(al_get_display_height(game->display) * 0.32) + al_get_font_line_height(game->_priv.font_bsod), al_map_rgb(170,170,170));
|
al_draw_filled_rectangle(al_get_display_width(game->display)/2 - al_get_text_width(game->_priv.font_bsod, header)/2 - 4, (int)(al_get_display_height(game->display) * 0.32), 4 + al_get_display_width(game->display)/2 + al_get_text_width(game->_priv.font_bsod, header)/2, (int)(al_get_display_height(game->display) * 0.32) + al_get_font_line_height(game->_priv.font_bsod), al_map_rgb(170,170,170));
|
||||||
|
|
||||||
|
@ -271,7 +271,7 @@ void FatalError(struct Game *game, bool fatal, char* format, ...) {
|
||||||
al_get_keyboard_state(&kb);
|
al_get_keyboard_state(&kb);
|
||||||
|
|
||||||
int i;
|
int i;
|
||||||
for (i=0; i<ALLEGRO_KEY_MAX; i++) {
|
for (i=0; i<ALLEGRO_KEY_PAUSE; i++) {
|
||||||
if (al_key_down(&kb, i)) {
|
if (al_key_down(&kb, i)) {
|
||||||
done = true;
|
done = true;
|
||||||
break;
|
break;
|
||||||
|
@ -317,7 +317,7 @@ char* GetDataFilePath(struct Game *game, char* filename) {
|
||||||
}
|
}
|
||||||
|
|
||||||
TestPath(filename, "data/", &result);
|
TestPath(filename, "data/", &result);
|
||||||
TestPath(filename, "../share/radioedit/data/", &result);
|
TestPath(filename, "../share/ticklemonster/data/", &result);
|
||||||
TestPath(filename, "../data/", &result);
|
TestPath(filename, "../data/", &result);
|
||||||
#ifdef ALLEGRO_MACOSX
|
#ifdef ALLEGRO_MACOSX
|
||||||
TestPath(filename, "../Resources/data/", &result);
|
TestPath(filename, "../Resources/data/", &result);
|
||||||
|
|
Loading…
Reference in a new issue