@needle-tools/engine 2.67.16-pre → 2.67.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.
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@needle-tools/engine",
3
- "version": "2.67.16-pre",
3
+ "version": "2.67.16",
4
4
  "description": "Needle Engine is a web-based runtime for 3D apps. It runs on your machine for development, and can be deployed anywhere. It is flexible, extensible, and collaboration and XR come naturally.",
5
5
  "main": "dist/needle-engine.umd.cjs",
6
6
  "module": "lib/needle-engine.js",
@@ -1,5 +1,5 @@
1
1
  import { TypeStore } from "./../engine_typestore"
2
-
2
+
3
3
  // Import types
4
4
  import { __Ignore } from "../../engine-components/codegen/components";
5
5
  import { AlignmentConstraint } from "../../engine-components/AlignmentConstraint";
@@ -179,7 +179,7 @@ import { XRGrabModel } from "../../engine-components/WebXRGrabRendering";
179
179
  import { XRGrabRendering } from "../../engine-components/WebXRGrabRendering";
180
180
  import { XRRig } from "../../engine-components/WebXRRig";
181
181
  import { XRState } from "../../engine-components/XRFlag";
182
-
182
+
183
183
  // Register types
184
184
  TypeStore.add("__Ignore", __Ignore);
185
185
  TypeStore.add("AlignmentConstraint", AlignmentConstraint);
@@ -1,11 +1,10 @@
1
1
  import { DepthOfFieldEffect } from "postprocessing";
2
- import { PerspectiveCamera, Vector3 } from "three";
3
- import { getWorldPosition } from "../../../engine/engine_three_utils";
4
2
  import { serializable } from "../../../engine/engine_serialization";
5
3
  import { Mathf } from "../../../engine/engine_math";
6
4
  import { PostProcessingEffect } from "../PostProcessingEffect";
7
5
  import { VolumeParameter } from "../VolumeParameter";
8
6
  import { registerCustomEffectType } from "../VolumeProfile";
7
+ import { isMobileDevice } from "../../../engine/engine_utils";
9
8
 
10
9
  export enum DepthOfFieldMode {
11
10
  Off = 0,
@@ -20,7 +19,7 @@ export class DepthOfField extends PostProcessingEffect {
20
19
  }
21
20
 
22
21
  @serializable()
23
- mode! : DepthOfFieldMode;
22
+ mode!: DepthOfFieldMode;
24
23
 
25
24
  @serializable(VolumeParameter)
26
25
  focusDistance!: VolumeParameter;
@@ -34,13 +33,16 @@ export class DepthOfField extends PostProcessingEffect {
34
33
  @serializable(VolumeParameter)
35
34
  gaussianMaxRadius!: VolumeParameter;
36
35
 
36
+ @serializable(VolumeParameter)
37
+ resolutionScale?: VolumeParameter;
38
+
37
39
  init() {
38
40
  this.focalLength.valueProcessor = v => {
39
41
  const t = v / 300;
40
42
  const max = 2;// this.context.mainCameraComponent?.farClipPlane ?? 10;
41
43
  return Mathf.lerp(max, .01, t);
42
44
  };
43
-
45
+
44
46
  const maxBokehScale = 20;
45
47
  this.aperture.valueProcessor = v => {
46
48
  const t = 1 - v / 32;
@@ -49,7 +51,16 @@ export class DepthOfField extends PostProcessingEffect {
49
51
  }
50
52
 
51
53
  onCreateEffect() {
52
- if(this.mode === DepthOfFieldMode.Off) return undefined;
54
+ if (this.mode === DepthOfFieldMode.Off) return undefined;
55
+
56
+ const factor = 1 / window.devicePixelRatio;
57
+
58
+ if (this.resolutionScale === undefined) {
59
+ let defaultValue = 1;
60
+ if(isMobileDevice()) defaultValue = .6;
61
+ this.resolutionScale = new VolumeParameter(defaultValue * factor);
62
+ }
63
+
53
64
  // console.log(this.focusDistance.overrideState, this.focusDistance.value);
54
65
  // const depth = new DepthEffect({
55
66
  // inverted: true,
@@ -59,7 +70,7 @@ export class DepthOfField extends PostProcessingEffect {
59
70
  worldFocusRange: .2,
60
71
  focalLength: 1,
61
72
  bokehScale: 20,
62
- resolutionScale: 1,
73
+ resolutionScale: this.resolutionScale.value,
63
74
  });
64
75
 
65
76
  this.focusDistance.onValueChanged = v => {
@@ -68,6 +79,7 @@ export class DepthOfField extends PostProcessingEffect {
68
79
  this.focalLength.onValueChanged = v => dof.circleOfConfusionMaterial.worldFocusRange = v;
69
80
  this.aperture.onValueChanged = v => dof.bokehScale = v;
70
81
 
82
+ if (this.resolutionScale) this.resolutionScale.onValueChanged = v => dof.resolution.scale = v;
71
83
 
72
84
  return [dof];
73
85
  }
@@ -5,6 +5,11 @@ export declare type VolumeParameterValueProcessor = (value: any) => any;
5
5
 
6
6
  export class VolumeParameter {
7
7
 
8
+ constructor(value?: any) {
9
+ this._value = value;
10
+ this._defaultValue = value;
11
+ }
12
+
8
13
  @serializable()
9
14
  get overrideState(): boolean {
10
15
  return this._active;