Skip to content

Rock paper scissors video chat game with tensor flow gesture detection, websockets, and peer-to-peer UDP connection. Built in MERN stack!

Notifications You must be signed in to change notification settings

ThomasFoydel/RoShamBo

Repository files navigation

RoShamBo TensorFlow

Video-Chat Rock Paper Scissors

live now at roshambo.xyz

screenshot of the homepage of the application


Description

Built in MERN stack with tensor-flow, WebRTC, socketIO, and Material UI. Users can battle a computer, friends, or random users in a rock paper scissors fight to the death, using their webcams and hand gestures to select weapons. The Fingerpose package, built on top of tensor-flow's Handpose model, is used to determine the user's hand gesture based on snapshots from their webcam stream. Authentication is JWT based and the front-end state management relies on React's context API.

While researching tensor-flow I came across a crazy cool video / demo by Nicholas Renotte which detects hand poses and draws a canvas animation over the user's webcam. Inspired by Renotte's project, and using the same technique to detect gestures, I built some of my own handposes, and a social media/video-chat/websocket game based around using this as the player's controller.

This is just a game, and currently there are limitations to the handpose model (detects only one hand), but the possible future use of machine learning and hand gestures for user interface controls (and maybe even things like sign language detection) is extremely exciting.


Installation

Download the repo and run

npm run install-all

Also needed is a .env file in the root directory with a MONGO_URI property set to a mongoDB connection string and SECRET property set to whatever you want your secret to be- any long, random string will do.

To run the project locally use the command

npm run dev

This will start the server at localhost:8000

And the user interface at localhost:3000


Usage

Users can select weapons using their hand gesture once the game begins and a round has started

a player selecting a weapon using hand gesture

Once both players have selected their weapon choices and the data is sent to the server, the round outcome is sent back to the users and their health bars are updated, sound effects are triggered, and then the next round begins.

two players during a round outcome

Rock beats scissors and bird. Paper beats rock and tree. Scissors beats paper and bird. Tree beats scissors and rock. Bird beats tree and paper.

weapon symbols with arrows denoting victories

five hand gestures, rock is a raised fist, paper is a raised open hand, scissors is like a peace sign with the index and middle fingers, tree is a thumbs down, bird is a raised fist with the pinky finger extended as if to drink tea like a fancy person


License

license


Questions

Any questions on this or other projects can be directed to [email protected]


More Of My Projects

Thanks for checking this out! Find more of my work on my GitHub

About

Rock paper scissors video chat game with tensor flow gesture detection, websockets, and peer-to-peer UDP connection. Built in MERN stack!

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages