aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Makefile1
-rw-r--r--inc/cub3d.h2
-rw-r--r--map/lvl_three.cub2
-rw-r--r--src/ft_darken_rgb.c33
-rw-r--r--src/ft_draw_heals.c25
-rw-r--r--src/ft_draw_sprite.c26
-rw-r--r--src/ft_draw_textures.c19
-rw-r--r--src/ft_draw_traps.c26
-rw-r--r--src/ft_draw_verline.c1
-rw-r--r--src/ft_draw_weapons.c26
-rw-r--r--src/ft_floor_cast.c5
-rw-r--r--src/ft_get_sprite.c1
-rw-r--r--src/ft_raycasting.c1
-rw-r--r--src/ft_rgb_to_hex.c9
-rw-r--r--src/ft_suffer_animation.c2
15 files changed, 69 insertions, 110 deletions
diff --git a/Makefile b/Makefile
index 48fc5d9..5eb7f84 100644
--- a/Makefile
+++ b/Makefile
@@ -63,7 +63,6 @@ SRCS_NAME += ft_extra_keys.c
SRCS_NAME += ft_draw_verline.c
SRCS_NAME += ft_rgb_to_hex.c
SRCS_NAME += ft_hex_to_rgb.c
-SRCS_NAME += ft_darken_rgb.c
SRCS_NAME += ft_raycasting.c
SRCS_NAME += ft_init_s_ray.c
SRCS_NAME += ft_init_map.c
diff --git a/inc/cub3d.h b/inc/cub3d.h
index 0d8fede..faf990b 100644
--- a/inc/cub3d.h
+++ b/inc/cub3d.h
@@ -218,7 +218,7 @@ void ft_music_fork(char **mcmd_words, char *const envp[]);
int8_t ft_save_to_bmp(t_cub *cl);
int ft_error(uint8_t retval, const char *errmsg, t_cub *clist);
int8_t ft_warp_level(char *path, t_cub *cl);
-uint32_t ft_rgb_to_hex(t_rgb rgb);
+uint32_t ft_rgb_to_hex(float dist, t_rgb rgb, t_cub *cl);
t_bmp_rgb ft_hex_to_rgb(uint32_t color);
uint32_t ft_darken(t_rgb rgb, t_cub *cl);
void ft_death_screen(t_cub *cl);
diff --git a/map/lvl_three.cub b/map/lvl_three.cub
index e4ea8c7..3044f7f 100644
--- a/map/lvl_three.cub
+++ b/map/lvl_three.cub
@@ -27,5 +27,5 @@ MU ./media/sound/BITURE-ET-MELANCOLIE.wav
10011111011111111111101
1001 101 101
10011111011111111111101
-1200000000000T000!00001
+1200000000000T!00000001
11111111111111111111111
diff --git a/src/ft_darken_rgb.c b/src/ft_darken_rgb.c
deleted file mode 100644
index 223a540..0000000
--- a/src/ft_darken_rgb.c
+++ /dev/null
@@ -1,33 +0,0 @@
-/* ************************************************************************** */
-/* */
-/* ::: :::::::: */
-/* ft_darken_rgb.c :+: :+: :+: */
-/* +:+ +:+ +:+ */
-/* By: rbousset <marvin@42.fr> +#+ +:+ +#+ */
-/* +#+#+#+#+#+ +#+ */
-/* Created: 2020/03/05 16:04:28 by rbousset #+# #+# */
-/* Updated: 2020/03/05 16:04:29 by rbousset ### ########lyon.fr */
-/* */
-/* ************************************************************************** */
-
-#include <cub3d.h>
-#include <stdint.h>
-
-uint32_t
- ft_darken(t_rgb rgb, t_cub *cl)
-{
- t_rgb darker;
- float calc;
- float dist;
-
- if ((dist = cl->rlist.row_dist) <= 0)
- dist = 0.0001;
- calc = (dist * 0.1 * cl->mlist.darklvl);
- calc = (calc >= 255) ? (255) : (calc);
- calc = (calc < 1) ? (1) : (calc);
- darker = rgb;
- darker.r /= calc;
- darker.g /= calc;
- darker.b /= calc;
- return (ft_rgb_to_hex(darker));
-}
diff --git a/src/ft_draw_heals.c b/src/ft_draw_heals.c
index bc1e1b2..0ef9590 100644
--- a/src/ft_draw_heals.c
+++ b/src/ft_draw_heals.c
@@ -61,22 +61,19 @@ static void
ft_put_heal(t_sprite *sprite, t_cub *cl)
{
float dist;
- float calc;
+ t_rgb rgb;
- if ((dist = cl->rlist.wall_dist_tab[sprite->x]) <= 0)
+ if ((dist = sqrtf(powf(cl->plist.pos_x - sprite->s_pos_x, 2)
+ + powf(cl->plist.pos_y - sprite->s_pos_y, 2))) <= 0)
dist = 0.0001;
- calc = (dist * 0.1 * cl->mlist.darklvl);
- calc = (calc >= 255) ? (255) : (calc);
- calc = (calc < 1) ? (1) : (calc);
- cl->img.ptr[sprite->x * 4 + (sprite->y * cl->img.sizeline)] =
- (uint8_t)cl->tlist[17].ptr[sprite->tex_x * 4 + 4 *
- cl->tlist[17].img_h * sprite->tex_y] / calc;
- cl->img.ptr[sprite->x * 4 + (sprite->y * cl->img.sizeline) + 1] =
- (uint8_t)cl->tlist[17].ptr[sprite->tex_x * 4 + 4 *
- cl->tlist[17].img_h * sprite->tex_y + 1] / calc;
- cl->img.ptr[sprite->x * 4 + (sprite->y * cl->img.sizeline) + 2] =
- (uint8_t)cl->tlist[17].ptr[sprite->tex_x * 4 + 4 *
- cl->tlist[17].img_h * sprite->tex_y + 2] / calc;
+ rgb.r = (uint8_t)cl->tlist[17].ptr[sprite->tex_x * 4 + 4 *
+ cl->tlist[17].img_h * sprite->tex_y + 2];
+ rgb.g = (uint8_t)cl->tlist[17].ptr[sprite->tex_x * 4 + 4 *
+ cl->tlist[17].img_h * sprite->tex_y + 1];
+ rgb.b = (uint8_t)cl->tlist[17].ptr[sprite->tex_x * 4 + 4 *
+ cl->tlist[17].img_h * sprite->tex_y];
+ *(int*)(cl->img.ptr + ((uint16_t)sprite->x * 4 +
+ (sprite->y * cl->img.sizeline))) = ft_rgb_to_hex(dist, rgb, cl);
}
void
diff --git a/src/ft_draw_sprite.c b/src/ft_draw_sprite.c
index 5fc28d3..b381957 100644
--- a/src/ft_draw_sprite.c
+++ b/src/ft_draw_sprite.c
@@ -13,7 +13,6 @@
#include <libft.h>
#include <cub3d.h>
#include <stdint.h>
-#include <stdio.h>
#include <stdlib.h>
#include <math.h>
@@ -69,22 +68,19 @@ static void
ft_put_sprite(t_sprite *sprite, t_cub *cl)
{
float dist;
- float calc;
+ t_rgb rgb;
- if ((dist = cl->rlist.wall_dist_tab[sprite->x]) <= 0)
+ if ((dist = sqrtf(powf(cl->plist.pos_x - sprite->s_pos_x, 2)
+ + powf(cl->plist.pos_y - sprite->s_pos_y, 2))) <= 0)
dist = 0.0001;
- calc = (dist * 0.1 * cl->mlist.darklvl);
- calc = (calc >= 255) ? (255) : (calc);
- calc = (calc < 1) ? (1) : (calc);
- cl->img.ptr[sprite->x * 4 + (sprite->y * cl->img.sizeline)] =
- (uint8_t)cl->tlist[sprite->current_sprite].ptr[sprite->tex_x * 4 + 4 *
- cl->tlist[sprite->current_sprite].img_h * sprite->tex_y] / calc;
- cl->img.ptr[sprite->x * 4 + (sprite->y * cl->img.sizeline) + 1] =
- (uint8_t)cl->tlist[sprite->current_sprite].ptr[sprite->tex_x * 4 + 4 *
- cl->tlist[sprite->current_sprite].img_h * sprite->tex_y + 1] / calc;
- cl->img.ptr[sprite->x * 4 + (sprite->y * cl->img.sizeline) + 2] =
- (uint8_t)cl->tlist[sprite->current_sprite].ptr[sprite->tex_x * 4 + 4 *
- cl->tlist[sprite->current_sprite].img_h * sprite->tex_y + 2] / calc;
+ rgb.r = (uint8_t)cl->tlist[sprite->current_sprite].ptr[sprite->tex_x
+ * 4 + 4 * cl->tlist[sprite->current_sprite].img_h * sprite->tex_y + 2];
+ rgb.g = (uint8_t)cl->tlist[sprite->current_sprite].ptr[sprite->tex_x
+ * 4 + 4 * cl->tlist[sprite->current_sprite].img_h * sprite->tex_y + 1];
+ rgb.b = (uint8_t)cl->tlist[sprite->current_sprite].ptr[sprite->tex_x
+ * 4 + 4 * cl->tlist[sprite->current_sprite].img_h * sprite->tex_y];
+ *(int*)(cl->img.ptr + ((uint16_t)sprite->x * 4 +
+ (sprite->y * cl->img.sizeline))) = ft_rgb_to_hex(dist, rgb, cl);
}
void
diff --git a/src/ft_draw_textures.c b/src/ft_draw_textures.c
index 126d0af..4bc0b78 100644
--- a/src/ft_draw_textures.c
+++ b/src/ft_draw_textures.c
@@ -26,22 +26,21 @@ void
ft_draw_texture(t_cub *cl, int x, int y, int tex_y)
{
float dist;
- float calc;
+ t_rgb rgb;
if ((dist = cl->rlist.wall_dist) <= 0)
dist = 0.0001;
- calc = (dist * 0.1 * cl->mlist.darklvl);
- calc = (calc >= 255) ? (255) : (calc);
- calc = (calc < 1) ? (1) : (calc);
- cl->img.ptr[x * 4 + (cl->img.sizeline * y)] =
+ rgb.b =
(uint8_t)cl->tlist[cl->w_side].ptr[cl->tlist[cl->w_side].tex_x * 4 + 4 *
- cl->tlist[cl->w_side].img_h * tex_y] / calc;
- cl->img.ptr[x * 4 + (cl->img.sizeline * y) + 1] =
+ cl->tlist[cl->w_side].img_h * tex_y];
+ rgb.g =
(uint8_t)cl->tlist[cl->w_side].ptr[cl->tlist[cl->w_side].tex_x * 4 + 4 *
- cl->tlist[cl->w_side].img_h * tex_y + 1] / calc;
- cl->img.ptr[x * 4 + (cl->img.sizeline * y) + 2] =
+ cl->tlist[cl->w_side].img_h * tex_y + 1];
+ rgb.r =
(uint8_t)cl->tlist[cl->w_side].ptr[cl->tlist[cl->w_side].tex_x * 4 + 4 *
- cl->tlist[cl->w_side].img_h * tex_y + 2] / calc;
+ cl->tlist[cl->w_side].img_h * tex_y + 2];
+ *(int*)(cl->img.ptr + ((uint16_t)x * 4 +
+ (y * cl->img.sizeline))) = ft_rgb_to_hex(dist, rgb, cl);
}
void
diff --git a/src/ft_draw_traps.c b/src/ft_draw_traps.c
index 05e8446..ed53dc0 100644
--- a/src/ft_draw_traps.c
+++ b/src/ft_draw_traps.c
@@ -12,6 +12,7 @@
#include <cub3d.h>
#include <stdint.h>
+#include <math.h>
static void
ft_sort_traps_norme(float *dist_tab, int32_t it, t_cub *cl)
@@ -58,22 +59,19 @@ static void
ft_put_trap(t_sprite *sprite, t_cub *cl)
{
float dist;
- float calc;
+ t_rgb rgb;
- if ((dist = cl->rlist.wall_dist_tab[sprite->x]) <= 0)
+ if ((dist = sqrtf(powf(cl->plist.pos_x - sprite->s_pos_x, 2)
+ + powf(cl->plist.pos_y - sprite->s_pos_y, 2))) <= 0)
dist = 0.0001;
- calc = (dist * 0.1 * cl->mlist.darklvl);
- calc = (calc >= 255) ? (255) : (calc);
- calc = (calc < 1) ? (1) : (calc);
- cl->img.ptr[sprite->x * 4 + (sprite->y * cl->img.sizeline)] =
- (uint8_t)cl->tlist[15].ptr[sprite->tex_x * 4 + 4 *
- cl->tlist[15].img_h * sprite->tex_y] / calc;
- cl->img.ptr[sprite->x * 4 + (sprite->y * cl->img.sizeline) + 1] =
- (uint8_t)cl->tlist[15].ptr[sprite->tex_x * 4 + 4 *
- cl->tlist[15].img_h * sprite->tex_y + 1] / calc;
- cl->img.ptr[sprite->x * 4 + (sprite->y * cl->img.sizeline) + 2] =
- (uint8_t)cl->tlist[15].ptr[sprite->tex_x * 4 + 4 *
- cl->tlist[15].img_h * sprite->tex_y + 2] / calc;
+ rgb.r = (uint8_t)cl->tlist[15].ptr[sprite->tex_x * 4 + 4 *
+ cl->tlist[15].img_h * sprite->tex_y + 2];
+ rgb.g = (uint8_t)cl->tlist[15].ptr[sprite->tex_x * 4 + 4 *
+ cl->tlist[15].img_h * sprite->tex_y + 1];
+ rgb.b = (uint8_t)cl->tlist[15].ptr[sprite->tex_x * 4 + 4 *
+ cl->tlist[15].img_h * sprite->tex_y];
+ *(int*)(cl->img.ptr + ((uint16_t)sprite->x * 4 +
+ (sprite->y * cl->img.sizeline))) = ft_rgb_to_hex(dist, rgb, cl);
}
void
diff --git a/src/ft_draw_verline.c b/src/ft_draw_verline.c
index 16dc63c..7bfba8d 100644
--- a/src/ft_draw_verline.c
+++ b/src/ft_draw_verline.c
@@ -10,7 +10,6 @@
/* */
/* ************************************************************************** */
-#include <stdio.h>
#include <cub3d.h>
#include <stdint.h>
diff --git a/src/ft_draw_weapons.c b/src/ft_draw_weapons.c
index 2e1ec13..c527987 100644
--- a/src/ft_draw_weapons.c
+++ b/src/ft_draw_weapons.c
@@ -12,6 +12,7 @@
#include <cub3d.h>
#include <stdint.h>
+#include <math.h>
static void
ft_sort_weapons_norme(float *dist_tab, int16_t *i, uint16_t j, t_cub *cl)
@@ -65,22 +66,19 @@ static void
ft_put_weapon(t_sprite *sprite, t_cub *cl)
{
float dist;
- float calc;
+ t_rgb rgb;
- if ((dist = cl->rlist.wall_dist_tab[sprite->x]) <= 0)
+ if ((dist = sqrtf(powf(cl->plist.pos_x - sprite->s_pos_x, 2)
+ + powf(cl->plist.pos_y - sprite->s_pos_y, 2))) <= 0)
dist = 0.0001;
- calc = (dist * 0.1 * cl->mlist.darklvl);
- calc = (calc >= 255) ? (255) : (calc);
- calc = (calc < 1) ? (1) : (calc);
- cl->img.ptr[sprite->x * 4 + (sprite->y * cl->img.sizeline)] =
- (uint8_t)cl->tlist[sprite->current_sprite].ptr[sprite->tex_x * 4 + 4 *
- cl->tlist[sprite->current_sprite].img_h * sprite->tex_y] / calc;
- cl->img.ptr[sprite->x * 4 + (sprite->y * cl->img.sizeline) + 1] =
- (uint8_t)cl->tlist[sprite->current_sprite].ptr[sprite->tex_x * 4 + 4 *
- cl->tlist[sprite->current_sprite].img_h * sprite->tex_y + 1] / calc;
- cl->img.ptr[sprite->x * 4 + (sprite->y * cl->img.sizeline) + 2] =
- (uint8_t)cl->tlist[sprite->current_sprite].ptr[sprite->tex_x * 4 + 4 *
- cl->tlist[sprite->current_sprite].img_h * sprite->tex_y + 2] / calc;
+ rgb.r = (uint8_t)cl->tlist[sprite->current_sprite].ptr[sprite->tex_x
+ * 4 + 4 * cl->tlist[sprite->current_sprite].img_h * sprite->tex_y + 2];
+ rgb.g = (uint8_t)cl->tlist[sprite->current_sprite].ptr[sprite->tex_x
+ * 4 + 4 * cl->tlist[sprite->current_sprite].img_h * sprite->tex_y + 1];
+ rgb.b = (uint8_t)cl->tlist[sprite->current_sprite].ptr[sprite->tex_x
+ * 4 + 4 * cl->tlist[sprite->current_sprite].img_h * sprite->tex_y];
+ *(int*)(cl->img.ptr + ((uint16_t)sprite->x * 4 +
+ (sprite->y * cl->img.sizeline))) = ft_rgb_to_hex(dist, rgb, cl);
}
void
diff --git a/src/ft_floor_cast.c b/src/ft_floor_cast.c
index 160a2c1..9166147 100644
--- a/src/ft_floor_cast.c
+++ b/src/ft_floor_cast.c
@@ -16,8 +16,11 @@
static void
ft_draw_plain_horizontal(t_rgb rgb, t_cub *cl, int32_t y, int32_t x)
{
+ float dist;
+
+ dist = (cl->rlist.row_dist > 0) ? (cl->rlist.row_dist) : (0.0001);
*(int*)(cl->img.ptr +
- (x * 4 + (y * cl->img.sizeline))) = ft_darken(rgb, cl);
+ (x * 4 + (y * cl->img.sizeline))) = ft_rgb_to_hex(dist, rgb, cl);
}
static void
diff --git a/src/ft_get_sprite.c b/src/ft_get_sprite.c
index 5a5ecd0..05b13b2 100644
--- a/src/ft_get_sprite.c
+++ b/src/ft_get_sprite.c
@@ -13,7 +13,6 @@
#include <libft.h>
#include <cub3d.h>
#include <stdint.h>
-#include <stdio.h>
static int8_t
ft_get_sprite_id(char *word)
diff --git a/src/ft_raycasting.c b/src/ft_raycasting.c
index 7baac29..e6c87ff 100644
--- a/src/ft_raycasting.c
+++ b/src/ft_raycasting.c
@@ -13,7 +13,6 @@
#include <libft.h>
#include <cub3d.h>
#include <stdint.h>
-#include <stdio.h>
#include <stdlib.h>
#include <math.h>
diff --git a/src/ft_rgb_to_hex.c b/src/ft_rgb_to_hex.c
index e101dcf..2b72287 100644
--- a/src/ft_rgb_to_hex.c
+++ b/src/ft_rgb_to_hex.c
@@ -14,10 +14,14 @@
#include <stdint.h>
uint32_t
- ft_rgb_to_hex(t_rgb rgb)
+ ft_rgb_to_hex(float dist, t_rgb rgb, t_cub *cl)
{
uint32_t res;
+ float calc;
+ calc = (dist * 0.1 * cl->mlist.darklvl);
+ calc = (calc >= 255) ? (255) : (calc);
+ calc = (calc < 1) ? (1) : (calc);
rgb.r = (rgb.r > 255) ? (255) : (rgb.r);
rgb.g = (rgb.g > 255) ? (255) : (rgb.g);
rgb.b = (rgb.b > 255) ? (255) : (rgb.b);
@@ -25,6 +29,7 @@ uint32_t
rgb.g = (rgb.g < 0) ? (0) : (rgb.g);
rgb.b = (rgb.b < 0) ? (0) : (rgb.b);
res = 0;
- res += ((rgb.r << 16) + (rgb.g << 8) + rgb.b);
+ res += (((uint8_t)(rgb.r / calc) << 16) + ((uint8_t)(rgb.g / calc) << 8)
+ + (uint8_t)(rgb.b / calc));
return (res);
}
diff --git a/src/ft_suffer_animation.c b/src/ft_suffer_animation.c
index 51de24a..1b48e47 100644
--- a/src/ft_suffer_animation.c
+++ b/src/ft_suffer_animation.c
@@ -75,7 +75,7 @@ void
rgb.g += 20;
rgb.b += 20;
*(int*)(cl->img.ptr +
- (x * 4 + (y * cl->img.sizeline))) = ft_rgb_to_hex(rgb);
+ (x * 4 + (y * cl->img.sizeline))) = ft_rgb_to_hex(0, rgb, cl);
}
}
ft_get_damaged(cl);