@base2datadesign/viewer-kit 0.2.14 → 0.2.16

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.
@@ -0,0 +1,28 @@
1
+ import * as THREE from "three";
2
+ export type CameraFrameMode = "iso" | "interior";
3
+ export type CameraFrameConfig = {
4
+ mode?: CameraFrameMode;
5
+ padding?: number;
6
+ direction?: [number, number, number];
7
+ };
8
+ export type CameraNormalizationConfig = {
9
+ recenter?: boolean;
10
+ floorToZero?: boolean;
11
+ normalizePlan?: {
12
+ target?: number;
13
+ maxScale?: number;
14
+ };
15
+ };
16
+ export type CameraNormalizationResult = {
17
+ bounds: THREE.Box3;
18
+ center: THREE.Vector3;
19
+ size: THREE.Vector3;
20
+ scale: number;
21
+ offset: THREE.Vector3;
22
+ };
23
+ export declare const normalizeObject3d: (object: THREE.Object3D, config?: CameraNormalizationConfig) => CameraNormalizationResult;
24
+ export declare const computeCameraFrame: (bounds: THREE.Box3, fovDegrees: number, config?: CameraFrameConfig) => {
25
+ position: THREE.Vector3;
26
+ target: THREE.Vector3;
27
+ };
28
+ //# sourceMappingURL=camera.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"camera.d.ts","sourceRoot":"","sources":["../src/camera.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAE/B,MAAM,MAAM,eAAe,GAAG,KAAK,GAAG,UAAU,CAAC;AAEjD,MAAM,MAAM,iBAAiB,GAAG;IAC9B,IAAI,CAAC,EAAE,eAAe,CAAC;IACvB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,SAAS,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC;CACtC,CAAC;AAEF,MAAM,MAAM,yBAAyB,GAAG;IACtC,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,aAAa,CAAC,EAAE;QACd,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB,QAAQ,CAAC,EAAE,MAAM,CAAC;KACnB,CAAC;CACH,CAAC;AAEF,MAAM,MAAM,yBAAyB,GAAG;IACtC,MAAM,EAAE,KAAK,CAAC,IAAI,CAAC;IACnB,MAAM,EAAE,KAAK,CAAC,OAAO,CAAC;IACtB,IAAI,EAAE,KAAK,CAAC,OAAO,CAAC;IACpB,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,KAAK,CAAC,OAAO,CAAC;CACvB,CAAC;AAKF,eAAO,MAAM,iBAAiB,GAC5B,QAAQ,KAAK,CAAC,QAAQ,EACtB,SAAS,yBAAyB,KACjC,yBA8CF,CAAC;AAEF,eAAO,MAAM,kBAAkB,GAC7B,QAAQ,KAAK,CAAC,IAAI,EAClB,YAAY,MAAM,EAClB,SAAS,iBAAiB,KACzB;IAAE,QAAQ,EAAE,KAAK,CAAC,OAAO,CAAC;IAAC,MAAM,EAAE,KAAK,CAAC,OAAO,CAAA;CAmBlD,CAAC"}
package/dist/camera.js ADDED
@@ -0,0 +1,62 @@
1
+ import * as THREE from "three";
2
+ const DEFAULT_FRAME_PADDING = 1.22;
3
+ const DEFAULT_FRAME_DIRECTION = [1, 0.7, 1];
4
+ export const normalizeObject3d = (object, config) => {
5
+ const resolved = config ?? {};
6
+ const offset = new THREE.Vector3();
7
+ let scale = 1;
8
+ object.updateMatrixWorld(true);
9
+ let bounds = new THREE.Box3().setFromObject(object);
10
+ let size = new THREE.Vector3();
11
+ let center = new THREE.Vector3();
12
+ bounds.getSize(size);
13
+ bounds.getCenter(center);
14
+ const targetPlan = resolved.normalizePlan?.target;
15
+ if (typeof targetPlan === "number" && Number.isFinite(targetPlan) && targetPlan > 0) {
16
+ const planMax = Math.max(size.x, size.z);
17
+ if (planMax > 1e-6) {
18
+ const maxScale = resolved.normalizePlan?.maxScale ?? 3;
19
+ scale = Math.min(maxScale, targetPlan / planMax);
20
+ if (Number.isFinite(scale) && scale > 0 && scale !== 1) {
21
+ object.scale.multiplyScalar(scale);
22
+ object.updateMatrixWorld(true);
23
+ bounds = new THREE.Box3().setFromObject(object);
24
+ bounds.getSize(size);
25
+ bounds.getCenter(center);
26
+ }
27
+ }
28
+ }
29
+ if (resolved.recenter) {
30
+ offset.x -= center.x;
31
+ offset.z -= center.z;
32
+ }
33
+ if (resolved.floorToZero) {
34
+ offset.y -= bounds.min.y;
35
+ }
36
+ if (offset.lengthSq() > 0) {
37
+ object.position.add(offset);
38
+ object.updateMatrixWorld(true);
39
+ bounds = new THREE.Box3().setFromObject(object);
40
+ bounds.getSize(size);
41
+ bounds.getCenter(center);
42
+ }
43
+ return { bounds, center, size, scale, offset };
44
+ };
45
+ export const computeCameraFrame = (bounds, fovDegrees, config) => {
46
+ const size = new THREE.Vector3();
47
+ const center = new THREE.Vector3();
48
+ bounds.getSize(size);
49
+ bounds.getCenter(center);
50
+ const mode = config?.mode ?? "iso";
51
+ if (mode === "interior") {
52
+ const position = new THREE.Vector3(center.x, center.y + size.y * 0.2, center.z + size.z * 0.2);
53
+ return { position, target: center };
54
+ }
55
+ const padding = config?.padding ?? DEFAULT_FRAME_PADDING;
56
+ const direction = new THREE.Vector3(...(config?.direction ?? DEFAULT_FRAME_DIRECTION)).normalize();
57
+ const radius = Math.max(0.5, size.length() * 0.5);
58
+ const vFov = THREE.MathUtils.degToRad(fovDegrees);
59
+ const distance = (radius / Math.sin(vFov / 2)) * padding;
60
+ const position = center.clone().add(direction.multiplyScalar(distance));
61
+ return { position, target: center };
62
+ };
@@ -7,6 +7,7 @@ export declare class ViewerEngine {
7
7
  private camera;
8
8
  private controls;
9
9
  private rootGroup;
10
+ private sceneBounds;
10
11
  private environmentSystem;
11
12
  private lightingSystem;
12
13
  private postFxSystem;
@@ -1 +1 @@
1
- {"version":3,"file":"ViewerEngine.d.ts","sourceRoot":"","sources":["../../src/engine/ViewerEngine.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAiB,WAAW,EAAiB,sBAAsB,EAAE,mBAAmB,EAAmB,YAAY,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAQrK,qBAAa,YAAY;IACvB,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,iBAAiB,CAAiB;IAE1D,OAAO,CAAC,SAAS,CAAc;IAC/B,OAAO,CAAC,QAAQ,CAAsB;IACtC,OAAO,CAAC,KAAK,CAAc;IAC3B,OAAO,CAAC,MAAM,CAA0B;IACxC,OAAO,CAAC,QAAQ,CAAgB;IAChC,OAAO,CAAC,SAAS,CAAc;IAE/B,OAAO,CAAC,iBAAiB,CAAoB;IAC7C,OAAO,CAAC,cAAc,CAAiB;IACvC,OAAO,CAAC,YAAY,CAAe;IACnC,OAAO,CAAC,WAAW,CAAc;IACjC,OAAO,CAAC,iBAAiB,CAAU;IAEnC,OAAO,CAAC,OAAO,CAAgB;IAC/B,OAAO,CAAC,QAAQ,CAAS;IACzB,OAAO,CAAC,OAAO,CAAS;IACxB,OAAO,CAAC,cAAc,CAAuB;IAC7C,OAAO,CAAC,SAAS,CAAS;IAC1B,OAAO,CAAC,UAAU,CAAS;IAC3B,OAAO,CAAC,aAAa,CAAS;gBAElB,OAAO,EAAE,mBAAmB;IAwDxC,SAAS,IAAI,YAAY;IAmBzB,OAAO,CAAC,UAAU;IAKlB,KAAK,IAAI,IAAI;IAgBb,IAAI,IAAI,IAAI;IAQZ,MAAM,IAAI,IAAI;IAcd,OAAO,IAAI,IAAI;IAef,SAAS,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI;IAIjC,gBAAgB,CAAC,MAAM,EAAE,sBAAsB,GAAG,IAAI;IAStD,YAAY,CAAC,IAAI,EAAE,OAAO,GAAG,IAAI;IAwBjC,SAAS,CAAC,KAAK,EAAE,OAAO,CAAC,WAAW,CAAC,GAAG,IAAI;IAe5C,cAAc,IAAI,WAAW;IAQvB,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;IAmCjC,WAAW,IAAI,cAAc;IAe7B,OAAO,CAAC,YAAY;IAuCpB,OAAO,CAAC,WAAW;IAyBnB,OAAO,CAAC,aAAa;CAKtB"}
1
+ {"version":3,"file":"ViewerEngine.d.ts","sourceRoot":"","sources":["../../src/engine/ViewerEngine.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAiB,WAAW,EAAiB,sBAAsB,EAAE,mBAAmB,EAAmB,YAAY,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAQrK,qBAAa,YAAY;IACvB,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,iBAAiB,CAAiB;IAE1D,OAAO,CAAC,SAAS,CAAc;IAC/B,OAAO,CAAC,QAAQ,CAAsB;IACtC,OAAO,CAAC,KAAK,CAAc;IAC3B,OAAO,CAAC,MAAM,CAA0B;IACxC,OAAO,CAAC,QAAQ,CAAgB;IAChC,OAAO,CAAC,SAAS,CAAc;IAC/B,OAAO,CAAC,WAAW,CAA2B;IAE9C,OAAO,CAAC,iBAAiB,CAAoB;IAC7C,OAAO,CAAC,cAAc,CAAiB;IACvC,OAAO,CAAC,YAAY,CAAe;IACnC,OAAO,CAAC,WAAW,CAAc;IACjC,OAAO,CAAC,iBAAiB,CAAU;IAEnC,OAAO,CAAC,OAAO,CAAgB;IAC/B,OAAO,CAAC,QAAQ,CAAS;IACzB,OAAO,CAAC,OAAO,CAAS;IACxB,OAAO,CAAC,cAAc,CAAuB;IAC7C,OAAO,CAAC,SAAS,CAAS;IAC1B,OAAO,CAAC,UAAU,CAAS;IAC3B,OAAO,CAAC,aAAa,CAAS;gBAElB,OAAO,EAAE,mBAAmB;IAwDxC,SAAS,IAAI,YAAY;IAmBzB,OAAO,CAAC,UAAU;IAKlB,KAAK,IAAI,IAAI;IAgBb,IAAI,IAAI,IAAI;IAQZ,MAAM,IAAI,IAAI;IAcd,OAAO,IAAI,IAAI;IAef,SAAS,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI;IAIjC,gBAAgB,CAAC,MAAM,EAAE,sBAAsB,GAAG,IAAI;IAStD,YAAY,CAAC,IAAI,EAAE,OAAO,GAAG,IAAI;IAyBjC,SAAS,CAAC,KAAK,EAAE,OAAO,CAAC,WAAW,CAAC,GAAG,IAAI;IAe5C,cAAc,IAAI,WAAW;IAQvB,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;IAmCjC,WAAW,IAAI,cAAc;IAe7B,OAAO,CAAC,YAAY;IAuCpB,OAAO,CAAC,WAAW;IAyBnB,OAAO,CAAC,aAAa;CAKtB"}
@@ -14,6 +14,7 @@ export class ViewerEngine {
14
14
  camera;
15
15
  controls;
16
16
  rootGroup;
17
+ sceneBounds = null;
17
18
  environmentSystem;
18
19
  lightingSystem;
19
20
  postFxSystem;
@@ -159,6 +160,7 @@ export class ViewerEngine {
159
160
  if (object3d && object3d.isObject3D) {
160
161
  this.rootGroup.add(object3d);
161
162
  const bounds = new THREE.Box3().setFromObject(object3d);
163
+ this.sceneBounds = bounds.clone();
162
164
  if (!bounds.isEmpty()) {
163
165
  const size = new THREE.Vector3();
164
166
  bounds.getSize(size);
@@ -300,7 +302,7 @@ export class ViewerEngine {
300
302
  this.lightingSystem.apply(preset);
301
303
  this.postFxSystem.apply(this.usePostprocessing ? preset.postfx : undefined);
302
304
  this.postFxSystem.invalidate();
303
- this.debugSystem.apply(preset);
305
+ this.debugSystem.apply(preset, this.sceneBounds);
304
306
  }
305
307
  resolvePreset(presetId) {
306
308
  if (presetId in this.presets)
package/dist/index.d.ts CHANGED
@@ -1,5 +1,7 @@
1
1
  export type { ViewerCreateOptions, ViewerHandle, ViewerSnapshot, CameraState, RenderPresetDefinition, PresetCatalog, LightingRigConfig, PostFxConfig, SceneExtrasConfig, SkyDefinition, SkyHdrConfig, SkyCubeConfig, ViewerDebugInfo, } from "./engine/types";
2
+ export type { CameraFrameConfig, CameraFrameMode, CameraNormalizationConfig, CameraNormalizationResult, } from "./camera";
2
3
  export { createViewer } from "./engine/createViewer";
4
+ export { computeCameraFrame, normalizeObject3d } from "./camera";
3
5
  export { DEFAULT_PRESET_ID, DEFAULT_PRESETS } from "./presets/defaults";
4
6
  export { SCIENCE_PRESETS, SCIENCE_PRESET_SUMMARIES, SCIENCE_DEFAULT_PRESET_ID, buildViewerPresets, buildSciencePresets, } from "./presets/sciencePresets";
5
7
  export { listScienceSkyOptions, getScienceSkyOption } from "./sky/scienceSky";
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,YAAY,EACV,mBAAmB,EACnB,YAAY,EACZ,cAAc,EACd,WAAW,EACX,sBAAsB,EACtB,aAAa,EACb,iBAAiB,EACjB,YAAY,EACZ,iBAAiB,EACjB,aAAa,EACb,YAAY,EACZ,aAAa,EACb,eAAe,GAChB,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAC;AACrD,OAAO,EAAE,iBAAiB,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AACxE,OAAO,EACL,eAAe,EACf,wBAAwB,EACxB,yBAAyB,EACzB,kBAAkB,EAClB,mBAAmB,GACpB,MAAM,0BAA0B,CAAC;AAClC,OAAO,EAAE,qBAAqB,EAAE,mBAAmB,EAAE,MAAM,kBAAkB,CAAC;AAC9E,YAAY,EAAE,gBAAgB,EAAE,MAAM,kBAAkB,CAAC;AACzD,YAAY,EACV,iBAAiB,EACjB,kBAAkB,EAClB,UAAU,EACV,aAAa,EACb,qBAAqB,EACrB,eAAe,GAChB,MAAM,mBAAmB,CAAC;AAC3B,OAAO,EAAE,oBAAoB,EAAE,YAAY,EAAE,uBAAuB,EAAE,MAAM,uBAAuB,CAAC;AACpG,OAAO,EAAE,yBAAyB,EAAE,MAAM,4BAA4B,CAAC;AACvE,OAAO,EACL,2BAA2B,EAC3B,oBAAoB,EACpB,mBAAmB,EACnB,iBAAiB,EACjB,mBAAmB,EACnB,8BAA8B,GAC/B,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EAAE,qBAAqB,EAAE,oBAAoB,EAAE,oBAAoB,EAAE,MAAM,2BAA2B,CAAC;AAC9G,cAAc,WAAW,CAAC;AAC1B,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AACtD,YAAY,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AAC3D,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,YAAY,EACV,mBAAmB,EACnB,YAAY,EACZ,cAAc,EACd,WAAW,EACX,sBAAsB,EACtB,aAAa,EACb,iBAAiB,EACjB,YAAY,EACZ,iBAAiB,EACjB,aAAa,EACb,YAAY,EACZ,aAAa,EACb,eAAe,GAChB,MAAM,gBAAgB,CAAC;AACxB,YAAY,EACV,iBAAiB,EACjB,eAAe,EACf,yBAAyB,EACzB,yBAAyB,GAC1B,MAAM,UAAU,CAAC;AAClB,OAAO,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAC;AACrD,OAAO,EAAE,kBAAkB,EAAE,iBAAiB,EAAE,MAAM,UAAU,CAAC;AACjE,OAAO,EAAE,iBAAiB,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AACxE,OAAO,EACL,eAAe,EACf,wBAAwB,EACxB,yBAAyB,EACzB,kBAAkB,EAClB,mBAAmB,GACpB,MAAM,0BAA0B,CAAC;AAClC,OAAO,EAAE,qBAAqB,EAAE,mBAAmB,EAAE,MAAM,kBAAkB,CAAC;AAC9E,YAAY,EAAE,gBAAgB,EAAE,MAAM,kBAAkB,CAAC;AACzD,YAAY,EACV,iBAAiB,EACjB,kBAAkB,EAClB,UAAU,EACV,aAAa,EACb,qBAAqB,EACrB,eAAe,GAChB,MAAM,mBAAmB,CAAC;AAC3B,OAAO,EAAE,oBAAoB,EAAE,YAAY,EAAE,uBAAuB,EAAE,MAAM,uBAAuB,CAAC;AACpG,OAAO,EAAE,yBAAyB,EAAE,MAAM,4BAA4B,CAAC;AACvE,OAAO,EACL,2BAA2B,EAC3B,oBAAoB,EACpB,mBAAmB,EACnB,iBAAiB,EACjB,mBAAmB,EACnB,8BAA8B,GAC/B,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EAAE,qBAAqB,EAAE,oBAAoB,EAAE,oBAAoB,EAAE,MAAM,2BAA2B,CAAC;AAC9G,cAAc,WAAW,CAAC;AAC1B,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AACtD,YAAY,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AAC3D,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC"}
package/dist/index.js CHANGED
@@ -1,4 +1,5 @@
1
1
  export { createViewer } from "./engine/createViewer";
2
+ export { computeCameraFrame, normalizeObject3d } from "./camera";
2
3
  export { DEFAULT_PRESET_ID, DEFAULT_PRESETS } from "./presets/defaults";
3
4
  export { SCIENCE_PRESETS, SCIENCE_PRESET_SUMMARIES, SCIENCE_DEFAULT_PRESET_ID, buildViewerPresets, buildSciencePresets, } from "./presets/sciencePresets";
4
5
  export { listScienceSkyOptions, getScienceSkyOption } from "./sky/scienceSky";
@@ -4,7 +4,7 @@ export declare class DebugSystem {
4
4
  private scene;
5
5
  private objects;
6
6
  constructor(scene: THREE.Scene);
7
- apply(preset: RenderPresetDefinition): void;
7
+ apply(preset: RenderPresetDefinition, bounds?: THREE.Box3 | null): void;
8
8
  dispose(): void;
9
9
  private add;
10
10
  private clear;
@@ -1 +1 @@
1
- {"version":3,"file":"debugSystem.d.ts","sourceRoot":"","sources":["../../src/systems/debugSystem.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,KAAK,EAAqB,sBAAsB,EAAE,MAAM,iBAAiB,CAAC;AAoKjF,qBAAa,WAAW;IACtB,OAAO,CAAC,KAAK,CAAc;IAC3B,OAAO,CAAC,OAAO,CAAwB;gBAE3B,KAAK,EAAE,KAAK,CAAC,KAAK;IAI9B,KAAK,CAAC,MAAM,EAAE,sBAAsB,GAAG,IAAI;IAwE3C,OAAO,IAAI,IAAI;IAIf,OAAO,CAAC,GAAG;IAKX,OAAO,CAAC,KAAK;CAmCd"}
1
+ {"version":3,"file":"debugSystem.d.ts","sourceRoot":"","sources":["../../src/systems/debugSystem.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,KAAK,EAAqB,sBAAsB,EAAE,MAAM,iBAAiB,CAAC;AAoKjF,qBAAa,WAAW;IACtB,OAAO,CAAC,KAAK,CAAc;IAC3B,OAAO,CAAC,OAAO,CAAwB;gBAE3B,KAAK,EAAE,KAAK,CAAC,KAAK;IAI9B,KAAK,CAAC,MAAM,EAAE,sBAAsB,EAAE,MAAM,CAAC,EAAE,KAAK,CAAC,IAAI,GAAG,IAAI,GAAG,IAAI;IA8EvE,OAAO,IAAI,IAAI;IAIf,OAAO,CAAC,GAAG;IAKX,OAAO,CAAC,KAAK;CAmCd"}
@@ -152,7 +152,7 @@ export class DebugSystem {
152
152
  constructor(scene) {
153
153
  this.scene = scene;
154
154
  }
155
- apply(preset) {
155
+ apply(preset, bounds) {
156
156
  const extras = { ...DEFAULT_EXTRAS, ...(preset.sceneExtras ?? {}) };
157
157
  this.clear();
158
158
  const skyMode = preset.sky?.mode ?? "gradient";
@@ -163,8 +163,14 @@ export class DebugSystem {
163
163
  const axesEnabled = extras.axes !== false;
164
164
  const originEnabled = extras.origin !== false;
165
165
  const groundColor = extras.groundColor ?? 0x2c2f33;
166
+ const boundsSize = bounds && !bounds.isEmpty() ? bounds.getSize(new THREE.Vector3()) : null;
167
+ const modelSpan = boundsSize ? Math.max(boundsSize.x, boundsSize.z, 1) : null;
168
+ const groundSizeDefault = isHdr ? HDR_GROUND_SIZE : 400;
169
+ const gridSizeDefault = DEFAULT_GRID_SIZE;
170
+ const derivedGroundSize = modelSpan ? Math.max(modelSpan * 4, groundSizeDefault * 0.5) : groundSizeDefault;
171
+ const derivedGridSize = modelSpan ? Math.max(modelSpan * 3, gridSizeDefault) : gridSizeDefault;
166
172
  if (groundEnabled) {
167
- const size = extras.groundSize ?? (isHdr ? HDR_GROUND_SIZE : 400);
173
+ const size = extras.groundSize ?? derivedGroundSize;
168
174
  const groundGeometry = new THREE.PlaneGeometry(size, size);
169
175
  const groundMaterial = new THREE.MeshStandardMaterial({
170
176
  color: groundColor,
@@ -182,7 +188,7 @@ export class DebugSystem {
182
188
  if (gridEnabled) {
183
189
  const gridPrimary = new THREE.Color(extras.gridColor ?? adjustGridColor(groundColor));
184
190
  const gridSecondary = new THREE.Color(extras.gridColorSecondary ?? gridPrimary.getHex());
185
- const gridSize = extras.gridSize ?? DEFAULT_GRID_SIZE;
191
+ const gridSize = extras.gridSize ?? derivedGridSize;
186
192
  const gridDivisions = extras.gridDivisions ?? Math.max(1, gridSize);
187
193
  const grid = new THREE.GridHelper(gridSize, gridDivisions, gridPrimary, gridSecondary);
188
194
  const offset = extras.gridHeightOffset ?? DEFAULT_GRID_HEIGHT_OFFSET;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@base2datadesign/viewer-kit",
3
- "version": "0.2.14",
3
+ "version": "0.2.16",
4
4
  "type": "module",
5
5
  "license": "UNLICENSED",
6
6
  "main": "./dist/index.js",