-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathnavigate.c
135 lines (126 loc) · 3.64 KB
/
navigate.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
/* ************************************************************************** */
/* */
/* :::::::: */
/* navigate.c :+: :+: */
/* +:+ */
/* By: dreijans <[email protected]> +#+ */
/* +#+ */
/* Created: 2023/05/20 18:50:12 by dreijans #+# #+# */
/* Updated: 2023/09/26 18:31:42 by djoyke ######## odam.nl */
/* */
/* ************************************************************************** */
#include "fractol.h"
/**
* @param param void to be replaced with t_fractol struct
* @brief event triggered function.
* checks with MLX42 functions and mlx struct how we're navigating through the image
* and if a certain key is pressed executes the correct action.
*/
void ft_move(void *param)
{
t_fractol *data;
data = param;
if (mlx_is_key_down(data->mlx, MLX_KEY_ESCAPE))
mlx_close_window(data->mlx);
ft_travel(data);
ft_iter(data);
if (mlx_is_mouse_down(data->mlx, MLX_MOUSE_BUTTON_RIGHT))
{
ft_mouse_pos(data);
choose(data);
}
}
/**
* @param data t_fractol struct
* @brief event triggered function.
* checks with MLX42 functions and mlx struct if the pressed key
* triggers an iteration increase or decrease.
*/
void ft_iter(t_fractol *data)
{
if (mlx_is_key_down(data->mlx, MLX_KEY_EQUAL))
{
data->max += 10;
choose(data);
}
if (mlx_is_key_down(data->mlx, MLX_KEY_MINUS))
{
data->max -= 10;
choose(data);
}
}
/**
* @param data t_fractol struct
* @brief event triggered function.
* checks with MLX42 functions and mlx struct how we're navigating through the image
* and calculates how big the movements need to be.
*/
void ft_travel(t_fractol *data)
{
if (mlx_is_key_down(data->mlx, MLX_KEY_UP))
{
data->y[0] -= 0.1 / 2;
data->y[1] -= 0.1 / 2;
choose(data);
}
if (mlx_is_key_down(data->mlx, MLX_KEY_DOWN))
{
data->y[0] += 0.1 / 2;
data->y[1] += 0.1 / 2;
choose(data);
}
if (mlx_is_key_down(data->mlx, MLX_KEY_LEFT))
{
data->x[0] += 0.1 / 2;
data->x[1] += 0.1 / 2;
choose(data);
}
if (mlx_is_key_down(data->mlx, MLX_KEY_RIGHT))
{
data->x[0] -= 0.1 / 2;
data->x[1] -= 0.1 / 2;
choose(data);
}
}
/**
* @param x double for x axis
* @param y double for y axis
* @param param void to be replaced with t_fractol struct
* @brief event triggered function. that zooms from the centre of the image
*/
void ft_zoom(double x, double y, void *param)
{
t_fractol *data;
data = param;
(void)x;
if (y > 0)
{
data->x[0] = data->x[0] * 0.95;
data->x[1] = data->x[1] * 0.95;
data->y[0] = data->y[0] * 0.95;
data->y[1] = data->y[1] * 0.95;
}
else if (y < 0)
{
data->x[0] = data->x[0] / 0.95;
data->x[1] = data->x[1] / 0.95;
data->y[0] = data->y[0] / 0.95;
data->y[1] = data->y[1] / 0.95;
}
choose(data);
}
/**
* @param data t_fractol struct
* @brief event triggered function.
* checks with MLX42 functions and mlx struct how the julia fractol needs to change
* by taking the x and y axis to recalculate the coordinates that need to be given to
* the julia making function.
*/
void ft_mouse_pos(t_fractol *data)
{
int32_t x;
int32_t y;
mlx_get_mouse_pos(data->mlx, &x, &y);
data->j_x = data->x[0] + ((double)x / WIDTH) * (data->x[1] - data->x[0]);
data->j_y = data->y[1] + ((double)y / HEIGHT) * (data->y[0] - data->y[1]);
}