cesium 移动模型视角
时间: 2023-07-05 20:27:01 浏览: 250
要在Cesium中实现移动模型视角,可以使用`Cesium.Camera.follow`方法。该方法将相机设置为跟随给定的实体或位置,并设置相机高度、距离和方位角等参数,以便在平移、旋转或缩放过程中保持视角恒定。
以下是一个示例代码,用于在Cesium中实现移动模型视角:
```javascript
var viewer = new Cesium.Viewer('cesiumContainer');
// 创建一个模型实体
var entity = viewer.entities.add({
name : 'model',
position : Cesium.Cartesian3.fromDegrees(-75.62898254394531, 40.02804946899414, 0.0),
model : {
uri : 'path/to/model.gltf'
}
});
// 跟随模型实体
viewer.camera.follow(entity, new Cesium.Cartesian3(0.0, -10.0, 5.0), new Cesium.Cartesian3(0.0, 0.0, 0.0));
```
在上述代码中,我们首先创建了一个Cesium Viewer对象,并添加了一个模型实体。然后使用`viewer.camera.follow`方法跟随该实体,设置相机高度、距离和方位角等参数,以便在移动模型时保持相机视角不变。
相关问题
cesium 移动倾斜模型位置
Cesium移动倾斜模型位置是指用Cesium地球浏览器中的倾斜摄影技术将建筑物、城市等实体进行三维模拟后,通过移动设备或者浏览器进行模型浏览时,随着用户的操作视角而发生位置变化的过程。Cesium在移动倾斜模型位置方面具有很大的优势,它能在不同的设备、不同的网速下,实现流畅自如的模型打开和位置移动,相比其他的3D地图框架更具有优势。用户可以通过简单的手势,在移动端设备上轻松实现模型的旋转、平移、缩放等操作,非常方便。Cesium倾斜摄影技术的高清晰度以及可以无缝拼接的特点,可以大幅提升用户的视觉体验。总之,Cesium移动倾斜模型位置的优势在于流畅自如的视角操作,高清晰度的展示和无缝拼接的特点,带给用户极佳的视觉冲击和良好的体验。
cesium卫星模型
### Cesium 中卫星模型的创建与展示
在 Cesium 中,可以通过 `Cesium.Model.fromGltf` 方法加载外部 GLTF 格式的三维模型文件来表示卫星实体。为了使卫星按照预定轨道运动,可以利用时间动态更新其位置属性。
#### 创建 Viewer 实例并配置动画播放功能
初始化 Cesium 的 viewer 对象时设置自动播放动画选项为开启状态[^1]:
```javascript
const viewer = new Cesium.Viewer('cesiumContainer', {
shouldAnimate: true,
});
```
#### 定义卫星轨迹函数
定义一个用于生成一系列坐标点构成的卫星飞行路径的方法,这里假设输入参数为起始经度和纬度值[^2]:
```javascript
function generateSatellitePath(lon, lat) {
const positions = [];
for (let angle = 0; angle <= 360; angle += 10) {
positions.push(
Cesium.Math.toRadians(lon + angle),
Cesium.Math.toRadians(lat),
7e5 // 高度设为70万米即约等于地球半径加上平均高度
);
}
return positions;
}
```
#### 添加带有自定义模型的 Entity 到场景中
通过调用 `viewer.entities.add()` 向当前视图添加新的 entity,并指定该对象的位置随时间变化而沿预设路线移动;同时指明要使用的 gltf 文件作为外观表现形式:
```javascript
// 假定已存在名为 'satellite.gltf' 的卫星模型资源位于服务器根目录下
const satelliteModelUrl = '/models/satellite.gltf';
// 构建卫星entity实例
const satelliteEntity = viewer.entities.add({
position: new Cesium.CallbackProperty(function () {
let index = Math.floor(viewer.clock.currentTime.secondsOfDay / 10);
if (index >= pathPositions.length) {
index %= pathPositions.length;
}
return Cesium.Cartesian3.fromDegreesArrayHeights([pathPositions[index]]);
}, false),
model: {
uri: satelliteModelUrl,
minimumPixelSize: 128,
maximumScale: 2.0
},
orientation: new Cesium.VelocityOrientationProperty(new Cesium.SampledPositionProperty())
});
// 开启实时跟踪模式以便跟随卫星视角变换
viewer.trackedEntity = satelliteEntity;
// 计算出完整的路径坐标数组供上面position回调使用
const initialLongitude = 116.4074; // 起始经度(北京)
const initialLatitude = 39.9042; // 起始纬度(北京)
const pathPositions = generateSatellitePath(initialLongitude, initialLatitude);
// 设置初始时间为上午八点钟整时刻
viewer.clock.startTime = Cesium.JulianDate.fromIso8601('2023-01-01T08:00:00Z');
viewer.clock.stopTime = Cesium.JulianDate.addHours(viewer.clock.startTime, 24, new Cesium.JulianDate());
viewer.clock.currentTime = Cesium.JulianDate.clone(viewer.clock.startTime);
viewer.clock.multiplier = 1000; // 加快速度以观察效果
viewer.clock.shouldAnimate = true;
```
阅读全文
相关推荐
data:image/s3,"s3://crabby-images/4ab4e/4ab4e16af55d61505c6ba78cf12ec100586fa6ad" alt="7z"
data:image/s3,"s3://crabby-images/6eee2/6eee29554420e01e83364d49443b3b12df11c8af" alt=""
data:image/s3,"s3://crabby-images/5402c/5402c08311ac4060fea3813aa755d24bfad9113e" alt="jsp"
data:image/s3,"s3://crabby-images/5402c/5402c08311ac4060fea3813aa755d24bfad9113e" alt="js"
data:image/s3,"s3://crabby-images/c7f95/c7f957a578cbb465f17670ca5ec5de6d8fbcb44e" alt="zip"
data:image/s3,"s3://crabby-images/c7f95/c7f957a578cbb465f17670ca5ec5de6d8fbcb44e" alt="zip"
data:image/s3,"s3://crabby-images/67779/677799e3f0cb300878598cdf44af630e5aa7bdbb" alt="-"
data:image/s3,"s3://crabby-images/c7f95/c7f957a578cbb465f17670ca5ec5de6d8fbcb44e" alt="-"
data:image/s3,"s3://crabby-images/76d5d/76d5dcefc5ad32aa65e7d5f6e5b202b09b84830d" alt="-"
data:image/s3,"s3://crabby-images/e802a/e802a808507cc67c433d0f14f4478cfc18013243" alt="-"
data:image/s3,"s3://crabby-images/e802a/e802a808507cc67c433d0f14f4478cfc18013243" alt="-"
data:image/s3,"s3://crabby-images/e802a/e802a808507cc67c433d0f14f4478cfc18013243" alt="-"
data:image/s3,"s3://crabby-images/e802a/e802a808507cc67c433d0f14f4478cfc18013243" alt="-"
data:image/s3,"s3://crabby-images/e802a/e802a808507cc67c433d0f14f4478cfc18013243" alt="-"
data:image/s3,"s3://crabby-images/e802a/e802a808507cc67c433d0f14f4478cfc18013243" alt="-"