2022-11-04 11:39:56 +08:00
|
|
|
<html>
|
|
|
|
|
|
|
|
|
|
<head>
|
2022-11-22 16:38:55 +08:00
|
|
|
<link rel="icon" href="./gemini-viewer-examples/demo/favicon.ico" />
|
|
|
|
|
<link rel="stylesheet" type="text/css" href="./gemini-viewer-examples/demo/global.css" />
|
|
|
|
|
<link rel="stylesheet" type="text/css" href="./gemini-viewer-examples/demo/iconfont/iconfont.css" />
|
|
|
|
|
<link rel="stylesheet" href="./gemini-viewer-examples/demo/layerManager/layerManager.css" />
|
|
|
|
|
<link rel="stylesheet" href="./gemini-viewer-examples/demo/settings/SettingsPanel.css">
|
2022-11-04 11:39:56 +08:00
|
|
|
</head>
|
|
|
|
|
|
|
|
|
|
<body>
|
|
|
|
|
<div id="viewerContainer">
|
|
|
|
|
<div id="myCanvas" class="renderer-container"></div>
|
|
|
|
|
</div>
|
|
|
|
|
<script type="module">
|
2022-11-22 16:38:55 +08:00
|
|
|
import { DxfViewer } from "./gemini-viewer-examples/demo/libs/gemini-viewer.esm.min.js";
|
|
|
|
|
import DxfSettingsPanel from './gemini-viewer-examples/demo/settings/DxfSettingsPanel.js';
|
|
|
|
|
import LayerManager from "./gemini-viewer-examples/demo/layerManager/LayerManager.js";
|
2022-11-04 11:39:56 +08:00
|
|
|
|
|
|
|
|
const models = [{
|
|
|
|
|
modelId: "dxf_1",
|
|
|
|
|
name: "dxf_1",
|
2022-11-22 16:38:55 +08:00
|
|
|
src: "./gemini-viewer-examples/demo/models/dxf/apartments.dxf",
|
2022-11-04 11:39:56 +08:00
|
|
|
merge: true,
|
|
|
|
|
visible: true,
|
|
|
|
|
}];
|
|
|
|
|
const config = {
|
|
|
|
|
containerId: "myCanvas",
|
|
|
|
|
enableAxisGizmo: true,
|
|
|
|
|
enableStats: true,
|
|
|
|
|
enableToolbar: true,
|
|
|
|
|
enableSpinner: true,
|
|
|
|
|
enableProgressBar: true,
|
|
|
|
|
enableBottomBar: true,
|
|
|
|
|
enableLayoutBar: true,
|
|
|
|
|
};
|
|
|
|
|
const viewer = new DxfViewer(config);
|
|
|
|
|
// const fontFiles = ["three/fonts/Microsoft_YaHei_Regular.typeface.json"];
|
2022-11-22 16:38:55 +08:00
|
|
|
const fontFiles = ["./gemini-viewer-examples/demo/three/fonts/hztxt.shx", "./gemini-viewer-examples/demo/three/fonts/simplex.shx"];
|
2022-11-04 11:39:56 +08:00
|
|
|
await viewer.setFont(fontFiles);
|
|
|
|
|
|
|
|
|
|
// loadProjectModel
|
|
|
|
|
let counter = 0; // to indicate how many models are loading
|
|
|
|
|
models.forEach((modelCfg) => {
|
|
|
|
|
if (modelCfg.visible === false) {
|
|
|
|
|
// visible is true by default
|
|
|
|
|
return; // only load visible ones
|
|
|
|
|
}
|
|
|
|
|
counter++;
|
|
|
|
|
const onProgress = (event) => {
|
|
|
|
|
let type = "Loading progress";
|
|
|
|
|
if (event.type === "parseProgress") {
|
|
|
|
|
type = "Parsing progress";
|
|
|
|
|
}
|
|
|
|
|
const progress = ((event.loaded * 100) / event.total).toFixed(2);
|
|
|
|
|
console.log(`[Demo] ${type}: ${progress}%`);
|
|
|
|
|
};
|
|
|
|
|
try {
|
|
|
|
|
viewer
|
|
|
|
|
.loadModelAsync(modelCfg, onProgress)
|
|
|
|
|
.then(() => {
|
|
|
|
|
console.log(`[Demo] Loaded model ${modelCfg.src}`);
|
|
|
|
|
if (!viewer.layerManager) {
|
|
|
|
|
viewer.layerManager = new LayerManager(viewer);
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
.finally(() => {
|
|
|
|
|
counter--;
|
|
|
|
|
});
|
|
|
|
|
} catch (ex) {
|
|
|
|
|
console.log(ex);
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
// as a demo page, add dxfSettingsPanel to window!
|
|
|
|
|
window.dxfSettingsPanel = new DxfSettingsPanel(viewer);
|
|
|
|
|
</script>
|
|
|
|
|
</body>
|
|
|
|
|
|
|
|
|
|
</html>
|