diff options
-rw-r--r-- | inc/cub3d.h | 10 | ||||
-rw-r--r-- | map/map_one.cub | 2 | ||||
-rw-r--r-- | src/ft_check_missing.c | 5 | ||||
-rw-r--r-- | src/ft_get_colors.c | 12 | ||||
-rw-r--r-- | src/ft_get_res.c | 4 | ||||
-rw-r--r-- | src/ft_get_screen_size.c | 15 | ||||
-rw-r--r-- | src/ft_init_lists.c | 41 | ||||
-rw-r--r-- | src/ft_parse_map.c | 1 | ||||
-rw-r--r-- | src/ft_print_list.c | 4 | ||||
-rw-r--r-- | src/ft_rgb_to_hex.c | 18 | ||||
-rw-r--r-- | src/ft_select_get.c | 10 | ||||
-rw-r--r-- | src/main.c | 1 |
12 files changed, 76 insertions, 47 deletions
diff --git a/inc/cub3d.h b/inc/cub3d.h index f017973..7ea11d6 100644 --- a/inc/cub3d.h +++ b/inc/cub3d.h @@ -58,9 +58,9 @@ typedef struct s_img typedef struct s_rgb { - uint8_t r; - uint8_t g; - uint8_t b; + int16_t r; + int16_t g; + int16_t b; } t_rgb; /* @@ -85,8 +85,6 @@ typedef struct s_cub char *ea_tex_path; char *we_tex_path; char *sprite_path; - int f_color; - int c_color; char *mapl; char **map; size_t map_w; @@ -130,6 +128,6 @@ int ft_map_error(t_cub *clist); int ft_init_winlx(t_cub *clist); void ft_drawmap(t_cub *clist); void ft_print_list(t_cub *clist); -int ft_rgb_to_hex(t_rgb rgb); +uint32_t ft_rgb_to_hex(t_rgb rgb); # endif diff --git a/map/map_one.cub b/map/map_one.cub index ad496ae..2a4c17a 100644 --- a/map/map_one.cub +++ b/map/map_one.cub @@ -7,7 +7,7 @@ WE ./path_to_the_west_texture S ./path_to_the_sprite_texture -F 100,123,213 +F 255,255,213 C 225,30,0 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 diff --git a/src/ft_check_missing.c b/src/ft_check_missing.c index 50fabbb..00bfbe9 100644 --- a/src/ft_check_missing.c +++ b/src/ft_check_missing.c @@ -27,6 +27,7 @@ int int ft_check_missing(t_cub *clist) { + ft_printf("[%d], [%d], [%d]\n", clist->f_rgb.r, clist->f_rgb.g, clist->f_rgb.b); if (!clist->no_tex_path[0]) return (ft_missing_error("north side texture", clist)); else if (!clist->so_tex_path[0]) @@ -39,9 +40,9 @@ int return (ft_missing_error("sprite texture", clist)); else if (clist->wlist->x_size == 0 || clist->wlist->y_size == 0) return (ft_missing_error("resolution", clist)); - else if (clist->f_color < 0) + else if (clist->f_rgb.r == -1 || clist->f_rgb.g == -1 || clist->f_rgb.b == -1) return (ft_missing_error("floor color", clist)); - else if (clist->c_color < 0) + else if (clist->c_rgb.r == -1 || clist->c_rgb.g == -1 || clist->c_rgb.b == -1) return (ft_missing_error("ceiling color", clist)); else if (clist->plist->pos_x == 0 || clist->plist->pos_y == 0) return (ft_missing_error("player spawn", clist)); diff --git a/src/ft_get_colors.c b/src/ft_get_colors.c index 249ff5a..52461ea 100644 --- a/src/ft_get_colors.c +++ b/src/ft_get_colors.c @@ -45,12 +45,6 @@ int8_t ft_free_words(num); return (-1); } - clist->f_color = ft_atoi(num[0]); - clist->f_color *= 1000; - clist->f_color += ft_atoi(num[1]); - clist->f_color *= 1000; - clist->f_color += ft_atoi(num[2]); - clist->f_rgb.r = ft_atoi(num[0]); clist->f_rgb.g = ft_atoi(num[1]); clist->f_rgb.b = ft_atoi(num[2]); @@ -75,12 +69,6 @@ int8_t ft_free_words(num); return (-1); } - clist->c_color = ft_atoi(num[0]); - clist->c_color *= 1000; - clist->c_color += ft_atoi(num[1]); - clist->c_color *= 1000; - clist->c_color += ft_atoi(num[2]); - clist->c_rgb.r = ft_atoi(num[0]); clist->c_rgb.g = ft_atoi(num[1]); clist->c_rgb.b = ft_atoi(num[2]); diff --git a/src/ft_get_res.c b/src/ft_get_res.c index 649ab23..5e3dc06 100644 --- a/src/ft_get_res.c +++ b/src/ft_get_res.c @@ -30,7 +30,9 @@ static int8_t int8_t ft_get_res(char **words, t_cub *clist) { - t_win *wlist = clist->wlist; + t_win *wlist; + + wlist = clist->wlist; if (!(*words + 0) || !(*(words + 1)) || !(*(words + 2)) || (*(words + 3))) return (-1); diff --git a/src/ft_get_screen_size.c b/src/ft_get_screen_size.c index cd9b162..a580a77 100644 --- a/src/ft_get_screen_size.c +++ b/src/ft_get_screen_size.c @@ -1,8 +1,21 @@ +/* ************************************************************************** */ +/* LE - / */ +/* / */ +/* ft_get_screen_size.c .:: .:/ . .:: */ +/* +:+:+ +: +: +:+:+ */ +/* By: rbousset <marvin@le-101.fr> +:+ +: +: +:+ */ +/* #+# #+ #+ #+# */ +/* Created: 2020/02/05 16:06:58 by rbousset #+# ## ## #+# */ +/* Updated: 2020/02/05 16:06:59 by rbousset ### #+. /#+ ###.fr */ +/* / */ +/* / */ +/* ************************************************************************** */ + #include <libft.h> #include <cub3d.h> int8_t -ft_get_screen_size(t_win *wlist) + ft_get_screen_size(t_win *wlist) { char **words; diff --git a/src/ft_init_lists.c b/src/ft_init_lists.c index 291ef7b..ec46713 100644 --- a/src/ft_init_lists.c +++ b/src/ft_init_lists.c @@ -18,6 +18,30 @@ #include <stdlib.h> #include <limits.h> +static t_rgb + ft_init_rgb(void) +{ + t_rgb rgb; + + rgb.r = -1; + rgb.g = -1; + rgb.b = -1; + return (rgb); +} + +static t_player + *ft_init_player(void) +{ + t_player *plist; + + if (!(plist = (t_player*)malloc(sizeof(t_player)))) + return (NULL); + plist->pos_x = 0; + plist->pos_y = 0; + plist->view_side = 0; + return (plist); +} + t_win *ft_init_win(void) { @@ -36,19 +60,6 @@ t_win return (wlist); } -static t_player - *ft_init_player(void) -{ - t_player *plist; - - if (!(plist = (t_player*)malloc(sizeof(t_player)))) - return (NULL); - plist->pos_x = 0; - plist->pos_y = 0; - plist->view_side = 0; - return (plist); -} - t_cub *ft_init_cub(void) { @@ -67,12 +78,12 @@ t_cub !(clist->plist = ft_init_player())) return (NULL); clist->map[1] = 0; - clist->f_color = -1; - clist->c_color = -1; clist->map_w = 0; clist->map_h = 0; clist->line_chk = 0; clist->map_start = 0; clist->isspawn = 0; + clist->f_rgb = ft_init_rgb(); + clist->c_rgb = ft_init_rgb(); return (clist); } diff --git a/src/ft_parse_map.c b/src/ft_parse_map.c index 58df20a..64b590b 100644 --- a/src/ft_parse_map.c +++ b/src/ft_parse_map.c @@ -122,6 +122,5 @@ void if ((clist->scale = ((uint16_t)clist->wlist->x_size / (uint16_t)clist->map_w) - 1) < 1) clist->scale = 1; - ft_print_list(clist); close(fd); } diff --git a/src/ft_print_list.c b/src/ft_print_list.c index 4e9e8d7..6c2b702 100644 --- a/src/ft_print_list.c +++ b/src/ft_print_list.c @@ -26,8 +26,8 @@ void ft_printf("West ------- [%s]\n", clist->we_tex_path); ft_printf("East ------- [%s]\n", clist->ea_tex_path); ft_printf("Sprite ----- [%s]\n", clist->sprite_path); - ft_printf("F color ---- [%d]\n", clist->f_color); - ft_printf("C color ---- [%d]\n", clist->c_color); + ft_printf("F color ---- [%d]\n", ft_rgb_to_hex(clist->f_rgb)); + ft_printf("C color ---- [%d]\n", ft_rgb_to_hex(clist->c_rgb)); i = 0; ft_printf("Map\n----\n"); while (clist->map[i]) diff --git a/src/ft_rgb_to_hex.c b/src/ft_rgb_to_hex.c index 525296d..4a7ad8e 100644 --- a/src/ft_rgb_to_hex.c +++ b/src/ft_rgb_to_hex.c @@ -1,9 +1,23 @@ +/* ************************************************************************** */ +/* LE - / */ +/* / */ +/* ft_rgb_to_hex.c .:: .:/ . .:: */ +/* +:+:+ +: +: +:+:+ */ +/* By: rbousset <marvin@le-101.fr> +:+ +: +: +:+ */ +/* #+# #+ #+ #+# */ +/* Created: 2020/02/05 16:07:13 by rbousset #+# ## ## #+# */ +/* Updated: 2020/02/05 16:07:14 by rbousset ### #+. /#+ ###.fr */ +/* / */ +/* / */ +/* ************************************************************************** */ + #include <cub3d.h> +#include <stdint.h> -int +uint32_t ft_rgb_to_hex(t_rgb rgb) { - int res; + uint32_t res; res = 0; res += ((rgb.r << 16) + (rgb.g << 8) + rgb.b); diff --git a/src/ft_select_get.c b/src/ft_select_get.c index 188a6de..53a37d4 100644 --- a/src/ft_select_get.c +++ b/src/ft_select_get.c @@ -33,10 +33,12 @@ ft_check_exists(const int8_t ret, t_cub *clist) return (-1); else if (ret == 5 && (clist->sprite_path[0])) return (-1); - else if (ret == 6 && (clist->f_color != -1)) - return (-1); - else if (ret == 7 && (clist->c_color != -1)) - return (-1); + /* else if (ret == 6 && ((clist->f_rgb.r != -1) || (clist->f_rgb.g != -1) */ + /* || (clist->f_rgb.b != -1))) */ + /* return (-1); */ + /* else if (ret == 7 && ((clist->c_rgb.r != -1) || (clist->c_rgb.g != -1) */ + /* || (clist->c_rgb.b != -1))) */ + /* return (-1); */ return (ret); } @@ -31,6 +31,7 @@ int ft_memdel((void**)&clist); return (1); } + ft_print_list(clist); ft_parse_map("map/map_one.cub", clist); if (ft_init_winlx(clist) < 0) return (ft_exit(3, clist)); |