2023-08-19 14:18:41 +02:00
|
|
|
#ifndef NPC_H
|
|
|
|
#define NPC_H
|
|
|
|
|
|
|
|
|
|
|
|
#include <stdbool.h>
|
2023-08-26 17:13:05 +02:00
|
|
|
#include <stdint.h>
|
2023-08-19 14:18:41 +02:00
|
|
|
|
|
|
|
#include "game.h"
|
|
|
|
#include "memory.h"
|
|
|
|
|
2024-07-21 02:42:50 +02:00
|
|
|
enum
|
|
|
|
{
|
|
|
|
|
|
|
|
NPC_NONE = 0,
|
|
|
|
NPC_FRIENDLY = 1, //The player's team
|
|
|
|
NPC_HOSTILE = 2, //to the player
|
|
|
|
NPC_ALL = 3
|
|
|
|
|
|
|
|
} NPC_groups;
|
2023-08-19 14:18:41 +02:00
|
|
|
|
2023-08-26 17:13:05 +02:00
|
|
|
typedef struct
|
|
|
|
{
|
|
|
|
/* current coordinates of the NPC */
|
|
|
|
float curx, cury;
|
|
|
|
|
|
|
|
/* initial coordinates of the NPC (needed to get absolute coordinates of path) */
|
|
|
|
uint32_t x;
|
|
|
|
uint32_t y;
|
|
|
|
/* the ID of the first element of the dialog */
|
|
|
|
/* (to be aligned with "dialogs.json" IDs)*/
|
|
|
|
uint32_t dialogID;
|
|
|
|
/* the number of the target point of the path */
|
|
|
|
/* Note: it must keep the value 0 if NPC has no path assigned */
|
|
|
|
uint32_t currentPoint;
|
|
|
|
/* data of the path */
|
|
|
|
uint32_t hasPath;
|
|
|
|
uint32_t path_length;
|
|
|
|
int16_t *xpath;
|
|
|
|
int16_t *ypath;
|
|
|
|
|
2024-07-21 02:42:50 +02:00
|
|
|
int8_t hostile_to_group;
|
|
|
|
|
|
|
|
|
|
|
|
|
2023-08-26 17:13:05 +02:00
|
|
|
/* is the current NPC in pause (during dialog) */
|
|
|
|
bool paused;
|
|
|
|
} NPC;
|
|
|
|
|
2024-07-23 18:06:42 +02:00
|
|
|
//Frees then malloc()s a new path to npc
|
|
|
|
//Useful if you want to safely edit a path
|
|
|
|
int npc_clear_path(NPC *npc);
|
|
|
|
|
|
|
|
//Adds point x,y to the path of npc
|
|
|
|
//Won't work on static NPCs, use npc_clear_path before or make them on the heap
|
|
|
|
int npc_append_path(uint16_t x, uint16_t y, NPC *npc);
|
|
|
|
|
|
|
|
//Clears the NPCs path and creates a new one going to dest,
|
|
|
|
//avoiding non-walkable tiles
|
|
|
|
//Returns non-zero on failure
|
|
|
|
int npc_pathfind(int dest_x, int dest_y, Map *full_map, NPC *npc);
|
2023-08-19 14:18:41 +02:00
|
|
|
|
|
|
|
/* Draws the player player. This function should be called after drawing the
|
|
|
|
* map! */
|
|
|
|
void npc_draw(Game *game);
|
|
|
|
|
2024-07-21 02:42:50 +02:00
|
|
|
void update_npcs(Game *game);
|
|
|
|
|
|
|
|
void update_npc(NPC *npc);
|
2023-08-26 17:13:05 +02:00
|
|
|
|
|
|
|
void reload_npc(Game *game);
|
2023-08-19 14:18:41 +02:00
|
|
|
|
|
|
|
#endif
|
|
|
|
|