libsuperderpy/src/level.c

252 lines
9.2 KiB
C
Raw Normal View History

2012-02-28 13:09:12 +01:00
/*! \file level.c
* \brief Playable Level code.
*/
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-22 12:43:14 +01:00
#include <stdio.h>
#include "moonwalk.h"
#include "config.h"
#include "pause.h"
2012-02-22 12:43:14 +01:00
#include "level.h"
2012-04-06 23:32:15 +02:00
#include "timeline.h"
void Level_Passed(struct Game *game) {
if (game->level.current_level<6) {
int available = atoi(GetConfigOptionDefault("MuffinAttack", "level", "1"));
available++;
if ((available<2) || (available>7)) available=1;
if (available==(game->level.current_level+1)) {
char* text = malloc(2*sizeof(char));
sprintf(text, "%d", available);
SetConfigOption("MuffinAttack", "level", text);
free(text);
}
} else {
SetConfigOption("MuffinAttack", "completed", "1");
}
}
2012-04-08 19:01:30 +02:00
bool Accelerate(struct Game *game, struct TM_Action *action, enum TM_ActionState state) {
if (state != TM_ACTIONSTATE_RUNNING) return false;
game->level.speed+=0.000001;
if (game->level.speed<0.0025) return false;
return true;
}
2012-02-22 12:43:14 +01:00
void Level_Draw(struct Game *game) {
if (game->level.current_level!=1) Moonwalk_Draw(game);
else {
2012-04-08 19:01:30 +02:00
al_clear_to_color(al_map_rgb(0,0,0));
al_draw_bitmap(game->level.clouds, (-game->level.cl_pos)*al_get_bitmap_width(game->level.clouds), 0, 0);
al_draw_bitmap(game->level.clouds, (1+(-game->level.cl_pos))*al_get_bitmap_width(game->level.clouds), 0, 0);
al_draw_bitmap(game->level.background, (-game->level.bg_pos)*al_get_bitmap_width(game->level.background), 0, 0);
al_draw_bitmap(game->level.background, (1+(-game->level.bg_pos))*al_get_bitmap_width(game->level.background), 0, 0);
al_draw_bitmap(game->level.stage, (-game->level.st_pos)*al_get_bitmap_width(game->level.stage), 0 ,0);
al_draw_bitmap(game->level.stage, (1+(-game->level.st_pos))*al_get_bitmap_width(game->level.stage), 0 ,0);
al_draw_bitmap(game->level.foreground, (-game->level.fg_pos)*al_get_bitmap_width(game->level.foreground), 0 ,0);
al_draw_bitmap(game->level.foreground, (1+(-game->level.fg_pos))*al_get_bitmap_width(game->level.foreground), 0 ,0);
if (game->level.speed > 0) {
game->level.cl_pos += game->level.speed * 0.6;
game->level.bg_pos += game->level.speed * 0.6;
game->level.st_pos += game->level.speed * 1;
game->level.fg_pos += game->level.speed * 1.75;
if (game->level.cl_pos >= 1) game->level.cl_pos=1-game->level.cl_pos;
if (game->level.bg_pos >= 1) game->level.bg_pos=1-game->level.bg_pos;
if (game->level.st_pos >= 1) game->level.st_pos=1-game->level.st_pos;
if (game->level.fg_pos >= 1) game->level.fg_pos=1-game->level.fg_pos;
}
game->level.cl_pos += 0.0001;
2012-04-06 23:32:15 +02:00
TM_Process();
}
2012-02-22 12:43:14 +01:00
}
2012-04-07 13:33:04 +02:00
bool FadeIn(struct Game *game, struct TM_Action *action, enum TM_ActionState state) {
if (!action->arguments) {
2012-04-07 20:32:47 +02:00
action->arguments = TM_AddToArgs(action->arguments, malloc(sizeof(float)));
action->arguments = TM_AddToArgs(action->arguments, (void*)al_create_bitmap(al_get_display_width(game->display), al_get_display_height(game->display)));
2012-04-07 13:33:04 +02:00
}
float* fadeloop;
ALLEGRO_BITMAP* fade_bitmap;
fadeloop = (float*)action->arguments->value;
fade_bitmap = (ALLEGRO_BITMAP*)action->arguments->next->value;
if (state == TM_ACTIONSTATE_INIT) {
*fadeloop = 255;
al_set_target_bitmap(fade_bitmap);
al_clear_to_color(al_map_rgb(0,0,0));
al_set_target_bitmap(al_get_backbuffer(game->display));
} else if (state == TM_ACTIONSTATE_RUNNING) {
al_draw_tinted_bitmap(fade_bitmap,al_map_rgba_f(1,1,1,*fadeloop/255.0),0,0,0);
*fadeloop-=tps(game, 600);
if (*fadeloop<=0) return true;
} else {
al_destroy_bitmap(fade_bitmap);
free(fadeloop);
2012-04-07 18:32:47 +02:00
TM_DestroyArgs(action->arguments);
2012-04-07 18:41:39 +02:00
action->arguments = NULL;
2012-04-07 13:33:04 +02:00
}
return false;
}
bool FadeOut(struct Game *game, struct TM_Action *action, enum TM_ActionState state) {
if (!action->arguments) {
2012-04-07 20:32:47 +02:00
action->arguments = TM_AddToArgs(action->arguments, malloc(sizeof(float)));
action->arguments = TM_AddToArgs(action->arguments, (void*)al_create_bitmap(al_get_display_width(game->display), al_get_display_height(game->display)));
2012-04-07 13:33:04 +02:00
}
float* fadeloop;
ALLEGRO_BITMAP* fade_bitmap;
fadeloop = (float*)action->arguments->value;
fade_bitmap = (ALLEGRO_BITMAP*)action->arguments->next->value;
if (state == TM_ACTIONSTATE_INIT) {
*fadeloop = 0;
al_set_target_bitmap(fade_bitmap);
al_clear_to_color(al_map_rgb(0,0,0));
al_set_target_bitmap(al_get_backbuffer(game->display));
} else if (state == TM_ACTIONSTATE_RUNNING) {
al_draw_tinted_bitmap(fade_bitmap,al_map_rgba_f(1,1,1,*fadeloop/255.0),0,0,0);
*fadeloop+=tps(game, 600);
if (*fadeloop>=256) return true;
} else {
al_destroy_bitmap(fade_bitmap);
free(fadeloop);
Level_Unload(game);
game->gamestate = GAMESTATE_LOADING;
game->loadstate = GAMESTATE_MAP;
2012-04-07 18:32:47 +02:00
TM_DestroyArgs(action->arguments);
2012-04-07 18:41:39 +02:00
action->arguments = NULL;
2012-04-07 13:33:04 +02:00
}
return false;
}
bool napis2(struct Game *game, struct TM_Action *action, enum TM_ActionState state) {
if (!action->arguments) {
2012-04-07 20:32:47 +02:00
action->arguments = TM_AddToArgs(action->arguments, malloc(sizeof(int)));
}
int* tmp;
tmp = (int*)action->arguments->value;
if (state == TM_ACTIONSTATE_INIT) {
*tmp = 0;
} else if (state == TM_ACTIONSTATE_RUNNING) {
2012-04-07 13:33:04 +02:00
al_draw_text_with_shadow(game->font, al_map_rgb(255,255,255), *tmp, 100, 0, "lol");
*tmp+=5;
if (*tmp>=al_get_display_width(game->display)) { *tmp=0; return true; }
2012-04-07 18:32:47 +02:00
} else {
TM_DestroyArgs(action->arguments);
2012-04-07 18:41:39 +02:00
action->arguments = NULL;
}
2012-04-06 23:32:15 +02:00
return false;
}
2012-04-07 13:33:04 +02:00
bool napis(struct Game *game, struct TM_Action *action, enum TM_ActionState state) {
if (!action->arguments) {
2012-04-07 20:32:47 +02:00
action->arguments = TM_AddToArgs(action->arguments, malloc(sizeof(int)));
}
int* tmp;
tmp = (int*)action->arguments->value;
if (state == TM_ACTIONSTATE_INIT) {
*tmp = 0;
} else if (state == TM_ACTIONSTATE_RUNNING) {
2012-04-07 13:33:04 +02:00
al_draw_text_with_shadow(game->font, al_map_rgb(255,255,255), *tmp, 20, 0, "wat");
*tmp+=10;
if (*tmp>=al_get_display_width(game->display)) { *tmp=0; return true; }
} else {
TM_AddBackgroundAction(&napis2, NULL, 0);
2012-04-07 18:32:47 +02:00
TM_DestroyArgs(action->arguments);
2012-04-07 18:41:39 +02:00
action->arguments = NULL;
}
2012-04-06 23:32:15 +02:00
return false;
}
bool wyjscie(struct Game *game, struct TM_Action *action, enum TM_ActionState state) {
if (state == TM_ACTIONSTATE_DESTROY) {
Level_Passed(game);
2012-04-07 13:33:04 +02:00
TM_AddBackgroundAction(&FadeOut, NULL, 0);
}
2012-04-06 23:32:15 +02:00
return true;
}
2012-02-22 12:43:14 +01:00
void Level_Load(struct Game *game) {
2012-04-08 19:01:30 +02:00
game->level.cl_pos=0;
game->level.bg_pos=0;
game->level.fg_pos=0.2;
game->level.st_pos=0.1;
game->level.speed=0;
2012-04-06 23:32:15 +02:00
al_clear_to_color(al_map_rgb(0,0,0));
if (game->level.current_level!=1) Moonwalk_Load(game);
2012-04-06 23:32:15 +02:00
else {
TM_Init(game);
2012-04-08 19:01:30 +02:00
TM_AddBackgroundAction(&Accelerate, NULL, 5000);
2012-04-06 23:32:15 +02:00
TM_AddAction(&napis, NULL);
TM_AddAction(&napis, NULL);
2012-04-08 19:01:30 +02:00
TM_AddDelay(60*1000);
2012-04-06 23:32:15 +02:00
TM_AddAction(&napis, NULL);
2012-04-07 23:03:34 +02:00
TM_AddBackgroundAction(&napis2, NULL, 1125);
2012-04-06 23:32:15 +02:00
TM_AddAction(&wyjscie, NULL);
2012-04-07 13:33:04 +02:00
TM_AddBackgroundAction(&FadeIn, NULL, 0);
2012-04-06 23:32:15 +02:00
}
2012-02-22 12:43:14 +01:00
}
2012-02-25 22:26:31 +01:00
2012-02-22 12:43:14 +01:00
int Level_Keydown(struct Game *game, ALLEGRO_EVENT *ev) {
if (game->level.current_level!=1) Moonwalk_Keydown(game, ev);
if (ev->keyboard.keycode==ALLEGRO_KEY_ESCAPE) {
game->gamestate = GAMESTATE_PAUSE;
game->loadstate = GAMESTATE_LEVEL;
Pause_Load(game);
}
return 0;
}
2012-04-06 23:32:15 +02:00
void Level_ProcessLogic(struct Game *game, ALLEGRO_EVENT *ev) {
if (game->level.current_level==1) TM_HandleEvent(ev);
}
void Level_Preload(struct Game *game) {
Pause_Preload(game);
if (game->level.current_level!=1) Moonwalk_Preload(game);
2012-04-08 19:01:30 +02:00
Level_PreloadBitmaps(game);
}
void Level_Unload(struct Game *game) {
Pause_Unload_Real(game);
if (game->level.current_level!=1) Moonwalk_Unload(game);
2012-04-06 23:32:15 +02:00
else {
TM_Destroy();
}
2012-04-08 19:01:30 +02:00
Level_UnloadBitmaps(game);
2012-02-22 12:43:14 +01:00
}
2012-02-25 22:26:31 +01:00
void Level_UnloadBitmaps(struct Game *game) {
if (game->level.current_level!=1) Moonwalk_UnloadBitmaps(game);
2012-04-08 19:01:30 +02:00
else {
al_destroy_bitmap(game->level.foreground);
al_destroy_bitmap(game->level.background);
al_destroy_bitmap(game->level.stage);
al_destroy_bitmap(game->level.clouds);
}
}
void Level_PreloadBitmaps(struct Game *game) {
if (game->level.current_level!=1) Moonwalk_PreloadBitmaps(game);
2012-04-08 19:01:30 +02:00
else {
// TODO: handle strange display aspects
game->level.clouds = LoadScaledBitmap("levels/1/clouds.png", al_get_display_height(game->display)*4.73307291666666666667, al_get_display_height(game->display));
game->level.foreground = LoadScaledBitmap("levels/1/foreground.png", al_get_display_height(game->display)*4.73307291666666666667, al_get_display_height(game->display));
game->level.background = LoadScaledBitmap("levels/1/background.png", al_get_display_height(game->display)*4.73307291666666666667, al_get_display_height(game->display));
game->level.stage = LoadScaledBitmap("levels/1/stage.png", al_get_display_height(game->display)*4.73307291666666666667, al_get_display_height(game->display));
}
2012-02-22 12:43:14 +01:00
}