-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathdraw_set.c
More file actions
92 lines (82 loc) · 2.57 KB
/
draw_set.c
File metadata and controls
92 lines (82 loc) · 2.57 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
79
80
81
82
83
84
85
86
87
88
89
90
91
92
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* draw_set.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: rvinnie <marvin@42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2021/08/02 16:33:07 by rvinnie #+# #+# */
/* Updated: 2021/08/02 16:33:08 by rvinnie ### ########.fr */
/* */
/* ************************************************************************** */
#include "fractol.h"
void my_pxl_put(t_data *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;
}
void set_info(t_info *s_info, t_set *s_set, int x, int y)
{
double x_diff;
double y_diff;
x_diff = s_info->s_set.range / (double)s_info->w;
y_diff = s_info->s_set.range / (double)s_info->h;
s_set->a = x * x_diff - s_info->s_set.range / 2 - s_info->s_set.hor_diff;
s_set->b = y * y_diff - s_info->s_set.range / 2 - s_info->s_set.ver_diff;
s_set->start_a = s_set->a;
s_set->start_b = s_set->b;
}
void put_set_pxls(t_info *s_info, t_set *s_set, int x, int y)
{
int n;
n = 0;
while (n < s_info->max_iter)
{
s_set->next_a = s_set->a * s_set->a - s_set->b * s_set->b;
s_set->next_b = 2 * s_set->a * s_set->b;
if (s_info->kind == 2)
{
s_set->a = s_set->next_a + s_set->start_a;
s_set->b = s_set->next_b + s_set->start_b;
}
else
{
s_set->a = s_set->next_a + s_set->jul_real;
s_set->b = s_set->next_b + s_set->jul_img;
}
if (fabs(s_set->a + s_set->b) > (double)16)
break ;
n++;
}
my_pxl_put(&s_info->img, x, y, take_color(*s_info, n));
}
void draw_set(t_info *s_info)
{
int x;
int y;
y = 0;
while (y < s_info->h)
{
x = 0;
while (x < s_info->w)
{
set_info(s_info, &s_info->s_set, x, y);
put_set_pxls(s_info, &s_info->s_set, x++, y);
}
y++;
}
}
void sets_drawer(t_info *s_info)
{
s_info->s_set.range = 4;
s_info->s_set.hor_diff = 0;
s_info->s_set.ver_diff = 0;
if (s_info->kind == 1)
{
s_info->s_set.jul_real = JUL_REAL_1;
s_info->s_set.jul_img = JUL_IMG_1;
}
draw_set(s_info);
mlx_put_image_to_window(s_info->mlx, s_info->win, s_info->img.img, 0, 0);
}