@needle-tools/engine 2.67.16-pre → 2.67.17
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/CHANGELOG.md +3 -0
- package/dist/needle-engine.js +1967 -1957
- package/dist/needle-engine.min.js +68 -68
- package/dist/needle-engine.umd.cjs +65 -65
- package/lib/engine-components/postprocessing/Effects/DepthOfField.d.ts +1 -0
- package/lib/engine-components/postprocessing/Effects/DepthOfField.js +15 -1
- package/lib/engine-components/postprocessing/Effects/DepthOfField.js.map +1 -1
- package/lib/engine-components/postprocessing/VolumeParameter.d.ts +1 -0
- package/lib/engine-components/postprocessing/VolumeParameter.js +4 -0
- package/lib/engine-components/postprocessing/VolumeParameter.js.map +1 -1
- package/lib/tsconfig.tsbuildinfo +1 -1
- package/package.json +1 -1
- package/src/engine/codegen/register_types.js +2 -2
- package/src/engine-components/postprocessing/Effects/DepthOfField.ts +18 -6
- package/src/engine-components/postprocessing/VolumeParameter.ts +5 -0
|
@@ -13,6 +13,7 @@ export declare class DepthOfField extends PostProcessingEffect {
|
|
|
13
13
|
focalLength: VolumeParameter;
|
|
14
14
|
aperture: VolumeParameter;
|
|
15
15
|
gaussianMaxRadius: VolumeParameter;
|
|
16
|
+
resolutionScale?: VolumeParameter;
|
|
16
17
|
init(): void;
|
|
17
18
|
onCreateEffect(): DepthOfFieldEffect[] | undefined;
|
|
18
19
|
unapply(): void;
|
|
@@ -10,6 +10,7 @@ import { Mathf } from "../../../engine/engine_math";
|
|
|
10
10
|
import { PostProcessingEffect } from "../PostProcessingEffect";
|
|
11
11
|
import { VolumeParameter } from "../VolumeParameter";
|
|
12
12
|
import { registerCustomEffectType } from "../VolumeProfile";
|
|
13
|
+
import { isMobileDevice } from "../../../engine/engine_utils";
|
|
13
14
|
export var DepthOfFieldMode;
|
|
14
15
|
(function (DepthOfFieldMode) {
|
|
15
16
|
DepthOfFieldMode[DepthOfFieldMode["Off"] = 0] = "Off";
|
|
@@ -25,6 +26,7 @@ export class DepthOfField extends PostProcessingEffect {
|
|
|
25
26
|
focalLength;
|
|
26
27
|
aperture;
|
|
27
28
|
gaussianMaxRadius;
|
|
29
|
+
resolutionScale;
|
|
28
30
|
init() {
|
|
29
31
|
this.focalLength.valueProcessor = v => {
|
|
30
32
|
const t = v / 300;
|
|
@@ -40,6 +42,13 @@ export class DepthOfField extends PostProcessingEffect {
|
|
|
40
42
|
onCreateEffect() {
|
|
41
43
|
if (this.mode === DepthOfFieldMode.Off)
|
|
42
44
|
return undefined;
|
|
45
|
+
const factor = 1 / window.devicePixelRatio;
|
|
46
|
+
if (this.resolutionScale === undefined) {
|
|
47
|
+
let defaultValue = 1;
|
|
48
|
+
if (isMobileDevice())
|
|
49
|
+
defaultValue = .6;
|
|
50
|
+
this.resolutionScale = new VolumeParameter(defaultValue * factor);
|
|
51
|
+
}
|
|
43
52
|
// console.log(this.focusDistance.overrideState, this.focusDistance.value);
|
|
44
53
|
// const depth = new DepthEffect({
|
|
45
54
|
// inverted: true,
|
|
@@ -49,13 +58,15 @@ export class DepthOfField extends PostProcessingEffect {
|
|
|
49
58
|
worldFocusRange: .2,
|
|
50
59
|
focalLength: 1,
|
|
51
60
|
bokehScale: 20,
|
|
52
|
-
resolutionScale:
|
|
61
|
+
resolutionScale: this.resolutionScale.value,
|
|
53
62
|
});
|
|
54
63
|
this.focusDistance.onValueChanged = v => {
|
|
55
64
|
dof.circleOfConfusionMaterial.worldFocusDistance = v;
|
|
56
65
|
};
|
|
57
66
|
this.focalLength.onValueChanged = v => dof.circleOfConfusionMaterial.worldFocusRange = v;
|
|
58
67
|
this.aperture.onValueChanged = v => dof.bokehScale = v;
|
|
68
|
+
if (this.resolutionScale)
|
|
69
|
+
this.resolutionScale.onValueChanged = v => dof.resolution.scale = v;
|
|
59
70
|
return [dof];
|
|
60
71
|
}
|
|
61
72
|
unapply() {
|
|
@@ -76,5 +87,8 @@ __decorate([
|
|
|
76
87
|
__decorate([
|
|
77
88
|
serializable(VolumeParameter)
|
|
78
89
|
], DepthOfField.prototype, "gaussianMaxRadius", void 0);
|
|
90
|
+
__decorate([
|
|
91
|
+
serializable(VolumeParameter)
|
|
92
|
+
], DepthOfField.prototype, "resolutionScale", void 0);
|
|
79
93
|
registerCustomEffectType("DepthOfField", DepthOfField);
|
|
80
94
|
//# sourceMappingURL=DepthOfField.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DepthOfField.js","sourceRoot":"","sources":["../../../../src/engine-components/postprocessing/Effects/DepthOfField.ts"],"names":[],"mappings":";;;;;;AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;
|
|
1
|
+
{"version":3,"file":"DepthOfField.js","sourceRoot":"","sources":["../../../../src/engine-components/postprocessing/Effects/DepthOfField.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
export declare type VolumeParameterChangedEvent = (newValue: any, oldValue: any, parameter: VolumeParameter) => void;
|
|
2
2
|
export declare type VolumeParameterValueProcessor = (value: any) => any;
|
|
3
3
|
export declare class VolumeParameter {
|
|
4
|
+
constructor(value?: any);
|
|
4
5
|
get overrideState(): boolean;
|
|
5
6
|
set overrideState(val: boolean);
|
|
6
7
|
private _active;
|
|
@@ -6,6 +6,10 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
|
|
|
6
6
|
};
|
|
7
7
|
import { serializable } from "../../engine/engine_serialization";
|
|
8
8
|
export class VolumeParameter {
|
|
9
|
+
constructor(value) {
|
|
10
|
+
this._value = value;
|
|
11
|
+
this._defaultValue = value;
|
|
12
|
+
}
|
|
9
13
|
get overrideState() {
|
|
10
14
|
return this._active;
|
|
11
15
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"VolumeParameter.js","sourceRoot":"","sources":["../../../src/engine-components/postprocessing/VolumeParameter.ts"],"names":[],"mappings":";;;;;;AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,mCAAmC,CAAC;AAKjE,MAAM,OAAO,eAAe;
|
|
1
|
+
{"version":3,"file":"VolumeParameter.js","sourceRoot":"","sources":["../../../src/engine-components/postprocessing/VolumeParameter.ts"],"names":[],"mappings":";;;;;;AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,mCAAmC,CAAC;AAKjE,MAAM,OAAO,eAAe;IAExB,YAAY,KAAW;QACnB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;IAC/B,CAAC;IAGD,IAAI,aAAa;QACb,OAAO,IAAI,CAAC,OAAO,CAAC;IACxB,CAAC;IACD,IAAI,aAAa,CAAC,GAAY;QAC1B,IAAI,IAAI,CAAC,OAAO,KAAK,GAAG;YAAE,OAAO;QACjC,IAAI,CAAC,OAAO,GAAG,GAAG,CAAC;QACnB,MAAM,KAAK,GAAG,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC;QAClE,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;IACnC,CAAC;IACO,OAAO,GAAY,IAAI,CAAC;IAKhC,IAAI,KAAK;QACL,OAAO,IAAI,CAAC,MAAM,CAAC;IACvB,CAAC;IACD,IAAI,KAAK,CAAC,GAAQ;QACd,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;IAClC,CAAC;IACO,MAAM,CAAM;IACZ,mBAAmB,CAAO;IAGlC,IAAI,YAAY,CAAC,GAAQ;QACrB,IAAI,CAAC,aAAa,GAAG,GAAG,CAAC;IAC7B,CAAC;IACO,aAAa,GAAQ,SAAS,CAAC;IAGvC,8EAA8E;IAC9E,MAAM;QACF,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,mBAAmB,EAAE,IAAI,CAAC,CAAC;IACtD,CAAC;IAED,2DAA2D;IAC3D,cAAc,CAA4C;IAC1D,6DAA6D;IAC7D,cAAc,CAA0C;IAGhD,YAAY,CAAC,GAAQ,EAAE,WAAoB;QAC/C,IAAI,GAAG,KAAK,IAAI,IAAI,GAAG,KAAK,SAAS;YAAE,OAAO;QAE9C,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,KAAK,KAAK;YACtD,OAAO;QAEX,MAAM,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC;QAE7B,IAAI,CAAC,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,aAAa,KAAK,SAAS,EAAE;YACnD,6HAA6H;YAC7H,8EAA8E;YAC9E,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,aAAa,CAAC;YACjC,GAAG,GAAG,IAAI,CAAC,aAAa,CAAC;SAC5B;aACI;YACD,IAAI,CAAC,mBAAmB,GAAG,GAAG,CAAC;YAC/B,IAAI,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,cAAc;gBACnC,GAAG,GAAG,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC;YACnC,IAAI,CAAC,MAAM,GAAG,GAAG,CAAC;SACrB;QAED,IAAI,IAAI,CAAC,cAAc,EAAE;YACrB,IAAI,CAAC,cAAc,CAAC,GAAG,EAAE,QAAQ,EAAE,IAAI,CAAC,CAAC;SAC5C;IACL,CAAC;IAEO,kBAAkB,CAAC,QAAa;QAEpC,IAAI,IAAI,CAAC,mBAAmB,KAAK,QAAQ;YACrC,OAAO,KAAK,CAAC;QAEjB,0IAA0I;QAE1I,OAAO,IAAI,CAAC;IAChB,CAAC;CACJ;AA5EG;IADC,YAAY,EAAE;oDAGd;AAYD;IADC,YAAY,EAAE;4CAGd"}
|