pyGLFW
======
This module provides Python bindings for `GLFW <http://www.glfw.org/>`__
(on GitHub: `glfw/glfw <http://github.com/glfw/glfw>`__). It is a
``ctypes`` wrapper which keeps very close to the original GLFW API,
except for:
- function names use the pythonic ``words_with_underscores`` notation
instead of ``camelCase``
- ``GLFW_`` and ``glfw`` prefixes have been removed, as their function
is replaced by the module namespace
(you can use ``from glfw.GLFW import *`` if you prefer the naming
convention used by the GLFW C API)
- structs have been replaced with Python sequences and namedtuples
- functions like ``glfwGetMonitors`` return a list instead of a pointer
and an object count
- Gamma ramps use floats between 0.0 and 1.0 instead of unsigned shorts
(use ``glfw.NORMALIZE_GAMMA_RAMPS=False`` to disable this)
- GLFW errors are reported as ``glfw.GLFWError`` warnings if no error
callback is set (use ``glfw.ERROR_REPORTING=False`` to disable this,
set it to 'warn' instead to issue warnings, set it to 'log' to log it
using the 'glfw' logger or set it to a dict to define the behavior for
specific error codes)
- instead of a sequence for ``GLFWimage`` structs, PIL/pillow ``Image``
objects can be used
Installation
------------
pyGLFW can be installed using pip:
.. code:: sh
pip install glfw
Windows
~~~~~~~
The GLFW shared library and Visual C++ runtime are included in the Python wheels.
To use a different GLFW library, you can set ``PYGLFW_LIBRARY`` to its location.
macOS
~~~~~
The GLFW shared library for 64-bit is included in the Python wheels for macOS.
If you are using a 32-bit Python installation or otherwise cannot use the
library downloaded with the wheel, you can build and install it yourself by
`compiling GLFW from source <http://www.glfw.org/docs/latest/compile.html>`__
(use ``-DBUILD_SHARED_LIBS=ON``).
pyGLFW will search for the library in a list of search paths (including those
in ``DYLD_LIBRARY_PATH``). If you want to use a specific library, you can set
the ``PYGLFW_LIBRARY`` environment variable to its path.
Linux
~~~~~
The GLFW shared library is included in the Python wheels for Linux. Although
pyGLFW will try to detect whether the GLFW library for Wayland or X11 should
be used, you can set the ``PYGLFW_LIBRARY_VARIANT`` variable to ``wayland`` or
``x11`` to select either variant of the library.
If you cannot use these on your system, you can install the GLFW shared
library using a package management system (e.g. ``apt install libglfw3``
on Debian or Ubuntu) or you can build and install it yourself by
`compiling GLFW from source <http://www.glfw.org/docs/latest/compile.html>`__
(use ``-DBUILD_SHARED_LIBS=ON``).
pyGLFW will search for the library in a list of search paths (including those
in ``LD_LIBRARY_PATH``). If you want to use a specific library, you can set
the ``PYGLFW_LIBRARY`` environment variable to its path.
cx_Freeze / PyInstaller
~~~~~~~~~~~~~~~~~~~~~~~
pyGLFW will search for the GLFW library in the current working directory, the directory
of the executable and in the package on non-Windows platforms if running in an
executable frozen with cx_Freeze or PyInstaller, unless the ``PYGLFW_LIBRARY``
environment variable is set.
Development Version
~~~~~~~~~~~~~~~~~~~
If you are using the development version of GLFW and would like to use wrappers
for currently unreleased macros and functions, you can instead install:
.. code:: sh
pip install glfw[preview]
or set the ``PYGLFW_PREVIEW`` environment variable.
Note, however, that there will be a slight delay between the development
version of GLFW and the wrappers provided by this package.
Example Code
------------
The example from the `GLFW
documentation <http://www.glfw.org/documentation.html>`__ ported to
pyGLFW:
.. code:: python
import glfw
def main():
# Initialize the library
if not glfw.init():
return
# Create a windowed mode window and its OpenGL context
window = glfw.create_window(640, 480, "Hello World", None, None)
if not window:
glfw.terminate()
return
# Make the window's context current
glfw.make_context_current(window)
# Loop until the user closes the window
while not glfw.window_should_close(window):
# Render here, e.g. using pyOpenGL
# Swap front and back buffers
glfw.swap_buffers(window)
# Poll for and process events
glfw.poll_events()
glfw.terminate()
if __name__ == "__main__":
main()
Raw data
{
"_id": null,
"home_page": "https://github.com/FlorianRhiem/pyGLFW",
"name": "glfw",
"maintainer": null,
"docs_url": null,
"requires_python": null,
"maintainer_email": null,
"keywords": null,
"author": "Florian Rhiem",
"author_email": "florian.rhiem@gmail.com",
"download_url": "https://files.pythonhosted.org/packages/2d/2a/48716456664a0db318e9a2565a1622a5c8400a553688b17d6d6d3a5efbd9/glfw-2.8.0.tar.gz",
"platform": null,
"description": "pyGLFW\n======\n\nThis module provides Python bindings for `GLFW <http://www.glfw.org/>`__\n(on GitHub: `glfw/glfw <http://github.com/glfw/glfw>`__). It is a\n``ctypes`` wrapper which keeps very close to the original GLFW API,\nexcept for:\n\n- function names use the pythonic ``words_with_underscores`` notation\n instead of ``camelCase``\n- ``GLFW_`` and ``glfw`` prefixes have been removed, as their function\n is replaced by the module namespace\n (you can use ``from glfw.GLFW import *`` if you prefer the naming\n convention used by the GLFW C API)\n- structs have been replaced with Python sequences and namedtuples\n- functions like ``glfwGetMonitors`` return a list instead of a pointer\n and an object count\n- Gamma ramps use floats between 0.0 and 1.0 instead of unsigned shorts\n (use ``glfw.NORMALIZE_GAMMA_RAMPS=False`` to disable this)\n- GLFW errors are reported as ``glfw.GLFWError`` warnings if no error\n callback is set (use ``glfw.ERROR_REPORTING=False`` to disable this,\n set it to 'warn' instead to issue warnings, set it to 'log' to log it\n using the 'glfw' logger or set it to a dict to define the behavior for\n specific error codes)\n- instead of a sequence for ``GLFWimage`` structs, PIL/pillow ``Image``\n objects can be used\n\nInstallation\n------------\n\npyGLFW can be installed using pip:\n\n.. code:: sh\n\n pip install glfw\n\nWindows\n~~~~~~~\n\nThe GLFW shared library and Visual C++ runtime are included in the Python wheels.\n\nTo use a different GLFW library, you can set ``PYGLFW_LIBRARY`` to its location.\n\nmacOS\n~~~~~\n\nThe GLFW shared library for 64-bit is included in the Python wheels for macOS.\n\nIf you are using a 32-bit Python installation or otherwise cannot use the\nlibrary downloaded with the wheel, you can build and install it yourself by\n`compiling GLFW from source <http://www.glfw.org/docs/latest/compile.html>`__\n(use ``-DBUILD_SHARED_LIBS=ON``).\n\npyGLFW will search for the library in a list of search paths (including those\nin ``DYLD_LIBRARY_PATH``). If you want to use a specific library, you can set\nthe ``PYGLFW_LIBRARY`` environment variable to its path.\n\nLinux\n~~~~~\n\nThe GLFW shared library is included in the Python wheels for Linux. Although\npyGLFW will try to detect whether the GLFW library for Wayland or X11 should\nbe used, you can set the ``PYGLFW_LIBRARY_VARIANT`` variable to ``wayland`` or\n``x11`` to select either variant of the library.\n\nIf you cannot use these on your system, you can install the GLFW shared\nlibrary using a package management system (e.g. ``apt install libglfw3``\non Debian or Ubuntu) or you can build and install it yourself by\n`compiling GLFW from source <http://www.glfw.org/docs/latest/compile.html>`__\n(use ``-DBUILD_SHARED_LIBS=ON``).\n\npyGLFW will search for the library in a list of search paths (including those\nin ``LD_LIBRARY_PATH``). If you want to use a specific library, you can set\nthe ``PYGLFW_LIBRARY`` environment variable to its path.\n\ncx_Freeze / PyInstaller\n~~~~~~~~~~~~~~~~~~~~~~~\n\npyGLFW will search for the GLFW library in the current working directory, the directory\nof the executable and in the package on non-Windows platforms if running in an\nexecutable frozen with cx_Freeze or PyInstaller, unless the ``PYGLFW_LIBRARY``\nenvironment variable is set.\n\nDevelopment Version\n~~~~~~~~~~~~~~~~~~~\n\nIf you are using the development version of GLFW and would like to use wrappers\nfor currently unreleased macros and functions, you can instead install:\n\n.. code:: sh\n\n pip install glfw[preview]\n\nor set the ``PYGLFW_PREVIEW`` environment variable.\n\nNote, however, that there will be a slight delay between the development\nversion of GLFW and the wrappers provided by this package.\n\nExample Code\n------------\n\nThe example from the `GLFW\ndocumentation <http://www.glfw.org/documentation.html>`__ ported to\npyGLFW:\n\n.. code:: python\n\n import glfw\n\n def main():\n # Initialize the library\n if not glfw.init():\n return\n # Create a windowed mode window and its OpenGL context\n window = glfw.create_window(640, 480, \"Hello World\", None, None)\n if not window:\n glfw.terminate()\n return\n\n # Make the window's context current\n glfw.make_context_current(window)\n\n # Loop until the user closes the window\n while not glfw.window_should_close(window):\n # Render here, e.g. using pyOpenGL\n\n # Swap front and back buffers\n glfw.swap_buffers(window)\n\n # Poll for and process events\n glfw.poll_events()\n\n glfw.terminate()\n\n if __name__ == \"__main__\":\n main()\n",
"bugtrack_url": null,
"license": "MIT",
"summary": "A ctypes-based wrapper for GLFW3.",
"version": "2.8.0",
"project_urls": {
"Homepage": "https://github.com/FlorianRhiem/pyGLFW"
},
"split_keywords": [],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "b6f14d412c337cba7aa2f77bac46df463ab0cf8c82dd70a02f75c915e506fb15",
"md5": "f94e26446e300bb4340be80e1da72d4f",
"sha256": "28aaef2f022b57cd37525ad1d11ba9049931a273359964fb3cd36762eb093ed1"
},
"downloads": -1,
"filename": "glfw-2.8.0-py2.py27.py3.py30.py31.py32.py33.py34.py35.py36.py37.py38.p39.p310.p311.p312.p313-none-macosx_10_6_intel.whl",
"has_sig": false,
"md5_digest": "f94e26446e300bb4340be80e1da72d4f",
"packagetype": "bdist_wheel",
"python_version": "py2.py27.py3.py30.py31.py32.py33.py34.py35.py36.py37.py38.p39.p310.p311.p312.p313",
"requires_python": null,
"size": 105239,
"upload_time": "2024-11-22T15:43:48",
"upload_time_iso_8601": "2024-11-22T15:43:48.123895Z",
"url": "https://files.pythonhosted.org/packages/b6/f1/4d412c337cba7aa2f77bac46df463ab0cf8c82dd70a02f75c915e506fb15/glfw-2.8.0-py2.py27.py3.py30.py31.py32.py33.py34.py35.py36.py37.py38.p39.p310.p311.p312.p313-none-macosx_10_6_intel.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "d1761c5e408b55f8ed6787421f4ceaa1f26b6618a8ece9b6c199e559be810d5f",
"md5": "bdb531cf9e32158635aaa3a76c9e40a5",
"sha256": "0239e478ff065719064fd1272ad29f8542e8178b11c614674bb930d85aa2d1e7"
},
"downloads": -1,
"filename": "glfw-2.8.0-py2.py27.py3.py30.py31.py32.py33.py34.py35.py36.py37.py38.p39.p310.p311.p312.p313-none-macosx_11_0_arm64.whl",
"has_sig": false,
"md5_digest": "bdb531cf9e32158635aaa3a76c9e40a5",
"packagetype": "bdist_wheel",
"python_version": "py2.py27.py3.py30.py31.py32.py33.py34.py35.py36.py37.py38.p39.p310.p311.p312.p313",
"requires_python": null,
"size": 102088,
"upload_time": "2024-11-22T15:43:50",
"upload_time_iso_8601": "2024-11-22T15:43:50.013880Z",
"url": "https://files.pythonhosted.org/packages/d1/76/1c5e408b55f8ed6787421f4ceaa1f26b6618a8ece9b6c199e559be810d5f/glfw-2.8.0-py2.py27.py3.py30.py31.py32.py33.py34.py35.py36.py37.py38.p39.p310.p311.p312.p313-none-macosx_11_0_arm64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "47162ffe39faf5bababe5b4ac47a2a6bfdb3ba5d88e4837228a723cb45cd919e",
"md5": "b96242e9ddd37b04ea7d554f40c4cb12",
"sha256": "44b5313cffa4a037e8e2988bccba6fa7de0a24123509f4ccf3e49b831cf72abb"
},
"downloads": -1,
"filename": "glfw-2.8.0-py2.py27.py3.py30.py31.py32.py33.py34.py35.py36.py37.py38.p39.p310.p311.p312.p313-none-manylinux2014_aarch64.whl",
"has_sig": false,
"md5_digest": "b96242e9ddd37b04ea7d554f40c4cb12",
"packagetype": "bdist_wheel",
"python_version": "py2.py27.py3.py30.py31.py32.py33.py34.py35.py36.py37.py38.p39.p310.p311.p312.p313",
"requires_python": null,
"size": 229946,
"upload_time": "2024-11-22T15:43:51",
"upload_time_iso_8601": "2024-11-22T15:43:51.578783Z",
"url": "https://files.pythonhosted.org/packages/47/16/2ffe39faf5bababe5b4ac47a2a6bfdb3ba5d88e4837228a723cb45cd919e/glfw-2.8.0-py2.py27.py3.py30.py31.py32.py33.py34.py35.py36.py37.py38.p39.p310.p311.p312.p313-none-manylinux2014_aarch64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "433f038bd92471d38654e440c30faccff1d36f1da5e9ea96cc112ac6d59777e5",
"md5": "9dfb3d6c15aaf0c93aed82db253ba472",
"sha256": "0fd982cf42a8e3137e05e392280826311961f9e99c82a0ccf22a63a0d2acd143"
},
"downloads": -1,
"filename": "glfw-2.8.0-py2.py27.py3.py30.py31.py32.py33.py34.py35.py36.py37.py38.p39.p310.p311.p312.p313-none-manylinux2014_x86_64.whl",
"has_sig": false,
"md5_digest": "9dfb3d6c15aaf0c93aed82db253ba472",
"packagetype": "bdist_wheel",
"python_version": "py2.py27.py3.py30.py31.py32.py33.py34.py35.py36.py37.py38.p39.p310.p311.p312.p313",
"requires_python": null,
"size": 241890,
"upload_time": "2024-11-22T15:43:53",
"upload_time_iso_8601": "2024-11-22T15:43:53.530535Z",
"url": "https://files.pythonhosted.org/packages/43/3f/038bd92471d38654e440c30faccff1d36f1da5e9ea96cc112ac6d59777e5/glfw-2.8.0-py2.py27.py3.py30.py31.py32.py33.py34.py35.py36.py37.py38.p39.p310.p311.p312.p313-none-manylinux2014_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "2383714deff4fc489e760bf92b8335005ba291f450ed1ba8fd651d708b787fb4",
"md5": "841ce6b2dad0b462b467ee3ec49d800e",
"sha256": "523e1fc03898bcb0711f78d6f21eee58c1f865bb764cbd36b9549580a4c43454"
},
"downloads": -1,
"filename": "glfw-2.8.0-py2.py27.py3.py30.py31.py32.py33.py34.py35.py36.py37.py38.p39.p310.p311.p312.p313-none-manylinux_2_28_aarch64.whl",
"has_sig": false,
"md5_digest": "841ce6b2dad0b462b467ee3ec49d800e",
"packagetype": "bdist_wheel",
"python_version": "py2.py27.py3.py30.py31.py32.py33.py34.py35.py36.py37.py38.p39.p310.p311.p312.p313",
"requires_python": null,
"size": 230122,
"upload_time": "2024-11-22T15:43:54",
"upload_time_iso_8601": "2024-11-22T15:43:54.945106Z",
"url": "https://files.pythonhosted.org/packages/23/83/714deff4fc489e760bf92b8335005ba291f450ed1ba8fd651d708b787fb4/glfw-2.8.0-py2.py27.py3.py30.py31.py32.py33.py34.py35.py36.py37.py38.p39.p310.p311.p312.p313-none-manylinux_2_28_aarch64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "bb55a513de61cafe6bd70c064a5b714dc084120fe8f90a5ba51fbc5cfe42fc13",
"md5": "4d15ac03c7c07807bc24ff310d9283ee",
"sha256": "9cd20351b14587c6fe7063afb33cc03152e38dd2bff2b69613cb044bf3bdb635"
},
"downloads": -1,
"filename": "glfw-2.8.0-py2.py27.py3.py30.py31.py32.py33.py34.py35.py36.py37.py38.p39.p310.p311.p312.p313-none-manylinux_2_28_x86_64.whl",
"has_sig": false,
"md5_digest": "4d15ac03c7c07807bc24ff310d9283ee",
"packagetype": "bdist_wheel",
"python_version": "py2.py27.py3.py30.py31.py32.py33.py34.py35.py36.py37.py38.p39.p310.p311.p312.p313",
"requires_python": null,
"size": 243445,
"upload_time": "2024-11-22T15:43:56",
"upload_time_iso_8601": "2024-11-22T15:43:56.186824Z",
"url": "https://files.pythonhosted.org/packages/bb/55/a513de61cafe6bd70c064a5b714dc084120fe8f90a5ba51fbc5cfe42fc13/glfw-2.8.0-py2.py27.py3.py30.py31.py32.py33.py34.py35.py36.py37.py38.p39.p310.p311.p312.p313-none-manylinux_2_28_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "64653c18a715c8a57a4e1de96311b6ad6c77c3b90535fc92c4a5e26b2e18f87d",
"md5": "8f2b0b3b76e4cda704554d5a748f034d",
"sha256": "13a75d8d3e8d4bb24595f2354a392ccf7c54ddd20dacb88e1188b760f2a7714b"
},
"downloads": -1,
"filename": "glfw-2.8.0-py2.py27.py3.py30.py31.py32.py33.py34.py35.py36.py37.py38.p39.p310.p311.p312.p313-none-win32.whl",
"has_sig": false,
"md5_digest": "8f2b0b3b76e4cda704554d5a748f034d",
"packagetype": "bdist_wheel",
"python_version": "py2.py27.py3.py30.py31.py32.py33.py34.py35.py36.py37.py38.p39.p310.p311.p312.p313",
"requires_python": null,
"size": 552596,
"upload_time": "2024-11-22T15:43:57",
"upload_time_iso_8601": "2024-11-22T15:43:57.659707Z",
"url": "https://files.pythonhosted.org/packages/64/65/3c18a715c8a57a4e1de96311b6ad6c77c3b90535fc92c4a5e26b2e18f87d/glfw-2.8.0-py2.py27.py3.py30.py31.py32.py33.py34.py35.py36.py37.py38.p39.p310.p311.p312.p313-none-win32.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "9d3d29791f39363b613a0b62b9ca7a2449ef55fe51096797ae3bc90c1bb8d143",
"md5": "4a9d23b1cc16f669ddeece63cae5efe2",
"sha256": "1416f10d2c2748c39910e9d9e6a10a5473743c5a745518061e4051be4c5caaa1"
},
"downloads": -1,
"filename": "glfw-2.8.0-py2.py27.py3.py30.py31.py32.py33.py34.py35.py36.py37.py38.p39.p310.p311.p312.p313-none-win_amd64.whl",
"has_sig": false,
"md5_digest": "4a9d23b1cc16f669ddeece63cae5efe2",
"packagetype": "bdist_wheel",
"python_version": "py2.py27.py3.py30.py31.py32.py33.py34.py35.py36.py37.py38.p39.p310.p311.p312.p313",
"requires_python": null,
"size": 559382,
"upload_time": "2024-11-22T15:44:00",
"upload_time_iso_8601": "2024-11-22T15:44:00.481463Z",
"url": "https://files.pythonhosted.org/packages/9d/3d/29791f39363b613a0b62b9ca7a2449ef55fe51096797ae3bc90c1bb8d143/glfw-2.8.0-py2.py27.py3.py30.py31.py32.py33.py34.py35.py36.py37.py38.p39.p310.p311.p312.p313-none-win_amd64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "2d2a48716456664a0db318e9a2565a1622a5c8400a553688b17d6d6d3a5efbd9",
"md5": "3e69cfe7d4c5bcb3562f4d4ea5227a4b",
"sha256": "90e90d328b0b26fed6e1631d21801e2d8a7a0c5dcb480e733c177567ec9666f0"
},
"downloads": -1,
"filename": "glfw-2.8.0.tar.gz",
"has_sig": false,
"md5_digest": "3e69cfe7d4c5bcb3562f4d4ea5227a4b",
"packagetype": "sdist",
"python_version": "source",
"requires_python": null,
"size": 31372,
"upload_time": "2024-11-22T15:44:01",
"upload_time_iso_8601": "2024-11-22T15:44:01.680274Z",
"url": "https://files.pythonhosted.org/packages/2d/2a/48716456664a0db318e9a2565a1622a5c8400a553688b17d6d6d3a5efbd9/glfw-2.8.0.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-11-22 15:44:01",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "FlorianRhiem",
"github_project": "pyGLFW",
"travis_ci": false,
"coveralls": false,
"github_actions": false,
"lcname": "glfw"
}