Open-source Cloud Gaming Service For Retro Games
Video demo: https://www.youtube.com/watch?v=GUBrJGAxZZg
Technical wrapup: https://webrtchacks.com/open-source-cloud-gaming-with-webrtc/
CloudRetro provides an open-source cloud gaming platform for retro games. It started as an experiment for testing cloud gaming performance with WebRTC and libretro, and now it aims to deliver the most modern and convenient gaming experience through the technology.
Theoretically, in cloud gaming, games are run on remote servers and media are streamed to the player optimally to ensure the most comfortable user interaction. It opens the ability to play any retro games on web-browser directly, which are fully compatible with multi-platform like Desktop, Android, IOS.
Single play: http://cloudretro.io
Direct play an existing game: Pokemon Emerald
*In ideal network condition and less resource contention on servers, the game will run smoothly as in the video demo. Because I only hosted the platform on limited servers in US East, US West, Eu, Singapore, you may experience some latency issues + connection problem. You can try hosting the service following the instruction the next section to have a better sense of performance.
Screenshot | Screenshot |
---|---|
- Cloud gaming: Game logic and storage is hosted on cloud service. It reduces the cumbersome of game initialization. Images and audio are streamed to user in the most optimal way using advanced encoding technology.
- Cross-platform compatibility: The game is run on web browser, the most universal built-in app. No console, plugin, external app or devices are needed.
- Emulator agnostic: The game can be played directly without any extra effort to set up the gaming emulator or platform.
- Collaborate gameplay: Follow the idea of crowdplay(TwitchPlaysPokemon), multiple players can play the same game together by addressing the same deeplink. The game experience is powered by cloud-gaming, so the game is much smoother. Check CrowdPlay section
- Online multiplayer: The first time in history, you can play multiplayer on Retro games online. You can try Samurai Showndown with 2 players for fighting game example.
- Horizontally scaled: The infrastructure is designed to be able to scale under high traffic by adding more instances.
- Cloud storage: Game state is storing on online storage, so you can come back and continue playing your incomplete game later.
You try running the server directly by make dev.run-docker
. It will spawn a docker environment and you can access the service on localhost:8000
.
Install Golang https://golang.org/doc/install . Because the project uses GoModule, so it requires Go1.11 version.
Setup MSYS2 (MinGW) environment if you are using Windows:
- Please refer to the Libretro doc for initial environment setup
- Add Golang installation path into your .bashrc
$ echo 'export PATH=/c/Go/bin:$PATH' >> ~/.bashrc
- Install dependencies as described down bellow
- Copy required Libretro Core DLLs into the
cloud-game\assets\emulator\libretro\cores
folder and replace existing Linux SOs in thecloud-game\pkg\config\config.go
EmulatorConfig object. - Use
C:\msys64\mingw64.exe
for building - To run the app use either MinGw terminal or copy: libdl.dll, libogg-0.dll, libopenal-1.dll, libopus-0.dll, libopusfile-0.dll, libvpx-1.dll
files from
C:\msys64\mingw64\bin
into the./bin
folder and then run.
- Install libvpx, libopus, pkg-config
# Ubuntu
apt-get install -y pkg-config libvpx-dev libopus-dev libopusfile-dev
# MacOS
brew install libvpx pkg-config opus opusfile
# Windows (MSYS2)
pacman -Sy --noconfirm --needed git make mingw-w64-x86_64-{gcc,pkg-config,dlfcn,libvpx,opusfile}
Because the coordinator and workers need to run simultaneously. Workers connect to the coordinator.
- Script
make dev.run
- The scripts spawns 2 processes one in the background and one in foreground
- Manual
- Need to run coordinator and worker separately in two session
go run cmd/coordinator/main.go
- spawn coordinatorgo run cmd/worker/main.go --coordinatorhost localhost:8000
- spawn workers connecting to coordinator
High level | Worker internal |
---|---|
By clicking these deep link, you can join the game directly and play it together with other people.
And you can host the new game by yourself by accessing cloudretro.io and click "share" button to generate a deeplink to your current game.
Synchronize a game session on multiple devices
- The project cannot be possible without the contribution with those amazing people:
- sergystepanov for Front end refactor; Audio re-implementation; bilinear, nearest neighbor interpolation scaling; Window setup document; build workflow on multi-os.
- sadlil for massive code structure reogranization; log and monitor server introduction.
- Pion Webrtc team for the incredible Golang Webrtc library and their supports https://github.com/pion/webrtc/.
- libretro/kivutar Golang libretro https://github.com/libretro/go-nanoarch and https://www.libretro.com/.
- gen2brain for the h264 go encoder https://github.com/gen2brain/x264-go
- poi5305 for the video encoding https://github.com/poi5305/go-yuv2webRTC.
- fogleman for the NES emulator https://github.com/fogleman/nes.
Nguyen Huu Thanh
https://www.linkedin.com/in/huuthanhnguyen/
Tri Dang Minh
https://trich.im