Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/elyse502/the-maze-project
ALX final Portfolio Project - End of Foundation
https://github.com/elyse502/the-maze-project
3d-game c-programming game-development portfolio showcase
Last synced: about 1 month ago
JSON representation
ALX final Portfolio Project - End of Foundation
- Host: GitHub
- URL: https://github.com/elyse502/the-maze-project
- Owner: elyse502
- License: mit
- Created: 2023-11-21T08:14:31.000Z (about 1 year ago)
- Default Branch: main
- Last Pushed: 2023-12-13T22:34:43.000Z (about 1 year ago)
- Last Synced: 2024-11-06T21:19:43.544Z (3 months ago)
- Topics: 3d-game, c-programming, game-development, portfolio, showcase
- Language: C
- Homepage: https://elyse502.github.io/The-Maze-Project-Page/
- Size: 118 KB
- Stars: 6
- Watchers: 1
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# The Maze Project 👨🎓
![8970c3ee63d8149b93e30229276c3f7580ac9447](https://github.com/elyse502/The-Maze-Project/assets/125453474/4efdeb36-7965-4844-9e7d-ae8028561ed8)
This project is a first person `3D` maze game. Similar to Wolfenstein or Doom, minus enemies and weapons, although they may be added later. It was made using `SDL2` and `C`. It runs on Mac OS X and Linux/Ubuntu. The game uses the technique raycasting to create the apparent `3D` nature of the maze. The Maze is a 3D Maze game that uses ray casting to render a 2D map into a 3D navigable world!
The Maze was written in C using `SDL2` library. Deveploment was performed using Ubuntu 14.04 LTS - gcc (Ubuntu 4.8.4-2ubuntu1~14.04) 4.8.4
### About SDL2 💻
Simple DirectMedia Layer is a cross-platform development library designed to provide low level access to audio, keyboard, mouse, joystick, and graphics hardware via OpenGL and Direct3D. It is used by video playback software, emulators, and popular games including Valve's award winning catalog and many Humble Bundle games.## Requirements to Play
- Mac OS X or Linux/Ubuntu
- SDL2If you don't have SDL2 installed download the installation script here. Then find the script and run it in your terminal:
```groovy
$ ls
install_SDL2.sh
$ chmod 755 install_SDL2.sh
$ sudo ./install_SDL2.sh
```## Start the Game
First step is to clone the repo:
```groovy
git clone https://github.com/elyse502/The-Maze-Project.git
```Compile all .c files in the maze directory:
```groovy
elysee_niyibizi@pc:~/maze$ gcc -g -Wall -Werror -Wextra -pedantic -I/usr/local/include/SDL2 ./src/*.c -o maze -L/usr/lib/x86_64-linux-gnu -lSDL2 -lm
```
Alternatively, just use the make command:
```sh
make
```Run the maze with the map you'd like to play:
```groovy
./maze maps/level_1
```
Or you can run with multiple maps at once:
```groovy
./maze maps/level_1 maps/level_2
```Some basic maps are provided in this repo in the maps/ directory, but you can make your own maps to play as well.
After running `./maze maps/level_1` you should see a screen like this:
![Screenshot from 2023-11-21 10-23-10](https://github.com/elyse502/The-Maze/assets/125453474/53546f9f-7dc8-42af-a2d9-18c9fd737c76)
If you're using the provided maps it'll just be a red screen, but that's not all. If you rotate with the arrow keys to the right you'll see the rest of the maze:
![Screenshot from 2023-11-21 10-27-31](https://github.com/elyse502/The-Maze/assets/125453474/f06c5ca5-5463-4e6c-8bb7-ab34f0a00fa5)
## Play the Game
The goal of the game is to find the end of the maze. To move through the maze use the arrow keys. The left and right arrow keys will rotate the player. The up and down arrow keys will move the player forward or backward.Currently the player's starting position and the end goal position of the maze can be decided when creating the map file. If no positions are stated in the file then the player starts in the top left corner and the goal will be in the last floor space in the file.
When you have found the end of the maze you will either move, rather abruptly, to the next maze or the game will exit and you will be greeted with a win message in your console.
![Screenshot from 2023-11-21 11-05-21](https://github.com/elyse502/The-Maze-Project/assets/125453474/89b1d413-0d82-4a12-906f-000516f674e0)
## Creating a Maze
The files in the `maps/` directory provide examples of the file format for a maze to work with this game. The different characters in the file represent different colored walls, the floor, the player position, or the position of the end goal.Example of a maze file:
In the image above the player starts 2 spaces in from the top left corner, and the end goal is placed in the bottom left most space that isn't a wall. There are five columns that are mostly blue, but have green, yellow, and white wall chunks in them.
**Map File Characters' in Game Meanings**
- **0**: Floor/walkable space
- **1**: Red Wall
- **2**: Green Wall
- **3**: Blue Wall
- **4**: Yellow Wall
- **w**: End goal
- **p**: Player start position
- All other characters will be defaulted to white walls## Flowchart
![The Maze Flow Chart](https://i.imgur.com/t0MxNni.png)## Reference
- [lazyfoo](http://lazyfoo.net/tutorials/SDL/index.php#Event%20Driven%20Programming)
- [geeksforgeeks](https://www.geeksforgeeks.org/structure-vs-class-in-cpp/)
- [permadi.com](https://permadi.com/1996/05/ray-casting-tutorial-1/)
- [lodev.org](https://lodev.org/cgtutor/raycasting.html)
- [cplusplus.com](https://cplusplus.com/forum/beginner/214311/)
- [pikuma.com](https://pikuma.com/courses/raycasting-engine-tutorial-algorithm-javascript)
- [3DSage/OpenGL-Raycaster](https://www.youtube.com/watch?v=gYRrGTC7GtA)## Demo
[![The Maze Demo](https://github.com/elyse502/The-Maze/assets/125453474/f06c5ca5-5463-4e6c-8bb7-ab34f0a00fa5)](https://youtu.be/MLKPI4e5RTE)
Click on The PICTURE☝️
📍This project is still a work in progress more detail on the project will be available in the future🍿📺🍿## Author :black_nib:
1. _[NIYIBIZI Elysée](https://linktr.ee/niyibizi_elysee) | [Github](https://github.com/elyse502) | [Linkedin](https://www.linkedin.com/in/niyibizi-elys%C3%A9e/) | [Twitter](https://twitter.com/Niyibizi_Elyse)._## License
This project is licensed under the MIT License - see the [LICENSE](LICENSE) file for details.
# Acknowledgements 🙏
All work contained in this project was completed as part of the curriculum for _Alx-Africa_. _Alx-Africa_ is a remote-based full-stack software engineering program that prepares students for careers in the tech industry using project-based peer learning. For more information, visit this [link](https://www.alxafrica.com/).
* **ALX staff**: For the help, advice, and resources throughout the project and curriculum.
* **Cohort 13 and all ALX students**: For friendship, support, and insights over the last year.
* **YOU**: For reading this documentation and testing out The Game. I hope you enjoyed the ride!## Support🎉
If you like how I present and document my work do me a favor of giving a Star ✨ to my [Repos](https://github.com/elyse502?tab=repositories) |&&| a [Follow](https://github.com/elyse502) 👥