RenderableShadowCylinder

Inherits Renderable

This Renderable displays the shadow cylinder behind a planetary body. Given the SPICE name of a planetary body and an observer, it will show a cylinder extending behind the body away from the observer to highlight the areas of space from which the observer is occluded by the body. A concrete example is using the Sun as the observer, in which case the shadow cylinder indicates the areas in which there is darkness.

Members

Name

Documentation

Type

Description

Optional

Aberration

The aberration method that is used for computing the shadow cylinder. The options are “NONE”, “LT” (Light Time), “LT + S” (Light Time Stellar), “CN” (Converged Newtonian), and “CN + S” (Converged Newtonian Stellar).

String

In list { NONE, LT, LT+S, CN, CN+S }

No

Body

The SPICE name of target body that is used as the shadow caster.

String

Value of type ‘String’

No

BodyFrame

The SPICE name of the reference frame in which the shadow cylinder is expressed.

String

Value of type ‘String’

No

LightSource

The SPICE name of the object that is used as the illuminator for computing the shadow cylinder.

String

Value of type ‘String’

No

Observer

The SPICE name of the object that is the observer.

String

Value of type ‘String’

No

TerminatorType

Determines the type of terminator to use for calculating the shadow eclipse.

String

In list { UMBRAL, PENUMBRAL }

No

NumberOfPoints

The number of control points used for constructing the shadow geometry. The higher this number, the more detailed the shadow is, but it will have a negative impact on the performance.

Integer

Value of type ‘Integer’

Yes

ShadowColor

The color used for the shadow cylinder.

Color3

Value of type ‘Color3’

Yes

ShadowLength

A factor that controls the length of the shadow that is cast by the target object. The total length of the shadow is equal to the distance from the target to the light source multiplied with this value.

Double

Value of type ‘Double’

Yes

Inherited members from Renderable

Name

Documentation

Type

Description

Optional

DimInAtmosphere

Decides if the object should be dimmed (i.e. faded out) when the camera is in the sunny part of an atmosphere.

Boolean

Value of type ‘Boolean’

Yes

Enabled

Determines whether this object will be visible or not.

Boolean

Value of type ‘Boolean’

Yes

Opacity

This value determines the opacity of this renderable. A value of 0 means completely transparent.

Double

In range: ( 0,1 )

Yes

RenderBinMode

A value that specifies if the renderable should be rendered in the Background, Opaque, Pre-/PostDeferredTransparency, Overlay, or Sticker rendering step.

String

In list { Background, Opaque, PreDeferredTransparent, Overlay, PostDeferredTransparent, Sticker }

Yes

Tag

A single tag or a list of tags that this renderable will respond to when setting properties.

Table, or String

Value of type ‘Table’, or Value of type ‘String’

Yes

Type

The type of the renderable.

String

Value of type ‘String’

Yes

Asset Examples

  1local transforms = asset.require("./transforms")
  2local sunTransforms = asset.require("scene/solarsystem/sun/transforms")
  3local kernels = asset.require("./kernels")
  4local coreKernels = asset.require("spice/core")
  5
  6
  7
  8local textures = asset.resource({
  9  Name = "Charon Textures",
 10  Type = "HttpSynchronization",
 11  Identifier = "charon_textures",
 12  Version = 3
 13})
 14
 15
 16local CharonRadius = 603500
 17
 18local CharonProjection = {
 19  Identifier = "CharonProjection",
 20  Parent = transforms.PlutoBarycenterAccurate.Identifier,
 21  Transform = {
 22    Translation = {
 23      Type = "SpiceTranslation",
 24      Target = kernels.ID.Charon,
 25      Observer = kernels.ID.PlutoBarycenter
 26    },
 27    Rotation = {
 28      Type = "SpiceRotation",
 29      SourceFrame = kernels.Frame.Charon,
 30      DestinationFrame = coreKernels.Frame.Galactic
 31    }
 32  },
 33  Renderable = {
 34    Type = "RenderablePlanetProjection",
 35    Radius = CharonRadius,
 36    Segments = 350,
 37    ColorTexturePaths = {
 38      textures .. "NH_Charon_mosaic.png",
 39      textures .. "NH_Charon_mosaic_8192.png"
 40    },
 41    HeightTexturePaths = {
 42      textures .. "NH_Charon_DTM.png",
 43      textures .. "NH_Charon_DTM_8192.png"
 44    },
 45    MeridianShift = true,
 46    Projection = {
 47      Observer = kernels.ID.NewHorizons,
 48      Target = kernels.ID.Charon,
 49      Aberration = "NONE",
 50      AspectRatio = 2,
 51      Instrument = {
 52        Name = kernels.Frame.Lorri,
 53        Method = "ELLIPSOID",
 54        Aberration = "NONE",
 55        Fovy = 0.2907,
 56        Aspect = 1,
 57        Near = 0.2,
 58        Far = 10000
 59      },
 60      PotentialTargets = {
 61        kernels.ID.Pluto,
 62        kernels.ID.Charon
 63      }
 64    }
 65  },
 66  GUI = {
 67    Path = "/Solar System/Dwarf Planets/Pluto",
 68    Name = "Charon Projection"
 69  }
 70}
 71
 72local CharonText = {
 73  Identifier = "CharonText",
 74  Parent = CharonProjection.Identifier,
 75  Transform = {
 76    Translation = {
 77      Type = "StaticTranslation",
 78      Position = { 0, -1000000.0, 0 }
 79    }
 80  },
 81  Renderable = {
 82    Type = "RenderablePlaneImageLocal",
 83    Size = 19952623.15,
 84    Origin = "Center",
 85    Billboard = true,
 86    Texture = textures .. "Charon-Text.png",
 87    BlendMode = "Additive"
 88  },
 89  GUI = {
 90    Name = "Charon Text",
 91    Path = "/Solar System/Dwarf Planets/Pluto",
 92    Focusable = false
 93  }
 94}
 95
 96local CharonShadow = {
 97  Identifier = "CharonShadow",
 98  Parent = CharonProjection.Identifier,
 99  Renderable = {
100    Type = "RenderableShadowCylinder",
101    Opacity = 0.25,
102    TerminatorType = "PENUMBRAL",
103    LightSource = coreKernels.ID.Sun,
104    Observer = kernels.ID.NewHorizons,
105    Body = kernels.ID.Charon,
106    BodyFrame = kernels.Frame.Charon,
107    Aberration = "NONE"
108  },
109  GUI = {
110    Name = "Charon Shadow",
111    Path = "/Solar System/Dwarf Planets/Pluto",
112    Focusable = false
113  }
114}
115
116
117asset.onInitialize(function()
118  openspace.addSceneGraphNode(CharonProjection)
119  openspace.addSceneGraphNode(CharonText)
120  openspace.addSceneGraphNode(CharonShadow)
121end)
122
123asset.onDeinitialize(function()
124  openspace.removeSceneGraphNode(CharonShadow)
125  openspace.removeSceneGraphNode(CharonText)
126  openspace.removeSceneGraphNode(CharonProjection)
127end)
128
129asset.export(CharonProjection)
130asset.export(CharonText)
131asset.export(CharonShadow)