Skip to content

D-Daria/so_long

Repository files navigation



🎮 so_long ...and thanks for all the fish 🐟

Content

Summary

Game

Map

Bonus

How to run

Sources

📄 Summary

This project is a very small 2D game.

Its purpose is to make you work with textures, sprites, and some other very basic gameplay elements.

It is my first computer graphic project at School21 where we need to use graphic library: Minilibx.

The program so_long should take map as a parameter and display game in a window.

🎮 Game

• The player’s goal is to collect every collectible present on the map, then escape chosing the shortest possible route.

• The W, A, S, and D keys must be used to move the main character.

• The player should be able to move in these 4 directions: up, down, left, right.

• The player should not be able to move into walls.

• At every move, the current number of movements must be displayed in the shell.

• You have to use a 2D view (top-down or profile).

🗺 Map

The map can be composed of only these 5 characters:

0 for an empty space,

1 for a wall,

C for a collectible,

E for a map exit,

P for the player’s starting position

V villain 😈 for bonus part

Map rules

• The map has to be constructed with 3 components: walls, collectibles, and free space

• The map must contain at least 1 exit, 1 collectible, and 1 starting position.

• The map must be rectangular.

• The map must be closed/surrounded by walls. If it’s not, the program must return an error.

• You don’t have to check if there’s a valid path in the map.

• You must be able to parse any kind of map, as long as it respects the above rules.

All maps are located in maps directory.

😈 Bonus

• Make the player lose when they touch an enemy patrol.

• Add some sprite animation.

• Display the movement count directly on screen instead of writing it in the shell.

  1. Enemy

Calculate the number of empty spaces and put an enemy proportionally.

Or put villain before - that what I did

  1. Display steps in window
int
mlx_string_put(void *mlx_ptr, void *win_ptr, int x, int y, int color, char *string);
  1. Animation

Can be implemented using static variable.

Example with collectibles rotation

void	ft_collectibles_animation(t_data *data)
{
	static int	i; //static variable incremented
    //changing picture on certain counter value
    //lesser counter -> faster speed
    if (i == 0)
    	ft_put_img(COLLECT_1, w, h, data);
    else if (i == 2500)
    	ft_put_img(COLLECT_2, w, h, data);
	else if (i == 4500)
   		ft_put_img(COLLECT_3, w, h, data);
	else if (i == 6500)
    		ft_put_img(COLLECT_4, w, h, data);
	else if (i == 8500)
   		ft_put_img(COLLECT_5, w, h, data);
   	else if (i == 10500)
		ft_put_img(COLLECT_6, w, h, data);
	else if (i == 12500)
		ft_put_img(COLLECT_1, w, h, data);
    	
    i += 1;
    if (i > 12500)
    	i = 0;
}

I tried to make villains chasing my player.

choosing enemy moving direction

mid_height = map height / 2;
mid_width = map width / 2

player is on the left side of the map or enemy is on the oppposite side of the player
if (player_pos_x < mid_width || enemy_position_x > player_pos_x)
	move enemy left;

player is on the right side 
else if (player_pos_x > mid_width || enemy_position_x > player_pos_x)
	move enemy right;

player is on the top side or enemy is on the bottom
else if (player_pos_y < mid_height || enemy_position_y > player_pos_y)
	move enemy up;

player is on the bottom or enemy is on the top
else if (player_pos_y > mid_height || enemy_position_y < player_pos_y)
	move enemy down;

🏁 How to run

make compile both so_long and so_long_bonus programs

make

To run game with animation you can run so_long_bonus program with map as argument with _bonus suffix.

All maps are located in maps directory.

For example

./so_long_bonus maps/21_bonus.ber

Game preview

⚠️ Beware of enemies!!!

🔗 Sources:

Assets I used to create a game

https://pixel-poem.itch.io/dungeon-assetpuck
https://o-lobster.itch.io/simple-dungeon-crawler-16x16-pixel-pack

Original assets I used: Link to my drive

About

First very small 2D game

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published