chVisibleGeometry: Something visible in the geometry changed. See vcVisibleGeometry. This means that VisibleChangeHere with vcVisibleGeometry included should be called.
chVisibleNonGeometry: Something visible changed, but not geometry. See vcVisibleNonGeometry. This means that VisibleChangeHere with vcVisibleNonGeometry included should be called.
chCamera: Camera changed. See vcCamera. This means that VisibleChangeHere with vcCamera included should be called.
chRedisplay: Call VisibleChangeHere to redisplay the scene.
If you include one of the chVisibleGeometry, chVisibleNonGeometry, chCamera then this flag (chRedisplay) makes no effect. Otherwise, this flag should be used if your change requires redisplay of the 3D view for some other reasons.
chTransform: Transformation of children of this node changed.
Caller will analyze the scene (your children) to know what this implicates, don't include other flags with this.
chCoordinate: Coordinate (both VRML 1.0 and >= 2.0) node "point" field changed.
Caller will analyze the scene to know what this implicates, don't include other flags with this.
chVisibleVRML1State: Something visible in VRML 1.0 state node (that may be present in TX3DGraphTraverseState.LastNodes) changed, but not geometry. Excluding Coordinate node change (this one should go through chCoordinate only).
This is allowed, and ignored, on nodes that are not part of VRML 1.0 state. (This is useful for alphaChannel field, that is declared in TAbstractGeometryNode, and so is part of some VRML 1.0 state nodes but is also part of VRML >= 2.0 nodes.)
Caller will analyze the scene to know what this implicates, don't include other flags with this. Exception: you can (and should) include chUseBlending and chTextureImage for appropriate changes.
chGeometryVRML1State: Some visible geometry changed because of VRML 1.0 state node change. This is for VRML 1.0 state node changes, excluding non-geometry changes (these go to chVisibleVRML1State) and Coordinate changes (these go to chCoordinate).
Caller will analyze the scene to know what this implicates, don't include other flags with this.
chMaterial2: Something visible in VRML >= 2.0 Material (or TwoSidedMaterial) changed.
Caller will analyze the scene to know what this implicates, don't include other flags with this. Exception: you can (and should) include chUseBlending for appropriate Material changes.
chUseBlending: Something that may affect UseBlending calculation possibly changed. This is guaranteed to work only when used together with chVisibleVRML1State and chMaterial2. It's understood that only shapes that use given material need UseBlending recalculated.
chLightInstanceProperty: Light property that is also reflected in TLightInstance structure. Only allowed on node's descending from TAbstractLightNode.
Caller will analyze the scene to know what this implicates, don't include other flags with this. Exception: include also chLightLocationDirection when appropriate.
chLightLocationDirection: Light's location and/or direction changed.
Caller will analyze the scene to know what this implicates, don't include other flags with this. Exception: include also chLightInstanceProperty when appropriate.
Caller will analyze the scene to know what this implicates, don't include other flags with this. Exception: you can mix it with chVisibleVRML1State or chTextureRendererProperties.
chTextureRendererProperties: Texture properties used by the renderer changed (something other than only the texture data). This is for fields contained in X3DTextureNode.
Caller will analyze the scene to know what this implicates, don't include other flags with this. Exception: you can mix it with chTextureImage.
Caller will analyze the scene to know what this implicates, don't include other flags with this.
chShadowCasters: What is considered a shadow caster changed.
Caller will analyze the scene to know what this implicates, don't include other flags with this.
chGeneratedTextureUpdateNeeded: Mark the generated texture node (parent of this field) as requiring update (assuming it's "update" field value wants it too).
Caller will analyze the scene to know what this implicates, don't include other flags with this.
chFontStyle: VRML >= 2.0 FontStyle changed. Caller will analyze the scene to know what this implicates, don't include other flags with this.
chHeadLightOn: HeadLight on status changed. Caller will analyze the scene to know what this implicates, don't include other flags with this.
chClipPlane: Clip plane visible change (enabled or plane equation).
chDragSensorEnabled: Enabled field of the pointing-device drag sensor changed. Use only for TSFBool fields within TAbstractDragSensorNode.
chBackground: X3DBackgroundNode properties that are stored inside TBackground display list have changed.
chEverything: Everything changed and needs to be recalculated. This is needed for changes on stuff internally cached in TCastleSceneCore, TCastleScene, TShape that cannot be expressed as one of above flags.
Use only as a last resort, as this is very costly! (And in an ideal implementation, should not be needed.)
Don't include other flags with this.
chShadowMaps: Higher-level shadow maps fields changed. They have to be processed to lower-level fields by calling TCastleSceneCore.ProcessShadowMapsReceivers.