@operato/scene-visualizer 9.2.2 → 10.0.0-beta.2
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/dist/carrier.d.ts +263 -0
- package/dist/carrier.js +272 -0
- package/dist/carrier.js.map +1 -0
- package/dist/desk.d.ts +238 -3
- package/dist/desk.js +1 -2
- package/dist/desk.js.map +1 -1
- package/dist/editors/index.d.ts +1 -0
- package/dist/editors/index.js +5 -0
- package/dist/editors/index.js.map +1 -1
- package/dist/editors/property-editor-gltf-fill-targets.d.ts +17 -0
- package/dist/editors/property-editor-gltf-fill-targets.js +211 -0
- package/dist/editors/property-editor-gltf-fill-targets.js.map +1 -0
- package/dist/editors/property-editor-gltf-info.js +38 -29
- package/dist/editors/property-editor-gltf-info.js.map +1 -1
- package/dist/editors/property-editor-location-increase-pattern.js +91 -95
- package/dist/editors/property-editor-location-increase-pattern.js.map +1 -1
- package/dist/effects/outline.js +1 -1
- package/dist/effects/outline.js.map +1 -1
- package/dist/index.d.ts +5 -17
- package/dist/index.js +7 -17
- package/dist/index.js.map +1 -1
- package/dist/rack-table-3d.d.ts +16 -0
- package/dist/rack-table-3d.js +94 -0
- package/dist/rack-table-3d.js.map +1 -0
- package/dist/rack-table-cell.d.ts +238 -3
- package/dist/rack-table-cell.js +44 -51
- package/dist/rack-table-cell.js.map +1 -1
- package/dist/rack-table-location.d.ts +37 -0
- package/dist/rack-table-location.js +227 -0
- package/dist/rack-table-location.js.map +1 -0
- package/dist/rack-table.d.ts +13 -29
- package/dist/rack-table.js +108 -380
- package/dist/rack-table.js.map +1 -1
- package/dist/rack.d.ts +3 -5
- package/dist/rack.js +7 -9
- package/dist/rack.js.map +1 -1
- package/dist/signal-tower.d.ts +492 -0
- package/dist/signal-tower.js +275 -0
- package/dist/signal-tower.js.map +1 -0
- package/dist/stock.d.ts +22 -10
- package/dist/stock.js +87 -81
- package/dist/stock.js.map +1 -1
- package/dist/tank.d.ts +492 -0
- package/dist/tank.js +312 -0
- package/dist/tank.js.map +1 -0
- package/dist/templates/carrier.d.ts +19 -0
- package/dist/templates/carrier.js +20 -0
- package/dist/templates/carrier.js.map +1 -0
- package/dist/templates/cube.js +1 -1
- package/dist/templates/cube.js.map +1 -1
- package/dist/templates/cylinder.js +3 -3
- package/dist/templates/cylinder.js.map +1 -1
- package/dist/templates/index.d.ts +1 -0
- package/dist/templates/index.js +9 -1
- package/dist/templates/index.js.map +1 -1
- package/dist/templates/signal-tower.d.ts +21 -0
- package/dist/templates/signal-tower.js +22 -0
- package/dist/templates/signal-tower.js.map +1 -0
- package/dist/templates/sphere.d.ts +1 -0
- package/dist/templates/sphere.js +5 -4
- package/dist/templates/sphere.js.map +1 -1
- package/dist/templates/tank.d.ts +21 -0
- package/dist/templates/tank.js +22 -0
- package/dist/templates/tank.js.map +1 -0
- package/dist/templates/vehicle.d.ts +19 -0
- package/dist/templates/vehicle.js +20 -0
- package/dist/templates/vehicle.js.map +1 -0
- package/dist/vehicle.d.ts +248 -0
- package/dist/vehicle.js +133 -0
- package/dist/vehicle.js.map +1 -0
- package/dist/visualizer.d.ts +4 -5
- package/dist/visualizer.js +15 -28
- package/dist/visualizer.js.map +1 -1
- package/icons/carrier.png +0 -0
- package/icons/signal-tower.png +0 -0
- package/icons/tank.png +0 -0
- package/icons/vehicle.png +0 -0
- package/package.json +16 -18
- package/dist/banner.d.ts +0 -15
- package/dist/banner.js +0 -76
- package/dist/banner.js.map +0 -1
- package/dist/camera.d.ts +0 -20
- package/dist/camera.js +0 -108
- package/dist/camera.js.map +0 -1
- package/dist/cube.d.ts +0 -13
- package/dist/cube.js +0 -38
- package/dist/cube.js.map +0 -1
- package/dist/cylinder.d.ts +0 -11
- package/dist/cylinder.js +0 -38
- package/dist/cylinder.js.map +0 -1
- package/dist/ellipse.d.ts +0 -5
- package/dist/ellipse.js +0 -22
- package/dist/ellipse.js.map +0 -1
- package/dist/gltf-object.d.ts +0 -20
- package/dist/gltf-object.js +0 -104
- package/dist/gltf-object.js.map +0 -1
- package/dist/html-overlay-element.d.ts +0 -1
- package/dist/html-overlay-element.js +0 -12
- package/dist/html-overlay-element.js.map +0 -1
- package/dist/light.d.ts +0 -15
- package/dist/light.js +0 -135
- package/dist/light.js.map +0 -1
- package/dist/polygon.d.ts +0 -17
- package/dist/polygon.js +0 -64
- package/dist/polygon.js.map +0 -1
- package/dist/rect.d.ts +0 -5
- package/dist/rect.js +0 -36
- package/dist/rect.js.map +0 -1
- package/dist/scene/component.d.ts +0 -1
- package/dist/scene/component.js +0 -29
- package/dist/scene/component.js.map +0 -1
- package/dist/sphere.d.ts +0 -11
- package/dist/sphere.js +0 -38
- package/dist/sphere.js.map +0 -1
- package/dist/sprite.d.ts +0 -9
- package/dist/sprite.js +0 -28
- package/dist/sprite.js.map +0 -1
- package/dist/text.d.ts +0 -1
- package/dist/text.js +0 -9
- package/dist/text.js.map +0 -1
- package/dist/three-container-editor.d.ts +0 -22
- package/dist/three-container-editor.js +0 -132
- package/dist/three-container-editor.js.map +0 -1
- package/dist/three-container.d.ts +0 -85
- package/dist/three-container.js +0 -565
- package/dist/three-container.js.map +0 -1
- package/dist/three-controls.d.ts +0 -11
- package/dist/three-controls.js +0 -616
- package/dist/three-controls.js.map +0 -1
- package/dist/three-layout.d.ts +0 -8
- package/dist/three-layout.js +0 -20
- package/dist/three-layout.js.map +0 -1
- package/dist/three-space.d.ts +0 -85
- package/dist/three-space.js +0 -570
- package/dist/three-space.js.map +0 -1
- package/dist/threed/common.d.ts +0 -22
- package/dist/threed/common.js +0 -19
- package/dist/threed/common.js.map +0 -1
- package/dist/threed/floor/floor.d.ts +0 -3
- package/dist/threed/floor/floor.js +0 -51
- package/dist/threed/floor/floor.js.map +0 -1
- package/dist/threed/html/elements.d.ts +0 -2
- package/dist/threed/html/elements.js +0 -21
- package/dist/threed/html/elements.js.map +0 -1
- package/dist/threed/index.d.ts +0 -15
- package/dist/threed/index.js +0 -16
- package/dist/threed/index.js.map +0 -1
- package/dist/threed/real-object-camera-meshed.d.ts +0 -12
- package/dist/threed/real-object-camera-meshed.js +0 -49
- package/dist/threed/real-object-camera-meshed.js.map +0 -1
- package/dist/threed/real-object-camera.d.ts +0 -9
- package/dist/threed/real-object-camera.js +0 -31
- package/dist/threed/real-object-camera.js.map +0 -1
- package/dist/threed/real-object-dom-element.d.ts +0 -9
- package/dist/threed/real-object-dom-element.js +0 -40
- package/dist/threed/real-object-dom-element.js.map +0 -1
- package/dist/threed/real-object-dummy.d.ts +0 -6
- package/dist/threed/real-object-dummy.js +0 -11
- package/dist/threed/real-object-dummy.js.map +0 -1
- package/dist/threed/real-object-extrude.d.ts +0 -21
- package/dist/threed/real-object-extrude.js +0 -173
- package/dist/threed/real-object-extrude.js.map +0 -1
- package/dist/threed/real-object-gltf.d.ts +0 -16
- package/dist/threed/real-object-gltf.js +0 -101
- package/dist/threed/real-object-gltf.js.map +0 -1
- package/dist/threed/real-object-group.d.ts +0 -5
- package/dist/threed/real-object-group.js +0 -11
- package/dist/threed/real-object-group.js.map +0 -1
- package/dist/threed/real-object-mesh.d.ts +0 -13
- package/dist/threed/real-object-mesh.js +0 -75
- package/dist/threed/real-object-mesh.js.map +0 -1
- package/dist/threed/real-object-plane.d.ts +0 -5
- package/dist/threed/real-object-plane.js +0 -22
- package/dist/threed/real-object-plane.js.map +0 -1
- package/dist/threed/real-object-scene.d.ts +0 -21
- package/dist/threed/real-object-scene.js +0 -67
- package/dist/threed/real-object-scene.js.map +0 -1
- package/dist/threed/real-object-sprite-2d.d.ts +0 -14
- package/dist/threed/real-object-sprite-2d.js +0 -45
- package/dist/threed/real-object-sprite-2d.js.map +0 -1
- package/dist/threed/real-object-sprite.d.ts +0 -11
- package/dist/threed/real-object-sprite.js +0 -50
- package/dist/threed/real-object-sprite.js.map +0 -1
- package/dist/threed/real-object-text.d.ts +0 -15
- package/dist/threed/real-object-text.js +0 -64
- package/dist/threed/real-object-text.js.map +0 -1
- package/dist/threed/real-object.d.ts +0 -64
- package/dist/threed/real-object.js +0 -260
- package/dist/threed/real-object.js.map +0 -1
- package/dist/threed/texture/canvas-texture.d.ts +0 -4
- package/dist/threed/texture/canvas-texture.js +0 -49
- package/dist/threed/texture/canvas-texture.js.map +0 -1
- package/dist/threed/texture/text-texture.d.ts +0 -8
- package/dist/threed/texture/text-texture.js +0 -79
- package/dist/threed/texture/text-texture.js.map +0 -1
- package/dist/threed/three-dimensional-container.d.ts +0 -8
- package/dist/threed/three-dimensional-container.js +0 -2
- package/dist/threed/three-dimensional-container.js.map +0 -1
- package/dist/threed/utils/bound-uv-generator.d.ts +0 -16
- package/dist/threed/utils/bound-uv-generator.js +0 -42
- package/dist/threed/utils/bound-uv-generator.js.map +0 -1
- package/dist/wall.d.ts +0 -13
- package/dist/wall.js +0 -45
- package/dist/wall.js.map +0 -1
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
const icon = new URL('../../icons/vehicle.png', import.meta.url).href;
|
|
2
|
+
export default {
|
|
3
|
+
type: 'vehicle',
|
|
4
|
+
description: 'Vehicle (AGV/Cart)',
|
|
5
|
+
group: 'warehouse' /* line|shape|textAndMedia|chartAndGauge|table|container|dataSource|IoT|3D|warehouse|form|etc */,
|
|
6
|
+
icon,
|
|
7
|
+
model: {
|
|
8
|
+
type: 'vehicle',
|
|
9
|
+
left: 100,
|
|
10
|
+
top: 100,
|
|
11
|
+
width: 120,
|
|
12
|
+
height: 80,
|
|
13
|
+
depth: 40,
|
|
14
|
+
fillStyle: '#888888',
|
|
15
|
+
strokeStyle: '#666',
|
|
16
|
+
lineWidth: 1,
|
|
17
|
+
alpha: 1
|
|
18
|
+
}
|
|
19
|
+
};
|
|
20
|
+
//# sourceMappingURL=vehicle.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"vehicle.js","sourceRoot":"","sources":["../../src/templates/vehicle.ts"],"names":[],"mappings":"AAAA,MAAM,IAAI,GAAG,IAAI,GAAG,CAAC,yBAAyB,EAAE,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,CAAA;AAErE,eAAe;IACb,IAAI,EAAE,SAAS;IACf,WAAW,EAAE,oBAAoB;IACjC,KAAK,EAAE,WAAW,CAAC,gGAAgG;IACnH,IAAI;IACJ,KAAK,EAAE;QACL,IAAI,EAAE,SAAS;QACf,IAAI,EAAE,GAAG;QACT,GAAG,EAAE,GAAG;QACR,KAAK,EAAE,GAAG;QACV,MAAM,EAAE,EAAE;QACV,KAAK,EAAE,EAAE;QACT,SAAS,EAAE,SAAS;QACpB,WAAW,EAAE,MAAM;QACnB,SAAS,EAAE,CAAC;QACZ,KAAK,EAAE,CAAC;KACT;CACF,CAAA","sourcesContent":["const icon = new URL('../../icons/vehicle.png', import.meta.url).href\n\nexport default {\n type: 'vehicle',\n description: 'Vehicle (AGV/Cart)',\n group: 'warehouse' /* line|shape|textAndMedia|chartAndGauge|table|container|dataSource|IoT|3D|warehouse|form|etc */,\n icon,\n model: {\n type: 'vehicle',\n left: 100,\n top: 100,\n width: 120,\n height: 80,\n depth: 40,\n fillStyle: '#888888',\n strokeStyle: '#666',\n lineWidth: 1,\n alpha: 1\n }\n}\n"]}
|
|
@@ -0,0 +1,248 @@
|
|
|
1
|
+
import { ComponentNature, Shape, RealObject } from '@hatiolab/things-scene';
|
|
2
|
+
export declare class Vehicle3D extends RealObject {
|
|
3
|
+
build(): void;
|
|
4
|
+
}
|
|
5
|
+
declare const Vehicle_base: (new (...args: any[]) => {
|
|
6
|
+
contains(x: number, y: number): boolean;
|
|
7
|
+
get path(): {
|
|
8
|
+
x: any;
|
|
9
|
+
y: any;
|
|
10
|
+
}[];
|
|
11
|
+
set path(path: {
|
|
12
|
+
x: any;
|
|
13
|
+
y: any;
|
|
14
|
+
}[]): any;
|
|
15
|
+
get anchors(): {
|
|
16
|
+
name: string;
|
|
17
|
+
position: {
|
|
18
|
+
x: any;
|
|
19
|
+
y: any;
|
|
20
|
+
};
|
|
21
|
+
}[];
|
|
22
|
+
get bounds(): any;
|
|
23
|
+
set bounds(bounds: any): any;
|
|
24
|
+
render(ctx: CanvasRenderingContext2D): void;
|
|
25
|
+
_app: any;
|
|
26
|
+
_model: any;
|
|
27
|
+
_state: any;
|
|
28
|
+
_delta: any;
|
|
29
|
+
_animation: any;
|
|
30
|
+
_animate: any;
|
|
31
|
+
_parent: any;
|
|
32
|
+
_disposed: any;
|
|
33
|
+
_textHidden: any;
|
|
34
|
+
_text_substitutor: any;
|
|
35
|
+
_value_substitutor: any;
|
|
36
|
+
_mappings: any;
|
|
37
|
+
_realObject: import("@hatiolab/things-scene").IRealObject | undefined;
|
|
38
|
+
_cachedState: any;
|
|
39
|
+
updatedAt: any;
|
|
40
|
+
fontSize: any;
|
|
41
|
+
__cache__: any;
|
|
42
|
+
created(): void;
|
|
43
|
+
added(parent: any): void;
|
|
44
|
+
removed(parent: any): void;
|
|
45
|
+
ready(): Promise<void>;
|
|
46
|
+
touch(): void;
|
|
47
|
+
clearCache(...attrs: any[]): void;
|
|
48
|
+
removeSelf(completely: any): void;
|
|
49
|
+
resetAnimation(): void;
|
|
50
|
+
dispose(): void;
|
|
51
|
+
get nature(): import("@hatiolab/things-scene").ComponentNature;
|
|
52
|
+
get disposed(): boolean;
|
|
53
|
+
isLayer(): boolean;
|
|
54
|
+
isGroup(): boolean;
|
|
55
|
+
isContainer(): this is import("@hatiolab/things-scene/dist-types/types/component").Container;
|
|
56
|
+
isLine(): boolean;
|
|
57
|
+
isRoot(): boolean;
|
|
58
|
+
isRootModel(): boolean;
|
|
59
|
+
is3dish(): boolean;
|
|
60
|
+
get is3dMode(): boolean;
|
|
61
|
+
isIn3DSpace(): boolean;
|
|
62
|
+
isTemplate(): boolean;
|
|
63
|
+
isHTMLElement(): boolean;
|
|
64
|
+
isConnectable(): boolean;
|
|
65
|
+
isIdentifiable(): boolean;
|
|
66
|
+
isPositionable(): boolean;
|
|
67
|
+
replaceRefids(replaceMap: any): void;
|
|
68
|
+
get(property: any): any;
|
|
69
|
+
set(props: any, propval?: any): any;
|
|
70
|
+
getState(property: any): any;
|
|
71
|
+
setState(props: any, propval?: any): any;
|
|
72
|
+
get model(): any;
|
|
73
|
+
get state(): any;
|
|
74
|
+
get hierarchy(): any;
|
|
75
|
+
get volatile(): never[];
|
|
76
|
+
_applyProps(target: any, props: any, options: any): any;
|
|
77
|
+
move(offset: {
|
|
78
|
+
x: number;
|
|
79
|
+
y: number;
|
|
80
|
+
}, ...args: boolean[]): void;
|
|
81
|
+
symmetryX(x?: number): void;
|
|
82
|
+
symmetryY(y: number): void;
|
|
83
|
+
adjustResize(bounds: import("@hatiolab/things-scene").BOUNDS, origin_bounds: import("@hatiolab/things-scene").BOUNDS, diagonal: boolean): {
|
|
84
|
+
left: any;
|
|
85
|
+
top: any;
|
|
86
|
+
width: any;
|
|
87
|
+
height: any;
|
|
88
|
+
};
|
|
89
|
+
adjustRotation(rotation: number, step: boolean): number;
|
|
90
|
+
outline(progress: number): any;
|
|
91
|
+
get center(): import("@hatiolab/things-scene").POINT;
|
|
92
|
+
set center(p: import("@hatiolab/things-scene").POINT): any;
|
|
93
|
+
get location(): import("@hatiolab/things-scene").POINT;
|
|
94
|
+
set location(l: import("@hatiolab/things-scene").POINT): any;
|
|
95
|
+
get rotate(): import("@hatiolab/things-scene").POINT;
|
|
96
|
+
set rotate(r: import("@hatiolab/things-scene").POINT): any;
|
|
97
|
+
get dimension(): import("@hatiolab/things-scene").DIMENSION;
|
|
98
|
+
set dimension(d: import("@hatiolab/things-scene").DIMENSION): any;
|
|
99
|
+
get drawPath(): import("@hatiolab/things-scene").POINT[];
|
|
100
|
+
get rotatePoint(): import("@hatiolab/things-scene").POINT;
|
|
101
|
+
get mutable(): boolean;
|
|
102
|
+
get resizable(): boolean;
|
|
103
|
+
get rotatable(): boolean;
|
|
104
|
+
buildRealObject(): import("@hatiolab/things-scene").IRealObject | undefined;
|
|
105
|
+
get realObject(): import("@hatiolab/things-scene").IRealObject | undefined;
|
|
106
|
+
draw(context?: import("@hatiolab/things-scene").SceneRenderContext): void;
|
|
107
|
+
prerender(context: import("@hatiolab/things-scene").SceneRenderContext): void;
|
|
108
|
+
postrender(context: import("@hatiolab/things-scene").SceneRenderContext): void;
|
|
109
|
+
prepare(resolve: (component: import("@hatiolab/things-scene").Component) => void, reject: (reason: any) => void): void;
|
|
110
|
+
prepareIf(condition: boolean): void;
|
|
111
|
+
drawText(context: import("@hatiolab/things-scene").SceneRenderContext): void;
|
|
112
|
+
drawStroke(context: import("@hatiolab/things-scene").SceneRenderContext, override?: Record<string, unknown>): void;
|
|
113
|
+
drawFill(context: import("@hatiolab/things-scene").SceneRenderContext, override?: Record<string, unknown>): void;
|
|
114
|
+
get strokeStyle(): any;
|
|
115
|
+
set strokeStyle(v: any): any;
|
|
116
|
+
get fillStyle(): any;
|
|
117
|
+
set fillStyle(v: any): any;
|
|
118
|
+
get fontColor(): string;
|
|
119
|
+
set fontColor(v: string): any;
|
|
120
|
+
get rotation(): number;
|
|
121
|
+
set rotation(v: number): any;
|
|
122
|
+
get decorators(): string[];
|
|
123
|
+
get decotag(): string;
|
|
124
|
+
get hidden(): boolean;
|
|
125
|
+
set hidden(v: boolean): any;
|
|
126
|
+
get tag(): string;
|
|
127
|
+
set tag(v: string): any;
|
|
128
|
+
get appendum(): any;
|
|
129
|
+
set appendum(v: any): any;
|
|
130
|
+
defaultTextSubstitutor(): string;
|
|
131
|
+
textLines(context?: import("@hatiolab/things-scene").SceneRenderContext): any[][];
|
|
132
|
+
get font(): string;
|
|
133
|
+
get lineHeight(): number;
|
|
134
|
+
get textSubstitutor(): () => string;
|
|
135
|
+
get text(): string;
|
|
136
|
+
set text(v: string): any;
|
|
137
|
+
get textBounds(): import("@hatiolab/things-scene").BOUNDS;
|
|
138
|
+
get textRotation(): number;
|
|
139
|
+
get textHidden(): boolean;
|
|
140
|
+
set textHidden(v: boolean): any;
|
|
141
|
+
get hasTextProperty(): boolean;
|
|
142
|
+
animate(opts: import("@hatiolab/things-scene").AnimationConfig): any;
|
|
143
|
+
effect(context: import("@hatiolab/things-scene").SceneRenderContext, model: any): void;
|
|
144
|
+
serialize(...others: any[]): string;
|
|
145
|
+
trim(): void;
|
|
146
|
+
closeScene(data: any): void;
|
|
147
|
+
delta(attr?: string | object, value?: any): any;
|
|
148
|
+
invalidate(): void;
|
|
149
|
+
get value(): any;
|
|
150
|
+
set value(v: any): any;
|
|
151
|
+
get data(): any;
|
|
152
|
+
set data(v: any): any;
|
|
153
|
+
set tap(v: any): any;
|
|
154
|
+
get mappings(): any[];
|
|
155
|
+
get retention(): number;
|
|
156
|
+
get animation(): import("@hatiolab/things-scene").AnimationController | undefined;
|
|
157
|
+
get started(): boolean;
|
|
158
|
+
set started(v: boolean): any;
|
|
159
|
+
get controls(): import("@hatiolab/things-scene").Control[] | undefined;
|
|
160
|
+
findFirst(finder: string | ((c: import("@hatiolab/things-scene").Component) => boolean), ...others: any[]): import("@hatiolab/things-scene").Component | undefined;
|
|
161
|
+
findAll(s: string | ((c: import("@hatiolab/things-scene").Component) => boolean), ...others: any[]): any[] | undefined;
|
|
162
|
+
capture(x: number, y: number, except?: (c: import("@hatiolab/things-scene").Component) => boolean): any;
|
|
163
|
+
findAnchor(name: string): any;
|
|
164
|
+
isDescendible(container: import("@hatiolab/things-scene").Component): boolean;
|
|
165
|
+
getContext(component?: unknown): any;
|
|
166
|
+
get root(): import("@hatiolab/things-scene").Component;
|
|
167
|
+
get rootModel(): import("@hatiolab/things-scene").Component;
|
|
168
|
+
get parent(): import("@hatiolab/things-scene").Component;
|
|
169
|
+
set parent(v: import("@hatiolab/things-scene").Component): any;
|
|
170
|
+
get scalable(): boolean;
|
|
171
|
+
get stuck(): boolean;
|
|
172
|
+
get capturable(): boolean;
|
|
173
|
+
get position(): string;
|
|
174
|
+
get origin(): string;
|
|
175
|
+
get offset(): import("@hatiolab/things-scene").POINT;
|
|
176
|
+
get app(): import("@hatiolab/things-scene").ApplicationContext;
|
|
177
|
+
drawEffect(context: import("@hatiolab/things-scene").SceneRenderContext): void;
|
|
178
|
+
prepareFill(resolve: Function, reject: Function): void;
|
|
179
|
+
prepareFillIf(condition: boolean): void;
|
|
180
|
+
onchangeFill(after: Record<string, any>, before: Record<string, any>): void;
|
|
181
|
+
drawImage(context: import("@hatiolab/things-scene").SceneRenderContext, image: HTMLImageElement, left: number, top: number, width: number, height: number): void;
|
|
182
|
+
mutateBounds(logic: ((bounds: import("@hatiolab/things-scene").BOUNDS) => import("@hatiolab/things-scene").BOUNDS | void) | null, context?: any): void;
|
|
183
|
+
mutatePath(beforeLogic: ((path: import("@hatiolab/things-scene").POINT[]) => import("@hatiolab/things-scene").POINT[] | void) | null, afterLogic: ((path: import("@hatiolab/things-scene").POINT[]) => import("@hatiolab/things-scene").POINT[] | void) | null, context?: any): void;
|
|
184
|
+
access(accessor: string): any;
|
|
185
|
+
substitute(template: string, data: any): string | undefined;
|
|
186
|
+
onchangeMappings(after: Record<string, any>, before: Record<string, any>): void;
|
|
187
|
+
onchangeData(after: Record<string, any>, before: Record<string, any>): void;
|
|
188
|
+
buildMappings(): void;
|
|
189
|
+
executeMappings(force?: boolean): void;
|
|
190
|
+
disposeMappings(): void;
|
|
191
|
+
ondropfile(transfered: FileList, files: string[]): void;
|
|
192
|
+
transcoordS2P(x: number, y: number, rp?: import("@hatiolab/things-scene").POINT): import("@hatiolab/things-scene").POINT;
|
|
193
|
+
transcoordP2S(x: number, y: number, rp?: import("@hatiolab/things-scene").POINT): import("@hatiolab/things-scene").POINT;
|
|
194
|
+
transcoordS2T(x: number, y: number, top?: import("@hatiolab/things-scene").Component): import("@hatiolab/things-scene").POINT;
|
|
195
|
+
transcoordT2P(x: number, y: number, top?: import("@hatiolab/things-scene").Component): import("@hatiolab/things-scene").POINT;
|
|
196
|
+
transcoordT2S(x: number, y: number, top?: import("@hatiolab/things-scene").Component): import("@hatiolab/things-scene").POINT;
|
|
197
|
+
transcoordS2TR(x: number, y: number, top?: import("@hatiolab/things-scene").Component): import("@hatiolab/things-scene").POINT;
|
|
198
|
+
transcoordS2O(x: number, y: number, target: import("@hatiolab/things-scene").Component): import("@hatiolab/things-scene").POINT;
|
|
199
|
+
transcoordC2S(x: number, y: number, top?: import("@hatiolab/things-scene").Component): import("@hatiolab/things-scene").POINT;
|
|
200
|
+
transcoordS2C(x: number, y: number, top?: import("@hatiolab/things-scene").Component): import("@hatiolab/things-scene").POINT;
|
|
201
|
+
toParent(x: number, y: number, rp?: import("@hatiolab/things-scene").POINT): import("@hatiolab/things-scene").POINT;
|
|
202
|
+
fromParent(x: number, y: number, rp?: import("@hatiolab/things-scene").POINT): import("@hatiolab/things-scene").POINT;
|
|
203
|
+
toScene(x: number, y: number, top?: import("@hatiolab/things-scene").Component): import("@hatiolab/things-scene").POINT;
|
|
204
|
+
fromScene(x: number, y: number, top?: import("@hatiolab/things-scene").Component): import("@hatiolab/things-scene").POINT;
|
|
205
|
+
toLocal(x: number, y: number, top?: import("@hatiolab/things-scene").Component): import("@hatiolab/things-scene").POINT;
|
|
206
|
+
toGlobal(x: number, y: number, top?: import("@hatiolab/things-scene").Component): import("@hatiolab/things-scene").POINT;
|
|
207
|
+
toOther(x: number, y: number, target: import("@hatiolab/things-scene").Component): import("@hatiolab/things-scene").POINT;
|
|
208
|
+
on(name: string | object, callback: Function, context?: any): any;
|
|
209
|
+
off(name?: string | object, callback?: Function, context?: any): any;
|
|
210
|
+
once(name: string | object, callback: Function, context?: any): any;
|
|
211
|
+
trigger(name: string, ...args: any[]): any;
|
|
212
|
+
delegate_on(delegator: any): any;
|
|
213
|
+
delegate_off(delegator: any): any;
|
|
214
|
+
onchange(after: Record<string, any>, before: Record<string, any>): void;
|
|
215
|
+
calculateBounds?(): void;
|
|
216
|
+
oncreate_element?(element: HTMLElement): void;
|
|
217
|
+
removeComponent(component: import("@hatiolab/things-scene").Component, ghost?: boolean): void;
|
|
218
|
+
addComponent(component: import("@hatiolab/things-scene").Component, ghost?: boolean): void;
|
|
219
|
+
insertComponentAt(component: import("@hatiolab/things-scene").Component, index: number, ghost?: boolean): void;
|
|
220
|
+
getOverlay(component: import("@hatiolab/things-scene").Component): HTMLElement | undefined;
|
|
221
|
+
findById(id: string): import("@hatiolab/things-scene").Component | undefined;
|
|
222
|
+
findByRefid(ref: string | number): import("@hatiolab/things-scene").Component | undefined;
|
|
223
|
+
findAllById(id: string): import("@hatiolab/things-scene").Component[];
|
|
224
|
+
resize(): void;
|
|
225
|
+
fit(type?: string): void;
|
|
226
|
+
get components(): import("@hatiolab/things-scene").Component[] | undefined;
|
|
227
|
+
get layout(): any;
|
|
228
|
+
get auxOverlay(): HTMLElement | undefined;
|
|
229
|
+
get isReady(): boolean;
|
|
230
|
+
get unitScale(): number;
|
|
231
|
+
get selected(): import("@hatiolab/things-scene").Component[];
|
|
232
|
+
set selected(_v: import("@hatiolab/things-scene").Component[]): any;
|
|
233
|
+
get focused(): import("@hatiolab/things-scene").Component | null;
|
|
234
|
+
set focused(_v: import("@hatiolab/things-scene").Component | null): any;
|
|
235
|
+
get hasSameParentForAllSelected(): boolean;
|
|
236
|
+
set hasSameParentForAllSelected(_v: boolean): any;
|
|
237
|
+
get fitMode(): string | undefined;
|
|
238
|
+
set fitMode(_v: string | undefined): any;
|
|
239
|
+
get element(): HTMLElement | null;
|
|
240
|
+
set element(_v: HTMLElement | null): any;
|
|
241
|
+
}) & typeof Shape;
|
|
242
|
+
export declare class Vehicle extends Vehicle_base {
|
|
243
|
+
is3dish(): boolean;
|
|
244
|
+
buildRealObject(): RealObject | undefined;
|
|
245
|
+
get nature(): ComponentNature;
|
|
246
|
+
render(ctx: CanvasRenderingContext2D): void;
|
|
247
|
+
}
|
|
248
|
+
export {};
|
package/dist/vehicle.js
ADDED
|
@@ -0,0 +1,133 @@
|
|
|
1
|
+
import { __decorate } from "tslib";
|
|
2
|
+
/*
|
|
3
|
+
* Copyright © HatioLab Inc. All rights reserved.
|
|
4
|
+
*/
|
|
5
|
+
import { RectPath, Shape, sceneComponent, RealObject } from '@hatiolab/things-scene';
|
|
6
|
+
import * as THREE from 'three';
|
|
7
|
+
import { RoundedBoxGeometry } from 'three/examples/jsm/geometries/RoundedBoxGeometry.js';
|
|
8
|
+
const NATURE = {
|
|
9
|
+
mutable: false,
|
|
10
|
+
resizable: true,
|
|
11
|
+
rotatable: true,
|
|
12
|
+
properties: [
|
|
13
|
+
{
|
|
14
|
+
type: 'color',
|
|
15
|
+
label: 'platform-color',
|
|
16
|
+
name: 'platformColor',
|
|
17
|
+
property: 'platformColor'
|
|
18
|
+
}
|
|
19
|
+
],
|
|
20
|
+
help: 'scene/component/vehicle'
|
|
21
|
+
};
|
|
22
|
+
const DEFAULT_PLATFORM_COLOR = '#333333';
|
|
23
|
+
const DEFAULT_BODY_COLOR = '#f0f0f0';
|
|
24
|
+
const BUMPER_COLOR = '#222222';
|
|
25
|
+
export class Vehicle3D extends RealObject {
|
|
26
|
+
build() {
|
|
27
|
+
super.build();
|
|
28
|
+
var { width, height, depth, fillStyle, platformColor } = this.component.state;
|
|
29
|
+
var w = width;
|
|
30
|
+
var h = height;
|
|
31
|
+
var d = depth || 50;
|
|
32
|
+
// 비율: 하단 범퍼 10%, 본체 58%, 간격 4%, 플랫폼 28%
|
|
33
|
+
var bumperH = d * 0.10;
|
|
34
|
+
var bodyH = d * 0.58;
|
|
35
|
+
var gapH = d * 0.04;
|
|
36
|
+
var platH = d * 0.28;
|
|
37
|
+
var totalH = bumperH + bodyH + gapH + platH;
|
|
38
|
+
var cornerR = Math.min(w, h, bodyH) * 0.12;
|
|
39
|
+
// ── 하단 범퍼 밴드 (본체보다 약간 넓게 돌출) ──
|
|
40
|
+
var bumperPad = Math.min(w, h) * 0.03;
|
|
41
|
+
var bumperCornerR = Math.min(w + bumperPad * 2, h + bumperPad * 2, bumperH) * 0.2;
|
|
42
|
+
var bumperGeo = new RoundedBoxGeometry(w + bumperPad * 2, bumperH, h + bumperPad * 2, 4, bumperCornerR);
|
|
43
|
+
var bumperMat = new THREE.MeshStandardMaterial({
|
|
44
|
+
color: BUMPER_COLOR,
|
|
45
|
+
roughness: 0.8,
|
|
46
|
+
metalness: 0.1
|
|
47
|
+
});
|
|
48
|
+
var bumper = new THREE.Mesh(bumperGeo, bumperMat);
|
|
49
|
+
bumper.position.y = bumperH / 2;
|
|
50
|
+
bumper.castShadow = true;
|
|
51
|
+
this.object3d.add(bumper);
|
|
52
|
+
// ── 본체 (둥근 모서리, 밝은색) ──
|
|
53
|
+
var bodyGeo = new RoundedBoxGeometry(w, bodyH, h, 4, cornerR);
|
|
54
|
+
var bodyMat = new THREE.MeshStandardMaterial({
|
|
55
|
+
color: fillStyle || DEFAULT_BODY_COLOR,
|
|
56
|
+
roughness: 0.3,
|
|
57
|
+
metalness: 0.05
|
|
58
|
+
});
|
|
59
|
+
var body = new THREE.Mesh(bodyGeo, bodyMat);
|
|
60
|
+
body.position.y = bumperH + bodyH / 2;
|
|
61
|
+
body.castShadow = true;
|
|
62
|
+
this.object3d.add(body);
|
|
63
|
+
// ── 상단 플랫폼 (본체보다 약간 안쪽, 어두운색) ──
|
|
64
|
+
var platInset = Math.min(w, h) * 0.04;
|
|
65
|
+
var platCornerR = Math.min(w - platInset * 2, h - platInset * 2, platH) * 0.15;
|
|
66
|
+
var platGeo = new RoundedBoxGeometry(w - platInset * 2, platH, h - platInset * 2, 4, platCornerR);
|
|
67
|
+
var platMat = new THREE.MeshStandardMaterial({
|
|
68
|
+
color: platformColor || DEFAULT_PLATFORM_COLOR,
|
|
69
|
+
roughness: 0.5,
|
|
70
|
+
metalness: 0.15
|
|
71
|
+
});
|
|
72
|
+
var plat = new THREE.Mesh(platGeo, platMat);
|
|
73
|
+
plat.position.y = bumperH + bodyH + gapH + platH / 2;
|
|
74
|
+
plat.castShadow = true;
|
|
75
|
+
this.object3d.add(plat);
|
|
76
|
+
// 수직 중앙 정렬
|
|
77
|
+
this.object3d.children.forEach(child => {
|
|
78
|
+
child.position.y -= totalH / 2;
|
|
79
|
+
});
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
/* ── 2D 렌더 ── */
|
|
83
|
+
function renderVehicle(ctx, x, y, w, h, fillStyle, platformColor) {
|
|
84
|
+
var r = Math.min(w, h) * 0.1;
|
|
85
|
+
var bumperH = Math.max(3, h * 0.10);
|
|
86
|
+
var platH = Math.max(4, h * 0.25);
|
|
87
|
+
var platInset = Math.min(w, h) * 0.04;
|
|
88
|
+
// 하단 범퍼 밴드 (본체보다 약간 넓게)
|
|
89
|
+
var bumperPad = Math.min(w, h) * 0.02;
|
|
90
|
+
ctx.fillStyle = BUMPER_COLOR;
|
|
91
|
+
ctx.beginPath();
|
|
92
|
+
ctx.roundRect(x - bumperPad, y + h - bumperH, w + bumperPad * 2, bumperH, [0, 0, r, r]);
|
|
93
|
+
ctx.fill();
|
|
94
|
+
// 본체 (둥근 사각형)
|
|
95
|
+
ctx.fillStyle = fillStyle || DEFAULT_BODY_COLOR;
|
|
96
|
+
ctx.beginPath();
|
|
97
|
+
ctx.roundRect(x, y + platH + 2, w, h - platH - bumperH - 2, r * 0.5);
|
|
98
|
+
ctx.fill();
|
|
99
|
+
ctx.strokeStyle = '#dddddd';
|
|
100
|
+
ctx.lineWidth = 0.5;
|
|
101
|
+
ctx.beginPath();
|
|
102
|
+
ctx.roundRect(x, y + platH + 2, w, h - platH - bumperH - 2, r * 0.5);
|
|
103
|
+
ctx.stroke();
|
|
104
|
+
// 상단 플랫폼 (약간 안쪽)
|
|
105
|
+
ctx.fillStyle = platformColor || DEFAULT_PLATFORM_COLOR;
|
|
106
|
+
ctx.beginPath();
|
|
107
|
+
ctx.roundRect(x + platInset, y, w - platInset * 2, platH, [r, r, 0, 0]);
|
|
108
|
+
ctx.fill();
|
|
109
|
+
}
|
|
110
|
+
let Vehicle = class Vehicle extends RectPath(Shape) {
|
|
111
|
+
is3dish() {
|
|
112
|
+
return true;
|
|
113
|
+
}
|
|
114
|
+
buildRealObject() {
|
|
115
|
+
return new Vehicle3D(this);
|
|
116
|
+
}
|
|
117
|
+
get nature() {
|
|
118
|
+
return NATURE;
|
|
119
|
+
}
|
|
120
|
+
render(ctx) {
|
|
121
|
+
var { left, top, width, height } = this.bounds;
|
|
122
|
+
var fillStyle = this.getState('fillStyle');
|
|
123
|
+
var platformColor = this.getState('platformColor');
|
|
124
|
+
renderVehicle(ctx, left, top, width, height, fillStyle, platformColor);
|
|
125
|
+
ctx.beginPath();
|
|
126
|
+
ctx.rect(left, top, width, height);
|
|
127
|
+
}
|
|
128
|
+
};
|
|
129
|
+
Vehicle = __decorate([
|
|
130
|
+
sceneComponent('vehicle')
|
|
131
|
+
], Vehicle);
|
|
132
|
+
export { Vehicle };
|
|
133
|
+
//# sourceMappingURL=vehicle.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"vehicle.js","sourceRoot":"","sources":["../src/vehicle.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright © HatioLab Inc. All rights reserved.\n */\nimport { ComponentNature, RectPath, Shape, sceneComponent, RealObject } from '@hatiolab/things-scene'\nimport * as THREE from 'three'\nimport { RoundedBoxGeometry } from 'three/examples/jsm/geometries/RoundedBoxGeometry.js'\n\nconst NATURE: ComponentNature = {\n mutable: false,\n resizable: true,\n rotatable: true,\n properties: [\n {\n type: 'color',\n label: 'platform-color',\n name: 'platformColor',\n property: 'platformColor'\n }\n ],\n help: 'scene/component/vehicle'\n}\n\nconst DEFAULT_PLATFORM_COLOR = '#333333'\nconst DEFAULT_BODY_COLOR = '#f0f0f0'\nconst BUMPER_COLOR = '#222222'\n\nexport class Vehicle3D extends RealObject {\n build() {\n super.build()\n\n var { width, height, depth, fillStyle, platformColor } = this.component.state\n\n var w = width\n var h = height\n var d = depth || 50\n\n // 비율: 하단 범퍼 10%, 본체 58%, 간격 4%, 플랫폼 28%\n var bumperH = d * 0.10\n var bodyH = d * 0.58\n var gapH = d * 0.04\n var platH = d * 0.28\n var totalH = bumperH + bodyH + gapH + platH\n\n var cornerR = Math.min(w, h, bodyH) * 0.12\n\n // ── 하단 범퍼 밴드 (본체보다 약간 넓게 돌출) ──\n var bumperPad = Math.min(w, h) * 0.03\n var bumperCornerR = Math.min(w + bumperPad * 2, h + bumperPad * 2, bumperH) * 0.2\n var bumperGeo = new RoundedBoxGeometry(w + bumperPad * 2, bumperH, h + bumperPad * 2, 4, bumperCornerR)\n var bumperMat = new THREE.MeshStandardMaterial({\n color: BUMPER_COLOR,\n roughness: 0.8,\n metalness: 0.1\n })\n var bumper = new THREE.Mesh(bumperGeo, bumperMat)\n bumper.position.y = bumperH / 2\n bumper.castShadow = true\n this.object3d.add(bumper)\n\n // ── 본체 (둥근 모서리, 밝은색) ──\n var bodyGeo = new RoundedBoxGeometry(w, bodyH, h, 4, cornerR)\n var bodyMat = new THREE.MeshStandardMaterial({\n color: fillStyle || DEFAULT_BODY_COLOR,\n roughness: 0.3,\n metalness: 0.05\n })\n var body = new THREE.Mesh(bodyGeo, bodyMat)\n body.position.y = bumperH + bodyH / 2\n body.castShadow = true\n this.object3d.add(body)\n\n // ── 상단 플랫폼 (본체보다 약간 안쪽, 어두운색) ──\n var platInset = Math.min(w, h) * 0.04\n var platCornerR = Math.min(w - platInset * 2, h - platInset * 2, platH) * 0.15\n var platGeo = new RoundedBoxGeometry(w - platInset * 2, platH, h - platInset * 2, 4, platCornerR)\n var platMat = new THREE.MeshStandardMaterial({\n color: platformColor || DEFAULT_PLATFORM_COLOR,\n roughness: 0.5,\n metalness: 0.15\n })\n var plat = new THREE.Mesh(platGeo, platMat)\n plat.position.y = bumperH + bodyH + gapH + platH / 2\n plat.castShadow = true\n this.object3d.add(plat)\n\n // 수직 중앙 정렬\n this.object3d.children.forEach(child => {\n child.position.y -= totalH / 2\n })\n }\n}\n\n/* ── 2D 렌더 ── */\n\nfunction renderVehicle(\n ctx: CanvasRenderingContext2D,\n x: number,\n y: number,\n w: number,\n h: number,\n fillStyle: string,\n platformColor: string\n) {\n var r = Math.min(w, h) * 0.1\n var bumperH = Math.max(3, h * 0.10)\n var platH = Math.max(4, h * 0.25)\n var platInset = Math.min(w, h) * 0.04\n\n // 하단 범퍼 밴드 (본체보다 약간 넓게)\n var bumperPad = Math.min(w, h) * 0.02\n ctx.fillStyle = BUMPER_COLOR\n ctx.beginPath()\n ctx.roundRect(x - bumperPad, y + h - bumperH, w + bumperPad * 2, bumperH, [0, 0, r, r])\n ctx.fill()\n\n // 본체 (둥근 사각형)\n ctx.fillStyle = fillStyle || DEFAULT_BODY_COLOR\n ctx.beginPath()\n ctx.roundRect(x, y + platH + 2, w, h - platH - bumperH - 2, r * 0.5)\n ctx.fill()\n\n ctx.strokeStyle = '#dddddd'\n ctx.lineWidth = 0.5\n ctx.beginPath()\n ctx.roundRect(x, y + platH + 2, w, h - platH - bumperH - 2, r * 0.5)\n ctx.stroke()\n\n // 상단 플랫폼 (약간 안쪽)\n ctx.fillStyle = platformColor || DEFAULT_PLATFORM_COLOR\n ctx.beginPath()\n ctx.roundRect(x + platInset, y, w - platInset * 2, platH, [r, r, 0, 0])\n ctx.fill()\n}\n\n@sceneComponent('vehicle')\nexport class Vehicle extends RectPath(Shape) {\n is3dish() {\n return true\n }\n\n buildRealObject(): RealObject | undefined {\n return new Vehicle3D(this as any)\n }\n\n get nature() {\n return NATURE\n }\n\n render(ctx: CanvasRenderingContext2D) {\n var { left, top, width, height } = this.bounds\n var fillStyle = this.getState('fillStyle')\n var platformColor = this.getState('platformColor')\n\n renderVehicle(ctx, left, top, width, height, fillStyle, platformColor)\n\n ctx.beginPath()\n ctx.rect(left, top, width, height)\n }\n}\n"]}
|
package/dist/visualizer.d.ts
CHANGED
|
@@ -1,9 +1,7 @@
|
|
|
1
|
-
import { Component, Properties, ComponentNature } from '@hatiolab/things-scene';
|
|
1
|
+
import { Component, Properties, ComponentNature, RealObject, ThreeContainer } from '@hatiolab/things-scene';
|
|
2
2
|
import * as THREE from 'three';
|
|
3
|
-
import {
|
|
4
|
-
|
|
5
|
-
import { ThreeContainer } from './three-container.js';
|
|
6
|
-
export declare class Visualizer extends ThreeContainer {
|
|
3
|
+
import { type StockMaterialProvider } from './stock.js';
|
|
4
|
+
export declare class Visualizer extends ThreeContainer implements StockMaterialProvider {
|
|
7
5
|
_legendTarget?: Component;
|
|
8
6
|
_objects: {
|
|
9
7
|
[id: string]: RealObject;
|
|
@@ -11,6 +9,7 @@ export declare class Visualizer extends ThreeContainer {
|
|
|
11
9
|
_stock_materials: THREE.Material[];
|
|
12
10
|
_default_material?: THREE.Material;
|
|
13
11
|
_empty_material?: THREE.Material;
|
|
12
|
+
get hideEmptyStock(): boolean;
|
|
14
13
|
get legendTarget(): Component | undefined;
|
|
15
14
|
putObject(id: string, object: RealObject): void;
|
|
16
15
|
getObject(id: string): RealObject;
|
package/dist/visualizer.js
CHANGED
|
@@ -2,9 +2,7 @@
|
|
|
2
2
|
* Copyright © HatioLab Inc. All rights reserved.
|
|
3
3
|
*/
|
|
4
4
|
import { __decorate } from "tslib";
|
|
5
|
-
import { ScenePopup, sceneComponent } from '@hatiolab/things-scene';
|
|
6
|
-
import './three-layout.js';
|
|
7
|
-
import { ThreeContainer } from './three-container.js';
|
|
5
|
+
import { ScenePopup, sceneComponent, ThreeContainer } from '@hatiolab/things-scene';
|
|
8
6
|
import { Stock } from './stock.js';
|
|
9
7
|
const NATURE = {
|
|
10
8
|
mutable: false,
|
|
@@ -144,15 +142,18 @@ const NATURE = {
|
|
|
144
142
|
};
|
|
145
143
|
const WEBGL_NO_SUPPORT_TEXT = 'WebGL no support';
|
|
146
144
|
let Visualizer = class Visualizer extends ThreeContainer {
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
145
|
+
_legendTarget;
|
|
146
|
+
_objects = {};
|
|
147
|
+
_stock_materials = [];
|
|
148
|
+
_default_material;
|
|
149
|
+
_empty_material;
|
|
150
|
+
get hideEmptyStock() {
|
|
151
|
+
return !!this.getState('hideEmptyStock');
|
|
151
152
|
}
|
|
152
153
|
get legendTarget() {
|
|
153
154
|
var { legendTarget } = this.state;
|
|
154
155
|
if (!this._legendTarget && legendTarget) {
|
|
155
|
-
this._legendTarget = this.root.findById(legendTarget);
|
|
156
|
+
this._legendTarget = this.root.findById?.(legendTarget);
|
|
156
157
|
this._legendTarget && this._legendTarget.on('change', this.onLegendTargetChanged, this);
|
|
157
158
|
}
|
|
158
159
|
return this._legendTarget;
|
|
@@ -244,24 +245,15 @@ let Visualizer = class Visualizer extends ThreeContainer {
|
|
|
244
245
|
this.resetMaterials();
|
|
245
246
|
}
|
|
246
247
|
onmouseup(e) {
|
|
247
|
-
|
|
248
|
-
if (this._controls) {
|
|
249
|
-
if (this._lastFocused) {
|
|
250
|
-
;
|
|
251
|
-
this._lastFocused._focused = false;
|
|
252
|
-
}
|
|
248
|
+
if (this.controlsManager.isActive) {
|
|
253
249
|
const { popupScene, left, top, width, height } = this.state;
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
this.
|
|
257
|
-
this._mouse.y = -((pointer.y - top) / height) * 2 + 1;
|
|
258
|
-
var object = this.getObjectByRaycast();
|
|
259
|
-
var realObject = object === null || object === void 0 ? void 0 : object.userData.context;
|
|
250
|
+
const pointer = this.transcoordC2S(e.offsetX, e.offsetY);
|
|
251
|
+
this.eventManager.updateMouseNDC(pointer.x, pointer.y, left, top, width, height);
|
|
252
|
+
const realObject = this.eventManager.handleClick(this.cameraManager.camera, this.sceneManager.scene, e);
|
|
260
253
|
if (realObject) {
|
|
261
|
-
if (
|
|
262
|
-
;
|
|
254
|
+
if (popupScene && realObject instanceof Stock) {
|
|
263
255
|
realObject.onmouseup(e, this, (data) => {
|
|
264
|
-
ScenePopup.show(this,
|
|
256
|
+
ScenePopup.show(this, popupScene, {
|
|
265
257
|
data,
|
|
266
258
|
modal: false,
|
|
267
259
|
closable: true,
|
|
@@ -270,11 +262,6 @@ let Visualizer = class Visualizer extends ThreeContainer {
|
|
|
270
262
|
});
|
|
271
263
|
});
|
|
272
264
|
}
|
|
273
|
-
;
|
|
274
|
-
realObject._focused = true;
|
|
275
|
-
realObject._focusedAt = performance.now();
|
|
276
|
-
this._lastFocused = realObject;
|
|
277
|
-
(_a = realObject.component) === null || _a === void 0 ? void 0 : _a.trigger('click', e);
|
|
278
265
|
}
|
|
279
266
|
else {
|
|
280
267
|
ScenePopup.hide(this.root);
|
package/dist/visualizer.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"visualizer.js","sourceRoot":"","sources":["../src/visualizer.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright © HatioLab Inc. All rights reserved.\n */\n\nimport { Component, ScenePopup, Properties, ComponentNature, sceneComponent } from '@hatiolab/things-scene'\nimport * as THREE from 'three'\n\nimport { RealObject } from './threed/real-object.js'\nimport './three-layout.js'\nimport { ThreeContainer } from './three-container.js'\nimport { Stock } from './stock.js'\n\nconst NATURE: ComponentNature = {\n mutable: false,\n resizable: true,\n rotatable: true,\n properties: [\n {\n type: 'number',\n label: 'fov',\n name: 'fov',\n property: 'fov'\n },\n {\n type: 'number',\n label: 'near',\n name: 'near',\n property: 'near'\n },\n {\n type: 'number',\n label: 'far',\n name: 'far',\n property: 'far'\n },\n {\n type: 'number',\n label: 'zoom',\n name: 'zoom',\n property: 'zoom'\n },\n {\n type: 'number',\n label: 'camera-x',\n name: 'cameraX'\n },\n {\n type: 'number',\n label: 'camera-y',\n name: 'cameraY'\n },\n {\n type: 'number',\n label: 'camera-z',\n name: 'cameraZ'\n },\n {\n type: 'select',\n label: 'precision',\n name: 'precision',\n property: {\n options: [\n {\n display: 'High',\n value: 'highp'\n },\n {\n display: 'Medium',\n value: 'mediump'\n },\n {\n display: 'Low',\n value: 'lowp'\n }\n ]\n }\n },\n {\n type: 'checkbox',\n label: 'anti-alias',\n name: 'antialias',\n property: 'antialias'\n },\n {\n type: 'checkbox',\n label: 'auto-rotate',\n name: 'autoRotate',\n property: 'autoRotate'\n },\n {\n type: 'checkbox',\n label: '3dmode',\n name: 'threed',\n property: 'threed'\n },\n {\n type: 'checkbox',\n label: 'debug',\n name: 'debug',\n property: 'debug'\n },\n {\n type: 'string',\n label: 'location-field',\n name: 'locationField',\n placeholder: 'location'\n },\n {\n type: 'board-selector',\n label: 'popup-scene',\n name: 'popupScene'\n },\n {\n type: 'id-input',\n label: 'legend-target',\n name: 'legendTarget',\n property: {\n component: 'legend'\n }\n },\n {\n type: 'number',\n label: 'rotation-speed',\n name: 'rotationSpeed'\n },\n {\n type: 'checkbox',\n label: 'hide-empty-stock',\n name: 'hideEmptyStock'\n },\n {\n type: 'select',\n label: 'popup-position',\n name: 'popupPosition',\n property: {\n options: [\n { display: '', value: '' },\n { display: 'CENTER', value: 'center' },\n { display: 'LEFTTOP', value: 'left-top' },\n { display: 'RIGHTTOP', value: 'right-top' },\n { display: 'LEFTBOTTOM', value: 'left-bottom' },\n { display: 'RIGHTBOTTOM', value: 'right-bottom' }\n ]\n }\n }\n ],\n help: 'scene/component/visualizer'\n}\n\nconst WEBGL_NO_SUPPORT_TEXT = 'WebGL no support'\n\n@sceneComponent('visualizer')\nexport class Visualizer extends ThreeContainer {\n _legendTarget?: Component\n\n _objects: { [id: string]: RealObject } = {}\n\n _stock_materials: THREE.Material[] = []\n _default_material?: THREE.Material /* only for Stock */\n _empty_material?: THREE.Material /* only for Stock */\n\n get legendTarget() {\n var { legendTarget } = this.state\n\n if (!this._legendTarget && legendTarget) {\n this._legendTarget = this.root.findById(legendTarget)\n this._legendTarget && this._legendTarget.on('change', this.onLegendTargetChanged, this)\n }\n\n return this._legendTarget\n }\n\n putObject(id: string, object: RealObject) {\n id && (this._objects[id] = object)\n }\n\n getObject(id: string): RealObject {\n return this._objects[id]\n }\n\n /* Container Overides .. */\n\n dispose() {\n this._legendTarget && this._legendTarget.off('change', this.onLegendTargetChanged, this)\n delete this._legendTarget\n\n super.dispose()\n }\n\n get nature(): ComponentNature {\n return NATURE\n }\n\n resetMaterials() {\n this._stock_materials.forEach(m => {\n if (m.dispose) m.dispose()\n })\n\n this._stock_materials = []\n }\n\n /* Event Handlers */\n\n onchange(after: Properties, before: Properties) {\n if (before.hasOwnProperty('legendTarget') || after.hasOwnProperty('legendTarget')) {\n this._legendTarget && this._legendTarget.off('change', this.onLegendTargetChanged, this)\n delete this._legendTarget\n this.resetMaterials()\n }\n\n super.onchange(after, before)\n }\n\n onchangeData(): void {\n if (typeof this.data !== 'object') {\n return\n }\n\n var data = this.data\n var locationField = this.getState('locationField') || 'location'\n\n if (data instanceof Array) {\n /**\n * Array type data\n * (e.g. data: [{\n * 'location' : 'A0101-01',\n * 'description': 'description1',\n * ...\n * }, {\n * ...\n * }])\n */\n\n data = data.reduce((acc, value, i, arr) => {\n var location = value[locationField]\n\n if (!location) {\n return acc\n }\n\n // 하나의 로케이션에 여러 레코드 정보가 올 수 있으므로, 하나이 로케이션의 스탁정보를 items 배열에 담는다.\n if (acc[location]) {\n acc[location]['items'].push(value)\n } else {\n acc[location] = { items: [value] }\n }\n\n return acc\n }, {})\n }\n\n /**\n * Object type data\n * (e.g. data: {\n * 'A0101-01': { items: [{ location: 'A0101-01', qty: 10, description: 'description', ... }, {...}] },\n * ...\n * })\n */\n for (var key in data) {\n let id = key\n if (data.hasOwnProperty(id)) {\n let d = data[id]\n let object = this.getObject(id)\n if (object) {\n ;(object as Stock).onchangeStockData(d)\n }\n }\n }\n }\n\n onLegendTargetChanged(after: { [key: string]: any }, before: { [key: string]: any }) {\n if (after.hasOwnProperty('status') && before.hasOwnProperty('status')) this.resetMaterials()\n }\n\n onmouseup(e: MouseEvent) {\n if (this._controls) {\n if (this._lastFocused) {\n ;(this._lastFocused as any)._focused = false\n }\n\n const { popupScene, left, top, width, height } = this.state\n\n var ref = popupScene\n var pointer = this.transcoordC2S(e.offsetX, e.offsetY)\n\n this._mouse!.x = ((pointer.x - left) / width) * 2 - 1\n this._mouse!.y = -((pointer.y - top) / height) * 2 + 1\n\n var object = this.getObjectByRaycast()\n var realObject = object?.userData.context\n\n if (realObject) {\n if (ref && realObject instanceof Stock) {\n ;(realObject as any).onmouseup(e, this, (data: any) => {\n ScenePopup.show(this, ref, {\n data,\n modal: false,\n closable: true,\n output: false,\n location: this.state.popupPosition || 'right-top'\n })\n })\n }\n\n ;(realObject as any)._focused = true\n ;(realObject as any)._focusedAt = performance.now()\n this._lastFocused = realObject\n realObject.component?.trigger('click', e)\n } else {\n ScenePopup.hide(this.root)\n }\n\n this.invalidate()\n\n e.stopPropagation()\n }\n }\n}\n"]}
|
|
1
|
+
{"version":3,"file":"visualizer.js","sourceRoot":"","sources":["../src/visualizer.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright © HatioLab Inc. All rights reserved.\n */\n\nimport { Component, ScenePopup, Properties, ComponentNature, sceneComponent, RealObject, ThreeContainer } from '@hatiolab/things-scene'\nimport * as THREE from 'three'\nimport { Stock, type StockMaterialProvider } from './stock.js'\n\nconst NATURE: ComponentNature = {\n mutable: false,\n resizable: true,\n rotatable: true,\n properties: [\n {\n type: 'number',\n label: 'fov',\n name: 'fov',\n property: 'fov'\n },\n {\n type: 'number',\n label: 'near',\n name: 'near',\n property: 'near'\n },\n {\n type: 'number',\n label: 'far',\n name: 'far',\n property: 'far'\n },\n {\n type: 'number',\n label: 'zoom',\n name: 'zoom',\n property: 'zoom'\n },\n {\n type: 'number',\n label: 'camera-x',\n name: 'cameraX'\n },\n {\n type: 'number',\n label: 'camera-y',\n name: 'cameraY'\n },\n {\n type: 'number',\n label: 'camera-z',\n name: 'cameraZ'\n },\n {\n type: 'select',\n label: 'precision',\n name: 'precision',\n property: {\n options: [\n {\n display: 'High',\n value: 'highp'\n },\n {\n display: 'Medium',\n value: 'mediump'\n },\n {\n display: 'Low',\n value: 'lowp'\n }\n ]\n }\n },\n {\n type: 'checkbox',\n label: 'anti-alias',\n name: 'antialias',\n property: 'antialias'\n },\n {\n type: 'checkbox',\n label: 'auto-rotate',\n name: 'autoRotate',\n property: 'autoRotate'\n },\n {\n type: 'checkbox',\n label: '3dmode',\n name: 'threed',\n property: 'threed'\n },\n {\n type: 'checkbox',\n label: 'debug',\n name: 'debug',\n property: 'debug'\n },\n {\n type: 'string',\n label: 'location-field',\n name: 'locationField',\n placeholder: 'location'\n },\n {\n type: 'board-selector',\n label: 'popup-scene',\n name: 'popupScene'\n },\n {\n type: 'id-input',\n label: 'legend-target',\n name: 'legendTarget',\n property: {\n component: 'legend'\n }\n },\n {\n type: 'number',\n label: 'rotation-speed',\n name: 'rotationSpeed'\n },\n {\n type: 'checkbox',\n label: 'hide-empty-stock',\n name: 'hideEmptyStock'\n },\n {\n type: 'select',\n label: 'popup-position',\n name: 'popupPosition',\n property: {\n options: [\n { display: '', value: '' },\n { display: 'CENTER', value: 'center' },\n { display: 'LEFTTOP', value: 'left-top' },\n { display: 'RIGHTTOP', value: 'right-top' },\n { display: 'LEFTBOTTOM', value: 'left-bottom' },\n { display: 'RIGHTBOTTOM', value: 'right-bottom' }\n ]\n }\n }\n ],\n help: 'scene/component/visualizer'\n}\n\nconst WEBGL_NO_SUPPORT_TEXT = 'WebGL no support'\n\n@sceneComponent('visualizer')\nexport class Visualizer extends ThreeContainer implements StockMaterialProvider {\n _legendTarget?: Component\n\n _objects: { [id: string]: RealObject } = {}\n\n _stock_materials: THREE.Material[] = []\n _default_material?: THREE.Material\n _empty_material?: THREE.Material\n\n get hideEmptyStock(): boolean {\n return !!this.getState('hideEmptyStock')\n }\n\n get legendTarget() {\n var { legendTarget } = this.state\n\n if (!this._legendTarget && legendTarget) {\n this._legendTarget = this.root.findById?.(legendTarget)\n this._legendTarget && this._legendTarget.on('change', this.onLegendTargetChanged, this)\n }\n\n return this._legendTarget\n }\n\n putObject(id: string, object: RealObject) {\n id && (this._objects[id] = object)\n }\n\n getObject(id: string): RealObject {\n return this._objects[id]\n }\n\n /* Container Overides .. */\n\n dispose() {\n this._legendTarget && this._legendTarget.off('change', this.onLegendTargetChanged, this)\n delete this._legendTarget\n\n super.dispose()\n }\n\n get nature(): ComponentNature {\n return NATURE\n }\n\n resetMaterials() {\n this._stock_materials.forEach(m => {\n if (m.dispose) m.dispose()\n })\n\n this._stock_materials = []\n }\n\n /* Event Handlers */\n\n onchange(after: Properties, before: Properties) {\n if (before.hasOwnProperty('legendTarget') || after.hasOwnProperty('legendTarget')) {\n this._legendTarget && this._legendTarget.off('change', this.onLegendTargetChanged, this)\n delete this._legendTarget\n this.resetMaterials()\n }\n\n super.onchange(after, before)\n }\n\n onchangeData(): void {\n if (typeof this.data !== 'object') {\n return\n }\n\n var data = this.data\n var locationField = this.getState('locationField') || 'location'\n\n if (data instanceof Array) {\n /**\n * Array type data\n * (e.g. data: [{\n * 'location' : 'A0101-01',\n * 'description': 'description1',\n * ...\n * }, {\n * ...\n * }])\n */\n\n data = data.reduce((acc, value, i, arr) => {\n var location = value[locationField]\n\n if (!location) {\n return acc\n }\n\n // 하나의 로케이션에 여러 레코드 정보가 올 수 있으므로, 하나이 로케이션의 스탁정보를 items 배열에 담는다.\n if (acc[location]) {\n acc[location]['items'].push(value)\n } else {\n acc[location] = { items: [value] }\n }\n\n return acc\n }, {})\n }\n\n /**\n * Object type data\n * (e.g. data: {\n * 'A0101-01': { items: [{ location: 'A0101-01', qty: 10, description: 'description', ... }, {...}] },\n * ...\n * })\n */\n for (var key in data) {\n let id = key\n if (data.hasOwnProperty(id)) {\n let d = data[id]\n let object = this.getObject(id)\n if (object) {\n ;(object as Stock).onchangeStockData(d)\n }\n }\n }\n }\n\n onLegendTargetChanged(after: { [key: string]: any }, before: { [key: string]: any }) {\n if (after.hasOwnProperty('status') && before.hasOwnProperty('status')) this.resetMaterials()\n }\n\n onmouseup(e: MouseEvent) {\n if (this.controlsManager.isActive) {\n const { popupScene, left, top, width, height } = this.state\n const pointer = this.transcoordC2S(e.offsetX, e.offsetY)\n this.eventManager.updateMouseNDC(pointer.x, pointer.y, left, top, width, height)\n\n const realObject = this.eventManager.handleClick(\n this.cameraManager.camera!,\n this.sceneManager.scene!,\n e\n )\n\n if (realObject) {\n if (popupScene && realObject instanceof Stock) {\n realObject.onmouseup(e, this, (data: any) => {\n ScenePopup.show(this as any, popupScene, {\n data,\n modal: false,\n closable: true,\n output: false,\n location: this.state.popupPosition || 'right-top'\n } as any)\n })\n }\n } else {\n ScenePopup.hide(this.root as any)\n }\n\n this.invalidate()\n e.stopPropagation()\n }\n }\n}\n"]}
|
|
Binary file
|
|
Binary file
|
package/icons/tank.png
ADDED
|
Binary file
|
|
Binary file
|