kitchen-simulator 1.1.1-test.49 → 1.1.1-test.50
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/es/@history.js +2 -0
- package/es/AppContext.js +3 -0
- package/es/KitchenConfigurator.js +645 -0
- package/es/KitchenConfiguratorApp.js +480 -0
- package/es/actions/area-actions.js +14 -0
- package/es/actions/export.js +23 -0
- package/es/actions/groups-actions.js +89 -0
- package/es/actions/holes-actions.js +119 -0
- package/es/actions/items-actions.js +313 -0
- package/es/actions/lines-actions.js +81 -0
- package/es/actions/project-actions.js +281 -0
- package/es/actions/scene-actions.js +33 -0
- package/es/actions/vertices-actions.js +27 -0
- package/es/actions/viewer2d-actions.js +58 -0
- package/es/actions/viewer3d-actions.js +23 -0
- package/es/catalog/areas/area/planner-element.js +40 -0
- package/es/catalog/areas/area/textures/ceramic-tile.jpg +0 -0
- package/es/catalog/areas/area/textures/grass.jpg +0 -0
- package/es/catalog/areas/area/textures/parquet.jpg +0 -0
- package/es/catalog/areas/area/textures/strand-porcelain.jpg +0 -0
- package/es/catalog/areas/area/textures/tile1.jpg +0 -0
- package/es/catalog/catalog.js +277 -0
- package/es/catalog/envMap/nx.hdr +0 -0
- package/es/catalog/envMap/ny.hdr +0 -0
- package/es/catalog/envMap/nz.hdr +0 -0
- package/es/catalog/envMap/px.hdr +0 -0
- package/es/catalog/envMap/py.hdr +0 -0
- package/es/catalog/envMap/pz.hdr +0 -0
- package/es/catalog/factories/area-factory-3d.js +181 -0
- package/es/catalog/factories/area-factory.js +81 -0
- package/es/catalog/factories/export.js +7 -0
- package/es/catalog/factories/wall-factory-3d.js +202 -0
- package/es/catalog/factories/wall-factory.js +268 -0
- package/es/catalog/holes/door-closet/planner-element.js +222 -0
- package/es/catalog/holes/door-double/door_double.png +0 -0
- package/es/catalog/holes/door-double/planner-element.js +315 -0
- package/es/catalog/holes/door-exterior/planner-element.js +215 -0
- package/es/catalog/holes/door-interior/planner-element.js +227 -0
- package/es/catalog/holes/door-panic/panicDoor.png +0 -0
- package/es/catalog/holes/door-panic/planner-element.js +503 -0
- package/es/catalog/holes/door-panic-double/panicDoorDouble.png +0 -0
- package/es/catalog/holes/door-panic-double/planner-element.js +463 -0
- package/es/catalog/holes/door-sliding/planner-element.js +225 -0
- package/es/catalog/holes/doorway-framed/planner-element.js +145 -0
- package/es/catalog/holes/doorway-frameless/planner-element.js +104 -0
- package/es/catalog/holes/export.js +13 -0
- package/es/catalog/holes/gate/gate.jpg +0 -0
- package/es/catalog/holes/window-clear/planner-element.js +166 -0
- package/es/catalog/holes/window-clear/texture.png +0 -0
- package/es/catalog/holes/window-cross/planner-element.js +165 -0
- package/es/catalog/holes/window-cross/texture.png +0 -0
- package/es/catalog/holes/window-double-hung/planner-element.js +303 -0
- package/es/catalog/holes/window-double-hung/texture.png +0 -0
- package/es/catalog/holes/window-vertical/planner-element.js +276 -0
- package/es/catalog/holes/window-vertical/texture.png +0 -0
- package/es/catalog/lines/wall/planner-element.js +70 -0
- package/es/catalog/lines/wall/textures/bricks-normal.jpg +0 -0
- package/es/catalog/lines/wall/textures/bricks-normal2.jpg +0 -0
- package/es/catalog/lines/wall/textures/bricks.jpg +0 -0
- package/es/catalog/lines/wall/textures/bricks2.jpg +0 -0
- package/es/catalog/lines/wall/textures/bricks3.jpg +0 -0
- package/es/catalog/lines/wall/textures/morden-normal.jpg +0 -0
- package/es/catalog/lines/wall/textures/morden.jpg +0 -0
- package/es/catalog/lines/wall/textures/painted-normal.jpg +0 -0
- package/es/catalog/lines/wall/textures/painted.jpg +0 -0
- package/es/catalog/lines/wall/textures/plaster-normal.jpg +0 -0
- package/es/catalog/lines/wall/textures/plaster.jpg +0 -0
- package/es/catalog/lines/wall/wall.png +0 -0
- package/es/catalog/molding/molding-dcm/planner-element.js +28 -0
- package/es/catalog/molding/molding-dcm/texture.png +0 -0
- package/es/catalog/molding/molding-fbm/planner-element.js +28 -0
- package/es/catalog/molding/molding-fbm/texture.png +0 -0
- package/es/catalog/molding/molding-lrm/planner-element.js +28 -0
- package/es/catalog/molding/molding-lrm/texture.png +0 -0
- package/es/catalog/properties/export.js +21 -0
- package/es/catalog/properties/property-checkbox.js +116 -0
- package/es/catalog/properties/property-color.js +39 -0
- package/es/catalog/properties/property-enum.js +97 -0
- package/es/catalog/properties/property-hidden.js +19 -0
- package/es/catalog/properties/property-lenght-measure.js +101 -0
- package/es/catalog/properties/property-length-measure.js +134 -0
- package/es/catalog/properties/property-length-measure_hole.js +101 -0
- package/es/catalog/properties/property-number.js +48 -0
- package/es/catalog/properties/property-read-only.js +26 -0
- package/es/catalog/properties/property-string.js +48 -0
- package/es/catalog/properties/property-toggle.js +39 -0
- package/es/catalog/properties/shared-property-style.js +14 -0
- package/es/catalog/utils/FuseUtils.js +82 -0
- package/es/catalog/utils/exporter.js +148 -0
- package/es/catalog/utils/geom-utils.js +189 -0
- package/es/catalog/utils/item-loader.js +1521 -0
- package/es/catalog/utils/load-obj.js +91 -0
- package/es/catalog/utils/mtl-loader.js +358 -0
- package/es/catalog/utils/obj-loader.js +477 -0
- package/es/class/FuseUtils.js +82 -0
- package/es/class/area.js +145 -0
- package/es/class/export.js +24 -0
- package/es/class/group.js +440 -0
- package/es/class/guide.js +62 -0
- package/es/class/hole.js +929 -0
- package/es/class/item.js +1883 -0
- package/es/class/layer.js +667 -0
- package/es/class/line.js +1180 -0
- package/es/class/project.js +793 -0
- package/es/class/vertex.js +202 -0
- package/es/components/content.js +107 -0
- package/es/components/disclaimer/disclaimer.js +97 -0
- package/es/components/export.js +9 -0
- package/es/components/style/button.js +113 -0
- package/es/components/style/cancel-button.js +22 -0
- package/es/components/style/content-container.js +33 -0
- package/es/components/style/content-title.js +29 -0
- package/es/components/style/delete-button.js +25 -0
- package/es/components/style/export.js +31 -0
- package/es/components/style/form-block.js +24 -0
- package/es/components/style/form-color-input.js +27 -0
- package/es/components/style/form-label.js +26 -0
- package/es/components/style/form-number-input.js +213 -0
- package/es/components/style/form-number-input_2.js +206 -0
- package/es/components/style/form-select.js +68 -0
- package/es/components/style/form-slider.js +61 -0
- package/es/components/style/form-submit-button.js +26 -0
- package/es/components/style/form-text-input.js +95 -0
- package/es/components/viewer2d/area.js +81 -0
- package/es/components/viewer2d/export.js +31 -0
- package/es/components/viewer2d/grids/grid-horizontal-streak.js +37 -0
- package/es/components/viewer2d/grids/grid-streak.js +37 -0
- package/es/components/viewer2d/grids/grid-vertical-streak.js +37 -0
- package/es/components/viewer2d/grids/grids.js +35 -0
- package/es/components/viewer2d/group.js +53 -0
- package/es/components/viewer2d/item.js +513 -0
- package/es/components/viewer2d/layer.js +164 -0
- package/es/components/viewer2d/line.js +882 -0
- package/es/components/viewer2d/ruler.js +100 -0
- package/es/components/viewer2d/rulerDist.js +146 -0
- package/es/components/viewer2d/rulerX.js +151 -0
- package/es/components/viewer2d/rulerY.js +153 -0
- package/es/components/viewer2d/scene.js +140 -0
- package/es/components/viewer2d/snap.js +74 -0
- package/es/components/viewer2d/state.js +78 -0
- package/es/components/viewer2d/utils.js +198 -0
- package/es/components/viewer2d/vertex.js +65 -0
- package/es/components/viewer2d/viewer2d.js +1398 -0
- package/es/components/viewer3d/camera-controls-module/camera-controls.module.js +2592 -0
- package/es/components/viewer3d/dcm.js +401 -0
- package/es/components/viewer3d/fbm.js +414 -0
- package/es/components/viewer3d/front3D.js +66 -0
- package/es/components/viewer3d/grid-creator.js +25 -0
- package/es/components/viewer3d/grids/grid-horizontal-streak.js +36 -0
- package/es/components/viewer3d/grids/grid-streak.js +27 -0
- package/es/components/viewer3d/grids/grid-vertical-streak.js +36 -0
- package/es/components/viewer3d/libs/first-person-controls.js +67 -0
- package/es/components/viewer3d/libs/helvetiker_regular.typeface.js +1281 -0
- package/es/components/viewer3d/libs/mtl-loader.js +357 -0
- package/es/components/viewer3d/libs/obj-loader.js +462 -0
- package/es/components/viewer3d/libs/orbit-controls.js +699 -0
- package/es/components/viewer3d/libs/pointer-lock-controls.js +46 -0
- package/es/components/viewer3d/lrm.js +305 -0
- package/es/components/viewer3d/model.js +708 -0
- package/es/components/viewer3d/pointer-lock-navigation.js +115 -0
- package/es/components/viewer3d/ruler-utils/itemRect.js +61 -0
- package/es/components/viewer3d/ruler-utils/layer3D.js +495 -0
- package/es/components/viewer3d/ruler-utils/ruler3D.js +227 -0
- package/es/components/viewer3d/ruler-utils/scene3D.js +60 -0
- package/es/components/viewer3d/ruler-utils/state3D.js +18 -0
- package/es/components/viewer3d/scene-creator.js +3608 -0
- package/es/components/viewer3d/three-memory-cleaner.js +51 -0
- package/es/components/viewer3d/viewer3d-first-person.js +315 -0
- package/es/components/viewer3d/viewer3d.js +2527 -0
- package/es/constants.js +636 -0
- package/es/index.js +16 -0
- package/es/models.js +510 -0
- package/es/plugins/SVGLoader.js +1412 -0
- package/es/plugins/autosave.js +33 -0
- package/es/plugins/console-debugger.js +37 -0
- package/es/plugins/export.js +9 -0
- package/es/plugins/keyboard.js +101 -0
- package/es/reducers/areas-reducer.js +12 -0
- package/es/reducers/export.js +25 -0
- package/es/reducers/groups-reducer.js +38 -0
- package/es/reducers/holes-reducer.js +62 -0
- package/es/reducers/items-reducer.js +140 -0
- package/es/reducers/lines-reducer.js +45 -0
- package/es/reducers/project-reducer.js +129 -0
- package/es/reducers/reducer.js +19 -0
- package/es/reducers/scene-reducer.js +28 -0
- package/es/reducers/user-reducer.js +40 -0
- package/es/reducers/vertices-reducer.js +19 -0
- package/es/reducers/viewer2d-reducer.js +75 -0
- package/es/reducers/viewer3d-reducer.js +56 -0
- package/es/shared-style.js +66 -0
- package/es/styles/export.js +5 -0
- package/es/styles/tabs.css +40 -0
- package/es/translator/en.js +104 -0
- package/es/translator/it.js +79 -0
- package/es/translator/ru.js +79 -0
- package/es/translator/translator.js +84 -0
- package/es/utils/browser.js +33 -0
- package/es/utils/email-validator.js +4 -0
- package/es/utils/export.js +25 -0
- package/es/utils/geometry.js +2420 -0
- package/es/utils/get-edges-of-subgraphs.js +27 -0
- package/es/utils/graph-cycles.js +237 -0
- package/es/utils/graph-inner-cycles.js +46 -0
- package/es/utils/graph.js +150 -0
- package/es/utils/helper.js +268 -0
- package/es/utils/history.js +29 -0
- package/es/utils/id-broker.js +19 -0
- package/es/utils/logger.js +8 -0
- package/es/utils/math.js +50 -0
- package/es/utils/molding.js +871 -0
- package/es/utils/name-generator.js +18 -0
- package/es/utils/objects-utils.js +50 -0
- package/es/utils/phone-validator.js +4 -0
- package/es/utils/process-black-list.js +18 -0
- package/es/utils/react-if.js +18 -0
- package/es/utils/snap-scene.js +99 -0
- package/es/utils/snap.js +237 -0
- package/es/utils/summarizeCart.js +24 -0
- package/es/utils/threeCSG.es6.js +498 -0
- package/es/version.js +2 -0
- package/lib/catalog/properties/property-string.js +55 -0
- package/lib/catalog/properties/property-toggle.js +46 -0
- package/lib/catalog/properties/shared-property-style.js +20 -0
- package/lib/catalog/utils/FuseUtils.js +88 -0
- package/lib/catalog/utils/exporter.js +155 -0
- package/lib/catalog/utils/geom-utils.js +205 -0
- package/lib/catalog/utils/item-loader.js +1533 -0
- package/lib/catalog/utils/load-obj.js +99 -0
- package/lib/catalog/utils/mtl-loader.js +363 -0
- package/lib/catalog/utils/obj-loader.js +482 -0
- package/lib/class/FuseUtils.js +88 -0
- package/lib/class/area.js +150 -0
- package/lib/class/export.js +96 -0
- package/lib/class/group.js +445 -0
- package/lib/class/guide.js +67 -0
- package/lib/class/hole.js +934 -0
- package/lib/class/item.js +1889 -0
- package/lib/class/layer.js +672 -0
- package/lib/class/line.js +1186 -0
- package/lib/class/project.js +799 -0
- package/lib/class/vertex.js +207 -0
- package/lib/components/content.js +116 -0
- package/lib/components/disclaimer/disclaimer.js +105 -0
- package/lib/components/export.js +33 -0
- package/lib/components/style/button.js +120 -0
- package/lib/components/style/cancel-button.js +29 -0
- package/lib/components/style/content-container.js +40 -0
- package/lib/components/style/content-title.js +37 -0
- package/lib/components/style/delete-button.js +34 -0
- package/lib/components/style/export.js +121 -0
- package/lib/components/style/form-block.js +31 -0
- package/lib/components/style/form-color-input.js +34 -0
- package/lib/components/style/form-label.js +33 -0
- package/lib/components/style/form-number-input.js +220 -0
- package/lib/components/style/form-number-input_2.js +213 -0
- package/lib/components/style/form-select.js +75 -0
- package/lib/components/style/form-slider.js +68 -0
- package/lib/components/style/form-submit-button.js +35 -0
- package/lib/components/style/form-text-input.js +101 -0
- package/lib/components/viewer2d/area.js +88 -0
- package/lib/components/viewer2d/export.js +121 -0
- package/lib/components/viewer2d/grids/grid-horizontal-streak.js +44 -0
- package/lib/components/viewer2d/grids/grid-streak.js +44 -0
- package/lib/components/viewer2d/grids/grid-vertical-streak.js +44 -0
- package/lib/components/viewer2d/grids/grids.js +44 -0
- package/lib/components/viewer2d/group.js +62 -0
- package/lib/components/viewer2d/item.js +521 -0
- package/lib/components/viewer2d/layer.js +171 -0
- package/lib/components/viewer2d/line.js +892 -0
- package/lib/components/viewer2d/ruler.js +107 -0
- package/lib/components/viewer2d/rulerDist.js +153 -0
- package/lib/components/viewer2d/rulerX.js +158 -0
- package/lib/components/viewer2d/rulerY.js +160 -0
- package/lib/components/viewer2d/scene.js +147 -0
- package/lib/components/viewer2d/snap.js +83 -0
- package/lib/components/viewer2d/state.js +87 -0
- package/lib/components/viewer2d/utils.js +210 -0
- package/lib/components/viewer2d/vertex.js +74 -0
- package/lib/components/viewer2d/viewer2d.js +1405 -0
- package/lib/components/viewer3d/camera-controls-module/camera-controls.module.js +2597 -0
- package/lib/components/viewer3d/dcm.js +407 -0
- package/lib/components/viewer3d/fbm.js +420 -0
- package/lib/components/viewer3d/front3D.js +75 -0
- package/lib/components/viewer3d/grid-creator.js +34 -0
- package/lib/components/viewer3d/grids/grid-horizontal-streak.js +44 -0
- package/lib/components/viewer3d/grids/grid-streak.js +35 -0
- package/lib/components/viewer3d/grids/grid-vertical-streak.js +44 -0
- package/lib/components/viewer3d/libs/first-person-controls.js +74 -0
- package/lib/components/viewer3d/libs/helvetiker_regular.typeface.js +1287 -0
- package/lib/components/viewer3d/libs/mtl-loader.js +363 -0
- package/lib/components/viewer3d/libs/obj-loader.js +468 -0
- package/lib/components/viewer3d/libs/orbit-controls.js +705 -0
- package/lib/components/viewer3d/libs/pointer-lock-controls.js +52 -0
- package/lib/components/viewer3d/lrm.js +311 -0
- package/lib/components/viewer3d/model.js +714 -0
- package/lib/components/viewer3d/pointer-lock-navigation.js +122 -0
- package/lib/components/viewer3d/ruler-utils/itemRect.js +68 -0
- package/lib/components/viewer3d/ruler-utils/layer3D.js +502 -0
- package/lib/components/viewer3d/ruler-utils/ruler3D.js +234 -0
- package/lib/components/viewer3d/ruler-utils/scene3D.js +68 -0
- package/lib/components/viewer3d/ruler-utils/state3D.js +25 -0
- package/lib/components/viewer3d/scene-creator.js +3642 -0
- package/lib/components/viewer3d/three-memory-cleaner.js +60 -0
- package/lib/components/viewer3d/viewer3d-first-person.js +320 -0
- package/lib/components/viewer3d/viewer3d.js +2532 -0
- package/lib/constants.js +645 -0
- package/lib/index.js +96 -0
- package/lib/models.js +517 -0
- package/lib/plugins/SVGLoader.js +1417 -0
- package/lib/plugins/autosave.js +39 -0
- package/lib/plugins/console-debugger.js +44 -0
- package/lib/plugins/export.js +33 -0
- package/lib/plugins/keyboard.js +107 -0
- package/lib/reducers/areas-reducer.js +18 -0
- package/lib/reducers/export.js +97 -0
- package/lib/reducers/groups-reducer.js +44 -0
- package/lib/reducers/holes-reducer.js +68 -0
- package/lib/reducers/items-reducer.js +146 -0
- package/lib/reducers/lines-reducer.js +51 -0
- package/lib/reducers/project-reducer.js +135 -0
- package/lib/reducers/reducer.js +26 -0
- package/lib/reducers/scene-reducer.js +34 -0
- package/lib/reducers/user-reducer.js +46 -0
- package/lib/reducers/vertices-reducer.js +25 -0
- package/lib/reducers/viewer2d-reducer.js +82 -0
- package/lib/reducers/viewer3d-reducer.js +63 -0
- package/lib/shared-style.js +72 -0
- package/lib/styles/export.js +13 -0
- package/lib/translator/en.js +110 -0
- package/lib/translator/it.js +85 -0
- package/lib/translator/ru.js +85 -0
- package/lib/translator/translator.js +90 -0
- package/lib/utils/browser.js +40 -0
- package/lib/utils/email-validator.js +10 -0
- package/lib/utils/export.js +56 -0
- package/lib/utils/geometry.js +2516 -0
- package/lib/utils/get-edges-of-subgraphs.js +34 -0
- package/lib/utils/graph-cycles.js +240 -0
- package/lib/utils/graph-inner-cycles.js +54 -0
- package/lib/utils/graph.js +157 -0
- package/lib/utils/helper.js +291 -0
- package/lib/utils/history.js +36 -0
- package/lib/utils/id-broker.js +25 -0
- package/lib/utils/logger.js +14 -0
- package/lib/utils/math.js +57 -0
- package/lib/utils/molding.js +895 -0
- package/lib/utils/name-generator.js +23 -0
- package/lib/utils/objects-utils.js +60 -0
- package/lib/utils/phone-validator.js +10 -0
- package/lib/utils/process-black-list.js +24 -0
- package/lib/utils/react-if.js +24 -0
- package/lib/utils/snap-scene.js +105 -0
- package/lib/utils/snap.js +249 -0
- package/lib/utils/summarizeCart.js +30 -0
- package/lib/utils/threeCSG.es6.js +503 -0
- package/lib/version.js +8 -0
- package/package.json +3 -3
|
@@ -0,0 +1,1533 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.addEdgesToMesh = addEdgesToMesh;
|
|
7
|
+
exports.loadTexture = loadTexture;
|
|
8
|
+
exports.render2DItem = render2DItem;
|
|
9
|
+
exports.render3DApplianceItem = render3DApplianceItem;
|
|
10
|
+
exports.render3DItem = render3DItem;
|
|
11
|
+
exports.render3DLightingItem = render3DLightingItem;
|
|
12
|
+
var _convertUnits = _interopRequireDefault(require("convert-units"));
|
|
13
|
+
var _immutable = require("immutable");
|
|
14
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
15
|
+
var Three = _interopRequireWildcard(require("three"));
|
|
16
|
+
var SceneCreator = _interopRequireWildcard(require("../../components/viewer3d/scene-creator"));
|
|
17
|
+
var _constants = require("../../constants");
|
|
18
|
+
var _models = require("../../models");
|
|
19
|
+
var GeomUtils = _interopRequireWildcard(require("./geom-utils"));
|
|
20
|
+
var _loadObj = require("./load-obj");
|
|
21
|
+
var _helper = require("../../utils/helper");
|
|
22
|
+
function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function _interopRequireWildcard(e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, "default": e }; if (null === e || "object" != _typeof(e) && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (var _t2 in e) "default" !== _t2 && {}.hasOwnProperty.call(e, _t2) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, _t2)) && (i.get || i.set) ? o(f, _t2, i) : f[_t2] = e[_t2]); return f; })(e, t); }
|
|
23
|
+
function _interopRequireDefault(e) { return e && e.__esModule ? e : { "default": e }; }
|
|
24
|
+
function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
|
|
25
|
+
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
26
|
+
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
27
|
+
function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
|
|
28
|
+
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
|
|
29
|
+
function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
|
|
30
|
+
function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); }
|
|
31
|
+
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
32
|
+
function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } }
|
|
33
|
+
function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; }
|
|
34
|
+
function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t["return"] && (u = t["return"](), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
|
|
35
|
+
function _arrayWithHoles(r) { if (Array.isArray(r)) return r; }
|
|
36
|
+
// env Map ///////////////
|
|
37
|
+
var paramsCounter = {
|
|
38
|
+
envMap: 'HDR',
|
|
39
|
+
roughness: 0.6,
|
|
40
|
+
metalness: 0.3,
|
|
41
|
+
exposure: 1
|
|
42
|
+
// debug: true
|
|
43
|
+
};
|
|
44
|
+
var params = {
|
|
45
|
+
envMap: 'HDR',
|
|
46
|
+
roughness: 0.9,
|
|
47
|
+
metalness: 0.1,
|
|
48
|
+
metalness_glossy: 0.2,
|
|
49
|
+
exposure: 1.0
|
|
50
|
+
// debug: false
|
|
51
|
+
};
|
|
52
|
+
var paramsModel = {
|
|
53
|
+
envMap: 'HDR',
|
|
54
|
+
roughness: 0.9,
|
|
55
|
+
metalness: 0.2,
|
|
56
|
+
exposure: 1.0
|
|
57
|
+
// debug: false
|
|
58
|
+
};
|
|
59
|
+
|
|
60
|
+
// /////////////////////////
|
|
61
|
+
|
|
62
|
+
var cachedObject = {}; // cached Object for quickly load-3d
|
|
63
|
+
|
|
64
|
+
// render 2d function//////
|
|
65
|
+
function render2DItem(element, layer, scene, sizeinfo, layoutpos, is_corner, shape_svg) {
|
|
66
|
+
var _useState = (0, _react.useState)(false),
|
|
67
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
68
|
+
hover = _useState2[0],
|
|
69
|
+
setHover = _useState2[1];
|
|
70
|
+
var x = element.x,
|
|
71
|
+
y = element.y,
|
|
72
|
+
rotation = element.rotation;
|
|
73
|
+
var el_DSN = 'el_DSN',
|
|
74
|
+
doorStylesKeys = [];
|
|
75
|
+
var _element = element.toJS();
|
|
76
|
+
if (_element.doorStyle !== undefined) {
|
|
77
|
+
if (_element.doorStyle.doorStyles !== undefined) {
|
|
78
|
+
doorStylesKeys = Object.keys(_element.doorStyle.doorStyles);
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
if ((doorStylesKeys.includes('euro_length') || doorStylesKeys.includes('euro_width') || doorStylesKeys.includes('euro_shape_svg')) && _element.doorStyle.doorStyles.is_euro_cds) {
|
|
82
|
+
el_DSN = _element.doorStyle.door_style_name;
|
|
83
|
+
} else {
|
|
84
|
+
el_DSN = 'el_DSN';
|
|
85
|
+
}
|
|
86
|
+
var width, depth, el_euro_length, el_euro_width, el_euro_length_unit, el_euro_width_unit, el_is_euro_cds, el_euro_shape_svg;
|
|
87
|
+
if (doorStylesKeys.length > 0) {
|
|
88
|
+
el_euro_length = _element.doorStyle.doorStyles.euro_length;
|
|
89
|
+
el_euro_width = _element.doorStyle.doorStyles.euro_width;
|
|
90
|
+
el_is_euro_cds = _element.doorStyle.doorStyles.is_euro_cds;
|
|
91
|
+
el_euro_shape_svg = _element.doorStyle.doorStyles.euro_shape_svg;
|
|
92
|
+
}
|
|
93
|
+
if (el_euro_length === undefined && el_euro_width === undefined) {
|
|
94
|
+
el_DSN = 'el_DSN';
|
|
95
|
+
}
|
|
96
|
+
if (el_DSN === 'Euro & Frameless') {
|
|
97
|
+
// sizeinfo["depth"] = el_euro_length;
|
|
98
|
+
// sizeinfo["width"] = el_euro_width;
|
|
99
|
+
}
|
|
100
|
+
var tempWidth = element.properties.get('width');
|
|
101
|
+
var tempDepth = element.properties.get('depth');
|
|
102
|
+
width = tempWidth && {
|
|
103
|
+
length: tempWidth.get('_length'),
|
|
104
|
+
unit: tempWidth.get('_unit')
|
|
105
|
+
};
|
|
106
|
+
depth = tempDepth && {
|
|
107
|
+
length: tempDepth.get('_length'),
|
|
108
|
+
unit: tempDepth.get('_unit')
|
|
109
|
+
};
|
|
110
|
+
var originalWidth = (0, _convertUnits["default"])(sizeinfo.width).from('in').to('cm');
|
|
111
|
+
var originalDepth = (0, _convertUnits["default"])(sizeinfo.depth).from('in').to('cm');
|
|
112
|
+
var newWidth = (0, _convertUnits["default"])(width.length).from(width.unit).to('cm');
|
|
113
|
+
var newDepth = (0, _convertUnits["default"])(depth.length).from(depth.unit).to('cm');
|
|
114
|
+
var padding = (0, _convertUnits["default"])(_constants.SHAPE_SVG_PADDING).from(_constants.UNIT_INCH).to(_constants.UNIT_CENTIMETER);
|
|
115
|
+
var angle = element.rotation + 90;
|
|
116
|
+
var textRotation = 0;
|
|
117
|
+
if (Math.sin(angle * Math.PI / 180) < 0) {
|
|
118
|
+
textRotation = 180;
|
|
119
|
+
}
|
|
120
|
+
var color = '#eee';
|
|
121
|
+
if (layoutpos == _constants.BASE_CABINET_LAYOUTPOS) {
|
|
122
|
+
color = '#3f8db3';
|
|
123
|
+
}
|
|
124
|
+
if (layoutpos == _constants.TALL_CABINET_LAYOUTPOS) {
|
|
125
|
+
color = '#93b3be';
|
|
126
|
+
}
|
|
127
|
+
if (layoutpos == _constants.WALL_CABINET_LAYOUTPOS) {
|
|
128
|
+
color = '#48b08dcc';
|
|
129
|
+
}
|
|
130
|
+
var splitStr = [];
|
|
131
|
+
var txtContent = [];
|
|
132
|
+
var lineCount = 0; //parseInt(((newWidth) / 8 - 0.51).toFixed(), 10) - 1;
|
|
133
|
+
var rowCount = 0; //parseInt((element.type.length / lineCount - 0.51).toFixed(), 10);
|
|
134
|
+
|
|
135
|
+
// Get type
|
|
136
|
+
var type = element.type;
|
|
137
|
+
var objSKU = this.obj.sku_number;
|
|
138
|
+
if (objSKU.length !== 0) {
|
|
139
|
+
var dcId,
|
|
140
|
+
doorStyle = element.doorStyle;
|
|
141
|
+
if (doorStyle instanceof _immutable.Map) {
|
|
142
|
+
dcId = doorStyle.get('id');
|
|
143
|
+
} else {
|
|
144
|
+
dcId = doorStyle.id;
|
|
145
|
+
}
|
|
146
|
+
var skuItem = this.obj.skuArray.find(function (el) {
|
|
147
|
+
return el.door_color_id === dcId;
|
|
148
|
+
});
|
|
149
|
+
if (skuItem !== undefined) {
|
|
150
|
+
type = skuItem.sku;
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
if (rowCount > 0) {
|
|
154
|
+
for (var _x = 0; _x < rowCount; _x++) {
|
|
155
|
+
splitStr.push(type.slice(lineCount * _x, lineCount * (_x + 1)));
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
splitStr.push(type.slice(lineCount * rowCount));
|
|
159
|
+
splitStr.forEach(function (el, key) {
|
|
160
|
+
txtContent.push(/*#__PURE__*/_react["default"].createElement("text", {
|
|
161
|
+
key: 'text' + key,
|
|
162
|
+
x: "0",
|
|
163
|
+
y: newDepth / 2 - 12,
|
|
164
|
+
dy: 16 * key,
|
|
165
|
+
transform: "translate(".concat(newWidth / 2, ", ").concat(newDepth / 2 + 5, ") scale(1,-1) rotate(").concat(textRotation, ")")
|
|
166
|
+
// textLength={newWidth - 10}
|
|
167
|
+
// lengthAdjust="spacingAndGlyphs"
|
|
168
|
+
,
|
|
169
|
+
style: {
|
|
170
|
+
fontWeight: 500,
|
|
171
|
+
fontSize: '7px',
|
|
172
|
+
textAnchor: 'middle',
|
|
173
|
+
fill: '#FFF',
|
|
174
|
+
display: 'block'
|
|
175
|
+
}
|
|
176
|
+
}, el));
|
|
177
|
+
});
|
|
178
|
+
var style = {
|
|
179
|
+
stroke: element.selected ? '#565658' : '#565658',
|
|
180
|
+
strokeWidth: '2px',
|
|
181
|
+
fill: color
|
|
182
|
+
};
|
|
183
|
+
// let arrow_style = { stroke: element.selected ? '#0096fd' : null, strokeWidth: "2px", fill: "#84e1ce" };
|
|
184
|
+
|
|
185
|
+
var rendered = null;
|
|
186
|
+
if (shape_svg || el_euro_shape_svg) {
|
|
187
|
+
var svg_url, svg_width, svg_depth;
|
|
188
|
+
if (typeof shape_svg == 'string' || typeof el_euro_shape_svg == 'string') {
|
|
189
|
+
if (el_DSN === 'Euro & Frameless' && el_is_euro_cds) {
|
|
190
|
+
svg_url = el_euro_shape_svg;
|
|
191
|
+
svg_width = newWidth;
|
|
192
|
+
svg_depth = newDepth;
|
|
193
|
+
} else {
|
|
194
|
+
svg_url = shape_svg;
|
|
195
|
+
svg_width = originalWidth;
|
|
196
|
+
svg_depth = originalDepth;
|
|
197
|
+
}
|
|
198
|
+
} else {
|
|
199
|
+
// if (el_DSN === "Euro & Frameless" && el_is_euro_cds) {
|
|
200
|
+
// // svg_url = el_euro_shape_svg.url;
|
|
201
|
+
// } else {
|
|
202
|
+
// }
|
|
203
|
+
svg_url = shape_svg.url;
|
|
204
|
+
svg_width = (0, _convertUnits["default"])(_constants.SHAPE_SVG_WIDTH).from(_constants.UNIT_INCH).to(_constants.UNIT_CENTIMETER);
|
|
205
|
+
svg_depth = (0, _convertUnits["default"])(_constants.SHAPE_SVG_DEPTH).from(_constants.UNIT_INCH).to(_constants.UNIT_CENTIMETER);
|
|
206
|
+
}
|
|
207
|
+
var padding_width = padding * newWidth / svg_width;
|
|
208
|
+
var padding_depth = padding * newDepth / svg_depth;
|
|
209
|
+
rendered = /*#__PURE__*/_react["default"].createElement("g", {
|
|
210
|
+
onMouseOver: function onMouseOver(event) {
|
|
211
|
+
setHover(true);
|
|
212
|
+
},
|
|
213
|
+
onMouseOut: function onMouseOut(event) {
|
|
214
|
+
setHover(false);
|
|
215
|
+
},
|
|
216
|
+
transform: "translate(".concat(x, ",").concat(y, ")")
|
|
217
|
+
}, /*#__PURE__*/_react["default"].createElement("g", {
|
|
218
|
+
transform: "rotate(".concat(rotation, ")")
|
|
219
|
+
}, /*#__PURE__*/_react["default"].createElement("g", {
|
|
220
|
+
transform: "translate(".concat(-newWidth / 2 - padding_width, ",").concat(-newDepth / 2 - padding_depth, ")")
|
|
221
|
+
}, /*#__PURE__*/_react["default"].createElement("image", {
|
|
222
|
+
preserveAspectRatio: "none",
|
|
223
|
+
style: {
|
|
224
|
+
pointerEvents: 'none'
|
|
225
|
+
},
|
|
226
|
+
href: svg_url,
|
|
227
|
+
width: "".concat(newWidth + 2 * padding_width),
|
|
228
|
+
height: "".concat(newDepth + 2 * padding_depth),
|
|
229
|
+
transform: "scale(1, -1)",
|
|
230
|
+
x: "0",
|
|
231
|
+
y: "".concat(-newDepth - 2 * padding_depth)
|
|
232
|
+
}), /*#__PURE__*/_react["default"].createElement("rect", {
|
|
233
|
+
x: "".concat(padding_width),
|
|
234
|
+
y: "".concat(padding_depth),
|
|
235
|
+
width: "".concat(newWidth),
|
|
236
|
+
height: "".concat(newDepth),
|
|
237
|
+
visibility: element.toJS().doorStyle.doorStyles !== undefined ? element.toJS().doorStyle.doorStyles && element.toJS().doorStyle.doorStyles.cds && element.toJS().doorStyle.doorStyles.cds.length != 0 && element.toJS().doorStyle.doorStyles.cds.filter(function (cd) {
|
|
238
|
+
return cd.itemID == element.getIn(['itemID']);
|
|
239
|
+
}) ? 'hidden' : 'visible' : 'hidden',
|
|
240
|
+
style: {
|
|
241
|
+
pointerEvents: 'all',
|
|
242
|
+
opacity: 0.7,
|
|
243
|
+
postion: 'relative'
|
|
244
|
+
},
|
|
245
|
+
fill: _constants.STATUS_WARNING_LIGHT_COLOR,
|
|
246
|
+
stroke: _constants.STATUS_WARNING_COLOR,
|
|
247
|
+
strokeWidth: "2px"
|
|
248
|
+
}), /*#__PURE__*/_react["default"].createElement("g", {
|
|
249
|
+
transform: "translate(".concat(padding_width, ",").concat(padding_depth, ")")
|
|
250
|
+
}, txtContent))));
|
|
251
|
+
} else {
|
|
252
|
+
rendered = /*#__PURE__*/_react["default"].createElement("g", {
|
|
253
|
+
onMouseOver: function onMouseOver(event) {
|
|
254
|
+
setHover(true);
|
|
255
|
+
},
|
|
256
|
+
onMouseOut: function onMouseOut(event) {
|
|
257
|
+
setHover(false);
|
|
258
|
+
},
|
|
259
|
+
transform: "translate(".concat(x, ",").concat(y, ")")
|
|
260
|
+
}, /*#__PURE__*/_react["default"].createElement("g", {
|
|
261
|
+
transform: "rotate(".concat(rotation, ")")
|
|
262
|
+
}, /*#__PURE__*/_react["default"].createElement("g", {
|
|
263
|
+
transform: "translate(".concat(-newWidth / 2, ",").concat(-newDepth / 2, ")")
|
|
264
|
+
}, newDepth > 15 ? [/*#__PURE__*/_react["default"].createElement("rect", {
|
|
265
|
+
key: "base",
|
|
266
|
+
x: "0",
|
|
267
|
+
y: "12",
|
|
268
|
+
width: newWidth,
|
|
269
|
+
height: newDepth - 12,
|
|
270
|
+
style: style
|
|
271
|
+
}), /*#__PURE__*/_react["default"].createElement("polygon", {
|
|
272
|
+
key: "door",
|
|
273
|
+
style: style,
|
|
274
|
+
points: "0,9 ".concat(newWidth, ",9 ").concat(newWidth, ",6 ").concat(newWidth - 5, ",6 ").concat(newWidth - 5, ",3 ").concat(newWidth - 2, ",3 ").concat(newWidth - 2, " 0 ").concat(newWidth - 10, " 0 ").concat(newWidth - 10, ",3 ").concat(newWidth - 7, ",3 ").concat(newWidth - 7, ",6 0 6")
|
|
275
|
+
})] : /*#__PURE__*/_react["default"].createElement("rect", {
|
|
276
|
+
key: "base",
|
|
277
|
+
x: "0",
|
|
278
|
+
y: "0",
|
|
279
|
+
width: newWidth,
|
|
280
|
+
height: newDepth,
|
|
281
|
+
style: style
|
|
282
|
+
}), txtContent)));
|
|
283
|
+
}
|
|
284
|
+
return rendered;
|
|
285
|
+
}
|
|
286
|
+
// end of render 2d function /////////////////////////
|
|
287
|
+
|
|
288
|
+
function loadTexture(url) {
|
|
289
|
+
var texture = new Three.TextureLoader().load(url);
|
|
290
|
+
texture.colorSpace = Three.SRGBColorSpace;
|
|
291
|
+
texture.wrapS = Three.MirroredRepeatWrapping;
|
|
292
|
+
texture.wrapT = Three.MirroredRepeatWrapping;
|
|
293
|
+
return texture;
|
|
294
|
+
}
|
|
295
|
+
var applyTexture = function applyTexture(material, texture, length, height) {
|
|
296
|
+
if (texture) {
|
|
297
|
+
material.map = texture;
|
|
298
|
+
material.needsUpdate = true;
|
|
299
|
+
material.map.wrapS = Three.RepeatWrapping;
|
|
300
|
+
material.map.wrapT = Three.RepeatWrapping;
|
|
301
|
+
material.map.repeat.set(length * 0.01, height * 0.01);
|
|
302
|
+
if (texture.normal) {
|
|
303
|
+
material.normalMap = loadTexture(texture.normal.uri);
|
|
304
|
+
material.normalScale = new Vector2(texture.normal.normalScaleX, texture.normal.normalScaleY);
|
|
305
|
+
material.normalMap.wrapS = Three.RepeatWrapping;
|
|
306
|
+
material.normalMap.wrapT = Three.RepeatWrapping;
|
|
307
|
+
material.normalMap.repeat.set(length * texture.normal.lengthRepeatScale, height * texture.normal.heightRepeatScale);
|
|
308
|
+
}
|
|
309
|
+
}
|
|
310
|
+
};
|
|
311
|
+
var assignUVs = function assignUVs(geometry) {
|
|
312
|
+
geometry.computeBoundingBox();
|
|
313
|
+
var _geometry$boundingBox = geometry.boundingBox,
|
|
314
|
+
min = _geometry$boundingBox.min,
|
|
315
|
+
max = _geometry$boundingBox.max;
|
|
316
|
+
var offset = new Three.Vector3(0 - min.x, 0 - min.y, 0 - min.z);
|
|
317
|
+
var range = new Three.Vector3(max.x - min.x, max.y - min.y, max.z - min.z);
|
|
318
|
+
geometry.faceVertexUvs[0] = geometry.faces.map(function (face) {
|
|
319
|
+
var v1 = geometry.vertices[face.a];
|
|
320
|
+
var v2 = geometry.vertices[face.b];
|
|
321
|
+
var v3 = geometry.vertices[face.c];
|
|
322
|
+
return [new Three.Vector3((v1.x + offset.x) / range.x, (v1.y + offset.y) / range.y, (v1.z + offset.z) / range.z), new Three.Vector3((v2.x + offset.x) / range.x, (v2.y + offset.y) / range.y, (v1.z + offset.z) / range.z), new Three.Vector3((v3.x + offset.x) / range.x, (v3.y + offset.y) / range.y, (v1.z + offset.z) / range.z)];
|
|
323
|
+
});
|
|
324
|
+
geometry.uvsNeedUpdate = true;
|
|
325
|
+
};
|
|
326
|
+
|
|
327
|
+
/**
|
|
328
|
+
* Render 3D Item
|
|
329
|
+
* @param {Item} element Rendering item
|
|
330
|
+
* @param sizeinfo Dimesion of the item
|
|
331
|
+
* @param structure_json Structure of the item such as place holders and meshes, etc
|
|
332
|
+
*/
|
|
333
|
+
function render3DItem(element, layer, scene, sizeinfo, structure_json, is_corner) {
|
|
334
|
+
var mode = arguments.length > 6 && arguments[6] !== undefined ? arguments[6] : null;
|
|
335
|
+
if (element.doorStyle.constructor !== _immutable.Map) {
|
|
336
|
+
element = element.set('doorStyle', (0, _immutable.fromJS)(element.doorStyle));
|
|
337
|
+
}
|
|
338
|
+
if (element.doorStyle.toJS().handle_gltf !== '') {
|
|
339
|
+
// Check element has doorHandle
|
|
340
|
+
for (var i = 1; i < 10; i++) {
|
|
341
|
+
element = element.setIn(['doorStyle', 'doorStyles', 'door_handle_' + i + '_gltf'], element.doorStyle.toJS().handle_gltf);
|
|
342
|
+
element = element.setIn(['doorStyle', 'doorStyles', 'fixed_drawer_door_handle_' + i + '_gltf'], element.doorStyle.toJS().handle_gltf);
|
|
343
|
+
element = element.setIn(['doorStyle', 'doorStyles', 'drawer_door_handle_' + i + '_gltf'], element.doorStyle.toJS().handle_gltf);
|
|
344
|
+
}
|
|
345
|
+
}
|
|
346
|
+
var width = {
|
|
347
|
+
length: sizeinfo.width,
|
|
348
|
+
unit: 'in'
|
|
349
|
+
};
|
|
350
|
+
var depth = {
|
|
351
|
+
length: sizeinfo.depth,
|
|
352
|
+
unit: 'in'
|
|
353
|
+
};
|
|
354
|
+
var height = {
|
|
355
|
+
length: sizeinfo.height,
|
|
356
|
+
unit: 'in'
|
|
357
|
+
};
|
|
358
|
+
var newWidth = (0, _convertUnits["default"])(width.length).from(width.unit).to('in');
|
|
359
|
+
var newDepth = (0, _convertUnits["default"])(depth.length).from(depth.unit).to('in');
|
|
360
|
+
var newHeight = (0, _convertUnits["default"])(height.length).from(height.unit).to('in');
|
|
361
|
+
var mainName = ''; // to get name structure//
|
|
362
|
+
if (element.properties.get('width')) newWidth = element.getIn(['properties', 'width', '_length']);
|
|
363
|
+
if (element.properties.get('depth')) newDepth = element.getIn(['properties', 'depth', '_length']);
|
|
364
|
+
if (element.properties.get('height')) newHeight = element.getIn(['properties', 'height', '_length']);
|
|
365
|
+
var structure = structure_json;
|
|
366
|
+
// structure.push({name:'model', url: '/assets/model/DCM.gltf'});
|
|
367
|
+
structure.model = '/assets/model/DCM.gltf';
|
|
368
|
+
var placeholders = structure.placeholders;
|
|
369
|
+
var doorStyles = null;
|
|
370
|
+
var color = 0xffffff,
|
|
371
|
+
glossness = 1,
|
|
372
|
+
handleMaterial = {};
|
|
373
|
+
var counterTop = element.counterTop;
|
|
374
|
+
if (layer.toJS().counterTop.uri) {
|
|
375
|
+
counterTop.uri = layer.toJS().counterTop.uri;
|
|
376
|
+
}
|
|
377
|
+
if ('name' in element.doorStyle) {
|
|
378
|
+
doorStyles = new _immutable.Map(element.doorStyle.doorStyles);
|
|
379
|
+
color = element.doorStyle.color;
|
|
380
|
+
glossness = element.doorStyle.glossness;
|
|
381
|
+
handleMaterial.metalness = element.doorStyle.metalness;
|
|
382
|
+
handleMaterial.roughness = element.doorStyle.roughness;
|
|
383
|
+
} else if (element.doorStyle != null && element.doorStyle) {
|
|
384
|
+
doorStyles = element.doorStyle.get('doorStyles');
|
|
385
|
+
color = element.doorStyle.get('color');
|
|
386
|
+
glossness = element.doorStyle.get('glossness');
|
|
387
|
+
handleMaterial.metalness = element.doorStyle.get('metalness');
|
|
388
|
+
handleMaterial.roughness = element.doorStyle.get('roughness');
|
|
389
|
+
}
|
|
390
|
+
if (color === undefined) color = '#ffffff';
|
|
391
|
+
if (glossness === undefined) glossness = 1;
|
|
392
|
+
var tempDoorStyles = doorStyles.toJS();
|
|
393
|
+
var tempPlaceholders = structure.tempPlaceholders;
|
|
394
|
+
var tPlaceholders = tempPlaceholders.find(function (el) {
|
|
395
|
+
return el.id === tempDoorStyles.cabinet_door_style_id;
|
|
396
|
+
});
|
|
397
|
+
if (tPlaceholders !== undefined) {
|
|
398
|
+
placeholders = tPlaceholders.placeholders;
|
|
399
|
+
var tempStructure = _objectSpread(_objectSpread({}, tPlaceholders.structure), {}, {
|
|
400
|
+
animation: structure.animation,
|
|
401
|
+
placeholders: structure.placeholders,
|
|
402
|
+
tempPlaceholders: structure.tempPlaceholders,
|
|
403
|
+
model: structure.model
|
|
404
|
+
});
|
|
405
|
+
structure = tempStructure;
|
|
406
|
+
}
|
|
407
|
+
var userData = structure.animation;
|
|
408
|
+
// ///////////////////////////
|
|
409
|
+
var onLoadItem = function onLoadItem(object) {
|
|
410
|
+
var areaMaterial = new Three.MeshStandardMaterial();
|
|
411
|
+
areaMaterial.side = Three.DoubleSide;
|
|
412
|
+
// areaMaterial.envMap = textureCube;
|
|
413
|
+
if (doorStyles != null) if (doorStyles.get('base') != undefined) {
|
|
414
|
+
var normalMap = doorStyles.get('base');
|
|
415
|
+
var interiortexture = loadTexture(normalMap);
|
|
416
|
+
applyTexture(areaMaterial, interiortexture, 100, 100);
|
|
417
|
+
}
|
|
418
|
+
var object1 = object;
|
|
419
|
+
var newAltitude = element.properties.get('altitude').get('_length');
|
|
420
|
+
var newUnit = element.properties.get('altitude').get('_unit') || 'in';
|
|
421
|
+
newAltitude = (0, _convertUnits["default"])(newAltitude).from(newUnit).to(scene.unit);
|
|
422
|
+
var _element = element.toJS();
|
|
423
|
+
if (!_element.doorStyle.doorStyles.is_euro_cds) {
|
|
424
|
+
object1.scale.set(100 * newWidth / sizeinfo.width, 100 * newHeight / sizeinfo.height, 100 * newDepth / sizeinfo.depth);
|
|
425
|
+
} else {
|
|
426
|
+
object1.scale.set(100, 100, 100);
|
|
427
|
+
}
|
|
428
|
+
// Normalize the origin of the object
|
|
429
|
+
var boundingBox = GeomUtils.baseBox3FromObject(object1);
|
|
430
|
+
object1.userData = boundingBox;
|
|
431
|
+
var door_animate_offset = {};
|
|
432
|
+
var matchStr = /\d_(door[^LR1-9]*)(_[LR])?(_[1-9])?$/;
|
|
433
|
+
object1.children.forEach(function (child) {
|
|
434
|
+
var door_match = child.name.match(matchStr);
|
|
435
|
+
if (door_match && door_match.length > 2) {
|
|
436
|
+
var _child$children$;
|
|
437
|
+
var rotate_match_text = element.properties.toJS().flip_doorhandle ? 'rotate_L' : 'rotate_R';
|
|
438
|
+
if (door_match[2] === '_L') {
|
|
439
|
+
rotate_match_text = element.properties.toJS().flip_doorhandle ? 'rotate_R' : 'rotate_L';
|
|
440
|
+
}
|
|
441
|
+
var isDoubleDoor = door_match && door_match[2] !== undefined;
|
|
442
|
+
(_child$children$ = child.children[0]) === null || _child$children$ === void 0 || _child$children$.children.forEach(function (it) {
|
|
443
|
+
var _it$name, _it$children;
|
|
444
|
+
if (it !== null && it !== void 0 && (_it$name = it.name) !== null && _it$name !== void 0 && _it$name.includes('handle') && (_it$children = it.children) !== null && _it$children !== void 0 && _it$children.length && is_corner === 1 && isDoubleDoor) {
|
|
445
|
+
var _child$name, _child$name2, _object1$children, _t0$name, _t0$children;
|
|
446
|
+
var tname = child !== null && child !== void 0 && (_child$name = child.name) !== null && _child$name !== void 0 && _child$name.endsWith('_L') ? child.name.replace('_L', '_R') : child === null || child === void 0 || (_child$name2 = child.name) === null || _child$name2 === void 0 ? void 0 : _child$name2.replace('_R', '_L');
|
|
447
|
+
var tmp = (object1 === null || object1 === void 0 || (_object1$children = object1.children) === null || _object1$children === void 0 ? void 0 : _object1$children.filter(function (item) {
|
|
448
|
+
return (item === null || item === void 0 ? void 0 : item.name) === tname;
|
|
449
|
+
})) || [];
|
|
450
|
+
var t0 = tmp[0];
|
|
451
|
+
var filterStr = t0 !== null && t0 !== void 0 && (_t0$name = t0.name) !== null && _t0$name !== void 0 && _t0$name.endsWith('_L') ? 'rotate_L' : 'rotate_R';
|
|
452
|
+
var tposArr = (t0 === null || t0 === void 0 || (_t0$children = t0.children) === null || _t0$children === void 0 || (_t0$children = _t0$children[0]) === null || _t0$children === void 0 || (_t0$children = _t0$children.children) === null || _t0$children === void 0 ? void 0 : _t0$children.filter(function (item) {
|
|
453
|
+
var _item$name;
|
|
454
|
+
return item === null || item === void 0 || (_item$name = item.name) === null || _item$name === void 0 ? void 0 : _item$name.endsWith(filterStr);
|
|
455
|
+
})) || [];
|
|
456
|
+
var tpos0 = tposArr[0];
|
|
457
|
+
if (it.name.includes('base_end')) {
|
|
458
|
+
var _it$position$x, _it$position, _it$position$y, _it$position2, _tpos0$position$x, _tpos0$position;
|
|
459
|
+
door_animate_offset[child.name] = {
|
|
460
|
+
x: -2 * ((_it$position$x = (_it$position = it.position) === null || _it$position === void 0 ? void 0 : _it$position.x) !== null && _it$position$x !== void 0 ? _it$position$x : 0) - 0.12,
|
|
461
|
+
y: (_it$position$y = (_it$position2 = it.position) === null || _it$position2 === void 0 ? void 0 : _it$position2.y) !== null && _it$position$y !== void 0 ? _it$position$y : 0,
|
|
462
|
+
z: -((_tpos0$position$x = tpos0 === null || tpos0 === void 0 || (_tpos0$position = tpos0.position) === null || _tpos0$position === void 0 ? void 0 : _tpos0$position.x) !== null && _tpos0$position$x !== void 0 ? _tpos0$position$x : 0) + 0.12,
|
|
463
|
+
isCorner: true
|
|
464
|
+
};
|
|
465
|
+
} else {
|
|
466
|
+
var _it$position$x2, _it$position3, _it$position$y2, _it$position4, _tpos0$position$x2, _tpos0$position2;
|
|
467
|
+
door_animate_offset[child.name] = {
|
|
468
|
+
x: -((_it$position$x2 = (_it$position3 = it.position) === null || _it$position3 === void 0 ? void 0 : _it$position3.x) !== null && _it$position$x2 !== void 0 ? _it$position$x2 : 0) - 0.04,
|
|
469
|
+
y: (_it$position$y2 = (_it$position4 = it.position) === null || _it$position4 === void 0 ? void 0 : _it$position4.y) !== null && _it$position$y2 !== void 0 ? _it$position$y2 : 0,
|
|
470
|
+
z: 2 * ((_tpos0$position$x2 = tpos0 === null || tpos0 === void 0 || (_tpos0$position2 = tpos0.position) === null || _tpos0$position2 === void 0 ? void 0 : _tpos0$position2.x) !== null && _tpos0$position$x2 !== void 0 ? _tpos0$position$x2 : 0) - 0.01,
|
|
471
|
+
isCorner: true
|
|
472
|
+
};
|
|
473
|
+
}
|
|
474
|
+
} else if (it.name.endsWith(rotate_match_text) && door_animate_offset[child.name] == undefined) {
|
|
475
|
+
door_animate_offset[child.name] = {
|
|
476
|
+
x: it.position.x,
|
|
477
|
+
y: it.position.y,
|
|
478
|
+
z: it.position.z,
|
|
479
|
+
isCorner: false
|
|
480
|
+
};
|
|
481
|
+
}
|
|
482
|
+
});
|
|
483
|
+
}
|
|
484
|
+
});
|
|
485
|
+
object1.userData.door_animate_offset = door_animate_offset;
|
|
486
|
+
object1.userData.animation = userData;
|
|
487
|
+
var center = [(boundingBox.max.x - boundingBox.min.x) / 2 + boundingBox.min.x, (boundingBox.max.y - boundingBox.min.y) / 2 + boundingBox.min.y, (boundingBox.max.z - boundingBox.min.z) / 2 + boundingBox.min.z];
|
|
488
|
+
object1.position.x -= center[0];
|
|
489
|
+
object1.position.y -= center[1] - (boundingBox.max.y - boundingBox.min.y) / 2;
|
|
490
|
+
object1.position.z -= center[2];
|
|
491
|
+
object1.position.y += newAltitude;
|
|
492
|
+
if (element.selected) {
|
|
493
|
+
// if object is selected
|
|
494
|
+
// save object transform info///
|
|
495
|
+
var scalevec = new Three.Vector3(object1.scale.x, object1.scale.y, object1.scale.z);
|
|
496
|
+
var posVec = new Three.Vector3(object1.position.x, object1.position.y, object1.position.z);
|
|
497
|
+
object.scale.set(1 * newWidth / sizeinfo.width, 1 * newHeight / sizeinfo.height, 1 * newDepth / sizeinfo.depth);
|
|
498
|
+
object1.position.set(0, 0, 0);
|
|
499
|
+
object1.rotation.set(0, 0, 0);
|
|
500
|
+
|
|
501
|
+
//let box = new Three.BoxHelper(object, 0xffffff);
|
|
502
|
+
//box.material.lineWidth = 5;
|
|
503
|
+
//box.renderOrder = 1000;
|
|
504
|
+
//box.material.depthTest = false;
|
|
505
|
+
//object.add(box);
|
|
506
|
+
var _boundingBox = GeomUtils.baseBox3FromObject(object);
|
|
507
|
+
var max = _boundingBox.max;
|
|
508
|
+
var min = _boundingBox.min;
|
|
509
|
+
var radius = Math.sqrt((_boundingBox.max.x - _boundingBox.min.x) * (_boundingBox.max.x - _boundingBox.min.x) + (_boundingBox.max.z - _boundingBox.min.z) * (_boundingBox.max.z - _boundingBox.min.z)) / 2;
|
|
510
|
+
var moveBox = new Three.BoxGeometry(max.x - min.x, max.y - min.y, max.z - min.z);
|
|
511
|
+
|
|
512
|
+
// translate Object
|
|
513
|
+
var controlGeom = GeomUtils.controlGeom();
|
|
514
|
+
|
|
515
|
+
// rotate Object //////////
|
|
516
|
+
var rotGeom = GeomUtils.rotGeoms(radius + 0.05);
|
|
517
|
+
// //////////////////////////////////
|
|
518
|
+
|
|
519
|
+
// upwards Geometry/////////// Move up Object
|
|
520
|
+
var upwardsGeom = GeomUtils.upwardsGeom();
|
|
521
|
+
|
|
522
|
+
// vertical line - 4 lines around object//////////////////////////
|
|
523
|
+
var vLineGeom = new Three.BufferGeometry();
|
|
524
|
+
var vertices = [(max.x - min.x) / 2 + min.x, 0, max.z, (max.x - min.x) / 2 + min.x, 0, max.z + 1.3];
|
|
525
|
+
vLineGeom.setAttribute('position', new Three.BufferAttribute(new Float32Array(vertices), 3));
|
|
526
|
+
var vLineGeom1 = new Three.BufferGeometry();
|
|
527
|
+
var vertices1 = [(max.x - min.x) / 2 + min.x, 0, min.z, (max.x - min.x) / 2 + min.x, 0, min.z - 1.3];
|
|
528
|
+
vLineGeom1.setAttribute('position', new Three.BufferAttribute(new Float32Array(vertices1), 3));
|
|
529
|
+
var vLineGeom2 = new Three.BufferGeometry();
|
|
530
|
+
var vertices2 = [max.x, 0, max.z - (max.z - min.z) / 2, max.x + 1.3, 0, max.z - (max.z - min.z) / 2];
|
|
531
|
+
vLineGeom2.setAttribute('position', new Three.BufferAttribute(new Float32Array(vertices2), 3));
|
|
532
|
+
var vLineGeom3 = new Three.BufferGeometry();
|
|
533
|
+
var vertices3 = [min.x, 0, max.z - (max.z - min.z) / 2, min.x - 1.3, 0, max.z - (max.z - min.z) / 2];
|
|
534
|
+
vLineGeom3.setAttribute('position', new Three.BufferAttribute(new Float32Array(vertices3), 3));
|
|
535
|
+
// ///////////////////////////////////////
|
|
536
|
+
|
|
537
|
+
// set names of transform object
|
|
538
|
+
var rotFillObj = new Three.Mesh(rotGeom.rotFill, new Three.MeshPhongMaterial({
|
|
539
|
+
color: new Three.Color(0x000000).convertLinearToSRGB(),
|
|
540
|
+
side: Three.DoubleSide,
|
|
541
|
+
colorWrite: true
|
|
542
|
+
}));
|
|
543
|
+
var rotStrokeObj = new Three.Line(rotGeom.rotStroke, new Three.LineBasicMaterial({
|
|
544
|
+
color: new Three.Color(0xffffff).convertLinearToSRGB(),
|
|
545
|
+
colorWrite: true
|
|
546
|
+
}));
|
|
547
|
+
rotFillObj.name = 'rotate';
|
|
548
|
+
var upObj = new Three.Mesh(upwardsGeom, new Three.MeshBasicMaterial({
|
|
549
|
+
color: new Three.Color(0xffffff).convertLinearToSRGB(),
|
|
550
|
+
side: Three.DoubleSide
|
|
551
|
+
}));
|
|
552
|
+
upObj.name = 'transUp';
|
|
553
|
+
var mBox = new Three.Mesh(moveBox, new Three.MeshBasicMaterial({
|
|
554
|
+
color: new Three.Color(0xdd6699).convertLinearToSRGB(),
|
|
555
|
+
side: Three.DoubleSide,
|
|
556
|
+
transparent: true,
|
|
557
|
+
opacity: 0.4
|
|
558
|
+
}));
|
|
559
|
+
var _color = new Three.Color(_constants.SHADE_DARK_PURPLE_COLOR).convertLinearToSRGB();
|
|
560
|
+
var vLine = new Three.Line(vLineGeom, new Three.LineBasicMaterial({
|
|
561
|
+
color: _color
|
|
562
|
+
}));
|
|
563
|
+
var vLine1 = new Three.Line(vLineGeom1, new Three.LineBasicMaterial({
|
|
564
|
+
color: _color
|
|
565
|
+
}));
|
|
566
|
+
var vLine2 = new Three.Line(vLineGeom2, new Three.LineBasicMaterial({
|
|
567
|
+
color: _color
|
|
568
|
+
}));
|
|
569
|
+
var vLine3 = new Three.Line(vLineGeom3, new Three.LineBasicMaterial({
|
|
570
|
+
color: _color
|
|
571
|
+
}));
|
|
572
|
+
vLine.renderOrder = 1;
|
|
573
|
+
vLine1.renderOrder = 1;
|
|
574
|
+
vLine2.renderOrder = 1;
|
|
575
|
+
vLine3.renderOrder = 1;
|
|
576
|
+
vLine.material.transparent = true;
|
|
577
|
+
vLine1.material.transparent = true;
|
|
578
|
+
vLine2.material.transparent = true;
|
|
579
|
+
vLine3.material.transparent = true;
|
|
580
|
+
vLine.material.depthTest = false;
|
|
581
|
+
vLine1.material.depthTest = false;
|
|
582
|
+
vLine2.material.depthTest = false;
|
|
583
|
+
vLine3.material.depthTest = false;
|
|
584
|
+
// translate vector to center of object
|
|
585
|
+
var uVec = new Three.Vector3(-posVec.x / scalevec.x, -posVec.y / scalevec.y, -posVec.z / scalevec.z);
|
|
586
|
+
vLine.translateY(0.1);
|
|
587
|
+
vLine1.translateY(0.1);
|
|
588
|
+
vLine2.translateY(0.1);
|
|
589
|
+
vLine3.translateY(0.1);
|
|
590
|
+
|
|
591
|
+
//rotObj.translateOnAxis(uVec, 1);
|
|
592
|
+
upObj.translateOnAxis(uVec, 1);
|
|
593
|
+
upObj.translateY(max.y - min.y);
|
|
594
|
+
mBox.name = 'TransformBox';
|
|
595
|
+
mBox.translateOnAxis(new Three.Vector3(uVec.x, uVec.y + (max.y - min.y) / 2, uVec.z), 1);
|
|
596
|
+
mBox.scale.set(1.01, 1.01, 1.01);
|
|
597
|
+
|
|
598
|
+
// other side rotate object
|
|
599
|
+
var rotFillObj1 = rotFillObj.clone();
|
|
600
|
+
var rotStrokeObj1 = rotStrokeObj.clone();
|
|
601
|
+
rotFillObj1.rotateY(Math.PI);
|
|
602
|
+
rotStrokeObj1.rotateY(Math.PI);
|
|
603
|
+
rotFillObj.translateY(0.1);
|
|
604
|
+
rotFillObj1.translateY(0.1);
|
|
605
|
+
rotStrokeObj.translateY(0.1);
|
|
606
|
+
rotStrokeObj1.translateY(0.1);
|
|
607
|
+
|
|
608
|
+
// assets Objects group includes rotate objects...
|
|
609
|
+
var asrtObj = new Three.Group();
|
|
610
|
+
// asrtObj.add(rotFillObj);
|
|
611
|
+
// asrtObj.add(rotFillObj1);
|
|
612
|
+
// asrtObj.add(rotStrokeObj);
|
|
613
|
+
// asrtObj.add(rotStrokeObj1);
|
|
614
|
+
//asrtObj.add(upObj);
|
|
615
|
+
asrtObj.add(vLine);
|
|
616
|
+
asrtObj.add(vLine1);
|
|
617
|
+
asrtObj.add(vLine2);
|
|
618
|
+
asrtObj.add(vLine3);
|
|
619
|
+
mBox.visible = false;
|
|
620
|
+
asrtObj.add(mBox);
|
|
621
|
+
asrtObj.scale.set(1 / object.scale.x, object.scale.y, 1 / object.scale.z);
|
|
622
|
+
//asrtObj.translateY(newAltitude / scalevec.y);
|
|
623
|
+
asrtObj.name = 'TransformGizmo';
|
|
624
|
+
// add assets Objects Group
|
|
625
|
+
object1.add(asrtObj);
|
|
626
|
+
|
|
627
|
+
// recover objects transform
|
|
628
|
+
object1.position.x = posVec.x;
|
|
629
|
+
object1.position.y = posVec.y;
|
|
630
|
+
object1.position.z = posVec.z;
|
|
631
|
+
object1.scale.set(scalevec.x, scalevec.y, scalevec.z);
|
|
632
|
+
setTimeout(function () {
|
|
633
|
+
SceneCreator.getDistances(layer);
|
|
634
|
+
}, 100);
|
|
635
|
+
}
|
|
636
|
+
var flip_doorhandle = element.properties.get('flip_doorhandle');
|
|
637
|
+
if (flip_doorhandle) {
|
|
638
|
+
SceneCreator.updateDoorHandleMesh(element, object1, true);
|
|
639
|
+
}
|
|
640
|
+
object1.traverse(function (obj) {
|
|
641
|
+
if (obj.type === _constants.OBJTYPE_MESH) {
|
|
642
|
+
var name = obj.name;
|
|
643
|
+
if (name.match(/_door_.*_glass_/)) {
|
|
644
|
+
var material = new Three.MeshPhysicalMaterial({
|
|
645
|
+
roughness: 0,
|
|
646
|
+
transmission: 1,
|
|
647
|
+
thickness: 0.5,
|
|
648
|
+
// Add refraction!
|
|
649
|
+
transparency: 0.8
|
|
650
|
+
});
|
|
651
|
+
obj.material = material;
|
|
652
|
+
} else if (name.startsWith('sink_')) {
|
|
653
|
+
// texture = loadTexture('/assets/img/texture/steel.jpg');
|
|
654
|
+
|
|
655
|
+
var _material;
|
|
656
|
+
// Get color from name
|
|
657
|
+
if (name.includes('black') || name.includes('white')) {
|
|
658
|
+
var _color2;
|
|
659
|
+
if (name.includes('black')) {
|
|
660
|
+
_color2 = new Three.Color(0x555555).convertLinearToSRGB();
|
|
661
|
+
} else {
|
|
662
|
+
_color2 = 0xffffff;
|
|
663
|
+
}
|
|
664
|
+
_material = new Three.MeshPhysicalMaterial({
|
|
665
|
+
roughness: 0.5,
|
|
666
|
+
metalness: 0,
|
|
667
|
+
// transmission: 1,
|
|
668
|
+
transparent: true,
|
|
669
|
+
opacity: 1,
|
|
670
|
+
thickness: 0.5,
|
|
671
|
+
// Add refraction!
|
|
672
|
+
// transparency: 0.8,
|
|
673
|
+
color: _color2,
|
|
674
|
+
side: Three.DoubleSide
|
|
675
|
+
});
|
|
676
|
+
} else {
|
|
677
|
+
// if (name.includes('chrome')) {
|
|
678
|
+
_material = new Three.MeshPhysicalMaterial({
|
|
679
|
+
roughness: 0.2,
|
|
680
|
+
metalness: 1,
|
|
681
|
+
reflectivity: 0.5,
|
|
682
|
+
color: new Three.Color(0xdddddd).convertLinearToSRGB()
|
|
683
|
+
});
|
|
684
|
+
}
|
|
685
|
+
obj.material = _material;
|
|
686
|
+
}
|
|
687
|
+
}
|
|
688
|
+
if (element.toJS().properties.open_doors) {
|
|
689
|
+
var open_doors = element.toJS().properties.open_doors;
|
|
690
|
+
var object_match = obj.name.match(/\d_(interior_drawer[^LR1-9]*)(_[LR1-9])?$/) || obj.name.match(matchStr);
|
|
691
|
+
if (object_match && object_match.length > 2) {
|
|
692
|
+
var isDoor = object_match[1] === 'door';
|
|
693
|
+
if (isDoor) {
|
|
694
|
+
var offsetData = object1.userData.door_animate_offset[obj.name];
|
|
695
|
+
// Open Door
|
|
696
|
+
(0, _helper.animateDoor)(offsetData, obj, open_doors, element.toJS(), is_corner, 'Opened2D');
|
|
697
|
+
} else {
|
|
698
|
+
// Open Drawer
|
|
699
|
+
(0, _helper.translateDrawer)(element.toJS(), obj, open_doors, 'Opened2D');
|
|
700
|
+
}
|
|
701
|
+
}
|
|
702
|
+
}
|
|
703
|
+
});
|
|
704
|
+
return object1;
|
|
705
|
+
};
|
|
706
|
+
// keys in structure
|
|
707
|
+
var keys = Object.keys(structure);
|
|
708
|
+
// if exist in cached Objects
|
|
709
|
+
if (element.type + color + 'doorStyle' + JSON.stringify(doorStyles.toJS()) + element.counterTop.uri in cachedObject) {
|
|
710
|
+
var _objGroup = cachedObject[element.type + color + 'doorStyle' + JSON.stringify(doorStyles.toJS())].clone();
|
|
711
|
+
return Promise.resolve(onLoadItem(_objGroup.clone()));
|
|
712
|
+
}
|
|
713
|
+
|
|
714
|
+
// base Object/////
|
|
715
|
+
var objGroup = null;
|
|
716
|
+
var _loadGLTFs = function loadGLTFs(i) {
|
|
717
|
+
if (keys[i] === 'animation') {
|
|
718
|
+
// if animation info
|
|
719
|
+
i++;
|
|
720
|
+
return _loadGLTFs(i);
|
|
721
|
+
}
|
|
722
|
+
if (keys[i] === 'placeholders') {
|
|
723
|
+
// if placeholders group
|
|
724
|
+
i++;
|
|
725
|
+
return _loadGLTFs(i);
|
|
726
|
+
}
|
|
727
|
+
if (i === keys.length) {
|
|
728
|
+
// if end of keys
|
|
729
|
+
cachedObject[element.type + color + 'doorStyle' + JSON.stringify(doorStyles.toJS())] = objGroup.clone(); //register to cachedObject
|
|
730
|
+
return onLoadItem(cachedObject[element.type + color + 'doorStyle' + JSON.stringify(doorStyles.toJS())].clone());
|
|
731
|
+
}
|
|
732
|
+
if (keys[i] === 'base') {
|
|
733
|
+
// if base Objects
|
|
734
|
+
i++;
|
|
735
|
+
return _loadGLTFs(i);
|
|
736
|
+
}
|
|
737
|
+
var phsArray = [];
|
|
738
|
+
var placeholderStructure = placeholders[keys[i]];
|
|
739
|
+
if (placeholderStructure == undefined || placeholderStructure.length == 0) {
|
|
740
|
+
i++;
|
|
741
|
+
return _loadGLTFs(i);
|
|
742
|
+
}
|
|
743
|
+
for (var j = 0; j < placeholderStructure.length; j++) {
|
|
744
|
+
var phData = placeholderStructure[j];
|
|
745
|
+
var phs = phData.split('/');
|
|
746
|
+
var temp = phData.split('/');
|
|
747
|
+
// placeholder remake////////////////
|
|
748
|
+
for (var k = 0; k < phs.length; k++) {
|
|
749
|
+
if (phs[k] in placeholders) {
|
|
750
|
+
var placeholderphs = placeholders[phs[k]];
|
|
751
|
+
var key = placeholderStructure.length / placeholderphs.length;
|
|
752
|
+
phs[k] = placeholderphs[Math.floor(j / key)];
|
|
753
|
+
var splitedData = phs[k].split('/');
|
|
754
|
+
if (splitedData.length > 1) {
|
|
755
|
+
phs[k] = splitedData[splitedData.length - 1];
|
|
756
|
+
for (var m = splitedData.length - 2; m >= 0; m--) {
|
|
757
|
+
phs.unshift(splitedData[m]);
|
|
758
|
+
temp.unshift(splitedData[m]);
|
|
759
|
+
}
|
|
760
|
+
}
|
|
761
|
+
k = -1;
|
|
762
|
+
continue;
|
|
763
|
+
}
|
|
764
|
+
if (phs[k].indexOf('ph') == -1) {
|
|
765
|
+
var _url = structure[temp[k - 1]];
|
|
766
|
+
if (temp[k - 1] + '_doorStyle' + element.type + 'doorStyle' + JSON.stringify(doorStyles.toJS()) in structure) {
|
|
767
|
+
if (structure[temp[k - 1] + '_doorStyle' + element.type + 'doorStyle' + JSON.stringify(doorStyles.toJS())] != null) {
|
|
768
|
+
_url = structure[temp[k - 1] + '_doorStyle' + element.type + 'doorStyle' + JSON.stringify(doorStyles.toJS())];
|
|
769
|
+
}
|
|
770
|
+
}
|
|
771
|
+
if (_typeof(_url) == Array) _url = _url[0];
|
|
772
|
+
var uData = _url.split('/');
|
|
773
|
+
uData = uData[uData.length - 1];
|
|
774
|
+
uData = uData.slice(0, -5);
|
|
775
|
+
var datas = uData.split('_');
|
|
776
|
+
uData = datas[1];
|
|
777
|
+
for (var _i = 2; _i < datas.length; _i++) {
|
|
778
|
+
uData += '_';
|
|
779
|
+
uData += datas[_i];
|
|
780
|
+
}
|
|
781
|
+
uData = mainName.replace('main', uData);
|
|
782
|
+
phs[k] = 'ph_' + uData + '_' + phs[k];
|
|
783
|
+
}
|
|
784
|
+
}
|
|
785
|
+
phsArray.push(phs);
|
|
786
|
+
}
|
|
787
|
+
var url = structure[keys[i]];
|
|
788
|
+
var normalMap = '';
|
|
789
|
+
var urlData = url.split('/');
|
|
790
|
+
for (var _j = 0; _j < element.submodule.size; _j++) {
|
|
791
|
+
var replaceUrlData = element.submodule.get(_j).split('/');
|
|
792
|
+
if (urlData.includes(replaceUrlData[replaceUrlData.length - 2])) {
|
|
793
|
+
url = element.submodule.get(_j);
|
|
794
|
+
break;
|
|
795
|
+
}
|
|
796
|
+
}
|
|
797
|
+
for (var _j2 = 0; _j2 < element.normalMap.size; _j2++) {
|
|
798
|
+
var normalMapData = element.normalMap.get(_j2).split('/');
|
|
799
|
+
if (urlData.includes(normalMapData[normalMapData.length - 2])) {
|
|
800
|
+
normalMap = element.normalMap.get(_j2);
|
|
801
|
+
break;
|
|
802
|
+
}
|
|
803
|
+
}
|
|
804
|
+
|
|
805
|
+
// replace submodule gltf file
|
|
806
|
+
// if (placeholderTree.length > 0) {
|
|
807
|
+
if (phsArray.length > 0) {
|
|
808
|
+
// let loadUrl = dirName + url;
|
|
809
|
+
var loadUrl = url;
|
|
810
|
+
if (doorStyles.get(keys[i] + '_gltf') != undefined) {
|
|
811
|
+
loadUrl = doorStyles.get(keys[i] + '_gltf');
|
|
812
|
+
structure[keys[i] + '_doorStyle' + element.type + 'doorStyle' + JSON.stringify(doorStyles.toJS())] = loadUrl;
|
|
813
|
+
} else {
|
|
814
|
+
structure[keys[i] + '_doorStyle' + element.type + 'doorStyle' + JSON.stringify(doorStyles.toJS())] = null;
|
|
815
|
+
}
|
|
816
|
+
return (0, _loadObj.loadGLTF)(loadUrl).then(function (object) {
|
|
817
|
+
if (normalMap !== '') {
|
|
818
|
+
var normalUrl = normalMap.split('.')[0] + '-normal.' + normalMap.split('.')[1];
|
|
819
|
+
var t = loadTexture(normalMap);
|
|
820
|
+
var _m = loadTexture(normalUrl);
|
|
821
|
+
var mat2 = new Three.MeshStandardMaterial({
|
|
822
|
+
metalness: glossness === 1 ? params.metalness : params.metalness_glossy,
|
|
823
|
+
roughness: glossness || params.roughness
|
|
824
|
+
});
|
|
825
|
+
mat2.map = t;
|
|
826
|
+
mat2.normalMap = _m;
|
|
827
|
+
// mat2.envMap = textureCube;
|
|
828
|
+
for (var _j3 = 0; _j3 < object.children.length; _j3++) {
|
|
829
|
+
if (object.children[_j3].type === _constants.OBJTYPE_MESH) {
|
|
830
|
+
object.children[_j3].material = mat2;
|
|
831
|
+
object.children[_j3].receiveShadow = true;
|
|
832
|
+
}
|
|
833
|
+
}
|
|
834
|
+
}
|
|
835
|
+
|
|
836
|
+
// set Door Style////
|
|
837
|
+
if (doorStyles != null) if (doorStyles.get(keys[i]) != undefined) {
|
|
838
|
+
// let normalMap = "catalog/items/doorstyle/" + doorStyles.get(keys[i]);
|
|
839
|
+
var _normalMap = doorStyles.get(keys[i]);
|
|
840
|
+
var _mat;
|
|
841
|
+
if (_normalMap === '') {
|
|
842
|
+
var examplecolor = new Three.Color(parseInt(color.slice(1), 16)).convertLinearToSRGB();
|
|
843
|
+
_mat = new Three.MeshStandardMaterial({
|
|
844
|
+
color: examplecolor,
|
|
845
|
+
metalness: glossness === 1 ? params.metalness : params.metalness_glossy,
|
|
846
|
+
roughness: glossness || params.roughness
|
|
847
|
+
});
|
|
848
|
+
} else {
|
|
849
|
+
var _t = loadTexture(_normalMap);
|
|
850
|
+
_mat = new Three.MeshStandardMaterial({
|
|
851
|
+
// NOTE : this is for cabinets (wood) frontface
|
|
852
|
+
metalness: 0.1,
|
|
853
|
+
roughness: 0.5
|
|
854
|
+
// metalness: glossness === 1 ? params.metalness : params.metalness_glossy,
|
|
855
|
+
// roughness: glossness || params.roughness
|
|
856
|
+
});
|
|
857
|
+
_mat.map = _t;
|
|
858
|
+
}
|
|
859
|
+
// mat2.envMap = textureCube;
|
|
860
|
+
for (var _j4 = 0; _j4 < object.children.length; _j4++) {
|
|
861
|
+
if (object.children[_j4].type === _constants.OBJTYPE_MESH) {
|
|
862
|
+
object.children[_j4].material = _mat;
|
|
863
|
+
object.children[_j4].receiveShadow = true;
|
|
864
|
+
object.children[_j4].castShadow = true;
|
|
865
|
+
!object.children[_j4].name.includes('handle') && addEdgesToMesh(object.children[_j4]);
|
|
866
|
+
} else if (!object.children[_j4].name.startsWith('ph_') && object.children[_j4].type === _constants.OBJTYPE_GROUP) {
|
|
867
|
+
object.children[_j4].traverse(function (prim) {
|
|
868
|
+
prim.material = _mat;
|
|
869
|
+
prim.receiveShadow = true;
|
|
870
|
+
});
|
|
871
|
+
}
|
|
872
|
+
}
|
|
873
|
+
} else {
|
|
874
|
+
var _mat2 = new Three.MeshStandardMaterial({
|
|
875
|
+
metalness: glossness === 1 ? params.metalness : params.metalness_glossy,
|
|
876
|
+
roughness: glossness || params.roughness
|
|
877
|
+
});
|
|
878
|
+
// mat2.envMap = textureCube;
|
|
879
|
+
for (var _j5 = 0; _j5 < object.children.length; _j5++) {
|
|
880
|
+
if (object.children[_j5].type === _constants.OBJTYPE_MESH) {
|
|
881
|
+
object.children[_j5].material = _mat2;
|
|
882
|
+
object.children[_j5].receiveShadow = true;
|
|
883
|
+
}
|
|
884
|
+
}
|
|
885
|
+
}
|
|
886
|
+
for (var _i2 = 0; _i2 < phsArray.length; _i2++) {
|
|
887
|
+
var _phs = phsArray[_i2];
|
|
888
|
+
var parent = objGroup;
|
|
889
|
+
for (var _j6 = 0; _j6 < _phs.length; _j6++) {
|
|
890
|
+
var placeholder = _phs[_j6];
|
|
891
|
+
for (var _k = 0; _k < ((_parent = parent) === null || _parent === void 0 ? void 0 : _parent.children.length); _k++) {
|
|
892
|
+
var _parent;
|
|
893
|
+
if (_j6 != _phs.length - 1) {
|
|
894
|
+
if (parent.children[_k].name == placeholder) {
|
|
895
|
+
parent = parent.children[_k].children[0];
|
|
896
|
+
break;
|
|
897
|
+
}
|
|
898
|
+
} else {
|
|
899
|
+
if (parent.children[_k].name == placeholder) {
|
|
900
|
+
var tmp = object.clone();
|
|
901
|
+
if (placeholder.includes('drawer_door') && placeholder.includes('_handle')) {
|
|
902
|
+
tmp.rotateZ(Math.PI / 2);
|
|
903
|
+
}
|
|
904
|
+
if (placeholder.includes('_handle') && tmp.children[0].type === _constants.OBJTYPE_MESH) {
|
|
905
|
+
// NOTE: change metalness of handle
|
|
906
|
+
tmp.children[0].material.metalness = 1;
|
|
907
|
+
// handleMaterial.metalness || 0.2;
|
|
908
|
+
tmp.children[0].material.roughness = handleMaterial.roughness || 0.1;
|
|
909
|
+
//tmp.children[0].material.map = loadTexture('catalog/areas/area/textures/grass.jpg');
|
|
910
|
+
}
|
|
911
|
+
parent.children[_k].add(tmp);
|
|
912
|
+
}
|
|
913
|
+
}
|
|
914
|
+
}
|
|
915
|
+
}
|
|
916
|
+
}
|
|
917
|
+
}, function (reason) {
|
|
918
|
+
console.log('loadGLTF failed for reason:', reason);
|
|
919
|
+
}).then(function () {
|
|
920
|
+
i++;
|
|
921
|
+
return _loadGLTFs(i);
|
|
922
|
+
});
|
|
923
|
+
}
|
|
924
|
+
};
|
|
925
|
+
return (0, _loadObj.loadGLTF)(structure['base']).then(function (object) {
|
|
926
|
+
object.name = 'MainObject';
|
|
927
|
+
object.receiveShadow = true;
|
|
928
|
+
objGroup = object;
|
|
929
|
+
if (doorStyles != null) if (doorStyles.get('base') != undefined) {
|
|
930
|
+
var normalMap = doorStyles.get('base');
|
|
931
|
+
if (counterTop.uri === undefined) {
|
|
932
|
+
try {
|
|
933
|
+
counterTop = counterTop.toJS();
|
|
934
|
+
} catch (error) {
|
|
935
|
+
console.log(error);
|
|
936
|
+
}
|
|
937
|
+
}
|
|
938
|
+
if (counterTop.uri === undefined && layer.toJS().counterTop.uri !== undefined) {
|
|
939
|
+
counterTop.uri = layer.toJS().counterTop.uri;
|
|
940
|
+
}
|
|
941
|
+
var countTopMap = counterTop.uri;
|
|
942
|
+
var interiorMap = doorStyles.get('interior');
|
|
943
|
+
var countT = loadTexture(countTopMap);
|
|
944
|
+
countT.wrapS = Three.RepeatWrapping;
|
|
945
|
+
countT.wrapT = Three.RepeatWrapping;
|
|
946
|
+
countT.repeat.set(1, 1);
|
|
947
|
+
var examplecolor = new Three.Color(parseInt(color.slice(1), 16)).convertLinearToSRGB();
|
|
948
|
+
var mat2 = null,
|
|
949
|
+
mat3 = null,
|
|
950
|
+
mat4 = null;
|
|
951
|
+
if (normalMap === '') {
|
|
952
|
+
mat2 = new Three.MeshStandardMaterial({
|
|
953
|
+
color: examplecolor,
|
|
954
|
+
metalness: glossness === 1 ? params.metalness : params.metalness_glossy,
|
|
955
|
+
roughness: glossness || params.roughness
|
|
956
|
+
});
|
|
957
|
+
} else {
|
|
958
|
+
mat2 = new Three.MeshStandardMaterial({
|
|
959
|
+
// TODO: changes in metalness and roughness of base_main (cabinet wood)
|
|
960
|
+
metalness: 0.1,
|
|
961
|
+
roughness: 0.5
|
|
962
|
+
// metalness: glossness === 1 ? params.metalness : params.metalness_glossy,
|
|
963
|
+
// roughness: glossness || params.roughness
|
|
964
|
+
});
|
|
965
|
+
}
|
|
966
|
+
// mat2.envMap = textureCube;
|
|
967
|
+
|
|
968
|
+
if (normalMap !== '') {
|
|
969
|
+
var t = loadTexture(normalMap);
|
|
970
|
+
mat2.map = t;
|
|
971
|
+
}
|
|
972
|
+
if (normalMap === '') {
|
|
973
|
+
mat3 = new Three.MeshStandardMaterial({
|
|
974
|
+
// color: examplecolor,
|
|
975
|
+
metalness: counterTop.metalness,
|
|
976
|
+
roughness: counterTop.roughness
|
|
977
|
+
});
|
|
978
|
+
} else {
|
|
979
|
+
mat3 = new Three.MeshStandardMaterial({
|
|
980
|
+
// metalness: counterTop.metalness,
|
|
981
|
+
// roughness: counterTop.roughness
|
|
982
|
+
metalness: 0.3,
|
|
983
|
+
roughness: 0.8
|
|
984
|
+
});
|
|
985
|
+
}
|
|
986
|
+
mat3.map = countT;
|
|
987
|
+
// mat3.envMap = textureCube;
|
|
988
|
+
mat4 = new Three.MeshStandardMaterial({
|
|
989
|
+
metalness: params.metalness,
|
|
990
|
+
roughness: params.roughness
|
|
991
|
+
});
|
|
992
|
+
mat4.map = loadTexture(interiorMap);
|
|
993
|
+
for (var j = 0; j < object.children.length; j++) {
|
|
994
|
+
if (object.children[j].name.includes('main')) {}
|
|
995
|
+
if (object.children[j].name.includes('countertop')) {
|
|
996
|
+
object.children[j].material = mat3;
|
|
997
|
+
object.children[j].receiveShadow = true;
|
|
998
|
+
object.children[j].castShadow = true;
|
|
999
|
+
addEdgesToMesh(object.children[j]);
|
|
1000
|
+
} else if (object.children[j].name.includes('_interior_')) {
|
|
1001
|
+
object.children[j].material = mat4;
|
|
1002
|
+
} else if (object.children[j].type === _constants.OBJTYPE_MESH) {
|
|
1003
|
+
object.children[j].material = mat2;
|
|
1004
|
+
object.children[j].receiveShadow = true;
|
|
1005
|
+
object.children[j].castShadow = true;
|
|
1006
|
+
}
|
|
1007
|
+
}
|
|
1008
|
+
}
|
|
1009
|
+
}, function (reason) {
|
|
1010
|
+
console.log('loadGLTF failed for reason:', reason);
|
|
1011
|
+
objGroup = GeomUtils.emptyBoxHolder(newWidth, newHeight, newDepth);
|
|
1012
|
+
}).then(function () {
|
|
1013
|
+
return _loadGLTFs(0);
|
|
1014
|
+
});
|
|
1015
|
+
}
|
|
1016
|
+
|
|
1017
|
+
// render 3d appliance function ////////////////////////////////
|
|
1018
|
+
function render3DApplianceItem(element, layer, scene, sizeinfo, structure_json) {
|
|
1019
|
+
var mode = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : null;
|
|
1020
|
+
var structure = structure_json;
|
|
1021
|
+
var applianceMaterial = element.applianceMaterial;
|
|
1022
|
+
if (applianceMaterial.metalness == undefined) applianceMaterial = applianceMaterial.toJS();
|
|
1023
|
+
var onLoadItem = function onLoadItem(object) {
|
|
1024
|
+
var newAltitude = element.properties.get('altitude').get('_length');
|
|
1025
|
+
var newUnit = element.properties.get('altitude').get('_unit') || 'in';
|
|
1026
|
+
newAltitude = (0, _convertUnits["default"])(newAltitude).from(newUnit).to(scene.unit);
|
|
1027
|
+
var newWidth = element.properties.get('width').get('_length');
|
|
1028
|
+
var newWidthUnit = element.properties.get('width').get('_unit') || 'in';
|
|
1029
|
+
newWidth = (0, _convertUnits["default"])(newWidth).from(newWidthUnit).to('in');
|
|
1030
|
+
var newHeight = element.properties.get('height').get('_length');
|
|
1031
|
+
var newHeightUnit = element.properties.get('height').get('_unit') || 'in';
|
|
1032
|
+
newHeight = (0, _convertUnits["default"])(newHeight).from(newHeightUnit).to('in');
|
|
1033
|
+
var newDepth = element.properties.get('depth').get('_length');
|
|
1034
|
+
var newDepthUnit = element.properties.get('depth').get('_unit') || 'in';
|
|
1035
|
+
newDepth = (0, _convertUnits["default"])(newDepth).from(newDepthUnit).to('in');
|
|
1036
|
+
object.scale.set(100 * newWidth / sizeinfo.width, 100 * newHeight / sizeinfo.height, 100 * newDepth / sizeinfo.depth);
|
|
1037
|
+
// Normalize the origin of the object
|
|
1038
|
+
var boundingBox = new Three.Box3().setFromObject(object);
|
|
1039
|
+
object.userData = boundingBox;
|
|
1040
|
+
var center = [(boundingBox.max.x - boundingBox.min.x) / 2 + boundingBox.min.x, (boundingBox.max.y - boundingBox.min.y) / 2 + boundingBox.min.y, (boundingBox.max.z - boundingBox.min.z) / 2 + boundingBox.min.z];
|
|
1041
|
+
object.position.x -= center[0];
|
|
1042
|
+
object.position.y -= center[1] - (boundingBox.max.y - boundingBox.min.y) / 2;
|
|
1043
|
+
object.position.z -= center[2];
|
|
1044
|
+
object.position.y += newAltitude;
|
|
1045
|
+
object.traverse(function (obj) {
|
|
1046
|
+
if (obj.type === _constants.OBJTYPE_MESH) {
|
|
1047
|
+
var name = obj.name;
|
|
1048
|
+
var texture,
|
|
1049
|
+
textureLoader = new Three.TextureLoader();
|
|
1050
|
+
if (name.includes('_black')) {
|
|
1051
|
+
obj.material.roughness = 0.4;
|
|
1052
|
+
obj.material.metalness = 1.0;
|
|
1053
|
+
obj.material.color = new Three.Color(0, 0, 0);
|
|
1054
|
+
obj.castShadow = true;
|
|
1055
|
+
obj.receiveShadow = true;
|
|
1056
|
+
return object;
|
|
1057
|
+
} else if (name.includes('_wood')) {
|
|
1058
|
+
texture = loadTexture('/assets/img/texture/wood.jpg');
|
|
1059
|
+
} else if (name.includes('_glass')) {
|
|
1060
|
+
// texture = loadTexture('/assets/img/texture/glass.jpg');
|
|
1061
|
+
var material = new Three.MeshPhysicalMaterial({
|
|
1062
|
+
transparent: true,
|
|
1063
|
+
opacity: 0.5,
|
|
1064
|
+
roughness: 0,
|
|
1065
|
+
transmission: 1,
|
|
1066
|
+
thickness: 0.5,
|
|
1067
|
+
// Add refraction!
|
|
1068
|
+
transparency: 0.8
|
|
1069
|
+
});
|
|
1070
|
+
obj.material = material;
|
|
1071
|
+
obj.castShadow = true;
|
|
1072
|
+
obj.receiveShadow = true;
|
|
1073
|
+
return object;
|
|
1074
|
+
} else if (name.includes('_steel')) {
|
|
1075
|
+
// texture = loadTexture('/assets/img/texture/steel.jpg');
|
|
1076
|
+
var _material2 = new Three.MeshPhysicalMaterial({
|
|
1077
|
+
roughness: 0.2,
|
|
1078
|
+
metalness: 0.5,
|
|
1079
|
+
reflectivity: 0.5,
|
|
1080
|
+
color: new Three.Color(0xdddddd).convertLinearToSRGB()
|
|
1081
|
+
});
|
|
1082
|
+
obj.material = _material2;
|
|
1083
|
+
obj.castShadow = true;
|
|
1084
|
+
obj.receiveShadow = true;
|
|
1085
|
+
return object;
|
|
1086
|
+
}
|
|
1087
|
+
var mat = new Three.MeshStandardMaterial({
|
|
1088
|
+
metalness: 0.1,
|
|
1089
|
+
roughness: 0.9,
|
|
1090
|
+
map: texture
|
|
1091
|
+
});
|
|
1092
|
+
obj.material = mat;
|
|
1093
|
+
}
|
|
1094
|
+
});
|
|
1095
|
+
if (element.selected) {
|
|
1096
|
+
// if object is selected
|
|
1097
|
+
// save object transform info///
|
|
1098
|
+
var scalevec = new Three.Vector3(object.scale.x, object.scale.y, object.scale.z);
|
|
1099
|
+
var posVec = new Three.Vector3(object.position.x, object.position.y, object.position.z);
|
|
1100
|
+
object.scale.set(1 * newWidth / sizeinfo.width, 1 * newHeight / sizeinfo.height, 1 * newDepth / sizeinfo.depth);
|
|
1101
|
+
object.position.set(0, 0, 0);
|
|
1102
|
+
object.rotation.set(0, 0, 0);
|
|
1103
|
+
var _boundingBox2 = new Three.Box3().setFromObject(object);
|
|
1104
|
+
var max = _boundingBox2.max;
|
|
1105
|
+
var min = _boundingBox2.min;
|
|
1106
|
+
var radius = Math.sqrt((_boundingBox2.max.x - _boundingBox2.min.x) * (_boundingBox2.max.x - _boundingBox2.min.x) + (_boundingBox2.max.z - _boundingBox2.min.z) * (_boundingBox2.max.z - _boundingBox2.min.z)) / 2;
|
|
1107
|
+
var moveBox = new Three.BoxGeometry(max.x - min.x, max.y - min.y, max.z - min.z);
|
|
1108
|
+
|
|
1109
|
+
// translate Object
|
|
1110
|
+
var controlGeom = GeomUtils.controlGeom();
|
|
1111
|
+
// ////////////////////////
|
|
1112
|
+
|
|
1113
|
+
// rotate Object //////////
|
|
1114
|
+
var rotGeom = GeomUtils.rotGeoms(radius + 0.05);
|
|
1115
|
+
// //////////////////////////////////
|
|
1116
|
+
|
|
1117
|
+
// upwards Geometry/////////// Move up Object
|
|
1118
|
+
var upwardsGeom = GeomUtils.upwardsGeom();
|
|
1119
|
+
// ///////////////////////////////////////
|
|
1120
|
+
|
|
1121
|
+
// vertical line - 4 lines around object//////////////////////////
|
|
1122
|
+
var vLineGeom = new Three.BufferGeometry();
|
|
1123
|
+
var vertices = [(max.x - min.x) / 2 + min.x, 0, min.z, (max.x - min.x) / 2 + min.x, 0, min.z + 1.3];
|
|
1124
|
+
vLineGeom.setAttribute('position', new Three.BufferAttribute(new Float32Array(vertices), 3));
|
|
1125
|
+
var vLineGeom1 = new Three.BufferGeometry();
|
|
1126
|
+
var vertices1 = [(max.x - min.x) / 2 + min.x, 0, min.z, (max.x - min.x) / 2 + min.x, 0, min.z - 1.3];
|
|
1127
|
+
vLineGeom1.setAttribute('position', new Three.BufferAttribute(new Float32Array(vertices1), 3));
|
|
1128
|
+
var vLineGeom2 = new Three.BufferGeometry();
|
|
1129
|
+
var vertices2 = [max.x, 0, max.z - (max.z - min.z) / 2, max.x + 1.3, 0, max.z - (max.z - min.z) / 2];
|
|
1130
|
+
vLineGeom1.setAttribute('position', new Three.BufferAttribute(new Float32Array(vertices2), 3));
|
|
1131
|
+
var vLineGeom3 = new Three.BufferGeometry();
|
|
1132
|
+
var vertices3 = [min.x, 0, max.z - (max.z - min.z) / 2, min.x - 1.3, 0, max.z - (max.z - min.z) / 2];
|
|
1133
|
+
vLineGeom1.setAttribute('position', new Three.BufferAttribute(new Float32Array(vertices3), 3));
|
|
1134
|
+
// ///////////////////////////////////////
|
|
1135
|
+
|
|
1136
|
+
// set names of transform object
|
|
1137
|
+
var rotFillObj = new Three.Mesh(rotGeom.rotFill, new Three.MeshPhongMaterial({
|
|
1138
|
+
color: 0x000000,
|
|
1139
|
+
side: Three.DoubleSide,
|
|
1140
|
+
colorWrite: true
|
|
1141
|
+
}));
|
|
1142
|
+
var rotStrokeObj = new Three.Line(rotGeom.rotStroke, new Three.LineBasicMaterial({
|
|
1143
|
+
color: 0xffffff,
|
|
1144
|
+
colorWrite: true
|
|
1145
|
+
}));
|
|
1146
|
+
rotFillObj.name = 'rotate';
|
|
1147
|
+
var upObj = new Three.Mesh(upwardsGeom, new Three.MeshBasicMaterial({
|
|
1148
|
+
color: 0xffffff,
|
|
1149
|
+
side: Three.DoubleSide
|
|
1150
|
+
}));
|
|
1151
|
+
upObj.name = 'transUp';
|
|
1152
|
+
var mBox = new Three.Mesh(moveBox, new Three.MeshBasicMaterial({
|
|
1153
|
+
color: new Three.Color(0xdd6699).convertLinearToSRGB(),
|
|
1154
|
+
side: Three.DoubleSide,
|
|
1155
|
+
transparent: true,
|
|
1156
|
+
opacity: 0.4
|
|
1157
|
+
}));
|
|
1158
|
+
var color = new Three.Color(_constants.ARROW_COLOR).convertLinearToSRGB();
|
|
1159
|
+
var vLine = new Three.Line(vLineGeom, new Three.LineBasicMaterial({
|
|
1160
|
+
color: color
|
|
1161
|
+
}));
|
|
1162
|
+
var vLine1 = new Three.Line(vLineGeom1, new Three.LineBasicMaterial({
|
|
1163
|
+
color: color
|
|
1164
|
+
}));
|
|
1165
|
+
var vLine2 = new Three.Line(vLineGeom2, new Three.LineBasicMaterial({
|
|
1166
|
+
color: color
|
|
1167
|
+
}));
|
|
1168
|
+
var vLine3 = new Three.Line(vLineGeom3, new Three.LineBasicMaterial({
|
|
1169
|
+
color: color
|
|
1170
|
+
}));
|
|
1171
|
+
vLine.renderOrder = 1;
|
|
1172
|
+
vLine1.renderOrder = 1;
|
|
1173
|
+
vLine2.renderOrder = 1;
|
|
1174
|
+
vLine3.renderOrder = 1;
|
|
1175
|
+
vLine.material.transparent = true;
|
|
1176
|
+
vLine1.material.transparent = true;
|
|
1177
|
+
vLine2.material.transparent = true;
|
|
1178
|
+
vLine3.material.transparent = true;
|
|
1179
|
+
vLine.material.depthTest = false;
|
|
1180
|
+
vLine1.material.depthTest = false;
|
|
1181
|
+
vLine2.material.depthTest = false;
|
|
1182
|
+
vLine3.material.depthTest = false;
|
|
1183
|
+
// translate vector to center of object
|
|
1184
|
+
var uVec = new Three.Vector3(-posVec.x / scalevec.x, -posVec.y / scalevec.y, -posVec.z / scalevec.z);
|
|
1185
|
+
vLine.translateY(0.1);
|
|
1186
|
+
vLine1.translateY(0.1);
|
|
1187
|
+
vLine2.translateY(0.1);
|
|
1188
|
+
vLine3.translateY(0.1);
|
|
1189
|
+
upObj.translateOnAxis(uVec, 1);
|
|
1190
|
+
upObj.translateY(max.y - min.y + 0.05);
|
|
1191
|
+
mBox.name = 'TransformBox';
|
|
1192
|
+
mBox.translateOnAxis(new Three.Vector3(uVec.x, uVec.y + (max.y - min.y) / 2, uVec.z), 1);
|
|
1193
|
+
mBox.scale.set(1.01, 1.01, 1.01);
|
|
1194
|
+
|
|
1195
|
+
// other side rotate object
|
|
1196
|
+
var rotFillObj1 = rotFillObj.clone();
|
|
1197
|
+
var rotStrokeObj1 = rotStrokeObj.clone();
|
|
1198
|
+
rotFillObj1.rotateY(Math.PI);
|
|
1199
|
+
rotStrokeObj1.rotateY(Math.PI);
|
|
1200
|
+
rotFillObj.translateY(0.1);
|
|
1201
|
+
rotFillObj1.translateY(0.1);
|
|
1202
|
+
rotStrokeObj.translateY(0.1);
|
|
1203
|
+
rotStrokeObj1.translateY(0.1);
|
|
1204
|
+
|
|
1205
|
+
// assets Objects group includes rotate objects...
|
|
1206
|
+
var asrtObj = new Three.Group();
|
|
1207
|
+
// asrtObj.add(rotFillObj);
|
|
1208
|
+
// asrtObj.add(rotFillObj1);
|
|
1209
|
+
// asrtObj.add(rotStrokeObj);
|
|
1210
|
+
// asrtObj.add(rotStrokeObj1);
|
|
1211
|
+
asrtObj.add(vLine);
|
|
1212
|
+
asrtObj.add(vLine1);
|
|
1213
|
+
asrtObj.add(vLine2);
|
|
1214
|
+
asrtObj.add(vLine3);
|
|
1215
|
+
mBox.visible = false;
|
|
1216
|
+
asrtObj.add(mBox);
|
|
1217
|
+
asrtObj.scale.set(1 / object.scale.x, object.scale.y, 1 / object.scale.z);
|
|
1218
|
+
// asrtObj.translateY(newAltitude / scalevec.y);
|
|
1219
|
+
asrtObj.name = 'TransformGizmo';
|
|
1220
|
+
// add assets Objects Group
|
|
1221
|
+
object.add(asrtObj);
|
|
1222
|
+
|
|
1223
|
+
// recover objects transform
|
|
1224
|
+
object.position.x = posVec.x;
|
|
1225
|
+
object.position.y = posVec.y;
|
|
1226
|
+
object.position.z = posVec.z;
|
|
1227
|
+
object.scale.set(scalevec.x, scalevec.y, scalevec.z);
|
|
1228
|
+
}
|
|
1229
|
+
return object;
|
|
1230
|
+
};
|
|
1231
|
+
|
|
1232
|
+
// keys in structure
|
|
1233
|
+
var keys = Object.keys(structure);
|
|
1234
|
+
|
|
1235
|
+
// if exist in cached Objects
|
|
1236
|
+
if (element.type in cachedObject) {
|
|
1237
|
+
var _objGroup2 = cachedObject[element.type].clone();
|
|
1238
|
+
return Promise.resolve(onLoadItem(_objGroup2.clone()));
|
|
1239
|
+
}
|
|
1240
|
+
|
|
1241
|
+
// base Object/////
|
|
1242
|
+
var objGroup = null;
|
|
1243
|
+
var _loadGLTFs2 = function loadGLTFs(i) {
|
|
1244
|
+
if (i === keys.length) {
|
|
1245
|
+
// if end of keys
|
|
1246
|
+
cachedObject[element.type] = objGroup.clone(); //register to cachedObject
|
|
1247
|
+
return onLoadItem(cachedObject[element.type].clone());
|
|
1248
|
+
}
|
|
1249
|
+
if (keys[i] === 'base') {
|
|
1250
|
+
// if base Objects
|
|
1251
|
+
i++;
|
|
1252
|
+
return _loadGLTFs2(i);
|
|
1253
|
+
}
|
|
1254
|
+
};
|
|
1255
|
+
|
|
1256
|
+
// load base to start //
|
|
1257
|
+
// return loadGLTF(dirName + structure["base"])
|
|
1258
|
+
return (0, _loadObj.loadGLTF)(structure['base']).then(function (object) {
|
|
1259
|
+
// let textureURL = `${API_SERVER_URL}/uploads/assets/default/steel.jpg`;
|
|
1260
|
+
// let texture = loadTexture(textureURL);
|
|
1261
|
+
// texture.wrapS = Three.MirroredRepeatWrapping;
|
|
1262
|
+
// texture.wrapT = Three.MirroredRepeatWrapping;
|
|
1263
|
+
|
|
1264
|
+
object.name = 'MainObject';
|
|
1265
|
+
// NOTE: changed appliance emissive color to black
|
|
1266
|
+
var mat2 = new Three.MeshStandardMaterial({
|
|
1267
|
+
emissive: new Three.Color(0x0d0d0d).convertLinearToSRGB(),
|
|
1268
|
+
metalness: applianceMaterial.metalness,
|
|
1269
|
+
roughness: applianceMaterial.roughness
|
|
1270
|
+
});
|
|
1271
|
+
// mat2.envMap = textureCube;
|
|
1272
|
+
object.material = mat2;
|
|
1273
|
+
for (var j = 0; j < object.children.length; j++) {
|
|
1274
|
+
if (object.children[j].type === _constants.OBJTYPE_MESH) {
|
|
1275
|
+
object.children[j].material = mat2;
|
|
1276
|
+
object.children[j].receiveShadow = true;
|
|
1277
|
+
object.children[j].castShadow = true; // change
|
|
1278
|
+
}
|
|
1279
|
+
}
|
|
1280
|
+
objGroup = object;
|
|
1281
|
+
}, function (reason) {
|
|
1282
|
+
console.log('loadGLTF failed for reason:', reason);
|
|
1283
|
+
objGroup = GeomUtils.emptyBoxHolder(newWidth, newHeight, newDepth);
|
|
1284
|
+
}).then(function () {
|
|
1285
|
+
return _loadGLTFs2(0);
|
|
1286
|
+
});
|
|
1287
|
+
}
|
|
1288
|
+
// render 3d appliance function ////////////////////////////////
|
|
1289
|
+
function render3DLightingItem(element, layer, scene, sizeinfo, structure_json) {
|
|
1290
|
+
var mode = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : null;
|
|
1291
|
+
var structure = structure_json;
|
|
1292
|
+
var onLoadItem = function onLoadItem(object) {
|
|
1293
|
+
var width = {
|
|
1294
|
+
length: sizeinfo.width,
|
|
1295
|
+
unit: 'in'
|
|
1296
|
+
};
|
|
1297
|
+
var depth = {
|
|
1298
|
+
length: sizeinfo.depth,
|
|
1299
|
+
unit: 'in'
|
|
1300
|
+
};
|
|
1301
|
+
var height = {
|
|
1302
|
+
length: sizeinfo.height,
|
|
1303
|
+
unit: 'in'
|
|
1304
|
+
};
|
|
1305
|
+
var newWidth = (0, _convertUnits["default"])(width.length).from(width.unit).to('cm');
|
|
1306
|
+
var newDepth = (0, _convertUnits["default"])(depth.length).from(depth.unit).to('cm');
|
|
1307
|
+
var newHeight = (0, _convertUnits["default"])(height.length).from(height.unit).to('cm');
|
|
1308
|
+
var newAltitude = element.properties.get('altitude').get('_length');
|
|
1309
|
+
var newUnit = element.properties.get('altitude').get('_unit') || 'in';
|
|
1310
|
+
newAltitude = (0, _convertUnits["default"])(newAltitude).from(newUnit).to(scene.unit);
|
|
1311
|
+
|
|
1312
|
+
//object.scale.set(newWidth, newHeight, newDepth);
|
|
1313
|
+
object.scale.set(100, 100, 100);
|
|
1314
|
+
// Normalize the origin of the object
|
|
1315
|
+
var boundingBox = new Three.Box3().setFromObject(object);
|
|
1316
|
+
object.userData = boundingBox;
|
|
1317
|
+
var objectHeight = boundingBox.max.y - boundingBox.min.y;
|
|
1318
|
+
var objectYPos = boundingBox.min.y;
|
|
1319
|
+
var center = [(boundingBox.max.x - boundingBox.min.x) / 2 + boundingBox.min.x, (boundingBox.max.y - boundingBox.min.y) / 2 + boundingBox.min.y, (boundingBox.max.z - boundingBox.min.z) / 2 + boundingBox.min.z];
|
|
1320
|
+
object.position.x = center[0];
|
|
1321
|
+
object.position.y = newHeight + newAltitude - boundingBox.max.y;
|
|
1322
|
+
object.position.z = center[2];
|
|
1323
|
+
if (element.selected) {
|
|
1324
|
+
// if object is selected
|
|
1325
|
+
// save object transform info///
|
|
1326
|
+
var scalevec = new Three.Vector3(object.scale.x, object.scale.y, object.scale.z);
|
|
1327
|
+
var posVec = new Three.Vector3(object.position.x, object.position.y, object.position.z);
|
|
1328
|
+
object.scale.set(1, 1, 1);
|
|
1329
|
+
object.position.set(0, 0, 0);
|
|
1330
|
+
object.rotation.set(0, 0, 0);
|
|
1331
|
+
|
|
1332
|
+
//let box = new Three.BoxHelper(object, 0xffffff);
|
|
1333
|
+
//box.material.lineWidth = 5;
|
|
1334
|
+
//box.renderOrder = 1000;
|
|
1335
|
+
//box.material.depthTest = false;
|
|
1336
|
+
//object.add(box);
|
|
1337
|
+
var _boundingBox3 = new Three.Box3().setFromObject(object);
|
|
1338
|
+
var max = _boundingBox3.max;
|
|
1339
|
+
var min = _boundingBox3.min;
|
|
1340
|
+
var radius = Math.sqrt((_boundingBox3.max.x - _boundingBox3.min.x) * (_boundingBox3.max.x - _boundingBox3.min.x) + (_boundingBox3.max.z - _boundingBox3.min.z) * (_boundingBox3.max.z - _boundingBox3.min.z)) / 2;
|
|
1341
|
+
var moveBox = new Three.BoxGeometry(max.x - min.x, max.y - min.y, max.z - min.z);
|
|
1342
|
+
|
|
1343
|
+
// translate Object
|
|
1344
|
+
var controlGeom = GeomUtils.controlGeom();
|
|
1345
|
+
|
|
1346
|
+
// rotate Object //////////
|
|
1347
|
+
var rotGeom = GeomUtils.rotGeoms(radius + 0.05);
|
|
1348
|
+
// //////////////////////////////////
|
|
1349
|
+
|
|
1350
|
+
// upwards Geometry/////////// Move up Object
|
|
1351
|
+
var upwardsGeom = GeomUtils.upwardsGeom();
|
|
1352
|
+
|
|
1353
|
+
// vertical line - 4 lines around object//////////////////////////
|
|
1354
|
+
var vLineGeom = new Three.BufferGeometry();
|
|
1355
|
+
var vertices = [(max.x - min.x) / 2 + min.x, 0, min.z, (max.x - min.x) / 2 + min.x, 0, min.z + 1.3];
|
|
1356
|
+
vLineGeom.setAttribute('position', new Three.BufferAttribute(new Float32Array(vertices), 3));
|
|
1357
|
+
var vLineGeom1 = new Three.BufferGeometry();
|
|
1358
|
+
var vertices1 = [(max.x - min.x) / 2 + min.x, 0, min.z, (max.x - min.x) / 2 + min.x, 0, min.z - 1.3];
|
|
1359
|
+
vLineGeom1.setAttribute('position', new Three.BufferAttribute(new Float32Array(vertices1), 3));
|
|
1360
|
+
var vLineGeom2 = new Three.BufferGeometry();
|
|
1361
|
+
var vertices2 = [min.x, 0, max.z - (max.z - min.z) / 2, min.x + 1.3, 0, max.z - (max.z - min.z) / 2];
|
|
1362
|
+
vLineGeom2.setAttribute('position', new Three.BufferAttribute(new Float32Array(vertices2), 3));
|
|
1363
|
+
var vLineGeom3 = new Three.BufferGeometry();
|
|
1364
|
+
var vertices3 = [min.x, 0, max.z - (max.z - min.z) / 2, min.x - 1.3, 0, max.z - (max.z - min.z) / 2];
|
|
1365
|
+
vLineGeom3.setAttribute('position', new Three.BufferAttribute(new Float32Array(vertices3), 3));
|
|
1366
|
+
// ///////////////////////////////////////
|
|
1367
|
+
|
|
1368
|
+
// set names of transform object
|
|
1369
|
+
var rotFillObj = new Three.Mesh(rotGeom.rotFill, new Three.MeshPhongMaterial({
|
|
1370
|
+
color: 0x000000,
|
|
1371
|
+
side: Three.DoubleSide,
|
|
1372
|
+
colorWrite: true
|
|
1373
|
+
}));
|
|
1374
|
+
var rotStrokeObj = new Three.Line(rotGeom.rotStroke, new Three.LineBasicMaterial({
|
|
1375
|
+
color: 0xffffff,
|
|
1376
|
+
colorWrite: true
|
|
1377
|
+
}));
|
|
1378
|
+
rotFillObj.name = 'rotate';
|
|
1379
|
+
var upObj = new Three.Mesh(upwardsGeom, new Three.MeshBasicMaterial({
|
|
1380
|
+
color: 0xffffff,
|
|
1381
|
+
side: Three.DoubleSide
|
|
1382
|
+
}));
|
|
1383
|
+
upObj.name = 'transUp';
|
|
1384
|
+
var mBox = new Three.Mesh(moveBox, new Three.MeshBasicMaterial({
|
|
1385
|
+
color: 0xdd6699,
|
|
1386
|
+
side: Three.DoubleSide,
|
|
1387
|
+
transparent: true,
|
|
1388
|
+
opacity: 0.4
|
|
1389
|
+
}));
|
|
1390
|
+
var color = new Three.Color(_constants.ARROW_COLOR).convertLinearToSRGB();
|
|
1391
|
+
var vLine = new Three.Line(vLineGeom, new Three.LineBasicMaterial({
|
|
1392
|
+
color: color
|
|
1393
|
+
}));
|
|
1394
|
+
var vLine1 = new Three.Line(vLineGeom1, new Three.LineBasicMaterial({
|
|
1395
|
+
color: color
|
|
1396
|
+
}));
|
|
1397
|
+
var vLine2 = new Three.Line(vLineGeom2, new Three.LineBasicMaterial({
|
|
1398
|
+
color: color
|
|
1399
|
+
}));
|
|
1400
|
+
var vLine3 = new Three.Line(vLineGeom3, new Three.LineBasicMaterial({
|
|
1401
|
+
color: color
|
|
1402
|
+
}));
|
|
1403
|
+
vLine.renderOrder = 1;
|
|
1404
|
+
vLine1.renderOrder = 1;
|
|
1405
|
+
vLine2.renderOrder = 1;
|
|
1406
|
+
vLine3.renderOrder = 1;
|
|
1407
|
+
vLine.material.transparent = true;
|
|
1408
|
+
vLine1.material.transparent = true;
|
|
1409
|
+
vLine2.material.transparent = true;
|
|
1410
|
+
vLine3.material.transparent = true;
|
|
1411
|
+
vLine.material.depthTest = false;
|
|
1412
|
+
vLine1.material.depthTest = false;
|
|
1413
|
+
vLine2.material.depthTest = false;
|
|
1414
|
+
vLine3.material.depthTest = false;
|
|
1415
|
+
// translate vector to center of object
|
|
1416
|
+
var uVec = new Three.Vector3(-posVec.x / scalevec.x, -posVec.y / scalevec.y, -posVec.z / scalevec.z);
|
|
1417
|
+
vLine.translateY(1.6);
|
|
1418
|
+
vLine1.translateY(1.6);
|
|
1419
|
+
vLine2.translateY(1.6);
|
|
1420
|
+
vLine3.translateY(1.6);
|
|
1421
|
+
|
|
1422
|
+
//rotObj.translateOnAxis(uVec, 1);
|
|
1423
|
+
upObj.translateOnAxis(uVec, 1);
|
|
1424
|
+
upObj.translateY(max.y - min.y);
|
|
1425
|
+
mBox.name = 'TransformBox';
|
|
1426
|
+
mBox.translateOnAxis(new Three.Vector3(uVec.x, uVec.y + (max.y - min.y) / 2, uVec.z), 1);
|
|
1427
|
+
mBox.scale.set(1.01, 1.01, 1.01);
|
|
1428
|
+
|
|
1429
|
+
// other side rotate object
|
|
1430
|
+
var rotFillObj1 = rotFillObj.clone();
|
|
1431
|
+
var rotStrokeObj1 = rotStrokeObj.clone();
|
|
1432
|
+
rotFillObj1.rotateY(Math.PI);
|
|
1433
|
+
rotStrokeObj1.rotateY(Math.PI);
|
|
1434
|
+
rotFillObj.translateY(1.6);
|
|
1435
|
+
rotFillObj1.translateY(1.6);
|
|
1436
|
+
rotStrokeObj.translateY(1.6);
|
|
1437
|
+
rotStrokeObj1.translateY(1.6);
|
|
1438
|
+
|
|
1439
|
+
// assets Objects group includes rotate objects...
|
|
1440
|
+
var asrtObj = new Three.Group();
|
|
1441
|
+
// asrtObj.add(rotFillObj);
|
|
1442
|
+
// asrtObj.add(rotFillObj1);
|
|
1443
|
+
// asrtObj.add(rotStrokeObj);
|
|
1444
|
+
// asrtObj.add(rotStrokeObj1);
|
|
1445
|
+
//asrtObj.add(upObj);
|
|
1446
|
+
asrtObj.add(vLine);
|
|
1447
|
+
asrtObj.add(vLine1);
|
|
1448
|
+
asrtObj.add(vLine2);
|
|
1449
|
+
asrtObj.add(vLine3);
|
|
1450
|
+
mBox.visible = false;
|
|
1451
|
+
asrtObj.add(mBox);
|
|
1452
|
+
asrtObj.scale.set(1, 1, 1);
|
|
1453
|
+
//asrtObj.translateY(newAltitude / scalevec.y);
|
|
1454
|
+
asrtObj.name = 'TransformGizmo';
|
|
1455
|
+
// add assets Objects Group
|
|
1456
|
+
object.add(asrtObj);
|
|
1457
|
+
|
|
1458
|
+
// recover objects transform
|
|
1459
|
+
object.position.x = posVec.x;
|
|
1460
|
+
object.position.y = posVec.y;
|
|
1461
|
+
object.position.z = posVec.z;
|
|
1462
|
+
object.scale.set(scalevec.x, scalevec.y, scalevec.z);
|
|
1463
|
+
setTimeout(function () {
|
|
1464
|
+
SceneCreator.getDistances(layer);
|
|
1465
|
+
}, 100);
|
|
1466
|
+
}
|
|
1467
|
+
return object;
|
|
1468
|
+
};
|
|
1469
|
+
|
|
1470
|
+
// keys in structure
|
|
1471
|
+
var keys = Object.keys(structure);
|
|
1472
|
+
|
|
1473
|
+
// if exist in cached Objects
|
|
1474
|
+
if (element.type in cachedObject) {
|
|
1475
|
+
var _objGroup3 = cachedObject[element.type].clone();
|
|
1476
|
+
return Promise.resolve(onLoadItem(_objGroup3.clone()));
|
|
1477
|
+
}
|
|
1478
|
+
|
|
1479
|
+
// base Object/////
|
|
1480
|
+
var objGroup = null;
|
|
1481
|
+
var _loadGLTFs3 = function loadGLTFs(i) {
|
|
1482
|
+
if (i === keys.length) {
|
|
1483
|
+
// if end of keys
|
|
1484
|
+
cachedObject[element.type] = objGroup.clone(); //register to cachedObject
|
|
1485
|
+
return onLoadItem(cachedObject[element.type].clone());
|
|
1486
|
+
}
|
|
1487
|
+
if (keys[i] === 'base') {
|
|
1488
|
+
// if base Objects
|
|
1489
|
+
i++;
|
|
1490
|
+
return _loadGLTFs3(i);
|
|
1491
|
+
}
|
|
1492
|
+
};
|
|
1493
|
+
|
|
1494
|
+
// load base to start //
|
|
1495
|
+
// return loadGLTF(dirName + structure["base"])
|
|
1496
|
+
return (0, _loadObj.loadGLTF)(structure['base']).then(function (object) {
|
|
1497
|
+
// let textureURL = `${API_SERVER_URL}/uploads/assets/default/steel.jpg`;
|
|
1498
|
+
// let texture = loadTexture(textureURL);
|
|
1499
|
+
// texture.wrapS = Three.MirroredRepeatWrapping;
|
|
1500
|
+
// texture.wrapT = Three.MirroredRepeatWrapping;
|
|
1501
|
+
|
|
1502
|
+
object.name = 'MainObject';
|
|
1503
|
+
var mat2 = new Three.MeshStandardMaterial({
|
|
1504
|
+
emissive: new Three.Color(0x666666).convertLinearToSRGB(),
|
|
1505
|
+
metalness: 0.7,
|
|
1506
|
+
roughness: 0.3
|
|
1507
|
+
});
|
|
1508
|
+
// mat2.envMap = textureCube;
|
|
1509
|
+
object.material = mat2;
|
|
1510
|
+
for (var j = 0; j < object.children.length; j++) {
|
|
1511
|
+
if (object.children[j].type === _constants.OBJTYPE_MESH) {
|
|
1512
|
+
object.children[j].material = mat2;
|
|
1513
|
+
object.children[j].receiveShadow = true;
|
|
1514
|
+
}
|
|
1515
|
+
}
|
|
1516
|
+
objGroup = object;
|
|
1517
|
+
}, function (reason) {
|
|
1518
|
+
console.log('loadGLTF failed for reason:', reason);
|
|
1519
|
+
objGroup = GeomUtils.emptyBoxHolder(newWidth, newHeight, newDepth);
|
|
1520
|
+
}).then(function () {
|
|
1521
|
+
return _loadGLTFs3(0);
|
|
1522
|
+
});
|
|
1523
|
+
}
|
|
1524
|
+
function addEdgesToMesh(inChild) {
|
|
1525
|
+
var boxEdge = new Three.EdgesGeometry(inChild.geometry, 10);
|
|
1526
|
+
var boxEdgeMaterial = new Three.LineBasicMaterial({
|
|
1527
|
+
color: 0x000000,
|
|
1528
|
+
transparent: true,
|
|
1529
|
+
opacity: 0.09
|
|
1530
|
+
});
|
|
1531
|
+
var boxEdgeLine = new Three.LineSegments(boxEdge, boxEdgeMaterial);
|
|
1532
|
+
// inChild.add(boxEdgeLine);
|
|
1533
|
+
}
|