-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathput_obj.c
92 lines (84 loc) · 3.19 KB
/
put_obj.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
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* put_obj.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: mehtel <[email protected]> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2021/03/23 18:56:19 by mehtel #+# #+# */
/* Updated: 2021/03/23 19:07:27 by mehtel ### ########.fr */
/* */
/* ************************************************************************** */
#include "cub3d.h"
void put_player(t_vars *vars)
{
t_ray cords;
int line_len;
int x;
init_player_screen(vars, &cords);
x = -1;
while (++x < vars->map->resolution_width)
{
init_ray(vars, &cords, x);
find_ray_dir_and_initial_len(vars, &cords);
cast_ray(vars, &cords);
calculate_perp_dist(vars, &cords);
line_len = (vars->map->resolution_hight / cords.perp * vars->win_k);
if (cords.perp == 0)
line_len = vars->map->resolution_hight;
vars->map->zbuf[x] = cords.perp;
find_x_texture_cord(&cords, vars);
put_textured_line(vars, line_len, &cords, x);
}
find_distanse_to_sprites(vars);
selection_sorting_sprite(vars->map->sprites_dist,
vars->map->sprites_order,
vars->map->sprite_counter);
project_sprites(vars, &cords);
}
int get_pole_by_ray_dir(t_ray *cords)
{
int ret;
if (cords->side == X)
ret = (cords->ray_dir[X] > 0) ? EA : WE;
else
ret = (cords->ray_dir[Y] < 0) ? NO : SO;
return (ret);
}
void find_x_texture_cord(t_ray *cords, t_vars *vars)
{
cords->cur_tex = get_pole_by_ray_dir(cords);
cords->on_wall = vars->player[!cords->side]
+ cords->perp * cords->ray_dir[!cords->side];
cords->on_wall -= floor((cords->on_wall));
cords->tex[X] = (int)(cords->on_wall
* (double)vars->texs[cords->cur_tex]->size[X]);
if (cords->cur_tex == EA || cords->cur_tex == NO)
cords->tex[X] = vars->texs[cords->cur_tex]->size[X] - cords->tex[X] - 1;
}
void put_textured_line(t_vars *vars, int line_len,
t_ray *cords, int x)
{
double shift;
double pos;
int start_of_line;
int end_of_line;
start_of_line = (vars->map->resolution_hight >> 1) - (line_len >> 1);
start_of_line *= start_of_line > 0;
end_of_line = (vars->map->resolution_hight >> 1) + (line_len >> 1);
if (end_of_line > vars->map->resolution_hight)
end_of_line = (vars->map->resolution_hight - 1);
shift = 1.0 * vars->texs[cords->cur_tex]->size[Y] / line_len;
pos = ((start_of_line - (vars->map->resolution_hight >> 1)
+ (line_len >> 1)) * shift);
while (start_of_line < end_of_line)
{
cords->tex[Y] = (int)pos & (vars->texs[cords->cur_tex]->size[Y] - 1);
pos += shift;
pixel_put(vars, x, start_of_line,
*(int*)(vars->texs[cords->cur_tex]->addr
+ vars->texs[cords->cur_tex]->line_length * cords->tex[Y]
+ cords->tex[X] * vars->texs[cords->cur_tex]->bits_per_pixel / 8));
start_of_line++;
}
}