1
import {Controller} from "../Controller.js";
2
import {math} from "@xeokit/xeokit-sdk/dist/xeokit-sdk.es.js";
4
const tempVec3a = math.vec3();
7
class ThreeDMode extends Controller {
9
constructor(parent, cfg) {
13
if (!cfg.buttonElement) {
14
throw "Missing config: buttonElement";
17
this._saveOrthoActive = null;
18
this._buttonElement = cfg.buttonElement;
20
this._cameraControlNavModeMediator = cfg.cameraControlNavModeMediator;
24
this.on("enabled", (enabled) => {
26
this._buttonElement.classList.add("disabled");
28
this._buttonElement.classList.remove("disabled");
32
this._buttonElement.addEventListener("click", (event) => {
33
if (this.getEnabled()) {
34
this.bimViewer._sectionTool.hideControl();
35
this.setActive(!this.getActive(), () => {
38
event.preventDefault();
41
this.bimViewer.on("reset", () => {
42
this.setActive(true, () => {
48
super.setEnabled(enabled);
49
this._saveOrthoActive = this.bimViewer._orthoMode.getActive();
52
setActive(active, done) {
53
if (this._active === active) {
59
this._active = active;
61
this._buttonElement.classList.add("active");
63
this._enterThreeDMode(() => {
64
this.fire("active", this._active);
68
this._enterThreeDMode();
69
this.fire("active", this._active);
72
this._buttonElement.classList.remove("active");
74
this._exitThreeDMode(() => {
75
this.fire("active", this._active);
79
this._exitThreeDMode();
80
this.fire("active", this._active);
85
_enterThreeDMode(done) {
87
const viewer = this.viewer;
88
const scene = viewer.scene;
89
const aabb = scene.getAABB(scene.visibleObjectIds);
90
const diag = math.getAABB3Diag(aabb);
91
const center = math.getAABB3Center(aabb, tempVec3a);
92
const dist = Math.abs(diag / Math.tan(65.0 / 2));
93
const camera = scene.camera;
94
const dir = (camera.yUp) ? [-1, -1, -1] : [1, 1, 1];
95
const up = (camera.yUp) ? [-1, 1, -1] : [-1, 1, 1];
97
viewer.cameraControl.pivotPos = center;
99
this.bimViewer._navCubeMode.setActive(true);
100
this.bimViewer._firstPersonMode.setEnabled(true);
101
this._cameraControlNavModeMediator.setThreeDModeActive(true);
102
this.bimViewer._sectionTool.setEnabled(true);
103
this.bimViewer._orthoMode.setEnabled(true);
106
viewer.cameraFlight.flyTo({
108
eye: [center[0] - (dist * dir[0]), center[1] - (dist * dir[1]), center[2] - (dist * dir[2])],
110
orthoScale: diag * 1.3,
112
projection: this._saveOrthoActive ? "ortho" : "perspective"
117
viewer.cameraFlight.jumpTo({
119
eye: [center[0] - (dist * dir[0]), center[1] - (dist * dir[1]), center[2] - (dist * dir[2])],
121
orthoScale: diag * 1.3,
122
projection: this._saveOrthoActive ? "ortho" : "perspective"
127
_exitThreeDMode(done) {
129
const viewer = this.viewer;
130
const scene = viewer.scene;
131
const camera = scene.camera;
132
const aabb = scene.getAABB(scene.visibleObjectIds);
133
const look2 = math.getAABB3Center(aabb);
134
const diag = math.getAABB3Diag(aabb);
136
const sca = Math.abs(diag / Math.tan(fitFOV * math.DEGTORAD));
137
const orthoScale2 = diag * 1.3;
138
const eye2 = tempVec3a;
140
eye2[0] = look2[0] + (camera.worldUp[0] * sca);
141
eye2[1] = look2[1] + (camera.worldUp[1] * sca);
142
eye2[2] = look2[2] + (camera.worldUp[2] * sca);
144
const up2 = math.mulVec3Scalar(camera.worldForward, -1, []);
146
this.bimViewer._sectionTool.setActive(false);
147
this.bimViewer._firstPersonMode.setEnabled(false);
149
this._saveOrthoActive = this.bimViewer._orthoMode.getActive();
150
this.bimViewer._orthoMode.setEnabled(false);
152
this._cameraControlNavModeMediator.setThreeDModeActive(false);
155
viewer.cameraFlight.flyTo({
159
orthoScale: orthoScale2,
162
this.bimViewer._navCubeMode.setActive(false);
165
viewer.cameraFlight.jumpTo({
169
orthoScale: orthoScale2,
172
this.bimViewer._navCubeMode.setActive(false);