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
|
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* state.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: cacharle <marvin@42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2020/02/24 09:58:01 by cacharle #+# #+# */
/* Updated: 2020/02/25 15:57:01 by cacharle ### ########.fr */
/* */
/* ************************************************************************** */
#include "fractol.h"
void state_update_palette(t_state *state)
{
int i;
t_color_hsl hsl;
free(state->palette);
if ((state->palette = malloc(sizeof(t_color) * (state->iterations + 1))) == NULL)
{
state->running = false;
return ;
}
i = -1;
while (++i < state->iterations)
{
hsl.h = (int)(255.0 * ((double)i / (double)state->iterations));
hsl.s = 100;
hsl.l = 127;
state->palette[i] = color_hsl_to_rgb(hsl);
}
state->palette[i].hexcode = 0x0;
}
static int st_state_dispatch_func(t_state *state, char *fractal_name)
{
if (ft_strcmp(fractal_name, "mandelbrot") == 0)
state->func = &mandelbrot;
else if (ft_strcmp(fractal_name, "julia") == 0)
{
state->func = &julia;
state->c.r = 0.0;
state->c.i = 0.0;
return (0);
}
else if (ft_strcmp(fractal_name, "tricorn") == 0)
state->func = &tricorn;
else if (ft_strcmp(fractal_name, "burningship") == 0)
state->func = &burningship;
else
return (-1);
state->c.r = NAN;
state->c.i = NAN;
return (0);
}
int state_init(t_state *state, char *fractal_name)
{
if (st_state_dispatch_func(state, fractal_name) < 0)
return (-1);
if ((state->mlx_ptr = mlx_init()) == NULL)
return (-1);
if ((state->window_ptr = mlx_new_window(state->mlx_ptr, WINDOW_WIDTH, WINDOW_HEIGHT, WINDOW_TITLE)) == NULL)
return (state_destroy(state));
state->window.width = WINDOW_WIDTH;
state->window.height = WINDOW_HEIGHT;
if ((state->window.id = mlx_new_image(state->mlx_ptr, state->window.width, state->window.height)) == NULL)
return (state_destroy(state));
state->window.data = mlx_get_data_addr(state->window.id, &state->window.depth,
&state->window.size_line, &state->window.endian);
state->running = true;
state->center.r = 0.0;
state->center.i = 0.0;
state->plane.r = 4.0;
state->plane.i = 4.0;
state->iterations = 30;
state->palette = NULL;
state_update_palette(state);
state->updated = false;
return (0);
}
int state_destroy(t_state *state)
{
if (state == NULL)
return (-1);
if (state->mlx_ptr != NULL && state->window.id != NULL)
mlx_destroy_image(state->mlx_ptr, state->window.id);
if (state->mlx_ptr != NULL && state->window_ptr != NULL)
mlx_destroy_window(state->mlx_ptr, state->window_ptr);
return (-1);
}
|