SgLightsource
Represents a light-emitting object in the scene, such as a directional, point, or spot light. Affects how nearby objects are lit, casting shadows and influencing material appearance. Supports adjustable intensity, color, range, and falloff based on light type.
Inherits from
Usage
To use this class, add the following require at the top of your script:
Reference
create
Create a new lightsource object in the scenegraph.
Parameters
selfoptions(table): A table of options to fill the parametersparent(SceneObject): The parent scene object to add this to
Returns
Promise: promise which will resolve to the created object
Example
-- Options can be omitted. This example shows the defaults,
-- only specify the ones you want different.
SgLightsource.create({
active = true,
name = "",
transform = Transform.new(),
layers = {0},
tags = {},
castShadows = false,
type = SgLightsource.LightType.Point,
color = Color.new(255, 255, 255),
groundColor = Color.new(64, 64, 64),
intensity = 1,
distance = 100,
decay = 2,
angle = 0.5,
penumbra = 0,
shadowBias = 0,
shadowSize = SgLightsource.ShadowSize.x512
})
Properties
You can access these properties directly on the object or through :get("propertyName") or :set("propertyName", value) methods.
| Property | Type | Default | Description |
|---|---|---|---|
| active | Boolean | true | A Boolean attribute indicating whether the 3D object is active or not. When set to true, the object is considered active in the scene. |
| static | Boolean | false | A Boolean attribute indicating whether the 3D object is static or not. Static objects can and will never be transformed during runtime. |
| transform | Transform | Transform.new() | Specifies the transformation properties of the 3D object, including its position, rotation, and scale in the scene. |
| layers | Layers | [0] | Determines the layers the 3D object belongs to. Layers are used to organize objects in the scene for various purposes like rendering and interaction. |
| tags | Tags | [] | A list of tags associated with the 3D object. Tags are used for categorizing and identifying objects for scripting and scene management. |
| rendered | Boolean | true | Indicates if the 3D object is being rendered. |
| type | Enum | Point | Options: Point, Directional, Ambient, Hemisphere, Spot |
| color | Color | Color.new(255, 255, 255, 255) | |
| intensity | Float | 10 |
Enum: LightType
Enumeration of the available lightsource types
| Field Name | Description |
|---|---|
| Point | string: point light |
| Directional | string: directional light |
| Ambient | string: ambient light |
| Hemisphere | string: hemisphere light |
| Spot | string: spot light |
Enum: ShadowSize
Enumeration of the available shadow sizes
| Field Name | Description |
|---|---|
| x128 | string: 128 x 128 pixels |
| x256 | string: 256 x 256 pixels |
| x512 | string: 512 x 512 pixels |
| x1024 | string: 1024 x 1024 pixels |
| x2048 | string: 2048 x 2048 pixels |