2023-07-06 22:02:37 +02:00
|
|
|
#ifndef PLAYER_H
|
|
|
|
#define PLAYER_H
|
|
|
|
|
2024-03-27 10:44:15 +01:00
|
|
|
#include "config.h"
|
2023-08-11 08:04:17 +02:00
|
|
|
#include "game.h"
|
2023-07-08 15:55:06 +02:00
|
|
|
#include "memory.h"
|
2024-07-29 21:04:23 +02:00
|
|
|
|
2024-07-29 11:36:11 +02:00
|
|
|
#include <stdbool.h>
|
2023-07-08 15:55:06 +02:00
|
|
|
|
2024-07-27 17:20:06 +02:00
|
|
|
typedef struct {
|
|
|
|
const char *name;
|
|
|
|
bopti_image_t *face;
|
|
|
|
} Face;
|
|
|
|
|
|
|
|
#define FACES 4
|
2023-07-06 22:02:37 +02:00
|
|
|
|
2023-08-11 08:54:04 +02:00
|
|
|
/* Structure 'Player' has been moved to game.h */
|
|
|
|
/* to avoid circular references between map.h, game.h and player.h */
|
|
|
|
/* only methods propotypes are now in dedicated header files */
|
|
|
|
|
2024-07-25 13:07:19 +02:00
|
|
|
/* player_draw()
|
2024-07-29 11:36:11 +02:00
|
|
|
*
|
2024-07-25 13:07:19 +02:00
|
|
|
* Draws the player. This function should be called after drawing the
|
|
|
|
* map!
|
|
|
|
* game: The game struct which contains the player struct used.
|
|
|
|
*/
|
2023-08-11 08:54:04 +02:00
|
|
|
void player_draw(Game *game);
|
2023-07-06 22:02:37 +02:00
|
|
|
|
2024-07-25 13:07:19 +02:00
|
|
|
/* player_move()
|
2024-07-29 11:36:11 +02:00
|
|
|
*
|
2024-07-25 13:07:19 +02:00
|
|
|
* Move the player in a direction.
|
|
|
|
* game: The game struct.
|
|
|
|
* direction: The direction to move the player in.
|
|
|
|
*/
|
2023-08-11 08:54:04 +02:00
|
|
|
void player_move(Game *game, Direction direction);
|
2023-07-06 22:02:37 +02:00
|
|
|
|
2024-07-31 20:10:45 +02:00
|
|
|
/*Tries to do an action based on previously set flags (called if the shift key
|
|
|
|
* is pressed)*/
|
2023-08-11 08:54:04 +02:00
|
|
|
void player_action(Game *game);
|
2023-07-06 22:02:37 +02:00
|
|
|
|
2024-07-25 13:07:19 +02:00
|
|
|
/* player_collision()
|
2024-07-29 11:36:11 +02:00
|
|
|
*
|
2024-07-25 13:07:19 +02:00
|
|
|
* Check if the player is in collision with the map or a NPC. Checkpos is used
|
|
|
|
* to check the axis where the player is not moving.
|
|
|
|
* game: The game struct.
|
|
|
|
* direction: The direction the player is moving in.
|
|
|
|
* nomov_axis_check: The axis that isn't changed by this movement.
|
|
|
|
*/
|
2023-08-11 08:54:04 +02:00
|
|
|
bool player_collision(Game *game, Direction direction,
|
2023-07-09 13:22:20 +02:00
|
|
|
Checkpos nomov_axis_check);
|
2023-07-06 22:02:37 +02:00
|
|
|
|
2024-07-25 13:07:19 +02:00
|
|
|
/* player_fix_position()
|
2024-07-29 11:36:11 +02:00
|
|
|
*
|
2024-07-25 13:07:19 +02:00
|
|
|
* Fix the position of the player so that he's not a bit inside of a hard block
|
|
|
|
* after a collision.
|
|
|
|
* game: The game struct.
|
|
|
|
* fix_x: If we should fix the position on the X axis.
|
|
|
|
* fix_y: If we should fix the position on the Y axis.
|
|
|
|
*/
|
2023-08-11 08:54:04 +02:00
|
|
|
void player_fix_position(Game *game, bool fix_x, bool fix_y);
|
|
|
|
|
2024-07-25 13:07:19 +02:00
|
|
|
/* player_damage()
|
2024-07-29 11:36:11 +02:00
|
|
|
*
|
2024-07-25 13:07:19 +02:00
|
|
|
* Apply damage to player
|
|
|
|
* game: The game struct.
|
|
|
|
* amount: The amount of damage to apply.
|
|
|
|
*/
|
2023-08-11 08:54:04 +02:00
|
|
|
void player_damage(Game *game, int amount);
|
2023-07-06 22:02:37 +02:00
|
|
|
|
2023-07-07 14:20:13 +02:00
|
|
|
#endif
|