Added malfunctioning ship.

Currently it doesn't seem to be detecting the key preses.
This commit is contained in:
Nicolás Ortega Froysa 2018-03-25 17:47:31 +02:00
parent 80113d51ff
commit 88f3a5f1a5
No known key found for this signature in database
GPG Key ID: FEC70E3BAE2E69BF
8 changed files with 54 additions and 118 deletions

View File

@ -42,7 +42,6 @@ include_directories(
SYSTEM ${ALLEG5_INCLUDE_DIRS}) SYSTEM ${ALLEG5_INCLUDE_DIRS})
set(SRCS set(SRCS
src/display.c
src/event_manager.c src/event_manager.c
src/main.c src/main.c
src/ship.c) src/ship.c)

View File

@ -1,41 +0,0 @@
/*
* Copyright (C) 2018 Ortega Froysa, Nicolás <nortega@themusicinnoise.net>
* Author: Ortega Froysa, Nicolás <nortega@themusicinnoise.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 3 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, see <http://www.gnu.org/licenses/>.
*/
#include "display.h"
#ifdef DEBUG
# include <stdio.h>
#endif
int create_display(ALLEGRO_DISPLAY *display,
unsigned int width, unsigned int height) {
display = al_create_display(width, height);
if(!display)
return 0;
#ifdef DEBUG
puts("Initialized display.");
#endif
return 1;
}
void destroy_display(ALLEGRO_DISPLAY *display) {
al_destroy_display(display);
#ifdef DEBUG
puts("Destroyed display.");
#endif
}

View File

@ -1,40 +0,0 @@
/*
* Copyright (C) 2018 Ortega Froysa, Nicolás <nortega@themusicinnoise.net>
* Author: Ortega Froysa, Nicolás <nortega@themusicinnoise.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 3 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, see <http://www.gnu.org/licenses/>.
*/
#pragma once
#include <allegro5/allegro.h>
/**
* @brief Create an allegro 5 display with a given width and height.
*
* @param display The display to create.
* @param width The width of the display.
* @param height The height of the display.
*
* @return If successful it will return 1, else it will return 0.
*/
int create_display(ALLEGRO_DISPLAY *display,
unsigned int width, unsigned int height);
/**
* @brief Destroy the display (used for shutdown).
*
* @param display The display to destroy.
*/
void destroy_display(ALLEGRO_DISPLAY *display);

View File

