F24: Dodge Cars

From Embedded Systems Learning Academy
Revision as of 08:53, 17 December 2024 by Proj user13 (talk | contribs) (Schedule)

Jump to: navigation, search

== Dodge Cars ==DodgeCar.jpeg

Abstract

Dodge Cars is a fast-paced action game where players control a vehicle to avoid collisions with incoming obstacles. The objective is to maneuver the car left or right, dodging other cars or objects as they approach. As the game progresses, the speed of obstacles increases, adding difficulty. The game utilizes a 64x64 LED matrix display for visuals, with an SJ2 board for processing. A button allows players to access the menu, navigate, and pause the game (or optional photosensor). An ultrasonic sensor detects if the player is sitting too close to the screen, warning them to adjust their position. An accelerometer is used to control the left and right movements of the player car. The final score of the player will be displayed at the end of every game and a speaker attached to the board will generate the game sounds.

Introduction

Dodge Cars is an engaging and fast-paced action game designed to test players' reflexes and coordination. Players navigate a car through a dynamically changing environment, dodging incoming obstacles that become increasingly difficult to avoid as the game progresses. This interactive experience leverages modern hardware and creative gameplay mechanics, delivering a fun and challenging game suitable for players of all ages.

The game is powered by a 64x64 LED matrix display that provides a vibrant, retro-inspired visual experience. An SJ2 board acts as the central processing unit, seamlessly handling the game's inputs, outputs, and real-time logic. Players control the movement of their car using an accelerometer, adding an immersive, physical dimension to the gameplay. Safety and accessibility are also prioritized, with features like an ultrasonic sensor to promote proper player posture and a button or optional photosensor for intuitive menu navigation. To enhance the overall experience, a speaker generates immersive game sounds, and the final score is displayed at the end of each session, encouraging replayability.

Objective

The primary objective of this project is to develop an interactive game system that combines hardware and software components to deliver a compelling gaming experience. Key objectives include:

  • Design an engaging game loop where players must dodge obstacles using precise control of a car, with increasing difficulty as the game progresses.
  • Utilize modern hardware components like a 64x64 LED matrix for visuals, an accelerometer for motion control, and an ultrasonic sensor to enhance player safety.
  • Provide intuitive user interactions through menu navigation using a button or photosensor, along with clear audio-visual feedback from the speaker and display.
  • Promote player engagement and challenge by showcasing the final score at the end of each game and encouraging improvement through replayability.
  • Integrate safety measures by alerting players if they are sitting too close to the screen, fostering healthier gaming habits.

This project aims to blend creativity, engineering, and user-centric design into a fun and immersive gaming system that highlights the potential of embedded systems in interactive applications.

Team Members & Responsibilities

  • Shreyas
    • Working on Accelerometer Sensor
  • Teja
    • Working on MP3 decoder
  • Navaneeth
    • Working on Game logic and LED screen

Schedule

Week# Start Date End Date Task Status
1
  • 10/12/2024
  • 10/13/2024
  • 10/18/2024
  • 10/13/2024
  • Read previous projects, gather information and discuss among the group members.
  • Create GitLab repository for project
  • Completed
  • Completed
2
  • 10/19/2024
  • 10/20/2024
  • Order necessary parts
  • Completed
3
  • 10/26/2024
  • 11/01/2024
  • Read and familiarize with LED Matrix Datasheet
  • Completed


4
  • 11/02/2024
  • 11/08/2024
  • Develop graphics driver for LED matrix and implement initial game objects
  • Completed
5
  • 11/09/2024
  • 11/09/2024
  • 11/09/2024
  • 11/10/2024
  • 11/15/2024
  • 11/15/2024
  • Finalize wiki schedule
  • Update LED Driver to display objects on screen
  • Map out plan for states within gameplay
  • Completed
  • Completed
  • Completed
6
  • 11/16/2024
  • 11/22/2024
  • Getting objects(cars) moving on screen with boundaries
  • Read and familiarize with MPU6050 datasheet
  • Creating an initial draft video of gameplay
  • Completed
  • Completed
  • Completed
7
  • 11/23/2024
  • 11/29/2024
  • Create algorithm and state for oncoming cars
  • Create controls for movement of player's car
  • Create SPI driver for communicating with MP3 and SD Card
  • Completed
  • Completed
  • Completed
8
  • 11/30/2024
  • 12/06/2024
  • Get music to play using MP3 decoder
  • Create driver and read data from MPU6050
  • Integrate components
  • Completed
  • Completed
  • Completed
9
  • 12/07/2024
  • 12/13/2024
  • Address bugs during testing of integrated system
  • Test pause/play functionality
  • Completed
  • Completed
  • Completed
10
  • 12/16/2024
  • 12/14/2024
  • 12/14/2024
  • 12/14/2024
  • 12/16/2024
  • 12/16/2024
  • 12/16/2024
  • 12/16/2024
  • Final Demo
  • Update Gitlab repo with final code.
  • Update test video.
  • Update the wiki page.
  • Not started
  • Not started
  • Not started
  • Not started


Parts List and Cost

Part Model Quantity Cost
  • Micro-Controller SJ2 Board
  • SJ2 Board
  • 1
  • 50.00$
  • RGB LED Matrix
  • 2
  • 72.56$
  • MPU-6050 Accelerometer & Gyroscope sensor
  • 1
  • 6.99$
  • MP3 Decoder
  • 1
  • 19.95$

