cesium获取模型的数据包含b3dm和cmpt

**getreadyPromise()**方法在模型加载完成后调用

url为模型地址

javascript 复制代码
// tileset模型
function tilesetM(url) {
  tileset = viewer.scene.primitives.add(
    new Cesium.Cesium3DTileset({
      // url: '../../public/asd/tileset.json',
      url: url,
      // type: "3dtiles",
      maximumScreenSpaceError: 2, //最大的屏幕空间误差
      show: true,
      
    })
  );
  viewer.flyTo(tileset);
  viewer.scene.globe.depthTestAgainstTerrain = true; // 开启地形深度检测
  // viewer.extend(Cesium.viewerCesium3DTilesInspectorMixin); // 开启3D Tiles检测器
  getreadyPromise();
}
javascript 复制代码
let dataModeList: any = [];
function getreadyPromise() {
  var model = viewer.scene.primitives.get(0);
  // 监听模型加载完成
  model.readyPromise.then(function (modelval) {
    let tileset3dDate = [];
    //构件数据放入对象中
    tileset.tileLoad.addEventListener(function (tile) {
      processTileFeatures(tile, function (data) {
      });
    });
  });
}
function processTileFeatures(tile, callback) {
  var content = tile.content;
  var innerContents = content.innerContents;
  if (Cesium.defined(innerContents)) {
    var length = innerContents.length;
    for (var i = 0; i < length; ++i) {
      processContentFeatures(innerContents[i], callback);
    }
  } else {
    processContentFeatures(content, callback);
  }
  console.log('dataModeList:', dataModeList);
}

function processContentFeatures(content, callback) {
  var featuresLength = content.featuresLength;
  for (var i = 0; i < featuresLength; ++i) {
    var feature = content.getFeature(i);
    // console.log("feature:",feature.getProperty("CODE"))
    // console.log("Id:",feature.getProperty("id"))
    dataModeList.push({
      id: feature.getProperty('id'),
      name: feature.getProperty('name'),
      CODE: feature.getProperty('CODE'),
      sid: feature.getProperty('sid'),
      modeName: feature.getProperty('名称'),
      modeType: feature.getProperty('类型'),
    });
    callback(feature);
  }
}
相关推荐
Kayshen4 分钟前
我在设计工具里实现了一个 Agent Team:多智能体协作生成 UI 的实战经验
前端·aigc·agent
swipe16 分钟前
深入理解 JavaScript 中的 this 绑定机制:从原理到实战
前端·javascript·面试
Json_Lee17 分钟前
2026 年了,多 Agent 编码该怎么选?agent-team vs Claude Agent Teams vs Claude Squad vs Met
前端·后端·vibecoding
Novlan120 分钟前
Stepper 小数输入精度丢失 Bug 修复
前端
陈随易25 分钟前
刚上市就断货?如此火爆的编程显示器到底有什么魔力
前端·后端·程序员
兆子龙39 分钟前
前端哨兵模式(Sentinel Pattern):优雅实现无限滚动加载
前端·javascript·算法
豆苗学前端1 小时前
彻底讲透浏览器渲染原理,吊打面试官
前端·javascript·面试
踩着两条虫1 小时前
AI 驱动的 Vue3 应用开发平台 入门指南(五):创建 H5 移动应用
前端·vue.js·ai编程
ZengLiangYi1 小时前
用 AudioContext.suspend()/resume() 作为流式音视频的同步门控
前端·音视频开发
进击的尘埃1 小时前
可视化搭建引擎的撤销重做系统:Command 模式 + Immutable 快照实现操作历史树
javascript