Examples¶
Here you will find a list of the included examples. Each example have a short description and a screenshot (if applicable).
To look at the source code of an example open it on github by following the link. The examples are also included in the source distribution of Pymunk (but not if you install using the wheel file). You can find the source distribution at PyPI, https://pypi.org/project/pymunk/#files (file named pymunk-x.y.z.zip).
Jupyter Notebooks¶
There are a couple examples that are provided as Jupyter Notebooks (.ipynb). They are possible to either view online in a browser directly on github, or opened as a Notebook.
matplotlib_util_demo.ipynb¶
Displays the same space as the pygame and pyglet draw demos, but using matplotlib and the notebook.
Source: examples/matplotlib_util_demo.ipynb
data:image/s3,"s3://crabby-images/d7f76/d7f76177bda498aee787fd68eb9dd5006004911f" alt="../_images/matplotlib_util_demo.png"
newtons_cradle.ipynb¶
Similar simulation as newtons_cradle.py, but this time as a Notebook. Compared to the draw demo this demo will output a animation of the simulated space.
Source: examples/newtons_cradle.ipynb
Standalone Python¶
To run the examples yourself either install pymunk and run the mobule. Alternatively you can run each file separately.
Given that pymunk is installed:
$> python -m pymunk.examples.breakout
To list all the examples, use the -l option:
$> python -m pymunk.examples -l
Each example contains something unique. Not all of the examples use the same style. For example, some use the pymunk.pygame_util module to draw stuff, others contain the actual drawing code themselves. However, each example is self contained. Except for external libraries (such as pygame) and pymunk each example can be run directly to make it easy to read the code and understand what happens even if it means that some code is repeated for each example.
If you have made something that uses pymunk and would like it displayed here or in a showcase section of the site, feel free to contact me!
arrows.py¶
Source: examples/arrows.py
Showcase of flying arrows that can stick to objects in a somewhat realistic looking way.
data:image/s3,"s3://crabby-images/98d76/98d761138727fc84dd125b571a554fe392a3406f" alt="../_images/arrows.png"
balls_and_lines.py¶
Source: examples/balls_and_lines.py
This example lets you dynamically create static walls and dynamic balls
data:image/s3,"s3://crabby-images/6d555/6d555365790f4a6b00aa4597b31bd25a32a9915d" alt="../_images/balls_and_lines.png"
basic_test.py¶
Source: examples/basic_test.py
Very simple example that does not depend on any third party library such as pygame or pyglet like the other examples.
bouncing_balls.py¶
Source: examples/bouncing_balls.py
This example spawns (bouncing) balls randomly on a L-shape constructed of two segment shapes. Not interactive.
data:image/s3,"s3://crabby-images/bd63b/bd63ba40f806f070db7a0ce7d4a7bccef736412c" alt="../_images/bouncing_balls.png"
box2d_pyramid.py¶
Source: examples/box2d_pyramid.py
Remake of the pyramid demo from the box2d testbed.
data:image/s3,"s3://crabby-images/86f2a/86f2a9cae1e23b082d8764e306dc149e7a287115" alt="../_images/box2d_pyramid.png"
box2d_vertical_stack.py¶
Source: examples/box2d_vertical_stack.py
Remake of the veritcal stack demo from the box2d testbed.
data:image/s3,"s3://crabby-images/5f39a/5f39abaaa4bd09a3d4aaa1cd4eb197ff4b65c616" alt="../_images/box2d_vertical_stack.png"
breakout.py¶
Source: examples/breakout.py
Very simple breakout clone. A circle shape serves as the paddle, then breakable bricks constructed of Poly-shapes.
The code showcases several pymunk concepts such as elasitcity, impulses, constant object speed, joints, collision handlers and post step callbacks.
data:image/s3,"s3://crabby-images/17a69/17a697bbb9374d443244127c3bd1f93649805755" alt="../_images/breakout.png"
camera.py¶
Source: examples/camera.py
Basic showcase on how the transform property on SpaceDebugDrawOptions can be used as a camera to allow panning. Use arrows to move the camera.
data:image/s3,"s3://crabby-images/8c881/8c881d97727f9345cd40392607f7d7c9e0ac4ce3" alt="../_images/camera.png"
colors.py¶
Source: examples/colors.py
An example of the determinism of pymunk by coloring balls according to their position, and then respawning them to verify each ball ends up in the same place. Inspired by Pymunk user Nam Dao.
data:image/s3,"s3://crabby-images/1b13e/1b13ec475062d6ea6db8732527f1e8ff195c1d57" alt="../_images/colors.png"
colors_pyglet_batch.py¶
Source: examples/colors_pyglet_batch.py
An example of the determinism of pymunk by coloring balls according to their position, and then respawning them to verify each ball ends up in the same place. Inspired by Pymunk user Nam Dao.
This is also a demonstration of the performance boost from the batch api in pymunk.batch.
Running this script for 30 seconds with cProfile, about 57% of the time is spent on drawing without batching, but with batching only uses 34% of the time. The rest of the time is mainly spent on space.Step stepping the simulation forward.
To try yourself:
> python -m cProfile -o batch_on.prof -m pymunk.examples.colors_pyglet_batch
data:image/s3,"s3://crabby-images/d56dc/d56dc2b9ff7b45f62ce622036364b40e2e7edabf" alt="../_images/colors_pyglet_batch.png"
constraints.py¶
Source: examples/constraints.py
Pymunk constraints demo. Showcase of all the constraints included in Pymunk.
Adapted from the Chipmunk Joints demo: https://github.com/slembcke/Chipmunk2D/blob/master/demo/Joints.c
data:image/s3,"s3://crabby-images/2942c/2942cdc49ba0822c5a78cd660ea86beea0138dee" alt="../_images/constraints.png"
contact_and_no_flipy.py¶
Source: examples/contact_and_no_flipy.py
This example spawns (bouncing) balls randomly on a L-shape constructed of two segment shapes. For each collision it draws a red circle with size depending on collision strength. Not interactive.
data:image/s3,"s3://crabby-images/2a208/2a20813596aedab0ee41ca7c2c8f63e61ebcb74a" alt="../_images/contact_and_no_flipy.png"
contact_with_friction.py¶
Source: examples/contact_with_friction.py
This example spawns (bouncing) balls randomly on a L-shape constructed of two segment shapes. Displays collsion strength and rotating balls thanks to friction. Not interactive.
data:image/s3,"s3://crabby-images/9fdae/9fdaeb348f17e6ad65134e635b53a7ae46ed31f9" alt="../_images/contact_with_friction.png"
copy_and_pickle.py¶
Source: examples/copy_and_pickle.py
This example shows how you can copy, save and load a space using pickle.
data:image/s3,"s3://crabby-images/d922f/d922fc1ea6eb5a05569d6c3539f925ac421a3c83" alt="../_images/copy_and_pickle.png"
damped_rotary_spring_pointer.py¶
Source: examples/damped_rotary_spring_pointer.py
This example showcase an arrow pointing or aiming towards the cursor.
data:image/s3,"s3://crabby-images/12ba5/12ba5633c821a885963a15fcaa8b86b831c0006e" alt="../_images/damped_rotary_spring_pointer.png"
deformable.py¶
Source: examples/deformable.py
This is an example on how the autogeometry can be used for deformable terrain.
data:image/s3,"s3://crabby-images/406c2/406c28b442da1ecdaa9581187131968f05744916" alt="../_images/deformable.png"
flipper.py¶
Source: examples/flipper.py
A very basic flipper game.
data:image/s3,"s3://crabby-images/3ca04/3ca0478b4fafea64229e6f9c63a1b4da626e6585" alt="../_images/flipper.png"
index_video.py¶
Source: examples/index_video.py
Program used to generate the logo animation on the pymunk main page.
This program will showcase several features of Pymunk, such as collisions, debug drawing, automatic generation of shapes from images, motors, joints and sleeping bodies.
data:image/s3,"s3://crabby-images/d3010/d301035cec18f3592d6c8ca569310b7182b7c1b2" alt="../_images/index_video.png"
newtons_cradle.py¶
Source: examples/newtons_cradle.py
A screensaver version of Newton’s Cradle with an interactive mode.
data:image/s3,"s3://crabby-images/ed104/ed1048a69fd6ad8e0c82e1734ca22148fd1049f9" alt="../_images/newtons_cradle.png"
planet.py¶
Source: examples/planet.py
Showcase of planets/satellites (small boxes) orbiting around a star.
Uses a custom velocity function to manually calculate the gravity, assuming the star is in the middle and is massive enough that the satellites does not affect it.
This is a port of the Planet demo included in Chipmunk.
data:image/s3,"s3://crabby-images/c72a2/c72a2496a9885b35d17cec9a25119781948a2910" alt="../_images/planet.png"
platformer.py¶
Source: examples/platformer.py
Showcase of a very basic 2d platformer
The red girl sprite is taken from Sithjester’s RMXP Resources: http://untamed.wild-refuge.net/rmxpresources.php?characters
Note
The code of this example is a bit messy. If you adapt this to your own code you might want to structure it a bit differently.
data:image/s3,"s3://crabby-images/855d2/855d276f7f16245003d6c2840ffbd14b691bc597" alt="../_images/platformer.png"
playground.py¶
Source: examples/playground.py
A basic playground. Most interesting function is draw a shape, basically move the mouse as you want and pymunk will approximate a Poly shape from the drawing.
data:image/s3,"s3://crabby-images/2dd4a/2dd4a69a8eebf4a138077a69459edf2ef8c5e8d2" alt="../_images/playground.png"
point_query.py¶
Source: examples/point_query.py
This example showcase point queries by highlighting the shape under the mouse pointer.
data:image/s3,"s3://crabby-images/08cd9/08cd9f611c7c87a9d03445fce761bd9789a238e1" alt="../_images/point_query.png"
pygame_util_demo.py¶
Source: examples/pygame_util_demo.py
Showcase what the output of pymunk.pygame_util draw methods will look like.
See pyglet_util_demo.py for a comparison to pyglet.
data:image/s3,"s3://crabby-images/53cb8/53cb8d26b06a414714b47e65bce8b5b13a137ffb" alt="../_images/pygame_util_demo.png"
pyglet_util_demo.py¶
Source: examples/pyglet_util_demo.py
Showcase what the output of pymunk.pyglet_util draw methods will look like.
See pygame_util_demo.py for a comparison to pygame.
data:image/s3,"s3://crabby-images/46ceb/46ceb1688072c9309b684ef6fd92c252dee4b754" alt="../_images/pyglet_util_demo.png"
shapes_for_draw_demos.py¶
Source: examples/shapes_for_draw_demos.py
Helper function fill_space for the draw demos. Adds a lot of stuff to a space.
slide_and_pinjoint.py¶
Source: examples/slide_and_pinjoint.py
A L shape attached with a joint and constrained to not tip over.
This example is also used in the Get Started Tutorial.
data:image/s3,"s3://crabby-images/ca61b/ca61bc0c2a3b56261ace9d5a43b81038c927ea80" alt="../_images/slide_and_pinjoint.png"
spiderweb.py¶
Source: examples/spiderweb.py
Showcase of a elastic spiderweb (drawing with pyglet)
It is possible to grab one of the crossings with the mouse
data:image/s3,"s3://crabby-images/55692/55692ba4ae6c45f1da4e3f3c4385e0ee970ad838" alt="../_images/spiderweb.png"
tank.py¶
Source: examples/tank.py
Port of the Chipmunk tank demo. Showcase a topdown tank driving towards the mouse, and hitting obstacles on the way.
data:image/s3,"s3://crabby-images/30a36/30a36c7ee8b57ce45813306410ad4839eeed205e" alt="../_images/tank.png"
using_sprites.py¶
Source: examples/using_sprites.py
Very basic example of using a sprite image to draw a shape more similar how you would do it in a real game instead of the simple line drawings used by the other examples.
data:image/s3,"s3://crabby-images/0ef93/0ef9340916ab15f9d650d732fa5f3f680419a801" alt="../_images/using_sprites.png"
using_sprites_pyglet.py¶
Source: examples/using_sprites_pyglet.py
This example is a clone of the using_sprites example with the difference that it uses pyglet instead of pygame to showcase sprite drawing.
data:image/s3,"s3://crabby-images/71ff3/71ff3c72bd2181d31ca0d8fd859f4c03f49631d6" alt="../_images/using_sprites_pyglet.png"
Additional Examples¶
kivy_pymunk_demo¶
Source: additional_examples/kivy_pymunk_demo
A rudimentary port of the intro video used for the intro animation on pymunk.org. The code is tested on both Windows and Android.
Note that it doesn’t display Kivy best practices, the intro_video code was just converted to Kivy in the most basic way to show that its possible, its not supposed to show the best way to structure a Kivy application using Pymunk.
data:image/s3,"s3://crabby-images/869e2/869e231846a2d07637a389ad9115f540bc527e43" alt="../_images/kivy_pymunk_demo.png"
no_dependencies.py¶
Source: additional_examples/no_dependencies.py
Very simple example that does not depend on any third party library such as pygame or pyglet like the other examples.
py2exe_setup__basic_test.py¶
Source: additional_examples/py2exe_setup__basic_test.py
Simple example of py2exe to create a exe of the no_dependencies example.
Tested on py2exe 0.13.0.0 on python 3.11