mirror of
https://gitlab.com/dosowisko.net/libsuperderpy.git
synced 2025-02-01 11:06:44 +01:00
moonwalk :D
This commit is contained in:
parent
cf2f82f5f9
commit
a02f0a361b
1 changed files with 14 additions and 8 deletions
22
src/level.c
22
src/level.c
|
@ -15,19 +15,23 @@ void Level_Draw(struct Game *game) {
|
||||||
al_set_target_bitmap(al_get_backbuffer(game->display));
|
al_set_target_bitmap(al_get_backbuffer(game->display));
|
||||||
|
|
||||||
game->level.derpy_pos=game->level.derpy_pos+0.00092;
|
game->level.derpy_pos=game->level.derpy_pos+0.00092;
|
||||||
if (game->level.derpy_pos>1) game->level.derpy_pos=-0.2;
|
if (game->level.derpy_pos>1) { UnloadGameState(game);
|
||||||
|
game->gamestate = GAMESTATE_LOADING;
|
||||||
|
game->loadstate = GAMESTATE_MENU; return; }
|
||||||
game->level.derpy_frame_tmp++;
|
game->level.derpy_frame_tmp++;
|
||||||
if (game->level.derpy_frame_tmp%3==0) {
|
if (game->level.derpy_frame_tmp%3==0) {
|
||||||
|
if (game->level.derpy_frame_tmp%5==0) game->level.derpy_frame++;
|
||||||
game->level.derpy_frame++;
|
game->level.derpy_frame++;
|
||||||
if (game->level.derpy_frame==24) game->level.derpy_frame=0;
|
if (game->level.derpy_frame>=24) game->level.derpy_frame=0;
|
||||||
}
|
}
|
||||||
al_draw_scaled_bitmap(game->level.image,0,0,al_get_bitmap_width(game->level.image),al_get_bitmap_height(game->level.image),0,0,al_get_display_width(game->display), al_get_display_height(game->display),0);
|
al_draw_scaled_bitmap(game->level.image,0,0,al_get_bitmap_width(game->level.image),al_get_bitmap_height(game->level.image),0,0,al_get_display_width(game->display), al_get_display_height(game->display),0);
|
||||||
al_draw_bitmap(game->level.derpy, game->level.derpy_pos*al_get_display_width(game->display), al_get_display_height(game->display)-al_get_bitmap_height(game->level.derpy), 0);
|
al_draw_bitmap(game->level.derpy, game->level.derpy_pos*al_get_display_width(game->display), al_get_display_height(game->display)-al_get_bitmap_height(game->level.derpy), ALLEGRO_FLIP_HORIZONTAL);
|
||||||
al_draw_textf(game->font, al_map_rgb(255,255,255), al_get_display_width(game->display)/2, al_get_display_height(game->display)/2, ALLEGRO_ALIGN_CENTRE, "Level %d: Not implemented yet!", game->level.current_level);
|
al_draw_textf(game->font, al_map_rgb(255,255,255), al_get_display_width(game->display)/2, al_get_display_height(game->display)/2.2, ALLEGRO_ALIGN_CENTRE, "Level %d: Not implemented yet!", game->level.current_level);
|
||||||
|
al_draw_text(game->font, al_map_rgb(255,255,255), al_get_display_width(game->display)/2, al_get_display_height(game->display)/1.8, ALLEGRO_ALIGN_CENTRE, "Have some moonwalk instead.");
|
||||||
}
|
}
|
||||||
|
|
||||||
void Level_Load(struct Game *game) {
|
void Level_Load(struct Game *game) {
|
||||||
if (game->music) al_play_sample(game->level.sample, 1.0, 0.0, 1.0, ALLEGRO_PLAYMODE_LOOP, NULL);
|
if (game->music) al_play_sample(game->level.sample, 0.75, 0.0, 1.0, ALLEGRO_PLAYMODE_LOOP, NULL);
|
||||||
ALLEGRO_EVENT ev;
|
ALLEGRO_EVENT ev;
|
||||||
for(int fadeloop=0; fadeloop<256; fadeloop+=10){
|
for(int fadeloop=0; fadeloop<256; fadeloop+=10){
|
||||||
al_wait_for_event(game->event_queue, &ev);
|
al_wait_for_event(game->event_queue, &ev);
|
||||||
|
@ -54,7 +58,7 @@ void Level_Preload(struct Game *game) {
|
||||||
game->level.derpy_pos = -0.2;
|
game->level.derpy_pos = -0.2;
|
||||||
PrintConsole(game, "Initializing level %d...", game->level.current_level);
|
PrintConsole(game, "Initializing level %d...", game->level.current_level);
|
||||||
game->level.image = al_load_bitmap( "data/table.png" );
|
game->level.image = al_load_bitmap( "data/table.png" );
|
||||||
game->level.sample = al_load_sample( "data/about.flac" );
|
game->level.sample = al_load_sample( "data/moonwalk.flac" );
|
||||||
game->level.derpy_walkcycle = al_load_bitmap( "data/derpcycle.png" );
|
game->level.derpy_walkcycle = al_load_bitmap( "data/derpcycle.png" );
|
||||||
|
|
||||||
if (!game->level.sample){
|
if (!game->level.sample){
|
||||||
|
@ -67,7 +71,8 @@ void Level_Preload(struct Game *game) {
|
||||||
game->level.fade_bitmap = al_create_bitmap(al_get_display_width(game->display), al_get_display_height(game->display));
|
game->level.fade_bitmap = al_create_bitmap(al_get_display_width(game->display), al_get_display_height(game->display));
|
||||||
al_set_target_bitmap(game->level.fade_bitmap);
|
al_set_target_bitmap(game->level.fade_bitmap);
|
||||||
al_draw_scaled_bitmap(game->level.image,0,0,al_get_bitmap_width(game->level.image),al_get_bitmap_height(game->level.image),0,0,al_get_display_width(game->display), al_get_display_height(game->display),0);
|
al_draw_scaled_bitmap(game->level.image,0,0,al_get_bitmap_width(game->level.image),al_get_bitmap_height(game->level.image),0,0,al_get_display_width(game->display), al_get_display_height(game->display),0);
|
||||||
al_draw_textf(game->font, al_map_rgb(255,255,255), al_get_display_width(game->display)/2, al_get_display_height(game->display)/2, ALLEGRO_ALIGN_CENTRE, "Level %d: Not implemented yet!", game->level.current_level);
|
al_draw_textf(game->font, al_map_rgb(255,255,255), al_get_display_width(game->display)/2, al_get_display_height(game->display)/2.2, ALLEGRO_ALIGN_CENTRE, "Level %d: Not implemented yet!", game->level.current_level);
|
||||||
|
al_draw_text(game->font, al_map_rgb(255,255,255), al_get_display_width(game->display)/2, al_get_display_height(game->display)/1.8, ALLEGRO_ALIGN_CENTRE, "Have some moonwalk instead.");
|
||||||
al_set_target_bitmap(al_get_backbuffer(game->display));
|
al_set_target_bitmap(al_get_backbuffer(game->display));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -76,7 +81,8 @@ void Level_Unload(struct Game *game) {
|
||||||
game->level.fade_bitmap = al_create_bitmap(al_get_display_width(game->display), al_get_display_height(game->display));
|
game->level.fade_bitmap = al_create_bitmap(al_get_display_width(game->display), al_get_display_height(game->display));
|
||||||
al_set_target_bitmap(game->level.fade_bitmap);
|
al_set_target_bitmap(game->level.fade_bitmap);
|
||||||
al_draw_scaled_bitmap(game->level.image,0,0,al_get_bitmap_width(game->level.image),al_get_bitmap_height(game->level.image),0,0,al_get_display_width(game->display), al_get_display_height(game->display),0);
|
al_draw_scaled_bitmap(game->level.image,0,0,al_get_bitmap_width(game->level.image),al_get_bitmap_height(game->level.image),0,0,al_get_display_width(game->display), al_get_display_height(game->display),0);
|
||||||
al_draw_textf(game->font, al_map_rgb(255,255,255), al_get_display_width(game->display)/2, al_get_display_height(game->display)/2, ALLEGRO_ALIGN_CENTRE, "Level %d: Not implemented yet!", game->level.current_level);
|
al_draw_textf(game->font, al_map_rgb(255,255,255), al_get_display_width(game->display)/2, al_get_display_height(game->display)/2.2, ALLEGRO_ALIGN_CENTRE, "Level %d: Not implemented yet!", game->level.current_level);
|
||||||
|
al_draw_text(game->font, al_map_rgb(255,255,255), al_get_display_width(game->display)/2, al_get_display_height(game->display)/1.8, ALLEGRO_ALIGN_CENTRE, "Have some moonwalk instead.");
|
||||||
al_set_target_bitmap(al_get_backbuffer(game->display));
|
al_set_target_bitmap(al_get_backbuffer(game->display));
|
||||||
for(int fadeloop=255; fadeloop>=0; fadeloop-=10){
|
for(int fadeloop=255; fadeloop>=0; fadeloop-=10){
|
||||||
al_wait_for_event(game->event_queue, &ev);
|
al_wait_for_event(game->event_queue, &ev);
|
||||||
|
|
Loading…
Reference in a new issue