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

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
jeramyRR
This is an interesting article to read. Elixir’s performance, like usual, is excellent. However, it seems like the high CPU usage is co...
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
arpan
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...
New
ricklove
I was just introduced to Elixir and Phoenix. I was told about the 2 million websocket test that was done 2 years ago. From my research, t...
New
crabonature
I’m still quite new to Elixir. As I understand we got in Elixir “multi guards” as convention to simplify one large guard with or’s?: de...
New
WolfDan
After doing a port from a c++ library to my project in phoenix I’ve seen that I need a faster way to run this algorithm and I found this ...
New
sergio
There’s a new TIOBE index report that came out that shows Elixir is still not in the top 50 used languages. It also goes on to call Elix...
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
cblavier
Hey there, It’s been more than a year since we started using LiveView as our main UI library and building a whole library of UI componen...
New

Other popular topics Top

TunkShif
This post is an instruction guide to help you setup your Neovim for Elixir development from scratch. It includes general information on h...
274 41454 115
New
mcarvalho
What is the difference between System.get_env and Application.get_env? For example, what are best practices to use one versus another.
New
lessless
I believe there are people here who are dealing with CSV files import on the daily basis, and since Excel is a really popular tool there ...
New
belgoros
I’m not a pro in using Regex and can’t figure out why the following behaviour happens, especially if we take into account the difference ...
New
grych
Hi folks, Few months ago I have announced the proof-of-concept of the library to manipulate the browsers DOM objects directly from Elixi...
639 52238 488
New
saif
Hello everyone, Long time lurker first time poster here. I’ve recently begun working on Elixir full-time again! :raised_hands: It’s been...
New
nsuchy
Hi. I’ve noticed that Windows Powershell has it’s own IEX command and you cannot access Elixir’s IEX due to the conflict. This isn’t a cr...
New
sergio_101
I am VERY much an elixir newbie. I have taken one elixir course and one phoenix course on Udemy. During that course, I saw the instructor...
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
hariharasudhan94
I would like to know what is the best IDE for elixir development?
New

We're in Beta

About us Mission Statement