render_dxf_project.html 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187
  1. <html>
  2. <head>
  3. <link rel="icon" href="/geminiRender/favicon.ico"/>
  4. <link rel="stylesheet" type="text/css" href="/geminiRender/global.css"/>
  5. <link rel="stylesheet" href="/geminiRender/layerManager/layerManager.css">
  6. <link rel="stylesheet" href="/geminiRender/settings/SettingsPanel.css">
  7. <style>
  8. .upload-btn {
  9. margin-top: 2em;
  10. }
  11. .upload-btn button {
  12. width: 0.1px;
  13. height: 0.1px;
  14. opacity: 0;
  15. overflow: hidden;
  16. position: absolute;
  17. z-index: -1;
  18. }
  19. .upload-btn label {
  20. color: #353535;
  21. background: gray;
  22. border: 0;
  23. border-radius: 3px;
  24. /*transition: ease 0.2s background-color;*/
  25. font-size: 1rem;
  26. font-weight: 700;
  27. text-overflow: ellipsis;
  28. white-space: nowrap;
  29. cursor: pointer;
  30. display: inline-block;
  31. overflow: hidden;
  32. padding: 0.625rem 1.25rem;
  33. }
  34. .upload-btn label:hover {
  35. background: #DDD;
  36. }
  37. .upload-btn svg {
  38. width: 1em;
  39. height: 1em;
  40. vertical-align: middle;
  41. fill: currentColor;
  42. margin-top: -0.25em;
  43. margin-right: 0.25em;
  44. }
  45. .model-layout-switch-bar {
  46. display: none !important;
  47. }
  48. .toolbar {
  49. display: none !important;
  50. }
  51. .axesRenderer {
  52. display: none !important;
  53. }
  54. </style>
  55. </head>
  56. <body>
  57. <div id="app">
  58. <div id="myCanvas" class="container"></div>
  59. </div>
  60. <div style="position: absolute; top: 10px; opacity: 0.6; width: 100%;text-align: center;">
  61. <!-- <div class="upload-btn" id="uploadBtn">-->
  62. <!-- <button id="uploadModelFile" type="button">点此上传本地模型文件</button>-->
  63. <!-- <label for="uploadModelFile" title="">-->
  64. <!-- <svg xmlns="http://www.w3.org/2000/svg" width="20" height="17" viewBox="0 0 20 17">-->
  65. <!-- <path-->
  66. <!-- d="M10 0l-5.2 4.9h3.3v5.1h3.8v-5.1h3.3l-5.2-4.9zm9.3 11.5l-3.2-2.1h-2l3.4 2.6h-3.5c-.1 0-.2.1-.2.1l-.8 2.3h-6l-.8-2.2c-.1-.1-.1-.2-.2-.2h-3.6l3.4-2.6h-2l-3.2 2.1c-.4.3-.7 1-.6 1.5l.6 3.1c.1.5.7.9 1.2.9h16.3c.6 0 1.1-.4 1.3-.9l.6-3.1c.1-.5-.2-1.2-.7-1.5z"></path>-->
  67. <!-- </svg>-->
  68. <!-- <span>Upload dxf</span>-->
  69. <!-- </label>-->
  70. <!-- <div style="margin-top: 1em;">-->
  71. <!-- <input id="fileUrlInput" style="display: inline-block; width: 20em; height: 2em;">-->
  72. <!-- <button-->
  73. <!-- style="width: 8em; height: 2em; color: #fff; overflow: auto; z-index: 1; opacity: 1; background: #000;"-->
  74. <!-- id="loadDxf">加载DXF-->
  75. <!-- </button>-->
  76. <!-- </div>-->
  77. <!-- </div>-->
  78. </div>
  79. <script type="module">
  80. import {DxfViewer, LocalDxfUploader, ToolbarMenuId} from "/geminiRender/libs/gemini-viewer.esm.min.js";
  81. import DxfSettingsPanel from '/geminiRender/settings/DxfSettingsPanel.js';
  82. import LayerManager from '/geminiRender/layerManager/LayerManager.js';
  83. const config = {
  84. containerId: "myCanvas",
  85. enableAxisGizmo: true,
  86. enableToolbar: true,
  87. enableBottomBar: true,
  88. enableSpinner: true,
  89. enableProgressBar: true,
  90. enableLayoutBar: true,
  91. toolbarMenuConfig: {
  92. [ToolbarMenuId.Settings]: {
  93. onActive: () => {
  94. console.log("[Toolbar]", "Activate Settings");
  95. if (!window.dxfSettingsPanel) {
  96. window.dxfSettingsPanel = new DxfSettingsPanel(window.viewer);
  97. }
  98. window.dxfSettingsPanel.show();
  99. },
  100. onDeactive: () => {
  101. console.log("[Toolbar]", "Deactivate Settings");
  102. if (!window.dxfSettingsPanel) {
  103. window.dxfSettingsPanel = new DxfSettingsPanel(window.viewer);
  104. }
  105. window.dxfSettingsPanel.hide();
  106. },
  107. },
  108. [ToolbarMenuId.Layers]: {
  109. onActive: () => {
  110. console.log("[Toolbar]", "Activate Layers");
  111. if (!window.layerManager) {
  112. window.layerManager = new LayerManager(window.viewer);
  113. }
  114. window.layerManager.show();
  115. },
  116. onDeactive: () => {
  117. console.log("[Toolbar]", "Deactivate Layers");
  118. if (!window.layerManager) {
  119. window.layerManager = new LayerManager(window.viewer);
  120. }
  121. window.layerManager.hide();
  122. },
  123. },
  124. },
  125. };
  126. const viewer = new DxfViewer(config);
  127. // const fontFiles = ["three/fonts/Microsoft_YaHei_Regular.typeface.json"];
  128. const fontFiles = ["/geminiRender/three/fonts/hztxt.shx", "/geminiRender/three/fonts/simplex.shx"];
  129. await viewer.setFont(fontFiles);
  130. window.viewer = viewer;
  131. const modelUploader = new LocalDxfUploader(viewer);
  132. modelUploader.onSuccess = () => {
  133. !viewer.layerManager && (viewer.layerManager = new LayerManager(viewer));
  134. }
  135. // document.getElementById("uploadModelFile").onclick = function () {
  136. // modelUploader.openFileBrowserToUpload();
  137. // }
  138. // document.getElementById("loadDxf").onclick = function () {
  139. // const url = document.getElementById("fileUrlInput").value;
  140. // if (url) {
  141. // viewer.loadModelAsync({src: url, merge: true}).then(() => {
  142. // console.log(`[Demo] Loaded model ${url}`);
  143. // !viewer.layerManager && (viewer.layerManager = new LayerManager(viewer));
  144. // })
  145. // }
  146. // }
  147. // as a demo page, add dxfSettingsPanel to window!
  148. window.dxfSettingsPanel = new DxfSettingsPanel(viewer);
  149. function getUrlParams(url) {
  150. const urlSearchParams = new URLSearchParams(url)
  151. const result = Object.fromEntries(urlSearchParams.entries())
  152. return result
  153. }
  154. window.onload = () => {
  155. debugger
  156. const path = getUrlParams(window.location.search)['path']
  157. console.log('path', path)
  158. }
  159. (function render() {
  160. const path = getUrlParams(window.location.search)['path']
  161. console.log('path', path)
  162. viewer.loadModelAsync({src: path, merge: true}).then(() => {
  163. console.log(`[Demo] Loaded model ${path}`);
  164. !viewer.layerManager && (viewer.layerManager = new LayerManager(viewer));
  165. })
  166. }())
  167. </script>
  168. </body>
  169. </html>