Skip to main content

A cross platform helper library for ModernGL making window creation and resource loading simple

Project description

pypi rtd

moderngl-window

A cross platform utility library for ModernGL making window creation and resource loading simple. It can also be used with PyOpenGL for rendering with the programmable pipeline.

Please report bugs or post questions/feedback on github.

Features

  • Cross platform support. Tested on Windows 10, Linux and Mac OS X. This can save users a lot of time and is often more difficult than most people imagine it to be.
  • Easily create a window for ModernGL using pyglet, pygame, PySide2, GLFW, SDL2, PyQt5 or tkinter supporting a wide range of window, keyboard and mouse events. These events are unified into a single system so your project can work with any window.
  • Load 2D textures, texture arrays and cube maps using Pillow
  • Load shaders as single or multiple glsl files
  • Load objects/scenes from wavefront/obj, GLTF 2.0 or STL
  • Resource finder system supporting multiple resource directories
  • A highly plugable library supporting custom loaders, resource finders and windows.
  • Type hints everywhere making code completion and linting a breeze

We are not trying to force the user into using every aspect of this library. If you have an exiting project and just need texture loading you will be able to do this without unnecessary hurdles as long as you provide us your moderngl.Context.

Install

$ pip install moderngl-window

Supported Platforms

  • Windows
  • Linux
  • Mac OS X

Sample Usage

Simple example opening a window clearing every frame using red (color).

# test.py
import moderngl_window as mglw

class Test(mglw.WindowConfig):
    gl_version = (3, 3)

    def render(self, time, frametime):
        self.ctx.clear(1.0, 0.0, 0.0, 0.0)

Test.run()

Run the example with different window backends:

$ python test.py --window pyglet
$ python test.py --window pygame2
$ python test.py --window glfw
$ python test.py --window sdl2
$ python test.py --window pyside2
$ python test.py --window pyqt5
$ python test.py --window tk

WindowConfig classes are the simplest way to get started without knowing a lot about this library. For more advanced usage see documentation or examples.

Setup from source

We assume the user knows how to handle virtualenvs.

# Install the package in editable mode
$ pip install -e .

# Install development requirements
$ pip install -e .[dev]

Running Tests

With dev requirements installed:

pytest

Building Docs

$ pip install -e .[dev]
$ sphinx-build -b html docs docs/_build

Contributing

Contributions are welcome regardless of experience level. Don't hesitate submitting issues, opening partial or completed pull requests.

Plugins

We are interested in contributions providing new loaders, windows etc. For these to be included in this library we require them to work cross platforms (win10/linux/osx) and be fairly easy to set up.

If it requires more than manually downloading a pre-compiled dll (like SDL2, GLFW etc.) it would most likely not be included, but you are welcome to present your case if you still think it should be included.

If you create your own repo/package containing plugins for this library, please make an issue and we'll link back to it. Be sure to include what platforms are supported, install instructions, how you configure it in moderngl-window and of course a clear and concise description of what exactly your package provides.

Citation

If you need to cite this repository in academic research:

@Online{Forselv2020,
  author = {Einar Forselv},
  title = {moderngl-window, a cross-platform windowing/utility library for ModernGL},
  date = {2020-05-01},
  publisher = {GitHub},
  journal = {GitHub repository},
  howpublished = {\url{https://github.com/moderngl/moderngl-window}},
  commit = {<insert hash if needed>}
}

If commit hash is required this can be found per release here: https://github.com/moderngl/moderngl-window/releases

Attributions

We can't build everything from scratch. We rely on certain packages and resources to make this project possible.

Windows

Loaders

Testing & Utility

Resources

Some History

The majority of the code in this library comes from demosys-py (somewhat modified). Because demosys-py is a framework we decided to split out a lot useful functionality into this library. Frameworks are a lot less appealing to users and it would be a shame to not make this more available to the ModernGL user base.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

moderngl-window-2.4.6.tar.gz (346.8 kB view details)

Uploaded Source

Built Distribution

moderngl_window-2.4.6-py3-none-any.whl (370.6 kB view details)

Uploaded Python 3

File details

Details for the file moderngl-window-2.4.6.tar.gz.

File metadata

  • Download URL: moderngl-window-2.4.6.tar.gz
  • Upload date:
  • Size: 346.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.11.6

File hashes

Hashes for moderngl-window-2.4.6.tar.gz
Algorithm Hash digest
SHA256 db9b4c27f35faa6f243b6d8cde6ada6da6e79541d62b8e536c0b20da29720c32
MD5 49d9321b867ac8ad843f4ed2963bcb00
BLAKE2b-256 36364823988c2155974a334753bfeef9c772d7b49b7f5c01f3e8a44c3813781c

See more details on using hashes here.

File details

Details for the file moderngl_window-2.4.6-py3-none-any.whl.

File metadata

File hashes

Hashes for moderngl_window-2.4.6-py3-none-any.whl
Algorithm Hash digest
SHA256 cfa81c2b222536270a077e2901f5f7a18e317f7332026ae443662555ebf7a66d
MD5 0506643dca50fa03ecad7b1fe0273847
BLAKE2b-256 632f85bfd320fa8b814dfc7da8e967323b568a8c7c6999e4fc8f6185fca888c9

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page