2024-09-11 17:29:54 +02:00
|
|
|
/* ************************************************************************** */
|
|
|
|
/* */
|
|
|
|
/* ::: :::::::: */
|
|
|
|
/* game.h :+: :+: :+: */
|
|
|
|
/* +:+ +:+ +:+ */
|
|
|
|
/* By: adjoly <adjoly@student.42angouleme.fr> +#+ +:+ +#+ */
|
|
|
|
/* +#+#+#+#+#+ +#+ */
|
|
|
|
/* Created: 2024/09/11 16:38:40 by adjoly #+# #+# */
|
2024-10-07 11:25:31 +02:00
|
|
|
/* Updated: 2024/10/06 18:48:33 by adjoly ### ########.fr */
|
2024-09-11 17:29:54 +02:00
|
|
|
/* */
|
|
|
|
/* ************************************************************************** */
|
|
|
|
|
|
|
|
#ifndef GAME_H
|
|
|
|
# define GAME_H
|
|
|
|
|
2024-10-07 11:25:31 +02:00
|
|
|
# include "dda.h"
|
|
|
|
# include "settings.h"
|
2024-09-16 18:50:24 +02:00
|
|
|
# include "parsing.h"
|
2024-10-07 11:25:31 +02:00
|
|
|
# include "typedef.h"
|
|
|
|
|
2024-09-16 18:50:24 +02:00
|
|
|
# include <stdint.h>
|
2024-10-07 11:25:31 +02:00
|
|
|
# include <stdlib.h>
|
2024-09-24 18:32:34 +02:00
|
|
|
# include <math.h>
|
|
|
|
# include <stdbool.h>
|
|
|
|
# include <unistd.h>
|
|
|
|
|
2024-09-11 17:29:54 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief This function is used to handle keypress
|
|
|
|
*
|
|
|
|
* @param key The key code of the pressed key
|
|
|
|
* @param mlx The mlx pointer(internal to MacroLibX)
|
|
|
|
*
|
|
|
|
* @return Minilibx go brrrr(useless always 0)
|
|
|
|
*/
|
2024-09-17 10:48:20 +02:00
|
|
|
int key_hook(int key, void *param);
|
2024-09-16 18:50:24 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief This function is used to create an image with the player position
|
|
|
|
*
|
2024-09-17 10:48:20 +02:00
|
|
|
* @param cub The address of a t_cub struct filled with mlx data and other
|
|
|
|
* thing
|
2024-09-16 18:50:24 +02:00
|
|
|
*
|
|
|
|
*/
|
2024-09-24 18:32:34 +02:00
|
|
|
void get_player_image(t_cub *cub, uint8_t key_pressed);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief This function is here to change the direction of the player
|
|
|
|
* by setting the t_player->direction and check overflow to be
|
|
|
|
* sure it stays between 0 and 2pi because it is expressed in
|
|
|
|
* radians
|
|
|
|
*
|
|
|
|
* @param speed The speed a which the player rotate
|
|
|
|
* @param clockwise The direction which the player rotate
|
|
|
|
* @param player A pointer to a t_player struct
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
void change_direction(double speed, bool clockwise, t_player *player);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Function used to draw a square
|
|
|
|
*
|
|
|
|
* @param cub The adress of a t_cub struct
|
|
|
|
* @param coord The coordinate of the printed square
|
|
|
|
* @param size The size of the printed square
|
|
|
|
* @param color The color of the printed square
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
void draw_square(t_cub *cub, t_coord coord, uint16_t size, int color);
|
2024-09-11 17:29:54 +02:00
|
|
|
|
2024-09-24 18:32:34 +02:00
|
|
|
/**
|
|
|
|
* @brief Function used to draw the map
|
|
|
|
*
|
|
|
|
* @param cub The address of the t_cub struct
|
|
|
|
*/
|
|
|
|
void print_map(t_cub *cub);
|
2024-10-07 11:25:31 +02:00
|
|
|
|
2024-09-11 17:29:54 +02:00
|
|
|
#endif
|