-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathft_movement.c
110 lines (100 loc) · 2.48 KB
/
ft_movement.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
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
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* ft_keyhook.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: rcheiko <[email protected]> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2021/04/01 11:57:25 by rcheiko #+# #+# */
/* Updated: 2021/04/20 11:41:29 by rcheiko ### ########.fr */
/* */
/* ************************************************************************** */
#include "cub3d.h"
void movement_w(t_mlx *d)
{
int x_tmp;
int y_tmp;
if (d->keyw == 1)
{
x_tmp = d->pos_x;
y_tmp = d->pos_y;
d->pos_x = d->pos_x + cos(M_PI / d->val_pi) * 8;
d->pos_y = d->pos_y - sin(M_PI / d->val_pi) * 8;
if (d->map[(int)d->pos_y / 64][(int)d->pos_x / 64] == 1)
{
d->pos_x = x_tmp;
d->pos_y = y_tmp;
}
}
}
void movement_s(t_mlx *d)
{
int x_tmp;
int y_tmp;
if (d->keys == 1)
{
x_tmp = d->pos_x;
y_tmp = d->pos_y;
d->pos_x = d->pos_x - cos(M_PI / d->val_pi) * 8;
d->pos_y = d->pos_y + sin(M_PI / d->val_pi) * 8;
if (d->map[(int)d->pos_y / 64][(int)d->pos_x / 64] == 1)
{
d->pos_x = x_tmp;
d->pos_y = y_tmp;
}
}
}
void movement_d(t_mlx *d)
{
int x_tmp;
int y_tmp;
if (d->keyd == 1)
{
d->val_pi = 180 / (d->angle - 90);
x_tmp = d->pos_x;
y_tmp = d->pos_y;
d->pos_x = d->pos_x + cos(M_PI / d->val_pi) * 8;
d->pos_y = d->pos_y - sin(M_PI / d->val_pi) * 8;
if (d->map[(int)d->pos_y / 64][(int)d->pos_x / 64] == 1)
{
d->pos_x = x_tmp;
d->pos_y = y_tmp;
}
}
}
void movement_a(t_mlx *d)
{
int x_tmp;
int y_tmp;
if (d->keya == 1)
{
d->val_pi = 180 / (d->angle + 90);
x_tmp = d->pos_x;
y_tmp = d->pos_y;
d->pos_x = d->pos_x + cos(M_PI / d->val_pi) * 8;
d->pos_y = d->pos_y - sin(M_PI / d->val_pi) * 8;
if (d->map[(int)d->pos_y / 64][(int)d->pos_x / 64] == 1)
{
d->pos_x = x_tmp;
d->pos_y = y_tmp;
}
}
}
void movement_fl_esc(t_mlx *d)
{
if (d->keyfg == 1)
{
d->angle = d->angle + 5;
verif_angle(d);
}
if (d->keyfd == 1)
{
d->angle = d->angle - 5;
verif_angle(d);
}
if (d->keyesc == 1)
{
free_all(d);
exit(0);
}
}