Design & Implementation

The design section can go over your hardware and software design. Organize this section using sub-sections that go over your design and implementation.

Hardware Design

Discuss your hardware design here. Show detailed schematics, and the interface here.

Hardware Interface

In this section, you can describe how your hardware communicates, such as which BUSes used. You can discuss your driver implementation here, such that the Software Design section is isolated to talk about high level workings rather than inner working of your project.

    • 1. Created a SPI (SSP0) driver to communicate with MP3 decoder and SD Card. We used the following pins:
MP3 Decoder Pin Pin Description Corresponding SJ2 Pin
MISO SSP0 MISO (Master In Slave Out) P0_17
MOSI SSP0 MOSI (Master Out Slave In) P1_18
SCK SSP0 SCK (Clock Pin) P1_20
SSEL SSP0 SSEL (Slave Select) P1_28
MP3CS (Chip Select) GPIO P0_6
DREQ GPIO P2_2
VCC VCC(3.3V) On Board
GND GND On Board

Software Design

Show your software design. For example, if you are designing an MP3 Player, show the tasks that you are using, and what they are doing at a high level. Do not show the details of the code. For example, do not show exact code, but you may show psuedocode and fragments of code. Keep in mind that you are showing DESIGN of your software, not the inner workings of it.

  • LED Matrix:
    • 1. Initialized LED matrix connected pins to board IOs.
    • 2. Designed matrix driver for screen display by reading an matrix.
    • 3. Designed pause menu, main menu and gameplay environment for different states of game.
    • 4. Used GPIO pins as buttons as controls in main menu
while true:
     if button_up_pressed:
       send 'U' over UART // Up 
   if button_down_pressed:
       send 'D' over UART // Down
   delay()
  • On-board Accelerometer:
    • 1. Initialized I2C channels for taking the x, y and z reading from the sensor and input the readings into the LED matrix gameplay.
    • 2. Used accelerometer readings as inputs for moving the car left and right during gameplay. Uses two tasks:

1. read_data Task

  • Initializes I2C communication with the accelerometer
    • Continuously reads X and Y axis data from the accelerometer
    • Interprets the data to detect tilt (left, right, or no tilt)
    • Updates a global variable (tilt_data_to_send) with the tilt direction

2. board_1_sender_task

  • Periodically sends the tilt data over UART to the second board attached to the LED matrix display
  • This task enables communication of tilt information to the LED matrix
  • Integrated sensor with bluetooth sensor to serve as a single player control during dual player co-op.


while true:
   read accelerometer data
   if tilt_left:
       send 'L' over UART
   else if tilt_right:
       send 'R' over UART
   else:
       send 'M' over UART
   delay(small_amount)


  • Bluetooth Sensor:
    • 1. Used Bluetooth sensor to communicate with LED matrix display to move car left and right.
    • 2. Worked as a single player control during dual player co-op.
    • 3. Used as a point of reference for game restart on the game over screen(START button can also be used). This sensor uses just one task for it's computation:
 while true:
   if bluetooth_data_received:
       if data == '1':
           move_player_two_car_left()
       else if data == '2':
           move_player_two_car_right()
       else if data == '3' and game_is_over:
           restart_game()    
   delay(small_amount)
  • Mp3 Player:
    • 1. Initialize using SPI.
    • 2. Check state of game and select appropriate task.
    • 3. Load song from SD card into MP3 decoder.

There are two tasks, one that updates the state of the game to read data from the SD card present on the SJ2 board while the other uses a queue to receive data from the first task and relay it to the MP3 decoder.

Task 1: Mp3 Reader

const char* current_song = NULL;
while True:
    Check state of game and switch to case STATE:
        Updates current songname
        load_song_into_queue(songname):
             if freaddir(root_directory) == True:
                Check for songname in directory 
                Read song data from mp3 file into queue
                Close file && Close directory
                return;

Task 2: MP3 player task

spi_cs() // Initialize SPI communication
Initialize the DREQ pin.
Enter an infinite loop:

    xQueueReceive(song_data)
    Iterate over each byte in the chunk:
        Check DREQ pin to see if the decoder is ready to receive data
        exchange_data(byte)             
spi_ds()
    • 2. Set device with selected sd card and volume.

Implementation

This section includes implementation, but again, not the details, just the high level. For example, you can list the steps it takes to communicate over a sensor, or the steps needed to write a page of memory onto SPI Flash. You can include sub-sections for each of your component implementation.

Testing & Technical Challenges

Describe the challenges of your project. What advise would you give yourself or someone else if your project can be started from scratch again? Make a smooth transition to testing section and described what it took to test your project.

Include sub-sections that list out a problem and solution, such as:

<Bug/issue name>

Discuss the issue and resolution.

Conclusion

Conclude your project here. You can recap your testing and problems. You should address the "so what" part here to indicate what you ultimately learnt from this project. How has this project increased your knowledge?

Project Video

Upload a video of your project and post the link here.

Project Source Code

References

Acknowledgement

Any acknowledgement that you may wish to provide can be included here.

References Used

List any references used in project.

Appendix

You can list the references you used.