2023-07-08 15:55:06 +02:00
|
|
|
#ifndef GAME_H
|
|
|
|
#define GAME_H
|
|
|
|
|
2023-08-16 19:25:24 +02:00
|
|
|
|
2023-08-11 08:04:17 +02:00
|
|
|
#include <gint/display.h>
|
2023-08-16 17:34:45 +02:00
|
|
|
#include <stdint.h>
|
2023-08-11 08:04:17 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/* 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-16 19:25:24 +02:00
|
|
|
int16_t x, y; /* The position of the player int the current map */
|
|
|
|
uint16_t px, py; /* The position of the player on screen */
|
|
|
|
int16_t wx, wy; /* position of the player in the world */
|
2023-08-16 23:12:16 +02:00
|
|
|
int8_t life; /* How many lives the player still has between 0 and 100. */
|
2023-08-16 19:25:24 +02:00
|
|
|
int8_t speed; /* The speed of the movement of the player. */
|
|
|
|
|
2023-08-16 23:12:16 +02:00
|
|
|
|
|
|
|
/* set to true if a action can be done in the current position of the map */
|
|
|
|
bool canDoSomething;
|
|
|
|
/* indicates which data are relevant to the current action in the */
|
|
|
|
/* extradata layer of the map */
|
|
|
|
int32_t whichAction;
|
|
|
|
/* the player is doing something */
|
|
|
|
bool isDoingAction;
|
2023-08-11 08:04:17 +02:00
|
|
|
} Player;
|
|
|
|
|
|
|
|
|
2023-08-15 16:50:51 +02:00
|
|
|
typedef struct {
|
2023-08-16 23:12:16 +02:00
|
|
|
/* position of the item */
|
2023-08-16 17:34:45 +02:00
|
|
|
uint16_t x;
|
|
|
|
uint16_t y;
|
2023-08-16 23:12:16 +02:00
|
|
|
/* its name */
|
2023-08-16 17:34:45 +02:00
|
|
|
char *name;
|
2023-08-16 23:12:16 +02:00
|
|
|
/* its class (NPC, SGN, INFO, ... )*/
|
2023-08-16 17:34:45 +02:00
|
|
|
char *type;
|
2023-08-16 23:12:16 +02:00
|
|
|
/* data to be shown in the dialog*/
|
2023-08-16 17:34:45 +02:00
|
|
|
char *dialog;
|
2023-08-16 23:12:16 +02:00
|
|
|
/* ... this can be extended as per needs ... */
|
2023-08-15 16:50:51 +02:00
|
|
|
} ExtraData;
|
|
|
|
|
2023-08-11 08:04:17 +02:00
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
/* width, height and the number of layer of the map */
|
2023-08-16 17:34:45 +02:00
|
|
|
uint16_t w;
|
|
|
|
uint16_t h;
|
2023-08-11 08:04:17 +02:00
|
|
|
uint16_t nblayers;
|
|
|
|
uint16_t tileset_size;
|
|
|
|
|
2023-08-16 17:34:45 +02:00
|
|
|
/* world coordinates of the upper left and bootom right*/
|
|
|
|
/* corners of the current map to be multiplied in game by PXSIZE */
|
2023-08-11 08:04:17 +02:00
|
|
|
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;
|
|
|
|
|
2023-08-16 23:12:16 +02:00
|
|
|
/* structure that contains all the items on the map to interract with */
|
|
|
|
/* each portion of the map has its own list to avoid scrutinizing too much */
|
|
|
|
/* data when lloking for proximity of items */
|
2023-08-16 17:34:45 +02:00
|
|
|
uint32_t nbextradata;
|
|
|
|
ExtraData *extradata;
|
|
|
|
|
2023-08-16 23:12:16 +02:00
|
|
|
/* list of all the tiles to draw the background and the foreground layers */
|
2023-08-11 08:04:17 +02:00
|
|
|
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_map;
|
2023-08-16 17:34:45 +02:00
|
|
|
bool debug_player;
|
|
|
|
bool debug_extra;
|
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-08-16 19:25:24 +02:00
|
|
|
/* This render a small sign on the upper lecft corner of the screen */
|
|
|
|
/* if the player can do an action */
|
|
|
|
void render_indicator(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
|
|
|
|
|