-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathraytracing_utils.c
More file actions
91 lines (84 loc) · 2.76 KB
/
raytracing_utils.c
File metadata and controls
91 lines (84 loc) · 2.76 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
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* raytracing_utils.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: youkhart <youkhart@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2019/12/25 22:06:48 by youkhart #+# #+# */
/* Updated: 2020/01/28 04:01:24 by youkhart ### ########.fr */
/* */
/* ************************************************************************** */
#include "minirt.h"
extern struct s_minirt g_rt;
extern int g_saving;
int put_menu(int menu)
{
if (!g_saving)
mlx_put_image_to_window(g_rt.data.mlx_ptr, g_rt.data.mlx_win,
g_rt.data.img_ptr, 0, 0);
if (!g_saving && !menu)
{
menu_toggle_msg();
show_menu();
selected_objects_msg();
}
g_saving = 0;
return (1);
}
t_intersection *test_intersection(t_obj *obj, t_ray ray)
{
if (!ft_memcmp(obj->type, "sp", 2))
return (intersects_with_sphere(ray, obj));
else if (!ft_strncmp(obj->type, "pl", 2))
return (intersects_with_plane(ray, obj));
else if (!ft_strncmp(obj->type, "tr", 2))
return (intersects_with_triangle(ray, obj));
else if (!ft_strncmp(obj->type, "cy", 2))
return (intersects_with_cylinder(ray, obj));
else if (!ft_strncmp(obj->type, "sq", 2))
return (intersects_with_square(ray, obj));
else
return (0);
}
int intersects_with_any(t_obj *obj, t_ray ray, float *t)
{
if (!ft_memcmp(obj->type, "sp", 2))
return (bool_intersects_with_sphere(ray, obj, t));
else if (!ft_strncmp(obj->type, "pl", 2))
return (bool_intersects_with_plane(ray, obj, t));
else if (!ft_strncmp(obj->type, "tr", 2))
return (bool_intersects_with_triangle(ray, obj, t));
else if (!ft_strncmp(obj->type, "cy", 2))
return (bool_intersects_with_cylinder(ray, obj, t));
else if (!ft_strncmp(obj->type, "sq", 2))
return (bool_intersects_with_square(ray, obj, t));
else
return (0);
}
t_intersection *get_closest_intersection(t_list *objects, t_ray ray)
{
t_list *objs;
t_intersection *closest;
t_intersection *inter;
float min_t;
objs = objects;
closest = NULL;
inter = NULL;
min_t = INFINITY;
while (objs)
{
inter = test_intersection((t_obj *)objs->content, ray);
if (inter && inter->t < min_t && inter->t > RAY_T_MIN)
{
min_t = inter->t;
if (closest)
free(closest);
closest = inter;
}
else if (inter)
free(inter);
objs = objs->next;
}
return (closest);
}