Welcome to the Gotta Catch 'Em All Pokémon web application! This project is a simplified version of Pokémon Red's Route 1, where the player can walk around, enter tall grass to find Pokémon, catch them, view them in the Pokédex, and save their game progress. The project is divided into two main parts: the frontend, developed with Vue.js, and the backend, built with Node.js.
- Objectives
- Features
- Project Structure
- Installation
- Usage
- Endpoints
- Components
- Screenshots and GIFs
- Authors
The main objectives of this project are:
- Reinforce and demonstrate Vue.js concepts through practical application.
- Implement a fully functional backend using Node.js and Express.js.
- Develop a seamless client-server communication using HTTP requests.
- Create an engaging user experience that mimics the classic Pokémon gameplay.
- Explore Route 1: Move around the map and explore the environment.
- Wild Encounters: Enter tall grass to randomly encounter wild Pokémon.
- Catch Pokémon: Use Pokéballs to catch encountered Pokémon.
- Pokédex: View all the Pokémon you have caught in your personal Pokédex.
- Save Progress: Save your game progress and continue later.
The frontend part of the project is organized as follows:
package.json
: Contains the project dependencies and scripts for building and running the application./src
: Contains all the source files for the Vue.js application.App.vue
: The main Vue component that serves as the entry point./components
: Directory containing custom Vue components used in the application./base_components
: Contains reusable base components.globals.js
: Contains global variables and configurations used throughout the Vue components.
More specific information at:
- https://github.com/lucas12avl/gotta-catch-em-all/blob/bb13e7e14d9c9c283d8986651d8901e607516290/gotta_catch_em_all_backend.pdf
- https://github.com/lucas12avl/gotta-catch-em-all/blob/bb13e7e14d9c9c283d8986651d8901e607516290/gotta_catch_em_all_frontend.pdf
The backend part of the project is structured as follows:
package.json
: Contains the project dependencies and scripts for starting the server.app.js
: The main server file that initializes and starts the Express server./public
: Contains the compiled and static files of the Vue frontend./routes
: Contains route definitions and logic for handling various API requests.
More specific information at gotta_catch_em_all_backend.pdf
Prerequisite: Have node.js installed, if not, download it from the official website at https://nodejs.org/en
Follow these steps to set up the project locally:
- Clone the repository and navigate to the frontend directory:
git clone https://github.com/lucas12avl/gotta-catch-em-all.git cd gotta-catch-em-all/frontend
- Install the dependencies:
npm install
- Start the development server:
npm run dev
- Navigate to the backend directory:
cd gotta-catch-em-all/backend
- Install the dependencies:
npm install
- Start the server:
node app.js
To use the application, follow these steps:
- Ensure both the frontend and backend servers are running.
- Open your browser and navigate to
http://localhost:5173/
to access the application. - Use the on-screen controls to move your character around Route 1.
- Enter tall grass to potentially encounter wild Pokémon.
- Attempt to catch Pokémon using Pokéballs.
- View your captured Pokémon in the Pokédex.
- Save your progress to continue your adventure later.
- Hint:
Have you captured all 2 different pokmons?
Then, go to the sign at the bottom of the map and press the A button to reveal an Easter egg!
(maybe another different pokemon is waiting for you)
The backend provides the following API endpoints:
GET /initial_info
: Returns the initial game information including player position, Pokémon data, and game settings.POST /enter_grass
: Triggered when the player enters tall grass, potentially resulting in a wild Pokémon encounter.POST /leave_grass
: Triggered when the player leaves tall grass, ending any ongoing wild encounter.POST /capture
: Used to attempt capturing a wild Pokémon.POST /save
: Saves the current game state including player progress and captured Pokémon.
The middleware components are essential parts of the game logic, handling various aspects of the gameplay:
- ControlsFrame: Manages button press and release events for character movement and interactions.
- MapMiddleware: Handles the display of the game map and character navigation.
- PlayerMiddleware: Manages the player sprite, including direction and movement.
- WildEncounterMiddleware: Manages wild Pokémon encounters when the player enters tall grass.
- MenuMiddleware: Displays the game menu and handles actions like saving the game.
Lucas Dalmau