PortuguΓͺs | English | EspaΓ±ol
Educational Maze is an interactive web application that allows users to program a car to navigate through a maze using visual programming blocks. Inspired by platforms like Scratch, this project aims to teach programming logic concepts in a fun and intuitive way.
With the Educational Maze, users can drag and drop command blocks to create sequences that direct the car's movement in the maze. In addition to the basic movement blocks, the project includes conditional blocks, loops, and even audio blocks that allow you to emit sounds at specific frequencies, similar to the Tone
and NoTone
commands in Arduino.
- Movement Blocks: Commands to move the car forward, backward, and turn left or right.
- Conditional Blocks: Allows executing commands based on specific conditions, such as the presence of walls.
- Repeat Blocks: Repeat sequences of commands multiple times or indefinitely.
- Mirroring Blocks: Horizontally or vertically mirror movements.
- Audio Blocks: Emit sounds at specific frequencies and stop the emitted sounds.
- Save and Open Programs: Save your block sequences and reload them later.
- Intuitive Interface: Drag and drop blocks to create programming sequences.
- Visual and Audio Feedback: Informative messages during execution and sounds to enhance interactivity.
- Difficulty Levels: Choose between different maze sizes (Easy, Medium, Hard).
Screenshot of the Educational Maze interface.
(Note: Add screenshots or animated GIFs in the screenshots
folder and update the links accordingly.)
- HTML5 - Application structure.
- CSS3 - Styling and responsive layout.
- JavaScript (ES6+) - Programming logic and interaction.
- Web Audio API - Emitting sounds at specific frequencies.
- Drag and Drop API - Functionality for dragging and dropping blocks.
- SVG - Vector graphics for the car.
These instructions will provide you with a copy of the project and allow you to run it on your local machine for development and testing purposes.
- A modern web browser (Chrome, Firefox, Edge, Safari).
- A local server to serve static files (optional, but recommended to avoid issues with ES6 modules).
-
Clone the repository:
git clone git@github.com:iagolirapasssos/Educational-Maze.git
-
Navigate to the project directory:
cd Educational-Maze
-
Open the
index.html
file in your browser:-
Option 1: Double-click the
index.html
file. -
Option 2: Use a local server. For example, with Python:
# For Python 3.x python -m http.server 8000
Open
http://localhost:8000
in your browser.
-
-
Select the Maze Level:
- Choose between Easy Level (8x8), Medium Level (12x12), or Hard Level (15x15) using the selector in the control panel.
-
Create the Maze:
- Click "π New Maze" to generate a new maze based on the selected level.
-
Program the Car:
- Drag the available blocks from the "Available Blocks" section to the "My Program" area.
- Arrange the blocks in the desired order to define the car's actions.
- Use repeat, conditional, and audio blocks to create more complex sequences.
-
Execute the Program:
- Click "βΆ Execute" to start running the program.
- Use "βΈ Pause" to pause the execution and "βΉ Stop" to completely interrupt it.
- "π Clear" removes all blocks from the "My Program" area.
- Use the "πΎ Save Program" and "π Open Program" buttons to manage your block sequences.
-
Objective:
- Navigate the car through the maze until it reaches the finish flag π.
Feel free to modify and customize the application according to your needs. You can add new blocks, change styles, or expand the existing functionality.
Contributions are welcome! Feel free to open issues or submit pull requests.
-
Fork the repository
-
Create a branch for your feature:
git checkout -b my-new-feature
-
Commit your changes:
git commit -m "Add new feature X"
-
Push to the branch:
git push origin my-new-feature
-
Open a Pull Request
This project is licensed under the MIT License - see the LICENSE file for details.
Prof. Iago Lira - prof.iagolirapassos@gmail.com
Project: https://github.com/iagolirapasssos/Educational-Maze
- Scratch - Inspiration for visual programming.
- Web Audio API - For audio implementation.
- MDN Web Docs - Web development reference.