pygame wasm, package and run python/pygame directly in modern web browsers.
Project description
pygbag
pygame wasm for everyone ( packager + test server )
runs pygame directly in modern web browsers, including mobile versions.
"your_game_folder" must contains a main.py and its loop must be async aware eg :
import asyncio
import pygame
pygame.init()
pygame.display.set_mode((320, 240))
pygame.display.set_caption("TEST")
async def main():
count = 3
while True:
print(f"""
Hello[{count}] from Pygame
""")
pygame.display.update()
await asyncio.sleep(0) # very important, and keep it 0
if not count:
pygame.quit()
return
count = count - 1
asyncio.run( main() )
# do not add anything from here
# asyncio.run is non block on pygame-wasm
usage:
pip3 install pygbag --user --upgrade
pygbag your_game_folder
command help:
pygbag --help your_game_folder
eg
user@pp /data/git/pygbag-wip $ python3.8 -m pygbag --help test
*pygbag 0.2.0*
Serving python files from [/data/git/pygbag-wip/test/build/web]
with no security/performance in mind, i'm just a test tool : don't rely on me
usage: __main__.py [-h] [--bind ADDRESS] [--directory DIRECTORY]
[--app_name APP_NAME] [--ume_block UME_BLOCK] [--cache CACHE]
[--package PACKAGE] [--title TITLE] [--version VERSION] [--build]
[--archive] [--icon ICON] [--cdn CDN] [--template TEMPLATE]
[--ssl SSL] [--port [PORT]]
optional arguments:
-h, --help show this help message and exit
--bind ADDRESS Specify alternate bind address [default: localhost]
--directory DIRECTORY
Specify alternative directory [default:/data/git/pygbag/test/build/web]
--PYBUILD PYBUILD Specify python version [default:3.11]
--app_name APP_NAME Specify user facing name of application [default:test]
--ume_block UME_BLOCK
Specify wait for user media engagement before running [default:1]
--can_close CAN_CLOSE
Specify if window will ask confirmation for closing [default:0]
--cache CACHE md5 based url cache directory
--package PACKAGE package name, better make it unique
--title TITLE App nice looking name
--version VERSION override prebuilt version path [default:0.3.0]
--build build only, do not run test server
--html build as html with embedded assets (pygame-script)
--no_opt turn off assets optimizer
--archive make build/web.zip archive for itch.io
--icon ICON icon png file 32x32 min should be favicon.png
--cdn CDN web site to cache locally [default:https://pygame-web.github.io/archives/0.3.0/]
--template TEMPLATE index.html template [default:default.tmpl]
--ssl SSL enable ssl with server.pem and key.pem
--port [PORT] Specify alternate port [default: 8000]
Now navigate to http://localhost:8000 with a modern Browser. use http://localhost:8000#debug for getting a terminal and a sized down canvas
v8 based browsers are preferred ( chromium/brave/chrome ... ) starting with 81.0.4044 ( android 4.4 ). Because they set baseline restrictions on WebAssembly loading. Using them while testing ensure proper operation on all browsers.
NOTES:
-
first load will be slower, because setting up local cache from cdn to avoid useless network transfer for getting pygame and cpython prebuilts.
-
each time changing code/template you must restart
pygbag your_game_folderbut cache is not destroyed. -
if you want to reset prebuilts cache, remove the build/web-cache folder in your_game_folder
BUILDING:
pygbag is not only a python module, and rebuilding all the toolchain can be quite hard
https://github.com/pygame-web/python-wasm-sdk <= build CPython (not pyodide)
then read/use pygbag CI to see how to build pygame + the C loader (pymain) and link it to libpython + libpygame
https://github.com/pygame-web/pygbag
prebuilts used by pygbag are stored on github from the repo https://github.com/pygame-web/archives under versionned folders
Support via Discord:
https://discord.gg/t3g7YjK7rw ( #pygame-web on Pygame Community )
French support:
forum thead:
https://discuss.afpy.org/t/moteur-2d-pour-python-pygame-web/834/2
irc:
#python-fr-off on libera.chat
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file pygbag-0.3.2.tar.gz.
File metadata
- Download URL: pygbag-0.3.2.tar.gz
- Upload date:
- Size: 27.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.8.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d0921b9337dd03a7a76b8f59ae29f461eb6ad5815d11600e9869ffa5f2079102
|
|
| MD5 |
6a46e94afdebf78cf8d2cbc7831e89f1
|
|
| BLAKE2b-256 |
7a59555a9d0c7869f2b09b23170fed2842c594beb518fab738b79fbf62d3a3f8
|
File details
Details for the file pygbag-0.3.2-py3-none-any.whl.
File metadata
- Download URL: pygbag-0.3.2-py3-none-any.whl
- Upload date:
- Size: 28.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.8.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b964a9401615381891984af453c3071c17379df54830968e8141ed45b2d862be
|
|
| MD5 |
0b16f06dc580f499c085452814f5fbc4
|
|
| BLAKE2b-256 |
6af212683f3885f43fc26dde893511273cb43bf84e39fdc8cd608761b796c2b0
|