ModelHandle/source/viewer/embeddedviewer.js

189 lines
6.5 KiB
JavaScript

OV.EmbeddedViewer = class
{
constructor (parentElement, parameters)
{
this.parentElement = parentElement;
this.parameters = {};
if (OV.IsDefined (parameters)) {
this.parameters = parameters;
}
this.canvas = document.createElement ('canvas');
this.parentElement.appendChild (this.canvas);
this.viewer = new OV.Viewer ();
this.viewer.Init (this.canvas);
let width = this.parentElement.clientWidth;
let height = this.parentElement.clientHeight;
this.viewer.Resize (width, height);
if (this.parameters.backgroundColor) {
this.viewer.SetBackgroundColor (this.parameters.backgroundColor);
}
if (this.parameters.edgeSettings) {
this.viewer.SetEdgeSettings (
this.parameters.edgeSettings.showEdges,
this.parameters.edgeSettings.edgeColor,
this.parameters.edgeSettings.edgeThreshold
);
}
if (this.parameters.environmentMap) {
this.viewer.SetEnvironmentMap (this.parameters.environmentMap);
}
window.addEventListener ('resize', () => {
this.Resize ();
});
}
LoadModelFromUrls (modelUrls)
{
if (modelUrls === null || modelUrls.length === 0) {
return null;
}
OV.TransformFileHostUrls (modelUrls);
let settings = new OV.ImportSettings ();
if (this.parameters.defaultColor) {
settings.defaultColor = this.parameters.defaultColor;
}
let progressDiv = null;
let loader = new OV.ThreeModelLoader ();
loader.LoadModel (modelUrls, OV.FileSource.Url, settings, {
onLoadStart : () => {
this.canvas.style.display = 'none';
progressDiv = document.createElement ('div');
progressDiv.innerHTML = 'Loading model...';
this.parentElement.appendChild (progressDiv);
},
onImportStart : () => {
progressDiv.innerHTML = 'Importing model...';
},
onVisualizationStart : () => {
progressDiv.innerHTML = 'Visualizing model...';
},
onModelFinished : (importResult, threeObject) => {
this.parentElement.removeChild (progressDiv);
this.canvas.style.display = 'inherit';
this.viewer.SetMainObject (threeObject);
let boundingSphere = this.viewer.GetBoundingSphere ((meshUserData) => {
return true;
});
this.viewer.AdjustClippingPlanesToSphere (boundingSphere);
if (this.parameters.camera) {
this.viewer.SetCamera (this.parameters.camera);
} else {
this.viewer.SetUpVector (importResult.upVector, false);
}
this.viewer.FitSphereToWindow (boundingSphere, false);
},
onTextureLoaded : () => {
this.viewer.Render ();
},
onLoadError : (importError) => {
let message = 'Unknown error';
if (importError.code === OV.ImportErrorCode.NoImportableFile) {
message = 'No importable file found';
} else if (importError.code === OV.ImportErrorCode.FailedToLoadFile) {
message = 'Failed to load file for import.';
} else if (importError.code === OV.ImportErrorCode.ImportFailed) {
message = 'Failed to import model.';
}
if (importError.message !== null) {
message += ' (' + importError.message + ')';
}
progressDiv.innerHTML = message;
}
});
}
GetViewer ()
{
return this.viewer;
}
Resize ()
{
let width = this.parentElement.clientWidth;
let height = this.parentElement.clientHeight;
this.viewer.Resize (width, height);
}
};
OV.Init3DViewerElement = function (parentElement, modelUrls, parameters)
{
let viewer = new OV.EmbeddedViewer (parentElement, parameters);
viewer.LoadModelFromUrls (modelUrls);
return viewer;
};
OV.Init3DViewerElements = function (onReady)
{
function LoadElement (element)
{
let camera = null;
let cameraParams = element.getAttribute ('camera');
if (cameraParams) {
camera = OV.ParameterConverter.StringToCamera (cameraParams);
}
let backgroundColor = null;
let backgroundColorParams = element.getAttribute ('backgroundcolor');
if (backgroundColorParams) {
backgroundColor = OV.ParameterConverter.StringToColor (backgroundColorParams);
}
let defaultColor = null;
let defaultColorParams = element.getAttribute ('defaultcolor');
if (defaultColorParams) {
defaultColor = OV.ParameterConverter.StringToColor (defaultColorParams);
}
let edgeSettings = null;
let edgeSettingsParams = element.getAttribute ('edgesettings');
if (edgeSettingsParams) {
edgeSettings = OV.ParameterConverter.StringToEdgeSettings (edgeSettingsParams);
}
let environmentMap = null;
let environmentMapParams = element.getAttribute ('environmentmap');
if (environmentMapParams) {
let environmentMapParts = environmentMapParams.split (',');
if (environmentMapParts.length === 6) {
environmentMap = environmentMapParts;
}
}
let modelUrls = null;
let modelParams = element.getAttribute ('model');
if (modelParams) {
modelUrls = OV.ParameterConverter.StringToModelUrls (modelParams);
}
return OV.Init3DViewerElement (element, modelUrls, {
camera : camera,
backgroundColor : backgroundColor,
defaultColor : defaultColor,
edgeSettings : edgeSettings,
environmentMap : environmentMap
});
}
let viewerElements = [];
window.addEventListener ('load', () => {
let elements = document.getElementsByClassName ('online_3d_viewer');
for (let i = 0; i < elements.length; i++) {
let element = elements[i];
let viewerElement = LoadElement (element);
viewerElements.push (viewerElement);
}
if (onReady !== undefined && onReady !== null) {
onReady (viewerElements);
}
});
};