javascript - 为什么 Cesium 查看器在我添加时不显示模型?

标签 javascript java angularjs spring-boot cesiumjs

我有一个应用程序,它显示城市的 3D map 和“添加建筑物”按钮。

当用户按下该按钮时,必须将建筑物模型插入到 map 中。

但事实并非如此 - 我在正确的位置看到了一个选择标记,但没有看到实际的建筑物。

方法一

我使用以下代码添加建筑物(参见文件 src\main\resources\static\js\myapp.js 源代码):

function addBuilding() {
  var position = Cesium.Cartesian3.fromDegrees(132.159633, 43.350116, 0.);
  createModel('/models/CesiumAir/Cesium_Air.gltf', position);
}

function createModel(url, position) {
    var heading = Cesium.Math.toRadians(135);
    var pitch = 0;
    var roll = 0;
    var orientation = Cesium.Transforms.headingPitchRollQuaternion(
        position, heading, pitch, roll);

    var entity = viewer.entities.add({
        name : url,
        position : position,
        orientation : orientation,
        model : {
            uri : url,
            minimumPixelSize : 128
        }
    });
    console.log("entity.model = " + entity.model);
    viewer.selectedEntity = entity;
}

这行不通,所以我尝试了另一种方法。

方法二

var scene = viewer.scene;
var modelMatrix = Cesium.Transforms.eastNorthUpToFixedFrame(
    Cesium.Cartesian3.fromDegrees(132.159633, 43.350116, 0.0));
var primitive = Cesium.Model.fromGltf({
                      url : '/models/CesiumAir/Cesium_Air.gltf',
                      modelMatrix : modelMatrix,
                      minimumPixelSize : 128,
                      appearance : new Cesium.DebugAppearance({
                          attributeName : 'normal'
                        })
                  });
scene.primitives.add(primitive);

这也没有用。

如果我在浏览器中打开 URL http://localhost:8080/models/CesiumAir/Cesium_Air.gltf,我可以看到一些 JSON 输出,所以链接断开不是原因.

如果您能告诉我我必须在我的程序中修改哪些内容才能使添加建筑物正常工作,我将不胜感激。源代码和构建说明可用 here .该应用程序使用 AngularJS,也许 Cesium 和 Angular 会以某种方式干扰。

video显示如何重现此错误。

更新 1: 当我打开页面时,有时(但不总是)出现以下异常(当我启用停止未捕获的异常时):

Error

最佳答案

在 myapp.js 中创建查看器时,将 Cesium.SceneMode.COLUMBUS_VIEW 更改为 Cesium.SceneMode.SCENE3DModel rendering is currently not supported outside of 3D mode .

关于javascript - 为什么 Cesium 查看器在我添加时不显示模型?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31608683/

相关文章:

javascript - 使用 AJAX 数据发布设置属性样式

java - Logstash计划将重复记录插入elasticsearch

javascript - 如何在不同的复选框 Angular 之间切换

javascript - angularjs morris 指令从 json 休息创建图表

javascript - 不使用 FlatMap 的平面阵列

javascript - 输入激活来自文本字段的链接

javascript - Promise.all() 在完成之前停止工作

java - 移出 hibernate 模板

java - 将 Double 数组转换为 BigDecimals 数组

angularjs - 当数组中的对象列表时,ng-repeat 中不允许出现重复错误