fix norm
This commit is contained in:
parent
bee17fcc1b
commit
2e17e4a4d9
87
main.c
87
main.c
@ -6,7 +6,7 @@
|
|||||||
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */
|
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2022/02/13 16:42:55 by apommier #+# #+# */
|
/* Created: 2022/02/13 16:42:55 by apommier #+# #+# */
|
||||||
/* Updated: 2022/02/13 22:02:38 by apommier ### ########.fr */
|
/* Updated: 2022/02/13 22:26:17 by apommier ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
@ -20,15 +20,6 @@
|
|||||||
#include <fcntl.h>
|
#include <fcntl.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
|
||||||
typedef struct s_data {
|
|
||||||
void *mlx;
|
|
||||||
void *mlx_win;
|
|
||||||
char **map_tab;
|
|
||||||
int item;
|
|
||||||
int move;
|
|
||||||
int bear;
|
|
||||||
} t_data;
|
|
||||||
|
|
||||||
size_t ft_strlen_double(char **s)
|
size_t ft_strlen_double(char **s)
|
||||||
{
|
{
|
||||||
size_t i;
|
size_t i;
|
||||||
@ -57,21 +48,25 @@ void quit_game(t_data *img)
|
|||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
int *choose_bear(t_data *img)
|
int *choose_bear(t_data *img)
|
||||||
{
|
{
|
||||||
int *buffer;
|
int *buffer;
|
||||||
int img_width;
|
int img_width;
|
||||||
int img_height;
|
int img_height;
|
||||||
|
|
||||||
buffer = 0;
|
buffer = 0;
|
||||||
if (img->bear == 119)
|
if (img->bear == 119)
|
||||||
buffer = mlx_xpm_file_to_image(img->mlx, "./sprite/back_bear.xpm", &img_width, &img_height);
|
buffer = mlx_xpm_file_to_image(img->mlx, "./sprite/back_bear.xpm",
|
||||||
|
&img_width, &img_height);
|
||||||
else if (img->bear == 97)
|
else if (img->bear == 97)
|
||||||
buffer = mlx_xpm_file_to_image(img->mlx, "./sprite/left_bear.xpm", &img_width, &img_height);
|
buffer = mlx_xpm_file_to_image(img->mlx, "./sprite/left_bear.xpm",
|
||||||
|
&img_width, &img_height);
|
||||||
else if (img->bear == 100)
|
else if (img->bear == 100)
|
||||||
buffer = mlx_xpm_file_to_image(img->mlx, "./sprite/right_bear.xpm", &img_width, &img_height);
|
buffer = mlx_xpm_file_to_image(img->mlx, "./sprite/right_bear.xpm",
|
||||||
|
&img_width, &img_height);
|
||||||
else
|
else
|
||||||
buffer = mlx_xpm_file_to_image(img->mlx, "./sprite/front_bear.xpm", &img_width, &img_height);
|
buffer = mlx_xpm_file_to_image(img->mlx, "./sprite/front_bear.xpm",
|
||||||
|
&img_width, &img_height);
|
||||||
if (buffer == 0)
|
if (buffer == 0)
|
||||||
return (0);
|
return (0);
|
||||||
return (buffer);
|
return (buffer);
|
||||||
@ -79,25 +74,29 @@ int *choose_bear(t_data *img)
|
|||||||
|
|
||||||
void print_case(char type, t_data *img, int y, int x)
|
void print_case(char type, t_data *img, int y, int x)
|
||||||
{
|
{
|
||||||
int *buffer;
|
int *buffer;
|
||||||
int img_width;
|
int img_width;
|
||||||
int img_height;
|
int img_height;
|
||||||
|
|
||||||
if (type == '1')
|
if (type == '1')
|
||||||
buffer = mlx_xpm_file_to_image(img->mlx, "./sprite/snow_tree.xpm", &img_width, &img_height);
|
buffer = mlx_xpm_file_to_image(img->mlx, "./sprite/snow_tree.xpm",
|
||||||
|
&img_width, &img_height);
|
||||||
else if (type == 'P')
|
else if (type == 'P')
|
||||||
buffer = choose_bear(img);
|
buffer = choose_bear(img);
|
||||||
else if (type == 'C')
|
else if (type == 'C')
|
||||||
buffer = mlx_xpm_file_to_image(img->mlx, "./sprite/honey.xpm", &img_width, &img_height);
|
buffer = mlx_xpm_file_to_image(img->mlx, "./sprite/honey.xpm",
|
||||||
|
&img_width, &img_height);
|
||||||
else if (type == 'E')
|
else if (type == 'E')
|
||||||
buffer = mlx_xpm_file_to_image(img->mlx, "./sprite/exit.XPM", &img_width, &img_height);
|
buffer = mlx_xpm_file_to_image(img->mlx, "./sprite/exit.XPM",
|
||||||
|
&img_width, &img_height);
|
||||||
else
|
else
|
||||||
buffer = mlx_xpm_file_to_image(img->mlx, "./sprite/back.xpm", &img_width, &img_height);
|
buffer = mlx_xpm_file_to_image(img->mlx, "./sprite/back.xpm",
|
||||||
|
&img_width, &img_height);
|
||||||
mlx_put_image_to_window(img->mlx, img->mlx_win, buffer, x * 32, y * 32);
|
mlx_put_image_to_window(img->mlx, img->mlx_win, buffer, x * 32, y * 32);
|
||||||
mlx_destroy_image(img->mlx, buffer);
|
mlx_destroy_image(img->mlx, buffer);
|
||||||
}
|
}
|
||||||
|
|
||||||
void print_map(char **map, t_data *img)
|
void print_map(char **map, t_data *img)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
int j;
|
int j;
|
||||||
@ -145,8 +144,8 @@ void change_map(t_data *img, int y, int x, char *change)
|
|||||||
|
|
||||||
int is_good(char **map, int type, t_data *img)
|
int is_good(char **map, int type, t_data *img)
|
||||||
{
|
{
|
||||||
int j;
|
int j;
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
i = 0;
|
i = 0;
|
||||||
j = 0;
|
j = 0;
|
||||||
@ -181,14 +180,36 @@ int key_press(int code, t_data *img)
|
|||||||
return (1);
|
return (1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
char **set_map(char **argv)
|
||||||
|
{
|
||||||
|
char **map;
|
||||||
|
char *map_line;
|
||||||
|
char *del;
|
||||||
|
char *swap;
|
||||||
|
int fd;
|
||||||
|
|
||||||
|
fd = open(argv[1], O_RDONLY);
|
||||||
|
swap = get_next_line(fd);
|
||||||
|
while (swap)
|
||||||
|
{
|
||||||
|
del = map;
|
||||||
|
map = ft_strjoin(map, swap);
|
||||||
|
free(swap);
|
||||||
|
swap = get_next_line(fd);
|
||||||
|
free(del);
|
||||||
|
}
|
||||||
|
return (map);
|
||||||
|
}
|
||||||
|
|
||||||
int main(int argc, char **argv)
|
int main(int argc, char **argv)
|
||||||
{
|
{
|
||||||
t_data img;
|
t_data img;
|
||||||
char *map = 0;
|
char *map;
|
||||||
int fd = 0;
|
int fd;
|
||||||
char *swap = 0;
|
char *swap;
|
||||||
char *del;
|
char *del;
|
||||||
|
|
||||||
|
map = 0;
|
||||||
(void)argc;
|
(void)argc;
|
||||||
img.bear = 0;
|
img.bear = 0;
|
||||||
img.move = 0;
|
img.move = 0;
|
||||||
@ -206,9 +227,9 @@ int main(int argc, char **argv)
|
|||||||
check_map(img.map_tab);
|
check_map(img.map_tab);
|
||||||
img.mlx = mlx_init();
|
img.mlx = mlx_init();
|
||||||
img.mlx_win = mlx_new_window(img.mlx, ft_strlen(img.map_tab[0]) * 32,
|
img.mlx_win = mlx_new_window(img.mlx, ft_strlen(img.map_tab[0]) * 32,
|
||||||
ft_strlen_double(img.map_tab) * 32, "Hungry Bear");
|
ft_strlen_double(img.map_tab) * 32, "Hungry Bear");
|
||||||
print_map(img.map_tab, &img);
|
print_map(img.map_tab, &img);
|
||||||
free(map);
|
free(map);
|
||||||
mlx_hook(img.mlx_win, 2, 1L<<0, &key_press, &img);
|
mlx_hook(img.mlx_win, 2, 1L << 0, &key_press, &img);
|
||||||
mlx_loop(img.mlx);
|
mlx_loop(img.mlx);
|
||||||
}
|
}
|
||||||
|
|||||||
27
parsing.c
27
parsing.c
@ -3,20 +3,17 @@
|
|||||||
/* ::: :::::::: */
|
/* ::: :::::::: */
|
||||||
/* parsing.c :+: :+: :+: */
|
/* parsing.c :+: :+: :+: */
|
||||||
/* +:+ +:+ +:+ */
|
/* +:+ +:+ +:+ */
|
||||||
/* By: apommier <apommier@student.4map.fr> +#+ +:+ +#+ */
|
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: map0map/0map/13 16:map1:43 by apommier #+# #+# */
|
/* Created: 2022/02/13 22:26:34 by apommier #+# #+# */
|
||||||
/* Updated: map0map/0map/13 map1:map4:44 by apommier ### ########.fr */
|
/* Updated: 2022/02/13 22:28:18 by apommier ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
|
|
||||||
#include "so_long.h"
|
#include "so_long.h"
|
||||||
#include "./libft/libft.h"
|
#include "./libft/libft.h"
|
||||||
#include <stdio.h>
|
|
||||||
|
|
||||||
|
int is_player(char **map)
|
||||||
int is_player(char **map)
|
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
int j;
|
int j;
|
||||||
@ -40,7 +37,7 @@ int is_player(char **map)
|
|||||||
return (0);
|
return (0);
|
||||||
}
|
}
|
||||||
|
|
||||||
int is_exit(char **map)
|
int is_exit(char **map)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
int j;
|
int j;
|
||||||
@ -62,10 +59,9 @@ int is_exit(char **map)
|
|||||||
if (exit > 0)
|
if (exit > 0)
|
||||||
return (1);
|
return (1);
|
||||||
return (0);
|
return (0);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int is_item(char **map)
|
int is_item(char **map)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
int j;
|
int j;
|
||||||
@ -87,7 +83,7 @@ int is_item(char **map)
|
|||||||
return (item);
|
return (item);
|
||||||
}
|
}
|
||||||
|
|
||||||
int is_rectangle(char **map)
|
int is_rectangle(char **map)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
int j;
|
int j;
|
||||||
@ -99,8 +95,9 @@ int is_rectangle(char **map)
|
|||||||
i = 1;
|
i = 1;
|
||||||
while (map[j][i])
|
while (map[j][i])
|
||||||
{
|
{
|
||||||
if (map[j][i] != '0' && map[j][i] != '1' && map[j][i] != 'P' && map[j][i] != 'E' && map[j][i] != 'C')
|
if (map[j][i] != '0' && map[j][i] != '1' && map[j][i] != 'P'
|
||||||
return (0);
|
&& map[j][i] != 'E' && map[j][i] != 'C')
|
||||||
|
return (0);
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
j++;
|
j++;
|
||||||
@ -142,7 +139,7 @@ int is_close(char **map)
|
|||||||
return (1);
|
return (1);
|
||||||
}
|
}
|
||||||
|
|
||||||
void ft_error(char *error_msg, char **map)
|
void ft_error(char *error_msg, char **map)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
@ -153,7 +150,7 @@ void ft_error(char *error_msg, char **map)
|
|||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
int check_map(char **map)
|
int check_map(char **map)
|
||||||
{
|
{
|
||||||
if (!is_player(map))
|
if (!is_player(map))
|
||||||
ft_error("You need just one player\n", map);
|
ft_error("You need just one player\n", map);
|
||||||
|
|||||||
16
so_long.h
16
so_long.h
@ -6,8 +6,22 @@
|
|||||||
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */
|
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2022/02/13 16:30:59 by apommier #+# #+# */
|
/* Created: 2022/02/13 16:30:59 by apommier #+# #+# */
|
||||||
/* Updated: 2022/02/13 19:14:29 by apommier ### ########.fr */
|
/* Updated: 2022/02/13 22:12:14 by apommier ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
|
#ifndef SO_LONG_H
|
||||||
|
# define SO_LONG_H
|
||||||
|
|
||||||
|
typedef struct s_data {
|
||||||
|
void *mlx;
|
||||||
|
void *mlx_win;
|
||||||
|
char **map_tab;
|
||||||
|
int item;
|
||||||
|
int move;
|
||||||
|
int bear;
|
||||||
|
} t_data;
|
||||||
|
|
||||||
int check_map(char **map);
|
int check_map(char **map);
|
||||||
|
|
||||||
|
#endif
|
||||||
Loading…
Reference in New Issue
Block a user