arpan

arpan

Pictionary a multiplayer drawing and guessing game

Hello everyone :wave:

Today I am very excited to announce a project that I have been working on for almost 3 months now.

The project is called Pictionary it is a guessing and drawing multiplayer game.

Check out the repository here
(Consider adding a star if you like my work)

Give it shot, play the game now, if you don’t find any active games then just join from two different browser sessions create a game from one browser, and join from another.
Play the game now!

Each game consists of a few rounds, in every round someone has to draw their chosen word and others have to guess it to gain points! Players with the highest scores are the winners at the end of the game.

Here’s a small demo of how it looks like in action

https://misc-files-share.s3.amazonaws.com/pictionary.gif

I took inspiration for this game from the original superhit game skribble, I also found another clone for this game written in Go, and I decided to make it in Elixir.

Building this game was very challenging and I learned a lot throughout the process.
Elixir offers just the right tools that are perfect for this kind of thing.

Here’s some of the interesting stuff I have done…

  • Players are drawing and whatever they draw gets broadcasted in real-time to all other players over WebSockets, How cool is that !!!

  • There is no Database I store everything in ETS or genserver state
    Dynamically launch and stop genservers for every game
    Combine the power of phoenix channels along with genservers and ETS to make it work wonderfully.

  • I used react js for the front and learned a bunch of stuff in react like dealing with WebSockets, using middlewares like redux-saga, dark mode, material UI, etc.

The elixir app is deployed to gigalixir and the react frontend app is deployed to netlify.

I am very happy with the results and would request you guys to take a look and play the game with your friends, its pretty fun actually :smiley:

I would like to thank this awesome community that helps me out whenever I am stuck or need advice and provides this platform to share my creations with others who are passionate about elixir like me.

PS: I think the game is stable however you might find a bug, if you face any issues feel free to create an issue and I will try to check it out.

Good Day everyone!

Most Liked

patrickdm

patrickdm

Really cool, starred!

Where Next?

Popular in Discussions Top

PragTob
Hello everyone, I know we had quite some threads (read through lots of them) about background job processing but it remains a hotly deba...
New
JakeBecker
TL;DR: I’ve just released an implementation of Microsoft’s IDE-independent Language Server Protocol for Elixir. It adds language support ...
1144 53690 245
New
thojanssens1
It would be nice to be able to define a redirect from one route to another from the router.ex file. E.g.: redirect "/", UserController, ...
New
arcanemachine
https://nitter.net/josevalim/status/1744395345872683471 https://twitter.com/josevalim/status/1744395345872683471
New
AstonJ
Are there any Elixir or Erlang libraries that help with this? I’ve been thinking how streaming services like twitch have exploded recentl...
New
sashaafm
Piggy backing a bit on @dvcrn topic BEAM optimization for functions with static return type?, I’ve been trying to understand in a deeper ...
New
tmbb
This is a post to discuss the new Phoenix LiveView functionality. From Chris’s talk, it appears that they generate all HTML on the serve...
342 18146 126
New
praveenperera
How We Replaced React with Phoenix By: Thought Bot
New
shishini
I think this twitter post and youtube video didn’t get as much attention as I hoped I am still new to Elixir, so can’t really judge ...
New
CharlesO
Erlang :list.nth simple, but 1 - based nth(1, [H|_]) -> H; nth(N, [_|T]) when N > 1 -> nth(N - 1, T). Elixir Enum.at … coo...
New

Other popular topics Top

lastday4you
I wanted to check elixir version in phoenix because i found that my elixir is 1.5 but when i use Enum.chunk_by it said the function is un...
New
greenz1
I have a phoenix application from which a user can download multiple(5-6) files of size 1MB. I couldn’t find anything related to sending ...
New
Patoshizzle
After calling mix ecto.create I get this error: 17:00:32.162 [error] GenServer #PID<0.412.0> terminating ** (Postgrex.Error) FATAL...
New
JeremM34
Hello, how can I check the Phoenix version ? Thanks !
New
shahryarjb
Hello, I have map which I want to convert it to string like this: the map: %{last_name: "tavakkoli", name: "shahryar"} the string I ne...
New
gausby
I asked this very same question on twitter and got some interesting feedback, but I thought it would be a good question to ask here as we...
1207 39297 209
New
AstonJ
We’ve put together this wiki for Phoenix LiveView - please feel free to add any info you feel is worth including. What is Phoenix LiveV...
New
klo
Got a question about when to concat vs. prepending items to list then reversing to achieve appending. So i know lists boil down to [1 | ...
New
hariharasudhan94
I would like to know what is the best IDE for elixir development?
New
openscript
Hello! Sorry for this astonishing simple question, but I’m really stuck. I try to set up the intellij-elixir plugin, but I don’t know ho...
New

We're in Beta

About us Mission Statement