handle cross click

This commit is contained in:
mcolonna 2024-11-07 14:27:17 +01:00
parent 3cd1066b1b
commit 8ad8eb1fbc
3 changed files with 20 additions and 10 deletions

View file

@ -6,7 +6,7 @@
/* By: mc <mc@student.42.fr> +#+ +:+ +#+ */ /* By: mc <mc@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */ /* +#+#+#+#+#+ +#+ */
/* Created: 2024/10/17 14:43:09 by mcolonna #+# #+# */ /* Created: 2024/10/17 14:43:09 by mcolonna #+# #+# */
/* Updated: 2024/11/01 20:59:28 by mc ### ########.fr */ /* Updated: 2024/11/07 14:26:28 by mc ### ########.fr */
/* */ /* */
/* ************************************************************************** */ /* ************************************************************************** */
@ -41,7 +41,9 @@ int hook_keypress(int keycode);
/// @return Unused. /// @return Unused.
int hook_keyrelease(int keycode); int hook_keyrelease(int keycode);
/// @brief To call at the start of the program. /// @brief To handle the input of a window.
void input_init(void); ///
/// @param win_ptr Reference to the window to use.
void input_init(void *win_ptr);
#endif #endif

View file

@ -6,7 +6,7 @@
/* By: mc <mc@student.42.fr> +#+ +:+ +#+ */ /* By: mc <mc@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */ /* +#+#+#+#+#+ +#+ */
/* Created: 2024/10/17 14:43:36 by mcolonna #+# #+# */ /* Created: 2024/10/17 14:43:36 by mcolonna #+# #+# */
/* Updated: 2024/11/01 20:59:32 by mc ### ########.fr */ /* Updated: 2024/11/07 14:25:46 by mc ### ########.fr */
/* */ /* */
/* ************************************************************************** */ /* ************************************************************************** */
@ -14,6 +14,13 @@
t_input_actions g_input_actions; t_input_actions g_input_actions;
static int set_quit(void *_)
{
(void)_;
g_input_actions.quit = true;
return (0);
}
static void set_action(int keycode, bool value) static void set_action(int keycode, bool value)
{ {
if (keycode == XK_Up || keycode == XK_z || keycode == XK_w) if (keycode == XK_Up || keycode == XK_z || keycode == XK_w)
@ -25,7 +32,7 @@ static void set_action(int keycode, bool value)
if (keycode == XK_Left || keycode == XK_q || keycode == XK_a) if (keycode == XK_Left || keycode == XK_q || keycode == XK_a)
g_input_actions.left = value; g_input_actions.left = value;
if (keycode == XK_Escape) if (keycode == XK_Escape)
g_input_actions.quit = value; set_quit(NULL);
} }
int hook_keypress(int keycode) int hook_keypress(int keycode)
@ -40,7 +47,10 @@ int hook_keyrelease(int keycode)
return (0); return (0);
} }
void input_init(void) void input_init(void *win_ptr)
{ {
ft_memset(&g_input_actions, 0, sizeof(g_input_actions)); ft_memset(&g_input_actions, 0, sizeof(g_input_actions));
mlx_hook(win_ptr, DestroyNotify, StructureNotifyMask, set_quit, NULL);
mlx_hook(win_ptr, KeyPress, KeyPressMask, hook_keypress, NULL);
mlx_hook(win_ptr, KeyRelease, KeyReleaseMask, hook_keyrelease, NULL);
} }

View file

@ -6,7 +6,7 @@
/* By: mc <mc@student.42.fr> +#+ +:+ +#+ */ /* By: mc <mc@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */ /* +#+#+#+#+#+ +#+ */
/* Created: 2024/10/31 16:57:40 by mc #+# #+# */ /* Created: 2024/10/31 16:57:40 by mc #+# #+# */
/* Updated: 2024/11/07 00:07:35 by mc ### ########.fr */ /* Updated: 2024/11/07 14:25:29 by mc ### ########.fr */
/* */ /* */
/* ************************************************************************** */ /* ************************************************************************** */
@ -53,7 +53,6 @@ static int loop_hook(void *param)
int main(int argc, char *argv[]) int main(int argc, char *argv[])
{ {
g_mlx = mlx_init(); g_mlx = mlx_init();
input_init();
if (argc != 2) if (argc != 2)
{ {
printf("Syntax: %s <map.cub>\n", argv[0]); printf("Syntax: %s <map.cub>\n", argv[0]);
@ -62,8 +61,7 @@ int main(int argc, char *argv[])
if (!map_from_file(&g_map, argv[1])) if (!map_from_file(&g_map, argv[1]))
return (1); return (1);
g_win = mlx_new_window(g_mlx, SCREEN_WIDTH, SCREEN_HEIGHT, "cub3d"); g_win = mlx_new_window(g_mlx, SCREEN_WIDTH, SCREEN_HEIGHT, "cub3d");
mlx_hook(g_win, KeyPress, KeyPressMask, hook_keypress, NULL); input_init(g_win);
mlx_hook(g_win, KeyRelease, KeyReleaseMask, hook_keyrelease, NULL);
mlx_loop_hook(g_mlx, loop_hook, NULL); mlx_loop_hook(g_mlx, loop_hook, NULL);
draw_screen(); draw_screen();
mlx_loop(g_mlx); mlx_loop(g_mlx);