使用 loadModel promise 加载多个模型

Loading multiple models with loadModel promise

我想使用 loadModel promise 和 loadAsHidden 选项加载一组模型。然后,一旦加载了所有模型,就立即显示它们。似乎每个承诺都在我 运行 loadModel 命令后立即解决。因此,在模型完全加载之前,showHiddenModels 函数是 运行。 Storeys 数组包含文件的 svf 地址。

function loadAllModels() {
    let options =
    {
        loadAsHidden: true,
        globalOffset: { x: 0, y: 0, z: 0 }            
    };

    let promises = [];
    let length = storeys.length;
    let counter = 0;

    for (let storey of storeys) {
        let modelPromise = viewer.loadModel(storey.Svf, options);
        modelPromise.then((result) => {                
            counter++;
            console.log('counter: ' + counter);

            if (counter == length) {
                showHiddenModels();
            }
        });

        promises.push(modelPromise);
    }
}

function showHiddenModels() {
    let models = viewer.impl.modelQueue().getHiddenModels();

    for (let model of models) {
         viewer.showModel(model);
    }

    let extension = viewer.getExtension('Autodesk.ViewCubeUi');
    extension.setViewCube('[top/front]');     
}

这是它在控制台中的样子。所以首先调用 promise.then 然后它开始加载文件。

LoadModel 在加载模型种子文件而不是完整的 geometry/texture 等后立即履行其承诺...

对于模型加载完成的生命周期事件订阅Autodesk.Viewing.GEOMETRY_LOADED_EVENT:

viewer.addEventListener(Autodesk.Viewing.GEOMETRY_LOADED_EVENT, event=>{
  //event {type:string, model:object, target:object}
})

并且在多个模型场景中,当每个模型完成加载时,此事件将触发多次 - 使用 model 对象的 ID 来判断最后一个模型何时完全加载。