Scene

new Cesium.Scene(options)

The container for all 3D graphical objects and state in a Cesium virtual scene. Generally, a scene is not created directly; instead, it is implicitly created by CesiumWidget.
参数名称 类型 描述信息
options object Object with the following properties:
参数名称 类型 默认值 描述信息
canvas HTMLCanvasElement The HTML canvas element to create the scene for.
contextOptions ContextOptions 可选 Context and WebGL creation properties.
creditContainer Element 可选 The HTML element in which the credits will be displayed.
creditViewport Element 可选 The HTML element in which to display the credit popup. If not specified, the viewport will be a added as a sibling of the canvas.
ellipsoid Ellipsoid Ellipsoid.default 可选 The default ellipsoid. If not specified, the default ellipsoid is used.
mapProjection MapProjection new GeographicProjection(options.ellipsoid) 可选 The map projection to use in 2D and Columbus View modes.
orderIndependentTranslucency boolean true 可选 If true and the configuration supports it, use order independent translucency.
scene3DOnly boolean false 可选 If true, optimizes memory use and performance for 3D mode but disables the ability to use 2D or Columbus View.
shadows boolean false 可选 Determines if shadows are cast by light sources.
mapMode2D MapMode2D MapMode2D.INFINITE_SCROLL 可选 Determines if the 2D map is rotatable or can be scrolled infinitely in the horizontal direction.
requestRenderMode boolean false 可选 If true, rendering a frame will only occur when needed as determined by changes within the scene. Enabling improves performance of the application, but requires using Scene#requestRender to render a new frame explicitly in this mode. This will be necessary in many cases after making changes to the scene in other parts of the API. See Improving Performance with Explicit Rendering.
maximumRenderTimeChange number 0.0 可选 If requestRenderMode is true, this value defines the maximum change in simulation time allowed before a render is requested. See Improving Performance with Explicit Rendering.
depthPlaneEllipsoidOffset number 0.0 可选 Adjust the DepthPlane to address rendering artefacts below ellipsoid zero elevation.
msaaSamples number 4 可选 If provided, this value controls the rate of multisample antialiasing. Typical multisampling rates are 2, 4, and sometimes 8 samples per pixel. Higher sampling rates of MSAA may impact performance in exchange for improved visual quality. This value only applies to WebGL2 contexts that support multisample render targets. Set to 1 to disable MSAA.
Throws:
使用示例:
// Create scene without anisotropic texture filtering
const scene = new Cesium.Scene({
  canvas : canvas,
  contextOptions : {
    allowTextureFilterAnisotropic : false
  }
});
参考:

成员(属性)

static Cesium.Scene.defaultLogDepthBuffer

Use this to set the default value for Scene#logarithmicDepthBuffer in newly constructed Scenes This property relies on fragmentDepth being supported.
Settings for atmosphere lighting effects affecting 3D Tiles and model rendering. This is not to be confused with Scene#skyAtmosphere which is responsible for rendering the sky.
The background color, which is only visible if there is no sky box, i.e., Scene#skyBox is undefined.
默认值: Color.BLACK
参考:
Gets or sets the camera.

readonly cameraUnderground : boolean

Whether or not the camera is underneath the globe.
默认值: false

readonly canvas : HTMLCanvasElement

Gets the canvas element to which this scene is bound.

readonly clampToHeightSupported : boolean

Returns true if the Scene#clampToHeight and Scene#clampToHeightMostDetailed functions are supported.
参考:

completeMorphOnUserInput : boolean

Determines whether or not to instantly complete the scene transition animation on user input.
默认值: true

debugCommandFilter : function

This property is for debugging only; it is not for production use.

A function that determines what commands are executed. As shown in the examples below, the function receives the command's owner as an argument, and returns a boolean indicating if the command should be executed.

The default is undefined, indicating that all commands are executed.

默认值: undefined
使用示例:
// Do not execute any commands.
scene.debugCommandFilter = function(command) {
    return false;
};

