Skip to content

A powerful cross-platform 2D game, graphics, and application engine for Python & C++

License

Notifications You must be signed in to change notification settings

BhavyeMathur/goopylib

Repository files navigation

Downloads PyPI PyPI - Python Version PyPI - Wheel GitHub


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:

https://github.com/BhavyeMathur/goopylib-solar-system-simulation

Brick Breaker:

https://github.com/BhavyeMathur/goopylib-brick-breaker

Conway's Game of Life:

https://github.com/BhavyeMathur/goopylib-conways-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)  # width=700, height=500

# centered at (0, 0), width=100, height=50
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.