In honor of John Horton Conway, the inventor of Game of Life, who recently passed away due to COVID-19 complications.
Given a board with m by n cells, each cell has an initial state live (1) or dead (0). Each cell interacts with its eight neighbors (horizontal, vertical, diagonal) using the following four rules:
- Any live cell with fewer than two live neighbors dies, as if caused by under-population.
- Any live cell with two or three live neighbors lives on to the next generation.
- Any live cell with more than three live neighbors dies, as if by over-population..
- Any dead cell with exactly three live neighbors becomes a live cell, as if by reproduction.
It turns out that you can run a pygame application in the browser by compiling it to JavaScript.
There is a library called Pyjsdl that does this. It is built on top of the PyJs compiler. I managed to convert a Conway's game of life written with pygame into an HTML web page.
-
Install Ubuntu Linux in VirtualBox I am using a Mac but pyjsdl works on Linux so I installed an Ubuntu VM on my machine
-
Install
Python
andpip
sudo apt update
sudo apt install python3-pip
sudo apt install python2
curl https://bootstrap.pypa.io/get-pip.py --output get-pip.py
sudo python2 get-pip.py
- Install
git
sudo apt install git
- Install
Pyjs
from source
git clone https://github.com/pyjs/pyjs.git
cd pyjs
sudo python2 setup.py install
Now you should have the pyjsbuild
tool installed.
- Install pygame
sudo apt install python-pygame
- Download the Pyjsdl module and unpack into the folder containing your game python script
wget https://s3.gatc.ca/files/pyjsdl-0.22.zip
unzip pyjsdl-0.22.zip
- Modify python game script
- Replace
import pygame
withimport pyjsdl as pygame
- Move the code inside the main loop to a
run()
function and get rid of the while loop. Callpyjsdl.display.setup(run)
to start executing therun()
function in a loop automatically
- Replace
- Compile the python script to JavaScript
pyjsbuild game.py
This generates a game.html
file in the folder named output
that can be run in a browser.
Note: This guide contains a mistake in Step 2: Install PyJsdl that tripped me up. The URL for downloading the zip file is wrong. It is not the actual PyJsdl library but just an exmple script you can use to test everything is set up properly.