// Execute only the billboard's commands.  That is, only draw the billboard.
const billboards = new Cesium.BillboardCollection();
scene.debugCommandFilter = function(command) {
    return command.owner === billboards;
};

readonly debugFrustumStatistics : object

This property is for debugging only; it is not for production use.

When Scene.debugShowFrustums is true, this contains properties with statistics about the number of command execute per frustum. totalCommands is the total number of commands executed, ignoring overlap. commandsInFrustums is an array with the number of times commands are executed redundantly, e.g., how many commands overlap two or three frustums.

默认值: undefined

debugShowCommands : boolean

This property is for debugging only; it is not for production use.

When true, commands are randomly shaded. This is useful for performance analysis to see what parts of a scene or model are command-dense and could benefit from batching.

默认值: false

debugShowDepthFrustum : number

This property is for debugging only; it is not for production use.

Indicates which frustum will have depth information displayed.

默认值: 1

debugShowFramesPerSecond : boolean

This property is for debugging only; it is not for production use.

Displays frames per second and time between frames.

默认值: false

debugShowFrustumPlanes : boolean

This property is for debugging only; it is not for production use.

When true, draws outlines to show the boundaries of the camera frustums

默认值: false

debugShowFrustums : boolean

This property is for debugging only; it is not for production use.

When true, commands are shaded based on the frustums they overlap. Commands in the closest frustum are tinted red, commands in the next closest are green, and commands in the farthest frustum are blue. If a command overlaps more than one frustum, the color components are combined, e.g., a command overlapping the first two frustums is tinted yellow.

默认值: false

readonly drawingBufferHeight : number

The drawingBufferHeight of the underlying GL context.
参考:

readonly drawingBufferWidth : number

The drawingBufferWidth of the underlying GL context.
参考:
The ellipsoid. If not specified, the default ellipsoid is used.

eyeSeparation : number

The eye separation distance in meters for use with cardboard or WebVR.

farToNearRatio : number

The far-to-near ratio of the multi-frustum when using a normal depth buffer.

This value is used to create the near and far values for each frustum of the multi-frustum. It is only used when Scene#logarithmicDepthBuffer is false. When logarithmicDepthBuffer is true, use Scene#logarithmicDepthFarToNearRatio.

默认值: 1000.0

focalLength : number

The focal length for use when with cardboard or WebVR.
Blends the atmosphere to geometry far from the camera for horizon views. Allows for additional performance improvements by rendering less geometry and dispatching less terrain requests. Disbaled by default if an ellipsoid other than WGS84 is used.
The value used for gamma correction. This is only used when rendering with high dynamic range.
默认值: 2.2
Gets or sets the depth-test ellipsoid.
Gets the collection of ground primitives.

highDynamicRange : boolean

Whether or not to use high dynamic range rendering.
默认值: false

readonly highDynamicRangeSupported : boolean

Whether or not high dynamic range rendering is supported.
默认值: true

readonly id : string

Gets the unique identifier for this scene.
Gets the collection of image layers that will be rendered on the globe.

invertClassification : boolean

When false, 3D Tiles will render normally. When true, classified 3D Tile geometry will render normally and unclassified 3D Tile geometry will render with the color multiplied by Scene#invertClassificationColor.
默认值: false

invertClassificationColor : Color

The highlight color of unclassified 3D Tile geometry when Scene#invertClassification is true.

When the color's alpha is less than 1.0, the unclassified portions of the 3D Tiles will not blend correctly with the classified positions of the 3D Tiles.

Also, when the color's alpha is less than 1.0, the WEBGL_depth_texture and EXT_frag_depth WebGL extensions must be supported.

默认值: Color.WHITE

readonly invertClassificationSupported : boolean

Returns true if the Scene#invertClassification is supported.
参考:

readonly lastRenderTime : JulianDate

Gets the simulation time when the scene was last rendered. Returns undefined if the scene has not yet been rendered.
The light source for shading. Defaults to a directional light from the Sun.

logarithmicDepthBuffer : boolean

Whether or not to use a logarithmic depth buffer. Enabling this option will allow for less frustums in the multi-frustum, increasing performance. This property relies on fragmentDepth being supported.

logarithmicDepthFarToNearRatio : number

The far-to-near ratio of the multi-frustum when using a logarithmic depth buffer.

This value is used to create the near and far values for each frustum of the multi-frustum. It is only used when Scene#logarithmicDepthBuffer is true. When logarithmicDepthBuffer is false, use Scene#farToNearRatio.

默认值: 1e9
Determines if the 2D map is rotatable or can be scrolled infinitely in the horizontal direction.
Get the map projection to use in 2D and Columbus View modes.
默认值: new GeographicProjection()

readonly maximumAliasedLineWidth : number

The maximum aliased line width, in pixels, supported by this WebGL implementation. It will be at least one.
参考:
  • glGet with ALIASED_LINE_WIDTH_RANGE.

readonly maximumCubeMapSize : number

The maximum length in pixels of one edge of a cube map, supported by this WebGL implementation. It will be at least 16.
参考:
  • glGet with GL_MAX_CUBE_MAP_TEXTURE_SIZE.

maximumRenderTimeChange : number

If Scene#requestRenderMode is true, this value defines the maximum change in simulation time allowed before a render is requested. Lower values increase the number of frames rendered and higher values decrease the number of frames rendered. If undefined, changes to the simulation time will never request a render. This value impacts the rate of rendering for changes in the scene like lighting, entity property updates, and animations.
默认值: 0.0
参考:

minimumDisableDepthTestDistance : number

The distance from the camera at which to disable the depth test of billboards, labels and points to, for example, prevent clipping against terrain. When set to zero, the depth test should always be applied. When less than zero, the depth test should never be applied. Setting the disableDepthTestDistance property of a billboard, label or point will override this value.
默认值: 0.0
Gets or sets the current mode of the scene.
默认值: SceneMode.SCENE3D
The Moon
默认值: undefined
The event fired at the completion of a scene transition.
默认值: Event()
The event fired at the beginning of a scene transition.
默认值: Event()
The current morph transition time between 2D/Columbus View and 3D, with 0.0 being 2D or Columbus View and 1.0 being 3D.
默认值: 1.0

msaaSamples : number

The sample rate of multisample antialiasing (values greater than 1 enable MSAA).
默认值: 4

readonly msaaSupported : boolean

Returns true if the Scene's context supports MSAA.

nearToFarDistance2D : number

Determines the uniform depth size in meters of each frustum of the multifrustum in 2D. If a primitive or model close to the surface shows z-fighting, decreasing this will eliminate the artifact, but decrease performance. On the other hand, increasing this will increase performance but may cause z-fighting among primitives close to the surface.
默认值: 1.75e6

readonly orderIndependentTranslucency : boolean

Gets whether or not the scene has order independent translucency enabled. Note that this only reflects the original construction option, and there are other factors that could prevent OIT from functioning on a given system configuration.

readonly pickPositionSupported : boolean

Returns true if the Scene#pickPosition function is supported.
参考:

pickTranslucentDepth : boolean

When true, enables picking translucent geometry using the depth buffer. Note that Scene#useDepthPicking must also be true for enabling this to work.

There is a decrease in performance when enabled. There are extra draw calls to write depth for translucent geometry.

默认值: false
使用示例:
// picking the position of a translucent primitive
viewer.screenSpaceEventHandler.setInputAction(function onLeftClick(movement) {
     const pickedFeature = viewer.scene.pick(movement.position);
     if (!Cesium.defined(pickedFeature)) {
         // nothing picked
         return;
     }
     const worldPosition = viewer.scene.pickPosition(movement.position);
}, Cesium.ScreenSpaceEventType.LEFT_CLICK);
Post processing effects applied to the final render.
Gets the event that will be raised immediately after the scene is rendered. Subscribers to the event receive the Scene instance as the first parameter and the current time as the second parameter.
参考:
Gets the event that will be raised immediately after the scene is updated and before the scene is rendered. Subscribers to the event receive the Scene instance as the first parameter and the current time as the second parameter.
参考:
Gets the event that will be raised after the scene is updated and immediately before the scene is rendered. Subscribers to the event receive the Scene instance as the first parameter and the current time as the second parameter.
参考:
Gets the event that will be raised before the scene is updated or rendered. Subscribers to the event receive the Scene instance as the first parameter and the current time as the second parameter.
参考:
Gets the collection of primitives.

readonly renderError : Event

Gets the event that will be raised when an error is thrown inside the render function. The Scene instance and the thrown error are the only two parameters passed to the event handler. By default, errors are not rethrown after this event is raised, but that can be changed by setting the rethrowRenderErrors property.

requestRenderMode : boolean

When true, rendering a frame will only occur when needed as determined by changes within the scene. Enabling improves performance of the application, but requires using Scene#requestRender to render a new frame explicitly in this mode. This will be necessary in many cases after making changes to the scene in other parts of the API.
默认值: false
参考:

rethrowRenderErrors : boolean

Exceptions occurring in render are always caught in order to raise the renderError event. If this property is true, the error is rethrown after the event is raised. If this property is false, the render function returns normally after raising the event.
默认值: false

readonly sampleHeightSupported : boolean

Returns true if the Scene#sampleHeight and Scene#sampleHeightMostDetailed functions are supported.
参考:

readonly scene3DOnly : boolean

Gets whether or not the scene is optimized for 3D only viewing.

readonly screenSpaceCameraController : ScreenSpaceCameraController

Gets the controller for camera input handling.
The shadow map for the scene's light source. When enabled, models, primitives, and the globe may cast and receive shadows.
The sky atmosphere drawn around the globe.
默认值: undefined
The SkyBox used to draw the stars.
默认值: undefined
参考:

specularEnvironmentMaps : string

The url to the KTX2 file containing the specular environment map and convoluted mipmaps for image-based lighting of PBR models.

readonly specularEnvironmentMapsSupported : boolean

Returns true if specular environment maps are supported.
参考:

sphericalHarmonicCoefficients : Array.<Cartesian3>

The spherical harmonic coefficients for image-based lighting of PBR models.

splitPosition : number

Gets or sets the position of the splitter within the viewport. Valid values are between 0.0 and 1.0.
The Sun.
默认值: undefined
Uses a bloom filter on the sun when enabled.
默认值: true
The terrain provider providing surface geometry for the globe.

readonly terrainProviderChanged : Event

Gets an event that's raised when the terrain provider is changed

useDepthPicking : boolean

When true, enables picking using the depth buffer.
默认值: true
When true, splits the scene into two viewports with steroscopic views for the left and right eyes. Used for cardboard and WebVR.
默认值: false

verticalExaggeration : number

The vertical exaggeration of the scene. When set to 1.0, no exaggeration is applied.
默认值: 1.0

verticalExaggerationRelativeHeight : number

The reference height for vertical exaggeration of the scene. When set to 0.0, the exaggeration is applied relative to the ellipsoid surface.
默认值: 0.0

方法

cartesianToCanvasCoordinates(position, result)Cartesian2

Transforms a position in cartesian coordinates to canvas coordinates. This is commonly used to place an HTML element at the same screen position as an object in the scene.
参数名称 类型 描述信息
position Cartesian3 The position in cartesian coordinates.
result Cartesian2 可选 An optional object to return the input position transformed to canvas coordinates.
返回值:
The modified result parameter or a new Cartesian2 instance if one was not provided. This may be undefined if the input position is near the center of the ellipsoid.
使用示例:
// Output the canvas position of longitude/latitude (0, 0) every time the mouse moves.
const scene = widget.scene;
const position = Cesium.Cartesian3.fromDegrees(0.0, 0.0);
const handler = new Cesium.ScreenSpaceEventHandler(scene.canvas);
handler.setInputAction(function(movement) {
    console.log(scene.cartesianToCanvasCoordinates(position));
}, Cesium.ScreenSpaceEventType.MOUSE_MOVE);

clampToHeight(cartesian, objectsToExclude, width, result)Cartesian3

Clamps the given cartesian position to the scene geometry along the geodetic surface normal. Returns the clamped position or undefined if there was no scene geometry to clamp to. May be used to clamp objects to the globe, 3D Tiles, or primitives in the scene.

This function only clamps to globe tiles and 3D Tiles that are rendered in the current view. Clamps to all other primitives regardless of their visibility.

参数名称 类型 默认值 描述信息
cartesian Cartesian3 The cartesian position.
objectsToExclude Array.<Object> 可选 A list of primitives, entities, or 3D Tiles features to not clamp to.
width number 0.1 可选 Width of the intersection volume in meters.
result Cartesian3 可选 An optional object to return the clamped position.
返回值:
The modified result parameter or a new Cartesian3 instance if one was not provided. This may be undefined if there was no scene geometry to clamp to.
Throws:
  • DeveloperError : clampToHeight is only supported in 3D mode.
  • DeveloperError : clampToHeight requires depth texture support. Check clampToHeightSupported.
使用示例:
// Clamp an entity to the underlying scene geometry
const position = entity.position.getValue(Cesium.JulianDate.now());
entity.position = viewer.scene.clampToHeight(position);
参考:

clampToHeightMostDetailed(cartesians, objectsToExclude, width)Promise.<Array.<Cartesian3>>

Initiates an asynchronous Scene#clampToHeight query for an array of Cartesian3 positions using the maximum level of detail for 3D Tilesets in the scene. Returns a promise that is resolved when the query completes. Each position is modified in place. If a position cannot be clamped because no geometry can be sampled at that location, or another error occurs, the element in the array is set to undefined.
参数名称 类型 默认值 描述信息
cartesians Array.<Cartesian3> The cartesian positions to update with clamped positions.
objectsToExclude Array.<Object> 可选 A list of primitives, entities, or 3D Tiles features to not clamp to.
width number 0.1 可选 Width of the intersection volume in meters.
返回值:
A promise that resolves to the provided list of positions when the query has completed.
Throws:
  • DeveloperError : clampToHeightMostDetailed is only supported in 3D mode.
  • DeveloperError : clampToHeightMostDetailed requires depth texture support. Check clampToHeightSupported.
使用示例:
const cartesians = [
    entities[0].position.getValue(Cesium.JulianDate.now()),
    entities[1].position.getValue(Cesium.JulianDate.now())
];
const promise = viewer.scene.clampToHeightMostDetailed(cartesians);
promise.then(function(updatedCartesians) {
    entities[0].position = updatedCartesians[0];
    entities[1].position = updatedCartesians[1];
}
参考:
Instantly completes an active transition.
Destroys the WebGL resources held by this object. Destroying an object allows for deterministic release of WebGL resources, instead of relying on the garbage collector to destroy this object.

Once an object is destroyed, it should not be used; calling any function other than isDestroyed will result in a DeveloperError exception. Therefore, assign the return value (undefined) to the object as done in the example.
Throws:
  • DeveloperError : This object was destroyed, i.e., destroy() was called.
使用示例:
scene = scene && scene.destroy();
参考:

drillPick(windowPosition, limit, width, height)Array.<any>

Returns a list of objects, each containing a `primitive` property, for all primitives at a particular window coordinate position. Other properties may also be set depending on the type of primitive and may be used to further identify the picked object. The primitives in the list are ordered by their visual order in the scene (front to back).
参数名称 类型 默认值 描述信息
windowPosition Cartesian2 Window coordinates to perform picking on.
limit number 可选 If supplied, stop drilling after collecting this many picks.
width number 3 可选 Width of the pick rectangle.
height number 3 可选 Height of the pick rectangle.
返回值:
Array of objects, each containing 1 picked primitives.
Throws:
使用示例:
const pickedObjects = scene.drillPick(new Cesium.Cartesian2(100.0, 200.0));
参考:

getCompressedTextureFormatSupported(format)boolean

Determines if a compressed texture format is supported.
参数名称 类型 描述信息
format string The texture format. May be the name of the format or the WebGL extension name, e.g. s3tc or WEBGL_compressed_texture_s3tc.
返回值:
Whether or not the format is supported.

isDestroyed()boolean

Returns true if this object was destroyed; otherwise, false.

If this object was destroyed, it should not be used; calling any function other than isDestroyed will result in a DeveloperError exception.
返回值:
true if this object was destroyed; otherwise, false.
参考:

morphTo2D(duration)

Asynchronously transitions the scene to 2D.
参数名称 类型 默认值 描述信息
duration number 2.0 可选 The amount of time, in seconds, for transition animations to complete.

morphTo3D(duration)

Asynchronously transitions the scene to 3D.
参数名称 类型 默认值 描述信息
duration number 2.0 可选 The amount of time, in seconds, for transition animations to complete.

morphToColumbusView(duration)

Asynchronously transitions the scene to Columbus View.
参数名称 类型 默认值 描述信息
duration number 2.0 可选 The amount of time, in seconds, for transition animations to complete.

pick(windowPosition, width, height)object

Returns an object with a `primitive` property that contains the first (top) primitive in the scene at a particular window coordinate or undefined if nothing is at the location. Other properties may potentially be set depending on the type of primitive and may be used to further identify the picked object.

When a feature of a 3D Tiles tileset is picked, pick returns a Cesium3DTileFeature object.

参数名称 类型 默认值 描述信息
windowPosition Cartesian2 Window coordinates to perform picking on.
width number 3 可选 Width of the pick rectangle.
height number 3 可选 Height of the pick rectangle.
返回值:
Object containing the picked primitive.
使用示例:
// On mouse over, color the feature yellow.
handler.setInputAction(function(movement) {
    const feature = scene.pick(movement.endPosition);
    if (feature instanceof Cesium.Cesium3DTileFeature) {
        feature.color = Cesium.Color.YELLOW;
    }
}, Cesium.ScreenSpaceEventType.MOUSE_MOVE);

pickMetadata(windowPosition, schemaId, className, propertyName)

Pick a metadata value at the given window position.
参数名称 类型 描述信息
windowPosition Cartesian2 Window coordinates to perform picking on.
schemaId string | undefined The ID of the metadata schema to pick values from. If this is `undefined`, then it will pick the values from the object that match the given class- and property name, regardless of the schema ID.
className string The name of the metadata class to pick values from
propertyName string The name of the metadata property to pick values from
返回值:
The metadata value
Experimental

This feature is not final and is subject to change without Cesium's standard deprecation policy.

pickMetadataSchema(windowPosition)MetadataSchema

Pick the schema of the metadata of the object at the given position
参数名称 类型 描述信息
windowPosition Cartesian2 Window coordinates to perform picking on.
返回值:
The metadata schema, or `undefined` if there is no object with associated metadata at the given position.
Experimental

This feature is not final and is subject to change without Cesium's standard deprecation policy.

pickPosition(windowPosition, result)Cartesian3

Returns the cartesian position reconstructed from the depth buffer and window position.

The position reconstructed from the depth buffer in 2D may be slightly different from those reconstructed in 3D and Columbus view. This is caused by the difference in the distribution of depth values of perspective and orthographic projection.

Set Scene#pickTranslucentDepth to true to include the depth of translucent primitives; otherwise, this essentially picks through translucent primitives.

参数名称 类型 描述信息
windowPosition Cartesian2 Window coordinates to perform picking on.
result Cartesian3 可选 The object on which to restore the result.
返回值:
The cartesian position.
Throws:
  • DeveloperError : Picking from the depth buffer is not supported. Check pickPositionSupported.

pickVoxel(windowPosition, width, height)VoxelCell|undefined

Returns a VoxelCell for the voxel sample rendered at a particular window coordinate, or undefined if no voxel is rendered at that position.
参数名称 类型 默认值 描述信息
windowPosition Cartesian2 Window coordinates to perform picking on.
width number 3 可选 Width of the pick rectangle.
height number 3 可选 Height of the pick rectangle.
返回值:
Information about the voxel cell rendered at the picked position.
使用示例:
On left click, report the value of the "color" property at that voxel sample.
handler.setInputAction(function(movement) {
  const voxelCell = scene.pickVoxel(movement.position);
  if (defined(voxelCell)) {
    console.log(voxelCell.getProperty("color"));
  }
}, Cesium.ScreenSpaceEventType.LEFT_CLICK);
Experimental

This feature is not final and is subject to change without Cesium's standard deprecation policy.

Update and render the scene. It is usually not necessary to call this function directly because CesiumWidget will do it automatically.
参数名称 类型 描述信息
time JulianDate 可选 The simulation time at which to render.
Requests a new rendered frame when Scene#requestRenderMode is set to true. The render rate will not exceed the CesiumWidget#targetFrameRate.
参考:

sampleHeight(position, objectsToExclude, width)number

Returns the height of scene geometry at the given cartographic position or undefined if there was no scene geometry to sample height from. The height of the input position is ignored. May be used to clamp objects to the globe, 3D Tiles, or primitives in the scene.

This function only samples height from globe tiles and 3D Tiles that are rendered in the current view. Samples height from all other primitives regardless of their visibility.

参数名称 类型 默认值 描述信息
position Cartographic The cartographic position to sample height from.
objectsToExclude Array.<Object> 可选 A list of primitives, entities, or 3D Tiles features to not sample height from.
width number 0.1 可选 Width of the intersection volume in meters.
返回值:
The height. This may be undefined if there was no scene geometry to sample height from.
Throws:
  • DeveloperError : sampleHeight is only supported in 3D mode.
  • DeveloperError : sampleHeight requires depth texture support. Check sampleHeightSupported.
使用示例:
const position = new Cesium.Cartographic(-1.31968, 0.698874);
const height = viewer.scene.sampleHeight(position);
console.log(height);
参考:

sampleHeightMostDetailed(positions, objectsToExclude, width)Promise.<Array.<Cartographic>>

Initiates an asynchronous Scene#sampleHeight query for an array of Cartographic positions using the maximum level of detail for 3D Tilesets in the scene. The height of the input positions is ignored. Returns a promise that is resolved when the query completes. Each point height is modified in place. If a height cannot be determined because no geometry can be sampled at that location, or another error occurs, the height is set to undefined.
参数名称 类型 默认值 描述信息
positions Array.<Cartographic> The cartographic positions to update with sampled heights.
objectsToExclude Array.<Object> 可选 A list of primitives, entities, or 3D Tiles features to not sample height from.
width number 0.1 可选 Width of the intersection volume in meters.
返回值:
A promise that resolves to the provided list of positions when the query has completed.
Throws:
  • DeveloperError : sampleHeightMostDetailed is only supported in 3D mode.
  • DeveloperError : sampleHeightMostDetailed requires depth texture support. Check sampleHeightSupported.
使用示例:
const positions = [
    new Cesium.Cartographic(-1.31968, 0.69887),
    new Cesium.Cartographic(-1.10489, 0.83923)
];
const promise = viewer.scene.sampleHeightMostDetailed(positions);
promise.then(function(updatedPosition) {
    // positions[0].height and positions[1].height have been updated.
    // updatedPositions is just a reference to positions.
}
参考:

setTerrain(terrain)Terrain

Update the terrain providing surface geometry for the globe.
参数名称 类型 描述信息
terrain Terrain The terrain provider async helper
返回值:
terrain The terrain provider async helper
使用示例s:
// Use Cesium World Terrain
scene.setTerrain(Cesium.Terrain.fromWorldTerrain());
// Use a custom terrain provider
const terrain = new Cesium.Terrain(Cesium.CesiumTerrainProvider.fromUrl("https://myTestTerrain.com"));
scene.setTerrain(terrain);

terrain.errorEvent.addEventListener(error => {
  alert(`Encountered an error while creating terrain! ${error}`);
});