Creating shapesΒΆ
There are 3 basic shape nodes: Triangle, Quad and Circle. It is also possible to create custom geometries with the Geometry node.
Rendering a triangle
data:image/s3,"s3://crabby-images/89eca/89eca8e8975ebb5463a44649e190ef6539bf4b3a" alt=""
import pynopegl as ngl
@ngl.scene()
def triangle(cfg: ngl.SceneCfg):
cfg.aspect_ratio = (1, 1)
return ngl.RenderColor(geometry=ngl.Triangle())
data:image/s3,"s3://crabby-images/581f2/581f2fbe0a3c98f6f12eaa74938ec9e05be75677" alt="graph"
Rendering a quadrilateral
data:image/s3,"s3://crabby-images/90636/90636b224ab891466df533d391df820c6edef51f" alt=""
import pynopegl as ngl
@ngl.scene()
def quad(cfg: ngl.SceneCfg):
cfg.aspect_ratio = (1, 1)
return ngl.RenderColor(geometry=ngl.Quad())
data:image/s3,"s3://crabby-images/72ea1/72ea1a2b98238ef799f840664cbe6e5d32f95966" alt="graph"
Rendering a circle with 64 points
data:image/s3,"s3://crabby-images/5989a/5989aed8ffcb92d441153a7d0b50d97221696a71" alt=""
import pynopegl as ngl
@ngl.scene()
def circle(cfg: ngl.SceneCfg):
cfg.aspect_ratio = (1, 1)
return ngl.RenderColor(geometry=ngl.Circle(radius=0.7, npoints=64))
data:image/s3,"s3://crabby-images/08df9/08df9d07cfe7834dc383ca5b4ed0edb73f005112" alt="graph"
Rendering a custom geometry composed of 4 random points
data:image/s3,"s3://crabby-images/34aef/34aef5548817139d20b55919f7d04737aab53945" alt=""
import array
import pynopegl as ngl
@ngl.scene()
def geometry(cfg: ngl.SceneCfg):
cfg.aspect_ratio = (1, 1)
p0 = (cfg.rng.uniform(-1, 0), cfg.rng.uniform(0, 1), 0)
p1 = (cfg.rng.uniform(0, 1), cfg.rng.uniform(0, 1), 0)
p2 = (cfg.rng.uniform(-1, 0), cfg.rng.uniform(-1, 0), 0)
p3 = (cfg.rng.uniform(0, 1), cfg.rng.uniform(-1, 0), 0)
vertices = array.array("f", p0 + p1 + p2 + p3)
uvcoords = array.array("f", p0[:2] + p1[:2] + p2[:2] + p3[:2])
geometry = ngl.Geometry(
vertices=ngl.BufferVec3(data=vertices),
uvcoords=ngl.BufferVec2(data=uvcoords),
topology="triangle_strip",
)
return ngl.RenderColor(geometry=geometry)
data:image/s3,"s3://crabby-images/426e1/426e1a38569b22c6b62ab7095c3a60a07b9069b3" alt="graph"