Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/olawalejoseph/rpg-game
This is a turn-based RPG game built with Phaser 3. It features a Hero in a search of treasure in a dangerous land.
https://github.com/olawalejoseph/rpg-game
game-template hero rpg-game
Last synced: 2 months ago
JSON representation
This is a turn-based RPG game built with Phaser 3. It features a Hero in a search of treasure in a dangerous land.
- Host: GitHub
- URL: https://github.com/olawalejoseph/rpg-game
- Owner: OlawaleJoseph
- License: mit
- Created: 2020-10-09T16:57:36.000Z (over 4 years ago)
- Default Branch: develop
- Last Pushed: 2020-10-14T16:39:58.000Z (over 4 years ago)
- Last Synced: 2024-10-18T06:36:13.549Z (3 months ago)
- Topics: game-template, hero, rpg-game
- Language: JavaScript
- Homepage:
- Size: 4.86 MB
- Stars: 4
- Watchers: 2
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
[![Netlify Status](https://api.netlify.com/api/v1/badges/06f45e3a-b5b3-4e1b-9242-97a5b2ab2a6f/deploy-status)](https://app.netlify.com/sites/pensive-jepsen-64351b/deploys)
# JavaScript capstone project - RPG game
Building a turn-based RPG game using JavaScript and Phaser game engine
## GAME DESIGN DOCUMENTATION
#### Design Process> The aim of this project was to create a turn based RPG game with the story centered around a hero(player).
#### Story and game play
The game is centered is about a hero that goes in serach of treasures in a dangerous land. People known to venture to this land were never seen again, hence the land is called NO ESCAPE. The hero embarking on this perilious journey aims to change all that by conquering all the trolls in the land and getting all the treasures of NO ESCAPE.#### Assets choice
Choice of assets for the game was obtained from opengameart.org, this includes player, troll, chest, background, trees.#### Technical Knowhow
I followed the tutorial on gamedevacademy.org on how to build a turn based RPG game. I built a simpler version of the game to help me understand how Phaser 3 works and to me familiarize myself with the concept of scenes and events in Phaser 3.#### Development stage
##### DAY 1
> I studied Phaser 3> I built a mini game with phaser 3
##### DAY 2
> I gathered required assets> I scaled images to preferred sizes
##### DAY 3
> Proloaded assets> Created a game template
> Created different scenes of the game but not the full functionality
##### DAY 3
> Created a game template> Created different scenes of the game but not the full functionality
> Linked scenes to each other to simulate gameplay
##### DAY 4
> I added animation to player sprite.> I added collision between player and walls, obstacles.
> I checked for overlap between player and chest, the switched to the battle scene if ther is an overlap.
> I Implemented battle logic of the game.
> I created the functionality to make async request to get highscores from microverse API and display them.
##### DAY 5
> I implemented a scene to ask user for their name before the game starts.> I implemented a scoring functionality.
> I wrote unit tests for the game.
> I refactored the code to make it better.
### Table of Contents
- [Objective](#Objective)
- [Story](#Story)
- [Characters](#Characters)
- [Gameplay](#Gameplay)
- [How to Play](#How-to-Play)
- [Technologies Used](#Technologies-Used)
- [Live Version](#Live-version)
- [Install and Run](#How-to-Install-and-Run-in-Your-Computer)
- [Acknowledgments](#Acknowledgments)### Objective
The objective of this project is to build a simple turn-based RPG game with a scoring system, using JavaScript ES6, Phaser 3 framework, and other modern technologies.
[Up](#Table-of-Contents)
### Story
A Hero goes in search for treasures in a dangerous land where people are known to never return from. The land is filled will trolls and treasures. Can this Hero make it through?
[Up](#Table-of-Contents)
### Characters
#### Player
Moves in all four directions.#### Troll
An Enemy that hits your hero. Every hit from the troll reduces the health of the hero by a random value.[Up](#Characters)
### Gameplay
You control a the Hero character using the up, down, left and right navigation keys.
You will get by a troll for every treasure box you open.
When attacked you enter the battle screen where you can attack your enemy by pressing the left arrow key twice. This is a turn-based RPG so each of you attack only once per turn. The battle continues until you defeat all foes or be defeated by them. Health it is been restored to full after each battle.
[Up](#Table-of-Contents)
### How to Play
1. #### Start Screen
Enter your name or avatar on the first screen and click on 'Play Now' button.
Next screen is where you control the game. You have 4 options:
2. #### Play
Here is where the fun begins. By clicking 'Play' you are transferred to the forest. You move your character on the screen by using the four arrow keys. You can move up, down, left, right, and even diagonally if you keep to arrows pressed simultaneously.
- #### Battlefield
When attacked by foes you are transferred to the Battlefield. On the left side of the screen appear the attacking enemies. On the right side is your hero. The left area lists the names of the enemies, the right area your hero, and in the middle is the attack command.
The attacker's name is in yellow letters. By pressing left key you can select the troll enemy then press space/left to commence the attack.
If you kill the enemy you return to the forest and you can proceed with your quest. If you lose it is 'Game Over' and you are transferred to the 'Game Over' scene.
3. #### Options
'Music Enabled' checkbox controls whether you will have music during playing or not.
'Sound Enabled' button is not operational yet.
4. #### Credits
The credits for this game.
5. #### LeaderBoard
The top 5 best scores are listed on the LeaderBoard.
6. #### Game Over
[Up](#Table-of-Contents)
### Technologies Used
- Node, npm
- Phaser 3
- JavaScript
- Webpack
- Babel
- Jest
- ESlint
- HTML/CSS
- Netlify
- Microverse Leaderboard API[Up](#Table-of-Contents)
### Live version
The game is hosted on two different servers, macexperts.gr and netlify.com. Both use the same API to store the scores so it does not matter in which one you play. You can play the game here:
- [**Live Version**](https://pensive-jepsen-64351b.netlify.app/)### How to Install and Run in Your Computer
To run the scripts **npm** is required. To get npm you have to install [Node.js](https://nodejs.org). Follow the installation instructions for your system Mac, Linux or Windows.
Use your terminal and run the commands after each instruction.
| Command | Description |
| ----------------------------------------------------------| ----------------------------------------------------- |
| `git clone https://github.com/OlawaleJoseph/RPG-GAME.git` | Clone the repository to you computer |
| `cd RPG-game` | Navigate to the newly created folder |
| `npm install` | Install dependencies and launch browser with examples |
| `npm start` | Makes the build and starts the development server |
| | Press `Ctrl + c` to kill **http-server** process |
| `http://localhost:8000` | Visit this link to play the game |[Up](#Table-of-Contents)
## Acknowledgements
- Microverse
- Opengameart.org
- Chest Image by RooMan93
- Button Image by StumpyStrust
- Hero Sprite by Curt[Up](#Table-of-Contents)
👤 **Adedeko Olawale**
- Github: [@OlawaleJoseph](https://github.com/OlawaleJoseph)
- Twitter: [@javanode123](https://twitter.com/javanode123)
- Linkedin: [olawale-adedeko](http://www.linkedin.com/in/olawale-adedeko)## 🤝 Contributing
Contributions, issues and feature requests are welcome!
Feel free to check the [issues page](https://github.com/OlawaleJoseph/RPG-GAME/issues).
1. Fork it (https://github.com/OlawaleJoseph/RPG-GAME/fork)
2. Create your feature branch (git checkout -b my-new-feature)
3. Commit your changes (git commit -am 'Add some feature')
4. Push to the branch (git push origin my-new-feature)
5. Create a new Pull Request## Show your support
Give a ⭐️ if you enjoyed this project!
## 📝 License
This project is [MIT](lic.url) licensed.