Skip to main content

Light volume calculation and rendering with OpenGL

Project description

This package provides the module lightvolume, which offers a CFFI binding to trylock/visibility. This, in turn, is a C++ implementation of the visibility algorithm documented in detail (with awesome interactive demos) on the Red Blob Games website.

API

First, import lightvolume:

import lightvolume

Then, we can create a number of shadow-casting bodies:

objects = [
    lightvolume.rect(0, 0, 500, 500),  # outer bounds - this is needed
    lightvolume.rect(20, 30, 10, 20),
    lightvolume.rect(290, 300, 100, 300),
]

Finally, we can render the lit area cast by a light in this scene (an OpenGL context must already have been created and appropriate GL state set):

light = 90, 200
lightvolume.draw_light(light, objects)

This module is intended to be used with appropriate shaders to provide attenuation, surface interactions such as bump mapping, and so on.

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

lightvolume-0.1.3.tar.gz (166.9 kB view details)

Uploaded Source

File details

Details for the file lightvolume-0.1.3.tar.gz.

File metadata

  • Download URL: lightvolume-0.1.3.tar.gz
  • Upload date:
  • Size: 166.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for lightvolume-0.1.3.tar.gz
Algorithm Hash digest
SHA256 f334172839d8218bb44ee74b4a924c7990074d13381a48a97da1635aa455c65b
MD5 2176f23b08c90d813e2c7551ae0fed99
BLAKE2b-256 c7677e0a2f92ce5bc2294dc4fcb5bad9ff359114be080e5b0b148864e368ef27

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