首页 > 解决方案 > 如何在 Javascript AutoDesk 中获取模型对象元数据属性

问题描述

我正在使用带有离线 svf 文件的 Javascript 中的 AutoDesk Forge Viewer (2D)。我已将 .dwg 文件转换为 svf 文件。

如何像我们使用 api“ https://developer.api.autodesk.com/modelderivative/v2/designdata/{urn}/metadata/{guid}/properties ”一样在 Javascript 中获取模型对象元数据属性?

我尝试使用 viewer.model.getProperties(dbId,function,funtion),但这只会给我特定于该 dbId 的详细信息,但我想要属性列表。

请帮我解决一下这个。

标签: javascriptautodesk-forgeautodesk-viewerautodesk-model-derivative

解决方案


首先,另一个博客讨论了模型导数如何提取属性。理论上,如果你得到 'aka json (json.gz)' 或 'sqlLite (sdb/db)',你就可以通过其他工具提取自己。 在 Forge Viewer 中如何使用 properties.db?.

我相信你已经知道http://extract.autodesk.io/你说你已经下载了 SVF。 http://extract.autodesk.io/ 为您提供下载翻译数据的逻辑,包括 json.gz 和 sqlLite db。

如果您更喜欢通过 Forge Viewer 转储浏览器中的所有属性,我能想到的唯一方法如下:

 function getAllDbIds(viewer) {
   var instanceTree = viewer.model.getData().instanceTree;

   var allDbIdsStr = Object.keys(instanceTree.nodeAccess.dbIdToIndex);

  return allDbIdsStr.map(function(id) { return parseInt(id)});
}

var AllDbIds = getAllDbIds(myViewer);
myViewer.model.getBulkProperties(AllDbIds, null,
   function(elements){
    console.log(elements);//this includes all properties of a node.
 })

实际上,我合并了两个博客: https ://forge.autodesk.com/cloud_and_mobile/2016/10/get-all-database-ids-in-the-model.html

https://forge.autodesk.com/blog/getbulkproperties-method


推荐阅读