What is it?
goopylib is powerful game, graphics, and GUI library for Python and C++ to build cross-platform applications.
It allows you to unlock the potential of OpenGL and low-level graphics with a high-level, simple-yet-powerful API.
Key Features:
- Cross-Platform & Powerful
- Fast! Built-in batch-rendering & optimizations
- Accessible through Python & C++
- Simple code to create, transform, & animate images, quads, triangles, circles, and more
- Automatic 2D Orthographic Camera & Camera Controller
- Window & Mouse events: key & button presses, several callbacks, etc.
In Development:
- Text Rendering
- GUI Elements
- Animation Engine
- Texture Factory
- Low-Level API Access
Future Plans:
- 2D Rigid-Body Physics Engine
- Sound & Lighting Engine
- Profiling Tools
- Build & Distribution Tools
Examples
Solar System Simulator:
Brick Breaker:
Conway's Game of Life:
Installation
Requires Python ≥ 3.8. To install goopylib on Windows or MacOS, use the
Python Package Index (PyPI):
pip install goopylib
Wheels for Linux are not currently supported but coming as soon as I can build them!
Tutorial
Let's start by creating a rectangle on an empty window:
import goopylib as gp
window = gp.Window(700, 500)
rect = gp.Rectangle((0, 0), 100, 50).draw(window)
while window.is_open():
gp.update()
Inside the loop, you can check for events (or define callbacks instead):
while window.is_open():
if window.check_key(gp.KEY_H):
rect.hide()
elif window.check_key(gp.KEY_S):
rect.show()
mousex, mousey = window.get_mouse_position()
if rect.contains(mousex, mousey):
print("Hovering over the rectangle!")
gp.update()
Draw other shapes or more complex objects:
img = gp.Image("filepath.png", (0, 0)).draw(window)
Install a simple camera controller that automatically moves, rotates, and zooms in & out!
controller = gp.CameraController(window)
while window.is_open():
controller.update()
Documentation
The documentation for goopylib can be found here.
Please submit an issue or email bhavyemathur@gmail.com for any questions!
Contributing & Usage
Contributions to goopylib are absolutely welcome! Please reach out to me if you have an idea or feature request or
submit a pull request yourself. I'd love to hear if you've used goopylib for a project—maybe we could even add some
screenshots to a gallery.
goopylib is licensed under the Mozilla Public License Version 2.0 which essentially enables you use
and modify goopylib (commercially or otherwise) as long as you attribute the project! See
choosealicense.com for more details.