diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/ft_basic_keys.c | 17 | ||||
-rw-r--r-- | src/ft_detect.c | 2 | ||||
-rw-r--r-- | src/ft_extra_keys.c | 5 | ||||
-rw-r--r-- | src/ft_raycasting.c | 2 |
4 files changed, 19 insertions, 7 deletions
diff --git a/src/ft_basic_keys.c b/src/ft_basic_keys.c index 48fc009..d147486 100644 --- a/src/ft_basic_keys.c +++ b/src/ft_basic_keys.c @@ -17,10 +17,11 @@ int ft_w_key(t_cub *clist) { t_player *pl; + const float move_speed = 0.2; pl = clist->plist; - pl->pos_y += 0.2 * (-1); - pl->pos_x += 0; + pl->pos_y += move_speed * pl->dir_x; + pl->pos_x += move_speed * pl->dir_y; return (0); } @@ -28,9 +29,11 @@ int ft_a_key(t_cub *clist) { t_player *pl; + const float move_speed = 0.1; pl = clist->plist; - pl->pos_x -= 0.2; + pl->pos_y += move_speed * -pl->dir_y; + pl->pos_x += move_speed * pl->dir_x; return (0); } @@ -38,9 +41,11 @@ int ft_s_key(t_cub *clist) { t_player *pl; + const float move_speed = 0.2; pl = clist->plist; - pl->pos_y += 0.2; + pl->pos_y += move_speed * -pl->dir_x; + pl->pos_x += move_speed * -pl->dir_y; return (0); } @@ -48,8 +53,10 @@ int ft_d_key(t_cub *clist) { t_player *pl; + const float move_speed = 0.1; pl = clist->plist; - pl->pos_x += 0.2; + pl->pos_y += move_speed * pl->dir_y; + pl->pos_x += move_speed * -pl->dir_x; return (0); } diff --git a/src/ft_detect.c b/src/ft_detect.c index bfc4449..10d7147 100644 --- a/src/ft_detect.c +++ b/src/ft_detect.c @@ -52,13 +52,13 @@ static void cl->rlist.x_side_dist = (cl->rlist.sqx + 1.0 - cl->rlist.x_ray_pos) * cl->rlist.x_delta_dist; } - ft_detection_init_y(cl); } void ft_detect(t_cub *cl) { ft_detection_init_x(cl); + ft_detection_init_y(cl); cl->rlist.hit = 0; while (cl->rlist.hit == 0) { diff --git a/src/ft_extra_keys.c b/src/ft_extra_keys.c index ebcaf48..79c0ed2 100644 --- a/src/ft_extra_keys.c +++ b/src/ft_extra_keys.c @@ -13,6 +13,7 @@ #include <cub3d.h> #include <stdint.h> #include <math.h> +#include <stdio.h> int ft_left_key(t_cub *clist) @@ -29,6 +30,8 @@ int sav_plane_x = pl->plane_x; pl->plane_x = pl->plane_x * cos(rot_speed) - pl->plane_y * sin(rot_speed); pl->plane_y = sav_plane_x * sin(rot_speed) + pl->plane_y * cos(rot_speed); + printf("dir_x> %f\n", pl->dir_x); + printf("dir_y> %f\n", pl->dir_y); return (0); } @@ -47,6 +50,8 @@ int sav_plane_x = pl->plane_x; pl->plane_x = pl->plane_x * cos(-rot_speed) - pl->plane_y * sin(-rot_speed); pl->plane_y = sav_plane_x * sin(-rot_speed) + pl->plane_y * cos(-rot_speed); + printf("dir_x> %f\n", pl->dir_x); + printf("dir_y> %f\n", pl->dir_y); return (0); } diff --git a/src/ft_raycasting.c b/src/ft_raycasting.c index fadb9db..a4446b3 100644 --- a/src/ft_raycasting.c +++ b/src/ft_raycasting.c @@ -55,7 +55,7 @@ void if (cl->rlist.wall_t < 0) cl->rlist.wall_t = 0; cl->rlist.wall_b = cl->rlist.line_h / 2 + wl->y_size / 2; - if (cl->rlist.wall_b >= wl->y_size)\ + if (cl->rlist.wall_b >= wl->y_size) cl->rlist.wall_b = wl->y_size - 1; ft_draw_verline(cl, i, cl->rlist.wall_t - 1, cl->rlist.wall_b); i++; |