aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Makefile1
-rw-r--r--inc/cub3d.h3
-rw-r--r--inc/cub3d_defines.h4
-rw-r--r--inc/cub3d_structs.h3
-rw-r--r--src/ft_check_missing.c12
-rw-r--r--src/ft_tex_init.c49
-rw-r--r--src/ft_tex_weap_init.c46
-rw-r--r--src/ft_warp_level.c1
-rw-r--r--src/main.c1
9 files changed, 95 insertions, 25 deletions
diff --git a/Makefile b/Makefile
index 33a509d..01ac1ec 100644
--- a/Makefile
+++ b/Makefile
@@ -105,6 +105,7 @@ SRCS_NAME += ft_get_heal_spawn.c
SRCS_NAME += ft_draw_heals.c
SRCS_NAME += ft_draw_heals_extra.c
SRCS_NAME += ft_find_item.c
+SRCS_NAME += ft_tex_weap_init.c
#--------------------------------------------------------------------------------------------------#
SRCS = $(addprefix ${SRCS_DIR},${SRCS_NAME})
#--------------------------------------------------------------------------------------------------#
diff --git a/inc/cub3d.h b/inc/cub3d.h
index fa42b4f..aedd550 100644
--- a/inc/cub3d.h
+++ b/inc/cub3d.h
@@ -61,7 +61,8 @@ void ft_death_hooks(t_win *wl, t_cub *cl);
** ====== TEXTURES ======
*/
-void ft_wall_tex_init(t_cub *clist);
+void ft_wall_tex_init(t_cub *cl);
+void ft_weap_tex_init(t_cub *cl);
void ft_choose_tex(t_cub *clist);
/*
diff --git a/inc/cub3d_defines.h b/inc/cub3d_defines.h
index f5824ce..8a435f2 100644
--- a/inc/cub3d_defines.h
+++ b/inc/cub3d_defines.h
@@ -95,6 +95,8 @@ enum
# define FT_SFX_TRAP_PATH "./media/sound/sfx/trap.wav"
# define FT_DEATH_SCREEN_PATH "./media/img/screens/death_screen.xpm"
# define FT_HUD_BACK_PATH "./media/img/tex/plate_small.xpm"
+# define FT_WEAPON_ONE_SPR_PATH "./media/img/sprites/sword_s.xpm"
+# define FT_WEAPON_TWO_SPR_PATH "./media/img/sprites/sword_s.xpm"
# define FT_WEAPON_ONE_PATH "./media/img/weapons/sword_w.xpm"
# define FT_WEAPON_ONE_FIRE_PATH "./media/img/weapons/sword_w_fire.xpm"
# define FT_WEAPON_TWO_PATH "./media/img/weapons/sword_w.xpm"
@@ -227,6 +229,8 @@ enum
# define FT_ERR_MISS_W_ONE_FIRE "weapon one shooting image"
# define FT_ERR_MISS_W_TWO "weapon two image"
# define FT_ERR_MISS_W_TWO_FIRE "weapon two shooting image"
+# define FT_ERR_MISS_W_ONE_SPR "weapon one image"
+# define FT_ERR_MISS_W_TWO_SPR "weapon one image"
/*
** ====== OTHER ======
diff --git a/inc/cub3d_structs.h b/inc/cub3d_structs.h
index fc3eead..332ced4 100644
--- a/inc/cub3d_structs.h
+++ b/inc/cub3d_structs.h
@@ -253,7 +253,8 @@ typedef struct s_cub
struct s_img death_screen;
struct s_rgb f_rgb;
struct s_rgb c_rgb;
- struct s_img tlist[18];
+ struct s_img tlist[20];
+ struct s_img tweap[4];
struct s_sprite **sprites;
struct s_sprite traps[512];
struct s_sprite heals[64];
diff --git a/src/ft_check_missing.c b/src/ft_check_missing.c
index fcebf3f..4b4a3ef 100644
--- a/src/ft_check_missing.c
+++ b/src/ft_check_missing.c
@@ -40,6 +40,15 @@ static int
{
int8_t i;
+ if (ft_check_not_found(FT_WEAPON_ONE_SPR_PATH) < 0 ||
+ ft_check_ext(FT_WEAPON_ONE_SPR_PATH, ".xpm") < 0)
+ return (ft_missing_error(FT_ERR_MISS_W_ONE_SPR, clist));
+ if (ft_check_not_found(FT_WEAPON_TWO_SPR_PATH) < 0 ||
+ ft_check_ext(FT_WEAPON_TWO_SPR_PATH, ".xpm") < 0)
+ return (ft_missing_error(FT_ERR_MISS_W_TWO_SPR, clist));
+ if (ft_check_not_found(FT_HEAL_PACK_PATH) < 0 ||
+ ft_check_ext(FT_HEAL_PACK_PATH, ".xpm") < 0)
+ return (ft_missing_error(FT_ERR_MISS_HEAL_PACK, clist));
i = 0;
while ((i + 2) <= clist->mlist.topsp)
{
@@ -71,9 +80,6 @@ static int
if (ft_check_not_found(FT_WEAPON_TWO_FIRE_PATH) < 0 ||
ft_check_ext(FT_WEAPON_TWO_FIRE_PATH, ".xpm") < 0)
return (ft_missing_error(FT_ERR_MISS_W_TWO_FIRE, clist));
- if (ft_check_not_found(FT_HEAL_PACK_PATH) < 0 ||
- ft_check_ext(FT_HEAL_PACK_PATH, ".xpm") < 0)
- return (ft_missing_error(FT_ERR_MISS_HEAL_PACK, clist));
return (ft_check_missing_sprites(clist));
}
diff --git a/src/ft_tex_init.c b/src/ft_tex_init.c
index 6486e87..34f9fb9 100644
--- a/src/ft_tex_init.c
+++ b/src/ft_tex_init.c
@@ -1,7 +1,7 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
-/* ft_basic_keys.c :+: :+: :+: */
+/* ft_tex_init.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: fmoenne- <marvin@42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
@@ -13,30 +13,31 @@
#include <libft.h>
#include <cub3d.h>
#include <stdint.h>
-#include <stdio.h>
#include <mlx.h>
/*
** tlist[] index summary
** ---------------------
-** 0 : no
-** 1 : so
-** 2 : ea
-** 3 : we
-** 4 : sprite 2
-** 5 : new level door
-** 6 : floor
-** 7 : ceil / skybox
-** 8 : sprite 3
-** 9 : sprite 4
-** 10 : sprite 5
-** 11 : sprite 6
-** 12 : sprite 7
-** 13 : sprite 8
-** 14 : sprite 9
-** 15 : trap
-** 16 : HUD back
-** 17 : heal pack
+** 0: no
+** 1: so
+** 2: ea
+** 3: we
+** 4: sprite 2
+** 5: new level door
+** 6: floor
+** 7: ceil / skybox
+** 8: sprite 3
+** 9: sprite 4
+** 10: sprite 5
+** 11: sprite 6
+** 12: sprite 7
+** 13: sprite 8
+** 14: sprite 9
+** 15: trap
+** 16: HUD back
+** 17: heal pack
+** 18: weapon one sprite
+** 19: weapon two sprite
*/
static void
@@ -78,6 +79,14 @@ static void
FT_HUD_BACK_PATH, &cl->tlist[16].img_w, &cl->tlist[16].img_h);
cl->tlist[16].ptr = mlx_get_data_addr(cl->tlist[16].img,
&cl->tlist[16].bpp, &cl->tlist[16].sizeline, &cl->tlist[16].endian);
+ cl->tlist[18].img = mlx_xpm_file_to_image(cl->wlist.wlx,
+ FT_WEAPON_ONE_SPR_PATH, &cl->tlist[18].img_w, &cl->tlist[18].img_h);
+ cl->tlist[18].ptr = mlx_get_data_addr(cl->tlist[18].img,
+ &cl->tlist[18].bpp, &cl->tlist[18].sizeline, &cl->tlist[18].endian);
+ cl->tlist[19].img = mlx_xpm_file_to_image(cl->wlist.wlx,
+ FT_WEAPON_TWO_SPR_PATH, &cl->tlist[19].img_w, &cl->tlist[19].img_h);
+ cl->tlist[19].ptr = mlx_get_data_addr(cl->tlist[19].img,
+ &cl->tlist[19].bpp, &cl->tlist[19].sizeline, &cl->tlist[19].endian);
cl->walltexgood = 1;
if (cl->mlist.sprite_var > 1)
ft_next_sprite_init(cl);
diff --git a/src/ft_tex_weap_init.c b/src/ft_tex_weap_init.c
new file mode 100644
index 0000000..ac78de9
--- /dev/null
+++ b/src/ft_tex_weap_init.c
@@ -0,0 +1,46 @@
+/* ************************************************************************** */
+/* */
+/* ::: :::::::: */
+/* ft_tex_weap_init.c :+: :+: :+: */
+/* +:+ +:+ +:+ */
+/* By: fmoenne- <marvin@42.fr> +#+ +:+ +#+ */
+/* +#+#+#+#+#+ +#+ */
+/* Created: 2020/02/14 17:43:55 by fmoenne- #+# #+# */
+/* Updated: 2020/02/14 17:43:56 by fmoenne- ### ########lyon.fr */
+/* */
+/* ************************************************************************** */
+
+#include <libft.h>
+#include <cub3d.h>
+#include <stdint.h>
+#include <stdio.h>
+#include <mlx.h>
+
+/*
+** tweap[] index summary
+** 0: weapon one
+** 1: weapon one fire
+** 2: weapon two
+** 3: weapon two fire
+*/
+
+void
+ ft_weap_tex_init(t_cub *cl)
+{
+ cl->tweap[0].img = mlx_xpm_file_to_image(cl->wlist.wlx,
+ FT_WEAPON_ONE_PATH, &cl->tweap[0].img_w, &cl->tweap[0].img_h);
+ cl->tweap[0].ptr = mlx_get_data_addr(cl->tweap[0].img,
+ &cl->tweap[0].bpp, &cl->tweap[0].sizeline, &cl->tweap[0].endian);
+ cl->tweap[1].img = mlx_xpm_file_to_image(cl->wlist.wlx,
+ FT_WEAPON_ONE_FIRE_PATH, &cl->tweap[1].img_w, &cl->tweap[1].img_h);
+ cl->tweap[1].ptr = mlx_get_data_addr(cl->tweap[1].img,
+ &cl->tweap[1].bpp, &cl->tweap[1].sizeline, &cl->tweap[1].endian);
+ cl->tweap[2].img = mlx_xpm_file_to_image(cl->wlist.wlx,
+ FT_WEAPON_TWO_PATH, &cl->tweap[2].img_w, &cl->tweap[2].img_h);
+ cl->tweap[2].ptr = mlx_get_data_addr(cl->tweap[2].img,
+ &cl->tweap[2].bpp, &cl->tweap[2].sizeline, &cl->tweap[2].endian);
+ cl->tweap[3].img = mlx_xpm_file_to_image(cl->wlist.wlx,
+ FT_WEAPON_TWO_FIRE_PATH, &cl->tweap[3].img_w, &cl->tweap[3].img_h);
+ cl->tweap[3].ptr = mlx_get_data_addr(cl->tweap[3].img,
+ &cl->tweap[3].bpp, &cl->tweap[3].sizeline, &cl->tweap[3].endian);
+}
diff --git a/src/ft_warp_level.c b/src/ft_warp_level.c
index a2b6006..09f0322 100644
--- a/src/ft_warp_level.c
+++ b/src/ft_warp_level.c
@@ -116,6 +116,7 @@ int8_t
if (isoldmus)
ft_memdel((void*)&tmp_mup);
ft_wall_tex_init(cl);
+ ft_weap_tex_init(cl);
ft_memdel((void*)&next_path);
return (0);
}
diff --git a/src/main.c b/src/main.c
index a1c9a8c..623787b 100644
--- a/src/main.c
+++ b/src/main.c
@@ -30,6 +30,7 @@ int
if (ft_init_winlx(clist) < 0)
return (ft_exit(FT_RET_FAILED_MLX, clist));
ft_wall_tex_init(clist);
+ ft_weap_tex_init(clist);
ft_use_args(argc, argv, envp, clist);
return (FT_RET_FINE);
}