Created
August 8, 2021 13:55
-
-
Save yiskang/9e0f14794e29cd7448138ec3866650fe to your computer and use it in GitHub Desktop.
Autodesk Forge Viewer CustomPropertyPanel for v7.x
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
///////////////////////////////////////////////////////////////////// | |
// Copyright (c) Autodesk, Inc. All rights reserved | |
// Written by Forge Partner Development | |
// | |
// Permission to use, copy, modify, and distribute this software in | |
// object code form for any purpose and without fee is hereby granted, | |
// provided that the above copyright notice appears in all copies and | |
// that both that copyright notice and the limited warranty and | |
// restricted rights notice below appear in all supporting | |
// documentation. | |
// | |
// AUTODESK PROVIDES THIS PROGRAM "AS IS" AND WITH ALL FAULTS. | |
// AUTODESK SPECIFICALLY DISCLAIMS ANY IMPLIED WARRANTY OF | |
// MERCHANTABILITY OR FITNESS FOR A PARTICULAR USE. AUTODESK, INC. | |
// DOES NOT WARRANT THAT THE OPERATION OF THE PROGRAM WILL BE | |
// UNINTERRUPTED OR ERROR FREE. | |
///////////////////////////////////////////////////////////////////// | |
// ******************************************* | |
// Custom Property Panel | |
// ******************************************* | |
function CustomPropertyPanel(viewer, options) { | |
this.viewer = viewer; | |
this.options = options; | |
this.nodeId = -1; // dbId of the current element showing properties | |
Autodesk.Viewing.Extensions.ViewerPropertyPanel.call(this, this.viewer); | |
} | |
CustomPropertyPanel.prototype = Object.create(Autodesk.Viewing.Extensions.ViewerPropertyPanel.prototype); | |
CustomPropertyPanel.prototype.constructor = CustomPropertyPanel; | |
CustomPropertyPanel.prototype.requestProperties = function() { | |
if (this.isVisible() && this.isDirty) { | |
if (this.currentModel != null && this.currentNodeIds.length > 0) { | |
this.requestNodeProperties(this.currentNodeIds[0]); | |
} else { | |
this.showDefaultProperties(); | |
} | |
this.isDirty = false; | |
} | |
}; | |
CustomPropertyPanel.prototype.setProperties = function (properties, options) { | |
Autodesk.Viewing.Extensions.ViewerPropertyPanel.prototype.setProperties.call(this, properties, options); | |
// add your custom properties here | |
// for example, let's show the dbId and externalId | |
var _this = this; | |
// dbId is right here as nodeId | |
this.addProperty('dbId', this.propertyNodeId, 'Custom Properties'); | |
// externalId is under all properties, let's get it! | |
this.viewer.getProperties(this.propertyNodeId, function (props) { | |
_this.addProperty('externalId', props.externalId, 'Custom Properties'); | |
}) | |
} | |
CustomPropertyPanel.prototype.setNodeProperties = function (nodeId) { | |
Autodesk.Viewing.Extensions.ViewerPropertyPanel.prototype.setNodeProperties.call(this, nodeId); | |
this.nodeId = nodeId; // store the dbId for later use | |
}; | |
CustomPropertyPanel.prototype.requestNodeProperties = function(nodeId) { | |
Autodesk.Viewing.Extensions.ViewerPropertyPanel.prototype.setNodeProperties.call(this, nodeId); | |
this.nodeId = nodeId; // store the dbId for later use | |
} | |
// ******************************************* | |
// Custom Property Panel Extension | |
// ******************************************* | |
function CustomPropertyPanelExtension(viewer, options) { | |
Autodesk.Viewing.Extension.call(this, viewer, options); | |
this.viewer = viewer; | |
this.options = options; | |
this.panel = null; | |
} | |
CustomPropertyPanelExtension.prototype = Object.create(Autodesk.Viewing.Extension.prototype); | |
CustomPropertyPanelExtension.prototype.constructor = CustomPropertyPanelExtension; | |
CustomPropertyPanelExtension.prototype.load = function () { | |
return true; | |
}; | |
CustomPropertyPanelExtension.prototype.onToolbarCreated = function () { | |
this.panel = new CustomPropertyPanel(this.viewer, this.options); | |
var _this = this; | |
this.viewer.addEventListener(Autodesk.Viewing.EXTENSION_LOADED_EVENT, function (e) { | |
if (e.extensionId !== 'Autodesk.PropertiesManager') return; | |
var ext = _this.viewer.getExtension('Autodesk.PropertiesManager'); | |
ext.setPanel(_this.panel); | |
}) | |
}; | |
CustomPropertyPanelExtension.prototype.unload = function () { | |
if (this.panel == null) return; | |
var ext = this.viewer.getExtension('Autodesk.PropertiesManager'); | |
this.panel = null; | |
ext.setDefaultPanel(); | |
return true; | |
}; | |
Autodesk.Viewing.theExtensionManager.registerExtension('Autodesk.Sample.CustomPropertyPanelExtension', CustomPropertyPanelExtension); |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment