@soonspacejs/plugin-effect 2.11.38 → 2.11.40
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/README.md +4 -4
- package/dist/builds/BuildsShader.d.ts +5 -0
- package/dist/circle-wave/index.d.ts +28 -0
- package/dist/contact-shadows/HorizontalBlurShader.d.ts +21 -0
- package/dist/contact-shadows/VerticalBlurShader.d.ts +21 -0
- package/dist/contact-shadows/index.d.ts +2 -0
- package/dist/cylinder-wave/index.d.ts +23 -0
- package/dist/flame/FlameImg.d.ts +2 -0
- package/dist/flame/FlameShader.d.ts +17 -0
- package/dist/index.d.ts +197 -0
- package/dist/points-wave/PointsWaveShader.d.ts +5 -0
- package/dist/sparkles/SparklesShader.d.ts +5 -0
- package/dist/sparkles/SparklesUtils.d.ts +6 -0
- package/dist/water/index.d.ts +52 -0
- package/dist/water/tools.d.ts +3 -0
- package/dist/weather/RainImg.d.ts +2 -0
- package/package.json +3 -3
package/README.md
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
# @soonspacejs/plugin-effect
|
|
2
|
-
|
|
3
|
-
> Effect plugin for SoonSpace.js
|
|
4
|
-
|
|
1
|
+
# @soonspacejs/plugin-effect
|
|
2
|
+
|
|
3
|
+
> Effect plugin for SoonSpace.js
|
|
4
|
+
|
|
5
5
|
Document: [http://www.xwbuilders.com:8800/plugin/effect.html](http://www.xwbuilders.com:8800/plugin/effect.html)
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { Mesh, MeshBasicMaterial, PlaneGeometry } from 'three';
|
|
2
|
+
import { IVector3 } from 'soonspacejs';
|
|
3
|
+
export interface InnerCircleWaveOptions {
|
|
4
|
+
textureUrl: string[];
|
|
5
|
+
position: IVector3;
|
|
6
|
+
width: number;
|
|
7
|
+
height: number;
|
|
8
|
+
isScaleAnimate: boolean;
|
|
9
|
+
isOpacityAnimate: boolean;
|
|
10
|
+
}
|
|
11
|
+
export declare class CircleWave {
|
|
12
|
+
outMaterial: MeshBasicMaterial | undefined;
|
|
13
|
+
outPlaneGeometry: PlaneGeometry | undefined;
|
|
14
|
+
outMesh: Mesh<PlaneGeometry, MeshBasicMaterial> | undefined;
|
|
15
|
+
inMaterial: MeshBasicMaterial;
|
|
16
|
+
inPlaneGeometry: PlaneGeometry;
|
|
17
|
+
inMesh: Mesh<PlaneGeometry, MeshBasicMaterial>;
|
|
18
|
+
readonly isScaleAnimate: boolean;
|
|
19
|
+
readonly isOpacityAnimate: boolean;
|
|
20
|
+
readonly AngleUnit: number;
|
|
21
|
+
readonly MaxScale: number;
|
|
22
|
+
readonly OpacityUnit: number;
|
|
23
|
+
readonly ScaleUnit: number;
|
|
24
|
+
constructor(options: InnerCircleWaveOptions);
|
|
25
|
+
createPlane(width?: number, height?: number): PlaneGeometry;
|
|
26
|
+
createMaterial(texturePath: string): MeshBasicMaterial;
|
|
27
|
+
update(): void;
|
|
28
|
+
}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Two pass Gaussian blur filter (horizontal and vertical blur shaders)
|
|
3
|
+
* - see http://www.cake23.de/traveling-wavefronts-lit-up.html
|
|
4
|
+
*
|
|
5
|
+
* - 9 samples per pass
|
|
6
|
+
* - standard deviation 2.7
|
|
7
|
+
* - "h" and "v" parameters should be set to "1 / width" and "1 / height"
|
|
8
|
+
*/
|
|
9
|
+
declare const HorizontalBlurShader: {
|
|
10
|
+
uniforms: {
|
|
11
|
+
tDiffuse: {
|
|
12
|
+
value: null;
|
|
13
|
+
};
|
|
14
|
+
h: {
|
|
15
|
+
value: number;
|
|
16
|
+
};
|
|
17
|
+
};
|
|
18
|
+
vertexShader: string;
|
|
19
|
+
fragmentShader: string;
|
|
20
|
+
};
|
|
21
|
+
export { HorizontalBlurShader, };
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Two pass Gaussian blur filter (horizontal and vertical blur shaders)
|
|
3
|
+
* - see http://www.cake23.de/traveling-wavefronts-lit-up.html
|
|
4
|
+
*
|
|
5
|
+
* - 9 samples per pass
|
|
6
|
+
* - standard deviation 2.7
|
|
7
|
+
* - "h" and "v" parameters should be set to "1 / width" and "1 / height"
|
|
8
|
+
*/
|
|
9
|
+
declare const VerticalBlurShader: {
|
|
10
|
+
uniforms: {
|
|
11
|
+
tDiffuse: {
|
|
12
|
+
value: null;
|
|
13
|
+
};
|
|
14
|
+
v: {
|
|
15
|
+
value: number;
|
|
16
|
+
};
|
|
17
|
+
};
|
|
18
|
+
vertexShader: string;
|
|
19
|
+
fragmentShader: string;
|
|
20
|
+
};
|
|
21
|
+
export { VerticalBlurShader, };
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { CylinderGeometry, MeshBasicMaterial } from 'three';
|
|
2
|
+
import { IVector3 } from 'soonspacejs';
|
|
3
|
+
export interface InnerCylinderWaveOptions {
|
|
4
|
+
position: IVector3;
|
|
5
|
+
topRadius: number;
|
|
6
|
+
bottomRadius: number;
|
|
7
|
+
height: number;
|
|
8
|
+
texturePath: string;
|
|
9
|
+
color: string;
|
|
10
|
+
}
|
|
11
|
+
export declare class CylinderWave {
|
|
12
|
+
material: MeshBasicMaterial;
|
|
13
|
+
geometry: CylinderGeometry;
|
|
14
|
+
mesh: any;
|
|
15
|
+
position: any;
|
|
16
|
+
maxScale: number;
|
|
17
|
+
minScale: number;
|
|
18
|
+
private opacityUnit;
|
|
19
|
+
constructor(options: InnerCylinderWaveOptions);
|
|
20
|
+
createGeometry(topRadius: number, bottomRadius: number, height: number): CylinderGeometry;
|
|
21
|
+
creatematerial(texturePath: string, color: string): MeshBasicMaterial;
|
|
22
|
+
update(): void;
|
|
23
|
+
}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
declare const _default: "";
|
|
2
|
+
export default _default;
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @author mattatz / http://mattatz.github.io
|
|
3
|
+
*
|
|
4
|
+
* Ray tracing based real-time procedural volumetric fire shader.
|
|
5
|
+
*
|
|
6
|
+
* Based on
|
|
7
|
+
* Alfred et al. Real-Time procedural volumetric fire / http://dl.acm.org/citation.cfm?id=1230131
|
|
8
|
+
* and
|
|
9
|
+
* webgl-noise / https://github.com/ashima/webgl-noise/blob/master/src/noise3D.glsl
|
|
10
|
+
* and
|
|
11
|
+
* primitive: blog | object space raymarching / https://github.com/ashima/webgl-noise/blob/master/src/noise3D.glsl
|
|
12
|
+
*/
|
|
13
|
+
declare const _default: {
|
|
14
|
+
vertexShader: string;
|
|
15
|
+
fragmentShader: string;
|
|
16
|
+
};
|
|
17
|
+
export default _default;
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1,197 @@
|
|
|
1
|
+
import SoonSpace, { IVector3, IColor } from 'soonspacejs';
|
|
2
|
+
import type { PluginObject, PluginObjectInfo } from 'soonspacejs/types/Library';
|
|
3
|
+
import { ParticleCluster, ParticleClusterOptions } from '@three3d/particle';
|
|
4
|
+
export * from '@three3d/particle';
|
|
5
|
+
import { InnerCircleWaveOptions } from './circle-wave';
|
|
6
|
+
import { InnerCylinderWaveOptions } from './cylinder-wave';
|
|
7
|
+
import { WaterOptions } from './water';
|
|
8
|
+
export interface FlameOptions extends PluginObjectInfo {
|
|
9
|
+
magnitude?: number;
|
|
10
|
+
gain?: number;
|
|
11
|
+
imgUrl?: string;
|
|
12
|
+
}
|
|
13
|
+
export interface SmokeOptions extends PluginObjectInfo {
|
|
14
|
+
imgUrl?: string;
|
|
15
|
+
count?: number;
|
|
16
|
+
maxAge?: number;
|
|
17
|
+
size?: number;
|
|
18
|
+
acceleration?: number;
|
|
19
|
+
velocity?: IVector3;
|
|
20
|
+
color?: IColor[];
|
|
21
|
+
}
|
|
22
|
+
export interface SparklesOptions extends PluginObjectInfo {
|
|
23
|
+
count?: number;
|
|
24
|
+
speed?: number | Float32Array;
|
|
25
|
+
opacity?: number | Float32Array;
|
|
26
|
+
color?: IColor | Float32Array;
|
|
27
|
+
size?: number | Float32Array;
|
|
28
|
+
scalar?: number | [number, number, number] | IVector3;
|
|
29
|
+
noise?: number | [number, number, number] | IVector3 | Float32Array;
|
|
30
|
+
}
|
|
31
|
+
export interface CreateWaterOptions extends PluginObjectInfo, Omit<WaterOptions, 'userData'> {
|
|
32
|
+
/**
|
|
33
|
+
* 是否开启水的动画
|
|
34
|
+
* @remarks
|
|
35
|
+
* 如果开启,则会一直触发场景渲染
|
|
36
|
+
* 如果关闭,则不会主动触发场景渲染,但在渲染渲染时仍会有动画效果,只是不会主动触发场景渲染
|
|
37
|
+
*/
|
|
38
|
+
animation?: boolean;
|
|
39
|
+
}
|
|
40
|
+
export interface ContactShadowsOptions extends Omit<PluginObjectInfo, 'scale'> {
|
|
41
|
+
opacity?: number;
|
|
42
|
+
width?: number;
|
|
43
|
+
height?: number;
|
|
44
|
+
blur?: number;
|
|
45
|
+
far?: number;
|
|
46
|
+
resolution?: number;
|
|
47
|
+
frames?: number;
|
|
48
|
+
scale?: number | [x: number, y: number];
|
|
49
|
+
darkness?: number;
|
|
50
|
+
}
|
|
51
|
+
export interface WeatherOptions {
|
|
52
|
+
/**
|
|
53
|
+
* 粒子贴图
|
|
54
|
+
*/
|
|
55
|
+
imgUrl?: string;
|
|
56
|
+
/**
|
|
57
|
+
* 颜色
|
|
58
|
+
*/
|
|
59
|
+
color?: IColor;
|
|
60
|
+
/**
|
|
61
|
+
* 大小
|
|
62
|
+
*/
|
|
63
|
+
size?: number;
|
|
64
|
+
/**
|
|
65
|
+
* 不透明度
|
|
66
|
+
*/
|
|
67
|
+
opacity?: number;
|
|
68
|
+
/**
|
|
69
|
+
* 粒子数量
|
|
70
|
+
*/
|
|
71
|
+
count?: number;
|
|
72
|
+
/**
|
|
73
|
+
* 粒子范围
|
|
74
|
+
*/
|
|
75
|
+
range?: number;
|
|
76
|
+
/**
|
|
77
|
+
* 粒子左右速度的随机范围
|
|
78
|
+
*/
|
|
79
|
+
velocityX?: [number, number];
|
|
80
|
+
/**
|
|
81
|
+
* 粒子上下速度的随机范围
|
|
82
|
+
*/
|
|
83
|
+
velocityY?: [number, number];
|
|
84
|
+
}
|
|
85
|
+
export type CircleWaveOptions = InnerCircleWaveOptions & PluginObjectInfo;
|
|
86
|
+
export type CylinderWaveOptions = InnerCylinderWaveOptions & PluginObjectInfo;
|
|
87
|
+
export interface PointsWaveOptions extends PluginObjectInfo {
|
|
88
|
+
xAxisCount?: number;
|
|
89
|
+
zAxisCount?: number;
|
|
90
|
+
showDistance?: number;
|
|
91
|
+
separation?: number;
|
|
92
|
+
size?: number;
|
|
93
|
+
maxFluctua?: number;
|
|
94
|
+
color?: IColor;
|
|
95
|
+
opacity?: number;
|
|
96
|
+
}
|
|
97
|
+
export interface BuildsOptions extends PluginObjectInfo {
|
|
98
|
+
buildWidth?: number;
|
|
99
|
+
buildHeigh?: number;
|
|
100
|
+
buildDepth?: number;
|
|
101
|
+
count?: number;
|
|
102
|
+
gapX?: number;
|
|
103
|
+
gapZ?: number;
|
|
104
|
+
showDistance?: number;
|
|
105
|
+
randShift?: number;
|
|
106
|
+
color?: IColor;
|
|
107
|
+
}
|
|
108
|
+
declare class EffectPlugin {
|
|
109
|
+
readonly ssp: SoonSpace;
|
|
110
|
+
[x: string]: any;
|
|
111
|
+
/**
|
|
112
|
+
* 天气预设图片
|
|
113
|
+
*/
|
|
114
|
+
readonly weatherPresetImgs: {
|
|
115
|
+
rain: string;
|
|
116
|
+
snow: any;
|
|
117
|
+
};
|
|
118
|
+
private _weatherId;
|
|
119
|
+
constructor(ssp: SoonSpace);
|
|
120
|
+
/**
|
|
121
|
+
* 创建火焰
|
|
122
|
+
* @params params
|
|
123
|
+
* @returns
|
|
124
|
+
*/
|
|
125
|
+
createFlame(params: FlameOptions): PluginObject;
|
|
126
|
+
/**
|
|
127
|
+
* @deprecated
|
|
128
|
+
* @params id
|
|
129
|
+
* @returns
|
|
130
|
+
*/
|
|
131
|
+
removeFlame(id: PluginObjectInfo['id']): boolean;
|
|
132
|
+
/**
|
|
133
|
+
* 创建烟雾
|
|
134
|
+
* @param params
|
|
135
|
+
* @returns
|
|
136
|
+
*/
|
|
137
|
+
createSmoke(params: SmokeOptions): PluginObject;
|
|
138
|
+
/**
|
|
139
|
+
* @deprecated
|
|
140
|
+
* @params id
|
|
141
|
+
* @returns
|
|
142
|
+
*/
|
|
143
|
+
removeSmoke(id: PluginObjectInfo['id']): boolean;
|
|
144
|
+
/**
|
|
145
|
+
* 创建星星
|
|
146
|
+
* @param params
|
|
147
|
+
* @returns
|
|
148
|
+
*/
|
|
149
|
+
createSparkles(params: SparklesOptions): PluginObject;
|
|
150
|
+
/**
|
|
151
|
+
* 创建接触阴影
|
|
152
|
+
* @params params
|
|
153
|
+
*/
|
|
154
|
+
createContactShadows({ scale, frames, opacity, width, height, blur, darkness, far, resolution, ...props }: ContactShadowsOptions): PluginObject;
|
|
155
|
+
/**
|
|
156
|
+
* 开启天气
|
|
157
|
+
* @param param0
|
|
158
|
+
*/
|
|
159
|
+
openWeather(params?: WeatherOptions): void;
|
|
160
|
+
/**
|
|
161
|
+
* 关闭天气
|
|
162
|
+
*/
|
|
163
|
+
closeWeather(): void;
|
|
164
|
+
/**
|
|
165
|
+
* 创建粒子簇
|
|
166
|
+
* @param options
|
|
167
|
+
* @returns
|
|
168
|
+
*/
|
|
169
|
+
createParticleCluster(options: ParticleClusterOptions): ParticleCluster;
|
|
170
|
+
/**
|
|
171
|
+
* 创建圆形光波
|
|
172
|
+
* @param options
|
|
173
|
+
* @returns
|
|
174
|
+
*/
|
|
175
|
+
createCircleWave(options: CircleWaveOptions): PluginObject;
|
|
176
|
+
/**
|
|
177
|
+
* 创建立柱光波
|
|
178
|
+
* @param options
|
|
179
|
+
* @returns
|
|
180
|
+
*/
|
|
181
|
+
createCylinderWave(options: CylinderWaveOptions): PluginObject;
|
|
182
|
+
/**
|
|
183
|
+
* 创建粒子波浪
|
|
184
|
+
* @param options
|
|
185
|
+
* @returns
|
|
186
|
+
*/
|
|
187
|
+
createPointsWave(options: PointsWaveOptions): PluginObject;
|
|
188
|
+
/**
|
|
189
|
+
* 创建建筑
|
|
190
|
+
* @param options
|
|
191
|
+
* @returns
|
|
192
|
+
*/
|
|
193
|
+
createBuilds(options: BuildsOptions): PluginObject;
|
|
194
|
+
createWater(options: CreateWaterOptions): PluginObject;
|
|
195
|
+
removeEffect(id: PluginObjectInfo['id']): boolean;
|
|
196
|
+
}
|
|
197
|
+
export default EffectPlugin;
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { Color } from 'three';
|
|
2
|
+
export declare const isFloat32Array: (def: any) => def is Float32Array;
|
|
3
|
+
export declare const expandColor: (v: Color) => number[];
|
|
4
|
+
export declare const isVector: (v: any) => boolean;
|
|
5
|
+
export declare const normalizeVector: (v: any) => number[];
|
|
6
|
+
export declare function usePropAsIsOrAsAttribute<T extends any>(count: number, prop?: T | Float32Array, setDefault?: (v: T) => number): Float32Array;
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
import type { Texture, ColorRepresentation, ShaderMaterialParameters, Mesh } from 'three';
|
|
2
|
+
import { Vector3 } from 'three';
|
|
3
|
+
import { IVector3 } from 'soonspacejs';
|
|
4
|
+
export interface WaterOptions extends ShaderMaterialParameters {
|
|
5
|
+
/**
|
|
6
|
+
* 水面的多边形区域
|
|
7
|
+
*/
|
|
8
|
+
polygon: IVector3[];
|
|
9
|
+
/**
|
|
10
|
+
* 水面的高度
|
|
11
|
+
* @remarks
|
|
12
|
+
* 默认为第一个顶点的 y 值
|
|
13
|
+
*/
|
|
14
|
+
height?: number;
|
|
15
|
+
/**
|
|
16
|
+
* 太阳的照射的方向
|
|
17
|
+
*/
|
|
18
|
+
sunDirection?: Vector3;
|
|
19
|
+
/**
|
|
20
|
+
* 太阳的颜色
|
|
21
|
+
*/
|
|
22
|
+
sunColor?: ColorRepresentation;
|
|
23
|
+
/**
|
|
24
|
+
* 水的颜色
|
|
25
|
+
*/
|
|
26
|
+
waterColor?: ColorRepresentation;
|
|
27
|
+
/**
|
|
28
|
+
* 水波的强度
|
|
29
|
+
*/
|
|
30
|
+
distortionScale?: number;
|
|
31
|
+
/**
|
|
32
|
+
* 透明度
|
|
33
|
+
*/
|
|
34
|
+
alpha?: number;
|
|
35
|
+
/**
|
|
36
|
+
* 速度
|
|
37
|
+
*/
|
|
38
|
+
speed?: number;
|
|
39
|
+
/**
|
|
40
|
+
* 水面法线纹理
|
|
41
|
+
*/
|
|
42
|
+
waterNormals?: string | Texture;
|
|
43
|
+
fog?: boolean;
|
|
44
|
+
eye?: Vector3;
|
|
45
|
+
clipBias?: number;
|
|
46
|
+
textureWidth?: number;
|
|
47
|
+
textureHeight?: number;
|
|
48
|
+
}
|
|
49
|
+
export type WaterMesh = Mesh & {
|
|
50
|
+
speed: number;
|
|
51
|
+
};
|
|
52
|
+
export declare function createWater(options: WaterOptions): WaterMesh;
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
declare const _default: "";
|
|
2
|
+
export default _default;
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@soonspacejs/plugin-effect",
|
|
3
3
|
"pluginName": "EffectPlugin",
|
|
4
|
-
"version": "2.11.
|
|
4
|
+
"version": "2.11.40",
|
|
5
5
|
"description": "Effect plugin for SoonSpace.js",
|
|
6
6
|
"main": "dist/index.esm.js",
|
|
7
7
|
"module": "dist/index.esm.js",
|
|
@@ -17,8 +17,8 @@
|
|
|
17
17
|
"@three3d/particle": "^1.0.4",
|
|
18
18
|
"heatmap-ts": "^0.0.4"
|
|
19
19
|
},
|
|
20
|
-
"gitHead": "
|
|
20
|
+
"gitHead": "fb93438e409cbbd6930d3f8218c7c95db92e94d0",
|
|
21
21
|
"peerDependencies": {
|
|
22
|
-
"soonspacejs": "2.11.
|
|
22
|
+
"soonspacejs": "2.11.40"
|
|
23
23
|
}
|
|
24
24
|
}
|