Skip to content

kaezrr/starGB

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

94 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

StarGB

A lightweight and efficient Nintendo Game Boy emulator written in C++ using SDL2 for graphics, spdlog for high-performance logging, and fmt for clean and flexible formatting. This project faithfully reproduces the classic Game Boy gaming experience, supporting popular game titles with various Memory Bank Controllers.


🎮 Features

  • Accurate Emulation: Faithfully replicates Game Boy hardware behavior for a classic gaming experience.
  • Supported MBCs: Compatible with games using:
    • MBC1
    • MBC3
    • MBC5
    • No MBC (simple ROMs)
  • Keyboard Support: Play directly using your keyboard.
    • up/down/left/right = arrow keys, a/b = s/a, start/select = enter/lshift
  • High-Performance Logging: Debug seamlessly with spdlog.

📸 Screenshots and Gameplay

Screenshots

Gameplay GIFs


🚀 Getting Started

Prerequisites

  • C++17 or later
  • SDL2
  • spdlog
  • fmt

Ensure these dependencies are installed on your system before building the emulator.

Installation

  1. Clone the repository:

    git clone https://github.com/kaezrr/starGB.git
    cd starGB
  2. Build the project using CMake:

    mkdir build
    cd build
    cmake .. -DCMAKE_BUILD_TYPE=Release
    make
  3. Put the roms that you want to run in the roms/ folder. (NOTE: don't delete the dmg_boot.bin file, it is necessary to run the emulator)

  4. Run the emulator:

    ./starGB [path/to/rom]

🛠️ Limitations and Future Plans

Current Limitations:

  • No Settings Customization: All configurations are hardcoded for now.
  • No Audio Support: Game audio is not yet implemented.

Future Plans:

  • Add audio emulation.
  • Introduce customizable key mapping and emulator settings.
  • Expand compatibility to Game Boy Color.

🤝 Contributing

Contributions are welcome! If you'd like to improve the emulator, feel free to fork the repository, make your changes, and submit a pull request.


🙌 Acknowledgments

  • Thanks to the open-source libraries SDL2, spdlog, and fmt for enabling this project.
  • Thanks to the wonder folks over at r/emuDev and their discord
  • Thanks to LIJI32 for the copyright free boot rom.
  • Thanks to pandocs and hacktix for their wonderful documentations.
  • Thanks to gekkio, blargg and adtennant for their absolutely amazing tests.
  • Inspired by the legacy of the Nintendo Game Boy and the retro gaming community.

About

A Nintendo Game Boy emulator written in C++

Resources

License

Stars

Watchers

Forks

Releases

No releases published