glre 0.38.0 → 0.40.0
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 +8 -4
- package/dist/addons.cjs +2 -0
- package/dist/addons.cjs.map +1 -0
- package/dist/addons.d.ts +1287 -0
- package/dist/addons.js +2 -0
- package/dist/addons.js.map +1 -0
- package/dist/index.cjs +31 -43
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.ts +187 -323
- package/dist/index.js +31 -43
- package/dist/index.js.map +1 -1
- package/dist/native.cjs +1 -48
- package/dist/native.cjs.map +1 -1
- package/dist/native.d.ts +536 -10
- package/dist/native.js +1 -48
- package/dist/native.js.map +1 -1
- package/dist/node.cjs +69 -0
- package/dist/node.cjs.map +1 -0
- package/dist/node.d.ts +626 -0
- package/dist/node.js +69 -0
- package/dist/node.js.map +1 -0
- package/dist/react.cjs +1 -48
- package/dist/react.cjs.map +1 -1
- package/dist/react.d.ts +524 -4
- package/dist/react.js +1 -48
- package/dist/react.js.map +1 -1
- package/dist/solid.cjs +1 -48
- package/dist/solid.cjs.map +1 -1
- package/dist/solid.d.ts +524 -4
- package/dist/solid.js +1 -48
- package/dist/solid.js.map +1 -1
- package/package.json +64 -11
- package/src/addons/animation/easing/backIn.ts +10 -0
- package/src/addons/animation/easing/backInOut.ts +12 -0
- package/src/addons/animation/easing/backOut.ts +10 -0
- package/src/addons/animation/easing/bounceIn.ts +10 -0
- package/src/addons/animation/easing/bounceInOut.ts +13 -0
- package/src/addons/animation/easing/bounceOut.ts +30 -0
- package/src/addons/animation/easing/circularIn.ts +9 -0
- package/src/addons/animation/easing/circularInOut.ts +11 -0
- package/src/addons/animation/easing/circularOut.ts +9 -0
- package/src/addons/animation/easing/cubicIn.ts +9 -0
- package/src/addons/animation/easing/cubicInOut.ts +11 -0
- package/src/addons/animation/easing/cubicOut.ts +10 -0
- package/src/addons/animation/easing/elasticIn.ts +10 -0
- package/src/addons/animation/easing/elasticInOut.ts +21 -0
- package/src/addons/animation/easing/elasticOut.ts +12 -0
- package/src/addons/animation/easing/exponentialIn.ts +9 -0
- package/src/addons/animation/easing/exponentialInOut.ts +13 -0
- package/src/addons/animation/easing/exponentialOut.ts +9 -0
- package/src/addons/animation/easing/index.ts +33 -0
- package/src/addons/animation/easing/linearIn.ts +9 -0
- package/src/addons/animation/easing/linearInOut.ts +9 -0
- package/src/addons/animation/easing/linearOut.ts +9 -0
- package/src/addons/animation/easing/quadraticIn.ts +9 -0
- package/src/addons/animation/easing/quadraticInOut.ts +10 -0
- package/src/addons/animation/easing/quadraticOut.ts +9 -0
- package/src/addons/animation/easing/quarticIn.ts +9 -0
- package/src/addons/animation/easing/quarticInOut.ts +11 -0
- package/src/addons/animation/easing/quarticOut.ts +10 -0
- package/src/addons/animation/easing/quinticIn.ts +9 -0
- package/src/addons/animation/easing/quinticInOut.ts +11 -0
- package/src/addons/animation/easing/quinticOut.ts +9 -0
- package/src/addons/animation/easing/sineIn.ts +10 -0
- package/src/addons/animation/easing/sineInOut.ts +10 -0
- package/src/addons/animation/easing/sineOut.ts +10 -0
- package/src/addons/color/palette/macbeth.ts +42 -0
- package/src/addons/color/space/cmyk2rgb.ts +12 -0
- package/src/addons/color/space/gamma2linear.ts +19 -0
- package/src/addons/color/space/hsl2rgb.ts +20 -0
- package/src/addons/color/space/hsv2rgb.ts +18 -0
- package/src/addons/color/space/hue2rgb.ts +12 -0
- package/src/addons/color/space/index.ts +29 -0
- package/src/addons/color/space/lab2lch.ts +22 -0
- package/src/addons/color/space/lab2rgb.ts +19 -0
- package/src/addons/color/space/lab2xyz.ts +32 -0
- package/src/addons/color/space/lch2lab.ts +21 -0
- package/src/addons/color/space/lch2rgb.ts +22 -0
- package/src/addons/color/space/linear2gamma.ts +19 -0
- package/src/addons/color/space/oklab2rgb.ts +35 -0
- package/src/addons/color/space/rgb2cmyk.ts +13 -0
- package/src/addons/color/space/rgb2hcv.ts +29 -0
- package/src/addons/color/space/rgb2hsl.ts +23 -0
- package/src/addons/color/space/rgb2hsv.ts +36 -0
- package/src/addons/color/space/rgb2hue.ts +29 -0
- package/src/addons/color/space/rgb2lab.ts +19 -0
- package/src/addons/color/space/rgb2lch.ts +22 -0
- package/src/addons/color/space/rgb2oklab.ts +45 -0
- package/src/addons/color/space/rgb2srgb.ts +34 -0
- package/src/addons/color/space/rgb2xyz.ts +20 -0
- package/src/addons/color/space/rgb2yiq.ts +22 -0
- package/src/addons/color/space/rgb2yuv.ts +32 -0
- package/src/addons/color/space/srgb2rgb.ts +34 -0
- package/src/addons/color/space/xyz2lab.ts +27 -0
- package/src/addons/color/space/xyz2rgb.ts +30 -0
- package/src/addons/color/space/yiq2rgb.ts +22 -0
- package/src/addons/color/space/yuv2rgb.ts +32 -0
- package/src/addons/draw/arrows.ts +75 -0
- package/src/addons/draw/axis.ts +57 -0
- package/src/addons/draw/bridge.ts +81 -0
- package/src/addons/draw/char.ts +30 -0
- package/src/addons/draw/circle.ts +29 -0
- package/src/addons/draw/fill.ts +25 -0
- package/src/addons/draw/flip.ts +45 -0
- package/src/addons/draw/hex.ts +29 -0
- package/src/addons/draw/index.ts +13 -0
- package/src/addons/draw/line.ts +16 -0
- package/src/addons/draw/point.ts +30 -0
- package/src/addons/draw/rect.ts +52 -0
- package/src/addons/draw/stroke.ts +31 -0
- package/src/addons/draw/tri.ts +29 -0
- package/src/addons/generative/cnoise.ts +239 -0
- package/src/addons/generative/curl.ts +64 -0
- package/src/addons/generative/fbm.ts +69 -0
- package/src/addons/generative/gerstnerWave.ts +21 -0
- package/src/addons/generative/gnoise.ts +113 -0
- package/src/addons/generative/index.ts +15 -0
- package/src/addons/generative/noised.ts +139 -0
- package/src/addons/generative/pnoise.ts +249 -0
- package/src/addons/generative/psrdnoise.ts +277 -0
- package/src/addons/generative/random.ts +136 -0
- package/src/addons/generative/snoise.ts +199 -0
- package/src/addons/generative/srandom.ts +90 -0
- package/src/addons/generative/voronoi.ts +134 -0
- package/src/addons/generative/voronoise.ts +69 -0
- package/src/addons/generative/wavelet.ts +77 -0
- package/src/addons/generative/worley.ts +99 -0
- package/src/addons/geometry/aabb/aabb.ts +8 -0
- package/src/addons/geometry/aabb/centroid.ts +10 -0
- package/src/addons/geometry/aabb/contain.ts +19 -0
- package/src/addons/geometry/aabb/diagonal.ts +10 -0
- package/src/addons/geometry/aabb/expand.ts +16 -0
- package/src/addons/geometry/aabb/index.ts +7 -0
- package/src/addons/geometry/aabb/intersect.ts +20 -0
- package/src/addons/geometry/aabb/square.ts +17 -0
- package/src/addons/geometry/index.ts +2 -0
- package/src/addons/geometry/triangle/area.ts +10 -0
- package/src/addons/geometry/triangle/barycentric.ts +50 -0
- package/src/addons/geometry/triangle/centroid.ts +10 -0
- package/src/addons/geometry/triangle/closestPoint.ts +85 -0
- package/src/addons/geometry/triangle/contain.ts +19 -0
- package/src/addons/geometry/triangle/distanceSq.ts +38 -0
- package/src/addons/geometry/triangle/index.ts +10 -0
- package/src/addons/geometry/triangle/intersect.ts +49 -0
- package/src/addons/geometry/triangle/normal.ts +12 -0
- package/src/addons/geometry/triangle/signedDistance.ts +31 -0
- package/src/addons/geometry/triangle/triangle.ts +9 -0
- package/src/addons/index.ts +8 -0
- package/src/addons/lighting/ray.ts +8 -0
- package/src/addons/math/aafloor.ts +13 -0
- package/src/addons/math/aafract.ts +38 -0
- package/src/addons/math/aamirror.ts +12 -0
- package/src/addons/math/aastep.ts +14 -0
- package/src/addons/math/absi.ts +9 -0
- package/src/addons/math/adaptiveThreshold.ts +24 -0
- package/src/addons/math/bump.ts +20 -0
- package/src/addons/math/const.ts +19 -0
- package/src/addons/math/cubic.ts +101 -0
- package/src/addons/math/cubicMix.ts +49 -0
- package/src/addons/math/decimate.ts +12 -0
- package/src/addons/math/dist.ts +143 -0
- package/src/addons/math/fcos.ts +11 -0
- package/src/addons/math/frac.ts +9 -0
- package/src/addons/math/gain.ts +14 -0
- package/src/addons/math/gaussian.ts +14 -0
- package/src/addons/math/grad4.ts +19 -0
- package/src/addons/math/hammersley.ts +54 -0
- package/src/addons/math/highPass.ts +12 -0
- package/src/addons/math/index.ts +63 -0
- package/src/addons/math/inside.ts +68 -0
- package/src/addons/math/invCubic.ts +9 -0
- package/src/addons/math/invQuartic.ts +9 -0
- package/src/addons/math/inverse.ts +9 -0
- package/src/addons/math/lengthSq.ts +10 -0
- package/src/addons/math/map.ts +27 -0
- package/src/addons/math/mirror.ts +12 -0
- package/src/addons/math/mmax.ts +27 -0
- package/src/addons/math/mmin.ts +28 -0
- package/src/addons/math/mmix.ts +47 -0
- package/src/addons/math/mod2.ts +44 -0
- package/src/addons/math/mod289.ts +46 -0
- package/src/addons/math/modi.ts +15 -0
- package/src/addons/math/nyquist.ts +15 -0
- package/src/addons/math/pack.ts +15 -0
- package/src/addons/math/parabola.ts +12 -0
- package/src/addons/math/permute.ts +42 -0
- package/src/addons/math/pow2.ts +10 -0
- package/src/addons/math/pow3.ts +9 -0
- package/src/addons/math/pow5.ts +10 -0
- package/src/addons/math/pow7.ts +12 -0
- package/src/addons/math/powFast.ts +18 -0
- package/src/addons/math/quartic.ts +15 -0
- package/src/addons/math/quat/index.ts +14 -0
- package/src/addons/math/quat/quat2mat3.ts +28 -0
- package/src/addons/math/quat/quat2mat4.ts +16 -0
- package/src/addons/math/quat/quatAdd.ts +18 -0
- package/src/addons/math/quat/quatConj.ts +14 -0
- package/src/addons/math/quat/quatDiv.ts +18 -0
- package/src/addons/math/quat/quatIdentity.ts +9 -0
- package/src/addons/math/quat/quatInverse.ts +17 -0
- package/src/addons/math/quat/quatLength.ts +15 -0
- package/src/addons/math/quat/quatLengthSq.ts +14 -0
- package/src/addons/math/quat/quatLerp.ts +40 -0
- package/src/addons/math/quat/quatMul.ts +38 -0
- package/src/addons/math/quat/quatNeg.ts +14 -0
- package/src/addons/math/quat/quatNorm.ts +16 -0
- package/src/addons/math/quat/quatSub.ts +18 -0
- package/src/addons/math/quintic.ts +16 -0
- package/src/addons/math/rotate2d.ts +16 -0
- package/src/addons/math/rotate3d.ts +37 -0
- package/src/addons/math/rotate3dX.ts +20 -0
- package/src/addons/math/rotate3dY.ts +20 -0
- package/src/addons/math/rotate3dZ.ts +20 -0
- package/src/addons/math/rotate4d.ts +41 -0
- package/src/addons/math/rotate4dX.ts +21 -0
- package/src/addons/math/rotate4dY.ts +16 -0
- package/src/addons/math/rotate4dZ.ts +21 -0
- package/src/addons/math/saturateMediump.ts +11 -0
- package/src/addons/math/scale2d.ts +44 -0
- package/src/addons/math/scale3d.ts +17 -0
- package/src/addons/math/scale4d.ts +50 -0
- package/src/addons/math/smootherstep.ts +16 -0
- package/src/addons/math/taylorInvSqrt.ts +9 -0
- package/src/addons/math/toMat3.ts +14 -0
- package/src/addons/math/toMat4.ts +14 -0
- package/src/addons/math/translate4d.ts +31 -0
- package/src/addons/math/unpack.ts +88 -0
- package/src/addons/sdf/boxSDF.ts +24 -0
- package/src/addons/sdf/circleSDF.ts +20 -0
- package/src/addons/sdf/crossSDF.ts +17 -0
- package/src/addons/sdf/hexSDF.ts +18 -0
- package/src/addons/sdf/index.ts +7 -0
- package/src/addons/sdf/lineSDF.ts +33 -0
- package/src/addons/sdf/rectSDF.ts +46 -0
- package/src/addons/sdf/sphereSDF.ts +20 -0
- package/src/addons/sdf/triSDF.ts +14 -0
- package/src/addons/space/aspect.ts +14 -0
- package/src/addons/space/bracketing.ts +44 -0
- package/src/addons/space/brickTile.ts +44 -0
- package/src/addons/space/cart2polar.ts +20 -0
- package/src/addons/space/center.ts +32 -0
- package/src/addons/space/checkerTile.ts +41 -0
- package/src/addons/space/depth2viewZ.ts +43 -0
- package/src/addons/space/displace.ts +55 -0
- package/src/addons/space/equirect2xyz.ts +17 -0
- package/src/addons/space/eulerView.ts +19 -0
- package/src/addons/space/fisheye2xyz.ts +18 -0
- package/src/addons/space/flipY.ts +25 -0
- package/src/addons/space/hexTile.ts +18 -0
- package/src/addons/space/index.ts +38 -0
- package/src/addons/space/kaleidoscope.ts +48 -0
- package/src/addons/space/linearizeDepth.ts +17 -0
- package/src/addons/space/lookAt.ts +49 -0
- package/src/addons/space/lookAtView.ts +40 -0
- package/src/addons/space/mirrorTile.ts +73 -0
- package/src/addons/space/nearest.ts +13 -0
- package/src/addons/space/orthographic.ts +25 -0
- package/src/addons/space/parallaxMapping.ts +149 -0
- package/src/addons/space/perspective.ts +24 -0
- package/src/addons/space/polar2cart.ts +24 -0
- package/src/addons/space/ratio.ts +14 -0
- package/src/addons/space/rotate.ts +37 -0
- package/src/addons/space/rotateX.ts +54 -0
- package/src/addons/space/rotateY.ts +54 -0
- package/src/addons/space/rotateZ.ts +54 -0
- package/src/addons/space/scale.ts +13 -0
- package/src/addons/space/sprite.ts +16 -0
- package/src/addons/space/sqTile.ts +20 -0
- package/src/addons/space/tbn.ts +26 -0
- package/src/addons/space/translate.ts +12 -0
- package/src/addons/space/triTile.ts +32 -0
- package/src/addons/space/uncenter.ts +32 -0
- package/src/addons/space/unratio.ts +12 -0
- package/src/addons/space/viewZ2depth.ts +25 -0
- package/src/addons/space/windmillTile.ts +58 -0
- package/src/addons/space/xyz2equirect.ts +10 -0
- package/src/index.ts +10 -23
- package/src/node/build.ts +127 -0
- package/src/node/create.ts +76 -0
- package/src/node/index.ts +64 -49
- package/src/node/scope.ts +66 -62
- package/src/node/types.ts +221 -187
- package/src/node/utils/const.ts +74 -13
- package/src/node/utils/index.ts +19 -14
- package/src/node/utils/infer.ts +32 -34
- package/src/node/utils/parse.ts +48 -24
- package/src/node/utils/utils.ts +52 -29
- package/src/types.ts +11 -6
- package/src/utils/helpers.ts +56 -0
- package/src/utils/pipeline.ts +24 -8
- package/src/utils/program.ts +62 -38
- package/src/{webgl.ts → utils/webgl.ts} +46 -30
- package/src/{webgpu.ts → utils/webgpu.ts} +22 -17
- package/src/node/core.ts +0 -121
- package/src/node/node.ts +0 -65
package/dist/react.d.ts
CHANGED
|
@@ -1,8 +1,528 @@
|
|
|
1
1
|
import * as reev from 'reev';
|
|
2
|
-
import {
|
|
3
|
-
|
|
4
|
-
|
|
2
|
+
import { EventState, Nested } from 'reev';
|
|
3
|
+
import * as refr from 'refr';
|
|
4
|
+
import { Queue, Frame } from 'refr';
|
|
5
|
+
|
|
6
|
+
declare const CONVERSIONS: readonly ["toBool", "toUInt", "toInt", "toFloat", "toBVec2", "toIVec2", "toUVec2", "toVec2", "toBVec3", "toIVec3", "toUVec3", "toVec3", "toBVec4", "toIVec4", "toUVec4", "toVec4", "toColor", "toMat2", "toMat3", "toMat4"];
|
|
7
|
+
declare const TYPE_MAPPING: {
|
|
8
|
+
readonly bool: "bool";
|
|
9
|
+
readonly uint: "u32";
|
|
10
|
+
readonly int: "i32";
|
|
11
|
+
readonly float: "f32";
|
|
12
|
+
readonly bvec2: "vec2<bool>";
|
|
13
|
+
readonly ivec2: "vec2i";
|
|
14
|
+
readonly uvec2: "vec2u";
|
|
15
|
+
readonly vec2: "vec2f";
|
|
16
|
+
readonly bvec3: "vec3<bool>";
|
|
17
|
+
readonly ivec3: "vec3i";
|
|
18
|
+
readonly uvec3: "vec3u";
|
|
19
|
+
readonly vec3: "vec3f";
|
|
20
|
+
readonly bvec4: "vec4<bool>";
|
|
21
|
+
readonly ivec4: "vec4i";
|
|
22
|
+
readonly uvec4: "vec4u";
|
|
23
|
+
readonly vec4: "vec4f";
|
|
24
|
+
readonly color: "color";
|
|
25
|
+
readonly mat2: "mat2x2f";
|
|
26
|
+
readonly mat3: "mat3x3f";
|
|
27
|
+
readonly mat4: "mat4x4f";
|
|
28
|
+
readonly texture: "texture_2d<f32>";
|
|
29
|
+
readonly sampler2D: "sampler";
|
|
30
|
+
readonly struct: "struct";
|
|
31
|
+
};
|
|
32
|
+
declare const CONSTANTS: (keyof typeof TYPE_MAPPING)[];
|
|
33
|
+
declare const OPERATORS: {
|
|
34
|
+
readonly not: "";
|
|
35
|
+
readonly add: "+";
|
|
36
|
+
readonly sub: "-";
|
|
37
|
+
readonly mul: "*";
|
|
38
|
+
readonly div: "/";
|
|
39
|
+
readonly mod: "%";
|
|
40
|
+
readonly equal: "==";
|
|
41
|
+
readonly notEqual: "!=";
|
|
42
|
+
readonly lessThan: "<";
|
|
43
|
+
readonly lessThanEqual: "<=";
|
|
44
|
+
readonly greaterThan: ">";
|
|
45
|
+
readonly greaterThanEqual: ">=";
|
|
46
|
+
readonly and: "&&";
|
|
47
|
+
readonly or: "||";
|
|
48
|
+
readonly bitAnd: "&";
|
|
49
|
+
readonly bitOr: "|";
|
|
50
|
+
readonly bitXor: "^";
|
|
51
|
+
readonly shiftLeft: "<<";
|
|
52
|
+
readonly shiftRight: ">>";
|
|
53
|
+
readonly addAssign: "+=";
|
|
54
|
+
readonly subAssign: "-=";
|
|
55
|
+
readonly mulAssign: "*=";
|
|
56
|
+
readonly divAssign: "/=";
|
|
57
|
+
readonly modAssign: "%=";
|
|
58
|
+
readonly bitAndAssign: "&=";
|
|
59
|
+
readonly bitOrAssign: "|=";
|
|
60
|
+
readonly bitXorAssign: "^=";
|
|
61
|
+
readonly shiftLeftAssign: "<<=";
|
|
62
|
+
readonly shiftRightAssign: ">>=";
|
|
63
|
+
};
|
|
64
|
+
declare const OPERATOR_KEYS: (keyof typeof OPERATORS)[];
|
|
65
|
+
declare const OPERATOR_TYPE_RULES: readonly [readonly ["float", "vec2", "vec2"], readonly ["float", "vec3", "vec3"], readonly ["float", "vec4", "vec4"], readonly ["int", "ivec2", "ivec2"], readonly ["int", "ivec3", "ivec3"], readonly ["int", "ivec4", "ivec4"], readonly ["uint", "uvec2", "uvec2"], readonly ["uint", "uvec3", "uvec3"], readonly ["uint", "uvec4", "uvec4"], readonly ["mat2", "vec2", "vec2"], readonly ["mat3", "vec3", "vec3"], readonly ["mat4", "vec4", "vec4"], readonly ["vec2", "mat2", "vec2"], readonly ["vec3", "mat3", "vec3"], readonly ["vec4", "mat4", "vec4"]];
|
|
66
|
+
/**
|
|
67
|
+
* 2.2. unified with:
|
|
68
|
+
* 1.2. index.ts functions and
|
|
69
|
+
* 3.2. types.ts _N
|
|
70
|
+
*/
|
|
71
|
+
declare const FUNCTIONS: readonly [...("texture" | "all" | "any" | "determinant" | "distance" | "dot" | "length" | "lengthSq" | "luminance" | "cross" | "cubeTexture" | "texelFetch" | "textureLod")[], "abs", "acos", "acosh", "asin", "asinh", "atan", "atanh", "ceil", "cos", "cosh", "dFdx", "dFdy", "degrees", "exp", "exp2", "floor", "fract", "fwidth", "inverse", "inverseSqrt", "log", "log2", "negate", "normalize", "oneMinus", "radians", "reciprocal", "round", "sign", "sin", "sinh", "sqrt", "tan", "tanh", "trunc", "saturate", "atan2", "clamp", "max", "min", "mix", "pow", "reflect", "refract", "smoothstep", "step"];
|
|
72
|
+
|
|
73
|
+
type Constants = (typeof CONSTANTS)[number] | 'void';
|
|
74
|
+
type Conversions = (typeof CONVERSIONS)[number];
|
|
75
|
+
type Functions = (typeof FUNCTIONS)[number];
|
|
76
|
+
type Operators = (typeof OPERATOR_KEYS)[number];
|
|
77
|
+
/**
|
|
78
|
+
* scope
|
|
79
|
+
*/
|
|
80
|
+
interface FnLayout {
|
|
81
|
+
name: string;
|
|
82
|
+
type: C | 'auto';
|
|
83
|
+
inputs?: Array<{
|
|
84
|
+
name: string;
|
|
85
|
+
type: C | 'auto';
|
|
86
|
+
}>;
|
|
87
|
+
}
|
|
88
|
+
type StructFields = Record<string, X>;
|
|
89
|
+
/**
|
|
90
|
+
* node
|
|
91
|
+
*/
|
|
92
|
+
type NodeTypes = 'attribute' | 'instance' | 'storage' | 'uniform' | 'constant' | 'variable' | 'varying' | 'ternary' | 'builtin' | 'conversion' | 'operator' | 'function' | 'struct' | 'member' | 'element' | 'gather' | 'scatter' | 'scope' | 'assign' | 'loop' | 'define' | 'if' | 'switch' | 'declare' | 'return' | 'break' | 'continue';
|
|
93
|
+
interface NodeProps {
|
|
94
|
+
id?: string;
|
|
95
|
+
args?: any[];
|
|
96
|
+
type?: string;
|
|
97
|
+
children?: any[];
|
|
98
|
+
inferFrom?: any[];
|
|
99
|
+
layout?: FnLayout;
|
|
100
|
+
fields?: StructFields;
|
|
101
|
+
initialValues?: StructFields;
|
|
102
|
+
}
|
|
103
|
+
interface NodeContext {
|
|
104
|
+
gl?: Partial<GL>;
|
|
105
|
+
label?: 'vert' | 'frag' | 'compute';
|
|
106
|
+
isWebGL?: boolean;
|
|
107
|
+
units?: any;
|
|
108
|
+
infers?: WeakMap<X, C>;
|
|
109
|
+
onMount?: (name: string) => void;
|
|
110
|
+
code?: {
|
|
111
|
+
headers: Map<string, string>;
|
|
112
|
+
fragInputs: Map<string, string>;
|
|
113
|
+
vertInputs: Map<string, string>;
|
|
114
|
+
vertOutputs: Map<string, string>;
|
|
115
|
+
vertVaryings: Map<string, string>;
|
|
116
|
+
computeInputs: Map<string, string>;
|
|
117
|
+
dependencies: Map<string, Set<string>>;
|
|
118
|
+
structStructFields: Map<string, StructFields>;
|
|
119
|
+
};
|
|
120
|
+
}
|
|
121
|
+
/**
|
|
122
|
+
* infer
|
|
123
|
+
*/
|
|
124
|
+
type _StringLength<A extends string> = A extends `${infer _}${infer A}` ? A extends '' ? 1 : A extends `${infer _}${infer B}` ? B extends '' ? 2 : B extends `${infer _}${infer C}` ? C extends '' ? 3 : 4 : never : never : never;
|
|
125
|
+
type InferOperator<L extends C, R extends C> = L extends R ? L : L extends 'float' | 'int' ? R : R extends 'float' | 'int' ? L : L extends 'mat4' ? R extends 'vec4' ? R : L : L extends 'mat3' ? R extends 'vec3' ? R : L : L extends 'mat2' ? R extends 'vec2' ? R : L : L extends 'vec4' ? R extends 'mat4' ? L : L : L extends 'vec3' ? R extends 'mat3' ? L : L : L extends 'vec2' ? R extends 'mat2' ? L : L : L;
|
|
126
|
+
type InferArrayElement<T extends C> = T extends 'mat4' ? 'vec4' : T extends 'mat3' ? 'vec3' : T extends 'mat2' ? 'vec2' : 'float';
|
|
127
|
+
type ExtractPairs<T> = T extends readonly [infer L, infer R, string] ? [L, R] | [R, L] : never;
|
|
128
|
+
type OperatorTypeRules = ExtractPairs<(typeof OPERATOR_TYPE_RULES)[number]>;
|
|
129
|
+
type IsInRules<L extends C, R extends C> = [L, R] extends OperatorTypeRules ? 1 : 0;
|
|
130
|
+
type ValidateOperator<L extends C, R extends C> = L extends R ? 1 : IsInRules<L, R>;
|
|
131
|
+
type InferSwizzleType<S extends string> = _StringLength<S> extends 4 ? 'vec4' : _StringLength<S> extends 3 ? 'vec3' : _StringLength<S> extends 2 ? 'vec2' : 'float';
|
|
132
|
+
/**
|
|
133
|
+
* Swizzles
|
|
134
|
+
*/
|
|
135
|
+
type _Swizzles<T extends string> = T | `${T}${T}` | `${T}${T}${T}` | `${T}${T}${T}${T}`;
|
|
136
|
+
type Swizzles = _Swizzles<'x' | 'y' | 'z' | 'w'> | _Swizzles<'r' | 'g' | 'b' | 'a'> | _Swizzles<'p' | 'q'> | _Swizzles<'s' | 't'>;
|
|
137
|
+
type Void = XImpl<'void'>;
|
|
138
|
+
type Bool = XImpl<'bool'>;
|
|
139
|
+
type UInt = XImpl<'uint'>;
|
|
140
|
+
type Int = XImpl<'int'>;
|
|
141
|
+
type Float = XImpl<'float'>;
|
|
142
|
+
type BVec2 = XImpl<'bvec2'>;
|
|
143
|
+
type IVec2 = XImpl<'ivec2'>;
|
|
144
|
+
type UVec2 = XImpl<'uvec2'>;
|
|
145
|
+
type Vec2 = XImpl<'vec2'>;
|
|
146
|
+
type BVec3 = XImpl<'bvec3'>;
|
|
147
|
+
type IVec3 = XImpl<'ivec3'>;
|
|
148
|
+
type UVec3 = XImpl<'uvec3'>;
|
|
149
|
+
type Vec3 = XImpl<'vec3'>;
|
|
150
|
+
type BVec4 = XImpl<'bvec4'>;
|
|
151
|
+
type IVec4 = XImpl<'ivec4'>;
|
|
152
|
+
type UVec4 = XImpl<'uvec4'>;
|
|
153
|
+
type Vec4 = XImpl<'vec4'>;
|
|
154
|
+
type Color = XImpl<'color'>;
|
|
155
|
+
type Mat2 = XImpl<'mat2'>;
|
|
156
|
+
type Mat3 = XImpl<'mat3'>;
|
|
157
|
+
type Mat4 = XImpl<'mat4'>;
|
|
158
|
+
type Texture = XImpl<'texture'>;
|
|
159
|
+
type Sampler2D = XImpl<'sampler2D'>;
|
|
160
|
+
type StructBase = XImpl<'struct'>;
|
|
161
|
+
interface ConstantsToType {
|
|
162
|
+
void: Void;
|
|
163
|
+
bool: Bool;
|
|
164
|
+
uint: UInt;
|
|
165
|
+
int: Int;
|
|
166
|
+
float: Float;
|
|
167
|
+
bvec2: BVec2;
|
|
168
|
+
ivec2: IVec2;
|
|
169
|
+
uvec2: UVec2;
|
|
170
|
+
vec2: Vec2;
|
|
171
|
+
bvec3: BVec3;
|
|
172
|
+
ivec3: IVec3;
|
|
173
|
+
uvec3: UVec3;
|
|
174
|
+
vec3: Vec3;
|
|
175
|
+
bvec4: BVec4;
|
|
176
|
+
ivec4: IVec4;
|
|
177
|
+
uvec4: UVec4;
|
|
178
|
+
vec4: Vec4;
|
|
179
|
+
color: Color;
|
|
180
|
+
mat2: Mat2;
|
|
181
|
+
mat3: Mat3;
|
|
182
|
+
mat4: Mat4;
|
|
183
|
+
texture: Texture;
|
|
184
|
+
sampler2D: Sampler2D;
|
|
185
|
+
struct: StructBase;
|
|
186
|
+
}
|
|
187
|
+
/**
|
|
188
|
+
* X and Y
|
|
189
|
+
*/
|
|
190
|
+
type XImpl<T extends C> = _X<T> & {
|
|
191
|
+
[K in string as K extends Methods ? never : K]: any;
|
|
192
|
+
} & {
|
|
193
|
+
[K in Swizzles]: X<InferSwizzleType<K>>;
|
|
194
|
+
};
|
|
195
|
+
type C = Constants;
|
|
196
|
+
type X<T extends C = C> = T extends keyof ConstantsToType ? ConstantsToType[T] : _X<T>;
|
|
197
|
+
type Methods = Functions | Operators | Conversions | Swizzles | '__nodeType' | 'type' | 'props' | 'isProxy' | 'assign' | 'toVar' | 'toString' | 'element' | 'select';
|
|
198
|
+
interface _X<T extends C> {
|
|
199
|
+
readonly __nodeType?: T;
|
|
200
|
+
assign(x: any): X<T>;
|
|
201
|
+
select(x: number | X<T>, y: X<'bool'>): X<T>;
|
|
202
|
+
fragment(c: NodeContext): string;
|
|
203
|
+
toVar(name?: string): X<T>;
|
|
204
|
+
toString(c?: NodeContext): string;
|
|
205
|
+
fragment(c?: NodeContext): string;
|
|
206
|
+
compute(c?: NodeContext): string;
|
|
207
|
+
vertex(c?: NodeContext): string;
|
|
208
|
+
type: NodeTypes;
|
|
209
|
+
props: NodeProps;
|
|
210
|
+
isProxy: true;
|
|
211
|
+
listeners: Set<(value: any) => void>;
|
|
212
|
+
element<Index extends X>(index: Index): X<InferArrayElement<T>>;
|
|
213
|
+
member<K extends string>(key: K): K extends keyof T ? (T[K] extends X<infer U> ? X<U> : never) : never;
|
|
214
|
+
add<U extends C>(x: ValidateOperator<T, U> extends 0 ? never : number | X<U>): X<InferOperator<T, U>>;
|
|
215
|
+
sub<U extends C>(x: ValidateOperator<T, U> extends 0 ? never : number | X<U>): X<InferOperator<T, U>>;
|
|
216
|
+
mul<U extends C>(x: ValidateOperator<T, U> extends 0 ? never : number | X<U>): X<InferOperator<T, U>>;
|
|
217
|
+
div<U extends C>(x: ValidateOperator<T, U> extends 0 ? never : number | X<U>): X<InferOperator<T, U>>;
|
|
218
|
+
mod<U extends C>(x: ValidateOperator<T, U> extends 0 ? never : number | X<U>): X<InferOperator<T, U>>;
|
|
219
|
+
equal<U extends C>(x: ValidateOperator<T, U> extends 0 ? never : number | X<U>): Bool;
|
|
220
|
+
notEqual<U extends C>(x: ValidateOperator<T, U> extends 0 ? never : number | X<U>): Bool;
|
|
221
|
+
lessThan<U extends C>(x: ValidateOperator<T, U> extends 0 ? never : number | X<U>): Bool;
|
|
222
|
+
lessThanEqual<U extends C>(x: ValidateOperator<T, U> extends 0 ? never : number | X<U>): Bool;
|
|
223
|
+
greaterThan<U extends C>(x: ValidateOperator<T, U> extends 0 ? never : number | X<U>): Bool;
|
|
224
|
+
greaterThanEqual<U extends C>(x: ValidateOperator<T, U> extends 0 ? never : number | X<U>): Bool;
|
|
225
|
+
and(x: Bool): Bool;
|
|
226
|
+
or(x: Bool): Bool;
|
|
227
|
+
not(): Bool;
|
|
228
|
+
bitAnd(x: X<T>): X<T>;
|
|
229
|
+
bitOr(x: X<T>): X<T>;
|
|
230
|
+
bitXor(x: X<T>): X<T>;
|
|
231
|
+
bitNot(): X<T>;
|
|
232
|
+
shiftLeft<U extends C>(x: X<U>): X<InferOperator<T, U>>;
|
|
233
|
+
shiftRight<U extends C>(x: X<U>): X<InferOperator<T, U>>;
|
|
234
|
+
addAssign<U extends C>(x: ValidateOperator<T, U> extends 0 ? never : number | X<U>): X<T>;
|
|
235
|
+
subAssign<U extends C>(x: ValidateOperator<T, U> extends 0 ? never : number | X<U>): X<T>;
|
|
236
|
+
mulAssign<U extends C>(x: ValidateOperator<T, U> extends 0 ? never : number | X<U>): X<T>;
|
|
237
|
+
divAssign<U extends C>(x: ValidateOperator<T, U> extends 0 ? never : number | X<U>): X<T>;
|
|
238
|
+
modAssign<U extends C>(x: ValidateOperator<T, U> extends 0 ? never : number | X<U>): X<T>;
|
|
239
|
+
bitAndAssign<U extends C>(x: ValidateOperator<T, U> extends 0 ? never : number | X<U>): X<T>;
|
|
240
|
+
bitOrAssign<U extends C>(x: ValidateOperator<T, U> extends 0 ? never : number | X<U>): X<T>;
|
|
241
|
+
bitXorAssign<U extends C>(x: ValidateOperator<T, U> extends 0 ? never : number | X<U>): X<T>;
|
|
242
|
+
shiftLeftAssign<U extends C>(x: ValidateOperator<T, U> extends 0 ? never : number | X<U>): X<T>;
|
|
243
|
+
shiftRightAssign<U extends C>(x: ValidateOperator<T, U> extends 0 ? never : number | X<U>): X<T>;
|
|
244
|
+
toBool(): Bool;
|
|
245
|
+
toUInt(): UInt;
|
|
246
|
+
toInt(): Int;
|
|
247
|
+
toFloat(): Float;
|
|
248
|
+
toBVec2(): BVec2;
|
|
249
|
+
toIVec2(): IVec2;
|
|
250
|
+
toUVec2(): UVec2;
|
|
251
|
+
toVec2(): Vec2;
|
|
252
|
+
toBVec3(): BVec3;
|
|
253
|
+
toIVec3(): IVec3;
|
|
254
|
+
toUVec3(): UVec3;
|
|
255
|
+
toVec3(): Vec3;
|
|
256
|
+
toBVec4(): BVec4;
|
|
257
|
+
toIVec4(): IVec4;
|
|
258
|
+
toUVec4(): UVec4;
|
|
259
|
+
toVec4(): Vec4;
|
|
260
|
+
toColor(): Color;
|
|
261
|
+
toMat2(): Mat2;
|
|
262
|
+
toMat3(): Mat3;
|
|
263
|
+
toMat4(): Mat4;
|
|
264
|
+
/**
|
|
265
|
+
* 3.1. unified logic with:
|
|
266
|
+
* 1.1. index.ts functions and
|
|
267
|
+
* 2.1. const.ts FUNCTION_RETURN_TYPES
|
|
268
|
+
*/
|
|
269
|
+
all(): Bool;
|
|
270
|
+
any(): Bool;
|
|
271
|
+
determinant(): T extends 'mat2' | 'mat3' | 'mat4' ? Float : never;
|
|
272
|
+
distance<U extends C>(y: T extends 'vec2' | 'vec3' | 'vec4' ? (U extends T ? number | X<U> : never) : never): Float;
|
|
273
|
+
dot<U extends C>(y: T extends 'vec2' | 'vec3' | 'vec4' | 'ivec2' | 'ivec3' | 'ivec4' ? U extends T ? number | X<U> : never : never): T extends `ivec${string}` ? Int : Float;
|
|
274
|
+
length(): T extends 'vec2' | 'vec3' | 'vec4' ? Float : never;
|
|
275
|
+
lengthSq(): Float;
|
|
276
|
+
luminance(): Float;
|
|
277
|
+
cross<U extends C = 'vec3'>(y: T extends 'vec3' ? (U extends 'vec3' ? number | X<U> : never) : never): Vec3;
|
|
278
|
+
cubeTexture(...args: X[]): Vec4;
|
|
279
|
+
texture(...args: X[]): Vec4;
|
|
280
|
+
texelFetch(...args: X[]): Vec4;
|
|
281
|
+
textureLod(...args: X[]): Vec4;
|
|
282
|
+
/**
|
|
283
|
+
* 3.2. unified with:
|
|
284
|
+
* 1.2. index.ts functions and
|
|
285
|
+
* 2.2. const.ts FUNCTIONS
|
|
286
|
+
*/
|
|
287
|
+
abs(): X<T>;
|
|
288
|
+
acos(): X<T>;
|
|
289
|
+
acosh(): X<T>;
|
|
290
|
+
asin(): X<T>;
|
|
291
|
+
asinh(): X<T>;
|
|
292
|
+
atan(): X<T>;
|
|
293
|
+
atanh(): X<T>;
|
|
294
|
+
ceil(): X<T>;
|
|
295
|
+
cos(): X<T>;
|
|
296
|
+
cosh(): X<T>;
|
|
297
|
+
degrees(): X<T>;
|
|
298
|
+
dFdx(): X<T>;
|
|
299
|
+
dFdy(): X<T>;
|
|
300
|
+
exp(): X<T>;
|
|
301
|
+
exp2(): X<T>;
|
|
302
|
+
floor(): X<T>;
|
|
303
|
+
fract(): X<T>;
|
|
304
|
+
fwidth(): X<T>;
|
|
305
|
+
inverseSqrt(): X<T>;
|
|
306
|
+
log(): X<T>;
|
|
307
|
+
log2(): X<T>;
|
|
308
|
+
negate(): X<T>;
|
|
309
|
+
normalize(): T extends 'vec2' | 'vec3' | 'vec4' ? X<T> : never;
|
|
310
|
+
oneMinus(): X<T>;
|
|
311
|
+
radians(): X<T>;
|
|
312
|
+
reciprocal(): X<T>;
|
|
313
|
+
round(): X<T>;
|
|
314
|
+
saturate(): X<T>;
|
|
315
|
+
sign(): X<T>;
|
|
316
|
+
sin(): X<T>;
|
|
317
|
+
sinh(): X<T>;
|
|
318
|
+
sqrt(): X<T>;
|
|
319
|
+
tan(): X<T>;
|
|
320
|
+
tanh(): X<T>;
|
|
321
|
+
trunc(): X<T>;
|
|
322
|
+
atan2<U extends C>(x: number | X<U>): X<T>;
|
|
323
|
+
clamp<U extends C>(min: number | X<U>, max: number | X<U>): X<InferOperator<T, U>>;
|
|
324
|
+
max<U extends C>(y: number | X<U>): X<InferOperator<T, U>>;
|
|
325
|
+
min<U extends C>(y: number | X<U>): X<InferOperator<T, U>>;
|
|
326
|
+
mix<U extends C>(y: number | X<U>, a: number | Float | X<U>): X<InferOperator<T, U>>;
|
|
327
|
+
pow<U extends C>(y: number | X<U>): X<T>;
|
|
328
|
+
reflect<U extends C>(N: T extends 'vec2' | 'vec3' | 'vec4' ? (U extends T ? number | X<U> : never) : never): X<T>;
|
|
329
|
+
refract<U extends C>(N: T extends 'vec2' | 'vec3' | 'vec4' ? (U extends T ? number | X<U> : never) : never, eta: number | Float): T extends 'vec2' | 'vec3' | 'vec4' ? X<T> : never;
|
|
330
|
+
smoothstep<U extends C>(edge0: number | X<U>, edge1: number | X<U>): X<InferOperator<T, U>>;
|
|
331
|
+
step<U extends C>(edge: number | X<U>): X<InferOperator<T, U>>;
|
|
332
|
+
}
|
|
333
|
+
|
|
334
|
+
type GL = EventState<{
|
|
335
|
+
/**
|
|
336
|
+
* initial value
|
|
337
|
+
*/
|
|
338
|
+
isNative: boolean;
|
|
339
|
+
isWebGL: boolean;
|
|
340
|
+
isError: boolean;
|
|
341
|
+
isLoop: boolean;
|
|
342
|
+
isDebug: boolean;
|
|
343
|
+
isDepth: boolean;
|
|
344
|
+
isGL: true;
|
|
345
|
+
width?: number;
|
|
346
|
+
height?: number;
|
|
347
|
+
size: [number, number];
|
|
348
|
+
mouse: [number, number];
|
|
349
|
+
count: number;
|
|
350
|
+
instanceCount: number;
|
|
351
|
+
particleCount: number | [number, number] | [number, number, number];
|
|
352
|
+
loading: number;
|
|
353
|
+
el: HTMLCanvasElement;
|
|
354
|
+
vs?: string | Vec4;
|
|
355
|
+
cs?: string | Void;
|
|
356
|
+
fs?: string | Vec4;
|
|
357
|
+
vert?: string | Vec4;
|
|
358
|
+
comp?: string | Void;
|
|
359
|
+
frag?: string | Vec4;
|
|
360
|
+
vertex?: string | Vec4;
|
|
361
|
+
compute?: string | Void;
|
|
362
|
+
fragment?: string | Vec4;
|
|
363
|
+
/**
|
|
364
|
+
* core state
|
|
365
|
+
*/
|
|
366
|
+
webgpu: WebGPUState;
|
|
367
|
+
webgl: WebGLState;
|
|
368
|
+
queue: Queue;
|
|
369
|
+
frame: Frame;
|
|
370
|
+
/**
|
|
371
|
+
* events
|
|
372
|
+
*/
|
|
373
|
+
ref?: any;
|
|
374
|
+
mount(): void;
|
|
375
|
+
clean(): void;
|
|
376
|
+
error(e?: string): void;
|
|
377
|
+
render(): void;
|
|
378
|
+
resize(e?: Event): void;
|
|
379
|
+
mousemove(e: MouseEvent): void;
|
|
380
|
+
loop(): void;
|
|
381
|
+
/**
|
|
382
|
+
* setter
|
|
383
|
+
*/
|
|
384
|
+
_uniform?(key: string, value: Uniform, isMatrix?: boolean): GL;
|
|
385
|
+
uniform(key: string, value: Uniform, isMatrix?: boolean): GL;
|
|
386
|
+
uniform(target: {
|
|
387
|
+
[key: string]: Uniform;
|
|
388
|
+
}): GL;
|
|
389
|
+
_texture?(key: string, value: string): GL;
|
|
390
|
+
texture(key: string, value: string): GL;
|
|
391
|
+
texture(target: {
|
|
392
|
+
[key: string]: string;
|
|
393
|
+
}): GL;
|
|
394
|
+
_attribute?(key: string, value: Attribute, iboValue?: Attribute): GL;
|
|
395
|
+
attribute(key: string, value: Attribute, iboValue?: Attribute): GL;
|
|
396
|
+
attribute(target: {
|
|
397
|
+
[key: string]: Attribute;
|
|
398
|
+
}): GL;
|
|
399
|
+
_instance?(key: string, value: Attribute, at?: number): GL;
|
|
400
|
+
instance(key: string, value: Attribute, at?: number): GL;
|
|
401
|
+
instance(target: {
|
|
402
|
+
[key: string]: Attribute;
|
|
403
|
+
}): GL;
|
|
404
|
+
_storage?(key: string, value: Storage): GL;
|
|
405
|
+
storage(key: string, value: Storage): GL;
|
|
406
|
+
storage(target: {
|
|
407
|
+
[key: string]: Storage;
|
|
408
|
+
}): GL;
|
|
409
|
+
}>;
|
|
410
|
+
type Uniform = number | number[] | Float32Array;
|
|
411
|
+
type Attribute = number[] | Float32Array;
|
|
412
|
+
type Storage = number[] | Float32Array;
|
|
413
|
+
/**
|
|
414
|
+
* for webgpu
|
|
415
|
+
*/
|
|
416
|
+
interface UniformData {
|
|
417
|
+
array: Float32Array;
|
|
418
|
+
buffer: GPUBuffer;
|
|
419
|
+
binding: number;
|
|
420
|
+
group: number;
|
|
421
|
+
}
|
|
422
|
+
interface TextureData {
|
|
423
|
+
binding: number;
|
|
424
|
+
group: number;
|
|
425
|
+
texture: GPUTexture;
|
|
426
|
+
sampler: GPUSampler;
|
|
427
|
+
view: GPUTextureView;
|
|
428
|
+
}
|
|
429
|
+
interface AttribData {
|
|
430
|
+
array: Float32Array;
|
|
431
|
+
buffer: GPUBuffer;
|
|
432
|
+
location: number;
|
|
433
|
+
stride: number;
|
|
434
|
+
isInstance?: boolean;
|
|
435
|
+
}
|
|
436
|
+
interface StorageData {
|
|
437
|
+
array: Float32Array;
|
|
438
|
+
buffer: GPUBuffer;
|
|
439
|
+
binding: number;
|
|
440
|
+
group: number;
|
|
441
|
+
}
|
|
442
|
+
interface WebGPUState {
|
|
443
|
+
device: GPUDevice;
|
|
444
|
+
uniforms: Nested<UniformData>;
|
|
445
|
+
textures: Nested<TextureData>;
|
|
446
|
+
attribs: Nested<AttribData>;
|
|
447
|
+
storages: Nested<StorageData>;
|
|
448
|
+
}
|
|
449
|
+
/**
|
|
450
|
+
* for webgl
|
|
451
|
+
*/
|
|
452
|
+
interface WebGLState {
|
|
453
|
+
context: WebGLRenderingContext;
|
|
454
|
+
program: WebGLProgram;
|
|
455
|
+
storages: any;
|
|
456
|
+
}
|
|
457
|
+
|
|
458
|
+
declare const isGL: (a: unknown) => a is EventState<GL>;
|
|
459
|
+
declare const isServer: () => boolean;
|
|
460
|
+
declare const isWebGPUSupported: () => boolean;
|
|
461
|
+
declare const createGL: (props?: Partial<GL>) => EventState<{
|
|
462
|
+
isNative: boolean;
|
|
463
|
+
isWebGL: boolean;
|
|
464
|
+
isError: boolean;
|
|
465
|
+
isLoop: boolean;
|
|
466
|
+
isDebug: boolean;
|
|
467
|
+
isDepth: boolean;
|
|
468
|
+
isGL: true;
|
|
469
|
+
width?: number;
|
|
470
|
+
height?: number;
|
|
471
|
+
size: [number, number];
|
|
472
|
+
mouse: [number, number];
|
|
473
|
+
count: number;
|
|
474
|
+
instanceCount: number;
|
|
475
|
+
particleCount: number | [number, number] | [number, number, number];
|
|
476
|
+
loading: number;
|
|
477
|
+
el: HTMLCanvasElement;
|
|
478
|
+
vs?: string | Vec4;
|
|
479
|
+
cs?: string | Void;
|
|
480
|
+
fs?: string | Vec4;
|
|
481
|
+
vert?: string | Vec4;
|
|
482
|
+
comp?: string | Void;
|
|
483
|
+
frag?: string | Vec4;
|
|
484
|
+
vertex?: string | Vec4;
|
|
485
|
+
compute?: string | Void;
|
|
486
|
+
fragment?: string | Vec4;
|
|
487
|
+
webgpu: WebGPUState;
|
|
488
|
+
webgl: WebGLState;
|
|
489
|
+
queue: refr.Queue;
|
|
490
|
+
frame: refr.Frame;
|
|
491
|
+
ref?: any;
|
|
492
|
+
mount(): void;
|
|
493
|
+
clean(): void;
|
|
494
|
+
error(e?: string): void;
|
|
495
|
+
render(): void;
|
|
496
|
+
resize(e?: Event): void;
|
|
497
|
+
mousemove(e: MouseEvent): void;
|
|
498
|
+
loop(): void;
|
|
499
|
+
_uniform?(key: string, value: number | number[] | Float32Array<ArrayBufferLike>, isMatrix?: boolean): GL;
|
|
500
|
+
uniform(key: string, value: number | number[] | Float32Array<ArrayBufferLike>, isMatrix?: boolean): GL;
|
|
501
|
+
uniform(target: {
|
|
502
|
+
[key: string]: number | number[] | Float32Array<ArrayBufferLike>;
|
|
503
|
+
}): GL;
|
|
504
|
+
_texture?(key: string, value: string): GL;
|
|
505
|
+
texture(key: string, value: string): GL;
|
|
506
|
+
texture(target: {
|
|
507
|
+
[key: string]: string;
|
|
508
|
+
}): GL;
|
|
509
|
+
_attribute?(key: string, value: number[] | Float32Array<ArrayBufferLike>, iboValue?: number[] | Float32Array<ArrayBufferLike>): GL;
|
|
510
|
+
attribute(key: string, value: number[] | Float32Array<ArrayBufferLike>, iboValue?: number[] | Float32Array<ArrayBufferLike>): GL;
|
|
511
|
+
attribute(target: {
|
|
512
|
+
[key: string]: number[] | Float32Array<ArrayBufferLike>;
|
|
513
|
+
}): GL;
|
|
514
|
+
_instance?(key: string, value: number[] | Float32Array<ArrayBufferLike>, at?: number): GL;
|
|
515
|
+
instance(key: string, value: number[] | Float32Array<ArrayBufferLike>, at?: number): GL;
|
|
516
|
+
instance(target: {
|
|
517
|
+
[key: string]: number[] | Float32Array<ArrayBufferLike>;
|
|
518
|
+
}): GL;
|
|
519
|
+
_storage?(key: string, value: number[] | Float32Array<ArrayBufferLike>): GL;
|
|
520
|
+
storage(key: string, value: number[] | Float32Array<ArrayBufferLike>): GL;
|
|
521
|
+
storage(target: {
|
|
522
|
+
[key: string]: number[] | Float32Array<ArrayBufferLike>;
|
|
523
|
+
}): GL;
|
|
524
|
+
}, any[] | unknown[]>;
|
|
5
525
|
|
|
6
526
|
declare const useGL: (props?: Partial<GL>) => reev.EventState<GL>;
|
|
7
527
|
|
|
8
|
-
export { GL, useGL };
|
|
528
|
+
export { type AttribData, type GL, type StorageData, type TextureData, type UniformData, type WebGLState, type WebGPUState, createGL, isGL, isServer, isWebGPUSupported, useGL };
|
package/dist/react.js
CHANGED
|
@@ -1,49 +1,2 @@
|
|
|
1
|
-
import{useState as
|
|
2
|
-
|
|
3
|
-
\u2193\u2193\u2193generated\u2193\u2193\u2193
|
|
4
|
-
${t}`)},oe=(e,t,r,o)=>{let n=e.createProgram(),s=Ce(e,t,e.FRAGMENT_SHADER,o.error),i=Ce(e,r,e.VERTEX_SHADER,o.error);if(!s||!i)return;if(e.attachShader(n,s),e.attachShader(n,i),e.linkProgram(n),e.getProgramParameter(n,e.LINK_STATUS))return n;let p=e.getProgramInfoLog(n);e.deleteProgram(n),o.error(`Could not link program: ${p}`)},Pt=(e,t)=>{let r=e.createBuffer();return e.bindBuffer(e.ARRAY_BUFFER,r),e.bufferData(e.ARRAY_BUFFER,new Float32Array(t),e.STATIC_DRAW),e.bindBuffer(e.ARRAY_BUFFER,null),r},$t=(e,t)=>{let r=e.createBuffer();return e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,r),e.bufferData(e.ELEMENT_ARRAY_BUFFER,new Int16Array(t),e.STATIC_DRAW),e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,null),r},Gt=(e,t,r)=>{r&&(e=Math.max(...r)+1);let o=t.length/e;return Math.floor(o)},_e=(e,t,r,o,n)=>{let s=Pt(e,o),i=$t(e,n),p=Gt(r,o,n);e.bindBuffer(e.ARRAY_BUFFER,s),e.enableVertexAttribArray(t),e.vertexAttribPointer(t,p,e.FLOAT,!1,0,0),i&&e.bindBuffer(e.ELEMENT_ARRAY_BUFFER,i)},se=(e,t,r)=>{if(x.num(r))return e.uniform1f(t,r);let o=r.length;if(o<=4)return e[`uniform${o}fv`](t,r);o=Math.sqrt(o)<<0,e[`uniformMatrix${o}fv`](t,!1,r)},Pe=(e,t,r,o)=>{let n=e.createTexture();e.bindTexture(e.TEXTURE_2D,n),e.texImage2D(e.TEXTURE_2D,0,e.RGBA,e.RGBA,e.UNSIGNED_BYTE,t),e.generateMipmap(e.TEXTURE_2D),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_MIN_FILTER,e.LINEAR),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_MAG_FILTER,e.LINEAR),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_WRAP_S,e.CLAMP_TO_EDGE),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_WRAP_T,e.CLAMP_TO_EDGE),e.bindTexture(e.TEXTURE_2D,null),e.uniform1i(r,o),e.activeTexture(e.TEXTURE0+o),e.bindTexture(e.TEXTURE_2D,n)},$e=(e,t,r,o,n,s,i)=>{let p=r*r,a=t.length/p;for(let u=0;u<p;u++)for(let d=0;d<Math.min(a,4);d++)i[4*u+d]=t[u*a+d]||0;e.activeTexture(e.TEXTURE0+s),e.bindTexture(e.TEXTURE_2D,o.texture),e.texImage2D(e.TEXTURE_2D,0,e.RGBA32F,r,r,0,e.RGBA,e.FLOAT,i),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_MIN_FILTER,e.NEAREST),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_MAG_FILTER,e.NEAREST),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_WRAP_S,e.CLAMP_TO_EDGE),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_WRAP_T,e.CLAMP_TO_EDGE),e.bindTexture(e.TEXTURE_2D,n.texture),e.texImage2D(e.TEXTURE_2D,0,e.RGBA32F,r,r,0,e.RGBA,e.FLOAT,i),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_MIN_FILTER,e.NEAREST),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_MAG_FILTER,e.NEAREST),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_WRAP_S,e.CLAMP_TO_EDGE),e.texParameteri(e.TEXTURE_2D,e.TEXTURE_WRAP_T,e.CLAMP_TO_EDGE)},Ge=(e,t)=>{for(let{ping:r,pong:o}of t)e.deleteTexture(r.texture),e.deleteTexture(o.texture),e.deleteFramebuffer(r.buffer),e.deleteFramebuffer(o.buffer)},Le=(e,t,r,o,n,s)=>{e.activeTexture(e.TEXTURE0+n),e.bindTexture(e.TEXTURE_2D,t.texture),e.uniform1i(o,n),s===0&&e.bindFramebuffer(e.FRAMEBUFFER,r.buffer);let i=e.COLOR_ATTACHMENT0+s;return e.framebufferTexture2D(e.FRAMEBUFFER,i,e.TEXTURE_2D,r.texture,0),i};var ie=["toBool","toUint","toInt","toFloat","toBvec2","toIvec2","toUvec2","toVec2","toBvec3","toIvec3","toUvec3","toVec3","toBvec4","toIvec4","toUvec4","toVec4","toColor","toMat2","toMat3","toMat4"],ae={bool:"bool",uint:"u32",int:"i32",float:"f32",bvec2:"vec2<bool>",ivec2:"vec2i",uvec2:"vec2u",vec2:"vec2f",bvec3:"vec3<bool>",ivec3:"vec3i",uvec3:"vec3u",vec3:"vec3f",bvec4:"vec4<bool>",ivec4:"vec4i",uvec4:"vec4u",vec4:"vec4f",color:"color",mat2:"mat2x2f",mat3:"mat3x3f",mat4:"mat4x4f",texture:"texture_2d<f32>",sampler2D:"sampler",struct:"struct"},ue=Object.keys(ae),pe={not:"",add:"+",sub:"-",mul:"*",div:"/",mod:"%",equal:"==",notEqual:"!=",lessThan:"<",lessThanEqual:"<=",greaterThan:">",greaterThanEqual:">=",and:"&&",or:"||",bitAnd:"&",bitOr:"|",bitXor:"^",shiftLeft:"<<",shiftRight:">>"},Ne=Object.keys(pe),fe={1:"float",2:"vec2",3:"vec3",4:"vec4",9:"mat3",16:"mat4"},Se={position:"vec4",vertex_index:"uint",instance_index:"uint",front_facing:"bool",frag_depth:"float",sample_index:"uint",sample_mask:"uint",point_coord:"vec2",global_invocation_id:"uvec3",positionLocal:"vec3",positionWorld:"vec3",positionView:"vec3",normalLocal:"vec3",normalWorld:"vec3",normalView:"vec3",screenCoordinate:"vec2",screenUV:"vec2",gl_FragCoord:"vec4",gl_VertexID:"uint",gl_InstanceID:"uint",gl_FrontFacing:"bool",gl_FragDepth:"float",gl_SampleID:"uint",gl_SampleMask:"uint",gl_PointCoord:"vec2",normal:"vec3",uv:"vec2",color:"vec4"},Re=["equal","notEqual","lessThan","lessThanEqual","greaterThan","greaterThanEqual"],we=["and","or"],Fe={position:"gl_FragCoord",vertex_index:"gl_VertexID",instance_index:"gl_InstanceID",front_facing:"gl_FrontFacing",frag_depth:"gl_FragDepth",sample_index:"gl_SampleID",sample_mask:"gl_SampleMask",point_coord:"gl_PointCoord",uv:"gl_FragCoord.xy"},ce={all:"bool",any:"bool",determinant:"float",distance:"float",dot:"float",length:"float",lengthSq:"float",luminance:"float",cross:"vec3",cubeTexture:"vec4",texture:"vec4",texelFetch:"vec4",textureLod:"vec4"},Ue=[...Object.keys(ce),"abs","acos","acosh","asin","asinh","atan","atanh","ceil","cos","cosh","dFdx","dFdy","degrees","exp","exp2","floor","fract","fwidth","inverseSqrt","log","log2","negate","normalize","oneMinus","radians","reciprocal","round","saturate","sign","sin","sinh","sqrt","tan","tanh","trunc","atan2","clamp","max","min","mix","pow","reflect","refract","smoothstep","step"];var Ae=e=>x.str(e)&&/^[xyzwrgbastpq]{1,4}$/.test(e),Ie=e=>Ne.includes(e),Oe=e=>Ue.includes(e),Me=e=>ie.includes(e),q=e=>!e||typeof e!="object"?!1:e.isProxy,le=e=>x.str(e)?ue.includes(e):!1,De=e=>{let t=(e>>16&255)/255,r=(e>>8&255)/255,o=(e&255)/255;return[t,r,o]},Lt=0,C=()=>`x${Lt++}`,Be=(e,t)=>{if(t==="global_invocation_id")return`uvec3(uint(gl_FragCoord.y) * uint(${Math.floor(Math.sqrt(e.gl?.particles||1024))}) + uint(gl_FragCoord.x), 0u, 0u)`;let r=Fe[t];if(!r)throw new Error(`Error: unknown builtin variable ${t}`);return r},N=(e,t)=>x.str(e)?t?.isWebGL?e:ae[e]||e:"",We=e=>pe[e]||e,ke=e=>{let t=ie.indexOf(e);return t!==-1?ue[t]:"float"},de=(e,t,r=!1,o=!1)=>e.isWebGL?r?n=>e.gl?.attribute?.(t,n):o?n=>e.gl?.texture?.(t,n):n=>e.gl?.uniform?.(t,n):r?n=>e.gl?._attribute?.(t,n):o?n=>e.gl?._texture?.(t,n):n=>e.gl?._uniform?.(t,n),xe=(e,t)=>{if(x.und(e))return;if(!q(e))return t(e);if(e.type!=="conversion")return;let r=e.props.children?.slice(1);x.und(r?.[0])||t(r.map(o=>o??r[0]))},Ve=e=>(e.code||(e.code={headers:new Map,fragInputs:new Map,vertInputs:new Map,vertOutputs:new Map,vertVaryings:new Map,computeInputs:new Map,dependencies:new Map,structFields:new Map},e.isWebGL)||(e.code.fragInputs.set("position","@builtin(position) position: vec4f"),e.code.vertOutputs.set("position","@builtin(position) position: vec4f")),e),ze=e=>x.num(e)||x.str(e)&&/^\d+$/.test(e),Y=(e,t="",r)=>{e.code?.dependencies?.has(t)||e.code.dependencies.set(t,new Set),le(r)||e.code.dependencies.get(t).add(r)};var Nt=e=>Se[e],St=(e,t,r)=>Re.includes(r)||we.includes(r)?"bool":e===t?e:e==="float"||e==="int"?t:t==="float"||t==="int"?e:e==="mat4"&&t==="vec4"||e==="mat3"&&t==="vec3"||e==="mat2"&&t==="vec2"?t:e,Rt=e=>x.bol(e)?"bool":x.str(e)?"texture":x.num(e)?"float":x.arr(e)?fe[e.length]:"float",me=e=>fe[e],qe=(e,t)=>{if(e.length===0)return"void";let[r]=e;return x.str(r)?r:X(r,t)},wt=e=>ce[e],Ft=(e,t)=>{let{type:r,props:o}=e,{id:n,children:s=[],inferFrom:i,layout:p}=o,[a,u,d]=s;if(r==="conversion")return a;if(r==="operator")return St(X(u,t),X(d,t),a);if(r==="builtin")return Nt(n);if(r==="function")return wt(a)||X(u,t);if(r==="define")return le(p?.type)?p?.type:!i||i.length===0?"void":qe(i,t);if(r==="attribute"&&x.arr(a)&&t.gl?.count)return me(a.length/t.gl.count);if(r==="member"){if(Ae(u))return me(u.length);if(q(a)){let h=X(a,t),T=t.code?.structFields?.get(h);if(T&&T[u])return X(T[u],t)}return"float"}return i?qe(i,t):X(a,t)},X=(e,t)=>{if(t||(t={}),!q(e))return Rt(e);if(x.arr(e))return me(e.length);if(t.infers||(t.infers=new WeakMap),t.infers.has(e))return t.infers.get(e);let r=Ft(e,t);return t.infers.set(e,r),r};var w=(e,t)=>e.filter(r=>!x.und(r)&&!x.nul(r)).map(r=>f(r,t)).join(", "),Ye=(e,t,r,o)=>{let n=()=>{let u=X(o,e);if(u==="float")return".x";if(u==="vec2")return".xy";if(u==="vec3")return".xyz";if(u==="vec4")return"";throw new Error(`Unsupported storage scatter type: ${u}`)},s=f(r,e),i=Math.floor(Math.sqrt(e.gl?.particles||1024)),p=`int(${s}) % ${i}`,a=`int(${s}) / ${i}`;return`texelFetch(${f(t,e)}, ivec2(${p}, ${a}), 0)${n()}`},He=(e,t,r)=>{let o=f(t,e),n=f(r,e),s=X(r,e);if(s==="float")return`_${o} = vec4(${n}, 0.0, 0.0, 1.0);`;if(s==="vec2")return`_${o} = vec4(${n}, 0.0, 1.0);`;if(s==="vec3")return`_${o} = vec4(${n}, 1.0);`;if(s==="vec4")return`_${o} = ${n};`;throw new Error(`Unsupported storage scatter type: ${s}`)},je=(e,t,r,o)=>{if(e.isWebGL)return`texture(${w(o?[t,r,o]:[t,r],e)})`;let n=f(t,e),s=[n,n+"Sampler",f(r,e)];return o?(s.push(f(o,e)),`textureSampleLevel(${s})`):`textureSample(${s})`},Ke=(e,t,r,o)=>{let n=`if (${f(t,e)}) {
|
|
5
|
-
${f(r,e)}
|
|
6
|
-
}`;for(let s=2;s<o.length;s+=2){let i=s>=o.length-1;n+=i?` else {
|
|
7
|
-
${f(o[s],e)}
|
|
8
|
-
}`:` else if (${f(o[s],e)}) {
|
|
9
|
-
${f(o[s+1],e)}
|
|
10
|
-
}`}return n},Ze=(e,t,r)=>{let o=`switch (${f(t,e)}) {
|
|
11
|
-
`;for(let n=1;n<r.length;n+=2)n>=r.length-1&&r.length%2===0?o+=`default:
|
|
12
|
-
${f(r[n],e)}
|
|
13
|
-
break;
|
|
14
|
-
`:n+1<r.length&&(o+=`case ${f(r[n],e)}:
|
|
15
|
-
${f(r[n+1],e)}
|
|
16
|
-
break;
|
|
17
|
-
`);return o+="}",o},Qe=(e,t,r)=>{let o=X(t,e),n=r?.props?.id;if(e.isWebGL)return`${o} ${n} = ${f(t,e)};`;let s=N(o);return`var ${n}: ${s} = ${f(t,e)};`},Je=(e,t,r={})=>{e.code?.structFields?.set(t,r);let o=[];for(let s in r){let i=r[s],p=X(i,e);e.isWebGL&&Y(e,t,p),o.push(e.isWebGL?`${p} ${s};`:`${s}: ${N(p,e)},`)}let n=o.join(`
|
|
18
|
-
`);return`struct ${t} {
|
|
19
|
-
${n}
|
|
20
|
-
};`},et=(e,t,r="",o)=>{let n=e.code?.structFields?.get(t)||{};if(e.isWebGL)if(o){let s=[];for(let i in n)s.push(o[i]);return`${t} ${r} = ${t}(${w(s,e)});`}else return`${t} ${r};`;else if(o){let s=[];for(let i in n)s.push(o[i]);return`var ${r}: ${t} = ${t}(${w(s,e)});`}else return`var ${r}: ${t};`},tt=(e,t,r)=>{let{id:o,children:n=[],layout:s}=t,[i,...p]=n,a=[],u=[];if(s?.inputs)for(let l of s.inputs)a.push([l.name,l.type]);else for(let l=0;l<p.length;l++)a.push([`p${l}`,X(p[l],e)]);let d=f(i,e),h=X(r,e),T=[];if(e?.isWebGL){for(let[l,g]of a)Y(e,o,g),u.push(`${g} ${l}`);Y(e,o,h),T.push(`${h} ${o}(${u}) {`)}else{for(let[g,b]of a)u.push(`${g}: ${N(b,e)}`);h==="void"?T.push(`fn ${o}(${u}) {`):T.push(`fn ${o}(${u}) -> ${N(h,e)} {`)}return d&&T.push(d),T.push("}"),T.join(`
|
|
21
|
-
`)},rt=(e,t,r)=>e.isWebGL?`${r} ${t};`:`@location(${e.code?.vertVaryings?.size||0}) ${t}: ${N(r,e)}`,nt=(e,t,r)=>{if(e.isWebGL)return`${r} ${t};`;let{location:o=0}=e.gl?.webgpu?.attribs.map.get(t)||{},n=N(r,e);return`@location(${o}) ${t}: ${n}`},ot=(e,t,r)=>{let o=r==="sampler2D"||r==="texture";if(e.isWebGL)return o?`uniform sampler2D ${t};`:`uniform ${r} ${t};`;if(o){let{group:p=1,binding:a=0}=e.gl?.webgpu?.textures.map.get(t)||{};return`@group(${p}) @binding(${a}) var ${t}Sampler: sampler;
|
|
22
|
-
@group(${p}) @binding(${a+1}) var ${t}: texture_2d<f32>;`}let{group:n=0,binding:s=0}=e.gl?.webgpu?.uniforms.map.get(t)||{},i=N(r,e);return`@group(${n}) @binding(${s}) var<uniform> ${t}: ${i};`},st=(e,t,r)=>{if(e.isWebGL){let i=`uniform sampler2D ${t};`;if(e.label!=="compute")return i;let p=e.units?.(t);return`${i}
|
|
23
|
-
layout(location = ${p}) out vec4 _${t};`}let{group:o=0,binding:n=0}=e.gl?.webgpu?.storages.map.get(t)||{},s=N(r,e);return`@group(${o}) @binding(${n}) var<storage, read_write> ${t}: array<${s}>;`},it=(e,t,r,o)=>e.isWebGL?`const ${r} ${t} = ${o};`:`const ${t}: ${N(r,e)} = ${o};`;var f=(e,t)=>{if(t||(t={}),Ve(t),x.arr(e))return w(e,t);if(x.str(e))return e;if(x.num(e)){let l=`${e}`;return l.includes(".")?l:l+".0"}if(x.bol(e))return e?"true":"false";if(!e)return"";let{type:r,props:o={}}=e,{id:n="i",children:s=[],fields:i,initialValues:p}=o,[a,u,d,h]=s;if(r==="variable")return n;if(r==="member")return`${f(a,t)}.${f(u,t)}`;if(r==="element")return`${f(a,t)}[${f(u,t)}]`;if(r==="gather")return t.isWebGL?Ye(t,a,u,e):`${f(a,t)}[${f(u,t)}]`;if(r==="scatter"){let[l,g]=a.props.children??[];return t.isWebGL?He(t,l,u):`${f(l,t)}[${f(g,t)}] = ${f(u,t)};`}if(r==="ternary")return t.isWebGL?`(${f(d,t)} ? ${f(a,t)} : ${f(u,t)})`:`select(${f(a,t)}, ${f(u,t)}, ${f(d,t)})`;if(r==="conversion")return`${N(a,t)}(${w(s.slice(1),t)})`;if(r==="operator")return a==="not"||a==="bitNot"?`!${f(u,t)}`:`(${f(u,t)} ${We(a)} ${f(d,t)})`;if(r==="function")return a==="negate"?`(-${f(u,t)})`:a==="oneMinus"?`(1.0-${f(u,t)})`:a==="texture"?je(t,u,d,h):a==="atan2"&&t.isWebGL?`atan(${f(u,t)}, ${f(d,t)})`:`${a}(${w(s.slice(1),t)})`;if(r==="scope")return s.map(l=>f(l,t)).join(`
|
|
24
|
-
`);if(r==="assign")return`${f(a,t)} = ${f(u,t)};`;if(r==="return")return`return ${f(a,t)};`;if(r==="loop")return t.isWebGL?`for (int ${n} = 0; ${n} < ${f(a,t)}; ${n} += 1) {
|
|
25
|
-
${f(u,t)}
|
|
26
|
-
}`:`for (var ${n}: i32 = 0; ${n} < ${f(a,t)}; ${n}++) {
|
|
27
|
-
${f(u,t)}
|
|
28
|
-
}`;if(r==="if")return Ke(t,a,u,s);if(r==="switch")return Ze(t,a,s);if(r==="declare")return Qe(t,a,u);if(r==="define")return t.code?.headers.has(n)||t.code?.headers.set(n,tt(t,o,e)),`${n}(${w(s.slice(1),t)})`;if(r==="struct")return t.code?.headers.has(n)||t.code?.headers.set(n,Je(t,n,i)),et(t,n,a.props.id,p);if(r==="varying"){if(t.code?.vertOutputs.has(n))return t.isWebGL?`${n}`:`out.${n}`;let l=rt(t,n,X(e,t));return t.code?.fragInputs.set(n,l),t.code?.vertOutputs.set(n,l),t.code?.vertVaryings.set(n,f(a,t)),t.isWebGL?`${n}`:`out.${n}`}if(r==="builtin"){if(t.isWebGL)return Be(t,n);if(n==="position")return"out.position";let l=`@builtin(${n}) ${n}: ${N(X(e,t),t)}`;return t.label==="compute"?t.code?.computeInputs.set(n,l):t.label==="frag"?t.code?.fragInputs.set(n,l):t.label==="vert"&&t.code?.vertInputs.set(n,l),`in.${n}`}if(r==="attribute"){let l=de(t,n,!0);return xe(a,l),e.listeners.add(l),t.code?.vertInputs.set(n,nt(t,n,X(e,t))),t.isWebGL?`${n}`:`in.${n}`}if(t.code?.headers.has(n))return n;let T="";if(r==="uniform"){let l=X(e,t),g=de(t,n,!1,l==="texture");xe(a,g),e.listeners.add(g),T=ot(t,n,l)}return r==="storage"&&(T=st(t,n,X(e,t))),r==="constant"&&(T=it(t,n,X(e,t),f(a,t))),T?(t.code?.headers.set(n,T),n):f(a,t)};var U=null,O=null,I=e=>{if(!U||(U.props.children||(U.props.children=[]),U.props.children.push(e),e.type!=="return"||!O))return;let{props:t}=O;t.inferFrom||(t.inferFrom=[]),t.inferFrom.push(e)};function at(e,t){t||(t=C());let r=m("variable",{id:t,inferFrom:[e]}),o=m("declare",null,e,r);return I(o),r}var ut=(e,t=!1,r)=>{let o=m(t?"scatter":"assign",null,e,r);return I(o),e},Ut=e=>{let t=m("return",{inferFrom:[e]},e);return I(t),t},Nr=(e,t=C())=>(r={},o=C())=>{let n=m("variable",{id:o,inferFrom:[t]}),s=m("struct",{id:t,fields:e,initialValues:r},n);return I(s),n},A=(e,t,r=O)=>{let[o,n]=[U,O];[U,O]=[e,r];let s=t();s&&Ut(s),[U,O]=[o,n]},Sr=(e,t)=>{let r=m("scope");A(r,t);let o=m("if",null,e,r);I(o);let n=()=>({ElseIf:(s,i)=>{let p=m("scope");return A(p,i),o.props.children.push(s,p),n()},Else:s=>{let i=m("scope");A(i,s),o.props.children.push(i)}});return n()},Rr=(e,t)=>{let r=m("scope"),o=C();A(r,()=>t({i:m("variable",{id:o,inferFrom:[v("int",0)]})}));let n=m("loop",{id:o},e,r);return I(n),n},wr=e=>{let t=m("switch",null,e);I(t);let r=()=>({Case:(...o)=>n=>{let s=m("scope");A(s,n);for(let i of o)t.props.children.push(i,s);return r()},Default:o=>{let n=m("scope");A(n,o),t.props.children.push(n)}});return r()};function Fr(e,t=C()){let r,o=(...n)=>{let s=r?.name||t,i=m("scope"),p=[],a=[];if(r?.inputs)for(let d of r.inputs)a.push({id:d.name,inferFrom:[v(d.type)]});else for(let d=0;d<n.length;d++)a.push({id:`p${d}`,inferFrom:[n[d]]});for(let d of a)p.push(m("variable",d));let u=m("define",{id:s,layout:r},i,...n);return A(i,()=>e(p),u),u};return o.setLayout=n=>(r=n,o),o}var At=(e,t)=>{if(t==="string")return f(e,null)},m=(e,t,...r)=>{t||(t={}),r.length&&(t.children=r);let o=new Set,n=(p,a)=>{if(a==="type")return e;if(a==="props")return t;if(a!=="__nodeType"){if(a==="toVar")return at.bind(null,i);if(a==="isProxy")return!0;if(a==="toString")return f.bind(null,i);if(a===Symbol.toPrimitive)return At.bind(null,i);if(a==="listeners")return o;if(a==="attribute")return(u=C())=>It(i,u);if(a==="constant")return(u=C())=>Ot(i,u);if(a==="uniform")return(u=C())=>W(i,u);if(a==="variable")return(u=C())=>Mt(u);if(a==="builtin")return(u=C())=>_(u);if(a==="vertexStage")return(u=C())=>Dt(i,u);if(a==="element")return u=>e==="storage"?Bt(i,u):pt(i,u);if(a==="member")return u=>Te(i,u);if(a==="assign")return ut.bind(null,i,i.type==="gather");if(Ie(a))return(...u)=>Wt(a,i,...u);if(Oe(a))return(...u)=>c(a,i,...u);if(Me(a))return()=>v(ke(a),i);if(x.str(a))return ze(a)?pt(i,a):Te(i,a)}},s=(p,a,u)=>(a==="value"&&o.forEach(d=>d(u)),x.str(a)&&Te(i,a).assign(u),!0),i=new Proxy({},{get:n,set:s});return i},It=(e,t=C())=>m("attribute",{id:t},e),Ot=(e,t=C())=>m("constant",{id:t},e),W=(e,t=C())=>m("uniform",{id:t},e),Mr=(e,t=C())=>m("storage",{id:t},e),Mt=(e=C())=>m("variable",{id:e}),_=(e=C())=>m("builtin",{id:e}),Dt=(e,t=C())=>m("varying",{id:t,inferFrom:[e]},e),Te=(e,t)=>m("member",null,e,t),pt=(e,t)=>m("element",null,e,t),Bt=(e,t)=>m("gather",null,e,t),Dr=(e,t)=>m("scatter",null,e,t),Br=(e,t,r)=>m("ternary",null,e,t,r),Wt=(e,...t)=>m("operator",null,e,...t),c=(e,...t)=>m("function",null,e,...t),v=(e,...t)=>m("conversion",null,e,...t);var kt=`
|
|
29
|
-
#version 300 es
|
|
30
|
-
precision mediump float;
|
|
31
|
-
out vec4 fragColor;
|
|
32
|
-
`.trim(),Vt=(e,t)=>{let r=[],o=new Set,n=new Set,s=i=>{if(n.has(i)||o.has(i))return;n.add(i);let p=t.get(i)||new Set;for(let a of p)e.has(a)&&s(a);n.delete(i),o.add(i),e.has(i)&&r.push([i,e.get(i)])};for(let[i]of e)s(i);return r},ge=(e,t)=>{let r=f(e,t),o="";return t.isWebGL&&t.code?.dependencies?o=Vt(t.code.headers,t.code.dependencies).map(([,s])=>s).join(`
|
|
33
|
-
`):o=Array.from(t.code?.headers?.values()||[]).join(`
|
|
34
|
-
`),[o,r]},H=(e,t)=>`struct ${e} {
|
|
35
|
-
${Array.from(t.values()).join(`,
|
|
36
|
-
`)}
|
|
37
|
-
}`,j=(e,t)=>{if(x.str(e))return e.trim();t.code?.headers?.clear(),t.label="frag";let[r,o]=ge(e,t),n=[];if(t.isWebGL){n.push(kt);for(let i of t.code?.fragInputs?.values()||[])n.push(`in ${i}`);n.push(r),n.push(`void main() {
|
|
38
|
-
fragColor = ${o};`)}else t.code?.fragInputs?.size&&n.push(H("Out",t.code.fragInputs)),n.push(r),n.push(`@fragment
|
|
39
|
-
fn main(out: Out) -> @location(0) vec4f {`),n.push(` return ${o};`);return n.push("}"),n.filter(Boolean).join(`
|
|
40
|
-
`).trim()},K=(e,t)=>{if(x.str(e))return e.trim();t.code?.headers?.clear(),t.label="vert";let[r,o]=ge(e,t),n=[];if(t.isWebGL){n.push("#version 300 es");for(let i of t.code?.vertInputs?.values()||[])n.push(`in ${i}`);for(let i of t.code?.vertOutputs?.values()||[])n.push(`out ${i}`);n.push(r),n.push("void main() {"),n.push(` gl_Position = ${o};`);for(let[i,p]of t.code?.vertVaryings?.entries()||[])n.push(` ${i} = ${p};`)}else{t.code?.vertInputs?.size&&n.push(H("In",t.code.vertInputs)),t.code?.vertOutputs?.size&&n.push(H("Out",t.code.vertOutputs)),n.push(r),n.push("@vertex"),n.push(`fn main(${t.code?.vertInputs?.size?"in: In":""}) -> Out {`),n.push(" var out: Out;"),n.push(` out.position = ${o};`);for(let[i,p]of t.code?.vertVaryings?.entries()||[])n.push(` out.${i} = ${p};`);n.push(" return out;")}return n.push("}"),n.filter(Boolean).join(`
|
|
41
|
-
`).trim()},Z=(e,t)=>{if(x.str(e))return e.trim();t.code?.headers?.clear(),t.label="compute";let[r,o]=ge(e,t),n=[];return t.isWebGL?(n.push("#version 300 es"),n.push("precision mediump float;"),n.push(r),n.push("void main() {"),n.push(` ${o};`),n.push("}")):(t.code?.computeInputs?.size&&n.push(H("In",t.code.computeInputs)),n.push(r),n.push("@compute @workgroup_size(32)"),n.push(`fn main(${t.code?.computeInputs?.size?"in: In":""}) {`),n.push(` ${o};`),n.push("}")),n.filter(Boolean).join(`
|
|
42
|
-
`).trim()};var be=_("position"),ve=_("vertex_index"),jr=_("instance_index"),Kr=_("front_facing"),Zr=_("frag_depth"),Qr=_("sample_index"),Jr=_("sample_mask"),en=_("point_coord"),tn=_("global_invocation_id"),rn=_("position"),nn=_("positionWorld"),on=_("positionView"),sn=_("normalLocal"),an=_("normalWorld"),un=_("normalView"),pn=_("screenCoordinate"),fn=_("screenUV"),Q=e=>v("float",e),k=e=>v("int",e),cn=e=>v("uint",e),ln=e=>v("bool",e),ct=(e,t)=>v("vec2",e,t),ft=(e,t,r)=>v("vec3",e,t,r),he=(e,t,r,o)=>v("vec4",e,t,r,o),dn=(...e)=>v("mat2",...e),xn=(...e)=>v("mat3",...e),mn=(...e)=>v("mat4",...e),Tn=(e,t)=>v("ivec2",e,t),gn=(e,t,r)=>v("ivec3",e,t,r),bn=(e,t,r,o)=>v("ivec4",e,t,r,o),vn=(e,t)=>v("uvec2",e,t),hn=(e,t,r)=>v("uvec3",e,t,r),yn=(e,t,r,o)=>v("uvec4",e,t,r,o),En=(e,t)=>v("bvec2",e,t),Xn=(e,t,r)=>v("bvec3",e,t,r),Cn=(e,t,r,o)=>v("bvec4",e,t,r,o),_n=e=>v("texture",e),Pn=()=>v("sampler2D"),$n=(e,t,r)=>x.num(e)&&x.und(t)&&x.und(r)?ft(...De(e)):ft(e,t,r),ye=W(ct(),"iResolution"),Gn=W(ct(),"iMouse"),Ln=W(Q(),"iTime"),Nn=be.xy.div(ye),Sn=e=>c("all",e),Rn=e=>c("any",e),wn=e=>c("length",e),Fn=e=>c("lengthSq",e),Un=(e,t)=>c("distance",e,t),An=(e,t)=>c("dot",e,t),In=(e,t)=>c("cross",e,t),On=(e,t,r)=>c("cubeTexture",e,t,r),Mn=(e,t,r)=>c("texture",e,t,r),Dn=(e,t,r)=>c("texelFetch",e,t,r),Bn=(e,t,r)=>c("textureLod",e,t,r),Wn=e=>c("abs",e),kn=e=>c("acos",e),Vn=e=>c("acosh",e),zn=e=>c("asin",e),qn=e=>c("asinh",e),Yn=e=>c("atan",e),Hn=e=>c("atanh",e),jn=e=>c("ceil",e),Kn=e=>c("cos",e),Zn=e=>c("cosh",e),Qn=e=>c("dFdx",e),Jn=e=>c("dFdy",e),eo=e=>c("degrees",e),to=e=>c("exp",e),ro=e=>c("exp2",e),no=e=>c("floor",e),lt=e=>c("fract",e),oo=e=>c("fwidth",e),so=e=>c("inverseSqrt",e),io=e=>c("log",e),ao=e=>c("log2",e),uo=e=>c("negate",e),po=e=>c("normalize",e),fo=e=>c("oneMinus",e),co=e=>c("radians",e),lo=e=>c("reciprocal",e),xo=e=>c("round",e),mo=e=>c("saturate",e),To=e=>c("sign",e),go=e=>c("sin",e),bo=e=>c("sinh",e),vo=e=>c("sqrt",e),ho=e=>c("tan",e),yo=e=>c("tanh",e),Eo=e=>c("trunc",e),Xo=(e,t)=>c("atan2",e,t),Co=(e,t,r)=>c("clamp",e,t,r),_o=(e,t)=>c("max",e,t),Po=(e,t)=>c("min",e,t),$o=(e,t,r)=>c("mix",e,t,r),Go=(e,t)=>c("pow",e,t),Lo=(e,t)=>c("reflect",e,t),No=(e,t,r)=>c("refract",e,t,r),So=(e,t,r)=>c("smoothstep",e,t,r),Ro=(e,t)=>c("step",e,t),wo=(e,t)=>e.sub(e.div(t).toFloat().floor().mul(t));var zt=`
|
|
43
|
-
#version 300 es
|
|
44
|
-
void main() {
|
|
45
|
-
float x = float(gl_VertexID % 2) * 4.0 - 1.0;
|
|
46
|
-
float y = float(gl_VertexID / 2) * 4.0 - 1.0;
|
|
47
|
-
gl_Position = vec4(x, y, 0.0, 1.0);
|
|
48
|
-
}`.trim(),qt=(e,t)=>{if(!e.cs)return null;t.getExtension("EXT_color_buffer_float");let r=0,o=0,n=M(()=>r++),s={isWebGL:!0,gl:e,units:n},i=oe(t,Z(e.cs,s),zt,e),p=Math.ceil(Math.sqrt(e.particles)),a=M(g=>t.getUniformLocation(i,g)),u=M(g=>{let b=new Float32Array(p*p*4),P={texture:t.createTexture(),buffer:t.createFramebuffer()},S={texture:t.createTexture(),buffer:t.createFramebuffer()};return{ping:P,pong:S,array:b,loc:a(g),unit:n(g)}});return{render:()=>{t.useProgram(i);let g=u.map.values().map(({ping:b,pong:P,loc:S,unit:F},D)=>{let[V,re]=o%2?[b,P]:[P,b];return Le(t,V,re,S,F,D)});t.drawBuffers(g),t.drawArrays(t.TRIANGLES,0,3),t.bindFramebuffer(t.FRAMEBUFFER,null),o++},clean:()=>{t.deleteProgram(i),Ge(t,u.map.values())},_uniform:(g,b)=>{t.useProgram(i),se(t,a(g),b)},_storage:(g,b)=>{let{ping:P,pong:S,unit:F,array:D}=u(g);$e(t,b,p,P,S,F,D)},storages:u}},dt=async e=>{let t={isWebGL:!0,gl:e},r=e.el.getContext("webgl2"),o=qt(e,r),n=oe(r,j(e.fs,t),K(e.vs,t),e);r.useProgram(n);let s=0,i=M(()=>s++),p=M(b=>r.getAttribLocation(n,b)),a=M(b=>r.getUniformLocation(n,b)),u=(b="",P,S)=>{let F=p(b,!0);_e(r,F,e.count,P,S)},d=(b,P)=>{r.useProgram(n),se(r,a(b),P),o?._uniform(b,P)},h=(b,P)=>{r.useProgram(n),z(e,P,S=>{Pe(r,S,a(b),i(b))})},T=()=>{o?.clean(),r.deleteProgram(n),r.getExtension("WEBGL_lose_context")?.loseContext()},l=()=>{o?.render(),r.useProgram(n),r.viewport(0,0,...e.size),r.drawArrays(r.TRIANGLES,0,e.count),r.bindFramebuffer(r.FRAMEBUFFER,null)};return{webgl:{context:r,program:n,storages:o?.storages},render:l,clean:T,_attribute:u,_uniform:d,_texture:h,_storage:o?._storage}};import{nested as ee}from"reev";var xt=async(e,t=console.log)=>{let r=navigator.gpu,o=r.getPreferredCanvasFormat(),s=await(await r.requestAdapter()).requestDevice();return s.onuncapturederror=i=>t(i.error.message),e.configure({device:s,format:o,alphaMode:"opaque"}),{device:s,format:o}},mt=()=>{let e=0,t=0,r=0,o=0;return{uniform:()=>{let n=Math.floor(e/12),s=e%12;return e++,{group:n,binding:s}},texture:()=>{let s=Math.floor(e/12)+1+Math.floor(t/6),i=t%6*2;return t++,{group:s,binding:i}},storage:()=>{let s=Math.floor(e/12)+Math.floor(t/6)+2+Math.floor(r/12),i=r%12;return r++,{group:s,binding:i}},attrib:()=>{let n=o;return o++,{location:n}}}},Yt=e=>e===2?"float32x2":e===3?"float32x3":e===4?"float32x4":"float32",Tt=e=>{let t=[],r=[];for(let{buffer:o,location:n,stride:s}of e)t[n]=o,r[n]={arrayStride:s*4,attributes:[{shaderLocation:n,offset:0,format:Yt(s)}]};return{vertexBuffers:t,bufferLayouts:r}},gt=(e,t,r,o=[])=>{let n=new Map,s={bindGroups:[],bindGroupLayouts:[]},i=(p,a,u)=>{n.has(p)||n.set(p,{layouts:[],bindings:[]});let{layouts:d,bindings:h}=n.get(p);d.push(a),h.push(u)};for(let{binding:p,buffer:a,group:u}of t)i(u,{binding:p,visibility:7,buffer:{type:"uniform"}},{binding:p,resource:{buffer:a}});for(let{binding:p,buffer:a,group:u}of o)i(u,{binding:p,visibility:6,buffer:{type:"storage"}},{binding:p,resource:{buffer:a}});for(let{binding:p,group:a,sampler:u,view:d}of r)i(a,{binding:p,visibility:2,sampler:{}},{binding:p,resource:u}),i(a,{binding:p+1,visibility:2,texture:{}},{binding:p+1,resource:d});for(let[p,{layouts:a,bindings:u}]of n)s.bindGroupLayouts[p]=e.createBindGroupLayout({entries:a}),s.bindGroups[p]=e.createBindGroup({layout:s.bindGroupLayouts[p],entries:u});return s},bt=(e,t,r,o,n,s)=>e.createRenderPipeline({vertex:{module:e.createShaderModule({label:"vert",code:n}),entryPoint:"main",buffers:r},fragment:{module:e.createShaderModule({label:"frag",code:s}),entryPoint:"main",targets:[{format:t}]},layout:e.createPipelineLayout({bindGroupLayouts:o}),primitive:{topology:"triangle-list"},depthStencil:{depthWriteEnabled:!0,depthCompare:"less",format:"depth24plus"}}),vt=(e,t,r)=>e.createComputePipeline({compute:{module:e.createShaderModule({label:"compute",code:r}),entryPoint:"main"},layout:e.createPipelineLayout({bindGroupLayouts:t})}),Ht=e=>e==="uniform"?72:e==="attrib"?40:140,J=(e,t,r)=>{Xe(t)||(t=new Float32Array(t));let o=Ht(r),n=r==="uniform"?Math.ceil(t.byteLength/256)*256:t.byteLength,s=e.createBuffer({size:n,usage:o});return{array:t,buffer:s}},ht=(e,t)=>({colorAttachments:[{view:e.getCurrentTexture().createView(),clearValue:{r:0,g:0,b:0,a:1},loadOp:"clear",storeOp:"store"}],depthStencilAttachment:{view:t.createView(),depthClearValue:1,depthLoadOp:"clear",depthStoreOp:"store"}}),yt=(e,t=1280,r=800)=>{let o=e.createTexture({size:[t,r],format:"rgba8unorm",usage:22}),n=e.createSampler({magFilter:"linear",minFilter:"linear"});return{texture:o,sampler:n}},Et=(e,t,r)=>e.createTexture({size:[t,r],format:"depth24plus",usage:GPUTextureUsage.RENDER_ATTACHMENT});var jt=32,Kt=(e,t,r)=>{let o=u=>{},n=ee((u,d)=>{let{array:h,buffer:T}=J(t,d,"storage"),{binding:l,group:g}=r.storage();return{array:h,buffer:T,binding:l,group:g}});return{storages:n,_storage:(u,d)=>{let{array:h,buffer:T}=n(u,d);t.queue.writeBuffer(T,0,h)},update:(u,d,h)=>{let T=vt(t,d,h);o=l=>{l.setPipeline(T),u.forEach((b,P)=>l.setBindGroup(P,b));let g=Math.ceil(e.particles/jt);l.dispatchWorkgroups(g,1,1),l.end()}},render:u=>{o(u)},clean:()=>{for(let{buffer:u}of n.map.values())u.destroy()}}},Xt=async e=>{let t=e.el.getContext("webgpu"),{device:r,format:o}=await xt(t,e.error),n=mt(),s=Kt(e,r,n),i,p,a,u=y=>{},d=!0,h,T=ee((y,E)=>{d=!0;let $=E.length/e.count,{location:G}=n.attrib(),{array:R,buffer:L}=J(r,E,"attrib");return{array:R,buffer:L,location:G,stride:$}}),l=ee((y,E)=>{d=!0;let{binding:$,group:G}=n.uniform(),{array:R,buffer:L}=J(r,E,"uniform");return{array:R,buffer:L,binding:$,group:G}}),g=ee((y,E=0,$=0)=>{d=!0;let{binding:G,group:R}=n.texture(),{texture:L,sampler:B}=yt(r,E,$);return{texture:L,sampler:B,binding:G,group:R,view:L.createView()}}),b=(y="",E)=>{let{array:$,buffer:G}=T(y,E);r.queue.writeBuffer(G,0,$)},P=(y,E)=>{x.num(E)&&(E=[E]);let{array:$,buffer:G}=l(y,E);$.set(E),r.queue.writeBuffer(G,0,$)},S=(y,E)=>{z(e,E,$=>{let{width:G,height:R}=$,{texture:L}=g(y,G,R);r.queue.copyExternalImageToTexture({source:$},{texture:L},{width:G,height:R})})},F=()=>{let{vertexBuffers:y,bufferLayouts:E}=Tt(T.map.values()),{bindGroups:$,bindGroupLayouts:G}=gt(r,l.map.values(),g.map.values(),s.storages.map.values()),R=bt(r,o,E,G,a,i);u=L=>{L.setPipeline(R),$.forEach((B,ne)=>L.setBindGroup(ne,B)),y.forEach((B,ne)=>L.setVertexBuffer(ne,B)),L.draw(e.count,1,0,0),L.end()},e.cs&&s.update($,G,p)},D=()=>{if(!i||!a){let E={isWebGL:!1,gl:e};i=j(e.fs,E),a=K(e.vs,E),p=Z(e.cs,E)}if(e.loading)return;d&&F(),d=!1;let y=r.createCommandEncoder();e.cs&&s.render(y.beginComputePass()),u(y.beginRenderPass(ht(t,h))),r.queue.submit([y.finish()])},V=()=>{let y=e.el;h?.destroy(),h=Et(r,y.width,y.height)},re=()=>{r.destroy(),h?.destroy();for(let{texture:y}of g.map.values())y.destroy();for(let{buffer:y}of l.map.values())y.destroy();for(let{buffer:y}of T.map.values())y.destroy();s.clean()};return V(),{webgpu:{device:r,uniforms:l,textures:g,attribs:T,storages:s.storages},render:D,resize:V,clean:re,_attribute:b,_uniform:P,_texture:S,_storage:s._storage}};var Ct=e=>x.obj(e)?"isGL"in e:!1,er=()=>typeof window>"u",tr=()=>er()?!1:"gpu"in navigator,Ee=performance.now(),rr=()=>he(lt(be.xy.div(ye)),0,1),nr=()=>he(Q(k(ve).mod(k(2))).mul(4).sub(1),Q(k(ve).div(k(2))).mul(4).sub(1),0,1),_t=e=>{let t=Zt({isNative:!1,isWebGL:!0,isError:!1,isLoop:!0,isGL:!0,size:[0,0],mouse:[0,0],count:6,particles:1024,webgl:{},webgpu:{},loading:0,error(){t.isError=!0,t.isLoop=!1,t.clean(),console.warn("GLRE Error:",...arguments)}});return t.queue=Jt(),t.frame=Qt(),t.attribute=te((r,o,n)=>t.queue(()=>t._attribute?.(r,o,n)),t),t.storage=te((r,o)=>t.queue(()=>t._storage?.(r,o)),t),t.uniform=te((r,o)=>t.queue(()=>t._uniform?.(r,o)),t),t.texture=te((r,o)=>t.queue(()=>t._texture?.(r,o)),t),t.uniform({iResolution:t.size,iMouse:[0,0],iTime:Ee}),t("mount",async()=>{t.vs=t.vs||t.vert||t.vertex||nr(),t.fs=t.fs||t.frag||t.fragment||rr(),t.cs=t.cs||t.comp||t.compute,tr()||(t.isWebGL=!0),t.isWebGL?t(await dt(t)):t(await Xt(t)),!t.isError&&(t.resize(),t.frame(()=>(t.loop(),t.queue.flush(),t.loading?!0:(t.render(),t.isLoop))),!t.isNative&&(window.addEventListener("resize",t.resize),t.el.addEventListener("mousemove",t.mousemove)))}),t("clean",()=>{t.frame.stop(),!t.isNative&&(window.removeEventListener("resize",t.resize),t.el.removeEventListener("mousemove",t.mousemove))}),t("resize",()=>{let r=t.width||window.innerWidth,o=t.height||window.innerHeight;t.size[0]=t.el.width=r,t.size[1]=t.el.height=o,t.uniform("iResolution",t.size)}),t("mousemove",(r,o=r.clientX,n=r.clientY)=>{let[s,i]=t.size,{top:p,left:a}=t.el.getBoundingClientRect();t.mouse[0]=(o-p-s/2)/(s/2),t.mouse[1]=-(n-a-i/2)/(i/2),t.uniform("iMouse",t.mouse)}),t("loop",()=>{Ee=performance.now()/1e3,t.uniform("iTime",Ee)}),t(e)};var fs=(e={})=>or(()=>{let t=Ct(e)?e:_t(e);return t.ref=r=>{r?(t.el=r,t.mount()):t.clean()},t})[0];export{Fr as Fn,Sr as If,Rr as Loop,Ut as Return,wr as Switch,Wn as abs,kn as acos,Vn as acosh,Sn as all,Rn as any,zn as asin,qn as asinh,ut as assign,Yn as atan,Xo as atan2,Hn as atanh,It as attribute,ln as bool,_ as builtin,En as bvec2,Xn as bvec3,Cn as bvec4,jn as ceil,Co as clamp,$n as color,Z as compute,Ot as constant,v as conversion,Kn as cos,Zn as cosh,_t as createGL,In as cross,On as cubeTexture,Qn as dFdx,Jn as dFdy,eo as degrees,Un as distance,An as dot,pt as element,to as exp,ro as exp2,Q as float,no as floor,lt as fract,Zr as fragDepth,j as fragment,Kr as frontFacing,c as function_,oo as fwidth,Bt as gather,Gn as iMouse,ye as iResolution,Ln as iTime,tn as id,jr as instanceIndex,k as int,so as inverseSqrt,Ct as isGL,er as isServer,tr as isWebGPUSupported,Tn as ivec2,gn as ivec3,bn as ivec4,wn as length,Fn as lengthSq,io as log,ao as log2,dn as mat2,xn as mat3,mn as mat4,_o as max,Te as member,Po as min,$o as mix,wo as mod,uo as negate,m as node,sn as normalLocal,un as normalView,an as normalWorld,po as normalize,fo as oneMinus,Wt as operator,en as pointCoord,be as position,rn as positionLocal,on as positionView,nn as positionWorld,Go as pow,co as radians,lo as reciprocal,Lo as reflect,No as refract,xo as round,Qr as sampleIndex,Jr as sampleMask,Pn as sampler2D,mo as saturate,Dr as scatter,pn as screenCoordinate,fn as screenUV,Br as select,To as sign,go as sin,bo as sinh,So as smoothstep,vo as sqrt,Ro as step,Mr as storage,Nr as struct,ho as tan,yo as tanh,Dn as texelFetch,Mn as texture,_n as texture2D,Bn as textureLod,at as toVar,Eo as trunc,cn as uint,W as uniform,fs as useGL,Nn as uv,vn as uvec2,hn as uvec3,yn as uvec4,Mt as variable,ct as vec2,ft as vec3,he as vec4,K as vertex,ve as vertexIndex,Dt as vertexStage,dt as webgl,Xt as webgpu};
|
|
1
|
+
import{useState as o}from"react";import{createGL as m,isGL as n}from"./index.js";export*from"./index.js";var f=(t={})=>o(()=>{let e=n(t)?t:m(t);return e.ref=r=>{r?(e.el=r,e.mount()):e.clean()},e})[0];export{f as useGL};
|
|
49
2
|
//# sourceMappingURL=react.js.map
|