@ -23,6 +23,7 @@
# include <stdio.h> # include <stdio.h>
#endif #endif
#include <stddef.h> #include <stddef.h>
#include <assert.h>
#include <allegro5/allegro.h> #include <allegro5/allegro.h>
static ALLEGRO_EVENT_QUEUE *event_queue; static ALLEGRO_EVENT_QUEUE *event_queue;
@ -30,6 +31,7 @@ static ALLEGRO_TIMER *timer;
static int keys[KEY_MAX]; static int keys[KEY_MAX];
int evnt_mngr_init(ALLEGRO_DISPLAY *display) { int evnt_mngr_init(ALLEGRO_DISPLAY *display) {
assert(display);
if(!al_install_keyboard()) if(!al_install_keyboard())
return 0; return 0;
#ifdef DEBUG #ifdef DEBUG
@ -133,13 +135,6 @@ void handle_event() {
} }
int key_is_down(int code) { int key_is_down(int code) {
if(code < 0 || code >= KEY_MAX) assert(code >= 0 && code <= KEY_MAX);
{ return keys[code];
#ifdef DEBUG
fprintf(stderr, "key_is_down(int): bad key code!\n");
#endif
return 0;
}
else
return keys[code];
} }

View File

@ -33,6 +33,9 @@ enum {
/** /**
* @brief Initialize the event handler. * @brief Initialize the event handler.
* *
* @param display A pointer to the display (used to get
* event source).
*
* @return 0 upon failure, 1 upon success. * @return 0 upon failure, 1 upon success.
*/ */
int evnt_mngr_init(ALLEGRO_DISPLAY *display); int evnt_mngr_init(ALLEGRO_DISPLAY *display);

View File

@ -17,7 +17,6 @@
*/ */
#include "globals.h" #include "globals.h"
#include "display.h"
#include "event_manager.h" #include "event_manager.h"
#include "ship.h" #include "ship.h"
@ -38,23 +37,32 @@ int main() {
fprintf(stderr, "alleg5: failed to initialize Allegro.\n"); fprintf(stderr, "alleg5: failed to initialize Allegro.\n");
return 1; return 1;
} }
#ifdef DEBUG
puts("Initialized allegro system.");
#endif
if(!al_init_primitives_addon()) if(!al_init_primitives_addon())
{ {
fprintf(stderr, "alleg5: failed to initialize primitives addon.\n"); fprintf(stderr, "alleg5: failed to initialize primitives addon.\n");
return 1; return 1;
} }
#ifdef DEBUG
puts("Initialized primitives addon.");
#endif
ALLEGRO_DISPLAY *display; ALLEGRO_DISPLAY *display = al_create_display(800, 600);
if(!create_display(display, 800, 600)) if(!display)
{ {
fprintf(stderr, "alleg5: failed to create display.\n"); fprintf(stderr, "alleg5: failed to initialize display.\n");
return 1; return 1;
} }
#ifdef DEBUG
puts("Created display.");
#endif
if(!evnt_mngr_init(display)) if(!evnt_mngr_init(display))
{ {
fprintf(stderr, "alleg5: failed to initialize event queue.\n"); fprintf(stderr, "alleg5: failed to initialize event queue.\n");
destroy_display(display); al_destroy_display(display);
return 1; return 1;
} }
@ -81,7 +89,7 @@ int main() {
*/ */
ship_update(&ship); ship_update(&ship);
al_clear_to_color(al_map_rgb(0, 0, 0)); al_clear_to_color(al_map_rgb(0, 0, 0));
// TODO: run simulation draw functions ship_draw(&ship);
if(show_info) if(show_info)
{ {
// TODO: draw simulation stats // TODO: draw simulation stats
@ -97,7 +105,7 @@ int main() {
} }
evnt_mngr_deinit(); evnt_mngr_deinit();
destroy_display(display); al_destroy_display(display);
al_shutdown_primitives_addon(); al_shutdown_primitives_addon();
#ifdef DEBUG #ifdef DEBUG
puts("Shutdown primitives addon."); puts("Shutdown primitives addon.");

View File

@ -20,10 +20,9 @@
#include "event_manager.h" #include "event_manager.h"
#include "globals.h" #include "globals.h"
#ifdef DEBUG
# include <stdio.h>
#endif
#include <math.h> #include <math.h>
#include <assert.h>
#include <allegro5/allegro_primitives.h>
#ifndef M_PI #ifndef M_PI
# define M_PI 3.14159265f # define M_PI 3.14159265f
@ -31,16 +30,10 @@
#define ACCEL 5.0f #define ACCEL 5.0f
#define TURN_ACCEL (M_PI / FPS) // turn at pi radians / sec #define TURN_ACCEL (M_PI / FPS) // turn at pi radians / sec
#define SHIP_RADIUS 10.0f // radius of the ship in pixels
void ship_init(struct ship *ship, int x, int y) { void ship_init(struct ship *ship, int x, int y) {
if(!ship) assert(ship);
{
#ifdef DEBUG
fprintf(stderr,
"ship_init(struct ship*,int,int): invalid ship.\n");
#endif
return;
}
ship->x = x; ship->x = x;
ship->y = y; ship->y = y;
ship->velX = ship->velY = 0; ship->velX = ship->velY = 0;
@ -48,15 +41,7 @@ void ship_init(struct ship *ship, int x, int y) {
} }
void ship_update(struct ship *ship) { void ship_update(struct ship *ship) {
if(!ship) assert(ship);
{
#ifdef DEBUG
fprintf(stderr,
"ship_update(struct ship*): invalid ship.\n");
#endif
return;
}
if(key_is_down(KEY_UP)) if(key_is_down(KEY_UP))
{ {
ship->velX += cos(ship->direction) * ACCEL; ship->velX += cos(ship->direction) * ACCEL;
@ -79,3 +64,21 @@ void ship_update(struct ship *ship) {
else if(ship->direction < 0) else if(ship->direction < 0)
ship->direction += M_PI * 2; ship->direction += M_PI * 2;
} }
void ship_draw(struct ship *ship) {
assert(ship);
const float x0 = ship->x + (cos(ship->direction) *
SHIP_RADIUS);
const float y0 = ship->y + (sin(ship->direction) *
SHIP_RADIUS);
const float x1 = ship->x + (cos(ship->direction +
M_PI * 0.8f) * SHIP_RADIUS);
const float y1 = ship->y + (sin(ship->direction +
M_PI * 0.8f) * SHIP_RADIUS);
const float x2 = ship->x + (cos(ship->direction +
M_PI * 1.2f) * SHIP_RADIUS);
const float y2 = ship->y + (sin(ship->direction +
M_PI * 1.2f) * SHIP_RADIUS);
al_draw_filled_triangle(x0, y0, x1, y1, x2, y2,
al_map_rgb(0xFF, 0x0, 0x0));
}

View File

@ -18,6 +18,8 @@
#pragma once #pragma once
#include <allegro5/allegro.h>
struct ship { struct ship {
float x, y; ///< The x and y coordinates of the ship. float x, y; ///< The x and y coordinates of the ship.
float velX, velY; ///< The x and y velocities of the ship. float velX, velY; ///< The x and y velocities of the ship.
@ -44,3 +46,10 @@ void ship_init(struct ship *ship, int x, int y);
* @param ship A pointer to the ship object. * @param ship A pointer to the ship object.
*/ */
void ship_update(struct ship *ship); void ship_update(struct ship *ship);
/**
* @brief Draw the ship.
*
* @param ship Ship object to draw.
*/
void ship_draw(struct ship *ship);