Skip to content

davidpendergast/pyengine

Repository files navigation

pyengine

Note: This has bugs, it's not well documented, and it's not very pleasant to use!

This was originally the core "engine" of Skeletris, built on top of pygame, and I've extracted it here as a standalone resource.

It sidesteps most of pygame's rendering API to interface directly with PyOpenGL instead. This means you can't use pygame-y stuff like pygame.draw, pygame.font, and direct surface manipulation & blitting to put stuff onto the screen.

Instead, you load or create a massive spritesheet that contains all the sprites you'll ever need, bind it to the GPU, and work solely with those for the entire game. You create a fixed number of "sprite layers", fill them with "sprite objects" (AKA sub-rectangles of the original sheet), update their positions, sizes, etc., and then render each layer to the screen with a single draw call. In exchange for flexibily, you get speed. That's the idea anyways.

Some key features:

  • Quick and easy OpenGL setup, that supports on-the-fly pixel scale readjustment (renderengine.py).
  • A layer-based sprite rendering system (renderengine.py, layers.py, sprites.py).
  • Easier window creation, resizing, and fullscreen management (window.py).
  • Some helpful methods involving music & sounds (music.py + sounds.py).
  • A more convenient way to handle keyboard + mouse inputs (inputs.py).
  • Automatic crash reporting (entry_point.py)

And some new (post-Skeletris) stuff:

  • Ability to draw triangles and lines.

And there's a demo scene to help illustrate the setup (gameloop.py).

This is what it should look like:

demo

About

the skeletris engine, extracted here for re-use

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages