如何设置Cesium JS地图中心(坐标:纬度和经度)

时间:2014-02-08 18:33:04

标签: javascript cesium

我想初始化cesium,以便地图以某些特定坐标为中心而不是默认坐标。我有以下初始化代码:

var map = new Cesium.CesiumWidget('map-js');
map.centralBody.terrainProvider = new Cesium.CesiumTerrainProvider({
    url : 'http://cesiumjs.org/smallterrain'
});

通常,对于其他映射库,我会在初始化时设置中心,例如在mapbox上:

map = L.mapbox.map('map-js', 'api-key').setView([42.12, 12.45], 9);

如何使用 cesium

2 个答案:

答案 0 :(得分:6)

尝试在上面第一段代码后添加:

var scene = map.scene;
var ellipsoid = Cesium.Ellipsoid.WGS84;
var west = Cesium.Math.toRadians(-77.0);
var south = Cesium.Math.toRadians(38.0);
var east = Cesium.Math.toRadians(-72.0);
var north = Cesium.Math.toRadians(42.0);

var extent = new Cesium.Rectangle(west, south, east, north);
scene.camera.viewRectangle(extent, ellipsoid);

我们的Camera Demo中提供了更多示例。

EDIT(2014年5月):由于Cesium API更改,.getCamera()被重命名为.camera,相机的.controller已被删除并滚动到相机本身,{{{ 1}}重命名为Extent。上面的代码现在反映了新的API。有关重大更改的完整列表,请参阅CHANGES.md

答案 1 :(得分:5)

如果你想保持当前的“缩放”(也就是椭圆体的相机距离)并且只有lon / lat,你可以调用setView()并使用当前的相机高度,如:

    viewer.camera.setView({
        destination : Cesium.Cartesian3.fromDegrees(
            longitude,
            latitude,
            Cesium.Ellipsoid.WGS84.cartesianToCartographic(viewer.camera.position).height
        )
    });