2023-07-08 15:55:06 +02:00
|
|
|
#ifndef GAME_H
|
|
|
|
#define GAME_H
|
|
|
|
|
2023-08-11 08:04:17 +02:00
|
|
|
#include <gint/display.h>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/* The direction where the player is going to. */
|
|
|
|
typedef enum {
|
|
|
|
D_UP,
|
|
|
|
D_DOWN,
|
|
|
|
D_LEFT,
|
|
|
|
D_RIGHT
|
|
|
|
} Direction;
|
|
|
|
|
|
|
|
typedef enum {
|
|
|
|
P_LEFTUP = -1,
|
|
|
|
P_CENTER = 0,
|
|
|
|
P_RIGHTDOWN = 1
|
|
|
|
} Checkpos;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/* Struct that define player parameters */
|
|
|
|
typedef struct {
|
2023-08-14 18:40:36 +02:00
|
|
|
int x, y; /* The position of the player int the current map */
|
2023-08-11 08:04:17 +02:00
|
|
|
unsigned int px, py; /* The position of the player on screen */
|
2023-08-14 18:40:36 +02:00
|
|
|
int wx, wy; /* position of the player in the world */
|
2023-08-11 08:04:17 +02:00
|
|
|
unsigned short int life; /* How many lives the player still has between 0
|
|
|
|
* and 100. */
|
|
|
|
char speed; /* The speed of the movement of the player. */
|
|
|
|
} Player;
|
|
|
|
|
|
|
|
|
2023-08-15 16:50:51 +02:00
|
|
|
typedef struct {
|
|
|
|
uint16_t x, y;
|
|
|
|
char type[3];
|
|
|
|
} ExtraData;
|
|
|
|
|
2023-08-11 08:04:17 +02:00
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
/* width, height and the number of layer of the map */
|
|
|
|
uint16_t w, h;
|
|
|
|
uint16_t nblayers;
|
|
|
|
uint16_t tileset_size;
|
|
|
|
|
|
|
|
uint16_t xmin;
|
|
|
|
uint16_t ymin;
|
|
|
|
uint16_t xmax;
|
|
|
|
uint16_t ymax;
|
|
|
|
|
|
|
|
/* the tileset to use */
|
|
|
|
bopti_image_t *tileset;
|
|
|
|
|
|
|
|
/* contain the properties of the tiles */
|
|
|
|
/* this is given by the layer Walkable of the map in Tiled */
|
|
|
|
|
|
|
|
uint8_t *walkable;
|
|
|
|
|
|
|
|
/* list of all the tiles */
|
|
|
|
uint16_t *layers[];
|
|
|
|
} Map;
|
|
|
|
|
|
|
|
|
2023-07-08 15:55:06 +02:00
|
|
|
|
|
|
|
/* This struct will contain all the data of the game. It will make it possible
|
|
|
|
* to pass it to the NPCs to let them interact with the player and the rest of
|
|
|
|
* the world. */
|
|
|
|
typedef struct {
|
|
|
|
Map *map_level; /* The level that the player is currently playing */
|
|
|
|
Player player; /* The player data (see player.h). */
|
2023-07-08 20:07:34 +02:00
|
|
|
/* Some global variables */
|
|
|
|
/* Set to true when asked for exit */
|
|
|
|
bool exittoOS;
|
|
|
|
/* Set to true when screenshot is required */
|
|
|
|
bool screenshot;
|
|
|
|
/* Set to true when recording a video of the screen is required */
|
|
|
|
bool record;
|
|
|
|
/* How many ms the frame already took. */
|
|
|
|
long int frame_duration;
|
2023-08-10 16:22:31 +02:00
|
|
|
|
|
|
|
/* variables used for debuging */
|
|
|
|
bool debug_player;
|
|
|
|
bool debug_map;
|
2023-07-08 15:55:06 +02:00
|
|
|
} Game;
|
|
|
|
|
|
|
|
/* (Mibi88) TODO: Describe what this function is doing. */
|
|
|
|
void game_logic(Game *game);
|
|
|
|
|
|
|
|
/* Draws everything on screen. */
|
|
|
|
void draw(Game *game);
|
|
|
|
|
2023-07-08 20:07:34 +02:00
|
|
|
/* Handle key presses. */
|
|
|
|
void get_inputs(Game *game);
|
|
|
|
|
2023-07-08 15:55:06 +02:00
|
|
|
#endif
|
|
|
|
|