-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathinterception_v2.c
64 lines (61 loc) · 2.02 KB
/
interception_v2.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
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* interception_v2.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: aqadil <[email protected]> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2022/06/07 16:01:52 by aqadil #+# #+# */
/* Updated: 2022/07/17 09:11:21 by aqadil ### ########.fr */
/* */
/* ************************************************************************** */
#include "cub3d.h"
void calcule_vertical_interception(t_vars *var, t_data *mlx)
{
var->dis_v = 1000000;
var->tan = tan(deg_to_rad(var->ra));
var->dof = 0;
if (cos(deg_to_rad(var->ra)) > 0)
{
var->rx = (((int)mlx->px / 64) * 64) + 64;
var->ry = (mlx->px - var->rx) * var->tan + mlx->py;
var->xo = 64;
var->yo = -var->xo * var->tan;
}
else if (cos(deg_to_rad(var->ra)) < 0)
{
var->rx = (((int)mlx->px / 64) * 64) - 0.0001;
var->ry = (mlx->px - var->rx) * var->tan + mlx->py;
var->xo = -64;
var->yo = -var->xo * var->tan;
}
else
{
var->rx = mlx->px;
var->ry = mlx->py;
var->dof = var->max_ray_checks;
}
}
void calcule_horz_interception(t_vars *var, t_data *mlx)
{
if (sin(deg_to_rad(var->ra)) > 0)
{
var->ry = (((int)mlx->py / 64) * 64) - 0.0001;
var->rx = (mlx->py - var->ry) * var->tan + mlx->px;
var->yo = -64;
var->xo = -var->yo * var->tan;
}
else if (sin(deg_to_rad(var->ra)) < 0)
{
var->ry = (((int)mlx->py / 64) * 64) + 64;
var->rx = (mlx->py - var->ry) * var->tan + mlx->px;
var->yo = 64;
var->xo = -var->yo * var->tan;
}
else
{
var->rx = mlx->px;
var->ry = mlx->py;
var->dof = var->max_ray_checks;
}
}