Node Reference
Last modified: 17 December 2024Add Geometry
The Add Geometry node is used to add input geometry to the geometry collection. The Procedural Geometry input is evaluated before the Geometry input is added. Unique indicates that input geometry is added to a different object in the collection and includes a transform matrix.If a name is not provided here the bin's name will be the same as the input geometry.
Weld will collapse the input geometry into one object and remove duplicate vertices.
Add Instance
The Add Instance node is used to add input geometry to the Instance collection. This is intended to be with input scene objects. No geometry is made, It uses the target ItemID from the From Mesh node as the geometry input. Instancing the ProGeo object itself requires the Instance generator in Object Properties.Boolean CSG
The CSG node is used for creating Constructive Solid Geometry using mesh booleans. This is a non-destructive process. You can choose Union, which unifies geometry; Intersection, which purely shows the overlapping parts of the two objects used; or Subtraction, which takes the second object from the first. Objects need to be solid 3D shapes with no holes.Branch
New to 2024, the Branch Geometry node can be used to make all sorts of branches - from flowers and trees to lightning. The Position tab is for setting the initial disposition of your branch in a line between Position 1 and Position 2, with envelopes for animating those values over time. While the node has a vector input for Noise, you can also purely use the Branching tab. You have control over how many splits there will be, when they will take place, etc. The Mesh tab is for deciding whether your branch will use geometry or rely on edge rendering effects.
Cache Geometry
You can save Procedural Geometry objects by adding a cache path into the node flow. If an object is particularly complex to make, or going to be rendered across multiple machines, using a cache is a good idea.Options
Combine Geometry
This unprepossessing node just has a Geometry input and a Result output. If you double-click the node, you just get a field for naming. As soon as you hook something to the input node, you'll notice you get a new Geometry_1 input. Hook something to that and you'll get another. This node will merely put separate objects into a single one for downstream calculation. There is no Boolean math, they are just stuck together.Data Geometry
The Data node is used for getting mesh data such as point locations, polygon counts, center points and normals from a mesh object.Evaluate Geometry
This node can stop the For Loop operation if the result is not >0 (true).Extrude Geometry
The Extrude node is used for extruding (keeping the original polygon) or beveling (removing the original polygon). Both can have an inset value and be driven by envelopes and textures. If you use the Select Polygons node upstream, you can specify exactly which polygons get extruded.Options
- Inset
The distance to bring newly-extruded polygons from the bounds of the original polygon being extruded. Can be animated and textured
- Keep Selection
Checkbox to keep the polygons selected with the Select Polygon node further downstream in node connections
- New Surface
Dropdown with four choices:
New Polygons - Only polygons created with the extrude will get new surfacing. Essentially, the sides of the extrude
Original Polygons - Resurfaces the original polygons from which the extrusion was made. Essentially the top of the extrude
Both - Surfaces original and extruded polygons the same way
None - Has no impact on surfaces
Filter Geometry
The Filter Geometry node is for selecting specific details you wish to use elsewhere. Procedural Geometry goes in and you can choose what comes out. Double-clicking on the node reveals a dropdown menu of network shapes, but there's a text entry in case the item you want is not on the list. The first output, Result, is used with the corresponding Geometry Filter input on the Info Geometry node. The Item Count output outputs the integer count of how many things have been filtered.For Loop
The For Loop node is used for repeating an operation between the start and end values. For Loop can evaluate the input geometry multiple times with the Add Geometry transform position, rotation and scale. The loop can evaluate the Add Geometry and Add Instance nodes.From Mesh
The From Mesh node will take existing mesh-based objects and use them in a Procedural Geometry context. Objects can be transformed or have additional options like MDD point caches or being categorised as Static. New to 2024, the dropdown menu now contains a Load Mesh entry.
Geometry VDB
This node converts Procedural Geometry objects into VDB objects. The output node for this node requires nodes from the OpenVDB group to continue operations before using the VDB Geometry node to continue as Procedural Geometry geometry.
You can control over Voxel Size (basically the resolution of the object) and Inner and Outer Bandwidths for objects that might not have a consistent amount of detail.
Grid Geometry
Makes a regular grid of x by y cells. You can choose to make the grid visible by using Make Polygons or just have it as a non-rendering base for other objects - instances on the grid points as an example.Options
Hyper Paint
There are two outputs for this node, Result and Stroke Count. Stroke Count should go to the End input on the For Loop node and Result goes to the Geometry Filter input on the Info Geometry node.
tip
If you turn off keyframes, your stroke will be immediately visible. If you use keyframes you might need to jog the current frame for an update
Info Geometry
The Info Geometry node is most often paired with the Filter Geometry and Data Geometry nodes to extract information about the points, polygons and other details about the geometry it's attached to. Its Geometry Filter input can either be the Filter node's output or directly from Primitive Geometry or Add Geometry node outputs. The Collapse option available on double-clicking the node will output a single mesh, rather than separated components.
L-System
Introduction
L-systems or Lindenmayer systems - named after Hungarian scientist Aristid Lindenmeyer - are parallel (the four lines of rules are run at the same time) rewriting systems. An L-system consists of an alphabet of symbols called Tokens. There are rules to expand each Token into a larger string of symbols, a Seed string that starts construction, and a mechanism for translating the generated strings into geometric structures that can either be solid geometry or lines shown at render time using edges. If you are familiar with Turtle graphics from school L-Systems should feel similar. With the default when you add the L-Systems node, just try the iterations setting to see how the rules work.Presets
There are several example presets for you to pick apart in the Preset dropdown at the top of the window. There is also a button to add your own. The Seed value is used to start building and four lines of "code" that will be run in parallel to create the L-System. Next is a button to show the complete Token List, which you can refer to while creating your own rules. Many L-Systems are available online and are easily translatable to LightWave's token format.Other settings
In the lower half of the window, there are three tabs:Lathe
The Lathe node spins geometry around a chosen axis. You can decide how many turns to make, an offset and whether to close the ends. Lathed geometry can have a distinct surface.
Lerp Vector
The Lerp node linearly interpolates between vector1 and vector2 by the delta <0,1>.Line Geometry
Using three nulls you can create procedural lines in Layout. The first null, call it Nodes, is used for the nodes to create the line, the other two nulls are base and target. Add the Procedural Geometry modifier to the Nodes null and use Item Info nodes with the Line Geometry node to create the procedural line. This line will be rendered using the Object Properties > Edge settings. Remember, a positive number here indicates a line measured in screen pixels (no matter how near or far it is); a negative number indicates a real-world size. The Subdivide Integer input can be used to deform the line using Nodal Displacement in Object Properties.Point Geometry
The Point node outputs points using an expanding list of input points. When you add an input another input will appear.Poly Geometry
The Poly node outputs polygons of several different types.Options
Primitive Geometry
The Primitive node outputs cubes, cylinders or spheres. You can dictate the number of sides for Cylinders or division level for spheres.Options
Scatter Points
The Scatter Points node outputs points or single-point polygons offset from the input mesh surface.Select Polygons
When you don't want to affect an object completely - just some of its polys - this is the node for you.Options
Set Position
Set position is used to modify the position of Mesh or Spline geometry in a Procedural Geometry context. The Position Vector input could be supplied by a texture or some other mechanism and the UVBlend scalar input is best fed with a gradient (because they have a built-in UV component).
Spline Geometry
When you double-click on the Spline Geometry node, you will have a choice between Spline and Polyline geometry.
Spline Options
A spline here is a curved line. It has handles at either end to control the tangent. Additional knots can be placed by right-clicking on a knot.
Polyline Options
A polyline is a set of straight edges, much as though you are creating this polygonally. Again, additional knots can be placed by right-clicking a knot
Shared Controls
- Rotate
Rotate the items you are using along the spline about the spline. Using Y Up ghosts this option
- Output
A dropdown with four styles of spline or Polyline to choose from:
Points - Converts the user-created knots and Segments into points
Skin -The main option and the reason for the radius setting.
Knots - Uses the user-created knots and automatic tangential knots
Line Chain - Converts the Polyline into a chain of 2-point polygons
Gizmo
The Spline node features a gizmo with transforms. and an edit menu.Menu
The gizmo has a right click menu.Rotate and scale
The gizmo has rotation and scaling handles per knot.Visualization
The gizmo has a visualization showing the changing transforms at each segment along the path.Transform Path
The Transform Item node can move an item along a spline path. In this example, the spline path has a multi-polygon profile extrusion.Spline Info
This node is used for downstream access to the Spline Geometry node. The input nodes are Spline, which is always only ever fed by the Spline Info output from the Spline Geometry node and Delta, which is used for the value of the distance from the start of the loop <0,1>. The node will output Position, Forward, Tangent, Normal, Rotation and Radius at the given distance from the start of the spline. Radius is the interpolated radius values along the length. Length refers to the distance between points and Count is the current iteration.Thicken
Thicken makes a shell offset of your mesh with few controls. The offset determines how thick the wall will be and you can offset outwards with a positive value or inward with a negative value; this can be enveloped. The New Surface choice is the same as with Extrude Geometry.
Transform Item
Used to transform (change position, rotation or scale) an item in a Procedural Geometry network.
VDB Geometry
Converts from an OpenVDB SDF to Procedural Geometry geometry. You can give the resulting object a new name if desired.