-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpaint_sprites.c
109 lines (100 loc) · 3.86 KB
/
paint_sprites.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
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* paint_sprites.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: lbrandy <[email protected]> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2021/03/11 13:58:48 by lbrandy #+# #+# */
/* Updated: 2021/04/02 19:42:16 by lbrandy ### ########.fr */
/* */
/* ************************************************************************** */
#include "cub3d.h"
void init_sprite_dist(t_datasprite *data_sprite, t_pos *pos, t_all *all)
{
int i;
i = 0;
while (i < data_sprite->count_sprites)
{
data_sprite->sprites[i].dist = (pos->pos_x - data_sprite->sprites[i].x)
* (pos->pos_x - data_sprite->sprites[i].x)
+ (pos->pos_y - data_sprite->sprites[i].y)
* (pos->pos_y - data_sprite->sprites[i].y);
i++;
}
data_sprite->tex_width = all->s->width;
data_sprite->tex_height = all->s->height;
}
void calculate_draw(t_datasprite *sprite, t_textures *res)
{
sprite->draw_start_y = -sprite->sprite_height / 2 + res->y / 2;
if (sprite->draw_start_y < 0)
sprite->draw_start_y = 0;
sprite->draw_end_y = sprite->sprite_height / 2 + res->y / 2;
if (sprite->draw_end_y >= res->y)
sprite->draw_end_y = res->y - 1;
sprite->sprite_width = abs((int)(res->x * 0.66 / sprite->transform_y));
sprite->draw_start_x = -sprite->sprite_width / 2 + sprite->sprite_screen_x;
if (sprite->draw_start_x < 0)
sprite->draw_start_x = 0;
sprite->draw_end_x = sprite->sprite_width / 2 + sprite->sprite_screen_x;
if (sprite->draw_end_x >= res->x)
sprite->draw_end_x = res->x - 1;
}
void calc_sprite(t_datasprite *sprite, int i, t_pos *pos, t_textures *res)
{
sprite->sprite_x = sprite->sprites[i].x - pos->pos_x + 0.5;
sprite->sprite_y = sprite->sprites[i].y - pos->pos_y + 0.5;
sprite->inv_det = 1.0 / (pos->plane_x * pos->dir_y
- pos->dir_x * pos->plane_y);
sprite->transform_x = sprite->inv_det * (pos->dir_y
* sprite->sprite_x - pos->dir_x * sprite->sprite_y);
sprite->transform_y = sprite->inv_det * (-pos->plane_y
* sprite->sprite_x + pos->plane_x * sprite->sprite_y);
sprite->sprite_screen_x = (int)((res->x / 2) * (1
+ sprite->transform_x / sprite->transform_y));
sprite->sprite_height = abs((int)(res->x * 0.66 / sprite->transform_y));
calculate_draw(sprite, res);
}
void draw_sprite(t_datasprite *s, t_textures *r, t_datatext *t, t_all *all)
{
int y;
int d;
while (s->stripe < s->draw_end_x)
{
s->tex_x = (int)(256 * (s->stripe - (-s->sprite_width / 2
+ s->sprite_screen_x)) * s->tex_width
/ s->sprite_width) / 256;
if (s->transform_y > 0 && s->stripe > 0 && s->stripe < r->x
&& s->transform_y < s->z_buffer[s->stripe])
{
y = s->draw_start_y;
while (y < s->draw_end_y)
{
d = y * 256 - r->y * 128 + s->sprite_height * 128;
s->tex_y = ((d * s->tex_height) / s->sprite_height) / 256;
s->color = (*(int *)(t->addr + (s->tex_y
* t->length + s->tex_x * (t->bpp / 8))));
if ((s->color & 0x00FFFFFF) != 0)
my_mlx_pixel_put(all, s->stripe, y, s->color);
y++;
}
}
s->stripe++;
}
}
void draw_sprites(t_all *all)
{
int i;
i = 0;
init_sprite_dist(all->data_sprite, all->pos, all);
quick_sort(all->data_sprite->sprites, 0,
all->data_sprite->count_sprites - 1);
while (i < all->data_sprite->count_sprites)
{
calc_sprite(all->data_sprite, i, all->pos, all->textures);
all->data_sprite->stripe = all->data_sprite->draw_start_x;
draw_sprite(all->data_sprite, all->textures, all->s, all);
i++;
}
}