diff options
-rw-r--r-- | inc/cub3d_defines.h | 3 | ||||
-rw-r--r-- | inc/cub3d_structs.h | 2 | ||||
-rw-r--r-- | src/ft_check_map_line.c | 3 | ||||
-rw-r--r-- | src/ft_extra_keys.c | 9 | ||||
-rw-r--r-- | src/ft_find_item.c | 12 | ||||
-rw-r--r-- | src/ft_get_topsp.c | 32 | ||||
-rw-r--r-- | src/ft_init_lists.c | 5 | ||||
-rw-r--r-- | src/ft_init_map.c | 2 | ||||
-rw-r--r-- | src/ft_warp_level.c | 13 |
9 files changed, 38 insertions, 43 deletions
diff --git a/inc/cub3d_defines.h b/inc/cub3d_defines.h index 7df3de3..c3c5d66 100644 --- a/inc/cub3d_defines.h +++ b/inc/cub3d_defines.h @@ -289,5 +289,8 @@ enum # define FT_TRAP_DAMAGE_AMOUNT 45 # define FT_HEAL_PACK_AMOUNT 20 # define FT_BOUNCE_FACTOR 4 +# define FT_WEAP_ONE_STRT_AMMO -4 +# define FT_WEAP_TWO_STRT_AMMO 30 +# define FT_WEAP_THREE_STRT_AMMO 24 # endif diff --git a/inc/cub3d_structs.h b/inc/cub3d_structs.h index babf3be..380b7f4 100644 --- a/inc/cub3d_structs.h +++ b/inc/cub3d_structs.h @@ -135,6 +135,7 @@ typedef struct s_player int16_t life; uint8_t has_weapon[3]; int8_t handles_weapon; + int16_t ammo[3]; } t_player; typedef struct s_ray @@ -214,7 +215,6 @@ typedef struct s_map uint8_t isskybox; uint8_t istraps; uint8_t isheals; - uint8_t isweapon[3]; uint8_t darklvl; uint16_t scale; int8_t topsp; diff --git a/src/ft_check_map_line.c b/src/ft_check_map_line.c index 9419ab2..44580db 100644 --- a/src/ft_check_map_line.c +++ b/src/ft_check_map_line.c @@ -39,9 +39,6 @@ static int8_t } cl->mlist.istraps = (line[i] == 'T') ? (1) : (cl->mlist.istraps); cl->mlist.isheals = (line[i] == '+') ? (1) : (cl->mlist.isheals); - cl->mlist.isweapon[0] = (line[i] == '!') ? (1) : (cl->mlist.isweapon[0]); - cl->mlist.isweapon[1] = (line[i] == '@') ? (1) : (cl->mlist.isweapon[1]); - ft_get_topsp(line[i], cl); return (0); } diff --git a/src/ft_extra_keys.c b/src/ft_extra_keys.c index a78f821..097e2e2 100644 --- a/src/ft_extra_keys.c +++ b/src/ft_extra_keys.c @@ -71,8 +71,15 @@ int int ft_space_key(t_cub *clist) { - if (clist->plist.fire == 0) + uint8_t w_id; + + w_id = clist->plist.handles_weapon; + w_id = (w_id == 2) ? (1) : (w_id); + w_id = (w_id == 4) ? (2) : (w_id); + if (clist->plist.fire == 0 && + (clist->plist.ammo[w_id] > 0 || clist->plist.ammo[w_id] == -4)) { + clist->plist.ammo[w_id] -= w_id; clist->sfx[clist->plist.handles_weapon + 7].sfx_play(clist->sfx); clist->plist.fire = 1; } diff --git a/src/ft_find_item.c b/src/ft_find_item.c index caeb3f4..cea05fa 100644 --- a/src/ft_find_item.c +++ b/src/ft_find_item.c @@ -30,6 +30,17 @@ static uint16_t } static void + ft_set_ammo(uint8_t weap_id, t_player *pl) +{ + if (weap_id == 0) + pl->ammo[0] = FT_WEAP_ONE_STRT_AMMO; + else if (weap_id == 1) + pl->ammo[1] = FT_WEAP_TWO_STRT_AMMO; + else if (weap_id == 2) + pl->ammo[2] = FT_WEAP_THREE_STRT_AMMO; +} + +static void ft_weapon_check(const char map_char, t_player *pl, t_cub *cl) { uint8_t weap_id; @@ -48,6 +59,7 @@ static void pl->handles_weapon = (weap_id == 0) ? (0) : (pl->handles_weapon); pl->handles_weapon = (weap_id == 1) ? (2) : (pl->handles_weapon); pl->handles_weapon = (weap_id == 2) ? (4) : (pl->handles_weapon); + ft_set_ammo(weap_id, pl); if (weap_id == 0) cl->sfx[6].sfx_play(cl->sfx); else if (weap_id == 1) diff --git a/src/ft_get_topsp.c b/src/ft_get_topsp.c deleted file mode 100644 index 84339c3..0000000 --- a/src/ft_get_topsp.c +++ /dev/null @@ -1,32 +0,0 @@ -/* ************************************************************************** */ -/* */ -/* ::: :::::::: */ -/* ft_check_map_line.c :+: :+: :+: */ -/* +:+ +:+ +:+ */ -/* By: rbousset <marvin@42.fr> +#+ +:+ +#+ */ -/* +#+#+#+#+#+ +#+ */ -/* Created: 2020/02/14 17:28:34 by rbousset #+# #+# */ -/* Updated: 2020/02/14 17:28:37 by rbousset ### ########lyon.fr */ -/* */ -/* ************************************************************************** */ - -#include <libft.h> -#include <cub3d.h> -#include <stddef.h> -#include <stdint.h> - -void - ft_get_topsp(char c, t_cub *clist) -{ - (void)c; - (void)clist; - /* int8_t x; */ - - /* if ((x = ft_strlchr(FT_CHRST_SPRITES, c)) > 0) */ - /* { */ - /* if ((x + 2) > clist->mlist.topsp) */ - /* { */ - /* clist->mlist.topsp = x + 2; */ - /* } */ - /* } */ -} diff --git a/src/ft_init_lists.c b/src/ft_init_lists.c index d9a2ad2..b551aab 100644 --- a/src/ft_init_lists.c +++ b/src/ft_init_lists.c @@ -33,7 +33,7 @@ t_rgb ** -1: no weapon ** 0: weapon one ** 2: weapon two -** 4: weapon two +** 4: weapon three */ t_player @@ -55,6 +55,9 @@ t_player plist.has_weapon[1] = 0; plist.has_weapon[2] = 0; plist.handles_weapon = -1; + plist.ammo[0] = 0; + plist.ammo[1] = 0; + plist.ammo[2] = 0; plist.life = FT_STRT_LIFE; plist.fire = 0; return (plist); diff --git a/src/ft_init_map.c b/src/ft_init_map.c index a2a9ce1..1b55d17 100644 --- a/src/ft_init_map.c +++ b/src/ft_init_map.c @@ -97,8 +97,6 @@ int8_t mlist->isskybox = 0; mlist->istraps = 0; mlist->isheals = 0; - mlist->isweapon[0] = 0; - mlist->isweapon[1] = 0; mlist->traps_nbr = 0; mlist->heals_nbr = 0; return (ft_init_map_norme(mlist)); diff --git a/src/ft_warp_level.c b/src/ft_warp_level.c index 02911b0..5055445 100644 --- a/src/ft_warp_level.c +++ b/src/ft_warp_level.c @@ -21,14 +21,18 @@ static void ft_player_keepings(t_cub *cl) { - int16_t tmp_life; - uint8_t tmp_has[3]; - int8_t tmp_handles; + int16_t tmp_life; + uint8_t tmp_has[3]; + uint16_t tmp_ammo[3]; + int8_t tmp_handles; tmp_life = cl->plist.life; tmp_has[0] = cl->plist.has_weapon[0]; tmp_has[1] = cl->plist.has_weapon[1]; tmp_has[2] = cl->plist.has_weapon[2]; + tmp_ammo[0] = cl->plist.ammo[0]; + tmp_ammo[1] = cl->plist.ammo[1]; + tmp_ammo[2] = cl->plist.ammo[2]; tmp_handles = cl->plist.handles_weapon; cl->plist = ft_init_player(); if (!cl->isdead) @@ -36,6 +40,9 @@ static void cl->plist.has_weapon[0] = tmp_has[0]; cl->plist.has_weapon[1] = tmp_has[1]; cl->plist.has_weapon[2] = tmp_has[2]; + cl->plist.ammo[0] = tmp_ammo[0]; + cl->plist.ammo[1] = tmp_ammo[1]; + cl->plist.ammo[2] = tmp_ammo[2]; cl->plist.handles_weapon = tmp_handles; } |