-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathmain.c
More file actions
78 lines (70 loc) · 2.37 KB
/
main.c
File metadata and controls
78 lines (70 loc) · 2.37 KB
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
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* main.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: zurag <zurag@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2021/10/10 19:31:23 by zurag #+# #+# */
/* Updated: 2021/10/10 19:31:24 by zurag ### ########.fr */
/* */
/* ************************************************************************** */
#include "fractol.h"
void my_mlx_pixel_put(t_vars *data, int x, int y, int color)
{
char *dst;
dst = data->addr + (y * data->line_length + x * (data->bits_per_pixel / 8));
*(unsigned int *)dst = color;
}
int create_trgb(int t, int r, int g, int b)
{
return (t << 24 | r << 16 | g << 8 | b);
}
void ft_print_available_params(void)
{
write(2, "Available params: julia; mandelbrot; burning_ship;\n", 52);
exit(1);
}
void ft_init_fractal(t_vars *vars_mlx, char *name)
{
if (!ft_strncmp(name, "julia", 8))
{
vars_mlx->name = 'j';
vars_mlx->fractal.dx = 0.285;
vars_mlx->fractal.dy = 0.01;
}
else if (!ft_strncmp(name, "mandelbrot", 11))
{
vars_mlx->name = 'm';
vars_mlx->fractal.dx = -100;
vars_mlx->fractal.dy = 0;
}
else if (!ft_strncmp(name, "burning_ship", 13))
{
vars_mlx->name = 'b';
vars_mlx->fractal.dx = 100;
vars_mlx->fractal.dy = -100;
}
else
ft_print_available_params();
ft_fractal(vars_mlx);
}
int main(int argc, char **argv)
{
t_vars vars_mlx;
vars_mlx.fractal.flag_j = 1;
vars_mlx.fractal.zoom = 0.8;
vars_mlx.fractal.max_iter = 25;
vars_mlx.fractal.color = 1;
if (argc != 2)
ft_print_available_params();
vars_mlx.mlx = mlx_init();
vars_mlx.win = mlx_new_window(vars_mlx.mlx, WIDHT, HEIGHT, "fractal");
ft_init_fractal(&vars_mlx, argv[1]);
mlx_hook(vars_mlx.win, 2, 0, mlx_key, &vars_mlx);
mlx_hook(vars_mlx.win, 4, 0, ft_zoom, &vars_mlx);
if (vars_mlx.name == 'j')
mlx_hook(vars_mlx.win, 6, 1L << 6, ft_mouse, &vars_mlx);
mlx_loop(vars_mlx.mlx);
return (0);
}