Memorio is a dynamic memory game that challenges you to remember and replicate a path shown during a demo phase, using your keyboard's directional arrows. After watching a sequence of arrows light up on a grid, it's your turn to step up and trace the path from memory. Sounds simple? Think again! As you progress, the paths become more complex and the pressure mounts.
Ready to see how far your memory can take you? Dive into Memorio and set new high scores (if you can tho)
Key Features:
- Dynamic Difficulty: Paths become more complex as you progress.
- Interactive Gameplay: Utilize your keyboard's directional arrows to trace paths.
- Score Tracking: Aim for high scores by efficiently completing paths.
- Sound Effects: Engaging sounds for starting, flipping, validating, or invalidating moves.
After a sequence of arrows lights up on a grid, it's your turn to memorize and trace the path. Success leads to more challenging rounds, while mistakes introduce penalties.
VITE_GRID_SIZE=7
: Grid size (rows and columns).VITE_DEFAUT_PATHLENGTH=3
: Default number of moves at the start.VITE_DEFAUT_PATHLENGTH_MAX=15
: Maximum number of moves.VITE_HARDCORE_PATHLENGTH_MAX=25
: Maximum number of moves in hardcore mode.VITE_DEFAUT_DEMO_DELAY=600
: Demo phase duration in milliseconds.VITE_HARDCORE_DELAY=150
: Hardcore mode demo phase duration.VITE_PENALTY_PERCENT=25
: Penalty percentage after a failure.
Experience Memorio here.
- Clone the repository.
- Install dependencies using
npm install
. - Setup the environment variables in a
.env
file. - Start the development server with
npm run dev
. - For production builds, use
npm run build
.
src/App.tsx
: Entry point that renders the game component.src/components/Game.tsx
: Core game logic, handling UI and interactions.src/machines/gameMachine.ts
: State management using XState for game flow.src/utils/gameUtils.ts
: Utility functions for game logic, including path generation and move validation.
To add new features, such as additional game modes or UI enhancements, you might start by introducing new states and transitions within the game machine (src/machines/gameMachine.ts
). For instance, adding a "challenge mode" could involve creating new states for timed rounds, and integrating these within the existing state machine logic.
- State Management: Familiarize yourself with XState documentation to effectively work with the state machine.
- React and TypeScript: Leverage React functional components and TypeScript for type safety and component reusability.
- Environment Variables: Use
.env
for sensitive or configurable settings to keep the game flexible and secure. - Sound Effects: Replace sound files in
src/assets/sfx/
with your own, ensuring to maintain the file names or update references insrc/components/Game.tsx
.
Contributions are welcome! Please submit a pull request or open an issue for any features or bug fixes.
Memorio is licensed under the GPL-3.0 License.