From 3981a52286ad97c1b3241d69fd302bf3193fefc8 Mon Sep 17 00:00:00 2001 From: "junwei.gu" Date: Wed, 12 Jul 2023 19:23:35 +0800 Subject: [PATCH] demo(examples): update native example --- README.md | 15 +- dist/index.js | 25498 +++++++++++++++++------------- example/mesh/instance.html | 7 +- example/mesh/skybox.html | 2 +- example/native/cube1.html | 8 +- example/native/model.html | 10 +- example/native/particles.html | 95 +- example/native/textureCube.html | 8 +- package.json | 2 +- 9 files changed, 14908 insertions(+), 10737 deletions(-) diff --git a/README.md b/README.md index 7ce42df..ef997e7 100644 --- a/README.md +++ b/README.md @@ -4,15 +4,16 @@ ## install -- `npm install` +- `npm i @gengine-js/gengine` ## build -- `npm run dev` +- `npm install` + +- `npm run build` ## Usage - ``` - ``` ## Native @@ -188,12 +188,6 @@ init(); - - -``` - ## feature - [✔] Camera @@ -230,4 +224,3 @@ 2. Complete core glTF 2.0 3. Text and Sprite 4. Pick -``` diff --git a/dist/index.js b/dist/index.js index ea0d832..e485fb7 100644 --- a/dist/index.js +++ b/dist/index.js @@ -1,796 +1,1080 @@ -var e, - t, - i, - r, - n, - s, - a, - o, - c, - l, - h, - u, - f, - d, - m, - p, - g, - x, - v, - y, - S, - b, - w, - T, - E, - M, - U, - _, - L, - C, - R, - A, - D, - z, - I, - P, - N, - B, - O, - V, - F; -!(function (e) { - e.SRGB = "srgb"; -})(e || (e = {})), - (function (e) { - (e.LowPower = "low-power"), (e.HighPerformance = "high-performance"); - })(t || (t = {})), - (function (e) { - (e.DepthClipControl = "depth-clip-control"), - (e.Depth24UnormStencil8 = "depth24unorm-stencil8"), - (e.Depth32FloatStencil8 = "depth32float-stencil8"), - (e.TextureCompressionBC = "texture-compression-bc"), - (e.TextureCompressionETC2 = "texture-compression-etc2"), - (e.TextureCompressionASTC = "texture-compression-astc"), - (e.TimestampQuery = "timestamp-query"), - (e.IndirectFirstInstance = "indirect-first-instance"), - (e.ShaderF16 = "shader-f16"), - (e.BGRA8UnormStorage = "bgra8unorm-storage"); - })(i || (i = {})), - (function (e) { - (e[(e.MapRead = 1)] = "MapRead"), - (e[(e.MapWrite = 2)] = "MapWrite"), - (e[(e.CopySrc = 4)] = "CopySrc"), - (e[(e.CopyDst = 8)] = "CopyDst"), - (e[(e.Index = 16)] = "Index"), - (e[(e.Vertex = 32)] = "Vertex"), - (e[(e.Uniform = 64)] = "Uniform"), - (e[(e.Storage = 128)] = "Storage"), - (e[(e.Indirect = 256)] = "Indirect"), - (e[(e.QueryResolve = 512)] = "QueryResolve"); - })(r || (r = {})), - (function (e) { - (e[(e.Read = 1)] = "Read"), (e[(e.Write = 2)] = "Write"); - })(n || (n = {})), - (function (e) { - (e.E1d = "1d"), (e.E2d = "2d"), (e.E3d = "3d"); - })(s || (s = {})), - (function (e) { - (e[(e.CopySrc = 1)] = "CopySrc"), - (e[(e.CopyDst = 2)] = "CopyDst"), - (e[(e.TextureBinding = 4)] = "TextureBinding"), - (e[(e.StorageBinding = 8)] = "StorageBinding"), - (e[(e.RenderAttachment = 16)] = "RenderAttachment"); - })(a || (a = {})), - (function (e) { - (e.E1d = "1d"), - (e.E2d = "2d"), - (e.E2dArray = "2d-array"), - (e.Cube = "cube"), - (e.CubeArray = "cube-array"), - (e.E3d = "3d"); - })(o || (o = {})), - (function (e) { - (e.All = "all"), (e.StencilOnly = "stencil-only"), (e.DepthOnly = "depth-only"); - })(c || (c = {})), - (function (e) { - (e.R8Unorm = "r8unorm"), - (e.R8Snorm = "r8snorm"), - (e.R8Uint = "r8uint"), - (e.R8Sint = "r8sint"), - (e.R16Uint = "r16uint"), - (e.R16Sint = "r16sint"), - (e.R16Float = "r16float"), - (e.RG8Unorm = "rg8unorm"), - (e.RG8Snorm = "rg8snorm"), - (e.RG8Uint = "rg8uint"), - (e.RG8Sint = "rg8sint"), - (e.R32Uint = "r32uint"), - (e.R32Sint = "r32sint"), - (e.R32Float = "r32float"), - (e.RG16Uint = "rg16uint"), - (e.RG16Sint = "rg16sint"), - (e.RG16Float = "rg16float"), - (e.RGBA8Unorm = "rgba8unorm"), - (e.RGBA8UnormSRGB = "rgba8unorm-srgb"), - (e.RGBA8Snorm = "rgba8snorm"), - (e.RGBA8Uint = "rgba8uint"), - (e.RGBA8Sint = "rgba8sint"), - (e.BGRA8Unorm = "bgra8unorm"), - (e.BGRA8UnormSRGB = "bgra8unorm-srgb"), - (e.RGB9E5UFloat = "rgb9e5ufloat"), - (e.RGB10A2Unorm = "rgb10a2unorm"), - (e.RG11B10UFloat = "rg11b10ufloat"), - (e.RG32Uint = "rg32uint"), - (e.RG32Sint = "rg32sint"), - (e.RG32Float = "rg32float"), - (e.RGBA16Uint = "rgba16uint"), - (e.RGBA16Sint = "rgba16sint"), - (e.RGBA16Float = "rgba16float"), - (e.RGBA32Uint = "rgba32uint"), - (e.RGBA32Sint = "rgba32sint"), - (e.RGBA32Float = "rgba32float"), - (e.Stencil8 = "stencil8"), - (e.Depth16Unorm = "depth16unorm"), - (e.Depth24Plus = "depth24plus"), - (e.Depth24PlusStencil8 = "depth24plus-stencil8"), - (e.Depth32Float = "depth32float"), - (e.BC1RGBAUnorm = "bc1-rgba-unorm"), - (e.BC1RGBAUnormSRGB = "bc1-rgba-unorm-srgb"), - (e.BC2RGBAUnorm = "bc2-rgba-unorm"), - (e.BC2RGBAUnormSRGB = "bc2-rgba-unorm-srgb"), - (e.BC3RGBAUnorm = "bc3-rgba-unorm"), - (e.BC3RGBAUnormSRGB = "bc3-rgba-unorm-srgb"), - (e.BC4RUnorm = "bc4-r-unorm"), - (e.BC4RSnorm = "bc4-r-snorm"), - (e.BC5RGUnorm = "bc5-rg-unorm"), - (e.BC5RGSnorm = "bc5-rg-snorm"), - (e.BC6HRGBUFloat = "bc6h-rgb-ufloat"), - (e.BC6HRGBFloat = "bc6h-rgb-float"), - (e.BC7RGBAUnorm = "bc7-rgba-unorm"), - (e.BC7RGBAUnormSRGB = "bc7-rgba-unorm-srgb"), - (e.ETC2RGB8Unorm = "etc2-rgb8unorm"), - (e.ETC2RGB8UnormSRGB = "etc2-rgb8unorm-srgb"), - (e.ETC2RGB8A1Unorm = "etc2-rgb8a1unorm"), - (e.ETC2RGB8A1UnormSRGB = "etc2-rgb8a1unorm-srgb"), - (e.ETC2RGBA8Unorm = "etc2-rgba8unorm"), - (e.ETC2RGBA8UnormSRGB = "etc2-rgba8unorm-srgb"), - (e.EACR11Unorm = "eac-r11unorm"), - (e.EACR11Snorm = "eac-r11snorm"), - (e.EACRG11Unorm = "eac-rg11unorm"), - (e.EACRG11Snorm = "eac-rg11snorm"), - (e.ASTC4x4Unorm = "astc-4x4-unorm"), - (e.ASTC4x4UnormSRGB = "astc-4x4-unorm-srgb"), - (e.ASTC5x4Unorm = "astc-5x4-unorm"), - (e.ASTC5x4UnormSRGB = "astc-5x4-unorm-srgb"), - (e.ASTC5x5Unorm = "astc-5x5-unorm"), - (e.ASTC5x5UnormSRGB = "astc-5x5-unorm-srgb"), - (e.ASTC6x5Unorm = "astc-6x5-unorm"), - (e.ASTC6x5UnormSRGB = "astc-6x5-unorm-srgb"), - (e.ASTC6x6Unorm = "astc-6x6-unorm"), - (e.ASTC6x6UnormSRGB = "astc-6x6-unorm-srgb"), - (e.ASTC8x5Unorm = "astc-8x5-unorm"), - (e.ASTC8x5UnormSRGB = "astc-8x5-unorm-srgb"), - (e.ASTC8x6Unorm = "astc-8x6-unorm"), - (e.ASTC8x6UnormSRGB = "astc-8x6-unorm-srgb"), - (e.ASTC8x8Unorm = "astc-8x8-unorm"), - (e.ASTC8x8UnormSRGB = "astc-8x8-unorm-srgb"), - (e.ASTC10x5Unorm = "astc-10x5-unorm"), - (e.ASTC10x5UnormSRGB = "astc-10x5-unorm-srgb"), - (e.ASTC10x6Unorm = "astc-10x6-unorm"), - (e.ASTC10x6UnormSRGB = "astc-10x6-unorm-srgb"), - (e.ASTC10x8Unorm = "astc-10x8-unorm"), - (e.ASTC10x8UnormSRGB = "astc-10x8-unorm-srgb"), - (e.ASTC10x10Unorm = "astc-10x10-unorm"), - (e.ASTC10x10UnormSRGB = "astc-10x10-unorm-srgb"), - (e.ASTC12x10Unorm = "astc-12x10-unorm"), - (e.ASTC12x10UnormSRGB = "astc-12x10-unorm-srgb"), - (e.ASTC12x12Unorm = "astc-12x12-unorm"), - (e.ASTC12x12UnormSRGB = "astc-12x12-unorm-srgb"), - (e.Depth24UnormStencil8 = "depth24unorm-stencil8"), - (e.Depth32FloatStencil8 = "depth32float-stencil8"); - })(l || (l = {})), - (function (e) { - (e.ClampToEdge = "clamp-to-edge"), (e.Repeat = "repeat"), (e.MirrorRepeat = "mirror-repeat"); - })(h || (h = {})), - (function (e) { - (e.Nearest = "nearest"), (e.Linear = "linear"); - })(u || (u = {})), - (function (e) { - (e.Never = "never"), - (e.Less = "less"), - (e.Equal = "equal"), - (e.LessEqual = "less-equal"), - (e.Greater = "greater"), - (e.NotEqual = "not-equal"), - (e.GreaterEqual = "greater-equal"), - (e.Always = "always"); - })(f || (f = {})), - (function (e) { - (e[(e.Vertex = 1)] = "Vertex"), (e[(e.Fragment = 2)] = "Fragment"), (e[(e.Compute = 4)] = "Compute"); - })(d || (d = {})), - (function (e) { - (e.Uniform = "uniform"), (e.Storage = "storage"), (e.ReadOnlyStorage = "read-only-storage"); - })(m || (m = {})), - (function (e) { - (e.Filtering = "filtering"), (e.NonFiltering = "non-filtering"), (e.Comparison = "comparison"); - })(p || (p = {})), - (function (e) { - (e.Float = "float"), - (e.UnfilterableFloat = "unfilterable-float"), - (e.Depth = "depth"), - (e.Sint = "sint"), - (e.Uint = "uint"); - })(g || (g = {})), - (function (e) { - e.WriteOnly = "write-only"; - })(x || (x = {})), - (function (e) { - (e.Error = "error"), (e.Warning = "warning"), (e.Info = "info"); - })(v || (v = {})), - (function (e) { - e.Auto = "auto"; - })(y || (y = {})), - (function (e) { - (e.PointList = "point-list"), - (e.LineList = "line-list"), - (e.LineStrip = "line-strip"), - (e.TriangleList = "triangle-list"), - (e.TriangleStrip = "triangle-strip"); - })(S || (S = {})), - (function (e) { - (e.CCW = "ccw"), (e.CW = "cw"); - })(b || (b = {})), - (function (e) { - (e.None = "none"), (e.Front = "front"), (e.Back = "back"); - })(w || (w = {})), - (function (e) { - (e[(e.Red = 1)] = "Red"), - (e[(e.Green = 2)] = "Green"), - (e[(e.Blue = 4)] = "Blue"), - (e[(e.Alpha = 8)] = "Alpha"), - (e[(e.All = 15)] = "All"); - })(T || (T = {})), - (function (e) { - (e.Zero = "zero"), - (e.One = "one"), - (e.Src = "src"), - (e.OneMinusSrc = "one-minus-src"), - (e.SrcAlpha = "src-alpha"), - (e.OneMinusSrcAlpha = "one-minus-src-alpha"), - (e.Dst = "dst"), - (e.OneMinusDst = "one-minus-dst"), - (e.DstAlpha = "dst-alpha"), - (e.OneMinusDstAlpha = "one-minus-dst-alpha"), - (e.SrcAlphaSaturated = "src-alpha-saturated"), - (e.Constant = "constant"), - (e.OneMinusConstant = "one-minus-constant"); - })(E || (E = {})), - (function (e) { - (e.Add = "add"), - (e.Subtract = "subtract"), - (e.ReverseSubtract = "reverse-subtract"), - (e.Min = "min"), - (e.Max = "max"); - })(M || (M = {})), - (function (e) { - (e.Keep = "keep"), - (e.Zero = "zero"), - (e.Replace = "replace"), - (e.Invert = "invert"), - (e.IncrementClamp = "increment-clamp"), - (e.DecrementClamp = "decrement-clamp"), - (e.IncrementWrap = "increment-wrap"), - (e.DecrementWrap = "decrement-wrap"); - })(U || (U = {})), - (function (e) { - (e.Uint16 = "uint16"), (e.Uint32 = "uint32"); - })(_ || (_ = {})), - (function (e) { - (e.Uint8x2 = "uint8x2"), - (e.Uint8x4 = "uint8x4"), - (e.Sint8x2 = "sint8x2"), - (e.Sint8x4 = "sint8x4"), - (e.Unorm8x2 = "unorm8x2"), - (e.Unorm8x4 = "unorm8x4"), - (e.Snorm8x2 = "snorm8x2"), - (e.Snorm8x4 = "snorm8x4"), - (e.Uint16x2 = "uint16x2"), - (e.Uint16x4 = "uint16x4"), - (e.Sint16x2 = "sint16x2"), - (e.Sint16x4 = "sint16x4"), - (e.Unorm16x2 = "unorm16x2"), - (e.Unorm16x4 = "unorm16x4"), - (e.Snorm16x2 = "snorm16x2"), - (e.Snorm16x4 = "snorm16x4"), - (e.Float16x2 = "float16x2"), - (e.Float16x4 = "float16x4"), - (e.Float32 = "float32"), - (e.Float32x2 = "float32x2"), - (e.Float32x3 = "float32x3"), - (e.Float32x4 = "float32x4"), - (e.Uint32 = "uint32"), - (e.Uint32x2 = "uint32x2"), - (e.Uint32x3 = "uint32x3"), - (e.Uint32x4 = "uint32x4"), - (e.Sint32 = "sint32"), - (e.Sint32x2 = "sint32x2"), - (e.Sint32x3 = "sint32x3"), - (e.Sint32x4 = "sint32x4"); - })(L || (L = {})), - (function (e) { - (e.Vertex = "vertex"), (e.Instance = "instance"); - })(C || (C = {})), - (function (e) { - (e.Beginning = "beginning"), (e.End = "end"); - })(R || (R = {})), - (function (e) { - (e.Beginning = "beginning"), (e.End = "end"); - })(A || (A = {})), - (function (e) { - (e.Load = "load"), (e.Clear = "clear"); - })(D || (D = {})), - (function (e) { - (e.Store = "store"), (e.Discard = "discard"); - })(z || (z = {})), - (function (e) { - (e.Occlusion = "occlusion"), (e.Timestamp = "timestamp"); - })(I || (I = {})), - (function (e) { - (e.Opaque = "opaque"), (e.Premultiplied = "premultiplied"); - })(P || (P = {})), - (function (e) { - e.Destroyed = "destroyed"; - })(N || (N = {})), - (function (e) { - (e.OutOfMemory = "out-of-memory"), (e.Validation = "validation"); - })(B || (B = {})), - (function (e) { - (e[(e.Red = 1)] = "Red"), - (e[(e.Green = 2)] = "Green"), - (e[(e.Blue = 4)] = "Blue"), - (e[(e.Alpha = 8)] = "Alpha"), - (e[(e.All = 15)] = "All"); - })(O || (O = {})), - (function (e) { - (e.Shadow = "shadow"), (e.Pick = "pick"); - })(V || (V = {})), - (function (e) { - (e[(e.OUTSIDE = -1)] = "OUTSIDE"), (e[(e.INTERSECTING = 0)] = "INTERSECTING"), (e[(e.INSIDE = 1)] = "INSIDE"); - })(F || (F = {})); -class $ { - constructor(e, t, i, r, n) { - (this.device = t), - (this.usage = i), - (this.data = r), - (this.size = null != n ? (n + 3) & -4 : (r.byteLength + 3) & -4), - (this.gpuBuffer = t.createBuffer({ label: e || "", size: this.size, usage: i })), - r && this.setSubData(0, r, this.size); - } - static create(e, t, i, r, n) { - return new $(e, t, i, r, n); - } - static createVertexBuffer(e, t, i) { - return new $(e, t, r.Vertex | r.CopyDst, i, i.byteLength); - } - static createIndexBuffer(e, t, i) { - return new $(e, t, r.Index | r.CopyDst, i); - } - static createUniformBuffer(e, t, i, r) { - return new $(e, t, r, null, i); - } - static createStorageBuffer(e, t, i, n = r.Storage) { - return new $(e, t, n, null, i); - } - setSubData(e, t, i) { - const r = t.buffer, - n = i ?? r.byteLength, - s = this.device.createBuffer({ mappedAtCreation: !0, size: n, usage: GPUBufferUsage.COPY_SRC }), - a = s.getMappedRange(); - new Uint16Array(a).set(new Uint16Array(r)), s.unmap(), this.copyToBuffer(s, e, n), s.destroy(); - } - copyToBuffer(e, t, i) { - const r = this.device.createCommandEncoder(); - r.copyBufferToBuffer(e, 0, this.gpuBuffer, t, i), this.device.queue.submit([r.finish()]); - } - copyToTexture(e, t, i, r) { - const n = this.device.createCommandEncoder(); - n.copyBufferToTexture({ buffer: this.gpuBuffer, bytesPerRow: e, rowsPerImage: t }, i, r), - this.device.queue.submit([n.finish()]); +/** @internal */ +var PredefinedColorSpace; +(function (PredefinedColorSpace) { + PredefinedColorSpace["SRGB"] = "srgb"; +})(PredefinedColorSpace || (PredefinedColorSpace = {})); +/** @internal */ +var PowerPreference; +(function (PowerPreference) { + PowerPreference["LowPower"] = "low-power"; + PowerPreference["HighPerformance"] = "high-performance"; +})(PowerPreference || (PowerPreference = {})); +/** @internal */ +var FeatureName; +(function (FeatureName) { + FeatureName["DepthClipControl"] = "depth-clip-control"; + FeatureName["Depth24UnormStencil8"] = "depth24unorm-stencil8"; + FeatureName["Depth32FloatStencil8"] = "depth32float-stencil8"; + FeatureName["TextureCompressionBC"] = "texture-compression-bc"; + FeatureName["TextureCompressionETC2"] = "texture-compression-etc2"; + FeatureName["TextureCompressionASTC"] = "texture-compression-astc"; + FeatureName["TimestampQuery"] = "timestamp-query"; + FeatureName["IndirectFirstInstance"] = "indirect-first-instance"; + FeatureName["ShaderF16"] = "shader-f16"; + FeatureName["BGRA8UnormStorage"] = "bgra8unorm-storage"; +})(FeatureName || (FeatureName = {})); +/** @internal */ +var BufferUsage; +(function (BufferUsage) { + BufferUsage[(BufferUsage["MapRead"] = 1)] = "MapRead"; + BufferUsage[(BufferUsage["MapWrite"] = 2)] = "MapWrite"; + BufferUsage[(BufferUsage["CopySrc"] = 4)] = "CopySrc"; + BufferUsage[(BufferUsage["CopyDst"] = 8)] = "CopyDst"; + BufferUsage[(BufferUsage["Index"] = 16)] = "Index"; + BufferUsage[(BufferUsage["Vertex"] = 32)] = "Vertex"; + BufferUsage[(BufferUsage["Uniform"] = 64)] = "Uniform"; + BufferUsage[(BufferUsage["Storage"] = 128)] = "Storage"; + BufferUsage[(BufferUsage["Indirect"] = 256)] = "Indirect"; + BufferUsage[(BufferUsage["QueryResolve"] = 512)] = "QueryResolve"; +})(BufferUsage || (BufferUsage = {})); +/** @internal */ +var MapMode; +(function (MapMode) { + MapMode[(MapMode["Read"] = 1)] = "Read"; + MapMode[(MapMode["Write"] = 2)] = "Write"; +})(MapMode || (MapMode = {})); +/** @internal */ +var TextureDimension; +(function (TextureDimension) { + TextureDimension["E1d"] = "1d"; + TextureDimension["E2d"] = "2d"; + TextureDimension["E3d"] = "3d"; +})(TextureDimension || (TextureDimension = {})); +/** @internal */ +var TextureUsage; +(function (TextureUsage) { + TextureUsage[(TextureUsage["CopySrc"] = 1)] = "CopySrc"; + TextureUsage[(TextureUsage["CopyDst"] = 2)] = "CopyDst"; + TextureUsage[(TextureUsage["TextureBinding"] = 4)] = "TextureBinding"; + TextureUsage[(TextureUsage["StorageBinding"] = 8)] = "StorageBinding"; + TextureUsage[(TextureUsage["RenderAttachment"] = 16)] = "RenderAttachment"; +})(TextureUsage || (TextureUsage = {})); +/** @internal */ +var TextureViewDimension; +(function (TextureViewDimension) { + TextureViewDimension["E1d"] = "1d"; + TextureViewDimension["E2d"] = "2d"; + TextureViewDimension["E2dArray"] = "2d-array"; + TextureViewDimension["Cube"] = "cube"; + TextureViewDimension["CubeArray"] = "cube-array"; + TextureViewDimension["E3d"] = "3d"; +})(TextureViewDimension || (TextureViewDimension = {})); +/** @internal */ +var TextureAspect; +(function (TextureAspect) { + TextureAspect["All"] = "all"; + TextureAspect["StencilOnly"] = "stencil-only"; + TextureAspect["DepthOnly"] = "depth-only"; +})(TextureAspect || (TextureAspect = {})); +/** + * Comments taken from https://github.com/gfx-rs/wgpu/blob/master/wgpu-types/src/lib.rs + * @internal + */ +var TextureFormat; +(function (TextureFormat) { + // 8-bit formats + TextureFormat["R8Unorm"] = "r8unorm"; + TextureFormat["R8Snorm"] = "r8snorm"; + TextureFormat["R8Uint"] = "r8uint"; + TextureFormat["R8Sint"] = "r8sint"; + // 16-bit formats + TextureFormat["R16Uint"] = "r16uint"; + TextureFormat["R16Sint"] = "r16sint"; + TextureFormat["R16Float"] = "r16float"; + TextureFormat["RG8Unorm"] = "rg8unorm"; + TextureFormat["RG8Snorm"] = "rg8snorm"; + TextureFormat["RG8Uint"] = "rg8uint"; + TextureFormat["RG8Sint"] = "rg8sint"; + // 32-bit formats + TextureFormat["R32Uint"] = "r32uint"; + TextureFormat["R32Sint"] = "r32sint"; + TextureFormat["R32Float"] = "r32float"; + TextureFormat["RG16Uint"] = "rg16uint"; + TextureFormat["RG16Sint"] = "rg16sint"; + TextureFormat["RG16Float"] = "rg16float"; + TextureFormat["RGBA8Unorm"] = "rgba8unorm"; + TextureFormat["RGBA8UnormSRGB"] = "rgba8unorm-srgb"; + TextureFormat["RGBA8Snorm"] = "rgba8snorm"; + TextureFormat["RGBA8Uint"] = "rgba8uint"; + TextureFormat["RGBA8Sint"] = "rgba8sint"; + TextureFormat["BGRA8Unorm"] = "bgra8unorm"; + TextureFormat["BGRA8UnormSRGB"] = "bgra8unorm-srgb"; + // Packed 32-bit formats + TextureFormat["RGB9E5UFloat"] = "rgb9e5ufloat"; + TextureFormat["RGB10A2Unorm"] = "rgb10a2unorm"; + TextureFormat["RG11B10UFloat"] = "rg11b10ufloat"; + // 64-bit formats + TextureFormat["RG32Uint"] = "rg32uint"; + TextureFormat["RG32Sint"] = "rg32sint"; + TextureFormat["RG32Float"] = "rg32float"; + TextureFormat["RGBA16Uint"] = "rgba16uint"; + TextureFormat["RGBA16Sint"] = "rgba16sint"; + TextureFormat["RGBA16Float"] = "rgba16float"; + // 128-bit formats + TextureFormat["RGBA32Uint"] = "rgba32uint"; + TextureFormat["RGBA32Sint"] = "rgba32sint"; + TextureFormat["RGBA32Float"] = "rgba32float"; + // Depth and stencil formats + TextureFormat["Stencil8"] = "stencil8"; + TextureFormat["Depth16Unorm"] = "depth16unorm"; + TextureFormat["Depth24Plus"] = "depth24plus"; + TextureFormat["Depth24PlusStencil8"] = "depth24plus-stencil8"; + TextureFormat["Depth32Float"] = "depth32float"; + // BC compressed formats usable if "texture-compression-bc" is both + // supported by the device/user agent and enabled in requestDevice. + TextureFormat["BC1RGBAUnorm"] = "bc1-rgba-unorm"; + TextureFormat["BC1RGBAUnormSRGB"] = "bc1-rgba-unorm-srgb"; + TextureFormat["BC2RGBAUnorm"] = "bc2-rgba-unorm"; + TextureFormat["BC2RGBAUnormSRGB"] = "bc2-rgba-unorm-srgb"; + TextureFormat["BC3RGBAUnorm"] = "bc3-rgba-unorm"; + TextureFormat["BC3RGBAUnormSRGB"] = "bc3-rgba-unorm-srgb"; + TextureFormat["BC4RUnorm"] = "bc4-r-unorm"; + TextureFormat["BC4RSnorm"] = "bc4-r-snorm"; + TextureFormat["BC5RGUnorm"] = "bc5-rg-unorm"; + TextureFormat["BC5RGSnorm"] = "bc5-rg-snorm"; + TextureFormat["BC6HRGBUFloat"] = "bc6h-rgb-ufloat"; + TextureFormat["BC6HRGBFloat"] = "bc6h-rgb-float"; + TextureFormat["BC7RGBAUnorm"] = "bc7-rgba-unorm"; + TextureFormat["BC7RGBAUnormSRGB"] = "bc7-rgba-unorm-srgb"; + // ETC2 compressed formats usable if "texture-compression-etc2" is both + // supported by the device/user agent and enabled in requestDevice. + TextureFormat["ETC2RGB8Unorm"] = "etc2-rgb8unorm"; + TextureFormat["ETC2RGB8UnormSRGB"] = "etc2-rgb8unorm-srgb"; + TextureFormat["ETC2RGB8A1Unorm"] = "etc2-rgb8a1unorm"; + TextureFormat["ETC2RGB8A1UnormSRGB"] = "etc2-rgb8a1unorm-srgb"; + TextureFormat["ETC2RGBA8Unorm"] = "etc2-rgba8unorm"; + TextureFormat["ETC2RGBA8UnormSRGB"] = "etc2-rgba8unorm-srgb"; + TextureFormat["EACR11Unorm"] = "eac-r11unorm"; + TextureFormat["EACR11Snorm"] = "eac-r11snorm"; + TextureFormat["EACRG11Unorm"] = "eac-rg11unorm"; + TextureFormat["EACRG11Snorm"] = "eac-rg11snorm"; + // ASTC compressed formats usable if "texture-compression-astc" is both + // supported by the device/user agent and enabled in requestDevice. + TextureFormat["ASTC4x4Unorm"] = "astc-4x4-unorm"; + TextureFormat["ASTC4x4UnormSRGB"] = "astc-4x4-unorm-srgb"; + TextureFormat["ASTC5x4Unorm"] = "astc-5x4-unorm"; + TextureFormat["ASTC5x4UnormSRGB"] = "astc-5x4-unorm-srgb"; + TextureFormat["ASTC5x5Unorm"] = "astc-5x5-unorm"; + TextureFormat["ASTC5x5UnormSRGB"] = "astc-5x5-unorm-srgb"; + TextureFormat["ASTC6x5Unorm"] = "astc-6x5-unorm"; + TextureFormat["ASTC6x5UnormSRGB"] = "astc-6x5-unorm-srgb"; + TextureFormat["ASTC6x6Unorm"] = "astc-6x6-unorm"; + TextureFormat["ASTC6x6UnormSRGB"] = "astc-6x6-unorm-srgb"; + TextureFormat["ASTC8x5Unorm"] = "astc-8x5-unorm"; + TextureFormat["ASTC8x5UnormSRGB"] = "astc-8x5-unorm-srgb"; + TextureFormat["ASTC8x6Unorm"] = "astc-8x6-unorm"; + TextureFormat["ASTC8x6UnormSRGB"] = "astc-8x6-unorm-srgb"; + TextureFormat["ASTC8x8Unorm"] = "astc-8x8-unorm"; + TextureFormat["ASTC8x8UnormSRGB"] = "astc-8x8-unorm-srgb"; + TextureFormat["ASTC10x5Unorm"] = "astc-10x5-unorm"; + TextureFormat["ASTC10x5UnormSRGB"] = "astc-10x5-unorm-srgb"; + TextureFormat["ASTC10x6Unorm"] = "astc-10x6-unorm"; + TextureFormat["ASTC10x6UnormSRGB"] = "astc-10x6-unorm-srgb"; + TextureFormat["ASTC10x8Unorm"] = "astc-10x8-unorm"; + TextureFormat["ASTC10x8UnormSRGB"] = "astc-10x8-unorm-srgb"; + TextureFormat["ASTC10x10Unorm"] = "astc-10x10-unorm"; + TextureFormat["ASTC10x10UnormSRGB"] = "astc-10x10-unorm-srgb"; + TextureFormat["ASTC12x10Unorm"] = "astc-12x10-unorm"; + TextureFormat["ASTC12x10UnormSRGB"] = "astc-12x10-unorm-srgb"; + TextureFormat["ASTC12x12Unorm"] = "astc-12x12-unorm"; + TextureFormat["ASTC12x12UnormSRGB"] = "astc-12x12-unorm-srgb"; + // "depth24unorm-stencil8" feature + TextureFormat["Depth24UnormStencil8"] = "depth24unorm-stencil8"; + // "depth32float-stencil8" feature + TextureFormat["Depth32FloatStencil8"] = "depth32float-stencil8"; +})(TextureFormat || (TextureFormat = {})); +/** @internal */ +var AddressMode; +(function (AddressMode) { + AddressMode["ClampToEdge"] = "clamp-to-edge"; + AddressMode["Repeat"] = "repeat"; + AddressMode["MirrorRepeat"] = "mirror-repeat"; +})(AddressMode || (AddressMode = {})); +/** @internal */ +var FilterMode; +(function (FilterMode) { + FilterMode["Nearest"] = "nearest"; + FilterMode["Linear"] = "linear"; +})(FilterMode || (FilterMode = {})); +/** @internal */ +var CompareFunction; +(function (CompareFunction) { + CompareFunction["Never"] = "never"; + CompareFunction["Less"] = "less"; + CompareFunction["Equal"] = "equal"; + CompareFunction["LessEqual"] = "less-equal"; + CompareFunction["Greater"] = "greater"; + CompareFunction["NotEqual"] = "not-equal"; + CompareFunction["GreaterEqual"] = "greater-equal"; + CompareFunction["Always"] = "always"; +})(CompareFunction || (CompareFunction = {})); +/** @internal */ +var ShaderStage; +(function (ShaderStage) { + ShaderStage[(ShaderStage["Vertex"] = 1)] = "Vertex"; + ShaderStage[(ShaderStage["Fragment"] = 2)] = "Fragment"; + ShaderStage[(ShaderStage["Compute"] = 4)] = "Compute"; +})(ShaderStage || (ShaderStage = {})); +/** @internal */ +var BufferBindingType; +(function (BufferBindingType) { + BufferBindingType["Uniform"] = "uniform"; + BufferBindingType["Storage"] = "storage"; + BufferBindingType["ReadOnlyStorage"] = "read-only-storage"; +})(BufferBindingType || (BufferBindingType = {})); +/** @internal */ +var SamplerBindingType; +(function (SamplerBindingType) { + SamplerBindingType["Filtering"] = "filtering"; + SamplerBindingType["NonFiltering"] = "non-filtering"; + SamplerBindingType["Comparison"] = "comparison"; +})(SamplerBindingType || (SamplerBindingType = {})); +/** @internal */ +var TextureSampleType; +(function (TextureSampleType) { + TextureSampleType["Float"] = "float"; + TextureSampleType["UnfilterableFloat"] = "unfilterable-float"; + TextureSampleType["Depth"] = "depth"; + TextureSampleType["Sint"] = "sint"; + TextureSampleType["Uint"] = "uint"; +})(TextureSampleType || (TextureSampleType = {})); +/** @internal */ +var StorageTextureAccess; +(function (StorageTextureAccess) { + StorageTextureAccess["WriteOnly"] = "write-only"; +})(StorageTextureAccess || (StorageTextureAccess = {})); +/** @internal */ +var CompilationMessageType; +(function (CompilationMessageType) { + CompilationMessageType["Error"] = "error"; + CompilationMessageType["Warning"] = "warning"; + CompilationMessageType["Info"] = "info"; +})(CompilationMessageType || (CompilationMessageType = {})); +/** @internal */ +var AutoLayoutMode; +(function (AutoLayoutMode) { + AutoLayoutMode["Auto"] = "auto"; +})(AutoLayoutMode || (AutoLayoutMode = {})); +/** @internal */ +var PrimitiveTopology; +(function (PrimitiveTopology) { + PrimitiveTopology["PointList"] = "point-list"; + PrimitiveTopology["LineList"] = "line-list"; + PrimitiveTopology["LineStrip"] = "line-strip"; + PrimitiveTopology["TriangleList"] = "triangle-list"; + PrimitiveTopology["TriangleStrip"] = "triangle-strip"; +})(PrimitiveTopology || (PrimitiveTopology = {})); +/** @internal */ +var FrontFace; +(function (FrontFace) { + FrontFace["CCW"] = "ccw"; + FrontFace["CW"] = "cw"; +})(FrontFace || (FrontFace = {})); +/** @internal */ +var CullMode; +(function (CullMode) { + CullMode["None"] = "none"; + CullMode["Front"] = "front"; + CullMode["Back"] = "back"; +})(CullMode || (CullMode = {})); +/** @internal */ +var ColorWriteFlags; +(function (ColorWriteFlags) { + ColorWriteFlags[(ColorWriteFlags["Red"] = 1)] = "Red"; + ColorWriteFlags[(ColorWriteFlags["Green"] = 2)] = "Green"; + ColorWriteFlags[(ColorWriteFlags["Blue"] = 4)] = "Blue"; + ColorWriteFlags[(ColorWriteFlags["Alpha"] = 8)] = "Alpha"; + ColorWriteFlags[(ColorWriteFlags["All"] = 15)] = "All"; +})(ColorWriteFlags || (ColorWriteFlags = {})); +/** @internal */ +var BlendFactor; +(function (BlendFactor) { + BlendFactor["Zero"] = "zero"; + BlendFactor["One"] = "one"; + BlendFactor["Src"] = "src"; + BlendFactor["OneMinusSrc"] = "one-minus-src"; + BlendFactor["SrcAlpha"] = "src-alpha"; + BlendFactor["OneMinusSrcAlpha"] = "one-minus-src-alpha"; + BlendFactor["Dst"] = "dst"; + BlendFactor["OneMinusDst"] = "one-minus-dst"; + BlendFactor["DstAlpha"] = "dst-alpha"; + BlendFactor["OneMinusDstAlpha"] = "one-minus-dst-alpha"; + BlendFactor["SrcAlphaSaturated"] = "src-alpha-saturated"; + BlendFactor["Constant"] = "constant"; + BlendFactor["OneMinusConstant"] = "one-minus-constant"; +})(BlendFactor || (BlendFactor = {})); +/** @internal */ +var BlendOperation; +(function (BlendOperation) { + BlendOperation["Add"] = "add"; + BlendOperation["Subtract"] = "subtract"; + BlendOperation["ReverseSubtract"] = "reverse-subtract"; + BlendOperation["Min"] = "min"; + BlendOperation["Max"] = "max"; +})(BlendOperation || (BlendOperation = {})); +/** @internal */ +var StencilOperation; +(function (StencilOperation) { + StencilOperation["Keep"] = "keep"; + StencilOperation["Zero"] = "zero"; + StencilOperation["Replace"] = "replace"; + StencilOperation["Invert"] = "invert"; + StencilOperation["IncrementClamp"] = "increment-clamp"; + StencilOperation["DecrementClamp"] = "decrement-clamp"; + StencilOperation["IncrementWrap"] = "increment-wrap"; + StencilOperation["DecrementWrap"] = "decrement-wrap"; +})(StencilOperation || (StencilOperation = {})); +/** @internal */ +var IndexFormat; +(function (IndexFormat) { + IndexFormat["Uint16"] = "uint16"; + IndexFormat["Uint32"] = "uint32"; +})(IndexFormat || (IndexFormat = {})); +/** @internal */ +var VertexFormat; +(function (VertexFormat) { + VertexFormat["Uint8x2"] = "uint8x2"; + VertexFormat["Uint8x4"] = "uint8x4"; + VertexFormat["Sint8x2"] = "sint8x2"; + VertexFormat["Sint8x4"] = "sint8x4"; + VertexFormat["Unorm8x2"] = "unorm8x2"; + VertexFormat["Unorm8x4"] = "unorm8x4"; + VertexFormat["Snorm8x2"] = "snorm8x2"; + VertexFormat["Snorm8x4"] = "snorm8x4"; + VertexFormat["Uint16x2"] = "uint16x2"; + VertexFormat["Uint16x4"] = "uint16x4"; + VertexFormat["Sint16x2"] = "sint16x2"; + VertexFormat["Sint16x4"] = "sint16x4"; + VertexFormat["Unorm16x2"] = "unorm16x2"; + VertexFormat["Unorm16x4"] = "unorm16x4"; + VertexFormat["Snorm16x2"] = "snorm16x2"; + VertexFormat["Snorm16x4"] = "snorm16x4"; + VertexFormat["Float16x2"] = "float16x2"; + VertexFormat["Float16x4"] = "float16x4"; + VertexFormat["Float32"] = "float32"; + VertexFormat["Float32x2"] = "float32x2"; + VertexFormat["Float32x3"] = "float32x3"; + VertexFormat["Float32x4"] = "float32x4"; + VertexFormat["Uint32"] = "uint32"; + VertexFormat["Uint32x2"] = "uint32x2"; + VertexFormat["Uint32x3"] = "uint32x3"; + VertexFormat["Uint32x4"] = "uint32x4"; + VertexFormat["Sint32"] = "sint32"; + VertexFormat["Sint32x2"] = "sint32x2"; + VertexFormat["Sint32x3"] = "sint32x3"; + VertexFormat["Sint32x4"] = "sint32x4"; +})(VertexFormat || (VertexFormat = {})); +/** @internal */ +var InputStepMode; +(function (InputStepMode) { + InputStepMode["Vertex"] = "vertex"; + InputStepMode["Instance"] = "instance"; +})(InputStepMode || (InputStepMode = {})); +/** @internal */ +var ComputePassTimestampLocation; +(function (ComputePassTimestampLocation) { + ComputePassTimestampLocation["Beginning"] = "beginning"; + ComputePassTimestampLocation["End"] = "end"; +})(ComputePassTimestampLocation || (ComputePassTimestampLocation = {})); +/** @internal */ +var RenderPassTimestampLocation; +(function (RenderPassTimestampLocation) { + RenderPassTimestampLocation["Beginning"] = "beginning"; + RenderPassTimestampLocation["End"] = "end"; +})(RenderPassTimestampLocation || (RenderPassTimestampLocation = {})); +/** @internal */ +var LoadOp; +(function (LoadOp) { + LoadOp["Load"] = "load"; + LoadOp["Clear"] = "clear"; +})(LoadOp || (LoadOp = {})); +/** @internal */ +var StoreOp; +(function (StoreOp) { + StoreOp["Store"] = "store"; + StoreOp["Discard"] = "discard"; +})(StoreOp || (StoreOp = {})); +/** @internal */ +var QueryType; +(function (QueryType) { + QueryType["Occlusion"] = "occlusion"; + QueryType["Timestamp"] = "timestamp"; +})(QueryType || (QueryType = {})); +/** @internal */ +var CanvasAlphaMode; +(function (CanvasAlphaMode) { + CanvasAlphaMode["Opaque"] = "opaque"; + CanvasAlphaMode["Premultiplied"] = "premultiplied"; +})(CanvasAlphaMode || (CanvasAlphaMode = {})); +/** @internal */ +var DeviceLostReason; +(function (DeviceLostReason) { + DeviceLostReason["Destroyed"] = "destroyed"; +})(DeviceLostReason || (DeviceLostReason = {})); +/** @internal */ +var ErrorFilter; +(function (ErrorFilter) { + ErrorFilter["OutOfMemory"] = "out-of-memory"; + ErrorFilter["Validation"] = "validation"; +})(ErrorFilter || (ErrorFilter = {})); +var GPUColorWrite; +(function (GPUColorWrite) { + GPUColorWrite[(GPUColorWrite["Red"] = 1)] = "Red"; + GPUColorWrite[(GPUColorWrite["Green"] = 2)] = "Green"; + GPUColorWrite[(GPUColorWrite["Blue"] = 4)] = "Blue"; + GPUColorWrite[(GPUColorWrite["Alpha"] = 8)] = "Alpha"; + GPUColorWrite[(GPUColorWrite["All"] = 15)] = "All"; +})(GPUColorWrite || (GPUColorWrite = {})); +var CommandSubType; +(function (CommandSubType) { + CommandSubType["Shadow"] = "shadow"; + CommandSubType["Pick"] = "pick"; +})(CommandSubType || (CommandSubType = {})); +var Intersect; +(function (Intersect) { + Intersect[(Intersect["OUTSIDE"] = -1)] = "OUTSIDE"; + Intersect[(Intersect["INTERSECTING"] = 0)] = "INTERSECTING"; + Intersect[(Intersect["INSIDE"] = 1)] = "INSIDE"; +})(Intersect || (Intersect = {})); + +class Buffer { + constructor(label, device, usage, data, size) { + this.device = device; + this.usage = usage; + this.data = data; + this.size = size != undefined ? (size + 3) & ~3 : (data.byteLength + 3) & ~3; // 4 bytes alignments (because of the upload which requires this) + this.gpuBuffer = device.createBuffer({ + label: label || "", + size: this.size, + usage + }); + if (data) this.setSubData(0, data, this.size); + } + static create(label, device, usage, data, size) { + return new Buffer(label, device, usage, data, size); + } + static createVertexBuffer(label, device, data) { + return new Buffer(label, device, BufferUsage.Vertex | BufferUsage.CopyDst, data, data.byteLength); + } + static createIndexBuffer(label, device, data) { + return new Buffer(label, device, BufferUsage.Index | BufferUsage.CopyDst, data); + } + static createUniformBuffer(label, device, size, usage) { + return new Buffer(label, device, usage, null, size); + } + static createStorageBuffer(label, device, size, usage = BufferUsage.Storage) { + return new Buffer(label, device, usage, null, size); + } + // https://github.com/gpuweb/gpuweb/blob/main/design/BufferOperations.md + setSubData(offset, data, size) { + const srcArrayBuffer = data.buffer; + const byteCount = size ?? srcArrayBuffer.byteLength; + const srcBuffer = this.device.createBuffer({ + mappedAtCreation: true, + size: byteCount, + usage: GPUBufferUsage.COPY_SRC + }); + const arrayBuffer = srcBuffer.getMappedRange(); + new Uint16Array(arrayBuffer).set(new Uint16Array(srcArrayBuffer)); // memcpy + srcBuffer.unmap(); + this.copyToBuffer(srcBuffer, offset, byteCount); + srcBuffer.destroy(); + } + copyToBuffer(srcBuffer, offset, byteCount) { + const commandEncoder = this.device.createCommandEncoder(); + commandEncoder.copyBufferToBuffer(srcBuffer, 0, this.gpuBuffer, offset, byteCount); + this.device.queue.submit([commandEncoder.finish()]); + } + copyToTexture(bytesPerRow, rowsPerImage, destination, extent) { + const commandEncoder = this.device.createCommandEncoder(); + commandEncoder.copyBufferToTexture( + { + buffer: this.gpuBuffer, + bytesPerRow, + rowsPerImage + }, + destination, + extent + ); + this.device.queue.submit([commandEncoder.finish()]); } destroy() { this.gpuBuffer.destroy(); } } -const G = new Map(); -class k { - constructor(e, t, i = [], r) { - (this.groupLayouts = i), - (this.index = r || 0), - (this.gpuPipelineLayout = e.createPipelineLayout({ - label: t, - bindGroupLayouts: i.map((e) => e.gpuBindGroupLayout) - })); + +const pipelineLayoutCache = new Map(); +class PipelineLayout { + constructor(device, label, groupLayouts = [], index) { + this.groupLayouts = groupLayouts; + this.index = index || 0; + this.gpuPipelineLayout = device.createPipelineLayout({ + label: label, + bindGroupLayouts: groupLayouts.map((layout) => { + return layout.gpuBindGroupLayout; + }) + }); } - static getPipelineLayoutFromCache(e, t, i) { - if (G.has(t)) return G.get(t); - { - const r = new k(e, t, i); - return G.set(t, r), r; + static getPipelineLayoutFromCache(device, label, groupLayouts) { + if (pipelineLayoutCache.has(label)) { + return pipelineLayoutCache.get(label); + } else { + const bindGroupLayout = new PipelineLayout(device, label, groupLayouts); + pipelineLayoutCache.set(label, bindGroupLayout); + return bindGroupLayout; } } } -const q = new Map(), - j = new Map(); -class H { - constructor(e, t, i) { - (this.type = e), (this.descriptor = i), (this.device = t), this.createPipeline(); + +const renderPipelines = new Map(); +const computePipelines = new Map(); +class Pipeline { + constructor(type, device, descriptor) { + this.type = type; + this.descriptor = descriptor; + this.device = device; + this.createPipeline(); } createPipeline() { - "render" == this.type - ? (this.gpuPipeline = this.device.createRenderPipeline(this.descriptor)) - : (this.gpuPipeline = this.device.createComputePipeline(this.descriptor)); - } - bind(e) { - this.type, e.setPipeline(this.gpuPipeline); - } - static getRenderPipelineFromCache(e, t, i) { - const { renderState: r, shaderSource: n } = t, - s = JSON.stringify(r), - a = X(n.uid.concat(s)), - o = i?.filter((e) => null != e)?.sort((e, t) => e.index - t.index); - let c = q.get(a); - if (!c) { - const i = H.getPipelineDescriptor(e, t, r, o, a.toString()); - (c = new H("render", e, i)), q.set(a, c); - } - return c; - } - static getComputePipelineFromCache(e, t, i) { - const { shaderSource: r } = t, - n = X(r.uid); - let s = j.get(n); - return ( - s || - ((s = new H("compute", e, { - layout: k.getPipelineLayoutFromCache(e, n.toString(), i).gpuPipelineLayout, - compute: { module: r.getShaderModule(e).compute, entryPoint: r?.compute?.computeMain || "main" } - })), - j.set(n, s)), - s - ); + if (this.type == "render") { + this.gpuPipeline = this.device.createRenderPipeline(this.descriptor); + } else { + this.gpuPipeline = this.device.createComputePipeline(this.descriptor); + } } - static getPipelineDescriptor(e, t, i, r, n) { - const { vertexBuffers: s, shaderSource: a } = t, - { vert: o, frag: c } = a.getShaderModule(e), - l = { layout: k.getPipelineLayoutFromCache(e, n, r).gpuPipelineLayout }; - return ( - o && - (l.vertex = { - module: o, - entryPoint: a?.render?.vertMain || "main", - buffers: s.map((e) => e.getBufferDes()) - }), - i.primitive && (l.primitive = i.primitive.getGPUPrimitiveDec()), - i.depthStencil && (l.depthStencil = i.depthStencil.getGPUDepthStencilDec()), - i.multisample && (l.multisample = i.multisample.getMultiSampleDec()), - c && - (l.fragment = { - module: c, - entryPoint: a?.render?.fragMain || "main", - targets: i.targets.map((e) => e.getGPUTargetDec()) - }), - l - ); + bind(passEncoder) { + if (this.type == "render") { + passEncoder.setPipeline(this.gpuPipeline); + } else { + passEncoder.setPipeline(this.gpuPipeline); + } } -} -function X(e) { - let t = 0; - if (0 == e.length) return t; - for (let i = 0; i < e.length; i++) { - (t = (t << 5) - t + e.charCodeAt(i)), (t &= t); - } - return t; -} -class Y { - constructor(e) { - (this.shaderData = e.shaderData), - (this.renderTarget = e.renderTarget), - (this.useLight = e.useLight), - (this.vertexBuffers = e.vertexBuffers), - (this.indexBuffer = e.indexBuffer), - (this.renderState = e.renderState), - (this.queryIndex = e.queryIndex), - (this.count = e.count), - (this.instances = e.instances), - (this.shaderSource = e.shaderSource), - (this.dirty = e.dirty), - (this.lightShaderData = e.lightShaderData); - } - shallowClone(e) { - if (e) - return new Y({ - vertexBuffers: this.vertexBuffers, - indexBuffer: this.indexBuffer, - shaderData: e.shaderData, - instances: this.instances, - count: this.count, - renderState: e.renderState, - shaderSource: e.shaderSource, - lightShaderData: e.light ? this.lightShaderData : void 0, - useLight: e.light + static getRenderPipelineFromCache(device, drawComand, groupLayouts) { + const { renderState, shaderSource } = drawComand; + const rsStr = JSON.stringify(renderState); + const combineStr = shaderSource.uid.concat(rsStr); + const hashId = stringToHash(combineStr); + const combineLayouts = groupLayouts + ?.filter((layout) => layout != undefined) + ?.sort((layout1, layout2) => layout1.index - layout2.index); + let pipeline = renderPipelines.get(hashId); + if (!pipeline) { + const descriptor = Pipeline.getPipelineDescriptor( + device, + drawComand, + renderState, + combineLayouts, + hashId.toString() + ); + pipeline = new Pipeline("render", device, descriptor); + renderPipelines.set(hashId, pipeline); + } + return pipeline; + } + static getComputePipelineFromCache(device, computeCommad, groupLayouts) { + const { shaderSource } = computeCommad; + const hashId = stringToHash(shaderSource.uid); + let pipeline = computePipelines.get(hashId); + if (!pipeline) { + pipeline = new Pipeline("compute", device, { + layout: PipelineLayout.getPipelineLayoutFromCache(device, hashId.toString(), groupLayouts) + .gpuPipelineLayout, + compute: { + module: shaderSource.getShaderModule(device).compute, + entryPoint: shaderSource?.compute?.computeMain || "main" + } }); + computePipelines.set(hashId, pipeline); + } + return pipeline; } - render(e) { - const { device: t, passEncoder: i, camera: r, querySet: n, viewPort: s, scissorTest: a } = e || {}, - { - shaderData: o, - renderState: c, - vertexBuffers: l, - indexBuffer: h, - lightShaderData: u, - shaderSource: f, - count: d, - instances: m, - renderTarget: p, - useLight: g, - indirectOffset: x, - indirectBuffer: v, - queryIndex: y - } = this, - S = p?.beginRenderPass?.(t) ?? i, - b = Object.assign({}, u?.defines ?? {}, r?.shaderData?.defines ?? {}); - o?.bind?.(t, S), - r?.shaderData?.bind(t, S), - g && u?.bind?.(t, S), - c?.bind?.({ passEncoder: S, viewPort: s, scissorTest: a }), - l?.forEach?.((e) => e?.bind?.(t, S)), - h?.bind?.(t, S), - f?.setDefines?.(b); - const w = H.getRenderPipelineFromCache(t, this, [o?.groupLayout, u?.groupLayout, r?.shaderData?.groupLayout]); - null != y && n?.beginQuery(S, y), - w.bind(S), - h - ? v - ? S.drawIndexedIndirect(v.gpuBuffer, x || 0) - : S.drawIndexed(d || 0, m || 1, 0, 0, 0) - : d && (v ? S.drawIndirect(v.gpuBuffer, x) : S.draw(d, m || 1, 0, 0)), - null != y && n?.endQuery(S), - p?.endRenderPass?.(); - } -} -const W = "premultiplied"; -var Z, K, Q; -!(function (e) { - (e.Camera = "camera"), - (e.Light = "light"), - (e.Mesh = "mesh"), - (e.SkinMesh = "skinMesh"), - (e.Node = "node"), - (e.Axes = "axes"), - (e.Skybox = "skyBox"), - (e.PostEffect = "postEffect"), - (e.Debug = "debug"); -})(Z || (Z = {})), - (function (e) { - (e.SpotLight = "spotLight"), - (e.PointLight = "pointLight"), - (e.AmbientLight = "ambientLight"), - (e.DirectionalLight = "directionalLight"); - })(K || (K = {})), - (function (e) { - (e.Float = "f32"), - (e.FloatVec2 = "vec2"), - (e.FloatVec3 = "vec3"), - (e.FloatVec4 = "vec4"), - (e.FloatArray = "array"), - (e.Mat2 = "mat2x2"), - (e.Mat3 = "mat3x3"), - (e.Mat4 = "mat4x4"), - (e.Color = "color"), - (e.Mat4Array = "array>"), - (e.Vec2Array = "array>"), - (e.Vec3Array = "array>"), - (e.Vec4Array = "array>"), - (e.UniformUint = "u32"), - (e.PointLights = "pointLights"), - (e.PointLightShadows = "pointLightShadows"), - (e.SpotLights = "spotLights"), - (e.SpotLightShadows = "spotLightShadows"), - (e.DirtectLights = "dirtectLights"), - (e.DirtectLightShadows = "dirtectLightShadows"), - (e.UniformStructArray = "StructArray"); - })(Q || (Q = {})); -class J { - constructor(e) { - (this.device = e), (this.sampler = e.createSampler({ minFilter: "linear" })), (this.pipelines = {}); - } - getMipmapPipeline(e) { - let t = this.pipelines[e]; - return ( - t || - (this.mipmapShaderModule || - (this.mipmapShaderModule = this.device.createShaderModule({ - code: "\n var pos : array, 3> = array, 3>(\n vec2(-1.0, -1.0), vec2(-1.0, 3.0), vec2(3.0, -1.0));\n struct VertexOutput {\n @builtin(position) position : vec4,\n @location(0) texCoord : vec2,\n };\n @vertex\n fn vertexMain(@builtin(vertex_index) vertexIndex : u32) -> VertexOutput {\n var output : VertexOutput;\n output.texCoord = pos[vertexIndex] * vec2(0.5, -0.5) + vec2(0.5);\n output.position = vec4(pos[vertexIndex], 0.0, 1.0);\n return output;\n }\n @group(0) @binding(0) var imgSampler : sampler;\n @group(0) @binding(1) var img : texture_2d;\n @fragment\n fn fragmentMain(@location(0) texCoord : vec2) -> @location(0) vec4 {\n return textureSample(img, imgSampler, texCoord);\n }\n " - })), - (t = this.device.createRenderPipeline({ - layout: "auto", - vertex: { module: this.mipmapShaderModule, entryPoint: "vertexMain" }, - fragment: { module: this.mipmapShaderModule, entryPoint: "fragmentMain", targets: [{ format: e }] } - })), - (this.pipelines[e] = t)), - t - ); + static getPipelineDescriptor(device, drawComand, renderState, groupLayouts, hashId) { + const { vertexBuffers, shaderSource } = drawComand; + const { vert, frag } = shaderSource.getShaderModule(device); + const pipelineDec = { + layout: PipelineLayout.getPipelineLayoutFromCache(device, hashId, groupLayouts).gpuPipelineLayout + }; + if (vert) + pipelineDec.vertex = { + module: vert, + entryPoint: shaderSource?.render?.vertMain || "main", + buffers: vertexBuffers.map((vertexBuffer) => vertexBuffer.getBufferDes()) + }; + if (renderState.primitive) pipelineDec.primitive = renderState.primitive.getGPUPrimitiveDec(); + if (renderState.depthStencil) pipelineDec.depthStencil = renderState.depthStencil.getGPUDepthStencilDec(); + if (renderState.multisample) pipelineDec.multisample = renderState.multisample.getMultiSampleDec(); + if (frag) + pipelineDec.fragment = { + module: frag, + entryPoint: shaderSource?.render?.fragMain || "main", + targets: renderState.targets.map((target) => { + return target.getGPUTargetDec(); + }) + }; + return pipelineDec; + } +} +// Borrowed from https://werxltd.com/wp/2010/05/13/javascript-implementation-of-javas-string-hashcode-method/ +function stringToHash(str) { + let hash = 0; + if (str.length == 0) return hash; + for (let i = 0; i < str.length; i++) { + const char = str.charCodeAt(i); + hash = (hash << 5) - hash + char; + hash = hash & hash; // Convert to 32bit integer + } + return hash; +} + +class DrawCommand { + constructor(options) { + this.shaderData = options.shaderData; + this.renderTarget = options.renderTarget; + this.useLight = options.useLight; + this.vertexBuffers = options.vertexBuffers; + this.indexBuffer = options.indexBuffer; + this.renderState = options.renderState; + this.queryIndex = options.queryIndex; + this.count = options.count; + this.instances = options.instances; + this.shaderSource = options.shaderSource; + this.dirty = options.dirty; + this.lightShaderData = options.lightShaderData; + } + shallowClone(material) { + if (!material) return; + return new DrawCommand({ + vertexBuffers: this.vertexBuffers, + indexBuffer: this.indexBuffer, + shaderData: material.shaderData, + instances: this.instances, + count: this.count, + renderState: material.renderState, + shaderSource: material.shaderSource, + lightShaderData: material.light ? this.lightShaderData : undefined, + useLight: material.light + }); + } + render(params) { + const { device, passEncoder, camera, querySet, viewPort, scissorTest } = params || {}; + const { + shaderData, + renderState, + vertexBuffers, + indexBuffer, + lightShaderData, + shaderSource, + count, + instances, + renderTarget, + useLight, + indirectOffset, + indirectBuffer, + queryIndex + } = this; + const currentPassEncoder = renderTarget?.beginRenderPass?.(device) ?? passEncoder; + const defines = Object.assign({}, lightShaderData?.defines ?? {}, camera?.shaderData?.defines ?? {}); + shaderData?.bind?.(device, currentPassEncoder); + camera?.shaderData?.bind(device, currentPassEncoder); + useLight && lightShaderData?.bind?.(device, currentPassEncoder); + renderState?.bind?.({ + passEncoder: currentPassEncoder, + viewPort: viewPort, + scissorTest: scissorTest + }); + vertexBuffers?.forEach?.((vertexBuffer) => vertexBuffer?.bind?.(device, currentPassEncoder)); + indexBuffer?.bind?.(device, currentPassEncoder); + shaderSource?.setDefines?.(defines); + const pipeline = Pipeline.getRenderPipelineFromCache(device, this, [ + shaderData?.groupLayout, + lightShaderData?.groupLayout, + camera?.shaderData?.groupLayout + ]); + if (queryIndex != undefined) querySet?.beginQuery(currentPassEncoder, queryIndex); + pipeline.bind(currentPassEncoder); + if (indexBuffer) { + if (indirectBuffer) { + currentPassEncoder.drawIndexedIndirect(indirectBuffer.gpuBuffer, indirectOffset || 0); + } else { + currentPassEncoder.drawIndexed(count || 0, instances || 1, 0, 0, 0); + } + } else if (count) { + if (indirectBuffer) { + currentPassEncoder.drawIndirect(indirectBuffer.gpuBuffer, indirectOffset); + } else { + currentPassEncoder.draw(count, instances || 1, 0, 0); + } + } + if (queryIndex != undefined) querySet?.endQuery(currentPassEncoder); + renderTarget?.endRenderPass?.(); } - generateMipmap(e) { - const t = e.gpuTexture, - i = e.textureProp, - r = this.getMipmapPipeline(i.format); - if ("3d" == i.dimension || "1d" == i.dimension) +} + +const GPUCanvasCompositingAlphaMode = { + Opaque: "opaque", + Premultiplied: "premultiplied" +}; +var RenderObjectType; +(function (RenderObjectType) { + RenderObjectType["Camera"] = "camera"; + RenderObjectType["Light"] = "light"; + RenderObjectType["Mesh"] = "mesh"; + RenderObjectType["SkinMesh"] = "skinMesh"; + RenderObjectType["Node"] = "node"; + RenderObjectType["Axes"] = "axes"; + RenderObjectType["Skybox"] = "skyBox"; + RenderObjectType["PostEffect"] = "postEffect"; + RenderObjectType["Debug"] = "debug"; +})(RenderObjectType || (RenderObjectType = {})); +var LightType; +(function (LightType) { + LightType["SpotLight"] = "spotLight"; + LightType["PointLight"] = "pointLight"; + LightType["AmbientLight"] = "ambientLight"; + LightType["DirectionalLight"] = "directionalLight"; +})(LightType || (LightType = {})); +var UniformEnum; +(function (UniformEnum) { + UniformEnum["Float"] = "f32"; + UniformEnum["FloatVec2"] = "vec2"; + UniformEnum["FloatVec3"] = "vec3"; + UniformEnum["FloatVec4"] = "vec4"; + UniformEnum["FloatArray"] = "array"; + UniformEnum["Mat2"] = "mat2x2"; + UniformEnum["Mat3"] = "mat3x3"; + UniformEnum["Mat4"] = "mat4x4"; + UniformEnum["Color"] = "color"; + UniformEnum["Mat4Array"] = "array>"; + UniformEnum["Vec2Array"] = "array>"; + UniformEnum["Vec3Array"] = "array>"; + UniformEnum["Vec4Array"] = "array>"; + UniformEnum["UniformUint"] = "u32"; + UniformEnum["PointLights"] = "pointLights"; + UniformEnum["PointLightShadows"] = "pointLightShadows"; + UniformEnum["SpotLights"] = "spotLights"; + UniformEnum["SpotLightShadows"] = "spotLightShadows"; + UniformEnum["DirtectLights"] = "dirtectLights"; + UniformEnum["DirtectLightShadows"] = "dirtectLightShadows"; + UniformEnum["UniformStructArray"] = "StructArray"; +})(UniformEnum || (UniformEnum = {})); + +class MipmapGenerator { + constructor(device) { + this.device = device; + this.sampler = device.createSampler({ minFilter: "linear" }); + // We'll need a new pipeline for every texture format used. + this.pipelines = {}; + } + getMipmapPipeline(format) { + let pipeline = this.pipelines[format]; + if (!pipeline) { + // Shader modules is shared between all pipelines, so only create once. + if (!this.mipmapShaderModule) { + this.mipmapShaderModule = this.device.createShaderModule({ + code: ` + var pos : array, 3> = array, 3>( + vec2(-1.0, -1.0), vec2(-1.0, 3.0), vec2(3.0, -1.0)); + struct VertexOutput { + @builtin(position) position : vec4, + @location(0) texCoord : vec2, + }; + @vertex + fn vertexMain(@builtin(vertex_index) vertexIndex : u32) -> VertexOutput { + var output : VertexOutput; + output.texCoord = pos[vertexIndex] * vec2(0.5, -0.5) + vec2(0.5); + output.position = vec4(pos[vertexIndex], 0.0, 1.0); + return output; + } + @group(0) @binding(0) var imgSampler : sampler; + @group(0) @binding(1) var img : texture_2d; + @fragment + fn fragmentMain(@location(0) texCoord : vec2) -> @location(0) vec4 { + return textureSample(img, imgSampler, texCoord); + } + ` + }); + } + pipeline = this.device.createRenderPipeline({ + layout: "auto", + vertex: { + module: this.mipmapShaderModule, + entryPoint: "vertexMain" + }, + fragment: { + module: this.mipmapShaderModule, + entryPoint: "fragmentMain", + targets: [{ format }] + } + }); + this.pipelines[format] = pipeline; + } + return pipeline; + } + /** + * Generates mipmaps for the given GPUTexture from the data in level 0. + * + * @param {module:External.GPUTexture} texture - Texture to generate mipmaps for. + * @param {object} textureDescriptor - GPUTextureDescriptor the texture was created with. + * @returns {module:External.GPUTexture} - The originally passed texture + */ + generateMipmap(sourceTexture) { + const texture = sourceTexture.gpuTexture; + const textureDescriptor = sourceTexture.textureProp; + // TODO: Does this need to handle sRGB formats differently? + const pipeline = this.getMipmapPipeline(textureDescriptor.format); + if (textureDescriptor.dimension == "3d" || textureDescriptor.dimension == "1d") { throw new Error("Generating mipmaps for non-2d textures is currently unsupported!"); - let n = t; - const s = i.size.depth || 1, - a = i.usage & GPUTextureUsage.RENDER_ATTACHMENT; - if (!a) { - const e = { + } + let mipTexture = texture; + const arrayLayerCount = textureDescriptor.size.depth || 1; // Only valid for 2D textures. + // If the texture was created with RENDER_ATTACHMENT usage we can render directly between mip levels. + const renderToSource = textureDescriptor.usage & GPUTextureUsage.RENDER_ATTACHMENT; + if (!renderToSource) { + // Otherwise we have to use a separate texture to render into. It can be one mip level smaller than the source + // texture, since we already have the top level. + const mipTextureDescriptor = { size: { - width: Math.ceil(i.size.width / 2), - height: Math.ceil(i.size.height / 2), - depthOrArrayLayers: s + width: Math.ceil(textureDescriptor.size.width / 2), + height: Math.ceil(textureDescriptor.size.height / 2), + depthOrArrayLayers: arrayLayerCount }, - format: i.format, + format: textureDescriptor.format, usage: GPUTextureUsage.TEXTURE_BINDING | GPUTextureUsage.COPY_SRC | GPUTextureUsage.RENDER_ATTACHMENT, - mipLevelCount: i.mipLevelCount - 1 + mipLevelCount: textureDescriptor.mipLevelCount - 1 }; - n = this.device.createTexture(e); + mipTexture = this.device.createTexture(mipTextureDescriptor); } - const o = this.device.createCommandEncoder({}), - c = r.getBindGroupLayout(0); - for (let e = 0; e < s; ++e) { - let s = t.createView({ - baseMipLevel: 0, + const commandEncoder = this.device.createCommandEncoder({}); + // TODO: Consider making this static. + const bindGroupLayout = pipeline.getBindGroupLayout(0); + for (let arrayLayer = 0; arrayLayer < arrayLayerCount; ++arrayLayer) { + let srcView = texture.createView({ + baseMipLevel: 0, + mipLevelCount: 1, + dimension: "2d", + baseArrayLayer: arrayLayer, + arrayLayerCount: 1 + }); + let dstMipLevel = renderToSource ? 1 : 0; + for (let i = 1; i < textureDescriptor.mipLevelCount; ++i) { + const dstView = mipTexture.createView({ + baseMipLevel: dstMipLevel++, mipLevelCount: 1, dimension: "2d", - baseArrayLayer: e, + baseArrayLayer: arrayLayer, arrayLayerCount: 1 - }), - l = a ? 1 : 0; - for (let t = 1; t < i.mipLevelCount; ++t) { - const t = n.createView({ - baseMipLevel: l++, - mipLevelCount: 1, - dimension: "2d", - baseArrayLayer: e, - arrayLayerCount: 1 - }), - i = o.beginRenderPass({ colorAttachments: [{ view: t, loadOp: "clear", storeOp: "store" }] }), - a = this.device.createBindGroup({ - layout: c, - entries: [ - { binding: 0, resource: this.sampler }, - { binding: 1, resource: s } - ] - }); - i.setPipeline(r), i.setBindGroup(0, a), i.draw(3, 1, 0, 0), i.end(), (s = t); + }); + const passEncoder = commandEncoder.beginRenderPass({ + colorAttachments: [ + { + view: dstView, + loadOp: "clear", + storeOp: "store" + } + ] + }); + const bindGroup = this.device.createBindGroup({ + layout: bindGroupLayout, + entries: [ + { + binding: 0, + resource: this.sampler + }, + { + binding: 1, + resource: srcView + } + ] + }); + passEncoder.setPipeline(pipeline); + passEncoder.setBindGroup(0, bindGroup); + passEncoder.draw(3, 1, 0, 0); + passEncoder.end(); + srcView = dstView; } } - if (!a) { - const e = { - width: Math.ceil(i.size.width / 2), - height: Math.ceil(i.size.height / 2), - depthOrArrayLayers: s + // If we didn't render to the source texture, finish by copying the mip results from the temporary mipmap texture + // to the source. + if (!renderToSource) { + const mipLevelSize = { + width: Math.ceil(textureDescriptor.size.width / 2), + height: Math.ceil(textureDescriptor.size.height / 2), + depthOrArrayLayers: arrayLayerCount }; - for (let r = 1; r < i.mipLevelCount; ++r) - o.copyTextureToTexture({ texture: n, mipLevel: r - 1 }, { texture: t, mipLevel: r }, e), - (e.width = Math.ceil(e.width / 2)), - (e.height = Math.ceil(e.height / 2)); - } - return this.device.queue.submit([o.finish()]), a || n.destroy(), t; - } -} -function ee(e, t) { - return null != e ? e : t; -} -ee.EMPTY_OBJECT = Object.freeze({}); -class te { - constructor(e) { - (this.scissorTest = e?.scissorTest), - (this.viewport = e?.viewport), - (this.depthStencil = e?.depthStencil), - (this.blendConstant = e?.blendConstant), - (this.stencilReference = e?.stencilReference), - (this.multisample = e?.multisample), - (this.primitive = e?.primitive), - (this.stencilEnabled = !1), - (this.scissorTestEnabled = !1), - (this.targets = e?.targets); - } - bind(e) { - const { passEncoder: t, viewPort: i, scissorTest: r } = e, - n = this.viewport ?? i, - s = this.scissorTest ?? r; - if ((this.stencilReference && t.setStencilReference(this.stencilReference), n?.equalsAndUpdateCache(le))) { - const { x: e, y: i, width: r, height: s, minDepth: a, maxDepth: o } = n; - t.setViewport(e, i, r, s, a, o); - } - if ((this.blendConstant && t.setBlendConstant(this.blendConstant), s?.equalsAndUpdateCache(he))) { - const { x: e, y: i, width: r, height: n } = s; - t.setScissorRect(e, i, r, n); + for (let i = 1; i < textureDescriptor.mipLevelCount; ++i) { + commandEncoder.copyTextureToTexture( + { + texture: mipTexture, + mipLevel: i - 1 + }, + { + texture: texture, + mipLevel: i + }, + mipLevelSize + ); + mipLevelSize.width = Math.ceil(mipLevelSize.width / 2); + mipLevelSize.height = Math.ceil(mipLevelSize.height / 2); + } } - } - destroy() { - (this.scissorTest = void 0), - (this.viewport = void 0), - (this.depthStencil = void 0), - (this.blendConstant = void 0), - (this.stencilReference = -1), - (this.multisample = void 0), - (this.primitive = void 0), - (this.stencilEnabled = !1), - (this.scissorTestEnabled = !1); + this.device.queue.submit([commandEncoder.finish()]); + if (!renderToSource) { + mipTexture.destroy(); + } + return texture; } } -class ie { - constructor(e, t, i, r) { - (this.r = e), (this.g = t), (this.b = i), (this.a = r); + +function defaultValue(a, b) { + if (a !== undefined && a !== null) { + return a; } + return b; } -class re { - constructor(e = 1, t = 4294967295, i = !1) { - (this.count = e), (this.mask = t), (this.alphaToCoverageEnabled = i); +/** + * A frozen empty object that can be used as the default value for options passed as + * an object literal. + * @type {Object} + * @memberof defaultValue + */ +defaultValue.EMPTY_OBJECT = Object.freeze({}); + +class RenderState { + constructor(params) { + this.scissorTest = params?.scissorTest; + this.viewport = params?.viewport; + this.depthStencil = params?.depthStencil; + this.blendConstant = params?.blendConstant; + this.stencilReference = params?.stencilReference; + this.multisample = params?.multisample; + this.primitive = params?.primitive; + this.stencilEnabled = false; + this.scissorTestEnabled = false; + this.targets = params?.targets; + } + bind(params) { + const { passEncoder, viewPort, scissorTest } = params; + const finalViewport = this.viewport ?? viewPort; + const finalScissorTest = this.scissorTest ?? scissorTest; + if (this.stencilReference) passEncoder.setStencilReference(this.stencilReference); + if (finalViewport?.equalsAndUpdateCache(cacheViewPort)) { + const { x, y, width, height, minDepth, maxDepth } = finalViewport; + passEncoder.setViewport(x, y, width, height, minDepth, maxDepth); + } + if (this.blendConstant) passEncoder.setBlendConstant(this.blendConstant); + if (finalScissorTest?.equalsAndUpdateCache(cacheScissorTest)) { + const { x, y, width, height } = finalScissorTest; + passEncoder.setScissorRect(x, y, width, height); + } } - getMultiSampleDec() { - return { count: this.count, mask: this.mask, alphaToCoverageEnabled: this.alphaToCoverageEnabled }; + destroy() { + this.scissorTest = undefined; + this.viewport = undefined; + this.depthStencil = undefined; + this.blendConstant = undefined; + this.stencilReference = -1; + this.multisample = undefined; + this.primitive = undefined; + this.stencilEnabled = false; + this.scissorTestEnabled = false; } } -class ne { - constructor(e = 0, t = 0, i = 0, r = 0, n = !0) { - (this.x = e), (this.y = t), (this.width = i), (this.height = r), (this.variable = n); +class BlendConstant { + constructor(r, g, b, a) { + this.r = r; + this.g = g; + this.b = b; + this.a = a; } - set(e, t, i, r) { - (this.x = e), (this.y = t), (this.width = i), (this.height = r); +} +class MultiSample { + constructor(count = 1, mask = 0xffffffff, alphaToCoverageEnabled = false) { + this.count = count; + this.mask = mask; + this.alphaToCoverageEnabled = alphaToCoverageEnabled; } - equalsAndUpdateCache(e) { - const { x: t, y: i, width: r, height: n } = e; - return ( - (this.x != t || this.y != i || this.width != r || this.height != n) && - (e.set(this.x, this.y, this.width, this.height), !0) - ); + getMultiSampleDec() { + return { + count: this.count, + mask: this.mask, + alphaToCoverageEnabled: this.alphaToCoverageEnabled + }; } } -class se { - constructor(e = 0, t = 0, i = 0, r = 0, n = 0, s = 1, a = !0) { - (this.x = e), - (this.y = t), - (this.width = i), - (this.height = r), - (this.minDepth = n), - (this.maxDepth = s), - (this.variable = a); - } - set(e, t, i, r, n = 0, s = 1) { - this.variable && - ((this.x = e), (this.y = t), (this.width = i), (this.height = r), (this.minDepth = n), (this.maxDepth = s)); +class ScissorTest { + constructor(x = 0, y = 0, width = 0, height = 0, variable = true) { + this.x = x; + this.y = y; + this.width = width; + this.height = height; + this.variable = variable; + } + set(x, y, width, height) { + this.x = x; + this.y = y; + this.width = width; + this.height = height; + } + equalsAndUpdateCache(scissorTest) { + const { x, y, width, height } = scissorTest; + if (this.x != x || this.y != y || this.width != width || this.height != height) { + scissorTest.set(this.x, this.y, this.width, this.height); + return true; + } + return false; } - equalsAndUpdateCache(e) { - const { x: t, y: i, width: r, height: n, minDepth: s, maxDepth: a } = e; - return ( - (this.x != t || - this.y != i || - this.width != r || - this.height != n || - this.minDepth != s || - this.maxDepth != a) && - (e.set(this.x, this.y, this.width, this.height, this.minDepth, this.maxDepth), !0) - ); +} +class ViewPort { + constructor(x = 0, y = 0, width = 0, height = 0, minDepth = 0, maxDepth = 1, variable = true) { + this.x = x; + this.y = y; + this.width = width; + this.height = height; + this.minDepth = minDepth; + this.maxDepth = maxDepth; + this.variable = variable; + } + set(x, y, width, height, minDepth = 0, maxDepth = 1) { + if (!this.variable) return; + this.x = x; + this.y = y; + this.width = width; + this.height = height; + this.minDepth = minDepth; + this.maxDepth = maxDepth; + } + equalsAndUpdateCache(viewPort) { + const { x, y, width, height, minDepth, maxDepth } = viewPort; + if ( + this.x != x || + this.y != y || + this.width != width || + this.height != height || + this.minDepth != minDepth || + this.maxDepth != maxDepth + ) { + viewPort.set(this.x, this.y, this.width, this.height, this.minDepth, this.maxDepth); + return true; + } + return false; } } -class ae { - constructor(e, t, i, r) { - (this.frontFace = ee(i, b.CCW)), - (this.cullMode = ee(t, w.None)), - (this.unclippedDepth = ee(r, !1)), - (this.topology = ee(e, S.TriangleList)); +class Primitive { + constructor(topology, cullMode, frontFace, unclippedDepth) { + this.frontFace = defaultValue(frontFace, FrontFace.CCW); + this.cullMode = defaultValue(cullMode, CullMode.None); + this.unclippedDepth = defaultValue(unclippedDepth, false); + this.topology = defaultValue(topology, PrimitiveTopology.TriangleList); } getGPUPrimitiveDec() { return { @@ -801,24 +1085,24 @@ class ae { }; } } -class oe { - constructor(e) { - (this.format = ee(e?.format, l.Depth24Plus)), - (this.depthWriteEnabled = ee(e?.depthWriteEnabled, !0)), - (this.depthCompare = ee(e?.depthCompare, f.Less)), - (this.stencilReadMask = ee(e?.stencilReadMask, 4294967295)), - (this.stencilWriteMask = ee(e?.stencilWriteMask, 4294967295)), - (this.stencilFrontCompare = ee(e?.stencilFrontCompare, f.Always)), - (this.stencilFrontFailOp = ee(e?.stencilFrontFailOp, U.Keep)), - (this.stencilFrontDepthFailOp = ee(e?.stencilFrontDepthFailOp, U.Keep)), - (this.stencilFrontPassOp = ee(e?.stencilFrontPassOp, U.Keep)), - (this.stencilBackCompare = ee(e?.stencilBackCompare, f.Always)), - (this.stencilBackFailOp = ee(e?.stencilBackFailOp, U.Keep)), - (this.stencilBackDepthFailOp = ee(e?.stencilBackDepthFailOp, U.Keep)), - (this.stencilBackPassOp = ee(e?.stencilBackPassOp, U.Keep)), - (this.depthBias = ee(e?.depthBias, 0)), - (this.depthBiasSlopeScale = ee(e?.depthBiasSlopeScale, 0)), - (this.depthBiasClamp = ee(e?.depthBiasClamp, 0)); +class DepthStencil { + constructor(options) { + this.format = defaultValue(options?.format, TextureFormat.Depth24Plus); + this.depthWriteEnabled = defaultValue(options?.depthWriteEnabled, true); + this.depthCompare = defaultValue(options?.depthCompare, CompareFunction.Less); + this.stencilReadMask = defaultValue(options?.stencilReadMask, 0xffffffff); + this.stencilWriteMask = defaultValue(options?.stencilWriteMask, 0xffffffff); + this.stencilFrontCompare = defaultValue(options?.stencilFrontCompare, CompareFunction.Always); + this.stencilFrontFailOp = defaultValue(options?.stencilFrontFailOp, StencilOperation.Keep); + this.stencilFrontDepthFailOp = defaultValue(options?.stencilFrontDepthFailOp, StencilOperation.Keep); + this.stencilFrontPassOp = defaultValue(options?.stencilFrontPassOp, StencilOperation.Keep); + this.stencilBackCompare = defaultValue(options?.stencilBackCompare, CompareFunction.Always); + this.stencilBackFailOp = defaultValue(options?.stencilBackFailOp, StencilOperation.Keep); + this.stencilBackDepthFailOp = defaultValue(options?.stencilBackDepthFailOp, StencilOperation.Keep); + this.stencilBackPassOp = defaultValue(options?.stencilBackPassOp, StencilOperation.Keep); + this.depthBias = defaultValue(options?.depthBias, 0); + this.depthBiasSlopeScale = defaultValue(options?.depthBiasSlopeScale, 0); + this.depthBiasClamp = defaultValue(options?.depthBiasClamp, 0); } getGPUDepthStencilDec() { return { @@ -845,16 +1129,16 @@ class oe { }; } } -class ce { - constructor(e) { - (this.format = ee(e?.format, l.BGRA8Unorm)), - (this.blendColorOperation = ee(e?.blendColorOperation, M.Add)), - (this.blendColorSrcFactor = ee(e?.blendColorSrcFactor, E?.SrcAlpha)), - (this.blendColorDstFactor = ee(e?.blendColorDstFactor, E.OneMinusSrcAlpha)), - (this.blendAlphaOperation = ee(e?.blendAlphaOperation, M.Add)), - (this.blendAlphaSrcFactor = ee(e?.blendAlphaSrcFactor, E.One)), - (this.blendAlphaDstFactor = ee(e?.blendAlphaDstFactor, E.One)), - (this.writeMask = ee(e?.writeMask, O.All)); +class Target { + constructor(options) { + this.format = defaultValue(options?.format, TextureFormat.BGRA8Unorm); + this.blendColorOperation = defaultValue(options?.blendColorOperation, BlendOperation.Add); + this.blendColorSrcFactor = defaultValue(options?.blendColorSrcFactor, BlendFactor?.SrcAlpha); + this.blendColorDstFactor = defaultValue(options?.blendColorDstFactor, BlendFactor.OneMinusSrcAlpha); + this.blendAlphaOperation = defaultValue(options?.blendAlphaOperation, BlendOperation.Add); + this.blendAlphaSrcFactor = defaultValue(options?.blendAlphaSrcFactor, BlendFactor.One); + this.blendAlphaDstFactor = defaultValue(options?.blendAlphaDstFactor, BlendFactor.One); + this.writeMask = defaultValue(options?.writeMask, GPUColorWrite.All); } getGPUTargetDec() { return { @@ -875,192 +1159,239 @@ class ce { }; } } -const le = new se(), - he = new ne(); -class ue { +const cacheViewPort = new ViewPort(); +const cacheScissorTest = new ScissorTest(); + +class Context { get viewPort() { return this._viewPort; } get scissorTest() { return this._scissorTest; } - constructor({ canvas: e, container: t, context: i, pixelRatio: r } = {}) { - if (!t.clientWidth || !t.clientHeight) throw new Error("container width or height illegality"); - (this.canvas = e || document.createElement("canvas")), (this.pixelRatio = r || window.devicePixelRatio || 1); - const n = t.clientWidth * this.pixelRatio, - s = t.clientHeight * this.pixelRatio; - (this.canvas.width = n), - (this.canvas.height = s), - (this.canvas.style.width = t.clientWidth + "px"), - (this.canvas.style.height = t.clientHeight + "px"), - t.appendChild(this.canvas), - (this.context = i || this.canvas.getContext("webgpu")), - (this.device = void 0); - } - async init(e = {}, t = {}, i = {}) { + constructor({ canvas, container, context, pixelRatio } = {}) { + if (!container.clientWidth || !container.clientHeight) throw new Error("container width or height illegality"); + this.canvas = canvas || document.createElement("canvas"); + // this.canvas.style.display = "block"; + this.pixelRatio = pixelRatio || window.devicePixelRatio || 1; + const width = container.clientWidth * this.pixelRatio; + const height = container.clientHeight * this.pixelRatio; + this.canvas.width = width; + this.canvas.height = height; + this.canvas.style.width = container.clientWidth + "px"; + this.canvas.style.height = container.clientHeight + "px"; + container.appendChild(this.canvas); + this.context = context || this.canvas.getContext("webgpu"); + this.device = undefined; + } + async init(requestAdapter = {}, deviceDescriptor = {}, presentationContextDescriptor = {}) { try { - if (!this.context) throw new Error('Failed to instantiate "webgpu" context.'); - if (!navigator.gpu) throw new Error('Missing "navigator.gpu".'); - (this.adapter = await navigator.gpu.requestAdapter()), - (this.device = await this.adapter.requestDevice()), - (this.presentationSize = { - width: this.canvas.clientWidth * this.pixelRatio, - height: this.canvas.clientHeight * this.pixelRatio, - depth: 1 - }), - (this.presentationFormat = navigator.gpu.getPreferredCanvasFormat()), - this.device.addEventListener("uncapturederror", (e) => { - console.error(e); - }), - (this.mipmapTools = new J(this.device)), - this.context.configure({ - device: this.device, - format: this.presentationFormat, - usage: a.RenderAttachment, - alphaMode: "premultiplied", - ...i - }), - (this._viewPort = new se( - 0, - 0, - this.canvas.clientWidth * this.pixelRatio, - this.canvas.clientHeight * this.pixelRatio - )), - (this._scissorTest = new ne( - 0, - 0, - this.canvas.clientWidth * this.pixelRatio, - this.canvas.clientHeight * this.pixelRatio - )); - } catch (e) { - return console.error(e), !1; + if (!this.context) { + throw new Error(`Failed to instantiate "webgpu" context.`); + } + if (!navigator.gpu) { + throw new Error(`Missing "navigator.gpu".`); + } + this.adapter = await navigator.gpu.requestAdapter(); + this.device = await this.adapter.requestDevice(); + this.presentationSize = { + width: this.canvas.clientWidth * this.pixelRatio, + height: this.canvas.clientHeight * this.pixelRatio, + depth: 1 + }; + this.presentationFormat = navigator.gpu.getPreferredCanvasFormat(); + this.device.addEventListener("uncapturederror", (error) => { + console.error(error); + // State.error = true; + }); + this.mipmapTools = new MipmapGenerator(this.device); + this.context.configure({ + device: this.device, + format: this.presentationFormat, + usage: TextureUsage.RenderAttachment, + alphaMode: "premultiplied", + ...presentationContextDescriptor + }); + this._viewPort = new ViewPort( + 0, + 0, + this.canvas.clientWidth * this.pixelRatio, + this.canvas.clientHeight * this.pixelRatio + ); + this._scissorTest = new ScissorTest( + 0, + 0, + this.canvas.clientWidth * this.pixelRatio, + this.canvas.clientHeight * this.pixelRatio + ); + } catch (error) { + console.error(error); + return false; } - return !0; + return true; } - setViewPort(e, t, i, r) { - this._viewPort.set(e, t, i, r); + setViewPort(x, y, width, height) { + this._viewPort.set(x, y, width, height); } resetViewPortToFullCanvas() { this._viewPort.set(0, 0, this.canvas.clientWidth * this.pixelRatio, this.canvas.clientHeight * this.pixelRatio); } - setScissorTest(e, t, i, r) { - this._scissorTest.set(e, t, i, r); - } - resize(e, t, i = {}) { - const r = e * this.pixelRatio, - n = t * this.pixelRatio; - (this.canvas.style.width = r + "px"), - (this.canvas.style.height = n + "px"), - (this.canvas.width = r), - (this.canvas.height = n), - (this.presentationSize = { width: r, height: n, depth: 1 }), - this.context.configure({ - device: this.device, - format: navigator.gpu.getPreferredCanvasFormat(), - usage: a.RenderAttachment, - alphaMode: W, - ...i - }); + setScissorTest(x, y, width, height) { + this._scissorTest.set(x, y, width, height); + } + resize(width, height, presentationContextDescriptor = {}) { + const w = width * this.pixelRatio; + const h = height * this.pixelRatio; + this.canvas.style.width = w + "px"; + this.canvas.style.height = h + "px"; + this.canvas.width = w; + this.canvas.height = h; + this.presentationSize = { + width: w, + height: h, + depth: 1 + }; + this.context.configure({ + device: this.device, + format: navigator.gpu.getPreferredCanvasFormat(), + usage: TextureUsage.RenderAttachment, + alphaMode: GPUCanvasCompositingAlphaMode.Premultiplied, + ...presentationContextDescriptor + }); } } -class fe { - constructor(e) { - (this.textureProp = Object.assign( + +class Texture { + constructor(textureProp) { + this.textureProp = Object.assign( { - format: l.RGBA8Unorm, + format: TextureFormat.RGBA8Unorm, usage: GPUTextureUsage.TEXTURE_BINDING | GPUTextureUsage.COPY_DST | GPUTextureUsage.RENDER_ATTACHMENT, - dataIsTexture: !1 + dataIsTexture: false }, - e - )), - (this.dirty = !0), - (this.fixedSize = e.fixedSize || !1); + textureProp + ); + this.dirty = true; + this.fixedSize = textureProp.fixedSize || false; } get layoutType() { - const { viewFormats: e, sampleType: t, sampleCount: i } = this.textureProp; - return { sampleType: ee(t, "float"), viewDimension: ee(e, "2d"), multisampled: !!(i && i > 1) }; + const { viewFormats, sampleType, sampleCount } = this.textureProp; + // const + return { + sampleType: defaultValue(sampleType, "float"), + viewDimension: defaultValue(viewFormats, "2d"), + multisampled: sampleCount && sampleCount > 1 ? true : false + }; } get storageTextureLayoutType() { - const { access: e = x.WriteOnly, viewFormats: t, format: i } = this.textureProp; - return { viewDimension: ee(t, "2d"), access: e, format: i }; + const { access = StorageTextureAccess.WriteOnly, viewFormats, format } = this.textureProp; + return { + viewDimension: defaultValue(viewFormats, "2d"), + access, + format + }; } get textureView() { - return ( - this._textureView || - (this._textureView = this.gpuTexture.createView({ dimension: ee(this.textureProp.viewFormats, "2d") })), - this._textureView - ); + if (!this._textureView) + this._textureView = this.gpuTexture.createView({ + dimension: defaultValue(this.textureProp.viewFormats, "2d") + }); + return this._textureView; + } + update(device) { + if (!this.device) this.device = device; + if (this.dirty) { + this.checkNeedCreateTexture(); + this.dirty = false; + if (this.textureProp.data) { + if (Array.isArray(this.textureProp.data)) { + this.textureProp.data.forEach((imageData) => { + this.setData(imageData); + }); + } else { + this.setData(this.textureProp.data); + } + } + if (this.textureProp.needMipMap) { + if (!Texture.mipmapTools) Texture.mipmapTools = new MipmapGenerator(this.device); + this.gpuTexture = Texture.mipmapTools.generateMipmap(this); + } + } } - update(e) { - this.device || (this.device = e), - this.dirty && - (this.checkNeedCreateTexture(), - (this.dirty = !1), - this.textureProp.data && - (Array.isArray(this.textureProp.data) - ? this.textureProp.data.forEach((e) => { - this.setData(e); - }) - : this.setData(this.textureProp.data)), - this.textureProp.needMipMap && - (fe.mipmapTools || (fe.mipmapTools = new J(this.device)), - (this.gpuTexture = fe.mipmapTools.generateMipmap(this)))); - } - setData(e) { + setData(options) { const { - source: t, - width: i = e.source.width, - height: r = e.source.height, - depth: n = 1, - sourceX: s = 0, - sourceY: a = 0, - mipLevel: o = 0, - x: c = 0, - y: l = 0, - z: h = 0, - aspect: u = "all", - colorSpace: f = "srgb", - premultipliedAlpha: d = !1 - } = e; - if (t instanceof fe) { - let e = this.device.createCommandEncoder(); - e.copyTextureToTexture( - { texture: t.gpuTexture, origin: [s, a] }, - { texture: this.gpuTexture, origin: { x: 0, y: 0, z: h }, mipLevel: o }, - { width: i, height: r, depthOrArrayLayers: 1 } - ), - this.device.queue.submit([e.finish()]), - (e = null); - } else + source, + width = options.source.width, + height = options.source.height, + depth = 1, + sourceX = 0, + sourceY = 0, + mipLevel = 0, + x = 0, + y = 0, + z = 0, + aspect = "all", + colorSpace = "srgb", + premultipliedAlpha = false + } = options; + if (source instanceof Texture) { + let commandEncoder = this.device.createCommandEncoder(); + commandEncoder.copyTextureToTexture( + { + texture: source.gpuTexture, + origin: [sourceX, sourceY] + // aspect + }, + { + texture: this.gpuTexture, + origin: { x: 0, y: 0, z }, + mipLevel + // aspect + }, + { + width, + height, + depthOrArrayLayers: 1 + } + ); + this.device.queue.submit([commandEncoder.finish()]); + commandEncoder = null; + } else { this.device.queue.copyExternalImageToTexture( - { source: t, origin: [s, a] }, + { + source, + origin: [sourceX, sourceY] + }, { texture: this.gpuTexture, - origin: [c, l, h], - mipLevel: o, - aspect: u, - colorSpace: f, - premultipliedAlpha: d + origin: [x, y, z], + mipLevel, + aspect, + colorSpace, + premultipliedAlpha }, - [i, r, n] + [width, height, depth] ); + } } - setSize(e, t, i) { - this.fixedSize || - ((this.textureProp.size.width = e), - (this.textureProp.size.height = t), - i && (this.textureProp.size.depth = i), - (this.dirty = !0)); + setSize(width, height, depth) { + if (this.fixedSize) return; + this.textureProp.size.width = width; + this.textureProp.size.height = height; + if (depth) this.textureProp.size.depth = depth; + this.dirty = true; } destroy() { this.gpuTexture.destroy(); } createGPUTexture() { - if ("number" == typeof this.textureProp.format) throw new Error("number format"); - const { width: e, height: t, depth: i } = this.textureProp.size; + if (typeof this.textureProp.format === "number") { + throw new Error("number format"); + } + const { width, height, depth } = this.textureProp.size; return this.device.createTexture({ label: this.textureProp?.label || "undefined", - size: [e, t, i], + size: [width, height, depth], dimension: this.textureProp.dimension || "2d", format: this.textureProp.format, usage: this.textureProp.usage, @@ -1069,3502 +1400,4804 @@ class fe { }); } checkNeedCreateTexture() { - const { width: e, height: t, depth: i } = this.textureProp.size; - this.gpuTexture - ? (e == this.gpuTexture.width && t == this.gpuTexture.height) || - ((this._textureView = void 0), this.gpuTexture.destroy(), (this.gpuTexture = this.createGPUTexture())) - : (this.gpuTexture = this.createGPUTexture()); - } -} -class de { - constructor(e, t = { type: "filtering" }) { - (this.descriptor = e), - (this.descriptor = {}), - Object.assign( - this.descriptor, - { - magFilter: "linear", - minFilter: "linear", - addressModeU: "clamp-to-edge", - addressModeV: "clamp-to-edge" - }, - e - ), - (this.layoutType = t); - } - update(e) { - this.gpuSampler || (this.gpuSampler = e.createSampler(this.descriptor)); - } -} -de.baseSampler = new de({ magFilter: "linear", minFilter: "linear" }); -class me { - constructor(e, t) { - (this.value = e), (this.op = "clear"), (this.storeOp = "store"), Object.assign(this, t); + const { width, height, depth } = this.textureProp.size; + if (this.gpuTexture) { + if (width != this.gpuTexture.width || height != this.gpuTexture.height) { + this._textureView = undefined; + this.gpuTexture.destroy(); + this.gpuTexture = this.createGPUTexture(); + } + } else { + this.gpuTexture = this.createGPUTexture(); + } } } -function pe(e) { - return null != e; -} -var ge = function (e) { - null == e && (e = new Date().getTime()), - (this.N = 624), - (this.M = 397), - (this.MATRIX_A = 2567483615), - (this.UPPER_MASK = 2147483648), - (this.LOWER_MASK = 2147483647), - (this.mt = new Array(this.N)), - (this.mti = this.N + 1), - e.constructor == Array ? this.init_by_array(e, e.length) : this.init_seed(e); -}; -(ge.prototype.init_seed = function (e) { - for (this.mt[0] = e >>> 0, this.mti = 1; this.mti < this.N; this.mti++) { - e = this.mt[this.mti - 1] ^ (this.mt[this.mti - 1] >>> 30); - (this.mt[this.mti] = ((1812433253 * ((4294901760 & e) >>> 16)) << 16) + 1812433253 * (65535 & e) + this.mti), - (this.mt[this.mti] >>>= 0); - } -}), - (ge.prototype.init_by_array = function (e, t) { - var i, r, n; - for (this.init_seed(19650218), i = 1, r = 0, n = this.N > t ? this.N : t; n; n--) { - var s = this.mt[i - 1] ^ (this.mt[i - 1] >>> 30); - (this.mt[i] = - (this.mt[i] ^ (((1664525 * ((4294901760 & s) >>> 16)) << 16) + 1664525 * (65535 & s))) + e[r] + r), - (this.mt[i] >>>= 0), - r++, - ++i >= this.N && ((this.mt[0] = this.mt[this.N - 1]), (i = 1)), - r >= t && (r = 0); - } - for (n = this.N - 1; n; n--) { - s = this.mt[i - 1] ^ (this.mt[i - 1] >>> 30); - (this.mt[i] = - (this.mt[i] ^ (((1566083941 * ((4294901760 & s) >>> 16)) << 16) + 1566083941 * (65535 & s))) - i), - (this.mt[i] >>>= 0), - ++i >= this.N && ((this.mt[0] = this.mt[this.N - 1]), (i = 1)); - } - this.mt[0] = 2147483648; - }), - (ge.prototype.random_int = function () { - var e, - t = new Array(0, this.MATRIX_A); - if (this.mti >= this.N) { - var i; - for (this.mti == this.N + 1 && this.init_seed(5489), i = 0; i < this.N - this.M; i++) - (e = (this.mt[i] & this.UPPER_MASK) | (this.mt[i + 1] & this.LOWER_MASK)), - (this.mt[i] = this.mt[i + this.M] ^ (e >>> 1) ^ t[1 & e]); - for (; i < this.N - 1; i++) - (e = (this.mt[i] & this.UPPER_MASK) | (this.mt[i + 1] & this.LOWER_MASK)), - (this.mt[i] = this.mt[i + (this.M - this.N)] ^ (e >>> 1) ^ t[1 & e]); - (e = (this.mt[this.N - 1] & this.UPPER_MASK) | (this.mt[0] & this.LOWER_MASK)), - (this.mt[this.N - 1] = this.mt[this.M - 1] ^ (e >>> 1) ^ t[1 & e]), - (this.mti = 0); + +class Sampler { + constructor( + descriptor, + layoutType = { + type: "filtering" } - return ( - (e = this.mt[this.mti++]), - (e ^= e >>> 11), - (e ^= (e << 7) & 2636928640), - (e ^= (e << 15) & 4022730752), - (e ^= e >>> 18) >>> 0 - ); - }), - (ge.prototype.random_int31 = function () { - return this.random_int() >>> 1; - }), - (ge.prototype.random_incl = function () { - return this.random_int() * (1 / 4294967295); - }), - (ge.prototype.random = function () { - return this.random_int() * (1 / 4294967296); - }), - (ge.prototype.random_excl = function () { - return (this.random_int() + 0.5) * (1 / 4294967296); - }), - (ge.prototype.random_long = function () { - return (67108864 * (this.random_int() >>> 5) + (this.random_int() >>> 6)) * (1 / 9007199254740992); - }); -var xe = ge; -class ve { - static signNotZero(e) { - return e < 0 ? -1 : 1; - } - static toSNorm(e, t) { - return (t = ee(t, 255)), Math.round((0.5 * ve.clamp(e, -1, 1) + 0.5) * t); - } - static fromSNorm(e, t) { - return (t = ee(t, 255)), (ve.clamp(e, 0, t) / t) * 2 - 1; - } - static normalize(e, t, i) { - return 0 === (i = Math.max(i - t, 0)) ? 0 : ve.clamp((e - t) / i, 0, 1); - } - static lerp(e, t, i) { - return (1 - i) * e + i * t; - } - static toRadians(e) { - if (!pe(e)) throw new Error("degrees is required."); - return e * ve.RADIANS_PER_DEGREE; - } - static toDegrees(e) { - if (!pe(e)) throw new Error("radians is required."); - return e * ve.DEGREES_PER_RADIAN; - } - static negativePiToPi(e) { - if (!pe(e)) throw new Error("angle is required."); - return e >= -ve.PI && e <= ve.PI ? e : ve.zeroToTwoPi(e + ve.PI) - ve.PI; - } - static zeroToTwoPi(e) { - if (!pe(e)) throw new Error("angle is required."); - if (e >= 0 && e <= ve.TWO_PI) return e; - const t = ve.mod(e, ve.TWO_PI); - return Math.abs(t) < ve.EPSILON14 && Math.abs(e) > ve.EPSILON14 ? ve.TWO_PI : t; - } - static mod(e, t) { - if (!pe(e)) throw new Error("m is required."); - if (!pe(t)) throw new Error("n is required."); - if (0 === t) throw new Error("divisor cannot be 0."); - return ve.sign(e) === ve.sign(t) && Math.abs(e) < Math.abs(t) ? e : ((e % t) + t) % t; - } - static equalsEpsilon(e, t, i, r = i) { - if (!pe(e)) throw new Error("left is required."); - if (!pe(t)) throw new Error("right is required."); - (i = ee(i, 0)), (r = ee(r, i)); - const n = Math.abs(e - t); - return n <= r || n <= i * Math.max(Math.abs(e), Math.abs(t)); - } - static lessThan(e, t, i = 0) { - if (!pe(e)) throw new Error("first is required."); - if (!pe(t)) throw new Error("second is required."); - if (!pe(i)) throw new Error("absoluteEpsilon is required."); - return e - t < -i; - } - static lessThanOrEquals(e, t, i = 0) { - if (!pe(e)) throw new Error("first is required."); - if (!pe(t)) throw new Error("second is required."); - if (!pe(i)) throw new Error("absoluteEpsilon is required."); - return e - t < i; - } - static greaterThan(e, t, i = 0) { - if (!pe(e)) throw new Error("first is required."); - if (!pe(t)) throw new Error("second is required."); - if (!pe(i)) throw new Error("absoluteEpsilon is required."); - return e - t > i; - } - static greaterThanOrEquals(e, t, i = 0) { - if (!pe(e)) throw new Error("first is required."); - if (!pe(t)) throw new Error("second is required."); - if (!pe(i)) throw new Error("absoluteEpsilon is required."); - return e - t > -i; - } - static isPowerOfTwo(e) { - if ("number" != typeof e || e < 0 || e > 4294967295) - throw new Error("A number between 0 and (2^32)-1 is required."); - return 0 !== e && 0 == (e & (e - 1)); - } - static nextPowerOfTwo(e) { - if ("number" != typeof e || e < 0 || e > 2147483648) - throw new Error("A number between 0 and 2^31 is required."); - return --e, (e |= e >> 1), (e |= e >> 2), (e |= e >> 4), (e |= e >> 8), (e |= e >> 16), ++e; - } - static previousPowerOfTwo(e) { - if ("number" != typeof e || e < 0 || e > 4294967295) - throw new Error("A number between 0 and (2^32)-1 is required."); - return ( - (e |= e >> 1), - (e |= e >> 2), - (e |= e >> 4), - (e |= e >> 8), - (e |= e >> 16), - (e = ((e |= e >> 32) >>> 0) - (e >>> 1)) + ) { + this.descriptor = descriptor; + this.descriptor = {}; + Object.assign( + this.descriptor, + { + magFilter: "linear", + minFilter: "linear", + // mipmapFilter: "linear", + addressModeU: "clamp-to-edge", + addressModeV: "clamp-to-edge" + // addressModeW: "clamp-to-edge", + }, + descriptor ); + this.layoutType = layoutType; } - static clamp(e, t, i) { - return e < t ? t : e > i ? i : e; - } - static fog(e, t) { - const i = e * t; - return 1 - Math.exp(-i * i); - } -} -(ve.EPSILON1 = 0.1), - (ve.EPSILON2 = 0.01), - (ve.EPSILON3 = 0.001), - (ve.EPSILON4 = 1e-4), - (ve.EPSILON5 = 1e-5), - (ve.EPSILON6 = 1e-6), - (ve.EPSILON7 = 1e-7), - (ve.EPSILON8 = 1e-8), - (ve.EPSILON9 = 1e-9), - (ve.EPSILON10 = 1e-10), - (ve.EPSILON11 = 1e-11), - (ve.EPSILON12 = 1e-12), - (ve.EPSILON13 = 1e-13), - (ve.EPSILON14 = 1e-14), - (ve.EPSILON15 = 1e-15), - (ve.EPSILON16 = 1e-16), - (ve.EPSILON17 = 1e-17), - (ve.EPSILON18 = 1e-18), - (ve.EPSILON19 = 1e-19), - (ve.EPSILON20 = 1e-20), - (ve.EPSILON21 = 1e-21), - (ve.GRAVITATIONALPARAMETER = 3986004418e5), - (ve.SIXTY_FOUR_KILOBYTES = 65536), - (ve.FOUR_GIGABYTES = 4294967296), - (ve.sign = ee(Math.sign, function (e) { - return 0 === (e = +e) || e != e ? e : e > 0 ? 1 : -1; - })), - (ve.sinh = ee(Math.sinh, function (e) { - return (Math.exp(e) - Math.exp(-e)) / 2; - })), - (ve.cosh = ee(Math.cosh, function (e) { - return (Math.exp(e) + Math.exp(-e)) / 2; - })), - (ve.PI = Math.PI), - (ve.ONE_OVER_PI = 1 / Math.PI), - (ve.PI_OVER_TWO = Math.PI / 2), - (ve.PI_OVER_THREE = Math.PI / 3), - (ve.PI_OVER_FOUR = Math.PI / 4), - (ve.PI_OVER_SIX = Math.PI / 6), - (ve.THREE_PI_OVER_TWO = (3 * Math.PI) / 2), - (ve.TWO_PI = 2 * Math.PI), - (ve.ONE_OVER_TWO_PI = 1 / (2 * Math.PI)), - (ve.RADIANS_PER_DEGREE = Math.PI / 180), - (ve.DEGREES_PER_RADIAN = 180 / Math.PI), - (ve.RADIANS_PER_ARCSECOND = ve.RADIANS_PER_DEGREE / 3600), - (ve.nextRandomNumber = function () { - return ye.random(); - }), - (ve.randomBetween = function (e, t) { - return ve.nextRandomNumber() * (t - e) + e; - }), - (ve.acosClamped = function (e) { - if (!pe(e)) throw new Error("value is required."); - return Math.acos(ve.clamp(e, -1, 1)); - }), - (ve.asinClamped = function (e) { - if (!pe(e)) throw new Error("value is required."); - return Math.asin(ve.clamp(e, -1, 1)); - }), - (ve.chordLength = function (e, t) { - if (!pe(e)) throw new Error("angle is required."); - if (!pe(t)) throw new Error("radius is required."); - return 2 * t * Math.sin(0.5 * e); - }), - (ve.logBase = function (e, t) { - if (!pe(e)) throw new Error("number is required."); - if (!pe(t)) throw new Error("base is required."); - return Math.log(e) / Math.log(t); - }), - (ve.cbrt = ee(Math.cbrt, function (e) { - const t = Math.pow(Math.abs(e), 1 / 3); - return e < 0 ? -t : t; - })), - (ve.log2 = ee(Math.log2, function (e) { - return Math.log(e) * Math.LOG2E; - })); -const ye = new xe(); -class Se { - constructor(e = 0, t = 0) { - (this.x = e), (this.y = t), (this.x = e), (this.y = t); - } - set(e, t) { - return (this.x = e), (this.y = t), this; + update(device) { + if (!this.gpuSampler) this.gpuSampler = device.createSampler(this.descriptor); } - toArray() { - return [this.x, this.y]; +} +Sampler.baseSampler = new Sampler({ + magFilter: "linear", + minFilter: "linear" +}); + +class Attachment { + constructor(value, options) { + this.value = value; + this.op = "clear"; + this.storeOp = "store"; + Object.assign(this, options); } - clone(e) { - return Se.clone(this, e); +} + +function defined(value) { + return value !== undefined && value !== null; +} + +/* + https://github.com/banksean wrapped Makoto Matsumoto and Takuji Nishimura's code in a namespace + so it's better encapsulated. Now you can have multiple random number generators + and they won't stomp all over eachother's state. + + If you want to use this as a substitute for Math.random(), use the random() + method like so: + + var m = new MersenneTwister(); + var randomNumber = m.random(); + + You can also call the other genrand_{foo}() methods on the instance. + + If you want to use a specific seed in order to get a repeatable random + sequence, pass an integer into the constructor: + + var m = new MersenneTwister(123); + + and that will always produce the same random sequence. + + Sean McCullough (banksean@gmail.com) +*/ + +/* + A C-program for MT19937, with initialization improved 2002/1/26. + Coded by Takuji Nishimura and Makoto Matsumoto. + + Before using, initialize the state by using init_seed(seed) + or init_by_array(init_key, key_length). + + Copyright (C) 1997 - 2002, Makoto Matsumoto and Takuji Nishimura, + All rights reserved. + + Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions + are met: + + 1. Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. + + 2. Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. + + 3. The names of its contributors may not be used to endorse or promote + products derived from this software without specific prior written + permission. + + THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS + "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT + LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR + A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR + CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, + EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, + PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR + PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF + LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING + NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS + SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + + + Any feedback is very welcome. + http://www.math.sci.hiroshima-u.ac.jp/~m-mat/MT/emt.html + email: m-mat @ math.sci.hiroshima-u.ac.jp (remove space) +*/ + +var MersenneTwister = function (seed) { + if (seed == undefined) { + seed = new Date().getTime(); } - equals(e) { - return Se.equals(this, e); + + /* Period parameters */ + this.N = 624; + this.M = 397; + this.MATRIX_A = 0x9908b0df; /* constant vector a */ + this.UPPER_MASK = 0x80000000; /* most significant w-r bits */ + this.LOWER_MASK = 0x7fffffff; /* least significant r bits */ + + this.mt = new Array(this.N); /* the array for the state vector */ + this.mti = this.N + 1; /* mti==N+1 means mt[N] is not initialized */ + + if (seed.constructor == Array) { + this.init_by_array(seed, seed.length); + } else { + this.init_seed(seed); } - equalsEpsilon(e, t = 0, i = 0) { - return Se.equalsEpsilon(this, e, t, i); +}; + +/* initializes mt[N] with a seed */ +/* origin name init_genrand */ +MersenneTwister.prototype.init_seed = function (s) { + this.mt[0] = s >>> 0; + for (this.mti = 1; this.mti < this.N; this.mti++) { + var s = this.mt[this.mti - 1] ^ (this.mt[this.mti - 1] >>> 30); + this.mt[this.mti] = ((((s & 0xffff0000) >>> 16) * 1812433253) << 16) + (s & 0x0000ffff) * 1812433253 + this.mti; + /* See Knuth TAOCP Vol2. 3rd Ed. P.106 for multiplier. */ + /* In the previous versions, MSBs of the seed affect */ + /* only MSBs of the array mt[]. */ + /* 2002/01/09 modified by Makoto Matsumoto */ + this.mt[this.mti] >>>= 0; + /* for >32 bit machines */ } - toString() { - return `(${this.x}, ${this.y})`; +}; + +/* initialize by an array with array-length */ +/* init_key is the array for initializing keys */ +/* key_length is its length */ +/* slight change for C++, 2004/2/26 */ +MersenneTwister.prototype.init_by_array = function (init_key, key_length) { + var i, j, k; + this.init_seed(19650218); + i = 1; + j = 0; + k = this.N > key_length ? this.N : key_length; + for (; k; k--) { + var s = this.mt[i - 1] ^ (this.mt[i - 1] >>> 30); + this.mt[i] = + (this.mt[i] ^ (((((s & 0xffff0000) >>> 16) * 1664525) << 16) + (s & 0x0000ffff) * 1664525)) + + init_key[j] + + j; /* non linear */ + this.mt[i] >>>= 0; /* for WORDSIZE > 32 machines */ + i++; + j++; + if (i >= this.N) { + this.mt[0] = this.mt[this.N - 1]; + i = 1; + } + if (j >= key_length) j = 0; + } + for (k = this.N - 1; k; k--) { + var s = this.mt[i - 1] ^ (this.mt[i - 1] >>> 30); + this.mt[i] = + (this.mt[i] ^ (((((s & 0xffff0000) >>> 16) * 1566083941) << 16) + (s & 0x0000ffff) * 1566083941)) - + i; /* non linear */ + this.mt[i] >>>= 0; /* for WORDSIZE > 32 machines */ + i++; + if (i >= this.N) { + this.mt[0] = this.mt[this.N - 1]; + i = 1; + } } - fromBufferAttribute(e, t) { - return (this.x = e.getX(t)), (this.y = e.getY(t)), this; + + this.mt[0] = 0x80000000; /* MSB is 1; assuring non-zero initial array */ +}; + +/* generates a random number on [0,0xffffffff]-interval */ +/* origin name genrand_int32 */ +MersenneTwister.prototype.random_int = function () { + var y; + var mag01 = new Array(0x0, this.MATRIX_A); + /* mag01[x] = x * MATRIX_A for x=0,1 */ + + if (this.mti >= this.N) { + /* generate N words at one time */ + var kk; + + if (this.mti == this.N + 1) + /* if init_seed() has not been called, */ + this.init_seed(5489); /* a default initial seed is used */ + + for (kk = 0; kk < this.N - this.M; kk++) { + y = (this.mt[kk] & this.UPPER_MASK) | (this.mt[kk + 1] & this.LOWER_MASK); + this.mt[kk] = this.mt[kk + this.M] ^ (y >>> 1) ^ mag01[y & 0x1]; + } + for (; kk < this.N - 1; kk++) { + y = (this.mt[kk] & this.UPPER_MASK) | (this.mt[kk + 1] & this.LOWER_MASK); + this.mt[kk] = this.mt[kk + (this.M - this.N)] ^ (y >>> 1) ^ mag01[y & 0x1]; + } + y = (this.mt[this.N - 1] & this.UPPER_MASK) | (this.mt[0] & this.LOWER_MASK); + this.mt[this.N - 1] = this.mt[this.M - 1] ^ (y >>> 1) ^ mag01[y & 0x1]; + + this.mti = 0; } - applyMatrix3(e) { - const t = this.x, - i = this.y; - return (this.x = e[0] * t + e[3] * i + e[6]), (this.y = e[1] * t + e[4] * i + e[7]), this; + + y = this.mt[this.mti++]; + + /* Tempering */ + y ^= y >>> 11; + y ^= (y << 7) & 0x9d2c5680; + y ^= (y << 15) & 0xefc60000; + y ^= y >>> 18; + + return y >>> 0; +}; + +/* generates a random number on [0,0x7fffffff]-interval */ +/* origin name genrand_int31 */ +MersenneTwister.prototype.random_int31 = function () { + return this.random_int() >>> 1; +}; + +/* generates a random number on [0,1]-real-interval */ +/* origin name genrand_real1 */ +MersenneTwister.prototype.random_incl = function () { + return this.random_int() * (1.0 / 4294967295.0); + /* divided by 2^32-1 */ +}; + +/* generates a random number on [0,1)-real-interval */ +MersenneTwister.prototype.random = function () { + return this.random_int() * (1.0 / 4294967296.0); + /* divided by 2^32 */ +}; + +/* generates a random number on (0,1)-real-interval */ +/* origin name genrand_real3 */ +MersenneTwister.prototype.random_excl = function () { + return (this.random_int() + 0.5) * (1.0 / 4294967296.0); + /* divided by 2^32 */ +}; + +/* generates a random number on [0,1) with 53-bit resolution*/ +/* origin name genrand_res53 */ +MersenneTwister.prototype.random_long = function () { + var a = this.random_int() >>> 5, + b = this.random_int() >>> 6; + return (a * 67108864.0 + b) * (1.0 / 9007199254740992.0); +}; + +/* These real versions are due to Isaku Wada, 2002/01/09 added */ + +var mersenneTwister = MersenneTwister; + +class GMath { + static signNotZero(value) { + return value < 0.0 ? -1.0 : 1.0; } - static fromElements(e, t, i) { - return pe(i) ? ((i.x = e), (i.y = t), i) : new Se(e, t); + static toSNorm(value, rangeMaximum) { + rangeMaximum = defaultValue(rangeMaximum, 255); + return Math.round((GMath.clamp(value, -1.0, 1.0) * 0.5 + 0.5) * rangeMaximum); } - static clone(e, t) { - if (pe(e)) return pe(t) ? ((t.x = e.x), (t.y = e.y), t) : new Se(e.x, e.y); + static fromSNorm(value, rangeMaximum) { + rangeMaximum = defaultValue(rangeMaximum, 255); + return (GMath.clamp(value, 0.0, rangeMaximum) / rangeMaximum) * 2.0 - 1.0; } - static maximumComponent(e) { - return Math.max(e.x, e.y); + static normalize(value, rangeMinimum, rangeMaximum) { + rangeMaximum = Math.max(rangeMaximum - rangeMinimum, 0.0); + return rangeMaximum === 0.0 ? 0.0 : GMath.clamp((value - rangeMinimum) / rangeMaximum, 0.0, 1.0); } - static minimumComponent(e) { - return Math.min(e.x, e.y); + static lerp(p, q, time) { + return (1.0 - time) * p + time * q; } - static minimumByComponent(e, t, i) { - return (i.x = Math.min(e.x, t.x)), (i.y = Math.min(e.y, t.y)), i; + static toRadians(degrees) { + if (!defined(degrees)) { + throw new Error("degrees is required."); + } + return degrees * GMath.RADIANS_PER_DEGREE; } - static maximumByComponent(e, t, i) { - return (i.x = Math.max(e.x, t.x)), (i.y = Math.max(e.y, t.y)), i; + static toDegrees(radians) { + if (!defined(radians)) { + throw new Error("radians is required."); + } + return radians * GMath.DEGREES_PER_RADIAN; } - static clamp(e, t, i, r) { - const n = ve.clamp(e.x, t.x, i.x), - s = ve.clamp(e.y, t.y, i.y); - return (r.x = n), (r.y = s), r; + static negativePiToPi(angle) { + if (!defined(angle)) { + throw new Error("angle is required."); + } + if (angle >= -GMath.PI && angle <= GMath.PI) { + // Early exit if the input is already inside the range. This avoids + // unnecessary math which could introduce floating point error. + return angle; + } + return GMath.zeroToTwoPi(angle + GMath.PI) - GMath.PI; } - static magnitudeSquared(e) { - return e.x * e.x + e.y * e.y; + static zeroToTwoPi(angle) { + if (!defined(angle)) { + throw new Error("angle is required."); + } + if (angle >= 0 && angle <= GMath.TWO_PI) { + // Early exit if the input is already inside the range. This avoids + // unnecessary math which could introduce floating point error. + return angle; + } + const mod = GMath.mod(angle, GMath.TWO_PI); + if (Math.abs(mod) < GMath.EPSILON14 && Math.abs(angle) > GMath.EPSILON14) { + return GMath.TWO_PI; + } + return mod; } - static magnitude(e) { - return Math.sqrt(Se.magnitudeSquared(e)); + static mod(m, n) { + if (!defined(m)) { + throw new Error("m is required."); + } + if (!defined(n)) { + throw new Error("n is required."); + } + if (n === 0.0) { + throw new Error("divisor cannot be 0."); + } + if (GMath.sign(m) === GMath.sign(n) && Math.abs(m) < Math.abs(n)) { + // Early exit if the input does not need to be modded. This avoids + // unnecessary math which could introduce floating point error. + return m; + } + return ((m % n) + n) % n; } - static distance(e, t) { - return Se.subtract(e, t, be), Se.magnitude(be); + static equalsEpsilon(left, right, relativeEpsilon, absoluteEpsilon = relativeEpsilon) { + if (!defined(left)) { + throw new Error("left is required."); + } + if (!defined(right)) { + throw new Error("right is required."); + } + relativeEpsilon = defaultValue(relativeEpsilon, 0.0); + absoluteEpsilon = defaultValue(absoluteEpsilon, relativeEpsilon); + const absDiff = Math.abs(left - right); + return absDiff <= absoluteEpsilon || absDiff <= relativeEpsilon * Math.max(Math.abs(left), Math.abs(right)); + } + static lessThan(left, right, absoluteEpsilon = 0) { + if (!defined(left)) { + throw new Error("first is required."); + } + if (!defined(right)) { + throw new Error("second is required."); + } + if (!defined(absoluteEpsilon)) { + throw new Error("absoluteEpsilon is required."); + } + return left - right < -absoluteEpsilon; } - static distanceSquared(e, t) { - return Se.subtract(e, t, be), Se.magnitudeSquared(be); + static lessThanOrEquals(left, right, absoluteEpsilon = 0) { + if (!defined(left)) { + throw new Error("first is required."); + } + if (!defined(right)) { + throw new Error("second is required."); + } + if (!defined(absoluteEpsilon)) { + throw new Error("absoluteEpsilon is required."); + } + return left - right < absoluteEpsilon; } - static normalize(e, t) { - const i = Se.magnitude(e); - if (((t.x = e.x / i), (t.y = e.y / i), isNaN(t.x) || isNaN(t.y))) - throw new Error("normalized result is not a number"); - return t; - } - static dot(e, t) { - return e.x * t.x + e.y * t.y; - } - static cross(e, t) { - return e.x * t.y - e.y * t.x; - } - static multiplyComponents(e, t, i) { - return (i.x = e.x * t.x), (i.y = e.y * t.y), i; + static greaterThan(left, right, absoluteEpsilon = 0) { + if (!defined(left)) { + throw new Error("first is required."); + } + if (!defined(right)) { + throw new Error("second is required."); + } + if (!defined(absoluteEpsilon)) { + throw new Error("absoluteEpsilon is required."); + } + return left - right > absoluteEpsilon; } - static divideComponents(e, t, i) { - return (i.x = e.x / t.x), (i.y = e.y / t.y), i; + static greaterThanOrEquals(left, right, absoluteEpsilon = 0) { + if (!defined(left)) { + throw new Error("first is required."); + } + if (!defined(right)) { + throw new Error("second is required."); + } + if (!defined(absoluteEpsilon)) { + throw new Error("absoluteEpsilon is required."); + } + return left - right > -absoluteEpsilon; } - static add(e, t, i) { - return (i.x = e.x + t.x), (i.y = e.y + t.y), i; + static isPowerOfTwo(n) { + // >>includeStart('debug', pragmas.debug); + if (typeof n !== "number" || n < 0 || n > 4294967295) { + throw new Error("A number between 0 and (2^32)-1 is required."); + } + // >>includeEnd('debug'); + return n !== 0 && (n & (n - 1)) === 0; } - static subtract(e, t, i) { - return (i.x = e.x - t.x), (i.y = e.y - t.y), i; + static nextPowerOfTwo(n) { + if (typeof n !== "number" || n < 0 || n > 2147483648) { + throw new Error("A number between 0 and 2^31 is required."); + } + // From http://graphics.stanford.edu/~seander/bithacks.html#RoundUpPowerOf2 + --n; + n |= n >> 1; + n |= n >> 2; + n |= n >> 4; + n |= n >> 8; + n |= n >> 16; + ++n; + return n; } - static multiplyByScalar(e, t, i) { - return (i.x = e.x * t), (i.y = e.y * t), i; + static previousPowerOfTwo(n) { + if (typeof n !== "number" || n < 0 || n > 4294967295) { + throw new Error("A number between 0 and (2^32)-1 is required."); + } + n |= n >> 1; + n |= n >> 2; + n |= n >> 4; + n |= n >> 8; + n |= n >> 16; + n |= n >> 32; + // The previous bitwise operations implicitly convert to signed 32-bit. Use `>>>` to convert to unsigned + n = (n >>> 0) - (n >>> 1); + return n; } - static divideByScalar(e, t, i) { - return (i.x = e.x / t), (i.y = e.y / t), i; + static clamp(value, min, max) { + return value < min ? min : value > max ? max : value; } - static negate(e, t) { - return (t.x = -e.x), (t.y = -e.y), t; + /** + * @private + */ + static fog(distanceToCamera, density) { + const scalar = distanceToCamera * density; + return 1.0 - Math.exp(-(scalar * scalar)); } - static abs(e, t) { - return (t.x = Math.abs(e.x)), (t.y = Math.abs(e.y)), t; +} +GMath.EPSILON1 = 0.1; +GMath.EPSILON2 = 0.01; +GMath.EPSILON3 = 0.001; +GMath.EPSILON4 = 0.0001; +GMath.EPSILON5 = 0.00001; +GMath.EPSILON6 = 0.000001; +GMath.EPSILON7 = 0.0000001; +GMath.EPSILON8 = 0.00000001; +GMath.EPSILON9 = 0.000000001; +GMath.EPSILON10 = 0.0000000001; +GMath.EPSILON11 = 0.00000000001; +GMath.EPSILON12 = 0.000000000001; +GMath.EPSILON13 = 0.0000000000001; +GMath.EPSILON14 = 0.00000000000001; +GMath.EPSILON15 = 0.000000000000001; +GMath.EPSILON16 = 0.0000000000000001; +GMath.EPSILON17 = 0.00000000000000001; +GMath.EPSILON18 = 0.000000000000000001; +GMath.EPSILON19 = 0.0000000000000000001; +GMath.EPSILON20 = 0.00000000000000000001; +GMath.EPSILON21 = 0.000000000000000000001; +GMath.GRAVITATIONALPARAMETER = 3.986004418e14; +GMath.SIXTY_FOUR_KILOBYTES = 64 * 1024; +GMath.FOUR_GIGABYTES = 4 * 1024 * 1024 * 1024; +GMath.sign = defaultValue(Math.sign, function sign(value) { + value = +value; // coerce to number + if (value === 0 || value !== value) { + // zero or NaN + return value; + } + return value > 0 ? 1 : -1; +}); +GMath.sinh = defaultValue(Math.sinh, function sinh(value) { + return (Math.exp(value) - Math.exp(-value)) / 2.0; +}); +GMath.cosh = defaultValue(Math.cosh, function cosh(value) { + return (Math.exp(value) + Math.exp(-value)) / 2.0; +}); +GMath.PI = Math.PI; +GMath.ONE_OVER_PI = 1.0 / Math.PI; +GMath.PI_OVER_TWO = Math.PI / 2.0; +GMath.PI_OVER_THREE = Math.PI / 3.0; +GMath.PI_OVER_FOUR = Math.PI / 4.0; +GMath.PI_OVER_SIX = Math.PI / 6.0; +GMath.THREE_PI_OVER_TWO = (3.0 * Math.PI) / 2.0; +GMath.TWO_PI = 2.0 * Math.PI; +GMath.ONE_OVER_TWO_PI = 1.0 / (2.0 * Math.PI); +GMath.RADIANS_PER_DEGREE = Math.PI / 180.0; +GMath.DEGREES_PER_RADIAN = 180.0 / Math.PI; +GMath.RADIANS_PER_ARCSECOND = GMath.RADIANS_PER_DEGREE / 3600.0; +GMath.nextRandomNumber = function () { + return randomNumberGenerator.random(); +}; +GMath.randomBetween = function (min, max) { + return GMath.nextRandomNumber() * (max - min) + min; +}; +GMath.acosClamped = function (value) { + if (!defined(value)) { + throw new Error("value is required."); } - static lerp(e, t, i, r) { - return Se.multiplyByScalar(t, i, we), (r = Se.multiplyByScalar(e, 1 - i, r)), Se.add(we, r, r); + return Math.acos(GMath.clamp(value, -1.0, 1.0)); +}; +GMath.asinClamped = function (value) { + if (!defined(value)) { + throw new Error("value is required."); } - static angleBetween(e, t) { - return Se.normalize(e, Te), Se.normalize(t, Ee), ve.acosClamped(Se.dot(Te, Ee)); + return Math.asin(GMath.clamp(value, -1.0, 1.0)); +}; +GMath.chordLength = function (angle, radius) { + if (!defined(angle)) { + throw new Error("angle is required."); } - static mostOrthogonalAxis(e, t) { - const i = Se.normalize(e, Me); - return Se.abs(i, i), (t = i.x <= i.y ? Se.clone(Se.UNIT_X, t) : Se.clone(Se.UNIT_Y, t)); + if (!defined(radius)) { + throw new Error("radius is required."); } - static equals(e, t) { - return e === t || (pe(e) && pe(t) && e.x === t.x && e.y === t.y); + return 2.0 * radius * Math.sin(angle * 0.5); +}; +GMath.logBase = function (number, base) { + if (!defined(number)) { + throw new Error("number is required."); } - static equalsArray(e, t, i) { - return e.x === t[i] && e.y === t[i + 1]; + if (!defined(base)) { + throw new Error("base is required."); } - static equalsEpsilon(e, t, i = 0, r = 0) { - return e === t || (pe(e) && pe(t) && ve.equalsEpsilon(e.x, t.x, i, r) && ve.equalsEpsilon(e.y, t.y, i, r)); + return Math.log(number) / Math.log(base); +}; +GMath.cbrt = defaultValue(Math.cbrt, function cbrt(number) { + const result = Math.pow(Math.abs(number), 1.0 / 3.0); + return number < 0.0 ? -result : result; +}); +GMath.log2 = defaultValue(Math.log2, function log2(number) { + return Math.log(number) * Math.LOG2E; +}); +const randomNumberGenerator = new mersenneTwister(); + +/** + * A 2D Cartesian point. + * @alias Vector2 + * @constructor + * + * @param {Number} [x=0.0] The X component. + * @param {Number} [y=0.0] The Y component. + * + */ +class Vector2 { + constructor(x = 0.0, y = 0.0) { + this.x = x; + this.y = y; + this.x = x; + this.y = y; + } + set(x, y) { + this.x = x; + this.y = y; + return this; } -} -(Se.ZERO = Object.freeze(new Se(0, 0))), - (Se.ONE = Object.freeze(new Se(1, 1))), - (Se.UNIT_X = Object.freeze(new Se(1, 0))), - (Se.UNIT_Y = Object.freeze(new Se(0, 1))); -const be = new Se(), - we = new Se(), - Te = new Se(), - Ee = new Se(), - Me = new Se(); -class Ue { - constructor(e = 0, t = 0, i = 0) { - (this.x = e), (this.y = t), (this.z = i); + toArray() { + return [this.x, this.y]; } - set(e, t, i) { - return (this.x = e), (this.y = t), (this.z = i), this; + clone(result) { + return Vector2.clone(this, result); } - toArray() { - return [this.x, this.y, this.z]; + equals(right) { + return Vector2.equals(this, right); } - copy(e) { - return (this.x = e.x), (this.y = e.y), (this.z = e.z), this; - } - lerp(e, t) { - return Ue.lerp(this, e, t, this), this; - } - add(e) { - return Ue.add(this, e, this), this; - } - addScaledVector(e, t) { - return (this.x += e.x * t), (this.y += e.y * t), (this.z += e.z * t), this; - } - subtract(e) { - return Ue.subtract(this, e, this), this; - } - applyQuaternion(e) { - const t = this.x, - i = this.y, - r = this.z, - n = e.x, - s = e.y, - a = e.z, - o = e.w, - c = o * t + s * r - a * i, - l = o * i + a * t - n * r, - h = o * r + n * i - s * t, - u = -n * t - s * i - a * r; - return ( - (this.x = c * o + u * -n + l * -a - h * -s), - (this.y = l * o + u * -s + h * -n - c * -a), - (this.z = h * o + u * -a + c * -s - l * -n), - this - ); + equalsEpsilon(right, relativeEpsilon = 0, absoluteEpsilon = 0) { + return Vector2.equalsEpsilon(this, right, relativeEpsilon, absoluteEpsilon); } - setFromMatrixColumn(e, t) { - return this.fromArray(e, 4 * t); + toString() { + return `(${this.x}, ${this.y})`; } - fromArray(e, t = 0) { - return (this.x = e[t]), (this.y = e[t + 1]), (this.z = e[t + 2]), this; + fromBufferAttribute(attribute, index) { + this.x = attribute.getX(index); + this.y = attribute.getY(index); + return this; } - multiplyByScalar(e) { - return Ue.multiplyByScalar(this, e, this), this; + applyMatrix3(matrix3) { + const x = this.x, + y = this.y; + this.x = matrix3[0] * x + matrix3[3] * y + matrix3[6]; + this.y = matrix3[1] * x + matrix3[4] * y + matrix3[7]; + return this; } - clone() { - return Ue.clone(this, new Ue()); + static fromElements(x, y, result) { + if (!defined(result)) { + return new Vector2(x, y); + } + result.x = x; + result.y = y; + return result; } - length() { - return Math.sqrt(this.x * this.x + this.y * this.y + this.z * this.z); + static clone(cartesian, result) { + if (!defined(cartesian)) { + return undefined; + } + if (!defined(result)) { + return new Vector2(cartesian.x, cartesian.y); + } + result.x = cartesian.x; + result.y = cartesian.y; + return result; + } + static maximumComponent(cartesian) { + return Math.max(cartesian.x, cartesian.y); + } + static minimumComponent(cartesian) { + return Math.min(cartesian.x, cartesian.y); + } + static minimumByComponent(first, second, result) { + result.x = Math.min(first.x, second.x); + result.y = Math.min(first.y, second.y); + return result; + } + static maximumByComponent(first, second, result) { + result.x = Math.max(first.x, second.x); + result.y = Math.max(first.y, second.y); + return result; + } + static clamp(value, min, max, result) { + const x = GMath.clamp(value.x, min.x, max.x); + const y = GMath.clamp(value.y, min.y, max.y); + result.x = x; + result.y = y; + return result; + } + static magnitudeSquared(cartesian) { + return cartesian.x * cartesian.x + cartesian.y * cartesian.y; + } + static magnitude(cartesian) { + return Math.sqrt(Vector2.magnitudeSquared(cartesian)); + } + static distance(left, right) { + Vector2.subtract(left, right, distanceScratch$2); + return Vector2.magnitude(distanceScratch$2); + } + static distanceSquared(left, right) { + Vector2.subtract(left, right, distanceScratch$2); + return Vector2.magnitudeSquared(distanceScratch$2); + } + static normalize(cartesian, result) { + const magnitude = Vector2.magnitude(cartesian); + result.x = cartesian.x / magnitude; + result.y = cartesian.y / magnitude; + // >>includeStart('debug', pragmas.debug); + if (isNaN(result.x) || isNaN(result.y)) { + throw new Error("normalized result is not a number"); + } + // >>includeEnd('debug'); + return result; + } + static dot(left, right) { + return left.x * right.x + left.y * right.y; + } + static cross(left, right) { + return left.x * right.y - left.y * right.x; + } + static multiplyComponents(left, right, result) { + result.x = left.x * right.x; + result.y = left.y * right.y; + return result; + } + static divideComponents(left, right, result) { + result.x = left.x / right.x; + result.y = left.y / right.y; + return result; + } + static add(left, right, result) { + result.x = left.x + right.x; + result.y = left.y + right.y; + return result; + } + static subtract(left, right, result) { + result.x = left.x - right.x; + result.y = left.y - right.y; + return result; + } + static multiplyByScalar(cartesian, scalar, result) { + result.x = cartesian.x * scalar; + result.y = cartesian.y * scalar; + return result; + } + static divideByScalar(cartesian, scalar, result) { + result.x = cartesian.x / scalar; + result.y = cartesian.y / scalar; + return result; + } + static negate(cartesian, result) { + result.x = -cartesian.x; + result.y = -cartesian.y; + return result; + } + static abs(cartesian, result) { + result.x = Math.abs(cartesian.x); + result.y = Math.abs(cartesian.y); + return result; + } + static lerp(start, end, t, result) { + Vector2.multiplyByScalar(end, t, lerpScratch$3); + result = Vector2.multiplyByScalar(start, 1.0 - t, result); + return Vector2.add(lerpScratch$3, result, result); + } + static angleBetween(left, right) { + Vector2.normalize(left, angleBetweenScratch$1); + Vector2.normalize(right, angleBetweenScratch2$1); + return GMath.acosClamped(Vector2.dot(angleBetweenScratch$1, angleBetweenScratch2$1)); + } + static mostOrthogonalAxis(cartesian, result) { + const f = Vector2.normalize(cartesian, mostOrthogonalAxisScratch$1); + Vector2.abs(f, f); + if (f.x <= f.y) { + result = Vector2.clone(Vector2.UNIT_X, result); + } else { + result = Vector2.clone(Vector2.UNIT_Y, result); + } + return result; } - applyMatrix4(e) { - const t = this.x, - i = this.y, - r = this.z, - n = e, - s = 1 / (n[3] * t + n[7] * i + n[11] * r + n[15]); - return ( - (this.x = (n[0] * t + n[4] * i + n[8] * r + n[12]) * s), - (this.y = (n[1] * t + n[5] * i + n[9] * r + n[13]) * s), - (this.z = (n[2] * t + n[6] * i + n[10] * r + n[14]) * s), - this - ); + static equals(left, right) { + return left === right || (defined(left) && defined(right) && left.x === right.x && left.y === right.y); } - applyMatrix3(e) { - const t = this.x, - i = this.y, - r = this.z; - return ( - (this.x = t * e[0] + i * e[3] + r * e[6]), - (this.y = t * e[1] + i * e[4] + r * e[7]), - (this.z = t * e[2] + i * e[5] + r * e[8]), - this - ); + /** + * @private + */ + static equalsArray(cartesian, array, offset) { + return cartesian.x === array[offset] && cartesian.y === array[offset + 1]; } - transformDirection(e) { - const t = this.x, - i = this.y, - r = this.z, - n = e; + static equalsEpsilon(left, right, relativeEpsilon = 0, absoluteEpsilon = 0) { return ( - (this.x = n[0] * t + n[4] * i + n[8] * r), - (this.y = n[1] * t + n[5] * i + n[9] * r), - (this.z = n[2] * t + n[6] * i + n[10] * r), - this.normalize() + left === right || + (defined(left) && + defined(right) && + GMath.equalsEpsilon(left.x, right.x, relativeEpsilon, absoluteEpsilon) && + GMath.equalsEpsilon(left.y, right.y, relativeEpsilon, absoluteEpsilon)) ); } - setFromMatrixPosition(e) { - const t = e; - return (this.x = t[12]), (this.y = t[13]), (this.z = t[14]), this; - } - normalize() { - return Ue.normalize(this, this), this; - } - equals(e) { - return Ue.equals(this, e); - } - equalsEpsilon(e, t = 0, i = 0) { - return Ue.equalsEpsilon(this, e, t, i); - } - toString() { - return `(${this.x}, ${this.y}, ${this.z})`; - } - fromBufferAttribute(e, t) { - return (this.x = e.getX(t)), (this.y = e.getY(t)), (this.z = e.getZ(t)), this; - } - static fromVector4(e, t) { - return (t.x = e.x), (t.y = e.y), (t.z = e.z), t; - } - static fromSpherical(e, t) { - pe(t) || (t = new Ue()); - const { phi: i, radius: r, theta: n } = e, - s = Math.sin(i) * r; - return (t.x = s * Math.sin(n)), (t.y = Math.cos(i) * r), (t.z = s * Math.cos(n)), t; +} +Vector2.ZERO = Object.freeze(new Vector2(0.0, 0.0)); +Vector2.ONE = Object.freeze(new Vector2(1.0, 1.0)); +Vector2.UNIT_X = Object.freeze(new Vector2(1.0, 0.0)); +Vector2.UNIT_Y = Object.freeze(new Vector2(0.0, 1.0)); +const distanceScratch$2 = new Vector2(); +const lerpScratch$3 = new Vector2(); +const angleBetweenScratch$1 = new Vector2(); +const angleBetweenScratch2$1 = new Vector2(); +const mostOrthogonalAxisScratch$1 = new Vector2(); + +class Vector3 { + constructor(x = 0, y = 0, z = 0) { + this.x = x; + this.y = y; + this.z = z; + } + set(x, y, z) { + this.x = x; + this.y = y; + this.z = z; + return this; } - static fromElements(e, t, i, r) { - return pe(r) ? ((r.x = e), (r.y = t), (r.z = i), r) : new Ue(e, t, i); + toArray() { + return [this.x, this.y, this.z]; } - static clone(e, t = new Ue()) { - if (pe(e)) return pe(t) ? ((t.x = e.x), (t.y = e.y), (t.z = e.z), t) : new Ue(e.x, e.y, e.z); + copy(v) { + this.x = v.x; + this.y = v.y; + this.z = v.z; + return this; } - static maximumComponent(e) { - return Math.max(e.x, e.y, e.z); + lerp(end, t) { + Vector3.lerp(this, end, t, this); + return this; } - static minimumComponent(e) { - return Math.min(e.x, e.y, e.z); + add(v) { + Vector3.add(this, v, this); + return this; } - static minimumByComponent(e, t, i) { - return (i.x = Math.min(e.x, t.x)), (i.y = Math.min(e.y, t.y)), (i.z = Math.min(e.z, t.z)), i; + addScaledVector(v, s) { + this.x += v.x * s; + this.y += v.y * s; + this.z += v.z * s; + return this; } - static maximumByComponent(e, t, i) { - return (i.x = Math.max(e.x, t.x)), (i.y = Math.max(e.y, t.y)), (i.z = Math.max(e.z, t.z)), i; + subtract(v) { + Vector3.subtract(this, v, this); + return this; } - static clamp(e, t, i, r) { - const n = ve.clamp(e.x, t.x, i.x), - s = ve.clamp(e.y, t.y, i.y), - a = ve.clamp(e.z, t.z, i.z); - return (r.x = n), (r.y = s), (r.z = a), r; + applyQuaternion(q) { + const x = this.x, + y = this.y, + z = this.z; + const qx = q.x, + qy = q.y, + qz = q.z, + qw = q.w; + // calculate quat * vector + const ix = qw * x + qy * z - qz * y; + const iy = qw * y + qz * x - qx * z; + const iz = qw * z + qx * y - qy * x; + const iw = -qx * x - qy * y - qz * z; + // calculate result * inverse quat + this.x = ix * qw + iw * -qx + iy * -qz - iz * -qy; + this.y = iy * qw + iw * -qy + iz * -qx - ix * -qz; + this.z = iz * qw + iw * -qz + ix * -qy - iy * -qx; + return this; } - static magnitudeSquared(e) { - return e.x * e.x + e.y * e.y + e.z * e.z; + setFromMatrixColumn(m, index) { + return this.fromArray(m, index * 4); } - static magnitude(e) { - return Math.sqrt(Ue.magnitudeSquared(e)); + fromArray(array, offset = 0) { + this.x = array[offset]; + this.y = array[offset + 1]; + this.z = array[offset + 2]; + return this; } - static distance(e, t) { - return Ue.subtract(e, t, _e), Ue.magnitude(_e); + multiplyByScalar(scale) { + Vector3.multiplyByScalar(this, scale, this); + return this; } - static distanceSquared(e, t) { - return Ue.subtract(e, t, _e), Ue.magnitudeSquared(_e); + clone() { + return Vector3.clone(this, new Vector3()); } - static normalize(e, t) { - const i = Ue.magnitude(e); - if (((t.x = e.x / i), (t.y = e.y / i), (t.z = e.z / i), isNaN(t.x) || isNaN(t.y) || isNaN(t.z))) - throw new Error("normalized result is not a number"); - return t; + length() { + return Math.sqrt(this.x * this.x + this.y * this.y + this.z * this.z); } - static dot(e, t) { - return e.x * t.x + e.y * t.y + e.z * t.z; + applyMatrix4(matrix) { + const x = this.x, + y = this.y, + z = this.z; + const e = matrix; + const w = 1 / (e[3] * x + e[7] * y + e[11] * z + e[15]); + this.x = (e[0] * x + e[4] * y + e[8] * z + e[12]) * w; + this.y = (e[1] * x + e[5] * y + e[9] * z + e[13]) * w; + this.z = (e[2] * x + e[6] * y + e[10] * z + e[14]) * w; + return this; } - static multiplyComponents(e, t, i) { - return (i.x = e.x * t.x), (i.y = e.y * t.y), (i.z = e.z * t.z), i; + applyMatrix3(matrix) { + const x = this.x, + y = this.y, + z = this.z; + this.x = x * matrix[0] + y * matrix[3] + z * matrix[6]; + this.y = x * matrix[1] + y * matrix[4] + z * matrix[7]; + this.z = x * matrix[2] + y * matrix[5] + z * matrix[8]; + return this; } - static divideComponents(e, t, i) { - return (i.x = e.x / t.x), (i.y = e.y / t.y), (i.z = e.z / t.z), i; + transformDirection(matrix) { + const x = this.x, + y = this.y, + z = this.z; + const e = matrix; + this.x = e[0] * x + e[4] * y + e[8] * z; + this.y = e[1] * x + e[5] * y + e[9] * z; + this.z = e[2] * x + e[6] * y + e[10] * z; + return this.normalize(); + } + setFromMatrixPosition(matrix) { + const e = matrix; + this.x = e[12]; + this.y = e[13]; + this.z = e[14]; + return this; } - static add(e, t, i) { - return (i.x = e.x + t.x), (i.y = e.y + t.y), (i.z = e.z + t.z), i; + normalize() { + Vector3.normalize(this, this); + return this; } - static subtract(e, t, i) { - return (i.x = e.x - t.x), (i.y = e.y - t.y), (i.z = e.z - t.z), i; + equals(right) { + return Vector3.equals(this, right); } - static multiplyByScalar(e, t, i) { - return (i.x = e.x * t), (i.y = e.y * t), (i.z = e.z * t), i; + equalsEpsilon(right, relativeEpsilon = 0, absoluteEpsilon = 0) { + return Vector3.equalsEpsilon(this, right, relativeEpsilon, absoluteEpsilon); } - static divideByScalar(e, t, i) { - return (i.x = e.x / t), (i.y = e.y / t), (i.z = e.z / t), i; + toString() { + return `(${this.x}, ${this.y}, ${this.z})`; } - static negate(e, t) { - return (t.x = -e.x), (t.y = -e.y), (t.z = -e.z), t; + fromBufferAttribute(attribute, index) { + this.x = attribute.getX(index); + this.y = attribute.getY(index); + this.z = attribute.getZ(index); + return this; } - static abs(e, t) { - return (t.x = Math.abs(e.x)), (t.y = Math.abs(e.y)), (t.z = Math.abs(e.z)), t; + static fromVector4(vec4, result) { + result.x = vec4.x; + result.y = vec4.y; + result.z = vec4.z; + return result; } - static lerp(e, t, i, r) { - return Ue.multiplyByScalar(t, i, Le), (r = Ue.multiplyByScalar(e, 1 - i, r)), Ue.add(Le, r, r); + static fromSpherical(spherical, result) { + if (!defined(result)) { + result = new Vector3(); + } + const { phi, radius, theta } = spherical; + const sinPhiRadius = Math.sin(phi) * radius; + result.x = sinPhiRadius * Math.sin(theta); + result.y = Math.cos(phi) * radius; + result.z = sinPhiRadius * Math.cos(theta); + return result; + } + static fromElements(x, y, z, result) { + if (!defined(result)) { + return new Vector3(x, y, z); + } + result.x = x; + result.y = y; + result.z = z; + return result; + } + static clone(cartesian, result = new Vector3()) { + if (!defined(cartesian)) { + return undefined; + } + if (!defined(result)) { + return new Vector3(cartesian.x, cartesian.y, cartesian.z); + } + result.x = cartesian.x; + result.y = cartesian.y; + result.z = cartesian.z; + return result; + } + static maximumComponent(cartesian) { + return Math.max(cartesian.x, cartesian.y, cartesian.z); + } + static minimumComponent(cartesian) { + return Math.min(cartesian.x, cartesian.y, cartesian.z); + } + static minimumByComponent(first, second, result) { + result.x = Math.min(first.x, second.x); + result.y = Math.min(first.y, second.y); + result.z = Math.min(first.z, second.z); + return result; + } + static maximumByComponent(first, second, result) { + result.x = Math.max(first.x, second.x); + result.y = Math.max(first.y, second.y); + result.z = Math.max(first.z, second.z); + return result; + } + static clamp(value, min, max, result) { + const x = GMath.clamp(value.x, min.x, max.x); + const y = GMath.clamp(value.y, min.y, max.y); + const z = GMath.clamp(value.z, min.z, max.z); + result.x = x; + result.y = y; + result.z = z; + return result; + } + static magnitudeSquared(cartesian) { + return cartesian.x * cartesian.x + cartesian.y * cartesian.y + cartesian.z * cartesian.z; + } + static magnitude(cartesian) { + return Math.sqrt(Vector3.magnitudeSquared(cartesian)); + } + static distance(left, right) { + Vector3.subtract(left, right, distanceScratch$1); + return Vector3.magnitude(distanceScratch$1); + } + static distanceSquared(left, right) { + Vector3.subtract(left, right, distanceScratch$1); + return Vector3.magnitudeSquared(distanceScratch$1); + } + static normalize(cartesian, result) { + const magnitude = Vector3.magnitude(cartesian); + result.x = cartesian.x / magnitude; + result.y = cartesian.y / magnitude; + result.z = cartesian.z / magnitude; + if (isNaN(result.x) || isNaN(result.y) || isNaN(result.z)) { + throw new Error("normalized result is not a number"); + } + return result; + } + static dot(left, right) { + return left.x * right.x + left.y * right.y + left.z * right.z; + } + static multiplyComponents(left, right, result) { + result.x = left.x * right.x; + result.y = left.y * right.y; + result.z = left.z * right.z; + return result; + } + static divideComponents(left, right, result) { + result.x = left.x / right.x; + result.y = left.y / right.y; + result.z = left.z / right.z; + return result; + } + static add(left, right, result) { + result.x = left.x + right.x; + result.y = left.y + right.y; + result.z = left.z + right.z; + return result; + } + static subtract(left, right, result) { + result.x = left.x - right.x; + result.y = left.y - right.y; + result.z = left.z - right.z; + return result; + } + static multiplyByScalar(cartesian, scalar, result) { + result.x = cartesian.x * scalar; + result.y = cartesian.y * scalar; + result.z = cartesian.z * scalar; + return result; + } + static divideByScalar(cartesian, scalar, result) { + result.x = cartesian.x / scalar; + result.y = cartesian.y / scalar; + result.z = cartesian.z / scalar; + return result; + } + static negate(cartesian, result) { + result.x = -cartesian.x; + result.y = -cartesian.y; + result.z = -cartesian.z; + return result; + } + static abs(cartesian, result) { + result.x = Math.abs(cartesian.x); + result.y = Math.abs(cartesian.y); + result.z = Math.abs(cartesian.z); + return result; + } + static lerp(start, end, t, result) { + Vector3.multiplyByScalar(end, t, lerpScratch$2); + result = Vector3.multiplyByScalar(start, 1.0 - t, result); + return Vector3.add(lerpScratch$2, result, result); + } + static angleBetween(left, right) { + Vector3.normalize(left, angleBetweenScratch); + Vector3.normalize(right, angleBetweenScratch2); + const cosine = Vector3.dot(angleBetweenScratch, angleBetweenScratch2); + const sine = Vector3.magnitude(Vector3.cross(angleBetweenScratch, angleBetweenScratch2, angleBetweenScratch)); + return Math.atan2(sine, cosine); + } + static mostOrthogonalAxis(cartesian, result) { + const f = Vector3.normalize(cartesian, mostOrthogonalAxisScratch); + Vector3.abs(f, f); + if (f.x <= f.y) { + if (f.x <= f.z) { + result = Vector3.clone(Vector3.UNIT_X, result); + } else { + result = Vector3.clone(Vector3.UNIT_Z, result); + } + } else if (f.y <= f.z) { + result = Vector3.clone(Vector3.UNIT_Y, result); + } else { + result = Vector3.clone(Vector3.UNIT_Z, result); + } + return result; } - static angleBetween(e, t) { - Ue.normalize(e, Ce), Ue.normalize(t, Re); - const i = Ue.dot(Ce, Re), - r = Ue.magnitude(Ue.cross(Ce, Re, Ce)); - return Math.atan2(r, i); + static projectVector(a, b, result) { + const scalar = Vector3.dot(a, b) / Vector3.dot(b, b); + return Vector3.multiplyByScalar(b, scalar, result); } - static mostOrthogonalAxis(e, t) { - const i = Ue.normalize(e, Ae); + static equals(left, right) { return ( - Ue.abs(i, i), - (t = - i.x <= i.y - ? i.x <= i.z - ? Ue.clone(Ue.UNIT_X, t) - : Ue.clone(Ue.UNIT_Z, t) - : i.y <= i.z - ? Ue.clone(Ue.UNIT_Y, t) - : Ue.clone(Ue.UNIT_Z, t)) + left === right || + (defined(left) && defined(right) && left.x === right.x && left.y === right.y && left.z === right.z) ); } - static projectVector(e, t, i) { - const r = Ue.dot(e, t) / Ue.dot(t, t); - return Ue.multiplyByScalar(t, r, i); - } - static equals(e, t) { - return e === t || (pe(e) && pe(t) && e.x === t.x && e.y === t.y && e.z === t.z); + /** + * @private + */ + static equalsArray(cartesian, array, offset) { + return cartesian.x === array[offset] && cartesian.y === array[offset + 1] && cartesian.z === array[offset + 2]; } - static equalsArray(e, t, i) { - return e.x === t[i] && e.y === t[i + 1] && e.z === t[i + 2]; - } - static equalsEpsilon(e, t, i = 0, r = 0) { + static equalsEpsilon(left, right, relativeEpsilon = 0, absoluteEpsilon = 0) { return ( - e === t || - (pe(e) && - pe(t) && - ve.equalsEpsilon(e.x, t.x, i, r) && - ve.equalsEpsilon(e.y, t.y, i, r) && - ve.equalsEpsilon(e.z, t.z, i, r)) + left === right || + (defined(left) && + defined(right) && + GMath.equalsEpsilon(left.x, right.x, relativeEpsilon, absoluteEpsilon) && + GMath.equalsEpsilon(left.y, right.y, relativeEpsilon, absoluteEpsilon) && + GMath.equalsEpsilon(left.z, right.z, relativeEpsilon, absoluteEpsilon)) ); } - static cross(e, t, i) { - const r = e.x, - n = e.y, - s = e.z, - a = t.x, - o = t.y, - c = t.z, - l = n * c - s * o, - h = s * a - r * c, - u = r * o - n * a; - return (i.x = l), (i.y = h), (i.z = u), i; - } -} -(Ue.ZERO = Object.freeze(new Ue(0, 0, 0))), - (Ue.ONE = Object.freeze(new Ue(1, 1, 1))), - (Ue.UNIT_X = Object.freeze(new Ue(1, 0, 0))), - (Ue.UNIT_Y = Object.freeze(new Ue(0, 1, 0))), - (Ue.UNIT_Z = Object.freeze(new Ue(0, 0, 1))), - (Ue.midpoint = function (e, t, i) { - return (i.x = 0.5 * (e.x + t.x)), (i.y = 0.5 * (e.y + t.y)), (i.z = 0.5 * (e.z + t.z)), i; - }); -const _e = new Ue(), - Le = new Ue(), - Ce = new Ue(), - Re = new Ue(), - Ae = new Ue(); -class De { - constructor(e, t, i) { - (this.name = e), - (this.value = t), - (this.itemSize = i), - (this.name = e), - (this.offset = 0), - (this.shaderLocation = 0), - (this.attributeType = Be.attribute), - (this.dirty = !0); + static cross(left, right, result) { + const leftX = left.x; + const leftY = left.y; + const leftZ = left.z; + const rightX = right.x; + const rightY = right.y; + const rightZ = right.z; + const x = leftY * rightZ - leftZ * rightY; + const y = leftZ * rightX - leftX * rightZ; + const z = leftX * rightY - leftY * rightX; + result.x = x; + result.y = y; + result.z = z; + return result; + } +} +Vector3.ZERO = Object.freeze(new Vector3(0.0, 0.0, 0.0)); +Vector3.ONE = Object.freeze(new Vector3(1.0, 1.0, 1.0)); +Vector3.UNIT_X = Object.freeze(new Vector3(1.0, 0.0, 0.0)); +Vector3.UNIT_Y = Object.freeze(new Vector3(0.0, 1.0, 0.0)); +Vector3.UNIT_Z = Object.freeze(new Vector3(0.0, 0.0, 1.0)); +Vector3.midpoint = function (left, right, result) { + result.x = (left.x + right.x) * 0.5; + result.y = (left.y + right.y) * 0.5; + result.z = (left.z + right.z) * 0.5; + return result; +}; +const distanceScratch$1 = new Vector3(); +const lerpScratch$2 = new Vector3(); +const angleBetweenScratch = new Vector3(); +const angleBetweenScratch2 = new Vector3(); +const mostOrthogonalAxisScratch = new Vector3(); + +class Attribute { + constructor(name, value, itemSize) { + this.name = name; + this.value = value; + this.itemSize = itemSize; + this.name = name; + this.offset = 0; + this.shaderLocation = 0; + this.attributeType = AttributeType.attribute; + this.dirty = true; } getGPUAttribute() { - return [{ shaderLocation: this.shaderLocation, format: this.format, offset: this.offset }]; + return [ + { + shaderLocation: this.shaderLocation, + format: this.format, + offset: this.offset + } + ]; } destroy() { this.value = []; } - applyMatrix3(e) { - if (2 === this.itemSize) - for (let t = 0, i = this.value.length / this.itemSize; t < i; t++) - De.v2.fromBufferAttribute(this, t), De.v2.applyMatrix3(e), this.setXY(t, De.v2.x, De.v2.y); - else if (3 === this.itemSize) - for (let t = 0, i = this.value.length / this.itemSize; t < i; t++) - De.v3.fromBufferAttribute(this, t), De.v3.applyMatrix3(e), this.setXYZ(t, De.v3.x, De.v3.y, De.v3.z); + applyMatrix3(matrix3) { + if (this.itemSize === 2) { + for (let i = 0, l = this.value.length / this.itemSize; i < l; i++) { + Attribute.v2.fromBufferAttribute(this, i); + Attribute.v2.applyMatrix3(matrix3); + this.setXY(i, Attribute.v2.x, Attribute.v2.y); + } + } else if (this.itemSize === 3) { + for (let i = 0, l = this.value.length / this.itemSize; i < l; i++) { + Attribute.v3.fromBufferAttribute(this, i); + Attribute.v3.applyMatrix3(matrix3); + this.setXYZ(i, Attribute.v3.x, Attribute.v3.y, Attribute.v3.z); + } + } return this; } - applyMatrix4(e) { - for (let t = 0, i = this.value.length / this.itemSize; t < i; t++) - De.v3.fromBufferAttribute(this, t), De.v3.applyMatrix4(e), this.setXYZ(t, De.v3.x, De.v3.y, De.v3.z); + applyMatrix4(matrix4) { + for (let i = 0, l = this.value.length / this.itemSize; i < l; i++) { + Attribute.v3.fromBufferAttribute(this, i); + Attribute.v3.applyMatrix4(matrix4); + this.setXYZ(i, Attribute.v3.x, Attribute.v3.y, Attribute.v3.z); + } return this; } - setX(e, t) { - return (this.value[e * this.itemSize] = t), this; + setX(index, x) { + this.value[index * this.itemSize] = x; + return this; } - getX(e) { - return this.value[e * this.itemSize]; + getX(index) { + const x = this.value[index * this.itemSize]; + return x; } - setY(e, t) { - return (this.value[e * this.itemSize + 1] = t), this; + setY(index, y) { + this.value[index * this.itemSize + 1] = y; + return this; } - getY(e) { - return this.value[e * this.itemSize + 1]; + getY(index) { + const y = this.value[index * this.itemSize + 1]; + return y; } - setZ(e, t) { - return (this.value[e * this.itemSize + 2] = t), this; + setZ(index, z) { + this.value[index * this.itemSize + 2] = z; + return this; } - getZ(e) { - return this.value[e * this.itemSize + 2]; + getZ(index) { + const z = this.value[index * this.itemSize + 2]; + return z; } - getW(e) { - return this.value[e * this.itemSize + 3]; + getW(index) { + const w = this.value[index * this.itemSize + 3]; + return w; } - setXY(e, t, i) { - return (e *= this.itemSize), (this.value[e + 0] = t), (this.value[e + 1] = i), this; + setXY(index, x, y) { + index *= this.itemSize; + this.value[index + 0] = x; + this.value[index + 1] = y; + return this; } - setXYZ(e, t, i, r) { - return (e *= this.itemSize), (this.value[e + 0] = t), (this.value[e + 1] = i), (this.value[e + 2] = r), this; + setXYZ(index, x, y, z) { + index *= this.itemSize; + this.value[index + 0] = x; + this.value[index + 1] = y; + this.value[index + 2] = z; + return this; } - setXYZW(e, t, i, r, n) { - return ( - (e *= this.itemSize), - (this.value[e + 0] = t), - (this.value[e + 1] = i), - (this.value[e + 2] = r), - (this.value[e + 3] = n), - this - ); + setXYZW(index, x, y, z, w) { + index *= this.itemSize; + this.value[index + 0] = x; + this.value[index + 1] = y; + this.value[index + 2] = z; + this.value[index + 3] = w; + return this; } } -(De.v3 = new Ue()), (De.v2 = new Se()); -class ze { - constructor(e, t, i) { - (this.names = e), - (this.itemSizes = i), - (this.value = t), - (this.attributeType = Be.interleavedAttribute), - (this.dirty = !0); +Attribute.v3 = new Vector3(); +Attribute.v2 = new Vector2(); +class InterleavedAttribute { + constructor(names, value, itemSizes) { + this.names = names; + this.itemSizes = itemSizes; + this.value = value; + this.attributeType = AttributeType.interleavedAttribute; + this.dirty = true; } getGPUAttribute() { - const e = []; - return ( - this.itemSizes.reduce( - (t, i, r) => ( - e.push({ - shaderLocation: r, - format: 1 == i ? `${this.format}` : `${this.format}x${i}`, - offset: t * this.byteSize - }), - t + i - ), - 0 - ), - e - ); + const result = []; + this.itemSizes.reduce((total, current, index) => { + result.push({ + shaderLocation: index, + format: current == 1 ? `${this.format}` : `${this.format}x${current}`, + offset: total * this.byteSize + }); + return (total += current); + }, 0); + return result; } destroy() { - (this.value = null), (this.names = null), (this.itemSizes = null); + this.value = null; + this.names = null; + this.itemSizes = null; } } -class Ie extends De { - constructor(e, t, i) { - super(e, t, i); - const { format: r, totalByteSize: n } = (function (e, t) { - const i = `${e}x${t}`; - return { - [L.Float32]: { - format: "float32", - totalByteSize: Float32Array.BYTES_PER_ELEMENT * t, - byteSize: Float32Array.BYTES_PER_ELEMENT - }, - [L.Float32x2]: { - format: "float32x2", - totalByteSize: Float32Array.BYTES_PER_ELEMENT * t, - byteSize: Float32Array.BYTES_PER_ELEMENT - }, - [L.Float32x3]: { - format: "float32x3", - totalByteSize: Float32Array.BYTES_PER_ELEMENT * t, - byteSize: Float32Array.BYTES_PER_ELEMENT - }, - [L.Float32x4]: { - format: "float32x4", - totalByteSize: Float32Array.BYTES_PER_ELEMENT * t, - byteSize: Float32Array.BYTES_PER_ELEMENT - } - }[i]; - })(L.Float32, i); - (this.format = r), (this.attributeByteSize = n); - } -} -class Pe extends ze { - constructor(e, t, i) { - super(e, t, i), (this.format = L.Float32), (this.byteSize = Float32Array.BYTES_PER_ELEMENT); - } -} -class Ne extends Pe { - constructor(e, t, i) { - super(e, void 0, i), (this.buffer = t); - } -} -var Be; -!(function (e) { - (e[(e.interleavedAttribute = 0)] = "interleavedAttribute"), (e[(e.attribute = 1)] = "attribute"); -})(Be || (Be = {})); -const Oe = new Map(); -class Ve { - constructor(e) { - (this.index = e.index || 0), - (this.offset = e.offset ?? 0), - (this.alignedSize = e.alignedSize ?? 0), - (this.maxOffset = e.maxOffset ?? 0), - (this.dynamic = e.dynamic ?? !1), - (this.gpuBindGroup = e.device.createBindGroup({ - label: e.label, - layout: e.layout.gpuBindGroupLayout, - entries: e.entires.map((e) => ({ binding: e.binding, resource: e.resource })) - })); - } - bind(e) { +class Float32Attribute extends Attribute { + constructor(name, value, itemSize) { + super(name, value, itemSize); + const { format, totalByteSize } = getAttributeFormat(VertexFormat.Float32, itemSize); + this.format = format; + this.attributeByteSize = totalByteSize; + } +} +class InterleavedFloat32Attribute extends InterleavedAttribute { + constructor(names, value, itemSizes) { + super(names, value, itemSizes); + this.format = VertexFormat.Float32; + this.byteSize = Float32Array.BYTES_PER_ELEMENT; + } +} +class BufferFloat32Attribute extends InterleavedFloat32Attribute { + constructor(names, buffer, itemSizes) { + super(names, undefined, itemSizes); + this.buffer = buffer; + } +} +var AttributeType; +(function (AttributeType) { + AttributeType[(AttributeType["interleavedAttribute"] = 0)] = "interleavedAttribute"; + AttributeType[(AttributeType["attribute"] = 1)] = "attribute"; +})(AttributeType || (AttributeType = {})); +function getAttributeFormat(type, itemSize) { + const key = `${type}x${itemSize}`; + return { + [VertexFormat.Float32]: { + format: "float32", + totalByteSize: Float32Array.BYTES_PER_ELEMENT * itemSize, + byteSize: Float32Array.BYTES_PER_ELEMENT + }, + [VertexFormat.Float32x2]: { + format: "float32x2", + totalByteSize: Float32Array.BYTES_PER_ELEMENT * itemSize, + byteSize: Float32Array.BYTES_PER_ELEMENT + }, + [VertexFormat.Float32x3]: { + format: "float32x3", + totalByteSize: Float32Array.BYTES_PER_ELEMENT * itemSize, + byteSize: Float32Array.BYTES_PER_ELEMENT + }, + [VertexFormat.Float32x4]: { + format: "float32x4", + totalByteSize: Float32Array.BYTES_PER_ELEMENT * itemSize, + byteSize: Float32Array.BYTES_PER_ELEMENT + } + }[key]; +} + +const bindGroupCache = new Map(); +class BindGroup { + constructor(options) { + this.index = options.index || 0; + this.offset = options.offset ?? 0; + this.alignedSize = options.alignedSize ?? 0; + this.maxOffset = options.maxOffset ?? 0; + this.dynamic = options.dynamic ?? false; + this.gpuBindGroup = options.device.createBindGroup({ + label: options.label, + layout: options.layout.gpuBindGroupLayout, + entries: options.entires.map((entity) => ({ + binding: entity.binding, + resource: entity.resource + })) + }); + } + bind(passEncoder) { + // dynamic uniforms must bind multiple times if (this.dynamic) { - const t = [0]; - (t[0] = this.offset * this.alignedSize), - (this.offset = ++this.offset < this.maxOffset ? this.offset : 0), - e.setBindGroup(this.index, this.gpuBindGroup, t); - } else e.setBindGroup(this.index, this.gpuBindGroup); + const dynamicOffsets = [0]; + dynamicOffsets[0] = this.offset * this.alignedSize; + this.offset = ++this.offset < this.maxOffset ? this.offset : 0; + passEncoder.setBindGroup(this.index, this.gpuBindGroup, dynamicOffsets); + } else { + passEncoder.setBindGroup(this.index, this.gpuBindGroup); + } } destroy() { - (this.gpuBindGroup = void 0), (this.device = void 0); + this.gpuBindGroup = undefined; + this.device = undefined; } - static getBindGroupFromCache(e) { - if (Oe.has(e.label)) return Oe.get(e.label); - { - const t = new Ve(e); - return Oe.set(e.label, t), t; + static getBindGroupFromCache(options) { + if (bindGroupCache.has(options.label)) { + return bindGroupCache.get(options.label); + } else { + const bindGroup = new BindGroup(options); + bindGroupCache.set(options.label, bindGroup); + return bindGroup; } } - static removeBindGroupFromCache(e) { - Oe.delete(e); + static removeBindGroupFromCache(bindGroup) { + bindGroupCache.delete(bindGroup); } } -class Fe { - constructor(e) { - (this.binding = e.binding), (this.resource = e.resource); + +class BindGroupEntity { + constructor(options) { + this.binding = options.binding; + this.resource = options.resource; } getGPUGroupEntity() { - return { binding: this.binding, resource: this.resource }; - } -} -class $e { - constructor(e, t, i, r, n, s) { - (this.type = e), - (this.colorAttachments = t), - (this.depthAttachment = i), - (this.stencilAttachment = r), - (this.querySet = n), - (this.fixedSize = s), - (this.renderEncoder = void 0), - (this.computeEncoder = void 0), - (this._renderPassDescriptor = void 0), - (this.commandEncoder = void 0), - (this.device = void 0), - (this.fixedSize = !1); + return { + binding: this.binding, + resource: this.resource + }; + } +} + +class RenderTarget { + constructor(type, colorAttachments, depthAttachment, stencilAttachment, querySet, fixedSize) { + this.type = type; + this.colorAttachments = colorAttachments; + this.depthAttachment = depthAttachment; + this.stencilAttachment = stencilAttachment; + this.querySet = querySet; + this.fixedSize = fixedSize; + this.renderEncoder = undefined; + this.computeEncoder = undefined; + this._renderPassDescriptor = undefined; + this.commandEncoder = undefined; + this.device = undefined; + this.fixedSize = false; } get renderPassDescriptor() { - return (this._renderPassDescriptor = this.getRenderPassDescriptor()), this._renderPassDescriptor; + this._renderPassDescriptor = this.getRenderPassDescriptor(); + return this._renderPassDescriptor; } - getColorTexture(e = 0) { - const t = this.colorAttachments[e]; - return t ? t.texture : null; + getColorTexture(index = 0) { + const colAtt = this.colorAttachments[index]; + if (colAtt) { + return colAtt.texture; + } else { + return null; + } } getDepthTexture() { - if (this.depthAttachment) return this.depthAttachment.texture; + if (this.depthAttachment) { + return this.depthAttachment.texture; + } } getRenderPassDescriptor() { - return ( - this.depthAttachment?.texture?.update(this.device), - this?.querySet?.update(this.device), - { - ...(this.colorAttachments && { - colorAttachments: this.colorAttachments.map( - (e) => ( - e?.texture?.update && e?.texture?.update(this.device), - { - view: e?.textureView?.() ?? e.texture.textureView, - resolveTarget: null != e.resolveTarget ? e.resolveTarget.textureView : void 0, - clearValue: e.value, - loadOp: e.op, - storeOp: e.storeOp - } - ) - ) - }), - ...((this.depthAttachment || this.stencilAttachment) && { - depthStencilAttachment: { - view: this.depthAttachment?.texture?.textureView || void 0, - depthLoadOp: this.depthAttachment?.op || "clear", - depthClearValue: this.depthAttachment?.value || 1, - depthStoreOp: this.depthAttachment?.storeOp || "store", - depthReadOnly: this.depthAttachment?.readOnly || !1 - } - }), - ...(this.querySet && { occlusionQuerySet: this.querySet.gpuQuerySet }) - } - ); + this.depthAttachment?.texture?.update(this.device); + this?.querySet?.update(this.device); + return { + ...(this.colorAttachments && { + colorAttachments: this.colorAttachments.map((colorAttachment) => { + colorAttachment?.texture?.update && colorAttachment?.texture?.update(this.device); + return { + view: + // 暂时这么写 + colorAttachment?.textureView?.() ?? colorAttachment.texture.textureView, + resolveTarget: + colorAttachment.resolveTarget != undefined + ? colorAttachment.resolveTarget.textureView + : undefined, + clearValue: colorAttachment.value, + loadOp: colorAttachment.op, + storeOp: colorAttachment.storeOp + }; + }) + }), + ...((this.depthAttachment || this.stencilAttachment) && { + depthStencilAttachment: { + view: this.depthAttachment?.texture?.textureView || undefined, + depthLoadOp: this.depthAttachment?.op || "clear", + depthClearValue: this.depthAttachment?.value || 1.0, + depthStoreOp: this.depthAttachment?.storeOp || "store", + depthReadOnly: this.depthAttachment?.readOnly || false + // stencilLoadOp: this.stencilAttachment?.op || "clear", + // stencilClearValue: this.stencilAttachment?.value || 0, + // stencilStoreOp: this.stencilAttachment?.storeOp || "store", + } + }), + ...(this.querySet && { occlusionQuerySet: this.querySet.gpuQuerySet }) + }; } - beginRenderPass(e) { - return ( - this.device || (this.device = e), - (this.commandEncoder = this.device.createCommandEncoder()), - (this.renderEncoder = this.commandEncoder.beginRenderPass(this.renderPassDescriptor)), - this.renderEncoder - ); + beginRenderPass(device) { + if (!this.device) this.device = device; + this.commandEncoder = this.device.createCommandEncoder(); + this.renderEncoder = this.commandEncoder.beginRenderPass(this.renderPassDescriptor); + return this.renderEncoder; } endRenderPass() { - this.renderEncoder?.end(), - this.device.queue.submit([this.commandEncoder.finish()]), - (this.commandEncoder = null), - (this.renderEncoder = null); + this.renderEncoder?.end(); + this.device.queue.submit([this.commandEncoder.finish()]); + this.commandEncoder = null; + this.renderEncoder = null; } - beginComputePassEncoder(e) { - return ( - this.device || (this.device = e), - (this.commandEncoder = this.device.createCommandEncoder()), - (this.computeEncoder = this.commandEncoder.beginComputePass()), - this.computeEncoder - ); + beginComputePassEncoder(device) { + if (!this.device) this.device = device; + this.commandEncoder = this.device.createCommandEncoder(); + this.computeEncoder = this.commandEncoder.beginComputePass(); + return this.computeEncoder; } endComputePassEncoder() { - this.computeEncoder?.end(), - this.device.queue.submit([this.commandEncoder.finish()]), - (this.commandEncoder = null), - (this.renderEncoder = null); - } - setSize(e, t, i = 1) { - this.fixedSize || - (this?.depthAttachment?.texture?.setSize?.(e, t, i), - this?.colorAttachments?.forEach?.((r) => r?.texture?.setSize?.(e, t, i))); + this.computeEncoder?.end(); + this.device.queue.submit([this.commandEncoder.finish()]); + this.commandEncoder = null; + this.renderEncoder = null; + } + setSize(width, height, depth = 1) { + if (this.fixedSize) return; + this?.depthAttachment?.texture?.setSize?.(width, height, depth); + this?.colorAttachments?.forEach?.((colorAttachment) => + colorAttachment?.texture?.setSize?.(width, height, depth) + ); } destroy() { - this.colorAttachments && - this.colorAttachments.forEach((e) => { - e.texture && e.texture.destroy(); - }), - this.depthAttachment.texture && this.depthAttachment.texture.destroy(); - } -} -class Ge { - constructor(e = 0, t = 0, i = 0, r = 0, n = 0, s = 0, a = 0, o = 0, c = 0) { - (this[0] = e), - (this[1] = r), - (this[2] = a), - (this[3] = t), - (this[4] = n), - (this[5] = o), - (this[6] = i), - (this[7] = s), - (this[8] = c); - } - setFromMatrix4(e) { - return ( - (this[0] = e[0]), - (this[1] = e[1]), - (this[2] = e[2]), - (this[3] = e[4]), - (this[4] = e[5]), - (this[5] = e[2]), - (this[6] = e[8]), - (this[7] = e[9]), - (this[8] = e[10]), - this - ); + if (this.colorAttachments) { + this.colorAttachments.forEach((colorAttachment) => { + if (colorAttachment.texture) { + colorAttachment.texture.destroy(); + } + }); + } + if (this.depthAttachment.texture) this.depthAttachment.texture.destroy(); + } +} + +/** + * A 3x3 matrix, indexable as a column-major order array. + * @param {Number} [column0Row0=0.0] The value for column 0, row 0. + * @param {Number} [column1Row0=0.0] The value for column 1, row 0. + * @param {Number} [column2Row0=0.0] The value for column 2, row 0. + * @param {Number} [column0Row1=0.0] The value for column 0, row 1. + * @param {Number} [column1Row1=0.0] The value for column 1, row 1. + * @param {Number} [column2Row1=0.0] The value for column 2, row 1. + * @param {Number} [column0Row2=0.0] The value for column 0, row 2. + * @param {Number} [column1Row2=0.0] The value for column 1, row 2. + * @param {Number} [column2Row2=0.0] The value for column 2, row 2. + */ +class Matrix3 { + constructor( + column0Row0 = 0, + column1Row0 = 0, + column2Row0 = 0, + column0Row1 = 0, + column1Row1 = 0, + column2Row1 = 0, + column0Row2 = 0, + column1Row2 = 0, + column2Row2 = 0 + ) { + this[0] = column0Row0; + this[1] = column0Row1; + this[2] = column0Row2; + this[3] = column1Row0; + this[4] = column1Row1; + this[5] = column1Row2; + this[6] = column2Row0; + this[7] = column2Row1; + this[8] = column2Row2; + } + setFromMatrix4(matrix) { + this[0] = matrix[0]; + this[1] = matrix[1]; + this[2] = matrix[2]; + this[3] = matrix[4]; + this[4] = matrix[5]; + this[5] = matrix[2]; + this[6] = matrix[8]; + this[7] = matrix[9]; + this[8] = matrix[10]; + return this; + } + getNormalMatrix(matrix4) { + this.setFromMatrix4(matrix4); + Matrix3.inverse(this, this); + Matrix3.transpose(this, this); + return this; } - getNormalMatrix(e) { - return this.setFromMatrix4(e), Ge.inverse(this, this), Ge.transpose(this, this), this; - } - static clone(e, t) { - if (pe(e)) - return pe(t) - ? ((t[0] = e[0]), - (t[1] = e[1]), - (t[2] = e[2]), - (t[3] = e[3]), - (t[4] = e[4]), - (t[5] = e[5]), - (t[6] = e[6]), - (t[7] = e[7]), - (t[8] = e[8]), - t) - : new Ge(e[0], e[3], e[6], e[1], e[4], e[7], e[2], e[5], e[8]); - } - static fromColumnMajorArray(e, t) { - return pe(t) || (t = new Ge()), Ge.clone(e, t); - } - static fromRowMajorArray(e, t) { - return pe(t) - ? ((t[0] = e[0]), - (t[1] = e[3]), - (t[2] = e[6]), - (t[3] = e[1]), - (t[4] = e[4]), - (t[5] = e[7]), - (t[6] = e[2]), - (t[7] = e[5]), - (t[8] = e[8]), - t) - : new Ge(e[0], e[1], e[2], e[3], e[4], e[5], e[6], e[7], e[8]); - } - static fromQuaternion(e, t) { - const i = e.x * e.x, - r = e.x * e.y, - n = e.x * e.z, - s = e.x * e.w, - a = e.y * e.y, - o = e.y * e.z, - c = e.y * e.w, - l = e.z * e.z, - h = e.z * e.w, - u = e.w * e.w, - f = i - a - l + u, - d = 2 * (r - h), - m = 2 * (n + c), - p = 2 * (r + h), - g = -i + a - l + u, - x = 2 * (o - s), - v = 2 * (n - c), - y = 2 * (o + s), - S = -i - a + l + u; - return pe(t) - ? ((t[0] = f), - (t[1] = p), - (t[2] = v), - (t[3] = d), - (t[4] = g), - (t[5] = y), - (t[6] = m), - (t[7] = x), - (t[8] = S), - t) - : new Ge(f, d, m, p, g, x, v, y, S); - } - static fromScale(e, t) { - return pe(t) - ? ((t[0] = e.x), - (t[1] = 0), - (t[2] = 0), - (t[3] = 0), - (t[4] = e.y), - (t[5] = 0), - (t[6] = 0), - (t[7] = 0), - (t[8] = e.z), - t) - : new Ge(e.x, 0, 0, 0, e.y, 0, 0, 0, e.z); - } - static fromRotationX(e, t) { - const i = Math.cos(e), - r = Math.sin(e); - return pe(t) - ? ((t[0] = 1), - (t[1] = 0), - (t[2] = 0), - (t[3] = 0), - (t[4] = i), - (t[5] = r), - (t[6] = 0), - (t[7] = -r), - (t[8] = i), - t) - : new Ge(1, 0, 0, 0, i, -r, 0, r, i); - } - static fromRotationY(e, t) { - const i = Math.cos(e), - r = Math.sin(e); - return pe(t) - ? ((t[0] = i), - (t[1] = 0), - (t[2] = -r), - (t[3] = 0), - (t[4] = 1), - (t[5] = 0), - (t[6] = r), - (t[7] = 0), - (t[8] = i), - t) - : new Ge(i, 0, r, 0, 1, 0, -r, 0, i); - } - static fromRotationZstatic(e, t) { - const i = Math.cos(e), - r = Math.sin(e); - return pe(t) - ? ((t[0] = i), - (t[1] = r), - (t[2] = 0), - (t[3] = -r), - (t[4] = i), - (t[5] = 0), - (t[6] = 0), - (t[7] = 0), - (t[8] = 1), - t) - : new Ge(i, -r, 0, r, i, 0, 0, 0, 1); + static clone(matrix, result) { + if (!defined(matrix)) { + return undefined; + } + if (!defined(result)) { + return new Matrix3( + matrix[0], + matrix[3], + matrix[6], + matrix[1], + matrix[4], + matrix[7], + matrix[2], + matrix[5], + matrix[8] + ); + } + result[0] = matrix[0]; + result[1] = matrix[1]; + result[2] = matrix[2]; + result[3] = matrix[3]; + result[4] = matrix[4]; + result[5] = matrix[5]; + result[6] = matrix[6]; + result[7] = matrix[7]; + result[8] = matrix[8]; + return result; + } + static fromColumnMajorArray(values, result) { + if (!defined(result)) { + result = new Matrix3(); + } + return Matrix3.clone(values, result); + } + static fromRowMajorArray(values, result) { + if (!defined(result)) { + return new Matrix3( + values[0], + values[1], + values[2], + values[3], + values[4], + values[5], + values[6], + values[7], + values[8] + ); + } + result[0] = values[0]; + result[1] = values[3]; + result[2] = values[6]; + result[3] = values[1]; + result[4] = values[4]; + result[5] = values[7]; + result[6] = values[2]; + result[7] = values[5]; + result[8] = values[8]; + return result; + } + static fromQuaternion(quaternion, result) { + const x2 = quaternion.x * quaternion.x; + const xy = quaternion.x * quaternion.y; + const xz = quaternion.x * quaternion.z; + const xw = quaternion.x * quaternion.w; + const y2 = quaternion.y * quaternion.y; + const yz = quaternion.y * quaternion.z; + const yw = quaternion.y * quaternion.w; + const z2 = quaternion.z * quaternion.z; + const zw = quaternion.z * quaternion.w; + const w2 = quaternion.w * quaternion.w; + const m00 = x2 - y2 - z2 + w2; + const m01 = 2.0 * (xy - zw); + const m02 = 2.0 * (xz + yw); + const m10 = 2.0 * (xy + zw); + const m11 = -x2 + y2 - z2 + w2; + const m12 = 2.0 * (yz - xw); + const m20 = 2.0 * (xz - yw); + const m21 = 2.0 * (yz + xw); + const m22 = -x2 - y2 + z2 + w2; + if (!defined(result)) { + return new Matrix3(m00, m01, m02, m10, m11, m12, m20, m21, m22); + } + result[0] = m00; + result[1] = m10; + result[2] = m20; + result[3] = m01; + result[4] = m11; + result[5] = m21; + result[6] = m02; + result[7] = m12; + result[8] = m22; + return result; + } + static fromScale(scale, result) { + if (!defined(result)) { + return new Matrix3(scale.x, 0.0, 0.0, 0.0, scale.y, 0.0, 0.0, 0.0, scale.z); + } + result[0] = scale.x; + result[1] = 0.0; + result[2] = 0.0; + result[3] = 0.0; + result[4] = scale.y; + result[5] = 0.0; + result[6] = 0.0; + result[7] = 0.0; + result[8] = scale.z; + return result; + } + static fromRotationX(angle, result) { + const cosAngle = Math.cos(angle); + const sinAngle = Math.sin(angle); + if (!defined(result)) { + return new Matrix3(1.0, 0.0, 0.0, 0.0, cosAngle, -sinAngle, 0.0, sinAngle, cosAngle); + } + result[0] = 1.0; + result[1] = 0.0; + result[2] = 0.0; + result[3] = 0.0; + result[4] = cosAngle; + result[5] = sinAngle; + result[6] = 0.0; + result[7] = -sinAngle; + result[8] = cosAngle; + return result; + } + static fromRotationY(angle, result) { + const cosAngle = Math.cos(angle); + const sinAngle = Math.sin(angle); + if (!defined(result)) { + return new Matrix3(cosAngle, 0.0, sinAngle, 0.0, 1.0, 0.0, -sinAngle, 0.0, cosAngle); + } + result[0] = cosAngle; + result[1] = 0.0; + result[2] = -sinAngle; + result[3] = 0.0; + result[4] = 1.0; + result[5] = 0.0; + result[6] = sinAngle; + result[7] = 0.0; + result[8] = cosAngle; + return result; + } + static fromRotationZstatic(angle, result) { + const cosAngle = Math.cos(angle); + const sinAngle = Math.sin(angle); + if (!defined(result)) { + return new Matrix3(cosAngle, -sinAngle, 0.0, sinAngle, cosAngle, 0.0, 0.0, 0.0, 1.0); + } + result[0] = cosAngle; + result[1] = sinAngle; + result[2] = 0.0; + result[3] = -sinAngle; + result[4] = cosAngle; + result[5] = 0.0; + result[6] = 0.0; + result[7] = 0.0; + result[8] = 1.0; + return result; } toArray() { - const e = []; - return Ge.toArray(this, e), e; - } - static toArray(e, t) { - return pe(t) - ? ((t[0] = e[0]), - (t[1] = e[1]), - (t[2] = e[2]), - (t[3] = e[3]), - (t[4] = e[4]), - (t[5] = e[5]), - (t[6] = e[6]), - (t[7] = e[7]), - (t[8] = e[8]), - t) - : [e[0], e[1], e[2], e[3], e[4], e[5], e[6], e[7], e[8]]; - } - static getElementIndex(e, t) { - return 3 * e + t; - } - static getColumn(e, t, i) { - const r = 3 * t, - n = e[r], - s = e[r + 1], - a = e[r + 2]; - return (i.x = n), (i.y = s), (i.z = a), i; - } - static setColumn(e, t, i, r) { - const n = 3 * t; - return ((r = Ge.clone(e, r))[n] = i.x), (r[n + 1] = i.y), (r[n + 2] = i.z), r; - } - static getRow(e, t, i) { - const r = e[t], - n = e[t + 3], - s = e[t + 6]; - return (i.x = r), (i.y = n), (i.z = s), i; - } - static setRow(e, t, i, r) { - return ((r = Ge.clone(e, r))[t] = i.x), (r[t + 3] = i.y), (r[t + 6] = i.z), r; - } - static setScale(e, t, i) { - const r = Ge.getScale(e, ke), - n = t.x / r.x, - s = t.y / r.y, - a = t.z / r.z; + const result = []; + Matrix3.toArray(this, result); + return result; + } + static toArray(matrix, result) { + if (!defined(result)) { + return [matrix[0], matrix[1], matrix[2], matrix[3], matrix[4], matrix[5], matrix[6], matrix[7], matrix[8]]; + } + result[0] = matrix[0]; + result[1] = matrix[1]; + result[2] = matrix[2]; + result[3] = matrix[3]; + result[4] = matrix[4]; + result[5] = matrix[5]; + result[6] = matrix[6]; + result[7] = matrix[7]; + result[8] = matrix[8]; + return result; + } + static getElementIndex(column, row) { + return column * 3 + row; + } + static getColumn(matrix, index, result) { + const startIndex = index * 3; + const x = matrix[startIndex]; + const y = matrix[startIndex + 1]; + const z = matrix[startIndex + 2]; + result.x = x; + result.y = y; + result.z = z; + return result; + } + static setColumn(matrix, index, cartesian, result) { + result = Matrix3.clone(matrix, result); + const startIndex = index * 3; + result[startIndex] = cartesian.x; + result[startIndex + 1] = cartesian.y; + result[startIndex + 2] = cartesian.z; + return result; + } + static getRow(matrix, index, result) { + const x = matrix[index]; + const y = matrix[index + 3]; + const z = matrix[index + 6]; + result.x = x; + result.y = y; + result.z = z; + return result; + } + static setRow(matrix, index, cartesian, result) { + result = Matrix3.clone(matrix, result); + result[index] = cartesian.x; + result[index + 3] = cartesian.y; + result[index + 6] = cartesian.z; + return result; + } + static setScale(matrix, scale, result) { + const existingScale = Matrix3.getScale(matrix, scaleScratch1$2); + const scaleRatioX = scale.x / existingScale.x; + const scaleRatioY = scale.y / existingScale.y; + const scaleRatioZ = scale.z / existingScale.z; + result[0] = matrix[0] * scaleRatioX; + result[1] = matrix[1] * scaleRatioX; + result[2] = matrix[2] * scaleRatioX; + result[3] = matrix[3] * scaleRatioY; + result[4] = matrix[4] * scaleRatioY; + result[5] = matrix[5] * scaleRatioY; + result[6] = matrix[6] * scaleRatioZ; + result[7] = matrix[7] * scaleRatioZ; + result[8] = matrix[8] * scaleRatioZ; + return result; + } + static getScale(matrix, result) { + result.x = Vector3.magnitude(Vector3.fromElements(matrix[0], matrix[1], matrix[2], scratchColumn$2)); + result.y = Vector3.magnitude(Vector3.fromElements(matrix[3], matrix[4], matrix[5], scratchColumn$2)); + result.z = Vector3.magnitude(Vector3.fromElements(matrix[6], matrix[7], matrix[8], scratchColumn$2)); + return result; + } + static getMaximumScale(matrix) { + Matrix3.getScale(matrix, scaleScratch3$2); + return Vector3.maximumComponent(scaleScratch3$2); + } + static setRotation(matrix, rotation, result) { + const scale = Matrix3.getScale(matrix, scaleScratch4$2); + result[0] = rotation[0] * scale.x; + result[1] = rotation[1] * scale.x; + result[2] = rotation[2] * scale.x; + result[3] = rotation[3] * scale.y; + result[4] = rotation[4] * scale.y; + result[5] = rotation[5] * scale.y; + result[6] = rotation[6] * scale.z; + result[7] = rotation[7] * scale.z; + result[8] = rotation[8] * scale.z; + return result; + } + static getRotation(matrix, result) { + const scale = Matrix3.getScale(matrix, scaleScratch5$2); + result[0] = matrix[0] / scale.x; + result[1] = matrix[1] / scale.x; + result[2] = matrix[2] / scale.x; + result[3] = matrix[3] / scale.y; + result[4] = matrix[4] / scale.y; + result[5] = matrix[5] / scale.y; + result[6] = matrix[6] / scale.z; + result[7] = matrix[7] / scale.z; + result[8] = matrix[8] / scale.z; + return result; + } + static multiply(left, right, result) { + const column0Row0 = left[0] * right[0] + left[3] * right[1] + left[6] * right[2]; + const column0Row1 = left[1] * right[0] + left[4] * right[1] + left[7] * right[2]; + const column0Row2 = left[2] * right[0] + left[5] * right[1] + left[8] * right[2]; + const column1Row0 = left[0] * right[3] + left[3] * right[4] + left[6] * right[5]; + const column1Row1 = left[1] * right[3] + left[4] * right[4] + left[7] * right[5]; + const column1Row2 = left[2] * right[3] + left[5] * right[4] + left[8] * right[5]; + const column2Row0 = left[0] * right[6] + left[3] * right[7] + left[6] * right[8]; + const column2Row1 = left[1] * right[6] + left[4] * right[7] + left[7] * right[8]; + const column2Row2 = left[2] * right[6] + left[5] * right[7] + left[8] * right[8]; + result[0] = column0Row0; + result[1] = column0Row1; + result[2] = column0Row2; + result[3] = column1Row0; + result[4] = column1Row1; + result[5] = column1Row2; + result[6] = column2Row0; + result[7] = column2Row1; + result[8] = column2Row2; + return result; + } + static add(left, right, result) { + result[0] = left[0] + right[0]; + result[1] = left[1] + right[1]; + result[2] = left[2] + right[2]; + result[3] = left[3] + right[3]; + result[4] = left[4] + right[4]; + result[5] = left[5] + right[5]; + result[6] = left[6] + right[6]; + result[7] = left[7] + right[7]; + result[8] = left[8] + right[8]; + return result; + } + static subtract(left, right, result) { + result[0] = left[0] - right[0]; + result[1] = left[1] - right[1]; + result[2] = left[2] - right[2]; + result[3] = left[3] - right[3]; + result[4] = left[4] - right[4]; + result[5] = left[5] - right[5]; + result[6] = left[6] - right[6]; + result[7] = left[7] - right[7]; + result[8] = left[8] - right[8]; + return result; + } + static multiplyByVector(matrix, cartesian, result) { + const vX = cartesian.x; + const vY = cartesian.y; + const vZ = cartesian.z; + const x = matrix[0] * vX + matrix[3] * vY + matrix[6] * vZ; + const y = matrix[1] * vX + matrix[4] * vY + matrix[7] * vZ; + const z = matrix[2] * vX + matrix[5] * vY + matrix[8] * vZ; + result.x = x; + result.y = y; + result.z = z; + return result; + } + static multiplyByScalar(matrix, scalar, result) { + result[0] = matrix[0] * scalar; + result[1] = matrix[1] * scalar; + result[2] = matrix[2] * scalar; + result[3] = matrix[3] * scalar; + result[4] = matrix[4] * scalar; + result[5] = matrix[5] * scalar; + result[6] = matrix[6] * scalar; + result[7] = matrix[7] * scalar; + result[8] = matrix[8] * scalar; + return result; + } + static multiplyByScale(matrix, scale, result) { + result[0] = matrix[0] * scale.x; + result[1] = matrix[1] * scale.x; + result[2] = matrix[2] * scale.x; + result[3] = matrix[3] * scale.y; + result[4] = matrix[4] * scale.y; + result[5] = matrix[5] * scale.y; + result[6] = matrix[6] * scale.z; + result[7] = matrix[7] * scale.z; + result[8] = matrix[8] * scale.z; + return result; + } + static negate(matrix, result) { + result[0] = -matrix[0]; + result[1] = -matrix[1]; + result[2] = -matrix[2]; + result[3] = -matrix[3]; + result[4] = -matrix[4]; + result[5] = -matrix[5]; + result[6] = -matrix[6]; + result[7] = -matrix[7]; + result[8] = -matrix[8]; + return result; + } + static transpose(matrix, result) { + const column0Row0 = matrix[0]; + const column0Row1 = matrix[3]; + const column0Row2 = matrix[6]; + const column1Row0 = matrix[1]; + const column1Row1 = matrix[4]; + const column1Row2 = matrix[7]; + const column2Row0 = matrix[2]; + const column2Row1 = matrix[5]; + const column2Row2 = matrix[8]; + result[0] = column0Row0; + result[1] = column0Row1; + result[2] = column0Row2; + result[3] = column1Row0; + result[4] = column1Row1; + result[5] = column1Row2; + result[6] = column2Row0; + result[7] = column2Row1; + result[8] = column2Row2; + return result; + } + static abs(matrix, result) { + result[0] = Math.abs(matrix[0]); + result[1] = Math.abs(matrix[1]); + result[2] = Math.abs(matrix[2]); + result[3] = Math.abs(matrix[3]); + result[4] = Math.abs(matrix[4]); + result[5] = Math.abs(matrix[5]); + result[6] = Math.abs(matrix[6]); + result[7] = Math.abs(matrix[7]); + result[8] = Math.abs(matrix[8]); + return result; + } + static determinant(matrix) { + const m11 = matrix[0]; + const m21 = matrix[3]; + const m31 = matrix[6]; + const m12 = matrix[1]; + const m22 = matrix[4]; + const m32 = matrix[7]; + const m13 = matrix[2]; + const m23 = matrix[5]; + const m33 = matrix[8]; + return m11 * (m22 * m33 - m23 * m32) + m12 * (m23 * m31 - m21 * m33) + m13 * (m21 * m32 - m22 * m31); + } + static inverse(matrix, result) { + const m11 = matrix[0]; + const m21 = matrix[1]; + const m31 = matrix[2]; + const m12 = matrix[3]; + const m22 = matrix[4]; + const m32 = matrix[5]; + const m13 = matrix[6]; + const m23 = matrix[7]; + const m33 = matrix[8]; + const determinant = Matrix3.determinant(matrix); + // >>includeStart('debug', pragmas.debug); + if (Math.abs(determinant) <= GMath.EPSILON15) { + throw new Error("matrix is not invertible"); + } + // >>includeEnd('debug'); + result[0] = m22 * m33 - m23 * m32; + result[1] = m23 * m31 - m21 * m33; + result[2] = m21 * m32 - m22 * m31; + result[3] = m13 * m32 - m12 * m33; + result[4] = m11 * m33 - m13 * m31; + result[5] = m12 * m31 - m11 * m32; + result[6] = m12 * m23 - m13 * m22; + result[7] = m13 * m21 - m11 * m23; + result[8] = m11 * m22 - m12 * m21; + const scale = 1.0 / determinant; + return Matrix3.multiplyByScalar(result, scale, result); + } + static inverseTranspose(matrix, result) { + return Matrix3.inverse(Matrix3.transpose(matrix, scratchTransposeMatrix$1), result); + } + static equals(left, right) { return ( - (i[0] = e[0] * n), - (i[1] = e[1] * n), - (i[2] = e[2] * n), - (i[3] = e[3] * s), - (i[4] = e[4] * s), - (i[5] = e[5] * s), - (i[6] = e[6] * a), - (i[7] = e[7] * a), - (i[8] = e[8] * a), - i + left === right || + (defined(left) && + defined(right) && + left[0] === right[0] && + left[1] === right[1] && + left[2] === right[2] && + left[3] === right[3] && + left[4] === right[4] && + left[5] === right[5] && + left[6] === right[6] && + left[7] === right[7] && + left[8] === right[8]) ); } - static getScale(e, t) { + static equalsEpsilon(left, right, epsilon = 0) { + epsilon = defaultValue(epsilon, 0); return ( - (t.x = Ue.magnitude(Ue.fromElements(e[0], e[1], e[2], qe))), - (t.y = Ue.magnitude(Ue.fromElements(e[3], e[4], e[5], qe))), - (t.z = Ue.magnitude(Ue.fromElements(e[6], e[7], e[8], qe))), - t + left === right || + (defined(left) && + defined(right) && + Math.abs(left[0] - right[0]) <= epsilon && + Math.abs(left[1] - right[1]) <= epsilon && + Math.abs(left[2] - right[2]) <= epsilon && + Math.abs(left[3] - right[3]) <= epsilon && + Math.abs(left[4] - right[4]) <= epsilon && + Math.abs(left[5] - right[5]) <= epsilon && + Math.abs(left[6] - right[6]) <= epsilon && + Math.abs(left[7] - right[7]) <= epsilon && + Math.abs(left[8] - right[8]) <= epsilon) ); } - static getMaximumScale(e) { - return Ge.getScale(e, je), Ue.maximumComponent(je); + clone(result) { + return Matrix3.clone(this, result); } - static setRotation(e, t, i) { - const r = Ge.getScale(e, He); - return ( - (i[0] = t[0] * r.x), - (i[1] = t[1] * r.x), - (i[2] = t[2] * r.x), - (i[3] = t[3] * r.y), - (i[4] = t[4] * r.y), - (i[5] = t[5] * r.y), - (i[6] = t[6] * r.z), - (i[7] = t[7] * r.z), - (i[8] = t[8] * r.z), - i - ); + equals(right) { + return Matrix3.equals(this, right); } - static getRotation(e, t) { - const i = Ge.getScale(e, Xe); + /** + * @private + */ + equalsArray(matrix, array, offset) { return ( - (t[0] = e[0] / i.x), - (t[1] = e[1] / i.x), - (t[2] = e[2] / i.x), - (t[3] = e[3] / i.y), - (t[4] = e[4] / i.y), - (t[5] = e[5] / i.y), - (t[6] = e[6] / i.z), - (t[7] = e[7] / i.z), - (t[8] = e[8] / i.z), - t + matrix[0] === array[offset] && + matrix[1] === array[offset + 1] && + matrix[2] === array[offset + 2] && + matrix[3] === array[offset + 3] && + matrix[4] === array[offset + 4] && + matrix[5] === array[offset + 5] && + matrix[6] === array[offset + 6] && + matrix[7] === array[offset + 7] && + matrix[8] === array[offset + 8] ); } - static multiply(e, t, i) { - const r = e[0] * t[0] + e[3] * t[1] + e[6] * t[2], - n = e[1] * t[0] + e[4] * t[1] + e[7] * t[2], - s = e[2] * t[0] + e[5] * t[1] + e[8] * t[2], - a = e[0] * t[3] + e[3] * t[4] + e[6] * t[5], - o = e[1] * t[3] + e[4] * t[4] + e[7] * t[5], - c = e[2] * t[3] + e[5] * t[4] + e[8] * t[5], - l = e[0] * t[6] + e[3] * t[7] + e[6] * t[8], - h = e[1] * t[6] + e[4] * t[7] + e[7] * t[8], - u = e[2] * t[6] + e[5] * t[7] + e[8] * t[8]; - return ( - (i[0] = r), - (i[1] = n), - (i[2] = s), - (i[3] = a), - (i[4] = o), - (i[5] = c), - (i[6] = l), - (i[7] = h), - (i[8] = u), - i - ); + /** + * Compares this matrix to the provided matrix componentwise and returns + * true if they are within the provided epsilon, + * false otherwise. + * + * @param {Matrix3} [right] The right hand side matrix. + * @param {Number} [epsilon=0] The epsilon to use for equality testing. + * @returns {Boolean} true if they are within the provided epsilon, false otherwise. + */ + equalsEpsilon(right, epsilon) { + return Matrix3.equalsEpsilon(this, right, epsilon); } - static add(e, t, i) { + toString() { return ( - (i[0] = e[0] + t[0]), - (i[1] = e[1] + t[1]), - (i[2] = e[2] + t[2]), - (i[3] = e[3] + t[3]), - (i[4] = e[4] + t[4]), - (i[5] = e[5] + t[5]), - (i[6] = e[6] + t[6]), - (i[7] = e[7] + t[7]), - (i[8] = e[8] + t[8]), - i + `(${this[0]}, ${this[3]}, ${this[6]})\n` + + `(${this[1]}, ${this[4]}, ${this[7]})\n` + + `(${this[2]}, ${this[5]}, ${this[8]})` ); } - static subtract(e, t, i) { - return ( - (i[0] = e[0] - t[0]), - (i[1] = e[1] - t[1]), - (i[2] = e[2] - t[2]), - (i[3] = e[3] - t[3]), - (i[4] = e[4] - t[4]), - (i[5] = e[5] - t[5]), - (i[6] = e[6] - t[6]), - (i[7] = e[7] - t[7]), - (i[8] = e[8] - t[8]), - i - ); +} +Matrix3.IDENTITY = Object.freeze(new Matrix3(1.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 1.0)); +Matrix3.ZERO = Object.freeze(new Matrix3(0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0)); +const scaleScratch1$2 = new Vector3(); +new Vector3(); +const scratchColumn$2 = new Vector3(); +const scaleScratch3$2 = new Vector3(); +const scaleScratch4$2 = new Vector3(); +const scaleScratch5$2 = new Vector3(); +const scratchTransposeMatrix$1 = new Matrix3(); + +class Vector4 { + constructor(x = 0, y = 0, z = 0, w = 0) { + this.x = x; + this.y = y; + this.z = z; + this.w = w; + } + set(x, y, z, w) { + this.x = x; + this.y = y; + this.z = z; + this.w = w; } - static multiplyByVector(e, t, i) { - const r = t.x, - n = t.y, - s = t.z, - a = e[0] * r + e[3] * n + e[6] * s, - o = e[1] * r + e[4] * n + e[7] * s, - c = e[2] * r + e[5] * n + e[8] * s; - return (i.x = a), (i.y = o), (i.z = c), i; + toArray() { + return [this.x, this.y, this.z, this.w]; } - static multiplyByScalar(e, t, i) { - return ( - (i[0] = e[0] * t), - (i[1] = e[1] * t), - (i[2] = e[2] * t), - (i[3] = e[3] * t), - (i[4] = e[4] * t), - (i[5] = e[5] * t), - (i[6] = e[6] * t), - (i[7] = e[7] * t), - (i[8] = e[8] * t), - i - ); + clone(result) { + return Vector4.clone(this, result); } - static multiplyByScale(e, t, i) { - return ( - (i[0] = e[0] * t.x), - (i[1] = e[1] * t.x), - (i[2] = e[2] * t.x), - (i[3] = e[3] * t.y), - (i[4] = e[4] * t.y), - (i[5] = e[5] * t.y), - (i[6] = e[6] * t.z), - (i[7] = e[7] * t.z), - (i[8] = e[8] * t.z), - i - ); + equals(right) { + return Vector4.equals(this, right); } - static negate(e, t) { - return ( - (t[0] = -e[0]), - (t[1] = -e[1]), - (t[2] = -e[2]), - (t[3] = -e[3]), - (t[4] = -e[4]), - (t[5] = -e[5]), - (t[6] = -e[6]), - (t[7] = -e[7]), - (t[8] = -e[8]), - t - ); + equalsEpsilon(right, relativeEpsilon = 0, absoluteEpsilon = 0) { + return Vector4.equalsEpsilon(this, right, relativeEpsilon, absoluteEpsilon); } - static transpose(e, t) { - const i = e[0], - r = e[3], - n = e[6], - s = e[1], - a = e[4], - o = e[7], - c = e[2], - l = e[5], - h = e[8]; - return ( - (t[0] = i), - (t[1] = r), - (t[2] = n), - (t[3] = s), - (t[4] = a), - (t[5] = o), - (t[6] = c), - (t[7] = l), - (t[8] = h), - t - ); + toString() { + return `(${this.x}, ${this.y}, ${this.z}, ${this.w})`; + } + fromBufferAttribute(attribute, index) { + this.x = attribute.getX(index); + this.y = attribute.getY(index); + this.z = attribute.getZ(index); + this.w = attribute.getW(index); + return this; } - static abs(e, t) { + static fromElements(x, y, z, w, result) { + if (!defined(result)) { + return new Vector4(x, y, z, w); + } + result.x = x; + result.y = y; + result.z = z; + result.w = w; + return result; + } + static clone(cartesian, result) { + if (!defined(cartesian)) { + return undefined; + } + if (!defined(result)) { + return new Vector4(cartesian.x, cartesian.y, cartesian.z, cartesian.w); + } + result.x = cartesian.x; + result.y = cartesian.y; + result.z = cartesian.z; + result.w = cartesian.w; + return result; + } + static maximumComponent(cartesian) { + return Math.max(cartesian.x, cartesian.y, cartesian.z, cartesian.w); + } + static minimumComponent(cartesian) { + return Math.min(cartesian.x, cartesian.y, cartesian.z, cartesian.w); + } + static minimumByComponent(first, second, result) { + result.x = Math.min(first.x, second.x); + result.y = Math.min(first.y, second.y); + result.z = Math.min(first.z, second.z); + result.w = Math.min(first.w, second.w); + return result; + } + static maximumByComponent(first, second, result) { + result.x = Math.max(first.x, second.x); + result.y = Math.max(first.y, second.y); + result.z = Math.max(first.z, second.z); + result.w = Math.max(first.w, second.w); + return result; + } + static clamp(value, min, max, result) { + const x = GMath.clamp(value.x, min.x, max.x); + const y = GMath.clamp(value.y, min.y, max.y); + const z = GMath.clamp(value.z, min.z, max.z); + const w = GMath.clamp(value.w, min.w, max.w); + result.x = x; + result.y = y; + result.z = z; + result.w = w; + return result; + } + static magnitudeSquared(cartesian) { return ( - (t[0] = Math.abs(e[0])), - (t[1] = Math.abs(e[1])), - (t[2] = Math.abs(e[2])), - (t[3] = Math.abs(e[3])), - (t[4] = Math.abs(e[4])), - (t[5] = Math.abs(e[5])), - (t[6] = Math.abs(e[6])), - (t[7] = Math.abs(e[7])), - (t[8] = Math.abs(e[8])), - t + cartesian.x * cartesian.x + + cartesian.y * cartesian.y + + cartesian.z * cartesian.z + + cartesian.w * cartesian.w ); } - static determinant(e) { - const t = e[0], - i = e[3], - r = e[6], - n = e[1], - s = e[4], - a = e[7], - o = e[2], - c = e[5], - l = e[8]; - return t * (s * l - c * a) + n * (c * r - i * l) + o * (i * a - s * r); - } - static inverse(e, t) { - const i = e[0], - r = e[1], - n = e[2], - s = e[3], - a = e[4], - o = e[5], - c = e[6], - l = e[7], - h = e[8], - u = Ge.determinant(e); - if (Math.abs(u) <= ve.EPSILON15) throw new Error("matrix is not invertible"); - (t[0] = a * h - l * o), - (t[1] = l * n - r * h), - (t[2] = r * o - a * n), - (t[3] = c * o - s * h), - (t[4] = i * h - c * n), - (t[5] = s * n - i * o), - (t[6] = s * l - c * a), - (t[7] = c * r - i * l), - (t[8] = i * a - s * r); - const f = 1 / u; - return Ge.multiplyByScalar(t, f, t); - } - static inverseTranspose(e, t) { - return Ge.inverse(Ge.transpose(e, Ye), t); - } - static equals(e, t) { + static magnitude(cartesian) { + return Math.sqrt(Vector4.magnitudeSquared(cartesian)); + } + static distance(left, right) { + Vector4.subtract(left, right, distanceScratch); + return Vector4.magnitude(distanceScratch); + } + static distanceSquared(left, right) { + Vector4.subtract(left, right, distanceScratch); + return Vector4.magnitudeSquared(distanceScratch); + } + static normalize(cartesian, result) { + const magnitude = Vector4.magnitude(cartesian); + result.x = cartesian.x / magnitude; + result.y = cartesian.y / magnitude; + result.z = cartesian.z / magnitude; + result.w = cartesian.w / magnitude; + // >>includeStart('debug', pragmas.debug); + if (isNaN(result.x) || isNaN(result.y) || isNaN(result.z) || isNaN(result.w)) { + throw new Error("normalized result is not a number"); + } + // >>includeEnd('debug'); + return result; + } + static dot(left, right) { + return left.x * right.x + left.y * right.y + left.z * right.z + left.w * right.w; + } + static multiplyComponents(left, right, result) { + result.x = left.x * right.x; + result.y = left.y * right.y; + result.z = left.z * right.z; + result.w = left.w * right.w; + return result; + } + static divideComponents(left, right, result) { + result.x = left.x / right.x; + result.y = left.y / right.y; + result.z = left.z / right.z; + result.w = left.w / right.w; + return result; + } + static add(left, right, result) { + result.x = left.x + right.x; + result.y = left.y + right.y; + result.z = left.z + right.z; + result.w = left.w + right.w; + return result; + } + static subtract(left, right, result) { + result.x = left.x - right.x; + result.y = left.y - right.y; + result.z = left.z - right.z; + result.w = left.w - right.w; + return result; + } + static multiplyByScalar(cartesian, scalar, result) { + result.x = cartesian.x * scalar; + result.y = cartesian.y * scalar; + result.z = cartesian.z * scalar; + result.w = cartesian.w * scalar; + return result; + } + static divideByScalar(cartesian, scalar, result) { + result.x = cartesian.x / scalar; + result.y = cartesian.y / scalar; + result.z = cartesian.z / scalar; + result.w = cartesian.w / scalar; + return result; + } + static negate(cartesian, result) { + result.x = -cartesian.x; + result.y = -cartesian.y; + result.z = -cartesian.z; + result.w = -cartesian.w; + return result; + } + static abs(cartesian, result) { + result.x = Math.abs(cartesian.x); + result.y = Math.abs(cartesian.y); + result.z = Math.abs(cartesian.z); + result.w = Math.abs(cartesian.w); + return result; + } + static lerp(start, end, t, result) { + Vector4.multiplyByScalar(end, t, lerpScratch$1); + result = Vector4.multiplyByScalar(start, 1.0 - t, result); + return Vector4.add(lerpScratch$1, result, result); + } + static equals(left, right) { return ( - e === t || - (pe(e) && - pe(t) && - e[0] === t[0] && - e[1] === t[1] && - e[2] === t[2] && - e[3] === t[3] && - e[4] === t[4] && - e[5] === t[5] && - e[6] === t[6] && - e[7] === t[7] && - e[8] === t[8]) + left === right || + (defined(left) && + defined(right) && + left.x === right.x && + left.y === right.y && + left.z === right.z && + left.w === right.w) ); } - static equalsEpsilon(e, t, i = 0) { + static equalsArray(cartesian, array, offset) { return ( - (i = ee(i, 0)), - e === t || - (pe(e) && - pe(t) && - Math.abs(e[0] - t[0]) <= i && - Math.abs(e[1] - t[1]) <= i && - Math.abs(e[2] - t[2]) <= i && - Math.abs(e[3] - t[3]) <= i && - Math.abs(e[4] - t[4]) <= i && - Math.abs(e[5] - t[5]) <= i && - Math.abs(e[6] - t[6]) <= i && - Math.abs(e[7] - t[7]) <= i && - Math.abs(e[8] - t[8]) <= i) + cartesian.x === array[offset] && + cartesian.y === array[offset + 1] && + cartesian.z === array[offset + 2] && + cartesian.w === array[offset + 3] ); } - clone(e) { - return Ge.clone(this, e); - } - equals(e) { - return Ge.equals(this, e); - } - equalsArray(e, t, i) { + static equalsEpsilon(left, right, relativeEpsilon = 0, absoluteEpsilon = 0) { return ( - e[0] === t[i] && - e[1] === t[i + 1] && - e[2] === t[i + 2] && - e[3] === t[i + 3] && - e[4] === t[i + 4] && - e[5] === t[i + 5] && - e[6] === t[i + 6] && - e[7] === t[i + 7] && - e[8] === t[i + 8] + left === right || + (defined(left) && + defined(right) && + GMath.equalsEpsilon(left.x, right.x, relativeEpsilon, absoluteEpsilon) && + GMath.equalsEpsilon(left.y, right.y, relativeEpsilon, absoluteEpsilon) && + GMath.equalsEpsilon(left.z, right.z, relativeEpsilon, absoluteEpsilon) && + GMath.equalsEpsilon(left.w, right.w, relativeEpsilon, absoluteEpsilon)) ); } - equalsEpsilon(e, t) { - return Ge.equalsEpsilon(this, e, t); - } - toString() { - return `(${this[0]}, ${this[3]}, ${this[6]})\n(${this[1]}, ${this[4]}, ${this[7]})\n(${this[2]}, ${this[5]}, ${this[8]})`; - } } -(Ge.IDENTITY = Object.freeze(new Ge(1, 0, 0, 0, 1, 0, 0, 0, 1))), - (Ge.ZERO = Object.freeze(new Ge(0, 0, 0, 0, 0, 0, 0, 0, 0))); -const ke = new Ue(); -new Ue(); -const qe = new Ue(), - je = new Ue(), - He = new Ue(), - Xe = new Ue(), - Ye = new Ge(); -class We { - constructor(e = 0, t = 0, i = 0, r = 0) { - (this.x = e), (this.y = t), (this.z = i), (this.w = r); - } - set(e, t, i, r) { - (this.x = e), (this.y = t), (this.z = i), (this.w = r); - } - toArray() { - return [this.x, this.y, this.z, this.w]; +Vector4.ZERO = Object.freeze(new Vector4(0.0, 0.0, 0.0, 0.0)); +Vector4.ONE = Object.freeze(new Vector4(1.0, 1.0, 1.0, 1.0)); +Vector4.UNIT_X = Object.freeze(new Vector4(1.0, 0.0, 0.0, 0.0)); +Vector4.UNIT_Y = Object.freeze(new Vector4(0.0, 1.0, 0.0, 0.0)); +Vector4.UNIT_Z = Object.freeze(new Vector4(0.0, 0.0, 1.0, 0.0)); +Vector4.UNIT_W = Object.freeze(new Vector4(0.0, 0.0, 0.0, 1.0)); +// scratchU8Array and scratchF32Array are views into the same buffer +const scratchF32Array = new Float32Array(1); +new Uint8Array(scratchF32Array.buffer); +const testU32 = new Uint32Array([0x11223344]); +const testU8 = new Uint8Array(testU32.buffer); +testU8[0] === 0x44; +const distanceScratch = new Vector4(); +const lerpScratch$1 = new Vector4(); +new Vector4(); + +class Matrix4 { + /** + * A 4x4 matrix, indexable as a column-major order array. + * @param {Number} [column0Row0=0.0] The value for column 0, row 0. + * @param {Number} [column1Row0=0.0] The value for column 1, row 0. + * @param {Number} [column2Row0=0.0] The value for column 2, row 0. + * @param {Number} [column3Row0=0.0] The value for column 3, row 0. + * @param {Number} [column0Row1=0.0] The value for column 0, row 1. + * @param {Number} [column1Row1=0.0] The value for column 1, row 1. + * @param {Number} [column2Row1=0.0] The value for column 2, row 1. + * @param {Number} [column3Row1=0.0] The value for column 3, row 1. + * @param {Number} [column0Row2=0.0] The value for column 0, row 2. + * @param {Number} [column1Row2=0.0] The value for column 1, row 2. + * @param {Number} [column2Row2=0.0] The value for column 2, row 2. + * @param {Number} [column3Row2=0.0] The value for column 3, row 2. + * @param {Number} [column0Row3=0.0] The value for column 0, row 3. + * @param {Number} [column1Row3=0.0] The value for column 1, row 3. + * @param {Number} [column2Row3=0.0] The value for column 2, row 3. + * @param {Number} [column3Row3=0.0] The value for column 3, row 3. + */ + constructor( + column0Row0 = 0, + column1Row0 = 0, + column2Row0 = 0, + column3Row0 = 0, + column0Row1 = 0, + column1Row1 = 0, + column2Row1 = 0, + column3Row1 = 0, + column0Row2 = 0, + column1Row2 = 0, + column2Row2 = 0, + column3Row2 = 0, + column0Row3 = 0, + column1Row3 = 0, + column2Row3 = 0, + column3Row3 = 0 + ) { + this[0] = column0Row0; + this[1] = column0Row1; + this[2] = column0Row2; + this[3] = column0Row3; + this[4] = column1Row0; + this[5] = column1Row1; + this[6] = column1Row2; + this[7] = column1Row3; + this[8] = column2Row0; + this[9] = column2Row1; + this[10] = column2Row2; + this[11] = column2Row3; + this[12] = column3Row0; + this[13] = column3Row1; + this[14] = column3Row2; + this[15] = column3Row3; + } + // ???? + clone(result = new Matrix4()) { + return Matrix4.clone(this, result); + } + set(mat4) { + Matrix4.clone(mat4, this); + return this; } - clone(e) { - return We.clone(this, e); + equals(right) { + return Matrix4.equals(this, right); + } + compose(position, quaternion, scale) { + const te = this; + const x = quaternion.x, + y = quaternion.y, + z = quaternion.z, + w = quaternion.w; + const x2 = x + x, + y2 = y + y, + z2 = z + z; + const xx = x * x2, + xy = x * y2, + xz = x * z2; + const yy = y * y2, + yz = y * z2, + zz = z * z2; + const wx = w * x2, + wy = w * y2, + wz = w * z2; + const sx = scale.x, + sy = scale.y, + sz = scale.z; + te[0] = (1 - (yy + zz)) * sx; + te[1] = (xy + wz) * sx; + te[2] = (xz - wy) * sx; + te[3] = 0; + te[4] = (xy - wz) * sy; + te[5] = (1 - (xx + zz)) * sy; + te[6] = (yz + wx) * sy; + te[7] = 0; + te[8] = (xz + wy) * sz; + te[9] = (yz - wx) * sz; + te[10] = (1 - (xx + yy)) * sz; + te[11] = 0; + te[12] = position.x; + te[13] = position.y; + te[14] = position.z; + te[15] = 1; + return this; } - equals(e) { - return We.equals(this, e); + equalsEpsilon(right, epsilon = 0) { + return Matrix4.equalsEpsilon(this, right, epsilon); } - equalsEpsilon(e, t = 0, i = 0) { - return We.equalsEpsilon(this, e, t, i); + lookAt(eye, target, up) { + const matrix = this; + Vector3.subtract(eye, target, z); + if (z.length() === 0) { + // eye and target are in the same position + z.z = 1; + } + z.normalize(); + Vector3.cross(up, z, x); + if (x.length() === 0) { + // up and z are parallel + if (Math.abs(up.z) === 1) { + z.x += 0.0001; + } else { + z.z += 0.0001; + } + z.normalize(); + Vector3.cross(up, z, x); + } + x.normalize(); + Vector3.cross(z, x, y); + matrix[0] = x.x; + matrix[4] = y.x; + matrix[8] = z.x; + matrix[1] = x.y; + matrix[5] = y.y; + matrix[9] = z.y; + matrix[2] = x.z; + matrix[6] = y.z; + matrix[10] = z.z; + return this; } toString() { - return `(${this.x}, ${this.y}, ${this.z}, ${this.w})`; - } - fromBufferAttribute(e, t) { - return (this.x = e.getX(t)), (this.y = e.getY(t)), (this.z = e.getZ(t)), (this.w = e.getW(t)), this; - } - static fromElements(e, t, i, r, n) { - return pe(n) ? ((n.x = e), (n.y = t), (n.z = i), (n.w = r), n) : new We(e, t, i, r); - } - static clone(e, t) { - if (pe(e)) return pe(t) ? ((t.x = e.x), (t.y = e.y), (t.z = e.z), (t.w = e.w), t) : new We(e.x, e.y, e.z, e.w); - } - static maximumComponent(e) { - return Math.max(e.x, e.y, e.z, e.w); - } - static minimumComponent(e) { - return Math.min(e.x, e.y, e.z, e.w); - } - static minimumByComponent(e, t, i) { return ( - (i.x = Math.min(e.x, t.x)), - (i.y = Math.min(e.y, t.y)), - (i.z = Math.min(e.z, t.z)), - (i.w = Math.min(e.w, t.w)), - i + `(${this[0]}, ${this[4]}, ${this[8]}, ${this[12]})\n` + + `(${this[1]}, ${this[5]}, ${this[9]}, ${this[13]})\n` + + `(${this[2]}, ${this[6]}, ${this[10]}, ${this[14]})\n` + + `(${this[3]}, ${this[7]}, ${this[11]}, ${this[15]})` ); } - static maximumByComponent(e, t, i) { - return ( - (i.x = Math.max(e.x, t.x)), - (i.y = Math.max(e.y, t.y)), - (i.z = Math.max(e.z, t.z)), - (i.w = Math.max(e.w, t.w)), - i - ); - } - static clamp(e, t, i, r) { - const n = ve.clamp(e.x, t.x, i.x), - s = ve.clamp(e.y, t.y, i.y), - a = ve.clamp(e.z, t.z, i.z), - o = ve.clamp(e.w, t.w, i.w); - return (r.x = n), (r.y = s), (r.z = a), (r.w = o), r; - } - static magnitudeSquared(e) { - return e.x * e.x + e.y * e.y + e.z * e.z + e.w * e.w; - } - static magnitude(e) { - return Math.sqrt(We.magnitudeSquared(e)); - } - static distance(e, t) { - return We.subtract(e, t, Qe), We.magnitude(Qe); - } - static distanceSquared(e, t) { - return We.subtract(e, t, Qe), We.magnitudeSquared(Qe); - } - static normalize(e, t) { - const i = We.magnitude(e); - if ( - ((t.x = e.x / i), - (t.y = e.y / i), - (t.z = e.z / i), - (t.w = e.w / i), - isNaN(t.x) || isNaN(t.y) || isNaN(t.z) || isNaN(t.w)) - ) - throw new Error("normalized result is not a number"); - return t; - } - static dot(e, t) { - return e.x * t.x + e.y * t.y + e.z * t.z + e.w * t.w; - } - static multiplyComponents(e, t, i) { - return (i.x = e.x * t.x), (i.y = e.y * t.y), (i.z = e.z * t.z), (i.w = e.w * t.w), i; - } - static divideComponents(e, t, i) { - return (i.x = e.x / t.x), (i.y = e.y / t.y), (i.z = e.z / t.z), (i.w = e.w / t.w), i; - } - static add(e, t, i) { - return (i.x = e.x + t.x), (i.y = e.y + t.y), (i.z = e.z + t.z), (i.w = e.w + t.w), i; - } - static subtract(e, t, i) { - return (i.x = e.x - t.x), (i.y = e.y - t.y), (i.z = e.z - t.z), (i.w = e.w - t.w), i; - } - static multiplyByScalar(e, t, i) { - return (i.x = e.x * t), (i.y = e.y * t), (i.z = e.z * t), (i.w = e.w * t), i; - } - static divideByScalar(e, t, i) { - return (i.x = e.x / t), (i.y = e.y / t), (i.z = e.z / t), (i.w = e.w / t), i; - } - static negate(e, t) { - return (t.x = -e.x), (t.y = -e.y), (t.z = -e.z), (t.w = -e.w), t; - } - static abs(e, t) { - return (t.x = Math.abs(e.x)), (t.y = Math.abs(e.y)), (t.z = Math.abs(e.z)), (t.w = Math.abs(e.w)), t; - } - static lerp(e, t, i, r) { - return We.multiplyByScalar(t, i, Je), (r = We.multiplyByScalar(e, 1 - i, r)), We.add(Je, r, r); - } - static equals(e, t) { - return e === t || (pe(e) && pe(t) && e.x === t.x && e.y === t.y && e.z === t.z && e.w === t.w); - } - static equalsArray(e, t, i) { - return e.x === t[i] && e.y === t[i + 1] && e.z === t[i + 2] && e.w === t[i + 3]; - } - static equalsEpsilon(e, t, i = 0, r = 0) { - return ( - e === t || - (pe(e) && - pe(t) && - ve.equalsEpsilon(e.x, t.x, i, r) && - ve.equalsEpsilon(e.y, t.y, i, r) && - ve.equalsEpsilon(e.z, t.z, i, r) && - ve.equalsEpsilon(e.w, t.w, i, r)) - ); - } -} -(We.ZERO = Object.freeze(new We(0, 0, 0, 0))), - (We.ONE = Object.freeze(new We(1, 1, 1, 1))), - (We.UNIT_X = Object.freeze(new We(1, 0, 0, 0))), - (We.UNIT_Y = Object.freeze(new We(0, 1, 0, 0))), - (We.UNIT_Z = Object.freeze(new We(0, 0, 1, 0))), - (We.UNIT_W = Object.freeze(new We(0, 0, 0, 1))); -const Ze = new Float32Array(1); -new Uint8Array(Ze.buffer); -const Ke = new Uint32Array([287454020]); -new Uint8Array(Ke.buffer)[0]; -const Qe = new We(), - Je = new We(); -new We(); -class et { - constructor( - e = 0, - t = 0, - i = 0, - r = 0, - n = 0, - s = 0, - a = 0, - o = 0, - c = 0, - l = 0, - h = 0, - u = 0, - f = 0, - d = 0, - m = 0, - p = 0 - ) { - (this[0] = e), - (this[1] = n), - (this[2] = c), - (this[3] = f), - (this[4] = t), - (this[5] = s), - (this[6] = l), - (this[7] = d), - (this[8] = i), - (this[9] = a), - (this[10] = h), - (this[11] = m), - (this[12] = r), - (this[13] = o), - (this[14] = u), - (this[15] = p); - } - clone(e = new et()) { - return et.clone(this, e); - } - set(e) { - return et.clone(e, this), this; - } - equals(e) { - return et.equals(this, e); - } - compose(e, t, i) { - const r = this, - n = t.x, - s = t.y, - a = t.z, - o = t.w, - c = n + n, - l = s + s, - h = a + a, - u = n * c, - f = n * l, - d = n * h, - m = s * l, - p = s * h, - g = a * h, - x = o * c, - v = o * l, - y = o * h, - S = i.x, - b = i.y, - w = i.z; - return ( - (r[0] = (1 - (m + g)) * S), - (r[1] = (f + y) * S), - (r[2] = (d - v) * S), - (r[3] = 0), - (r[4] = (f - y) * b), - (r[5] = (1 - (u + g)) * b), - (r[6] = (p + x) * b), - (r[7] = 0), - (r[8] = (d + v) * w), - (r[9] = (p - x) * w), - (r[10] = (1 - (u + m)) * w), - (r[11] = 0), - (r[12] = e.x), - (r[13] = e.y), - (r[14] = e.z), - (r[15] = 1), - this - ); - } - equalsEpsilon(e, t = 0) { - return et.equalsEpsilon(this, e, t); - } - lookAt(e, t, i) { - const r = this; - return ( - Ue.subtract(e, t, dt), - 0 === dt.length() && (dt.z = 1), - dt.normalize(), - Ue.cross(i, dt, ut), - 0 === ut.length() && - (1 === Math.abs(i.z) ? (dt.x += 1e-4) : (dt.z += 1e-4), dt.normalize(), Ue.cross(i, dt, ut)), - ut.normalize(), - Ue.cross(dt, ut, ft), - (r[0] = ut.x), - (r[4] = ft.x), - (r[8] = dt.x), - (r[1] = ut.y), - (r[5] = ft.y), - (r[9] = dt.y), - (r[2] = ut.z), - (r[6] = ft.z), - (r[10] = dt.z), - this - ); - } - toString() { - return `(${this[0]}, ${this[4]}, ${this[8]}, ${this[12]})\n(${this[1]}, ${this[5]}, ${this[9]}, ${this[13]})\n(${this[2]}, ${this[6]}, ${this[10]}, ${this[14]})\n(${this[3]}, ${this[7]}, ${this[11]}, ${this[15]})`; - } - static clone(e, t) { - if (pe(e)) - return pe(t) - ? ((t[0] = e[0]), - (t[1] = e[1]), - (t[2] = e[2]), - (t[3] = e[3]), - (t[4] = e[4]), - (t[5] = e[5]), - (t[6] = e[6]), - (t[7] = e[7]), - (t[8] = e[8]), - (t[9] = e[9]), - (t[10] = e[10]), - (t[11] = e[11]), - (t[12] = e[12]), - (t[13] = e[13]), - (t[14] = e[14]), - (t[15] = e[15]), - t) - : new et( - e[0], - e[4], - e[8], - e[12], - e[1], - e[5], - e[9], - e[13], - e[2], - e[6], - e[10], - e[14], - e[3], - e[7], - e[11], - e[15] - ); - } - static fromColumnMajorArray(e, t) { - return et.clone(e, t); - } - static fromRowMajorArray(e, t) { - return pe(t) - ? ((t[0] = e[0]), - (t[1] = e[4]), - (t[2] = e[8]), - (t[3] = e[12]), - (t[4] = e[1]), - (t[5] = e[5]), - (t[6] = e[9]), - (t[7] = e[13]), - (t[8] = e[2]), - (t[9] = e[6]), - (t[10] = e[10]), - (t[11] = e[14]), - (t[12] = e[3]), - (t[13] = e[7]), - (t[14] = e[11]), - (t[15] = e[15]), - t) - : new et( - e[0], - e[1], - e[2], - e[3], - e[4], - e[5], - e[6], - e[7], - e[8], - e[9], - e[10], - e[11], - e[12], - e[13], - e[14], - e[15] - ); - } - static fromRotationTranslation(e, t, i) { - return ( - (t = ee(t, Ue.ZERO)), - pe(i) - ? ((i[0] = e[0]), - (i[1] = e[1]), - (i[2] = e[2]), - (i[3] = 0), - (i[4] = e[3]), - (i[5] = e[4]), - (i[6] = e[5]), - (i[7] = 0), - (i[8] = e[6]), - (i[9] = e[7]), - (i[10] = e[8]), - (i[11] = 0), - (i[12] = t.x), - (i[13] = t.y), - (i[14] = t.z), - (i[15] = 1), - i) - : new et(e[0], e[3], e[6], t.x, e[1], e[4], e[7], t.y, e[2], e[5], e[8], t.z, 0, 0, 0, 1) - ); - } - static fromTranslationQuaternionRotationScale(e, t, i, r) { - pe(r) || (r = new et()); - const n = i.x, - s = i.y, - a = i.z, - o = t.x * t.x, - c = t.x * t.y, - l = t.x * t.z, - h = t.x * t.w, - u = t.y * t.y, - f = t.y * t.z, - d = t.y * t.w, - m = t.z * t.z, - p = t.z * t.w, - g = t.w * t.w, - x = o - u - m + g, - v = 2 * (c - p), - y = 2 * (l + d), - S = 2 * (c + p), - b = -o + u - m + g, - w = 2 * (f - h), - T = 2 * (l - d), - E = 2 * (f + h), - M = -o - u + m + g; - return ( - (r[0] = x * n), - (r[1] = S * n), - (r[2] = T * n), - (r[3] = 0), - (r[4] = v * s), - (r[5] = b * s), - (r[6] = E * s), - (r[7] = 0), - (r[8] = y * a), - (r[9] = w * a), - (r[10] = M * a), - (r[11] = 0), - (r[12] = e.x), - (r[13] = e.y), - (r[14] = e.z), - (r[15] = 1), - r - ); - } - static fromTranslationRotationScale(e, t) { - return et.fromTranslationQuaternionRotationScale(e.translation, e.rotation, e.scale, t); - } - static fromTranslation(e, t) { - return et.fromRotationTranslation(Ge.IDENTITY, e, t); - } - static fromScale(e, t) { - return pe(t) - ? ((t[0] = e.x), - (t[1] = 0), - (t[2] = 0), - (t[3] = 0), - (t[4] = 0), - (t[5] = e.y), - (t[6] = 0), - (t[7] = 0), - (t[8] = 0), - (t[9] = 0), - (t[10] = e.z), - (t[11] = 0), - (t[12] = 0), - (t[13] = 0), - (t[14] = 0), - (t[15] = 1), - t) - : new et(e.x, 0, 0, 0, 0, e.y, 0, 0, 0, 0, e.z, 0, 0, 0, 0, 1); - } - static fromRotation(e, t) { - return ( - pe(t) || (t = new et()), - (t[0] = e[0]), - (t[1] = e[1]), - (t[2] = e[2]), - (t[3] = 0), - (t[4] = e[3]), - (t[5] = e[4]), - (t[6] = e[5]), - (t[7] = 0), - (t[8] = e[6]), - (t[9] = e[7]), - (t[10] = e[8]), - (t[11] = 0), - (t[12] = 0), - (t[13] = 0), - (t[14] = 0), - (t[15] = 1), - t - ); - } - static makePerspective(e, t, i, r, n, s) { - const a = new et(), - o = (2 * n) / (t - e), - c = (2 * n) / (i - r), - l = (t + e) / (t - e), - h = (i + r) / (i - r), - u = -s / (s - n), - f = (-s * n) / (s - n); - return ( - (a[0] = o), - (a[4] = 0), - (a[8] = l), - (a[12] = 0), - (a[1] = 0), - (a[5] = c), - (a[9] = h), - (a[13] = 0), - (a[2] = 0), - (a[6] = 0), - (a[10] = u), - (a[14] = f), - (a[3] = 0), - (a[7] = 0), - (a[11] = -1), - (a[15] = 0), - a + static clone(matrix, result) { + if (!defined(matrix)) { + return undefined; + } + if (!defined(result)) { + return new Matrix4( + matrix[0], + matrix[4], + matrix[8], + matrix[12], + matrix[1], + matrix[5], + matrix[9], + matrix[13], + matrix[2], + matrix[6], + matrix[10], + matrix[14], + matrix[3], + matrix[7], + matrix[11], + matrix[15] + ); + } + result[0] = matrix[0]; + result[1] = matrix[1]; + result[2] = matrix[2]; + result[3] = matrix[3]; + result[4] = matrix[4]; + result[5] = matrix[5]; + result[6] = matrix[6]; + result[7] = matrix[7]; + result[8] = matrix[8]; + result[9] = matrix[9]; + result[10] = matrix[10]; + result[11] = matrix[11]; + result[12] = matrix[12]; + result[13] = matrix[13]; + result[14] = matrix[14]; + result[15] = matrix[15]; + return result; + } + static fromColumnMajorArray(values, result) { + return Matrix4.clone(values, result); + } + static fromRowMajorArray(values, result) { + if (!defined(result)) { + return new Matrix4( + values[0], + values[1], + values[2], + values[3], + values[4], + values[5], + values[6], + values[7], + values[8], + values[9], + values[10], + values[11], + values[12], + values[13], + values[14], + values[15] + ); + } + result[0] = values[0]; + result[1] = values[4]; + result[2] = values[8]; + result[3] = values[12]; + result[4] = values[1]; + result[5] = values[5]; + result[6] = values[9]; + result[7] = values[13]; + result[8] = values[2]; + result[9] = values[6]; + result[10] = values[10]; + result[11] = values[14]; + result[12] = values[3]; + result[13] = values[7]; + result[14] = values[11]; + result[15] = values[15]; + return result; + } + static fromRotationTranslation(rotation, translation, result) { + translation = defaultValue(translation, Vector3.ZERO); + if (!defined(result)) { + return new Matrix4( + rotation[0], + rotation[3], + rotation[6], + translation.x, + rotation[1], + rotation[4], + rotation[7], + translation.y, + rotation[2], + rotation[5], + rotation[8], + translation.z, + 0.0, + 0.0, + 0.0, + 1.0 + ); + } + result[0] = rotation[0]; + result[1] = rotation[1]; + result[2] = rotation[2]; + result[3] = 0.0; + result[4] = rotation[3]; + result[5] = rotation[4]; + result[6] = rotation[5]; + result[7] = 0.0; + result[8] = rotation[6]; + result[9] = rotation[7]; + result[10] = rotation[8]; + result[11] = 0.0; + result[12] = translation.x; + result[13] = translation.y; + result[14] = translation.z; + result[15] = 1.0; + return result; + } + static fromTranslationQuaternionRotationScale(translation, rotation, scale, result) { + if (!defined(result)) { + result = new Matrix4(); + } + const scaleX = scale.x; + const scaleY = scale.y; + const scaleZ = scale.z; + const x2 = rotation.x * rotation.x; + const xy = rotation.x * rotation.y; + const xz = rotation.x * rotation.z; + const xw = rotation.x * rotation.w; + const y2 = rotation.y * rotation.y; + const yz = rotation.y * rotation.z; + const yw = rotation.y * rotation.w; + const z2 = rotation.z * rotation.z; + const zw = rotation.z * rotation.w; + const w2 = rotation.w * rotation.w; + const m00 = x2 - y2 - z2 + w2; + const m01 = 2.0 * (xy - zw); + const m02 = 2.0 * (xz + yw); + const m10 = 2.0 * (xy + zw); + const m11 = -x2 + y2 - z2 + w2; + const m12 = 2.0 * (yz - xw); + const m20 = 2.0 * (xz - yw); + const m21 = 2.0 * (yz + xw); + const m22 = -x2 - y2 + z2 + w2; + result[0] = m00 * scaleX; + result[1] = m10 * scaleX; + result[2] = m20 * scaleX; + result[3] = 0.0; + result[4] = m01 * scaleY; + result[5] = m11 * scaleY; + result[6] = m21 * scaleY; + result[7] = 0.0; + result[8] = m02 * scaleZ; + result[9] = m12 * scaleZ; + result[10] = m22 * scaleZ; + result[11] = 0.0; + result[12] = translation.x; + result[13] = translation.y; + result[14] = translation.z; + result[15] = 1.0; + return result; + } + static fromTranslationRotationScale(translationRotationScale, result) { + return Matrix4.fromTranslationQuaternionRotationScale( + translationRotationScale.translation, + translationRotationScale.rotation, + translationRotationScale.scale, + result ); } - static makeOrthographic(e, t, i, r, n, s) { - const a = new et(), - o = 1 / (t - e), - c = 1 / (i - r), - l = 1 / (s - n), - h = (t + e) * o, - u = (i + r) * c, - f = n * l; - return ( - (a[0] = 2 * o), - (a[4] = 0), - (a[8] = 0), - (a[12] = -h), - (a[1] = 0), - (a[5] = 2 * c), - (a[9] = 0), - (a[13] = -u), - (a[2] = 0), - (a[6] = 0), - (a[10] = -1 * l), - (a[14] = -f), - (a[3] = 0), - (a[7] = 0), - (a[11] = 0), - (a[15] = 1), - a - ); + static fromTranslation(translation, result) { + return Matrix4.fromRotationTranslation(Matrix3.IDENTITY, translation, result); + } + static fromScale(scale, result) { + if (!defined(result)) { + return new Matrix4( + scale.x, + 0.0, + 0.0, + 0.0, + 0.0, + scale.y, + 0.0, + 0.0, + 0.0, + 0.0, + scale.z, + 0.0, + 0.0, + 0.0, + 0.0, + 1.0 + ); + } + result[0] = scale.x; + result[1] = 0.0; + result[2] = 0.0; + result[3] = 0.0; + result[4] = 0.0; + result[5] = scale.y; + result[6] = 0.0; + result[7] = 0.0; + result[8] = 0.0; + result[9] = 0.0; + result[10] = scale.z; + result[11] = 0.0; + result[12] = 0.0; + result[13] = 0.0; + result[14] = 0.0; + result[15] = 1.0; + return result; + } + static fromRotation(rotation, result) { + if (!defined(result)) { + result = new Matrix4(); + } + result[0] = rotation[0]; + result[1] = rotation[1]; + result[2] = rotation[2]; + result[3] = 0.0; + result[4] = rotation[3]; + result[5] = rotation[4]; + result[6] = rotation[5]; + result[7] = 0.0; + result[8] = rotation[6]; + result[9] = rotation[7]; + result[10] = rotation[8]; + result[11] = 0.0; + result[12] = 0.0; + result[13] = 0.0; + result[14] = 0.0; + result[15] = 1.0; + return result; + } + static makePerspective(left, right, top, bottom, near, far) { + // from three.js + const matrix = new Matrix4(); + const x = (2 * near) / (right - left); + const y = (2 * near) / (top - bottom); + const a = (right + left) / (right - left); + const b = (top + bottom) / (top - bottom); + const c = -far / (far - near); + const d = (-far * near) / (far - near); + matrix[0] = x; + matrix[4] = 0; + matrix[8] = a; + matrix[12] = 0; + matrix[1] = 0; + matrix[5] = y; + matrix[9] = b; + matrix[13] = 0; + matrix[2] = 0; + matrix[6] = 0; + matrix[10] = c; + matrix[14] = d; + matrix[3] = 0; + matrix[7] = 0; + matrix[11] = -1; + matrix[15] = 0; + return matrix; + } + static makeOrthographic(left, right, top, bottom, near, far) { + const matrix = new Matrix4(); + const w = 1.0 / (right - left); + const h = 1.0 / (top - bottom); + const p = 1.0 / (far - near); + const x = (right + left) * w; + const y = (top + bottom) * h; + const z = near * p; + matrix[0] = 2 * w; + matrix[4] = 0; + matrix[8] = 0; + matrix[12] = -x; + matrix[1] = 0; + matrix[5] = 2 * h; + matrix[9] = 0; + matrix[13] = -y; + matrix[2] = 0; + matrix[6] = 0; + matrix[10] = -1 * p; + matrix[14] = -z; + matrix[3] = 0; + matrix[7] = 0; + matrix[11] = 0; + matrix[15] = 1; + return matrix; } toArray() { - const e = []; - return et.toArray(this, e), e; - } - static toArray(e, t) { - return pe(t) - ? ((t[0] = e[0]), - (t[1] = e[1]), - (t[2] = e[2]), - (t[3] = e[3]), - (t[4] = e[4]), - (t[5] = e[5]), - (t[6] = e[6]), - (t[7] = e[7]), - (t[8] = e[8]), - (t[9] = e[9]), - (t[10] = e[10]), - (t[11] = e[11]), - (t[12] = e[12]), - (t[13] = e[13]), - (t[14] = e[14]), - (t[15] = e[15]), - t) - : [e[0], e[1], e[2], e[3], e[4], e[5], e[6], e[7], e[8], e[9], e[10], e[11], e[12], e[13], e[14], e[15]]; - } - static getElementIndex(e, t) { - return 4 * e + t; - } - static getColumn(e, t, i) { - const r = 4 * t, - n = e[r], - s = e[r + 1], - a = e[r + 2], - o = e[r + 3]; - return (i.x = n), (i.y = s), (i.z = a), (i.w = o), i; - } - static setColumn(e, t, i, r) { - const n = 4 * t; - return ((r = et.clone(e, r))[n] = i.x), (r[n + 1] = i.y), (r[n + 2] = i.z), (r[n + 3] = i.w), r; - } - static getRow(e, t, i) { - const r = e[t], - n = e[t + 4], - s = e[t + 8], - a = e[t + 12]; - return (i.x = r), (i.y = n), (i.z = s), (i.w = a), i; - } - static setRow(e, t, i, r) { - return ((r = et.clone(e, r))[t] = i.x), (r[t + 4] = i.y), (r[t + 8] = i.z), (r[t + 12] = i.w), r; - } - static setTranslation(e, t, i) { - return ( - (i[0] = e[0]), - (i[1] = e[1]), - (i[2] = e[2]), - (i[3] = e[3]), - (i[4] = e[4]), - (i[5] = e[5]), - (i[6] = e[6]), - (i[7] = e[7]), - (i[8] = e[8]), - (i[9] = e[9]), - (i[10] = e[10]), - (i[11] = e[11]), - (i[12] = t.x), - (i[13] = t.y), - (i[14] = t.z), - (i[15] = e[15]), - i - ); - } - static setScale(e, t, i) { - const r = et.getScale(e, it), - n = t.x / r.x, - s = t.y / r.y, - a = t.z / r.z; - return ( - (i[0] = e[0] * n), - (i[1] = e[1] * n), - (i[2] = e[2] * n), - (i[3] = e[3]), - (i[4] = e[4] * s), - (i[5] = e[5] * s), - (i[6] = e[6] * s), - (i[7] = e[7]), - (i[8] = e[8] * a), - (i[9] = e[9] * a), - (i[10] = e[10] * a), - (i[11] = e[11]), - (i[12] = e[12]), - (i[13] = e[13]), - (i[14] = e[14]), - (i[15] = e[15]), - i - ); - } - static getScale(e, t) { - return ( - (t.x = Ue.magnitude(Ue.fromElements(e[0], e[1], e[2], rt))), - (t.y = Ue.magnitude(Ue.fromElements(e[4], e[5], e[6], rt))), - (t.z = Ue.magnitude(Ue.fromElements(e[8], e[9], e[10], rt))), - t - ); - } - static getMaximumScale(e) { - return et.getScale(e, nt), Ue.maximumComponent(nt); - } - static setRotation(e, t, i) { - const r = et.getScale(e, st); - return ( - (i[0] = t[0] * r.x), - (i[1] = t[1] * r.x), - (i[2] = t[2] * r.x), - (i[3] = e[3]), - (i[4] = t[3] * r.y), - (i[5] = t[4] * r.y), - (i[6] = t[5] * r.y), - (i[7] = e[7]), - (i[8] = t[6] * r.z), - (i[9] = t[7] * r.z), - (i[10] = t[8] * r.z), - (i[11] = e[11]), - (i[12] = e[12]), - (i[13] = e[13]), - (i[14] = e[14]), - (i[15] = e[15]), - i - ); - } - static getRotation(e, t) { - const i = et.getScale(e, at), - r = 1 / i.x, - n = 1 / i.y, - s = 1 / i.z, - a = e[0] * r, - o = e[1] * n, - c = e[2] * s, - l = e[4] * r, - h = e[5] * n, - u = e[6] * s, - f = e[8] * r, - d = e[9] * n, - m = e[10] * s, - p = a + h + m; - let g = 0; - return ( - p > 0 - ? ((g = 2 * Math.sqrt(p + 1)), - (t.w = 0.25 * g), - (t.x = (u - d) / g), - (t.y = (f - c) / g), - (t.z = (o - l) / g)) - : a > h && a > m - ? ((g = 2 * Math.sqrt(1 + a - h - m)), - (t.w = (u - d) / g), - (t.x = 0.25 * g), - (t.y = (o + l) / g), - (t.z = (f + c) / g)) - : h > m - ? ((g = 2 * Math.sqrt(1 + h - a - m)), - (t.w = (f - c) / g), - (t.x = (o + l) / g), - (t.y = 0.25 * g), - (t.z = (u + d) / g)) - : ((g = 2 * Math.sqrt(1 + m - a - h)), - (t.w = (o - l) / g), - (t.x = (f + c) / g), - (t.y = (u + d) / g), - (t.z = 0.25 * g)), - t - ); - } - static multiply(e, t, i) { - const r = e[0], - n = e[1], - s = e[2], - a = e[3], - o = e[4], - c = e[5], - l = e[6], - h = e[7], - u = e[8], - f = e[9], - d = e[10], - m = e[11], - p = e[12], - g = e[13], - x = e[14], - v = e[15], - y = t[0], - S = t[1], - b = t[2], - w = t[3], - T = t[4], - E = t[5], - M = t[6], - U = t[7], - _ = t[8], - L = t[9], - C = t[10], - R = t[11], - A = t[12], - D = t[13], - z = t[14], - I = t[15], - P = r * y + o * S + u * b + p * w, - N = n * y + c * S + f * b + g * w, - B = s * y + l * S + d * b + x * w, - O = a * y + h * S + m * b + v * w, - V = r * T + o * E + u * M + p * U, - F = n * T + c * E + f * M + g * U, - $ = s * T + l * E + d * M + x * U, - G = a * T + h * E + m * M + v * U, - k = r * _ + o * L + u * C + p * R, - q = n * _ + c * L + f * C + g * R, - j = s * _ + l * L + d * C + x * R, - H = a * _ + h * L + m * C + v * R, - X = r * A + o * D + u * z + p * I, - Y = n * A + c * D + f * z + g * I, - W = s * A + l * D + d * z + x * I, - Z = a * A + h * D + m * z + v * I; - return ( - (i[0] = P), - (i[1] = N), - (i[2] = B), - (i[3] = O), - (i[4] = V), - (i[5] = F), - (i[6] = $), - (i[7] = G), - (i[8] = k), - (i[9] = q), - (i[10] = j), - (i[11] = H), - (i[12] = X), - (i[13] = Y), - (i[14] = W), - (i[15] = Z), - i - ); - } - static add(e, t, i) { - return ( - (i[0] = e[0] + t[0]), - (i[1] = e[1] + t[1]), - (i[2] = e[2] + t[2]), - (i[3] = e[3] + t[3]), - (i[4] = e[4] + t[4]), - (i[5] = e[5] + t[5]), - (i[6] = e[6] + t[6]), - (i[7] = e[7] + t[7]), - (i[8] = e[8] + t[8]), - (i[9] = e[9] + t[9]), - (i[10] = e[10] + t[10]), - (i[11] = e[11] + t[11]), - (i[12] = e[12] + t[12]), - (i[13] = e[13] + t[13]), - (i[14] = e[14] + t[14]), - (i[15] = e[15] + t[15]), - i - ); - } - static subtract(e, t, i) { - return ( - (i[0] = e[0] - t[0]), - (i[1] = e[1] - t[1]), - (i[2] = e[2] - t[2]), - (i[3] = e[3] - t[3]), - (i[4] = e[4] - t[4]), - (i[5] = e[5] - t[5]), - (i[6] = e[6] - t[6]), - (i[7] = e[7] - t[7]), - (i[8] = e[8] - t[8]), - (i[9] = e[9] - t[9]), - (i[10] = e[10] - t[10]), - (i[11] = e[11] - t[11]), - (i[12] = e[12] - t[12]), - (i[13] = e[13] - t[13]), - (i[14] = e[14] - t[14]), - (i[15] = e[15] - t[15]), - i - ); - } - static multiplyTransformation(e, t, i) { - const r = e[0], - n = e[1], - s = e[2], - a = e[4], - o = e[5], - c = e[6], - l = e[8], - h = e[9], - u = e[10], - f = e[12], - d = e[13], - m = e[14], - p = t[0], - g = t[1], - x = t[2], - v = t[4], - y = t[5], - S = t[6], - b = t[8], - w = t[9], - T = t[10], - E = t[12], - M = t[13], - U = t[14], - _ = r * p + a * g + l * x, - L = n * p + o * g + h * x, - C = s * p + c * g + u * x, - R = r * v + a * y + l * S, - A = n * v + o * y + h * S, - D = s * v + c * y + u * S, - z = r * b + a * w + l * T, - I = n * b + o * w + h * T, - P = s * b + c * w + u * T, - N = r * E + a * M + l * U + f, - B = n * E + o * M + h * U + d, - O = s * E + c * M + u * U + m; - return ( - (i[0] = _), - (i[1] = L), - (i[2] = C), - (i[3] = 0), - (i[4] = R), - (i[5] = A), - (i[6] = D), - (i[7] = 0), - (i[8] = z), - (i[9] = I), - (i[10] = P), - (i[11] = 0), - (i[12] = N), - (i[13] = B), - (i[14] = O), - (i[15] = 1), - i - ); - } - static multiplyByMatrix3(e, t, i) { - const r = e[0], - n = e[1], - s = e[2], - a = e[4], - o = e[5], - c = e[6], - l = e[8], - h = e[9], - u = e[10], - f = t[0], - d = t[1], - m = t[2], - p = t[3], - g = t[4], - x = t[5], - v = t[6], - y = t[7], - S = t[8], - b = r * f + a * d + l * m, - w = n * f + o * d + h * m, - T = s * f + c * d + u * m, - E = r * p + a * g + l * x, - M = n * p + o * g + h * x, - U = s * p + c * g + u * x, - _ = r * v + a * y + l * S, - L = n * v + o * y + h * S, - C = s * v + c * y + u * S; - return ( - (i[0] = b), - (i[1] = w), - (i[2] = T), - (i[3] = 0), - (i[4] = E), - (i[5] = M), - (i[6] = U), - (i[7] = 0), - (i[8] = _), - (i[9] = L), - (i[10] = C), - (i[11] = 0), - (i[12] = e[12]), - (i[13] = e[13]), - (i[14] = e[14]), - (i[15] = e[15]), - i - ); - } - static multiplyByTranslation(e, t, i) { - const r = t.x, - n = t.y, - s = t.z, - a = r * e[0] + n * e[4] + s * e[8] + e[12], - o = r * e[1] + n * e[5] + s * e[9] + e[13], - c = r * e[2] + n * e[6] + s * e[10] + e[14]; - return ( - (i[0] = e[0]), - (i[1] = e[1]), - (i[2] = e[2]), - (i[3] = e[3]), - (i[4] = e[4]), - (i[5] = e[5]), - (i[6] = e[6]), - (i[7] = e[7]), - (i[8] = e[8]), - (i[9] = e[9]), - (i[10] = e[10]), - (i[11] = e[11]), - (i[12] = a), - (i[13] = o), - (i[14] = c), - (i[15] = e[15]), - i - ); - } - static multiplyByScale(e, t, i) { - const r = t.x, - n = t.y, - s = t.z; - return 1 === r && 1 === n && 1 === s - ? et.clone(e, i) - : ((i[0] = r * e[0]), - (i[1] = r * e[1]), - (i[2] = r * e[2]), - (i[3] = e[3]), - (i[4] = n * e[4]), - (i[5] = n * e[5]), - (i[6] = n * e[6]), - (i[7] = e[7]), - (i[8] = s * e[8]), - (i[9] = s * e[9]), - (i[10] = s * e[10]), - (i[11] = e[11]), - (i[12] = e[12]), - (i[13] = e[13]), - (i[14] = e[14]), - (i[15] = e[15]), - i); - } - static multiplyByUniformScale(e, t, i) { - return ( - (i[0] = e[0] * t), - (i[1] = e[1] * t), - (i[2] = e[2] * t), - (i[3] = e[3]), - (i[4] = e[4] * t), - (i[5] = e[5] * t), - (i[6] = e[6] * t), - (i[7] = e[7]), - (i[8] = e[8] * t), - (i[9] = e[9] * t), - (i[10] = e[10] * t), - (i[11] = e[11]), - (i[12] = e[12]), - (i[13] = e[13]), - (i[14] = e[14]), - (i[15] = e[15]), - i - ); - } - static multiplyByVector(e, t, i) { - const r = t.x, - n = t.y, - s = t.z, - a = t.w, - o = e[0] * r + e[4] * n + e[8] * s + e[12] * a, - c = e[1] * r + e[5] * n + e[9] * s + e[13] * a, - l = e[2] * r + e[6] * n + e[10] * s + e[14] * a, - h = e[3] * r + e[7] * n + e[11] * s + e[15] * a; - return (i.x = o), (i.y = c), (i.z = l), (i.w = h), i; - } - static multiplyByPointAsVector(e, t, i) { - const r = t.x, - n = t.y, - s = t.z, - a = e[0] * r + e[4] * n + e[8] * s, - o = e[1] * r + e[5] * n + e[9] * s, - c = e[2] * r + e[6] * n + e[10] * s; - return (i.x = a), (i.y = o), (i.z = c), i; - } - static multiplyByPoint(e, t, i) { - const r = t.x, - n = t.y, - s = t.z, - a = e[0] * r + e[4] * n + e[8] * s + e[12], - o = e[1] * r + e[5] * n + e[9] * s + e[13], - c = e[2] * r + e[6] * n + e[10] * s + e[14]; - return (i.x = a), (i.y = o), (i.z = c), i; - } - static multiplyByScalar(e, t, i) { - return ( - (i[0] = e[0] * t), - (i[1] = e[1] * t), - (i[2] = e[2] * t), - (i[3] = e[3] * t), - (i[4] = e[4] * t), - (i[5] = e[5] * t), - (i[6] = e[6] * t), - (i[7] = e[7] * t), - (i[8] = e[8] * t), - (i[9] = e[9] * t), - (i[10] = e[10] * t), - (i[11] = e[11] * t), - (i[12] = e[12] * t), - (i[13] = e[13] * t), - (i[14] = e[14] * t), - (i[15] = e[15] * t), - i - ); - } - static negate(e, t) { - return ( - (t[0] = -e[0]), - (t[1] = -e[1]), - (t[2] = -e[2]), - (t[3] = -e[3]), - (t[4] = -e[4]), - (t[5] = -e[5]), - (t[6] = -e[6]), - (t[7] = -e[7]), - (t[8] = -e[8]), - (t[9] = -e[9]), - (t[10] = -e[10]), - (t[11] = -e[11]), - (t[12] = -e[12]), - (t[13] = -e[13]), - (t[14] = -e[14]), - (t[15] = -e[15]), - t - ); - } - static transpose(e, t) { - const i = e[1], - r = e[2], - n = e[3], - s = e[6], - a = e[7], - o = e[11]; - return ( - (t[0] = e[0]), - (t[1] = e[4]), - (t[2] = e[8]), - (t[3] = e[12]), - (t[4] = i), - (t[5] = e[5]), - (t[6] = e[9]), - (t[7] = e[13]), - (t[8] = r), - (t[9] = s), - (t[10] = e[10]), - (t[11] = e[14]), - (t[12] = n), - (t[13] = a), - (t[14] = o), - (t[15] = e[15]), - t - ); - } - static abs(e, t) { - return ( - (t[0] = Math.abs(e[0])), - (t[1] = Math.abs(e[1])), - (t[2] = Math.abs(e[2])), - (t[3] = Math.abs(e[3])), - (t[4] = Math.abs(e[4])), - (t[5] = Math.abs(e[5])), - (t[6] = Math.abs(e[6])), - (t[7] = Math.abs(e[7])), - (t[8] = Math.abs(e[8])), - (t[9] = Math.abs(e[9])), - (t[10] = Math.abs(e[10])), - (t[11] = Math.abs(e[11])), - (t[12] = Math.abs(e[12])), - (t[13] = Math.abs(e[13])), - (t[14] = Math.abs(e[14])), - (t[15] = Math.abs(e[15])), - t - ); - } - static equals(e, t) { - return ( - e === t || - (pe(e) && - pe(t) && - e[12] === t[12] && - e[13] === t[13] && - e[14] === t[14] && - e[0] === t[0] && - e[1] === t[1] && - e[2] === t[2] && - e[4] === t[4] && - e[5] === t[5] && - e[6] === t[6] && - e[8] === t[8] && - e[9] === t[9] && - e[10] === t[10] && - e[3] === t[3] && - e[7] === t[7] && - e[11] === t[11] && - e[15] === t[15]) - ); - } - static equalsEpsilon(e, t, i) { + const result = []; + Matrix4.toArray(this, result); + return result; + } + /** + * Computes an Array from the provided Matrix4 instance. + * The array will be in column-major order. + * @example + * //create an array from an instance of Matrix4 + * // m = [10.0, 14.0, 18.0, 22.0] + * // [11.0, 15.0, 19.0, 23.0] + * // [12.0, 16.0, 20.0, 24.0] + * // [13.0, 17.0, 21.0, 25.0] + * const a = Matrix4.toArray(m); + * + * // m remains the same + * //creates a = [10.0, 11.0, 12.0, 13.0, 14.0, 15.0, 16.0, 17.0, 18.0, 19.0, 20.0, 21.0, 22.0, 23.0, 24.0, 25.0] + */ + static toArray(matrix, result) { + if (!defined(result)) { + return [ + matrix[0], + matrix[1], + matrix[2], + matrix[3], + matrix[4], + matrix[5], + matrix[6], + matrix[7], + matrix[8], + matrix[9], + matrix[10], + matrix[11], + matrix[12], + matrix[13], + matrix[14], + matrix[15] + ]; + } + result[0] = matrix[0]; + result[1] = matrix[1]; + result[2] = matrix[2]; + result[3] = matrix[3]; + result[4] = matrix[4]; + result[5] = matrix[5]; + result[6] = matrix[6]; + result[7] = matrix[7]; + result[8] = matrix[8]; + result[9] = matrix[9]; + result[10] = matrix[10]; + result[11] = matrix[11]; + result[12] = matrix[12]; + result[13] = matrix[13]; + result[14] = matrix[14]; + result[15] = matrix[15]; + return result; + } + static getElementIndex(column, row) { + return column * 4 + row; + } + static getColumn(matrix, index, result) { + const startIndex = index * 4; + const x = matrix[startIndex]; + const y = matrix[startIndex + 1]; + const z = matrix[startIndex + 2]; + const w = matrix[startIndex + 3]; + result.x = x; + result.y = y; + result.z = z; + result.w = w; + return result; + } + static setColumn(matrix, index, cartesian, result) { + result = Matrix4.clone(matrix, result); + const startIndex = index * 4; + result[startIndex] = cartesian.x; + result[startIndex + 1] = cartesian.y; + result[startIndex + 2] = cartesian.z; + result[startIndex + 3] = cartesian.w; + return result; + } + static getRow(matrix, index, result) { + const x = matrix[index]; + const y = matrix[index + 4]; + const z = matrix[index + 8]; + const w = matrix[index + 12]; + result.x = x; + result.y = y; + result.z = z; + result.w = w; + return result; + } + static setRow(matrix, index, cartesian, result) { + result = Matrix4.clone(matrix, result); + result[index] = cartesian.x; + result[index + 4] = cartesian.y; + result[index + 8] = cartesian.z; + result[index + 12] = cartesian.w; + return result; + } + static setTranslation(matrix, translation, result) { + result[0] = matrix[0]; + result[1] = matrix[1]; + result[2] = matrix[2]; + result[3] = matrix[3]; + result[4] = matrix[4]; + result[5] = matrix[5]; + result[6] = matrix[6]; + result[7] = matrix[7]; + result[8] = matrix[8]; + result[9] = matrix[9]; + result[10] = matrix[10]; + result[11] = matrix[11]; + result[12] = translation.x; + result[13] = translation.y; + result[14] = translation.z; + result[15] = matrix[15]; + return result; + } + static setScale(matrix, scale, result) { + const existingScale = Matrix4.getScale(matrix, scaleScratch1$1); + const scaleRatioX = scale.x / existingScale.x; + const scaleRatioY = scale.y / existingScale.y; + const scaleRatioZ = scale.z / existingScale.z; + result[0] = matrix[0] * scaleRatioX; + result[1] = matrix[1] * scaleRatioX; + result[2] = matrix[2] * scaleRatioX; + result[3] = matrix[3]; + result[4] = matrix[4] * scaleRatioY; + result[5] = matrix[5] * scaleRatioY; + result[6] = matrix[6] * scaleRatioY; + result[7] = matrix[7]; + result[8] = matrix[8] * scaleRatioZ; + result[9] = matrix[9] * scaleRatioZ; + result[10] = matrix[10] * scaleRatioZ; + result[11] = matrix[11]; + result[12] = matrix[12]; + result[13] = matrix[13]; + result[14] = matrix[14]; + result[15] = matrix[15]; + return result; + } + static getScale(matrix, result) { + result.x = Vector3.magnitude(Vector3.fromElements(matrix[0], matrix[1], matrix[2], scratchColumn$1)); + result.y = Vector3.magnitude(Vector3.fromElements(matrix[4], matrix[5], matrix[6], scratchColumn$1)); + result.z = Vector3.magnitude(Vector3.fromElements(matrix[8], matrix[9], matrix[10], scratchColumn$1)); + return result; + } + static getMaximumScale(matrix) { + Matrix4.getScale(matrix, scaleScratch3$1); + return Vector3.maximumComponent(scaleScratch3$1); + } + static setRotation(matrix, rotation, result) { + const scale = Matrix4.getScale(matrix, scaleScratch4$1); + result[0] = rotation[0] * scale.x; + result[1] = rotation[1] * scale.x; + result[2] = rotation[2] * scale.x; + result[3] = matrix[3]; + result[4] = rotation[3] * scale.y; + result[5] = rotation[4] * scale.y; + result[6] = rotation[5] * scale.y; + result[7] = matrix[7]; + result[8] = rotation[6] * scale.z; + result[9] = rotation[7] * scale.z; + result[10] = rotation[8] * scale.z; + result[11] = matrix[11]; + result[12] = matrix[12]; + result[13] = matrix[13]; + result[14] = matrix[14]; + result[15] = matrix[15]; + return result; + } + static getRotation(matrix, result) { + const scale = Matrix4.getScale(matrix, scaleScratch5$1); + const is1 = 1 / scale.x; + const is2 = 1 / scale.y; + const is3 = 1 / scale.z; + const sm11 = matrix[0] * is1; + const sm12 = matrix[1] * is2; + const sm13 = matrix[2] * is3; + const sm21 = matrix[4] * is1; + const sm22 = matrix[5] * is2; + const sm23 = matrix[6] * is3; + const sm31 = matrix[8] * is1; + const sm32 = matrix[9] * is2; + const sm33 = matrix[10] * is3; + const trace = sm11 + sm22 + sm33; + let S = 0; + if (trace > 0) { + S = Math.sqrt(trace + 1.0) * 2; + result.w = 0.25 * S; + result.x = (sm23 - sm32) / S; + result.y = (sm31 - sm13) / S; + result.z = (sm12 - sm21) / S; + } else if (sm11 > sm22 && sm11 > sm33) { + S = Math.sqrt(1.0 + sm11 - sm22 - sm33) * 2; + result.w = (sm23 - sm32) / S; + result.x = 0.25 * S; + result.y = (sm12 + sm21) / S; + result.z = (sm31 + sm13) / S; + } else if (sm22 > sm33) { + S = Math.sqrt(1.0 + sm22 - sm11 - sm33) * 2; + result.w = (sm31 - sm13) / S; + result.x = (sm12 + sm21) / S; + result.y = 0.25 * S; + result.z = (sm23 + sm32) / S; + } else { + S = Math.sqrt(1.0 + sm33 - sm11 - sm22) * 2; + result.w = (sm12 - sm21) / S; + result.x = (sm31 + sm13) / S; + result.y = (sm23 + sm32) / S; + result.z = 0.25 * S; + } + return result; + } + static multiply(left, right, result) { + const left0 = left[0]; + const left1 = left[1]; + const left2 = left[2]; + const left3 = left[3]; + const left4 = left[4]; + const left5 = left[5]; + const left6 = left[6]; + const left7 = left[7]; + const left8 = left[8]; + const left9 = left[9]; + const left10 = left[10]; + const left11 = left[11]; + const left12 = left[12]; + const left13 = left[13]; + const left14 = left[14]; + const left15 = left[15]; + const right0 = right[0]; + const right1 = right[1]; + const right2 = right[2]; + const right3 = right[3]; + const right4 = right[4]; + const right5 = right[5]; + const right6 = right[6]; + const right7 = right[7]; + const right8 = right[8]; + const right9 = right[9]; + const right10 = right[10]; + const right11 = right[11]; + const right12 = right[12]; + const right13 = right[13]; + const right14 = right[14]; + const right15 = right[15]; + const column0Row0 = left0 * right0 + left4 * right1 + left8 * right2 + left12 * right3; + const column0Row1 = left1 * right0 + left5 * right1 + left9 * right2 + left13 * right3; + const column0Row2 = left2 * right0 + left6 * right1 + left10 * right2 + left14 * right3; + const column0Row3 = left3 * right0 + left7 * right1 + left11 * right2 + left15 * right3; + const column1Row0 = left0 * right4 + left4 * right5 + left8 * right6 + left12 * right7; + const column1Row1 = left1 * right4 + left5 * right5 + left9 * right6 + left13 * right7; + const column1Row2 = left2 * right4 + left6 * right5 + left10 * right6 + left14 * right7; + const column1Row3 = left3 * right4 + left7 * right5 + left11 * right6 + left15 * right7; + const column2Row0 = left0 * right8 + left4 * right9 + left8 * right10 + left12 * right11; + const column2Row1 = left1 * right8 + left5 * right9 + left9 * right10 + left13 * right11; + const column2Row2 = left2 * right8 + left6 * right9 + left10 * right10 + left14 * right11; + const column2Row3 = left3 * right8 + left7 * right9 + left11 * right10 + left15 * right11; + const column3Row0 = left0 * right12 + left4 * right13 + left8 * right14 + left12 * right15; + const column3Row1 = left1 * right12 + left5 * right13 + left9 * right14 + left13 * right15; + const column3Row2 = left2 * right12 + left6 * right13 + left10 * right14 + left14 * right15; + const column3Row3 = left3 * right12 + left7 * right13 + left11 * right14 + left15 * right15; + result[0] = column0Row0; + result[1] = column0Row1; + result[2] = column0Row2; + result[3] = column0Row3; + result[4] = column1Row0; + result[5] = column1Row1; + result[6] = column1Row2; + result[7] = column1Row3; + result[8] = column2Row0; + result[9] = column2Row1; + result[10] = column2Row2; + result[11] = column2Row3; + result[12] = column3Row0; + result[13] = column3Row1; + result[14] = column3Row2; + result[15] = column3Row3; + return result; + } + static add(left, right, result) { + result[0] = left[0] + right[0]; + result[1] = left[1] + right[1]; + result[2] = left[2] + right[2]; + result[3] = left[3] + right[3]; + result[4] = left[4] + right[4]; + result[5] = left[5] + right[5]; + result[6] = left[6] + right[6]; + result[7] = left[7] + right[7]; + result[8] = left[8] + right[8]; + result[9] = left[9] + right[9]; + result[10] = left[10] + right[10]; + result[11] = left[11] + right[11]; + result[12] = left[12] + right[12]; + result[13] = left[13] + right[13]; + result[14] = left[14] + right[14]; + result[15] = left[15] + right[15]; + return result; + } + static subtract(left, right, result) { + result[0] = left[0] - right[0]; + result[1] = left[1] - right[1]; + result[2] = left[2] - right[2]; + result[3] = left[3] - right[3]; + result[4] = left[4] - right[4]; + result[5] = left[5] - right[5]; + result[6] = left[6] - right[6]; + result[7] = left[7] - right[7]; + result[8] = left[8] - right[8]; + result[9] = left[9] - right[9]; + result[10] = left[10] - right[10]; + result[11] = left[11] - right[11]; + result[12] = left[12] - right[12]; + result[13] = left[13] - right[13]; + result[14] = left[14] - right[14]; + result[15] = left[15] - right[15]; + return result; + } + static multiplyTransformation(left, right, result) { + const left0 = left[0]; + const left1 = left[1]; + const left2 = left[2]; + const left4 = left[4]; + const left5 = left[5]; + const left6 = left[6]; + const left8 = left[8]; + const left9 = left[9]; + const left10 = left[10]; + const left12 = left[12]; + const left13 = left[13]; + const left14 = left[14]; + const right0 = right[0]; + const right1 = right[1]; + const right2 = right[2]; + const right4 = right[4]; + const right5 = right[5]; + const right6 = right[6]; + const right8 = right[8]; + const right9 = right[9]; + const right10 = right[10]; + const right12 = right[12]; + const right13 = right[13]; + const right14 = right[14]; + const column0Row0 = left0 * right0 + left4 * right1 + left8 * right2; + const column0Row1 = left1 * right0 + left5 * right1 + left9 * right2; + const column0Row2 = left2 * right0 + left6 * right1 + left10 * right2; + const column1Row0 = left0 * right4 + left4 * right5 + left8 * right6; + const column1Row1 = left1 * right4 + left5 * right5 + left9 * right6; + const column1Row2 = left2 * right4 + left6 * right5 + left10 * right6; + const column2Row0 = left0 * right8 + left4 * right9 + left8 * right10; + const column2Row1 = left1 * right8 + left5 * right9 + left9 * right10; + const column2Row2 = left2 * right8 + left6 * right9 + left10 * right10; + const column3Row0 = left0 * right12 + left4 * right13 + left8 * right14 + left12; + const column3Row1 = left1 * right12 + left5 * right13 + left9 * right14 + left13; + const column3Row2 = left2 * right12 + left6 * right13 + left10 * right14 + left14; + result[0] = column0Row0; + result[1] = column0Row1; + result[2] = column0Row2; + result[3] = 0.0; + result[4] = column1Row0; + result[5] = column1Row1; + result[6] = column1Row2; + result[7] = 0.0; + result[8] = column2Row0; + result[9] = column2Row1; + result[10] = column2Row2; + result[11] = 0.0; + result[12] = column3Row0; + result[13] = column3Row1; + result[14] = column3Row2; + result[15] = 1.0; + return result; + } + static multiplyByMatrix3(matrix, rotation, result) { + const left0 = matrix[0]; + const left1 = matrix[1]; + const left2 = matrix[2]; + const left4 = matrix[4]; + const left5 = matrix[5]; + const left6 = matrix[6]; + const left8 = matrix[8]; + const left9 = matrix[9]; + const left10 = matrix[10]; + const right0 = rotation[0]; + const right1 = rotation[1]; + const right2 = rotation[2]; + const right4 = rotation[3]; + const right5 = rotation[4]; + const right6 = rotation[5]; + const right8 = rotation[6]; + const right9 = rotation[7]; + const right10 = rotation[8]; + const column0Row0 = left0 * right0 + left4 * right1 + left8 * right2; + const column0Row1 = left1 * right0 + left5 * right1 + left9 * right2; + const column0Row2 = left2 * right0 + left6 * right1 + left10 * right2; + const column1Row0 = left0 * right4 + left4 * right5 + left8 * right6; + const column1Row1 = left1 * right4 + left5 * right5 + left9 * right6; + const column1Row2 = left2 * right4 + left6 * right5 + left10 * right6; + const column2Row0 = left0 * right8 + left4 * right9 + left8 * right10; + const column2Row1 = left1 * right8 + left5 * right9 + left9 * right10; + const column2Row2 = left2 * right8 + left6 * right9 + left10 * right10; + result[0] = column0Row0; + result[1] = column0Row1; + result[2] = column0Row2; + result[3] = 0.0; + result[4] = column1Row0; + result[5] = column1Row1; + result[6] = column1Row2; + result[7] = 0.0; + result[8] = column2Row0; + result[9] = column2Row1; + result[10] = column2Row2; + result[11] = 0.0; + result[12] = matrix[12]; + result[13] = matrix[13]; + result[14] = matrix[14]; + result[15] = matrix[15]; + return result; + } + static multiplyByTranslation(matrix, translation, result) { + const x = translation.x; + const y = translation.y; + const z = translation.z; + const tx = x * matrix[0] + y * matrix[4] + z * matrix[8] + matrix[12]; + const ty = x * matrix[1] + y * matrix[5] + z * matrix[9] + matrix[13]; + const tz = x * matrix[2] + y * matrix[6] + z * matrix[10] + matrix[14]; + result[0] = matrix[0]; + result[1] = matrix[1]; + result[2] = matrix[2]; + result[3] = matrix[3]; + result[4] = matrix[4]; + result[5] = matrix[5]; + result[6] = matrix[6]; + result[7] = matrix[7]; + result[8] = matrix[8]; + result[9] = matrix[9]; + result[10] = matrix[10]; + result[11] = matrix[11]; + result[12] = tx; + result[13] = ty; + result[14] = tz; + result[15] = matrix[15]; + return result; + } + static multiplyByScale(matrix, scale, result) { + const scaleX = scale.x; + const scaleY = scale.y; + const scaleZ = scale.z; + // Faster than Vector3.equals + if (scaleX === 1.0 && scaleY === 1.0 && scaleZ === 1.0) { + return Matrix4.clone(matrix, result); + } + result[0] = scaleX * matrix[0]; + result[1] = scaleX * matrix[1]; + result[2] = scaleX * matrix[2]; + result[3] = matrix[3]; + result[4] = scaleY * matrix[4]; + result[5] = scaleY * matrix[5]; + result[6] = scaleY * matrix[6]; + result[7] = matrix[7]; + result[8] = scaleZ * matrix[8]; + result[9] = scaleZ * matrix[9]; + result[10] = scaleZ * matrix[10]; + result[11] = matrix[11]; + result[12] = matrix[12]; + result[13] = matrix[13]; + result[14] = matrix[14]; + result[15] = matrix[15]; + return result; + } + static multiplyByUniformScale(matrix, scale, result) { + result[0] = matrix[0] * scale; + result[1] = matrix[1] * scale; + result[2] = matrix[2] * scale; + result[3] = matrix[3]; + result[4] = matrix[4] * scale; + result[5] = matrix[5] * scale; + result[6] = matrix[6] * scale; + result[7] = matrix[7]; + result[8] = matrix[8] * scale; + result[9] = matrix[9] * scale; + result[10] = matrix[10] * scale; + result[11] = matrix[11]; + result[12] = matrix[12]; + result[13] = matrix[13]; + result[14] = matrix[14]; + result[15] = matrix[15]; + return result; + } + static multiplyByVector(matrix, cartesian, result) { + const vX = cartesian.x; + const vY = cartesian.y; + const vZ = cartesian.z; + const vW = cartesian.w; + const x = matrix[0] * vX + matrix[4] * vY + matrix[8] * vZ + matrix[12] * vW; + const y = matrix[1] * vX + matrix[5] * vY + matrix[9] * vZ + matrix[13] * vW; + const z = matrix[2] * vX + matrix[6] * vY + matrix[10] * vZ + matrix[14] * vW; + const w = matrix[3] * vX + matrix[7] * vY + matrix[11] * vZ + matrix[15] * vW; + result.x = x; + result.y = y; + result.z = z; + result.w = w; + return result; + } + static multiplyByPointAsVector(matrix, cartesian, result) { + const vX = cartesian.x; + const vY = cartesian.y; + const vZ = cartesian.z; + const x = matrix[0] * vX + matrix[4] * vY + matrix[8] * vZ; + const y = matrix[1] * vX + matrix[5] * vY + matrix[9] * vZ; + const z = matrix[2] * vX + matrix[6] * vY + matrix[10] * vZ; + result.x = x; + result.y = y; + result.z = z; + return result; + } + static multiplyByPoint(matrix, cartesian, result) { + const vX = cartesian.x; + const vY = cartesian.y; + const vZ = cartesian.z; + const x = matrix[0] * vX + matrix[4] * vY + matrix[8] * vZ + matrix[12]; + const y = matrix[1] * vX + matrix[5] * vY + matrix[9] * vZ + matrix[13]; + const z = matrix[2] * vX + matrix[6] * vY + matrix[10] * vZ + matrix[14]; + result.x = x; + result.y = y; + result.z = z; + return result; + } + static multiplyByScalar(matrix, scalar, result) { + result[0] = matrix[0] * scalar; + result[1] = matrix[1] * scalar; + result[2] = matrix[2] * scalar; + result[3] = matrix[3] * scalar; + result[4] = matrix[4] * scalar; + result[5] = matrix[5] * scalar; + result[6] = matrix[6] * scalar; + result[7] = matrix[7] * scalar; + result[8] = matrix[8] * scalar; + result[9] = matrix[9] * scalar; + result[10] = matrix[10] * scalar; + result[11] = matrix[11] * scalar; + result[12] = matrix[12] * scalar; + result[13] = matrix[13] * scalar; + result[14] = matrix[14] * scalar; + result[15] = matrix[15] * scalar; + return result; + } + static negate(matrix, result) { + result[0] = -matrix[0]; + result[1] = -matrix[1]; + result[2] = -matrix[2]; + result[3] = -matrix[3]; + result[4] = -matrix[4]; + result[5] = -matrix[5]; + result[6] = -matrix[6]; + result[7] = -matrix[7]; + result[8] = -matrix[8]; + result[9] = -matrix[9]; + result[10] = -matrix[10]; + result[11] = -matrix[11]; + result[12] = -matrix[12]; + result[13] = -matrix[13]; + result[14] = -matrix[14]; + result[15] = -matrix[15]; + return result; + } + static transpose(matrix, result) { + const matrix1 = matrix[1]; + const matrix2 = matrix[2]; + const matrix3 = matrix[3]; + const matrix6 = matrix[6]; + const matrix7 = matrix[7]; + const matrix11 = matrix[11]; + result[0] = matrix[0]; + result[1] = matrix[4]; + result[2] = matrix[8]; + result[3] = matrix[12]; + result[4] = matrix1; + result[5] = matrix[5]; + result[6] = matrix[9]; + result[7] = matrix[13]; + result[8] = matrix2; + result[9] = matrix6; + result[10] = matrix[10]; + result[11] = matrix[14]; + result[12] = matrix3; + result[13] = matrix7; + result[14] = matrix11; + result[15] = matrix[15]; + return result; + } + static abs(matrix, result) { + result[0] = Math.abs(matrix[0]); + result[1] = Math.abs(matrix[1]); + result[2] = Math.abs(matrix[2]); + result[3] = Math.abs(matrix[3]); + result[4] = Math.abs(matrix[4]); + result[5] = Math.abs(matrix[5]); + result[6] = Math.abs(matrix[6]); + result[7] = Math.abs(matrix[7]); + result[8] = Math.abs(matrix[8]); + result[9] = Math.abs(matrix[9]); + result[10] = Math.abs(matrix[10]); + result[11] = Math.abs(matrix[11]); + result[12] = Math.abs(matrix[12]); + result[13] = Math.abs(matrix[13]); + result[14] = Math.abs(matrix[14]); + result[15] = Math.abs(matrix[15]); + return result; + } + static equals(left, right) { + // Given that most matrices will be transformation matrices, the elements + // are tested in order such that the test is likely to fail as early + // as possible. I _think_ this is just as friendly to the L1 cache + // as testing in index order. It is certainty faster in practice. return ( - (i = ee(i, 0)), - e === t || - (pe(e) && - pe(t) && - Math.abs(e[0] - t[0]) <= i && - Math.abs(e[1] - t[1]) <= i && - Math.abs(e[2] - t[2]) <= i && - Math.abs(e[3] - t[3]) <= i && - Math.abs(e[4] - t[4]) <= i && - Math.abs(e[5] - t[5]) <= i && - Math.abs(e[6] - t[6]) <= i && - Math.abs(e[7] - t[7]) <= i && - Math.abs(e[8] - t[8]) <= i && - Math.abs(e[9] - t[9]) <= i && - Math.abs(e[10] - t[10]) <= i && - Math.abs(e[11] - t[11]) <= i && - Math.abs(e[12] - t[12]) <= i && - Math.abs(e[13] - t[13]) <= i && - Math.abs(e[14] - t[14]) <= i && - Math.abs(e[15] - t[15]) <= i) + left === right || + (defined(left) && + defined(right) && + // Translation + left[12] === right[12] && + left[13] === right[13] && + left[14] === right[14] && + // Rotation/scale + left[0] === right[0] && + left[1] === right[1] && + left[2] === right[2] && + left[4] === right[4] && + left[5] === right[5] && + left[6] === right[6] && + left[8] === right[8] && + left[9] === right[9] && + left[10] === right[10] && + // Bottom row + left[3] === right[3] && + left[7] === right[7] && + left[11] === right[11] && + left[15] === right[15]) ); } - static getTranslation(e, t) { - return (t.x = e[12]), (t.y = e[13]), (t.z = e[14]), t; - } - static getMatrix3(e, t) { + static equalsEpsilon(left, right, epsilon) { + epsilon = defaultValue(epsilon, 0); return ( - (t[0] = e[0]), - (t[1] = e[1]), - (t[2] = e[2]), - (t[3] = e[4]), - (t[4] = e[5]), - (t[5] = e[6]), - (t[6] = e[8]), - (t[7] = e[9]), - (t[8] = e[10]), - t + left === right || + (defined(left) && + defined(right) && + Math.abs(left[0] - right[0]) <= epsilon && + Math.abs(left[1] - right[1]) <= epsilon && + Math.abs(left[2] - right[2]) <= epsilon && + Math.abs(left[3] - right[3]) <= epsilon && + Math.abs(left[4] - right[4]) <= epsilon && + Math.abs(left[5] - right[5]) <= epsilon && + Math.abs(left[6] - right[6]) <= epsilon && + Math.abs(left[7] - right[7]) <= epsilon && + Math.abs(left[8] - right[8]) <= epsilon && + Math.abs(left[9] - right[9]) <= epsilon && + Math.abs(left[10] - right[10]) <= epsilon && + Math.abs(left[11] - right[11]) <= epsilon && + Math.abs(left[12] - right[12]) <= epsilon && + Math.abs(left[13] - right[13]) <= epsilon && + Math.abs(left[14] - right[14]) <= epsilon && + Math.abs(left[15] - right[15]) <= epsilon) ); } - static inverse(e, t) { - const i = e[0], - r = e[4], - n = e[8], - s = e[12], - a = e[1], - o = e[5], - c = e[9], - l = e[13], - h = e[2], - u = e[6], - f = e[10], - d = e[14], - m = e[3], - p = e[7], - g = e[11], - x = e[15]; - let v = f * x, - y = d * g, - S = u * x, - b = d * p, - w = u * g, - T = f * p, - E = h * x, - M = d * m, - U = h * g, - _ = f * m, - L = h * p, - C = u * m; - const R = v * o + b * c + w * l - (y * o + S * c + T * l), - A = y * a + E * c + _ * l - (v * a + M * c + U * l), - D = S * a + M * o + L * l - (b * a + E * o + C * l), - z = T * a + U * o + C * c - (w * a + _ * o + L * c), - I = y * r + S * n + T * s - (v * r + b * n + w * s), - P = v * i + M * n + U * s - (y * i + E * n + _ * s), - N = b * i + E * r + C * s - (S * i + M * r + L * s), - B = w * i + _ * r + L * n - (T * i + U * r + C * n); - (v = n * l), - (y = s * c), - (S = r * l), - (b = s * o), - (w = r * c), - (T = n * o), - (E = i * l), - (M = s * a), - (U = i * c), - (_ = n * a), - (L = i * o), - (C = r * a); - const O = v * p + b * g + w * x - (y * p + S * g + T * x), - V = y * m + E * g + _ * x - (v * m + M * g + U * x), - F = S * m + M * p + L * x - (b * m + E * p + C * x), - $ = T * m + U * p + C * g - (w * m + _ * p + L * g), - G = S * f + T * d + y * u - (w * d + v * u + b * f), - k = U * d + v * h + M * f - (E * f + _ * d + y * h), - q = E * u + C * d + b * h - (L * d + S * h + M * u), - j = L * f + w * h + _ * u - (U * u + C * f + T * h); - let H = i * R + r * A + n * D + s * z; - if (Math.abs(H) < ve.EPSILON21) { - if (Ge.equalsEpsilon(et.getMatrix3(e, ot), ct, ve.EPSILON7) && We.equals(et.getRow(e, 3, lt), ht)) - return ( - (t[0] = 0), - (t[1] = 0), - (t[2] = 0), - (t[3] = 0), - (t[4] = 0), - (t[5] = 0), - (t[6] = 0), - (t[7] = 0), - (t[8] = 0), - (t[9] = 0), - (t[10] = 0), - (t[11] = 0), - (t[12] = -e[12]), - (t[13] = -e[13]), - (t[14] = -e[14]), - (t[15] = 1), - t - ); + static getTranslation(matrix, result) { + result.x = matrix[12]; + result.y = matrix[13]; + result.z = matrix[14]; + return result; + } + static getMatrix3(matrix, result) { + result[0] = matrix[0]; + result[1] = matrix[1]; + result[2] = matrix[2]; + result[3] = matrix[4]; + result[4] = matrix[5]; + result[5] = matrix[6]; + result[6] = matrix[8]; + result[7] = matrix[9]; + result[8] = matrix[10]; + return result; + } + static inverse(matrix, result) { + // + // Ported from: + // ftp://download.intel.com/design/PentiumIII/sml/24504301.pdf + // + const src0 = matrix[0]; + const src1 = matrix[4]; + const src2 = matrix[8]; + const src3 = matrix[12]; + const src4 = matrix[1]; + const src5 = matrix[5]; + const src6 = matrix[9]; + const src7 = matrix[13]; + const src8 = matrix[2]; + const src9 = matrix[6]; + const src10 = matrix[10]; + const src11 = matrix[14]; + const src12 = matrix[3]; + const src13 = matrix[7]; + const src14 = matrix[11]; + const src15 = matrix[15]; + // calculate pairs for first 8 elements (cofactors) + let tmp0 = src10 * src15; + let tmp1 = src11 * src14; + let tmp2 = src9 * src15; + let tmp3 = src11 * src13; + let tmp4 = src9 * src14; + let tmp5 = src10 * src13; + let tmp6 = src8 * src15; + let tmp7 = src11 * src12; + let tmp8 = src8 * src14; + let tmp9 = src10 * src12; + let tmp10 = src8 * src13; + let tmp11 = src9 * src12; + // calculate first 8 elements (cofactors) + const dst0 = tmp0 * src5 + tmp3 * src6 + tmp4 * src7 - (tmp1 * src5 + tmp2 * src6 + tmp5 * src7); + const dst1 = tmp1 * src4 + tmp6 * src6 + tmp9 * src7 - (tmp0 * src4 + tmp7 * src6 + tmp8 * src7); + const dst2 = tmp2 * src4 + tmp7 * src5 + tmp10 * src7 - (tmp3 * src4 + tmp6 * src5 + tmp11 * src7); + const dst3 = tmp5 * src4 + tmp8 * src5 + tmp11 * src6 - (tmp4 * src4 + tmp9 * src5 + tmp10 * src6); + const dst4 = tmp1 * src1 + tmp2 * src2 + tmp5 * src3 - (tmp0 * src1 + tmp3 * src2 + tmp4 * src3); + const dst5 = tmp0 * src0 + tmp7 * src2 + tmp8 * src3 - (tmp1 * src0 + tmp6 * src2 + tmp9 * src3); + const dst6 = tmp3 * src0 + tmp6 * src1 + tmp11 * src3 - (tmp2 * src0 + tmp7 * src1 + tmp10 * src3); + const dst7 = tmp4 * src0 + tmp9 * src1 + tmp10 * src2 - (tmp5 * src0 + tmp8 * src1 + tmp11 * src2); + // calculate pairs for second 8 elements (cofactors) + tmp0 = src2 * src7; + tmp1 = src3 * src6; + tmp2 = src1 * src7; + tmp3 = src3 * src5; + tmp4 = src1 * src6; + tmp5 = src2 * src5; + tmp6 = src0 * src7; + tmp7 = src3 * src4; + tmp8 = src0 * src6; + tmp9 = src2 * src4; + tmp10 = src0 * src5; + tmp11 = src1 * src4; + // calculate second 8 elements (cofactors) + const dst8 = tmp0 * src13 + tmp3 * src14 + tmp4 * src15 - (tmp1 * src13 + tmp2 * src14 + tmp5 * src15); + const dst9 = tmp1 * src12 + tmp6 * src14 + tmp9 * src15 - (tmp0 * src12 + tmp7 * src14 + tmp8 * src15); + const dst10 = tmp2 * src12 + tmp7 * src13 + tmp10 * src15 - (tmp3 * src12 + tmp6 * src13 + tmp11 * src15); + const dst11 = tmp5 * src12 + tmp8 * src13 + tmp11 * src14 - (tmp4 * src12 + tmp9 * src13 + tmp10 * src14); + const dst12 = tmp2 * src10 + tmp5 * src11 + tmp1 * src9 - (tmp4 * src11 + tmp0 * src9 + tmp3 * src10); + const dst13 = tmp8 * src11 + tmp0 * src8 + tmp7 * src10 - (tmp6 * src10 + tmp9 * src11 + tmp1 * src8); + const dst14 = tmp6 * src9 + tmp11 * src11 + tmp3 * src8 - (tmp10 * src11 + tmp2 * src8 + tmp7 * src9); + const dst15 = tmp10 * src10 + tmp4 * src8 + tmp9 * src9 - (tmp8 * src9 + tmp11 * src10 + tmp5 * src8); + // calculate determinant + let det = src0 * dst0 + src1 * dst1 + src2 * dst2 + src3 * dst3; + if (Math.abs(det) < GMath.EPSILON21) { + // Special case for a zero scale matrix that can occur, for example, + // when a model's node has a [0, 0, 0] scale. + if ( + Matrix3.equalsEpsilon( + Matrix4.getMatrix3(matrix, scratchInverseRotation), + scratchMatrix3Zero, + GMath.EPSILON7 + ) && + Vector4.equals(Matrix4.getRow(matrix, 3, scratchBottomRow), scratchExpectedBottomRow) + ) { + result[0] = 0.0; + result[1] = 0.0; + result[2] = 0.0; + result[3] = 0.0; + result[4] = 0.0; + result[5] = 0.0; + result[6] = 0.0; + result[7] = 0.0; + result[8] = 0.0; + result[9] = 0.0; + result[10] = 0.0; + result[11] = 0.0; + result[12] = -matrix[12]; + result[13] = -matrix[13]; + result[14] = -matrix[14]; + result[15] = 1.0; + return result; + } throw new Error("matrix is not invertible because its determinate is zero."); } + // calculate matrix inverse + det = 1.0 / det; + result[0] = dst0 * det; + result[1] = dst1 * det; + result[2] = dst2 * det; + result[3] = dst3 * det; + result[4] = dst4 * det; + result[5] = dst5 * det; + result[6] = dst6 * det; + result[7] = dst7 * det; + result[8] = dst8 * det; + result[9] = dst9 * det; + result[10] = dst10 * det; + result[11] = dst11 * det; + result[12] = dst12 * det; + result[13] = dst13 * det; + result[14] = dst14 * det; + result[15] = dst15 * det; + return result; + } + static inverseTransformation(matrix, result) { + // This function is an optimized version of the below 4 lines. + // const rT = Matrix3.transpose(Matrix4.getMatrix3(matrix)); + // const rTN = Matrix3.negate(rT); + // const rTT = Matrix3.multiplyByVector(rTN, Matrix4.getTranslation(matrix)); + // return Matrix4.fromRotationTranslation(rT, rTT, result); + const matrix0 = matrix[0]; + const matrix1 = matrix[1]; + const matrix2 = matrix[2]; + const matrix4 = matrix[4]; + const matrix5 = matrix[5]; + const matrix6 = matrix[6]; + const matrix8 = matrix[8]; + const matrix9 = matrix[9]; + const matrix10 = matrix[10]; + const vX = matrix[12]; + const vY = matrix[13]; + const vZ = matrix[14]; + const x = -matrix0 * vX - matrix1 * vY - matrix2 * vZ; + const y = -matrix4 * vX - matrix5 * vY - matrix6 * vZ; + const z = -matrix8 * vX - matrix9 * vY - matrix10 * vZ; + result[0] = matrix0; + result[1] = matrix4; + result[2] = matrix8; + result[3] = 0.0; + result[4] = matrix1; + result[5] = matrix5; + result[6] = matrix9; + result[7] = 0.0; + result[8] = matrix2; + result[9] = matrix6; + result[10] = matrix10; + result[11] = 0.0; + result[12] = x; + result[13] = y; + result[14] = z; + result[15] = 1.0; + return result; + } + static inverseTranspose(matrix, result) { + return Matrix4.inverse(Matrix4.transpose(matrix, scratchTransposeMatrix), result); + } + /** + * @private + */ + static equalsArray(matrix, array, offset) { return ( - (H = 1 / H), - (t[0] = R * H), - (t[1] = A * H), - (t[2] = D * H), - (t[3] = z * H), - (t[4] = I * H), - (t[5] = P * H), - (t[6] = N * H), - (t[7] = B * H), - (t[8] = O * H), - (t[9] = V * H), - (t[10] = F * H), - (t[11] = $ * H), - (t[12] = G * H), - (t[13] = k * H), - (t[14] = q * H), - (t[15] = j * H), - t - ); - } - static inverseTransformation(e, t) { - const i = e[0], - r = e[1], - n = e[2], - s = e[4], - a = e[5], - o = e[6], - c = e[8], - l = e[9], - h = e[10], - u = e[12], - f = e[13], - d = e[14], - m = -i * u - r * f - n * d, - p = -s * u - a * f - o * d, - g = -c * u - l * f - h * d; - return ( - (t[0] = i), - (t[1] = s), - (t[2] = c), - (t[3] = 0), - (t[4] = r), - (t[5] = a), - (t[6] = l), - (t[7] = 0), - (t[8] = n), - (t[9] = o), - (t[10] = h), - (t[11] = 0), - (t[12] = m), - (t[13] = p), - (t[14] = g), - (t[15] = 1), - t - ); - } - static inverseTranspose(e, t) { - return et.inverse(et.transpose(e, tt), t); - } - static equalsArray(e, t, i) { - return ( - e[0] === t[i] && - e[1] === t[i + 1] && - e[2] === t[i + 2] && - e[3] === t[i + 3] && - e[4] === t[i + 4] && - e[5] === t[i + 5] && - e[6] === t[i + 6] && - e[7] === t[i + 7] && - e[8] === t[i + 8] && - e[9] === t[i + 9] && - e[10] === t[i + 10] && - e[11] === t[i + 11] && - e[12] === t[i + 12] && - e[13] === t[i + 13] && - e[14] === t[i + 14] && - e[15] === t[i + 15] + matrix[0] === array[offset] && + matrix[1] === array[offset + 1] && + matrix[2] === array[offset + 2] && + matrix[3] === array[offset + 3] && + matrix[4] === array[offset + 4] && + matrix[5] === array[offset + 5] && + matrix[6] === array[offset + 6] && + matrix[7] === array[offset + 7] && + matrix[8] === array[offset + 8] && + matrix[9] === array[offset + 9] && + matrix[10] === array[offset + 10] && + matrix[11] === array[offset + 11] && + matrix[12] === array[offset + 12] && + matrix[13] === array[offset + 13] && + matrix[14] === array[offset + 14] && + matrix[15] === array[offset + 15] ); } } -(et.IDENTITY = Object.freeze(new et(1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1))), - (et.ZERO = Object.freeze(new et(0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0))); -const tt = new et(); -new Ue(), new Ue(), new Ue(); -const it = new Ue(); -new Ue(); -const rt = new Ue(), - nt = new Ue(), - st = new Ue(), - at = new Ue(), - ot = new Ge(), - ct = new Ge(), - lt = new We(), - ht = new We(0, 0, 0, 1), - ut = new Ue(), - ft = new Ue(), - dt = new Ue(); -class mt { - constructor(e = new Ue(0, 0, 0), t = 0) { - (this.center = e), (this.radius = t), (this.originCenter = this.center.clone()), (this.originRadius = t); - } - static fromPoints(e) { - const t = new mt(); - if (!pe(e) || 0 === e.length) return (t.center = Ue.clone(Ue.ZERO, t.center)), (t.radius = 0), t; - const i = Ue.clone(e[0], bt), - r = Ue.clone(i, pt), - n = Ue.clone(i, gt), - s = Ue.clone(i, xt), - a = Ue.clone(i, vt), - o = Ue.clone(i, yt), - c = Ue.clone(i, St), - l = e.length; - let h; - for (h = 1; h < l; h++) { - Ue.clone(e[h], i); - const t = i.x, - l = i.y, - u = i.z; - t < r.x && Ue.clone(i, r), - t > a.x && Ue.clone(i, a), - l < n.y && Ue.clone(i, n), - l > o.y && Ue.clone(i, o), - u < s.z && Ue.clone(i, s), - u > c.z && Ue.clone(i, c); - } - const u = Ue.magnitudeSquared(Ue.subtract(a, r, wt)), - f = Ue.magnitudeSquared(Ue.subtract(o, n, wt)), - d = Ue.magnitudeSquared(Ue.subtract(c, s, wt)); - let m = r, - p = a, - g = u; - f > g && ((g = f), (m = n), (p = o)), d > g && ((g = d), (m = s), (p = c)); - const x = Tt; - (x.x = 0.5 * (m.x + p.x)), (x.y = 0.5 * (m.y + p.y)), (x.z = 0.5 * (m.z + p.z)); - let v = Ue.magnitudeSquared(Ue.subtract(p, x, wt)), - y = Math.sqrt(v); - const S = Et; - (S.x = r.x), (S.y = n.y), (S.z = s.z); - const b = Mt; - (b.x = a.x), (b.y = o.y), (b.z = c.z); - const w = Ue.midpoint(S, b, Ut); - let T = 0; - for (h = 0; h < l; h++) { - Ue.clone(e[h], i); - const t = Ue.magnitude(Ue.subtract(i, w, wt)); - t > T && (T = t); - const r = Ue.magnitudeSquared(Ue.subtract(i, x, wt)); - if (r > v) { - const e = Math.sqrt(r); - (y = 0.5 * (y + e)), (v = y * y); - const t = e - y; - (x.x = (y * x.x + t * i.x) / e), (x.y = (y * x.y + t * i.y) / e), (x.z = (y * x.z + t * i.z) / e); +Matrix4.IDENTITY = Object.freeze( + new Matrix4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0) +); +Matrix4.ZERO = Object.freeze( + new Matrix4(0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0) +); +const scratchTransposeMatrix = new Matrix4(); +new Vector3(); +new Vector3(); +new Vector3(); +const scaleScratch1$1 = new Vector3(); +new Vector3(); +const scratchColumn$1 = new Vector3(); +const scaleScratch3$1 = new Vector3(); +const scaleScratch4$1 = new Vector3(); +const scaleScratch5$1 = new Vector3(); +const scratchInverseRotation = new Matrix3(); +const scratchMatrix3Zero = new Matrix3(); +const scratchBottomRow = new Vector4(); +const scratchExpectedBottomRow = new Vector4(0.0, 0.0, 0.0, 1.0); +const x = new Vector3(); +const y = new Vector3(); +const z = new Vector3(); + +class BoundingSphere { + constructor(center = new Vector3(0, 0, 0), radius = 0) { + this.center = center; + this.radius = radius; + this.originCenter = this.center.clone(); + this.originRadius = radius; + } + /** + * @param {Vector3[]} [positions] An array of points that the bounding sphere will enclose. Each point must have x, y, and z properties. + * @returns {BoundingSphere} The modified result parameter or a new BoundingSphere instance if one was not provided. + */ + static fromPoints(positions) { + const result = new BoundingSphere(); + if (!defined(positions) || positions.length === 0) { + result.center = Vector3.clone(Vector3.ZERO, result.center); + result.radius = 0.0; + return result; + } + const currentPos = Vector3.clone(positions[0], fromPointsCurrentPos); + const xMin = Vector3.clone(currentPos, fromPointsXMin); + const yMin = Vector3.clone(currentPos, fromPointsYMin); + const zMin = Vector3.clone(currentPos, fromPointsZMin); + const xMax = Vector3.clone(currentPos, fromPointsXMax); + const yMax = Vector3.clone(currentPos, fromPointsYMax); + const zMax = Vector3.clone(currentPos, fromPointsZMax); + const numPositions = positions.length; + let i; + for (i = 1; i < numPositions; i++) { + Vector3.clone(positions[i], currentPos); + const x = currentPos.x; + const y = currentPos.y; + const z = currentPos.z; + // Store points containing the the smallest and largest components + if (x < xMin.x) { + Vector3.clone(currentPos, xMin); + } + if (x > xMax.x) { + Vector3.clone(currentPos, xMax); + } + if (y < yMin.y) { + Vector3.clone(currentPos, yMin); + } + if (y > yMax.y) { + Vector3.clone(currentPos, yMax); + } + if (z < zMin.z) { + Vector3.clone(currentPos, zMin); + } + if (z > zMax.z) { + Vector3.clone(currentPos, zMax); + } + } + // Compute x-, y-, and z-spans (Squared distances b/n each component's min. and max.). + const xSpan = Vector3.magnitudeSquared(Vector3.subtract(xMax, xMin, fromPointsScratch)); + const ySpan = Vector3.magnitudeSquared(Vector3.subtract(yMax, yMin, fromPointsScratch)); + const zSpan = Vector3.magnitudeSquared(Vector3.subtract(zMax, zMin, fromPointsScratch)); + // Set the diameter endpoints to the largest span. + let diameter1 = xMin; + let diameter2 = xMax; + let maxSpan = xSpan; + if (ySpan > maxSpan) { + maxSpan = ySpan; + diameter1 = yMin; + diameter2 = yMax; + } + if (zSpan > maxSpan) { + maxSpan = zSpan; + diameter1 = zMin; + diameter2 = zMax; + } + // Calculate the center of the initial sphere found by Ritter's algorithm + const ritterCenter = fromPointsRitterCenter; + ritterCenter.x = (diameter1.x + diameter2.x) * 0.5; + ritterCenter.y = (diameter1.y + diameter2.y) * 0.5; + ritterCenter.z = (diameter1.z + diameter2.z) * 0.5; + // Calculate the radius of the initial sphere found by Ritter's algorithm + let radiusSquared = Vector3.magnitudeSquared(Vector3.subtract(diameter2, ritterCenter, fromPointsScratch)); + let ritterRadius = Math.sqrt(radiusSquared); + // Find the center of the sphere found using the Naive method. + const minBoxPt = fromPointsMinBoxPt; + minBoxPt.x = xMin.x; + minBoxPt.y = yMin.y; + minBoxPt.z = zMin.z; + const maxBoxPt = fromPointsMaxBoxPt; + maxBoxPt.x = xMax.x; + maxBoxPt.y = yMax.y; + maxBoxPt.z = zMax.z; + const naiveCenter = Vector3.midpoint(minBoxPt, maxBoxPt, fromPointsNaiveCenterScratch); + // Begin 2nd pass to find naive radius and modify the ritter sphere. + let naiveRadius = 0; + for (i = 0; i < numPositions; i++) { + Vector3.clone(positions[i], currentPos); + // Find the furthest point from the naive center to calculate the naive radius. + const r = Vector3.magnitude(Vector3.subtract(currentPos, naiveCenter, fromPointsScratch)); + if (r > naiveRadius) { + naiveRadius = r; + } + // Make adjustments to the Ritter Sphere to include all points. + const oldCenterToPointSquared = Vector3.magnitudeSquared( + Vector3.subtract(currentPos, ritterCenter, fromPointsScratch) + ); + if (oldCenterToPointSquared > radiusSquared) { + const oldCenterToPoint = Math.sqrt(oldCenterToPointSquared); + // Calculate new radius to include the point that lies outside + ritterRadius = (ritterRadius + oldCenterToPoint) * 0.5; + radiusSquared = ritterRadius * ritterRadius; + // Calculate center of new Ritter sphere + const oldToNew = oldCenterToPoint - ritterRadius; + ritterCenter.x = (ritterRadius * ritterCenter.x + oldToNew * currentPos.x) / oldCenterToPoint; + ritterCenter.y = (ritterRadius * ritterCenter.y + oldToNew * currentPos.y) / oldCenterToPoint; + ritterCenter.z = (ritterRadius * ritterCenter.z + oldToNew * currentPos.z) / oldCenterToPoint; + } + } + if (ritterRadius < naiveRadius) { + Vector3.clone(ritterCenter, result.center); + result.radius = ritterRadius; + } else { + Vector3.clone(naiveCenter, result.center); + result.radius = naiveRadius; + } + return result; + } + /** + * Computes a tight-fitting bounding sphere enclosing a list of 3D points, where the points are + * stored in a flat array in X, Y, Z, order. The bounding sphere is computed by running two + * algorithms, a naive algorithm and Ritter's algorithm. The smaller of the two spheres is used to + * ensure a tight fit. + * + * @param {Number[]} [positions] An array of points that the bounding sphere will enclose. Each point + * is formed from three elements in the array in the order X, Y, Z. + * @param {Vector3} [center=Vector3.ZERO] The position to which the positions are relative, which need not be the + * origin of the coordinate system. This is useful when the positions are to be used for + * relative-to-center (RTC) rendering. + * @param {Number} [stride=3] The number of array elements per vertex. It must be at least 3, but it may + * be higher. Regardless of the value of this parameter, the X coordinate of the first position + * is at array index 0, the Y coordinate is at array index 1, and the Z coordinate is at array index + * 2. When stride is 3, the X coordinate of the next position then begins at array index 3. If + * the stride is 5, however, two array elements are skipped and the next position begins at array + * index 5. + * @param {BoundingSphere} [result] The object onto which to store the result. + * @returns {BoundingSphere} The modified result parameter or a new BoundingSphere instance if one was not provided. + * + * @example + * // Compute the bounding sphere from 3 positions, each specified relative to a center. + * // In addition to the X, Y, and Z coordinates, the points array contains two additional + * // elements per point which are ignored for the purpose of computing the bounding sphere. + * const center = new Vector3(1.0, 2.0, 3.0); + * const points = [1.0, 2.0, 3.0, 0.1, 0.2, + * 4.0, 5.0, 6.0, 0.1, 0.2, + * 7.0, 8.0, 9.0, 0.1, 0.2]; + * const sphere = BoundingSphere.fromVertices(points, center, 5); + * + */ + static fromVertices(positions, center = Vector3.ZERO, stride = 3) { + const result = new BoundingSphere(); + if (!defined(positions) || positions.length === 0) { + result.center = Vector3.clone(Vector3.ZERO, result.center); + result.radius = 0.0; + return result; + } + center = defaultValue(center, Vector3.ZERO); + stride = defaultValue(stride, 3); + const currentPos = fromPointsCurrentPos; + currentPos.x = positions[0] + center.x; + currentPos.y = positions[1] + center.y; + currentPos.z = positions[2] + center.z; + const xMin = Vector3.clone(currentPos, fromPointsXMin); + const yMin = Vector3.clone(currentPos, fromPointsYMin); + const zMin = Vector3.clone(currentPos, fromPointsZMin); + const xMax = Vector3.clone(currentPos, fromPointsXMax); + const yMax = Vector3.clone(currentPos, fromPointsYMax); + const zMax = Vector3.clone(currentPos, fromPointsZMax); + const numElements = positions.length; + let i; + for (i = 0; i < numElements; i += stride) { + const x = positions[i] + center.x; + const y = positions[i + 1] + center.y; + const z = positions[i + 2] + center.z; + currentPos.x = x; + currentPos.y = y; + currentPos.z = z; + // Store points containing the the smallest and largest components + if (x < xMin.x) { + Vector3.clone(currentPos, xMin); + } + if (x > xMax.x) { + Vector3.clone(currentPos, xMax); + } + if (y < yMin.y) { + Vector3.clone(currentPos, yMin); + } + if (y > yMax.y) { + Vector3.clone(currentPos, yMax); + } + if (z < zMin.z) { + Vector3.clone(currentPos, zMin); + } + if (z > zMax.z) { + Vector3.clone(currentPos, zMax); } } - return y < T ? (Ue.clone(x, t.center), (t.radius = y)) : (Ue.clone(w, t.center), (t.radius = T)), t; - } - static fromVertices(e, t = Ue.ZERO, i = 3) { - const r = new mt(); - if (!pe(e) || 0 === e.length) return (r.center = Ue.clone(Ue.ZERO, r.center)), (r.radius = 0), r; - (t = ee(t, Ue.ZERO)), (i = ee(i, 3)); - const n = bt; - (n.x = e[0] + t.x), (n.y = e[1] + t.y), (n.z = e[2] + t.z); - const s = Ue.clone(n, pt), - a = Ue.clone(n, gt), - o = Ue.clone(n, xt), - c = Ue.clone(n, vt), - l = Ue.clone(n, yt), - h = Ue.clone(n, St), - u = e.length; - let f; - for (f = 0; f < u; f += i) { - const i = e[f] + t.x, - r = e[f + 1] + t.y, - u = e[f + 2] + t.z; - (n.x = i), - (n.y = r), - (n.z = u), - i < s.x && Ue.clone(n, s), - i > c.x && Ue.clone(n, c), - r < a.y && Ue.clone(n, a), - r > l.y && Ue.clone(n, l), - u < o.z && Ue.clone(n, o), - u > h.z && Ue.clone(n, h); - } - const d = Ue.magnitudeSquared(Ue.subtract(c, s, wt)), - m = Ue.magnitudeSquared(Ue.subtract(l, a, wt)), - p = Ue.magnitudeSquared(Ue.subtract(h, o, wt)); - let g = s, - x = c, - v = d; - m > v && ((v = m), (g = a), (x = l)), p > v && ((v = p), (g = o), (x = h)); - const y = Tt; - (y.x = 0.5 * (g.x + x.x)), (y.y = 0.5 * (g.y + x.y)), (y.z = 0.5 * (g.z + x.z)); - let S = Ue.magnitudeSquared(Ue.subtract(x, y, wt)), - b = Math.sqrt(S); - const w = Et; - (w.x = s.x), (w.y = a.y), (w.z = o.z); - const T = Mt; - (T.x = c.x), (T.y = l.y), (T.z = h.z); - const E = Ue.midpoint(w, T, Ut); - let M = 0; - for (f = 0; f < u; f += i) { - (n.x = e[f] + t.x), (n.y = e[f + 1] + t.y), (n.z = e[f + 2] + t.z); - const i = Ue.magnitude(Ue.subtract(n, E, wt)); - i > M && (M = i); - const r = Ue.magnitudeSquared(Ue.subtract(n, y, wt)); - if (r > S) { - const e = Math.sqrt(r); - (b = 0.5 * (b + e)), (S = b * b); - const t = e - b; - (y.x = (b * y.x + t * n.x) / e), (y.y = (b * y.y + t * n.y) / e), (y.z = (b * y.z + t * n.z) / e); + // Compute x-, y-, and z-spans (Squared distances b/n each component's min. and max.). + const xSpan = Vector3.magnitudeSquared(Vector3.subtract(xMax, xMin, fromPointsScratch)); + const ySpan = Vector3.magnitudeSquared(Vector3.subtract(yMax, yMin, fromPointsScratch)); + const zSpan = Vector3.magnitudeSquared(Vector3.subtract(zMax, zMin, fromPointsScratch)); + // Set the diameter endpoints to the largest span. + let diameter1 = xMin; + let diameter2 = xMax; + let maxSpan = xSpan; + if (ySpan > maxSpan) { + maxSpan = ySpan; + diameter1 = yMin; + diameter2 = yMax; + } + if (zSpan > maxSpan) { + maxSpan = zSpan; + diameter1 = zMin; + diameter2 = zMax; + } + // Calculate the center of the initial sphere found by Ritter's algorithm + const ritterCenter = fromPointsRitterCenter; + ritterCenter.x = (diameter1.x + diameter2.x) * 0.5; + ritterCenter.y = (diameter1.y + diameter2.y) * 0.5; + ritterCenter.z = (diameter1.z + diameter2.z) * 0.5; + // Calculate the radius of the initial sphere found by Ritter's algorithm + let radiusSquared = Vector3.magnitudeSquared(Vector3.subtract(diameter2, ritterCenter, fromPointsScratch)); + let ritterRadius = Math.sqrt(radiusSquared); + // Find the center of the sphere found using the Naive method. + const minBoxPt = fromPointsMinBoxPt; + minBoxPt.x = xMin.x; + minBoxPt.y = yMin.y; + minBoxPt.z = zMin.z; + const maxBoxPt = fromPointsMaxBoxPt; + maxBoxPt.x = xMax.x; + maxBoxPt.y = yMax.y; + maxBoxPt.z = zMax.z; + const naiveCenter = Vector3.midpoint(minBoxPt, maxBoxPt, fromPointsNaiveCenterScratch); + // Begin 2nd pass to find naive radius and modify the ritter sphere. + let naiveRadius = 0; + for (i = 0; i < numElements; i += stride) { + currentPos.x = positions[i] + center.x; + currentPos.y = positions[i + 1] + center.y; + currentPos.z = positions[i + 2] + center.z; + // Find the furthest point from the naive center to calculate the naive radius. + const r = Vector3.magnitude(Vector3.subtract(currentPos, naiveCenter, fromPointsScratch)); + if (r > naiveRadius) { + naiveRadius = r; + } + // Make adjustments to the Ritter Sphere to include all points. + const oldCenterToPointSquared = Vector3.magnitudeSquared( + Vector3.subtract(currentPos, ritterCenter, fromPointsScratch) + ); + if (oldCenterToPointSquared > radiusSquared) { + const oldCenterToPoint = Math.sqrt(oldCenterToPointSquared); + // Calculate new radius to include the point that lies outside + ritterRadius = (ritterRadius + oldCenterToPoint) * 0.5; + radiusSquared = ritterRadius * ritterRadius; + // Calculate center of new Ritter sphere + const oldToNew = oldCenterToPoint - ritterRadius; + ritterCenter.x = (ritterRadius * ritterCenter.x + oldToNew * currentPos.x) / oldCenterToPoint; + ritterCenter.y = (ritterRadius * ritterCenter.y + oldToNew * currentPos.y) / oldCenterToPoint; + ritterCenter.z = (ritterRadius * ritterCenter.z + oldToNew * currentPos.z) / oldCenterToPoint; } } - return b < M ? (Ue.clone(y, r.center), (r.radius = b)) : (Ue.clone(E, r.center), (r.radius = M)), r; - } - intersectPlane(e) { - const t = this.center, - i = this.radius, - r = e.normal, - n = Ue.dot(r, t) + e.distance; - return n < -i ? F.OUTSIDE : n < i ? F.INTERSECTING : F.INSIDE; - } - update(e) { - et.multiplyByPoint(e, this.originCenter, this.center), - (this.radius = et.getMaximumScale(e) * this.originRadius); - } - distanceToCamera(e) { - return Math.max(0, Ue.distance(this.center, e.position) - this.radius); - } -} -const pt = new Ue(), - gt = new Ue(), - xt = new Ue(), - vt = new Ue(), - yt = new Ue(), - St = new Ue(), - bt = new Ue(), - wt = new Ue(), - Tt = new Ue(), - Et = new Ue(), - Mt = new Ue(), - Ut = new Ue(); -class _t { - constructor(e, t) { - (this.label = e), (this.indices = t), (this.indexFormat = _.Uint16), (this.dirty = !0); - } - setIndices(e) { - (this.indices = e), (this.dirty = !0); - } - bind(e, t) { - this.dirty && - ((this.dirty = !1), - (this.buffer = $.createIndexBuffer( + if (ritterRadius < naiveRadius) { + Vector3.clone(ritterCenter, result.center); + result.radius = ritterRadius; + } else { + Vector3.clone(naiveCenter, result.center); + result.radius = naiveRadius; + } + return result; + } + intersectPlane(plane) { + const center = this.center; + const radius = this.radius; + const normal = plane.normal; + const distanceToPlane = Vector3.dot(normal, center) + plane.distance; + if (distanceToPlane < -radius) { + // The center point is negative side of the plane normal + return Intersect.OUTSIDE; + } else if (distanceToPlane < radius) { + // The center point is positive side of the plane, but radius extends beyond it; partial overlap + return Intersect.INTERSECTING; + } + return Intersect.INSIDE; + } + update(transform) { + Matrix4.multiplyByPoint(transform, this.originCenter, this.center); + this.radius = Matrix4.getMaximumScale(transform) * this.originRadius; + } + distanceToCamera(camera) { + return Math.max(0.0, Vector3.distance(this.center, camera.position) - this.radius); + } +} +const fromPointsXMin = new Vector3(); +const fromPointsYMin = new Vector3(); +const fromPointsZMin = new Vector3(); +const fromPointsXMax = new Vector3(); +const fromPointsYMax = new Vector3(); +const fromPointsZMax = new Vector3(); +const fromPointsCurrentPos = new Vector3(); +const fromPointsScratch = new Vector3(); +const fromPointsRitterCenter = new Vector3(); +const fromPointsMinBoxPt = new Vector3(); +const fromPointsMaxBoxPt = new Vector3(); +const fromPointsNaiveCenterScratch = new Vector3(); + +class IndexBuffer { + constructor(label, indices) { + this.label = label; + this.indices = indices; + this.indexFormat = IndexFormat.Uint16; + this.dirty = true; + } + setIndices(indices) { + this.indices = indices; + this.dirty = true; + } + bind(device, passEncoder) { + if (this.dirty) { + this.dirty = false; + this.buffer = Buffer.createIndexBuffer( this.label, - e, - this.indexFormat == _.Uint16 ? new Uint16Array(this.indices) : new Uint32Array(this.indices) - ))), - t.setIndexBuffer(this.buffer.gpuBuffer, this.indexFormat); + device, + this.indexFormat == IndexFormat.Uint16 ? new Uint16Array(this.indices) : new Uint32Array(this.indices) + ); + } + passEncoder.setIndexBuffer(this.buffer.gpuBuffer, this.indexFormat); } destroy() { this.buffer.destroy(); } } -class Lt { - constructor(e = 0) { - (this._attributes = new Map()), (this.shaderLocation = e), (this.offset = 0), (this.interleave = !1); + +class Attributes { + constructor(shaderLocation = 0) { + this._attributes = new Map(); + this.shaderLocation = shaderLocation; + this.offset = 0; + this.interleave = false; } get dirty() { - let e = !1; - return this._attributes.forEach((t) => !e && (e = t.dirty)), e; + let result = false; + this._attributes.forEach((attribute) => (!result ? (result = attribute.dirty) : false)); + return result; } - set dirty(e) { - this._attributes.forEach((t) => (t.dirty = e)); + set dirty(value) { + this._attributes.forEach((attribute) => (attribute.dirty = value)); } get values() { return this._attributes; } - getAttribute(e) { - return this._attributes.get(e); + getAttribute(name) { + return this._attributes.get(name); } - setAttribute(e) { - e.attributeType === Be.attribute ? this.setNotInterleavedAttribute(e) : this.setInterleavedAttribute(e); + setAttribute(attribute) { + if (attribute.attributeType === AttributeType.attribute) { + this.setNotInterleavedAttribute(attribute); + } else { + this.setInterleavedAttribute(attribute); + } } - setNotInterleavedAttribute(e) { - this._attributes.has(e.name) || - ((e.shaderLocation = this.shaderLocation), - (this.shaderLocation += 1), - (e.offset = this.offset), - (this.offset += e.attributeByteSize), - this._attributes.set(e.name, e)); + setNotInterleavedAttribute(attribute) { + if (this._attributes.has(attribute.name)) return; + attribute.shaderLocation = this.shaderLocation; + this.shaderLocation += 1; + attribute.offset = this.offset; + this.offset += attribute.attributeByteSize; + this._attributes.set(attribute.name, attribute); } - setInterleavedAttribute(e) { - this._attributes.has(e.names.toString()) || this._attributes.set(e.names.toString(), e); + setInterleavedAttribute(attribute) { + if (this._attributes.has(attribute.names.toString())) return; + this._attributes.set(attribute.names.toString(), attribute); } getGPUAttributesDes() { - const e = []; - return ( - this._attributes.forEach((t) => { - e.push(...t.getGPUAttribute()); - }), - e - ); + const result = []; + this._attributes.forEach((attribute) => { + result.push(...attribute.getGPUAttribute()); + }); + return result; } getAtrributeValues() { - const e = []; - let t, - i = 0, - r = null; - const n = []; - this._attributes.forEach((s) => { - s.attributeType === Be.attribute - ? (e.push(s.itemSize), n.push(s.value), (i += s.itemSize)) - : (this.interleave || (this.interleave = !0), - (r = r ?? s.value), - (t = s?.buffer), - (i = s.itemSizes.reduce((e, t) => e + t, 0))); + const arrayStrides = []; + let arrayStride = 0; + let buffer = undefined; + let values = null; + const arrays = []; + this._attributes.forEach((attribute) => { + if (attribute.attributeType === AttributeType.attribute) { + arrayStrides.push(attribute.itemSize); + arrays.push(attribute.value); + arrayStride += attribute.itemSize; + } else { + if (!this.interleave) this.interleave = true; + values = values ?? attribute.value; + buffer = attribute?.buffer; + arrayStride = attribute.itemSizes.reduce((total, current) => (total += current), 0); + } }); - const s = this.interleave ? new Float32Array(r) : this.interleaveTypedArray(Float32Array, e, ...n); - return { arrayStride: i * s.BYTES_PER_ELEMENT, typeArray: s, buffer: t }; + const typeArray = this.interleave + ? new Float32Array(values) + : this.interleaveTypedArray(Float32Array, arrayStrides, ...arrays); + return { + arrayStride: arrayStride * typeArray.BYTES_PER_ELEMENT, + typeArray, + buffer + }; } destroy() { - this._attributes.forEach((e) => { - e.destroy(); + this._attributes.forEach((attribute) => { + attribute.destroy(); }); } - interleaveTypedArray(e, t, ...i) { - const r = i.reduce((e, t) => e + t.length, 0), - n = new e(r), - s = t.reduce((e, t) => e + t); - for (let e = 0; e < r; e++) { - let r = 0; - for (let a = 0; a < t.length; a++) for (let o = 0; o < t[a]; o++) (n[e * s + r] = i[a][t[a] * e + o]), r++; + /** + * Interleave n typed arrays + * @alias module:interleaveTypedArray + * @param {TypedArray} ResultConstructor Returned typed array constructor + * @param {Array} elements Number of elements to group for each typed array + * @param {...TypedArray} arrays Arrays to interleave + * @returns {TypedArray} + */ + interleaveTypedArray(ResultConstructor, elements, ...arrays) { + const totalLength = arrays.reduce((total, arr) => total + arr.length, 0); + const result = new ResultConstructor(totalLength); + const stride = elements.reduce((a, b) => a + b); + for (let i = 0; i < totalLength; i++) { + let offset = 0; + for (let j = 0; j < elements.length; j++) { + for (let k = 0; k < elements[j]; k++) { + result[i * stride + offset] = arrays[j][elements[j] * i + k]; + offset++; + } + } } - return n; + return result; } } -class Ct { - constructor(e) { - const { label: t, index: i, locationIndex: r = 0, stepMode: n = C.Vertex, arrayStride: s } = e; - (this.index = i || 0), - (this.attributes = new Lt(r)), - (this.stepMode = n), - (this.dirty = !0), - (this.label = t?.concat(`_${i}_VertexBuffer`)), - (this.arrayStride = s), - (this.defines = {}), - (this.locationIndex = r); + +class VertexBuffer { + // + constructor(params) { + const { label, index, locationIndex = 0, stepMode = InputStepMode.Vertex, arrayStride } = params; + this.index = index || 0; + this.attributes = new Attributes(locationIndex); + this.stepMode = stepMode; + this.dirty = true; + this.label = label?.concat(`_${index}_VertexBuffer`); + this.arrayStride = arrayStride; + this.defines = {}; + this.locationIndex = locationIndex; } getBufferDes() { - return { + const result = { arrayStride: this.arrayStride, stepMode: this.stepMode, attributes: this.attributes.getGPUAttributesDes() }; + return result; } - setAttribute(e) { - e.attributeType === Be.attribute - ? this.setLocationIndex(e.name) - : e?.names.forEach((e) => this.setLocationIndex(e)), - this.attributes.setAttribute(e), - (this.dirty = !0); + setAttribute(attribute) { + if (attribute.attributeType === AttributeType.attribute) { + this.setLocationIndex(attribute.name); + } else { + attribute?.names.forEach((name) => this.setLocationIndex(name)); + } + this.attributes.setAttribute(attribute); + this.dirty = true; } - getAttribute(e) { - return this.attributes.getAttribute(e); + getAttribute(name) { + return this.attributes.getAttribute(name); } - containAttribute(e) { - return null != this.defines[e?.concat("Location")]; + containAttribute(name) { + return this.defines[name?.concat("Location")] != undefined ? true : false; } - bind(e, t) { + bind(device, passEncoder) { if (this.attributes.dirty) { - this.attributes.dirty = !1; - const { arrayStride: t, typeArray: i, buffer: r } = this.attributes.getAtrributeValues(); - void 0 === this.arrayStride && (this.arrayStride = t), - this.buffer - ? i && this.buffer.setSubData(0, i) - : (this.buffer = r ?? $.createVertexBuffer(this.label, e, i)); + this.attributes.dirty = false; + const { arrayStride, typeArray, buffer } = this.attributes.getAtrributeValues(); + if (this.arrayStride === undefined) this.arrayStride = arrayStride; + if (!this.buffer) { + this.buffer = buffer ?? Buffer.createVertexBuffer(this.label, device, typeArray); + } else { + // update Buffer + if (typeArray) this.buffer.setSubData(0, typeArray); + } } - t.setVertexBuffer(this.index, this.buffer.gpuBuffer); + passEncoder.setVertexBuffer(this.index, this.buffer.gpuBuffer); } - setLocationIndex(e) { - !this.defines[e?.concat("Location")] && - e && - ((this.defines[e?.concat("Location")] = this.locationIndex), (this.locationIndex += 1)); + setLocationIndex(name) { + if (this.defines[name?.concat("Location")] || !name) return; + this.defines[name?.concat("Location")] = this.locationIndex; + this.locationIndex += 1; } destroy() { - this.buffer.destroy(), this.attributes.destroy(); - } -} -function Rt(e, t, i) { - i = ee(i, !1); - const r = {}, - n = pe(e), - s = pe(t); - let a, o, c; - if (n) - for (a in e) - e.hasOwnProperty(a) && - ((o = e[a]), - s && i && "object" == typeof o && t.hasOwnProperty(a) - ? ((c = t[a]), (r[a] = "object" == typeof c ? Rt(o, c, i) : o)) - : (r[a] = o)); - if (s) for (a in t) t.hasOwnProperty(a) && !r.hasOwnProperty(a) && ((c = t[a]), (r[a] = c)); - return r; -} -class At { + this.buffer.destroy(); + this.attributes.destroy(); + } +} + +/** + * Merges two objects, copying their properties onto a new combined object. When two objects have the same + * property, the value of the property on the first object is used. If either object is undefined, + * it will be treated as an empty object. + * + * @example + * const object1 = { + * propOne : 1, + * propTwo : { + * value1 : 10 + * } + * } + * const object2 = { + * propTwo : 2 + * } + * const final = combine(object1, object2); + * + * // final === { + * // propOne : 1, + * // propTwo : { + * // value1 : 10 + * // } + * // } + * + * @param {Object} [object1] The first object to merge. + * @param {Object} [object2] The second object to merge. + * @param {Boolean} [deep=false] Perform a recursive merge. + * @returns {Object} The combined object containing all properties from both objects. + * + * @function + */ +function combine(object1, object2, deep) { + deep = defaultValue(deep, false); + const result = {}; + const object1Defined = defined(object1); + const object2Defined = defined(object2); + let property; + let object1Value; + let object2Value; + if (object1Defined) { + for (property in object1) { + if (object1.hasOwnProperty(property)) { + object1Value = object1[property]; + if (object2Defined && deep && typeof object1Value === "object" && object2.hasOwnProperty(property)) { + object2Value = object2[property]; + if (typeof object2Value === "object") { + result[property] = combine(object1Value, object2Value, deep); + } else { + result[property] = object1Value; + } + } else { + result[property] = object1Value; + } + } + } + } + if (object2Defined) { + for (property in object2) { + if (object2.hasOwnProperty(property) && !result.hasOwnProperty(property)) { + object2Value = object2[property]; + result[property] = object2Value; + } + } + } + return result; +} + +class Geometry { get defines() { - return Object.assign({}, this._defines, ...this.vertexBuffers.map((e) => e.defines)); + return Object.assign({}, this._defines, ...this.vertexBuffers.map((vertexBuffer) => vertexBuffer.defines)); } - set defines(e) { - (this.definesDirty = !0), (this._defines = Rt(e, this._defines, !1)); + set defines(value) { + this.definesDirty = true; + this._defines = combine(value, this._defines, false); } get currentLocationIndex() { - return this?.vertexBuffers?.reduce((e, t) => (t.locationIndex > e ? (e = t.locationIndex) : e), 0); + return this?.vertexBuffers?.reduce( + (max, current) => (current.locationIndex > max ? (max = current.locationIndex) : max), + 0 + ); } get vertexBufferCount() { return this.vertexBuffers.length; } - constructor(e) { - (this.type = e.type || void 0), - (this.boundingSphere = void 0), - (this.dirty = !1), - (this.definesDirty = !0), - (this.defaultVertexBuffer = new Ct({ label: this.type, index: 0 })), - (this.vertexBuffers = [this.defaultVertexBuffer]), - (this._defines = {}), - (this.normals = []), - (this.uvs = []), - (this.positions = []), - (this.indices = []), - (this.tangents = []); - } - getAttribute(e) { - return this.defaultVertexBuffer.getAttribute(e); - } - setAttribute(e) { - this.defaultVertexBuffer.setAttribute(e); - } - setIndice(e) { - (this.indices = e), - this.indexBuffer || (this.indexBuffer = new _t(this.type + "IndexBuffer")), - this.indexBuffer.setIndices(e); - } - update(e) {} - computeBoundingSphere(e, t = 3) { - this.boundingSphere = mt.fromVertices(e, new Ue(0, 0, 0), t); + constructor(options) { + this.type = options.type || undefined; + this.boundingSphere = undefined; + this.dirty = false; + this.definesDirty = true; + this.defaultVertexBuffer = new VertexBuffer({ + label: this.type, + index: 0 + }); + this.vertexBuffers = [this.defaultVertexBuffer]; + this._defines = {}; + this.normals = []; + this.uvs = []; + this.positions = []; + this.indices = []; + this.tangents = []; + } + getAttribute(name) { + return this.defaultVertexBuffer.getAttribute(name); + } + setAttribute(attribute) { + this.defaultVertexBuffer.setAttribute(attribute); + } + setIndice(indices) { + this.indices = indices; + if (!this.indexBuffer) this.indexBuffer = new IndexBuffer(this.type + "IndexBuffer"); + this.indexBuffer.setIndices(indices); + } + update(frameState) { + // todo } + computeBoundingSphere(positions, stride = 3) { + this.boundingSphere = BoundingSphere.fromVertices(positions, new Vector3(0, 0, 0), stride); + } + /** + * Calculate mesh tangent. + * @remark need to set positions(with or not with indices), normals, uv before calculation. + * @remark based on http://foundationsofgameenginedev.com/FGED2-sample.pdf + */ calculateTangents() { - if (!this.normals || !this.uvs) throw "Set normal and uv before calculation."; - const { indices: e, positions: t, normals: i, uvs: r } = this, - n = new Ue(), - s = new Ue(), - a = new Ue(), - o = new Se(), - c = new Se(), - l = new Se(), - h = new Ue(), - u = new Ue(), - f = new Ue(), - d = new Ue(), - m = new Ue(), - p = this.indices.length, - g = e ? e.length / 3 : t.length / 3, - x = new Array(p), - v = new Array(p); + if (!this.normals || !this.uvs) { + throw "Set normal and uv before calculation."; + } + const { indices, positions, normals, uvs } = this; + const tempPos0 = new Vector3(), + tempPos1 = new Vector3(), + tempPos2 = new Vector3(), + tempUV0 = new Vector2(), + tempUV1 = new Vector2(), + tempUV2 = new Vector2(); + const e1 = new Vector3(), + e2 = new Vector3(), + t = new Vector3(), + b = new Vector3(), + temp = new Vector3(); + const vertexCount = this.indices.length; + const triangleCount = indices ? indices.length / 3 : positions.length / 3; + const tangents = new Array(vertexCount); + const biTangents = new Array(vertexCount); this.tangents = []; - for (let e = 0; e < p; e++) (x[e] = new We()), (v[e] = new Ue()); - for (let i = 0; i < g; i++) { - let p = 3 * i, - g = 3 * i + 1, - y = 3 * i + 2; - e && ((p = e[p]), (g = e[g]), (y = e[y])); - const S = n.set(t[p], t[p + 1], t[p + 2]), - b = s.set(t[g], t[g + 1], t[g + 2]), - w = a.set(t[y], t[y + 1], t[y + 2]), - T = o.set(r[p], r[p + 1]), - E = c.set(r[g], r[g + 1]), - M = l.set(r[y], r[y + 1]); - Ue.subtract(b, S, h), Ue.subtract(w, S, u); - const U = E.x - T.x, - _ = M.x - T.x, - L = E.y - T.y, - C = M.y - T.y, - R = 1 / (U * C - _ * L); - Ue.multiplyByScalar(h, C * R, f), - Ue.multiplyByScalar(u, L * R, m), - Ue.subtract(f, m, f), - Ue.multiplyByScalar(u, U * R, d), - Ue.multiplyByScalar(h, _ * R, m), - Ue.subtract(d, m, d); - let A = x[p]; - A.set(A.x + f.x, A.y + f.y, A.z + f.z, 1), - (A = x[g]), - A.set(A.x + f.x, A.y + f.y, A.z + f.z, 1), - (A = x[y]), - A.set(A.x + f.x, A.y + f.y, A.z + f.z, 1), - v[p].add(d), - v[g].add(d), - v[y].add(d); - } - for (let e = 0; e < p; e++) { - const t = new Ue(i[3 * e], i[3 * e + 1], i[3 * e + 2]), - r = v[e], - n = x[e]; - f.set(n.x, n.y, n.z), Ue.cross(f, r, m); - const s = Ue.dot(m, t) > 0 ? 1 : -1; - Ue.multiplyByScalar(t, Ue.dot(f, t), m), - Ue.subtract(f, m, f), - Ue.normalize(f, f), - n.set(f.x, f.y, f.z, s), - this.tangents.push(f.x, f.y, f.z, s); + for (let i = 0; i < vertexCount; i++) { + tangents[i] = new Vector4(); + biTangents[i] = new Vector3(); + } + // Calculate tangent and bi-tangent for each triangle and add to all three vertices. + for (let k = 0; k < triangleCount; k++) { + let i0 = 3 * k; + let i1 = 3 * k + 1; + let i2 = 3 * k + 2; + if (indices) { + i0 = indices[i0]; + i1 = indices[i1]; + i2 = indices[i2]; + } + const p0 = tempPos0.set(positions[i0], positions[i0 + 1], positions[i0 + 2]); + const p1 = tempPos1.set(positions[i1], positions[i1 + 1], positions[i1 + 2]); + const p2 = tempPos2.set(positions[i2], positions[i2 + 1], positions[i2 + 2]); + const w0 = tempUV0.set(uvs[i0], uvs[i0 + 1]); + const w1 = tempUV1.set(uvs[i1], uvs[i1 + 1]); + const w2 = tempUV2.set(uvs[i2], uvs[i2 + 1]); + Vector3.subtract(p1, p0, e1); + Vector3.subtract(p2, p0, e2); + const x1 = w1.x - w0.x; + const x2 = w2.x - w0.x; + const y1 = w1.y - w0.y; + const y2 = w2.y - w0.y; + const r = 1.0 / (x1 * y2 - x2 * y1); + Vector3.multiplyByScalar(e1, y2 * r, t); + Vector3.multiplyByScalar(e2, y1 * r, temp); + Vector3.subtract(t, temp, t); + Vector3.multiplyByScalar(e2, x1 * r, b); + Vector3.multiplyByScalar(e1, x2 * r, temp); + Vector3.subtract(b, temp, b); + let tangent = tangents[i0]; + tangent.set(tangent.x + t.x, tangent.y + t.y, tangent.z + t.z, 1.0); + tangent = tangents[i1]; + tangent.set(tangent.x + t.x, tangent.y + t.y, tangent.z + t.z, 1.0); + tangent = tangents[i2]; + tangent.set(tangent.x + t.x, tangent.y + t.y, tangent.z + t.z, 1.0); + biTangents[i0].add(b); + biTangents[i1].add(b); + biTangents[i2].add(b); } + // Orthonormalize each tangent and calculate the handedness. + for (let i = 0; i < vertexCount; i++) { + const n = new Vector3(normals[3 * i], normals[3 * i + 1], normals[3 * i + 2]); + const b = biTangents[i]; + const tangent = tangents[i]; + t.set(tangent.x, tangent.y, tangent.z); + Vector3.cross(t, b, temp); + const w = Vector3.dot(temp, n) > 0.0 ? 1 : -1; + Vector3.multiplyByScalar(n, Vector3.dot(t, n), temp); + Vector3.subtract(t, temp, t); + Vector3.normalize(t, t); + // t.normalize(); + tangent.set(t.x, t.y, t.z, w); + this.tangents.push(t.x, t.y, t.z, w); + } + // this.setTangents(tangents); } destroy() { - this?.indexBuffer.destroy(), - this.defaultVertexBuffer.destroy(), - (this.normals = null), - (this.uvs = null), - (this.positions = null), - (this.indices = null), - (this.tangents = null), - (this.boundingSphere = void 0); - } -} -class Dt extends At { - constructor(e = 10, t = 10) { - super({ type: "planeGeometry" }), - (this.width = e), - (this.height = t), - (this.defines = { HAS_NORMAL: !0 }), - this.init(); + this?.indexBuffer.destroy(); + this.defaultVertexBuffer.destroy(); + this.normals = null; + this.uvs = null; + this.positions = null; + this.indices = null; + this.tangents = null; + this.boundingSphere = undefined; + } +} + +class PlaneGeometry extends Geometry { + constructor(width = 10, height = 10) { + super({ + type: "planeGeometry" + }); + this.width = width; + this.height = height; + this.defines = { + HAS_NORMAL: true + }; + this.init(); } init() { - const { indices: e, normals: t, uvs: i, vertices: r } = this.createGrid(this.width, this.height); - this.computeBoundingSphere(r), - this.setAttribute(new Ie("position", r, 3)), - this.setAttribute(new Ie("normal", t, 3)), - this.setAttribute(new Ie("uv", i, 2)), - this.setIndice(e), - (this.count = e.length); - } - createGrid(e = 1, t = 1, i = 1, r = 1) { - const n = e / 2, - s = t / 2, - a = Math.floor(i), - o = Math.floor(r), - c = a + 1, - l = o + 1, - h = e / a, - u = t / o, - f = [], - d = [], - m = [], - p = []; - for (let e = 0; e < l; e++) { - const t = e * u - s; - for (let i = 0; i < c; i++) { - const r = i * h - n; - d.push(r, -t, 0), m.push(0, 0, 1), p.push(i / a), p.push(1 - e / o); + // generate pos uv normal so on + const { indices, normals, uvs, vertices } = this.createGrid(this.width, this.height); + this.computeBoundingSphere(vertices); + this.setAttribute(new Float32Attribute("position", vertices, 3)); + this.setAttribute(new Float32Attribute("normal", normals, 3)); + this.setAttribute(new Float32Attribute("uv", uvs, 2)); + this.setIndice(indices); + this.count = indices.length; + } + createGrid(width = 1, height = 1, widthSegments = 1, heightSegments = 1) { + const width_half = width / 2; + const height_half = height / 2; + const gridX = Math.floor(widthSegments); + const gridY = Math.floor(heightSegments); + const gridX1 = gridX + 1; + const gridY1 = gridY + 1; + const segment_width = width / gridX; + const segment_height = height / gridY; + // + const indices = []; + const vertices = []; + const normals = []; + const uvs = []; + for (let iy = 0; iy < gridY1; iy++) { + const y = iy * segment_height - height_half; + for (let ix = 0; ix < gridX1; ix++) { + const x = ix * segment_width - width_half; + vertices.push(x, -y, 0); + normals.push(0, 0, 1); + uvs.push(ix / gridX); + uvs.push(1 - iy / gridY); } } - for (let e = 0; e < o; e++) - for (let t = 0; t < a; t++) { - const i = t + c * e, - r = t + c * (e + 1), - n = t + 1 + c * (e + 1), - s = t + 1 + c * e; - f.push(i, r, s), f.push(r, n, s); + for (let iy = 0; iy < gridY; iy++) { + for (let ix = 0; ix < gridX; ix++) { + const a = ix + gridX1 * iy; + const b = ix + gridX1 * (iy + 1); + const c = ix + 1 + gridX1 * (iy + 1); + const d = ix + 1 + gridX1 * iy; + indices.push(a, b, d); + indices.push(b, c, d); } - return { indices: f, normals: m, uvs: p, vertices: d }; + } + return { indices, normals, uvs, vertices }; } } -class zt { - constructor(e = 0, t = 0, i = 0, r = 1) { - (this.x = e), (this.y = t), (this.z = i), (this.w = r); - } - set(e, t, i, r) { - (this.x = e), (this.y = t), (this.z = i), (this.w = r); + +/** + * A set of 4-dimensional coordinates used to represent rotation in 3-dimensional space. + * @alias Quaternion + * @constructor + * + * @param {Number} [x=0.0] The X component. + * @param {Number} [y=0.0] The Y component. + * @param {Number} [z=0.0] The Z component. + * @param {Number} [w=0.0] The W component. + * + * @see PackableForInterpolation + */ +class Quaternion { + constructor(x = 0, y = 0, z = 0, w = 1) { + this.x = x; + this.y = y; + this.z = z; + this.w = w; + } + set(x, y, z, w) { + this.x = x; + this.y = y; + this.z = z; + this.w = w; } normalize() { - const e = 1 / zt.magnitude(this), - t = this.x * e, - i = this.y * e, - r = this.z * e, - n = this.w * e; - return (this.x = t), (this.y = i), (this.z = r), (this.w = n), this; + const inverseMagnitude = 1.0 / Quaternion.magnitude(this); + const x = this.x * inverseMagnitude; + const y = this.y * inverseMagnitude; + const z = this.z * inverseMagnitude; + const w = this.w * inverseMagnitude; + this.x = x; + this.y = y; + this.z = z; + this.w = w; + return this; } invert() { - return (this.x *= -1), (this.y *= -1), (this.z *= -1), this; - } - dot(e) { - return this.x * e.x + this.y * e.y + this.z * e.z + this.w * e.w; + this.x *= -1; + this.y *= -1; + this.z *= -1; + return this; } - setFromUnitVectors(e, t) { - let i = Ue.dot(e, t) + 1; - return ( - i < Number.EPSILON - ? ((i = 0), - Math.abs(e.x) > Math.abs(e.z) - ? ((this.x = -e.y), (this.y = e.x), (this.z = 0), (this.w = i)) - : ((this.x = 0), (this.y = -e.z), (this.z = e.y), (this.w = i))) - : ((this.x = e.y * t.z - e.z * t.y), - (this.y = e.z * t.x - e.x * t.z), - (this.z = e.x * t.y - e.y * t.x), - (this.w = i)), - this.normalize() - ); + dot(v) { + return this.x * v.x + this.y * v.y + this.z * v.z + this.w * v.w; } - setFromRotationMatrix(e) { - const t = e, - i = t[0], - r = t[4], - n = t[8], - s = t[1], - a = t[5], - o = t[9], - c = t[2], - l = t[6], - h = t[10], - u = i + a + h; - if (u > 0) { - const e = 0.5 / Math.sqrt(u + 1); - (this.w = 0.25 / e), (this.x = (l - o) * e), (this.y = (n - c) * e), (this.z = (s - r) * e); - } else if (i > a && i > h) { - const e = 2 * Math.sqrt(1 + i - a - h); - (this.w = (l - o) / e), (this.x = 0.25 * e), (this.y = (r + s) / e), (this.z = (n + c) / e); - } else if (a > h) { - const e = 2 * Math.sqrt(1 + a - i - h); - (this.w = (n - c) / e), (this.x = (r + s) / e), (this.y = 0.25 * e), (this.z = (o + l) / e); + setFromUnitVectors(vFrom, vTo) { + // assumes direction vectors vFrom and vTo are normalized + let r = Vector3.dot(vFrom, vTo) + 1; + if (r < Number.EPSILON) { + // vFrom and vTo point in opposite directions + r = 0; + if (Math.abs(vFrom.x) > Math.abs(vFrom.z)) { + this.x = -vFrom.y; + this.y = vFrom.x; + this.z = 0; + this.w = r; + } else { + this.x = 0; + this.y = -vFrom.z; + this.z = vFrom.y; + this.w = r; + } + } else { + // crossVectors( vFrom, vTo ); // inlined to avoid cyclic dependency on Vector3 + this.x = vFrom.y * vTo.z - vFrom.z * vTo.y; + this.y = vFrom.z * vTo.x - vFrom.x * vTo.z; + this.z = vFrom.x * vTo.y - vFrom.y * vTo.x; + this.w = r; + } + return this.normalize(); + } + setFromRotationMatrix(matrix) { + const te = matrix, + m11 = te[0], + m12 = te[4], + m13 = te[8], + m21 = te[1], + m22 = te[5], + m23 = te[9], + m31 = te[2], + m32 = te[6], + m33 = te[10], + trace = m11 + m22 + m33; + if (trace > 0) { + const s = 0.5 / Math.sqrt(trace + 1.0); + this.w = 0.25 / s; + this.x = (m32 - m23) * s; + this.y = (m13 - m31) * s; + this.z = (m21 - m12) * s; + } else if (m11 > m22 && m11 > m33) { + const s = 2.0 * Math.sqrt(1.0 + m11 - m22 - m33); + this.w = (m32 - m23) / s; + this.x = 0.25 * s; + this.y = (m12 + m21) / s; + this.z = (m13 + m31) / s; + } else if (m22 > m33) { + const s = 2.0 * Math.sqrt(1.0 + m22 - m11 - m33); + this.w = (m13 - m31) / s; + this.x = (m12 + m21) / s; + this.y = 0.25 * s; + this.z = (m23 + m32) / s; } else { - const e = 2 * Math.sqrt(1 + h - i - a); - (this.w = (s - r) / e), (this.x = (n + c) / e), (this.y = (o + l) / e), (this.z = 0.25 * e); + const s = 2.0 * Math.sqrt(1.0 + m33 - m11 - m22); + this.w = (m21 - m12) / s; + this.x = (m13 + m31) / s; + this.y = (m23 + m32) / s; + this.z = 0.25 * s; } return this; } clone() { - return zt.clone(this, this); + return Quaternion.clone(this, this); } - equals(e) { - return zt.equals(this, e); + equals(right) { + return Quaternion.equals(this, right); } - equalsEpsilon(e, t = 0) { - return zt.equalsEpsilon(this, e, t); + equalsEpsilon(right, epsilon = 0) { + return Quaternion.equalsEpsilon(this, right, epsilon); } toArray() { - const { x: e, y: t, z: i, w: r } = this; - return [e, t, i, r]; - } - static fromAxisAngle(e, t) { - const i = t / 2, - r = Math.sin(i); - It = Ue.normalize(e, It); - const n = It.x * r, - s = It.y * r, - a = It.z * r, - o = Math.cos(i), - c = new zt(n, s, a, o); - return (c.x = n), (c.y = s), (c.z = a), (c.w = o), c; - } - static clone(e, t) { - if (pe(e)) return pe(t) ? ((t.x = e.x), (t.y = e.y), (t.z = e.z), (t.w = e.w), t) : new zt(e.x, e.y, e.z, e.w); - } - static conjugate(e, t) { - return (t.x = -e.x), (t.y = -e.y), (t.z = -e.z), (t.w = e.w), t; - } - static magnitudeSquared(e) { - return e.x * e.x + e.y * e.y + e.z * e.z + e.w * e.w; - } - static magnitude(e) { - return Math.sqrt(zt.magnitudeSquared(e)); - } - static normalize(e, t) { - const i = 1 / zt.magnitude(e), - r = e.x * i, - n = e.y * i, - s = e.z * i, - a = e.w * i; - return (t.x = r), (t.y = n), (t.z = s), (t.w = a), t; - } - static inverse(e, t) { - const i = zt.magnitudeSquared(e); - return (t = zt.conjugate(e, t)), zt.multiplyByScalar(t, 1 / i, t); - } - static add(e, t, i) { - return (i.x = e.x + t.x), (i.y = e.y + t.y), (i.z = e.z + t.z), (i.w = e.w + t.w), i; - } - static subtract(e, t, i) { - return (i.x = e.x - t.x), (i.y = e.y - t.y), (i.z = e.z - t.z), (i.w = e.w - t.w), i; - } - static negate(e, t) { - return (t.x = -e.x), (t.y = -e.y), (t.z = -e.z), (t.w = -e.w), t; - } - static dot(e, t) { - return e.x * t.x + e.y * t.y + e.z * t.z + e.w * t.w; - } - static multiply(e, t, i) { - const r = e.x, - n = e.y, - s = e.z, - a = e.w, - o = t.x, - c = t.y, - l = t.z, - h = t.w, - u = a * o + r * h + n * l - s * c, - f = a * c - r * l + n * h + s * o, - d = a * l + r * c - n * o + s * h, - m = a * h - r * o - n * c - s * l; - return (i.x = u), (i.y = f), (i.z = d), (i.w = m), i; - } - static multiplyByScalar(e, t, i) { - return (i.x = e.x * t), (i.y = e.y * t), (i.z = e.z * t), (i.w = e.w * t), i; - } - static divideByScalar(e, t, i) { - return (i.x = e.x / t), (i.y = e.y / t), (i.z = e.z / t), (i.w = e.w / t), i; - } - static computeAxis(e, t) { - const i = e.w; - if (Math.abs(i - 1) < ve.EPSILON6) return (t.x = t.y = t.z = 0), t; - const r = 1 / Math.sqrt(1 - i * i); - return (t.x = e.x * r), (t.y = e.y * r), (t.z = e.z * r), t; - } - static computeAngle(e) { - return Math.abs(e.w - 1) < ve.EPSILON6 ? 0 : 2 * Math.acos(e.w); - } - static lerp(e, t, i, r) { - return (Pt = zt.multiplyByScalar(t, i, Pt)), (r = zt.multiplyByScalar(e, 1 - i, r)), zt.add(Pt, r, r); - } - static slerp(e, t, i, r) { - let n = zt.dot(e, t), - s = t; - if ((n < 0 && ((n = -n), (s = Nt = zt.negate(t, Nt))), 1 - n < ve.EPSILON6)) return zt.lerp(e, s, i, r); - const a = Math.acos(n); + const { x, y, z, w } = this; + return [x, y, z, w]; + } + static fromAxisAngle(axis, angle) { + const halfAngle = angle / 2.0; + const s = Math.sin(halfAngle); + fromAxisAngleScratch = Vector3.normalize(axis, fromAxisAngleScratch); + const x = fromAxisAngleScratch.x * s; + const y = fromAxisAngleScratch.y * s; + const z = fromAxisAngleScratch.z * s; + const w = Math.cos(halfAngle); + // if (!defined(result)) { + // return + // } + const result = new Quaternion(x, y, z, w); + result.x = x; + result.y = y; + result.z = z; + result.w = w; + return result; + } + // static fromRotationMatrix(matrix: Matrix3, result: Quaternion): Quaternion { + // let root; + // let x; + // let y; + // let z; + // let w; + // const m00 = matrix[Matrix3.COLUMN0ROW0]; + // const m11 = matrix[Matrix3.COLUMN1ROW1]; + // const m22 = matrix[Matrix3.COLUMN2ROW2]; + // const trace = m00 + m11 + m22; + // if (trace > 0.0) { + // // |w| > 1/2, may as well choose w > 1/2 + // root = Math.sqrt(trace + 1.0); // 2w + // w = 0.5 * root; + // root = 0.5 / root; // 1/(4w) + // x = (matrix[Matrix3.COLUMN1ROW2] - matrix[Matrix3.COLUMN2ROW1]) * root; + // y = (matrix[Matrix3.COLUMN2ROW0] - matrix[Matrix3.COLUMN0ROW2]) * root; + // z = (matrix[Matrix3.COLUMN0ROW1] - matrix[Matrix3.COLUMN1ROW0]) * root; + // } else { + // // |w| <= 1/2 + // const next = fromRotationMatrixNext; + // let i = 0; + // if (m11 > m00) { + // i = 1; + // } + // if (m22 > m00 && m22 > m11) { + // i = 2; + // } + // const j = next[i]; + // const k = next[j]; + // root = Math.sqrt( + // matrix[Matrix3.getElementIndex(i, i)] - + // matrix[Matrix3.getElementIndex(j, j)] - + // matrix[Matrix3.getElementIndex(k, k)] + + // 1.0 + // ); + // const quat = fromRotationMatrixQuat; + // quat[i] = 0.5 * root; + // root = 0.5 / root; + // w = (matrix[Matrix3.getElementIndex(k, j)] - matrix[Matrix3.getElementIndex(j, k)]) * root; + // quat[j] = (matrix[Matrix3.getElementIndex(j, i)] + matrix[Matrix3.getElementIndex(i, j)]) * root; + // quat[k] = (matrix[Matrix3.getElementIndex(k, i)] + matrix[Matrix3.getElementIndex(i, k)]) * root; + // x = -quat[0]; + // y = -quat[1]; + // z = -quat[2]; + // } + // if (!defined(result)) { + // return new Quaternion(x, y, z, w); + // } + // result.x = x; + // result.y = y; + // result.z = z; + // result.w = w; + // return result; + // } + static clone(quaternion, result) { + if (!defined(quaternion)) { + return undefined; + } + if (!defined(result)) { + return new Quaternion(quaternion.x, quaternion.y, quaternion.z, quaternion.w); + } + result.x = quaternion.x; + result.y = quaternion.y; + result.z = quaternion.z; + result.w = quaternion.w; + return result; + } + static conjugate(quaternion, result) { + result.x = -quaternion.x; + result.y = -quaternion.y; + result.z = -quaternion.z; + result.w = quaternion.w; + return result; + } + static magnitudeSquared(quaternion) { return ( - (Bt = zt.multiplyByScalar(e, Math.sin((1 - i) * a), Bt)), - (Ot = zt.multiplyByScalar(s, Math.sin(i * a), Ot)), - (r = zt.add(Bt, Ot, r)), - zt.multiplyByScalar(r, 1 / Math.sin(a), r) + quaternion.x * quaternion.x + + quaternion.y * quaternion.y + + quaternion.z * quaternion.z + + quaternion.w * quaternion.w ); } - static squad(e, t, i, r, n, s) { - const a = zt.slerp(e, t, n, Vt), - o = zt.slerp(i, r, n, Ft); - return zt.slerp(a, o, 2 * n * (1 - n), s); - } - static equals(e, t) { - return e === t || (pe(e) && pe(t) && e.x === t.x && e.y === t.y && e.z === t.z && e.w === t.w); - } - static equalsEpsilon(e, t, i = 0) { + static magnitude(quaternion) { + return Math.sqrt(Quaternion.magnitudeSquared(quaternion)); + } + static normalize(quaternion, result) { + const inverseMagnitude = 1.0 / Quaternion.magnitude(quaternion); + const x = quaternion.x * inverseMagnitude; + const y = quaternion.y * inverseMagnitude; + const z = quaternion.z * inverseMagnitude; + const w = quaternion.w * inverseMagnitude; + result.x = x; + result.y = y; + result.z = z; + result.w = w; + return result; + } + static inverse(quaternion, result) { + const magnitudeSquared = Quaternion.magnitudeSquared(quaternion); + result = Quaternion.conjugate(quaternion, result); + return Quaternion.multiplyByScalar(result, 1.0 / magnitudeSquared, result); + } + static add(left, right, result) { + result.x = left.x + right.x; + result.y = left.y + right.y; + result.z = left.z + right.z; + result.w = left.w + right.w; + return result; + } + static subtract(left, right, result) { + result.x = left.x - right.x; + result.y = left.y - right.y; + result.z = left.z - right.z; + result.w = left.w - right.w; + return result; + } + static negate(quaternion, result) { + result.x = -quaternion.x; + result.y = -quaternion.y; + result.z = -quaternion.z; + result.w = -quaternion.w; + return result; + } + static dot(left, right) { + return left.x * right.x + left.y * right.y + left.z * right.z + left.w * right.w; + } + static multiply(left, right, result) { + const leftX = left.x; + const leftY = left.y; + const leftZ = left.z; + const leftW = left.w; + const rightX = right.x; + const rightY = right.y; + const rightZ = right.z; + const rightW = right.w; + const x = leftW * rightX + leftX * rightW + leftY * rightZ - leftZ * rightY; + const y = leftW * rightY - leftX * rightZ + leftY * rightW + leftZ * rightX; + const z = leftW * rightZ + leftX * rightY - leftY * rightX + leftZ * rightW; + const w = leftW * rightW - leftX * rightX - leftY * rightY - leftZ * rightZ; + result.x = x; + result.y = y; + result.z = z; + result.w = w; + return result; + } + static multiplyByScalar(quaternion, scalar, result) { + result.x = quaternion.x * scalar; + result.y = quaternion.y * scalar; + result.z = quaternion.z * scalar; + result.w = quaternion.w * scalar; + return result; + } + static divideByScalar(quaternion, scalar, result) { + result.x = quaternion.x / scalar; + result.y = quaternion.y / scalar; + result.z = quaternion.z / scalar; + result.w = quaternion.w / scalar; + return result; + } + static computeAxis(quaternion, result) { + const w = quaternion.w; + if (Math.abs(w - 1.0) < GMath.EPSILON6) { + result.x = result.y = result.z = 0; + return result; + } + const scalar = 1.0 / Math.sqrt(1.0 - w * w); + result.x = quaternion.x * scalar; + result.y = quaternion.y * scalar; + result.z = quaternion.z * scalar; + return result; + } + static computeAngle(quaternion) { + if (Math.abs(quaternion.w - 1.0) < GMath.EPSILON6) { + return 0.0; + } + return 2.0 * Math.acos(quaternion.w); + } + static lerp(start, end, t, result) { + lerpScratch = Quaternion.multiplyByScalar(end, t, lerpScratch); + result = Quaternion.multiplyByScalar(start, 1.0 - t, result); + return Quaternion.add(lerpScratch, result, result); + } + static slerp(start, end, t, result) { + let dot = Quaternion.dot(start, end); + // The angle between start must be acute. Since q and -q represent + // the same rotation, negate q to get the acute angle. + let r = end; + if (dot < 0.0) { + dot = -dot; + r = slerpEndNegated = Quaternion.negate(end, slerpEndNegated); + } + // dot > 0, as the dot product approaches 1, the angle between the + // quaternions vanishes. use linear interpolation. + if (1.0 - dot < GMath.EPSILON6) { + return Quaternion.lerp(start, r, t, result); + } + const theta = Math.acos(dot); + slerpScaledP = Quaternion.multiplyByScalar(start, Math.sin((1 - t) * theta), slerpScaledP); + slerpScaledR = Quaternion.multiplyByScalar(r, Math.sin(t * theta), slerpScaledR); + result = Quaternion.add(slerpScaledP, slerpScaledR, result); + return Quaternion.multiplyByScalar(result, 1.0 / Math.sin(theta), result); + } + static squad(q0, q1, s0, s1, t, result) { + const slerp0 = Quaternion.slerp(q0, q1, t, squadScratchQuaternion0); + const slerp1 = Quaternion.slerp(s0, s1, t, squadScratchQuaternion1); + return Quaternion.slerp(slerp0, slerp1, 2.0 * t * (1.0 - t), result); + } + static equals(left, right) { return ( - (i = ee(i, 0)), - e === t || - (pe(e) && - pe(t) && - Math.abs(e.x - t.x) <= i && - Math.abs(e.y - t.y) <= i && - Math.abs(e.z - t.z) <= i && - Math.abs(e.w - t.w) <= i) + left === right || + (defined(left) && + defined(right) && + left.x === right.x && + left.y === right.y && + left.z === right.z && + left.w === right.w) ); } - static exp(e, t) { - const i = Ue.magnitude(e); - let r = 0; + static equalsEpsilon(left, right, epsilon = 0) { + epsilon = defaultValue(epsilon, 0); return ( - 0 !== i && (r = Math.sin(i) / i), (t.x = e.x * r), (t.y = e.y * r), (t.z = e.z * r), (t.w = Math.cos(i)), t + left === right || + (defined(left) && + defined(right) && + Math.abs(left.x - right.x) <= epsilon && + Math.abs(left.y - right.y) <= epsilon && + Math.abs(left.z - right.z) <= epsilon && + Math.abs(left.w - right.w) <= epsilon) ); } + static exp(cartesian, result) { + const theta = Vector3.magnitude(cartesian); + let sinThetaOverTheta = 0.0; + if (theta !== 0.0) { + sinThetaOverTheta = Math.sin(theta) / theta; + } + result.x = cartesian.x * sinThetaOverTheta; + result.y = cartesian.y * sinThetaOverTheta; + result.z = cartesian.z * sinThetaOverTheta; + result.w = Math.cos(theta); + return result; + } } -(zt.ZERO = Object.freeze(new zt(0, 0, 0, 0))), (zt.IDENTITY = Object.freeze(new zt(0, 0, 0, 1))); -let It = new Ue(); +Quaternion.ZERO = Object.freeze(new Quaternion(0.0, 0.0, 0.0, 0.0)); +Quaternion.IDENTITY = Object.freeze(new Quaternion(0.0, 0.0, 0.0, 1.0)); +let fromAxisAngleScratch = new Vector3(); new Array(3); -let Pt = new zt(), - Nt = new zt(), - Bt = new zt(), - Ot = new zt(); -new Ue(), new Ue(); -const Vt = new zt(), - Ft = new zt(); -class $t { +let lerpScratch = new Quaternion(); +let slerpEndNegated = new Quaternion(); +let slerpScaledP = new Quaternion(); +let slerpScaledR = new Quaternion(); +new Vector3(); +new Vector3(); +const squadScratchQuaternion0 = new Quaternion(); +const squadScratchQuaternion1 = new Quaternion(); + +class RenderObject { constructor() { - (this._position = new Ue()), - (this._scale = new Ue(1, 1, 1)), - (this._quaternion = new zt()), - (this.modelMatrix = et.clone(et.IDENTITY, new et())), - (this._normalMatrix = et.clone(et.IDENTITY, new et())), - (this.up = new Ue(0, 1, 0)), - (this._target = new Ue(0, 0, 0)); + this._position = new Vector3(); + this._scale = new Vector3(1, 1, 1); + this._quaternion = new Quaternion(); + this.modelMatrix = Matrix4.clone(Matrix4.IDENTITY, new Matrix4()); + this._normalMatrix = Matrix4.clone(Matrix4.IDENTITY, new Matrix4()); + this.up = new Vector3(0, 1, 0); + this._target = new Vector3(0, 0, 0); } get normalMatrix() { return this._normalMatrix; @@ -4579,73 +6212,82 @@ class $t { return this._quaternion; } updateNormalMatrix() { - et.inverse(this.modelMatrix, this._normalMatrix), et.transpose(this._normalMatrix, this._normalMatrix); - } - updateMatrix(e) { - this.modelMatrix.compose(this.position, this.quaternion, this.scale), - e && et.multiply(e, this.modelMatrix, this.modelMatrix), - this.updateNormalMatrix(); - } - lookAt(e, t, i) { - this._target.set(e, t, i), - this.type == Z.Camera || this.type == Z.Light - ? jt.lookAt(this.position, this._target, this.up) - : jt.lookAt(this._target, this.position, this.up), - this.quaternion.setFromRotationMatrix(jt); - } - rotateOnAxis(e, t) { - const i = zt.fromAxisAngle(e, t); - zt.multiply(this.quaternion, i, this.quaternion); - } - rotateX(e) { - return this.rotateOnAxis(Gt, e); - } - rotateY(e) { - return this.rotateOnAxis(kt, e); - } - rotateZ(e) { - return this.rotateOnAxis(qt, e); - } -} -const Gt = new Ue(1, 0, 0), - kt = new Ue(0, 1, 0), - qt = new Ue(0, 0, 1), - jt = new et(); -class Ht extends $t { - constructor(e, t) { - super(), - (this.type = Z.Light), - (this._color = Ue.multiplyByScalar(e, t, new Ue())), - (this._intensity = t), - (this._position = new Ue(0, 1, 0)), - (this._target = new Ue()), - (this.positionDirty = !0), - (this.targetDirty = !0), - (this.colorDirty = !0), - (this.shadowDirty = !0), - (this.intensityDirty = !0), - (this._shadow = null); + Matrix4.inverse(this.modelMatrix, this._normalMatrix); + Matrix4.transpose(this._normalMatrix, this._normalMatrix); + } + updateMatrix(matrix) { + this.modelMatrix.compose(this.position, this.quaternion, this.scale); + if (matrix) Matrix4.multiply(matrix, this.modelMatrix, this.modelMatrix); + this.updateNormalMatrix(); + } + lookAt(x, y, z) { + this._target.set(x, y, z); + if (this.type == RenderObjectType.Camera || this.type == RenderObjectType.Light) { + _m1.lookAt(this.position, this._target, this.up); + } else { + _m1.lookAt(this._target, this.position, this.up); + } + this.quaternion.setFromRotationMatrix(_m1); + } + rotateOnAxis(axis, angle) { + const quat = Quaternion.fromAxisAngle(axis, angle); + Quaternion.multiply(this.quaternion, quat, this.quaternion); + } + rotateX(angle) { + return this.rotateOnAxis(_xAxis, angle); + } + rotateY(angle) { + return this.rotateOnAxis(_yAxis, angle); + } + rotateZ(angle) { + return this.rotateOnAxis(_zAxis, angle); + } +} +const _xAxis = new Vector3(1, 0, 0); +const _yAxis = new Vector3(0, 1, 0); +const _zAxis = new Vector3(0, 0, 1); +const _m1 = new Matrix4(); + +class Light extends RenderObject { + constructor(color, intensity) { + super(); + this.type = RenderObjectType.Light; + this._color = Vector3.multiplyByScalar(color, intensity, new Vector3()); + this._intensity = intensity; + this._position = new Vector3(0, 1, 0); + this._target = new Vector3(); + this.positionDirty = true; + this.targetDirty = true; + this.colorDirty = true; + this.shadowDirty = true; + this.intensityDirty = true; + this._shadow = null; } get position() { return this._position; } - set position(e) { - (this.positionDirty = !0), (this._position = e); + set position(value) { + this.positionDirty = true; + this._position = value; } get target() { return this._target; } - set target(e) { - (this.targetDirty = !0), (this._target = e); + set target(value) { + this.targetDirty = true; + this._target = value; } get color() { return this._color; } - set color(e) { - (this.colorDirty = !0), (this._color = e); + set color(value) { + this.colorDirty = true; + this._color = value; } - set intensity(e) { - (this.color = Ue.multiplyByScalar(this.color, e, new Ue())), (this.intensityDirty = !0), (this._intensity = e); + set intensity(value) { + this.color = Vector3.multiplyByScalar(this.color, value, new Vector3()); + this.intensityDirty = true; + this._intensity = value; } get intensity() { return this._intensity; @@ -4653,579 +6295,924 @@ class Ht extends $t { get shadow() { return this._shadow; } - set shadow(e) { - (this.shadowDirty = !0), (this._shadow = e); + set shadow(value) { + this.shadowDirty = true; + this._shadow = value; } } -const Xt = /^#([0-9a-f])([0-9a-f])([0-9a-f])([0-9a-f])?$/i, - Yt = /^#([0-9a-f]{2})([0-9a-f]{2})([0-9a-f]{2})([0-9a-f]{2})?$/i, - Wt = /^rgba?\(\s*([0-9.]+%?)\s*,\s*([0-9.]+%?)\s*,\s*([0-9.]+%?)(?:\s*,\s*([0-9.]+))?\s*\)$/i, - Zt = /^hsla?\(\s*([0-9.]+)\s*,\s*([0-9.]+%)\s*,\s*([0-9.]+%)(?:\s*,\s*([0-9.]+))?\s*\)$/i; -function Kt(e, t, i) { - return ( - i < 0 && (i += 1), - i > 1 && (i -= 1), - 6 * i < 1 ? e + 6 * (t - e) * i : 2 * i < 1 ? t : 3 * i < 2 ? e + (t - e) * (2 / 3 - i) * 6 : e - ); + +// #rgba +const rgbaMatcher = /^#([0-9a-f])([0-9a-f])([0-9a-f])([0-9a-f])?$/i; +// #rrggbbaa +const rrggbbaaMatcher = /^#([0-9a-f]{2})([0-9a-f]{2})([0-9a-f]{2})([0-9a-f]{2})?$/i; +// rgb(), rgba(), or rgb%() +const rgbParenthesesMatcher = /^rgba?\(\s*([0-9.]+%?)\s*,\s*([0-9.]+%?)\s*,\s*([0-9.]+%?)(?:\s*,\s*([0-9.]+))?\s*\)$/i; +// hsl() or hsla() +const hslParenthesesMatcher = /^hsla?\(\s*([0-9.]+)\s*,\s*([0-9.]+%)\s*,\s*([0-9.]+%)(?:\s*,\s*([0-9.]+))?\s*\)$/i; +function hue2rgb(m1, m2, h) { + if (h < 0) { + h += 1; + } + if (h > 1) { + h -= 1; + } + if (h * 6 < 1) { + return m1 + (m2 - m1) * 6 * h; + } + if (h * 2 < 1) { + return m2; + } + if (h * 3 < 2) { + return m1 + (m2 - m1) * (2 / 3 - h) * 6; + } + return m1; } -class Qt { - constructor(e = 1, t = 1, i = 1) { - (this.red = e), (this.green = t), (this.blue = i); - } - set(e) { - return "string" == typeof e && Qt.fromCssColorString(e, this), this; +class Color { + constructor(red = 1.0, green = 1.0, blue = 1.0) { + /** + * The red component. + * @type {Number} + * @default 1.0 + */ + this.red = red; + /** + * The green component. + * @type {Number} + * @default 1.0 + */ + this.green = green; + /** + * The blue component. + * @type {Number} + * @default 1.0 + */ + this.blue = blue; + } + set(value) { + if (typeof value === "string") { + Color.fromCssColorString(value, this); + } + return this; } toArray() { return [this.red, this.green, this.blue]; } - clone(e) { - return Qt.clone(this, e); + clone(result) { + return Color.clone(this, result); } - equals(e) { - return Qt.equals(this, e); + equals(other) { + return Color.equals(this, other); } toCssHexString() { - let e = Qt.floatToByte(this.red).toString(16); - e.length < 2 && (e = `0${e}`); - let t = Qt.floatToByte(this.green).toString(16); - t.length < 2 && (t = `0${t}`); - let i = Qt.floatToByte(this.blue).toString(16); - return i.length < 2 && (i = `0${i}`), `#${e}${t}${i}`; - } - toBytes(e) { - const t = Qt.floatToByte(this.red), - i = Qt.floatToByte(this.green), - r = Qt.floatToByte(this.blue); - return pe(e) ? ((e[0] = t), (e[1] = i), (e[2] = r), e) : [t, i, r]; - } - static fromBytes(e, t, i, r) { - return ( - (e = Qt.byteToFloat(ee(e, 255))), - (t = Qt.byteToFloat(ee(t, 255))), - (i = Qt.byteToFloat(ee(i, 255))), - pe(r) ? ((r.red = e), (r.green = t), (r.blue = i), r) : new Qt(e, t, i) - ); - } - static fromHsl(e, t, i, r) { - (e = ee(e, 0) % 1), (t = ee(t, 0)); - let n = (i = ee(i, 0)), - s = i, - a = i; - if (0 !== t) { - let r; - r = i < 0.5 ? i * (1 + t) : i + t - i * t; - const o = 2 * i - r; - (n = Kt(o, r, e + 1 / 3)), (s = Kt(o, r, e)), (a = Kt(o, r, e - 1 / 3)); - } - return pe(r) ? ((r.red = n), (r.green = s), (r.blue = a), r) : new Qt(n, s, a); - } - static fromRandom(e, t) { - let i = (e = ee(e, ee.EMPTY_OBJECT)).red; - if (!pe(i)) { - const t = ee(e.minimumRed, 0), - r = ee(e.maximumRed, 1); - i = t + ve.nextRandomNumber() * (r - t); - } - let r = e.green; - if (!pe(r)) { - const t = ee(e.minimumGreen, 0), - i = ee(e.maximumGreen, 1); - r = t + ve.nextRandomNumber() * (i - t); - } - let n = e.blue; - if (!pe(n)) { - const t = ee(e.minimumBlue, 0), - i = ee(e.maximumBlue, 1); - n = t + ve.nextRandomNumber() * (i - t); - } - return pe(t) ? ((t.red = i), (t.green = r), (t.blue = n), t) : new Qt(i, r, n); - } - static fromCssColorString(e, t = new Qt()) { - e = e.replace(/\s/g, ""); - const i = Qt[e.toUpperCase()]; - if (pe(i)) return Qt.clone(i, t), t; - let r = Xt.exec(e); - return null !== r - ? ((t.red = parseInt(r[1], 16) / 15), - (t.green = parseInt(r[2], 16) / 15), - (t.blue = parseInt(r[3], 16) / 15), - t) - : ((r = Yt.exec(e)), - null !== r - ? ((t.red = parseInt(r[1], 16) / 255), - (t.green = parseInt(r[2], 16) / 255), - (t.blue = parseInt(r[3], 16) / 255), - t) - : ((r = Wt.exec(e)), - null !== r - ? ((t.red = parseFloat(r[1]) / ("%" === r[1].substr(-1) ? 100 : 255)), - (t.green = parseFloat(r[2]) / ("%" === r[2].substr(-1) ? 100 : 255)), - (t.blue = parseFloat(r[3]) / ("%" === r[3].substr(-1) ? 100 : 255)), - t) - : ((r = Zt.exec(e)), - null !== r - ? Qt.fromHsl( - parseFloat(r[1]) / 360, - parseFloat(r[2]) / 100, - parseFloat(r[3]) / 100, - t - ) - : (t = void 0)))); - } - static byteToFloat(e) { - return e / 255; - } - static floatToByte(e) { - return 1 === e ? 255 : (256 * e) | 0; - } - static clone(e, t) { - if (pe(e)) - return pe(t) - ? ((t.red = e.red), (t.green = e.green), (t.blue = e.blue), t) - : new Qt(e.red, e.green, e.blue); - } - static equals(e, t) { - return e === t || (pe(e) && pe(t) && e.red === t.red && e.green === t.green && e.blue === t.blue); - } - static equalsArray(e, t, i) { - return e.red === t[i] && e.green === t[i + 1] && e.blue === t[i + 2]; - } -} -class Jt { - constructor(e = 0, t = 0, i = 0, r = 0) { - (this[0] = e), (this[1] = i), (this[2] = t), (this[3] = r); - } - static clone(e, t) { - if (pe(e)) - return pe(t) - ? ((t[0] = e[0]), (t[1] = e[1]), (t[2] = e[2]), (t[3] = e[3]), t) - : new Jt(e[0], e[2], e[1], e[3]); - } - static fromColumnMajorArray(e, t) { - return Jt.clone(e, t); - } - static fromRowMajorArray(e, t) { - return pe(t) ? ((t[0] = e[0]), (t[1] = e[2]), (t[2] = e[1]), (t[3] = e[3]), t) : new Jt(e[0], e[1], e[2], e[3]); - } - static fromScale(e, t) { - return pe(t) ? ((t[0] = e.x), (t[1] = 0), (t[2] = 0), (t[3] = e.y), t) : new Jt(e.x, 0, 0, e.y); - } - static fromRotation(e, t) { - const i = Math.cos(e), - r = Math.sin(e); - return pe(t) ? ((t[0] = i), (t[1] = r), (t[2] = -r), (t[3] = i), t) : new Jt(i, -r, r, i); - } - toArray() { - const e = []; - return Jt.toArray(this, e), e; - } - static toArray(e, t) { - return pe(t) ? ((t[0] = e[0]), (t[1] = e[1]), (t[2] = e[2]), (t[3] = e[3]), t) : [e[0], e[1], e[2], e[3]]; - } - static getElementIndex(e, t) { - return 2 * e + t; - } - static getColumn(e, t, i) { - const r = 2 * t, - n = e[r], - s = e[r + 1]; - return (i.x = n), (i.y = s), i; - } - static setColumn(e, t, i, r) { - const n = 2 * t; - return ((r = Jt.clone(e, r))[n] = i.x), (r[n + 1] = i.y), r; + let r = Color.floatToByte(this.red).toString(16); + if (r.length < 2) { + r = `0${r}`; + } + let g = Color.floatToByte(this.green).toString(16); + if (g.length < 2) { + g = `0${g}`; + } + let b = Color.floatToByte(this.blue).toString(16); + if (b.length < 2) { + b = `0${b}`; + } + return `#${r}${g}${b}`; + } + toBytes(result) { + const red = Color.floatToByte(this.red); + const green = Color.floatToByte(this.green); + const blue = Color.floatToByte(this.blue); + if (!defined(result)) { + return [red, green, blue]; + } + result[0] = red; + result[1] = green; + result[2] = blue; + return result; + } + static fromBytes(red, green, blue, result) { + red = Color.byteToFloat(defaultValue(red, 255.0)); + green = Color.byteToFloat(defaultValue(green, 255.0)); + blue = Color.byteToFloat(defaultValue(blue, 255.0)); + if (!defined(result)) { + return new Color(red, green, blue); + } + result.red = red; + result.green = green; + result.blue = blue; + return result; + } + static fromHsl(hue, saturation, lightness, result) { + hue = defaultValue(hue, 0.0) % 1.0; + saturation = defaultValue(saturation, 0.0); + lightness = defaultValue(lightness, 0.0); + let red = lightness; + let green = lightness; + let blue = lightness; + if (saturation !== 0) { + let m2; + if (lightness < 0.5) { + m2 = lightness * (1 + saturation); + } else { + m2 = lightness + saturation - lightness * saturation; + } + const m1 = 2.0 * lightness - m2; + red = hue2rgb(m1, m2, hue + 1 / 3); + green = hue2rgb(m1, m2, hue); + blue = hue2rgb(m1, m2, hue - 1 / 3); + } + if (!defined(result)) { + return new Color(red, green, blue); + } + result.red = red; + result.green = green; + result.blue = blue; + return result; + } + /** + * Creates a random color using the provided options. For reproducible random colors, you should + * call {@link GMath#setRandomNumberSeed} once at the beginning of your application. + * + * @param {Object} [options] Object with the following properties: + * @param {Number} [options.red] If specified, the red component to use instead of a randomized value. + * @param {Number} [options.minimumRed=0.0] The maximum red value to generate if none was specified. + * @param {Number} [options.maximumRed=1.0] The minimum red value to generate if none was specified. + * @param {Number} [options.green] If specified, the green component to use instead of a randomized value. + * @param {Number} [options.minimumGreen=0.0] The maximum green value to generate if none was specified. + * @param {Number} [options.maximumGreen=1.0] The minimum green value to generate if none was specified. + * @param {Number} [options.blue] If specified, the blue component to use instead of a randomized value. + * @param {Number} [options.minimumBlue=0.0] The maximum blue value to generate if none was specified. + * @param {Number} [options.maximumBlue=1.0] The minimum blue value to generate if none was specified. + * @param {Color} [result] The object to store the result in, if undefined a new instance will be created. + * @returns {Color} The modified result parameter or a new instance if result was undefined. + * + * @example + * //Create a completely random color + * const color = Color.fromRandom(); + * + * //Create a random shade of yellow. + * const color1 = Color.fromRandom({ + * red : 1.0, + * green : 1.0, + * }); + * + * //Create a random bright color. + * const color2 = Color.fromRandom({ + * minimumRed : 0.75, + * minimumGreen : 0.75, + * minimumBlue : 0.75, + * }); + */ + static fromRandom(options, result) { + options = defaultValue(options, defaultValue.EMPTY_OBJECT); + let red = options.red; + if (!defined(red)) { + const minimumRed = defaultValue(options.minimumRed, 0); + const maximumRed = defaultValue(options.maximumRed, 1.0); + red = minimumRed + GMath.nextRandomNumber() * (maximumRed - minimumRed); + } + let green = options.green; + if (!defined(green)) { + const minimumGreen = defaultValue(options.minimumGreen, 0); + const maximumGreen = defaultValue(options.maximumGreen, 1.0); + green = minimumGreen + GMath.nextRandomNumber() * (maximumGreen - minimumGreen); + } + let blue = options.blue; + if (!defined(blue)) { + const minimumBlue = defaultValue(options.minimumBlue, 0); + const maximumBlue = defaultValue(options.maximumBlue, 1.0); + blue = minimumBlue + GMath.nextRandomNumber() * (maximumBlue - minimumBlue); + } + if (!defined(result)) { + return new Color(red, green, blue); + } + result.red = red; + result.green = green; + result.blue = blue; + return result; + } + static fromCssColorString(color, result = new Color()) { + // Remove all whitespaces from the color string + color = color.replace(/\s/g, ""); + const namedColor = Color[color.toUpperCase()]; + if (defined(namedColor)) { + Color.clone(namedColor, result); + return result; + } + let matches = rgbaMatcher.exec(color); + if (matches !== null) { + result.red = parseInt(matches[1], 16) / 15; + result.green = parseInt(matches[2], 16) / 15.0; + result.blue = parseInt(matches[3], 16) / 15.0; + return result; + } + matches = rrggbbaaMatcher.exec(color); + if (matches !== null) { + result.red = parseInt(matches[1], 16) / 255.0; + result.green = parseInt(matches[2], 16) / 255.0; + result.blue = parseInt(matches[3], 16) / 255.0; + return result; + } + matches = rgbParenthesesMatcher.exec(color); + if (matches !== null) { + result.red = parseFloat(matches[1]) / ("%" === matches[1].substr(-1) ? 100.0 : 255.0); + result.green = parseFloat(matches[2]) / ("%" === matches[2].substr(-1) ? 100.0 : 255.0); + result.blue = parseFloat(matches[3]) / ("%" === matches[3].substr(-1) ? 100.0 : 255.0); + return result; + } + matches = hslParenthesesMatcher.exec(color); + if (matches !== null) { + return Color.fromHsl( + parseFloat(matches[1]) / 360.0, + parseFloat(matches[2]) / 100.0, + parseFloat(matches[3]) / 100.0, + result + ); + } + result = undefined; + return result; } - static getRow(e, t, i) { - const r = e[t], - n = e[t + 2]; - return (i.x = r), (i.y = n), i; + static byteToFloat(value) { + return value / 255.0; } - static setRow(e, t, i, r) { - return ((r = Jt.clone(e, r))[t] = i.x), (r[t + 2] = i.y), r; + static floatToByte(value) { + return value === 1.0 ? 255.0 : (value * 256.0) | 0; } - static setScale(e, t, i) { - const r = Jt.getScale(e, ei), - n = t.x / r.x, - s = t.y / r.y; - return (i[0] = e[0] * n), (i[1] = e[1] * n), (i[2] = e[2] * s), (i[3] = e[3] * s), i; + static clone(color, result) { + if (!defined(color)) { + return undefined; + } + if (!defined(result)) { + return new Color(color.red, color.green, color.blue); + } + result.red = color.red; + result.green = color.green; + result.blue = color.blue; + return result; } - static getScale(e, t) { + static equals(left, right) { return ( - (t.x = Se.magnitude(Se.fromElements(e[0], e[1], ri))), - (t.y = Se.magnitude(Se.fromElements(e[2], e[3], ri))), - t + left === right || // + (defined(left) && // + defined(right) && // + left.red === right.red && // + left.green === right.green && // + left.blue === right.blue) ); } - static getMaximumScale(e) { - return Jt.getScale(e, ti), Se.maximumComponent(ti); - } - static setRotation(e, t, i) { - const r = Jt.getScale(e, ii); - return (i[0] = t[0] * r.x), (i[1] = t[1] * r.x), (i[2] = t[2] * r.y), (i[3] = t[3] * r.y), i; - } - static getRotation(e, t) { - const i = Jt.getScale(e, ni); - return (t[0] = e[0] / i.x), (t[1] = e[1] / i.x), (t[2] = e[2] / i.y), (t[3] = e[3] / i.y), t; + /** + * @private + */ + static equalsArray(color, array, offset) { + return color.red === array[offset] && color.green === array[offset + 1] && color.blue === array[offset + 2]; } - static multiply(e, t, i) { - const r = e[0] * t[0] + e[2] * t[1], - n = e[0] * t[2] + e[2] * t[3], - s = e[1] * t[0] + e[3] * t[1], - a = e[1] * t[2] + e[3] * t[3]; - return (i[0] = r), (i[1] = s), (i[2] = n), (i[3] = a), i; - } - static add(e, t, i) { - return (i[0] = e[0] + t[0]), (i[1] = e[1] + t[1]), (i[2] = e[2] + t[2]), (i[3] = e[3] + t[3]), i; - } - static subtract(e, t, i) { - return (i[0] = e[0] - t[0]), (i[1] = e[1] - t[1]), (i[2] = e[2] - t[2]), (i[3] = e[3] - t[3]), i; - } - static multiplyByVector(e, t, i) { - const r = e[0] * t.x + e[2] * t.y, - n = e[1] * t.x + e[3] * t.y; - return (i.x = r), (i.y = n), i; - } - static multiplyByScalar(e, t, i) { - return (i[0] = e[0] * t), (i[1] = e[1] * t), (i[2] = e[2] * t), (i[3] = e[3] * t), i; - } - static multiplyByScale(e, t, i) { - return (i[0] = e[0] * t.x), (i[1] = e[1] * t.x), (i[2] = e[2] * t.y), (i[3] = e[3] * t.y), i; - } - static negate(e, t) { - return (t[0] = -e[0]), (t[1] = -e[1]), (t[2] = -e[2]), (t[3] = -e[3]), t; - } - static transpose(e, t) { - const i = e[0], - r = e[2], - n = e[1], - s = e[3]; - return (t[0] = i), (t[1] = r), (t[2] = n), (t[3] = s), t; +} + +/** + * A 2x2 matrix, indexable as a column-major order array. + * @param {Number} [column0Row0=0.0] The value for column 0, row 0. + * @param {Number} [column1Row0=0.0] The value for column 1, row 0. + * @param {Number} [column0Row1=0.0] The value for column 0, row 1. + * @param {Number} [column1Row1=0.0] The value for column 1, row 1. + */ +class Matrix2 { + constructor(column0Row0 = 0, column1Row0 = 0, column0Row1 = 0, column1Row1 = 0) { + this[0] = column0Row0; + this[1] = column0Row1; + this[2] = column1Row0; + this[3] = column1Row1; + } + static clone(matrix, result) { + if (!defined(matrix)) { + return undefined; + } + if (!defined(result)) { + return new Matrix2(matrix[0], matrix[2], matrix[1], matrix[3]); + } + result[0] = matrix[0]; + result[1] = matrix[1]; + result[2] = matrix[2]; + result[3] = matrix[3]; + return result; + } + static fromColumnMajorArray(values, result) { + return Matrix2.clone(values, result); + } + static fromRowMajorArray(values, result) { + if (!defined(result)) { + return new Matrix2(values[0], values[1], values[2], values[3]); + } + result[0] = values[0]; + result[1] = values[2]; + result[2] = values[1]; + result[3] = values[3]; + return result; + } + static fromScale(scale, result) { + if (!defined(result)) { + return new Matrix2(scale.x, 0.0, 0.0, scale.y); + } + result[0] = scale.x; + result[1] = 0.0; + result[2] = 0.0; + result[3] = scale.y; + return result; + } + static fromRotation(angle, result) { + const cosAngle = Math.cos(angle); + const sinAngle = Math.sin(angle); + if (!defined(result)) { + return new Matrix2(cosAngle, -sinAngle, sinAngle, cosAngle); + } + result[0] = cosAngle; + result[1] = sinAngle; + result[2] = -sinAngle; + result[3] = cosAngle; + return result; } - static abs(e, t) { - return (t[0] = Math.abs(e[0])), (t[1] = Math.abs(e[1])), (t[2] = Math.abs(e[2])), (t[3] = Math.abs(e[3])), t; + toArray() { + const result = []; + Matrix2.toArray(this, result); + return result; } - static equals(e, t) { - return e === t || (pe(e) && pe(t) && e[0] === t[0] && e[1] === t[1] && e[2] === t[2] && e[3] === t[3]); + static toArray(matrix, result) { + if (!defined(result)) { + return [matrix[0], matrix[1], matrix[2], matrix[3]]; + } + result[0] = matrix[0]; + result[1] = matrix[1]; + result[2] = matrix[2]; + result[3] = matrix[3]; + return result; + } + static getElementIndex(column, row) { + return column * 2 + row; + } + static getColumn(matrix, index, result) { + const startIndex = index * 2; + const x = matrix[startIndex]; + const y = matrix[startIndex + 1]; + result.x = x; + result.y = y; + return result; + } + static setColumn(matrix, index, cartesian, result) { + result = Matrix2.clone(matrix, result); + const startIndex = index * 2; + result[startIndex] = cartesian.x; + result[startIndex + 1] = cartesian.y; + return result; + } + static getRow(matrix, index, result) { + const x = matrix[index]; + const y = matrix[index + 2]; + result.x = x; + result.y = y; + return result; + } + static setRow(matrix, index, cartesian, result) { + result = Matrix2.clone(matrix, result); + result[index] = cartesian.x; + result[index + 2] = cartesian.y; + return result; + } + static setScale(matrix, scale, result) { + const existingScale = Matrix2.getScale(matrix, scaleScratch1); + const scaleRatioX = scale.x / existingScale.x; + const scaleRatioY = scale.y / existingScale.y; + result[0] = matrix[0] * scaleRatioX; + result[1] = matrix[1] * scaleRatioX; + result[2] = matrix[2] * scaleRatioY; + result[3] = matrix[3] * scaleRatioY; + return result; + } + static getScale(matrix, result) { + result.x = Vector2.magnitude(Vector2.fromElements(matrix[0], matrix[1], scratchColumn)); + result.y = Vector2.magnitude(Vector2.fromElements(matrix[2], matrix[3], scratchColumn)); + return result; + } + static getMaximumScale(matrix) { + Matrix2.getScale(matrix, scaleScratch3); + return Vector2.maximumComponent(scaleScratch3); + } + static setRotation(matrix, rotation, result) { + const scale = Matrix2.getScale(matrix, scaleScratch4); + result[0] = rotation[0] * scale.x; + result[1] = rotation[1] * scale.x; + result[2] = rotation[2] * scale.y; + result[3] = rotation[3] * scale.y; + return result; + } + static getRotation(matrix, result) { + const scale = Matrix2.getScale(matrix, scaleScratch5); + result[0] = matrix[0] / scale.x; + result[1] = matrix[1] / scale.x; + result[2] = matrix[2] / scale.y; + result[3] = matrix[3] / scale.y; + return result; + } + static multiply(left, right, result) { + const column0Row0 = left[0] * right[0] + left[2] * right[1]; + const column1Row0 = left[0] * right[2] + left[2] * right[3]; + const column0Row1 = left[1] * right[0] + left[3] * right[1]; + const column1Row1 = left[1] * right[2] + left[3] * right[3]; + result[0] = column0Row0; + result[1] = column0Row1; + result[2] = column1Row0; + result[3] = column1Row1; + return result; + } + static add(left, right, result) { + result[0] = left[0] + right[0]; + result[1] = left[1] + right[1]; + result[2] = left[2] + right[2]; + result[3] = left[3] + right[3]; + return result; + } + static subtract(left, right, result) { + result[0] = left[0] - right[0]; + result[1] = left[1] - right[1]; + result[2] = left[2] - right[2]; + result[3] = left[3] - right[3]; + return result; + } + static multiplyByVector(matrix, cartesian, result) { + const x = matrix[0] * cartesian.x + matrix[2] * cartesian.y; + const y = matrix[1] * cartesian.x + matrix[3] * cartesian.y; + result.x = x; + result.y = y; + return result; + } + static multiplyByScalar(matrix, scalar, result) { + result[0] = matrix[0] * scalar; + result[1] = matrix[1] * scalar; + result[2] = matrix[2] * scalar; + result[3] = matrix[3] * scalar; + return result; + } + static multiplyByScale(matrix, scale, result) { + result[0] = matrix[0] * scale.x; + result[1] = matrix[1] * scale.x; + result[2] = matrix[2] * scale.y; + result[3] = matrix[3] * scale.y; + return result; + } + static negate(matrix, result) { + result[0] = -matrix[0]; + result[1] = -matrix[1]; + result[2] = -matrix[2]; + result[3] = -matrix[3]; + return result; + } + static transpose(matrix, result) { + const column0Row0 = matrix[0]; + const column0Row1 = matrix[2]; + const column1Row0 = matrix[1]; + const column1Row1 = matrix[3]; + result[0] = column0Row0; + result[1] = column0Row1; + result[2] = column1Row0; + result[3] = column1Row1; + return result; + } + static abs(matrix, result) { + result[0] = Math.abs(matrix[0]); + result[1] = Math.abs(matrix[1]); + result[2] = Math.abs(matrix[2]); + result[3] = Math.abs(matrix[3]); + return result; + } + static equals(left, right) { + return ( + left === right || + (defined(left) && + defined(right) && + left[0] === right[0] && + left[1] === right[1] && + left[2] === right[2] && + left[3] === right[3]) + ); } - static equalsArray(e, t, i) { - return e[0] === t[i] && e[1] === t[i + 1] && e[2] === t[i + 2] && e[3] === t[i + 3]; + /** + * @private + */ + static equalsArray(matrix, array, offset) { + return ( + matrix[0] === array[offset] && + matrix[1] === array[offset + 1] && + matrix[2] === array[offset + 2] && + matrix[3] === array[offset + 3] + ); } - static equalsEpsilon(e, t, i = 0) { + static equalsEpsilon(left, right, epsilon = 0) { + epsilon = defaultValue(epsilon, 0); return ( - (i = ee(i, 0)), - e === t || - (pe(e) && - pe(t) && - Math.abs(e[0] - t[0]) <= i && - Math.abs(e[1] - t[1]) <= i && - Math.abs(e[2] - t[2]) <= i && - Math.abs(e[3] - t[3]) <= i) + left === right || + (defined(left) && + defined(right) && + Math.abs(left[0] - right[0]) <= epsilon && + Math.abs(left[1] - right[1]) <= epsilon && + Math.abs(left[2] - right[2]) <= epsilon && + Math.abs(left[3] - right[3]) <= epsilon) ); } - clone(e) { - return Jt.clone(this, e); + clone(result) { + return Matrix2.clone(this, result); } - equals(e) { - return Jt.equals(this, e); + equals(right) { + return Matrix2.equals(this, right); } - equalsEpsilon(e, t = 0) { - return Jt.equalsEpsilon(this, e, t); + equalsEpsilon(right, epsilon = 0) { + return Matrix2.equalsEpsilon(this, right, epsilon); } toString() { - return `(${this[0]}, ${this[2]})\n(${this[1]}, ${this[3]})`; + return `(${this[0]}, ${this[2]})\n` + `(${this[1]}, ${this[3]})`; } } -(Jt.IDENTITY = Object.freeze(new Jt(1, 0, 0, 1))), (Jt.ZERO = Object.freeze(new Jt(0, 0, 0, 0))); -const ei = new Se(); -new Se(); -const ti = new Se(), - ii = new Se(), - ri = new Se(), - ni = new Se(); -class si { - constructor(e, t, i) { - (this.name = e), (this.cb = t), (this.offset = ee(i, 0)), (this.type = "number"); +Matrix2.IDENTITY = Object.freeze(new Matrix2(1.0, 0.0, 0.0, 1.0)); +Matrix2.ZERO = Object.freeze(new Matrix2(0.0, 0.0, 0.0, 0.0)); +const scaleScratch1 = new Vector2(); +new Vector2(); +const scaleScratch3 = new Vector2(); +const scaleScratch4 = new Vector2(); +const scratchColumn = new Vector2(); +const scaleScratch5 = new Vector2(); + +class Uniform { + constructor(uniformName, cb, offset) { + this.name = uniformName; + this.cb = cb; + this.offset = defaultValue(offset, 0); + this.type = "number"; + } + setBuffer(array, offset = 0) { + for (let i = 0; i < array.length; i++) { + this.buffer[i + offset] = array[i]; + } } - setBuffer(e, t = 0) { - for (let i = 0; i < e.length; i++) this.buffer[i + t] = e[i]; + set() { + return undefined; } - set() {} getValue() { - let e; - switch (typeof this.cb) { + let result; + const cbType = typeof this.cb; + switch (cbType) { case "object": - e = this.cb[this.name] || this.cb; + result = this.cb[this.name] || this.cb; break; case "function": - e = this.cb(); + // @ts-ignore + result = this.cb(); break; case "number": - e = this.cb; + result = this.cb; break; default: throw new Error("type is error"); } - return e; - } - equals(e) { - if (this._value.length !== e.length) return !1; - for (let t = 0; t < e.length; t++) if (e[t] !== this._value[t]) return !1; - return !0; + return result; + } + // compare array + equals(v) { + if (this._value.length !== v.length) return false; + for (let i = 0; i < v.length; i++) { + if (v[i] !== this._value[i]) { + return false; + } + } + return true; } } -class ai extends si { - constructor(e, t, i, r, n) { - super(e, r, n), - (this.value = void 0), - (this._value = 0), - (this.byteSize = 4), - (this.buffer = new Uint32Array(t.buffer, i, 1)), - (this.type = "uint"); +class UniformUint extends Uniform { + constructor(uniformName, buffer, byteOffset, cb, offset) { + super(uniformName, cb, offset); + this.value = undefined; + this._value = 0; + this.byteSize = 4; + this.buffer = new Uint32Array(buffer.buffer, byteOffset, 1); + this.type = "uint"; } set() { - return ( - null != this.cb && (this.value = this.getValue()), - this.value !== this._value && ((this._value = this.value), (this.buffer[0] = this.value), !0) - ); + if (this.cb != undefined) this.value = this.getValue(); + if (this.value !== this._value) { + this._value = this.value; + this.buffer[0] = this.value; + return true; + } + return false; } } -ai.align = 4; -class oi extends si { - constructor(e, t, i, r, n) { - super(e, r, n), - (this.value = void 0), - (this._value = 0), - (this.byteSize = 4), - (this.buffer = new Float32Array(t.buffer, i, 1)), - (this.type = "vec1"); +UniformUint.align = 4; +class UniformFloat extends Uniform { + constructor(uniformName, buffer, byteOffset, cb, offset) { + super(uniformName, cb, offset); + this.value = undefined; + this._value = 0; + this.byteSize = 4; + this.buffer = new Float32Array(buffer.buffer, byteOffset, 1); + this.type = "vec1"; } set() { - return ( - null != this.cb && (this.value = this.getValue()), - this.value !== this._value && ((this._value = this.value), (this.buffer[0] = this.value), !0) - ); + if (this.cb != undefined) this.value = this.getValue(); + if (this.value !== this._value) { + this._value = this.value; + this.buffer[0] = this.value; + return true; + } + return false; } } -oi.align = 4; -class ci extends si { - constructor(e, t, i, r, n) { - super(e, r, n), - (this.value = void 0), - (this._value = new Se()), - (this.buffer = new Float32Array(t.buffer, i, 2)), - (this.byteSize = 8), - (this.type = "vec2"); +UniformFloat.align = 4; +class UniformFloatVec2 extends Uniform { + constructor(uniformName, buffer, byteOffset, cb, offset) { + super(uniformName, cb, offset); + this.value = undefined; + this._value = new Vector2(); + this.buffer = new Float32Array(buffer.buffer, byteOffset, 2); + this.byteSize = 8; + this.type = "vec2"; } set() { - null != this.cb && (this.value = this.getValue()); - const e = this.value; - return e instanceof Se - ? !Se.equals(e, this._value) && (Se.clone(e, this._value), this.setBuffer(this._value.toArray()), !0) - : !this.equals(e) && ((this._value = e), this.setBuffer(e), !0); - } -} -ci.align = 8; -class li extends si { - constructor(e, t, i, r, n) { - super(e, r, n), - (this.value = void 0), - (this._value = new Ue()), - (this.buffer = new Float32Array(t.buffer, i, 3)), - (this.byteSize = 12), - (this.type = "vec3"); + if (this.cb != undefined) this.value = this.getValue(); + const v = this.value; + if (v instanceof Vector2) { + if (Vector2.equals(v, this._value)) return false; + Vector2.clone(v, this._value); + this.setBuffer(this._value.toArray()); + return true; + } else { + if (this.equals(v)) return false; + this._value = v; + this.setBuffer(v); + return true; + } + } +} +UniformFloatVec2.align = 8; +class UniformFloatVec3 extends Uniform { + constructor(uniformName, buffer, byteOffset, cb, offset) { + super(uniformName, cb, offset); + this.value = undefined; + this._value = new Vector3(); + this.buffer = new Float32Array(buffer.buffer, byteOffset, 3); + this.byteSize = 12; + this.type = "vec3"; } set() { - null != this.cb && (this.value = this.getValue()); - const e = this.value; - return e instanceof Ue - ? !Ue.equals(e, this._value) && (Ue.clone(e, this._value), this.setBuffer(this._value.toArray()), !0) - : !this.equals(e) && ((this._value = e), this.setBuffer(e), !0); - } -} -li.align = 16; -class hi extends si { - constructor(e, t, i, r, n) { - super(e, r, n), - (this.value = void 0), - (this._value = new We()), - (this.buffer = new Float32Array(t.buffer, i, 4)), - (this.byteSize = 16), - (this.type = "vec4"); + if (this.cb != undefined) this.value = this.getValue(); + const v = this.value; + if (v instanceof Vector3) { + if (Vector3.equals(v, this._value)) return false; + Vector3.clone(v, this._value); + this.setBuffer(this._value.toArray()); + return true; + } else { + if (this.equals(v)) return false; + this._value = v; + this.setBuffer(v); + return true; + } + } +} +UniformFloatVec3.align = 16; +class UniformFloatVec4 extends Uniform { + constructor(uniformName, buffer, byteOffset, cb, offset) { + super(uniformName, cb, offset); + this.value = undefined; + this._value = new Vector4(); + this.buffer = new Float32Array(buffer.buffer, byteOffset, 4); + this.byteSize = 16; + this.type = "vec4"; } set() { - null != this.cb && (this.value = this.getValue()); - const e = this.value; - return e instanceof We - ? !We.equals(e, this._value) && (We.clone(e, this._value), this.setBuffer(this._value.toArray()), !0) - : !this.equals(e) && ((this._value = e), this.setBuffer(e), !0); - } -} -hi.align = 16; -class ui extends si { - constructor(e, t, i, r, n) { - super(e, r, n), - (this.value = void 0), - (this._value = new Qt()), - (this.buffer = new Float32Array(t.buffer, i, 3)), - (this.byteSize = 12), - (this.type = "vec3"); + if (this.cb != undefined) this.value = this.getValue(); + const v = this.value; + if (v instanceof Vector4) { + if (Vector4.equals(v, this._value)) return false; + Vector4.clone(v, this._value); + this.setBuffer(this._value.toArray()); + return true; + } else { + if (this.equals(v)) return false; + this._value = v; + this.setBuffer(v); + return true; + } + } +} +UniformFloatVec4.align = 16; +class UniformColor extends Uniform { + constructor(uniformName, buffer, byteOffset, cb, offset) { + super(uniformName, cb, offset); + this.value = undefined; + this._value = new Color(); + this.buffer = new Float32Array(buffer.buffer, byteOffset, 3); + this.byteSize = 12; + this.type = "vec3"; } set() { - null != this.cb && (this.value = this.getValue()); - const e = this.value; - return e instanceof Qt - ? !Qt.equals(e, this._value) && (Qt.clone(e, this._value), this.setBuffer(this._value.toArray()), !0) - : !this.equals(e) && ((this._value = e), this.setBuffer(e), !0); - } -} -ui.align = 16; -class fi extends si { - constructor(e, t, i, r, n) { - super(e, r, n), - (this.value = void 0), - (this._value = new Jt()), - (this.buffer = new Float32Array(t.buffer, i, 4)), - (this.byteSize = 16), - (this.type = "mat2"); + if (this.cb != undefined) this.value = this.getValue(); + const v = this.value; + if (v instanceof Color) { + if (Color.equals(v, this._value)) return false; + Color.clone(v, this._value); + this.setBuffer(this._value.toArray()); + return true; + } else { + if (this.equals(v)) return false; + this._value = v; + this.setBuffer(v); + return true; + } + } +} +UniformColor.align = 16; +class UniformMat2 extends Uniform { + constructor(uniformName, buffer, byteOffset, cb, offset) { + super(uniformName, cb, offset); + this.value = undefined; + this._value = new Matrix2(); + this.buffer = new Float32Array(buffer.buffer, byteOffset, 4); + this.byteSize = 16; + this.type = "mat2"; } set() { - null != this.cb && (this.value = this.getValue()); - const e = this.value; - return e instanceof Jt - ? !Jt.equals(e, this._value) && (Jt.clone(e, this._value), this.setBuffer(this._value.toArray()), !0) - : !this.equals(e) && ((this._value = e), this.setBuffer(e), !0); - } -} -fi.align = 8; -class di extends si { - constructor(e, t, i, r, n) { - super(e, r, n), - (this.value = void 0), - (this._value = new Ge()), - (this.buffer = new Float32Array(t.buffer, i, 9)), - (this.byteSize = 48), - (this.type = "mat3"); + if (this.cb != undefined) this.value = this.getValue(); + const v = this.value; + if (v instanceof Matrix2) { + if (Matrix2.equals(v, this._value)) return false; + Matrix2.clone(v, this._value); + this.setBuffer(this._value.toArray()); + return true; + } else { + if (this.equals(v)) return false; + this._value = v; + this.setBuffer(v); + return true; + } + } +} +UniformMat2.align = 8; +class UniformMat3 extends Uniform { + constructor(uniformName, buffer, byteOffset, cb, offset) { + super(uniformName, cb, offset); + this.value = undefined; + this._value = new Matrix3(); + this.buffer = new Float32Array(buffer.buffer, byteOffset, 9); + this.byteSize = 48; + this.type = "mat3"; } set() { - null != this.cb && (this.value = this.getValue()); - const e = this.value; - return e instanceof Ge - ? !Ge.equals(e, this._value) && (Ge.clone(e, this._value), this.setBuffer(this._value.toArray()), !0) - : !this.equals(e) && ((this._value = e), this.setBuffer(e), !0); - } -} -di.align = 16; -class mi extends si { - constructor(e, t, i, r, n) { - super(e, r, n), - (this.value = void 0), - (this._value = new et()), - (this.buffer = new Float32Array(t.buffer, i, 16)), - (this.byteSize = 64), - (this.type = "mat4"); + if (this.cb != undefined) this.value = this.getValue(); + const v = this.value; + if (v instanceof Matrix3) { + if (Matrix3.equals(v, this._value)) return false; + Matrix3.clone(v, this._value); + this.setBuffer(this._value.toArray()); + return true; + } else { + if (this.equals(v)) return false; + this._value = v; + this.setBuffer(v); + return true; + } + } +} +UniformMat3.align = 16; +class UniformMat4 extends Uniform { + constructor(uniformName, buffer, byteOffset, cb, offset) { + super(uniformName, cb, offset); + this.value = undefined; + this._value = new Matrix4(); + this.buffer = new Float32Array(buffer.buffer, byteOffset, 16); + this.byteSize = 64; + this.type = "mat4"; } set() { - null != this.cb && (this.value = this.getValue()); - const e = this.value; - return e instanceof et - ? !et.equals(e, this._value) && (et.clone(e, this._value), this.setBuffer(this._value.toArray()), !0) - : ((this._value = e), this.setBuffer(e), !0); + if (this.cb != undefined) this.value = this.getValue(); + const v = this.value; + if (v instanceof Matrix4) { + if (Matrix4.equals(v, this._value)) return false; + Matrix4.clone(v, this._value); + this.setBuffer(this._value.toArray()); + return true; + } else { + // if(this.equals(v)) return false; + this._value = v; + this.setBuffer(v); + return true; + } } } -mi.align = 16; -class pi extends si { - constructor(e, t, i, r, n) { - super(e, r, 0), - (this.byteSize = 64 * n), - (this.buffer = new Float32Array(t.buffer, i, this.byteSize / 4)), - (this.type = "mat4-array"); +UniformMat4.align = 16; +class UniformMatrix4Array extends Uniform { + constructor(uniformName, buffer, byteOffset, cb, count) { + super(uniformName, cb, 0); + this.byteSize = count * 64; + this.buffer = new Float32Array(buffer.buffer, byteOffset, this.byteSize / 4); + this.type = "mat4-array"; } set() { - if (((this.value = this.getValue()), !this.value)) return !1; - for (let e = 0; e < this.value.length; e++) this.setBuffer(this.value[e].toArray(), 16 * e); - return !0; + this.value = this.getValue(); + if (!this.value) return false; + for (let i = 0; i < this.value.length; i++) { + this.setBuffer(this.value[i].toArray(), i * 16); + } + return true; } } -pi.align = 16; -class gi extends si { - constructor(e, t, i, r, n) { - super(e, r, 0), - (this.buffer = new Float32Array(t.buffer, i, n)), - (this.byteSize = 4 * n), - (this.type = "float-array"); +UniformMatrix4Array.align = 16; +class UniformFloatArray extends Uniform { + // cb: Function; + constructor(uniformName, buffer, byteOffset, cb, count) { + super(uniformName, cb, 0); + this.buffer = new Float32Array(buffer.buffer, byteOffset, count); + this.byteSize = 4 * count; + this.type = "float-array"; } set() { this.value = this.getValue(); - for (let e = 0; e < this.value.length; e++) this.buffer[e] = this.value[e]; - return !0; + for (let i = 0; i < this.value.length; i++) { + this.buffer[i] = this.value[i]; + } + return true; } } -gi.align = 4; -class xi extends si { - constructor(e, t, i, r, n) { - super(e, r, 0), - (this.byteSize = 8 * n), - (this.buffer = new Float32Array(t.buffer, i, this.byteSize / 4)), - (this.type = "vec2-array"); +UniformFloatArray.align = 4; +class UniformVec2Array extends Uniform { + constructor(uniformName, buffer, byteOffset, cb, count) { + super(uniformName, cb, 0); + this.byteSize = count * 8; + this.buffer = new Float32Array(buffer.buffer, byteOffset, this.byteSize / 4); + this.type = "vec2-array"; } set() { + // this.value = this.cb(); this.value = this.getValue(); - let e = 0; - for (let t = 0; t < this.value.length; t++) - (this.buffer[e] = this.value[t].x), (this.buffer[e + 1] = this.value[t].y), (e += 2); - return !0; + let j = 0; + for (let i = 0; i < this.value.length; i++) { + this.buffer[j] = this.value[i].x; + this.buffer[j + 1] = this.value[i].y; + j += 2; + } + return true; } } -xi.align = 8; -class vi extends si { - constructor(e, t, i, r, n) { - super(e, r, 0), - (this.byteSize = 16 * n), - (this.buffer = new Float32Array(t.buffer, i, this.byteSize / 4)), - (this.type = "vec3-array"); +UniformVec2Array.align = 8; +class UniformVec3Array extends Uniform { + // cb: Function; + constructor(uniformName, buffer, byteOffset, cb, count) { + super(uniformName, cb, 0); + this.byteSize = count * 16; + this.buffer = new Float32Array(buffer.buffer, byteOffset, this.byteSize / 4); + this.type = "vec3-array"; } set() { + // this.value = this.cb(); this.value = this.getValue(); - let e = 0; - for (let t = 0; t < this.value.length; t++) - (this.buffer[e] = this.value[t].x), - (this.buffer[e + 1] = this.value[t].y), - (this.buffer[e + 2] = this.value[t].z), - (this.buffer[e + 3] = 0), - (e += 4); - return !0; - } -} -vi.align = 16; -class yi extends si { - constructor(e, t, i, r, n) { - super(e, r, 0), - (this.byteSize = 16 * n), - (this.buffer = new Float32Array(t.buffer, i, this.byteSize / 4)), - (this.type = "vec4-array"); + let j = 0; + for (let i = 0; i < this.value.length; i++) { + this.buffer[j] = this.value[i].x; + this.buffer[j + 1] = this.value[i].y; + this.buffer[j + 2] = this.value[i].z; + this.buffer[j + 3] = 0; + j += 4; + } + return true; + } +} +UniformVec3Array.align = 16; +class UniformVec4Array extends Uniform { + // cb: Function; + constructor(uniformName, buffer, byteOffset, cb, count) { + super(uniformName, cb, 0); + this.byteSize = count * 16; + this.buffer = new Float32Array(buffer.buffer, byteOffset, this.byteSize / 4); + this.type = "vec4-array"; } set() { this.value = this.getValue(); - let e = 0; - for (let t = 0; t < this.value.length; t++) - (this.buffer[e] = this.value[t].x), - (this.buffer[e + 1] = this.value[t].y), - (this.buffer[e + 2] = this.value[t].z), - (this.buffer[e + 3] = this.value[t].w), - (e += 4); - return !0; - } -} -yi.align = 16; -class Si extends si { - constructor(e, t, i, r, n, s) { - super(e, void 0, 0), - (this.binding = t), - (this.visibility = ee(n, d.Vertex | d.Fragment)), - (this.textureView = s), - (this.type = r ?? "texture"), - (this.isTexture = !0), - (this._texture = i); + let j = 0; + for (let i = 0; i < this.value.length; i++) { + this.buffer[j] = this.value[i].x; + this.buffer[j + 1] = this.value[i].y; + this.buffer[j + 2] = this.value[i].z; + this.buffer[j + 3] = this.value[i].w; + j += 4; + } + return true; + } +} +UniformVec4Array.align = 16; +class UniformTexture extends Uniform { + constructor(uniformName, binding, texture, type, visibility, textureView) { + super(uniformName, undefined, 0); + this.binding = binding; + this.visibility = defaultValue(visibility, ShaderStage.Vertex | ShaderStage.Fragment); + this.textureView = textureView; + this.type = type ?? "texture"; + this.isTexture = true; + this._texture = texture; } get layoutType() { return this.texture?.layoutType || "not yet bind"; @@ -5233,1610 +7220,1929 @@ class Si extends si { get storageTextureLayoutType() { return this.texture?.storageTextureLayoutType || "not yet bind"; } - bind(e) { - this._texture && - ((this.texture = this._texture instanceof Function ? this._texture() : this._texture), - this.texture.update(e)); + bind(device) { + if (!this._texture) return; + this.texture = this._texture instanceof Function ? this._texture() : this._texture; + this.texture.update(device); } } -class bi extends si { - constructor(e, t, i, r) { - super(e, void 0, 0), - (this.visibility = ee(r, d.Vertex | d.Fragment)), - (this.name = e), - (this.binding = t), - (this.type = "sampler"), - (this.isSampler = !0), - (this._sampler = i); +class UniformSampler extends Uniform { + constructor(uniformName, binding, sampler, visibility) { + super(uniformName, undefined, 0); + this.visibility = defaultValue(visibility, ShaderStage.Vertex | ShaderStage.Fragment); + this.name = uniformName; + this.binding = binding; + this.type = "sampler"; + this.isSampler = true; + this._sampler = sampler; } get layoutType() { return this.sampler?.layoutType || "not yet bind"; } - bind(e) { - (this.sampler = this._sampler instanceof Function ? this._sampler() : this._sampler), this.sampler.update(e); + bind(device) { + this.sampler = this._sampler instanceof Function ? this._sampler() : this._sampler; + this.sampler.update(device); } } -class wi extends si { - constructor(e, t, i, r, n) { - super(e, r, n), - (this.cb = r), - (this.type = "struct-array"), - (this.dirty = !1), - (this.byteOffset = i), - (this.sourceBuffer = t); +class UniformStructArray extends Uniform { + constructor(uniformName, buffer, byteOffset, cb, offset) { + super(uniformName, cb, offset); + this.cb = cb; + this.type = "struct-array"; + this.dirty = false; + this.byteOffset = byteOffset; + this.sourceBuffer = buffer; } set() { - return ( - (this.structArray = this.getValue()), - (this.byteSize = this.getStructSize()), - (this.buffer = new Float32Array(this.sourceBuffer.buffer, this.byteOffset, this.byteSize / 4)), - this.setSubData(), - !0 - ); + // + this.structArray = this.getValue(); + this.byteSize = this.getStructSize(); + this.buffer = new Float32Array(this.sourceBuffer.buffer, this.byteOffset, this.byteSize / 4); + this.setSubData(); + return true; } setSubData() { - this.structArray.forEach((e) => { - Object.keys(e).forEach((t) => { - const i = Array.isArray(e[t]?.value) ? e[t]?.value : e[t]?.value.toArray(); - Ci(this.buffer, i, e[t].offset); + this.structArray.forEach((struct) => { + const keys = Object.keys(struct); + keys.forEach((key) => { + const data = Array.isArray(struct[key]?.value) ? struct[key]?.value : (struct[key]?.value).toArray(); + setDataToTypeArray(this.buffer, data, struct[key].offset); }); }); } getStructSize() { - let e = 0; - return ( - this.structArray.forEach((t) => { - Object.keys(t).forEach((i) => { - (e += Ri.checkUniformOffset(e, wi.aligns[t[i].type])), - (t[i].offset = e), - (this.byteOffset += wi.byteSizes[t[i].type]); - }); - }), - e - ); + let byteOffset = 0; + this.structArray.forEach((struct) => { + const keys = Object.keys(struct); + keys.forEach((key) => { + byteOffset += UniformBuffer.checkUniformOffset(byteOffset, UniformStructArray.aligns[struct[key].type]); + struct[key].offset = byteOffset; + this.byteOffset += UniformStructArray.byteSizes[struct[key].type]; + }); + }); + return byteOffset; } } -(wi.align = 16), - (wi.aligns = { - [Q.UniformUint]: 4, - [Q.Float]: 4, - [Q.FloatVec2]: 8, - [Q.FloatVec3]: 16, - [Q.FloatVec4]: 16, - [Q.Mat2]: 8, - [Q.Mat3]: 16, - [Q.Mat4]: 16, - [Q.Color]: 16 - }), - (wi.byteSizes = { - [Q.UniformUint]: 4, - [Q.Float]: 4, - [Q.FloatVec2]: 8, - [Q.FloatVec3]: 12, - [Q.FloatVec4]: 16, - [Q.Mat2]: 16, - [Q.Mat3]: 48, - [Q.Mat4]: 64, - [Q.Color]: 12 - }); -class Ti extends si { - constructor(e, t, i, r, n) { - super(e, r, 0), - (this.cb = r), - (this.byteSize = 64 * n), - (this.buffer = new Float32Array(t.buffer, i, this.byteSize / 4)), - (this.type = "spotsLight"), - (this.dirty = !1); +UniformStructArray.align = 16; +UniformStructArray.aligns = { + [UniformEnum.UniformUint]: 4, + [UniformEnum.Float]: 4, + [UniformEnum.FloatVec2]: 8, + [UniformEnum.FloatVec3]: 16, + [UniformEnum.FloatVec4]: 16, + [UniformEnum.Mat2]: 8, + [UniformEnum.Mat3]: 16, + [UniformEnum.Mat4]: 16, + [UniformEnum.Color]: 16 +}; +UniformStructArray.byteSizes = { + [UniformEnum.UniformUint]: 4, + [UniformEnum.Float]: 4, + [UniformEnum.FloatVec2]: 8, + [UniformEnum.FloatVec3]: 12, + [UniformEnum.FloatVec4]: 16, + [UniformEnum.Mat2]: 16, + [UniformEnum.Mat3]: 48, + [UniformEnum.Mat4]: 64, + [UniformEnum.Color]: 12 +}; +class UniformSpotLights extends Uniform { + // cb: Function; + constructor(uniformName, buffer, byteOffset, cb, count) { + super(uniformName, cb, 0); + this.cb = cb; + this.byteSize = count * 64; + this.buffer = new Float32Array(buffer.buffer, byteOffset, this.byteSize / 4); + this.type = "spotsLight"; + this.dirty = false; } set() { - return ( - (this.lights = this.getValue()), - this.lights.forEach((e, t) => { - this.setSubData(e, t); - }), - this.dirty - ); + this.lights = this.getValue(); + this.lights.forEach((spotLight, index) => { + this.setSubData(spotLight, index); + }); + return this.dirty; + } + setSubData(spotLight, index) { + const offset = index * 16; + if (spotLight.positionDirty) { + this.dirty = setDataToTypeArray(this.buffer, spotLight.position.toArray(), offset + 0); // byteOffset=0; + } + if (spotLight.distanceDirty) { + this.dirty = setDataToTypeArray(this.buffer, spotLight.distance, offset + 3); // byteOffset=12; + } + if (spotLight.dirtectDirty) { + this.dirty = setDataToTypeArray(this.buffer, spotLight.directional.toArray(), offset + 4); // byteOffset=16; + } + if (spotLight.coneCosDirty) { + this.dirty = setDataToTypeArray(this.buffer, spotLight.coneCos, offset + 7); // byteOffset=28; + } + if (spotLight.colorDirty) { + this.dirty = setDataToTypeArray(this.buffer, spotLight.color.toArray(), offset + 8); // byteOffset=32; + } + if (spotLight.penumbraCosDirty) { + this.dirty = setDataToTypeArray(this.buffer, spotLight.penumbraCos, offset + 11); // byteOffset=44; + } + if (spotLight.decayDirty) { + this.dirty = setDataToTypeArray(this.buffer, spotLight.decay, offset + 12); // byteOffset=48; + } + spotLight.positionDirty = false; + spotLight.distanceDirty = false; + spotLight.dirtectDirty = false; + spotLight.coneCosDirty = false; + spotLight.colorDirty = false; + spotLight.penumbraCosDirty = false; + spotLight.decayDirty = false; } - setSubData(e, t) { - const i = 16 * t; - e.positionDirty && (this.dirty = Ci(this.buffer, e.position.toArray(), i + 0)), - e.distanceDirty && (this.dirty = Ci(this.buffer, e.distance, i + 3)), - e.dirtectDirty && (this.dirty = Ci(this.buffer, e.directional.toArray(), i + 4)), - e.coneCosDirty && (this.dirty = Ci(this.buffer, e.coneCos, i + 7)), - e.colorDirty && (this.dirty = Ci(this.buffer, e.color.toArray(), i + 8)), - e.penumbraCosDirty && (this.dirty = Ci(this.buffer, e.penumbraCos, i + 11)), - e.decayDirty && (this.dirty = Ci(this.buffer, e.decay, i + 12)), - (e.positionDirty = !1), - (e.distanceDirty = !1), - (e.dirtectDirty = !1), - (e.coneCosDirty = !1), - (e.colorDirty = !1), - (e.penumbraCosDirty = !1), - (e.decayDirty = !1); - } -} -Ti.align = 16; -class Ei extends si { - constructor(e, t, i, r, n) { - super(e, r, 0); - const s = Float32Array.BYTES_PER_ELEMENT; - (this._subDataSize = Ei.uniformSize), - (this.byteSize = n * this._subDataSize * s), - (this.buffer = new Float32Array(t.buffer, i, this.byteSize / 4)), - (this.type = "spotLightShadows"), - (this._nearValue = null), - (this._farValue = null); +} +UniformSpotLights.align = 16; +class UniformSpotLightShadows extends Uniform { + constructor(uniformName, buffer, byteOffset, cb, count) { + super(uniformName, cb, 0); + const bytesPerElement = Float32Array.BYTES_PER_ELEMENT; + this._subDataSize = UniformSpotLightShadows.uniformSize; + this.byteSize = count * this._subDataSize * bytesPerElement; + this.buffer = new Float32Array(buffer.buffer, byteOffset, this.byteSize / 4); + this.type = "spotLightShadows"; + this._nearValue = null; + this._farValue = null; } set() { - return ( - (this.lights = this.getValue()), - this.lights.forEach((e, t) => { - this.setSubData(e, t); - }), - this.dirty - ); + this.lights = this.getValue(); + this.lights.forEach((spotLight, index) => { + this.setSubData(spotLight, index); + }); + return this.dirty; } - setSubData(e, t) { - const i = t * this._subDataSize; - e.shadow.vpMatrixDirty && - ((e.shadow.vpMatrixDirty = !1), (this.dirty = Ci(this.buffer, e.shadow.camera.vpMatrix.toArray(), i + 0))); - const r = e.shadow.camera.near; - r != this._nearValue && ((this._nearValue = r), (this.dirty = Ci(this.buffer, this._nearValue, i + 16))); - const n = e.shadow.camera.far; - n != this._farValue && ((this._farValue = n), (this.dirty = Ci(this.buffer, this._farValue, i + 17))); + setSubData(spotLight, index) { + const offset = index * this._subDataSize; + if (spotLight.shadow.vpMatrixDirty) { + spotLight.shadow.vpMatrixDirty = false; + this.dirty = setDataToTypeArray(this.buffer, spotLight.shadow.camera.vpMatrix.toArray(), offset + 0); // byteOffset=0; + } + const nearValue = spotLight.shadow.camera.near; + if (nearValue != this._nearValue) { + this._nearValue = nearValue; + this.dirty = setDataToTypeArray(this.buffer, this._nearValue, offset + 16); // byteOffset=0; + } + const farValue = spotLight.shadow.camera.far; + if (farValue != this._farValue) { + this._farValue = farValue; + this.dirty = setDataToTypeArray(this.buffer, this._farValue, offset + 17); // byteOffset=0; + } } } -(Ei.align = 16), (Ei.uniformSize = 18); -class Mi extends si { - constructor(e, t, i, r, n) { - super(e, r, 0), - (this.byteSize = 32 * n), - (this.buffer = new Float32Array(t.buffer, i, this.byteSize / 4)), - (this.type = "pointsLight"); +UniformSpotLightShadows.align = 16; +UniformSpotLightShadows.uniformSize = 18; +class UniformPointLights extends Uniform { + // cb: Function; + constructor(uniformName, buffer, byteOffset, cb, count) { + super(uniformName, cb, 0); + this.byteSize = count * 32; + this.buffer = new Float32Array(buffer.buffer, byteOffset, this.byteSize / 4); + this.type = "pointsLight"; } set() { - return ( - (this.lights = this.getValue()), - this.lights.forEach((e, t) => { - this.setSubData(e, t); - }), - this.dirty - ); + this.lights = this.getValue(); + this.lights.forEach((pointLight, index) => { + this.setSubData(pointLight, index); + }); + return this.dirty; } - setSubData(e, t) { - const i = 8 * t; - e.positionDirty && ((e.positionDirty = !1), (this.dirty = Ci(this.buffer, e.position.toArray(), i + 0))), - e.distanceDirty && ((e.distanceDirty = !1), (this.dirty = Ci(this.buffer, e.distance, i + 3))), - e.colorDirty && ((e.colorDirty = !1), (this.dirty = Ci(this.buffer, e.color.toArray(), i + 4))), - e.decayDirty && ((e.decayDirty = !1), (this.dirty = Ci(this.buffer, e.decay, i + 7))); - } -} -Mi.align = 16; -class Ui extends si { - constructor(e, t, i, r, n) { - super(e, r, 0); - const s = Float32Array.BYTES_PER_ELEMENT; - (this._subDataSize = Ui.uniformSize), - (this.byteSize = n * s * this._subDataSize), - (this.buffer = new Float32Array(t.buffer, i, this.byteSize / 4)), - (this.type = "pointLightShadows"), - (this._nearValue = null), - (this._farValue = null); + setSubData(pointLight, index) { + const offset = index * 8; + if (pointLight.positionDirty) { + pointLight.positionDirty = false; + this.dirty = setDataToTypeArray(this.buffer, pointLight.position.toArray(), offset + 0); // byteOffset=0; + } + if (pointLight.distanceDirty) { + pointLight.distanceDirty = false; + this.dirty = setDataToTypeArray(this.buffer, pointLight.distance, offset + 3); // byteOffset=12; + } + if (pointLight.colorDirty) { + pointLight.colorDirty = false; + this.dirty = setDataToTypeArray(this.buffer, pointLight.color.toArray(), offset + 4); // byteOffset=32; + } + if (pointLight.decayDirty) { + pointLight.decayDirty = false; + this.dirty = setDataToTypeArray(this.buffer, pointLight.decay, offset + 7); // byteOffset=12; + } } - set() { - return ( - (this.lights = this.getValue()), - this.lights.forEach((e, t) => { - this.setSubData(e, t); - }), - this.dirty - ); +} +UniformPointLights.align = 16; +class UniformPointLightShadows extends Uniform { + constructor(uniformName, buffer, byteOffset, cb, count) { + super(uniformName, cb, 0); + const bytesPerElement = Float32Array.BYTES_PER_ELEMENT; + this._subDataSize = UniformPointLightShadows.uniformSize; + this.byteSize = count * bytesPerElement * this._subDataSize; + this.buffer = new Float32Array(buffer.buffer, byteOffset, this.byteSize / 4); + this.type = "pointLightShadows"; + this._nearValue = null; + this._farValue = null; } - setSubData(e, t) { - const i = t * this._subDataSize; - if (e.shadow.vpMatrixArrayDirty) { - e.shadow.vpMatrixArrayDirty = !1; - const t = e.shadow.camera.vpMatrixArray; - for (let e = 0; e < t.length; e++) { - const r = t[e]; - this.dirty = Ci(this.buffer, r.toArray(), i + 0 + 16 * e); + set() { + this.lights = this.getValue(); + this.lights.forEach((pointLight, index) => { + this.setSubData(pointLight, index); + }); + return this.dirty; + } + setSubData(pointLight, index) { + const offset = index * this._subDataSize; + if (pointLight.shadow.vpMatrixArrayDirty) { + pointLight.shadow.vpMatrixArrayDirty = false; + const vpMatrixArray = pointLight.shadow.camera.vpMatrixArray; + for (let i = 0; i < vpMatrixArray.length; i++) { + const vpMatrix = vpMatrixArray[i]; + this.dirty = setDataToTypeArray(this.buffer, vpMatrix.toArray(), offset + 0 + 16 * i); // byteOffset=98 * 4; + } + } + if (pointLight.shadow.viewPortDirty) { + pointLight.shadow.viewPortDirty = false; + for (let i = 0; i < 6; i++) { + this.dirty = setDataToTypeArray( + this.buffer, + pointLight.shadow.viewports[i].toArray(), + offset + 96 + 4 * i + ); // byteOffset=0; } } - if (e.shadow.viewPortDirty) { - e.shadow.viewPortDirty = !1; - for (let t = 0; t < 6; t++) this.dirty = Ci(this.buffer, e.shadow.viewports[t].toArray(), i + 96 + 4 * t); + const nearValue = pointLight.shadow.camera.near; + if (nearValue != this._nearValue) { + this._nearValue = nearValue; + this.dirty = setDataToTypeArray(this.buffer, this._nearValue, offset + 120); // byteOffset=0; + } + const farValue = pointLight.shadow.camera.far; + if (farValue != this._farValue) { + this._farValue = farValue; + this.dirty = setDataToTypeArray(this.buffer, this._farValue, offset + 121); // byteOffset=1; } - const r = e.shadow.camera.near; - r != this._nearValue && ((this._nearValue = r), (this.dirty = Ci(this.buffer, this._nearValue, i + 120))); - const n = e.shadow.camera.far; - n != this._farValue && ((this._farValue = n), (this.dirty = Ci(this.buffer, this._farValue, i + 121))); } } -(Ui.align = 16), (Ui.uniformSize = 122); -class _i extends si { - constructor(e, t, i, r, n) { - super(e, r, 0), - (this.cb = r), - (this.byteSize = 32 * n), - (this.buffer = new Float32Array(t.buffer, i, this.byteSize / 4)), - (this.type = "dirtectLights"); +UniformPointLightShadows.align = 16; +UniformPointLightShadows.uniformSize = 122; +class UniformDirtectLights extends Uniform { + constructor(uniformName, buffer, byteOffset, cb, count) { + super(uniformName, cb, 0); + this.cb = cb; + this.byteSize = count * 32; + this.buffer = new Float32Array(buffer.buffer, byteOffset, this.byteSize / 4); + this.type = "dirtectLights"; } set() { - return ( - (this.lights = this.getValue()), - this.lights.forEach((e, t) => { - this.setSubData(e, t); - }), - this.dirty - ); + this.lights = this.getValue(); + this.lights.forEach((directionalLight, index) => { + this.setSubData(directionalLight, index); + }); + return this.dirty; } - setSubData(e, t) { - const i = 8 * t; - e.dirtectDirty && ((e.dirtectDirty = !1), (this.dirty = Ci(this.buffer, e.directional.toArray(), i + 0))), - e.colorDirty && ((e.colorDirty = !1), (this.dirty = Ci(this.buffer, e.color.toArray(), i + 4))); + setSubData(directionalLight, index) { + const offset = index * 8; + if (directionalLight.dirtectDirty) { + directionalLight.dirtectDirty = false; + this.dirty = setDataToTypeArray(this.buffer, directionalLight.directional.toArray(), offset + 0); // byteOffset=16; + } + if (directionalLight.colorDirty) { + directionalLight.colorDirty = false; + this.dirty = setDataToTypeArray(this.buffer, directionalLight.color.toArray(), offset + 4); // byteOffset=32; + } } } -_i.align = 16; -class Li extends si { - constructor(e, t, i, r, n) { - super(e, r, 0); - const s = Float32Array.BYTES_PER_ELEMENT; - (this._subDataSize = Li.uniformSize), - (this.byteSize = n * s * this._subDataSize), - (this.buffer = new Float32Array(t.buffer, i, this.byteSize / 4)), - (this.type = "dirtectLightShadows"); +UniformDirtectLights.align = 16; +class UniformDirtectLightShadows extends Uniform { + constructor(uniformName, buffer, byteOffset, cb, count) { + super(uniformName, cb, 0); + const bytesPerElement = Float32Array.BYTES_PER_ELEMENT; + this._subDataSize = UniformDirtectLightShadows.uniformSize; + this.byteSize = count * bytesPerElement * this._subDataSize; + this.buffer = new Float32Array(buffer.buffer, byteOffset, this.byteSize / 4); + this.type = "dirtectLightShadows"; } set() { - return ( - (this.lights = this.getValue()), - this.lights.forEach((e, t) => { - this.setSubData(e, t); - }), - this.dirty - ); + this.lights = this.getValue(); + this.lights.forEach((directionalLight, index) => { + this.setSubData(directionalLight, index); + }); + return this.dirty; + } + setSubData(directionalLight, index) { + const offset = index * this._subDataSize; + if (directionalLight.shadow.vpMatrixDirty) { + directionalLight.shadow.vpMatrixDirty = false; + this.dirty = setDataToTypeArray(this.buffer, directionalLight.shadow.camera.vpMatrix.toArray(), offset + 0); // byteOffset=16; + } } - setSubData(e, t) { - const i = t * this._subDataSize; - e.shadow.vpMatrixDirty && - ((e.shadow.vpMatrixDirty = !1), (this.dirty = Ci(this.buffer, e.shadow.camera.vpMatrix.toArray(), i + 0))); +} +UniformDirtectLightShadows.align = 16; +UniformDirtectLightShadows.uniformSize = 16; +function setDataToTypeArray(buffer, data, offset) { + if (Array.isArray(data)) { + data.forEach((value, index) => { + buffer[index + offset] = value; + }); + } else { + buffer[offset] = data; } + return true; } -function Ci(e, t, i) { - return ( - Array.isArray(t) - ? t.forEach((t, r) => { - e[r + i] = t; - }) - : (e[i] = t), - !0 - ); -} -(Li.align = 16), (Li.uniformSize = 16); -class Ri { - constructor(e) { - (this.type = ee(e.type, "uniform")), - (this.label = ee(e.label, "")), - (this.name = ee(e.label, "")), - (this.hasDynamicOffset = e.hasDynamicOffset ?? !1), - (this.minBindingSize = e.minBindingSize ?? 0), - (this.binding = e.binding ?? 0), - (this.visibility = ee(e.visibility, d.Fragment | d.Vertex)), - (this.usage = ee(e.usage, r.Uniform | r.CopyDst)), - (this._uniformStruct = new Map()), - (this.uniformDirty = !0), - (this._bufferSize = e.size), - (this.buffer = e.buffer), - (this.offset = 0), - (this.dataBuffer = ee(e.dataBuffer, new Float32Array(ee(this._bufferSize, 400)))), - (this.byteOffset = 0), - (this.isUniformBuffer = !0), - (this.maxOffset = e.maxOffset ?? 0); + +class UniformBuffer { + constructor(options) { + this.type = defaultValue(options.type, "uniform"); + this.label = defaultValue(options.label, ""); + this.name = defaultValue(options.label, ""); + this.hasDynamicOffset = options.hasDynamicOffset ?? false; + this.minBindingSize = options.minBindingSize ?? 0; + this.binding = options.binding ?? 0; + this.visibility = defaultValue(options.visibility, ShaderStage.Fragment | ShaderStage.Vertex); + this.usage = defaultValue(options.usage, BufferUsage.Uniform | BufferUsage.CopyDst); + this._uniformStruct = new Map(); + this.uniformDirty = true; + this._bufferSize = options.size; + this.buffer = options.buffer; + this.offset = 0; + this.dataBuffer = defaultValue(options.dataBuffer, new Float32Array(defaultValue(this._bufferSize, 400))); + this.byteOffset = 0; + this.isUniformBuffer = true; + this.maxOffset = options.maxOffset ?? 0; } get layoutType() { - return { type: this.type, hasDynamicOffset: this.hasDynamicOffset, minBindingSize: this.minBindingSize }; + return { + type: this.type, + hasDynamicOffset: this.hasDynamicOffset, + minBindingSize: this.minBindingSize + }; } get bufferSize() { - return this._bufferSize ?? 4 * this.uniformsSize; + return this._bufferSize ?? this.uniformsSize * 4; } get uniformsSize() { - return null != this._bufferSize ? this._bufferSize / 4 : 16 * Math.ceil(this.byteOffset / 16); - } - bind(e) { - this._uniformStruct.forEach((e) => { - const t = e.set(); - null != e?.dirty && (e.dirty = !1), null != t && 0 == this.uniformDirty && (this.uniformDirty = t); - }), - this.uniformDirty && - ((this.uniformDirty = !1), - this.buffer || (this.buffer = $.createUniformBuffer(this.label, e, this.bufferSize, this.usage)), - this.type != m.Storage && - this.buffer.setSubData(0, this.dataBuffer.slice(0, ee(this?.bufferSize / 4, this.uniformsSize)))); + // https://gpuweb.github.io/gpuweb/wgsl/#address-space-layout-constraints + return this._bufferSize != undefined ? this._bufferSize / 4 : Math.ceil(this.byteOffset / 16) * 16; + } + bind(device) { + this._uniformStruct.forEach((uniform) => { + const result = uniform.set(); + if (uniform?.dirty != undefined) uniform.dirty = false; + if (result != undefined && this.uniformDirty == false) this.uniformDirty = result; + }); + if (this.uniformDirty) { + this.uniformDirty = false; + if (!this.buffer) this.buffer = Buffer.createUniformBuffer(this.label, device, this.bufferSize, this.usage); + if (this.type != BufferBindingType.Storage) + this.buffer.setSubData( + 0, + this.dataBuffer.slice(0, defaultValue(this?.bufferSize / 4, this.uniformsSize)) + ); + } } getUniformBufferStruct() { - let e = "struct MaterialUniform {\n "; - return ( - this._uniformStruct.forEach((t) => { - e += this.createUniformString(t); - }), - (e += "}\n"), - e - ); + let uniformStruct = `struct MaterialUniform {\n `; + this._uniformStruct.forEach((uniform) => { + uniformStruct += this.createUniformString(uniform); + }); + uniformStruct += `}\n`; + return uniformStruct; } - createUniformString(e) { - let t = ""; - switch (e.type) { + createUniformString(uniform) { + let result = ``; + switch (uniform.type) { case "vec1": - t = `${e.name} :f32,\n`; + result = `${uniform.name} :f32,\n`; break; case "vec2": - t = `${e.name} :vec2,\n`; + result = `${uniform.name} :vec2,\n`; break; case "vec3": - t = `${e.name} :vec3,\n`; + result = `${uniform.name} :vec3,\n`; break; case "vec4": - t = `${e.name} :vec4,\n`; + result = `${uniform.name} :vec4,\n`; break; case "mat2": - t = `${e.name} :mat2x2,\n`; + result = `${uniform.name} :mat2x2,\n`; break; case "mat3": - t = `${e.name} :mat3x3,\n`; + result = `${uniform.name} :mat3x3,\n`; break; case "mat4": - t = `${e.name} :mat4x4,\n`; + result = `${uniform.name} :mat4x4,\n`; + break; } - return t; - } - contains(e) { - return this._uniformStruct.get(e); - } - replaceUniformValue(e, t) { - const i = this._uniformStruct.get(e); - i && (i.cb = t); - } - setUniform(e, t, i, r) { - if (this._uniformStruct.get(e)) return; - const n = Ri.UniformType[i]; - this.byteOffset += Ri.checkUniformOffset(this.byteOffset, n.align); - const s = - null != r - ? new n(e, this.dataBuffer, this.byteOffset, t, r) - : new n(e, this.dataBuffer, this.byteOffset, t); - this._uniformStruct.set(e, s), (this.byteOffset += s.byteSize); - } - static checkUniformOffset(e, t) { - return Math.ceil(e / t) * t - e; + return result; + } + contains(name) { + return this._uniformStruct.get(name); + } + replaceUniformValue(name, value) { + const uniform = this._uniformStruct.get(name); + if (!uniform) return; + uniform.cb = value; + } + // uniformBuffer.setVec3Array('test',()=>{return [new Vector3(1,0,0),new Vector3(1,0.8,0.5)]},2); + // uniformBuffer.setFloatArray('test1',()=>{return [0.5,0.5,1.0]},3); + // uniformBuffer.setVec4Array('test4',()=>{return [new Vector4(0.5,0.6,0.2,1.0),new Vector4(0.5,0.8,0.8,1.0)]},2); + // uniformBuffer.setVec2Array('test2',()=>{return [new Vector2(0.5,0.6),new Vector2(0.5,0.8,)]},2); + setUniform(name, value, uniformType, count) { + if (this._uniformStruct.get(name)) return; + const TypeUniform = UniformBuffer.UniformType[uniformType]; + this.byteOffset += UniformBuffer.checkUniformOffset(this.byteOffset, TypeUniform.align); + const uniform = + count != undefined + ? new TypeUniform(name, this.dataBuffer, this.byteOffset, value, count) + : new TypeUniform(name, this.dataBuffer, this.byteOffset, value); + this._uniformStruct.set(name, uniform); + this.byteOffset += uniform.byteSize; + } + static checkUniformOffset(byteSize, Align) { + // from https://gpuweb.github.io/gpuweb/wgsl/#address-space-layout-constraints + // return this.hasDynamicOffset + // ? Math.ceil(byteSize / 256) * 256 - byteSize + // : Math.ceil(byteSize / Align) * Align - byteSize; + return Math.ceil(byteSize / Align) * Align - byteSize; } destroy() { this?.buffer?.destroy(); } } -Ri.UniformType = { - [Q.UniformUint]: ai, - [Q.Float]: oi, - [Q.FloatVec2]: ci, - [Q.FloatVec3]: li, - [Q.FloatVec4]: hi, - [Q.Mat2]: fi, - [Q.Mat3]: di, - [Q.Mat4]: mi, - [Q.Color]: ui, - [Q.FloatArray]: gi, - [Q.Vec2Array]: xi, - [Q.Vec3Array]: vi, - [Q.Vec4Array]: yi, - [Q.Mat4Array]: pi, - [Q.PointLights]: Mi, - [Q.SpotLights]: Ti, - [Q.DirtectLights]: _i, - [Q.PointLightShadows]: Ui, - [Q.SpotLightShadows]: Ei, - [Q.DirtectLightShadows]: Li, - [Q.UniformStructArray]: wi +UniformBuffer.UniformType = { + [UniformEnum.UniformUint]: UniformUint, + [UniformEnum.Float]: UniformFloat, + [UniformEnum.FloatVec2]: UniformFloatVec2, + [UniformEnum.FloatVec3]: UniformFloatVec3, + [UniformEnum.FloatVec4]: UniformFloatVec4, + [UniformEnum.Mat2]: UniformMat2, + [UniformEnum.Mat3]: UniformMat3, + [UniformEnum.Mat4]: UniformMat4, + [UniformEnum.Color]: UniformColor, + [UniformEnum.FloatArray]: UniformFloatArray, + [UniformEnum.Vec2Array]: UniformVec2Array, + [UniformEnum.Vec3Array]: UniformVec3Array, + [UniformEnum.Vec4Array]: UniformVec4Array, + [UniformEnum.Mat4Array]: UniformMatrix4Array, + [UniformEnum.PointLights]: UniformPointLights, + [UniformEnum.SpotLights]: UniformSpotLights, + [UniformEnum.DirtectLights]: UniformDirtectLights, + [UniformEnum.PointLightShadows]: UniformPointLightShadows, + [UniformEnum.SpotLightShadows]: UniformSpotLightShadows, + [UniformEnum.DirtectLightShadows]: UniformDirtectLightShadows, + [UniformEnum.UniformStructArray]: UniformStructArray }; -const Ai = /#([^\s]*)(\s*)/gm; -function Di(e, ...t) { - const i = []; - let r = { frag: "", elseIsValid: !1, expression: !0 }, - n = 1; - for (let s = 0; s < e.length; ++s) { - const a = e[s], - o = a.matchAll(Ai); - let c = 0, - l = !1; - for (const e of o) { - switch (((r.frag += a.substring(c, e.index)), e[1])) { + +// import Color from "../../math/Color"; +function colorFrag(defines) { + return ` + struct VertexOutput { + @builtin(position) position: vec4, + @location(0) color: vec4, + }; + @fragment + fn main(input:VertexOutput) -> @location(0) vec4 { + return input.color; + } + `; +} + +function colorVert(defines) { + return ` + struct VertexInput { + @location(${defines.positionLocation}) position: vec3, + @location(${defines.colorLocation}) color: vec4, + } + struct VertexOutput { + @builtin(position) position: vec4, + @location(0) color: vec4, + }; + struct SelfUniform { + modelMatrix: mat4x4, + } + struct SystemUniform { + projectionMatrix: mat4x4, + viewMatrix: mat4x4, + inverseViewMatrix: mat4x4, + cameraPosition: vec3, + }; + @binding(${defines.colorBinding}) @group(0) var selfUniform : SelfUniform; + @binding(${defines.cameraBinding}) @group(1) var systemUniform : SystemUniform; + @vertex + fn main(input: VertexInput) -> VertexOutput { + var output:VertexOutput; + output.color=input.color; + output.position = systemUniform.projectionMatrix * systemUniform.viewMatrix *selfUniform.modelMatrix*vec4(input.position,1.0); + return output; + } + `; +} + +const preprocessorSymbols = /#([^\s]*)(\s*)/gm; +// Template literal tag that handles simple preprocessor symbols for WGSL +// shaders. Supports #if/elif/else/endif statements. +function wgslParseDefines(strings, ...values) { + const stateStack = []; + let state = { frag: "", elseIsValid: false, expression: true }; + let depth = 1; + for (let i = 0; i < strings.length; ++i) { + const frag = strings[i]; + const matchedSymbols = frag.matchAll(preprocessorSymbols); + let lastIndex = 0; + let valueConsumed = false; + for (const match of matchedSymbols) { + state.frag += frag.substring(lastIndex, match.index); + switch (match[1]) { case "if": - if (e.index + e[0].length != a.length) + if (match.index + match[0].length != frag.length) { throw new Error("#if must be immediately followed by a template expression (ie: ${value})"); - (l = !0), i.push(r), n++, (r = { frag: "", elseIsValid: !0, expression: !!t[s] }); + } + valueConsumed = true; + stateStack.push(state); + depth++; + state = { frag: "", elseIsValid: true, expression: !!values[i] }; break; case "elif": - if (e.index + e[0].length != a.length) + if (match.index + match[0].length != frag.length) { throw new Error("#elif must be immediately followed by a template expression (ie: ${value})"); - if (!r.elseIsValid) throw new Error("#elif not preceeded by an #if or #elif"); - (l = !0), - r.expression && i.length != n && i.push(r), - (r = { frag: "", elseIsValid: !0, expression: !!t[s] }); + } else if (!state.elseIsValid) { + throw new Error("#elif not preceeded by an #if or #elif"); + } + valueConsumed = true; + if (state.expression && stateStack.length != depth) { + stateStack.push(state); + } + state = { frag: "", elseIsValid: true, expression: !!values[i] }; break; case "else": - if (!r.elseIsValid) throw new Error("#else not preceeded by an #if or #elif"); - r.expression && i.length != n && i.push(r), (r = { frag: e[2], elseIsValid: !1, expression: !0 }); + if (!state.elseIsValid) { + throw new Error("#else not preceeded by an #if or #elif"); + } + if (state.expression && stateStack.length != depth) { + stateStack.push(state); + } + state = { frag: match[2], elseIsValid: false, expression: true }; break; case "endif": - if (!i.length) throw new Error("#endif not preceeded by an #if"); - const o = i.length == n ? i.pop() : r; - (r = i.pop()), n--, o.expression && (r.frag += o.frag), (r.frag += e[2]); + if (!stateStack.length) { + throw new Error("#endif not preceeded by an #if"); + } + const branchState = stateStack.length == depth ? stateStack.pop() : state; + state = stateStack.pop(); + depth--; + if (branchState.expression) { + state.frag += branchState.frag; + } + state.frag += match[2]; break; default: - r.frag += e[0]; + // Unknown preprocessor symbol. Emit it back into the output frag unchanged. + state.frag += match[0]; + break; } - c = e.index + e[0].length; + lastIndex = match.index + match[0].length; + } + // If the frag didn't end on one of the preprocessor symbols append the rest of it here. + if (lastIndex != frag.length) { + state.frag += frag.substring(lastIndex, frag.length); + } + // If the next value wasn't consumed by the preprocessor symbol, append it here. + if (!valueConsumed && values.length > i) { + state.frag += values[i]; } - c != a.length && (r.frag += a.substring(c, a.length)), !l && t.length > s && (r.frag += t[s]); } - if (i.length) throw new Error("Mismatched #if/#endif count"); - return r.frag; -} -function zi(e) { - return `\n struct VertexInput {\n @location(${e.positionLocation}) position: vec2, \n }\n struct VertexOutput {\n @builtin(position) position: vec4,\n @location(0) uv: vec2,\n };\n @vertex\n fn main(input: VertexInput) -> VertexOutput {\n var output:VertexOutput;\n output.uv = input.position * 0.5 + 0.5;\n output.position = vec4(input.position, 0.0, 1.0);;\n return output;\n }\n `; + if (stateStack.length) { + throw new Error("Mismatched #if/#endif count"); + } + return state.frag; } -const Ii = { - light: function (e) { - return Di` - struct ReflectedLight { - ambient: vec3, - directDiffuse:vec3, - directSpecular:vec3, - indirectDiffuse:vec3, - indirectSpecular:vec3, - testColor: vec3, - }; - struct IncidentLight { - color: vec3, - direction: vec3, - visible: bool, - }; - struct Geometry { - position: vec3, - normal: vec3, - viewDir: vec3, - dotNV:f32, - #if ${e.USE_CLEARCOAT} - vec3 clearcoatNormal; - #endif - }; - #if ${e.spotLightsCount > 0} - struct SpotLight { - position: vec3, - distance: f32, - direction: vec3, - coneCos: f32, - color: vec3, - penumbraCos: f32, - decay: f32, - }; - fn getSpotLightInfo(spotLight:SpotLight,worldPos:vec3,shininess:f32,N:vec3,V:vec3)->ReflectedLight{ - var direction:vec3 = spotLight.position - worldPos; - var lightColor:ReflectedLight; - let lightDistance:f32 = length(direction); - direction = normalize(direction); - let angleCos:f32 = dot( direction, spotLight.direction ); - let decay:f32 = clamp(1.0 - pow(lightDistance/spotLight.distance, spotLight.decay), 0.0, 1.0); - let spotEffect:f32 = smoothstep( spotLight.penumbraCos, spotLight.coneCos, angleCos ); - let decayTotal:f32 = decay * spotEffect; - let d:f32 = max( dot( N, direction ), 0.0 ) * decayTotal; - lightColor.directDiffuse= spotLight.color * d; - let halfDir:vec3 = normalize( V + direction ); - let s:f32 = pow( clamp( dot( N, halfDir ), 0.0, 1.0 ), shininess ) * decayTotal; - lightColor.directSpecular= spotLight.color * s; - return lightColor; - } - fn getSpotLightIncidentLight(spotLight:SpotLight, geometry:Geometry)->IncidentLight { - var incidentLight:IncidentLight; - let lVector:vec3 = spotLight.position - geometry.position; - incidentLight.direction = normalize( lVector ); - - let lightDistance:f32 = length( lVector ); - let angleCos:f32 = dot( incidentLight.direction, spotLight.direction ); - - let spotEffect:f32 = smoothstep( spotLight.penumbraCos, spotLight.coneCos, angleCos ); - let decayEffect:f32 = clamp(1.0 - pow(lightDistance/spotLight.distance, 4.0), 0.0, 1.0); - - incidentLight.color=spotLight.color*spotEffect * decayEffect; - return incidentLight; - } - - #endif +function pbr_fs(defines) { + return wgslParseDefines` + // reference: https://github.com/KhronosGroup/glTF-WebGL-PBR/blob/master/shaders/pbr-frag.glsl + #include + #include + #include + #include + #include + #include + struct PhysicalMaterial { + diffuseColor:vec3, + roughness:f32, + specularColor:vec3, + #if ${defines.USE_CLEARCOAT} + clearcoat:f32, + clearcoatRoughness:f32, + clearcoatF0:vec3, + clearcoatF90:f32, + #endif - #if ${e.pointLightsCount > 0} - struct PointLight { - position: vec3, - distance: f32, - color: vec3, - decay: f32, - }; - fn getPointLightInfo(pointLight:PointLight,worldPos:vec3,shininess:f32,N:vec3,V:vec3)->ReflectedLight{ - var lightColor:ReflectedLight; - var direction:vec3 = worldPos - pointLight.position; - let dist:f32 = length( direction ); - direction = normalize(direction); - let decay = clamp(1.0 - pow(dist / pointLight.distance, pointLight.decay), 0.0, 1.0); - - let d = max( dot( N, -direction ), 0.0 ) * decay; - lightColor.directDiffuse = pointLight.color * d; - - let halfDir:vec3 = normalize( V - direction ); - let s:f32 = pow( clamp( dot( N, halfDir ), 0.0, 1.0 ), shininess ) * decay; - lightColor.directSpecular = pointLight.color * s; - return lightColor; - } - fn getPointLightIncidentLight(pointLight:PointLight, geometry:Geometry)->IncidentLight { - var incidentLight:IncidentLight; - let lVector:vec3 = pointLight.position-geometry.position; - incidentLight.direction= normalize( lVector ); - let lightDistance:f32 = length( lVector ); - // let weight:f32=1.0 - pow(lightDistance/pointLight.distance, 4.0); - incidentLight.color=pointLight.color*clamp(1.0 - pow(lightDistance/pointLight.distance, 4.0), 0.0, 1.0); - return incidentLight; - } - #endif - #if ${e.dirtectLightsCount > 0} - struct DirectionalLight { - direction: vec3, - color: vec3, - }; - fn getDirectLightInfo(directionalLight:DirectionalLight,shininess:f32,N:vec3,V:vec3)->ReflectedLight{ - var lightColor:ReflectedLight; - let d:f32 = max(dot(N, -directionalLight.direction), 0.0); - lightColor.directDiffuse += directionalLight.color * d; - - let halfDir:vec3 = normalize( V - directionalLight.direction ); - let s:f32 = pow( clamp( dot( N, halfDir ), 0.0, 1.0 ), shininess ); - lightColor.directSpecular += directionalLight.color * s; - return lightColor; - } - fn getDirectionalDirectLightIncidentLight(directionalLight:DirectionalLight,geometry:Geometry)->IncidentLight { - var incidentLight:IncidentLight; - incidentLight.color = directionalLight.color; - incidentLight.direction = normalize(directionalLight.direction); - return incidentLight; - } - #endif + #if ${defines.USE_IRIDESCENCE} + iridescence:f32, + iridescenceIOR:f32, + iridescenceThickness:f32, + iridescenceFresnel:vec3, + iridescenceF0:vec3, + #endif - #if ${e.openShadow} - struct LightInfo { - direction: vec3, - viewport: vec4, - }; - - fn linearizeDepth(depth: f32, near: f32, far: f32)->f32 { - return 2 * (near * far) / (far + near - depth * (far - near)); - } + #if ${defines.USE_SHEEN} + sheenColor:vec3, + sheenRoughness:f32, + #endif - fn getCubeFace(v : vec3) -> i32{ - let vAbs = abs(v); - - if (vAbs.z >= vAbs.x && vAbs.z >= vAbs.y) { - if (v.z < 0.0) { - return 3; - } - return 2; - } - - if (vAbs.y >= vAbs.x) { - if (v.y < 0.0) { - return 5; - } - return 4; - } - - if (v.x < 0.0) { - return 1; - } - return 0; - } + #if ${defines.IOR} + ior:f32, + #endif - fn getShadowValue(shadowMapArray:texture_depth_2d_array, shadowSampler:sampler_comparison, lightPos:vec4, geometry:Geometry, lightInfo:LightInfo, index:u32, isPointLight: bool, near: f32, far: f32)->f32 { - var visibility = 0.0; - var projectPos: vec3 = lightPos.xyz / lightPos.w; - var shadowPos: vec3 = vec3(projectPos.xy * vec2(0.5, -0.5) + vec2(0.5), projectPos.z); - var d:f32 = dot(geometry.normal, -lightInfo.direction); - var bias = max(0.012 * (1.0 - d), 0.001) / lightPos.w; - let oneOverShadowDepthTextureSize = 1.0 / 1024.0; - // var depth = select(shadowPos.z, (linearizeDepth(shadowPos.z, near, far) - near) / (far- near), isPerspectiveCamera); - var depth = shadowPos.z; + #if ${defines.USE_TRANSMISSION} + transmission:f32, + transmissionAlpha:f32, + thickness:f32, + attenuationDistance:f32, + attenuationColor:vec3, + #endif + }; + const M_PI:f32 = 3.141592653589793; + const c_MinRoughness:f32 = 0.04; + #include + #if ${defines.USE_IBL} + #include + #endif + @binding(${defines.pbrBinding}) @group(0) var materialUniform : MaterialUniform; + @binding(${defines.cameraBinding}) @group(1) var systemUniform : SystemUniform; + @fragment + fn main(input:FragInput) -> @location(0) vec4 + { + var perceptualRoughness:f32 = materialUniform.roughness; + var metallic:f32 = materialUniform.metallic; - if (isPointLight) { - shadowPos.x = shadowPos.x * lightInfo.viewport.z; - shadowPos.y = shadowPos.y * lightInfo.viewport.w; - var viewportX = lightInfo.viewport.x * lightInfo.viewport.z; - var viewportY = lightInfo.viewport.y * lightInfo.viewport.w; - var uvOffset = 1.5 / 1024.0; - shadowPos.x = clamp(shadowPos.x + viewportX, viewportX + uvOffset, viewportX + lightInfo.viewport.z - uvOffset); - shadowPos.y = clamp(shadowPos.y + viewportY, viewportY + uvOffset, viewportY + lightInfo.viewport.w - uvOffset); - } + #if ${defines.USE_METALNESSTEXTURE} + let mrSample:vec4 = textureSample(metalnessRoughnessTexture,metalnessRoughnessSampler, input.uv); + perceptualRoughness = mrSample.g * perceptualRoughness; + metallic = mrSample.b * metallic; + #endif + perceptualRoughness = clamp(perceptualRoughness, c_MinRoughness, 1.0); + metallic = clamp(metallic, 0.0, 1.0); + let alphaRoughness:f32 = perceptualRoughness * perceptualRoughness; - for (var y = -1; y <= 1; y++) { - for (var x = -1; x <= 1; x++) { - let offset = vec2(vec2(x, y)) * oneOverShadowDepthTextureSize; - - visibility += textureSampleCompare( - shadowMapArray, shadowSampler, - shadowPos.xy + offset, index, depth - bias); - } - } - visibility /= 9.0; - var inFrustum = shadowPos.x >= 0.0 && shadowPos.x <= 1.0 && shadowPos.y >= 0.0 && shadowPos.y <= 1.0; - if (!inFrustum || depth > 1.0) { - visibility = 1.0; - } - return visibility; - } - #endif - #if ${e.ambientLightCount || e.spotLightsCount || e.pointLightsCount || e.dirtectLightsCount} - struct LightUniforms{ - #if ${e.ambientLightCount} - ambient:vec4, - #endif - #if ${e.spotLightsCount} - spotLights:array, - #endif - #if ${e.pointLightsCount} - pointLights:array, - #endif - #if ${e.dirtectLightsCount} - dirtectLights:array, + // The albedo may be defined from a base texture or a flat color + #if ${defines.USE_TEXTURE} + let baseColor:vec4 = textureSample(baseColorTexture,baseColorSampler, input.uv) ; + #else + let baseColor:vec4 = vec4(materialUniform.color,1.0); #endif - } - @group(2) @binding(${e.lightBinding}) var lightUniforms: LightUniforms; - #if ${e.openShadow} - #if ${e.spotLightShadowMapsCount} - struct SpotLightShadow { - shadowCameraVPMatrix: mat4x4, - shadowCameraNear: f32, - shadowCameraFar: f32 - } + #if ${defines.USE_NORMALTEXTURE} + let n:vec3 = getNormalByNormalTexture(input); + #else + let n:vec3 = getNormal(input); #endif - #if ${e.pointLightShadowMapsCount} - struct PointLightShadow { - shadowCameraVPMatrixArray: array, 6>, - shadowCameraViewportArray: array, 6>, - shadowCameraNear: f32, - shadowCameraFar: f32, - // shadowCameraVPMatrix: mat4x4, - // shadowCameraVPMatrixArray: array, 6>, - // shadowCameraViewportArray: array, 6>, - } + var material:PhysicalMaterial; + material.diffuseColor=baseColor.rgb*( 1.0 - metallic ); + material.roughness=perceptualRoughness; + material.specularColor=mix( vec3( 0.04), baseColor.rgb, metallic ); + var geometry:Geometry; + geometry.normal=n; + geometry.viewDir=normalize(systemUniform.cameraPosition - input.worldPos); + geometry.position=input.worldPos; + geometry.dotNV = saturate(dot(geometry.normal, geometry.viewDir) ); + //light shading + var reflectedLight=parseLights(geometry,material); + var color=reflectedLight.directDiffuse+reflectedLight.directSpecular; + //IBL + #if ${defines.USE_IBL && defines.HAS_UV} + var reflectedLightDiffuse=indirectDiffuse_Physical(geometry,material); + var reflectedLightSpecular=indirectSpecular_Physical(geometry,material); + color+=reflectedLightDiffuse.indirectDiffuse; + color+=reflectedLightSpecular.indirectSpecular; #endif - #if ${e.directLightShadowMapsCount} - struct DirectLightShadow { - shadowCameraVPMatrix: mat4x4, - } + #if ${defines.USE_AOTEXTURE} + let ao:f32 = textureSample(aoTexture,aoSampler, input.uv).r; + color = mix(color, color * ao, materialUniform.occlusionStrength); #endif - struct ShadowUniforms{ - #if ${e.spotLightShadowMapsCount} - spotLightShadows:array, - #endif - #if ${e.pointLightShadowMapsCount} - pointLightShadows:array, - #endif - #if ${e.directLightShadowMapsCount} - directLightShadows:array, - #endif - } - @group(2) @binding(${e.shadowBinding}) var shadowUniforms: ShadowUniforms; - #if ${e.spotLightShadowMapTextureArrayBinding} - @group(2) @binding(${ - e.spotLightShadowMapTextureArrayBinding - }) var spotLightShadowMapTextureArray: texture_depth_2d_array; - #endif - #if ${e.pointLightShadowMapTextureArrayBinding} - @group(2) @binding(${ - e.pointLightShadowMapTextureArrayBinding - }) var pointLightShadowMapTextureArray: texture_depth_2d_array; + #if ${defines.USE_EMISSIVETEXTURE} + let emissive:vec3 = textureSample(emissiveTexture, emissiveSampler,input.uv).rgb ; + color += emissive; #endif - #if ${e.directLightShadowMapTextureArrayBinding} - @group(2) @binding(${ - e.directLightShadowMapTextureArrayBinding - }) var directLightShadowMapTextureArray: texture_depth_2d_array; - #endif - @group(2) @binding(${e.shadowSamplerBinding}) var shadowSampler: sampler_comparison; + return vec4(color, baseColor.a); + } + `; +} + +function pbr_vs(defines) { + return wgslParseDefines` + #include + #include + #include + #include + #include + #include + @binding(${defines.pbrBinding}) @group(0) var materialUniform : MaterialUniform; + @binding(${defines.cameraBinding}) @group(1) var systemUniform : SystemUniform; + @vertex + fn main(input: VertexInput)-> VertexOutput + { + var output: VertexOutput; + #if ${defines.HAS_UV} + output.uv = input.uv; #endif + var modelMatrix:mat4x4; + var vNormalView:vec3; + vNormalView = normalize(materialUniform.normalMatrix * vec4(input.normal,0.0)).xyz; + modelMatrix=materialUniform.modelMatrix; + #include + #include + output.normal = vNormalView.xyz; + output.position = systemUniform.projectionMatrix * systemUniform.viewMatrix *modelMatrix* vec4(input.position, 1.0); + let modelPos=modelMatrix *vec4(input.position,1.0); + output.worldPos = modelPos.xyz/modelPos.w; + return output; + } + `; +} +function pbrFrag(defines) { + return wgslParseDefines` + #include + #include + #include + #include + #include + #include + #include + #include + struct SystemUniform { + projectionMatrix: mat4x4, + viewMatrix: mat4x4, + inverseViewMatrix: mat4x4, + cameraPosition: vec3, + }; + // uniform vec3 lightProbe[9], +//////////////////////////////////// +struct VertexOutput { + @builtin(position) position: vec4, + @builtin(front_facing) is_front: bool, + @location(0) vUv: vec2, + @location(1) vViewPosition: vec3, // Vector from vertex to camera. + @location(2) vWorldPosition: vec3, + @location(3) vNormal: vec3, + // 可选 + #if ${defines.USE_LIGHTTEXTURE || defines.USE_AOTEXTURE} + @location(${defines.vUv2OutLocation}) vUv2: vec2, #endif - #if ${e.materialPhong} - fn parseLights(geometry:Geometry,shininess:f32)->ReflectedLight { - #elif ${e.materialPbr} - fn parseLights(geometry:Geometry,material:PhysicalMaterial)->ReflectedLight{ + + #if ${defines.USE_COLOR_ALPHA} + @location(${defines.vColorOutLocation}) vColor: vec4, + #elif ${defines.USE_COLOR || defines.USE_INSTANCING_COLOR} + @location(${defines.vColorOutLocation}) vColor: vec3, #endif - var reflectedLight:ReflectedLight; - var shadowValue:f32 = 1.0; - #if ${e.ambientLightCount > 0} - //处理环境光 - var ambientColor:vec3 = lightUniforms.ambient.xyz * lightUniforms.ambient.w; - reflectedLight.ambient += ambientColor; - #endif - #if ${e.spotLightsCount > 0} - //处理聚光灯 - var spotLight:SpotLight; - for (var k = 0u; k < ${e.spotLightsCount}; k = k + 1u) { - spotLight= lightUniforms.spotLights[k]; - #if ${e.materialPhong && e.openShadow && e.spotLightShadowMapsCount} - if k < textureNumLayers(spotLightShadowMapTextureArray) { - var spotLightShadow:SpotLightShadow = shadowUniforms.spotLightShadows[k]; - var lightPos: vec4 = spotLightShadow.shadowCameraVPMatrix * vec4(geometry.position,1.0); - var lightInfo:LightInfo; - lightInfo.direction = normalize(geometry.position - spotLight.position); + #if ${defines.USE_TANGENT} + @location(${defines.vTangentOutLocation}) vTangent: vec3, + @location(${defines.vBitangentOutLocation}) vBitangent: vec3, + #endif +}; + struct PhysicalMaterial { + diffuseColor:vec3, + roughness:f32, + specularColor:vec3, + specularF90:f32, + #if ${defines.USE_CLEARCOAT} + clearcoat:f32, + clearcoatRoughness:f32, + clearcoatF0:vec3, + clearcoatF90:f32, + #endif - shadowValue = getShadowValue(spotLightShadowMapTextureArray, shadowSampler, lightPos, geometry, lightInfo, k, false, - spotLightShadow.shadowCameraNear, spotLightShadow.shadowCameraFar); - } - spotLight.color *= shadowValue; - #endif - #if ${e.materialPhong} - let spReflectedLight=getSpotLightInfo(spotLight,geometry.position,shininess,geometry.normal,geometry.viewDir); - #elif ${e.materialPbr} - let incidentLight=getSpotLightIncidentLight(spotLight,geometry); - let spReflectedLight=direct_Physical(incidentLight, geometry, material); - #endif + #if ${defines.USE_IRIDESCENCE} + iridescence:f32, + iridescenceIOR:f32, + iridescenceThickness:f32, + iridescenceFresnel:vec3, + iridescenceF0:vec3, + #endif - reflectedLight.directDiffuse+=spReflectedLight.directDiffuse; - reflectedLight.directSpecular+=spReflectedLight.directSpecular; - } - #endif - #if ${e.pointLightsCount > 0} - //处理点光源 - var pointLight:PointLight; - for (var j = 0u; j < ${e.pointLightsCount};j = j + 1u) { - pointLight = lightUniforms.pointLights[j]; - #if ${e.materialPhong && e.openShadow && e.pointLightShadowMapsCount} - if j < textureNumLayers(pointLightShadowMapTextureArray) { - var pointLightShadow:PointLightShadow = shadowUniforms.pointLightShadows[j]; - var lightInfo:LightInfo; - lightInfo.direction = normalize(geometry.position - pointLight.position); - var cubeFace = getCubeFace(lightInfo.direction); - var lightPos: vec4 = pointLightShadow.shadowCameraVPMatrixArray[cubeFace] * vec4(geometry.position,1.0); - lightInfo.viewport = pointLightShadow.shadowCameraViewportArray[cubeFace]; + #if ${defines.USE_SHEEN} + sheenColor:vec3, + sheenRoughness:f32, + #endif - // var lightPos: vec4 = pointLightShadow.shadowCameraVPMatrix * vec4(geometry.position,1.0); + #if ${defines.IOR} + ior:f32, + #endif - shadowValue = getShadowValue(pointLightShadowMapTextureArray, shadowSampler, lightPos, geometry, lightInfo, j, true, - pointLightShadow.shadowCameraNear, pointLightShadow.shadowCameraFar); - - // reflectedLight.testColor = vec3(pointLightShadow.shadowCameraFar / 1000, - // pointLightShadow.shadowCameraVPMatrixArray[5][3][2] / 255, pointLightShadow.shadowCameraVPMatrixArray[5][3][3] / 255); - // reflectedLight.testColor = vec3(pointLightShadow.shadowCameraNear, pointLightShadow.shadowCameraNear, pointLightShadow.shadowCameraNear); - } - pointLight.color *= shadowValue; - #endif - #if ${e.materialPhong} - let poiReflectedLight=getPointLightInfo(pointLight,geometry.position,shininess,geometry.normal,geometry.viewDir); - #elif ${e.materialPbr} - let incidentLight=getPointLightIncidentLight(pointLight,geometry); - let poiReflectedLight=direct_Physical(incidentLight, geometry, material); - #endif + #if ${defines.USE_TRANSMISSION} + transmission:f32, + transmissionAlpha:f32, + thickness:f32, + attenuationDistance:f32, + attenuationColor:vec3, + #endif + }; +@binding(0) @group(0) var materialUniform : MaterialUniform; +@binding(0) @group(1) var systemUniform : SystemUniform; +@fragment +fn main(input:VertexOutput)-> @location(0) vec4 { + var diffuseColor:vec4 = vec4(materialUniform.diffuse, materialUniform.opacity ); + // ReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) ); + var reflectedLight:ReflectedLight; + var totalEmissiveRadiance:vec3 = materialUniform.emissive; + #if ${defines.USE_TEXTURE} + var sampledDiffuseColor:vec4 =textureSample(baseTexture, baseSampler, input.vUv); + #if ${defines.DECODE_VIDEO_TEXTURE} + sampledDiffuseColor = vec4( mix( pow( sampledDiffuseColor.rgb * 0.9478672986 + vec3( 0.0521327014 ), vec3( 2.4 ) ), sampledDiffuseColor.rgb * 0.0773993808, vec3( lessThanEqual( sampledDiffuseColor.rgb, vec3( 0.04045 ) ) ) ), sampledDiffuseColor.w ); + #endif - reflectedLight.directDiffuse+=poiReflectedLight.directDiffuse; - reflectedLight.directSpecular+=poiReflectedLight.directSpecular; - } + diffuseColor *= sampledDiffuseColor; #endif - #if ${e.dirtectLightsCount > 0} - //处理方向光 - var directionalLight:DirectionalLight; - for (var i= 0u; i <${e.dirtectLightsCount}; i = i + 1u) { - directionalLight = lightUniforms.dirtectLights[i]; - #if ${e.materialPhong && e.openShadow && e.directLightShadowMapsCount} - if i < textureNumLayers(directLightShadowMapTextureArray) { - var directLightShadow:DirectLightShadow = shadowUniforms.directLightShadows[i]; - var lightPos: vec4 = directLightShadow.shadowCameraVPMatrix * vec4(geometry.position,1.0); - var lightInfo:LightInfo; - lightInfo.direction = directionalLight.direction; - - shadowValue = getShadowValue(directLightShadowMapTextureArray, shadowSampler, lightPos, geometry, lightInfo, i, false, 0, 0); - } - directionalLight.color *= shadowValue; - #endif - - #if ${e.materialPhong} - let dirReflectedLight=getDirectLightInfo(directionalLight,shininess,geometry.normal,geometry.viewDir); - #elif ${e.materialPbr} - let incidentLight=getDirectionalDirectLightIncidentLight(directionalLight,geometry); - let dirReflectedLight=direct_Physical(incidentLight, geometry, material); - #endif - reflectedLight.directDiffuse+=dirReflectedLight.directDiffuse; - reflectedLight.directSpecular+=dirReflectedLight.directSpecular; - } + var roughnessFactor:f32 = materialUniform.roughness; + + #if ${defines.USE_ROUGHNESSTEXTURE} + let texelRoughness:vec4=textureSample(roughnessTexture, baseSampler, input.vUv); + roughnessFactor *= texelRoughness.g; #endif - return reflectedLight; - }`; - }, - brdf: function (e) { - return Di` - #if ${e.USE_SHEEN} - fn D_Charlie( roughness:f32,dotNH:f32 )->f32 { - let alpha:f32 = pow2( roughness ); - let invAlpha:f32 = 1.0 / alpha; - let cos2h:f32 = dotNH * dotNH; - let sin2h:f32 = max( 1.0 - cos2h, 0.0078125 ); - return ( 2.0 + invAlpha ) * pow( sin2h, invAlpha * 0.5 ) / ( 2.0 * PI ); - } - fn V_Neubelt( dotNV:f32, dotNL:f32 )->f32 { - return saturate( 1.0 / ( 4.0 * ( dotNL + dotNV - dotNL * dotNV ) ) ); - } - fn BRDF_Sheen(lightDir:vec3, viewDir:vec3, normal:vec3,sheenColor:vec3,sheenRoughness:f32 )->vec3 { - let halfDir:vec3 = normalize( lightDir + viewDir ); - let dotNL:f32 = saturate( dot( normal, lightDir ) ); - let dotNV:f32 = saturate( dot( normal, viewDir ) ); - let dotNH:f32 = saturate( dot( normal, halfDir ) ); - let D:f32 = D_Charlie( sheenRoughness, dotNH ); - let V:f32 = V_Neubelt( dotNV, dotNL ); - return sheenColor * ( D * V ); - } + + var metalnessFactor:f32 = materialUniform.metalness; + + #if ${defines.USE_METALNESSTEXTURE} + let texelMetalness:vec4 =textureSample(metalnessTexture, baseSampler, input.vUv); + metalnessFactor *= texelMetalness.b; #endif - fn BRDF_Lambert(diffuseColor:vec3)->vec3 { - return RECIPROCAL_PI * diffuseColor; + let faceDirection:f32 =select(-1.0,1.0,input.is_front); + #if ${defines.FLAT_SHADED} + let fdx:vec3 = dpdx( input.vViewPosition ); + let fdy:vec3 = dpdy( input.vViewPosition ); + let normal:vec3 = normalize( cross( fdy, fdx ) ); + #else + let normal:vec3 = normalize( input.vNormal ); + #if ${defines.DOUBLE_SIDED} + normal = normal * faceDirection; + #endif + #if ${defines.USE_TANGENT} + let tangent:vec3 = normalize( input.vTangent ); + let bitangent:vec3 = normalize( input.vBitangent ); + #if ${defines.DOUBLE_SIDED} + tangent = tangent * faceDirection; + bitangent = bitangent * faceDirection; + #endif + #if ${defines.TANGENTSPACE_NORMALTEXTURE || defines.USE_CLEARCOAT_NORMALTEXTURE} + let vTBN:mat3x3 = mat3x3( tangent, bitangent, normal ); + #endif + #endif + #endif + + let geometryNormal:vec3 = normal; - } // validated + #if ${defines.OBJECTSPACE_NORMALTEXTURE} + normal =textureSample(normalTexture, baseSampler, input.vUv).xyz * 2.0 - 1.0; + #if ${defines.FLIP_SIDED} + normal = - normal; + #endif + #if ${defines.DOUBLE_SIDED} + normal = normal * faceDirection; + #endif - fn F_Schlick( f0:vec3, dotVH:f32 )->vec3 { + normal = normalize(materialUniform.normalMatrix * normal ); - // Original approximation by Christophe Schlick '94 - // float fresnel = pow( 1.0 - dotVH, 5.0 ); + #elif ${defines.TANGENTSPACE_NORMALTEXTURE} + let tempMapN:vec3 =textureSample(normalTexture, baseSampler, input.vUv).xyz * 2.0 - 1.0; + let mapN:vec3 =tempMapN.xy *= materialUniform.normalScale; + #if ${defines.USE_TANGENT} + normal = normalize( vTBN * mapN ); + #else + normal = perturbNormal2Arb( - input.vViewPosition, normal, mapN, faceDirection ); + #endif - // Optimized variant (presented by Epic at SIGGRAPH '13) - // https://cdn2.unrealengine.com/Resources/files/2013SiggraphPresentationsNotes-26915738.pdf - let fresnel = exp2( ( - 5.55473 * dotVH - 6.98316 ) * dotVH ); - return ( 1.0 - f0 ) * fresnel + f0; + #elif ${defines.USE_BUMPTEXTURE} - } // validated + normal = perturbNormalArb( - input.vViewPosition, normal, dHdxy_fwd(), faceDirection ); + #endif - fn Schlick_to_F0(f:vec3, f90:f32, dotVH:f32 )->vec3 { - let x:f32 = clamp( 1.0 - dotVH, 0.0, 1.0 ); - let x2:f32 = x * x; - let x5:f32 = clamp( x * x2 * x2, 0.0, 0.9999 ); + #if ${defines.USE_CLEARCOAT} + var clearcoatNormal:vec3 = geometryNormal; + #endif + #if ${defines.USE_CLEARCOAT_NORMALTEXTURE} + var clearcoatMapN:vec3 =textureSample(clearcoatNormalTexture, baseSampler, input.vUv).xyz * 2.0 - 1.0; + clearcoatMapN.xy *= materialUniform.clearcoatNormalScale; + #if ${defines.USE_TANGENT} + clearcoatNormal = normalize( vTBN * clearcoatMapN ); + #else + clearcoatNormal = perturbNormal2Arb( - input.vViewPosition, clearcoatNormal, clearcoatMapN, faceDirection ); + #endif + #endif + #if ${defines.USE_EMISSIVETEXTURE} + let emissiveColor:vec4 =textureSample(emissiveTexture, baseSampler, input.vUv); + totalEmissiveRadiance *= emissiveColor.rgb; + #endif - return ( f - vec3( f90 ) * x5 ) / ( 1.0 - x5 ); - } - fn V_GGX_SmithCorrelated( alpha:f32, dotNL:f32,dotNV:f32 )->f32 { + var material:PhysicalMaterial; + material.diffuseColor = diffuseColor.rgb * ( 1.0 - metalnessFactor ); + let dxy:vec3 = max( abs( dpdx( geometryNormal ) ), abs( dpdy( geometryNormal ) ) ); + let geometryRoughness:f32 = max( max( dxy.x, dxy.y ), dxy.z ); + material.roughness = max( roughnessFactor, 0.0525 ); + material.roughness += geometryRoughness; + material.roughness = min( material.roughness, 1.0 ); - let a2 :f32= pow2( alpha ); + #if ${defines.IOR} + material.ior = materialUniform.ior; + #if ${defines.SPECULAR} + let specularIntensityFactor:f32 = materialUniform.specularIntensity; + let specularColorFactor:vec3 = materialUniform.specularColor; + #if ${defines.USE_SPECULARINTENSITYTEXTURE} + specularIntensityFactor *=textureSample(specularIntensityTexture, baseSampler, input.vUv).a; + #endif - let gv:f32 = dotNL * sqrt( a2 + ( 1.0 - a2 ) * pow2( dotNV ) ); - let gl:f32 = dotNV * sqrt( a2 + ( 1.0 - a2 ) * pow2( dotNL ) ); + #if ${defines.USE_SPECULARCOLORTEXTURE} + specularColorFactor *=textureSample(specularColorTexture, baseSampler, input.vUv).rgb; + #endif - return 0.5 / max((gv + gl), 0.000000001 ); + material.specularF90 = mix( specularIntensityFactor, 1.0, metalnessFactor ); + #else + let specularIntensityFactor:f32 = 1.0; + let specularColorFactor:vec3 = vec3( 1.0 ); + material.specularF90 = 1.0; + #endif + material.specularColor = mix( min( pow2( ( material.ior - 1.0 ) / ( material.ior + 1.0 ) ) * specularColorFactor, vec3( 1.0 ) ) * specularIntensityFactor, diffuseColor.rgb, metalnessFactor ); + #else + material.specularColor = mix( vec3( 0.04 ), diffuseColor.rgb, metalnessFactor ); + material.specularF90 = 1.0; + #endif + #if ${defines.USE_CLEARCOAT} + material.clearcoat = materialUniform.clearcoat; + material.clearcoatRoughness = materialUniform.clearcoatRoughness; + material.clearcoatF0 = vec3( 0.04 ); + material.clearcoatF90 = 1.0; + #if ${defines.USE_CLEARCOATTEXTURE} + material.clearcoat *=textureSample(clearcoatTexture, baseSampler, input.vUv).x; + #endif + #if ${defines.USE_CLEARCOAT_ROUGHNESSTEXTURE} + material.clearcoatRoughness *=textureSample(clearcoatRoughnessTexture, baseSampler, input.vUv).y; + #endif + material.clearcoat = saturate( material.clearcoat ); + material.clearcoatRoughness = max( material.clearcoatRoughness, 0.0525 ); + material.clearcoatRoughness += geometryRoughness; + material.clearcoatRoughness = min( material.clearcoatRoughness, 1.0 ); + #endif + #if ${defines.USE_IRIDESCENCE} + material.iridescence = materialUniform.iridescence; + material.iridescenceIOR = materialUniform.iridescenceIOR; + #if ${defines.USE_IRIDESCENCETEXTURE} + material.iridescence *=textureSample(iridescenceTexture, baseSampler, input.vUv).r; + #endif + #if ${defines.USE_IRIDESCENCE_THICKNESSTEXTURE} + material.iridescenceThickness = (materialUniform.iridescenceThicknessMaximum - materialUniform.iridescenceThicknessMinimum) * textureSample(iridescenceThicknessTexture, baseSampler, input.vUv).g + materialUniform.iridescenceThicknessMinimum; + #else + material.iridescenceThickness = materialUniform.iridescenceThicknessMaximum; + #endif + #endif + #if ${defines.USE_SHEEN} + material.sheenColor = materialUniform.sheenColor; + #if ${defines.USE_SHEENCOLORTEXTURE} + material.sheenColor *=textureSample(sheenColorTexture, baseSampler, input.vUv).rgb; + #endif + material.sheenRoughness = clamp( materialUniform.sheenRoughness, 0.07, 1.0 ); + #if ${defines.USE_SHEENROUGHNESSTEXTURE} + material.sheenRoughness *=textureSample(sheenRoughnessTexture, baseSampler, input.vUv).a; + #endif + #endif + + var geometry:GeometricContext; + geometry.position = - input.vViewPosition; + geometry.normal = normal; + // geometry.viewDir = ( isOrthographic ) ? vec3( 0, 0, 1 ) : normalize( input.vViewPosition ); + geometry.viewDir = normalize( input.vViewPosition); - } - fn D_GGX( alpha:f32, dotNH:f32 )->f32 { + #if ${defines.USE_CLEARCOAT} + geometry.clearcoatNormal = clearcoatNormal; + #endif - let a2:f32 = pow2( alpha ); + #if ${defines.USE_IRIDESCENCE} + let dotNVi:f32 = saturate( dot( normal, geometry.viewDir ) ); + if ( material.iridescenceThickness == 0.0 ) { + material.iridescence = 0.0; + } + else { + material.iridescence = saturate( material.iridescence ); + } + if ( material.iridescence > 0.0 ) { + material.iridescenceFresnel = evalIridescence( 1.0, material.iridescenceIOR, dotNVi, material.iridescenceThickness, material.specularColor ); + material.iridescenceF0 = Schlick_to_F0( material.iridescenceFresnel, 1.0, dotNVi ); + } + #endif - let denom:f32 = pow2( dotNH ) * ( a2 - 1.0 ) + 1.0; // avoid alpha = 0 with dotNH = 1 + var iblIrradiance:vec3 = vec3( 0.0 ); + var irradiance:vec3 = getAmbientLightIrradiance(commonLightsParms.ambient); + //irradiance += getLightProbeIrradiance( lightProbe, geometry.normal,systemUniform.viewMatrix ); - return RECIPROCAL_PI * a2 / pow2( denom ); + var radiance:vec3 = vec3( 0.0 ); + var clearcoatRadiance:vec3 = vec3( 0.0 ); - } - fn BRDF_GGX( lightDir:vec3, viewDir:vec3, normal:vec3, f0:vec3, roughness:f32 )->vec3 { + #if ${defines.USE_LIGHTTEXTURE} + let lightMapTexel:vec4 =textureSample(lightTexture, baseSampler, input.vUv2); + let lightMapIrradiance:vec3 = lightMapTexel.rgb * materialUniform.lightTextureIntensity; + irradiance += lightMapIrradiance; + #endif + //&& defines.STANDARD&&defines.ENVTEXTURE_TYPE_CUBE_UV + #if ${defines.USE_ENVTEXTURE} + iblIrradiance += getIBLIrradiance( geometry.normal,baseSampler,systemUniform.viewMatrix ); + #endif + #if ${defines.USE_ENVTEXTURE} + radiance += getIBLRadiance( geometry.viewDir,baseSampler,systemUniform.viewMatrix, geometry.normal, materialUniform.roughness ); + #if ${defines.USE_CLEARCOAT} + clearcoatRadiance += getIBLRadiance( geometry.viewDir,baseSampler,systemUniform.viewMatrix, geometry.clearcoatNormal, material.clearcoatRoughness ); + #endif + #endif + //直接光照 + let dirReflectedLight:ReflectedLight= parseLights(geometry,material); + reflectedLight.directDiffuse +=dirReflectedLight.directDiffuse; + reflectedLight.directSpecular +=dirReflectedLight.directSpecular; + //间接漫反射 + let indirectDiffuseLight:ReflectedLight= RE_IndirectDiffuse_Physical( irradiance, geometry, material); + reflectedLight.directDiffuse +=indirectDiffuseLight.indirectDiffuse; + reflectedLight.directSpecular +=indirectDiffuseLight.indirectSpecular; + //间接高光 + let indirectSpecularLight:ReflectedLight=RE_IndirectSpecular_Physical( radiance, iblIrradiance, clearcoatRadiance, geometry, material); + reflectedLight.directDiffuse +=indirectSpecularLight.indirectDiffuse; + reflectedLight.directSpecular +=indirectSpecularLight.indirectSpecular; + //环境光遮蔽 + #if ${defines.USE_AOTEXTURE} + let ambientOcclusion:f32 = (textureSample(aoTexture, baseSampler, input.vUv2).r - 1.0 ) * materialUniform.aoTextureIntensity + 1.0; - let alpha:f32 = pow2( roughness ); // UE4's roughness + reflectedLight.indirectDiffuse *= ambientOcclusion; + //&&defines.STANDARD + #if ${defines.USE_ENVTEXTURE} + let dotNV:f32 = saturate( dot( geometry.normal, geometry.viewDir ) ); + reflectedLight.indirectSpecular *= computeSpecularOcclusion( dotNV, ambientOcclusion, material.roughness ); + #endif + #endif - let halfDir = normalize( lightDir + viewDir ); + var totalDiffuse:vec3 = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse; + var totalSpecular:vec3 = reflectedLight.directSpecular + reflectedLight.indirectSpecular; + //透射 + #if ${defines.USE_TRANSMISSION} + material.transmission = materialUniform.transmission; + material.transmissionAlpha = 1.0; + material.thickness = materialUniform.thickness; + material.attenuationDistance = materialUniform.attenuationDistance; + material.attenuationColor = materialUniform.attenuationColor; + #if ${defines.USE_TRANSMISSIONTEXTURE} + material.transmission *=textureSample(transmissionTexture, baseSampler, input.vUv).r; + #endif + #if ${defines.USE_THICKNESSTEXTURE} + material.thickness *=textureSample(thicknessTexture, baseSampler, input.vUv).g; + #endif + let pos:vec3 = vWorldPosition; + let v:vec3 = normalize( cameraPosition - pos ); + let n:vec3 = inverseTransformDirection( normal, systemUniform.viewMatrix ); + let transmission:vec4 = getIBLVolumeRefraction( + n, v, material.roughness, material.diffuseColor, material.specularColor, material.specularF90, pos, modelMatrix, systemUniform.viewMatrix, systemUniform.projectionMatrix, material.ior, material.thickness, material.attenuationColor, material.attenuationDistance ); + material.transmissionAlpha = mix( material.transmissionAlpha, transmission.a, material.transmission ); + totalDiffuse = mix( totalDiffuse, transmission.rgb, material.transmission ); + #endif - let dotNL:f32 = saturate( dot( normal, lightDir ) ); - let dotNV:f32 = saturate( dot( normal, viewDir ) ); - let dotNH:f32 = saturate( dot( normal, halfDir ) ); - let dotVH:f32 = saturate( dot( lightDir, halfDir ) ); + let outgoingLight:vec3 = totalDiffuse + totalSpecular + totalEmissiveRadiance; - let F = F_Schlick( f0, dotVH ); + #if ${defines.USE_SHEEN} + let sheenEnergyComp:f32 = 1.0 - 0.157 * max3( material.sheenColor ); + outgoingLight = outgoingLight * sheenEnergyComp + sheenSpecular; + #endif - let V = V_GGX_SmithCorrelated( alpha, dotNL, dotNV ); + #if ${defines.USE_CLEARCOAT} + let dotNVcc:f32 = saturate( dot( geometry.clearcoatNormal, geometry.viewDir ) ); + let Fcc:vec3 = F_Schlick( material.clearcoatF0, material.clearcoatF90, dotNVcc ); + outgoingLight = outgoingLight * ( 1.0 - material.clearcoat * Fcc ) + clearcoatSpecular * material.clearcoat; + #endif - let D = D_GGX( alpha, dotNH ); + #if ${defines.USE_TRANSMISSION} + diffuseColor.a *= material.transmissionAlpha + 0.1; + #endif - return F * ( V * D ); + var finnalColor:vec4; + finnalColor = vec4( outgoingLight, diffuseColor.a ); + #if ${defines.TONE_MAPPING} + finnalColor.rgb = toneMapping( finnalColor.rgb,materialUniform.toneMappingExposure ); + #endif - } - fn direct_Physical( directLight:IncidentLight, geometry:Geometry,material:PhysicalMaterial)->ReflectedLight { - var reflectedLight:ReflectedLight; - let dotNL:f32 = saturate(dot( geometry.normal,geometry.viewDir)); - let irradiance:vec3 = dotNL * directLight.color*3.1415926; - reflectedLight.directSpecular = irradiance * BRDF_GGX( directLight.direction, geometry.viewDir, geometry.normal, material.specularColor, material.roughness ); - reflectedLight.directDiffuse = irradiance * BRDF_Lambert( material.diffuseColor ); - return reflectedLight; - } - `; - }, - phongFunction: function (e) { - return "\n fn G_BlinnPhong_Implicit( )->f32 {\n\n // geometry term is (n dot l)(n dot v) / 4(n dot l)(n dot v)\n return 0.25;\n\n }\n fn D_BlinnPhong( shininess:f32, dotNH:f32 )->f32 {\n\n return RECIPROCAL_PI * ( shininess * 0.5 + 1.0 ) * pow(dotNH, shininess);\n\n }\n fn BRDF_BlinnPhong( lightDir:vec3, viewDir:vec3, normal:vec3, specularColor:vec3, shininess:f32 )->vec3 {\n\n let halfDir = normalize( lightDir + viewDir );\n\n let dotNH:f32 = saturate( dot( normal, halfDir ) );\n let dotVH:f32 = saturate( dot( viewDir, halfDir ) );\n\n let F = F_Schlick( specularColor, 1.0, dotVH );\n\n let G:f32 = G_BlinnPhong_Implicit( );\n\n let D = D_BlinnPhong( shininess, dotNH );\n\n return F * ( G * D );\n\n } \n fn RE_Direct_BlinnPhong( directLight:IncidentLight,geometry:GeometricContext, material:BlinnPhongMaterial )->ReflectedLight{\n var reflectedLight:ReflectedLight; \n let dotNL:f32 = saturate(dot(geometry.normal, directLight.direction));\n let irradiance:vec3 = dotNL*directLight.color;\n\n reflectedLight.directDiffuse= irradiance * BRDF_Lambert( material.diffuseColor );\n\n reflectedLight.directSpecular= irradiance * BRDF_BlinnPhong( directLight.direction, geometry.viewDir, geometry.normal, material.specularColor, material.specularShininess ) * material.specularStrength;\n return reflectedLight;\n }\n fn RE_IndirectDiffuse_BlinnPhong( irradiance:vec3, geometry:GeometricContext, material:BlinnPhongMaterial)->ReflectedLight {\n var reflectedLight:ReflectedLight; \n reflectedLight.indirectDiffuse += irradiance * BRDF_Lambert( material.diffuseColor );\n return reflectedLight;\n }\n "; - }, - phongUtils: function (e) { - return "\n struct BlinnPhongMaterial {\n diffuseColor:vec3,\n specularColor:vec3,\n specularShininess:f32,\n specularStrength:f32,\n };\n const RECIPROCAL_PI:f32= 0.3183098861837907;\n fn pow2( x:f32 )->f32 { return x*x; }\n fn pow3( x:f32 )->f32 { return x*x*x; }\n fn pow4(x:f32 )->f32 { let x2 = x*x; return x2*x2; }\n fn max3( v:vec3 )->f32 { return max( max( v.x, v.y ), v.z ); }\n fn average(v:vec3 )->f32 { \n let result=vec3( 0.3333333, 0.3333333, 0.3333333);\n return dot( v,result ); \n }\n "; - }, - lightCommon: function (e) { - return Di` - struct ReflectedLight { - directDiffuse:vec3, - directSpecular:vec3, - indirectDiffuse:vec3, - indirectSpecular:vec3, - }; - struct Geometry { - position: vec3, - normal: vec3, - viewDir: vec3, - #if ${e.USE_CLEARCOAT} - vec3 clearcoatNormal; + finnalColor = linearToOutputTexel( finnalColor); + + #if ${defines.PREMULTIPLIED_ALPHA} + finnalColor.rgb *= finnalColor.a; #endif - }; - fn getAmbientLightIrradiance(ambientLightColor: vec3) -> vec3 { - let irradiance = ambientLightColor; - return irradiance; - } - fn getDistanceAttenuation(lightDistance: f32, cutoffDistance: f32, decayExponent: f32) -> f32 { - if (cutoffDistance > 0.0 && decayExponent > 0.0) { - let x:f32 = saturate(- lightDistance / cutoffDistance + 1.0); - return pow(x, decayExponent); - } - return 1.0; - } - fn getSpotAttenuation(coneCosine: f32, penumbraCosine: f32, angleCosine: f32) -> f32 { - return smoothstep(coneCosine, penumbraCosine, angleCosine); - } - fn shGetIrradianceAt( normal:vec3, shCoefficients:array,9>)->vec3 { - let x:f32 = normal.x; - let y:f32 = normal.y; - let z:f32 = normal.z; - var result:vec3 = shCoefficients[ 0 ] * 0.886227; - result += shCoefficients[ 1 ] * 2.0 * 0.511664 * y; - result += shCoefficients[ 2 ] * 2.0 * 0.511664 * z; - result += shCoefficients[ 3 ] * 2.0 * 0.511664 * x; - result += shCoefficients[ 4 ] * 2.0 * 0.429043 * x * y; - result += shCoefficients[ 5 ] * 2.0 * 0.429043 * y * z; - result += shCoefficients[ 6 ] * ( 0.743125 * z * z - 0.247708 ); - result += shCoefficients[ 7 ] * 2.0 * 0.429043 * x * z; - result += shCoefficients[ 8 ] * 0.429043 * ( x * x - y * y ); - return result; - } - fn inverseTransformDirection( dir:vec3, matrix:mat4x4 )->vec3 { - return normalize( ( vec4( dir, 0.0 ) * matrix ).xyz ); - } - `; - }, - pbrStruct: function (e) { - return Di` - struct MaterialUniform{ + #if ${defines.DITHERING} + finnalColor.rgb = dithering( finnalColor.rgb ); + #endif + return finnalColor; + }`; +} - modelMatrix: mat4x4, - - diffuse:vec3, - - opacity:f32, - - normalMatrix: mat3x3, - - emissive:vec3, - - roughness:f32, - - metalness:f32, - - #if ${e.TONE_MAPPING} - toneMappingExposure:f32, - #endif - - #if ${e.SPECULAR} - - specularColor:vec3, - - specularIntensity:f32, - #endif - - #if ${e.USE_SHEEN} - - sheenColor:vec3, - - sheenRoughness:f32, - #endif +function pbrVert(defines) { + return wgslParseDefines` + #include + struct VertexOutput { + @builtin(position) position: vec4, + @location(0) vUv: vec2, + @location(1) vViewPosition: vec3, // Vector from vertex to camera. + @location(2) vWorldPosition: vec3, + @location(3) vNormal: vec3, + // 可选 + #if ${defines.USE_LIGHTTEXTURE || defines.USE_AOTEXTURE} + @location(${defines.vUv2OutLocation}) vUv2: vec2, + #endif - #if ${e.USE_TRANSMISSION} - - attenuationColor:vec3, - - transmission:f32, - - transmissionSamplerSize:vec2, - - thickness:f32, - - attenuationDistance:f32, - - #endif + #if ${defines.USE_COLOR_ALPHA} + @location(${defines.vColorOutLocation}) vColor: vec4, + #elif ${defines.USE_COLOR || defines.USE_INSTANCING_COLOR} + @location(${defines.vColorOutLocation}) vColor: vec3, + #endif - #if ${e.USE_SKINNING} - - bindMatrix:mat4x4, - - bindMatrixInverse:mat4x4, - - boneTextureSize:u32, - #endif + #if ${defines.USE_TANGENT} + @location(${defines.vTangentOutLocation}) vTangent: vec3, + @location(${defines.vBitangentOutLocation}) vBitangent: vec3, + #endif + }; + struct GlobalUniform { + projectionMatrix: mat4x4, + viewMatrix: mat4x4, + inverseViewMatrix: mat4x4, + cameraPosition: vec3, + }; - #if ${e.USE_NORMALTEXTURE} - normalScale:vec2, - #endif - - #if ${e.IOR} - ior:f32, - #endif - - #if ${e.USE_CLEARCOAT} - - #if ${e.USE_CLEARCOAT_NORMALTEXTURE} - clearcoatNormalScale:vec2, - #endif - - clearcoat:f32, - - clearcoatRoughness:f32, - #endif - - #if ${e.USE_IRIDESCENCE} - iridescence:f32, - - iridescenceIOR:f32, - - iridescenceThicknessMinimum:f32, - - iridescenceThicknessMaximum:f32, - - #endif + //texture and sampler + // @group(0) @binding(${defines.samplerBinding}) var baseSampler: sampler; + #if ${defines.USE_SKINNING} + //uniform highp sampler2D boneTexture; + @group(0) @binding(${defines.boneTextureBinding}) var boneTexture: texture_2d; + #endif - #if ${e.USE_AOTEXTURE} - aoTextureIntensity:f32, - #endif + #if ${defines.USE_DISPLACEMENTTEXTURE} + //uniform sampler2D displacementMap; + @group(0) @binding(${defines.displacementTextureBinding}) var displacementMap: texture_2d; + #endif - #if ${e.USE_LIGHTTEXTURE} - lightTextureIntensity:f32, - #endif - - #if ${e.USE_ENVTEXTURE} - envTextureIntensity:f32, - - flipEnvTexture:f32, - #endif + #if ${defines.MORPHTARGETS_TEXTURE} + //uniform sampler2DArray morphTargetsTexture; + @group(0) @binding(${defines.morphTargetsTextureBinding}) var morphTargetsTexture: texture_2d_array; + #endif - #if ${e.USE_BUMPTEXTURE} - bumpScale:f32; - #endif + struct VertexInput { + @location(0) position: vec3, - #if ${e.USE_DISPLACEMENTTEXTURE} - - displacementScale:f32, - - displacementBias:f32, - #endif - - #if ${e.USE_MORPHTARGETS} - - morphTargetBaseInfluence:f32, - - #if ${e.MORPHTARGETS_TEXTURE} - - morphTargetsTextureSize:vec2, - - MORPHTARGETS_COUNT:u32, - - #endif - - morphTargetInfluences:array, - - #endif - } + @location(1) normal: vec3, - `; - }, - pbrFunction: function (e) { - return Di` + @location(2) uv: vec2, + #if ${defines.USE_LIGHTTEXTURE || defines.USE_AOTEXTURE} + @location(${defines.uv2Location}) uv2:vec2, + #endif + #if ${defines.USE_INSTANCING} + @location(${defines.instanceMatrixLocation}) instanceMatrix:mat4x4, + #endif + #if ${defines.USE_INSTANCING_COLOR} + @location(${defines.instanceColorLocation}) instanceColor:vec3, + #endif + + #if ${defines.USE_TANGENT} + @location(${defines.tangentLocation}) tangent:vec4, + #endif + #if ${defines.USE_COLOR_ALPHA} + @location(${defines.colorLocation}) color:vec4, + #elif ${defines.USE_COLOR} + @location(${defines.colorLocation}) color:vec3, + #endif - #if ${e.DITHERING} - fn dithering(color:vec3 )->vec3 { - let grid_position:f32 = rand( gl_FragCoord.xy ); - let dither_shift_RGB:vec3 = vec3( 0.25 / 255.0, -0.25 / 255.0, 0.25 / 255.0 ); - dither_shift_RGB = mix( 2.0 * dither_shift_RGB, -2.0 * dither_shift_RGB, grid_position ); - return color + dither_shift_RGB; - } - #endif + #if ${defines.USE_MORPHTARGETS && !defines.MORPHTARGETS_TEXTURE} + @location(${defines.morphTarget0Location}) morphTarget0:vec3, - #if ${e.USE_IRIDESCENCE} - fn BRDF_GGX_Iridescence( lightDir:vec3, viewDir:vec3,normal:vec3, f0:vec3, f90:f32,iridescence:f32, iridescenceFresnel:vec3,roughness:f32 )->vec3 { - let alpha:f32 = pow2( roughness ); - let halfDir:vec3 = normalize( lightDir + viewDir ); - let dotNL:f32 = saturate( dot( normal, lightDir ) ); - let dotNV:f32 = saturate( dot( normal, viewDir ) ); - let dotNH:f32 = saturate( dot( normal, halfDir ) ); - let dotVH:f32 = saturate( dot( viewDir, halfDir ) ); - let F:vec3 = mix( F_Schlick( f0, f90, dotVH ), iridescenceFresnel, iridescence ); - let V:f32 = V_GGX_SmithCorrelated( alpha, dotNL, dotNV ); - let D:f32 = D_GGX( alpha, dotNH ); - return F * ( V * D ); - } - #endif + @location(${defines.morphTarget1Location}) morphTarget1:vec3, - #if ${e.USE_SHEEN} - fn D_Charlie( roughness:f32,dotNH:f32 )->f32 { - let alpha:f32 = pow2( roughness ); - let invAlpha:f32 = 1.0 / alpha; - let cos2h:f32 = dotNH * dotNH; - let sin2h:f32 = max( 1.0 - cos2h, 0.0078125 ); - return ( 2.0 + invAlpha ) * pow( sin2h, invAlpha * 0.5 ) / ( 2.0 * PI ); - } - fn V_Neubelt( dotNV:f32, dotNL:f32 )->f32 { - return saturate( 1.0 / ( 4.0 * ( dotNL + dotNV - dotNL * dotNV ) ) ); + @location(${defines.morphTarget2Location}) morphTarget2:vec3, + + @location(${defines.morphTarget3Location}) morphTarget3:vec3, + #if ${defines.USE_MORPHNORMALS} + @location(${defines.morphNormal0Location}) morphNormal0:vec3, + + @location(${defines.morphNormal1Location}) morphNormal1:vec3, + + @location(${defines.morphNormal2Location}) morphNormal2:vec3, + + @location(${defines.morphNormal3Location}) morphNormal3:vec3, + #else + @location(${defines.morphTarget4Location}) morphTarget4:vec3, + + @location(${defines.morphTarget5Location}) morphTarget5:vec3, + + @location(${defines.morphTarget6Location}) morphTarget6:vec3, + + @location(${defines.morphTarget7Location}) morphTarget7:vec3, + #endif + #endif + #if ${defines.USE_SKINNING} + @location(${defines.skinIndexLocation}) skinIndex:vec4, + @location(${defines.skinWeightLocation}) skinWeight:vec4, + #endif + } + + #if ${defines.MORPHTARGETS_TEXTURE} + fn getMorph( vertexIndex:u32, morphTargetIndex:u32,offset:u32 )->vec4 { + let texelIndex:u32 = vertexIndex * MORPHTARGETS_TEXTURE_STRIDE + offset; + let y:u32 = texelIndex / materialUniform.morphTargetsTextureSize.x; + let x:u32 = texelIndex - y * materialUniform.morphTargetsTextureSize.x; + let morphUV:vec3 = vec3( x, y, morphTargetIndex ); + //textureLoad + //return texelFetch( morphTargetsTexture, morphUV, 0 ); + return textureLoad( morphTargetsTexture, morphUV, 0 ); } - fn BRDF_Sheen(lightDir:vec3, viewDir:vec3, normal:vec3,sheenColor:vec3,sheenRoughness:f32 )->vec3 { - let halfDir:vec3 = normalize( lightDir + viewDir ); - let dotNL:f32 = saturate( dot( normal, lightDir ) ); - let dotNV:f32 = saturate( dot( normal, viewDir ) ); - let dotNH:f32 = saturate( dot( normal, halfDir ) ); - let D:f32 = D_Charlie( sheenRoughness, dotNH ); - let V:f32 = V_Neubelt( dotNV, dotNL ); - return sheenColor * ( D * V ); + #endif + #if ${defines.USE_SKINNING} + fn getBoneMatrix( i:f32 )->mat4x4 { + let j:f32 = i * 4.0; + let x:f32 = j%f32( materialUniform.boneTextureSize ); + let y:f32 = floor( j / f32( materialUniform.boneTextureSize ) ); + let dx:f32 = 1.0 / f32( materialUniform.boneTextureSize ); + let dy:f32 = 1.0 / f32( materialUniform.boneTextureSize ); + y = dy * ( y + 0.5 ); + + let v1:vec4 = textureSample(boneTexture, baseSampler, vec2( dx * ( x + 0.5 ), y ) ); + let v2:vec4 = textureSample(boneTexture, baseSampler, vec2( dx * ( x + 1.5 ), y ) ); + let v3:vec4 = textureSample(boneTexture, baseSampler, vec2( dx * ( x + 2.5 ), y ) ); + let v4:vec4 = textureSample(boneTexture, baseSampler, vec2( dx * ( x + 3.5 ), y ) ); + let bone:mat4x4 = mat4x4( v1, v2, v3, v4 ); + return bone; } #endif - #if ${e.USE_IRIDESCENCE} - let XYZ_TO_REC709: mat3x3 = mat3x3( - 3.2404542, -0.9692660, 0.0556434, -1.5371385, 1.8760108, -0.2040259, -0.4985314, 0.0415560, 1.0572252 - ); - fn Fresnel0ToIor( fresnel0:vec3 )->vec3 { - let sqrtF0:vec3 = sqrt( fresnel0 ); - return ( vec3( 1.0 ) + sqrtF0 ) / ( vec3( 1.0 ) - sqrtF0 ); - } - fn IorToFresnel0(transmittedIor:vec3,incidentIor:f32 )->vec3 { - return pow2Vector( ( transmittedIor - vec3( incidentIor ) ) / ( transmittedIor + vec3( incidentIor ) ) ); - } - fn IorToFresnel0(transmittedIor:f32, incidentIor:f32 )->f32 { - return pow2Vector( ( transmittedIor - incidentIor ) / ( transmittedIor + incidentIor )); - } - fn evalSensitivity(OPD:f32,shift:vec3 )->vec3 { - let phase:f32 = 2.0 * PI * OPD * 1.0e-9; - let val:vec3 = vec3( 5.4856e-13, 4.4201e-13, 5.2481e-13 ); - let pos:vec3 = vec3( 1.6810e+06, 1.7953e+06, 2.2084e+06 ); - let vart:vec3 = vec3( 4.3278e+09, 9.3046e+09, 6.6121e+09 ); - let xyz:vec3 = val * sqrt( 2.0 * PI * vart ) * cos( pos * phase + shift ) * exp( - pow2( phase ) * vart ); - xyz.x += 9.7470e-14 * sqrt( 2.0 * PI * 4.5282e+09 ) * cos( 2.2399e+06 * phase + shift[ 0 ] ) * exp( - 4.5282e+09 * pow2( phase ) ); - xyz /= 1.0685e-7; - let rgb:vec3 = XYZ_TO_REC709 * xyz; - return rgb; - } - fn evalIridescence(outsideIOR:f32, eta2:f32,cosTheta1:f32,thinFilmThickness:f32,baseF0:vec3 )->vec3 { - var I:vec3; - let iridescenceIOR:f32 = mix( outsideIOR, eta2, smoothstep( 0.0, 0.03, thinFilmThickness ) ); - let sinTheta2Sq:f32 = pow2( outsideIOR / iridescenceIOR ) * ( 1.0 - pow2( cosTheta1 ) ); - let cosTheta2Sq:f32 = 1.0 - sinTheta2Sq; - if ( cosTheta2Sq < 0.0 ) { - return vec3( 1.0 ); + @binding(0) @group(0) var materialUniform : MaterialUniform; + @binding(0) @group(1) var globalUniform : GlobalUniform; + @vertex + fn main(input:VertexInput)->VertexOutput { + var vertexOutput:VertexOutput; + #if ${defines.USE_TEXTURE} + vertexOutput.vUv = input.uv; + #endif + #if ${defines.USE_LIGHTTEXTURE || defines.USE_AOTEXTURE} + vertexOutput.vUv2 input.uv2; + #endif + #if ${defines.USE_COLOR_ALPHA} + vertexOutput.vColor = vec4( 1.0 ); + #elif ${defines.USE_COLOR || defines.USE_INSTANCING_COLOR} + vertexOutput.vColor = vec3( 1.0 ); + #endif + #if ${defines.USE_COLOR} + vertexOutput.vColor *= input.color; + #endif + #if ${defines.USE_INSTANCING_COLOR} + vertexOutput.vColor.xyz *= input.instanceColor.xyz; + #endif + #if ${defines.USE_MORPHCOLORS && defines.MORPHTARGETS_TEXTURE} + vertexOutput.vColor *= materialUniform.morphTargetBaseInfluence; + for (let i : u32 = 0u; i < materialUniform.MORPHTARGETS_COUNT; i = i + 1u ) { + #if ${defines.USE_COLOR_ALPHA} + if ( materialUniform.morphTargetInfluences[ i ] ! = 0.0 ) vertexOutput.vColor += getMorph( gl_VertexID, i, 2 ) * materialUniform.morphTargetInfluences[ i ]; + #elif ${defines.USE_COLOR} + if ( materialUniform.morphTargetInfluences[ i ] ! = 0.0 ) vertexOutput.vColor += getMorph( gl_VertexID, i, 2 ).rgb * materialUniform.morphTargetInfluences[ i ]; + #endif } - let cosTheta2:f32 = sqrt( cosTheta2Sq ); - let R0:f32 = IorToFresnel0( iridescenceIOR, outsideIOR ); - let R12:f32 = F_Schlick( R0, 1.0, cosTheta1 ); - let R21:f32 = R12; - let T121:f32 = 1.0 - R12; - let phi12:f32 = 0.0; - if ( iridescenceIOR < outsideIOR ) phi12 = PI; - let phi21:f32 = PI - phi12; - let baseIOR:vec3 = Fresnel0ToIor( clamp( baseF0, 0.0, 0.9999 ) ); - let R1:vec3 = IorToFresnel0( baseIOR, iridescenceIOR ); - let R23:vec3 = F_Schlick( R1, 1.0, cosTheta2 ); - let phi23:vec3 = vec3( 0.0 ); - if ( baseIOR[ 0 ] < iridescenceIOR ) phi23[ 0 ] = PI; - if ( baseIOR[ 1 ] < iridescenceIOR ) phi23[ 1 ] = PI; - if ( baseIOR[ 2 ] < iridescenceIOR ) phi23[ 2 ] = PI; - let OPD:f32 = 2.0 * iridescenceIOR * thinFilmThickness * cosTheta2; - let phi:vec3 = vec3( phi21 ) + phi23; - let R123:vec3 = clamp( R12 * R23, 1e-5, 0.9999 ); - let r123:vec3 = sqrt( R123 ); - let Rs:vec3 = pow2( T121 ) * R23 / ( vec3( 1.0 ) - R123 ); - let C0:vec3 = R12 + Rs; - I = C0; - let Cm:vec3 = Rs - T121; - for ( let m : u32 = 1;m <= 2; ++ m ) { - Cm *= r123; - Sm:vec3 = 2.0 * evalSensitivity( f32( m ) * OPD, f32( m ) * phi ); - I += Cm * Sm; - } - return max( I, vec3( 0.0 ) ); - } + #endif + var objectNormal:vec3 = vec3(input.normal); + #if ${defines.USE_TANGENT} + let objectTangent:vec3 = vec3( input.tangent.xyz ); + #endif + #if ${defines.USE_MORPHNORMALS} + objectNormal *= materialUniform.morphTargetBaseInfluence; + #if ${defines.MORPHTARGETS_TEXTURE} + for ( let i : u32 = 0u; i < materialUniform.MORPHTARGETS_COUNT; i = i + 1u) { + if ( materialUniform.morphTargetInfluences[ i ] ! = 0.0 ) objectNormal += getMorph( gl_VertexID, i, 1 ).xyz * materialUniform.morphTargetInfluences[ i ]; + } + #else + objectNormal += morphNormal0 * materialUniform.morphTargetInfluences[ 0 ]; + objectNormal += morphNormal1 * materialUniform.morphTargetInfluences[ 1 ]; + objectNormal += morphNormal2 * materialUniform.morphTargetInfluences[ 2 ]; + objectNormal += morphNormal3 * materialUniform.morphTargetInfluences[ 3 ]; + #endif + #endif + #if ${defines.USE_SKINNING} + let boneMatX:mat4x4 = getBoneMatrix( input.skinIndex.x ); + let boneMatY:mat4x4 = getBoneMatrix( input.skinIndex.y ); + let boneMatZ:mat4x4 = getBoneMatrix( input.skinIndex.z ); + let boneMatW:mat4x4 = getBoneMatrix( input.skinIndex.w ); + #endif + #if ${defines.USE_SKINNING} + let skinMatrix:mat4x4 = mat4x4( 0.0 ); + skinMatrix += input.skinWeight.x * boneMatX; + skinMatrix += input.skinWeight.y * boneMatY; + skinMatrix += input.skinWeight.z * boneMatZ; + skinMatrix += input.skinWeight.w * boneMatW; + skinMatrix = materialUniform.bindMatrixInverse * skinMatrix * materialUniform.bindMatrix; + objectNormal = vec4( skinMatrix * vec4( objectNormal, 0.0 ) ).xyz; + #if ${defines.USE_TANGENT} + objectTangent = vec4( skinMatrix * vec4( objectTangent, 0.0 ) ).xyz; + #endif + #endif + var transformedNormal:vec3 = objectNormal; + // transformedNormal+=vec3(0.0); + #if ${defines.USE_INSTANCING} + let m:mat3x3 = mat3x3( input.instanceMatrix ); + transformedNormal /= vec3( dot( m[ 0 ], m[ 0 ] ), dot( m[ 1 ], m[ 1 ] ), dot( m[ 2 ], m[ 2 ] ) ); + transformedNormal = m * transformedNormal; + #endif + transformedNormal = materialUniform.normalMatrix * transformedNormal; + #if ${defines.FLIP_SIDED} + transformedNormal = - transformedNormal; + #endif + #if ${defines.USE_TANGENT} + let transformedTangent:vec3 = (globalUniform.viewMatrix*materialUniform.modelMatrix * vec4( objectTangent, 0.0 ) ).xyz; + #if ${defines.FLIP_SIDED} + transformedTangent = - transformedTangent; + #endif + #endif + vertexOutput.vNormal = normalize( transformedNormal ); + #if ${defines.FLAT_SHADED} + #if ${defines.USE_TANGENT} + vTangent = normalize( transformedTangent ); + vBitangent = normalize( cross( vNormal, vTangent ) * input.tangent.w ); + #endif + #endif + let transformed:vec3 = vec3( input.position ); + #if ${defines.USE_MORPHTARGETS} + transformed *= materialUniform.morphTargetBaseInfluence; + #if ${defines.MORPHTARGETS_TEXTURE} + for ( let i : u32 = 0u; i < materialUniform.MORPHTARGETS_COUNT; i = i + 1u ) { + if ( materialUniform.morphTargetInfluences[ i ] ! = 0.0 ) transformed += getMorph( gl_VertexID, i, 0 ).xyz * morphTargetInfluences[ i ]; + } + #else + transformed += input.morphTarget0 * materialUniform.morphTargetInfluences[ 0 ]; + transformed += input.morphTarget1 * materialUniform.morphTargetInfluences[ 1 ]; + transformed += input.morphTarget2 * materialUniform.morphTargetInfluences[ 2 ]; + transformed += input.morphTarget3 * materialUniform.morphTargetInfluences[ 3 ]; + #if ${defines.USE_MORPHNORMALS} + transformed += input.morphTarget4 * materialUniform.morphTargetInfluences[ 4 ]; + transformed += input.morphTarget5 * materialUniform.morphTargetInfluences[ 5 ]; + transformed += input.morphTarget6 * materialUniform.morphTargetInfluences[ 6 ]; + transformed += input.morphTarget7 * materialUniform.morphTargetInfluences[ 7 ]; + #endif + #endif + #endif + #if ${defines.USE_SKINNING} + let skinVertex:vec4 = materialUniform.bindMatrix * vec4( transformed, 1.0 ); + let skinned:vec4 = vec4( 0.0 ); + skinned += boneMatX * skinVertex * input.skinWeight.x; + skinned += boneMatY * skinVertex * input.skinWeight.y; + skinned += boneMatZ * skinVertex * input.skinWeight.z; + skinned += boneMatW * skinVertex * input.skinWeight.w; + transformed = ( materialUniform.bindMatrixInverse * skinned ).xyz; + #endif + #if ${defines.USE_DISPLACEMENTTEXTURE} + transformed += normalize( objectNormal ) * (textureSample(displacementMap, baseSampler, vUv).x * materialUniform.displacementScale + materialUniform.displacementBias ); + #endif + var mvPosition:vec4 = vec4( transformed, 1.0 ); + #if ${defines.USE_INSTANCING} + mvPosition = input.instanceMatrix * mvPosition; + #endif + mvPosition = globalUniform.viewMatrix*materialUniform.modelMatrix * mvPosition; + vertexOutput.position = globalUniform.projectionMatrix * mvPosition; + vertexOutput.vViewPosition = - mvPosition.xyz/mvPosition.w; + #if ${defines.USE_ENVTEXTURE || defines.DISTANCE || defines.USE_TRANSMISSION} + var worldPosition:vec4 = vec4( transformed, 1.0 ); + #if ${defines.USE_INSTANCING} + worldPosition = input.instanceMatrix * worldPosition; + #endif + worldPosition = materialUniform.modelMatrix * worldPosition; + #endif + #if ${defines.USE_TRANSMISSION} + vertexOutput.vWorldPosition = worldPosition.xyz; + #endif + return vertexOutput; + } + `; +} + +function phongFrag(defines) { + return wgslParseDefines` + struct MaterialUniform { + modelMatrix: mat4x4, + color: vec3, + opacity:f32, + normalMatrix: mat4x4, + emissive:vec3, + shininess:f32, + specular:vec3, + } + #include + #include + #include + #include + @binding(${defines.phongBinding}) @group(0) var materialUniform : MaterialUniform; + @binding(${defines.cameraBinding}) @group(1) var systemUniform : SystemUniform; + @fragment + fn main(input:FragInput) -> @location(0) vec4 { + var totalEmissiveRadiance:vec3 = materialUniform.emissive; + var color:vec4; + #if${defines.USE_COLORTEXTURE} + color= vec4(textureSample(baseColorTexture, baseColorSampler, input.uv).rgb+materialUniform.color,materialUniform.opacity); + #else + color=vec4(materialUniform.color,materialUniform.opacity); + #endif + let V:vec3 = normalize( systemUniform.cameraPosition - input.worldPos); + #if ${defines.USE_NORMALTEXTURE} + let N:vec3 = getNormalByNormalTexture(input); + #else + let N:vec3 = getNormal(input); + #endif + var geometry:Geometry; + geometry.normal=N; + geometry.viewDir=V; + geometry.position=input.worldPos; + let lightColor:ReflectedLight=parseLights(geometry,materialUniform.shininess); + // var finnalColor:vec3=color.xyz + (lightColor.directDiffuse + lightColor.directSpecular + lightColor.ambient); + var finnalColor:vec3=color.xyz * (lightColor.directDiffuse + lightColor.directSpecular + lightColor.ambient); + + // finnalColor = lightColor.testColor.xyz; + + return vec4(finnalColor,color.a); + }`; +} + +function phongVert(defines) { + return wgslParseDefines` + struct MaterialUniform { + modelMatrix: mat4x4, + color: vec3, + opacity:f32, + normalMatrix: mat4x4, + emissive:vec3, + specular:vec3, + shininess:f32, + } + #include + #include + #include + @binding(${defines.phongBinding}) @group(0) var selfUniform : MaterialUniform; + @binding(${defines.cameraBinding}) @group(1) var systemUniform : SystemUniform; + @vertex + fn main(input: VertexInput) -> VertexOutput { + var output: VertexOutput; + #if ${defines.HAS_UV} + output.uv = input.uv; + #endif + let modelPos=selfUniform.modelMatrix *vec4(input.position,1.0); + output.worldPos = modelPos.xyz/modelPos.w; + let vNormalView = selfUniform.normalMatrix * vec4(input.normal,0.0); + output.normal = vNormalView.xyz; + output.view = systemUniform.cameraPosition.xyz - modelPos.xyz; + let viewPosition=systemUniform.viewMatrix * modelPos; + output.viewPosition = -viewPosition.xyz; + output.position = systemUniform.projectionMatrix * systemUniform.viewMatrix * modelPos; + return output; + }`; +} + +function point_fs(defines) { + return wgslParseDefines` + #include + struct SelfUniform { + modelMatrix: mat4x4, + color:vec3, + size:f32, + opacity:f32, + } + @binding(${defines.pointBinding}) @group(0) var selfUniform : SelfUniform; + #if${defines.USE_COLORTEXTURE} + @group(0) @binding(${defines.baseColorSamplerBinding}) var baseColorSampler: sampler; + @group(0) @binding(${defines.baseColorTextureBinding}) var baseColorTexture: texture_2d; + #endif + @fragment + fn main(input:PointFragInput) -> @location(0) vec4 { + var color:vec4=vec4(selfUniform.color,selfUniform.opacity); + #if${defines.USE_COLORTEXTURE} + color=textureSample(baseColorTexture, baseColorSampler, input.uv); #endif - const clearcoatSpecular:vec3 = vec3( 0.0 ); - const sheenSpecular:vec3 = vec3( 0.0 ); + #if${defines.HAS_COLOR} + color=vec4(input.color,selfUniform.opacity); + #endif + return color; + } + `; +} - fn IBLSheenBRDF( normal:vec3, viewDir:vec3, roughness:f32 )->f32 { - let dotNV:f32 = saturate( dot( normal, viewDir ) ); - let r2:f32 = roughness * roughness; - let a:f32 =select(-8.48 * r2 + 14.3 * roughness - 9.95,-339.2 * r2 + 161.4 * roughness - 25.9,roughness < 0.25); - //let a:f32 = roughness < 0.25 ? -339.2 * r2 + 161.4 * roughness - 25.9 : -8.48 * r2 + 14.3 * roughness - 9.95; - let b:f32=select(1.97 * r2 - 3.27 * roughness + 0.72,44.0 * r2 - 23.7 * roughness + 3.26, roughness < 0.25); - //let b:f32 = roughness < 0.25 ? 44.0 * r2 - 23.7 * roughness + 3.26 : 1.97 * r2 - 3.27 * roughness + 0.72; - //let DG:f32 = exp( a * dotNV + b ) + ( roughness < 0.25 ? 0.0 : 0.1 * ( roughness - 0.25 ) ); - let DG:f32 = exp( a * dotNV + b ) + select(0.1 * ( roughness - 0.25 ),0.0,roughness < 0.25); - return saturate( DG * RECIPROCAL_PI ); - } - fn DFGApprox( specularColor:vec3, roughness:f32,dotNV:f32 )->vec3 { - const c0:vec4 = vec4( - 1, - 0.0275, - 0.572, 0.022 ); - let c1:vec4 = vec4( 1, 0.0425, 1.04, - 0.04 ); - let r:vec4 = roughness * c0 + c1; - let a004:f32 = min( r.x * r.x, exp2( - 9.28 * dotNV ) ) * r.x + r.y; - let fab:vec2 = vec2( - 1.04, 1.04 ) * a004 + r.zw; - return specularColor * fab.x + fab.y; +function point_vs(defines) { + return wgslParseDefines` + #include + #include + #include + struct SelfUniform { + modelMatrix: mat4x4, + color:vec3, + size:f32, + opacity:f32, } - fn EnvironmentBRDF( normal:vec3,viewDir:vec3,specularColor:vec3, specularF90:f32,roughness:f32 )->vec3 { - let fab:vec2 = DFGApprox( normal, viewDir, roughness ); - return specularColor * fab.x + specularF90 * fab.y; + @binding(${defines.pointBinding}) @group(0) var selfUniform : SelfUniform; + @binding(${defines.cameraBinding}) @group(1) var systemUniform : SystemUniform; + @vertex + fn main(input: PointVertInput) -> PointVertOutput { + var output:PointVertOutput; + let mvPosition:vec4= ystemUniform.viewMatrix *selfUniform.modelMatrix*vec4(0.0,0.0,0.0, 1.0 ); + #if ${defines.HAS_UV} + output.uv=input.uv; + #endif + #if ${defines.HAS_COLOR} + output.color=input.color; + #endif + #if ${defines.HAS_SIZE} + output.size=input.size; + #endif + vec2 alignedPosition = input.position.xy* selfUniform.size; + mvPosition.xy += alignedPosition; + output.position = systemUniform.projectionMatrix * mvPosition; + return output; + } + `; +} + +function quadFrag(defines) { + return ` + @group(0) @binding(1) var baseSampler: sampler; + @group(0) @binding(0) var colorTexture: texture_2d; + struct VertexOutput { + @builtin(position) position: vec4, + @location(0) uv: vec2, + }; + @fragment + fn main(input:VertexOutput) -> @location(0) vec4 { + return textureSample(colorTexture, baseSampler, vec2(input.uv.x,1.0-input.uv.y)); } + `; +} +function quadVert(defines) { + return ` + struct VertexInput { + @location(${defines.positionLocation}) position: vec2, + } + struct VertexOutput { + @builtin(position) position: vec4, + @location(0) uv: vec2, + }; + @vertex + fn main(input: VertexInput) -> VertexOutput { + var output:VertexOutput; + output.uv = input.position * 0.5 + 0.5; + output.position = vec4(input.position, 0.0, 1.0);; + return output; + } + `; +} - fn computeSpecularOcclusion( dotNV:f32, ambientOcclusion:f32, roughness:f32 )->f32 { - return saturate( pow( dotNV + ambientOcclusion, exp2( - 16.0 * roughness - 1.0 ) ) - 1.0 + ambientOcclusion ); +function skyBoxFrag(defines) { + return ` + fn lessThanEqual(a:vec3,b:vec3)->vec3{ + let xValue:f32=select(b.x,a.x,a.x<=b.x); + let yValue:f32=select(b.y,a.y,a.y<=b.y); + let zValue:f32=select(b.z,a.z,a.z<=b.z); + return vec3(xValue,yValue,zValue); + } + fn LinearTosRGB( value:vec4 )->vec4 { + return vec4( mix( pow( value.rgb, vec3( 0.41666 ) ) * 1.055 - vec3( 0.055 ), value.rgb * 12.92, vec3( lessThanEqual( value.rgb, vec3( 0.0031308 ) ) ) ), value.a ); } - #if ${e.USE_TRANSMISSION} + struct FragmentInput { + @location(0) texCoord : vec3 + }; + @group(0) @binding(2) var defaultSampler: sampler; + @group(0) @binding(1) var skyboxTexture: texture_cube; + @fragment + fn main(input : FragmentInput) -> @location(0) vec4 { + let color = textureSample(skyboxTexture, defaultSampler, input.texCoord); + return LinearTosRGB(color); + } +`; +} + +function skyBoxVert(defines) { + return ` + struct SystemUniform { + projectionMatrix: mat4x4, + viewMatrix: mat4x4, + inverseViewMatrix: mat4x4, + cameraPosition: vec3, + }; + struct MaterialUniform { + modelMatrix: mat4x4, + } + @binding(${defines.skyboxBinding}) @group(0) var selfUniform : MaterialUniform; + @binding(${defines.cameraBinding}) @group(1) var systemUniform : SystemUniform; + struct VertexInput { + @location(${defines.positionLocation}) position : vec3, + }; + struct VertexOutput { + @builtin(position) position : vec4, + @location(0) texCoord : vec3, + }; + @vertex + fn main(input : VertexInput) -> VertexOutput { + var output : VertexOutput; + output.texCoord = input.position.xyz; + var modelView = systemUniform.viewMatrix; + // Drop the translation portion of the modelView matrix + modelView[3] = vec4(0.0, 0.0, 0.0, modelView[3].w); + output.position = systemUniform.projectionMatrix * modelView * vec4(input.position,1.0); + output.position = output.position.xyww; + return output; + } + `; +} + +function sprite_fs(defines) { + return wgslParseDefines` + #include + struct SelfUniform { + modelMatrix: mat4x4, + color:vec3, + rotation:f32, + center:vec2, + opacity:f32, + } + @binding(${defines.spriteBinding}) @group(0) var selfUniform : SelfUniform; + #if${defines.USE_COLORTEXTURE} + @group(0) @binding(${defines.baseColorSamplerBinding}) var baseColorSampler: sampler; + @group(0) @binding(${defines.baseColorTextureBinding}) var baseColorTexture: texture_2d; + #endif + @fragment + fn main(input:VertexOutput) -> @location(0) vec4 { + #if${defines.USE_COLORTEXTURE} + return textureSample(baseColorTexture, baseColorSampler, input.uv); + #else + return vec4(selfUniform.color,selfUniform.opacity); + #endif + } + `; +} + +function sprite_vs(defines) { + return wgslParseDefines` + + #include + #include + #include + struct SelfUniform { + modelMatrix: mat4x4, + color:vec3, + rotation:f32, + center:vec2, + opacity:f32, + } + @binding(${defines.spriteBinding}) @group(0) var selfUniform : SelfUniform; + @binding(${defines.cameraBinding}) @group(1) var systemUniform : SystemUniform; + @vertex + fn main(input: VertexInput) -> VertexOutput { + var output:VertexOutput; + var mvPosition:vec4= systemUniform.viewMatrix *selfUniform.modelMatrix*vec4(0.0,0.0,0.0,1.0); + #if ${defines.HAS_UV} + output.uv=input.uv; + #endif + var scale:vec2; + scale.x = length(vec3(selfUniform.modelMatrix[0].x, selfUniform.modelMatrix[0].y, selfUniform.modelMatrix[0].z)); + scale.y = length(vec3(selfUniform.modelMatrix[1].x, selfUniform.modelMatrix[1].y, selfUniform.modelMatrix[1].z)); + // scale *= - mvPosition.z; + var alignedPosition:vec2 =(input.position.xy- (selfUniform.center - vec2(0.5,0.5))) * scale; + let rotatedPositionX = cos(selfUniform.rotation) * alignedPosition.x - sin( selfUniform.rotation ) * alignedPosition.y; + let rotatedPositionY = sin(selfUniform.rotation) * alignedPosition.x + cos( selfUniform.rotation ) * alignedPosition.y; + var rotatedPosition=vec2(rotatedPositionX,rotatedPositionY); + let newPoint =mvPosition.xy+ rotatedPosition; + output.position = systemUniform.projectionMatrix * vec4(newPoint.x,newPoint.y,mvPosition.z,mvPosition.w); + return output; + } + `; +} + +function blendFrag(defines) { + return ` + struct FragInput { + @location(0) uv: vec2, + }; + @group(0) @binding({{tDiffuseBinding}}) var tDiffuse: texture_2d; + @group(0) @binding({{baseColorTextureBinding}}) var baseColorTexture: texture_2d; + @group(0) @binding({{tSamplerBinding}}) var tSampler: sampler; + @fragment + fn main(input:FragInput) -> @location(0) vec4 { + let postColor:vec4 = textureSample(tDiffuse, tSampler, input.uv); + let baseColor:vec4 = textureSample(baseColorTexture, tSampler, input.uv); + return baseColor+postColor; + } + `; +} - fn getVolumeTransmissionRay( n:vec3, v:vec3, thickness:f32, ior:f32, modelMatrix:mat4x4:f32)->vec3 { - var refractionVector:vec3 = refract( - v, normalize( n ), 1.0 / ior ); - var modelScale:vec3; - modelScale.x = length( vec3( modelMatrix[0].xyz ) ); - modelScale.y = length( vec3( modelMatrix[1].xyz ) ); - modelScale.z = length( vec3( modelMatrix[2].xyz ) ); - return normalize( refractionVector ) * thickness * modelScale; +function Blur(defines) { + return ` + struct FragInput { + @location(0) uv: vec2, } - fn applyIorToRoughness(roughness:f32, ior:f32 )->f32 { - return roughness * clamp( ior * 2.0 - 2.0, 0.0, 1.0 ); + struct BlurUniforms { + direction:vec2, } - fn getTransmissionSample( fragCoord:vec2, roughness:f32,ior:f32 )->vec4 { - let framebufferLod:f32 = log2( materialUniform.transmissionSamplerSize.x ) * applyIorToRoughness( roughness, ior ); - return textureSampleLevel(transmissionSamplerTexture,baseSampler,fragCoord.xy, framebufferLod); - + fn gaussianPdf(x:f32, sigma:f32)->f32 { + return 0.39894 * exp( -0.5 * x * x/( sigma * sigma))/sigma; } - fn applyVolumeAttenuation( radiance:vec3, transmissionDistance:f32,attenuationColor:vec3,attenuationDistance:f32 )->vec3 { - if ( isinf( attenuationDistance ) ) { - return radiance; - } - else { - let attenuationCoefficient:vec3 = -log( attenuationColor ) / attenuationDistance; - let transmittance:vec3 = exp( - attenuationCoefficient * transmissionDistance ); - return transmittance * radiance; + @group(0) @binding(0) var blurUniforms : BlurUniforms; + @group(0) @binding({{tDiffuseBinding}}) var tDiffuse: texture_2d; + @group(0) @binding({{tSamplerBinding}}) var tSampler: sampler; + @fragment + fn main(input:FragInput) -> @location(0) vec4 { + let invSize:vec2 = vec2(1.0,1.0) / vec2(textureDimensions(tDiffuse)); + let fSigma:f32 =f32(${defines.SIGMA}); + var weightSum:f32 = gaussianPdf(0.0, fSigma); + let baseColor=textureSample(tDiffuse, tSampler, input.uv); + var diffuseSum:vec3 = baseColor.rgb * weightSum; + let uvOffset:vec2 = blurUniforms.direction * invSize; + for( var i : u32 = 1; i < ${defines.KERNEL_RADIUS};i = i + 1 ) { + let x:f32 = f32(i); + let w:f32 = gaussianPdf(x, fSigma); + let sample1:vec3=textureSample(tDiffuse, tSampler, input.uv+ uvOffset*x).rgb; + let sample2:vec3=textureSample(tDiffuse, tSampler, input.uv- uvOffset*x).rgb; + diffuseSum =diffuseSum+ (sample2+sample2)* w; + weightSum += 2.0 * w; } - - } - fn getIBLVolumeRefraction( n:vec3,v:vec3, roughness:f32, diffuseColor:vec3,specularColor:vec3, specularF90:f32,position:vec3, modelMatrix:mat4x4, viewMatrix:mat4x4,projMatrix:mat4x4,ior:f32, thickness:f32,attenuationColor:vec3,attenuationDistance:f32 )->vec4 { - let transmissionRay:vec3 = getVolumeTransmissionRay( n, v, thickness, ior, modelMatrix ); - let refractedRayExit:vec3 = position + transmissionRay; - let ndcPos:vec4 = projMatrix * viewMatrix * vec4( refractedRayExit, 1.0 ); - let refractionCoords:vec2 = ndcPos.xy / ndcPos.w; - refractionCoords += 1.0; - refractionCoords /= 2.0; - let transmittedLight:vec4 = getTransmissionSample( refractionCoords, roughness, ior ); - let attenuatedColor:vec3 = applyVolumeAttenuation( transmittedLight.rgb, length( transmissionRay ), attenuationColor, attenuationDistance ); - let F:vec3 = EnvironmentBRDF( n, v, specularColor, specularF90, roughness ); - return vec4( ( 1.0 - F ) * attenuatedColor * diffuseColor, transmittedLight.a ); + diffuseSum/=weightSum; + return vec4(diffuseSum,baseColor.a); } - #endif - - #if ${e.USE_BUMPTEXTURE} - fn dHdxy_fwd()->vec2 { - let dSTdx:vec2 = dpdx( vUv ); - let dSTdy:vec2 = dpdy( vUv ); - - let Hll:f32 = materialUniform.bumpScale * textureSample(bumpTexture, baseSampler, vUv).x; - let dBx:f32 = materialUniform.bumpScale * textureSample(bumpTexture, baseSampler, vUv + dSTdx).x - Hll; - let dBy:f32 = materialUniform.bumpScale * textureSample(bumpTexture, baseSampler, vUv + dSTdy).x - Hll; - return vec2( dBx, dBy ); - } - fn perturbNormalArb( surf_pos:vec3, surf_norm:vec3, dHdxy:vec2, faceDirection:f32 )->vec3 { - let vSigmaX:vec3 = dpdx( surf_pos.xyz ); - let vSigmaY:vec3 = dpdy( surf_pos.xyz ); - let vN:vec3 = surf_norm; - let R1:vec3 = cross( vSigmaY, vN ); - let R2:vec3 = cross( vN, vSigmaX ); - let fDet:f32 = dot( vSigmaX, R1 ) * faceDirection; - let vGrad:vec3 = sign( fDet ) * ( dHdxy.x * R1 + dHdxy.y * R2 ); - return normalize( abs( fDet ) * surf_norm - vGrad ); - } - #endif + `; +} - //! defined ( USE_TANGENT ) && ( defined ( TANGENTSPACE_NORMALTEXTURE ) || defined ( USE_CLEARCOAT_NORMALTEXTURE ) ) - #if ${(!e.USE_TANGENT && e.TANGENTSPACE_NORMALTEXTURE) || e.USE_CLEARCOAT_NORMALTEXTURE} - fn perturbNormal2Arb( eye_pos:vec3, surf_norm:vec3, textureN:vec3, faceDirection:f32 )->vec3 { - let q0:vec3 = dpdx( eye_pos.xyz ); - let q1:vec3 = dpdy( eye_pos.xyz ); - let st0:vec2 = dpdx( vUv.st ); - let st1:vec2 = dpdy( vUv.st ); - let N:vec3 = surf_norm; - let q1perp:vec3 = cross( q1, N ); - let q0perp:vec3 = cross( N, q0 ); - let T:vec3 = q1perp * st0.x + q0perp * st1.x; - let B:vec3 = q1perp * st0.y + q0perp * st1.y; - let det:f32 = max( dot( T, T ), dot( B, B ) ); - let scale:f32 = ( det == 0.0 ) ? 0.0 : faceDirection * inversesqrt( det ); - return normalize( T * ( textureN.x * scale ) + B * ( textureN.y * scale ) + N * textureN.z ); - } - #endif - struct MultiAndSingleScatter{ - multiScatter:vec3, - singleScatter:vec3 +function LuminosityHigh(defines) { + return ` + struct LuminosityUniforms{ + luminosityThreshold:f32, + smoothWidth:f32, + defaultColor:vec3, + defaultOpacity:f32, } - #if ${e.USE_IRIDESCENCE} - ////////inout vec3 singleScatter, inout vec3 multiScatter - fn computeMultiscatteringIridescence( normal:vec3, viewDir:vec3, specularColor:vec3, specularF90:f32, iridescence:f32,iridescenceF0:vec3, roughness:f32 )->MultiAndSingleScatter { - #else - ////////inout vec3 singleScatter, inout vec3 multiScatter - fn computeMultiscattering( normal:vec3,viewDir:vec3, specularColor:vec3, specularF90:f32, roughness:f32)->MultiAndSingleScatter { - #endif - let fab:vec2 = DFGApprox( normal, viewDir, roughness ); - - var multiAndSingleScatter:MultiAndSingleScatter; - - #if ${e.USE_IRIDESCENCE} - let Fr:vec3 = mix( specularColor, iridescenceF0, iridescence ); - #else - let Fr:vec3 = specularColor; - #endif - let FssEss:vec3 = Fr * fab.x + specularF90 * fab.y; - let Ess:f32 = fab.x + fab.y; - let Ems:f32 = 1.0 - Ess; - let Favg:vec3 = Fr + ( 1.0 - Fr ) * 0.047619; - let Fms:vec3 = FssEss * Favg / ( 1.0 - Ems * Favg ); - // singleScatter += FssEss; - // multiScatter += Fms * Ems; - multiAndSingleScatter.multiScatter=Fms * Ems; - multiAndSingleScatter.singleScatter=FssEss; - return multiAndSingleScatter; - } - //直接光照 - fn RE_Direct_Physical( directLight:IncidentLight, geometry:GeometricContext, material:PhysicalMaterial)->ReflectedLight { - var reflectedLight:ReflectedLight; - let dotNL:f32 = saturate(dot( geometry.normal, directLight.direction)); - let irradiance:vec3 = dotNL * directLight.color; - #if ${e.USE_CLEARCOAT} - let dotNLcc:f32 = saturate( dot( geometry.clearcoatNormal, directLight.direction ) ); - let ccIrradiance:vec3 = dotNLcc * directLight.color; - clearcoatSpecular += ccIrradiance * BRDF_GGX( directLight.direction, geometry.viewDir, geometry.clearcoatNormal, material.clearcoatF0, material.clearcoatF90, material.clearcoatRoughness ); - #endif - - #if ${e.USE_SHEEN} - sheenSpecular += irradiance * BRDF_Sheen( directLight.direction, geometry.viewDir, geometry.normal, material.sheenColor, material.sheenRoughness ); - #endif + struct FragInput { + @location(0) uv: vec2, + }; + @group(0) @binding(0) var luminosityUniforms : LuminosityUniforms; + @group(0) @binding({{tDiffuseBinding}}) var tDiffuse: texture_2d; + @group(0) @binding({{tSamplerBinding}}) var tSampler: sampler; + @fragment + fn main(input:FragInput)-> @location(0) vec4 { - #if ${e.USE_IRIDESCENCE} - reflectedLight.directSpecular = irradiance * BRDF_GGX_Iridescence( directLight.direction, geometry.viewDir, geometry.normal, material.specularColor, material.specularF90, material.iridescence, material.iridescenceFresnel, material.roughness ); - #else - reflectedLight.directSpecular = irradiance * BRDF_GGX( directLight.direction, geometry.viewDir, geometry.normal, material.specularColor, material.specularF90, material.roughness ); - #endif - reflectedLight.directDiffuse = irradiance * BRDF_Lambert( material.diffuseColor ); - return reflectedLight; - } - //间接光照 - fn RE_IndirectDiffuse_Physical( irradiance:vec3, geometry:GeometricContext, material:PhysicalMaterial )->ReflectedLight { - var reflectedLight:ReflectedLight; - reflectedLight.indirectDiffuse = irradiance * BRDF_Lambert( material.diffuseColor ); - return reflectedLight; - } - //间接高光 - fn RE_IndirectSpecular_Physical( radiance:vec3, irradiance:vec3, clearcoatRadiance:vec3, geometry:GeometricContext, material:PhysicalMaterial)->ReflectedLight { - var reflectedLight:ReflectedLight; - #if ${e.USE_CLEARCOAT} - clearcoatSpecular += clearcoatRadiance * EnvironmentBRDF( geometry.clearcoatNormal, geometry.viewDir, material.clearcoatF0, material.clearcoatF90, material.clearcoatRoughness ); - #endif - #if ${e.USE_SHEEN} - sheenSpecular += irradiance * material.sheenColor * IBLSheenBRDF( geometry.normal, geometry.viewDir, material.sheenRoughness ); - #endif - var singleScattering:vec3; - var multiScattering:vec3; - let cosineWeightedIrradiance:vec3 = irradiance * RECIPROCAL_PI; - var tempMultiAndSingleScatter:MultiAndSingleScatter; - #if ${e.USE_IRIDESCENCE} - tempMultiAndSingleScatter=computeMultiscatteringIridescence( geometry.normal, geometry.viewDir, material.specularColor, material.specularF90, material.iridescence, material.iridescenceFresnel, material.roughness ); - #else - tempMultiAndSingleScatter= computeMultiscattering( geometry.normal, geometry.viewDir, material.specularColor, material.specularF90, material.roughness ); - #endif - singleScattering=tempMultiAndSingleScatter.singleScatter; - multiScattering=tempMultiAndSingleScatter.multiScatter; - let totalScattering:vec3 = singleScattering + multiScattering; - let diffuse:vec3 = material.diffuseColor * ( 1.0 - max( max( totalScattering.r, totalScattering.g ), totalScattering.b ) ); - reflectedLight.indirectSpecular = radiance * singleScattering; - reflectedLight.indirectSpecular = multiScattering * cosineWeightedIrradiance; - reflectedLight.indirectDiffuse = diffuse * cosineWeightedIrradiance; - return reflectedLight; - } - `; - }, - pbrTexture: function (e) { - return Di` - #if ${e.USE_BUMPTEXTURE} - @group(0) @binding(${e.bumpTextureBinding}) var bumpTexture: texture_2d; - #endif - #if ${e.USE_TRANSMISSION} - #if ${e.USE_TRANSMISSIONTEXTURE} - @group(0) @binding(${e.transmissionTextureBinding}) var transmissionTexture: texture_2d; - #endif - #if ${e.USE_THICKNESSTEXTURE} - @group(0) @binding(${e.thicknessTextureBinding}) var thicknessTexture: texture_2d; - #endif - @group(0) @binding(${e.transmissionSamplerTextureBinding}) var transmissionSamplerTexture: texture_2d; - #endif - #if ${e.USE_ENVTEXTURE} - @group(0) @binding(${e.envTextureBinding}) var envTexture: texture_cube; - #endif - #if ${e.USE_NORMALTEXTURE} - @group(0) @binding(${e.normalTextureBinding}) var normalTexture: texture_2d; - #endif - - #if ${e.USE_CLEARCOATTEXTURE} - @group(0) @binding(${e.clearcoatTextureBinding}) var clearcoatTexture: texture_2d; - #endif - - #if ${e.USE_CLEARCOAT_ROUGHNESSTEXTURE} - @group(0) @binding(${e.clearcoatRclearcoatRoughnessTextureBinding}) var clearcoatRoughnessTexture: texture_2d; - #endif - - #if ${e.USE_CLEARCOAT_NORMALTEXTURE} - @group(0) @binding(${e.clearcoatNormalTextureBinding}) var clearcoatNormalTexture: texture_2d; - #endif - - #if ${e.USE_IRIDESCENCETEXTURE} - @group(0) @binding(${e.iridescenceTextureBinding}) var iridescenceTexture: texture_2d; - #endif - - #if ${e.USE_IRIDESCENCE_THICKNESSTEXTURE} - @group(0) @binding(${e.iridescenceThicknessTextureBinding}) var iridescenceThicknessTexture: texture_2d; - #endif - - #if ${e.USE_ROUGHNESSTEXTURE} - @group(0) @binding(${e.roughnessTextureBinding}) var roughnessTexture: texture_2d; - #endif - - #if ${e.USE_METALNESSTEXTURE} - @group(0) @binding(${e.metalnessTextureBinding}) var metalnessTexture: texture_2d; - #endif + let texel:vec4 = textureSample(tDiffuse, tSampler, input.uv); - #if ${e.SPECULAR} - #if ${e.USE_SPECULARINTENSITYTEXTURE} - @group(0) @binding(${e.specularIntensityTextureBinding}) var specularIntensityTexture: texture_2d; - #endif + let luma:vec3 = vec3( 0.299,0.587,0.114 ); - #if ${e.USE_SPECULARCOLORTEXTURE} - @group(0) @binding(${e.specularColorTextureBinding}) var specularColorTexture: texture_2d; - #endif - #endif + let v:f32 = dot( texel.xyz, luma ); - #if ${e.USE_SHEEN} - #if ${e.USE_SHEENCOLORTEXTURE} - @group(0) @binding(${e.sheenColorTextureBinding}) var sheenColorTexture: texture_2d; - #endif - #if ${e.USE_SHEENROUGHNESSTEXTURE} - @group(0) @binding(${e.sheenRoughnessTextureBinding}) var sheenRoughnessTexture: texture_2d; - #endif - #endif + let outputColor:vec4 = vec4( luminosityUniforms.defaultColor.rgb, luminosityUniforms.defaultOpacity ); - #if ${e.USE_TEXTURE} - @group(0) @binding(${e.baseSamplerBinding}) var baseSampler: sampler; - @group(0) @binding(${e.baseTextureBinding}) var baseTexture: texture_2d; - #endif + let alpha:f32 = smoothstep( luminosityUniforms.luminosityThreshold, luminosityUniforms.luminosityThreshold + luminosityUniforms.smoothWidth, v ); - #if ${e.USE_ALPHATEXTURE} - @group(0) @binding(${e.alphaTextureBinding}) var alphaTexture: texture_2d; - #endif + return mix( outputColor, texel, alpha ); + } + `; +} - #if ${e.USE_AOTEXTURE} - @group(0) @binding(${e.aoTextureBinding}) var aoTexture: texture_2d; - - #endif - #if ${e.USE_LIGHTTEXTURE} - @group(0) @binding(${e.lightTextureBinding}) var lightTexture: texture_2d; - #endif +function FragInput(defines) { + return wgslParseDefines` + struct FragInput { + @builtin(front_facing) frontFacing: bool, + @location(0) worldPos:vec3, + @location(1) normal:vec3, + @location(2) uv:vec2, + @location(3) view: vec3, // Vector from vertex to camera. + @location(4) color: vec4, + @location(5) viewPosition: vec3, + } + `; +} - #if ${e.USE_EMISSIVETEXTURE} - @group(0) @binding(${e.emissiveTextureBinding}) var emissiveTexture: texture_2d; - #endif - `; - }, - pbrUtils: function (e) { - return Di` - const PI:f32= 3.141592653589793; - const PI2:f32= 6.283185307179586; - const PI_HALF:f32= 1.5707963267948966; - const RECIPROCAL_PI:f32= 0.3183098861837907; - const RECIPROCAL_PI2:f32= 0.15915494309189535; - const EPSILON:f32= 1e-6; +function PointFragInput(defines) { + return ` + struct PointFragInput{ + @location(0) uv:vec2, + @location(1) color: vec4, + @location(2) size: f32, + } + `; +} - fn pow2(x:f32 )->f32 { - return x*x; - } - fn pow2Vector(x:vec3 )->vec3 { - return x*x; - } - fn pow3( x:f32 )->f32 { - return x*x*x; - } - fn pow4( x:f32 )->f32 { - let x2:f32 = x*x; - return x2*x2; - } - fn max3( v:vec3 )->f32 { - return max( max( v.x, v.y ), v.z ); - } - fn average(v:vec3 )->f32 { - return dot( v, vec3( 0.3333333 ) ); - } - fn rand( uv:vec2 )->f32 { - let a:f32 = 12.9898; - let b:f32 = 78.233; - let c:f32 = 43758.5453; - let dt:f32 = dot( uv.xy, vec2( a, b ) ); - let sn:f32 = dt % PI; - return fract( sin( sn ) * c ); - } - fn transformDirection( dir:vec3, matrix:mat4x4 )->vec3 { - return normalize( ( matrix * vec4( dir, 0.0 ) ).xyz ); - } +function PointVertInput(defines) { + return wgslParseDefines` + struct PointVertInput { + @location(${defines.positionLocation}) position: vec3, + @location(${defines.uvLocation}) uv: vec2, + #if${defines.HAS_COLOR} + @location(${defines.colorLocation}) color: vec3, + #endif + #if ${defines.HAS_SIZE} + @location(${defines.sizeLocation}) size: f32, + #endif + #if ${defines.USE_INSTANCE} + @builtin(instance_index) instanceIdx : u32 + #endif + } + `; +} - fn transposeMat3( m:mat3x3 )->mat3x3 { - var tmp:mat3x3; - tmp[ 0 ] = vec3( m[ 0 ].x, m[ 1 ].x, m[ 2 ].x ); - tmp[ 1 ] = vec3( m[ 0 ].y, m[ 1 ].y, m[ 2 ].y ); - tmp[ 2 ] = vec3( m[ 0 ].z, m[ 1 ].z, m[ 2 ].z ); - return tmp; - } - fn luminance( rgb:vec3 )->f32 { - let weights:vec3 = vec3(0.2126729, 0.7151522, 0.0721750 ); - return dot( weights, rgb ); - } - fn LinearToneMapping( color:vec3,toneMappingExposure:f32 )->vec3 { - return toneMappingExposure * color; +function PointVertOutput(defines) { + return ` + struct PointVertOutput{ + @builtin(position) position:vec4, + @location(0) uv:vec2, + @location(1) color: vec4, + @location(2) size: f32, } + `; +} - fn ReinhardToneMapping( color:vec3,toneMappingExposure:f32 )->vec3 { - var tempColor:vec3; - tempColor=color; - tempColor *= toneMappingExposure; - return saturate( tempColor / ( vec3( 1.0 ) + tempColor ) ); - } - fn CustomToneMapping( color:vec3 )->vec3 { - return color; - } - fn toneMapping( color:vec3,toneMappingExposure:f32 )->vec3 { - return ReinhardToneMapping( color,toneMappingExposure ); - } +function VertexInput(defines) { + return wgslParseDefines` + struct VertexInput { + @location(${defines.positionLocation}) position: vec3, + #if${defines.HAS_NORMAL} + @location(${defines.normalLocation}) normal: vec3, + #endif + #if${defines.HAS_COLOR} + @location(${defines.colorLocation}) color: vec3, + #endif + #if ${defines.HAS_UV} + @location(${defines.uvLocation}) uv: vec2, + #endif + #if${defines.HAS_SKIN} + @location(${defines.joint0Location}) joint0:vec4, + @location(${defines.weight0Location}) weight0:vec4, + #endif + #if ${defines.USE_INSTANCE} + @builtin(instance_index) instanceIdx : u32 + #endif + } + `; +} - fn LinearToLinear( value:vec4 )->vec4 { - return value; - } - fn lessThanEqual(a:vec3,b:vec3)->vec3{ - let xValue:f32=select(b.x,a.x,a.x<=b.x); - let yValue:f32=select(b.y,a.y,a.y<=b.y); - let zValue:f32=select(b.z,a.z,a.z<=b.z); - return vec3(xValue,yValue,zValue); - } - fn LinearTosRGB( value:vec4 )->vec4 { - return vec4( mix( pow( value.rgb, vec3( 0.41666 ) ) * 1.055 - vec3( 0.055 ), value.rgb * 12.92, vec3( lessThanEqual( value.rgb, vec3( 0.0031308 ) ) ) ), value.a ); - } - fn linearToOutputTexel(value:vec4 )->vec4 { - return LinearTosRGB( value ); - } +function VertexOutput(defines) { + return wgslParseDefines` + struct VertexOutput { + @builtin(position) position:vec4, + @location(0) worldPos:vec3, + @location(1) normal:vec3, + @location(2) uv:vec2, + @location(3) view: vec3, // Vector from vertex to camera. + @location(4) color: vec4, + @location(5) viewPosition: vec3, + } `; - }, - environment: function (e) { - return Di` - #if ${e.ENVTEXTURE_TYPE_CUBE_UV} +} + +function SystemUniform(defines) { + return wgslParseDefines` + struct SystemUniform { + projectionMatrix: mat4x4, + viewMatrix: mat4x4, + inverseViewMatrix: mat4x4, + cameraPosition: vec3, + }; + `; +} + +function TextureAndSamplerDefine(defines) { + return wgslParseDefines` + #if ${defines.USE_IBL} + @group(0) @binding(${defines.specularEnvTextureBinding}) var specularEnvTexture: texture_cube; + @group(0) @binding(${defines.specularEnvSamplerBinding}) var specularEnvSampler: sampler; + #endif + #if ${defines.USE_TEXTURE} + @group(0) @binding(${defines.baseColorTextureBinding}) var baseColorTexture: texture_2d; + @group(0) @binding(${defines.baseColorSamplerBinding}) var baseColorSampler: sampler; + #endif + // normal map + #if ${defines.USE_NORMALTEXTURE} + @group(0) @binding(${defines.normalTextureBinding}) var normalTexture: texture_2d; + @group(0) @binding(${defines.normalSamplerBinding}) var normalSampler: sampler; + #endif + // emmisve map + #if ${defines.USE_EMISSIVETEXTURE} + @group(0) @binding(${defines.emissiveTextureBinding}) var emissiveTexture: texture_2d; + @group(0) @binding(${defines.emissiveSamplerBinding}) var emissiveSampler: sampler; + #endif + + // metal roughness + #if ${defines.USE_METALNESSTEXTURE} + @group(0) @binding(${defines.metalnessRoughnessTextureBinding}) var metalnessRoughnessTexture: texture_2d; + @group(0) @binding(${defines.metalnessRoughnessSamplerBinding}) var metalnessRoughnessSampler: sampler; + #endif + // occlusion texture + #if ${defines.USE_AOTEXTURE} + @group(0) @binding(${defines.aoTextureBinding}) var aoTexture: texture_2d; + @group(0) @binding(${defines.aoSamplerBinding}) var aoSampler: sampler; + #endif + #if ${defines.USE_NORMALTEXTURE} + #include + #include + #else + #include + #endif + `; +} + +function environment(defines) { + return wgslParseDefines` + #if ${defines.ENVTEXTURE_TYPE_CUBE_UV} const cubeUV_minMipLevel:f32= 4.0; const cubeUV_minTileSize:f32= 16.0; const CUBEUV_MAX_MIP:f32=6.0; @@ -6927,61 +9233,506 @@ const Ii = { else if ( roughness >= cubeUV_r5 ) { mip = ( cubeUV_r4 - roughness ) * ( cubeUV_m5 - cubeUV_m4 ) / ( cubeUV_r4 - cubeUV_r5 ) + cubeUV_m4; } - else if ( roughness >= cubeUV_r6 ) { - mip = ( cubeUV_r5 - roughness ) * ( cubeUV_m6 - cubeUV_m5 ) / ( cubeUV_r5 - cubeUV_r6 ) + cubeUV_m5; + else if ( roughness >= cubeUV_r6 ) { + mip = ( cubeUV_r5 - roughness ) * ( cubeUV_m6 - cubeUV_m5 ) / ( cubeUV_r5 - cubeUV_r6 ) + cubeUV_m5; + } + else { + mip = - 2.0 * log2( 1.16 * roughness ); + } + return mip; + } + fn textureCubeUV(envTexture:texture_cube, baseSampler:sampler,sampleDir:vec3,roughness:f32 )->vec4 { + let mip = clamp( roughnessToMip( roughness ), cubeUV_m0, CUBEUV_MAX_MIP ); + let mipF = fract( mip ); + let mipInt = floor( mip ); + let color0:vec3 = bilinearCubeUV( envTexture,baseSampler,sampleDir, mipInt ); + if ( mipF == 0.0 ) { + return vec4(color0, 1.0 ); + } + else { + let color1:vec3 = bilinearCubeUV( envTexture,baseSampler, sampleDir, mipInt + 1.0 ); + return vec4(mix( color0, color1, mipF ), 1.0 ); + } + + } + #endif + #if ${defines.USE_ENVTEXTURE} + fn getIBLIrradiance( normal:vec3,baseSampler:sampler,viewMatrix:mat4x4)->vec3 { + #if ${defines.ENVTEXTURE_TYPE_CUBE_UV} + let worldNormal:vec3 = inverseTransformDirection( normal, viewMatrix ); + let envTextureColor:vec4 = textureCubeUV( envTexture,baseSampler, worldNormal, 1.0 ); + return PI * envTextureColor.rgb * materialUniform.envTextureIntensity; + #else + return vec3( 0.0 ); + #endif + } + fn getIBLRadiance( viewDir:vec3,baseSampler:sampler,viewMatrix:mat4x4,normal:vec3, roughness:f32 )->vec3 { + #if ${defines.ENVTEXTURE_TYPE_CUBE_UV} + var reflectVec:vec3 = reflect( - viewDir, normal ); + reflectVec = normalize( mix( reflectVec, normal, roughness * roughness) ); + reflectVec = inverseTransformDirection( reflectVec, viewMatrix ); + let envTextureColor:vec4 = textureCubeUV( envTexture,baseSampler, reflectVec, roughness ); + return envTextureColor.rgb * materialUniform.envTextureIntensity; + #else + return vec3( 0.0 ); + #endif + } + #endif + `; +} + +function instanceVertHeader(defines) { + return wgslParseDefines` + #if ${defines.USE_INSTANCE} + struct InstancesUniform { + instanceMatrixs: array, ${defines.instanceCount}>, + }; + @group(0) @binding(${defines.instanceMatrixsBufferBinding}) var instancesUniform: InstancesUniform; + #endif + `; +} +function instanceVertMain(defines) { + return wgslParseDefines` + #if ${defines.USE_INSTANCE} + modelMatrix=instancesUniform.instanceMatrixs[input.instanceIdx]; + #endif + `; +} + +function light(defines) { + return wgslParseDefines` + struct ReflectedLight { + ambient: vec3, + directDiffuse:vec3, + directSpecular:vec3, + indirectDiffuse:vec3, + indirectSpecular:vec3, + testColor: vec3, + }; + struct IncidentLight { + color: vec3, + direction: vec3, + visible: bool, + }; + struct Geometry { + position: vec3, + normal: vec3, + viewDir: vec3, + dotNV:f32, + #if ${defines.USE_CLEARCOAT} + vec3 clearcoatNormal; + #endif + }; + + #if ${defines.spotLightsCount > 0} + struct SpotLight { + position: vec3, + distance: f32, + direction: vec3, + coneCos: f32, + color: vec3, + penumbraCos: f32, + decay: f32, + }; + fn getSpotLightInfo(spotLight:SpotLight,worldPos:vec3,shininess:f32,N:vec3,V:vec3)->ReflectedLight{ + var direction:vec3 = spotLight.position - worldPos; + var lightColor:ReflectedLight; + let lightDistance:f32 = length(direction); + direction = normalize(direction); + let angleCos:f32 = dot( direction, spotLight.direction ); + let decay:f32 = clamp(1.0 - pow(lightDistance/spotLight.distance, spotLight.decay), 0.0, 1.0); + let spotEffect:f32 = smoothstep( spotLight.penumbraCos, spotLight.coneCos, angleCos ); + let decayTotal:f32 = decay * spotEffect; + let d:f32 = max( dot( N, direction ), 0.0 ) * decayTotal; + lightColor.directDiffuse= spotLight.color * d; + let halfDir:vec3 = normalize( V + direction ); + let s:f32 = pow( clamp( dot( N, halfDir ), 0.0, 1.0 ), shininess ) * decayTotal; + lightColor.directSpecular= spotLight.color * s; + return lightColor; + } + fn getSpotLightIncidentLight(spotLight:SpotLight, geometry:Geometry)->IncidentLight { + var incidentLight:IncidentLight; + let lVector:vec3 = spotLight.position - geometry.position; + incidentLight.direction = normalize( lVector ); + + let lightDistance:f32 = length( lVector ); + let angleCos:f32 = dot( incidentLight.direction, spotLight.direction ); + + let spotEffect:f32 = smoothstep( spotLight.penumbraCos, spotLight.coneCos, angleCos ); + let decayEffect:f32 = clamp(1.0 - pow(lightDistance/spotLight.distance, 4.0), 0.0, 1.0); + + incidentLight.color=spotLight.color*spotEffect * decayEffect; + return incidentLight; + } + + #endif + + #if ${defines.pointLightsCount > 0} + struct PointLight { + position: vec3, + distance: f32, + color: vec3, + decay: f32, + }; + fn getPointLightInfo(pointLight:PointLight,worldPos:vec3,shininess:f32,N:vec3,V:vec3)->ReflectedLight{ + var lightColor:ReflectedLight; + var direction:vec3 = worldPos - pointLight.position; + let dist:f32 = length( direction ); + direction = normalize(direction); + let decay = clamp(1.0 - pow(dist / pointLight.distance, pointLight.decay), 0.0, 1.0); + + let d = max( dot( N, -direction ), 0.0 ) * decay; + lightColor.directDiffuse = pointLight.color * d; + + let halfDir:vec3 = normalize( V - direction ); + let s:f32 = pow( clamp( dot( N, halfDir ), 0.0, 1.0 ), shininess ) * decay; + lightColor.directSpecular = pointLight.color * s; + return lightColor; + } + fn getPointLightIncidentLight(pointLight:PointLight, geometry:Geometry)->IncidentLight { + var incidentLight:IncidentLight; + let lVector:vec3 = pointLight.position-geometry.position; + incidentLight.direction= normalize( lVector ); + let lightDistance:f32 = length( lVector ); + // let weight:f32=1.0 - pow(lightDistance/pointLight.distance, 4.0); + incidentLight.color=pointLight.color*clamp(1.0 - pow(lightDistance/pointLight.distance, 4.0), 0.0, 1.0); + return incidentLight; + } + #endif + #if ${defines.dirtectLightsCount > 0} + struct DirectionalLight { + direction: vec3, + color: vec3, + }; + fn getDirectLightInfo(directionalLight:DirectionalLight,shininess:f32,N:vec3,V:vec3)->ReflectedLight{ + var lightColor:ReflectedLight; + let d:f32 = max(dot(N, -directionalLight.direction), 0.0); + lightColor.directDiffuse += directionalLight.color * d; + + let halfDir:vec3 = normalize( V - directionalLight.direction ); + let s:f32 = pow( clamp( dot( N, halfDir ), 0.0, 1.0 ), shininess ); + lightColor.directSpecular += directionalLight.color * s; + return lightColor; + } + fn getDirectionalDirectLightIncidentLight(directionalLight:DirectionalLight,geometry:Geometry)->IncidentLight { + var incidentLight:IncidentLight; + incidentLight.color = directionalLight.color; + incidentLight.direction = normalize(directionalLight.direction); + return incidentLight; + } + #endif + + #if ${defines.openShadow} + struct LightInfo { + direction: vec3, + viewport: vec4, + }; + + fn linearizeDepth(depth: f32, near: f32, far: f32)->f32 { + return 2 * (near * far) / (far + near - depth * (far - near)); + } + + fn getCubeFace(v : vec3) -> i32{ + let vAbs = abs(v); + + if (vAbs.z >= vAbs.x && vAbs.z >= vAbs.y) { + if (v.z < 0.0) { + return 3; + } + return 2; + } + + if (vAbs.y >= vAbs.x) { + if (v.y < 0.0) { + return 5; + } + return 4; } - else { - mip = - 2.0 * log2( 1.16 * roughness ); + + if (v.x < 0.0) { + return 1; } - return mip; + return 0; } - fn textureCubeUV(envTexture:texture_cube, baseSampler:sampler,sampleDir:vec3,roughness:f32 )->vec4 { - let mip = clamp( roughnessToMip( roughness ), cubeUV_m0, CUBEUV_MAX_MIP ); - let mipF = fract( mip ); - let mipInt = floor( mip ); - let color0:vec3 = bilinearCubeUV( envTexture,baseSampler,sampleDir, mipInt ); - if ( mipF == 0.0 ) { - return vec4(color0, 1.0 ); + + fn getShadowValue(shadowMapArray:texture_depth_2d_array, shadowSampler:sampler_comparison, lightPos:vec4, geometry:Geometry, lightInfo:LightInfo, index:u32, isPointLight: bool, near: f32, far: f32)->f32 { + var visibility = 0.0; + var projectPos: vec3 = lightPos.xyz / lightPos.w; + var shadowPos: vec3 = vec3(projectPos.xy * vec2(0.5, -0.5) + vec2(0.5), projectPos.z); + var d:f32 = dot(geometry.normal, -lightInfo.direction); + var bias = max(0.012 * (1.0 - d), 0.001) / lightPos.w; + let oneOverShadowDepthTextureSize = 1.0 / 1024.0; + // var depth = select(shadowPos.z, (linearizeDepth(shadowPos.z, near, far) - near) / (far- near), isPerspectiveCamera); + var depth = shadowPos.z; + + if (isPointLight) { + shadowPos.x = shadowPos.x * lightInfo.viewport.z; + shadowPos.y = shadowPos.y * lightInfo.viewport.w; + var viewportX = lightInfo.viewport.x * lightInfo.viewport.z; + var viewportY = lightInfo.viewport.y * lightInfo.viewport.w; + var uvOffset = 1.5 / 1024.0; + shadowPos.x = clamp(shadowPos.x + viewportX, viewportX + uvOffset, viewportX + lightInfo.viewport.z - uvOffset); + shadowPos.y = clamp(shadowPos.y + viewportY, viewportY + uvOffset, viewportY + lightInfo.viewport.w - uvOffset); } - else { - let color1:vec3 = bilinearCubeUV( envTexture,baseSampler, sampleDir, mipInt + 1.0 ); - return vec4(mix( color0, color1, mipF ), 1.0 ); + + for (var y = -1; y <= 1; y++) { + for (var x = -1; x <= 1; x++) { + let offset = vec2(vec2(x, y)) * oneOverShadowDepthTextureSize; + + visibility += textureSampleCompare( + shadowMapArray, shadowSampler, + shadowPos.xy + offset, index, depth - bias); + } } - + visibility /= 9.0; + var inFrustum = shadowPos.x >= 0.0 && shadowPos.x <= 1.0 && shadowPos.y >= 0.0 && shadowPos.y <= 1.0; + if (!inFrustum || depth > 1.0) { + visibility = 1.0; + } + return visibility; } - #endif - #if ${e.USE_ENVTEXTURE} - fn getIBLIrradiance( normal:vec3,baseSampler:sampler,viewMatrix:mat4x4)->vec3 { - #if ${e.ENVTEXTURE_TYPE_CUBE_UV} - let worldNormal:vec3 = inverseTransformDirection( normal, viewMatrix ); - let envTextureColor:vec4 = textureCubeUV( envTexture,baseSampler, worldNormal, 1.0 ); - return PI * envTextureColor.rgb * materialUniform.envTextureIntensity; - #else - return vec3( 0.0 ); + #endif + + #if ${ + defines.ambientLightCount || defines.spotLightsCount || defines.pointLightsCount || defines.dirtectLightsCount + } + struct LightUniforms{ + #if ${defines.ambientLightCount} + ambient:vec4, + #endif + #if ${defines.spotLightsCount} + spotLights:array, + #endif + #if ${defines.pointLightsCount} + pointLights:array, + #endif + #if ${defines.dirtectLightsCount} + dirtectLights:array, #endif } - fn getIBLRadiance( viewDir:vec3,baseSampler:sampler,viewMatrix:mat4x4,normal:vec3, roughness:f32 )->vec3 { - #if ${e.ENVTEXTURE_TYPE_CUBE_UV} - var reflectVec:vec3 = reflect( - viewDir, normal ); - reflectVec = normalize( mix( reflectVec, normal, roughness * roughness) ); - reflectVec = inverseTransformDirection( reflectVec, viewMatrix ); - let envTextureColor:vec4 = textureCubeUV( envTexture,baseSampler, reflectVec, roughness ); - return envTextureColor.rgb * materialUniform.envTextureIntensity; - #else - return vec3( 0.0 ); + @group(2) @binding(${defines.lightBinding}) var lightUniforms: LightUniforms; + + #if ${defines.openShadow} + #if ${defines.spotLightShadowMapsCount} + struct SpotLightShadow { + shadowCameraVPMatrix: mat4x4, + shadowCameraNear: f32, + shadowCameraFar: f32 + } + #endif + #if ${defines.pointLightShadowMapsCount} + struct PointLightShadow { + shadowCameraVPMatrixArray: array, 6>, + shadowCameraViewportArray: array, 6>, + shadowCameraNear: f32, + shadowCameraFar: f32, + // shadowCameraVPMatrix: mat4x4, + // shadowCameraVPMatrixArray: array, 6>, + // shadowCameraViewportArray: array, 6>, + } + #endif + #if ${defines.directLightShadowMapsCount} + struct DirectLightShadow { + shadowCameraVPMatrix: mat4x4, + } #endif + struct ShadowUniforms{ + #if ${defines.spotLightShadowMapsCount} + spotLightShadows:array, + #endif + #if ${defines.pointLightShadowMapsCount} + pointLightShadows:array, + #endif + #if ${defines.directLightShadowMapsCount} + directLightShadows:array, + #endif } + @group(2) @binding(${defines.shadowBinding}) var shadowUniforms: ShadowUniforms; + + #if ${defines.spotLightShadowMapTextureArrayBinding} + @group(2) @binding(${ + defines.spotLightShadowMapTextureArrayBinding + }) var spotLightShadowMapTextureArray: texture_depth_2d_array; + #endif + #if ${defines.pointLightShadowMapTextureArrayBinding} + @group(2) @binding(${ + defines.pointLightShadowMapTextureArrayBinding + }) var pointLightShadowMapTextureArray: texture_depth_2d_array; + #endif + #if ${defines.directLightShadowMapTextureArrayBinding} + @group(2) @binding(${ + defines.directLightShadowMapTextureArrayBinding + }) var directLightShadowMapTextureArray: texture_depth_2d_array; + #endif + @group(2) @binding(${defines.shadowSamplerBinding}) var shadowSampler: sampler_comparison; + #endif + #endif - `; - }, - blinn_phong: function (e) { - return "\n fn getPointLightInfo(pointLight:PointLight,worldPos:vec3,shininess:f32,N:vec3,V:vec3)->vec3{\n var color=vec3(0.0,0.0,0.0);\n var direction:vec3 = worldPos - pointLight.position;\n let dist:f32 = length( direction );\n direction = normalize(direction);\n let decay = clamp(1.0 - pow(dist / pointLight.distance, 4.0), 0.0, 1.0);\n\n let d = max( dot( N, -direction ), 0.0 ) * decay;\n color += pointLight.color * d;\n\n let halfDir:vec3 = normalize( V - direction );\n let s:f32 = pow( clamp( dot( N, halfDir ), 0.0, 1.0 ), shininess ) * decay;\n color += pointLight.color * s;\n return color;\n }\n fn getSpotLightInfo(spotLight:SpotLight,worldPos:vec3,shininess:f32,N:vec3,V:vec3)->vec3{\n var color=vec3(0.0,0.0,0.0);\n var direction:vec3 = spotLight.position - worldPos;\n let lightDistance:f32 = length(direction);\n direction = normalize(direction);\n let angleCos:f32 = dot( direction, -spotLight.direction );\n let decay:f32 = clamp(1.0 - pow(lightDistance/spotLight.distance, 4.0), 0.0, 1.0);\n let spotEffect:f32 = smoothstep( spotLight.penumbraCos, spotLight.coneCos, angleCos );\n let decayTotal:f32 = decay * spotEffect;\n let d:f32 = max( dot( N, direction ), 0.0 ) * decayTotal;\n color += spotLight.color * d;\n let halfDir:vec3 = normalize( V + direction );\n let s:f32 = pow( clamp( dot( N, halfDir ), 0.0, 1.0 ), shininess ) * decayTotal;\n color += spotLight.color * s;\n return color;\n }\n struct DirectionalLight {\n direction: vec3,\n color: vec3,\n };\n fn getDirectLightInfo(directionalLight:DirectionalLight,shininess:f32,N:vec3,V:vec3)->vec3{\n var color=vec3(0.0,0.0,0.0);\n let d:f32 = max(dot(N, -directionalLight.direction), 0.0);\n color += directionalLight.color * d;\n\n let halfDir:vec3 = normalize( V - directionalLight.direction );\n let s:f32 = pow( clamp( dot( N, halfDir ), 0.0, 1.0 ), shininess );\n color += directionalLight.color * s;\n return color;\n }\n "; - }, - getNormal: function (e) { - return Di` + #if ${defines.materialPhong} + fn parseLights(geometry:Geometry,shininess:f32)->ReflectedLight { + #elif ${defines.materialPbr} + fn parseLights(geometry:Geometry,material:PhysicalMaterial)->ReflectedLight{ + #endif + var reflectedLight:ReflectedLight; + var shadowValue:f32 = 1.0; + #if ${defines.ambientLightCount > 0} + //处理环境光 + var ambientColor:vec3 = lightUniforms.ambient.xyz * lightUniforms.ambient.w; + reflectedLight.ambient += ambientColor; + #endif + + #if ${defines.spotLightsCount > 0} + //处理聚光灯 + var spotLight:SpotLight; + for (var k = 0u; k < ${defines.spotLightsCount}; k = k + 1u) { + spotLight= lightUniforms.spotLights[k]; + #if ${defines.materialPhong && defines.openShadow && defines.spotLightShadowMapsCount} + if k < textureNumLayers(spotLightShadowMapTextureArray) { + var spotLightShadow:SpotLightShadow = shadowUniforms.spotLightShadows[k]; + var lightPos: vec4 = spotLightShadow.shadowCameraVPMatrix * vec4(geometry.position,1.0); + var lightInfo:LightInfo; + lightInfo.direction = normalize(geometry.position - spotLight.position); + + shadowValue = getShadowValue(spotLightShadowMapTextureArray, shadowSampler, lightPos, geometry, lightInfo, k, false, + spotLightShadow.shadowCameraNear, spotLightShadow.shadowCameraFar); + } + spotLight.color *= shadowValue; + #endif + #if ${defines.materialPhong} + let spReflectedLight=getSpotLightInfo(spotLight,geometry.position,shininess,geometry.normal,geometry.viewDir); + #elif ${defines.materialPbr} + let incidentLight=getSpotLightIncidentLight(spotLight,geometry); + let spReflectedLight=direct_Physical(incidentLight, geometry, material); + #endif + + reflectedLight.directDiffuse+=spReflectedLight.directDiffuse; + reflectedLight.directSpecular+=spReflectedLight.directSpecular; + } + #endif + #if ${defines.pointLightsCount > 0} + //处理点光源 + var pointLight:PointLight; + for (var j = 0u; j < ${defines.pointLightsCount};j = j + 1u) { + pointLight = lightUniforms.pointLights[j]; + #if ${defines.materialPhong && defines.openShadow && defines.pointLightShadowMapsCount} + if j < textureNumLayers(pointLightShadowMapTextureArray) { + var pointLightShadow:PointLightShadow = shadowUniforms.pointLightShadows[j]; + var lightInfo:LightInfo; + lightInfo.direction = normalize(geometry.position - pointLight.position); + var cubeFace = getCubeFace(lightInfo.direction); + var lightPos: vec4 = pointLightShadow.shadowCameraVPMatrixArray[cubeFace] * vec4(geometry.position,1.0); + lightInfo.viewport = pointLightShadow.shadowCameraViewportArray[cubeFace]; + + // var lightPos: vec4 = pointLightShadow.shadowCameraVPMatrix * vec4(geometry.position,1.0); + + shadowValue = getShadowValue(pointLightShadowMapTextureArray, shadowSampler, lightPos, geometry, lightInfo, j, true, + pointLightShadow.shadowCameraNear, pointLightShadow.shadowCameraFar); + + // reflectedLight.testColor = vec3(pointLightShadow.shadowCameraFar / 1000, + // pointLightShadow.shadowCameraVPMatrixArray[5][3][2] / 255, pointLightShadow.shadowCameraVPMatrixArray[5][3][3] / 255); + // reflectedLight.testColor = vec3(pointLightShadow.shadowCameraNear, pointLightShadow.shadowCameraNear, pointLightShadow.shadowCameraNear); + } + pointLight.color *= shadowValue; + #endif + #if ${defines.materialPhong} + let poiReflectedLight=getPointLightInfo(pointLight,geometry.position,shininess,geometry.normal,geometry.viewDir); + #elif ${defines.materialPbr} + let incidentLight=getPointLightIncidentLight(pointLight,geometry); + let poiReflectedLight=direct_Physical(incidentLight, geometry, material); + #endif + + reflectedLight.directDiffuse+=poiReflectedLight.directDiffuse; + reflectedLight.directSpecular+=poiReflectedLight.directSpecular; + } + #endif + #if ${defines.dirtectLightsCount > 0} + //处理方向光 + var directionalLight:DirectionalLight; + for (var i= 0u; i <${defines.dirtectLightsCount}; i = i + 1u) { + directionalLight = lightUniforms.dirtectLights[i]; + #if ${defines.materialPhong && defines.openShadow && defines.directLightShadowMapsCount} + if i < textureNumLayers(directLightShadowMapTextureArray) { + var directLightShadow:DirectLightShadow = shadowUniforms.directLightShadows[i]; + var lightPos: vec4 = directLightShadow.shadowCameraVPMatrix * vec4(geometry.position,1.0); + var lightInfo:LightInfo; + lightInfo.direction = directionalLight.direction; + + shadowValue = getShadowValue(directLightShadowMapTextureArray, shadowSampler, lightPos, geometry, lightInfo, i, false, 0, 0); + } + directionalLight.color *= shadowValue; + #endif + + #if ${defines.materialPhong} + let dirReflectedLight=getDirectLightInfo(directionalLight,shininess,geometry.normal,geometry.viewDir); + #elif ${defines.materialPbr} + let incidentLight=getDirectionalDirectLightIncidentLight(directionalLight,geometry); + let dirReflectedLight=direct_Physical(incidentLight, geometry, material); + #endif + + reflectedLight.directDiffuse+=dirReflectedLight.directDiffuse; + reflectedLight.directSpecular+=dirReflectedLight.directSpecular; + } + #endif + return reflectedLight; + }`; +} + +function lightCommon(defines) { + return wgslParseDefines` + struct ReflectedLight { + directDiffuse:vec3, + directSpecular:vec3, + indirectDiffuse:vec3, + indirectSpecular:vec3, + }; + struct Geometry { + position: vec3, + normal: vec3, + viewDir: vec3, + #if ${defines.USE_CLEARCOAT} + vec3 clearcoatNormal; + #endif + }; + fn getAmbientLightIrradiance(ambientLightColor: vec3) -> vec3 { + let irradiance = ambientLightColor; + return irradiance; + } + fn getDistanceAttenuation(lightDistance: f32, cutoffDistance: f32, decayExponent: f32) -> f32 { + if (cutoffDistance > 0.0 && decayExponent > 0.0) { + let x:f32 = saturate(- lightDistance / cutoffDistance + 1.0); + return pow(x, decayExponent); + } + return 1.0; + } + fn getSpotAttenuation(coneCosine: f32, penumbraCosine: f32, angleCosine: f32) -> f32 { + return smoothstep(coneCosine, penumbraCosine, angleCosine); + } + fn shGetIrradianceAt( normal:vec3, shCoefficients:array,9>)->vec3 { + let x:f32 = normal.x; + let y:f32 = normal.y; + let z:f32 = normal.z; + var result:vec3 = shCoefficients[ 0 ] * 0.886227; + result += shCoefficients[ 1 ] * 2.0 * 0.511664 * y; + result += shCoefficients[ 2 ] * 2.0 * 0.511664 * z; + result += shCoefficients[ 3 ] * 2.0 * 0.511664 * x; + result += shCoefficients[ 4 ] * 2.0 * 0.429043 * x * y; + result += shCoefficients[ 5 ] * 2.0 * 0.429043 * y * z; + result += shCoefficients[ 6 ] * ( 0.743125 * z * z - 0.247708 ); + result += shCoefficients[ 7 ] * 2.0 * 0.429043 * x * z; + result += shCoefficients[ 8 ] * 0.429043 * ( x * x - y * y ); + return result; + } + fn inverseTransformDirection( dir:vec3, matrix:mat4x4 )->vec3 { + return normalize( ( vec4( dir, 0.0 ) * matrix ).xyz ); + } + `; +} + +function getNormal(defines) { + return wgslParseDefines` fn getNormal(input:FragInput)->vec3{ var normal:vec3; - #if ${e.HAS_NORMAL} + #if ${defines.HAS_NORMAL} normal= input.normal; #else let pos_dx = dpdx(input.worldPos); @@ -6991,38 +9742,9 @@ const Ii = { return normal*(f32(input.frontFacing) * 2.0 - 1.0); } `; - }, - getTBN: function (e) { - return Di` - fn getTBN(input:FragInput)->mat3x3{ - #if ${e.HAS_TANGENT} - let tbn:mat3x3 = input.tbn; - #else - let normal:vec3 =normalize(input.normal); - let uv:vec2 = select(-input.uv,input.uv,input.frontFacing); - // ref: http://www.thetenthplanet.de/archives/1180 - // get edge vectors of the pixel triangle - let dp1:vec3 = vec3(dpdx(input.worldPos.x), dpdx(input.worldPos.y), dpdx(input.worldPos.z)); - let dp2:vec3 = vec3(dpdy(input.worldPos.x), dpdy(input.worldPos.y), dpdy(input.worldPos.z)); - let duv1:vec2 = dpdx(uv); - let duv2:vec2 = dpdy(uv); - - // solve the linear system - let dp2perp:vec3 = cross(dp2, normal); - let dp1perp:vec3 = cross(normal, dp1); - let tangent:vec3 = dp2perp * duv1.x + dp1perp * duv2.x; - let binormal:vec3 = dp2perp * duv1.y + dp1perp * duv2.y; - // construct a scale-invariant frame - let result:f32=max(dot(tangent, tangent), dot(binormal, binormal)); - let invmax:f32 = 1.0/sqrt(result); - let tbn:mat3x3 = mat3x3(tangent * invmax, binormal * invmax, normal); - #endif - return tbn; - } - `; - }, - getNormalByNormalTexture: function (e) { - return Di` +} +function getNormalByNormalTexture(defines) { + return wgslParseDefines` fn getNormalByNormalTexture(input:FragInput)->vec3{ var n:vec3 = textureSample(normalTexture,normalSampler, input.uv).rgb; let tbn:mat3x3 =getTBN(input); @@ -7031,1193 +9753,1086 @@ const Ii = { return n; } `; - }, - ibl: function (e) { - return Di` - fn getLightProbeRadiance( viewDir:vec3,normal:vec3, roughness:f32 )->vec3{ - var reflectVec:vec3 = reflect( -viewDir, normal ); - reflectVec.x = -reflectVec.x; // TextureCube is left-hand,so x need inverse - let mipCount:f32 = 10.0; // resolution of 256x256 - let lod:f32 = roughness * mipCount; - let specularLight:vec3 = textureSampleLevel(specularEnvTexture,specularEnvSampler, reflectVec, lod).rgb; - return specularLight; - } - fn getLightProbeIrradiance( lightProbe:array,9>, normal:vec3)->vec3 { - var worldNormal:vec3 = normal; - worldNormal.x = -normal.x; - var irradiance:vec3 = lightProbe[0]; - irradiance+=lightProbe[1] * (normal.y); - irradiance+=lightProbe[2] * (normal.z) ; - irradiance+=lightProbe[3] * (normal.x) ; - - irradiance+=lightProbe[4] * (normal.y * normal.x) ; - irradiance+=lightProbe[5] * (normal.y * normal.z) ; - irradiance+=lightProbe[6] * (3.0 * normal.z * normal.z - 1.0); - irradiance+=lightProbe[7] * (normal.z * normal.x) ; - irradiance+=lightProbe[8] * (normal.x * normal.x - normal.y * normal.y); - - return max(irradiance, vec3(0.0,0.0,0.0)); - } - fn DFGApprox( specularColor:vec3, roughness:f32,dotNV:f32 )->vec3 { - const c0:vec4 = vec4( - 1, - 0.0275, - 0.572, 0.022 ); - let c1:vec4 = vec4( 1, 0.0425, 1.04, - 0.04 ); - let r:vec4 = roughness * c0 + c1; - let a004:f32 = min( r.x * r.x, exp2( - 9.28 * dotNV ) ) * r.x + r.y; - let fab:vec2 = vec2( - 1.04, 1.04 ) * a004 + r.zw; - return specularColor * fab.x + fab.y; - } - //间接光照 - fn indirectDiffuse_Physical(geometry:Geometry, material:PhysicalMaterial )->ReflectedLight { - var reflectedLight:ReflectedLight; - var irradiance:vec3 = lightUniforms.ambient.xyz*lightUniforms.ambient.w; - irradiance *= PI; - reflectedLight.indirectDiffuse += irradiance * BRDF_Lambert( material.diffuseColor ); - return reflectedLight; - } - //间接高光 - fn indirectSpecular_Physical(geometry:Geometry, material:PhysicalMaterial)->ReflectedLight { - var reflectedLight:ReflectedLight; - // IBL specular - let radiance:vec3 = getLightProbeRadiance(geometry.viewDir, geometry.normal, material.roughness); - let radianceAttenuation:f32 = 1.0; - reflectedLight.indirectSpecular += radianceAttenuation * radiance * DFGApprox(material.specularColor, material.roughness, geometry.dotNV ); - return reflectedLight; - } - `; - }, - skinVertMain: function (e) { - return Di` - #if ${e.HAS_SKIN} - modelMatrix =getSkinMatrix(input.joint0,input.weight0); - vNormalView = normalize((materialUniform.normalMatrix * modelMatrix * vec4(input.normal, 0.0)).xyz); - #endif - `; - }, - skinVertHeader: function (e) { - return Di` - #if ${e.HAS_SKIN} - struct JointsUniform{ - matrixs:array, - } - struct InverseBindMatricesUniform{ - matrixs:array, - } - @binding(${e.skinJointsBufferBinding}) @group(0) var jointsUniform : JointsUniform; - @binding(${e.invsBufferBinding}) @group(0) var inverseBindMatricesUniform : InverseBindMatricesUniform; - fn getSkinMatrix(joints: vec4f, weights: vec4f) -> mat4x4 { - let joint0 = jointsUniform.matrixs[u32(joints.x)] * inverseBindMatricesUniform.matrixs[u32(joints.x)]; - let joint1 = jointsUniform.matrixs[u32(joints.y)] * inverseBindMatricesUniform.matrixs[u32(joints.y)]; - let joint2 = jointsUniform.matrixs[u32(joints.z)] * inverseBindMatricesUniform.matrixs[u32(joints.z)]; - let joint3 = jointsUniform.matrixs[u32(joints.w)] * inverseBindMatricesUniform.matrixs[u32(joints.w)]; - - let skinMatrix = joint0 * weights.x + - joint1 * weights.y + - joint2 * weights.z + - joint3 * weights.w; - return skinMatrix; - } - #endif - `; - }, - FragInput: function (e) { - return Di` - struct FragInput { - @builtin(front_facing) frontFacing: bool, - @location(0) worldPos:vec3, - @location(1) normal:vec3, - @location(2) uv:vec2, - @location(3) view: vec3, // Vector from vertex to camera. - @location(4) color: vec4, - @location(5) viewPosition: vec3, - } - `; - }, - VertexInput: function (e) { - return Di` - struct VertexInput { - @location(${e.positionLocation}) position: vec3, - #if${e.HAS_NORMAL} - @location(${e.normalLocation}) normal: vec3, - #endif - #if${e.HAS_COLOR} - @location(${e.colorLocation}) color: vec3, - #endif - #if ${e.HAS_UV} - @location(${e.uvLocation}) uv: vec2, - #endif - #if${e.HAS_SKIN} - @location(${e.joint0Location}) joint0:vec4, - @location(${e.weight0Location}) weight0:vec4, - #endif - #if ${e.USE_INSTANCE} - @builtin(instance_index) instanceIdx : u32 - #endif - } - `; - }, - VertexOutput: function (e) { - return Di` - struct VertexOutput { - @builtin(position) position:vec4, - @location(0) worldPos:vec3, - @location(1) normal:vec3, - @location(2) uv:vec2, - @location(3) view: vec3, // Vector from vertex to camera. - @location(4) color: vec4, - @location(5) viewPosition: vec3, - } - `; - }, - PbrMaterialStruct: function (e) { - return Di` - struct MaterialUniform { - modelMatrix: mat4x4, - color: vec3, - opacity:f32, - normalMatrix: mat4x4, - emissive:vec3, - metallic:f32, - roughness:f32, - #if ${e.USE_NORMALTEXTURE} - normalTextureScale:vec2, - #endif - #if ${e.USE_AOTEXTURE} - occlusionStrength:f32, - #endif - } - `; - }, - SystemUniform: function (e) { - return Di` - struct SystemUniform { - projectionMatrix: mat4x4, - viewMatrix: mat4x4, - inverseViewMatrix: mat4x4, - cameraPosition: vec3, - }; - `; - }, - instanceVertMain: function (e) { - return Di` - #if ${e.USE_INSTANCE} - modelMatrix=instancesUniform.instanceMatrixs[input.instanceIdx]; - #endif - `; - }, - instanceVertHeader: function (e) { - return Di` - #if ${e.USE_INSTANCE} - struct InstancesUniform { - instanceMatrixs: array, ${e.instanceCount}>, - }; - @group(0) @binding(${e.instanceMatrixsBufferBinding}) var instancesUniform: InstancesUniform; - #endif - `; - }, - TextureAndSamplerDefine: function (e) { - return Di` - #if ${e.USE_IBL} - @group(0) @binding(${e.specularEnvTextureBinding}) var specularEnvTexture: texture_cube; - @group(0) @binding(${e.specularEnvSamplerBinding}) var specularEnvSampler: sampler; - #endif - #if ${e.USE_TEXTURE} - @group(0) @binding(${e.baseColorTextureBinding}) var baseColorTexture: texture_2d; - @group(0) @binding(${e.baseColorSamplerBinding}) var baseColorSampler: sampler; - #endif - // normal map - #if ${e.USE_NORMALTEXTURE} - @group(0) @binding(${e.normalTextureBinding}) var normalTexture: texture_2d; - @group(0) @binding(${e.normalSamplerBinding}) var normalSampler: sampler; - #endif - // emmisve map - #if ${e.USE_EMISSIVETEXTURE} - @group(0) @binding(${e.emissiveTextureBinding}) var emissiveTexture: texture_2d; - @group(0) @binding(${e.emissiveSamplerBinding}) var emissiveSampler: sampler; - #endif - - // metal roughness - #if ${e.USE_METALNESSTEXTURE} - @group(0) @binding(${e.metalnessRoughnessTextureBinding}) var metalnessRoughnessTexture: texture_2d; - @group(0) @binding(${e.metalnessRoughnessSamplerBinding}) var metalnessRoughnessSampler: sampler; - #endif - // occlusion texture - #if ${e.USE_AOTEXTURE} - @group(0) @binding(${e.aoTextureBinding}) var aoTexture: texture_2d; - @group(0) @binding(${e.aoSamplerBinding}) var aoSampler: sampler; - #endif - #if ${e.USE_NORMALTEXTURE} - #include - #include - #else - #include - #endif - `; - }, - PointVertInput: function (e) { - return Di` - struct PointVertInput { - @location(${e.positionLocation}) position: vec3, - @location(${e.uvLocation}) uv: vec2, - #if${e.HAS_COLOR} - @location(${e.colorLocation}) color: vec3, - #endif - #if ${e.HAS_SIZE} - @location(${e.sizeLocation}) size: f32, - #endif - #if ${e.USE_INSTANCE} - @builtin(instance_index) instanceIdx : u32 - #endif - } - `; - }, - PointVertOutput: function (e) { - return "\n struct PointVertOutput{\n @builtin(position) position:vec4,\n @location(0) uv:vec2,\n @location(1) color: vec4,\n @location(2) size: f32,\n }\n "; - }, - PointFragInput: function (e) { - return "\n struct PointFragInput{\n @location(0) uv:vec2,\n @location(1) color: vec4,\n @location(2) size: f32,\n }\n "; - } -}; -function Pi(e) { - return null != e ? Vi(e) : void 0; } -const Ni = /^[ \t]*#include +<([\w\d./]+)>/gm; -let Bi = {}; -const Oi = { - phong: { - frag: function (e) { - return Di` - struct MaterialUniform { - modelMatrix: mat4x4, - color: vec3, - opacity:f32, - normalMatrix: mat4x4, - emissive:vec3, - shininess:f32, - specular:vec3, - } - #include - #include - #include - #include - @binding(${e.phongBinding}) @group(0) var materialUniform : MaterialUniform; - @binding(${e.cameraBinding}) @group(1) var systemUniform : SystemUniform; - @fragment - fn main(input:FragInput) -> @location(0) vec4 { - var totalEmissiveRadiance:vec3 = materialUniform.emissive; - var color:vec4; - #if${e.USE_COLORTEXTURE} - color= vec4(textureSample(baseColorTexture, baseColorSampler, input.uv).rgb+materialUniform.color,materialUniform.opacity); - #else - color=vec4(materialUniform.color,materialUniform.opacity); - #endif - let V:vec3 = normalize( systemUniform.cameraPosition - input.worldPos); - #if ${e.USE_NORMALTEXTURE} - let N:vec3 = getNormalByNormalTexture(input); +function getTBN(defines) { + return wgslParseDefines` + fn getTBN(input:FragInput)->mat3x3{ + #if ${defines.HAS_TANGENT} + let tbn:mat3x3 = input.tbn; #else - let N:vec3 = getNormal(input); - #endif - var geometry:Geometry; - geometry.normal=N; - geometry.viewDir=V; - geometry.position=input.worldPos; - let lightColor:ReflectedLight=parseLights(geometry,materialUniform.shininess); - // var finnalColor:vec3=color.xyz + (lightColor.directDiffuse + lightColor.directSpecular + lightColor.ambient); - var finnalColor:vec3=color.xyz * (lightColor.directDiffuse + lightColor.directSpecular + lightColor.ambient); - - // finnalColor = lightColor.testColor.xyz; + let normal:vec3 =normalize(input.normal); + let uv:vec2 = select(-input.uv,input.uv,input.frontFacing); + // ref: http://www.thetenthplanet.de/archives/1180 + // get edge vectors of the pixel triangle + let dp1:vec3 = vec3(dpdx(input.worldPos.x), dpdx(input.worldPos.y), dpdx(input.worldPos.z)); + let dp2:vec3 = vec3(dpdy(input.worldPos.x), dpdy(input.worldPos.y), dpdy(input.worldPos.z)); + let duv1:vec2 = dpdx(uv); + let duv2:vec2 = dpdy(uv); - return vec4(finnalColor,color.a); - }`; - }, - vert: function (e) { - return Di` - struct MaterialUniform { - modelMatrix: mat4x4, - color: vec3, - opacity:f32, - normalMatrix: mat4x4, - emissive:vec3, - specular:vec3, - shininess:f32, + // solve the linear system + let dp2perp:vec3 = cross(dp2, normal); + let dp1perp:vec3 = cross(normal, dp1); + let tangent:vec3 = dp2perp * duv1.x + dp1perp * duv2.x; + let binormal:vec3 = dp2perp * duv1.y + dp1perp * duv2.y; + // construct a scale-invariant frame + let result:f32=max(dot(tangent, tangent), dot(binormal, binormal)); + let invmax:f32 = 1.0/sqrt(result); + let tbn:mat3x3 = mat3x3(tangent * invmax, binormal * invmax, normal); + #endif + return tbn; } - #include - #include - #include - @binding(${e.phongBinding}) @group(0) var selfUniform : MaterialUniform; - @binding(${e.cameraBinding}) @group(1) var systemUniform : SystemUniform; - @vertex - fn main(input: VertexInput) -> VertexOutput { - var output: VertexOutput; - #if ${e.HAS_UV} - output.uv = input.uv; - #endif - let modelPos=selfUniform.modelMatrix *vec4(input.position,1.0); - output.worldPos = modelPos.xyz/modelPos.w; - let vNormalView = selfUniform.normalMatrix * vec4(input.normal,0.0); - output.normal = vNormalView.xyz; - output.view = systemUniform.cameraPosition.xyz - modelPos.xyz; - let viewPosition=systemUniform.viewMatrix * modelPos; - output.viewPosition = -viewPosition.xyz; - output.position = systemUniform.projectionMatrix * systemUniform.viewMatrix * modelPos; - return output; - }`; - } - }, - color: { - frag: function (e) { - return "\n struct VertexOutput {\n @builtin(position) position: vec4,\n @location(0) color: vec4,\n };\n @fragment\n fn main(input:VertexOutput) -> @location(0) vec4 {\n return input.color;\n }\n "; - }, - vert: function (e) { - return `\n struct VertexInput {\n @location(${e.positionLocation}) position: vec3, \n @location(${e.colorLocation}) color: vec4,\n }\n struct VertexOutput {\n @builtin(position) position: vec4,\n @location(0) color: vec4,\n };\n struct SelfUniform {\n modelMatrix: mat4x4,\n }\n struct SystemUniform {\n projectionMatrix: mat4x4,\n viewMatrix: mat4x4,\n inverseViewMatrix: mat4x4,\n cameraPosition: vec3,\n }; \n @binding(${e.colorBinding}) @group(0) var selfUniform : SelfUniform;\n @binding(${e.cameraBinding}) @group(1) var systemUniform : SystemUniform;\n @vertex\n fn main(input: VertexInput) -> VertexOutput {\n var output:VertexOutput;\n output.color=input.color;\n output.position = systemUniform.projectionMatrix * systemUniform.viewMatrix *selfUniform.modelMatrix*vec4(input.position,1.0);\n return output;\n }\n `; - } - }, - pbr: { - frag: function (e) { - return Di` - #include - #include - #include - #include - #include - #include - #include - #include - struct SystemUniform { - projectionMatrix: mat4x4, - viewMatrix: mat4x4, - inverseViewMatrix: mat4x4, - cameraPosition: vec3, - }; - // uniform vec3 lightProbe[9], -//////////////////////////////////// -struct VertexOutput { - @builtin(position) position: vec4, - @builtin(front_facing) is_front: bool, - @location(0) vUv: vec2, - @location(1) vViewPosition: vec3, // Vector from vertex to camera. - @location(2) vWorldPosition: vec3, - @location(3) vNormal: vec3, - // 可选 - #if ${e.USE_LIGHTTEXTURE || e.USE_AOTEXTURE} - @location(${e.vUv2OutLocation}) vUv2: vec2, - #endif + `; +} - #if ${e.USE_COLOR_ALPHA} - @location(${e.vColorOutLocation}) vColor: vec4, - #elif ${e.USE_COLOR || e.USE_INSTANCING_COLOR} - @location(${e.vColorOutLocation}) vColor: vec3, - #endif +function brdf(defines) { + return wgslParseDefines` + #if ${defines.USE_SHEEN} + fn D_Charlie( roughness:f32,dotNH:f32 )->f32 { + let alpha:f32 = pow2( roughness ); + let invAlpha:f32 = 1.0 / alpha; + let cos2h:f32 = dotNH * dotNH; + let sin2h:f32 = max( 1.0 - cos2h, 0.0078125 ); + return ( 2.0 + invAlpha ) * pow( sin2h, invAlpha * 0.5 ) / ( 2.0 * PI ); + } + fn V_Neubelt( dotNV:f32, dotNL:f32 )->f32 { + return saturate( 1.0 / ( 4.0 * ( dotNL + dotNV - dotNL * dotNV ) ) ); + } + fn BRDF_Sheen(lightDir:vec3, viewDir:vec3, normal:vec3,sheenColor:vec3,sheenRoughness:f32 )->vec3 { + let halfDir:vec3 = normalize( lightDir + viewDir ); + let dotNL:f32 = saturate( dot( normal, lightDir ) ); + let dotNV:f32 = saturate( dot( normal, viewDir ) ); + let dotNH:f32 = saturate( dot( normal, halfDir ) ); + let D:f32 = D_Charlie( sheenRoughness, dotNH ); + let V:f32 = V_Neubelt( dotNV, dotNL ); + return sheenColor * ( D * V ); + } + #endif + fn BRDF_Lambert(diffuseColor:vec3)->vec3 { - #if ${e.USE_TANGENT} - @location(${e.vTangentOutLocation}) vTangent: vec3, - @location(${e.vBitangentOutLocation}) vBitangent: vec3, - #endif -}; - struct PhysicalMaterial { - diffuseColor:vec3, - roughness:f32, - specularColor:vec3, - specularF90:f32, - #if ${e.USE_CLEARCOAT} - clearcoat:f32, - clearcoatRoughness:f32, - clearcoatF0:vec3, - clearcoatF90:f32, - #endif + return RECIPROCAL_PI * diffuseColor; - #if ${e.USE_IRIDESCENCE} - iridescence:f32, - iridescenceIOR:f32, - iridescenceThickness:f32, - iridescenceFresnel:vec3, - iridescenceF0:vec3, - #endif + } // validated - #if ${e.USE_SHEEN} - sheenColor:vec3, - sheenRoughness:f32, - #endif + fn F_Schlick( f0:vec3, dotVH:f32 )->vec3 { - #if ${e.IOR} - ior:f32, - #endif + // Original approximation by Christophe Schlick '94 + // float fresnel = pow( 1.0 - dotVH, 5.0 ); - #if ${e.USE_TRANSMISSION} - transmission:f32, - transmissionAlpha:f32, - thickness:f32, - attenuationDistance:f32, - attenuationColor:vec3, - #endif - }; -@binding(0) @group(0) var materialUniform : MaterialUniform; -@binding(0) @group(1) var systemUniform : SystemUniform; -@fragment -fn main(input:VertexOutput)-> @location(0) vec4 { - var diffuseColor:vec4 = vec4(materialUniform.diffuse, materialUniform.opacity ); - // ReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) ); - var reflectedLight:ReflectedLight; - var totalEmissiveRadiance:vec3 = materialUniform.emissive; - #if ${e.USE_TEXTURE} - var sampledDiffuseColor:vec4 =textureSample(baseTexture, baseSampler, input.vUv); - #if ${e.DECODE_VIDEO_TEXTURE} - sampledDiffuseColor = vec4( mix( pow( sampledDiffuseColor.rgb * 0.9478672986 + vec3( 0.0521327014 ), vec3( 2.4 ) ), sampledDiffuseColor.rgb * 0.0773993808, vec3( lessThanEqual( sampledDiffuseColor.rgb, vec3( 0.04045 ) ) ) ), sampledDiffuseColor.w ); - #endif + // Optimized variant (presented by Epic at SIGGRAPH '13) + // https://cdn2.unrealengine.com/Resources/files/2013SiggraphPresentationsNotes-26915738.pdf + let fresnel = exp2( ( - 5.55473 * dotVH - 6.98316 ) * dotVH ); + return ( 1.0 - f0 ) * fresnel + f0; - diffuseColor *= sampledDiffuseColor; - #endif + } // validated - var roughnessFactor:f32 = materialUniform.roughness; - - #if ${e.USE_ROUGHNESSTEXTURE} - let texelRoughness:vec4=textureSample(roughnessTexture, baseSampler, input.vUv); - roughnessFactor *= texelRoughness.g; - #endif + fn Schlick_to_F0(f:vec3, f90:f32, dotVH:f32 )->vec3 { + let x:f32 = clamp( 1.0 - dotVH, 0.0, 1.0 ); + let x2:f32 = x * x; + let x5:f32 = clamp( x * x2 * x2, 0.0, 0.9999 ); - var metalnessFactor:f32 = materialUniform.metalness; - - #if ${e.USE_METALNESSTEXTURE} - let texelMetalness:vec4 =textureSample(metalnessTexture, baseSampler, input.vUv); - metalnessFactor *= texelMetalness.b; - #endif + return ( f - vec3( f90 ) * x5 ) / ( 1.0 - x5 ); + } + fn V_GGX_SmithCorrelated( alpha:f32, dotNL:f32,dotNV:f32 )->f32 { - let faceDirection:f32 =select(-1.0,1.0,input.is_front); - #if ${e.FLAT_SHADED} - let fdx:vec3 = dpdx( input.vViewPosition ); - let fdy:vec3 = dpdy( input.vViewPosition ); - let normal:vec3 = normalize( cross( fdy, fdx ) ); - #else - let normal:vec3 = normalize( input.vNormal ); - #if ${e.DOUBLE_SIDED} - normal = normal * faceDirection; - #endif - #if ${e.USE_TANGENT} - let tangent:vec3 = normalize( input.vTangent ); - let bitangent:vec3 = normalize( input.vBitangent ); - #if ${e.DOUBLE_SIDED} - tangent = tangent * faceDirection; - bitangent = bitangent * faceDirection; - #endif - #if ${e.TANGENTSPACE_NORMALTEXTURE || e.USE_CLEARCOAT_NORMALTEXTURE} - let vTBN:mat3x3 = mat3x3( tangent, bitangent, normal ); - #endif - #endif - #endif - - let geometryNormal:vec3 = normal; + let a2 :f32= pow2( alpha ); - #if ${e.OBJECTSPACE_NORMALTEXTURE} - normal =textureSample(normalTexture, baseSampler, input.vUv).xyz * 2.0 - 1.0; - #if ${e.FLIP_SIDED} - normal = - normal; - #endif - #if ${e.DOUBLE_SIDED} - normal = normal * faceDirection; - #endif + let gv:f32 = dotNL * sqrt( a2 + ( 1.0 - a2 ) * pow2( dotNV ) ); + let gl:f32 = dotNV * sqrt( a2 + ( 1.0 - a2 ) * pow2( dotNL ) ); - normal = normalize(materialUniform.normalMatrix * normal ); + return 0.5 / max((gv + gl), 0.000000001 ); - #elif ${e.TANGENTSPACE_NORMALTEXTURE} - let tempMapN:vec3 =textureSample(normalTexture, baseSampler, input.vUv).xyz * 2.0 - 1.0; - let mapN:vec3 =tempMapN.xy *= materialUniform.normalScale; - #if ${e.USE_TANGENT} - normal = normalize( vTBN * mapN ); - #else - normal = perturbNormal2Arb( - input.vViewPosition, normal, mapN, faceDirection ); - #endif + } + fn D_GGX( alpha:f32, dotNH:f32 )->f32 { + + let a2:f32 = pow2( alpha ); - #elif ${e.USE_BUMPTEXTURE} + let denom:f32 = pow2( dotNH ) * ( a2 - 1.0 ) + 1.0; // avoid alpha = 0 with dotNH = 1 - normal = perturbNormalArb( - input.vViewPosition, normal, dHdxy_fwd(), faceDirection ); - #endif + return RECIPROCAL_PI * a2 / pow2( denom ); - #if ${e.USE_CLEARCOAT} - var clearcoatNormal:vec3 = geometryNormal; - #endif - #if ${e.USE_CLEARCOAT_NORMALTEXTURE} - var clearcoatMapN:vec3 =textureSample(clearcoatNormalTexture, baseSampler, input.vUv).xyz * 2.0 - 1.0; - clearcoatMapN.xy *= materialUniform.clearcoatNormalScale; - #if ${e.USE_TANGENT} - clearcoatNormal = normalize( vTBN * clearcoatMapN ); - #else - clearcoatNormal = perturbNormal2Arb( - input.vViewPosition, clearcoatNormal, clearcoatMapN, faceDirection ); - #endif - #endif - #if ${e.USE_EMISSIVETEXTURE} - let emissiveColor:vec4 =textureSample(emissiveTexture, baseSampler, input.vUv); - totalEmissiveRadiance *= emissiveColor.rgb; - #endif + } + fn BRDF_GGX( lightDir:vec3, viewDir:vec3, normal:vec3, f0:vec3, roughness:f32 )->vec3 { - var material:PhysicalMaterial; - material.diffuseColor = diffuseColor.rgb * ( 1.0 - metalnessFactor ); - let dxy:vec3 = max( abs( dpdx( geometryNormal ) ), abs( dpdy( geometryNormal ) ) ); - let geometryRoughness:f32 = max( max( dxy.x, dxy.y ), dxy.z ); - material.roughness = max( roughnessFactor, 0.0525 ); - material.roughness += geometryRoughness; - material.roughness = min( material.roughness, 1.0 ); + let alpha:f32 = pow2( roughness ); // UE4's roughness - #if ${e.IOR} - material.ior = materialUniform.ior; - #if ${e.SPECULAR} - let specularIntensityFactor:f32 = materialUniform.specularIntensity; - let specularColorFactor:vec3 = materialUniform.specularColor; - #if ${e.USE_SPECULARINTENSITYTEXTURE} - specularIntensityFactor *=textureSample(specularIntensityTexture, baseSampler, input.vUv).a; - #endif + let halfDir = normalize( lightDir + viewDir ); - #if ${e.USE_SPECULARCOLORTEXTURE} - specularColorFactor *=textureSample(specularColorTexture, baseSampler, input.vUv).rgb; - #endif + let dotNL:f32 = saturate( dot( normal, lightDir ) ); + let dotNV:f32 = saturate( dot( normal, viewDir ) ); + let dotNH:f32 = saturate( dot( normal, halfDir ) ); + let dotVH:f32 = saturate( dot( lightDir, halfDir ) ); - material.specularF90 = mix( specularIntensityFactor, 1.0, metalnessFactor ); - #else - let specularIntensityFactor:f32 = 1.0; - let specularColorFactor:vec3 = vec3( 1.0 ); - material.specularF90 = 1.0; - #endif - material.specularColor = mix( min( pow2( ( material.ior - 1.0 ) / ( material.ior + 1.0 ) ) * specularColorFactor, vec3( 1.0 ) ) * specularIntensityFactor, diffuseColor.rgb, metalnessFactor ); - #else - material.specularColor = mix( vec3( 0.04 ), diffuseColor.rgb, metalnessFactor ); - material.specularF90 = 1.0; - #endif - #if ${e.USE_CLEARCOAT} - material.clearcoat = materialUniform.clearcoat; - material.clearcoatRoughness = materialUniform.clearcoatRoughness; - material.clearcoatF0 = vec3( 0.04 ); - material.clearcoatF90 = 1.0; - #if ${e.USE_CLEARCOATTEXTURE} - material.clearcoat *=textureSample(clearcoatTexture, baseSampler, input.vUv).x; - #endif - #if ${e.USE_CLEARCOAT_ROUGHNESSTEXTURE} - material.clearcoatRoughness *=textureSample(clearcoatRoughnessTexture, baseSampler, input.vUv).y; - #endif - material.clearcoat = saturate( material.clearcoat ); - material.clearcoatRoughness = max( material.clearcoatRoughness, 0.0525 ); - material.clearcoatRoughness += geometryRoughness; - material.clearcoatRoughness = min( material.clearcoatRoughness, 1.0 ); - #endif - #if ${e.USE_IRIDESCENCE} - material.iridescence = materialUniform.iridescence; - material.iridescenceIOR = materialUniform.iridescenceIOR; - #if ${e.USE_IRIDESCENCETEXTURE} - material.iridescence *=textureSample(iridescenceTexture, baseSampler, input.vUv).r; - #endif - #if ${e.USE_IRIDESCENCE_THICKNESSTEXTURE} - material.iridescenceThickness = (materialUniform.iridescenceThicknessMaximum - materialUniform.iridescenceThicknessMinimum) * textureSample(iridescenceThicknessTexture, baseSampler, input.vUv).g + materialUniform.iridescenceThicknessMinimum; - #else - material.iridescenceThickness = materialUniform.iridescenceThicknessMaximum; - #endif - #endif - #if ${e.USE_SHEEN} - material.sheenColor = materialUniform.sheenColor; - #if ${e.USE_SHEENCOLORTEXTURE} - material.sheenColor *=textureSample(sheenColorTexture, baseSampler, input.vUv).rgb; - #endif - material.sheenRoughness = clamp( materialUniform.sheenRoughness, 0.07, 1.0 ); - #if ${e.USE_SHEENROUGHNESSTEXTURE} - material.sheenRoughness *=textureSample(sheenRoughnessTexture, baseSampler, input.vUv).a; - #endif - #endif - - var geometry:GeometricContext; - geometry.position = - input.vViewPosition; - geometry.normal = normal; - // geometry.viewDir = ( isOrthographic ) ? vec3( 0, 0, 1 ) : normalize( input.vViewPosition ); - geometry.viewDir = normalize( input.vViewPosition); + let F = F_Schlick( f0, dotVH ); - #if ${e.USE_CLEARCOAT} - geometry.clearcoatNormal = clearcoatNormal; - #endif + let V = V_GGX_SmithCorrelated( alpha, dotNL, dotNV ); - #if ${e.USE_IRIDESCENCE} - let dotNVi:f32 = saturate( dot( normal, geometry.viewDir ) ); - if ( material.iridescenceThickness == 0.0 ) { - material.iridescence = 0.0; - } - else { - material.iridescence = saturate( material.iridescence ); - } - if ( material.iridescence > 0.0 ) { - material.iridescenceFresnel = evalIridescence( 1.0, material.iridescenceIOR, dotNVi, material.iridescenceThickness, material.specularColor ); - material.iridescenceF0 = Schlick_to_F0( material.iridescenceFresnel, 1.0, dotNVi ); - } - #endif + let D = D_GGX( alpha, dotNH ); - var iblIrradiance:vec3 = vec3( 0.0 ); - var irradiance:vec3 = getAmbientLightIrradiance(commonLightsParms.ambient); - //irradiance += getLightProbeIrradiance( lightProbe, geometry.normal,systemUniform.viewMatrix ); + return F * ( V * D ); - var radiance:vec3 = vec3( 0.0 ); - var clearcoatRadiance:vec3 = vec3( 0.0 ); + } + fn direct_Physical( directLight:IncidentLight, geometry:Geometry,material:PhysicalMaterial)->ReflectedLight { + var reflectedLight:ReflectedLight; + let dotNL:f32 = saturate(dot( geometry.normal,geometry.viewDir)); + let irradiance:vec3 = dotNL * directLight.color*3.1415926; + reflectedLight.directSpecular = irradiance * BRDF_GGX( directLight.direction, geometry.viewDir, geometry.normal, material.specularColor, material.roughness ); + reflectedLight.directDiffuse = irradiance * BRDF_Lambert( material.diffuseColor ); + return reflectedLight; + } + `; +} - #if ${e.USE_LIGHTTEXTURE} - let lightMapTexel:vec4 =textureSample(lightTexture, baseSampler, input.vUv2); - let lightMapIrradiance:vec3 = lightMapTexel.rgb * materialUniform.lightTextureIntensity; - irradiance += lightMapIrradiance; - #endif - //&& defines.STANDARD&&defines.ENVTEXTURE_TYPE_CUBE_UV - #if ${e.USE_ENVTEXTURE} - iblIrradiance += getIBLIrradiance( geometry.normal,baseSampler,systemUniform.viewMatrix ); - #endif - #if ${e.USE_ENVTEXTURE} - radiance += getIBLRadiance( geometry.viewDir,baseSampler,systemUniform.viewMatrix, geometry.normal, materialUniform.roughness ); - #if ${e.USE_CLEARCOAT} - clearcoatRadiance += getIBLRadiance( geometry.viewDir,baseSampler,systemUniform.viewMatrix, geometry.clearcoatNormal, material.clearcoatRoughness ); - #endif - #endif - //直接光照 - let dirReflectedLight:ReflectedLight= parseLights(geometry,material); - reflectedLight.directDiffuse +=dirReflectedLight.directDiffuse; - reflectedLight.directSpecular +=dirReflectedLight.directSpecular; - //间接漫反射 - let indirectDiffuseLight:ReflectedLight= RE_IndirectDiffuse_Physical( irradiance, geometry, material); - reflectedLight.directDiffuse +=indirectDiffuseLight.indirectDiffuse; - reflectedLight.directSpecular +=indirectDiffuseLight.indirectSpecular; - //间接高光 - let indirectSpecularLight:ReflectedLight=RE_IndirectSpecular_Physical( radiance, iblIrradiance, clearcoatRadiance, geometry, material); - reflectedLight.directDiffuse +=indirectSpecularLight.indirectDiffuse; - reflectedLight.directSpecular +=indirectSpecularLight.indirectSpecular; - //环境光遮蔽 - #if ${e.USE_AOTEXTURE} - let ambientOcclusion:f32 = (textureSample(aoTexture, baseSampler, input.vUv2).r - 1.0 ) * materialUniform.aoTextureIntensity + 1.0; +function ibl(defines) { + return wgslParseDefines` + fn getLightProbeRadiance( viewDir:vec3,normal:vec3, roughness:f32 )->vec3{ + var reflectVec:vec3 = reflect( -viewDir, normal ); + reflectVec.x = -reflectVec.x; // TextureCube is left-hand,so x need inverse + let mipCount:f32 = 10.0; // resolution of 256x256 + let lod:f32 = roughness * mipCount; + let specularLight:vec3 = textureSampleLevel(specularEnvTexture,specularEnvSampler, reflectVec, lod).rgb; + return specularLight; + } + fn getLightProbeIrradiance( lightProbe:array,9>, normal:vec3)->vec3 { + var worldNormal:vec3 = normal; + worldNormal.x = -normal.x; + var irradiance:vec3 = lightProbe[0]; + irradiance+=lightProbe[1] * (normal.y); + irradiance+=lightProbe[2] * (normal.z) ; + irradiance+=lightProbe[3] * (normal.x) ; - reflectedLight.indirectDiffuse *= ambientOcclusion; - //&&defines.STANDARD - #if ${e.USE_ENVTEXTURE} - let dotNV:f32 = saturate( dot( geometry.normal, geometry.viewDir ) ); - reflectedLight.indirectSpecular *= computeSpecularOcclusion( dotNV, ambientOcclusion, material.roughness ); - #endif - #endif + irradiance+=lightProbe[4] * (normal.y * normal.x) ; + irradiance+=lightProbe[5] * (normal.y * normal.z) ; + irradiance+=lightProbe[6] * (3.0 * normal.z * normal.z - 1.0); + irradiance+=lightProbe[7] * (normal.z * normal.x) ; + irradiance+=lightProbe[8] * (normal.x * normal.x - normal.y * normal.y); - var totalDiffuse:vec3 = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse; - var totalSpecular:vec3 = reflectedLight.directSpecular + reflectedLight.indirectSpecular; - //透射 - #if ${e.USE_TRANSMISSION} - material.transmission = materialUniform.transmission; - material.transmissionAlpha = 1.0; - material.thickness = materialUniform.thickness; - material.attenuationDistance = materialUniform.attenuationDistance; - material.attenuationColor = materialUniform.attenuationColor; - #if ${e.USE_TRANSMISSIONTEXTURE} - material.transmission *=textureSample(transmissionTexture, baseSampler, input.vUv).r; - #endif - #if ${e.USE_THICKNESSTEXTURE} - material.thickness *=textureSample(thicknessTexture, baseSampler, input.vUv).g; - #endif - let pos:vec3 = vWorldPosition; - let v:vec3 = normalize( cameraPosition - pos ); - let n:vec3 = inverseTransformDirection( normal, systemUniform.viewMatrix ); - let transmission:vec4 = getIBLVolumeRefraction( - n, v, material.roughness, material.diffuseColor, material.specularColor, material.specularF90, pos, modelMatrix, systemUniform.viewMatrix, systemUniform.projectionMatrix, material.ior, material.thickness, material.attenuationColor, material.attenuationDistance ); - material.transmissionAlpha = mix( material.transmissionAlpha, transmission.a, material.transmission ); - totalDiffuse = mix( totalDiffuse, transmission.rgb, material.transmission ); - #endif + return max(irradiance, vec3(0.0,0.0,0.0)); + } + fn DFGApprox( specularColor:vec3, roughness:f32,dotNV:f32 )->vec3 { + const c0:vec4 = vec4( - 1, - 0.0275, - 0.572, 0.022 ); + let c1:vec4 = vec4( 1, 0.0425, 1.04, - 0.04 ); + let r:vec4 = roughness * c0 + c1; + let a004:f32 = min( r.x * r.x, exp2( - 9.28 * dotNV ) ) * r.x + r.y; + let fab:vec2 = vec2( - 1.04, 1.04 ) * a004 + r.zw; + return specularColor * fab.x + fab.y; + } + //间接光照 + fn indirectDiffuse_Physical(geometry:Geometry, material:PhysicalMaterial )->ReflectedLight { + var reflectedLight:ReflectedLight; + var irradiance:vec3 = lightUniforms.ambient.xyz*lightUniforms.ambient.w; + irradiance *= PI; + reflectedLight.indirectDiffuse += irradiance * BRDF_Lambert( material.diffuseColor ); + return reflectedLight; + } + //间接高光 + fn indirectSpecular_Physical(geometry:Geometry, material:PhysicalMaterial)->ReflectedLight { + var reflectedLight:ReflectedLight; + // IBL specular + let radiance:vec3 = getLightProbeRadiance(geometry.viewDir, geometry.normal, material.roughness); + let radianceAttenuation:f32 = 1.0; + reflectedLight.indirectSpecular += radianceAttenuation * radiance * DFGApprox(material.specularColor, material.roughness, geometry.dotNV ); + return reflectedLight; + } + `; +} - let outgoingLight:vec3 = totalDiffuse + totalSpecular + totalEmissiveRadiance; +function pbrFunction(defines) { + return wgslParseDefines` - #if ${e.USE_SHEEN} - let sheenEnergyComp:f32 = 1.0 - 0.157 * max3( material.sheenColor ); - outgoingLight = outgoingLight * sheenEnergyComp + sheenSpecular; - #endif + #if ${defines.DITHERING} + fn dithering(color:vec3 )->vec3 { + let grid_position:f32 = rand( gl_FragCoord.xy ); + let dither_shift_RGB:vec3 = vec3( 0.25 / 255.0, -0.25 / 255.0, 0.25 / 255.0 ); + dither_shift_RGB = mix( 2.0 * dither_shift_RGB, -2.0 * dither_shift_RGB, grid_position ); + return color + dither_shift_RGB; + } + #endif - #if ${e.USE_CLEARCOAT} - let dotNVcc:f32 = saturate( dot( geometry.clearcoatNormal, geometry.viewDir ) ); - let Fcc:vec3 = F_Schlick( material.clearcoatF0, material.clearcoatF90, dotNVcc ); - outgoingLight = outgoingLight * ( 1.0 - material.clearcoat * Fcc ) + clearcoatSpecular * material.clearcoat; - #endif + #if ${defines.USE_IRIDESCENCE} + fn BRDF_GGX_Iridescence( lightDir:vec3, viewDir:vec3,normal:vec3, f0:vec3, f90:f32,iridescence:f32, iridescenceFresnel:vec3,roughness:f32 )->vec3 { + let alpha:f32 = pow2( roughness ); + let halfDir:vec3 = normalize( lightDir + viewDir ); + let dotNL:f32 = saturate( dot( normal, lightDir ) ); + let dotNV:f32 = saturate( dot( normal, viewDir ) ); + let dotNH:f32 = saturate( dot( normal, halfDir ) ); + let dotVH:f32 = saturate( dot( viewDir, halfDir ) ); + let F:vec3 = mix( F_Schlick( f0, f90, dotVH ), iridescenceFresnel, iridescence ); + let V:f32 = V_GGX_SmithCorrelated( alpha, dotNL, dotNV ); + let D:f32 = D_GGX( alpha, dotNH ); + return F * ( V * D ); + } + #endif - #if ${e.USE_TRANSMISSION} - diffuseColor.a *= material.transmissionAlpha + 0.1; - #endif + #if ${defines.USE_SHEEN} + fn D_Charlie( roughness:f32,dotNH:f32 )->f32 { + let alpha:f32 = pow2( roughness ); + let invAlpha:f32 = 1.0 / alpha; + let cos2h:f32 = dotNH * dotNH; + let sin2h:f32 = max( 1.0 - cos2h, 0.0078125 ); + return ( 2.0 + invAlpha ) * pow( sin2h, invAlpha * 0.5 ) / ( 2.0 * PI ); + } + fn V_Neubelt( dotNV:f32, dotNL:f32 )->f32 { + return saturate( 1.0 / ( 4.0 * ( dotNL + dotNV - dotNL * dotNV ) ) ); + } + fn BRDF_Sheen(lightDir:vec3, viewDir:vec3, normal:vec3,sheenColor:vec3,sheenRoughness:f32 )->vec3 { + let halfDir:vec3 = normalize( lightDir + viewDir ); + let dotNL:f32 = saturate( dot( normal, lightDir ) ); + let dotNV:f32 = saturate( dot( normal, viewDir ) ); + let dotNH:f32 = saturate( dot( normal, halfDir ) ); + let D:f32 = D_Charlie( sheenRoughness, dotNH ); + let V:f32 = V_Neubelt( dotNV, dotNL ); + return sheenColor * ( D * V ); + } + #endif - var finnalColor:vec4; - finnalColor = vec4( outgoingLight, diffuseColor.a ); - #if ${e.TONE_MAPPING} - finnalColor.rgb = toneMapping( finnalColor.rgb,materialUniform.toneMappingExposure ); - #endif + #if ${defines.USE_IRIDESCENCE} + let XYZ_TO_REC709: mat3x3 = mat3x3( + 3.2404542, -0.9692660, 0.0556434, -1.5371385, 1.8760108, -0.2040259, -0.4985314, 0.0415560, 1.0572252 + ); + fn Fresnel0ToIor( fresnel0:vec3 )->vec3 { + let sqrtF0:vec3 = sqrt( fresnel0 ); + return ( vec3( 1.0 ) + sqrtF0 ) / ( vec3( 1.0 ) - sqrtF0 ); + } + fn IorToFresnel0(transmittedIor:vec3,incidentIor:f32 )->vec3 { + return pow2Vector( ( transmittedIor - vec3( incidentIor ) ) / ( transmittedIor + vec3( incidentIor ) ) ); + } + fn IorToFresnel0(transmittedIor:f32, incidentIor:f32 )->f32 { + return pow2Vector( ( transmittedIor - incidentIor ) / ( transmittedIor + incidentIor )); + } + fn evalSensitivity(OPD:f32,shift:vec3 )->vec3 { + let phase:f32 = 2.0 * PI * OPD * 1.0e-9; + let val:vec3 = vec3( 5.4856e-13, 4.4201e-13, 5.2481e-13 ); + let pos:vec3 = vec3( 1.6810e+06, 1.7953e+06, 2.2084e+06 ); + let vart:vec3 = vec3( 4.3278e+09, 9.3046e+09, 6.6121e+09 ); + let xyz:vec3 = val * sqrt( 2.0 * PI * vart ) * cos( pos * phase + shift ) * exp( - pow2( phase ) * vart ); + xyz.x += 9.7470e-14 * sqrt( 2.0 * PI * 4.5282e+09 ) * cos( 2.2399e+06 * phase + shift[ 0 ] ) * exp( - 4.5282e+09 * pow2( phase ) ); + xyz /= 1.0685e-7; + let rgb:vec3 = XYZ_TO_REC709 * xyz; + return rgb; + } + fn evalIridescence(outsideIOR:f32, eta2:f32,cosTheta1:f32,thinFilmThickness:f32,baseF0:vec3 )->vec3 { + var I:vec3; + let iridescenceIOR:f32 = mix( outsideIOR, eta2, smoothstep( 0.0, 0.03, thinFilmThickness ) ); + let sinTheta2Sq:f32 = pow2( outsideIOR / iridescenceIOR ) * ( 1.0 - pow2( cosTheta1 ) ); + let cosTheta2Sq:f32 = 1.0 - sinTheta2Sq; + if ( cosTheta2Sq < 0.0 ) { + return vec3( 1.0 ); + } + let cosTheta2:f32 = sqrt( cosTheta2Sq ); + let R0:f32 = IorToFresnel0( iridescenceIOR, outsideIOR ); + let R12:f32 = F_Schlick( R0, 1.0, cosTheta1 ); + let R21:f32 = R12; + let T121:f32 = 1.0 - R12; + let phi12:f32 = 0.0; + if ( iridescenceIOR < outsideIOR ) phi12 = PI; + let phi21:f32 = PI - phi12; + let baseIOR:vec3 = Fresnel0ToIor( clamp( baseF0, 0.0, 0.9999 ) ); + let R1:vec3 = IorToFresnel0( baseIOR, iridescenceIOR ); + let R23:vec3 = F_Schlick( R1, 1.0, cosTheta2 ); + let phi23:vec3 = vec3( 0.0 ); + if ( baseIOR[ 0 ] < iridescenceIOR ) phi23[ 0 ] = PI; + if ( baseIOR[ 1 ] < iridescenceIOR ) phi23[ 1 ] = PI; + if ( baseIOR[ 2 ] < iridescenceIOR ) phi23[ 2 ] = PI; + let OPD:f32 = 2.0 * iridescenceIOR * thinFilmThickness * cosTheta2; + let phi:vec3 = vec3( phi21 ) + phi23; + let R123:vec3 = clamp( R12 * R23, 1e-5, 0.9999 ); + let r123:vec3 = sqrt( R123 ); + let Rs:vec3 = pow2( T121 ) * R23 / ( vec3( 1.0 ) - R123 ); + let C0:vec3 = R12 + Rs; + I = C0; + let Cm:vec3 = Rs - T121; + for ( let m : u32 = 1;m <= 2; ++ m ) { + Cm *= r123; + Sm:vec3 = 2.0 * evalSensitivity( f32( m ) * OPD, f32( m ) * phi ); + I += Cm * Sm; + } + return max( I, vec3( 0.0 ) ); + } + #endif + const clearcoatSpecular:vec3 = vec3( 0.0 ); + const sheenSpecular:vec3 = vec3( 0.0 ); - finnalColor = linearToOutputTexel( finnalColor); + fn IBLSheenBRDF( normal:vec3, viewDir:vec3, roughness:f32 )->f32 { + let dotNV:f32 = saturate( dot( normal, viewDir ) ); + let r2:f32 = roughness * roughness; + let a:f32 =select(-8.48 * r2 + 14.3 * roughness - 9.95,-339.2 * r2 + 161.4 * roughness - 25.9,roughness < 0.25); + //let a:f32 = roughness < 0.25 ? -339.2 * r2 + 161.4 * roughness - 25.9 : -8.48 * r2 + 14.3 * roughness - 9.95; + let b:f32=select(1.97 * r2 - 3.27 * roughness + 0.72,44.0 * r2 - 23.7 * roughness + 3.26, roughness < 0.25); + //let b:f32 = roughness < 0.25 ? 44.0 * r2 - 23.7 * roughness + 3.26 : 1.97 * r2 - 3.27 * roughness + 0.72; + //let DG:f32 = exp( a * dotNV + b ) + ( roughness < 0.25 ? 0.0 : 0.1 * ( roughness - 0.25 ) ); + let DG:f32 = exp( a * dotNV + b ) + select(0.1 * ( roughness - 0.25 ),0.0,roughness < 0.25); + return saturate( DG * RECIPROCAL_PI ); + } + fn DFGApprox( specularColor:vec3, roughness:f32,dotNV:f32 )->vec3 { + const c0:vec4 = vec4( - 1, - 0.0275, - 0.572, 0.022 ); + let c1:vec4 = vec4( 1, 0.0425, 1.04, - 0.04 ); + let r:vec4 = roughness * c0 + c1; + let a004:f32 = min( r.x * r.x, exp2( - 9.28 * dotNV ) ) * r.x + r.y; + let fab:vec2 = vec2( - 1.04, 1.04 ) * a004 + r.zw; + return specularColor * fab.x + fab.y; + } + fn EnvironmentBRDF( normal:vec3,viewDir:vec3,specularColor:vec3, specularF90:f32,roughness:f32 )->vec3 { + let fab:vec2 = DFGApprox( normal, viewDir, roughness ); + return specularColor * fab.x + specularF90 * fab.y; + } - #if ${e.PREMULTIPLIED_ALPHA} - finnalColor.rgb *= finnalColor.a; - #endif - #if ${e.DITHERING} - finnalColor.rgb = dithering( finnalColor.rgb ); - #endif - return finnalColor; - }`; - }, - vert: function (e) { - return Di` - #include - struct VertexOutput { - @builtin(position) position: vec4, - @location(0) vUv: vec2, - @location(1) vViewPosition: vec3, // Vector from vertex to camera. - @location(2) vWorldPosition: vec3, - @location(3) vNormal: vec3, - // 可选 - #if ${e.USE_LIGHTTEXTURE || e.USE_AOTEXTURE} - @location(${e.vUv2OutLocation}) vUv2: vec2, - #endif - #if ${e.USE_COLOR_ALPHA} - @location(${e.vColorOutLocation}) vColor: vec4, - #elif ${e.USE_COLOR || e.USE_INSTANCING_COLOR} - @location(${e.vColorOutLocation}) vColor: vec3, - #endif + fn computeSpecularOcclusion( dotNV:f32, ambientOcclusion:f32, roughness:f32 )->f32 { + return saturate( pow( dotNV + ambientOcclusion, exp2( - 16.0 * roughness - 1.0 ) ) - 1.0 + ambientOcclusion ); + } + #if ${defines.USE_TRANSMISSION} - #if ${e.USE_TANGENT} - @location(${e.vTangentOutLocation}) vTangent: vec3, - @location(${e.vBitangentOutLocation}) vBitangent: vec3, - #endif - }; - struct GlobalUniform { - projectionMatrix: mat4x4, - viewMatrix: mat4x4, - inverseViewMatrix: mat4x4, - cameraPosition: vec3, - }; + fn getVolumeTransmissionRay( n:vec3, v:vec3, thickness:f32, ior:f32, modelMatrix:mat4x4:f32)->vec3 { + var refractionVector:vec3 = refract( - v, normalize( n ), 1.0 / ior ); + var modelScale:vec3; + modelScale.x = length( vec3( modelMatrix[0].xyz ) ); + modelScale.y = length( vec3( modelMatrix[1].xyz ) ); + modelScale.z = length( vec3( modelMatrix[2].xyz ) ); + return normalize( refractionVector ) * thickness * modelScale; + } + fn applyIorToRoughness(roughness:f32, ior:f32 )->f32 { + return roughness * clamp( ior * 2.0 - 2.0, 0.0, 1.0 ); + } + fn getTransmissionSample( fragCoord:vec2, roughness:f32,ior:f32 )->vec4 { + let framebufferLod:f32 = log2( materialUniform.transmissionSamplerSize.x ) * applyIorToRoughness( roughness, ior ); + return textureSampleLevel(transmissionSamplerTexture,baseSampler,fragCoord.xy, framebufferLod); - //texture and sampler - // @group(0) @binding(${e.samplerBinding}) var baseSampler: sampler; - #if ${e.USE_SKINNING} - //uniform highp sampler2D boneTexture; - @group(0) @binding(${e.boneTextureBinding}) var boneTexture: texture_2d; + } + fn applyVolumeAttenuation( radiance:vec3, transmissionDistance:f32,attenuationColor:vec3,attenuationDistance:f32 )->vec3 { + if ( isinf( attenuationDistance ) ) { + return radiance; + } + else { + let attenuationCoefficient:vec3 = -log( attenuationColor ) / attenuationDistance; + let transmittance:vec3 = exp( - attenuationCoefficient * transmissionDistance ); + return transmittance * radiance; + } + + } + fn getIBLVolumeRefraction( n:vec3,v:vec3, roughness:f32, diffuseColor:vec3,specularColor:vec3, specularF90:f32,position:vec3, modelMatrix:mat4x4, viewMatrix:mat4x4,projMatrix:mat4x4,ior:f32, thickness:f32,attenuationColor:vec3,attenuationDistance:f32 )->vec4 { + let transmissionRay:vec3 = getVolumeTransmissionRay( n, v, thickness, ior, modelMatrix ); + let refractedRayExit:vec3 = position + transmissionRay; + let ndcPos:vec4 = projMatrix * viewMatrix * vec4( refractedRayExit, 1.0 ); + let refractionCoords:vec2 = ndcPos.xy / ndcPos.w; + refractionCoords += 1.0; + refractionCoords /= 2.0; + let transmittedLight:vec4 = getTransmissionSample( refractionCoords, roughness, ior ); + let attenuatedColor:vec3 = applyVolumeAttenuation( transmittedLight.rgb, length( transmissionRay ), attenuationColor, attenuationDistance ); + let F:vec3 = EnvironmentBRDF( n, v, specularColor, specularF90, roughness ); + return vec4( ( 1.0 - F ) * attenuatedColor * diffuseColor, transmittedLight.a ); + } #endif - #if ${e.USE_DISPLACEMENTTEXTURE} - //uniform sampler2D displacementMap; - @group(0) @binding(${e.displacementTextureBinding}) var displacementMap: texture_2d; - #endif + #if ${defines.USE_BUMPTEXTURE} + fn dHdxy_fwd()->vec2 { + let dSTdx:vec2 = dpdx( vUv ); + let dSTdy:vec2 = dpdy( vUv ); - #if ${e.MORPHTARGETS_TEXTURE} - //uniform sampler2DArray morphTargetsTexture; - @group(0) @binding(${e.morphTargetsTextureBinding}) var morphTargetsTexture: texture_2d_array; + let Hll:f32 = materialUniform.bumpScale * textureSample(bumpTexture, baseSampler, vUv).x; + let dBx:f32 = materialUniform.bumpScale * textureSample(bumpTexture, baseSampler, vUv + dSTdx).x - Hll; + let dBy:f32 = materialUniform.bumpScale * textureSample(bumpTexture, baseSampler, vUv + dSTdy).x - Hll; + return vec2( dBx, dBy ); + } + fn perturbNormalArb( surf_pos:vec3, surf_norm:vec3, dHdxy:vec2, faceDirection:f32 )->vec3 { + let vSigmaX:vec3 = dpdx( surf_pos.xyz ); + let vSigmaY:vec3 = dpdy( surf_pos.xyz ); + let vN:vec3 = surf_norm; + let R1:vec3 = cross( vSigmaY, vN ); + let R2:vec3 = cross( vN, vSigmaX ); + let fDet:f32 = dot( vSigmaX, R1 ) * faceDirection; + let vGrad:vec3 = sign( fDet ) * ( dHdxy.x * R1 + dHdxy.y * R2 ); + return normalize( abs( fDet ) * surf_norm - vGrad ); + } #endif - struct VertexInput { - @location(0) position: vec3, + //! defined ( USE_TANGENT ) && ( defined ( TANGENTSPACE_NORMALTEXTURE ) || defined ( USE_CLEARCOAT_NORMALTEXTURE ) ) + #if ${(!defines.USE_TANGENT && defines.TANGENTSPACE_NORMALTEXTURE) || defines.USE_CLEARCOAT_NORMALTEXTURE} + fn perturbNormal2Arb( eye_pos:vec3, surf_norm:vec3, textureN:vec3, faceDirection:f32 )->vec3 { + let q0:vec3 = dpdx( eye_pos.xyz ); + let q1:vec3 = dpdy( eye_pos.xyz ); + let st0:vec2 = dpdx( vUv.st ); + let st1:vec2 = dpdy( vUv.st ); + let N:vec3 = surf_norm; + let q1perp:vec3 = cross( q1, N ); + let q0perp:vec3 = cross( N, q0 ); + let T:vec3 = q1perp * st0.x + q0perp * st1.x; + let B:vec3 = q1perp * st0.y + q0perp * st1.y; + let det:f32 = max( dot( T, T ), dot( B, B ) ); + let scale:f32 = ( det == 0.0 ) ? 0.0 : faceDirection * inversesqrt( det ); + return normalize( T * ( textureN.x * scale ) + B * ( textureN.y * scale ) + N * textureN.z ); + } + #endif + struct MultiAndSingleScatter{ + multiScatter:vec3, + singleScatter:vec3 + } + #if ${defines.USE_IRIDESCENCE} + ////////inout vec3 singleScatter, inout vec3 multiScatter + fn computeMultiscatteringIridescence( normal:vec3, viewDir:vec3, specularColor:vec3, specularF90:f32, iridescence:f32,iridescenceF0:vec3, roughness:f32 )->MultiAndSingleScatter { + #else + ////////inout vec3 singleScatter, inout vec3 multiScatter + fn computeMultiscattering( normal:vec3,viewDir:vec3, specularColor:vec3, specularF90:f32, roughness:f32)->MultiAndSingleScatter { + #endif + let fab:vec2 = DFGApprox( normal, viewDir, roughness ); - @location(1) normal: vec3, + var multiAndSingleScatter:MultiAndSingleScatter; - @location(2) uv: vec2, - #if ${e.USE_LIGHTTEXTURE || e.USE_AOTEXTURE} - @location(${e.uv2Location}) uv2:vec2, - #endif - #if ${e.USE_INSTANCING} - @location(${e.instanceMatrixLocation}) instanceMatrix:mat4x4, - #endif - #if ${e.USE_INSTANCING_COLOR} - @location(${e.instanceColorLocation}) instanceColor:vec3, - #endif - - #if ${e.USE_TANGENT} - @location(${e.tangentLocation}) tangent:vec4, - #endif - #if ${e.USE_COLOR_ALPHA} - @location(${e.colorLocation}) color:vec4, - #elif ${e.USE_COLOR} - @location(${e.colorLocation}) color:vec3, - #endif + #if ${defines.USE_IRIDESCENCE} + let Fr:vec3 = mix( specularColor, iridescenceF0, iridescence ); + #else + let Fr:vec3 = specularColor; + #endif + let FssEss:vec3 = Fr * fab.x + specularF90 * fab.y; + let Ess:f32 = fab.x + fab.y; + let Ems:f32 = 1.0 - Ess; + let Favg:vec3 = Fr + ( 1.0 - Fr ) * 0.047619; + let Fms:vec3 = FssEss * Favg / ( 1.0 - Ems * Favg ); + // singleScatter += FssEss; + // multiScatter += Fms * Ems; + multiAndSingleScatter.multiScatter=Fms * Ems; + multiAndSingleScatter.singleScatter=FssEss; + return multiAndSingleScatter; + } + //直接光照 + fn RE_Direct_Physical( directLight:IncidentLight, geometry:GeometricContext, material:PhysicalMaterial)->ReflectedLight { + var reflectedLight:ReflectedLight; + let dotNL:f32 = saturate(dot( geometry.normal, directLight.direction)); + let irradiance:vec3 = dotNL * directLight.color; + #if ${defines.USE_CLEARCOAT} + let dotNLcc:f32 = saturate( dot( geometry.clearcoatNormal, directLight.direction ) ); + let ccIrradiance:vec3 = dotNLcc * directLight.color; + clearcoatSpecular += ccIrradiance * BRDF_GGX( directLight.direction, geometry.viewDir, geometry.clearcoatNormal, material.clearcoatF0, material.clearcoatF90, material.clearcoatRoughness ); + #endif - #if ${e.USE_MORPHTARGETS && !e.MORPHTARGETS_TEXTURE} - @location(${e.morphTarget0Location}) morphTarget0:vec3, + #if ${defines.USE_SHEEN} + sheenSpecular += irradiance * BRDF_Sheen( directLight.direction, geometry.viewDir, geometry.normal, material.sheenColor, material.sheenRoughness ); + #endif - @location(${e.morphTarget1Location}) morphTarget1:vec3, + #if ${defines.USE_IRIDESCENCE} + reflectedLight.directSpecular = irradiance * BRDF_GGX_Iridescence( directLight.direction, geometry.viewDir, geometry.normal, material.specularColor, material.specularF90, material.iridescence, material.iridescenceFresnel, material.roughness ); + #else + reflectedLight.directSpecular = irradiance * BRDF_GGX( directLight.direction, geometry.viewDir, geometry.normal, material.specularColor, material.specularF90, material.roughness ); + #endif + reflectedLight.directDiffuse = irradiance * BRDF_Lambert( material.diffuseColor ); + return reflectedLight; + } + //间接光照 + fn RE_IndirectDiffuse_Physical( irradiance:vec3, geometry:GeometricContext, material:PhysicalMaterial )->ReflectedLight { + var reflectedLight:ReflectedLight; + reflectedLight.indirectDiffuse = irradiance * BRDF_Lambert( material.diffuseColor ); + return reflectedLight; + } + //间接高光 + fn RE_IndirectSpecular_Physical( radiance:vec3, irradiance:vec3, clearcoatRadiance:vec3, geometry:GeometricContext, material:PhysicalMaterial)->ReflectedLight { + var reflectedLight:ReflectedLight; + #if ${defines.USE_CLEARCOAT} + clearcoatSpecular += clearcoatRadiance * EnvironmentBRDF( geometry.clearcoatNormal, geometry.viewDir, material.clearcoatF0, material.clearcoatF90, material.clearcoatRoughness ); + #endif + #if ${defines.USE_SHEEN} + sheenSpecular += irradiance * material.sheenColor * IBLSheenBRDF( geometry.normal, geometry.viewDir, material.sheenRoughness ); + #endif + var singleScattering:vec3; + var multiScattering:vec3; + let cosineWeightedIrradiance:vec3 = irradiance * RECIPROCAL_PI; + var tempMultiAndSingleScatter:MultiAndSingleScatter; + #if ${defines.USE_IRIDESCENCE} + tempMultiAndSingleScatter=computeMultiscatteringIridescence( geometry.normal, geometry.viewDir, material.specularColor, material.specularF90, material.iridescence, material.iridescenceFresnel, material.roughness ); + #else + tempMultiAndSingleScatter= computeMultiscattering( geometry.normal, geometry.viewDir, material.specularColor, material.specularF90, material.roughness ); + #endif + singleScattering=tempMultiAndSingleScatter.singleScatter; + multiScattering=tempMultiAndSingleScatter.multiScatter; + let totalScattering:vec3 = singleScattering + multiScattering; + let diffuse:vec3 = material.diffuseColor * ( 1.0 - max( max( totalScattering.r, totalScattering.g ), totalScattering.b ) ); + reflectedLight.indirectSpecular = radiance * singleScattering; + reflectedLight.indirectSpecular = multiScattering * cosineWeightedIrradiance; + reflectedLight.indirectDiffuse = diffuse * cosineWeightedIrradiance; + return reflectedLight; + } + `; +} - @location(${e.morphTarget2Location}) morphTarget2:vec3, +function pbrStruct(defines) { + return wgslParseDefines` + struct MaterialUniform{ - @location(${e.morphTarget3Location}) morphTarget3:vec3, - #if ${e.USE_MORPHNORMALS} - @location(${e.morphNormal0Location}) morphNormal0:vec3, + modelMatrix: mat4x4, + + diffuse:vec3, + + opacity:f32, + + normalMatrix: mat3x3, + + emissive:vec3, + + roughness:f32, + + metalness:f32, + + #if ${defines.TONE_MAPPING} + toneMappingExposure:f32, + #endif + + #if ${defines.SPECULAR} + + specularColor:vec3, + + specularIntensity:f32, + #endif + + #if ${defines.USE_SHEEN} + + sheenColor:vec3, + + sheenRoughness:f32, + #endif - @location(${e.morphNormal1Location}) morphNormal1:vec3, + #if ${defines.USE_TRANSMISSION} + + attenuationColor:vec3, + + transmission:f32, + + transmissionSamplerSize:vec2, + + thickness:f32, + + attenuationDistance:f32, + + #endif - @location(${e.morphNormal2Location}) morphNormal2:vec3, + #if ${defines.USE_SKINNING} + + bindMatrix:mat4x4, + + bindMatrixInverse:mat4x4, + + boneTextureSize:u32, + #endif - @location(${e.morphNormal3Location}) morphNormal3:vec3, - #else - @location(${e.morphTarget4Location}) morphTarget4:vec3, + #if ${defines.USE_NORMALTEXTURE} + normalScale:vec2, + #endif + + #if ${defines.IOR} + ior:f32, + #endif + + #if ${defines.USE_CLEARCOAT} + + #if ${defines.USE_CLEARCOAT_NORMALTEXTURE} + clearcoatNormalScale:vec2, + #endif + + clearcoat:f32, + + clearcoatRoughness:f32, + #endif + + #if ${defines.USE_IRIDESCENCE} + iridescence:f32, + + iridescenceIOR:f32, + + iridescenceThicknessMinimum:f32, + + iridescenceThicknessMaximum:f32, + + #endif - @location(${e.morphTarget5Location}) morphTarget5:vec3, + #if ${defines.USE_AOTEXTURE} + aoTextureIntensity:f32, + #endif - @location(${e.morphTarget6Location}) morphTarget6:vec3, + #if ${defines.USE_LIGHTTEXTURE} + lightTextureIntensity:f32, + #endif + + #if ${defines.USE_ENVTEXTURE} + envTextureIntensity:f32, + + flipEnvTexture:f32, + #endif - @location(${e.morphTarget7Location}) morphTarget7:vec3, + #if ${defines.USE_BUMPTEXTURE} + bumpScale:f32; #endif - #endif - #if ${e.USE_SKINNING} - @location(${e.skinIndexLocation}) skinIndex:vec4, - @location(${e.skinWeightLocation}) skinWeight:vec4, - #endif - } - #if ${e.MORPHTARGETS_TEXTURE} - fn getMorph( vertexIndex:u32, morphTargetIndex:u32,offset:u32 )->vec4 { - let texelIndex:u32 = vertexIndex * MORPHTARGETS_TEXTURE_STRIDE + offset; - let y:u32 = texelIndex / materialUniform.morphTargetsTextureSize.x; - let x:u32 = texelIndex - y * materialUniform.morphTargetsTextureSize.x; - let morphUV:vec3 = vec3( x, y, morphTargetIndex ); - //textureLoad - //return texelFetch( morphTargetsTexture, morphUV, 0 ); - return textureLoad( morphTargetsTexture, morphUV, 0 ); - } - #endif - #if ${e.USE_SKINNING} - fn getBoneMatrix( i:f32 )->mat4x4 { - let j:f32 = i * 4.0; - let x:f32 = j%f32( materialUniform.boneTextureSize ); - let y:f32 = floor( j / f32( materialUniform.boneTextureSize ) ); - let dx:f32 = 1.0 / f32( materialUniform.boneTextureSize ); - let dy:f32 = 1.0 / f32( materialUniform.boneTextureSize ); - y = dy * ( y + 0.5 ); + #if ${defines.USE_DISPLACEMENTTEXTURE} + + displacementScale:f32, + + displacementBias:f32, + #endif - let v1:vec4 = textureSample(boneTexture, baseSampler, vec2( dx * ( x + 0.5 ), y ) ); - let v2:vec4 = textureSample(boneTexture, baseSampler, vec2( dx * ( x + 1.5 ), y ) ); - let v3:vec4 = textureSample(boneTexture, baseSampler, vec2( dx * ( x + 2.5 ), y ) ); - let v4:vec4 = textureSample(boneTexture, baseSampler, vec2( dx * ( x + 3.5 ), y ) ); - let bone:mat4x4 = mat4x4( v1, v2, v3, v4 ); - return bone; + #if ${defines.USE_MORPHTARGETS} + + morphTargetBaseInfluence:f32, + + #if ${defines.MORPHTARGETS_TEXTURE} + + morphTargetsTextureSize:vec2, + + MORPHTARGETS_COUNT:u32, + + #endif + + morphTargetInfluences:array, + + #endif } - #endif - @binding(0) @group(0) var materialUniform : MaterialUniform; - @binding(0) @group(1) var globalUniform : GlobalUniform; - @vertex - fn main(input:VertexInput)->VertexOutput { - var vertexOutput:VertexOutput; - #if ${e.USE_TEXTURE} - vertexOutput.vUv = input.uv; - #endif - #if ${e.USE_LIGHTTEXTURE || e.USE_AOTEXTURE} - vertexOutput.vUv2 input.uv2; - #endif - #if ${e.USE_COLOR_ALPHA} - vertexOutput.vColor = vec4( 1.0 ); - #elif ${e.USE_COLOR || e.USE_INSTANCING_COLOR} - vertexOutput.vColor = vec3( 1.0 ); - #endif - #if ${e.USE_COLOR} - vertexOutput.vColor *= input.color; - #endif - #if ${e.USE_INSTANCING_COLOR} - vertexOutput.vColor.xyz *= input.instanceColor.xyz; - #endif - #if ${e.USE_MORPHCOLORS && e.MORPHTARGETS_TEXTURE} - vertexOutput.vColor *= materialUniform.morphTargetBaseInfluence; - for (let i : u32 = 0u; i < materialUniform.MORPHTARGETS_COUNT; i = i + 1u ) { - #if ${e.USE_COLOR_ALPHA} - if ( materialUniform.morphTargetInfluences[ i ] ! = 0.0 ) vertexOutput.vColor += getMorph( gl_VertexID, i, 2 ) * materialUniform.morphTargetInfluences[ i ]; - #elif ${e.USE_COLOR} - if ( materialUniform.morphTargetInfluences[ i ] ! = 0.0 ) vertexOutput.vColor += getMorph( gl_VertexID, i, 2 ).rgb * materialUniform.morphTargetInfluences[ i ]; + `; +} + +function pbrTexture(defines) { + return wgslParseDefines` + #if ${defines.USE_BUMPTEXTURE} + @group(0) @binding(${defines.bumpTextureBinding}) var bumpTexture: texture_2d; + #endif + #if ${defines.USE_TRANSMISSION} + #if ${defines.USE_TRANSMISSIONTEXTURE} + @group(0) @binding(${defines.transmissionTextureBinding}) var transmissionTexture: texture_2d; #endif - } - #endif - var objectNormal:vec3 = vec3(input.normal); - #if ${e.USE_TANGENT} - let objectTangent:vec3 = vec3( input.tangent.xyz ); - #endif - #if ${e.USE_MORPHNORMALS} - objectNormal *= materialUniform.morphTargetBaseInfluence; - #if ${e.MORPHTARGETS_TEXTURE} - for ( let i : u32 = 0u; i < materialUniform.MORPHTARGETS_COUNT; i = i + 1u) { - if ( materialUniform.morphTargetInfluences[ i ] ! = 0.0 ) objectNormal += getMorph( gl_VertexID, i, 1 ).xyz * materialUniform.morphTargetInfluences[ i ]; - } - #else - objectNormal += morphNormal0 * materialUniform.morphTargetInfluences[ 0 ]; - objectNormal += morphNormal1 * materialUniform.morphTargetInfluences[ 1 ]; - objectNormal += morphNormal2 * materialUniform.morphTargetInfluences[ 2 ]; - objectNormal += morphNormal3 * materialUniform.morphTargetInfluences[ 3 ]; + #if ${defines.USE_THICKNESSTEXTURE} + @group(0) @binding(${defines.thicknessTextureBinding}) var thicknessTexture: texture_2d; + #endif + @group(0) @binding(${defines.transmissionSamplerTextureBinding}) var transmissionSamplerTexture: texture_2d; #endif - #endif - #if ${e.USE_SKINNING} - let boneMatX:mat4x4 = getBoneMatrix( input.skinIndex.x ); - let boneMatY:mat4x4 = getBoneMatrix( input.skinIndex.y ); - let boneMatZ:mat4x4 = getBoneMatrix( input.skinIndex.z ); - let boneMatW:mat4x4 = getBoneMatrix( input.skinIndex.w ); - #endif - #if ${e.USE_SKINNING} - let skinMatrix:mat4x4 = mat4x4( 0.0 ); - skinMatrix += input.skinWeight.x * boneMatX; - skinMatrix += input.skinWeight.y * boneMatY; - skinMatrix += input.skinWeight.z * boneMatZ; - skinMatrix += input.skinWeight.w * boneMatW; - skinMatrix = materialUniform.bindMatrixInverse * skinMatrix * materialUniform.bindMatrix; - objectNormal = vec4( skinMatrix * vec4( objectNormal, 0.0 ) ).xyz; - #if ${e.USE_TANGENT} - objectTangent = vec4( skinMatrix * vec4( objectTangent, 0.0 ) ).xyz; + #if ${defines.USE_ENVTEXTURE} + @group(0) @binding(${defines.envTextureBinding}) var envTexture: texture_cube; #endif - #endif - var transformedNormal:vec3 = objectNormal; - // transformedNormal+=vec3(0.0); - #if ${e.USE_INSTANCING} - let m:mat3x3 = mat3x3( input.instanceMatrix ); - transformedNormal /= vec3( dot( m[ 0 ], m[ 0 ] ), dot( m[ 1 ], m[ 1 ] ), dot( m[ 2 ], m[ 2 ] ) ); - transformedNormal = m * transformedNormal; - #endif - transformedNormal = materialUniform.normalMatrix * transformedNormal; - #if ${e.FLIP_SIDED} - transformedNormal = - transformedNormal; - #endif - #if ${e.USE_TANGENT} - let transformedTangent:vec3 = (globalUniform.viewMatrix*materialUniform.modelMatrix * vec4( objectTangent, 0.0 ) ).xyz; - #if ${e.FLIP_SIDED} - transformedTangent = - transformedTangent; + #if ${defines.USE_NORMALTEXTURE} + @group(0) @binding(${defines.normalTextureBinding}) var normalTexture: texture_2d; #endif - #endif - vertexOutput.vNormal = normalize( transformedNormal ); - #if ${e.FLAT_SHADED} - #if ${e.USE_TANGENT} - vTangent = normalize( transformedTangent ); - vBitangent = normalize( cross( vNormal, vTangent ) * input.tangent.w ); + + #if ${defines.USE_CLEARCOATTEXTURE} + @group(0) @binding(${defines.clearcoatTextureBinding}) var clearcoatTexture: texture_2d; #endif - #endif - let transformed:vec3 = vec3( input.position ); - #if ${e.USE_MORPHTARGETS} - transformed *= materialUniform.morphTargetBaseInfluence; - #if ${e.MORPHTARGETS_TEXTURE} - for ( let i : u32 = 0u; i < materialUniform.MORPHTARGETS_COUNT; i = i + 1u ) { - if ( materialUniform.morphTargetInfluences[ i ] ! = 0.0 ) transformed += getMorph( gl_VertexID, i, 0 ).xyz * morphTargetInfluences[ i ]; - } - #else - transformed += input.morphTarget0 * materialUniform.morphTargetInfluences[ 0 ]; - transformed += input.morphTarget1 * materialUniform.morphTargetInfluences[ 1 ]; - transformed += input.morphTarget2 * materialUniform.morphTargetInfluences[ 2 ]; - transformed += input.morphTarget3 * materialUniform.morphTargetInfluences[ 3 ]; - #if ${e.USE_MORPHNORMALS} - transformed += input.morphTarget4 * materialUniform.morphTargetInfluences[ 4 ]; - transformed += input.morphTarget5 * materialUniform.morphTargetInfluences[ 5 ]; - transformed += input.morphTarget6 * materialUniform.morphTargetInfluences[ 6 ]; - transformed += input.morphTarget7 * materialUniform.morphTargetInfluences[ 7 ]; - #endif + + #if ${defines.USE_CLEARCOAT_ROUGHNESSTEXTURE} + @group(0) @binding(${defines.clearcoatRclearcoatRoughnessTextureBinding}) var clearcoatRoughnessTexture: texture_2d; #endif - #endif - #if ${e.USE_SKINNING} - let skinVertex:vec4 = materialUniform.bindMatrix * vec4( transformed, 1.0 ); - let skinned:vec4 = vec4( 0.0 ); - skinned += boneMatX * skinVertex * input.skinWeight.x; - skinned += boneMatY * skinVertex * input.skinWeight.y; - skinned += boneMatZ * skinVertex * input.skinWeight.z; - skinned += boneMatW * skinVertex * input.skinWeight.w; - transformed = ( materialUniform.bindMatrixInverse * skinned ).xyz; - #endif - #if ${e.USE_DISPLACEMENTTEXTURE} - transformed += normalize( objectNormal ) * (textureSample(displacementMap, baseSampler, vUv).x * materialUniform.displacementScale + materialUniform.displacementBias ); - #endif - var mvPosition:vec4 = vec4( transformed, 1.0 ); - #if ${e.USE_INSTANCING} - mvPosition = input.instanceMatrix * mvPosition; - #endif - mvPosition = globalUniform.viewMatrix*materialUniform.modelMatrix * mvPosition; - vertexOutput.position = globalUniform.projectionMatrix * mvPosition; - vertexOutput.vViewPosition = - mvPosition.xyz/mvPosition.w; - #if ${e.USE_ENVTEXTURE || e.DISTANCE || e.USE_TRANSMISSION} - var worldPosition:vec4 = vec4( transformed, 1.0 ); - #if ${e.USE_INSTANCING} - worldPosition = input.instanceMatrix * worldPosition; + + #if ${defines.USE_CLEARCOAT_NORMALTEXTURE} + @group(0) @binding(${defines.clearcoatNormalTextureBinding}) var clearcoatNormalTexture: texture_2d; + #endif + + #if ${defines.USE_IRIDESCENCETEXTURE} + @group(0) @binding(${defines.iridescenceTextureBinding}) var iridescenceTexture: texture_2d; + #endif + + #if ${defines.USE_IRIDESCENCE_THICKNESSTEXTURE} + @group(0) @binding(${defines.iridescenceThicknessTextureBinding}) var iridescenceThicknessTexture: texture_2d; + #endif + + #if ${defines.USE_ROUGHNESSTEXTURE} + @group(0) @binding(${defines.roughnessTextureBinding}) var roughnessTexture: texture_2d; + #endif + + #if ${defines.USE_METALNESSTEXTURE} + @group(0) @binding(${defines.metalnessTextureBinding}) var metalnessTexture: texture_2d; + #endif + + #if ${defines.SPECULAR} + #if ${defines.USE_SPECULARINTENSITYTEXTURE} + @group(0) @binding(${defines.specularIntensityTextureBinding}) var specularIntensityTexture: texture_2d; + #endif + + #if ${defines.USE_SPECULARCOLORTEXTURE} + @group(0) @binding(${defines.specularColorTextureBinding}) var specularColorTexture: texture_2d; + #endif #endif - worldPosition = materialUniform.modelMatrix * worldPosition; - #endif - #if ${e.USE_TRANSMISSION} - vertexOutput.vWorldPosition = worldPosition.xyz; - #endif - return vertexOutput; + + #if ${defines.USE_SHEEN} + #if ${defines.USE_SHEENCOLORTEXTURE} + @group(0) @binding(${defines.sheenColorTextureBinding}) var sheenColorTexture: texture_2d; + #endif + #if ${defines.USE_SHEENROUGHNESSTEXTURE} + @group(0) @binding(${defines.sheenRoughnessTextureBinding}) var sheenRoughnessTexture: texture_2d; + #endif + #endif + + #if ${defines.USE_TEXTURE} + @group(0) @binding(${defines.baseSamplerBinding}) var baseSampler: sampler; + @group(0) @binding(${defines.baseTextureBinding}) var baseTexture: texture_2d; + #endif + + #if ${defines.USE_ALPHATEXTURE} + @group(0) @binding(${defines.alphaTextureBinding}) var alphaTexture: texture_2d; + #endif + + #if ${defines.USE_AOTEXTURE} + @group(0) @binding(${defines.aoTextureBinding}) var aoTexture: texture_2d; + + #endif + #if ${defines.USE_LIGHTTEXTURE} + @group(0) @binding(${defines.lightTextureBinding}) var lightTexture: texture_2d; + #endif + + #if ${defines.USE_EMISSIVETEXTURE} + @group(0) @binding(${defines.emissiveTextureBinding}) var emissiveTexture: texture_2d; + #endif + `; +} + +function pbrUtils(defines) { + return wgslParseDefines` + const PI:f32= 3.141592653589793; + const PI2:f32= 6.283185307179586; + const PI_HALF:f32= 1.5707963267948966; + const RECIPROCAL_PI:f32= 0.3183098861837907; + const RECIPROCAL_PI2:f32= 0.15915494309189535; + const EPSILON:f32= 1e-6; + + fn pow2(x:f32 )->f32 { + return x*x; + } + fn pow2Vector(x:vec3 )->vec3 { + return x*x; + } + fn pow3( x:f32 )->f32 { + return x*x*x; + } + fn pow4( x:f32 )->f32 { + let x2:f32 = x*x; + return x2*x2; + } + fn max3( v:vec3 )->f32 { + return max( max( v.x, v.y ), v.z ); + } + fn average(v:vec3 )->f32 { + return dot( v, vec3( 0.3333333 ) ); + } + fn rand( uv:vec2 )->f32 { + let a:f32 = 12.9898; + let b:f32 = 78.233; + let c:f32 = 43758.5453; + let dt:f32 = dot( uv.xy, vec2( a, b ) ); + let sn:f32 = dt % PI; + return fract( sin( sn ) * c ); + } + fn transformDirection( dir:vec3, matrix:mat4x4 )->vec3 { + return normalize( ( matrix * vec4( dir, 0.0 ) ).xyz ); + } + + fn transposeMat3( m:mat3x3 )->mat3x3 { + var tmp:mat3x3; + tmp[ 0 ] = vec3( m[ 0 ].x, m[ 1 ].x, m[ 2 ].x ); + tmp[ 1 ] = vec3( m[ 0 ].y, m[ 1 ].y, m[ 2 ].y ); + tmp[ 2 ] = vec3( m[ 0 ].z, m[ 1 ].z, m[ 2 ].z ); + return tmp; + } + fn luminance( rgb:vec3 )->f32 { + let weights:vec3 = vec3(0.2126729, 0.7151522, 0.0721750 ); + return dot( weights, rgb ); + } + fn LinearToneMapping( color:vec3,toneMappingExposure:f32 )->vec3 { + return toneMappingExposure * color; + } + + fn ReinhardToneMapping( color:vec3,toneMappingExposure:f32 )->vec3 { + var tempColor:vec3; + tempColor=color; + tempColor *= toneMappingExposure; + return saturate( tempColor / ( vec3( 1.0 ) + tempColor ) ); + } + fn CustomToneMapping( color:vec3 )->vec3 { + return color; + } + fn toneMapping( color:vec3,toneMappingExposure:f32 )->vec3 { + return ReinhardToneMapping( color,toneMappingExposure ); + } + + fn LinearToLinear( value:vec4 )->vec4 { + return value; + } + fn lessThanEqual(a:vec3,b:vec3)->vec3{ + let xValue:f32=select(b.x,a.x,a.x<=b.x); + let yValue:f32=select(b.y,a.y,a.y<=b.y); + let zValue:f32=select(b.z,a.z,a.z<=b.z); + return vec3(xValue,yValue,zValue); + } + fn LinearTosRGB( value:vec4 )->vec4 { + return vec4( mix( pow( value.rgb, vec3( 0.41666 ) ) * 1.055 - vec3( 0.055 ), value.rgb * 12.92, vec3( lessThanEqual( value.rgb, vec3( 0.0031308 ) ) ) ), value.a ); + } + fn linearToOutputTexel(value:vec4 )->vec4 { + return LinearTosRGB( value ); } `; - } - }, - skybox: { - frag: function (e) { - return "\n fn lessThanEqual(a:vec3,b:vec3)->vec3{\n let xValue:f32=select(b.x,a.x,a.x<=b.x);\n let yValue:f32=select(b.y,a.y,a.y<=b.y);\n let zValue:f32=select(b.z,a.z,a.z<=b.z);\n return vec3(xValue,yValue,zValue); \n }\n fn LinearTosRGB( value:vec4 )->vec4 {\n return vec4( mix( pow( value.rgb, vec3( 0.41666 ) ) * 1.055 - vec3( 0.055 ), value.rgb * 12.92, vec3( lessThanEqual( value.rgb, vec3( 0.0031308 ) ) ) ), value.a );\n }\n struct FragmentInput {\n @location(0) texCoord : vec3\n };\n @group(0) @binding(2) var defaultSampler: sampler;\n @group(0) @binding(1) var skyboxTexture: texture_cube;\n @fragment\n fn main(input : FragmentInput) -> @location(0) vec4 {\n let color = textureSample(skyboxTexture, defaultSampler, input.texCoord);\n return LinearTosRGB(color);\n }\n"; - }, - vert: function (e) { - return `\n struct SystemUniform {\n projectionMatrix: mat4x4,\n viewMatrix: mat4x4,\n inverseViewMatrix: mat4x4,\n cameraPosition: vec3,\n }; \n struct MaterialUniform {\n modelMatrix: mat4x4,\n }\n @binding(${e.skyboxBinding}) @group(0) var selfUniform : MaterialUniform;\n @binding(${e.cameraBinding}) @group(1) var systemUniform : SystemUniform;\n struct VertexInput {\n @location(${e.positionLocation}) position : vec3,\n };\n struct VertexOutput {\n @builtin(position) position : vec4,\n @location(0) texCoord : vec3,\n };\n @vertex\n fn main(input : VertexInput) -> VertexOutput {\n var output : VertexOutput;\n output.texCoord = input.position.xyz;\n var modelView = systemUniform.viewMatrix;\n // Drop the translation portion of the modelView matrix\n modelView[3] = vec4(0.0, 0.0, 0.0, modelView[3].w);\n output.position = systemUniform.projectionMatrix * modelView * vec4(input.position,1.0);\n output.position = output.position.xyww;\n return output;\n }\n `; - } - }, - resolve: { - frag: function (e) { - return "\n @group(0) @binding(1) var baseSampler: sampler;\n @group(0) @binding(0) var colorTexture: texture_2d;\n struct VertexOutput {\n @builtin(position) position: vec4,\n @location(0) uv: vec2,\n };\n @fragment\n fn main(input:VertexOutput) -> @location(0) vec4 {\n return textureSample(colorTexture, baseSampler, vec2(input.uv.x,1.0-input.uv.y));\n }\n "; - }, - vert: zi - }, - pbr_mat: { - frag: function (e) { - return Di` - // reference: https://github.com/KhronosGroup/glTF-WebGL-PBR/blob/master/shaders/pbr-frag.glsl - #include - #include - #include - #include - #include - #include - struct PhysicalMaterial { - diffuseColor:vec3, - roughness:f32, - specularColor:vec3, - #if ${e.USE_CLEARCOAT} - clearcoat:f32, - clearcoatRoughness:f32, - clearcoatF0:vec3, - clearcoatF90:f32, - #endif +} - #if ${e.USE_IRIDESCENCE} - iridescence:f32, - iridescenceIOR:f32, - iridescenceThickness:f32, - iridescenceFresnel:vec3, - iridescenceF0:vec3, - #endif +function blinn_phong(defines) { + return ` + fn getPointLightInfo(pointLight:PointLight,worldPos:vec3,shininess:f32,N:vec3,V:vec3)->vec3{ + var color=vec3(0.0,0.0,0.0); + var direction:vec3 = worldPos - pointLight.position; + let dist:f32 = length( direction ); + direction = normalize(direction); + let decay = clamp(1.0 - pow(dist / pointLight.distance, 4.0), 0.0, 1.0); - #if ${e.USE_SHEEN} - sheenColor:vec3, - sheenRoughness:f32, - #endif + let d = max( dot( N, -direction ), 0.0 ) * decay; + color += pointLight.color * d; - #if ${e.IOR} - ior:f32, - #endif + let halfDir:vec3 = normalize( V - direction ); + let s:f32 = pow( clamp( dot( N, halfDir ), 0.0, 1.0 ), shininess ) * decay; + color += pointLight.color * s; + return color; + } + fn getSpotLightInfo(spotLight:SpotLight,worldPos:vec3,shininess:f32,N:vec3,V:vec3)->vec3{ + var color=vec3(0.0,0.0,0.0); + var direction:vec3 = spotLight.position - worldPos; + let lightDistance:f32 = length(direction); + direction = normalize(direction); + let angleCos:f32 = dot( direction, -spotLight.direction ); + let decay:f32 = clamp(1.0 - pow(lightDistance/spotLight.distance, 4.0), 0.0, 1.0); + let spotEffect:f32 = smoothstep( spotLight.penumbraCos, spotLight.coneCos, angleCos ); + let decayTotal:f32 = decay * spotEffect; + let d:f32 = max( dot( N, direction ), 0.0 ) * decayTotal; + color += spotLight.color * d; + let halfDir:vec3 = normalize( V + direction ); + let s:f32 = pow( clamp( dot( N, halfDir ), 0.0, 1.0 ), shininess ) * decayTotal; + color += spotLight.color * s; + return color; + } + struct DirectionalLight { + direction: vec3, + color: vec3, + }; + fn getDirectLightInfo(directionalLight:DirectionalLight,shininess:f32,N:vec3,V:vec3)->vec3{ + var color=vec3(0.0,0.0,0.0); + let d:f32 = max(dot(N, -directionalLight.direction), 0.0); + color += directionalLight.color * d; - #if ${e.USE_TRANSMISSION} - transmission:f32, - transmissionAlpha:f32, - thickness:f32, - attenuationDistance:f32, - attenuationColor:vec3, - #endif - }; - const M_PI:f32 = 3.141592653589793; - const c_MinRoughness:f32 = 0.04; - #include - #if ${e.USE_IBL} - #include + let halfDir:vec3 = normalize( V - directionalLight.direction ); + let s:f32 = pow( clamp( dot( N, halfDir ), 0.0, 1.0 ), shininess ); + color += directionalLight.color * s; + return color; + } + `; +} + +function phongFunction(defines) { + return ` + fn G_BlinnPhong_Implicit( )->f32 { + + // geometry term is (n dot l)(n dot v) / 4(n dot l)(n dot v) + return 0.25; + + } + fn D_BlinnPhong( shininess:f32, dotNH:f32 )->f32 { + + return RECIPROCAL_PI * ( shininess * 0.5 + 1.0 ) * pow(dotNH, shininess); + + } + fn BRDF_BlinnPhong( lightDir:vec3, viewDir:vec3, normal:vec3, specularColor:vec3, shininess:f32 )->vec3 { + + let halfDir = normalize( lightDir + viewDir ); + + let dotNH:f32 = saturate( dot( normal, halfDir ) ); + let dotVH:f32 = saturate( dot( viewDir, halfDir ) ); + + let F = F_Schlick( specularColor, 1.0, dotVH ); + + let G:f32 = G_BlinnPhong_Implicit( ); + + let D = D_BlinnPhong( shininess, dotNH ); + + return F * ( G * D ); + + } + fn RE_Direct_BlinnPhong( directLight:IncidentLight,geometry:GeometricContext, material:BlinnPhongMaterial )->ReflectedLight{ + var reflectedLight:ReflectedLight; + let dotNL:f32 = saturate(dot(geometry.normal, directLight.direction)); + let irradiance:vec3 = dotNL*directLight.color; + + reflectedLight.directDiffuse= irradiance * BRDF_Lambert( material.diffuseColor ); + + reflectedLight.directSpecular= irradiance * BRDF_BlinnPhong( directLight.direction, geometry.viewDir, geometry.normal, material.specularColor, material.specularShininess ) * material.specularStrength; + return reflectedLight; + } + fn RE_IndirectDiffuse_BlinnPhong( irradiance:vec3, geometry:GeometricContext, material:BlinnPhongMaterial)->ReflectedLight { + var reflectedLight:ReflectedLight; + reflectedLight.indirectDiffuse += irradiance * BRDF_Lambert( material.diffuseColor ); + return reflectedLight; + } + `; +} + +function phongUtils(defines) { + return ` + struct BlinnPhongMaterial { + diffuseColor:vec3, + specularColor:vec3, + specularShininess:f32, + specularStrength:f32, + }; + const RECIPROCAL_PI:f32= 0.3183098861837907; + fn pow2( x:f32 )->f32 { return x*x; } + fn pow3( x:f32 )->f32 { return x*x*x; } + fn pow4(x:f32 )->f32 { let x2 = x*x; return x2*x2; } + fn max3( v:vec3 )->f32 { return max( max( v.x, v.y ), v.z ); } + fn average(v:vec3 )->f32 { + let result=vec3( 0.3333333, 0.3333333, 0.3333333); + return dot( v,result ); + } + `; +} + +function skinVertHeader(defines) { + return wgslParseDefines` + #if ${defines.HAS_SKIN} + struct JointsUniform{ + matrixs:array, + } + struct InverseBindMatricesUniform{ + matrixs:array, + } + @binding(${defines.skinJointsBufferBinding}) @group(0) var jointsUniform : JointsUniform; + @binding(${defines.invsBufferBinding}) @group(0) var inverseBindMatricesUniform : InverseBindMatricesUniform; + fn getSkinMatrix(joints: vec4f, weights: vec4f) -> mat4x4 { + let joint0 = jointsUniform.matrixs[u32(joints.x)] * inverseBindMatricesUniform.matrixs[u32(joints.x)]; + let joint1 = jointsUniform.matrixs[u32(joints.y)] * inverseBindMatricesUniform.matrixs[u32(joints.y)]; + let joint2 = jointsUniform.matrixs[u32(joints.z)] * inverseBindMatricesUniform.matrixs[u32(joints.z)]; + let joint3 = jointsUniform.matrixs[u32(joints.w)] * inverseBindMatricesUniform.matrixs[u32(joints.w)]; + + let skinMatrix = joint0 * weights.x + + joint1 * weights.y + + joint2 * weights.z + + joint3 * weights.w; + return skinMatrix; + } #endif - @binding(${e.pbrBinding}) @group(0) var materialUniform : MaterialUniform; - @binding(${e.cameraBinding}) @group(1) var systemUniform : SystemUniform; - @fragment - fn main(input:FragInput) -> @location(0) vec4 - { - var perceptualRoughness:f32 = materialUniform.roughness; - var metallic:f32 = materialUniform.metallic; + `; +} +function skinVertMain(defines) { + return wgslParseDefines` + #if ${defines.HAS_SKIN} + modelMatrix =getSkinMatrix(input.joint0,input.weight0); + vNormalView = normalize((materialUniform.normalMatrix * modelMatrix * vec4(input.normal, 0.0)).xyz); + #endif + `; +} - #if ${e.USE_METALNESSTEXTURE} - let mrSample:vec4 = textureSample(metalnessRoughnessTexture,metalnessRoughnessSampler, input.uv); - perceptualRoughness = mrSample.g * perceptualRoughness; - metallic = mrSample.b * metallic; - #endif - perceptualRoughness = clamp(perceptualRoughness, c_MinRoughness, 1.0); - metallic = clamp(metallic, 0.0, 1.0); - let alphaRoughness:f32 = perceptualRoughness * perceptualRoughness; +function PbrMaterialStruct(defines) { + return wgslParseDefines` + struct MaterialUniform { + modelMatrix: mat4x4, + color: vec3, + opacity:f32, + normalMatrix: mat4x4, + emissive:vec3, + metallic:f32, + roughness:f32, + #if ${defines.USE_NORMALTEXTURE} + normalTextureScale:vec2, + #endif + #if ${defines.USE_AOTEXTURE} + occlusionStrength:f32, + #endif + } + `; +} +const ShaderChunk = { + light, + brdf, + phongFunction, + phongUtils, + lightCommon, + pbrStruct, + pbrFunction, + pbrTexture, + pbrUtils, + environment, + blinn_phong, + getNormal, + getTBN, + getNormalByNormalTexture, + ibl, + skinVertMain, + skinVertHeader, + FragInput, + VertexInput, + VertexOutput, + PbrMaterialStruct, + SystemUniform, + instanceVertMain, + instanceVertHeader, + TextureAndSamplerDefine, + PointVertInput, + PointVertOutput, + PointFragInput +}; - // The albedo may be defined from a base texture or a flat color - #if ${e.USE_TEXTURE} - let baseColor:vec4 = textureSample(baseColorTexture,baseColorSampler, input.uv) ; - #else - let baseColor:vec4 = vec4(materialUniform.color,1.0); - #endif +function shadowMapDebuggerFrag(defines) { + return ` + @group(0) @binding(1) var shadowSampler: sampler; + @group(0) @binding(0) var shadowMap: texture_depth_2d; + + // @group(0) @binding(0) var shadowMap: texture_depth_2d_array; + // @group(0) @binding(0) var shadowMap: texture_2d; + + struct VertexOutput { + @builtin(position) position: vec4, + @location(0) uv: vec2, + }; + + fn linearizeDepth(depth: f32, near: f32, far: f32)->f32 { + return 2 * (near * far) / (far + near - depth * (far - near)); + } - #if ${e.USE_NORMALTEXTURE} - let n:vec3 = getNormalByNormalTexture(input); - #else - let n:vec3 = getNormal(input); - #endif - var material:PhysicalMaterial; - material.diffuseColor=baseColor.rgb*( 1.0 - metallic ); - material.roughness=perceptualRoughness; - material.specularColor=mix( vec3( 0.04), baseColor.rgb, metallic ); - var geometry:Geometry; - geometry.normal=n; - geometry.viewDir=normalize(systemUniform.cameraPosition - input.worldPos); - geometry.position=input.worldPos; - geometry.dotNV = saturate(dot(geometry.normal, geometry.viewDir) ); - //light shading - var reflectedLight=parseLights(geometry,material); - var color=reflectedLight.directDiffuse+reflectedLight.directSpecular; - //IBL - #if ${e.USE_IBL && e.HAS_UV} - var reflectedLightDiffuse=indirectDiffuse_Physical(geometry,material); - var reflectedLightSpecular=indirectSpecular_Physical(geometry,material); - color+=reflectedLightDiffuse.indirectDiffuse; - color+=reflectedLightSpecular.indirectSpecular; - #endif - #if ${e.USE_AOTEXTURE} - let ao:f32 = textureSample(aoTexture,aoSampler, input.uv).r; - color = mix(color, color * ao, materialUniform.occlusionStrength); - #endif + @fragment + fn main(input:VertexOutput) -> @location(0) vec4 { + let color: vec4 = textureGather(shadowMap, shadowSampler, vec2(input.uv.x,1.0-input.uv.y)); + let depth = (linearizeDepth(color.r, 0.1, 500) - 0.1) / (500 - 0.1); + return vec4(vec3(depth), 1.0); // PerspectiveCamera + // return color; + + // return textureSample(shadowMap, shadowSampler, vec2(input.uv.x,1.0-input.uv.y)); - #if ${e.USE_EMISSIVETEXTURE} - let emissive:vec3 = textureSample(emissiveTexture, emissiveSampler,input.uv).rgb ; - color += emissive; - #endif - return vec4(color, baseColor.a); } - `; - }, - vert: function (e) { - return Di` - #include - #include - #include - #include - #include - #include - @binding(${e.pbrBinding}) @group(0) var materialUniform : MaterialUniform; - @binding(${e.cameraBinding}) @group(1) var systemUniform : SystemUniform; + `; +} + +function shadowMapDebuggerVert(defines) { + return ` + struct VertexInput { + @location(${defines.positionLocation}) position: vec2, + } + struct VertexOutput { + @builtin(position) position: vec4, + @location(0) uv: vec2, + }; @vertex - fn main(input: VertexInput)-> VertexOutput - { - var output: VertexOutput; - #if ${e.HAS_UV} - output.uv = input.uv; - #endif - var modelMatrix:mat4x4; - var vNormalView:vec3; - vNormalView = normalize(materialUniform.normalMatrix * vec4(input.normal,0.0)).xyz; - modelMatrix=materialUniform.modelMatrix; - #include - #include - output.normal = vNormalView.xyz; - output.position = systemUniform.projectionMatrix * systemUniform.viewMatrix *modelMatrix* vec4(input.position, 1.0); - let modelPos=modelMatrix *vec4(input.position,1.0); - output.worldPos = modelPos.xyz/modelPos.w; - return output; - } - `; - } - }, - blur: { - frag: function (e) { - return `\n struct FragInput {\n @location(0) uv: vec2,\n }\n struct BlurUniforms {\n direction:vec2,\n }\n fn gaussianPdf(x:f32, sigma:f32)->f32 {\n return 0.39894 * exp( -0.5 * x * x/( sigma * sigma))/sigma;\n }\n @group(0) @binding(0) var blurUniforms : BlurUniforms;\n @group(0) @binding({{tDiffuseBinding}}) var tDiffuse: texture_2d;\n @group(0) @binding({{tSamplerBinding}}) var tSampler: sampler;\n @fragment\n fn main(input:FragInput) -> @location(0) vec4 {\n let invSize:vec2 = vec2(1.0,1.0) / vec2(textureDimensions(tDiffuse));\n let fSigma:f32 =f32(${e.SIGMA});\n var weightSum:f32 = gaussianPdf(0.0, fSigma);\n let baseColor=textureSample(tDiffuse, tSampler, input.uv);\n var diffuseSum:vec3 = baseColor.rgb * weightSum;\n let uvOffset:vec2 = blurUniforms.direction * invSize;\n for( var i : u32 = 1; i < ${e.KERNEL_RADIUS};i = i + 1 ) {\n let x:f32 = f32(i);\n let w:f32 = gaussianPdf(x, fSigma);\n let sample1:vec3=textureSample(tDiffuse, tSampler, input.uv+ uvOffset*x).rgb;\n let sample2:vec3=textureSample(tDiffuse, tSampler, input.uv- uvOffset*x).rgb;\n diffuseSum =diffuseSum+ (sample2+sample2)* w;\n weightSum += 2.0 * w;\n }\n diffuseSum/=weightSum;\n return vec4(diffuseSum,baseColor.a);\n }\n `; - }, - vert: zi - }, - luminosityHigh: { - frag: function (e) { - return "\n struct LuminosityUniforms{\n luminosityThreshold:f32,\n smoothWidth:f32,\n defaultColor:vec3,\n defaultOpacity:f32,\n }\n struct FragInput {\n @location(0) uv: vec2,\n };\n @group(0) @binding(0) var luminosityUniforms : LuminosityUniforms;\n @group(0) @binding({{tDiffuseBinding}}) var tDiffuse: texture_2d;\n @group(0) @binding({{tSamplerBinding}}) var tSampler: sampler;\n @fragment\n fn main(input:FragInput)-> @location(0) vec4 {\n\n let texel:vec4 = textureSample(tDiffuse, tSampler, input.uv);\n\n let luma:vec3 = vec3( 0.299,0.587,0.114 );\n\n let v:f32 = dot( texel.xyz, luma );\n\n let outputColor:vec4 = vec4( luminosityUniforms.defaultColor.rgb, luminosityUniforms.defaultOpacity );\n\n let alpha:f32 = smoothstep( luminosityUniforms.luminosityThreshold, luminosityUniforms.luminosityThreshold + luminosityUniforms.smoothWidth, v );\n\n return mix( outputColor, texel, alpha );\n }\n "; - }, - vert: zi - }, - blend: { - frag: function (e) { - return "\n struct FragInput {\n @location(0) uv: vec2,\n };\n @group(0) @binding({{tDiffuseBinding}}) var tDiffuse: texture_2d;\n @group(0) @binding({{baseColorTextureBinding}}) var baseColorTexture: texture_2d;\n @group(0) @binding({{tSamplerBinding}}) var tSampler: sampler;\n @fragment\n fn main(input:FragInput) -> @location(0) vec4 {\n let postColor:vec4 = textureSample(tDiffuse, tSampler, input.uv);\n let baseColor:vec4 = textureSample(baseColorTexture, tSampler, input.uv);\n return baseColor+postColor;\n } \n "; - }, - vert: zi - }, - shadowMapDebugger: { - frag: function (e) { - return "\n @group(0) @binding(1) var shadowSampler: sampler;\n @group(0) @binding(0) var shadowMap: texture_depth_2d;\n \n // @group(0) @binding(0) var shadowMap: texture_depth_2d_array;\n // @group(0) @binding(0) var shadowMap: texture_2d;\n\n struct VertexOutput {\n @builtin(position) position: vec4,\n @location(0) uv: vec2,\n };\n\n fn linearizeDepth(depth: f32, near: f32, far: f32)->f32 {\n return 2 * (near * far) / (far + near - depth * (far - near));\n }\n\n @fragment\n fn main(input:VertexOutput) -> @location(0) vec4 {\n\t\t\tlet color: vec4 = textureGather(shadowMap, shadowSampler, vec2(input.uv.x,1.0-input.uv.y));\n let depth = (linearizeDepth(color.r, 0.1, 500) - 0.1) / (500 - 0.1);\n return vec4(vec3(depth), 1.0); // PerspectiveCamera\n // return color;\n\n // return textureSample(shadowMap, shadowSampler, vec2(input.uv.x,1.0-input.uv.y));\n\n }\n "; - }, - vert: function (e) { - return `\n struct VertexInput {\n @location(${e.positionLocation}) position: vec2, \n }\n struct VertexOutput {\n @builtin(position) position: vec4,\n @location(0) uv: vec2,\n };\n @vertex\n fn main(input: VertexInput) -> VertexOutput {\n var output:VertexOutput;\n output.uv = input.position * 0.5 + 0.5;\n output.position = vec4(input.position, 0.0, 1.0);;\n return output;\n }\n `; - } - }, - shadowMap: { - vert: function (e) { - return Di` + fn main(input: VertexInput) -> VertexOutput { + var output:VertexOutput; + output.uv = input.position * 0.5 + 0.5; + output.position = vec4(input.position, 0.0, 1.0);; + return output; + } + `; +} + +// import Color from "../../math/Color"; +function shadowMapFrag(defines) { + return ` + struct VertexOutput { + @builtin(position) position: vec4, + @location(0) color: vec4, + }; + @fragment + fn main(input:VertexOutput) -> @location(0) vec4 { + return input.color; + } + `; +} + +function shadowMapVert(defines) { + return wgslParseDefines` struct VertexInput { - @location(${e.positionLocation}) position: vec3, + @location(${defines.positionLocation}) position: vec3, }; struct VertexOutput { @builtin(position) position: vec4, @@ -8232,21 +10847,21 @@ fn main(input:VertexOutput)-> @location(0) vec4 { cameraPosition: vec3, }; - #if ${e.isPointLightShadowMap} + #if ${defines.isPointLightShadowMap} struct PointLightUniform { vpMatrix: mat4x4, // vpMatrixArray: array, 6>, }; - @group(1) @binding(${e.pointLightShadowCameraBinding}) var pointLightUniform: PointLightUniform; + @group(1) @binding(${defines.pointLightShadowCameraBinding}) var pointLightUniform: PointLightUniform; #endif - @group(0) @binding(${e.selfBinding}) var selfUniform : SelfUniform; - @group(1) @binding(${e.cameraBinding}) var systemUniform : SystemUniform; + @group(0) @binding(${defines.selfBinding}) var selfUniform : SelfUniform; + @group(1) @binding(${defines.cameraBinding}) var systemUniform : SystemUniform; @vertex fn main(input: VertexInput) -> VertexOutput { var output:VertexOutput; - #if ${e.isPointLightShadowMap} + #if ${defines.isPointLightShadowMap} output.position = pointLightUniform.vpMatrix * selfUniform.modelMatrix * vec4(input.position,1.0); #else output.position = systemUniform.projectionMatrix * systemUniform.viewMatrix * selfUniform.modelMatrix * vec4(input.position,1.0); @@ -8254,286 +10869,384 @@ fn main(input:VertexOutput)-> @location(0) vec4 { return output; } `; - }, - frag: function (e) { - return "\n struct VertexOutput {\n @builtin(position) position: vec4,\n @location(0) color: vec4,\n };\n @fragment\n fn main(input:VertexOutput) -> @location(0) vec4 {\n return input.color;\n }\n "; - } +} + +function reduceComma(shader) { + // 对所有的include处理 + return shader != undefined ? resolveIncludes(shader) : undefined; +} +const includePattern = /^[ \t]*#include +<([\w\d./]+)>/gm; +let currentDefines = {}; +const shaders = { + phong: { + frag: phongFrag, + vert: phongVert + }, + color: { + frag: colorFrag, + vert: colorVert + }, + pbr: { + frag: pbrFrag, + vert: pbrVert + }, + skybox: { + frag: skyBoxFrag, + vert: skyBoxVert + }, + resolve: { + frag: quadFrag, + vert: quadVert + }, + pbr_mat: { + frag: pbr_fs, + vert: pbr_vs + }, + blur: { + frag: Blur, + vert: quadVert + }, + luminosityHigh: { + frag: LuminosityHigh, + vert: quadVert + }, + blend: { + frag: blendFrag, + vert: quadVert + }, + shadowMapDebugger: { + frag: shadowMapDebuggerFrag, + vert: shadowMapDebuggerVert + }, + shadowMap: { + vert: shadowMapVert, + frag: shadowMapFrag }, sprite: { - vert: function (e) { - return Di` - - #include - #include - #include - struct SelfUniform { - modelMatrix: mat4x4, - color:vec3, - rotation:f32, - center:vec2, - opacity:f32, - } - @binding(${e.spriteBinding}) @group(0) var selfUniform : SelfUniform; - @binding(${e.cameraBinding}) @group(1) var systemUniform : SystemUniform; - @vertex - fn main(input: VertexInput) -> VertexOutput { - var output:VertexOutput; - var mvPosition:vec4= systemUniform.viewMatrix *selfUniform.modelMatrix*vec4(0.0,0.0,0.0,1.0); - #if ${e.HAS_UV} - output.uv=input.uv; - #endif - var scale:vec2; - scale.x = length(vec3(selfUniform.modelMatrix[0].x, selfUniform.modelMatrix[0].y, selfUniform.modelMatrix[0].z)); - scale.y = length(vec3(selfUniform.modelMatrix[1].x, selfUniform.modelMatrix[1].y, selfUniform.modelMatrix[1].z)); - // scale *= - mvPosition.z; - var alignedPosition:vec2 =(input.position.xy- (selfUniform.center - vec2(0.5,0.5))) * scale; - let rotatedPositionX = cos(selfUniform.rotation) * alignedPosition.x - sin( selfUniform.rotation ) * alignedPosition.y; - let rotatedPositionY = sin(selfUniform.rotation) * alignedPosition.x + cos( selfUniform.rotation ) * alignedPosition.y; - var rotatedPosition=vec2(rotatedPositionX,rotatedPositionY); - let newPoint =mvPosition.xy+ rotatedPosition; - output.position = systemUniform.projectionMatrix * vec4(newPoint.x,newPoint.y,mvPosition.z,mvPosition.w); - return output; - } - `; - }, - frag: function (e) { - return Di` - #include - struct SelfUniform { - modelMatrix: mat4x4, - color:vec3, - rotation:f32, - center:vec2, - opacity:f32, - } - @binding(${e.spriteBinding}) @group(0) var selfUniform : SelfUniform; - #if${e.USE_COLORTEXTURE} - @group(0) @binding(${e.baseColorSamplerBinding}) var baseColorSampler: sampler; - @group(0) @binding(${e.baseColorTextureBinding}) var baseColorTexture: texture_2d; - #endif - @fragment - fn main(input:VertexOutput) -> @location(0) vec4 { - #if${e.USE_COLORTEXTURE} - return textureSample(baseColorTexture, baseColorSampler, input.uv); - #else - return vec4(selfUniform.color,selfUniform.opacity); - #endif - } - `; - } + vert: sprite_vs, + frag: sprite_fs }, point: { - vert: function (e) { - return Di` - #include - #include - #include - struct SelfUniform { - modelMatrix: mat4x4, - color:vec3, - size:f32, - opacity:f32, - } - @binding(${e.pointBinding}) @group(0) var selfUniform : SelfUniform; - @binding(${e.cameraBinding}) @group(1) var systemUniform : SystemUniform; - @vertex - fn main(input: PointVertInput) -> PointVertOutput { - var output:PointVertOutput; - let mvPosition:vec4= ystemUniform.viewMatrix *selfUniform.modelMatrix*vec4(0.0,0.0,0.0, 1.0 ); - #if ${e.HAS_UV} - output.uv=input.uv; - #endif - #if ${e.HAS_COLOR} - output.color=input.color; - #endif - #if ${e.HAS_SIZE} - output.size=input.size; - #endif - vec2 alignedPosition = input.position.xy* selfUniform.size; - mvPosition.xy += alignedPosition; - output.position = systemUniform.projectionMatrix * mvPosition; - return output; - } - `; - }, - frag: function (e) { - return Di` - #include - struct SelfUniform { - modelMatrix: mat4x4, - color:vec3, - size:f32, - opacity:f32, - } - @binding(${e.pointBinding}) @group(0) var selfUniform : SelfUniform; - #if${e.USE_COLORTEXTURE} - @group(0) @binding(${e.baseColorSamplerBinding}) var baseColorSampler: sampler; - @group(0) @binding(${e.baseColorTextureBinding}) var baseColorTexture: texture_2d; - #endif - @fragment - fn main(input:PointFragInput) -> @location(0) vec4 { - var color:vec4=vec4(selfUniform.color,selfUniform.opacity); - #if${e.USE_COLORTEXTURE} - color=textureSample(baseColorTexture, baseColorSampler, input.uv); - #endif - #if${e.HAS_COLOR} - color=vec4(input.color,selfUniform.opacity); - #endif - return color; - } - `; - } + vert: point_vs, + frag: point_fs } }; -function Vi(e) { - return e.replace(Ni, Fi); -} -function Fi(e, t) { - const i = Ii[t]; - if (void 0 === i) throw new Error(`Can not resolve #include <${t}>`); - return Vi(i(Bi)); -} -function $i(e, t = {}) { - const i = Oi[e]; - return (Bi = t), { vert: Pi(i?.vert(Bi)), frag: Pi(i?.frag(Bi)) }; -} -class Gi { - constructor(e) { - (this.shaderId = e.shaderId), - (this.defines = e.defines || {}), - (this.render = e.render), - (this.compute = e.compute), - (this.dirty = !0); +function resolveIncludes(string) { + return string.replace(includePattern, includeReplacer); +} +function includeReplacer(match, include) { + const excute = ShaderChunk[include]; + if (excute === undefined) { + throw new Error(`Can not resolve #include <${include}>`); + } + const result = excute(currentDefines); + return resolveIncludes(result); +} +function getVertFrag(type, defines = {}) { + const excuteFunc = shaders[type]; + currentDefines = defines; + return { + vert: reduceComma(excuteFunc?.vert(currentDefines)), + frag: reduceComma(excuteFunc?.frag(currentDefines)) + }; +} + +class ShaderSource { + constructor(options) { + this.shaderId = options.shaderId; + this.defines = options.defines || {}; + this.render = options.render; + this.compute = options.compute; + this.dirty = true; } get uid() { - return (this._uid = this.shaderId.concat(JSON.stringify(this.defines))), this._uid; + this._uid = this.shaderId.concat(JSON.stringify(this.defines)); + return this._uid; } - setDefines(e) { - e && ((this.dirty = !0), (this.defines = Object.assign(this.defines, e))); + setDefines(defines) { + if (!defines) return; + this.dirty = true; + this.defines = Object.assign(this.defines, defines); } - getShaderModule(e) { + getShaderModule(device) { if (this.dirty) { - const { vert: t, frag: i, compute: r } = this.getShaderStr() || {}, - n = t ? e.createShaderModule({ code: t }) : void 0, - s = i ? e.createShaderModule({ code: i }) : void 0, - a = r ? e.createShaderModule({ code: r }) : void 0; - (this._shaderModule = { vert: n, frag: s, compute: a }), (this.dirty = !1); + const { vert, frag, compute } = this.getShaderStr() || {}; + const vertGPUModule = vert ? device.createShaderModule({ code: vert }) : undefined; + const fragGPUModule = frag ? device.createShaderModule({ code: frag }) : undefined; + const computeGPUModule = compute ? device.createShaderModule({ code: compute }) : undefined; + this._shaderModule = { + vert: vertGPUModule, + frag: fragGPUModule, + compute: computeGPUModule + }; + this.dirty = false; } return this._shaderModule; } destroy() { - (this.render = null), (this.compute = null), (this._shaderModule = null), (this.defines = null); + this.render = null; + this.compute = null; + this._shaderModule = null; + this.defines = null; } getShaderStr() { - const { fragShader: e, vertShader: t } = this.render || {}, - { computeShader: i } = this.compute || {}, - r = $i(this.shaderId, this.defines); + const { fragShader, vertShader } = this.render || {}; + const { computeShader } = this.compute || {}; + const source = getVertFrag(this.shaderId, this.defines); + const vert = source?.vert ?? (vertShader instanceof Function ? vertShader(this.defines) : vertShader); + const frag = source?.frag ?? (fragShader instanceof Function ? fragShader(this.defines) : fragShader); + const compute = computeShader instanceof Function ? computeShader(this.defines) : computeShader; return { - vert: r?.vert ?? (t instanceof Function ? t(this.defines) : t), - frag: r?.frag ?? (e instanceof Function ? e(this.defines) : e), - compute: i instanceof Function ? i(this.defines) : i + vert, + frag, + compute }; } - static replaceMain(e, t) { - return (t = `void ${t}()`), e.replace(/void\s+main\s*\(\s*(?:void)?\s*\)/g, t); + static replaceMain(source, renamedMain) { + renamedMain = `void ${renamedMain}()`; + return source.replace(/void\s+main\s*\(\s*(?:void)?\s*\)/g, renamedMain); } } -const ki = ["array", "array>", "array>", "array>"]; -function qi(e, t, i, r, n) { - const s = t?.value instanceof Function; - switch (t.type) { + +const uniformArrayNames = ["array", "array>", "array>", "array>"]; +function checkContainFloatType(uniforms) { + let result = 0; + let hasArraytype = false; + const uniformsNames = Object.getOwnPropertyNames(uniforms); + uniformsNames.map((uniformsName) => { + if (uniforms[uniformsName].type == "texture" || uniforms[uniformsName].type == "sampler") { + result += 0; + } else { + if ( + uniformArrayNames.find((name) => { + return name === uniforms[uniformsName].type; + }) + ) { + hasArraytype = true; + } else { + result += 1; + } + } + }); + return { + hasFloat: result, + hasArraytype + }; +} +function addUniformToShaderData(name, uniform, shaderData, mesh, uniformBuffer) { + const valueIsFunc = uniform?.value instanceof Function; + switch (uniform.type) { case "f32": - n.setUniform(e, s ? t.value : () => t.value, Q.Float); + uniformBuffer.setUniform( + name, + valueIsFunc + ? uniform.value + : () => { + return uniform.value; + }, + UniformEnum.Float + ); break; case "vec2": - n.setUniform(e, s ? t.value : () => t.value, Q.FloatVec2); + uniformBuffer.setUniform( + name, + valueIsFunc + ? uniform.value + : () => { + return uniform.value; + }, + UniformEnum.FloatVec2 + ); break; case "vec3": - n.setUniform(e, s ? t.value : () => t.value, Q.FloatVec3); + uniformBuffer.setUniform( + name, + valueIsFunc + ? uniform.value + : () => { + return uniform.value; + }, + UniformEnum.FloatVec3 + ); break; case "color": - n.setUniform(e, s ? t.value : () => t.value, Q.Color); + uniformBuffer.setUniform( + name, + valueIsFunc + ? uniform.value + : () => { + return uniform.value; + }, + UniformEnum.Color + ); break; case "vec4": - n.setUniform(e, s ? t.value : () => t.value, Q.FloatVec4); + uniformBuffer.setUniform( + name, + valueIsFunc + ? uniform.value + : () => { + return uniform.value; + }, + UniformEnum.FloatVec4 + ); break; case "mat2x2": - n.setUniform(e, s ? t.value : () => t.value, Q.Mat2); + uniformBuffer.setUniform( + name, + valueIsFunc + ? uniform.value + : () => { + return uniform.value; + }, + UniformEnum.Mat2 + ); break; case "mat3x3": - n.setUniform(e, s ? t.value : () => t.value, Q.Mat3); + uniformBuffer.setUniform( + name, + valueIsFunc + ? uniform.value + : () => { + return uniform.value; + }, + UniformEnum.Mat3 + ); break; case "mat4x4": - n.setUniform( - e, - s - ? t.value - : () => ("modelMatrix" == e ? r?.modelMatrix : "normalMatrix" === e ? r?.normalMatrix : t.value), - Q.Mat4 + uniformBuffer.setUniform( + name, + valueIsFunc + ? uniform.value + : () => + name == "modelMatrix" + ? mesh?.modelMatrix + : name === "normalMatrix" + ? mesh?.normalMatrix + : uniform.value, + UniformEnum.Mat4 ); break; case "array": - n.setUniform(e, s ? t.value : () => t.value, Q.FloatArray, t.value.length); + uniformBuffer.setUniform( + name, + valueIsFunc + ? uniform.value + : () => { + return uniform.value; + }, + UniformEnum.FloatArray, + uniform.value.length + ); break; case "array>": - n.setUniform(e, s ? t.value : () => t.value, Q.Vec2Array, t.value.length); + uniformBuffer.setUniform( + name, + valueIsFunc + ? uniform.value + : () => { + return uniform.value; + }, + UniformEnum.Vec2Array, + uniform.value.length + ); break; case "array>": - n.setUniform(e, s ? t.value : () => t.value, Q.Vec3Array, t.value.length); + uniformBuffer.setUniform( + name, + valueIsFunc + ? uniform.value + : () => { + return uniform.value; + }, + UniformEnum.Vec3Array, + uniform.value.length + ); break; case "array>": - n.setUniform(e, s ? t.value : () => t.value, Q.Vec4Array, t.value.length); + uniformBuffer.setUniform( + name, + valueIsFunc + ? uniform.value + : () => { + return uniform.value; + }, + UniformEnum.Vec4Array, + uniform.value.length + ); break; case "texture": case "storageTexture": - i.setTexture(e, s ? t.value : () => t.value, t?.binding, t?.type, t?.visibility, t?.textureView); + shaderData.setTexture( + name, + valueIsFunc + ? uniform.value + : () => { + return uniform.value; + }, + uniform?.binding, + uniform?.type, + uniform?.visibility, + uniform?.textureView + ); break; case "sampler": - i.setSampler(e, s ? t.value : () => t.value, t?.binding, t?.visibility); + shaderData.setSampler( + name, + valueIsFunc + ? uniform.value + : () => { + return uniform.value; + }, + uniform?.binding, + uniform?.visibility + ); break; default: throw new Error("not match unifrom type"); } } -const ji = new Map(); -class Hi { - constructor(e, t, i = [], r = 0) { - (this.entries = i), - (this.index = r || 0), - (this.gpuBindGroupLayout = e.createBindGroupLayout({ - label: t, - entries: i.map( - ({ visibility: e, buffer: t, sampler: i, texture: r, storageTexture: n, binding: s }) => ({ - binding: s, - visibility: e, - buffer: t, - sampler: i, - texture: r, - storageTexture: n - }) - ) - })); + +const layoutCache = new Map(); +class BindGroupLayout { + constructor(device, label, entries = [], index = 0) { + this.entries = entries; + this.index = index || 0; + this.gpuBindGroupLayout = device.createBindGroupLayout({ + label: label, + entries: entries.map(({ visibility, buffer, sampler, texture, storageTexture, binding }) => ({ + binding, + visibility, + buffer, + sampler, + texture, + storageTexture + })) + }); } - static getBindGroupLayoutFromCache(e, t, i, r) { - if (ji.has(t)) return ji.get(t); - { - const n = new Hi(e, t, i, r); - return ji.set(t, n), n; + static getBindGroupLayoutFromCache(device, label, entires, index) { + if (layoutCache.has(label)) { + return layoutCache.get(label); + } else { + const bindGroupLayout = new BindGroupLayout(device, label, entires, index); + layoutCache.set(label, bindGroupLayout); + return bindGroupLayout; } } - static removeBindGroupLayoutFromCache(e) { - ji.delete(e); + static removeBindGroupLayoutFromCache(bindGroupLayout) { + layoutCache.delete(bindGroupLayout); } } -class Xi { - constructor(e) { - (this.binding = e.binding), - (this.visibility = e.visibility), - (this.buffer = e.buffer), - (this.sampler = e.sampler), - (this.texture = e.texture), - (this.storageTexture = e.storageTexture), - (this.externalTexture = e.externalTexture); + +class BindGroupLayoutEntry { + constructor(options) { + this.binding = options.binding; + this.visibility = options.visibility; + this.buffer = options.buffer; + this.sampler = options.sampler; + this.texture = options.texture; + this.storageTexture = options.storageTexture; + this.externalTexture = options.externalTexture; } getGPULayoutEntity() { return { @@ -8546,2076 +11259,2918 @@ class Xi { storageTexture: this.storageTexture }; } -} -class Yi { - constructor(e, t, i, r) { - (this.label = e), - (this.currentBinding = 0), - (this.defineDirty = !0), - (this.defines = {}), - (this._uniforms = new Map()), - (this.groupIndex = ee(r, 0)), - (this.layoutIndex = ee(i, 0)); - } - getUniformBuffer(e) { - return this._uniforms.get(e); - } - getTexture(e) { - return this._uniforms.get(e); - } - getSampler(e) { - return this._uniforms.get(e); - } - setUniformBuffer(e, t, i) { - this._uniforms.get(e) || - ((t.binding = this.currentBinding), - this.setDefine(e.concat("Binding"), i ?? this.currentBinding), - (this.currentBinding += 1), - this._uniforms.set(e, t)); - } - setTexture(e, t, i, r, n, s) { - if (this._uniforms.get(e)) return; - const a = new Si(e, i ?? this.currentBinding, t, r, n, s); - this.setDefine(e.concat("Binding"), i ?? this.currentBinding), - (this.currentBinding += 1), - this._uniforms.set(e, a); - } - setSampler(e, t, i, r) { - if (this._uniforms.get(e)) return; - const n = new bi(e, i ?? this.currentBinding, t, r); - this.setDefine(e.concat("Binding"), i ?? this.currentBinding), - (this.currentBinding += 1), - this._uniforms.set(e, n); - } - setDefine(e, t) { - if (void 0 === this.defines[e]) (this.defineDirty = !0), (this.defines[e] = t); - else { - if (this.defines[e] === t) return; - (this.defineDirty = !0), (this.defines[e] = t); - } - } - replaceUniformBufferValue(e, t) { - this._uniforms.forEach((i) => { - i?.isUniformBuffer && i.replaceUniformValue(e, t); +} + +class ShaderData { + constructor(label, size, layoutIndex, groupIndex) { + this.label = label; + this.currentBinding = 0; + this.defineDirty = true; + this.defines = {}; + this._uniforms = new Map(); + this.groupIndex = defaultValue(groupIndex, 0); + this.layoutIndex = defaultValue(layoutIndex, 0); + } + getUniformBuffer(name) { + return this._uniforms.get(name); + } + getTexture(name) { + return this._uniforms.get(name); + } + getSampler(name) { + return this._uniforms.get(name); + } + setUniformBuffer(name, uniformBuffer, binding) { + if (this._uniforms.get(name)) return; + uniformBuffer.binding = this.currentBinding; + this.setDefine(name.concat("Binding"), binding ?? this.currentBinding); + this.currentBinding += 1; + this._uniforms.set(name, uniformBuffer); + } + setTexture(name, value, binding, type, visibility, textureView) { + if (this._uniforms.get(name)) return; + const uniform = new UniformTexture(name, binding ?? this.currentBinding, value, type, visibility, textureView); + this.setDefine(name.concat("Binding"), binding ?? this.currentBinding); + this.currentBinding += 1; + this._uniforms.set(name, uniform); + } + setSampler(name, value, binding, visibility) { + if (this._uniforms.get(name)) return; + const uniform = new UniformSampler(name, binding ?? this.currentBinding, value, visibility); + this.setDefine(name.concat("Binding"), binding ?? this.currentBinding); + this.currentBinding += 1; + this._uniforms.set(name, uniform); + } + setDefine(name, value) { + if (this.defines[name] === undefined) { + this.defineDirty = true; + this.defines[name] = value; + } else { + if (this.defines[name] === value) { + return; + } else { + this.defineDirty = true; + this.defines[name] = value; + } + } + } + replaceUniformBufferValue(name, value) { + this._uniforms.forEach((uniform) => { + if (uniform?.isUniformBuffer) { + uniform.replaceUniformValue(name, value); + } }); } - bind(e, t) { - this.uploadUniform(e), - this.groupLayout || (this.groupLayout = this.createBindGroupLayout(e, this.label, this.layoutIndex)), - this.bindGroup || (this.bindGroup = this.createBindGroup(e, this.label, this.groupIndex)), - this.bindGroup.bind(t); + bind(device, passEncoder) { + this.uploadUniform(device); + if (!this.groupLayout) this.groupLayout = this.createBindGroupLayout(device, this.label, this.layoutIndex); + if (!this.bindGroup) this.bindGroup = this.createBindGroup(device, this.label, this.groupIndex); + this.bindGroup.bind(passEncoder); } destroy() { - this._uniforms.forEach((e) => { - e.destroy && e?.destroy(); - }), - (this.label = void 0), - (this.currentBinding = 1), - (this.defineDirty = !0), - (this.defines = void 0), - this._uniforms.clear(), - Hi.removeBindGroupLayoutFromCache(this.groupLayout), - (this.bindGroup = void 0); - } - createBindGroup(e, t, i) { - const { entities: r, dynamic: n, alignedSize: s, maxOffset: a } = this.createBindGroupEntity(); - return new Ve({ - label: t, - entires: r, - device: e, + this._uniforms.forEach((uniform) => { + if (uniform.destroy) uniform?.destroy(); + }); + this.label = undefined; + this.currentBinding = 1; + this.defineDirty = true; + this.defines = undefined; + this._uniforms.clear(); + BindGroupLayout.removeBindGroupLayoutFromCache(this.groupLayout); + this.bindGroup = undefined; + } + createBindGroup(device, label, groupIndex) { + const { entities, dynamic, alignedSize, maxOffset } = this.createBindGroupEntity(); + const bindGroup = new BindGroup({ + label: label, + entires: entities, + device: device, layout: this.groupLayout, - index: i || 0, - dynamic: n, - alignedSize: s, - maxOffset: a + index: groupIndex || 0, + dynamic, + alignedSize, + maxOffset }); + return bindGroup; + } + createBindGroupLayout(device, label, layoutIndex) { + const result = this.createBindGroupLayoutEntry(); + const groupLayout = BindGroupLayout.getBindGroupLayoutFromCache( + device, + label + "-" + result.uid, + result.layouts, + layoutIndex || 0 + ); + return groupLayout; } - createBindGroupLayout(e, t, i) { - const r = this.createBindGroupLayoutEntry(); - return Hi.getBindGroupLayoutFromCache(e, t + "-" + r.uid, r.layouts, i || 0); - } - uploadUniform(e) { - this._uniforms.forEach((t) => { - t.bind(e); + uploadUniform(device) { + this._uniforms.forEach((uniform) => { + uniform.bind(device); }); } createBindGroupLayoutEntry() { - let e = ""; - const t = new Map(); - return ( - this._uniforms.forEach((i) => { - t.has(i.name) || - ((e = "" === e ? e.concat(i.name) : e.concat(", ").concat(i.name)), - t.set(i.name, this.createOneLayoutEntry(i))); - }), - (e = `uniforms[${e}]`), - { uid: e, layouts: [...t.values()] } - ); + let uid = ""; + const result = new Map(); + this._uniforms.forEach((uniform) => { + if (!result.has(uniform.name)) { + uid = uid === "" ? uid.concat(uniform.name) : uid.concat(", ").concat(uniform.name); + result.set(uniform.name, this.createOneLayoutEntry(uniform)); + } + }); + uid = `uniforms[${uid}]`; + return { uid, layouts: [...result.values()] }; } createBindGroupEntity() { - const e = new Map(); - let t = !1, - i = 0, - r = 0; - return ( - this._uniforms.forEach((n) => { - e.has(n.name) || - (n?.hasDynamicOffset && ((t = !0), (r = n.maxOffset), (i = 256 * Math.ceil(n.uniformsSize / 1024))), - e.set(n.name, this.creayeOneGroupEntity(n))); - }), - { entities: [...e.values()], dynamic: t, alignedSize: i, maxOffset: r } - ); - } - createOneLayoutEntry(e) { - let t; - return ( - e.isUniformBuffer - ? (t = new Xi({ binding: e.binding, buffer: e.layoutType, visibility: e.visibility })) - : e.isTexture - ? (t = new Xi({ - binding: e.binding, - visibility: e.visibility, - texture: "texture" == e.type ? e.layoutType : void 0, - storageTexture: "storageTexture" == e.type ? e.storageTextureLayoutType : void 0 - })) - : e.isSampler && (t = new Xi({ binding: e.binding, visibility: e.visibility, sampler: e.layoutType })), - t - ); + const result = new Map(); + let dynamic = false, + alignedSize = 0, + maxOffset = 0; + this._uniforms.forEach((uniform) => { + if (!result.has(uniform.name)) { + if (uniform?.hasDynamicOffset) { + dynamic = true; + maxOffset = uniform.maxOffset; + alignedSize = Math.ceil(uniform.uniformsSize / (4 * 256)) * 256; + } + result.set(uniform.name, this.creayeOneGroupEntity(uniform)); + } + }); + return { + entities: [...result.values()], + dynamic, + alignedSize, + maxOffset + }; } - creayeOneGroupEntity(e) { - let t; - return ( - e.isUniformBuffer - ? (t = new Fe({ - binding: e.binding, - resource: { buffer: e.buffer.gpuBuffer, offset: e.offset, size: e.bufferSize } - })) - : e.isTexture - ? (t = new Fe({ binding: e.binding, resource: e?.textureView ?? e.texture.textureView })) - : e.isSampler && (t = new Fe({ binding: e.binding, resource: e.sampler.gpuSampler })), - t - ); + createOneLayoutEntry(uniform) { + let layoutEntity; + if (uniform.isUniformBuffer) { + layoutEntity = new BindGroupLayoutEntry({ + binding: uniform.binding, + buffer: uniform.layoutType, + visibility: uniform.visibility + }); + } else if (uniform.isTexture) { + layoutEntity = new BindGroupLayoutEntry({ + binding: uniform.binding, + visibility: uniform.visibility, + texture: uniform.type == "texture" ? uniform.layoutType : undefined, + storageTexture: uniform.type == "storageTexture" ? uniform.storageTextureLayoutType : undefined + }); + } else if (uniform.isSampler) { + layoutEntity = new BindGroupLayoutEntry({ + binding: uniform.binding, + visibility: uniform.visibility, + sampler: uniform.layoutType + }); + } + return layoutEntity; + } + creayeOneGroupEntity(uniform) { + let groupEntity; + if (uniform.isUniformBuffer) { + groupEntity = new BindGroupEntity({ + binding: uniform.binding, + resource: { + buffer: uniform.buffer.gpuBuffer, + offset: uniform.offset, + size: uniform.bufferSize + } + }); + } else if (uniform.isTexture) { + groupEntity = new BindGroupEntity({ + binding: uniform.binding, + resource: uniform?.textureView ?? uniform.texture.textureView + }); + } else if (uniform.isSampler) { + groupEntity = new BindGroupEntity({ + binding: uniform.binding, + resource: uniform.sampler.gpuSampler + }); + } + return groupEntity; } } -class Wi { + +class Material { constructor() { - (this.label = void 0), - (this.type = void 0), - (this.baseTexture = void 0), - (this.baseSampler = void 0), - (this._diffuse = new Qt(0, 0, 0)), - (this._opacity = 1), - (this.shaderData = void 0), - (this.shaderSource = void 0), - (this.dirty = !0), - (this._emissive = new Qt(0, 0, 0)), - (this._emissiveIntensity = 1), - (this._doubleSided = !0), - (this.light = !1), - (this.ready = !1), - this.init(); - } - set wireframe(e) { - this.renderState.primitive.topology = e ? S.LineList : S.TriangleList; - } - set topology(e) { - this.renderState.primitive.topology = e; + this.label = undefined; + this.type = undefined; + this.baseTexture = undefined; + this.baseSampler = undefined; + this._diffuse = new Color(0.0, 0.0, 0.0); + this._opacity = 1.0; + // Buffer + this.shaderData = undefined; + this.shaderSource = undefined; + this.dirty = true; + this._emissive = new Color(0.0, 0.0, 0); + this._emissiveIntensity = 1.0; + this._doubleSided = true; + this.light = false; + this.ready = false; + this.init(); + } + set wireframe(value) { + this.renderState.primitive.topology = value ? PrimitiveTopology.LineList : PrimitiveTopology.TriangleList; + } + set topology(value) { + this.renderState.primitive.topology = value; } get doubleSided() { return this._doubleSided; } - set doubleSided(e) { - (this._renderState.primitive.cullMode = e ? w.None : w.Back), (this._doubleSided = e); + set doubleSided(value) { + this._renderState.primitive.cullMode = value ? CullMode.None : CullMode.Back; + this._doubleSided = value; } get renderState() { return this._renderState; } - set renderState(e) { - this._renderState = e; + set renderState(value) { + this._renderState = value; } get diffuse() { return this._diffuse; } - set diffuse(e) { - this._diffuse = e; + set diffuse(v) { + this._diffuse = v; } get emissive() { return this._emissive; } - set emissive(e) { - this._emissive = e; + set emissive(v) { + this._emissive = v; } get emissiveIntensity() { return this._emissiveIntensity; } - set emissiveIntensity(e) { - this._emissiveIntensity = e; + set emissiveIntensity(v) { + this._emissiveIntensity = v; } get opacity() { return this._opacity; } - set opacity(e) { - this._opacity = e; + set opacity(v) { + this._opacity = v; + } + onBeforeRender() { + // callback + } + onBeforeCompile() { + // callback } - onBeforeRender() {} - onBeforeCompile() {} clone() { return null; } - update(e, t) {} + update(frameState, mesh) { + // update material + } createShaderData() { - this.shaderData && this.shaderData.destroy(), (this.shaderData = new Yi(this.type, 0)), (this.ready = !0); + if (this.shaderData) this.shaderData.destroy(); + this.shaderData = new ShaderData(this.type, 0); + this.ready = true; } init() { - const e = new ae(), - t = new ce(), - i = new oe(); - (this._renderState = new te()), - (this._renderState.primitive = e), - (this._renderState.targets = [t]), - (this._renderState.depthStencil = i); + // 默认渲染状态 + const primitive = new Primitive(); + const target = new Target(); + const depthStencil = new DepthStencil(); + this._renderState = new RenderState(); + this._renderState.primitive = primitive; + this._renderState.targets = [target]; + this._renderState.depthStencil = depthStencil; } destroy() { - (this.label = void 0), - (this.type = void 0), - (this.baseTexture = void 0), - (this.baseSampler = void 0), - (this.color = void 0); + this.label = undefined; + this.type = undefined; + this.baseTexture = undefined; + this.baseSampler = undefined; + this.color = undefined; } } -class Zi extends Wi { - constructor(e) { + +class ShaderMaterial extends Material { + constructor(options) { super(); - const { type: t, frag: i, vert: r, defines: n, light: s } = e; - (this.type = t), - (this.shaderMaterialParms = e), - (this.shaderSource = new Gi({ shaderId: t, render: { fragShader: i, vertShader: r }, defines: ee(n, {}) })), - (this.uniforms = e.uniforms), - (this.uniformBuffer = void 0), - (this.light = s || !1); + const { type, frag, vert, defines, light } = options; + this.type = type; + this.shaderMaterialParms = options; + this.shaderSource = new ShaderSource({ + shaderId: type, + render: { + fragShader: frag, + vertShader: vert + }, + defines: defaultValue(defines, {}) + }); + this.uniforms = options.uniforms; + this.uniformBuffer = undefined; + this.light = light || false; } - update(e, t) { - (this.shaderData && !this.dirty) || this.createShaderData(t); + update(frameState, mesh) { + if (!this.shaderData || this.dirty) this.createShaderData(mesh); } clone() { - return new Zi(this.shaderMaterialParms); + return new ShaderMaterial(this.shaderMaterialParms); } - createShaderData(e) { + createShaderData(mesh) { super.createShaderData(); - const t = (function (e) { - let t = 0, - i = !1; - return ( - Object.getOwnPropertyNames(e).map((r) => { - "texture" == e[r].type || "sampler" == e[r].type - ? (t += 0) - : ki.find((t) => t === e[r].type) - ? (i = !0) - : (t += 1); - }), - { hasFloat: t, hasArraytype: i } + const result = checkContainFloatType(this.uniforms); + if (result.hasFloat) { + this.uniformBuffer = result.hasArraytype + ? new UniformBuffer({ + label: this.type + "UniformBuffer", + type: BufferBindingType.ReadOnlyStorage, + usage: BufferUsage.Storage | BufferUsage.CopyDst + }) + : new UniformBuffer({ label: this.type + "UniformBuffer" }); + this.shaderData.setUniformBuffer(this.type, this.uniformBuffer); + } + const uniformsNames = Object.getOwnPropertyNames(this.uniforms); + uniformsNames.map((uniformsName) => { + addUniformToShaderData( + uniformsName, + this.uniforms[uniformsName], + this.shaderData, + mesh, + this.uniformBuffer ); - })(this.uniforms); - t.hasFloat && - ((this.uniformBuffer = t.hasArraytype - ? new Ri({ label: this.type + "UniformBuffer", type: m.ReadOnlyStorage, usage: r.Storage | r.CopyDst }) - : new Ri({ label: this.type + "UniformBuffer" })), - this.shaderData.setUniformBuffer(this.type, this.uniformBuffer)); - Object.getOwnPropertyNames(this.uniforms).map((t) => { - qi(t, this.uniforms[t], this.shaderData, e, this.uniformBuffer); }); } } -function Ki() { - return "xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g, function (e) { - const t = (16 * Math.random()) | 0; - return ("x" === e ? t : (3 & t) | 8).toString(16); + +function createGuid() { + // http://stackoverflow.com/questions/105034/how-to-create-a-guid-uuid-in-javascript + return "xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g, function (c) { + const r = (Math.random() * 16) | 0; + const v = c === "x" ? r : (r & 0x3) | 0x8; + return v.toString(16); }); } -class Qi extends $t { - constructor(e, t) { - super(), - (this.geometry = e), - (this.material = t), - (this.type = Z.Mesh), - (this.frustumCull = !0), - (this.uid = Ki()), - (this.subCommands = {}); + +class Mesh extends RenderObject { + constructor(geometry, material) { + super(); + this.geometry = geometry; + this.material = material; + this.type = RenderObjectType.Mesh; + this.frustumCull = true; + this.uid = createGuid(); + this.subCommands = {}; } get ready() { return this.material.ready; } - update(e, t) { - if ( - (this.updateMatrix(this?.parent?.modelMatrix), - this.geometry.update(e), - this.material.update(e, this), - this.geometry.boundingSphere.update(this.modelMatrix), - this.material.shaderSource.setDefines(e.defines), - this.type == Z.Debug) - ) - return void e.renderQueue.debugQueue.push(this); - this.distanceToCamera = this.geometry.boundingSphere.distanceToCamera(t); - e.cullingVolume.computeVisibility(this.geometry.boundingSphere) !== F.OUTSIDE && - this.frustumCull && - (this.material.transparent ? e.renderQueue.transparent.push(this) : e.renderQueue.opaque.push(this)); - } - beforeRender() {} - afterRender() {} - getDrawCommand(e, t, i) { - if ( - ((this.drawCommand && !this.material.dirty) || - (this.material.shaderSource.setDefines( - Object.assign({}, this.material.shaderData.defines, this.geometry.defines) - ), - this.material.dirty && (this.material.dirty = !1), - (this.drawCommand = new Y({ - vertexBuffers: this.geometry.vertexBuffers, - indexBuffer: this.geometry.indexBuffer, - shaderData: this.material.shaderData, - instances: this.instanceCount, - count: this.geometry.count, - renderState: this.material.renderState, - shaderSource: this.material.shaderSource, - lightShaderData: this.material.light ? i?.lightShaderData : void 0, - useLight: this.material.light - }))), - e) - ) { - if (!this.subCommands[t]) { - const i = e.clone(); - i.update(void 0, this), - i.dirty && (i.dirty = !1), - (this.subCommands[t] = this.drawCommand.shallowClone(i)); + update(frameState, camera) { + // update matrix + this.updateMatrix(this?.parent?.modelMatrix); + // create + this.geometry.update(frameState); + this.material.update(frameState, this); + // update boundingSphere + this.geometry.boundingSphere.update(this.modelMatrix); + this.material.shaderSource.setDefines(frameState.defines); + if (this.type == RenderObjectType.Debug) { + frameState.renderQueue.debugQueue.push(this); + return; + } + this.distanceToCamera = this.geometry.boundingSphere.distanceToCamera(camera); + const visibility = frameState.cullingVolume.computeVisibility(this.geometry.boundingSphere); + // 视锥剔除 + if (visibility === Intersect.OUTSIDE || !this.frustumCull) return; + if (this.material.transparent) { + frameState.renderQueue.transparent.push(this); + } else { + frameState.renderQueue.opaque.push(this); + } + } + beforeRender() { + // before render + } + afterRender() { + // after render + } + getDrawCommand(overrideMaterial, commandSubType, lightManger) { + if (!this.drawCommand || this.material.dirty) { + this.material.shaderSource.setDefines( + Object.assign({}, this.material.shaderData.defines, this.geometry.defines) + ); + if (this.material.dirty) this.material.dirty = false; + this.drawCommand = new DrawCommand({ + vertexBuffers: this.geometry.vertexBuffers, + indexBuffer: this.geometry.indexBuffer, + shaderData: this.material.shaderData, + instances: this.instanceCount, + count: this.geometry.count, + renderState: this.material.renderState, + shaderSource: this.material.shaderSource, + lightShaderData: this.material.light ? lightManger?.lightShaderData : undefined, + useLight: this.material.light + }); + } + if (overrideMaterial) { + if (!this.subCommands[commandSubType]) { + const copyMat = overrideMaterial.clone(); + copyMat.update(undefined, this); + if (copyMat.dirty) copyMat.dirty = false; + this.subCommands[commandSubType] = this.drawCommand.shallowClone(copyMat); } - return this.subCommands[t]; + return this.subCommands[commandSubType]; } return this.drawCommand; } destroy() { - this.geometry.destroy(), this.material.destroy(); + this.geometry.destroy(); + this.material.destroy(); } } -class Ji { - constructor(e, t) { - if (!(e && e instanceof Ht)) throw new Error("The parameter must be Light instance"); - (this.light = e), - (this.scene = t), - (this.debuggerSize = { width: 256, height: 256 }), - (this.mesh = this._createShadowMapMesh()); - const i = this.light.shadow.getShadowMapTexture(); - (this.material.uniforms.texture.value = i), (this.mesh.type = Z.Debug), this.scene.add(this.mesh); + +class ShadowMapDebugger { + constructor(light, scene) { + if (!light || !(light instanceof Light)) throw new Error("The parameter must be Light instance"); + this.light = light; + this.scene = scene; + this.debuggerSize = { + width: 256, + height: 256 + }; + this.mesh = this._createShadowMapMesh(); + const shadowMap = this.light.shadow.getShadowMapTexture(); + this.material.uniforms.texture.value = shadowMap; + this.mesh.type = RenderObjectType.Debug; + this.scene.add(this.mesh); } _createShadowMapMesh() { - const e = $i("shadowMapDebugger", { positionLocation: 0 }); - return ( - (this.geometry = new Dt(2, 2)), - (this.material = new Zi({ - type: "shadowMapDebugger", - frag: e.frag, - vert: e.vert, - uniforms: { - texture: { type: "texture", value: void 0 }, - sampler: { type: "sampler", value: new de({ magFilter: "linear", minFilter: "linear" }) } + const shader = getVertFrag("shadowMapDebugger", { + positionLocation: 0 + }); + this.geometry = new PlaneGeometry(2, 2); + this.material = new ShaderMaterial({ + type: "shadowMapDebugger", + frag: shader.frag, + vert: shader.vert, + uniforms: { + texture: { + type: "texture", + value: undefined + }, + sampler: { + type: "sampler", + value: new Sampler({ + magFilter: "linear", + minFilter: "linear" + }) } - })), - (this.material.renderState.viewport = new se(0, 0, this.debuggerSize.width, this.debuggerSize.height)), - new Qi(this.geometry, this.material) - ); + } + }); + this.material.renderState.viewport = new ViewPort(0, 0, this.debuggerSize.width, this.debuggerSize.height); + return new Mesh(this.geometry, this.material); } - setSize(e, t) { - e && t && ((this.debuggerSize.width = e), (this.debuggerSize.height = t), this.update()); + setSize(width, height) { + if (!width || !height) return; + this.debuggerSize.width = width; + this.debuggerSize.height = height; + this.update(); } update() { - this.material.renderState.viewport = new se(0, 0, this.debuggerSize.width, this.debuggerSize.height); + this.material.renderState.viewport = new ViewPort(0, 0, this.debuggerSize.width, this.debuggerSize.height); } } -class er extends Wi { + +class ColorMaterial extends Material { constructor() { - super(), (this.type = "color"), (this.shaderSource = new Gi({ shaderId: this.type, defines: {} })); + super(); + this.type = "color"; + this.shaderSource = new ShaderSource({ + shaderId: this.type, + defines: {} + }); } - update(e, t) { - (this.shaderData && !this.dirty) || this.createShaderData(); - const i = new Ri({ label: "color" }); - i.setUniform("modelMatrix", () => t.modelMatrix, Q.Mat4), this.shaderData.setUniformBuffer("color", i); + update(frameState, mesh) { + if (!this.shaderData || this.dirty) this.createShaderData(); + const uniformBuffer = new UniformBuffer({ label: "color" }); + uniformBuffer.setUniform( + "modelMatrix", + () => { + return mesh.modelMatrix; + }, + UniformEnum.Mat4 + ); + this.shaderData.setUniformBuffer("color", uniformBuffer); } } -class tr extends Qi { + +class Axes extends Mesh { constructor() { - super(), - (this.type = Z.Axes), - (this.distanceToCamera = 10), - (this.material = new er()), - (this.material.wireframe = !0), - this.init(); + super(); + this.type = RenderObjectType.Axes; + this.distanceToCamera = 10; + this.material = new ColorMaterial(); + this.material.wireframe = true; + this.init(); } - update(e) { - this.updateMatrix(), this.material.update(e, this), e.renderQueue.opaque.push(this); + update(frameState) { + this.updateMatrix(); + this.material.update(frameState, this); + frameState.renderQueue.opaque.push(this); } init() { - const e = [0, 1, 2, 3, 4, 5]; - (this.geometry = new At({})), - this.geometry.setAttribute(new Ie("position", [0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1], 3)), - this.geometry.setAttribute( - new Ie("color", [1, 0, 0, 1, 1, 0.5, 0.5, 1, 0, 1, 0, 1, 0.5, 1, 0.5, 1, 0, 0, 1, 1, 0.5, 0.5, 1, 1], 4) - ), - this.geometry.setIndice(e), - (this.geometry.count = e.length); + const position = [0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1]; + const colors = [1, 0, 0, 1, 1, 0.5, 0.5, 1, 0, 1, 0, 1, 0.5, 1, 0.5, 1, 0, 0, 1, 1, 0.5, 0.5, 1, 1]; + const indices = [0, 1, 2, 3, 4, 5]; + this.geometry = new Geometry({}); + this.geometry.setAttribute(new Float32Attribute("position", position, 3)); + this.geometry.setAttribute(new Float32Attribute("color", colors, 4)); + this.geometry.setIndice(indices); + this.geometry.count = indices.length; } } -class ir extends At { + +class SkyBoxGeometry extends Geometry { constructor() { - super({ type: "skyBoxGeometry" }), this.init(); + super({ + type: "skyBoxGeometry" + }); + this.init(); } init() { - const e = [ - 0, 2, 4, 6, 4, 2, 5, 3, 1, 3, 5, 7, 4, 1, 0, 1, 4, 5, 2, 3, 6, 7, 6, 3, 0, 1, 2, 3, 2, 1, 6, 5, 4, 5, 6, 7 + const positions = [ + 1.0, + 1.0, + 1.0, + -1.0, + 1.0, + 1.0, + 1.0, + -1.0, + 1.0, + -1.0, + -1.0, + 1.0, + 1.0, + 1.0, + -1.0, + -1.0, + 1.0, + -1.0, + 1.0, + -1.0, + -1.0, + -1.0, + -1.0, + -1.0 // 7 ]; - this.setAttribute( - new Ie("position", [1, 1, 1, -1, 1, 1, 1, -1, 1, -1, -1, 1, 1, 1, -1, -1, 1, -1, 1, -1, -1, -1, -1, -1], 3) - ), - this.setIndice(e), - (this.count = e.length); + const indices = [ + // PosX (Right) + 0, 2, 4, 6, 4, 2, + // NegX (Left) + 5, 3, 1, 3, 5, 7, + // PosY (Top) + 4, 1, 0, 1, 4, 5, + // NegY (Bottom) + 2, 3, 6, 7, 6, 3, + // PosZ (Front) + 0, 1, 2, 3, 2, 1, + // NegZ (Back) + 6, 5, 4, 5, 6, 7 + ]; + this.setAttribute(new Float32Attribute("position", positions, 3)); + this.setIndice(indices); + this.count = indices.length; } } -function rr() { - return !0; + +function returnTrue() { + return true; +} +function destroyObject(object) { + // message =message||"This object was destroyed, i.e., destroy() was called."; + function throwOnDestroyed() { + throw new Error("This object was destroyed, i.e., destroy() was called."); + } + for (const key in object) { + if (typeof object[key] === "function") { + object[key] = throwOnDestroyed; + } + } + object.isDestroyed = returnTrue; + return undefined; } -const nr = new (class { + +class TextureCache { constructor() { - (this._numberOfTextures = 0), - (this._textures = new Map()), - (this._numberOfTextures = 0), - (this._texturesToRelease = new Map()), - (this.defaultSampler = new de({ - magFilter: "linear", - minFilter: "linear", - addressModeU: "repeat", - addressModeV: "repeat" - })); + this._numberOfTextures = 0; + this._textures = new Map(); + this._numberOfTextures = 0; + this._texturesToRelease = new Map(); + this.defaultSampler = new Sampler({ + magFilter: "linear", + minFilter: "linear", + addressModeU: "repeat", + addressModeV: "repeat" + }); } get numberOfTextures() { return this._numberOfTextures; } - getTexture(e) { - const t = this._textures.get(e); - if (pe(t)) return delete this._texturesToRelease[e], ++t.count, t.texture; - } - addTexture(e, t) { - const i = { texture: t, count: 1 }; - (t.finalDestroy = t.destroy), - (t.destroy = () => { - 0 == --i.count && this._texturesToRelease.set(e, i); - }), - this._textures.set(e, i), - ++this._numberOfTextures; + getTexture(keyword) { + const cachedTexture = this._textures.get(keyword); + if (!defined(cachedTexture)) { + return undefined; + } + // No longer want to release this if it was previously released. + delete this._texturesToRelease[keyword]; + ++cachedTexture.count; + return cachedTexture.texture; + } + addTexture(keyword, texture) { + const cachedTexture = { + texture: texture, + count: 1 + }; + texture.finalDestroy = texture.destroy; + // const that = this; + texture.destroy = () => { + if (--cachedTexture.count === 0) { + this._texturesToRelease.set(keyword, cachedTexture); + } + }; + this._textures.set(keyword, cachedTexture); + ++this._numberOfTextures; } releasedTextures() { - this._texturesToRelease.forEach((e) => { - e.texture?.finalDestroy(), --this._numberOfTextures; - }), - this._texturesToRelease.clear(); + this._texturesToRelease.forEach((cacheTexture) => { + cacheTexture.texture?.finalDestroy(); + --this._numberOfTextures; + }); + this._texturesToRelease.clear(); } destroy() { - return ( - this._textures.forEach((e) => { - e.texture?.finalDestroy(); - }), - (function (e) { - function t() { - throw new Error("This object was destroyed, i.e., destroy() was called."); - } - for (const i in e) "function" == typeof e[i] && (e[i] = t); - e.isDestroyed = rr; - })(this) - ); + this._textures.forEach((cachedTexture) => { + cachedTexture.texture?.finalDestroy(); + }); + return destroyObject(this); } -})(); -async function sr(e) { - const t = e.map((e) => { - const t = document.createElement("img"); - return (t.src = e), t.decode().then(() => createImageBitmap(t)); - }), - i = await Promise.all(t); - await Promise.all(i); - const r = new de({ magFilter: "linear", minFilter: "linear" }), - n = i.map((e, t) => ({ source: e, width: e.width, height: e.height, depth: 1, x: 0, y: 0, z: t })); +} +const textureCache = new TextureCache(); + +async function CubeTextureLoader(urls) { + const promises = urls.map((src) => { + const img = document.createElement("img"); + img.src = src; + return img.decode().then(() => createImageBitmap(img)); + }); + const images = await Promise.all(promises); + await Promise.all(images); + const baseSampler = new Sampler({ + magFilter: "linear", + minFilter: "linear" + }); + const data = images.map((image, i) => { + return { + source: image, + width: image.width, + height: image.height, + depth: 1, + x: 0, + y: 0, + z: i + }; + }); + const baseTexture = new Texture({ + size: { + width: images[0].width, + height: images[0].height, + depth: 6 + }, + format: "rgba8unorm", + usage: GPUTextureUsage.TEXTURE_BINDING | GPUTextureUsage.COPY_DST | GPUTextureUsage.RENDER_ATTACHMENT, + data, + viewFormats: "cube", + mipLevelCount: 6, + needMipMap: true + }); return { - texture: new fe({ - size: { width: i[0].width, height: i[0].height, depth: 6 }, - format: "rgba8unorm", - usage: GPUTextureUsage.TEXTURE_BINDING | GPUTextureUsage.COPY_DST | GPUTextureUsage.RENDER_ATTACHMENT, - data: n, - viewFormats: "cube", - mipLevelCount: 6, - needMipMap: !0 - }), - sampler: r + texture: baseTexture, + sampler: baseSampler }; } -class ar extends Wi { + +class SkyBoxMaterial extends Material { constructor() { - super(), - (this.type = "skybox"), - (this.shaderSource = new Gi({ shaderId: this.type, defines: {} })), - (this.loadFish = !1), - (this.renderState.depthStencil.depthWriteEnabled = !1), - (this.renderState.depthStencil.depthCompare = f.LessEqual); - } - async loadTexture(e) { - const t = await sr(e); - (this.loadFish = !0), - nr.addTexture("specular", t.texture), - (this.baseTexture = t.texture), - (this.baseSampler = t.sampler); - } - update(e, t) { - this.loadFish && (this.shaderData || this.createShaderData(t)); - } - createShaderData(e) { + super(); + this.type = "skybox"; + this.shaderSource = new ShaderSource({ + shaderId: this.type, + defines: {} + }); + this.loadFish = false; + this.renderState.depthStencil.depthWriteEnabled = false; + this.renderState.depthStencil.depthCompare = CompareFunction.LessEqual; + } + async loadTexture(urls) { + const result = await CubeTextureLoader(urls); + this.loadFish = true; + textureCache.addTexture("specular", result.texture); + this.baseTexture = result.texture; + this.baseSampler = result.sampler; + } + update(frameState, mesh) { + if (!this.loadFish) return; + if (!this.shaderData) { + this.createShaderData(mesh); + } + } + createShaderData(mesh) { super.createShaderData(); - const t = new Ri({ label: "skybox" }); - t.setUniform("modelMatrix", () => e.modelMatrix, Q.Mat4), - this.shaderData.setUniformBuffer("skybox", t), - this.shaderData.setTexture("baseTexture", this.baseTexture), - this.shaderData.setSampler("baseSampler", this.baseSampler); - } -} -class or extends Qi { - constructor(e) { - super(), - (this.type = Z.Skybox), - (this.visibility = !0), - (this.material = new ar()), - e && this.material.loadTexture(e), - (this.geometry = new ir()), - (this.isSkyBox = !0); - } - update(e) { - this.updateMatrix(), - this.geometry.update(e), - this.material.update(e, this), - this.visibility && e.renderQueue.pre.push(this); - } -} -class cr extends $t { + const uniformBuffer = new UniformBuffer({ label: "skybox" }); + uniformBuffer.setUniform( + "modelMatrix", + () => { + return mesh.modelMatrix; + }, + UniformEnum.Mat4 + ); + this.shaderData.setUniformBuffer("skybox", uniformBuffer); + this.shaderData.setTexture("baseTexture", this.baseTexture); + this.shaderData.setSampler("baseSampler", this.baseSampler); + } +} + +class SkyBox extends Mesh { + constructor(urls) { + super(); + this.type = RenderObjectType.Skybox; + this.visibility = true; + this.material = new SkyBoxMaterial(); + if (urls) this.material.loadTexture(urls); + this.geometry = new SkyBoxGeometry(); + this.isSkyBox = true; + } + update(frameState) { + this.updateMatrix(); + this.geometry.update(frameState); + this.material.update(frameState, this); + if (this.visibility) frameState.renderQueue.pre.push(this); + } +} + +class Instance extends RenderObject { constructor() { - super(), (this._notUpdateMatrix = !1), (this.visiblity = !1), (this.id = Ki()); + super(); + this._notUpdateMatrix = false; + this.visiblity = false; + this.id = createGuid(); } - setMatrix4(e) { - this.modelMatrix.set(e), (this._notUpdateMatrix = !0); + setMatrix4(mat4) { + this.modelMatrix.set(mat4); + this._notUpdateMatrix = true; } - updateMatrix(e) { - this._notUpdateMatrix || super.updateMatrix(e); + updateMatrix(matrix) { + if (this._notUpdateMatrix) return; + super.updateMatrix(matrix); } } -class lr extends Qi { - constructor(e, t) { - super(e, t), (this.instances = new Map()), (this.renderInstances = []), (this.hasAddInstances = !1); - } - update(e, t) { - this.checkInstancesVisiblity({ frameState: e, camera: t }), - this.geometry.update(e), - this.material.update(e, this), - this.hasAddInstances || this.addUniformsToMaterial(), - (this.instanceCount = this.renderInstances.length), - this.renderInstances.length < 1 || - (this.material.transparent ? e.renderQueue.transparent.push(this) : e.renderQueue.opaque.push(this)); + +class InstanceMesh extends Mesh { + constructor(geo, mat) { + super(geo, mat); + this.instances = new Map(); + this.renderInstances = []; + this.hasAddInstances = false; + } + update(frameState, camera) { + // update instances visiblity + this.checkInstancesVisiblity({ frameState, camera }); + this.geometry.update(frameState); + this.material.update(frameState, this); + if (!this.hasAddInstances) this.addUniformsToMaterial(); + this.instanceCount = this.renderInstances.length; + if (this.renderInstances.length < 1) return; + if (this.material.transparent) { + frameState.renderQueue.transparent.push(this); + } else { + frameState.renderQueue.opaque.push(this); + } } - addInstance(e) { - this.instances.get(e.id) || this.instances.set(e.id, e); + addInstance(instance) { + if (this.instances.get(instance.id)) return; + this.instances.set(instance.id, instance); } - removeInstance(e) { - return this.instances.delete(e); + removeInstance(key) { + return this.instances.delete(key); } - getInstance(e) { - return this.instances.get(e); + getInstance(key) { + return this.instances.get(key); } - checkInstancesVisiblity(e) { - const { frameState: t, camera: i } = e, - r = this.renderInstances.length; - (this.renderInstances = []), - this.instances.forEach((e) => { - e.updateMatrix(this?.parent?.modelMatrix), - (e.visiblity = this.getInstanceVisiblity({ instance: e, frameState: t, camera: i })), - e.visiblity && this.renderInstances.push(e); - }), - (this.material.dirty = this.renderInstances.length === r), - this.material.dirty && (this.hasAddInstances = !1); + checkInstancesVisiblity(options) { + const { frameState, camera } = options; + const preFrameInstanceCount = this.renderInstances.length; + this.renderInstances = []; + this.instances.forEach((instance) => { + instance.updateMatrix(this?.parent?.modelMatrix); + instance.visiblity = this.getInstanceVisiblity({ instance, frameState, camera }); + if (instance.visiblity) this.renderInstances.push(instance); + }); + this.material.dirty = this.renderInstances.length === preFrameInstanceCount; + // rebuild instanceMatrixsBuffer + if (this.material.dirty) this.hasAddInstances = false; } - getInstanceVisiblity(e) { - const { instance: t, frameState: i, camera: r } = e; - this.geometry.boundingSphere.update(t.modelMatrix), - (this.distanceToCamera = this.geometry.boundingSphere.distanceToCamera(r)); - const n = i.cullingVolume.computeVisibility(this.geometry.boundingSphere); - return n === F.INTERSECTING || n === F.INSIDE; + getInstanceVisiblity(options) { + const { instance, frameState, camera } = options; + this.geometry.boundingSphere.update(instance.modelMatrix); + this.distanceToCamera = this.geometry.boundingSphere.distanceToCamera(camera); + const visibility = frameState.cullingVolume.computeVisibility(this.geometry.boundingSphere); + return visibility === Intersect.INTERSECTING || visibility === Intersect.INSIDE; } addUniformsToMaterial() { if (!this.material.shaderData) return; - this.hasAddInstances = !0; - const e = new Ri({ + this.hasAddInstances = true; + const instanceMatrixsBuffer = new UniformBuffer({ label: "instanceMatrixsBuffer", - type: m.ReadOnlyStorage, - usage: r.Storage | r.CopyDst, - size: 64 * this.instances.size + type: BufferBindingType.ReadOnlyStorage, + usage: BufferUsage.Storage | BufferUsage.CopyDst, + size: this.instances.size * 64 }); - e.setUniform( + instanceMatrixsBuffer.setUniform( "instanceMatrixs", - () => this?.renderInstances?.map((e) => e.modelMatrix), - Q.Mat4Array, + () => { + return this?.renderInstances?.map((renderInstance) => renderInstance.modelMatrix); + }, + UniformEnum.Mat4Array, this?.renderInstances?.length - ), - this.material.shaderData.setUniformBuffer("instanceMatrixsBuffer", e), - this.material.shaderData.setDefine("USE_INSTANCE", !0), - this.material.shaderData.setDefine("instanceCount", this?.renderInstances?.length); + ); + this.material.shaderData.setUniformBuffer("instanceMatrixsBuffer", instanceMatrixsBuffer); + this.material.shaderData.setDefine("USE_INSTANCE", true); + this.material.shaderData.setDefine("instanceCount", this?.renderInstances?.length); } } -class hr { - constructor(e) { - (this.dispatch = e.dispatch), (this.shaderData = e.shaderData), (this.shaderSource = e.shaderSource); - } - render(e) { - const { device: t, passEncoder: i } = e; - this.shaderData?.bind?.(t, i); - H.getComputePipelineFromCache(t, this, [this.shaderData.groupLayout]).bind(i); - const { x: r, y: n, z: s } = this.dispatch; - i.dispatchWorkgroups(r, n, s); + +class ComputeCommand { + constructor(options) { + this.dispatch = options.dispatch; + this.shaderData = options.shaderData; + this.shaderSource = options.shaderSource; + } + render(params) { + const { device, passEncoder } = params; + this.shaderData?.bind?.(device, passEncoder); + const pipeline = Pipeline.getComputePipelineFromCache(device, this, [this.shaderData.groupLayout]); + pipeline.bind(passEncoder); + const { x, y, z } = this.dispatch; + passEncoder.dispatchWorkgroups(x, y, z); } } -class ur { - constructor(e) { - (this.modelParams = e), - (this.renderType = null != this.modelParams.compute ? "compute" : "render"), - (this.vertexBuffers = new Map()); - } - render(e) { - const { device: t, passEncoder: i } = e; - this.command || - (this.command = "render" === this.renderType ? this.createDrawCommand() : this.createComputeCommand()), - this.renderType, - this.command.render({ device: t, passEncoder: i }); + +class Model { + constructor(params) { + this.modelParams = params; + this.renderType = this.modelParams.compute != undefined ? "compute" : "render"; + this.vertexBuffers = new Map(); + } + render(params) { + const { device, passEncoder } = params; + if (!this.command) + this.command = this.renderType === "render" ? this.createDrawCommand() : this.createComputeCommand(); + if (this.renderType === "render") { + this.command.render({ + device, + passEncoder: passEncoder + }); + } else { + this.command.render({ + device, + passEncoder: passEncoder + }); + } } - compute(e) { - const { device: t, passEncoder: i } = e; - this.command || (this.command = this.createComputeCommand()), - this.command.render({ device: t, passEncoder: i }); + compute(params) { + const { device, passEncoder } = params; + if (!this.command) this.command = this.createComputeCommand(); + this.command.render({ + device, + passEncoder: passEncoder + }); } - getVertexBufferByUid(e) { - return this.vertexBuffers.get(e); + getVertexBufferByUid(uid) { + return this.vertexBuffers.get(uid); } - getUniformBufferByUid(e) { - return this.shaderData.getUniformBuffer(e); + getUniformBufferByUid(uid) { + return this.shaderData.getUniformBuffer(uid); } - getTextureByName(e) { - return this.shaderData.getTexture(e); + getTextureByName(name) { + return this.shaderData.getTexture(name); } - getSamplerByName(e) { - return this.shaderData.getSampler(e); + getSamplerByName(name) { + return this.shaderData.getSampler(name); } destroy() { - this?.vertexBuffers.clear(), this?.shaderData.destroy(), (this.command = null), (this.modelParams = null); + this?.vertexBuffers.clear(); + this?.shaderData.destroy(); + this.command = null; + this.modelParams = null; } createDrawCommand() { - const { count: e, instances: t } = this.modelParams, - i = this.createVertexBuffer(); + const { count, instances } = this.modelParams; + const vertexBuffers = this.createVertexBuffer(); this.shaderData = this.createShaderData(); - const r = this.createIndexBuffer(), - n = this.createShaderSource(), - s = this.createRenderState(); - return new Y({ - vertexBuffers: i, + const indexBuffer = this.createIndexBuffer(); + const shaderSource = this.createShaderSource(); + const renderState = this.createRenderState(); + return new DrawCommand({ + vertexBuffers, shaderData: this.shaderData, - indexBuffer: r, - shaderSource: n, - renderState: s, - count: e, - instances: t + indexBuffer, + shaderSource, + renderState, + count, + instances }); } createComputeCommand() { - const { dispatch: e } = this.modelParams, - t = this.createShaderData(), - i = this.createShaderSource(); - return new hr({ dispatch: e, shaderData: t, shaderSource: i }); + const { dispatch } = this.modelParams; + const shaderData = this.createShaderData(); + const shaderSource = this.createShaderSource(); + return new ComputeCommand({ + dispatch, + shaderData, + shaderSource + }); } createVertexBuffer() { - const { vertexBuffers: e, shaderId: t } = this.modelParams; - let i = 0; + const { vertexBuffers, shaderId } = this.modelParams; + let locationIndex = 0; return ( - e?.map((e, r) => { - const { attributes: n, stepMode: s, uid: a, arrayStride: o } = e, - c = new Ct({ label: t, index: r, locationIndex: i, stepMode: s, arrayStride: o }); - return ( - Object.keys(n).forEach((e) => { - const { size: t, value: r, names: s, itemSizes: a, buffer: o } = n[e]; - c.setAttribute(s?.length > 0 ? (o ? new Ne(s, o, a) : new Pe(s, r, a)) : new Ie(e, r, t)); - i += s?.length > 0 ? s?.length : 1; - }), - this.vertexBuffers.set(a, c), - c - ); + vertexBuffers?.map((vertexBufferObject, index) => { + const { attributes, stepMode, uid, arrayStride } = vertexBufferObject; + const vertexBuffer = new VertexBuffer({ + label: shaderId, + index, + locationIndex, + stepMode: stepMode, + arrayStride + }); + const attributeKeys = Object.keys(attributes); + attributeKeys.forEach((key) => { + const { size, value, names, itemSizes, buffer } = attributes[key]; + vertexBuffer.setAttribute( + names?.length > 0 + ? buffer + ? new BufferFloat32Attribute(names, buffer, itemSizes) + : new InterleavedFloat32Attribute(names, value, itemSizes) + : new Float32Attribute(key, value, size) + ); + const count = names?.length > 0 ? names?.length : 1; + locationIndex += count; + }); + this.vertexBuffers.set(uid, vertexBuffer); + return vertexBuffer; }) || [] ); } createShaderSource() { - const { vert: e, frag: t, compute: i, shaderId: r } = this.modelParams; - return new Gi({ shaderId: r, render: { vertShader: e, fragShader: t }, compute: { computeShader: i } }); + const { vert, frag, compute, shaderId } = this.modelParams; + return new ShaderSource({ + shaderId, + render: { + vertShader: vert, + fragShader: frag + }, + compute: { + computeShader: compute + } + }); } createShaderData() { - const { shaderId: e, uniformBuffers: t, uniformTextureAndSampler: i } = this.modelParams, - r = new Yi(e); - return t.forEach((t) => this.createUniformBuffer(t, r, e)), this.addUniformToShaderData(i, r, void 0), r; + const { shaderId, uniformBuffers, uniformTextureAndSampler } = this.modelParams; + const shaderData = new ShaderData(shaderId); + // fill uniformBuffer + uniformBuffers.forEach((uniformBuffer) => this.createUniformBuffer(uniformBuffer, shaderData, shaderId)); + // fill texture and sampler + this.addUniformToShaderData(uniformTextureAndSampler, shaderData, undefined); + return shaderData; } createRenderState() { const { - blendConstant: e, - depthStencil: t, - viewPort: i, - scissorTest: r, - targets: n, - multiSample: s, - primitive: a, - stencilReference: o + blendConstant, + depthStencil, + viewPort, + scissorTest, + targets, + multiSample, + primitive, + stencilReference } = this.modelParams.renderState; - return new te({ - scissorTest: r ? new ne(r.x, r.y, r.width, r.height) : void 0, - viewport: i ? new se(i.x, i.y, i.width, i.height) : void 0, - targets: n?.map((e) => new ce(e)), - depthStencil: t ? new oe(t) : void 0, - blendConstant: e ? new ie(e.r, e.g, e.b, e.a) : void 0, - stencilReference: o || 0, - multisample: s ? new re(s.count, s.mask, s.alphaToCoverageEnabled) : void 0, - primitive: a ? new ae(a.topology, a.cullMode, a.frontFace, a.unclippedDepth) : void 0, - stencilEnabled: !1, - scissorTestEnabled: !1 + return new RenderState({ + scissorTest: scissorTest + ? new ScissorTest(scissorTest.x, scissorTest.y, scissorTest.width, scissorTest.height) + : undefined, + viewport: viewPort ? new ViewPort(viewPort.x, viewPort.y, viewPort.width, viewPort.height) : undefined, + targets: targets?.map((target) => { + return new Target(target); + }), + depthStencil: depthStencil ? new DepthStencil(depthStencil) : undefined, + blendConstant: blendConstant + ? new BlendConstant(blendConstant.r, blendConstant.g, blendConstant.b, blendConstant.a) + : undefined, + stencilReference: stencilReference || 0, + multisample: multiSample + ? new MultiSample(multiSample.count, multiSample.mask, multiSample.alphaToCoverageEnabled) + : undefined, + primitive: primitive + ? new Primitive(primitive.topology, primitive.cullMode, primitive.frontFace, primitive.unclippedDepth) + : undefined, + stencilEnabled: false, + scissorTestEnabled: false }); } createIndexBuffer() { - const { indices: e, shaderId: t } = this.modelParams; - let i; - return e && ((i = new _t(t + "IndexBuffer")), i.setIndices(e)), i; + const { indices, shaderId } = this.modelParams; + let indexBuffer = undefined; + if (indices) { + indexBuffer = new IndexBuffer(shaderId + "IndexBuffer"); + indexBuffer.setIndices(indices); + } + return indexBuffer; } - createUniformBuffer(e, t, i) { + createUniformBuffer(uniformBufferParams, shaderData, shaderId) { const { - type: n = "uniform", - usage: s = r.Uniform | r.CopyDst, - uniforms: a, - uid: o, - binding: c, - buffer: l, - bufferSize: h, - visibility: u - } = e, - f = new Ri({ - label: o + "_UniformBuffer", - type: n, - usage: s, - binding: c, - buffer: l, - visibility: u, - size: l?.size ?? h - }); - t.setUniformBuffer(o, f), l || this.addUniformToShaderData(a, t, f); - } - addUniformToShaderData(e, t, i) { - if (!e) return; - Object.getOwnPropertyNames(e).map((r) => { - qi(r, e[r], t, void 0, i); + type = "uniform", + usage = BufferUsage.Uniform | BufferUsage.CopyDst, + uniforms, + uid, + binding, + buffer, + bufferSize, + visibility + } = uniformBufferParams; + const uniformBuffer = new UniformBuffer({ + label: uid + "_UniformBuffer", + type: type, + usage: usage, + binding, + buffer, + visibility, + size: buffer?.size ?? bufferSize + }); + shaderData.setUniformBuffer(uid, uniformBuffer); + if (!buffer) this.addUniformToShaderData(uniforms, shaderData, uniformBuffer); + } + addUniformToShaderData(uniforms, shaderData, uniformBuffer) { + if (!uniforms) return; + const uniformsNames = Object.getOwnPropertyNames(uniforms); + uniformsNames.map((uniformsName) => { + addUniformToShaderData(uniformsName, uniforms[uniformsName], shaderData, undefined, uniformBuffer); }); } } -class fr extends At { + +class SpriteGeometry extends Geometry { constructor() { - super({ type: "spriteGeometry" }), this.init(); + super({ + type: "spriteGeometry" + }); + this.init(); } init() { - const e = [-0.5, -0.5, 0, 0, 0, 0.5, -0.5, 0, 1, 0, 0.5, 0.5, 0, 1, 1, -0.5, 0.5, 0, 0, 1], - t = [0, 1, 2, 0, 2, 3]; - this.computeBoundingSphere(e, 5), - this.setAttribute(new Pe(["position", "uv"], e, [3, 2])), - this.setIndice(t), - (this.count = t.length); + // xyz、uv + const vertices = [-0.5, -0.5, 0, 0, 0, 0.5, -0.5, 0, 1, 0, 0.5, 0.5, 0, 1, 1, -0.5, 0.5, 0, 0, 1]; + const indices = [0, 1, 2, 0, 2, 3]; + this.computeBoundingSphere(vertices, 5); + this.setAttribute(new InterleavedFloat32Attribute(["position", "uv"], vertices, [3, 2])); + this.setIndice(indices); + this.count = indices.length; } } -class dr extends Wi { + +class SpriteMaterial extends Material { constructor() { - super(), - (this.type = "sprite"), - (this.shaderSource = new Gi({ shaderId: this.type, defines: { HAS_UV: !0 } })), - (this.rotation = Math.PI), - (this.opacity = 1), - (this.center = new Se(0, 0)), - (this.color = new Qt(1, 0, 0)); - } - update(e, t) { - (this.shaderData && !this.dirty) || this.createShaderData(t); - } - createShaderData(e) { + super(); + this.type = "sprite"; + this.shaderSource = new ShaderSource({ + shaderId: this.type, + defines: { + HAS_UV: true + } + }); + this.rotation = Math.PI; + this.opacity = 1; + this.center = new Vector2(0, 0); + this.color = new Color(1, 0, 0); + } + update(frameState, mesh) { + if (!this.shaderData || this.dirty) this.createShaderData(mesh); + } + createShaderData(mesh) { super.createShaderData(); - const t = new Ri({ label: "sprite" }); - t.setUniform("modelMatrix", () => e.modelMatrix, Q.Mat4), - t.setUniform("color", this, Q.Color), - t.setUniform("rotation", this, Q.Float), - t.setUniform("center", this, Q.FloatVec2), - t.setUniform("opacity", this, Q.Float), - this.shaderData.setUniformBuffer("sprite", t), - this.baseTexture && - (this.shaderData.setDefine("USE_COLORTEXTURE", !0), - this.shaderData.setTexture("baseColorTexture", this.baseTexture), - this.shaderData.setSampler("baseColorSampler", this.baseSampler || nr.defaultSampler)); + const uniformBuffer = new UniformBuffer({ label: "sprite" }); + uniformBuffer.setUniform( + "modelMatrix", + () => { + return mesh.modelMatrix; + }, + UniformEnum.Mat4 + ); + uniformBuffer.setUniform("color", this, UniformEnum.Color); + uniformBuffer.setUniform("rotation", this, UniformEnum.Float); + uniformBuffer.setUniform("center", this, UniformEnum.FloatVec2); + uniformBuffer.setUniform("opacity", this, UniformEnum.Float); + this.shaderData.setUniformBuffer("sprite", uniformBuffer); + if (this.baseTexture) { + this.shaderData.setDefine("USE_COLORTEXTURE", true); + this.shaderData.setTexture("baseColorTexture", this.baseTexture); + this.shaderData.setSampler("baseColorSampler", this.baseSampler || textureCache.defaultSampler); + } } destroy() { - this?.baseTexture?.destroy(), super.destroy(); + this?.baseTexture?.destroy(); + super.destroy(); } } -class mr extends Qi { + +class Sprite extends Mesh { constructor() { - super(), (this.material = new dr()), (this.geometry = new fr()); + super(); + this.material = new SpriteMaterial(); + this.geometry = new SpriteGeometry(); + } + setTexture(texture) { + this.material.baseTexture = texture; } - setTexture(e) { - this.material.baseTexture = e; + setSampler(sampler) { + this.material.baseSampler = sampler; } - setSampler(e) { - this.material.baseSampler = e; +} + +/** + * Ensure first argument passed to the primitive functions is an object + * @param {...*} args + */ +function createBox(options) { + options = options || {}; + const dimensions = options.dimensions || [1, 1, 1]; + const position = options.position || [-dimensions[0] / 2, -dimensions[1] / 2, -dimensions[2] / 2]; + const x = position[0]; + const y = position[1]; + const z = position[2]; + const width = dimensions[0]; + const height = dimensions[1]; + const depth = dimensions[2]; + const fbl = { x: x, y: y, z: z + depth }; + const fbr = { x: x + width, y: y, z: z + depth }; + const ftl = { x: x, y: y + height, z: z + depth }; + const ftr = { x: x + width, y: y + height, z: z + depth }; + const bbl = { x: x, y: y, z: z }; + const bbr = { x: x + width, y: y, z: z }; + const btl = { x: x, y: y + height, z: z }; + const btr = { x: x + width, y: y + height, z: z }; + const positions = [ + // front + fbl.x, + fbl.y, + fbl.z, + fbr.x, + fbr.y, + fbr.z, + ftl.x, + ftl.y, + ftl.z, + ftl.x, + ftl.y, + ftl.z, + fbr.x, + fbr.y, + fbr.z, + ftr.x, + ftr.y, + ftr.z, + // right + fbr.x, + fbr.y, + fbr.z, + bbr.x, + bbr.y, + bbr.z, + ftr.x, + ftr.y, + ftr.z, + ftr.x, + ftr.y, + ftr.z, + bbr.x, + bbr.y, + bbr.z, + btr.x, + btr.y, + btr.z, + // back + fbr.x, + bbr.y, + bbr.z, + bbl.x, + bbl.y, + bbl.z, + btr.x, + btr.y, + btr.z, + btr.x, + btr.y, + btr.z, + bbl.x, + bbl.y, + bbl.z, + btl.x, + btl.y, + btl.z, + // left + bbl.x, + bbl.y, + bbl.z, + fbl.x, + fbl.y, + fbl.z, + btl.x, + btl.y, + btl.z, + btl.x, + btl.y, + btl.z, + fbl.x, + fbl.y, + fbl.z, + ftl.x, + ftl.y, + ftl.z, + // top + ftl.x, + ftl.y, + ftl.z, + ftr.x, + ftr.y, + ftr.z, + btl.x, + btl.y, + btl.z, + btl.x, + btl.y, + btl.z, + ftr.x, + ftr.y, + ftr.z, + btr.x, + btr.y, + btr.z, + // bottom + bbl.x, + bbl.y, + bbl.z, + bbr.x, + bbr.y, + bbr.z, + fbl.x, + fbl.y, + fbl.z, + fbl.x, + fbl.y, + fbl.z, + bbr.x, + bbr.y, + bbr.z, + fbr.x, + fbr.y, + fbr.z + ]; + const uvs = [ + // front + 0, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1, + // right + 0, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1, + // back + 0, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1, + // left + 0, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1, + // top + 0, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1, + // bottom + 0, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1 + ]; + const normals = [ + // front + 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, + // right + 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, + // back + 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, -1, + // left + -1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, + // top + 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, + // bottom + 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0 + ]; + return { + positions: positions, + normals: normals, + uvs: uvs + }; +} +function createSphere(options) { + options = options || {}; + const longBands = options.longBands || 32; + const latBands = options.latBands || 32; + const radius = options.radius || 1; + const lat_step = Math.PI / latBands; + const long_step = (2 * Math.PI) / longBands; + const num_positions = longBands * latBands * 4; + const num_indices = longBands * latBands * 6; + let lat_angle, long_angle; + const positions = new Array(num_positions * 3); + const normals = new Array(num_positions * 3); + const uvs = new Array(num_positions * 2); + const indices = new Array(num_indices); + let x1, x2, x3, x4, y1, y2, z1, z2, z3, z4, u1, u2, v1, v2; + let i, j; + let k = 0, + l = 0; + let vi, ti; + for (i = 0; i < latBands; i++) { + lat_angle = i * lat_step; + y1 = Math.cos(lat_angle); + y2 = Math.cos(lat_angle + lat_step); + for (j = 0; j < longBands; j++) { + long_angle = j * long_step; + x1 = Math.sin(lat_angle) * Math.cos(long_angle); + x2 = Math.sin(lat_angle) * Math.cos(long_angle + long_step); + x3 = Math.sin(lat_angle + lat_step) * Math.cos(long_angle); + x4 = Math.sin(lat_angle + lat_step) * Math.cos(long_angle + long_step); + z1 = Math.sin(lat_angle) * Math.sin(long_angle); + z2 = Math.sin(lat_angle) * Math.sin(long_angle + long_step); + z3 = Math.sin(lat_angle + lat_step) * Math.sin(long_angle); + z4 = Math.sin(lat_angle + lat_step) * Math.sin(long_angle + long_step); + u1 = 1 - j / longBands; + u2 = 1 - (j + 1) / longBands; + v1 = 1 - i / latBands; + v2 = 1 - (i + 1) / latBands; + vi = k * 3; + ti = k * 2; + positions[vi] = x1 * radius; + positions[vi + 1] = y1 * radius; + positions[vi + 2] = z1 * radius; // v0 + positions[vi + 3] = x2 * radius; + positions[vi + 4] = y1 * radius; + positions[vi + 5] = z2 * radius; // v1 + positions[vi + 6] = x3 * radius; + positions[vi + 7] = y2 * radius; + positions[vi + 8] = z3 * radius; // v2 + positions[vi + 9] = x4 * radius; + positions[vi + 10] = y2 * radius; + positions[vi + 11] = z4 * radius; // v3 + normals[vi] = x1; + normals[vi + 1] = y1; + normals[vi + 2] = z1; + normals[vi + 3] = x2; + normals[vi + 4] = y1; + normals[vi + 5] = z2; + normals[vi + 6] = x3; + normals[vi + 7] = y2; + normals[vi + 8] = z3; + normals[vi + 9] = x4; + normals[vi + 10] = y2; + normals[vi + 11] = z4; + uvs[ti] = u1; + uvs[ti + 1] = v1; + uvs[ti + 2] = u2; + uvs[ti + 3] = v1; + uvs[ti + 4] = u1; + uvs[ti + 5] = v2; + uvs[ti + 6] = u2; + uvs[ti + 7] = v2; + indices[l] = k; + indices[l + 1] = k + 1; + indices[l + 2] = k + 2; + indices[l + 3] = k + 2; + indices[l + 4] = k + 1; + indices[l + 5] = k + 3; + k += 4; + l += 6; + } } + return { + positions: positions, + normals: normals, + uvs: uvs, + indices: indices + }; } -class pr extends At { - constructor(e) { - super({ type: "sphereGeometry" }), (this.defines = { HAS_NORMAL: !0 }), (this.radius = e), this.init(); + +class SphereGeometry extends Geometry { + constructor(radius) { + super({ + type: "sphereGeometry" + }); + this.defines = { + HAS_NORMAL: true + }; + this.radius = radius; + this.init(); } init() { - const { - positions: e, - normals: t, - uvs: i, - indices: r - } = (function (e) { - const t = (e = e || {}).longBands || 32, - i = e.latBands || 32, - r = e.radius || 1, - n = Math.PI / i, - s = (2 * Math.PI) / t, - a = t * i * 4, - o = t * i * 6; - let c, l; - const h = new Array(3 * a), - u = new Array(3 * a), - f = new Array(2 * a), - d = new Array(o); - let m, - p, - g, - x, - v, - y, - S, - b, - w, - T, - E, - M, - U, - _, - L, - C, - R, - A, - D = 0, - z = 0; - for (L = 0; L < i; L++) - for (c = L * n, v = Math.cos(c), y = Math.cos(c + n), C = 0; C < t; C++) - (l = C * s), - (m = Math.sin(c) * Math.cos(l)), - (p = Math.sin(c) * Math.cos(l + s)), - (g = Math.sin(c + n) * Math.cos(l)), - (x = Math.sin(c + n) * Math.cos(l + s)), - (S = Math.sin(c) * Math.sin(l)), - (b = Math.sin(c) * Math.sin(l + s)), - (w = Math.sin(c + n) * Math.sin(l)), - (T = Math.sin(c + n) * Math.sin(l + s)), - (E = 1 - C / t), - (M = 1 - (C + 1) / t), - (U = 1 - L / i), - (_ = 1 - (L + 1) / i), - (R = 3 * D), - (A = 2 * D), - (h[R] = m * r), - (h[R + 1] = v * r), - (h[R + 2] = S * r), - (h[R + 3] = p * r), - (h[R + 4] = v * r), - (h[R + 5] = b * r), - (h[R + 6] = g * r), - (h[R + 7] = y * r), - (h[R + 8] = w * r), - (h[R + 9] = x * r), - (h[R + 10] = y * r), - (h[R + 11] = T * r), - (u[R] = m), - (u[R + 1] = v), - (u[R + 2] = S), - (u[R + 3] = p), - (u[R + 4] = v), - (u[R + 5] = b), - (u[R + 6] = g), - (u[R + 7] = y), - (u[R + 8] = w), - (u[R + 9] = x), - (u[R + 10] = y), - (u[R + 11] = T), - (f[A] = E), - (f[A + 1] = U), - (f[A + 2] = M), - (f[A + 3] = U), - (f[A + 4] = E), - (f[A + 5] = _), - (f[A + 6] = M), - (f[A + 7] = _), - (d[z] = D), - (d[z + 1] = D + 1), - (d[z + 2] = D + 2), - (d[z + 3] = D + 2), - (d[z + 4] = D + 1), - (d[z + 5] = D + 3), - (D += 4), - (z += 6); - return { positions: h, normals: u, uvs: f, indices: d }; - })({ radius: this.radius }); - this.computeBoundingSphere(e), - this.setAttribute(new Ie("position", e, 3)), - this.setAttribute(new Ie("normal", t, 3)), - this.setAttribute(new Ie("uv", i, 2)), - this.setIndice(r), - (this.count = r.length); - } -} -class gr extends At { - constructor(e = 10, t = 10, i = 10) { - super({ type: "boxGeometry" }), - (this.width = e), - (this.height = t), - (this.depth = i), - (this.defines = { HAS_NORMAL: !0 }), - this.init(); + const { positions, normals, uvs, indices } = createSphere({ radius: this.radius }); + // this.positions = positions; + // this.normals = normals; + // this.uvs = uvs; + // this.indices = indices; + this.computeBoundingSphere(positions); + this.setAttribute(new Float32Attribute("position", positions, 3)); + this.setAttribute(new Float32Attribute("normal", normals, 3)); + this.setAttribute(new Float32Attribute("uv", uvs, 2)); + this.setIndice(indices); + this.count = indices.length; + } +} + +class BoxGeometry extends Geometry { + constructor(width = 10, height = 10, depth = 10) { + super({ + type: "boxGeometry" + }); + this.width = width; + this.height = height; + this.depth = depth; + this.defines = { + HAS_NORMAL: true + }; + this.init(); } init() { - const { - positions: e, - normals: t, - uvs: i - } = (function (e) { - const t = (e = e || {}).dimensions || [1, 1, 1], - i = e.position || [-t[0] / 2, -t[1] / 2, -t[2] / 2], - r = i[0], - n = i[1], - s = i[2], - a = t[0], - o = t[1], - c = t[2], - l = { x: r, y: n, z: s + c }, - h = { x: r + a, y: n, z: s + c }, - u = { x: r, y: n + o, z: s + c }, - f = { x: r + a, y: n + o, z: s + c }, - d = { x: r, y: n, z: s }, - m = { x: r + a, y: n, z: s }, - p = { x: r, y: n + o, z: s }, - g = { x: r + a, y: n + o, z: s }; - return { - positions: [ - l.x, - l.y, - l.z, - h.x, - h.y, - h.z, - u.x, - u.y, - u.z, - u.x, - u.y, - u.z, - h.x, - h.y, - h.z, - f.x, - f.y, - f.z, - h.x, - h.y, - h.z, - m.x, - m.y, - m.z, - f.x, - f.y, - f.z, - f.x, - f.y, - f.z, - m.x, - m.y, - m.z, - g.x, - g.y, - g.z, - h.x, - m.y, - m.z, - d.x, - d.y, - d.z, - g.x, - g.y, - g.z, - g.x, - g.y, - g.z, - d.x, - d.y, - d.z, - p.x, - p.y, - p.z, - d.x, - d.y, - d.z, - l.x, - l.y, - l.z, - p.x, - p.y, - p.z, - p.x, - p.y, - p.z, - l.x, - l.y, - l.z, - u.x, - u.y, - u.z, - u.x, - u.y, - u.z, - f.x, - f.y, - f.z, - p.x, - p.y, - p.z, - p.x, - p.y, - p.z, - f.x, - f.y, - f.z, - g.x, - g.y, - g.z, - d.x, - d.y, - d.z, - m.x, - m.y, - m.z, - l.x, - l.y, - l.z, - l.x, - l.y, - l.z, - m.x, - m.y, - m.z, - h.x, - h.y, - h.z - ], - normals: [ - 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, - 1, 0, 0, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, -1, -1, 0, 0, -1, 0, 0, -1, 0, 0, - -1, 0, 0, -1, 0, 0, -1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, -1, 0, 0, -1, - 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0 - ], - uvs: [ - 0, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, - 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1, 0, 0, 1, 0, 0, 1, - 0, 1, 1, 0, 1, 1 - ] - }; - })({ dimensions: [this.depth, this.width, this.height] }); - this.computeBoundingSphere(e), - this.setAttribute(new Ie("position", e, 3)), - this.setAttribute(new Ie("normal", t, 3)), - this.setAttribute(new Ie("uv", i, 2)), - (this.count = 36); - } -} -class xr extends At { - constructor(e = 1, t = 0.4, i = 64, r = 8, n = 2, s = 3) { - super({ type: "torusKnotGeometry" }), - (this.defines = { HAS_NORMAL: !0 }), - (this.radius = e), - (this.tube = t), - (this.tubularSegments = i), - (this.radialSegments = r), - (this.p = n), - (this.q = s), - this.init(); + // generate pos uv normal so on + const { positions, normals, uvs } = createBox({ + dimensions: [this.depth, this.width, this.height] + }); + this.computeBoundingSphere(positions); + this.setAttribute(new Float32Attribute("position", positions, 3)); + this.setAttribute(new Float32Attribute("normal", normals, 3)); + this.setAttribute(new Float32Attribute("uv", uvs, 2)); + this.count = 36; + } +} + +class TorusKnotGeometry extends Geometry { + constructor(radius = 1, tube = 0.4, tubularSegments = 64, radialSegments = 8, p = 2, q = 3) { + super({ + type: "torusKnotGeometry" + }); + this.defines = { + HAS_NORMAL: true + }; + this.radius = radius; + this.tube = tube; + this.tubularSegments = tubularSegments; + this.radialSegments = radialSegments; + this.p = p; + this.q = q; + this.init(); } init() { - const { normals: e, uvs: t, positions: i, indices: r } = this.createGeometry(); - this.computeBoundingSphere(i), - this.setAttribute(new Ie("position", i, 3)), - this.setAttribute(new Ie("normal", e, 3)), - this.setAttribute(new Ie("uv", t, 2)), - this.setIndice(r), - (this.count = r.length); + const { normals, uvs, positions, indices } = this.createGeometry(); + this.computeBoundingSphere(positions); + this.setAttribute(new Float32Attribute("position", positions, 3)); + this.setAttribute(new Float32Attribute("normal", normals, 3)); + this.setAttribute(new Float32Attribute("uv", uvs, 2)); + this.setIndice(indices); + this.count = indices.length; } createGeometry() { - const e = [], - t = [], - i = [], - r = [], - n = Math.floor(this.tubularSegments), - s = Math.floor(this.radialSegments), - a = new Ue(), - o = new Ue(), - c = new Ue(), - l = new Ue(), - h = new Ue(), - u = new Ue(), - f = new Ue(); - for (let r = 0; r <= n; ++r) { - const d = (r / n) * this.p * Math.PI * 2; - vr(d, this.p, this.q, this.radius, c), - vr(d + 0.01, this.p, this.q, this.radius, l), - Ue.subtract(l, c, u), - Ue.add(l, c, f), - Ue.cross(u, f, h), - Ue.cross(h, u, f), - h.normalize(), - f.normalize(); - for (let l = 0; l <= s; ++l) { - const u = (l / s) * Math.PI * 2, - d = -this.tube * Math.cos(u), - m = this.tube * Math.sin(u); - (a.x = c.x + (d * f.x + m * h.x)), - (a.y = c.y + (d * f.y + m * h.y)), - (a.z = c.z + (d * f.z + m * h.z)), - e.push(a.x, a.y, a.z), - Ue.subtract(a, c, o), - o.normalize(), - t.push(o.x, o.y, o.z), - i.push(r / n), - i.push(l / s); + const positions = [], + normals = [], + uvs = [], + indices = []; + const tubularSegments = Math.floor(this.tubularSegments); + const radialSegments = Math.floor(this.radialSegments); + // helper variables + const vertex = new Vector3(); + const normal = new Vector3(); + const P1 = new Vector3(); + const P2 = new Vector3(); + const B = new Vector3(); + const T = new Vector3(); + const N = new Vector3(); + // generate vertices, normals and uvs + for (let i = 0; i <= tubularSegments; ++i) { + // the radian "u" is used to calculate the position on the torus curve of the current tubular segment + const u = (i / tubularSegments) * this.p * Math.PI * 2; + // now we calculate two points. P1 is our current position on the curve, P2 is a little farther ahead. + // these points are used to create a special "coordinate space", which is necessary to calculate the correct vertex positions + calculatePositionOnCurve(u, this.p, this.q, this.radius, P1); + calculatePositionOnCurve(u + 0.01, this.p, this.q, this.radius, P2); + // calculate orthonormal basis + Vector3.subtract(P2, P1, T); + // T.subVectors( P2, P1 ); + Vector3.add(P2, P1, N); + // N.addVectors( P2, P1 ); + Vector3.cross(T, N, B); + // B.crossVectors( T, N ); + Vector3.cross(B, T, N); + // N.crossVectors( B, T ); + // normalize B, N. T can be ignored, we don't use it + B.normalize(); + N.normalize(); + for (let j = 0; j <= radialSegments; ++j) { + // now calculate the vertices. they are nothing more than an extrusion of the torus curve. + // because we extrude a shape in the xy-plane, there is no need to calculate a z-value. + const v = (j / radialSegments) * Math.PI * 2; + const cx = -this.tube * Math.cos(v); + const cy = this.tube * Math.sin(v); + // now calculate the final vertex position. + // first we orient the extrusion with our basis vectors, then we add it to the current position on the curve + vertex.x = P1.x + (cx * N.x + cy * B.x); + vertex.y = P1.y + (cx * N.y + cy * B.y); + vertex.z = P1.z + (cx * N.z + cy * B.z); + positions.push(vertex.x, vertex.y, vertex.z); + // normal (P1 is always the center/origin of the extrusion, thus we can use it to calculate the normal) + Vector3.subtract(vertex, P1, normal); + normal.normalize(); + normals.push(normal.x, normal.y, normal.z); + // uv + uvs.push(i / tubularSegments); + uvs.push(j / radialSegments); } } - for (let e = 1; e <= n; e++) - for (let t = 1; t <= s; t++) { - const i = (s + 1) * (e - 1) + (t - 1), - n = (s + 1) * e + (t - 1), - a = (s + 1) * e + t, - o = (s + 1) * (e - 1) + t; - r.push(i, n, o), r.push(n, a, o); + // generate indices + for (let j = 1; j <= tubularSegments; j++) { + for (let i = 1; i <= radialSegments; i++) { + // indices + const a = (radialSegments + 1) * (j - 1) + (i - 1); + const b = (radialSegments + 1) * j + (i - 1); + const c = (radialSegments + 1) * j + i; + const d = (radialSegments + 1) * (j - 1) + i; + // faces + indices.push(a, b, d); + indices.push(b, c, d); } - return { normals: t, uvs: i, positions: e, indices: r }; + } + return { + normals, + uvs, + positions, + indices + }; } } -function vr(e, t, i, r, n) { - const s = Math.cos(e), - a = Math.sin(e), - o = (i / t) * e, - c = Math.cos(o); - (n.x = r * (2 + c) * 0.5 * s), (n.y = r * (2 + c) * a * 0.5), (n.z = r * Math.sin(o) * 0.5); +function calculatePositionOnCurve(u, p, q, radius, position) { + const cu = Math.cos(u); + const su = Math.sin(u); + const quOverP = (q / p) * u; + const cs = Math.cos(quOverP); + position.x = radius * (2 + cs) * 0.5 * cu; + position.y = radius * (2 + cs) * su * 0.5; + position.z = radius * Math.sin(quOverP) * 0.5; } -class yr extends Wi { + +class BlinnPhongMaterial extends Material { constructor() { - super(), - (this.type = "phong"), - (this.color = new Qt(1, 0, 0)), - (this.shaderSource = new Gi({ shaderId: this.type, defines: { materialPhong: !0 } })), - (this.light = !0), - (this.specular = new Qt(1, 1, 1)), - (this.shininess = 30), - (this.baseTexture = void 0), - (this.baseSampler = void 0); - } - update(e, t) { - (this.shaderData && !this.dirty) || this.createShaderData(t); - } - createShaderData(e) { + super(); + this.type = "phong"; + this.color = new Color(1.0, 0.0, 0.0); + this.shaderSource = new ShaderSource({ + shaderId: this.type, + defines: { + materialPhong: true + } + }); + this.light = true; + this.specular = new Color(1.0, 1.0, 1.0); + this.shininess = 30.0; + this.baseTexture = undefined; + this.baseSampler = undefined; + } + update(frameState, mesh) { + if (!this.shaderData || this.dirty) this.createShaderData(mesh); + } + createShaderData(mesh) { super.createShaderData(); - const t = new Ri({ label: "phong" }); - t.setUniform("modelMatrix", () => e.modelMatrix, Q.Mat4), - t.setUniform("color", this, Q.Color), - t.setUniform("opacity", this, Q.Float), - t.setUniform("normalMtrix", () => e.normalMatrix, Q.Mat4), - t.setUniform("emissive", this, Q.Color), - t.setUniform("shininess", this, Q.Float), - t.setUniform("specular", this, Q.Color), - this.shaderData.setUniformBuffer("phong", t), - this.baseTexture && - (this.shaderData.setDefine("USE_COLORTEXTURE", !0), - this.shaderData.setTexture("baseColorTexture", this.baseTexture), - this.shaderData.setSampler("baseColorSampler", this.baseSampler || nr.defaultSampler)), - this.normalTexture && - (this.shaderData.setDefine("USE_NORMALTEXTURE", !0), - this.shaderData.setTexture("normalTexture", this.normalTexture), - this.shaderData.setSampler("normalSampler", this.normalSampler || nr.defaultSampler)); + const uniformBuffer = new UniformBuffer({ label: "phong" }); + uniformBuffer.setUniform( + "modelMatrix", + () => { + return mesh.modelMatrix; + }, + UniformEnum.Mat4 + ); + uniformBuffer.setUniform("color", this, UniformEnum.Color); + uniformBuffer.setUniform("opacity", this, UniformEnum.Float); + uniformBuffer.setUniform( + "normalMtrix", + () => { + return mesh.normalMatrix; + }, + UniformEnum.Mat4 + ); + uniformBuffer.setUniform("emissive", this, UniformEnum.Color); + uniformBuffer.setUniform("shininess", this, UniformEnum.Float); + uniformBuffer.setUniform("specular", this, UniformEnum.Color); + this.shaderData.setUniformBuffer("phong", uniformBuffer); + if (this.baseTexture) { + this.shaderData.setDefine("USE_COLORTEXTURE", true); + this.shaderData.setTexture("baseColorTexture", this.baseTexture); + this.shaderData.setSampler("baseColorSampler", this.baseSampler || textureCache.defaultSampler); + } + if (this.normalTexture) { + this.shaderData.setDefine("USE_NORMALTEXTURE", true); + this.shaderData.setTexture("normalTexture", this.normalTexture); + this.shaderData.setSampler("normalSampler", this.normalSampler || textureCache.defaultSampler); + } } destroy() { - this?.baseTexture?.destroy(), super.destroy(); + this?.baseTexture?.destroy(); + super.destroy(); } } -class Sr extends Wi { + +class PbrMaterial extends Material { get roughness() { return this._roughness; } - set roughness(e) { - this._roughness = e; + set roughness(value) { + this._roughness = value; } get metalness() { return this._metalness; } - set metalness(e) { - this._metalness = e; + set metalness(v) { + this._metalness = v; } get aoTextureIntensity() { return this._aoTextureIntensity; } - set aoTextureIntensity(e) { - this._aoTextureIntensity = e; + set aoTextureIntensity(v) { + this._aoTextureIntensity = v; } get normalScale() { - return this.renderState && this.renderState.primitive && this.renderState.primitive.cullMode == w.Back - ? Se.negate(this._normalScale, new Se()) - : this._normalScale; + if (this.renderState && this.renderState.primitive) { + if (this.renderState.primitive.cullMode == CullMode.Back) { + return Vector2.negate(this._normalScale, new Vector2()); + } + } + return this._normalScale; } - set normalScale(e) { - this._normalScale = e; + set normalScale(v) { + this._normalScale = v; } - set IBLRender(e) { - (this._IBLRender = e), this.shaderSource.setDefines({ USE_IBL: this._IBLRender }), (this.dirty = !0); + set IBLRender(value) { + this._IBLRender = value; + this.shaderSource.setDefines({ + USE_IBL: this._IBLRender + }); + this.dirty = true; } constructor() { - super(), - (this.type = "pbr_mat"), - (this._roughness = 0.1), - (this._metalness = 0.1), - (this._aoTextureIntensity = 1), - (this.light = !0), - (this._normalScale = new Se(1, 1)), - (this._IBLRender = !0), - (this.shaderSource = new Gi({ - shaderId: this.type, - defines: { materialPbr: !0, USE_IBL: this._IBLRender } - })); - } - update(e, t) { - nr.getTexture("specular") && ((this.shaderData && !this.dirty) || this.createShaderData(t)); - } - createShaderData(e) { + super(); + this.type = "pbr_mat"; + this._roughness = 0.1; + this._metalness = 0.1; + this._aoTextureIntensity = 1.0; + this.light = true; + this._normalScale = new Vector2(1, 1); + this._IBLRender = true; + this.shaderSource = new ShaderSource({ + shaderId: this.type, + defines: { + materialPbr: true, + USE_IBL: this._IBLRender + } + }); + } + update(frameState, mesh) { + if (!textureCache.getTexture("specular")) return; + if (!this.shaderData || this.dirty) { + this.createShaderData(mesh); + } + } + createShaderData(mesh) { super.createShaderData(); - const t = new Ri({ label: "pbr" }); - t.setUniform("modelMatrix", () => e.modelMatrix, Q.Mat4), - t.setUniform("color", this, Q.Color), - t.setUniform("opacity", this, Q.Float), - t.setUniform("normalMtrix", () => e.normalMatrix, Q.Mat4), - t.setUniform("emissive", this, Q.Color), - t.setUniform("metalness", this, Q.Float), - t.setUniform("roughness", this, Q.Float), - this.shaderData.setUniformBuffer("pbr", t), - (this.specularEnvTexture = nr.getTexture("specular")), - this.baseTexture && - (this.shaderData.setDefine("USE_TEXTURE", !0), - this.shaderData.setTexture("baseColorTexture", this.baseTexture), - this.shaderData.setSampler("baseColorSampler", this.baseSampler || nr.defaultSampler)), - this.metalnessRoughnessTexture && - (this.shaderData.setDefine("USE_METALNESSTEXTURE", !0), - this.shaderData.setTexture("metalnessRoughnessTexture", this.metalnessRoughnessTexture), - this.shaderData.setSampler( - "metalnessRoughnessSampler", - this.metalnessRoughnessSampler || nr.defaultSampler - )), - this.normalTexture && - (t.setUniform("normalScale", this, Q.FloatVec2), - this.shaderData.setDefine("USE_NORMALTEXTURE", !0), - this.shaderData.setTexture("normalTexture", this.normalTexture), - this.shaderData.setSampler("normalSampler", this.normalSampler || nr.defaultSampler)), - this.aoTexture && - (this.shaderData.setDefine("USE_AOTEXTURE", !0), - this.shaderData.setTexture("aoTexture", this.aoTexture), - this.shaderData.setSampler("aoSampler", this.aoSampler || nr.defaultSampler), - t.setUniform("aoTextureIntensity", this, Q.Float)), - this.emissiveTexture && - (this.shaderData.setDefine("USE_EMISSIVETEXTURE", !0), - this.shaderData.setTexture("emissiveTexture", this.emissiveTexture), - this.shaderData.setSampler("emissiveSampler", this.emissiveSampler || nr.defaultSampler)), - this.specularEnvTexture && - this._IBLRender && - (this.shaderData.setTexture("specularEnvTexture", this.specularEnvTexture), - this.shaderData.setSampler("specularEnvSampler", this.specularEnvSampler || nr.defaultSampler)); + const uniformBuffer = new UniformBuffer({ label: "pbr" }); + uniformBuffer.setUniform( + "modelMatrix", + () => { + return mesh.modelMatrix; + }, + UniformEnum.Mat4 + ); + uniformBuffer.setUniform("color", this, UniformEnum.Color); + uniformBuffer.setUniform("opacity", this, UniformEnum.Float); + uniformBuffer.setUniform( + "normalMtrix", + () => { + return mesh.normalMatrix; + }, + UniformEnum.Mat4 + ); + uniformBuffer.setUniform("emissive", this, UniformEnum.Color); + uniformBuffer.setUniform("metalness", this, UniformEnum.Float); + uniformBuffer.setUniform("roughness", this, UniformEnum.Float); + this.shaderData.setUniformBuffer("pbr", uniformBuffer); + this.specularEnvTexture = textureCache.getTexture("specular"); + if (this.baseTexture) { + this.shaderData.setDefine("USE_TEXTURE", true); + this.shaderData.setTexture("baseColorTexture", this.baseTexture); + this.shaderData.setSampler("baseColorSampler", this.baseSampler || textureCache.defaultSampler); + } + if (this.metalnessRoughnessTexture) { + this.shaderData.setDefine("USE_METALNESSTEXTURE", true); + this.shaderData.setTexture("metalnessRoughnessTexture", this.metalnessRoughnessTexture); + this.shaderData.setSampler( + "metalnessRoughnessSampler", + this.metalnessRoughnessSampler || textureCache.defaultSampler + ); + } + if (this.normalTexture) { + uniformBuffer.setUniform("normalScale", this, UniformEnum.FloatVec2); + this.shaderData.setDefine("USE_NORMALTEXTURE", true); + this.shaderData.setTexture("normalTexture", this.normalTexture); + this.shaderData.setSampler("normalSampler", this.normalSampler || textureCache.defaultSampler); + } + if (this.aoTexture) { + this.shaderData.setDefine("USE_AOTEXTURE", true); + this.shaderData.setTexture("aoTexture", this.aoTexture); + this.shaderData.setSampler("aoSampler", this.aoSampler || textureCache.defaultSampler); + uniformBuffer.setUniform("aoTextureIntensity", this, UniformEnum.Float); + } + if (this.emissiveTexture) { + this.shaderData.setDefine("USE_EMISSIVETEXTURE", true); + this.shaderData.setTexture("emissiveTexture", this.emissiveTexture); + this.shaderData.setSampler("emissiveSampler", this.emissiveSampler || textureCache.defaultSampler); + } + if (this.specularEnvTexture && this._IBLRender) { + this.shaderData.setTexture("specularEnvTexture", this.specularEnvTexture); + this.shaderData.setSampler("specularEnvSampler", this.specularEnvSampler || textureCache.defaultSampler); + } } destroy() { - this?.aoTexture?.destroy(), - this?.baseTexture?.destroy(), - this?.emissiveTexture?.destroy(), - this?.normalTexture?.destroy(), - (this.specularEnvTexture = void 0); + this?.aoTexture?.destroy(); + this?.baseTexture?.destroy(); + this?.emissiveTexture?.destroy(); + this?.normalTexture?.destroy(); + this.specularEnvTexture = undefined; } } -class br { + +class EventDispatcher { constructor() { this._listeners = {}; } - addEventListener(e, t) { - void 0 === this._listeners && (this._listeners = {}); - const i = this._listeners; - void 0 === i[e] && (i[e] = []), -1 === i[e].indexOf(t) && i[e].push(t); - } - hasEventListener(e, t) { - if (void 0 === this._listeners) return !1; - const i = this._listeners; - return void 0 !== i[e] && -1 !== i[e].indexOf(t); + addEventListener(type, listener) { + if (this._listeners === undefined) this._listeners = {}; + const listeners = this._listeners; + if (listeners[type] === undefined) { + listeners[type] = []; + } + if (listeners[type].indexOf(listener) === -1) { + listeners[type].push(listener); + } } - removeEventListener(e, t) { - if (void 0 === this._listeners) return; - const i = this._listeners[e]; - if (void 0 !== i) { - const e = i.indexOf(t); - -1 !== e && i.splice(e, 1); + hasEventListener(type, listener) { + if (this._listeners === undefined) return false; + const listeners = this._listeners; + return listeners[type] !== undefined && listeners[type].indexOf(listener) !== -1; + } + removeEventListener(type, listener) { + if (this._listeners === undefined) return; + const listeners = this._listeners; + const listenerArray = listeners[type]; + if (listenerArray !== undefined) { + const index = listenerArray.indexOf(listener); + if (index !== -1) { + listenerArray.splice(index, 1); + } } } - dispatchEvent(e) { - if (void 0 === this._listeners) return; - const t = this._listeners[e.type]; - if (void 0 !== t) { - e.target = this; - const i = t.slice(0); - for (let t = 0, r = i.length; t < r; t++) i[t].call(this, e); - e.target = null; + dispatchEvent(event) { + if (this._listeners === undefined) return; + const listeners = this._listeners; + const listenerArray = listeners[event.type]; + if (listenerArray !== undefined) { + event.target = this; + const array = listenerArray.slice(0); + for (let i = 0, l = array.length; i < l; i++) { + array[i].call(this, event); + } + event.target = null; } } } -class wr { + +class RenderQueue { constructor() { - (this.pre = []), (this.opaque = []), (this.transparent = []), (this.computes = []), (this.debugQueue = []); + this.pre = []; + this.opaque = []; + this.transparent = []; + this.computes = []; + this.debugQueue = []; } sort() { - wr.sort(this.opaque, 0, this.opaque.length, wr._compareFromNearToFar), - wr.sort(this.transparent, 0, this.transparent.length, wr._compareFromFarToNear); - } - opaqueRender(e, t, i, r, n, s) { - this.opaque.map((a) => { - a.ready && (a.beforeRender(), wr.excuteCommand(a.getDrawCommand(r, n, s), t, i, e), a.afterRender()); + RenderQueue.sort(this.opaque, 0, this.opaque.length, RenderQueue._compareFromNearToFar); + RenderQueue.sort(this.transparent, 0, this.transparent.length, RenderQueue._compareFromFarToNear); + } + opaqueRender(camera, context, passEncoder, replaceMaterial, commandSubType, lightManger) { + this.opaque.map((mesh) => { + if (!mesh.ready) return; + mesh.beforeRender(); + RenderQueue.excuteCommand( + mesh.getDrawCommand(replaceMaterial, commandSubType, lightManger), + context, + passEncoder, + camera + ); + mesh.afterRender(); }); } - transparentRender(e, t, i, r, n, s) { - this.transparent.map((a) => { - a.ready && (a.beforeRender(), wr.excuteCommand(a.getDrawCommand(r, n, s), t, i, e), a.afterRender()); + transparentRender(camera, context, passEncoder, replaceMaterial, commandSubType, lightManger) { + this.transparent.map((mesh) => { + if (!mesh.ready) return; + mesh.beforeRender(); + RenderQueue.excuteCommand( + mesh.getDrawCommand(replaceMaterial, commandSubType, lightManger), + context, + passEncoder, + camera + ); + mesh.afterRender(); }); } - computeRender(e, t) { - this.computes.map((i) => { - wr.excuteCompute(i.getCommand(), e, t); + computeRender(context, passEncoder) { + this.computes.map((compute) => { + RenderQueue.excuteCompute(compute.getCommand(), context, passEncoder); }); } - debugQueueRender(e, t, i, r, n) { - this.debugQueue.map((s) => { - s.ready && (s.beforeRender(), wr.excuteCommand(s.getDrawCommand(r, n), t, i, e), s.afterRender()); + debugQueueRender(camera, context, passEncoder, replaceMaterial, commandSubType) { + this.debugQueue.map((mesh) => { + if (!mesh.ready) return; + mesh.beforeRender(); + RenderQueue.excuteCommand( + mesh.getDrawCommand(replaceMaterial, commandSubType), + context, + passEncoder, + camera + ); + mesh.afterRender(); }); } - preRender(e, t, i, r) { - this.pre.map((r) => { - r.ready && (r.beforeRender(), wr.excuteCommand(r.getDrawCommand(), t, i, e), r.afterRender()); + preRender(camera, context, passEncoder, replaceMaterial) { + this.pre.map((mesh) => { + if (!mesh.ready) return; + mesh.beforeRender(); + RenderQueue.excuteCommand(mesh.getDrawCommand(), context, passEncoder, camera); + mesh.afterRender(); }); } - static excuteCommand(e, t, i, r) { - e.render({ device: t.device, passEncoder: i, camera: r, viewPort: t?.viewPort, scissorTest: t?.scissorTest }); + static excuteCommand(command, context, passEncoder, camera) { + command.render({ + device: context.device, + passEncoder, + camera, + viewPort: context?.viewPort, + scissorTest: context?.scissorTest + }); } - static excuteCompute(e, t, i) { - e.render({ device: t.device, passEncoder: i }); + static excuteCompute(command, context, passEncoder) { + command.render({ device: context.device, passEncoder }); } reset() { - (this.pre = []), (this.opaque = []), (this.transparent = []), (this.computes = []), (this.debugQueue = []); - } - static _compareFromNearToFar(e, t) { - return e.priority - t.priority || e.distanceToCamera - t.distanceToCamera; - } - static _compareFromFarToNear(e, t) { - return e.priority - t.priority || t.distanceToCamera - e.distanceToCamera; - } - static sort(e, t, i, r) { - wr._quickSort(e, t, i, r); - } - static _quickSort(e, t, i, r) { - for (;;) { - if (i - t <= 10) return void wr._insertionSort(e, t, i, r); - const n = (t + i) >> 1; - let s = e[t], - a = e[i - 1], - o = e[n]; - if (r(s, a) > 0) { - const e = s; - (s = a), (a = e); + this.pre = []; + this.opaque = []; + this.transparent = []; + this.computes = []; + this.debugQueue = []; + } + static _compareFromNearToFar(a, b) { + return a.priority - b.priority || a.distanceToCamera - b.distanceToCamera; + } + static _compareFromFarToNear(a, b) { + return a.priority - b.priority || b.distanceToCamera - a.distanceToCamera; + } + // according to camera distance + static sort(insatnce, from, to, compareFunc) { + RenderQueue._quickSort(insatnce, from, to, compareFunc); + } + // from https://github.com/oasis-engine/engine/blob/main/packages/core/src/RenderPipeline/RenderQueue.ts + static _quickSort(a, from, to, compareFunc) { + while (true) { + // Insertion sort is faster for short arrays. + if (to - from <= 10) { + RenderQueue._insertionSort(a, from, to, compareFunc); + return; } - if (r(s, o) >= 0) { - const e = s; - (s = o), (o = a), (a = e); + const third_index = (from + to) >> 1; + // Find a pivot as the median of first, last and middle element. + let v0 = a[from]; + let v1 = a[to - 1]; + let v2 = a[third_index]; + const c01 = compareFunc(v0, v1); + if (c01 > 0) { + // v1 < v0, so swap them. + const tmp = v0; + v0 = v1; + v1 = tmp; + } // v0 <= v1. + const c02 = compareFunc(v0, v2); + if (c02 >= 0) { + // v2 <= v0 <= v1. + const tmp = v0; + v0 = v2; + v2 = v1; + v1 = tmp; } else { - if (r(a, o) > 0) { - const e = a; - (a = o), (o = e); + // v0 <= v1 && v0 < v2 + const c12 = compareFunc(v1, v2); + if (c12 > 0) { + // v0 <= v2 < v1 + const tmp = v1; + v1 = v2; + v2 = tmp; } } - (e[t] = s), (e[i - 1] = o); - const c = a; - let l = t + 1, - h = i - 1; - (e[n] = e[l]), (e[l] = c); - e: for (let t = l + 1; t < h; t++) { - let i = e[t], - n = r(i, c); - if (n < 0) (e[t] = e[l]), (e[l] = i), l++; - else if (n > 0) { + // v0 <= v1 <= v2 + a[from] = v0; + a[to - 1] = v2; + const pivot = v1; + let low_end = from + 1; // Upper bound of elements lower than pivot. + let high_start = to - 1; // Lower bound of elements greater than pivot. + a[third_index] = a[low_end]; + a[low_end] = pivot; + // From low_end to i are elements equal to pivot. + // From i to high_start are elements that haven't been compared yet. + partition: for (let i = low_end + 1; i < high_start; i++) { + let element = a[i]; + let order = compareFunc(element, pivot); + if (order < 0) { + a[i] = a[low_end]; + a[low_end] = element; + low_end++; + } else if (order > 0) { do { - if ((h--, h == t)) break e; - n = r(e[h], c); - } while (n > 0); - (e[t] = e[h]), (e[h] = i), n < 0 && ((i = e[t]), (e[t] = e[l]), (e[l] = i), l++); + high_start--; + if (high_start == i) break partition; + const top_elem = a[high_start]; + order = compareFunc(top_elem, pivot); + } while (order > 0); + a[i] = a[high_start]; + a[high_start] = element; + if (order < 0) { + element = a[i]; + a[i] = a[low_end]; + a[low_end] = element; + low_end++; + } } } - i - h < l - t ? (this._quickSort(e, h, i, r), (i = l)) : (this._quickSort(e, t, l, r), (t = h)); + if (to - high_start < low_end - from) { + this._quickSort(a, high_start, to, compareFunc); + to = low_end; + } else { + this._quickSort(a, from, low_end, compareFunc); + from = high_start; + } } } - static _insertionSort(e, t, i, r) { - for (let n = t + 1; n < i; n++) { - let i; - const s = e[n]; - for (i = n - 1; i >= t; i--) { - const t = e[i]; - if (!(r(t, s) > 0)) break; - e[i + 1] = t; + static _insertionSort(a, from, to, compareFunc) { + for (let i = from + 1; i < to; i++) { + let j; + const element = a[i]; + for (j = i - 1; j >= from; j--) { + const tmp = a[j]; + const order = compareFunc(tmp, element); + if (order > 0) { + a[j + 1] = tmp; + } else { + break; + } } - e[i + 1] = s; + a[j + 1] = element; } } } -class Tr { - constructor(e, t, i = {}) { - (this.context = e), - (this.lightManger = t), - (this.background = i.background), - (this.renderQueue = new wr()), - (this.geometryMemory = 0), - (this.textureMemory = 0), - (this.frameNumber = 0), - (this._defines = {}), - (this.definesDirty = !0); + +class FrameState { + constructor(context, lightManger, options = {}) { + this.context = context; + this.lightManger = lightManger; + this.background = options.background; + this.renderQueue = new RenderQueue(); + this.geometryMemory = 0; + this.textureMemory = 0; + this.frameNumber = 0; + this._defines = {}; + this.definesDirty = true; } get defines() { return this._defines; } - set defines(e) { - (this.definesDirty = !0), (this._defines = Rt(e, this._defines, !1)); + set defines(value) { + this.definesDirty = true; + this._defines = combine(value, this._defines, false); } - update(e, t = {}) { - (this.background = t.background), - this.renderQueue.reset(), - this?.lightManger?.update?.(this, e), - (this.cullingVolume = e.getCullingVolume()), - (this.frameNumber += 1); + update(camera, options = {}) { + this.background = options.background; + this.renderQueue.reset(); + this?.lightManger?.update?.(this, camera); + this.cullingVolume = camera.getCullingVolume(); + this.frameNumber += 1; } - resetCullingVolume(e) { - this.cullingVolume = e.getCullingVolume(); + resetCullingVolume(camera) { + this.cullingVolume = camera.getCullingVolume(); } - static getFrameStateOptionsByScene(e) { - return { background: e.background }; + static getFrameStateOptionsByScene(sceneInstance) { + return { + background: sceneInstance.background + }; } } -class Er extends Ht { - constructor(e, t) { - super(e, t), (this.lightType = K.AmbientLight), (this._colorAndIntensity = new We(e.x, e.y, e.z, t)); + +class AmbientLight extends Light { + constructor(color, intensity) { + super(color, intensity); + this.lightType = LightType.AmbientLight; + this._colorAndIntensity = new Vector4(color.x, color.y, color.z, intensity); } - get ColorAndIntensity() { - return ( - this._colorAndIntensity.set(this.color.x, this.color.y, this.color.z, this.intensity), - this._colorAndIntensity - ); + get ColorAndIntensity() { + this._colorAndIntensity.set(this.color.x, this.color.y, this.color.z, this.intensity); + return this._colorAndIntensity; } } -class Mr { - constructor(e) { - (this.spotLights = []), - (this.pointLights = []), - (this.directLights = []), - (this.ambientLight = new Er(new Ue(1, 1, 1), 0.2)), - (this.lightCountDirty = !0), - (this.openShadow = e.openShadow); - } - update(e, t) { - this.checkLightShadowState(), this.updateLight(t); - } - add(e) { - (this.lightCountDirty = !0), - e.lightType == K.AmbientLight - ? (this.ambientLight = e) - : e.lightType == K.DirectionalLight - ? this.directLights.push(e) - : e.lightType == K.PointLight - ? this.pointLights.push(e) - : e.lightType == K.SpotLight && this.spotLights.push(e); - } - remove(e) { - (this.lightCountDirty = !0), - e.lightType == K.AmbientLight - ? (this.ambientLight = new Er(new Ue(1, 1, 1), 1)) - : e.lightType == K.DirectionalLight - ? this.directLights.splice(this.directLights.indexOf(e), 1) - : e.lightType == K.PointLight - ? this.pointLights.splice(this.pointLights.indexOf(e), 1) - : e.lightType == K.SpotLight && this.spotLights.splice(this.spotLights.indexOf(e), 1); +// light.color ).multiplyScalar( light.intensity * scaleFactor ); + +class LightManger { + constructor(options) { + this.spotLights = []; + this.pointLights = []; + this.directLights = []; + this.ambientLight = new AmbientLight(new Vector3(1.0, 1.0, 1.0), 0.2); + this.lightCountDirty = true; + this.openShadow = options.openShadow; + } + update(frameState, camera) { + this.checkLightShadowState(); + this.updateLight(camera); + } + add(light) { + this.lightCountDirty = true; + if (light.lightType == LightType.AmbientLight) { + this.ambientLight = light; + } else if (light.lightType == LightType.DirectionalLight) { + this.directLights.push(light); + } else if (light.lightType == LightType.PointLight) { + this.pointLights.push(light); + } else if (light.lightType == LightType.SpotLight) { + this.spotLights.push(light); + } + } + remove(light) { + this.lightCountDirty = true; + if (light.lightType == LightType.AmbientLight) { + this.ambientLight = new AmbientLight(new Vector3(1.0, 1.0, 1.0), 1.0); + } else if (light.lightType == LightType.DirectionalLight) { + this.directLights.splice(this.directLights.indexOf(light), 1); + } else if (light.lightType == LightType.PointLight) { + this.pointLights.splice(this.pointLights.indexOf(light), 1); + } else if (light.lightType == LightType.SpotLight) { + this.spotLights.splice(this.spotLights.indexOf(light), 1); + } } checkLightShadowState() { - const e = this.getAllLights(); - for (let t = 0; t < e.length; t++) { - const i = e[t]; - i.shadowDirty && ((i.shadowDirty = !1), (this.lightCountDirty = !0)); + const lights = this.getAllLights(); + for (let i = 0; i < lights.length; i++) { + const light = lights[i]; + if (light.shadowDirty) { + light.shadowDirty = false; + this.lightCountDirty = true; + } } } updateLightShadow() { - this.spotLightShadowMapTextureArray && (this.spotLightShadowMapTextureArray.dirty = !0), - this.pointLightShadowMapTextureArray && (this.pointLightShadowMapTextureArray.dirty = !0), - this.directLightShadowMapTextureArray && (this.directLightShadowMapTextureArray.dirty = !0); - } - updateLight(e) { - this.lightCountDirty && - ((this.lightCountDirty = !1), - this.lightShaderData && this.lightShaderData.destroy(), - this.createLightShaderData()); + if (this.spotLightShadowMapTextureArray) this.spotLightShadowMapTextureArray.dirty = true; + if (this.pointLightShadowMapTextureArray) this.pointLightShadowMapTextureArray.dirty = true; + if (this.directLightShadowMapTextureArray) this.directLightShadowMapTextureArray.dirty = true; + } + updateLight(camera) { + if (this.lightCountDirty) { + this.lightCountDirty = false; + if (this.lightShaderData) this.lightShaderData.destroy(); + this.createLightShaderData(); + } } createLightShaderData() { - (this.lightShaderData = new Yi("light", 0, 2, 2)), - (this.lightUniformBuffer = new Ri({ - label: "light", - type: m.ReadOnlyStorage, - usage: r.Storage | r.CopyDst - })), - this.lightShaderData.setDefine("spotLightsCount", this.spotLights.length), - this.lightShaderData.setDefine("pointLightsCount", this.pointLights.length), - this.lightShaderData.setDefine("dirtectLightsCount", this.directLights.length), - this.lightShaderData.setDefine("ambientLightCount", 1), - this.ambientLight && - this.lightUniformBuffer.setUniform( - "ambientLight", - () => this.ambientLight.ColorAndIntensity, - Q.FloatVec4 - ), - this.spotLights.length && - this.lightUniformBuffer.setUniform( - "spotLights", - () => this.spotLights, - Q.SpotLights, - this.spotLights.length - ), - this.pointLights.length && - this.lightUniformBuffer.setUniform( - "pointLights", - () => this.pointLights, - Q.PointLights, - this.pointLights.length - ), - this.directLights.length && - this.lightUniformBuffer.setUniform( - "directLights", - () => this.directLights, - Q.DirtectLights, - this.directLights.length - ); - e: if (this.openShadow) { - const e = (this.spotLightShadowMapTextureArray = this.createShadowMapTextureArray(this.spotLights)), - t = (this.pointLightShadowMapTextureArray = this.createShadowMapTextureArray(this.pointLights)), - i = (this.directLightShadowMapTextureArray = this.createShadowMapTextureArray(this.directLights)); - if (!e && !t && !i) break e; - this.lightShaderData.setDefine("openShadow", this.openShadow), - (this.shadowUniformBuffer = new Ri({ + this.lightShaderData = new ShaderData("light", 0, 2, 2); + this.lightUniformBuffer = new UniformBuffer({ + label: "light", + type: BufferBindingType.ReadOnlyStorage, + usage: BufferUsage.Storage | BufferUsage.CopyDst + }); + this.lightShaderData.setDefine("spotLightsCount", this.spotLights.length); + this.lightShaderData.setDefine("pointLightsCount", this.pointLights.length); + this.lightShaderData.setDefine("dirtectLightsCount", this.directLights.length); + this.lightShaderData.setDefine("ambientLightCount", 1); + if (this.ambientLight) + this.lightUniformBuffer.setUniform( + "ambientLight", + () => { + return this.ambientLight.ColorAndIntensity; + }, + UniformEnum.FloatVec4 + ); + if (this.spotLights.length) { + // 初始化聚光灯 + this.lightUniformBuffer.setUniform( + "spotLights", + () => { + return this.spotLights; + }, + UniformEnum.SpotLights, + this.spotLights.length + ); + } + if (this.pointLights.length) { + // 点光源 + this.lightUniformBuffer.setUniform( + "pointLights", + () => { + return this.pointLights; + }, + UniformEnum.PointLights, + this.pointLights.length + ); + } + if (this.directLights.length) { + // 方向光 + this.lightUniformBuffer.setUniform( + "directLights", + () => { + return this.directLights; + }, + UniformEnum.DirtectLights, + this.directLights.length + ); + } + shadowShaderData: { + if (this.openShadow) { + const spotLightShadowMapTextureArray = (this.spotLightShadowMapTextureArray = + this.createShadowMapTextureArray(this.spotLights)); + const pointLightShadowMapTextureArray = (this.pointLightShadowMapTextureArray = + this.createShadowMapTextureArray(this.pointLights)); + const directLightShadowMapTextureArray = (this.directLightShadowMapTextureArray = + this.createShadowMapTextureArray(this.directLights)); + if ( + !spotLightShadowMapTextureArray && + !pointLightShadowMapTextureArray && + !directLightShadowMapTextureArray + ) + break shadowShaderData; + // define + this.lightShaderData.setDefine("openShadow", this.openShadow); + // shadowUniformBuffer + this.shadowUniformBuffer = new UniformBuffer({ label: "shadow", - type: m.ReadOnlyStorage, - usage: r.Storage | r.CopyDst - })); - const n = this.setShadowUniform("spotLightShadows", this.spotLights, Q.SpotLightShadows), - s = this.setShadowUniform("pointLightShadows", this.pointLights, Q.PointLightShadows), - a = this.setShadowUniform("directLightShadows", this.directLights, Q.DirtectLightShadows); - this.lightShaderData.setUniformBuffer("shadow", this.shadowUniformBuffer), - this.lightShaderData.setDefine("spotLightShadowMapsCount", n), - this.lightShaderData.setDefine("pointLightShadowMapsCount", s), - this.lightShaderData.setDefine("directLightShadowMapsCount", a), - void 0 !== e && - (e.textureProp.size.depth != n && console.warn("spotLightShadowMap align has problem"), - this.lightShaderData.setTexture("spotLightShadowMapTextureArray", e)), - void 0 !== t && - (t.textureProp.size.depth != s && console.warn("pointLightShadowMap align has problem"), - this.lightShaderData.setTexture("pointLightShadowMapTextureArray", t)), - void 0 !== i && - (i.textureProp.size.depth != a && console.warn("directLightShadowMap align has problem"), - this.lightShaderData.setTexture("directLightShadowMapTextureArray", i)), - this.lightShaderData.setSampler("shadowSampler", new de({ compare: f.Less }, { type: p.Comparison })); + type: BufferBindingType.ReadOnlyStorage, + usage: BufferUsage.Storage | BufferUsage.CopyDst + }); + // matrix,near,far... + const spotLightWithShadowCount = this.setShadowUniform( + "spotLightShadows", + this.spotLights, + UniformEnum.SpotLightShadows + ); + const pointLightWithShadowCount = this.setShadowUniform( + "pointLightShadows", + this.pointLights, + UniformEnum.PointLightShadows + ); + const directLightWithShadowCount = this.setShadowUniform( + "directLightShadows", + this.directLights, + UniformEnum.DirtectLightShadows + ); + this.lightShaderData.setUniformBuffer("shadow", this.shadowUniformBuffer); + this.lightShaderData.setDefine("spotLightShadowMapsCount", spotLightWithShadowCount); + this.lightShaderData.setDefine("pointLightShadowMapsCount", pointLightWithShadowCount); + this.lightShaderData.setDefine("directLightShadowMapsCount", directLightWithShadowCount); + // texture,sample + if (spotLightShadowMapTextureArray !== undefined) { + if (spotLightShadowMapTextureArray.textureProp.size.depth != spotLightWithShadowCount) + console.warn("spotLightShadowMap align has problem"); + this.lightShaderData.setTexture("spotLightShadowMapTextureArray", spotLightShadowMapTextureArray); + // this._testTexture = spotLightShadowMapTextureArray + } + if (pointLightShadowMapTextureArray !== undefined) { + if (pointLightShadowMapTextureArray.textureProp.size.depth != pointLightWithShadowCount) + console.warn("pointLightShadowMap align has problem"); + this.lightShaderData.setTexture("pointLightShadowMapTextureArray", pointLightShadowMapTextureArray); + // this._testTexture = pointLightShadowMapTextureArray; + } + if (directLightShadowMapTextureArray !== undefined) { + if (directLightShadowMapTextureArray.textureProp.size.depth != directLightWithShadowCount) + console.warn("directLightShadowMap align has problem"); + this.lightShaderData.setTexture( + "directLightShadowMapTextureArray", + directLightShadowMapTextureArray + ); + // this._testTexture = directLightShadowMapTextureArray + } + this.lightShaderData.setSampler( + "shadowSampler", + new Sampler({ compare: CompareFunction.Less }, { type: SamplerBindingType.Comparison }) + ); + // this.lightShaderData.setSampler("shadowSampler", new Sampler()); + } } this.lightShaderData.setUniformBuffer("light", this.lightUniformBuffer); } getAllLights() { - return [].concat(this.spotLights, this.pointLights, this.directLights); + const result = []; + return result.concat(this.spotLights, this.pointLights, this.directLights); } destroy() { - this.lightShaderData.destroy(), this.lightUniformBuffer.destroy(); - } - createShadowMapTextureArray(e) { - if (e.length <= 0) return; - const t = []; - for (let i = 0; i < e.length; i++) { - const r = e[i]; - if (r.shadow) { - const e = r.shadow.getShadowMapTexture(), - n = { - source: e, - width: e.textureProp.size.width, - height: e.textureProp.size.height, - depth: 1, - x: 0, - y: 0, - z: i - }; - t.push(n); + this.lightShaderData.destroy(); + this.lightUniformBuffer.destroy(); + } + createShadowMapTextureArray(lights) { + if (lights.length <= 0) return undefined; + const shadowMapSources = []; + for (let i = 0; i < lights.length; i++) { + const light = lights[i]; + if (light.shadow) { + const shadowMapTexture = light.shadow.getShadowMapTexture(); + const shadowMapSource = { + source: shadowMapTexture, + width: shadowMapTexture.textureProp.size.width, + height: shadowMapTexture.textureProp.size.height, + depth: 1, + x: 0, + y: 0, + z: i + }; + shadowMapSources.push(shadowMapSource); } } - if (t.length <= 0) return; - return new fe({ - size: { width: t[0].width, height: t[0].height, depth: t.length }, - fixedSize: !0, - sampleType: g.Depth, - format: l.Depth24Plus, - usage: a.TextureBinding | a.CopyDst, - data: t, - viewFormats: o.E2dArray + if (shadowMapSources.length <= 0) return undefined; + const shadowMapTextureArray = new Texture({ + size: { + width: shadowMapSources[0].width, + height: shadowMapSources[0].height, + depth: shadowMapSources.length + }, + fixedSize: true, + sampleType: TextureSampleType.Depth, + format: TextureFormat.Depth24Plus, + usage: TextureUsage.TextureBinding | TextureUsage.CopyDst, + data: shadowMapSources, + viewFormats: TextureViewDimension.E2dArray }); - } - setShadowUniform(e, t, i) { - if (t.length) { - const r = []; - for (let e = 0; e < t.length; e++) { - const i = t[e]; - i.shadow && r.push(i); + return shadowMapTextureArray; + } + setShadowUniform(uniformName, lights, uniformType) { + if (lights.length) { + const lightWithShadowArray = []; + for (let i = 0; i < lights.length; i++) { + const light = lights[i]; + if (!light.shadow) continue; + lightWithShadowArray.push(light); } - return this.shadowUniformBuffer.setUniform(e, () => r, i, r.length), r.length; + this.shadowUniformBuffer.setUniform( + uniformName, + () => { + return lightWithShadowArray; + }, + uniformType, + lightWithShadowArray.length + ); + return lightWithShadowArray.length; } } } -class Ur { + +class MeshManger { constructor() { this._list = new Map(); } get length() { return this._list.size; } - update(e, t) { - this._list.forEach((i) => { - i.update(e, t); + update(frameState, camera) { + this._list.forEach((instance) => { + instance.update(frameState, camera); }); } - add(e) { - return this._list.get(e.uid) ? this._list.get(e.uid) : (this._list.set(e.uid, e), e); + add(instance) { + if (this._list.get(instance.uid)) return this._list.get(instance.uid); + this._list.set(instance.uid, instance); + return instance; } - remove(e) { - return !!this._list.get(e.uid) && (e.destroy(), this._list.delete(e.uid), !0); + remove(instance) { + if (this._list.get(instance.uid)) { + instance.destroy(); + this._list.delete(instance.uid); + return true; + } + return false; } - contains(e) { - return !!this._list.get(e.uid); + contains(instance) { + return !!this._list.get(instance.uid); } } -class _r { + +class ResolveFrame { constructor() { - (this.geometry = new At({})), - this.geometry.setAttribute(new Ie("position", [-1, 1, -1, -1, 1, -1, 1, -1, 1, 1, -1, 1], 2)), - (this.geometry.count = 6); - const e = $i("resolve", { positionLocation: 0 }); - (this.material = new Zi({ + this.geometry = new Geometry({}); + this.geometry.setAttribute( + new Float32Attribute("position", [-1.0, 1.0, -1.0, -1.0, 1.0, -1.0, 1.0, -1.0, 1.0, 1.0, -1.0, 1.0], 2) + ); + this.geometry.count = 6; + const shader = getVertFrag("resolve", { positionLocation: 0 }); + this.material = new ShaderMaterial({ type: "resolve", - frag: e.frag, - vert: e.vert, + frag: shader.frag, + vert: shader.vert, uniforms: { - texture: { type: "texture", value: void 0 }, - sampler: { type: "sampler", value: new de({ magFilter: "linear", minFilter: "linear" }) } + texture: { + type: "texture", + value: undefined + }, + sampler: { + type: "sampler", + value: new Sampler({ + magFilter: "linear", + minFilter: "linear" + }) + } } - })), - (this.quadMesh = new Qi(this.geometry, this.material)); - } - setSize(e, t) { - this.canvasRenderTarget.setSize(e, t), (this.material.dirty = !0); - } - render(e, t) { - this.canvasRenderTarget || this.initRenderTarget(e), - (this.material.uniforms.texture.value = t), - this.material.update(void 0, this.quadMesh); - const i = this.quadMesh.getDrawCommand(), - r = this.canvasRenderTarget.beginRenderPass(e.device); - i.render({ device: e.device, passEncoder: r }), this.canvasRenderTarget.endRenderPass(); - } - initRenderTarget(e) { - const { width: t, height: i, depth: r } = e.presentationSize, - n = new me({ r: 0, g: 0, b: 0, a: 0 }, { textureView: () => e.context.getCurrentTexture().createView() }), - s = new fe({ - label: "resolveDepth", - size: { width: t, height: i, depth: r }, - format: l.Depth24Plus, - usage: a.RenderAttachment - }), - o = new me(1, { texture: s }); - this.canvasRenderTarget = new $e("render", [n], o); + }); + this.quadMesh = new Mesh(this.geometry, this.material); + } + setSize(width, height) { + this.canvasRenderTarget.setSize(width, height); + this.material.dirty = true; + } + render(context, colorTexture) { + if (!this.canvasRenderTarget) this.initRenderTarget(context); + // this.material + this.material.uniforms.texture.value = colorTexture; + this.material.update(undefined, this.quadMesh); + const drawComand = this.quadMesh.getDrawCommand(); + const currentRenderPassEncoder = this.canvasRenderTarget.beginRenderPass(context.device); + drawComand.render({ device: context.device, passEncoder: currentRenderPassEncoder }); + this.canvasRenderTarget.endRenderPass(); + } + initRenderTarget(context) { + const { width, height, depth } = context.presentationSize; + const colorAttachment = new Attachment( + { r: 0.0, g: 0.0, b: 0.0, a: 0 }, + { + textureView: () => { + return context.context.getCurrentTexture().createView(); + } + } + ); + const depthTexture = new Texture({ + label: "resolveDepth", + size: { width, height, depth }, + format: TextureFormat.Depth24Plus, + usage: TextureUsage.RenderAttachment + }); + const depthAttachment = new Attachment(1.0, { texture: depthTexture }); + this.canvasRenderTarget = new RenderTarget("render", [colorAttachment], depthAttachment); } } -class Lr { + +class PostEffectCollection { constructor() { - (this._postEffects = new Map()), (this.currentColorTexture = void 0), (this.resolveFrame = new _r()); + this._postEffects = new Map(); + this.currentColorTexture = undefined; + this.resolveFrame = new ResolveFrame(); } - add(e) { - this._postEffects.set(e.id, e); + add(postEffect) { + this._postEffects.set(postEffect.id, postEffect); } - remove(e) { - this._postEffects.delete(e.id), e.destroy(); + remove(postEffect) { + this._postEffects.delete(postEffect.id); + postEffect.destroy(); } - render(e, t) { - (this.currentColorTexture = t), - this._postEffects.forEach((t) => { - this.currentColorTexture = t.render(e, this.currentColorTexture); - }), - this.resolveFrame.render(e, this.currentColorTexture); + render(context, colorTexture) { + this.currentColorTexture = colorTexture; + this._postEffects.forEach((postEffect) => { + this.currentColorTexture = postEffect.render(context, this.currentColorTexture); + }); + this.resolveFrame.render(context, this.currentColorTexture); + } + setSize(width, height) { + this._postEffects.forEach((postEffect) => postEffect.setSize(width, height)); + this.resolveFrame.setSize(width, height); } - setSize(e, t) { - this._postEffects.forEach((i) => i.setSize(e, t)), this.resolveFrame.setSize(e, t); + postEffectsSort() { + // this._postEffects.sort() } - postEffectsSort() {} } -class Cr { - constructor(e) { - this.context = e; + +class Pass { + constructor(context) { + this.context = context; + } + update(frameState) { + // todo; } - update(e) {} - setSize(e, t) {} - beforeRender(e) { - (this.passRenderEncoder = this.renderTarget.beginRenderPass(this.context.device)), - this.computeTarget && - (this.passComputeEncoder = this.computeTarget.beginComputePassEncoder(this.context.device)); + setSize(width, height) { + // todo ; } - getColorTexture(e = 0) { - return this.renderTarget.getColorTexture(e); + beforeRender(options) { + this.passRenderEncoder = this.renderTarget.beginRenderPass(this.context.device); + if (this.computeTarget) + this.passComputeEncoder = this.computeTarget.beginComputePassEncoder(this.context.device); + } + getColorTexture(index = 0) { + return this.renderTarget.getColorTexture(index); } getDepthTexture() { return this.renderTarget.getDepthTexture(); } afterRender() { - this.renderTarget.endRenderPass(), this.computeTarget && this.computeTarget.endComputePassEncoder(); - } -} -class Rr extends Cr { - constructor(e) { - super(e), this.init(e); - } - beforeRender(e) { - this.updateRenderTarget(e), super.beforeRender(); - } - render(e, t) { - const { renderQueue: i, lightManger: r } = e; - i.sort(), - i.preRender(t, this.context, this.passRenderEncoder), - i.transparentRender(t, this.context, this.passRenderEncoder, void 0, void 0, r), - i.opaqueRender(t, this.context, this.passRenderEncoder, void 0, void 0, r), - i.debugQueueRender(t, this.context, this.passRenderEncoder); - } - init(e) { - this.createRenderTarget(e); - } - createRenderTarget(e) { - const { width: t, height: i, depth: r } = e.presentationSize, - n = new fe({ - label: "basicPassColor", - size: { width: t, height: i, depth: r }, - format: this.context.presentationFormat, - usage: a.RenderAttachment | a.TextureBinding - }), - s = new fe({ - label: "basicPassDepth", - size: { width: t, height: i, depth: r }, - format: l.Depth24Plus, - usage: a.RenderAttachment - }), - o = new me({ r: 0, g: 0, b: 0, a: 0 }, { texture: n }), - c = new me(1, { texture: s }); - this.renderTarget = new $e("render", [o], c); - } - setSize(e, t) { - this.renderTarget.setSize(e, t, 1); + this.renderTarget.endRenderPass(); + if (this.computeTarget) this.computeTarget.endComputePassEncoder(); } - updateRenderTarget(e) { - if (e?.background?.value instanceof Qt) { - const { red: t, green: i, blue: r } = e.background.value, - n = e.background?.opacity, - s = { r: t, g: i, b: r, a: n ?? 1 }; - this.renderTarget.colorAttachments[0].value = s; +} + +class BasicPass extends Pass { + constructor(context) { + super(context); + this.init(context); + } + beforeRender(frameState) { + this.updateRenderTarget(frameState); + super.beforeRender(); + } + render(frameState, camera) { + const { renderQueue, lightManger } = frameState; + renderQueue.sort(); + renderQueue.preRender(camera, this.context, this.passRenderEncoder); + renderQueue.transparentRender(camera, this.context, this.passRenderEncoder, undefined, undefined, lightManger); + renderQueue.opaqueRender(camera, this.context, this.passRenderEncoder, undefined, undefined, lightManger); + renderQueue.debugQueueRender(camera, this.context, this.passRenderEncoder); + } + init(context) { + this.createRenderTarget(context); + } + createRenderTarget(context) { + const { width, height, depth } = context.presentationSize; + const colorTexture = new Texture({ + label: "basicPassColor", + size: { width, height, depth }, + format: this.context.presentationFormat, + usage: TextureUsage.RenderAttachment | TextureUsage.TextureBinding + }); + const depthTexture = new Texture({ + label: "basicPassDepth", + size: { width, height, depth }, + format: TextureFormat.Depth24Plus, + usage: TextureUsage.RenderAttachment + }); + const colorAttachment = new Attachment({ r: 0.0, g: 0.0, b: 0.0, a: 0.0 }, { texture: colorTexture }); + const depthAttachment = new Attachment(1.0, { texture: depthTexture }); + this.renderTarget = new RenderTarget("render", [colorAttachment], depthAttachment); + } + setSize(width, height) { + this.renderTarget.setSize(width, height, 1); + } + updateRenderTarget(frameState) { + if (frameState?.background?.value instanceof Color) { + const { red, green, blue } = frameState.background.value; + const opacity = frameState.background?.opacity; + const clearValue = { + r: red, + g: green, + b: blue, + a: opacity ?? 1.0 + }; + this.renderTarget.colorAttachments[0].value = clearValue; } } } -class Ar { - constructor(e, t) { - (this.normal = Ue.clone(e)), (this.distance = t); + +/** + * A plane in Hessian Normal Form defined by + *
+ * ax + by + cz + d = 0
+ * 
+ * where (a, b, c) is the plane's normal, d is the signed + * distance to the plane, and (x, y, z) is any point on + * the plane. + * + * @alias Plane + * @constructor + * + * @param {Vector3} normal The plane's normal (normalized). + * @param {Number} distance The shortest distance from the origin to the plane. The sign of + * @example + * // The plane x=0 + * const plane = new Plane(Vector3.UNIT_X, 0.0); + * + * @exception {DeveloperError} Normal must be normalized + */ +class Plane { + constructor(normal, distance) { + this.normal = Vector3.clone(normal); + this.distance = distance; } normalize() { - const e = 1 / this.normal.length(); - return (this.normal = Ue.multiplyByScalar(this.normal, e, this.normal)), (this.distance *= e), this; - } - static fromPointNormal(e, t, i) { - if (!ve.equalsEpsilon(Ue.magnitude(t), 1, ve.EPSILON6)) throw new Error("normal must be normalized."); - const r = -Ue.dot(t, e); - return pe(i) ? (Ue.clone(t, i.normal), (i.distance = r), i) : new Ar(t, r); - } - static fromVector4(e, t) { - const i = Ue.fromVector4(e, Dr), - r = e.w; - if (!ve.equalsEpsilon(Ue.magnitude(i), 1, ve.EPSILON6)) throw new Error("normal must be normalized."); - return pe(t) ? (Ue.clone(i, t.normal), (t.distance = r), t) : new Ar(i, r); - } - static getPointDistance(e, t) { - return Ue.dot(e.normal, t) + e.distance; - } - static projectPointOntoPlane(e, t, i) { - pe(i) || (i = new Ue()); - const r = Ar.getPointDistance(e, t), - n = Ue.multiplyByScalar(e.normal, r, zr); - return Ue.subtract(t, n, i); - } - static transform(e, t, i) { - const r = e.normal, - n = e.distance, - s = et.inverseTranspose(t, Ir); - let a = We.fromElements(r.x, r.y, r.z, n, Pr); - a = et.multiplyByVector(s, a, a); - const o = Ue.fromVector4(a, Nr); - return (a = We.divideByScalar(a, Ue.magnitude(o), a)), Ar.fromVector4(a, i); - } - static clone(e, t) { - return pe(t) ? (Ue.clone(e.normal, t.normal), (t.distance = e.distance), t) : new Ar(e.normal, e.distance); - } - static equals(e, t) { - return e.distance === t.distance && Ue.equals(e.normal, t.normal); - } -} -(Ar.ORIGIN_XY_PLANE = Object.freeze(new Ar(Ue.UNIT_Z, 0))), - (Ar.ORIGIN_YZ_PLANE = Object.freeze(new Ar(Ue.UNIT_X, 0))), - (Ar.ORIGIN_ZX_PLANE = Object.freeze(new Ar(Ue.UNIT_Y, 0))); -const Dr = new Ue(), - zr = new Ue(), - Ir = new et(), - Pr = new We(), - Nr = new Ue(); -class Br { - constructor(e) { - this.planes = ee(e, [ - new Ar(Ue.UNIT_Z, 0), - new Ar(Ue.UNIT_Z, 0), - new Ar(Ue.UNIT_Z, 0), - new Ar(Ue.UNIT_Z, 0), - new Ar(Ue.UNIT_Z, 0), - new Ar(Ue.UNIT_Z, 0) + const inverseNormalLength = 1.0 / this.normal.length(); + this.normal = Vector3.multiplyByScalar(this.normal, inverseNormalLength, this.normal); + this.distance *= inverseNormalLength; + return this; + } + static fromPointNormal(point, normal, result) { + if (!GMath.equalsEpsilon(Vector3.magnitude(normal), 1.0, GMath.EPSILON6)) { + throw new Error("normal must be normalized."); + } + // >>includeEnd('debug'); + const distance = -Vector3.dot(normal, point); + if (!defined(result)) { + return new Plane(normal, distance); + } + Vector3.clone(normal, result.normal); + result.distance = distance; + return result; + } + static fromVector4(coefficients, result) { + const normal = Vector3.fromVector4(coefficients, scratchNormal); + const distance = coefficients.w; + // >>includeStart('debug', pragmas.debug); + if (!GMath.equalsEpsilon(Vector3.magnitude(normal), 1.0, GMath.EPSILON6)) { + throw new Error("normal must be normalized."); + } + // >>includeEnd('debug'); + if (!defined(result)) { + return new Plane(normal, distance); + } + Vector3.clone(normal, result.normal); + result.distance = distance; + return result; + } + static getPointDistance(plane, point) { + return Vector3.dot(plane.normal, point) + plane.distance; + } + static projectPointOntoPlane(plane, point, result) { + if (!defined(result)) { + result = new Vector3(); + } + // projectedPoint = point - (normal.point + scale) * normal + const pointDistance = Plane.getPointDistance(plane, point); + const scaledNormal = Vector3.multiplyByScalar(plane.normal, pointDistance, scratchCartesian); + return Vector3.subtract(point, scaledNormal, result); + } + static transform(plane, transform, result) { + const normal = plane.normal; + const distance = plane.distance; + const inverseTranspose = Matrix4.inverseTranspose(transform, scratchInverseTranspose); + let planeAsCartesian4 = Vector4.fromElements(normal.x, normal.y, normal.z, distance, scratchPlaneCartesian4); + planeAsCartesian4 = Matrix4.multiplyByVector(inverseTranspose, planeAsCartesian4, planeAsCartesian4); + // Convert the transformed plane to Hessian Normal Form + const transformedNormal = Vector3.fromVector4(planeAsCartesian4, scratchTransformNormal); + planeAsCartesian4 = Vector4.divideByScalar( + planeAsCartesian4, + Vector3.magnitude(transformedNormal), + planeAsCartesian4 + ); + return Plane.fromVector4(planeAsCartesian4, result); + } + static clone(plane, result) { + if (!defined(result)) { + return new Plane(plane.normal, plane.distance); + } + Vector3.clone(plane.normal, result.normal); + result.distance = plane.distance; + return result; + } + static equals(left, right) { + return left.distance === right.distance && Vector3.equals(left.normal, right.normal); + } +} +Plane.ORIGIN_XY_PLANE = Object.freeze(new Plane(Vector3.UNIT_Z, 0.0)); +Plane.ORIGIN_YZ_PLANE = Object.freeze(new Plane(Vector3.UNIT_X, 0.0)); +Plane.ORIGIN_ZX_PLANE = Object.freeze(new Plane(Vector3.UNIT_Y, 0.0)); +const scratchNormal = new Vector3(); +const scratchCartesian = new Vector3(); +const scratchInverseTranspose = new Matrix4(); +const scratchPlaneCartesian4 = new Vector4(); +const scratchTransformNormal = new Vector3(); + +/** + * The culling volume defined by planes. + * + * @alias CullingVolume + * @constructor + * + * @param {Vector4[]} [planes] An array of clipping planes. + */ +class CullingVolume { + constructor(planes) { + this.planes = defaultValue(planes, [ + new Plane(Vector3.UNIT_Z, 0.0), + new Plane(Vector3.UNIT_Z, 0.0), + new Plane(Vector3.UNIT_Z, 0.0), + new Plane(Vector3.UNIT_Z, 0.0), + new Plane(Vector3.UNIT_Z, 0.0), + new Plane(Vector3.UNIT_Z, 0.0) ]); } - static fromBoundingSphere(e, t) { - if (!pe(e)) throw new Error("boundingSphere is required."); - pe(t) || (t = new Br()); - const i = Or.length, - r = t.planes; - r.length = 2 * i; - const n = e.center, - s = e.radius; - let a = 0; - for (let e = 0; e < i; ++e) { - const t = Or[e]; - let i = r[a], - o = r[a + 1]; - pe(i) || (i = r[a] = new We()), - pe(o) || (o = r[a + 1] = new We()), - Ue.multiplyByScalar(t, -s, Vr), - Ue.add(n, Vr, Vr), - (i.x = t.x), - (i.y = t.y), - (i.z = t.z), - (i.w = -Ue.dot(t, Vr)), - Ue.multiplyByScalar(t, s, Vr), - Ue.add(n, Vr, Vr), - (o.x = -t.x), - (o.y = -t.y), - (o.z = -t.z), - (o.w = -Ue.dot(Ue.negate(t, Fr), Vr)), - (a += 2); - } - return t; - } - computeVisibility(e) { - if (!pe(e)) throw new Error("boundingVolume is required."); - const t = this.planes; - let i = !1; - for (let r = 0, n = t.length; r < n; ++r) { - const n = e.intersectPlane(t[r]); - if (n === F.OUTSIDE) return F.OUTSIDE; - n === F.INTERSECTING && (i = !0); - } - return i ? F.INTERSECTING : F.INSIDE; - } -} -(Br.MASK_OUTSIDE = 4294967295), (Br.MASK_INSIDE = 0), (Br.MASK_INDETERMINATE = 2147483647); -const Or = [new Ue(), new Ue(), new Ue()]; -Ue.clone(Ue.UNIT_X, Or[0]), Ue.clone(Ue.UNIT_Y, Or[1]), Ue.clone(Ue.UNIT_Z, Or[2]); -const Vr = new Ue(), - Fr = new Ue(); -new We(), new Ar(new Ue(1, 0, 0), 0); -class $r extends $t { + /** + * Constructs a culling volume from a bounding sphere. Creates six planes that create a box containing the sphere. + * The planes are aligned to the x, y, and z axes in world coordinates. + * + * @param {BoundingSphere} boundingSphere The bounding sphere used to create the culling volume. + * @param {CullingVolume} [result] The object onto which to store the result. + * @returns {CullingVolume} The culling volume created from the bounding sphere. + */ + static fromBoundingSphere(boundingSphere, result) { + if (!defined(boundingSphere)) { + throw new Error("boundingSphere is required."); + } + if (!defined(result)) { + result = new CullingVolume(); + } + const length = faces.length; + const planes = result.planes; + planes.length = 2 * length; + const center = boundingSphere.center; + const radius = boundingSphere.radius; + let planeIndex = 0; + for (let i = 0; i < length; ++i) { + const faceNormal = faces[i]; + let plane0 = planes[planeIndex]; + let plane1 = planes[planeIndex + 1]; + if (!defined(plane0)) { + plane0 = planes[planeIndex] = new Vector4(); + } + if (!defined(plane1)) { + plane1 = planes[planeIndex + 1] = new Vector4(); + } + Vector3.multiplyByScalar(faceNormal, -radius, scratchPlaneCenter); + Vector3.add(center, scratchPlaneCenter, scratchPlaneCenter); + plane0.x = faceNormal.x; + plane0.y = faceNormal.y; + plane0.z = faceNormal.z; + plane0.w = -Vector3.dot(faceNormal, scratchPlaneCenter); + Vector3.multiplyByScalar(faceNormal, radius, scratchPlaneCenter); + Vector3.add(center, scratchPlaneCenter, scratchPlaneCenter); + plane1.x = -faceNormal.x; + plane1.y = -faceNormal.y; + plane1.z = -faceNormal.z; + plane1.w = -Vector3.dot(Vector3.negate(faceNormal, scratchPlaneNormal), scratchPlaneCenter); + planeIndex += 2; + } + return result; + } + /** + * Determines whether a bounding volume intersects the culling volume. + * + * @param {Object} boundingVolume The bounding volume whose intersection with the culling volume is to be tested. + * @returns {Intersect} Intersect.OUTSIDE, Intersect.INTERSECTING, or Intersect.INSIDE. + */ + computeVisibility(boundingVolume) { + if (!defined(boundingVolume)) { + throw new Error("boundingVolume is required."); + } + const planes = this.planes; + let intersecting = false; + for (let k = 0, len = planes.length; k < len; ++k) { + const result = boundingVolume.intersectPlane(planes[k]); + if (result === Intersect.OUTSIDE) { + return Intersect.OUTSIDE; + } else if (result === Intersect.INTERSECTING) { + intersecting = true; + } + } + return intersecting ? Intersect.INTERSECTING : Intersect.INSIDE; + } +} +CullingVolume.MASK_OUTSIDE = 0xffffffff; +CullingVolume.MASK_INSIDE = 0x00000000; +CullingVolume.MASK_INDETERMINATE = 0x7fffffff; +const faces = [new Vector3(), new Vector3(), new Vector3()]; +Vector3.clone(Vector3.UNIT_X, faces[0]); +Vector3.clone(Vector3.UNIT_Y, faces[1]); +Vector3.clone(Vector3.UNIT_Z, faces[2]); +const scratchPlaneCenter = new Vector3(); +const scratchPlaneNormal = new Vector3(); +new Vector4(); +new Plane(new Vector3(1.0, 0.0, 0.0), 0.0); + +class Camera extends RenderObject { constructor() { - super(), - (this._viewMatrix = void 0), - (this.type = Z.Camera), - (this.cullingVolume = new Br()), - (this._viewMatrix = new et()), - (this._vpMatrix = new et()), - (this.projectMatrixDirty = !0), - this.createShaderData(); + super(); + this._viewMatrix = undefined; + this.type = RenderObjectType.Camera; + this.cullingVolume = new CullingVolume(); + this._viewMatrix = new Matrix4(); + this._vpMatrix = new Matrix4(); + this.projectMatrixDirty = true; + this.createShaderData(); } get viewMatrix() { - return this.updateMatrix(), et.inverse(this.modelMatrix, this._viewMatrix), this._viewMatrix; + this.updateMatrix(); + Matrix4.inverse(this.modelMatrix, this._viewMatrix); + return this._viewMatrix; } get projectionMatrix() { - return this.updateProjectionMatrix(), this._projectionMatrix; + this.updateProjectionMatrix(); + return this._projectionMatrix; } get vpMatrix() { - return et.multiply(this.projectionMatrix, this.viewMatrix, this._vpMatrix), this._vpMatrix; + Matrix4.multiply(this.projectionMatrix, this.viewMatrix, this._vpMatrix); + return this._vpMatrix; } get inverseViewMatrix() { - return this.updateMatrix(), this.modelMatrix; + this.updateMatrix(); + return this.modelMatrix; } updateProjectionMatrix() {} + /** + * get a culling volume for this frustum. + */ getCullingVolume() { - const e = this.viewMatrix.clone(new et()), - t = et.multiply(this.projectionMatrix, e, new et()), - i = this.cullingVolume.planes, - r = t, - n = r[0], - s = r[1], - a = r[2], - o = r[3], - c = r[4], - l = r[5], - h = r[6], - u = r[7], - f = r[8], - d = r[9], - m = r[10], - p = r[11], - g = r[12], - x = r[13], - v = r[14], - y = r[15]; - return ( - (i[0] = new Ar(new Ue(o - n, u - c, p - f), y - g)), - i[0].normalize(), - (i[1] = new Ar(new Ue(o + n, u + c, p + f), y + g)), - i[1].normalize(), - (i[2] = new Ar(new Ue(o + s, u + l, p + d), y + x)), - i[2].normalize(), - (i[3] = new Ar(new Ue(o - s, u - l, p - d), y - x)), - i[3].normalize(), - (i[4] = new Ar(new Ue(o - a, u - h, p - m), y - v)), - i[4].normalize(), - (i[5] = new Ar(new Ue(o + a, u + h, p + m), y + v)), - i[5].normalize(), - this.cullingVolume - ); + const cloneViewMatrix = this.viewMatrix.clone(new Matrix4()); + const vpMatrix = Matrix4.multiply(this.projectionMatrix, cloneViewMatrix, new Matrix4()); + const planes = this.cullingVolume.planes; + const me = vpMatrix; + const me0 = me[0], + me1 = me[1], + me2 = me[2], + me3 = me[3]; + const me4 = me[4], + me5 = me[5], + me6 = me[6], + me7 = me[7]; + const me8 = me[8], + me9 = me[9], + me10 = me[10], + me11 = me[11]; + const me12 = me[12], + me13 = me[13], + me14 = me[14], + me15 = me[15]; + planes[0] = new Plane(new Vector3(me3 - me0, me7 - me4, me11 - me8), me15 - me12); + planes[0].normalize(); + planes[1] = new Plane(new Vector3(me3 + me0, me7 + me4, me11 + me8), me15 + me12); + planes[1].normalize(); + planes[2] = new Plane(new Vector3(me3 + me1, me7 + me5, me11 + me9), me15 + me13); + planes[2].normalize(); + planes[3] = new Plane(new Vector3(me3 - me1, me7 - me5, me11 - me9), me15 - me13); + planes[3].normalize(); + planes[4] = new Plane(new Vector3(me3 - me2, me7 - me6, me11 - me10), me15 - me14); + planes[4].normalize(); + planes[5] = new Plane(new Vector3(me3 + me2, me7 + me6, me11 + me10), me15 + me14); + planes[5].normalize(); + return this.cullingVolume; } createShaderData() { - this.shaderData = new Yi("camera", 0, 1, 1); - const e = new Ri({ label: "camera" }); - e.setUniform("projectionMatrix", () => this.projectionMatrix, Q.Mat4), - e.setUniform("viewMatrix", () => this.viewMatrix, Q.Mat4), - e.setUniform("inverseViewMatrix", () => this.inverseViewMatrix, Q.Mat4), - e.setUniform("position", () => this.position, Q.FloatVec3), - this.shaderData.setUniformBuffer("camera", e); - } -} -class Gr extends $r { - constructor(e = 50, t = 1, i = 0.1, r = 2e3) { - super(), - (this._aspect = t), - (this.fov = e), - (this.near = i), - (this.far = r), - (this.xOffset = 0), - (this.yOffset = 0), - (this.projectMatrixDirty = !0), - this.updateCameraParms(), - (this.cullingVolume = new Br()), - (this.isPerspectiveCamera = !0); + this.shaderData = new ShaderData("camera", 0, 1, 1); + const uniformBuffer = new UniformBuffer({ label: "camera" }); + uniformBuffer.setUniform( + "projectionMatrix", + () => { + return this.projectionMatrix; + }, + UniformEnum.Mat4 + ); + uniformBuffer.setUniform( + "viewMatrix", + () => { + return this.viewMatrix; + }, + UniformEnum.Mat4 + ); + uniformBuffer.setUniform( + "inverseViewMatrix", + () => { + return this.inverseViewMatrix; + }, + UniformEnum.Mat4 + ); + uniformBuffer.setUniform( + "position", + () => { + return this.position; + }, + UniformEnum.FloatVec3 + ); + this.shaderData.setUniformBuffer("camera", uniformBuffer); + } +} + +class PerspectiveCamera extends Camera { + constructor(fov = 50, aspect = 1, near = 0.1, far = 2000) { + super(); + this._aspect = aspect; + this.fov = fov; + this.near = near; + this.far = far; + this.xOffset = 0; + this.yOffset = 0; + this.projectMatrixDirty = true; + this.updateCameraParms(); + this.cullingVolume = new CullingVolume(); + this.isPerspectiveCamera = true; } get aspect() { return this._aspect; } - set aspect(e) { - (this.projectMatrixDirty = !0), (this._aspect = e); + set aspect(v) { + this.projectMatrixDirty = true; + this._aspect = v; } get fov() { return this._fov; } - set fov(e) { - (this.projectMatrixDirty = !0), (this._fov = e); + set fov(v) { + this.projectMatrixDirty = true; + this._fov = v; } updateCameraParms() { - (this.top = this.near * Math.tan(0.5 * ve.RADIANS_PER_DEGREE * this.fov)), - (this.height = 2 * this.top), - (this.width = this.aspect * this.height), - (this.left = -0.5 * this.width); + this.top = this.near * Math.tan(0.5 * GMath.RADIANS_PER_DEGREE * this.fov); + this.height = 2 * this.top; + this.width = this.aspect * this.height; + this.left = -0.5 * this.width; } updateProjectionMatrix() { - this.projectMatrixDirty && - (this.updateCameraParms(), - (this._projectionMatrix = et.makePerspective( + if (this.projectMatrixDirty) { + this.updateCameraParms(); + this._projectionMatrix = Matrix4.makePerspective( this.left, this.left + this.width, this.top, this.top - this.height, this.near, this.far - )), - (this.projectMatrixDirty = !1)); + ); + this.projectMatrixDirty = false; + } } } -class kr extends Gr { - constructor(e = 50, t = 1, i = 0.1, r = 2e3) { - super(e, t, i, r), (this.vpMatrixArray = [new et(), new et(), new et(), new et(), new et(), new et()]); - } + +class PointLightShadowCamera extends PerspectiveCamera { + constructor(fov = 50, aspect = 1, near = 0.1, far = 2000) { + super(fov, aspect, near, far); + this.vpMatrixArray = [new Matrix4(), new Matrix4(), new Matrix4(), new Matrix4(), new Matrix4(), new Matrix4()]; + } + // createShaderData() { + // this.shaderData = new ShaderData("camera", 0, 1, 1); + // const uniformBuffer = new UniformBuffer({ + // label: "pointLightShadowCamera", + // type: "read-only-storage", + // usage: BufferUsage.Storage | BufferUsage.CopyDst, + // hasDynamicOffset: true, + // minBindingSize: 64, + // maxOffset: 6, + // size: 256 * 6 + // }); + // uniformBuffer.setMatrix4Array( + // "vpMatrixArray", + // () => { + // if (this.vpMatrixArray.length != 6) throw new Error("pointLightShadowCamera uniformBuffer has Error"); + // return this.vpMatrixArray; + // }, + // 6, + // 256 + // ); + // this.shaderData.setUniformBuffer("pointLightShadowCamera", uniformBuffer); + // this.shaderData.setDefine("isPointLightShadowMap", true); + // } createShaderData() { - this.shaderData = new Yi("camera", 0, 1, 1); - const e = new Ri({ label: "pointLightShadowCamera", type: "read-only-storage", usage: r.Storage | r.CopyDst }); - e.setUniform("vpMatrix", () => this.vpMatrix, Q.Mat4), - this.shaderData.setUniformBuffer("pointLightShadowCamera", e), - this.shaderData.setDefine("isPointLightShadowMap", !0); + this.shaderData = new ShaderData("camera", 0, 1, 1); + const uniformBuffer = new UniformBuffer({ + label: "pointLightShadowCamera", + type: "read-only-storage", + usage: BufferUsage.Storage | BufferUsage.CopyDst + }); + uniformBuffer.setUniform( + "vpMatrix", + () => { + return this.vpMatrix; + }, + UniformEnum.Mat4 + ); + this.shaderData.setUniformBuffer("pointLightShadowCamera", uniformBuffer); + this.shaderData.setDefine("isPointLightShadowMap", true); } - updateVpMatrixArrayAndIndex(e) { - et.clone(this.vpMatrix, this.vpMatrixArray[e]); + updateVpMatrixArrayAndIndex(index) { + Matrix4.clone(this.vpMatrix, this.vpMatrixArray[index]); } } -class qr { - constructor(e, t) { - (this._shadowMapSize = e), - (this._camera = t), - (this.viewPortDirty = !0), - (this.vpMatrixDirty = !0), - this._init(); + +class BaseShadow { + constructor(shadowMapSize, camera) { + this._shadowMapSize = shadowMapSize; + this._camera = camera; + this.viewPortDirty = true; + this.vpMatrixDirty = true; + this._init(); } get camera() { return this._camera; @@ -10636,648 +14191,982 @@ class qr { this._createShadowMapTexture(); } _createShadowMapTexture() { - this._shadowMap = new fe({ - size: { width: this._shadowMapSize.x, height: this._shadowMapSize.y, depth: 1 }, - fixedSize: !0, - sampleType: g.Depth, - format: l.Depth24Plus, - usage: a.RenderAttachment | a.TextureBinding | a.CopySrc + this._shadowMap = new Texture({ + size: { + width: this._shadowMapSize.x, + height: this._shadowMapSize.y, + depth: 1 + }, + fixedSize: true, + sampleType: TextureSampleType.Depth, + format: TextureFormat.Depth24Plus, + usage: TextureUsage.RenderAttachment | TextureUsage.TextureBinding | TextureUsage.CopySrc }); } - update(e) {} + update(light) {} } -class jr extends qr { + +class PointLightShadow extends BaseShadow { get camera() { return this._camera; } constructor() { - const e = new kr(90, 1, 0.1, 500); - super(new Se(1536, 1024), e), - (this.viewportSize = new Se(512, 512)), - (this.currentViewportIndex = 0), - (this.type = "pointLightShadow"), - (this.vpMatrixArrayDirty = !0), - (this._viewports = [ - new We(0, 0, 1 / 3, 0.5), - new We(1, 0, 1 / 3, 0.5), - new We(2, 0, 1 / 3, 0.5), - new We(0, 1, 1 / 3, 0.5), - new We(1, 1, 1 / 3, 0.5), - new We(2, 1, 1 / 3, 0.5) - ]), - (this._pointLightShadowLookDirections = [ - new Ue(1, 0, 0), - new Ue(-1, 0, 0), - new Ue(0, 0, 1), - new Ue(0, 0, -1), - new Ue(0, 1, 0), - new Ue(0, -1, 0) - ]), - (this._pointLightShadowUps = [ - new Ue(0, 1, 0), - new Ue(0, 1, 0), - new Ue(0, 1, 0), - new Ue(0, 1, 0), - new Ue(0, 0, 1), - new Ue(0, 0, -1) - ]); - } - update(e) { - this.updateMatrices(e); - } - updateMatrices(e) { - if (this.camera instanceof kr) { - this.camera.position.copy(e.position); - const t = Ue.clone(e.position); - t.add(this._pointLightShadowLookDirections[this.currentViewportIndex]), - this.camera.up.copy(this._pointLightShadowUps[this.currentViewportIndex]); - const { x: i, y: r, z: n } = t; - this.camera.lookAt(i, r, n), - this.camera.updateMatrix(), - this.camera.updateVpMatrixArrayAndIndex(this.currentViewportIndex), - 5 == this.currentViewportIndex && (this.vpMatrixArrayDirty = !0); - } - } -} -class Hr extends Ht { + const camera = new PointLightShadowCamera(90, 1, 0.1, 500); + super(new Vector2(1536, 1024), camera); + this.viewportSize = new Vector2(512, 512); + this.currentViewportIndex = 0; + this.type = "pointLightShadow"; + this.vpMatrixArrayDirty = true; + this._viewports = [ + // positive X 0 + new Vector4(0, 0, 1 / 3, 1 / 2), + // negative X 1 + new Vector4(1, 0, 1 / 3, 1 / 2), + // positive Z 2 + new Vector4(2, 0, 1 / 3, 1 / 2), + // negative Z 3 + new Vector4(0, 1, 1 / 3, 1 / 2), + // positive Y 4 + new Vector4(1, 1, 1 / 3, 1 / 2), + // negative Y 5 + new Vector4(2, 1, 1 / 3, 1 / 2) + ]; + this._pointLightShadowLookDirections = [ + new Vector3(1, 0, 0), + new Vector3(-1, 0, 0), + new Vector3(0, 0, 1), + new Vector3(0, 0, -1), + new Vector3(0, 1, 0), + new Vector3(0, -1, 0) + ]; + this._pointLightShadowUps = [ + new Vector3(0, 1, 0), + new Vector3(0, 1, 0), + new Vector3(0, 1, 0), + new Vector3(0, 1, 0), + new Vector3(0, 0, 1), + new Vector3(0, 0, -1) + ]; + } + update(light) { + this.updateMatrices(light); + } + updateMatrices(light) { + if (this.camera instanceof PointLightShadowCamera) { + this.camera.position.copy(light.position); + const target = Vector3.clone(light.position); + target.add(this._pointLightShadowLookDirections[this.currentViewportIndex]); + this.camera.up.copy(this._pointLightShadowUps[this.currentViewportIndex]); + const { x, y, z } = target; + this.camera.lookAt(x, y, z); + this.camera.updateMatrix(); + this.camera.updateVpMatrixArrayAndIndex(this.currentViewportIndex); + if (this.currentViewportIndex == 5) this.vpMatrixArrayDirty = true; + } + } +} + +class PointLight extends Light { get shadow() { return this._shadow; } - set shadow(e) { - (this.shadowDirty = !0), (this._shadow = e); + set shadow(value) { + this.shadowDirty = true; + this._shadow = value; } - constructor(e, t, i = 0, r = 4, n = !0) { - super(e, t), - (this._distance = i), - (this._decay = r), - (this.distanceDirty = !0), - (this.decayDirty = !0), - (this.lightType = K.PointLight), - n && (this.shadow = new jr()); + constructor(color, intensity, distance = 0, decay = 4, openShadow = true) { + super(color, intensity); + this._distance = distance; + this._decay = decay; + this.distanceDirty = true; + this.decayDirty = true; + this.lightType = LightType.PointLight; + if (openShadow) this.shadow = new PointLightShadow(); } - set distance(e) { - (this.distanceDirty = !0), (this._distance = e); + set distance(value) { + this.distanceDirty = true; + this._distance = value; } get distance() { return this._distance; } - set decay(e) { - (this.decayDirty = !0), (this._decay = e); + set decay(value) { + this.decayDirty = true; + this._decay = value; } get decay() { return this._decay; } } -class Xr extends Cr { - constructor(e) { - super(e), this.init(e); - } - render(e, t) { - const { renderQueue: i, context: r, lightManger: n } = e, - s = n.getAllLights(); - if (0 !== s.length) { - for (let e = 0; e < s.length; e++) { - const t = s[e], - a = t.shadow; - if (a) - if (a instanceof jr && t instanceof Hr) - for (let e = 0; e < a.viewports.length; e++) { - if (0 === e) this.renderTarget.depthAttachment.op = "clear"; - else this.renderTarget.depthAttachment.op = "load"; - this.beforeRender({ shadow: a }); - const s = a.viewports[e], - o = a.viewportSize; - (a.currentViewportIndex = e), - a.update(t), - r.setViewPort(s.x * o.x, s.y * o.y, o.x, o.y), - r.setScissorTest(s.x * o.x, s.y * o.y, o.x, o.y), - this.subRender(i, a, n), - super.afterRender(); - } - else - (this.renderTarget.depthAttachment.op = "clear"), - this.beforeRender({ shadow: a }), - a.update(t), - r.setViewPort(0, 0, a.shadowMapSize.x, a.shadowMapSize.y), - r.setScissorTest(0, 0, a.shadowMapSize.x, a.shadowMapSize.y), - this.subRender(i, a, n), - super.afterRender(); +// uniform +// color: {}, +// position: {}, +// decay: {}, +// distance: {} + +class ShadowPass extends Pass { + constructor(context) { + super(context); + this.init(context); + } + render(frameState, camera) { + const { renderQueue, context, lightManger } = frameState; + const lights = lightManger.getAllLights(); + if (lights.length === 0) return; + for (let i = 0; i < lights.length; i++) { + const light = lights[i]; + const shadow = light.shadow; + if (!shadow) continue; + // this._testTexture = context.lightManger._testTexture + // this.beforeRender({ shadow }); + if (shadow instanceof PointLightShadow && light instanceof PointLight) { + for (let i = 0; i < shadow.viewports.length; i++) { + // 动态buffer暂未调通,先以此种方式解决 + switch (i) { + case 0: + this.renderTarget.depthAttachment.op = "clear"; + break; + default: + this.renderTarget.depthAttachment.op = "load"; + break; + } + this.beforeRender({ shadow }); + const viewport = shadow.viewports[i]; + const viewportSize = shadow.viewportSize; + shadow.currentViewportIndex = i; + shadow.update(light); + // light.forceUpdate = true; + context.setViewPort( + viewport.x * viewportSize.x, + viewport.y * viewportSize.y, + viewportSize.x, + viewportSize.y + ); + context.setScissorTest( + viewport.x * viewportSize.x, + viewport.y * viewportSize.y, + viewportSize.x, + viewportSize.y + ); + this.subRender(renderQueue, shadow, lightManger); + super.afterRender(); + } + } else { + this.renderTarget.depthAttachment.op = "clear"; + this.beforeRender({ shadow }); + shadow.update(light); + context.setViewPort(0, 0, shadow.shadowMapSize.x, shadow.shadowMapSize.y); + context.setScissorTest(0, 0, shadow.shadowMapSize.x, shadow.shadowMapSize.y); + this.subRender(renderQueue, shadow, lightManger); + super.afterRender(); } - n.updateLightShadow(), r.resetViewPortToFullCanvas(); } + // super.afterRender(); + lightManger.updateLightShadow(); + context.resetViewPortToFullCanvas(); + } + subRender(renderQueue, shadow, lightManger) { + renderQueue.sort(); + // renderQueue.preRender(shadow.camera, this.context, this.passRenderEncoder); + renderQueue.transparentRender( + shadow.camera, + this.context, + this.passRenderEncoder, + this.shadowMaterial, + CommandSubType.Shadow, + lightManger + ); + renderQueue.opaqueRender( + shadow.camera, + this.context, + this.passRenderEncoder, + this.shadowMaterial, + CommandSubType.Shadow, + lightManger + ); } - subRender(e, t, i) { - e.sort(), - e.transparentRender(t.camera, this.context, this.passRenderEncoder, this.shadowMaterial, V.Shadow, i), - e.opaqueRender(t.camera, this.context, this.passRenderEncoder, this.shadowMaterial, V.Shadow, i); - } - beforeRender(e) { - const { shadow: t } = e; - this.setRenderTarget(t), super.beforeRender(); + // getDepthTexture(): Texture { + // return this._testTexture; + // } + beforeRender(options) { + const { shadow } = options; + this.setRenderTarget(shadow); + super.beforeRender(); } - setSize(e, t) { - this.renderTarget.setSize(e, t, 1); + setSize(width, height) { + this.renderTarget.setSize(width, height, 1); } - setRenderTarget(e) { - this.renderTarget.depthAttachment.texture = e.getShadowMapTexture(); + setRenderTarget(shadow) { + this.renderTarget.depthAttachment.texture = shadow.getShadowMapTexture(); } - init(e) { - this.createRenderTarget(e), this.createShadowMaterial(); + init(context) { + this.createRenderTarget(context); + this.createShadowMaterial(); } - createRenderTarget(e) { - const t = new me(1, { texture: void 0 }); - this.renderTarget = new $e("render", [], t); + createRenderTarget(context) { + const depthAttachment = new Attachment(1.0, { texture: undefined }); + this.renderTarget = new RenderTarget("render", [], depthAttachment); } createShadowMaterial() { - this.shadowMaterial = new Zi({ + const shadowMapShaderFunction = (defines = {}) => { + const finalDefines = Object.assign( + { + selfBinding: 0, + cameraBinding: 0, + positionLocation: 0 + }, + defines + ); + return getVertFrag("shadowMap", finalDefines).vert; + }; + this.shadowMaterial = new ShaderMaterial({ type: "shadowMaterial", - uniforms: { modelMatrix: { type: "mat4x4", value: null } }, - vert: (e = {}) => - $i("shadowMap", Object.assign({ selfBinding: 0, cameraBinding: 0, positionLocation: 0 }, e)).vert, - frag: void 0, - light: !1 + uniforms: { + modelMatrix: { type: "mat4x4", value: null } + }, + vert: shadowMapShaderFunction, + frag: undefined, + light: false // TODO:先true,false有显示bug }); } } -class Yr { - constructor(e) { - (this.context = e), (this.basicPass = new Rr(e)), (this.shadowPass = new Xr(e)); + +class ForwardRenderLine { + constructor(context) { + this.context = context; + this.basicPass = new BasicPass(context); + this.shadowPass = new ShadowPass(context); } getOutputTexture() { return this.basicPass.getColorTexture(0); + // return this.shadowPass.getDepthTexture() } - render(e, t) { - this.shadowPass.render(e, t), - this.basicPass.beforeRender(e), - this.basicPass.render(e, t), - this.basicPass.afterRender(); + render(frameState, camera) { + this.shadowPass.render(frameState, camera); + this.basicPass.beforeRender(frameState); + this.basicPass.render(frameState, camera); + this.basicPass.afterRender(); } - setSize(e, t) { - this.basicPass.setSize(e, t), this.shadowPass.setSize(e, t); + setSize(width, height) { + this.basicPass.setSize(width, height); + this.shadowPass.setSize(width, height); } destroy() { - this.basicPass = void 0; - } -} -class Wr extends br { - constructor(e) { - super(), - (this.container = - e.container instanceof HTMLDivElement ? e.container : document.getElementById(e.container)), - (this.meshManger = new Ur()), - (this.postEffectCollection = new Lr()), - (this.context = new ue({ canvas: null, container: this.container, pixelRatio: 1 })), - (this.requestAdapter = e.requestAdapter || {}), - (this.deviceDescriptor = e.deviceDescriptor || {}), - (this.presentationContextDescriptor = e.presentationContextDescriptor), - (this.ready = !1), - (this.inited = !1), - (this.lightManger = new Mr({ openShadow: !0 })), - (this.background = e.background); + this.basicPass = undefined; + } +} + +class Scene extends EventDispatcher { + constructor(options) { + super(); + this.container = + options.container instanceof HTMLDivElement + ? options.container + : document.getElementById(options.container); + this.meshManger = new MeshManger(); + this.postEffectCollection = new PostEffectCollection(); + this.context = new Context({ + canvas: null, + container: this.container, + pixelRatio: 1 + }); + this.requestAdapter = options.requestAdapter || {}; + this.deviceDescriptor = options.deviceDescriptor || {}; + this.presentationContextDescriptor = options.presentationContextDescriptor; + this.ready = false; + this.inited = false; + this.lightManger = new LightManger({ openShadow: true }); + this.background = options.background; } async init() { - await this.context.init(this.requestAdapter, this.deviceDescriptor, this.presentationContextDescriptor), - (this.currentRenderPipeline = new Yr(this.context)), - (this.frameState = new Tr(this.context, this.lightManger, Tr.getFrameStateOptionsByScene(this))), - (this.viewport = new se(0, 0, this.context.presentationSize.width, this.context.presentationSize.height)), - (this.ready = !0); - } - add(e) { - [Z.Node, Z.Skybox, Z.Mesh, Z.Debug].includes(e.type) - ? this.meshManger.add(e) - : e.type == Z.Light - ? this.lightManger.add(e) - : e.type == Z.PostEffect && this.postEffectCollection.add(e); - } - remove(e) { - [Z.Node, Z.Skybox, Z.Mesh].includes(e.type) - ? this.meshManger.remove(e) - : e.type == Z.Light - ? this.lightManger.remove(e) - : e.type == Z.PostEffect && this.postEffectCollection.remove(e); - } - setCamera(e) { - this.camera = e; - } - resize(e, t) { - this.context.resize(e, t), - this?.currentRenderPipeline?.setSize(e, t), - this?.postEffectCollection?.setSize(e, t); - } - async render(e, t) { - this.inited - ? (this.update(e, t), this.afterRender()) - : ((this.inited = !0), await this.init(), this.update(e, t), this.afterRender()); - } - afterRender() {} - setViewPort(e, t, i, r) { - return !!this.ready && (this.context.setViewPort(e, t, i, r), !0); - } - setScissorTest(e, t, i, r) { - return !!this.ready && (this.context.setScissorTest(e, t, i, r), !0); - } - update(e, t) { - this.ready && - (nr.releasedTextures(), - this.frameState.update(t ?? this.camera, Tr.getFrameStateOptionsByScene(this)), - (e ?? this.meshManger).update(this.frameState, t ?? this.camera), - this.currentRenderPipeline.render(this.frameState, t ?? this.camera), - this.postEffectCollection.render(this.context, this.currentRenderPipeline.getOutputTexture())); - } -} -class Zr { - constructor(e, t, i) { - (this.width = e), - (this.height = t), - this.initDefaultParms(), - (this.id = i), - (this.priority = 0), - (this.isPostEffect = !0), - (this.type = Z.PostEffect); - } - render(e, t) { + await this.context.init(this.requestAdapter, this.deviceDescriptor, this.presentationContextDescriptor); + this.currentRenderPipeline = new ForwardRenderLine(this.context); + this.frameState = new FrameState(this.context, this.lightManger, FrameState.getFrameStateOptionsByScene(this)); + this.viewport = new ViewPort(0, 0, this.context.presentationSize.width, this.context.presentationSize.height); + this.ready = true; + } + add(instance) { + if ( + [RenderObjectType.Node, RenderObjectType.Skybox, RenderObjectType.Mesh, RenderObjectType.Debug].includes( + instance.type + ) + ) { + this.meshManger.add(instance); + } else if (instance.type == RenderObjectType.Light) { + this.lightManger.add(instance); + } else if (instance.type == RenderObjectType.PostEffect) { + this.postEffectCollection.add(instance); + } + } + remove(instance) { + if ([RenderObjectType.Node, RenderObjectType.Skybox, RenderObjectType.Mesh].includes(instance.type)) { + this.meshManger.remove(instance); + } else if (instance.type == RenderObjectType.Light) { + this.lightManger.remove(instance); + } else if (instance.type == RenderObjectType.PostEffect) { + this.postEffectCollection.remove(instance); + } + } + setCamera(camera) { + this.camera = camera; + } + resize(width, height) { + this.context.resize(width, height); + this?.currentRenderPipeline?.setSize(width, height); + this?.postEffectCollection?.setSize(width, height); + } + async render(node, camera) { + if (!this.inited) { + this.inited = true; + await this.init(); + this.update(node, camera); + this.afterRender(); + } else { + this.update(node, camera); + this.afterRender(); + } + } + afterRender() { + // TODO + } + setViewPort(x, y, width, height) { + if (!this.ready) return false; + this.context.setViewPort(x, y, width, height); + return true; + } + setScissorTest(x, y, width, height) { + if (!this.ready) return false; + this.context.setScissorTest(x, y, width, height); + return true; + } + update(node, camera) { + if (!this.ready) return; + // 释放纹理 + textureCache.releasedTextures(); + // 更新FrameState + this.frameState.update(camera ?? this.camera, FrameState.getFrameStateOptionsByScene(this)); + // update primitive and select + (node ?? this.meshManger).update(this.frameState, camera ?? this.camera); + // selct renderPipeline + this.currentRenderPipeline.render(this.frameState, camera ?? this.camera); + // 后处理 + this.postEffectCollection.render(this.context, this.currentRenderPipeline.getOutputTexture()); + } +} + +class PostEffect { + constructor(width, height, id) { + this.width = width; + this.height = height; + this.initDefaultParms(); + this.id = id; + this.priority = 0; + this.isPostEffect = true; + this.type = RenderObjectType.PostEffect; + } + render(context, colorTexture) { return null; } - setSize(e, t) {} + setSize(width, height) { + // todo ; + } destroy() { this?.currentRenderTarget?.destroy(); } - renderMesh(e) { - (this.fullScreenQuad.material.dirty = !0), this.fullScreenQuad.material.update(); - const t = this.fullScreenQuad.getDrawCommand(), - i = this.currentRenderTarget.beginRenderPass(e.device); - t.render({ device: e.device, passEncoder: i }), this.currentRenderTarget.endRenderPass(); + renderMesh(context) { + this.fullScreenQuad.material.dirty = true; + this.fullScreenQuad.material.update(); + const drawComand = this.fullScreenQuad.getDrawCommand(); + const currentRenderPassEncoder = this.currentRenderTarget.beginRenderPass(context.device); + drawComand.render({ device: context.device, passEncoder: currentRenderPassEncoder }); + this.currentRenderTarget.endRenderPass(); } initDefaultParms() { - const e = new At({}); - e.setAttribute(new Ie("position", [-1, 1, -1, -1, 1, -1, 1, -1, 1, 1, -1, 1], 2)), (e.count = 6); - const t = new ae(), - i = new ce(), - r = new te(); - (r.primitive = t), - (r.targets = [i]), - (this.renderState = r), - (this.fullScreenQuad = new Qi(e)), - (this.defaultSampler = new de()); - } -} -class Kr extends Zr { - constructor(e) { - super(e.width, e.height, "bloom"), - (this.strength = e.strength), - (this.radius = e.radius), - (this.threshold = e.threshold), - this.init(); + const geometry = new Geometry({}); + geometry.setAttribute( + new Float32Attribute("position", [-1.0, 1.0, -1.0, -1.0, 1.0, -1.0, 1.0, -1.0, 1.0, 1.0, -1.0, 1.0], 2) + ); + geometry.count = 6; + // rs + const primitive = new Primitive(); + const target = new Target(); + // target.format=TextureFormat.RGBA8Unorm + const renderState = new RenderState(); + renderState.primitive = primitive; + renderState.targets = [target]; + this.renderState = renderState; + this.fullScreenQuad = new Mesh(geometry); + this.defaultSampler = new Sampler(); + } +} + +class BloomPostEffect extends PostEffect { + constructor(options) { + super(options.width, options.height, "bloom"); + this.strength = options.strength; + this.radius = options.radius; + this.threshold = options.threshold; + this.init(); } destroy() { this.renderTargetBright.destroy(); } - render(e, t) { - (this.currentRenderTarget = this.renderTargetBright), - (this.highPassUniforms.tDiffuse.value = t), - (this.fullScreenQuad.material = this.materialHighPassFilter), - this.renderMesh(e); - let i = this.renderTargetBright; - for (let t = 0; t < this.nMips; t++) - (this.fullScreenQuad.material = this.separableBlurMaterials[t]), - (this.separableBlurMaterials[t].uniforms.tDiffuse.value = i.getColorTexture()), - (this.separableBlurMaterials[t].uniforms.direction.value = Kr.BlurDirectionX), - (this.currentRenderTarget = this.renderTargetsHorizontal[t]), - this.renderMesh(e), - (this.fullScreenQuad.material = this.separableBlurYMaterials[t]), - (this.separableBlurYMaterials[t].uniforms.tDiffuse.value = - this.renderTargetsHorizontal[t].getColorTexture()), - (this.separableBlurYMaterials[t].uniforms.direction.value = Kr.BlurDirectionY), - (this.currentRenderTarget = this.renderTargetsVertical[t]), - this.renderMesh(e), - (i = this.renderTargetsVertical[t]); - return ( - (this.fullScreenQuad.material = this.compositeMaterial), - (this.currentRenderTarget = this.renderTargetsHorizontal[0]), - this.renderMesh(e), - (this.blendUniforms.baseColorTexture.value = t), - (this.fullScreenQuad.material = this.blendMaterial), - (this.currentRenderTarget = this.blendTarget), - this.renderMesh(e), - this.currentRenderTarget.getColorTexture() - ); - } - setSize(e, t) { - this?.renderTargetsHorizontal?.forEach((i) => i.setSize(e, t, 1)), - this?.renderTargetsVertical?.forEach((i) => i.setSize(e, t, 1)), - this?.renderTargetBright?.setSize?.(e, t, 1), - this?.blendTarget?.setSize?.(e, t, 1); + render(context, colorTexture) { + // 1. Extract Bright Areas + this.currentRenderTarget = this.renderTargetBright; + this.highPassUniforms.tDiffuse.value = colorTexture; + this.fullScreenQuad.material = this.materialHighPassFilter; + this.renderMesh(context); + // 2. Blur All the mips progressively + let inputRenderTarget = this.renderTargetBright; + for (let i = 0; i < this.nMips; i++) { + this.fullScreenQuad.material = this.separableBlurMaterials[i]; + this.separableBlurMaterials[i].uniforms.tDiffuse.value = inputRenderTarget.getColorTexture(); + this.separableBlurMaterials[i].uniforms.direction.value = BloomPostEffect.BlurDirectionX; + this.currentRenderTarget = this.renderTargetsHorizontal[i]; + this.renderMesh(context); + this.fullScreenQuad.material = this.separableBlurYMaterials[i]; + this.separableBlurYMaterials[i].uniforms.tDiffuse.value = this.renderTargetsHorizontal[i].getColorTexture(); + this.separableBlurYMaterials[i].uniforms.direction.value = BloomPostEffect.BlurDirectionY; + this.currentRenderTarget = this.renderTargetsVertical[i]; + this.renderMesh(context); + inputRenderTarget = this.renderTargetsVertical[i]; + } + // Composite All the mips + this.fullScreenQuad.material = this.compositeMaterial; + this.currentRenderTarget = this.renderTargetsHorizontal[0]; + this.renderMesh(context); + // blend + this.blendUniforms.baseColorTexture.value = colorTexture; + this.fullScreenQuad.material = this.blendMaterial; + this.currentRenderTarget = this.blendTarget; + this.renderMesh(context); + return this.currentRenderTarget.getColorTexture(); + } + setSize(width, height) { + this?.renderTargetsHorizontal?.forEach((renderTarget) => renderTarget.setSize(width, height, 1)); + this?.renderTargetsVertical?.forEach((renderTarget) => renderTarget.setSize(width, height, 1)); + this?.renderTargetBright?.setSize?.(width, height, 1); + this?.blendTarget?.setSize?.(width, height, 1); } init() { - (this.renderTargetsHorizontal = []), (this.renderTargetsVertical = []), (this.nMips = 5); - let e = Math.round(this.width / 2), - t = Math.round(this.height / 2); - this.renderTargetBright = new $e("render", [this.createColorAttachment(e, t)]); + this.renderTargetsHorizontal = []; + this.renderTargetsVertical = []; + this.nMips = 5; + let resx = Math.round(this.width / 2); + let resy = Math.round(this.height / 2); + this.renderTargetBright = new RenderTarget("render", [this.createColorAttachment(resx, resy)]); for (let i = 0; i < this.nMips; i++) { - const i = new $e("render", [this.createColorAttachment(e, t)]); - this.renderTargetsHorizontal.push(i); - const r = new $e("render", [this.createColorAttachment(e, t)]); - this.renderTargetsVertical.push(r), (e = Math.round(e / 2)), (t = Math.round(t / 2)); + const renderTargetHorizonal = new RenderTarget("render", [this.createColorAttachment(resx, resy)]); + this.renderTargetsHorizontal.push(renderTargetHorizonal); + const renderTargetVertical = new RenderTarget("render", [this.createColorAttachment(resx, resy)]); + this.renderTargetsVertical.push(renderTargetVertical); + resx = Math.round(resx / 2); + resy = Math.round(resy / 2); } + // luminosity high pass material this.highPassUniforms = { tDiffuse: { type: "texture", value: null }, - tSampler: { type: "sampler", value: this.defaultSampler }, + tSampler: { + type: "sampler", + value: this.defaultSampler + }, luminosityThreshol: { type: "float", value: this.threshold }, smoothWidth: { type: "float", value: 0.01 }, - defaultColor: { type: "color", value: new Qt(0, 0, 0) }, - defaultOpacity: { type: "float", value: 1 } + defaultColor: { type: "color", value: new Color(0.0, 0, 0) }, + defaultOpacity: { type: "float", value: 1.0 } }; - const i = $i("luminosityHigh", { positionLocation: 0 }); - (this.materialHighPassFilter = new Zi({ + const shader = getVertFrag("luminosityHigh", { positionLocation: 0 }); + this.materialHighPassFilter = new ShaderMaterial({ type: "bloom", uniforms: this.highPassUniforms, - vert: i.vert, - frag: i.frag - })), - (this.materialHighPassFilter.renderState = this.renderState), - (this.separableBlurMaterials = []), - (this.separableBlurYMaterials = []); - const r = [3, 5, 7, 9, 11]; - (e = Math.round(this.width / 2)), (t = Math.round(this.height / 2)); - for (let i = 0; i < this.nMips; i++) - this.separableBlurMaterials.push(this.getSeperableBlurMaterial(r[i], "BlurMaterial" + i)), - this.separableBlurYMaterials.push(this.getSeperableBlurMaterial(r[i], "BlurMaterialY" + i)), - (e = Math.round(e / 2)), - (t = Math.round(t / 2)); - (this.compositeMaterial = this.getCompositeMaterial(this.nMips, "compositeMaterial")), - (this.compositeMaterial.renderState = this.renderState), - (this.blendUniforms = { - tDiffuse: { type: "texture", value: this.renderTargetsHorizontal[0].getColorTexture() }, - baseColorTexture: { type: "texture", value: null }, - tSampler: { type: "sampler", value: this.defaultSampler } - }); - const n = $i("blend", { positionLocation: 0 }); - (this.blendMaterial = new Zi({ type: "postBlend", uniforms: this.blendUniforms, vert: n.vert, frag: n.frag })), - (this.blendMaterial.renderState = this.renderState), - (this.blendTarget = new $e("render", [this.createColorAttachment(this.width, this.height)])); - } - createColorAttachment(e, t) { - const i = new fe({ - size: { width: e, height: t, depth: 1 }, - format: l.BGRA8Unorm, - usage: a.RenderAttachment | a.TextureBinding + vert: shader.vert, + frag: shader.frag + }); + // Gaussian Blur Materials + this.materialHighPassFilter.renderState = this.renderState; + this.separableBlurMaterials = []; + this.separableBlurYMaterials = []; + const kernelSizeArray = [3, 5, 7, 9, 11]; + resx = Math.round(this.width / 2); + resy = Math.round(this.height / 2); + for (let i = 0; i < this.nMips; i++) { + this.separableBlurMaterials.push(this.getSeperableBlurMaterial(kernelSizeArray[i], "BlurMaterial" + i)); + this.separableBlurYMaterials.push(this.getSeperableBlurMaterial(kernelSizeArray[i], "BlurMaterialY" + i)); + resx = Math.round(resx / 2); + resy = Math.round(resy / 2); + } + // Composite material + this.compositeMaterial = this.getCompositeMaterial(this.nMips, "compositeMaterial"); + this.compositeMaterial.renderState = this.renderState; + this.blendUniforms = { + tDiffuse: { type: "texture", value: this.renderTargetsHorizontal[0].getColorTexture() }, + baseColorTexture: { type: "texture", value: null }, + tSampler: { + type: "sampler", + value: this.defaultSampler + } + }; + const blendShader = getVertFrag("blend", { positionLocation: 0 }); + this.blendMaterial = new ShaderMaterial({ + type: "postBlend", + uniforms: this.blendUniforms, + vert: blendShader.vert, + frag: blendShader.frag }); - return new me({ r: 0, g: 0, b: 0, a: 0 }, { texture: i }); + this.blendMaterial.renderState = this.renderState; + this.blendTarget = new RenderTarget("render", [this.createColorAttachment(this.width, this.height)]); + } + createColorAttachment(width, height) { + const colorTexture = new Texture({ + size: { width, height, depth: 1 }, + format: TextureFormat.BGRA8Unorm, + usage: TextureUsage.RenderAttachment | TextureUsage.TextureBinding + }); + const colorAttachment = new Attachment({ r: 0.0, g: 0.0, b: 0.0, a: 0.0 }, { texture: colorTexture }); + return colorAttachment; } - getCompositeMaterial(e, t) { - return new Zi({ - type: t, + getCompositeMaterial(nMips, type) { + return new ShaderMaterial({ + type, uniforms: { blurTexture1: { type: "texture", value: this.renderTargetsVertical[0].getColorTexture() }, blurTexture2: { type: "texture", value: this.renderTargetsVertical[1].getColorTexture() }, blurTexture3: { type: "texture", value: this.renderTargetsVertical[2].getColorTexture() }, blurTexture4: { type: "texture", value: this.renderTargetsVertical[3].getColorTexture() }, blurTexture5: { type: "texture", value: this.renderTargetsVertical[4].getColorTexture() }, - tSampler: { type: "sampler", value: this.defaultSampler }, + tSampler: { + type: "sampler", + value: this.defaultSampler + }, bloomStrength: { type: "f32", value: this.strength }, bloomRadius: { type: "f32", value: this.radius }, - bloomFactors: { type: "array", value: [1, 0.8, 0.6, 0.4, 0.2] }, + bloomFactors: { type: "array", value: [1.0, 0.8, 0.6, 0.4, 0.2] }, bloomTintColors: { type: "array", - value: [new Ue(1, 1, 1), new Ue(1, 1, 1), new Ue(1, 1, 1), new Ue(1, 1, 1), new Ue(1, 1, 1)] + value: [ + new Vector3(1, 1, 1), + new Vector3(1, 1, 1), + new Vector3(1, 1, 1), + new Vector3(1, 1, 1), + new Vector3(1, 1, 1) + ] } }, - vert: () => - "\n struct VertexInput {\n @location(0) position: vec2, \n }\n struct VertexOutput {\n @builtin(position) position: vec4,\n @location(0) uv: vec2,\n };\n @vertex\n fn main(input: VertexInput) -> VertexOutput {\n var output:VertexOutput;\n output.uv = input.position * 0.5 + 0.5;\n output.position = vec4(input.position, 0.0, 1.0);;\n return output;\n }\n ", - frag: (e) => - `\n struct FragInput {\n @location(0) uv: vec2,\n };\n struct BloomUniforms{\n bloomStrength:f32,\n bloomRadius:f32,\n bloomFactors : array,\n bloomTintColors : array,5>\n } \n @group(0) @binding(0) var bloomUniforms : BloomUniforms;\n\n @group(0) @binding(${e.blurTexture1Binding}) var blurTexture1: texture_2d;\n @group(0) @binding(${e.blurTexture2Binding}) var blurTexture2: texture_2d;\n @group(0) @binding(${e.blurTexture3Binding}) var blurTexture3: texture_2d;\n @group(0) @binding(${e.blurTexture4Binding}) var blurTexture4: texture_2d;\n @group(0) @binding(${e.blurTexture5Binding}) var blurTexture5: texture_2d;\n @group(0) @binding(${e.tSamplerBinding}}) var tSampler: sampler;\n\n\t\t\t\tfn lerpBloomFactor(factor:f32)->f32 {\n\t\t\t\t\tlet mirrorFactor:f32 = 1.2 - factor;\n\t\t\t\t\treturn mix(factor, mirrorFactor, bloomUniforms.bloomRadius);\n\t\t\t\t}\n @fragment\n\t\t\t\tfn main(input:FragInput)-> @location(0) vec4 {\n\t\t\t\t\treturn bloomUniforms.bloomStrength * ( lerpBloomFactor(bloomUniforms.bloomFactors[0]) * vec4(bloomUniforms.bloomTintColors[0], 1.0) * textureSample(blurTexture1, tSampler, input.uv) +\n\t\t\t\t\t\tlerpBloomFactor(bloomUniforms.bloomFactors[1]) * vec4(bloomUniforms.bloomTintColors[1], 1.0) * textureSample(blurTexture2, tSampler, input.uv) +\n\t\t\t\t\t\tlerpBloomFactor(bloomUniforms.bloomFactors[2]) * vec4(bloomUniforms.bloomTintColors[2], 1.0) * textureSample(blurTexture3, tSampler, input.uv) +\n\t\t\t\t\t\tlerpBloomFactor(bloomUniforms.bloomFactors[3]) * vec4(bloomUniforms.bloomTintColors[3], 1.0) * textureSample(blurTexture4, tSampler, input.uv) +\n\t\t\t\t\t\tlerpBloomFactor(bloomUniforms.bloomFactors[4]) * vec4(bloomUniforms.bloomTintColors[4], 1.0) * textureSample(blurTexture5, tSampler, input.uv) );\n\t\t\t\t}` + vert: () => { + return ` + struct VertexInput { + @location(0) position: vec2, + } + struct VertexOutput { + @builtin(position) position: vec4, + @location(0) uv: vec2, + }; + @vertex + fn main(input: VertexInput) -> VertexOutput { + var output:VertexOutput; + output.uv = input.position * 0.5 + 0.5; + output.position = vec4(input.position, 0.0, 1.0);; + return output; + } + `; + }, + frag: (defines) => { + return ` + struct FragInput { + @location(0) uv: vec2, + }; + struct BloomUniforms{ + bloomStrength:f32, + bloomRadius:f32, + bloomFactors : array, + bloomTintColors : array,5> + } + @group(0) @binding(0) var bloomUniforms : BloomUniforms; + + @group(0) @binding(${defines.blurTexture1Binding}) var blurTexture1: texture_2d; + @group(0) @binding(${defines.blurTexture2Binding}) var blurTexture2: texture_2d; + @group(0) @binding(${defines.blurTexture3Binding}) var blurTexture3: texture_2d; + @group(0) @binding(${defines.blurTexture4Binding}) var blurTexture4: texture_2d; + @group(0) @binding(${defines.blurTexture5Binding}) var blurTexture5: texture_2d; + @group(0) @binding(${defines.tSamplerBinding}}) var tSampler: sampler; + + fn lerpBloomFactor(factor:f32)->f32 { + let mirrorFactor:f32 = 1.2 - factor; + return mix(factor, mirrorFactor, bloomUniforms.bloomRadius); + } + @fragment + fn main(input:FragInput)-> @location(0) vec4 { + return bloomUniforms.bloomStrength * ( lerpBloomFactor(bloomUniforms.bloomFactors[0]) * vec4(bloomUniforms.bloomTintColors[0], 1.0) * textureSample(blurTexture1, tSampler, input.uv) + + lerpBloomFactor(bloomUniforms.bloomFactors[1]) * vec4(bloomUniforms.bloomTintColors[1], 1.0) * textureSample(blurTexture2, tSampler, input.uv) + + lerpBloomFactor(bloomUniforms.bloomFactors[2]) * vec4(bloomUniforms.bloomTintColors[2], 1.0) * textureSample(blurTexture3, tSampler, input.uv) + + lerpBloomFactor(bloomUniforms.bloomFactors[3]) * vec4(bloomUniforms.bloomTintColors[3], 1.0) * textureSample(blurTexture4, tSampler, input.uv) + + lerpBloomFactor(bloomUniforms.bloomFactors[4]) * vec4(bloomUniforms.bloomTintColors[4], 1.0) * textureSample(blurTexture5, tSampler, input.uv) ); + }`; + } }); } - getSeperableBlurMaterial(e, t) { - const i = $i("blur", { KERNEL_RADIUS: e, SIGMA: e, positionLocation: 0 }), - r = new Zi({ - type: t, - uniforms: { - tDiffuse: { type: "texture", value: null }, - direction: { type: "vec2", value: new Se(0, 0) }, - tSampler: { type: "sampler", value: this.defaultSampler } - }, - vert: i.vert, - frag: i.frag - }); - return (r.renderState = this.renderState), r; + getSeperableBlurMaterial(kernelRadius, type) { + const shader = getVertFrag("blur", { + KERNEL_RADIUS: kernelRadius, + SIGMA: kernelRadius, + positionLocation: 0 + }); + const mat = new ShaderMaterial({ + type, + uniforms: { + tDiffuse: { type: "texture", value: null }, + direction: { type: "vec2", value: new Vector2(0.0, 0.0) }, + tSampler: { + type: "sampler", + value: this.defaultSampler + } + }, + vert: shader.vert, + frag: shader.frag + }); + mat.renderState = this.renderState; + return mat; } } -(Kr.BlurDirectionX = new Se(1, 0)), (Kr.BlurDirectionY = new Se(0, 1)); -class Qr extends $r { - constructor(e = -1, t = 1, i = 1, r = -1, n = 0.1, s = 2e3) { - super(), - (this.near = n), - (this.far = s), - (this.left = e), - (this.top = i), - (this.bottom = r), - (this.right = t), - (this.isOrthographicCamera = !0); +BloomPostEffect.BlurDirectionX = new Vector2(1.0, 0.0); +BloomPostEffect.BlurDirectionY = new Vector2(0.0, 1.0); + +class OrthographicCamera extends Camera { + constructor(left = -1, right = 1, top = 1, bottom = -1, near = 0.1, far = 2000) { + super(); + this.near = near; + this.far = far; + this.left = left; + this.top = top; + this.bottom = bottom; + this.right = right; + this.isOrthographicCamera = true; } updateCameraParms() { - const e = (this.right - this.left) / 2, - t = (this.top - this.bottom) / 2, - i = (this.right + this.left) / 2, - r = (this.top + this.bottom) / 2; - return { left: i - e, right: i + e, top: r + t, bottom: r - t }; + const dx = (this.right - this.left) / 2; + const dy = (this.top - this.bottom) / 2; + const cx = (this.right + this.left) / 2; + const cy = (this.top + this.bottom) / 2; + return { + left: cx - dx, + right: cx + dx, + top: cy + dy, + bottom: cy - dy + }; } updateProjectionMatrix() { if (this.projectMatrixDirty) { - const { left: e, right: t, top: i, bottom: r } = this.updateCameraParms(); - (this._projectionMatrix = et.makeOrthographic(e, t, i, r, this.near, this.far)), - (this.projectMatrixDirty = !1); + const { left, right, top, bottom } = this.updateCameraParms(); + this._projectionMatrix = Matrix4.makeOrthographic(left, right, top, bottom, this.near, this.far); + this.projectMatrixDirty = false; } } } -class Jr extends qr { + +class SpotLightShadow extends BaseShadow { constructor() { - const e = new Gr(60, 1, 0.1, 500); - super(new Se(1024, 1024), e), (this.type = "spotLightShadow"); - } - update(e) { - this.updateMatrices(e); - } - updateMatrices(e) { - this.camera.position.copy(e.position); - const { x: t, y: i, z: r } = e.target; - this.camera.lookAt(t, i, r), this.camera.updateMatrix(), (this.vpMatrixDirty = !0); - } -} -class en extends Ht { - constructor(e, t, i = 0, r = 60, n = 60, s = 4, a = !0) { - super(e, t), - (this._distance = i), - (this._angle = (r / 180) * Math.PI), - (this._penumbra = (n / 180) * Math.PI), - (this._decay = s), - (this.lightType = K.SpotLight), - (this.angleDirty = !0), - (this.penumbraDirty = !0), - (this.distanceDirty = !0), - (this.decayDirty = !0), - (this.coneCosDirty = !0), - (this.penumbraCosDirty = !0), - a && (this.shadow = new Jr()), - this.updateConeCosOrPenumbraCos(); + const camera = new PerspectiveCamera(60, 1, 0.1, 500); + super(new Vector2(1024, 1024), camera); + this.type = "spotLightShadow"; + } + update(light) { + this.updateMatrices(light); + } + updateMatrices(light) { + this.camera.position.copy(light.position); + const { x, y, z } = light.target; + this.camera.lookAt(x, y, z); + this.camera.updateMatrix(); + this.vpMatrixDirty = true; + } +} + +class SpotLight extends Light { + constructor(color, intensity, distance = 0, angle = 60, penumbra = 60, decay = 4, openShadow = true) { + super(color, intensity); + this._distance = distance; + this._angle = (angle / 180) * Math.PI; + this._penumbra = (penumbra / 180) * Math.PI; + this._decay = decay; + this.lightType = LightType.SpotLight; + this.angleDirty = true; + this.penumbraDirty = true; + this.distanceDirty = true; + this.decayDirty = true; + this.coneCosDirty = true; + this.penumbraCosDirty = true; + if (openShadow) this.shadow = new SpotLightShadow(); + this.updateConeCosOrPenumbraCos(); } get dirtectDirty() { return this.positionDirty || this.targetDirty; } - set dirtectDirty(e) { - (this.positionDirty = e), (this.targetDirty = e); + set dirtectDirty(value) { + this.positionDirty = value; + this.targetDirty = value; } get directional() { - const e = new Ue(); - return Ue.subtract(this.position, this.target, e), Ue.normalize(e, new Ue()); + const result = new Vector3(); + Vector3.subtract(this.position, this.target, result); + return Vector3.normalize(result, new Vector3()); } get angle() { return this._angle; } - set angle(e) { - (this.angleDirty = !0), (this._angle = (e / 180) * Math.PI), this.updateConeCosOrPenumbraCos(); + set angle(value) { + this.angleDirty = true; + this._angle = (value / 180) * Math.PI; + this.updateConeCosOrPenumbraCos(); } get penumbra() { return this._penumbra; } - set penumbra(e) { - (this.penumbraDirty = !0), (this._penumbra = (e / 180) * Math.PI), this.updateConeCosOrPenumbraCos(); + set penumbra(value) { + this.penumbraDirty = true; + this._penumbra = (value / 180) * Math.PI; + this.updateConeCosOrPenumbraCos(); } - set distance(e) { - (this.distanceDirty = !0), (this._distance = e); + set distance(value) { + this.distanceDirty = true; + this._distance = value; } get distance() { return this._distance; } - set decay(e) { - (this.decayDirty = !0), (this._decay = e); + set decay(value) { + this.decayDirty = true; + this._decay = value; } get decay() { return this._decay; } - set coneCos(e) { - (this.coneCosDirty = !0), (this._coneCos = e); + set coneCos(value) { + this.coneCosDirty = true; + this._coneCos = value; } get coneCos() { return this._coneCos; } - set penumbraCos(e) { - (this.penumbraCosDirty = !0), (this._penumbraCos = e); + set penumbraCos(value) { + this.penumbraCosDirty = true; + this._penumbraCos = value; } get penumbraCos() { return this._penumbraCos; } updateConeCosOrPenumbraCos() { - (this._coneCos = Math.cos(this.angle)), (this._penumbraCos = Math.cos(this.angle + this.penumbra)); + this._coneCos = Math.cos(this.angle); + this._penumbraCos = Math.cos(this.angle + this.penumbra); } } -class tn extends qr { +// uniform +// color: {}, +// position: {}, +// direction: {}, +// distance: {}, +// coneCos: {}, +// penumbraCos: {}, +// decay: {} + +class DirectionalLightShadow extends BaseShadow { constructor() { - const e = new Qr(-50, 50, 50, -50, 0, 100); - super(new Se(1024, 1024), e), (this.type = "directionalLightShadow"); + const camera = new OrthographicCamera(-50, 50, 50, -50, 0, 100); + super(new Vector2(1024, 1024), camera); + this.type = "directionalLightShadow"; } - update(e) { - this.updateMatrices(e); + update(light) { + this.updateMatrices(light); } - updateMatrices(e) { - this.camera.position.copy(e.position); - const { x: t, y: i, z: r } = e.target; - this.camera.lookAt(t, i, r), this.camera.updateMatrix(), (this.vpMatrixDirty = !0); + updateMatrices(light) { + this.camera.position.copy(light.position); + const { x, y, z } = light.target; + this.camera.lookAt(x, y, z); + this.camera.updateMatrix(); + this.vpMatrixDirty = true; } } -class rn extends Ht { - constructor(e, t, i = !0) { - super(e, t), (this.lightType = K.DirectionalLight), i && (this.shadow = new tn()); + +class DirectionalLight extends Light { + constructor(color, intensity, openShadow = true) { + super(color, intensity); + this.lightType = LightType.DirectionalLight; + if (openShadow) this.shadow = new DirectionalLightShadow(); } get dirtectDirty() { return this.positionDirty || this.targetDirty; } - set dirtectDirty(e) { - (this.positionDirty = e), (this.targetDirty = e); + set dirtectDirty(value) { + this.positionDirty = value; + this.targetDirty = value; } get directional() { - const e = new Ue(); - return Ue.subtract(this.target, this.position, e), e.normalize(); + const result = new Vector3(); + Vector3.subtract(this.target, this.position, result); + return result.normalize(); } } -class nn extends $t { +// uniform +// direction: {}, +// color: {} + +class Node extends RenderObject { constructor() { - super(), (this.type = Z.Node), (this.children = new Map()), (this.parent = null), (this.uid = Ki()); - } - add(e) { - (e.parent = this), this.children.set(e.uid, e); - } - remove(e) { - this.children.delete(e.uid); - } - update(e, t) { - this.updateMatrix(this?.parent?.modelMatrix?.clone()), - this?.children?.forEach?.((i) => { - i.update(e, t); - }); + super(); + this.type = RenderObjectType.Node; + this.children = new Map(); + this.parent = null; + this.uid = createGuid(); + } + add(node) { + node.parent = this; + this.children.set(node.uid, node); + } + remove(node) { + this.children.delete(node.uid); + } + update(frameState, camera) { + this.updateMatrix(this?.parent?.modelMatrix?.clone()); + this?.children?.forEach?.((node) => { + node.update(frameState, camera); + }); } destroy() { - this.children.forEach((e) => { - e.destroy(); - }), - this?.children?.clear(); - } - traverse(e, t) { - for (let i = 0, r = this.children.size; i < r; i++) - this.children.forEach((i) => { - i.traverse(e, t); + this.children.forEach((node) => { + node.destroy(); + }); + this?.children?.clear(); + } + traverse(traverseFunction, param) { + for (let i = 0, len = this.children.size; i < len; i++) { + this.children.forEach((child) => { + child.traverse(traverseFunction, param); }); + } } } -class sn extends Qi { - constructor(e, t) { - super(e, t), (this.type = Z.SkinMesh), (this.uniformMatrixs = []), (this.hasAddJoints = !1); - } - setSkinData(e) { - (this.inverseBindMatrices = e.inverseBindMatrices), (this.joints = e.joints); - } - update(e, t) { - (this.uniformMatrixs = this.joints.map((e) => e.modelMatrix)), - super.update(e, t), - this.hasAddJoints || this.addUniformsToMaterial(); + +class SKinMesh extends Mesh { + constructor(geometry, material) { + super(geometry, material); + this.type = RenderObjectType.SkinMesh; + this.uniformMatrixs = []; + this.hasAddJoints = false; + } + setSkinData(data) { + this.inverseBindMatrices = data.inverseBindMatrices; + this.joints = data.joints; + } + update(frameState, camera) { + this.uniformMatrixs = this.joints.map((joint) => joint.modelMatrix); + super.update(frameState, camera); + if (!this.hasAddJoints) this.addUniformsToMaterial(); } addUniformsToMaterial() { - if (this.material.shaderData && ((this.hasAddJoints = !0), this.joints)) { - const e = new Ri({ - label: "skinJointsBuffer", - type: m.ReadOnlyStorage, - usage: r.Storage | r.CopyDst, - size: 3e3 - }), - t = new Ri({ label: "invsBuffer", type: m.ReadOnlyStorage, usage: r.Storage | r.CopyDst, size: 3e3 }); - e.setUniform("joints", () => this.uniformMatrixs, Q.Mat4Array, this.uniformMatrixs.length), - t.setUniform("jointsInv", () => this.inverseBindMatrices, Q.Mat4Array, this.inverseBindMatrices.length), - this.material.shaderData.setUniformBuffer("skinJointsBuffer", e), - this.material.shaderData.setUniformBuffer("invsBuffer", t); - } - } -} -function an(e, t, i, r) { - switch (e) { + if (!this.material.shaderData) return; + this.hasAddJoints = true; + if (this.joints) { + const skinJointsBuffer = new UniformBuffer({ + label: "skinJointsBuffer", + type: BufferBindingType.ReadOnlyStorage, + usage: BufferUsage.Storage | BufferUsage.CopyDst, + size: 3000 + }); + const invsBuffer = new UniformBuffer({ + label: "invsBuffer", + type: BufferBindingType.ReadOnlyStorage, + usage: BufferUsage.Storage | BufferUsage.CopyDst, + size: 3000 + }); + skinJointsBuffer.setUniform( + "joints", + () => { + return this.uniformMatrixs; + }, + UniformEnum.Mat4Array, + this.uniformMatrixs.length + ); + invsBuffer.setUniform( + "jointsInv", + () => { + return this.inverseBindMatrices; + }, + UniformEnum.Mat4Array, + this.inverseBindMatrices.length + ); + this.material.shaderData.setUniformBuffer("skinJointsBuffer", skinJointsBuffer); + this.material.shaderData.setUniformBuffer("invsBuffer", invsBuffer); + } + } +} + +function newTypedArray(type, buffer, byteOffset, length) { + switch (type) { case 5120: - return new Int8Array(t, i, r); + return new Int8Array(buffer, byteOffset, length); case 5121: - return new Uint8Array(t, i, r); + return new Uint8Array(buffer, byteOffset, length); case 5122: - return new Int16Array(t, i, r); + return new Int16Array(buffer, byteOffset, length); case 5123: - return new Uint16Array(t, i, r); + return new Uint16Array(buffer, byteOffset, length); case 5124: - return new Int32Array(t, i, r); + return new Int32Array(buffer, byteOffset, length); case 5125: - return new Uint32Array(t, i, r); + return new Uint32Array(buffer, byteOffset, length); case 5126: - return new Float32Array(t, i, r); + return new Float32Array(buffer, byteOffset, length); default: throw new Error("invalid component type"); } } -const on = { +function toIndices(array) { + if (array instanceof Uint16Array || array instanceof Uint32Array) { + return array; + } + let toArray; + if (array instanceof Float32Array) { + toArray = new Uint32Array(array.length); + } else { + toArray = new Uint16Array(array.length); + } + array.forEach((element, index) => { + toArray[index] = element; + }); + return toArray; +} +function generateNormals(indices, positions) { + const normals = new Float32Array(positions.length); + const vertexCount = indices ? indices.length : positions.length; + for (let i = 0; i < vertexCount; i += 3) { + const triIndices = []; + for (let n = 0; n < 3; n += 1) { + if (indices) { + triIndices.push(indices[i + n]); + } else { + triIndices.push(i + n); + } + } + const triangle = triIndices.map((vertexIndex) => { + const index = vertexIndex * 3; + return new Vector3(positions[index], positions[index + 1], positions[index + 2]); + }); + const dv1 = new Vector3(); + Vector3.subtract(triangle[1], triangle[0], dv1); + const dv2 = new Vector3(); + Vector3.subtract(triangle[2], triangle[0], dv2); + const normal = new Vector3(); + Vector3.cross(dv1.normalize(), dv2.normalize(), normal); + for (let n = 0; n < 3; n += 1) { + const index = (i + n) * 3; + normals[index + 0] += normal.x; + normals[index + 1] += normal.y; + normals[index + 2] += normal.z; + } + } + return normals; +} +const gltfEnum = { SCALAR: 1, VEC2: 2, VEC3: 3, @@ -11301,613 +15190,794 @@ const on = { 33648: "mirror-repeat", 10497: "repeat" }; -class cn { - constructor(e) { - (this.values = e.values ?? []), - (this.id = e.id), - (this.count = e.count), - (this.componentType = e.componentType), - (this.type = e.type), - (this.min = e.min), - (this.max = e.max); + +class Accessor { + constructor(options) { + this.values = options.values ?? []; + this.id = options.id; + this.count = options.count; + this.componentType = options.componentType; + this.type = options.type; + this.min = options.min; + this.max = options.max; } getArray() { return Array.from(this.values); } getVec4Array() { - const e = []; - for (let t = 0; t < this.values.length; t += 4) - e.push(new We(this.values[t], this.values[t + 1], this.values[t + 2], this.values[t + 3])); - return e; + const result = []; + for (let i = 0; i < this.values.length; i += 4) { + result.push(new Vector4(this.values[i], this.values[i + 1], this.values[i + 2], this.values[i + 3])); + } + return result; } getMat4Array() { - const e = []; - for (let t = 0; t < this.values.length; t += 16) { - const i = new et(); - et.fromColumnMajorArray(this.values.slice(t, t + 16), i), e.push(i); + const result = []; + for (let i = 0; i < this.values.length; i += 16) { + const mat4 = new Matrix4(); + Matrix4.fromColumnMajorArray(this.values.slice(i, i + 16), mat4); + result.push(mat4); } - return e; + return result; } } -class ln { - constructor(e, t, i) { - (this.name = e), (this.samplers = t), (this.channels = i); - } - play(e) { - let t, i, r; - this?.channels?.map((n) => { - switch (((i = n.sampler), i.getValue(e), (r = n.target), (t = r.node), r.path)) { + +class Animation { + constructor(name, samplers, channels) { + this.name = name; + this.samplers = samplers; + this.channels = channels; + } + play(time) { + let node, animationSampler, target; + this?.channels?.map((channel) => { + animationSampler = channel.sampler; + animationSampler.getValue(time); + target = channel.target; + node = target.node; + switch (target.path) { case "rotation": - zt.clone(i.currentValue, t.quaternion); + Quaternion.clone(animationSampler.currentValue, node.quaternion); break; case "translation": - We.clone(i.currentValue, t.position); + Vector4.clone(animationSampler.currentValue, node.position); break; case "scale": - We.clone(i.currentValue, t.scale); + Vector4.clone(animationSampler.currentValue, node.scale); + break; } }); } } -class hn { + +class AnimationChannel { + constructor() {} +} + +class AnimationChannelTarget { + constructor(node, path) { + this.node = node; + this.path = path; + } +} + +var Type2NumOfComponent; +(function (Type2NumOfComponent) { + Type2NumOfComponent[(Type2NumOfComponent["SCALAR"] = 1)] = "SCALAR"; + Type2NumOfComponent[(Type2NumOfComponent["VEC2"] = 2)] = "VEC2"; + Type2NumOfComponent[(Type2NumOfComponent["VEC3"] = 3)] = "VEC3"; + Type2NumOfComponent[(Type2NumOfComponent["VEC4"] = 4)] = "VEC4"; + Type2NumOfComponent[(Type2NumOfComponent["MAT2"] = 4)] = "MAT2"; + Type2NumOfComponent[(Type2NumOfComponent["MAT3"] = 9)] = "MAT3"; + Type2NumOfComponent[(Type2NumOfComponent["MAT4"] = 16)] = "MAT4"; +})(Type2NumOfComponent || (Type2NumOfComponent = {})); + +class AnimationSampler { constructor() {} + formGltf(gltf, sampler) { + this.input = gltf.accessors[sampler.input].values; //required, accessor object + this.output = gltf.accessors[sampler.output].values; //required, accessor object + this.interpolation = sampler.interpolation !== undefined ? sampler.interpolation : "LINEAR"; + this.currentIndex = 0; + // this.currentValue=new Vector4(); + this.endTime = this.input[this.input.length - 1]; + this.inputMax = this.endTime - this.input[0]; + this.inputType = gltf?.json?.accessors[sampler.input]?.type; + this.outputType = gltf?.json?.accessors[sampler.output]?.type; + } + getValue(time) { + if (time > this.endTime) { + time -= this.inputMax * Math.ceil((time - this.endTime) / this.inputMax); + this.currentIndex = 0; + } + const len = this.input.length; + while (this.currentIndex <= len - 2 && time >= this.input[this.currentIndex + 1]) { + this.currentIndex++; + } + if (this.currentIndex >= len - 1) { + // loop + time -= this.inputMax; + this.currentIndex = 0; + } + // @tmp: assume no stride + const count = Type2NumOfComponent[this.outputType]; + const animationOutputValueVec4a = count === 4 ? new Quaternion() : new Vector4(); + const animationOutputValueVec4b = count === 4 ? new Quaternion() : new Vector4(); + if (!this.currentValue) this.currentValue = count === 4 ? new Quaternion() : new Vector4(); + const i = this.currentIndex; + const o = i * count; + const on = o + count; + const u = Math.max(0, time - this.input[i]) / (this.input[i + 1] - this.input[i]); + animationOutputValueVec4a.set(this.output[o + 0], this.output[o + 1], this.output[o + 2], this.output[o + 3]); + animationOutputValueVec4b.set( + this.output[on + 0], + this.output[on + 1], + this.output[on + 2], + this.output[on + 3] + ); + switch (this.interpolation) { + case "LINEAR": + count === 4 + ? Quaternion.slerp(animationOutputValueVec4a, animationOutputValueVec4b, u, this.currentValue) + : Vector4.lerp(animationOutputValueVec4a, animationOutputValueVec4b, u, this.currentValue); + break; + } + } } -class un { - constructor(e, t) { - (this.node = e), (this.path = t); - } -} -var fn; -!(function (e) { - (e[(e.SCALAR = 1)] = "SCALAR"), - (e[(e.VEC2 = 2)] = "VEC2"), - (e[(e.VEC3 = 3)] = "VEC3"), - (e[(e.VEC4 = 4)] = "VEC4"), - (e[(e.MAT2 = 4)] = "MAT2"), - (e[(e.MAT3 = 9)] = "MAT3"), - (e[(e.MAT4 = 16)] = "MAT4"); -})(fn || (fn = {})); -class dn { - constructor() {} - formGltf(e, t) { - (this.input = e.accessors[t.input].values), - (this.output = e.accessors[t.output].values), - (this.interpolation = void 0 !== t.interpolation ? t.interpolation : "LINEAR"), - (this.currentIndex = 0), - (this.endTime = this.input[this.input.length - 1]), - (this.inputMax = this.endTime - this.input[0]), - (this.inputType = e?.json?.accessors[t.input]?.type), - (this.outputType = e?.json?.accessors[t.output]?.type); - } - getValue(e) { - e > this.endTime && - ((e -= this.inputMax * Math.ceil((e - this.endTime) / this.inputMax)), (this.currentIndex = 0)); - const t = this.input.length; - for (; this.currentIndex <= t - 2 && e >= this.input[this.currentIndex + 1]; ) this.currentIndex++; - this.currentIndex >= t - 1 && ((e -= this.inputMax), (this.currentIndex = 0)); - const i = fn[this.outputType], - r = 4 === i ? new zt() : new We(), - n = 4 === i ? new zt() : new We(); - this.currentValue || (this.currentValue = 4 === i ? new zt() : new We()); - const s = this.currentIndex, - a = s * i, - o = a + i, - c = Math.max(0, e - this.input[s]) / (this.input[s + 1] - this.input[s]); - if ( - (r.set(this.output[a + 0], this.output[a + 1], this.output[a + 2], this.output[a + 3]), - n.set(this.output[o + 0], this.output[o + 1], this.output[o + 2], this.output[o + 3]), - "LINEAR" === this.interpolation) - ) - 4 === i ? zt.slerp(r, n, c, this.currentValue) : We.lerp(r, n, c, this.currentValue); - } -} -class mn { - constructor(e, t, i = 0, r) { - (this.json = e), - (this.bufferViews = e.bufferViews), - (this.glbOffset = i), - (this.rootUrl = t), - (this.scenes = e.scenes), - (this.cameras = e.cameras || []), - (this.glbBin = r), - (this.meshes = []); + +class GLTF { + constructor(json, rootUrl, glbOffset = 0, glbBin) { + this.json = json; + this.bufferViews = json.bufferViews; + this.glbOffset = glbOffset; + this.rootUrl = rootUrl; + this.scenes = json.scenes; + this.cameras = json.cameras || []; + this.glbBin = glbBin; + this.meshes = []; } async parseData() { - (this.buffers = await this.loadBuffes()), - (this.images = await this.loadImages()), - this.parseSamplers(), - this.parseTextures(), - this.parseMaterials(), - this.parseAccessors(), - this.parseMeshs(), - this.parseNodes(), - this.normalizeData(), - this.parseScenes(), - this.parseAnimations(); - } - getAccessor(e) { - return this.accessors[e]; + this.buffers = await this.loadBuffes(); + this.images = await this.loadImages(); + this.parseSamplers(); + this.parseTextures(); + this.parseMaterials(); + this.parseAccessors(); + this.parseMeshs(); + this.parseNodes(); + this.normalizeData(); + this.parseScenes(); + this.parseAnimations(); + } + getAccessor(index) { + return this.accessors[index]; } parseSamplers() { - this.samplers = this.json.samplers ? this.json.samplers.map((e) => this.getSampler(e)) : []; + this.samplers = this.json.samplers ? this.json.samplers.map((sampler) => this.getSampler(sampler)) : []; } parseScenes() { - this.scenes = this.json.scenes.map((e) => { - const t = e?.nodes?.map((e) => this.nodes[e]); - return t; + this.scenes = this.json.scenes.map((scene) => { + const nodes = scene?.nodes?.map((nodeId) => { + return this.nodes[nodeId]; + }); + return nodes; }); } parseTextures() { this.textures = this.json.textures - ? this.json.textures.map((e) => ({ - sampler: void 0 !== e.sampler ? this.samplers[e.sampler] : this.getSampler({}), - texture: this.createTexture(e.source) - })) + ? this.json.textures.map((texture) => { + return { + sampler: texture.sampler !== undefined ? this.samplers[texture.sampler] : this.getSampler({}), + texture: this.createTexture(texture.source) + }; + }) : []; } parseMaterials() { this.materials = this.json.materials - ? this.json.materials.map((e) => { - const t = new Sr(), - { - baseColorFactor: i, - metallicFactor: r, - metallicRoughnessTexture: n, - baseColorTexture: s, - roughnessFactor: a - } = e.pbrMetallicRoughness; - return ( - e.normalTexture && (t.normalTexture = this.textures[e.normalTexture.index].texture), - e.occlusionTexture && (t.aoTexture = this.textures[e.occlusionTexture.index].texture), - e.emissiveTexture && (t.emissiveTexture = this.textures[e.emissiveTexture.index].texture), - s && (t.baseTexture = this.textures[s.index].texture), - n && (t.metalnessRoughnessTexture = this.textures[n.index].texture), - i && (t.color = new Qt(i[0], i[1], i[2])), - (t.metalness = r ?? 1), - (t.roughness = a ?? 0), - (t.baseSampler = new de({ - magFilter: "linear", - minFilter: "linear", - addressModeU: "repeat", - addressModeV: "repeat" - })), - t - ); + ? this.json.materials.map((material) => { + const mat = new PbrMaterial(); + const { + baseColorFactor, + metallicFactor, + metallicRoughnessTexture, + baseColorTexture, + roughnessFactor + } = material.pbrMetallicRoughness; + if (material.normalTexture) mat.normalTexture = this.textures[material.normalTexture.index].texture; + if (material.occlusionTexture) + mat.aoTexture = this.textures[material.occlusionTexture.index].texture; + if (material.emissiveTexture) + mat.emissiveTexture = this.textures[material.emissiveTexture.index].texture; + if (baseColorTexture) mat.baseTexture = this.textures[baseColorTexture.index].texture; + if (metallicRoughnessTexture) + mat.metalnessRoughnessTexture = this.textures[metallicRoughnessTexture.index].texture; + if (baseColorFactor) + mat.color = new Color(baseColorFactor[0], baseColorFactor[1], baseColorFactor[2]); + mat.metalness = metallicFactor ?? 1.0; + mat.roughness = roughnessFactor ?? 0.0; + mat.baseSampler = new Sampler({ + magFilter: "linear", + minFilter: "linear", + addressModeU: "repeat", + addressModeV: "repeat" + }); + return mat; }) : []; } parseAccessors() { - this.accessors = this.json.accessors.map((e, t) => { - const i = on[e.type]; - let r; - if ( - ((r = - void 0 === e.bufferView - ? an(e.componentType, new ArrayBuffer(i * e.count * on[e.componentType]), 0, e.count * i) - : this.getBufferView(e, i)), - e.sparse) - ) { - (e.sparse.indices.count = e.sparse.count), - (e.sparse.values.count = e.sparse.count), - (e.sparse.values.componentType = e.componentType); - const t = this.getBufferView(e.sparse.indices, 1), - n = this.getBufferView(e.sparse.values, i); - for (let s = 0; s < e.sparse.count; s += 1) - for (let e = 0; e < i; e += 1) r[t[s] * i + e] = n[s * i + e]; + this.accessors = this.json.accessors.map((accessor, index) => { + const n = gltfEnum[accessor.type]; + let array; + if (accessor.bufferView === undefined) { + array = newTypedArray( + accessor.componentType, + new ArrayBuffer(n * accessor.count * gltfEnum[accessor.componentType]), + 0, + accessor.count * n + ); + } else { + array = this.getBufferView(accessor, n); } - return new cn({ - componentType: on[e.componentType], - count: e.count, - type: i, - values: r, - id: t, - min: e?.min, - max: e?.max + if (accessor.sparse) { + accessor.sparse.indices.count = accessor.sparse.count; + accessor.sparse.values.count = accessor.sparse.count; + accessor.sparse.values.componentType = accessor.componentType; + const indices = this.getBufferView(accessor.sparse.indices, 1); + const values = this.getBufferView(accessor.sparse.values, n); + for (let i = 0; i < accessor.sparse.count; i += 1) { + for (let j = 0; j < n; j += 1) { + array[indices[i] * n + j] = values[i * n + j]; + } + } + } + return new Accessor({ + componentType: gltfEnum[accessor.componentType], + count: accessor.count, + type: n, + values: array, + id: index, + min: accessor?.min, + max: accessor?.max }); }); } parseAnimations() { - this.animations = this?.json?.animations?.map((e, t) => { - const i = e?.samplers?.map((e) => { - const t = new dn(); - return t.formGltf(this, e), t; - }), - r = e?.channels?.map((e) => { - const t = new hn(); - return (t.sampler = i[e.sampler]), (t.target = new un(this.nodes[e.target.node], e.target.path)), t; - }); - return new ln(t.toString(), i, r); + this.animations = this?.json?.animations?.map((gltfAnimation, index) => { + const samplers = gltfAnimation?.samplers?.map((gltfSampler) => { + const sampler = new AnimationSampler(); + sampler.formGltf(this, gltfSampler); + return sampler; + }); + const channels = gltfAnimation?.channels?.map((gltfChannel) => { + const animationChannel = new AnimationChannel(); + animationChannel.sampler = samplers[gltfChannel.sampler]; + animationChannel.target = new AnimationChannelTarget( + this.nodes[gltfChannel.target.node], + gltfChannel.target.path + ); + return animationChannel; + }); + const animation = new Animation(index.toString(), samplers, channels); + return animation; }); } parseMeshs() { - this.meshes = this?.json?.meshes?.map?.((e) => ({ - name: e.name, - primitives: e?.primitives?.map?.((t) => { - const i = void 0 !== t.material ? this.materials[t.material] : { pbrMetallicRoughness: {} }, - r = this.createGeometry(t, i), - n = new Qi(r, i); - return (n.name = e.name), n; - }) - })); - } - getSampler(e) { - return new de({ - magFilter: on[e.magFilter || 9729], - minFilter: on[e.minFilter || 9729], - addressModeU: on[e.wrapS || 10497], - addressModeV: on[e.wrapT || 10497] + this.meshes = this?.json?.meshes?.map?.((gltfmesh) => { + return { + name: gltfmesh.name, + primitives: gltfmesh?.primitives?.map?.((primitive) => { + const material = + primitive.material !== undefined + ? this.materials[primitive.material] + : { pbrMetallicRoughness: {} }; + const geo = this.createGeometry(primitive, material); + const mesh = new Mesh(geo, material); + mesh.name = gltfmesh.name; + return mesh; + }) + }; }); } - getBufferView(e, t) { - const i = this.bufferViews[e.bufferView], - r = (i.byteOffset || 0) + (e.byteOffset || 0), - n = Math.max(i.byteStride / 4 || 0, t); - let s = an( - e.componentType, - this.buffers[i.buffer], - 0 === i.buffer ? r + this.glbOffset : r, - (e.count - 1) * n + t - ); - if (n > t) { - const i = new (0, s.constructor)(e.count * t); - for (let e = 0, r = 0; e < i.length; e += t, r += n) for (let n = 0; n < t; n += 1) i[e + n] = s[r + n]; - s = i; - } - return s; - } - createGeometry(e, t) { - let i = null, - r = null; - const n = { HAS_NORMAL: !0 }; - let s; - r = this.getAccessor(e.attributes.POSITION); - const a = r.getArray(); - let o; - (s = r.count), - void 0 !== e.indices && - ((r = this.getAccessor(e.indices)), - (i = (function (e) { - if (e instanceof Uint16Array || e instanceof Uint32Array) return e; - let t; - return ( - (t = e instanceof Float32Array ? new Uint32Array(e.length) : new Uint16Array(e.length)), - e.forEach((e, i) => { - t[i] = e; - }), - t - ); - })(r.getArray())), - (s = r.count)), - void 0 !== e.attributes.NORMAL - ? ((r = this.getAccessor(e.attributes.NORMAL)), (o = r.getArray())) - : (o = (function (e, t) { - const i = new Float32Array(t.length), - r = e ? e.length : t.length; - for (let n = 0; n < r; n += 3) { - const r = []; - for (let t = 0; t < 3; t += 1) e ? r.push(e[n + t]) : r.push(n + t); - const s = r.map((e) => { - const i = 3 * e; - return new Ue(t[i], t[i + 1], t[i + 2]); - }), - a = new Ue(); - Ue.subtract(s[1], s[0], a); - const o = new Ue(); - Ue.subtract(s[2], s[0], o); - const c = new Ue(); - Ue.cross(a.normalize(), o.normalize(), c); - for (let e = 0; e < 3; e += 1) { - const t = 3 * (n + e); - (i[t + 0] += c.x), (i[t + 1] += c.y), (i[t + 2] += c.z); - } - } - return i; - })(i, a)); - let c = null; - void 0 !== e.attributes.TEXCOORD_0 && - ((r = this.getAccessor(e.attributes.TEXCOORD_0)), (c = r.getArray()), (n.HAS_UV = !0)), - void 0 !== e.attributes.TEXCOORD_1 && - ((r = this.getAccessor(e.attributes.TEXCOORD_1)), r.getArray(), (n.HAS_UV1 = !0)), - void 0 !== e.attributes.TANGENT && void 0 !== e.attributes.NORMAL - ? ((r = this.getAccessor(e.attributes.TANGENT)), r.getArray()) - : t.normalTexture; - let l = null, - h = 3; - void 0 !== e.attributes.COLOR_0 && - ((r = this.accessors[e.attributes.COLOR_0]), (l = r.getArray()), (h = r.type), (n.HAS_COLOR = !0)); - let u = null; - void 0 !== e.attributes.JOINTS_0 && - ((r = this.getAccessor(e.attributes.JOINTS_0)), (u = r.getArray()), (n.HAS_SKIN = !0)); - let f = null; - void 0 !== e.attributes.WEIGHTS_0 && ((r = this.getAccessor(e.attributes.WEIGHTS_0)), (f = r.getArray())); - const d = new At({ type: "pbrGeomtry" }); - return ( - i && d.setIndice(Array.from(i)), - a && d.setAttribute(new Ie("position", Array.from(a), 3)), - o && d.setAttribute(new Ie("normal", Array.from(o), 3)), - l && d.setAttribute(new Ie("color", Array.from(l), h)), - c && d.setAttribute(new Ie("uv", Array.from(c), 2)), - u && d.setAttribute(new Ie("joint0", Array.from(u), 4)), - f && d.setAttribute(new Ie("weight0", Array.from(f), 4)), - (d.defines = n), - d.computeBoundingSphere(Array.from(a)), - (d.count = s), - d - ); + getSampler(samplerJson) { + return new Sampler({ + magFilter: gltfEnum[samplerJson.magFilter || 9729], + minFilter: gltfEnum[samplerJson.minFilter || 9729], + addressModeU: gltfEnum[samplerJson.wrapS || 10497], + addressModeV: gltfEnum[samplerJson.wrapT || 10497] + }); } - createTexture(e) { - return new fe({ - size: { width: this.images[e].width, height: this.images[e].height, depth: 1 }, - data: { source: this.images[e] }, + getBufferView(accessor, n) { + const bufferView = this.bufferViews[accessor.bufferView]; + const offset = (bufferView.byteOffset || 0) + (accessor.byteOffset || 0); + const stride = Math.max(bufferView.byteStride / 4 || 0, n); + let array = newTypedArray( + accessor.componentType, + this.buffers[bufferView.buffer], + bufferView.buffer === 0 ? offset + this.glbOffset : offset, + (accessor.count - 1) * stride + n + ); + if (stride > n) { + const TypedArrayConstructor = array.constructor; + const strided = new TypedArrayConstructor(accessor.count * n); + for (let i = 0, j = 0; i < strided.length; i += n, j += stride) { + for (let k = 0; k < n; k += 1) { + strided[i + k] = array[j + k]; + } + } + array = strided; + } + return array; + } + createGeometry(primitive, material) { + let indices = null; + let accessor = null; + const defines = { HAS_NORMAL: true }; + let vertexCount; + accessor = this.getAccessor(primitive.attributes.POSITION); + const positions = accessor.getArray(); + vertexCount = accessor.count; + // const { max, min } = accessor; + // const boundingBox = { max, min }; + if (primitive.indices !== undefined) { + accessor = this.getAccessor(primitive.indices); + indices = toIndices(accessor.getArray()); + vertexCount = accessor.count; + } + let normals; + if (primitive.attributes.NORMAL !== undefined) { + accessor = this.getAccessor(primitive.attributes.NORMAL); + normals = accessor.getArray(); + } else { + normals = generateNormals(indices, positions); + } + let uvs = null; + if (primitive.attributes.TEXCOORD_0 !== undefined) { + accessor = this.getAccessor(primitive.attributes.TEXCOORD_0); + uvs = accessor.getArray(); + defines.HAS_UV = true; + } + if (primitive.attributes.TEXCOORD_1 !== undefined) { + accessor = this.getAccessor(primitive.attributes.TEXCOORD_1); + accessor.getArray(); + defines.HAS_UV1 = true; + } + if (primitive.attributes.TANGENT !== undefined && primitive.attributes.NORMAL !== undefined) { + accessor = this.getAccessor(primitive.attributes.TANGENT); + accessor.getArray(); + // defines.HAS_TANGENT = true; + } else if (material.normalTexture); + let colors = null, + colorSize = 3; + if (primitive.attributes.COLOR_0 !== undefined) { + accessor = this.accessors[primitive.attributes.COLOR_0]; + colors = accessor.getArray(); + colorSize = accessor.type; + defines.HAS_COLOR = true; + } + let joints = null; + if (primitive.attributes.JOINTS_0 !== undefined) { + accessor = this.getAccessor(primitive.attributes.JOINTS_0); + joints = accessor.getArray(); + defines.HAS_SKIN = true; + } + let weights = null; + if (primitive.attributes.WEIGHTS_0 !== undefined) { + accessor = this.getAccessor(primitive.attributes.WEIGHTS_0); + weights = accessor.getArray(); + } + const geo = new Geometry({ type: "pbrGeomtry" }); + if (indices) geo.setIndice(Array.from(indices)); + if (positions) geo.setAttribute(new Float32Attribute("position", Array.from(positions), 3)); + if (normals) geo.setAttribute(new Float32Attribute("normal", Array.from(normals), 3)); + if (colors) geo.setAttribute(new Float32Attribute("color", Array.from(colors), colorSize)); + if (uvs) geo.setAttribute(new Float32Attribute("uv", Array.from(uvs), 2)); + if (joints) geo.setAttribute(new Float32Attribute("joint0", Array.from(joints), 4)); + if (weights) geo.setAttribute(new Float32Attribute("weight0", Array.from(weights), 4)); + geo.defines = defines; + geo.computeBoundingSphere(Array.from(positions)); + geo.count = vertexCount; + return geo; + } + createTexture(source) { + return new Texture({ + size: { + width: this.images[source].width, + height: this.images[source].height, + depth: 1 + }, + data: { + source: this.images[source] + }, format: "rgba8unorm", usage: GPUTextureUsage.TEXTURE_BINDING | GPUTextureUsage.COPY_DST | GPUTextureUsage.RENDER_ATTACHMENT }); } async loadImages() { - const e = []; - let t = Promise.resolve(); - this.json.images && - (t = Promise.all( - this.json.images.map(async (t, i) => { - if (t.uri) { - const r = "data:" === t.uri.slice(0, 5) ? t.uri : `${this.rootUrl}/${t.uri}`; - e[i] = await fetch(r) - .then((e) => e.blob()) - .then((e) => createImageBitmap(e, { colorSpaceConversion: "none" })); + const images = []; + let loadExternalImages = Promise.resolve(); + if (this.json.images) { + loadExternalImages = Promise.all( + this.json.images.map(async (image, index) => { + if (image.uri) { + const imageUrl = image.uri.slice(0, 5) === "data:" ? image.uri : `${this.rootUrl}/${image.uri}`; + images[index] = await fetch(imageUrl) + .then((response) => response.blob()) + .then((blob) => + createImageBitmap(blob, { + colorSpaceConversion: "none" + }) + ); } }) - )); - let i = Promise.resolve(); - return ( - this.json.images && - (i = Promise.all( - this.json.images.map(async (t, i) => { - if (void 0 !== t.bufferView) { - const { buffer: r, byteOffset: n, byteLength: s } = this.json.bufferViews[t.bufferView], - a = new Uint8Array(this.buffers[r], 0 === r ? n + this.glbOffset : n, s); - let o; - o = t.mimeType ? t.mimeType : 255 === a[0] ? "image/jpeg" : "image/png"; - const c = new Blob([a], { type: o }); - e[i] = await createImageBitmap(c, { colorSpaceConversion: "none" }); + ); + } + let loadInternalImages = Promise.resolve(); + if (this.json.images) { + loadInternalImages = Promise.all( + this.json.images.map(async (image, index) => { + if (image.bufferView !== undefined) { + const { buffer, byteOffset, byteLength } = this.json.bufferViews[image.bufferView]; + const array = new Uint8Array( + this.buffers[buffer], + buffer === 0 ? byteOffset + this.glbOffset : byteOffset, + byteLength + ); + let type; + if (image.mimeType) { + type = image.mimeType; + } else { + type = array[0] === 0xff ? "image/jpeg" : "image/png"; } - }) - )), - await Promise.all([t, i]), - e - ); + const blob = new Blob([array], { type }); + images[index] = await createImageBitmap(blob, { + colorSpaceConversion: "none" + }); + } + }) + ); + } + await Promise.all([loadExternalImages, loadInternalImages]); + return images; } async loadBuffes() { - const e = []; - return ( - await Promise.all( - this.json.buffers.map((t, i) => { - if (!t.uri) { - if (0 !== i) throw new Error("buffer uri undefined"); - return (e[i] = this.glbBin), Promise.resolve(); + const buffers = []; + await Promise.all( + this.json.buffers.map((buffer, index) => { + if (!buffer.uri) { + if (index !== 0) { + throw new Error("buffer uri undefined"); } - const r = "data:" === t.uri.slice(0, 5) ? t.uri : `${this.rootUrl}/${t.uri}`; - return fetch(r) - .then((e) => e.arrayBuffer()) - .then((t) => { - e[i] = t; - }); - }) - ), - e + buffers[index] = this.glbBin; + return Promise.resolve(); + } + const bufferUrl = buffer.uri.slice(0, 5) === "data:" ? buffer.uri : `${this.rootUrl}/${buffer.uri}`; + return fetch(bufferUrl) + .then((response) => response.arrayBuffer()) + .then((arrayBuffer) => { + buffers[index] = arrayBuffer; + }); + }) ); + return buffers; } parseNodes() { - this.nodes = this?.json?.nodes?.map((e) => { - const t = new nn(); - if ((this.parseNodeTRS(t, e), e.name && (t.name = e.name), null != e.mesh)) { - let i, - r = !1; - null != e.skin && ((i = this.json.skins[e.skin]), (r = !0)), - this.meshes[e.mesh].primitives.forEach((e, n, s) => { - const a = r && e.type == Z.Mesh ? new sn(e.geometry, e.material) : e; - r && - e.type == Z.Mesh && - ((s[n] = a), - a.setSkinData({ - inverseBindMatrices: this.getAccessor(i.inverseBindMatrices).getMat4Array(), - joints: i.joints - })), - t.add(a); - }); + this.nodes = this?.json?.nodes?.map((gltfNode) => { + const node = new Node(); + this.parseNodeTRS(node, gltfNode); + if (gltfNode.name) node.name = gltfNode.name; + if (gltfNode.mesh != undefined) { + let gltfSkin = undefined, + isSkinMesh = false; + if (gltfNode.skin != undefined) { + gltfSkin = this.json.skins[gltfNode.skin]; + isSkinMesh = true; + } + this.meshes[gltfNode.mesh].primitives.forEach((primitive, index, source) => { + const tempPrimitive = + isSkinMesh && primitive.type == RenderObjectType.Mesh + ? new SKinMesh(primitive.geometry, primitive.material) + : primitive; + if (isSkinMesh && primitive.type == RenderObjectType.Mesh) { + source[index] = tempPrimitive; + tempPrimitive.setSkinData({ + inverseBindMatrices: this.getAccessor(gltfSkin.inverseBindMatrices).getMat4Array(), + joints: gltfSkin.joints + // name: gltfSkin.name, + // skeleton: gltfSkin.skeleton + }); + } + node.add(tempPrimitive); + }); } - return t; + return node; }); } - parseNodeTRS(e, t) { - let { matrix: i, rotation: r, translation: n, scale: s } = t; - if (i) { - const e = new et(), - t = new Ue(), - a = new Ue(), - o = new zt(); - et.fromColumnMajorArray(i, e), - et.getScale(e, t), - et.getTranslation(e, a), - et.getRotation(e, o), - (r = o.toArray()), - (n = a.toArray()), - (s = t.toArray()); + parseNodeTRS(node, gltfNode) { + let { matrix, rotation, translation, scale } = gltfNode; + if (matrix) { + const tempMatrix4 = new Matrix4(), + tempScale = new Vector3(), + tempTranslation = new Vector3(), + tempRotation = new Quaternion(); + Matrix4.fromColumnMajorArray(matrix, tempMatrix4); + Matrix4.getScale(tempMatrix4, tempScale); + Matrix4.getTranslation(tempMatrix4, tempTranslation); + Matrix4.getRotation(tempMatrix4, tempRotation); + rotation = tempRotation.toArray(); + translation = tempTranslation.toArray(); + scale = tempScale.toArray(); } - return ( - r && e.quaternion.set(r[0], r[1], r[2], r[3]), - n && e.position.set(n[0], n[1], n[2]), - s && e.scale.set(s[0], s[1], s[2]), - e - ); + if (rotation) node.quaternion.set(rotation[0], rotation[1], rotation[2], rotation[3]); + if (translation) node.position.set(translation[0], translation[1], translation[2]); + if (scale) node.scale.set(scale[0], scale[1], scale[2]); + return node; } normalizeData() { - this?.nodes?.map?.((e, t) => { - this.json?.nodes[t]?.children?.map((t) => { - const i = this.nodes[t]; - e.add(i); + this?.nodes?.map?.((node, index) => { + this.json?.nodes[index]?.children?.map((nodeId) => { + const childNode = this.nodes[nodeId]; + node.add(childNode); }); - }), - this.meshes.map((e) => { - e.primitives.map((e) => { - e.type == Z.SkinMesh && (e.joints = e.joints.map((e) => this.nodes[e])); - }); + }); + this.meshes.map((mesh) => { + mesh.primitives.map((primitive) => { + if (primitive.type == RenderObjectType.SkinMesh) + primitive.joints = primitive.joints.map((joint) => { + return this.nodes[joint]; + }); }); + }); } } -async function pn(e) { - let t; - const i = e.split(".").pop(), - r = e.substring(0, e.lastIndexOf("/")); - if ("gltf" === i) { - const i = await fetch(e).then((e) => e.json()); - t = new mn(i, r, 0); +async function loadGLTF(url) { + let gltf; + const ext = url.split(".").pop(); + const rootUrl = url.substring(0, url.lastIndexOf("/")); + if (ext === "gltf") { + const json = await fetch(url).then((response) => response.json()); + gltf = new GLTF(json, rootUrl, 0); } else { - const i = await fetch(e).then((e) => e.arrayBuffer()), - n = new Uint32Array(i, 12, 1)[0], - s = new Uint8Array(i, 20, n), - a = JSON.parse(new TextDecoder("utf-8").decode(s)); - t = new mn(a, r, 28 + n, i); - } - return await t.parseData(), t; + const glb = await fetch(url).then((response) => response.arrayBuffer()); + const jsonLength = new Uint32Array(glb, 12, 1)[0]; + const jsonChunk = new Uint8Array(glb, 20, jsonLength); + const json = JSON.parse(new TextDecoder("utf-8").decode(jsonChunk)); + gltf = new GLTF(json, rootUrl, 28 + jsonLength, glb); + } + await gltf.parseData(); + return gltf; } -async function gn(e) { - const t = document.createElement("img"); - (t.src = e), await t.decode(); - const i = await createImageBitmap(t); - return new fe({ size: { width: i.width, height: i.height, depth: 1 }, data: { source: i }, format: "rgba8unorm" }); + +async function loadTexture(url) { + const img = document.createElement("img"); + img.src = url; + await img.decode(); + const imageBitmap = await createImageBitmap(img); + const baseTexture = new Texture({ + size: { width: imageBitmap.width, height: imageBitmap.height, depth: 1 }, + data: { + source: imageBitmap + }, + format: "rgba8unorm" + }); + return baseTexture; } -class xn { - constructor(e = 1, t = 0, i = 0) { - return (this.radius = e), (this.phi = t), (this.theta = i), this; + +// from three.js +class Spherical { + constructor(radius = 1, phi = 0, theta = 0) { + this.radius = radius; + this.phi = phi; // polar angle + this.theta = theta; // azimuthal angle + return this; } - set(e, t, i) { - return (this.radius = e), (this.phi = t), (this.theta = i), this; + set(radius, phi, theta) { + this.radius = radius; + this.phi = phi; + this.theta = theta; + return this; } - copy(e) { - return (this.radius = e.radius), (this.phi = e.phi), (this.theta = e.theta), this; + copy(other) { + this.radius = other.radius; + this.phi = other.phi; + this.theta = other.theta; + return this; } + // restrict phi to be between EPS and PI-EPS makeSafe() { - const e = 1e-6; - return (this.phi = Math.max(e, Math.min(Math.PI - e, this.phi))), this; + const EPS = 0.000001; + this.phi = Math.max(EPS, Math.min(Math.PI - EPS, this.phi)); + return this; } - setFromVector3(e) { - return this.setFromCartesianCoords(e.x, e.y, e.z); + setFromVector3(v) { + return this.setFromCartesianCoords(v.x, v.y, v.z); } - setFromCartesianCoords(e, t, i) { - return ( - (this.radius = Math.sqrt(e * e + t * t + i * i)), - 0 === this.radius - ? ((this.theta = 0), (this.phi = 0)) - : ((this.theta = Math.atan2(e, i)), (this.phi = Math.acos(ve.clamp(t / this.radius, -1, 1)))), - this - ); + setFromCartesianCoords(x, y, z) { + this.radius = Math.sqrt(x * x + y * y + z * z); + if (this.radius === 0) { + this.theta = 0; + this.phi = 0; + } else { + this.theta = Math.atan2(x, z); + this.phi = Math.acos(GMath.clamp(y / this.radius, -1, 1)); + } + return this; } clone() { - return new xn(this.radius, this.phi, this.theta); - } -} -const vn = { type: "change" }, - yn = { type: "start" }, - Sn = { type: "end" }; -class bn extends br { - constructor(e, t) { - super(), - void 0 === t && console.warn('OrbitControls: The second parameter "domElement" is now mandatory.'), - t === document && - console.error( - 'OrbitControls: "document" should not be used as the target "domElement". Please use "renderer.domElement" instead.' - ), - (this.object = e), - (this.domElement = t), - (this.domElement.style.touchAction = "none"), - (this.enabled = !0), - (this.target = new Ue()), - (this.minDistance = 0), - (this.maxDistance = 1 / 0), - (this.minZoom = 0), - (this.maxZoom = 1 / 0), - (this.minPolarAngle = 0), - (this.maxPolarAngle = Math.PI), - (this.minAzimuthAngle = -1 / 0), - (this.maxAzimuthAngle = 1 / 0), - (this.enableDamping = !1), - (this.dampingFactor = 0.05), - (this.enableZoom = !0), - (this.zoomSpeed = 1), - (this.enableRotate = !0), - (this.rotateSpeed = 1), - (this.enablePan = !0), - (this.panSpeed = 1), - (this.screenSpacePanning = !1), - (this.keyPanSpeed = 7), - (this.autoRotate = !1), - (this.autoRotateSpeed = 2), - (this.keys = { LEFT: "ArrowLeft", UP: "ArrowUp", RIGHT: "ArrowRight", BOTTOM: "ArrowDown" }), - (this.mouseButtons = { LEFT: $n.ROTATE, MIDDLE: $n.DOLLY, RIGHT: $n.PAN }), - (this.touches = { ONE: Gn.ROTATE, TWO: Gn.DOLLY_PAN }), - (this.target0 = this.target.clone()), - (this.position0 = this.object.position.clone()), - (this.zoom0 = this.object.zoom), - (this._domElementKeyEvents = null); - const i = this; - (this.update = (function () { - const e = new Ue(), - t = new zt().setFromUnitVectors(i.object.up, new Ue(0, 1, 0)), - r = t.clone().invert(), - n = new Ue(), - s = new zt(), - a = 2 * Math.PI; - return function () { - const o = i.object.position; - e.copy(o).subtract(i.target), - e.applyQuaternion(t), - Mn.setFromVector3(e), - i.autoRotate && Tn === wn.NONE && kn(i.getAutoRotationAngle()), - i.enableDamping - ? ((Mn.theta += Un.theta * i.dampingFactor), (Mn.phi += Un.phi * i.dampingFactor)) - : ((Mn.theta += Un.theta), (Mn.phi += Un.phi)); - let c = i.minAzimuthAngle, - l = i.maxAzimuthAngle; - return ( - isFinite(c) && - isFinite(l) && - (c < -Math.PI ? (c += a) : c > Math.PI && (c -= a), - l < -Math.PI ? (l += a) : l > Math.PI && (l -= a), - (Mn.theta = - c <= l - ? Math.max(c, Math.min(l, Mn.theta)) - : Mn.theta > (c + l) / 2 - ? Math.max(c, Mn.theta) - : Math.min(l, Mn.theta))), - (Mn.phi = Math.max(i.minPolarAngle, Math.min(i.maxPolarAngle, Mn.phi))), - Mn.makeSafe(), - (Mn.radius *= _n), - (Mn.radius = Math.max(i.minDistance, Math.min(i.maxDistance, Mn.radius))), - !0 === i.enableDamping ? i.target.addScaledVector(Ln, i.dampingFactor) : i.target.add(Ln), - Ue.fromSpherical(Mn, e), - e.applyQuaternion(r), - o.copy(i.target).add(e), - i.object.lookAt(i.target.x, i.target.y, i.target.z), - !0 === i.enableDamping - ? ((Un.theta *= 1 - i.dampingFactor), - (Un.phi *= 1 - i.dampingFactor), - Ue.multiplyByScalar(Ln, 1 - i.dampingFactor, Ln)) - : (Un.set(0, 0, 0), Ln.set(0, 0, 0)), - (_n = 1), - !!( - Cn || - Ue.distanceSquared(n, i.object.position) > En || - 8 * (1 - s.dot(i.object.quaternion)) > En - ) && - (i.dispatchEvent(vn), - Ue.clone(i.object.position, n), - zt.clone(i.object.quaternion, s), - (Cn = !1), - !0) - ); + return new Spherical(this.radius, this.phi, this.theta); + } +} + +//from three.js +const _changeEvent = { type: "change" }; +const _startEvent = { type: "start" }; +const _endEvent = { type: "end" }; +class OrbitControl extends EventDispatcher { + constructor(object, domElement) { + super(); + if (domElement === undefined) + console.warn('OrbitControls: The second parameter "domElement" is now mandatory.'); + if (domElement === document) + console.error( + 'OrbitControls: "document" should not be used as the target "domElement". Please use "renderer.domElement" instead.' + ); + this.object = object; + this.domElement = domElement; + this.domElement.style.touchAction = "none"; // disable touch scroll + // Set to false to disable this control + this.enabled = true; + // "target" sets the location of focus, where the object orbits around + this.target = new Vector3(); + // How far you can dolly in and out ( PerspectiveCamera only ) + this.minDistance = 0; + this.maxDistance = Infinity; + // How far you can zoom in and out ( OrthographicCamera only ) + this.minZoom = 0; + this.maxZoom = Infinity; + // How far you can orbit vertically, upper and lower limits. + // Range is 0 to Math.PI radians. + this.minPolarAngle = 0; // radians + this.maxPolarAngle = Math.PI; // radians + // How far you can orbit horizontally, upper and lower limits. + // If set, the interval [ min, max ] must be a sub-interval of [ - 2 PI, 2 PI ], with ( max - min < 2 PI ) + this.minAzimuthAngle = -Infinity; // radians + this.maxAzimuthAngle = Infinity; // radians + // Set to true to enable damping (inertia) + // If damping is enabled, you must call controls.update() in your animation loop + this.enableDamping = false; + this.dampingFactor = 0.05; + // This option actually enables dollying in and out; left as "zoom" for backwards compatibility. + // Set to false to disable zooming + this.enableZoom = true; + this.zoomSpeed = 1.0; + // Set to false to disable rotating + this.enableRotate = true; + this.rotateSpeed = 1.0; + // Set to false to disable panning + this.enablePan = true; + this.panSpeed = 1.0; + this.screenSpacePanning = false; // if false, pan orthogonal to world-space direction camera.up + this.keyPanSpeed = 7.0; // pixels moved per arrow key push + // Set to true to automatically rotate around the target + // If auto-rotate is enabled, you must call controls.update() in your animation loop + this.autoRotate = false; + this.autoRotateSpeed = 2.0; // 30 seconds per orbit when fps is 60 + // The four arrow keys + this.keys = { + LEFT: "ArrowLeft", + UP: "ArrowUp", + RIGHT: "ArrowRight", + BOTTOM: "ArrowDown" + }; + // Mouse buttons + this.mouseButtons = { + LEFT: MOUSE.ROTATE, + MIDDLE: MOUSE.DOLLY, + RIGHT: MOUSE.PAN + }; + // Touch fingers + this.touches = { ONE: TOUCH.ROTATE, TWO: TOUCH.DOLLY_PAN }; + // for reset + this.target0 = this.target.clone(); + this.position0 = this.object.position.clone(); + this.zoom0 = this.object.zoom; + // the target DOM element for key events + this._domElementKeyEvents = null; + // + // public methods + // + // this method is exposed, but perhaps it would be better if we can make it private... + const that = this; + this.update = (function () { + const offset = new Vector3(); + // so camera.up is the orbit axis + const quat = new Quaternion().setFromUnitVectors(that.object.up, new Vector3(0, 1, 0)); + const quatInverse = quat.clone().invert(); + const lastPosition = new Vector3(); + const lastQuaternion = new Quaternion(); + const twoPI = 2 * Math.PI; + return function update() { + const position = that.object.position; + offset.copy(position).subtract(that.target); + // rotate offset to "y-axis-is-up" space + offset.applyQuaternion(quat); + // angle from z-axis around y-axis + spherical.setFromVector3(offset); + if (that.autoRotate && state === STATE.NONE) { + rotateLeft(that.getAutoRotationAngle()); + } + if (that.enableDamping) { + spherical.theta += sphericalDelta.theta * that.dampingFactor; + spherical.phi += sphericalDelta.phi * that.dampingFactor; + } else { + spherical.theta += sphericalDelta.theta; + spherical.phi += sphericalDelta.phi; + } + // restrict theta to be between desired limits + let min = that.minAzimuthAngle; + let max = that.maxAzimuthAngle; + if (isFinite(min) && isFinite(max)) { + if (min < -Math.PI) min += twoPI; + else if (min > Math.PI) min -= twoPI; + if (max < -Math.PI) max += twoPI; + else if (max > Math.PI) max -= twoPI; + if (min <= max) { + spherical.theta = Math.max(min, Math.min(max, spherical.theta)); + } else { + spherical.theta = + spherical.theta > (min + max) / 2 + ? Math.max(min, spherical.theta) + : Math.min(max, spherical.theta); + } + } + // restrict phi to be between desired limits + spherical.phi = Math.max(that.minPolarAngle, Math.min(that.maxPolarAngle, spherical.phi)); + spherical.makeSafe(); + spherical.radius *= scale; + // restrict radius to be between desired limits + spherical.radius = Math.max(that.minDistance, Math.min(that.maxDistance, spherical.radius)); + // move target to panned location + if (that.enableDamping === true) { + that.target.addScaledVector(panOffset, that.dampingFactor); + } else { + that.target.add(panOffset); + } + Vector3.fromSpherical(spherical, offset); + // rotate offset back to "camera-up-vector-is-up" space + offset.applyQuaternion(quatInverse); + position.copy(that.target).add(offset); + that.object.lookAt(that.target.x, that.target.y, that.target.z); + if (that.enableDamping === true) { + sphericalDelta.theta *= 1 - that.dampingFactor; + sphericalDelta.phi *= 1 - that.dampingFactor; + Vector3.multiplyByScalar(panOffset, 1 - that.dampingFactor, panOffset); + // panOffset.multiplyScalar( 1 - this.dampingFactor ); + } else { + sphericalDelta.set(0, 0, 0); + panOffset.set(0, 0, 0); + } + scale = 1; + // update condition is: + // min(camera displacement, camera rotation in radians)^2 > EPS + // using small-angle approximation cos(x/2) = 1 - x^2 / 8 + if ( + zoomChanged || + Vector3.distanceSquared(lastPosition, that.object.position) > EPS || + 8 * (1 - lastQuaternion.dot(that.object.quaternion)) > EPS + ) { + that.dispatchEvent(_changeEvent); + //lastPosition.copy( this.object.position ); + Vector3.clone(that.object.position, lastPosition); + Quaternion.clone(that.object.quaternion, lastQuaternion); + //lastQuaternion.copy( this.object.quaternion ); + zoomChanged = false; + return true; + } + return false; }; - })()), - this.init(); + })(); + this.init(); } getPolarAngle() { return this.spherical.phi; @@ -11916,350 +15986,453 @@ class bn extends br { return this.spherical.theta; } getDistance() { - return Ue.distance(this.object.position, this.target); + return Vector3.distance(this.object.position, this.target); } - listenToKeyEvents(e) { - e.addEventListener("keydown", this.onKeyDown), (this._domElementKeyEvents = e); + listenToKeyEvents(domElement) { + domElement.addEventListener("keydown", this.onKeyDown); + this._domElementKeyEvents = domElement; } saveState() { - Ue.clone(this.target, this.target0), - Ue.clone(this.object.position, this.position0), - (this.zoom0 = this.object.zoom); + Vector3.clone(this.target, this.target0); + //this.target0.copy( this.target ); + Vector3.clone(this.object.position, this.position0); + //this.position0.copy( this.object.position ); + this.zoom0 = this.object.zoom; } reset() { - Ue.clone(this.target0, this.target), - Ue.clone(this.position0, this.object.position), - (this.object.zoom = this.zoom0), - this.object.updateProjectionMatrix(), - this.dispatchEvent(vn), - this.update(), - (Tn = wn.NONE); + Vector3.clone(this.target0, this.target); + //this.target.copy( this.target0 ); + Vector3.clone(this.position0, this.object.position); + //this.object.position.copy( this.position0 ); + this.object.zoom = this.zoom0; + this.object.updateProjectionMatrix(); + this.dispatchEvent(_changeEvent); + this.update(); + state = STATE.NONE; } init() { - const e = this, - t = (function () { - const e = new Ue(); - return function (t, i) { - e.setFromMatrixColumn(i, 0), e.multiplyByScalar(-t), Ln.add(e); - }; - })(), - i = (function () { - const t = new Ue(); - return function (i, r) { - !0 === e.screenSpacePanning - ? t.setFromMatrixColumn(r, 1) - : (t.setFromMatrixColumn(r, 0), Ue.cross(e.object.up, t, t)), - t.multiplyByScalar(i), - Ln.add(t); - }; - })(), - r = (function () { - const r = new Ue(); - return function (n, s) { - const a = e.domElement; - if (e.object.isPerspectiveCamera) { - const o = e.object.position; - r.copy(o).subtract(e.target); - let c = r.length(); - (c *= Math.tan(((e.object.fov / 2) * Math.PI) / 180)), - t((2 * n * c) / a.clientHeight, e.object.modelMatrix), - i((2 * s * c) / a.clientHeight, e.object.modelMatrix); - } else - e.object.isOrthographicCamera - ? (t( - (n * (e.object.right - e.object.left)) / e.object.zoom / a.clientWidth, - e.object.modelMatrix - ), - i( - (s * (e.object.top - e.object.bottom)) / e.object.zoom / a.clientHeight, - e.object.modelMatrix - )) - : (console.warn( - "WARNING: OrbitControls.js encountered an unknown camera type - pan disabled." - ), - (e.enablePan = !1)); - }; - })(), - n = (e) => { - this.object.isPerspectiveCamera - ? (_n /= e) - : this.object.isOrthographicCamera - ? ((this.object.zoom = Math.max(this.minZoom, Math.min(this.maxZoom, this.object.zoom * e))), - this.object.updateProjectionMatrix(), - (Cn = !0)) - : (console.warn( - "WARNING: OrbitControls.js encountered an unknown camera type - dolly/zoom disabled." - ), - (this.enableZoom = !1)); - }, - s = (e) => { - this.object.isPerspectiveCamera - ? (_n *= e) - : this.object.isOrthographicCamera - ? ((this.object.zoom = Math.max(this.minZoom, Math.min(this.maxZoom, this.object.zoom / e))), - this.object.updateProjectionMatrix(), - (Cn = !0)) - : (console.warn( - "WARNING: OrbitControls.js encountered an unknown camera type - dolly/zoom disabled." - ), - (this.enableZoom = !1)); - }, - a = (e) => { - An.set(e.clientX, e.clientY), Se.subtract(An, Rn, Dn), Se.multiplyByScalar(Dn, this.rotateSpeed, Dn); - const t = this.domElement; - kn((2 * Math.PI * Dn.x) / t.clientHeight), - qn((2 * Math.PI * Dn.y) / t.clientHeight), - Se.clone(An, Rn), - this.update(); - }, - o = (e) => { - Bn.set(e.clientX, e.clientY), - Se.subtract(Bn, Nn, On), - On.y > 0 ? n(w()) : On.y < 0 && s(w()), - Se.clone(Bn, Nn), - this.update(); - }, - c = (e) => { - In.set(e.clientX, e.clientY), - Se.subtract(In, zn, Pn), - Se.multiplyByScalar(Pn, this.panSpeed, Pn), - r(Pn.x, Pn.y), - Se.clone(In, zn), - this.update(); - }, - l = (e) => { - e.deltaY < 0 ? s(w()) : e.deltaY > 0 && n(w()), this.update(); - }, - h = (e) => { - let t = !1; - switch (e.code) { - case this.keys.UP: - r(0, this.keyPanSpeed), (t = !0); - break; - case this.keys.BOTTOM: - r(0, -this.keyPanSpeed), (t = !0); - break; - case this.keys.LEFT: - r(this.keyPanSpeed, 0), (t = !0); - break; - case this.keys.RIGHT: - r(-this.keyPanSpeed, 0), (t = !0); - } - t && (e.preventDefault(), this.update()); - }, - u = () => { - this.enableZoom && Jn(), this.enablePan && Qn(); - }, - f = () => { - this.enableZoom && Jn(), this.enableRotate && Kn(); - }, - d = (e) => { - if (1 == Vn.length) An.set(e.pageX, e.pageY); - else { - const t = Xn(e), - i = 0.5 * (e.pageX + t.x), - r = 0.5 * (e.pageY + t.y); - An.set(i, r); - } - Se.subtract(An, Rn, Dn), Se.multiplyByScalar(Dn, this.rotateSpeed, Dn); - const t = this.domElement; - kn((2 * Math.PI * Dn.x) / t.clientHeight), qn((2 * Math.PI * Dn.y) / t.clientHeight), Se.clone(An, Rn); - }, - m = (e) => { - if (1 === Vn.length) In.set(e.pageX, e.pageY); - else { - const t = Xn(e), - i = 0.5 * (e.pageX + t.x), - r = 0.5 * (e.pageY + t.y); - In.set(i, r); - } - Se.subtract(In, zn, Pn), Se.multiplyByScalar(Pn, this.panSpeed, Pn), r(Pn.x, Pn.y), Se.clone(In, zn); - }, - p = (e) => { - const t = Xn(e), - i = e.pageX - t.x, - r = e.pageY - t.y, - s = Math.sqrt(i * i + r * r); - Bn.set(0, s), On.set(0, Math.pow(Bn.y / Nn.y, this.zoomSpeed)), n(On.y), Se.clone(Bn, Nn); - }, - g = (e) => { - this.enableZoom && p(e), this.enablePan && m(e); - }, - x = (e) => { - this.enableZoom && p(e), this.enableRotate && d(e); + const that = this; + const panLeft = (function () { + const v = new Vector3(); + return function panLeft(distance, objectMatrix) { + v.setFromMatrixColumn(objectMatrix, 0); // get X column of objectMatrix + v.multiplyByScalar(-distance); + panOffset.add(v); }; - (this.onPointerDown = (e) => { - !1 !== this.enabled && - (0 === Vn.length && - (this.domElement.setPointerCapture(e.pointerId), - this.domElement.addEventListener("pointermove", this.onPointerMove), - this.domElement.addEventListener("pointerup", this.onPointerUp)), - (function (e) { - Vn.push(e); - })(e), - "touch" === e.pointerType ? S(e) : v(e)); - }), - (this.onPointerMove = (e) => { - !1 !== this.enabled && ("touch" === e.pointerType ? b(e) : y(e)); - }), - (this.onPointerUp = (e) => { - jn(e), - 0 === Vn.length && - (this.domElement.releasePointerCapture(e.pointerId), - this.domElement.removeEventListener("pointermove", this.onPointerMove), - this.domElement.removeEventListener("pointerup", this.onPointerUp)), - this.dispatchEvent(Sn), - (Tn = wn.NONE); - }); - const v = (e) => { - let t; - switch (e.button) { - case 0: - t = this.mouseButtons.LEFT; - break; - case 1: - t = this.mouseButtons.MIDDLE; - break; - case 2: - t = this.mouseButtons.RIGHT; - break; - default: - t = -1; - } - switch (t) { - case $n.DOLLY: - if (!1 === this.enableZoom) return; - !(function (e) { - Nn.set(e.clientX, e.clientY); - })(e), - (Tn = wn.DOLLY); - break; - case $n.ROTATE: - if (e.ctrlKey || e.metaKey || e.shiftKey) { - if (!1 === this.enablePan) return; - Wn(e), (Tn = wn.PAN); - } else { - if (!1 === this.enableRotate) return; - Yn(e), (Tn = wn.ROTATE); - } - break; - case $n.PAN: - if (e.ctrlKey || e.metaKey || e.shiftKey) { - if (!1 === this.enableRotate) return; - Yn(e), (Tn = wn.ROTATE); - } else { - if (!1 === this.enablePan) return; - Wn(e), (Tn = wn.PAN); - } - break; - default: - Tn = wn.NONE; - } - Tn !== wn.NONE && this.dispatchEvent(yn); - }, - y = (e) => { - switch (Tn) { - case wn.ROTATE: - if (!1 === this.enableRotate) return; - a(e); - break; - case wn.DOLLY: - if (!1 === this.enableZoom) return; - o(e); - break; - case wn.PAN: - if (!1 === this.enablePan) return; - c(e); + })(); + const panUp = (function () { + const panUpV = new Vector3(); + return function panUp(distance, objectMatrix) { + if (that.screenSpacePanning === true) { + panUpV.setFromMatrixColumn(objectMatrix, 1); + } else { + panUpV.setFromMatrixColumn(objectMatrix, 0); + //panUpV.crossVectors( this.object.up, panUpV ); + Vector3.cross(that.object.up, panUpV, panUpV); } + panUpV.multiplyByScalar(distance); + panOffset.add(panUpV); }; - (this.onMouseWheel = (e) => { - !1 !== this.enabled && - !1 !== this.enableZoom && - Tn === wn.NONE && - (e.preventDefault(), this.dispatchEvent(yn), l(e), this.dispatchEvent(Sn)); - }), - (this.onKeyDown = (e) => { - !1 !== this.enabled && !1 !== this.enablePan && h(e); - }); - const S = (e) => { - switch ((Hn(e), Vn.length)) { - case 1: - switch (this.touches.ONE) { - case Gn.ROTATE: - if (!1 === this.enableRotate) return; - Kn(), (Tn = wn.TOUCH_ROTATE); - break; - case Gn.PAN: - if (!1 === this.enablePan) return; - Qn(), (Tn = wn.TOUCH_PAN); - break; - default: - Tn = wn.NONE; - } - break; - case 2: - switch (this.touches.TWO) { - case Gn.DOLLY_PAN: - if (!1 === this.enableZoom && !1 === this.enablePan) return; - u(), (Tn = wn.TOUCH_DOLLY_PAN); - break; - case Gn.DOLLY_ROTATE: - if (!1 === this.enableZoom && !1 === this.enableRotate) return; - f(), (Tn = wn.TOUCH_DOLLY_ROTATE); - break; - default: - Tn = wn.NONE; - } - break; - default: - Tn = wn.NONE; - } - Tn !== wn.NONE && this.dispatchEvent(yn); - }, - b = (e) => { - switch ((Hn(e), Tn)) { - case wn.TOUCH_ROTATE: - if (!1 === this.enableRotate) return; - d(e), this.update(); - break; - case wn.TOUCH_PAN: - if (!1 === this.enablePan) return; - m(e), this.update(); - break; - case wn.TOUCH_DOLLY_PAN: - if (!1 === this.enableZoom && !1 === this.enablePan) return; - g(e), this.update(); - break; - case wn.TOUCH_DOLLY_ROTATE: - if (!1 === this.enableZoom && !1 === this.enableRotate) return; - x(e), this.update(); - break; - default: - Tn = wn.NONE; + })(); + // deltaX and deltaY are in pixels; right and down are positive + const pan = (function () { + const offset = new Vector3(); + return function pan(deltaX, deltaY) { + const element = that.domElement; + if (that.object.isPerspectiveCamera) { + // perspective + const position = that.object.position; + offset.copy(position).subtract(that.target); + let targetDistance = offset.length(); + // half of the fov is center to top of screen + targetDistance *= Math.tan(((that.object.fov / 2) * Math.PI) / 180.0); + // we use only clientHeight here so aspect ratio does not distort speed + panLeft((2 * deltaX * targetDistance) / element.clientHeight, that.object.modelMatrix); + panUp((2 * deltaY * targetDistance) / element.clientHeight, that.object.modelMatrix); + } else if (that.object.isOrthographicCamera) { + // orthographic + panLeft( + (deltaX * (that.object.right - that.object.left)) / that.object.zoom / element.clientWidth, + that.object.modelMatrix + ); + panUp( + (deltaY * (that.object.top - that.object.bottom)) / that.object.zoom / element.clientHeight, + that.object.modelMatrix + ); + } else { + // camera neither orthographic nor perspective + console.warn("WARNING: OrbitControls.js encountered an unknown camera type - pan disabled."); + that.enablePan = false; } }; - (this.onContextMenu = (e) => { - !1 !== this.enabled && e.preventDefault(); - }), - (this.getAutoRotationAngle = () => ((2 * Math.PI) / 60 / 60) * this.autoRotateSpeed); - const w = () => Math.pow(0.95, this.zoomSpeed); - this.domElement.addEventListener("contextmenu", this.onContextMenu), - this.domElement.addEventListener("pointerdown", this.onPointerDown), - this.domElement.addEventListener("pointercancel", Zn), - this.domElement.addEventListener("wheel", this.onMouseWheel, { passive: !1 }); + })(); + const dollyOut = (dollyScale) => { + if (this.object.isPerspectiveCamera) { + scale /= dollyScale; + } else if (this.object.isOrthographicCamera) { + this.object.zoom = Math.max(this.minZoom, Math.min(this.maxZoom, this.object.zoom * dollyScale)); + this.object.updateProjectionMatrix(); + zoomChanged = true; + } else { + console.warn("WARNING: OrbitControls.js encountered an unknown camera type - dolly/zoom disabled."); + this.enableZoom = false; + } + }; + const dollyIn = (dollyScale) => { + if (this.object.isPerspectiveCamera) { + scale *= dollyScale; + } else if (this.object.isOrthographicCamera) { + this.object.zoom = Math.max(this.minZoom, Math.min(this.maxZoom, this.object.zoom / dollyScale)); + this.object.updateProjectionMatrix(); + zoomChanged = true; + } else { + console.warn("WARNING: OrbitControls.js encountered an unknown camera type - dolly/zoom disabled."); + this.enableZoom = false; + } + }; + const handleMouseMoveRotate = (event) => { + rotateEnd.set(event.clientX, event.clientY); + Vector2.subtract(rotateEnd, rotateStart, rotateDelta); + Vector2.multiplyByScalar(rotateDelta, this.rotateSpeed, rotateDelta); + //rotateDelta.subVectors( rotateEnd, rotateStart ).multiplyScalar( this.rotateSpeed ); + const element = this.domElement; + rotateLeft((2 * Math.PI * rotateDelta.x) / element.clientHeight); // yes, height + rotateUp((2 * Math.PI * rotateDelta.y) / element.clientHeight); + Vector2.clone(rotateEnd, rotateStart); + //rotateStart.copy( rotateEnd ); + this.update(); + }; + const handleMouseMoveDolly = (event) => { + dollyEnd.set(event.clientX, event.clientY); + Vector2.subtract(dollyEnd, dollyStart, dollyDelta); + // dollyDelta.subVectors( dollyEnd, dollyStart ); + if (dollyDelta.y > 0) { + dollyOut(getZoomScale()); + } else if (dollyDelta.y < 0) { + dollyIn(getZoomScale()); + } + Vector2.clone(dollyEnd, dollyStart); + // dollyStart.copy( dollyEnd ); + this.update(); + }; + const handleMouseMovePan = (event) => { + panEnd.set(event.clientX, event.clientY); + Vector2.subtract(panEnd, panStart, panDelta); + Vector2.multiplyByScalar(panDelta, this.panSpeed, panDelta); + //panDelta.subVectors( panEnd, panStart ).multiplyScalar( this.panSpeed ); + pan(panDelta.x, panDelta.y); + Vector2.clone(panEnd, panStart); + //panStart.copy( panEnd ); + this.update(); + }; + const handleMouseWheel = (event) => { + if (event.deltaY < 0) { + dollyIn(getZoomScale()); + } else if (event.deltaY > 0) { + dollyOut(getZoomScale()); + } + this.update(); + }; + const handleKeyDown = (event) => { + let needsUpdate = false; + switch (event.code) { + case this.keys.UP: + pan(0, this.keyPanSpeed); + needsUpdate = true; + break; + case this.keys.BOTTOM: + pan(0, -this.keyPanSpeed); + needsUpdate = true; + break; + case this.keys.LEFT: + pan(this.keyPanSpeed, 0); + needsUpdate = true; + break; + case this.keys.RIGHT: + pan(-this.keyPanSpeed, 0); + needsUpdate = true; + break; + } + if (needsUpdate) { + // prevent the browser from scrolling on cursor keys + event.preventDefault(); + this.update(); + } + }; + const handleTouchStartDollyPan = () => { + if (this.enableZoom) handleTouchStartDolly(); + if (this.enablePan) handleTouchStartPan(); + }; + const handleTouchStartDollyRotate = () => { + if (this.enableZoom) handleTouchStartDolly(); + if (this.enableRotate) handleTouchStartRotate(); + }; + const handleTouchMoveRotate = (event) => { + if (pointers.length == 1) { + rotateEnd.set(event.pageX, event.pageY); + } else { + const position = getSecondPointerPosition(event); + const x = 0.5 * (event.pageX + position.x); + const y = 0.5 * (event.pageY + position.y); + rotateEnd.set(x, y); + } + Vector2.subtract(rotateEnd, rotateStart, rotateDelta); + Vector2.multiplyByScalar(rotateDelta, this.rotateSpeed, rotateDelta); + //rotateDelta.subVectors( rotateEnd, rotateStart ).multiplyScalar( this.rotateSpeed ); + const element = this.domElement; + rotateLeft((2 * Math.PI * rotateDelta.x) / element.clientHeight); // yes, height + rotateUp((2 * Math.PI * rotateDelta.y) / element.clientHeight); + Vector2.clone(rotateEnd, rotateStart); + //rotateStart.copy( rotateEnd ); + }; + const handleTouchMovePan = (event) => { + if (pointers.length === 1) { + panEnd.set(event.pageX, event.pageY); + } else { + const position = getSecondPointerPosition(event); + const x = 0.5 * (event.pageX + position.x); + const y = 0.5 * (event.pageY + position.y); + panEnd.set(x, y); + } + Vector2.subtract(panEnd, panStart, panDelta); + Vector2.multiplyByScalar(panDelta, this.panSpeed, panDelta); + //panDelta.subVectors( panEnd, panStart ).multiplyScalar( this.panSpeed ); + pan(panDelta.x, panDelta.y); + Vector2.clone(panEnd, panStart); + // panStart.copy( panEnd ); + }; + const handleTouchMoveDolly = (event) => { + const position = getSecondPointerPosition(event); + const dx = event.pageX - position.x; + const dy = event.pageY - position.y; + const distance = Math.sqrt(dx * dx + dy * dy); + dollyEnd.set(0, distance); + dollyDelta.set(0, Math.pow(dollyEnd.y / dollyStart.y, this.zoomSpeed)); + dollyOut(dollyDelta.y); + Vector2.clone(dollyEnd, dollyStart); + //dollyStart.copy( dollyEnd ); + }; + const handleTouchMoveDollyPan = (event) => { + if (this.enableZoom) handleTouchMoveDolly(event); + if (this.enablePan) handleTouchMovePan(event); + }; + const handleTouchMoveDollyRotate = (event) => { + if (this.enableZoom) handleTouchMoveDolly(event); + if (this.enableRotate) handleTouchMoveRotate(event); + }; + // + // event handlers - FSM: listen for events and reset state + // + this.onPointerDown = (event) => { + if (this.enabled === false) return; + if (pointers.length === 0) { + this.domElement.setPointerCapture(event.pointerId); + this.domElement.addEventListener("pointermove", this.onPointerMove); + this.domElement.addEventListener("pointerup", this.onPointerUp); + } + // + addPointer(event); + if (event.pointerType === "touch") { + onTouchStart(event); + } else { + onMouseDown(event); + } + }; + this.onPointerMove = (event) => { + if (this.enabled === false) return; + if (event.pointerType === "touch") { + onTouchMove(event); + } else { + onMouseMove(event); + } + }; + this.onPointerUp = (event) => { + removePointer(event); + if (pointers.length === 0) { + this.domElement.releasePointerCapture(event.pointerId); + this.domElement.removeEventListener("pointermove", this.onPointerMove); + this.domElement.removeEventListener("pointerup", this.onPointerUp); + } + this.dispatchEvent(_endEvent); + state = STATE.NONE; + }; + const onMouseDown = (event) => { + let mouseAction; + switch (event.button) { + case 0: + mouseAction = this.mouseButtons.LEFT; + break; + case 1: + mouseAction = this.mouseButtons.MIDDLE; + break; + case 2: + mouseAction = this.mouseButtons.RIGHT; + break; + default: + mouseAction = -1; + } + switch (mouseAction) { + case MOUSE.DOLLY: + if (this.enableZoom === false) return; + handleMouseDownDolly(event); + state = STATE.DOLLY; + break; + case MOUSE.ROTATE: + if (event.ctrlKey || event.metaKey || event.shiftKey) { + if (this.enablePan === false) return; + handleMouseDownPan(event); + state = STATE.PAN; + } else { + if (this.enableRotate === false) return; + handleMouseDownRotate(event); + state = STATE.ROTATE; + } + break; + case MOUSE.PAN: + if (event.ctrlKey || event.metaKey || event.shiftKey) { + if (this.enableRotate === false) return; + handleMouseDownRotate(event); + state = STATE.ROTATE; + } else { + if (this.enablePan === false) return; + handleMouseDownPan(event); + state = STATE.PAN; + } + break; + default: + state = STATE.NONE; + } + if (state !== STATE.NONE) { + this.dispatchEvent(_startEvent); + } + }; + const onMouseMove = (event) => { + switch (state) { + case STATE.ROTATE: + if (this.enableRotate === false) return; + handleMouseMoveRotate(event); + break; + case STATE.DOLLY: + if (this.enableZoom === false) return; + handleMouseMoveDolly(event); + break; + case STATE.PAN: + if (this.enablePan === false) return; + handleMouseMovePan(event); + break; + } + }; + this.onMouseWheel = (event) => { + if (this.enabled === false || this.enableZoom === false || state !== STATE.NONE) return; + event.preventDefault(); + this.dispatchEvent(_startEvent); + handleMouseWheel(event); + this.dispatchEvent(_endEvent); + }; + this.onKeyDown = (event) => { + if (this.enabled === false || this.enablePan === false) return; + handleKeyDown(event); + }; + const onTouchStart = (event) => { + trackPointer(event); + switch (pointers.length) { + case 1: + switch (this.touches.ONE) { + case TOUCH.ROTATE: + if (this.enableRotate === false) return; + handleTouchStartRotate(); + state = STATE.TOUCH_ROTATE; + break; + case TOUCH.PAN: + if (this.enablePan === false) return; + handleTouchStartPan(); + state = STATE.TOUCH_PAN; + break; + default: + state = STATE.NONE; + } + break; + case 2: + switch (this.touches.TWO) { + case TOUCH.DOLLY_PAN: + if (this.enableZoom === false && this.enablePan === false) return; + handleTouchStartDollyPan(); + state = STATE.TOUCH_DOLLY_PAN; + break; + case TOUCH.DOLLY_ROTATE: + if (this.enableZoom === false && this.enableRotate === false) return; + handleTouchStartDollyRotate(); + state = STATE.TOUCH_DOLLY_ROTATE; + break; + default: + state = STATE.NONE; + } + break; + default: + state = STATE.NONE; + } + if (state !== STATE.NONE) { + this.dispatchEvent(_startEvent); + } + }; + const onTouchMove = (event) => { + trackPointer(event); + switch (state) { + case STATE.TOUCH_ROTATE: + if (this.enableRotate === false) return; + handleTouchMoveRotate(event); + this.update(); + break; + case STATE.TOUCH_PAN: + if (this.enablePan === false) return; + handleTouchMovePan(event); + this.update(); + break; + case STATE.TOUCH_DOLLY_PAN: + if (this.enableZoom === false && this.enablePan === false) return; + handleTouchMoveDollyPan(event); + this.update(); + break; + case STATE.TOUCH_DOLLY_ROTATE: + if (this.enableZoom === false && this.enableRotate === false) return; + handleTouchMoveDollyRotate(event); + this.update(); + break; + default: + state = STATE.NONE; + } + }; + this.onContextMenu = (event) => { + if (this.enabled === false) return; + event.preventDefault(); + }; + this.getAutoRotationAngle = () => { + return ((2 * Math.PI) / 60 / 60) * this.autoRotateSpeed; + }; + const getZoomScale = () => { + return Math.pow(0.95, this.zoomSpeed); + }; + this.domElement.addEventListener("contextmenu", this.onContextMenu); + this.domElement.addEventListener("pointerdown", this.onPointerDown); + this.domElement.addEventListener("pointercancel", onPointerCancel); + this.domElement.addEventListener("wheel", this.onMouseWheel, { + passive: false + }); } dispose() { - this.domElement.removeEventListener("contextmenu", this.onContextMenu), - this.domElement.removeEventListener("pointerdown", this.onPointerDown), - this.domElement.removeEventListener("pointercancel", Zn), - this.domElement.removeEventListener("wheel", this.onMouseWheel), - this.domElement.removeEventListener("pointermove", this.onPointerMove), - this.domElement.removeEventListener("pointerup", this.onPointerUp), - null !== this._domElementKeyEvents && - this._domElementKeyEvents.removeEventListener("keydown", this.onKeyDown); + this.domElement.removeEventListener("contextmenu", this.onContextMenu); + this.domElement.removeEventListener("pointerdown", this.onPointerDown); + this.domElement.removeEventListener("pointercancel", onPointerCancel); + this.domElement.removeEventListener("wheel", this.onMouseWheel); + this.domElement.removeEventListener("pointermove", this.onPointerMove); + this.domElement.removeEventListener("pointerup", this.onPointerUp); + if (this._domElementKeyEvents !== null) { + this._domElementKeyEvents.removeEventListener("keydown", this.onKeyDown); + } + //this.dispatchEvent( { type: 'dispose' } ); // should this be added here? } } -const wn = { +const STATE = { NONE: -1, ROTATE: 0, DOLLY: 1, @@ -12269,149 +16442,170 @@ const wn = { TOUCH_DOLLY_PAN: 5, TOUCH_DOLLY_ROTATE: 6 }; -let Tn = wn.NONE; -const En = 1e-6, - Mn = new xn(), - Un = new xn(); -let _n = 1; -const Ln = new Ue(); -let Cn = !1; -const Rn = new Se(), - An = new Se(), - Dn = new Se(), - zn = new Se(), - In = new Se(), - Pn = new Se(), - Nn = new Se(), - Bn = new Se(), - On = new Se(), - Vn = [], - Fn = {}; -var $n, Gn; -function kn(e) { - Un.theta -= e; -} -function qn(e) { - Un.phi -= e; -} -function jn(e) { - delete Fn[e.pointerId]; - for (let t = 0; t < Vn.length; t++) if (Vn[t].pointerId == e.pointerId) return void Vn.splice(t, 1); -} -function Hn(e) { - let t = Fn[e.pointerId]; - void 0 === t && ((t = new Se()), (Fn[e.pointerId] = t)), t.set(e.pageX, e.pageY); -} -function Xn(e) { - const t = e.pointerId === Vn[0].pointerId ? Vn[1] : Vn[0]; - return Fn[t.pointerId]; -} -function Yn(e) { - Rn.set(e.clientX, e.clientY); -} -function Wn(e) { - zn.set(e.clientX, e.clientY); -} -function Zn(e) { - jn(e); -} -function Kn() { - if (1 === Vn.length) Rn.set(Vn[0].pageX, Vn[0].pageY); - else { - const e = 0.5 * (Vn[0].pageX + Vn[1].pageX), - t = 0.5 * (Vn[0].pageY + Vn[1].pageY); - Rn.set(e, t); - } -} -function Qn() { - if (1 === Vn.length) zn.set(Vn[0].pageX, Vn[0].pageY); - else { - const e = 0.5 * (Vn[0].pageX + Vn[1].pageX), - t = 0.5 * (Vn[0].pageY + Vn[1].pageY); - zn.set(e, t); - } -} -function Jn() { - const e = Vn[0].pageX - Vn[1].pageX, - t = Vn[0].pageY - Vn[1].pageY, - i = Math.sqrt(e * e + t * t); - Nn.set(0, i); -} -!(function (e) { - (e[(e.LEFT = 0)] = "LEFT"), - (e[(e.MIDDLE = 1)] = "MIDDLE"), - (e[(e.RIGHT = 2)] = "RIGHT"), - (e[(e.ROTATE = 0)] = "ROTATE"), - (e[(e.DOLLY = 1)] = "DOLLY"), - (e[(e.PAN = 2)] = "PAN"); -})($n || ($n = {})), - (function (e) { - (e[(e.ROTATE = 0)] = "ROTATE"), - (e[(e.PAN = 1)] = "PAN"), - (e[(e.DOLLY_PAN = 2)] = "DOLLY_PAN"), - (e[(e.DOLLY_ROTATE = 3)] = "DOLLY_ROTATE"); - })(Gn || (Gn = {})); +let state = STATE.NONE; +const EPS = 0.000001; +// current position in spherical coordinates +const spherical = new Spherical(); +const sphericalDelta = new Spherical(); +let scale = 1; +const panOffset = new Vector3(); +let zoomChanged = false; +const rotateStart = new Vector2(); +const rotateEnd = new Vector2(); +const rotateDelta = new Vector2(); +const panStart = new Vector2(); +const panEnd = new Vector2(); +const panDelta = new Vector2(); +const dollyStart = new Vector2(); +const dollyEnd = new Vector2(); +const dollyDelta = new Vector2(); +const pointers = []; +const pointerPositions = {}; +var MOUSE; +(function (MOUSE) { + MOUSE[(MOUSE["LEFT"] = 0)] = "LEFT"; + MOUSE[(MOUSE["MIDDLE"] = 1)] = "MIDDLE"; + MOUSE[(MOUSE["RIGHT"] = 2)] = "RIGHT"; + MOUSE[(MOUSE["ROTATE"] = 0)] = "ROTATE"; + MOUSE[(MOUSE["DOLLY"] = 1)] = "DOLLY"; + MOUSE[(MOUSE["PAN"] = 2)] = "PAN"; +})(MOUSE || (MOUSE = {})); +var TOUCH; +(function (TOUCH) { + TOUCH[(TOUCH["ROTATE"] = 0)] = "ROTATE"; + TOUCH[(TOUCH["PAN"] = 1)] = "PAN"; + TOUCH[(TOUCH["DOLLY_PAN"] = 2)] = "DOLLY_PAN"; + TOUCH[(TOUCH["DOLLY_ROTATE"] = 3)] = "DOLLY_ROTATE"; +})(TOUCH || (TOUCH = {})); +function rotateLeft(angle) { + sphericalDelta.theta -= angle; +} +function rotateUp(angle) { + sphericalDelta.phi -= angle; +} +function addPointer(event) { + pointers.push(event); +} +function removePointer(event) { + delete pointerPositions[event.pointerId]; + for (let i = 0; i < pointers.length; i++) { + if (pointers[i].pointerId == event.pointerId) { + pointers.splice(i, 1); + return; + } + } +} +function trackPointer(event) { + let position = pointerPositions[event.pointerId]; + if (position === undefined) { + position = new Vector2(); + pointerPositions[event.pointerId] = position; + } + position.set(event.pageX, event.pageY); +} +function getSecondPointerPosition(event) { + const pointer = event.pointerId === pointers[0].pointerId ? pointers[1] : pointers[0]; + return pointerPositions[pointer.pointerId]; +} +function handleMouseDownRotate(event) { + rotateStart.set(event.clientX, event.clientY); +} +function handleMouseDownDolly(event) { + dollyStart.set(event.clientX, event.clientY); +} +function handleMouseDownPan(event) { + panStart.set(event.clientX, event.clientY); +} +function onPointerCancel(event) { + removePointer(event); +} +function handleTouchStartRotate() { + if (pointers.length === 1) { + rotateStart.set(pointers[0].pageX, pointers[0].pageY); + } else { + const x = 0.5 * (pointers[0].pageX + pointers[1].pageX); + const y = 0.5 * (pointers[0].pageY + pointers[1].pageY); + rotateStart.set(x, y); + } +} +function handleTouchStartPan() { + if (pointers.length === 1) { + panStart.set(pointers[0].pageX, pointers[0].pageY); + } else { + const x = 0.5 * (pointers[0].pageX + pointers[1].pageX); + const y = 0.5 * (pointers[0].pageY + pointers[1].pageY); + panStart.set(x, y); + } +} +function handleTouchStartDolly() { + const dx = pointers[0].pageX - pointers[1].pageX; + const dy = pointers[0].pageY - pointers[1].pageY; + const distance = Math.sqrt(dx * dx + dy * dy); + dollyStart.set(0, distance); +} + export { - h as AddressMode, - Er as AmbientLight, - me as Attachment, - De as Attribute, - tr as Axes, - Ve as BindGroup, - Fe as BindGroupEntity, - E as BlendFactor, - M as BlendOperation, - yr as BlinnPhongMaterial, - Kr as BloomPostEffect, - gr as BoxGeometry, - $ as Buffer, - r as BufferUsage, - Qt as Color, - T as ColorWriteFlags, - f as CompareFunction, - ue as Context, - sr as CubeTextureLoader, - w as CullMode, - rn as DirectionalLight, - Y as DrawCommand, - u as FilterMode, - b as FrontFace, - _ as IndexFormat, - C as InputStepMode, - cr as Instance, - lr as InstanceMesh, - Qi as Mesh, - ur as Model, - bn as OrbitControl, - Qr as OrthographicCamera, - Sr as PbrMaterial, - Gr as PerspectiveCamera, - Dt as PlaneGeometry, - Hr as PointLight, - S as PrimitiveTopology, - te as RenderState, - $e as RenderTarget, - de as Sampler, - Wr as Scene, - Zi as ShaderMaterial, - d as ShaderStage, - Ji as ShadowMapDebugger, - or as SkyBox, - pr as SphereGeometry, - en as SpotLight, - mr as Sprite, - U as StencilOperation, - x as StorageTextureAccess, - fe as Texture, - c as TextureAspect, - s as TextureDimension, - l as TextureFormat, - g as TextureSampleType, - a as TextureUsage, - o as TextureViewDimension, - xr as TorusKnotGeometry, - Ue as Vector3, - L as VertexFormat, - pn as loadGLTF, - gn as loadTexture + AddressMode, + AmbientLight, + Attachment, + Attribute, + Axes, + BindGroup, + BindGroupEntity, + BlendFactor, + BlendOperation, + BlinnPhongMaterial, + BloomPostEffect, + BoxGeometry, + Buffer, + BufferUsage, + Color, + ColorWriteFlags, + CompareFunction, + Context, + CubeTextureLoader, + CullMode, + DirectionalLight, + DrawCommand, + FilterMode, + FrontFace, + IndexFormat, + InputStepMode, + Instance, + InstanceMesh, + Mesh, + Model, + OrbitControl, + OrthographicCamera, + PbrMaterial, + PerspectiveCamera, + PlaneGeometry, + PointLight, + PrimitiveTopology, + RenderState, + RenderTarget, + Sampler, + Scene, + ShaderMaterial, + ShaderStage, + ShadowMapDebugger, + SkyBox, + SphereGeometry, + SpotLight, + Sprite, + StencilOperation, + StorageTextureAccess, + Texture, + TextureAspect, + TextureDimension, + TextureFormat, + TextureSampleType, + TextureUsage, + TextureViewDimension, + TorusKnotGeometry, + Vector3, + VertexFormat, + loadGLTF, + loadTexture }; +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"index.js","sources":["../src/core/WebGPUConstant.ts","../src/render/Buffer.ts","../src/render/PipelineLayout.ts","../src/render/Pipeline.ts","../src/render/DrawCommand.ts","../src/core/WebGPUTypes.ts","../src/utils/MipmapGenerator.ts","../src/utils/defaultValue.ts","../src/render/RenderState.ts","../src/render/Context.ts","../src/render/Texture.ts","../src/render/Sampler.ts","../src/render/Attachment.ts","../src/utils/defined.ts","../node_modules/mersenne-twister/src/mersenne-twister.js","../src/math/Math.ts","../src/math/Vector2.ts","../src/math/Vector3.ts","../src/render/Attribute.ts","../src/render/BindGroup.ts","../src/render/BindGroupEntity.ts","../src/render/RenderTarget.ts","../src/math/Matrix3.ts","../src/math/Vector4.ts","../src/math/Matrix4.ts","../src/core/BoundingSphere.ts","../src/render/IndexBuffer.ts","../src/render/Attributes.ts","../src/render/VertexBuffer.ts","../src/utils/combine.ts","../src/geometry/Geometry.ts","../src/geometry/PlaneGeometry.ts","../src/math/Quaternion.ts","../src/core/RenderObject.ts","../src/light/Light.ts","../src/math/Color.ts","../src/math/Matrix2.ts","../src/render/Uniforms.ts","../src/render/UniformBuffer.ts","../src/shader/material/colorFrag.ts","../src/shader/material/colorVert.ts","../src/shader/WgslPreprocessor.ts","../src/shader/material/pbr_fs.ts","../src/shader/material/pbr_vs.ts","../src/shader/material/pbrFrag.ts","../src/shader/material/pbrVert.ts","../src/shader/material/phongFrag.ts","../src/shader/material/phongVert.ts","../src/shader/material/point_fs.ts","../src/shader/material/point_vs.ts","../src/shader/material/quadFrag.ts","../src/shader/material/quadVert.ts","../src/shader/material/skyBoxFrag.ts","../src/shader/material/skyBoxVert.ts","../src/shader/material/sprite_fs.ts","../src/shader/material/sprite_vs.ts","../src/shader/postProcess/blend/blendFrag.ts","../src/shader/postProcess/bloom/Blur.ts","../src/shader/postProcess/bloom/LuminosityHigh.ts","../src/shader/shaderChunk/attribute/FragInput.ts","../src/shader/shaderChunk/attribute/PointFragInput.ts","../src/shader/shaderChunk/attribute/PointVertInput.ts","../src/shader/shaderChunk/attribute/PointVertOutput.ts","../src/shader/shaderChunk/attribute/VertexInput.ts","../src/shader/shaderChunk/attribute/VertexOutput.ts","../src/shader/shaderChunk/common/SystemUniform.ts","../src/shader/shaderChunk/common/TextureAndSamplerDefine.ts","../src/shader/shaderChunk/environment/environment.ts","../src/shader/shaderChunk/instance/Instance.ts","../src/shader/shaderChunk/light/light.ts","../src/shader/shaderChunk/light/lightCommon.ts","../src/shader/shaderChunk/normal/getNormalBackUp.ts","../src/shader/shaderChunk/pbr/brdf.ts","../src/shader/shaderChunk/pbr/ibl.ts","../src/shader/shaderChunk/pbr/pbrFunction.ts","../src/shader/shaderChunk/pbr/pbrStruct.ts","../src/shader/shaderChunk/pbr/pbrTexture.ts","../src/shader/shaderChunk/pbr/pbrUtils.ts","../src/shader/shaderChunk/phong/blinn_phong.ts","../src/shader/shaderChunk/phong/phongFunction.ts","../src/shader/shaderChunk/phong/phongUtils.ts","../src/shader/shaderChunk/skin/SkinVert.ts","../src/shader/shaderChunk/struct/PbrMaterialStruct.ts","../src/shader/shaderChunk/ShaderChunk.ts","../src/shader/shaderChunk/shadow/shadowMapDebuggerFrag.ts","../src/shader/shaderChunk/shadow/shadowMapDebuggerVert.ts","../src/shader/shaderChunk/shadow/shadowMapFrag.ts","../src/shader/shaderChunk/shadow/shadowMapVert.ts","../src/shader/Shaders.ts","../src/shader/ShaderSource.ts","../src/utils/uniformUtils.ts","../src/render/BindGroupLayout.ts","../src/render/BindGroupLayoutEntry.ts","../src/render/ShaderData.ts","../src/material/Material.ts","../src/material/ShaderMaterial.ts","../src/utils/createGuid.ts","../src/mesh/Mesh.ts","../src/helper/ShadowMapDebugger.ts","../src/material/ColorMaterial.ts","../src/mesh/Axes.ts","../src/geometry/SkyBoxGeometry.ts","../src/utils/destroyObject.ts","../src/core/TextureCache.ts","../src/loader/CubeTextureLoader.ts","../src/material/SkyBoxMaterial.ts","../src/mesh/SkyBox.ts","../src/mesh/Instance.ts","../src/mesh/InstanceMesh.ts","../src/render/ComputeCommand.ts","../src/mesh/Model.ts","../src/geometry/SpriteGeometry.ts","../src/material/SpriteMaterial.ts","../src/mesh/Sprite.ts","../src/utils/GeometryUtils.ts","../src/geometry/SphereGeometry.ts","../src/geometry/BoxGeometry.ts","../src/geometry/TorusKnotGeometry.ts","../src/material/BlinnPhongMaterial.ts","../src/material/PbrMaterial.ts","../src/core/EventDispatcher.ts","../src/core/RenderQueue.ts","../src/core/FrameState.ts","../src/light/AmbientLight.ts","../src/core/LightManger.ts","../src/core/MeshManger.ts","../src/post-process/ResolveFrame.ts","../src/post-process/PostEffectCollection.ts","../src/pass/Pass.ts","../src/pass/BasicPass.ts","../src/math/Plane.ts","../src/core/CullingVolume.ts","../src/camera/Camera.ts","../src/camera/PerspectiveCamera.ts","../src/camera/PointLightShadowCamera.ts","../src/light/shadows/BaseShadow.ts","../src/light/shadows/PointLightShadow.ts","../src/light/PointLight.ts","../src/pass/ShadowPass.ts","../src/renderpipeline/ForwardRenderLine.ts","../src/Scene.ts","../src/post-process/PostEffect.ts","../src/post-process/BloomPostEffect.ts","../src/camera/OrthographicCamera.ts","../src/light/shadows/SpotLightShadow.ts","../src/light/SpotLight.ts","../src/light/shadows/DirectionalLightShadow.ts","../src/light/DirectionalLight.ts","../src/mesh/Node.ts","../src/mesh/SKinMesh.ts","../src/utils/gltfUtils.ts","../src/loader/gltf/libs/Accessor.ts","../src/loader/gltf/libs/Animation.ts","../src/loader/gltf/libs/AnimationChannel.ts","../src/loader/gltf/libs/AnimationChannelTarget.ts","../src/loader/gltf/types/gltfType.ts","../src/loader/gltf/libs/AnimationSampler.ts","../src/loader/GLTFLoader.ts","../src/utils/utils.ts","../src/math/Spherical.ts","../src/control/OrbitControl.ts"],"sourcesContent":["/** @internal */\nexport enum PredefinedColorSpace {\n\tSRGB = \"srgb\"\n}\n\n/** @internal */\nexport enum PowerPreference {\n\tLowPower = \"low-power\",\n\tHighPerformance = \"high-performance\"\n}\n\n/** @internal */\nexport enum FeatureName {\n\tDepthClipControl = \"depth-clip-control\",\n\tDepth24UnormStencil8 = \"depth24unorm-stencil8\",\n\tDepth32FloatStencil8 = \"depth32float-stencil8\",\n\tTextureCompressionBC = \"texture-compression-bc\",\n\tTextureCompressionETC2 = \"texture-compression-etc2\",\n\tTextureCompressionASTC = \"texture-compression-astc\",\n\tTimestampQuery = \"timestamp-query\",\n\tIndirectFirstInstance = \"indirect-first-instance\",\n\tShaderF16 = \"shader-f16\",\n\tBGRA8UnormStorage = \"bgra8unorm-storage\"\n}\n\n/** @internal */\nexport enum BufferUsage {\n\tMapRead = 1,\n\tMapWrite = 2,\n\tCopySrc = 4,\n\tCopyDst = 8,\n\tIndex = 16,\n\tVertex = 32,\n\tUniform = 64,\n\tStorage = 128,\n\tIndirect = 256,\n\tQueryResolve = 512\n}\n\n/** @internal */\nexport enum MapMode {\n\tRead = 1,\n\tWrite = 2\n}\n\n/** @internal */\nexport enum TextureDimension {\n\tE1d = \"1d\",\n\tE2d = \"2d\",\n\tE3d = \"3d\"\n}\n\n/** @internal */\nexport enum TextureUsage {\n\tCopySrc = 1,\n\tCopyDst = 2,\n\tTextureBinding = 4,\n\tStorageBinding = 8,\n\tRenderAttachment = 16\n}\n\n/** @internal */\nexport enum TextureViewDimension {\n\tE1d = \"1d\",\n\tE2d = \"2d\",\n\tE2dArray = \"2d-array\",\n\tCube = \"cube\",\n\tCubeArray = \"cube-array\",\n\tE3d = \"3d\"\n}\n\n/** @internal */\nexport enum TextureAspect {\n\tAll = \"all\",\n\tStencilOnly = \"stencil-only\",\n\tDepthOnly = \"depth-only\"\n}\n\n/**\n * Comments taken from https://github.com/gfx-rs/wgpu/blob/master/wgpu-types/src/lib.rs\n * @internal\n */\nexport enum TextureFormat {\n\t// 8-bit formats\n\tR8Unorm = \"r8unorm\", // Red channel only. 8 bit integer per channel. [0, 255] converted to/from float [0, 1] in shader.\n\tR8Snorm = \"r8snorm\", // Red channel only. 8 bit integer per channel. [-127, 127] converted to/from float [-1, 1] in shader.\n\tR8Uint = \"r8uint\", // Red channel only. 8 bit integer per channel. Unsigned in shader.\n\tR8Sint = \"r8sint\", // Red channel only. 8 bit integer per channel. Signed in shader.\n\n\t// 16-bit formats\n\tR16Uint = \"r16uint\", // Red channel only. 16 bit integer per channel. Unsigned in shader.\n\tR16Sint = \"r16sint\", // Red channel only. 16 bit integer per channel. Signed in shader.\n\tR16Float = \"r16float\", // Red channel only. 16 bit float per channel. Float in shader.\n\tRG8Unorm = \"rg8unorm\", // Red and green channels. 8 bit integer per channel. [0, 255] converted to/from float [0, 1] in shader.\n\tRG8Snorm = \"rg8snorm\", // Red and green channels. 8 bit integer per channel. [-127, 127] converted to/from float [-1, 1] in shader.\n\tRG8Uint = \"rg8uint\", // Red and green channels. 8 bit integer per channel. Unsigned in shader.\n\tRG8Sint = \"rg8sint\", // Red and green channels. 8 bit integer per channel. Signed in shader.\n\n\t// 32-bit formats\n\tR32Uint = \"r32uint\", // Red channel only. 32 bit integer per channel. Unsigned in shader.\n\tR32Sint = \"r32sint\", // Red channel only. 32 bit integer per channel. Signed in shader.\n\tR32Float = \"r32float\", // Red channel only. 32 bit float per channel. Float in shader.\n\tRG16Uint = \"rg16uint\", // Red and green channels. 16 bit integer per channel. Unsigned in shader.\n\tRG16Sint = \"rg16sint\", // Red and green channels. 16 bit integer per channel. Signed in shader.\n\tRG16Float = \"rg16float\", // Red and green channels. 16 bit float per channel. Float in shader.\n\tRGBA8Unorm = \"rgba8unorm\", // Red, green, blue, and alpha channels. 8 bit integer per channel. [0, 255] converted to/from float [0, 1] in shader.\n\tRGBA8UnormSRGB = \"rgba8unorm-srgb\", // Red, green, blue, and alpha channels. 8 bit integer per channel. Srgb-color [0, 255] converted to/from linear-color float [0, 1] in shader.\n\tRGBA8Snorm = \"rgba8snorm\", // Red, green, blue, and alpha channels. 8 bit integer per channel. [-127, 127] converted to/from float [-1, 1] in shader.\n\tRGBA8Uint = \"rgba8uint\", // Red, green, blue, and alpha channels. 8 bit integer per channel. Unsigned in shader.\n\tRGBA8Sint = \"rgba8sint\", // Red, green, blue, and alpha channels. 8 bit integer per channel. Signed in shader.\n\tBGRA8Unorm = \"bgra8unorm\", // Blue, green, red, and alpha channels. 8 bit integer per channel. [0, 255] converted to/from float [0, 1] in shader.\n\tBGRA8UnormSRGB = \"bgra8unorm-srgb\", // Blue, green, red, and alpha channels. 8 bit integer per channel. Srgb-color [0, 255] converted to/from linear-color float [0, 1] in shader.\n\t// Packed 32-bit formats\n\tRGB9E5UFloat = \"rgb9e5ufloat\", // Packed unsigned float with 9 bits mantisa for each RGB component, then a common 5 bits exponent\n\tRGB10A2Unorm = \"rgb10a2unorm\", // Red, green, blue, and alpha channels. 10 bit integer for RGB channels, 2 bit integer for alpha channel. [0, 1023] ([0, 3] for alpha) converted to/from float [0, 1] in shader.\n\tRG11B10UFloat = \"rg11b10ufloat\", // Red, green, and blue channels. 11 bit float with no sign bit for RG channels. 10 bit float with no sign bit for blue channel. Float in shader.\n\n\t// 64-bit formats\n\tRG32Uint = \"rg32uint\", // Red and green channels. 32 bit integer per channel. Unsigned in shader.\n\tRG32Sint = \"rg32sint\", // Red and green channels. 32 bit integer per channel. Signed in shader.\n\tRG32Float = \"rg32float\", // Red and green channels. 32 bit float per channel. Float in shader.\n\tRGBA16Uint = \"rgba16uint\", // Red, green, blue, and alpha channels. 16 bit integer per channel. Unsigned in shader.\n\tRGBA16Sint = \"rgba16sint\", // Red, green, blue, and alpha channels. 16 bit integer per channel. Signed in shader.\n\tRGBA16Float = \"rgba16float\", // Red, green, blue, and alpha channels. 16 bit float per channel. Float in shader.\n\n\t// 128-bit formats\n\tRGBA32Uint = \"rgba32uint\", // Red, green, blue, and alpha channels. 32 bit integer per channel. Unsigned in shader.\n\tRGBA32Sint = \"rgba32sint\", // Red, green, blue, and alpha channels. 32 bit integer per channel. Signed in shader.\n\tRGBA32Float = \"rgba32float\", // Red, green, blue, and alpha channels. 32 bit float per channel. Float in shader.\n\n\t// Depth and stencil formats\n\tStencil8 = \"stencil8\",\n\tDepth16Unorm = \"depth16unorm\",\n\tDepth24Plus = \"depth24plus\", // Special depth format with at least 24 bit integer depth.\n\tDepth24PlusStencil8 = \"depth24plus-stencil8\", // Special depth/stencil format with at least 24 bit integer depth and 8 bits integer stencil.\n\tDepth32Float = \"depth32float\", // Special depth format with 32 bit floating point depth.\n\n\t// BC compressed formats usable if \"texture-compression-bc\" is both\n\t// supported by the device/user agent and enabled in requestDevice.\n\tBC1RGBAUnorm = \"bc1-rgba-unorm\", // 4x4 block compressed texture. 8 bytes per block (4 bit/px). 4 color + alpha pallet. 5 bit R + 6 bit G + 5 bit B + 1 bit alpha. Also known as DXT1.\n\tBC1RGBAUnormSRGB = \"bc1-rgba-unorm-srgb\", // 4x4 block compressed texture. 8 bytes per block (4 bit/px). 4 color + alpha pallet. 5 bit R + 6 bit G + 5 bit B + 1 bit alpha. Also known as DXT1.\n\tBC2RGBAUnorm = \"bc2-rgba-unorm\", // 4x4 block compressed texture. 16 bytes per block (8 bit/px). 4 color pallet. 5 bit R + 6 bit G + 5 bit B + 4 bit alpha. Also known as DXT3.\n\tBC2RGBAUnormSRGB = \"bc2-rgba-unorm-srgb\", // 4x4 block compressed texture. 16 bytes per block (8 bit/px). 4 color pallet. 5 bit R + 6 bit G + 5 bit B + 4 bit alpha. Also known as DXT3.\n\tBC3RGBAUnorm = \"bc3-rgba-unorm\", // 4x4 block compressed texture. 16 bytes per block (8 bit/px). 4 color pallet + 8 alpha pallet. 5 bit R + 6 bit G + 5 bit B + 8 bit alpha. Also known as DXT5.\n\tBC3RGBAUnormSRGB = \"bc3-rgba-unorm-srgb\", // 4x4 block compressed texture. 16 bytes per block (8 bit/px). 4 color pallet + 8 alpha pallet. 5 bit R + 6 bit G + 5 bit B + 8 bit alpha. Also known as DXT5.\n\tBC4RUnorm = \"bc4-r-unorm\", // 4x4 block compressed texture. 8 bytes per block (4 bit/px). 8 color pallet. 8 bit R. Also known as RGTC1.\n\tBC4RSnorm = \"bc4-r-snorm\", // 4x4 block compressed texture. 8 bytes per block (4 bit/px). 8 color pallet. 8 bit R. Also known as RGTC1.\n\tBC5RGUnorm = \"bc5-rg-unorm\", // 4x4 block compressed texture. 16 bytes per block (8 bit/px). 8 color red pallet + 8 color green pallet. 8 bit RG. Also known as RGTC2.\n\tBC5RGSnorm = \"bc5-rg-snorm\", // 4x4 block compressed texture. 16 bytes per block (8 bit/px). 8 color red pallet + 8 color green pallet. 8 bit RG. Also known as RGTC2.\n\tBC6HRGBUFloat = \"bc6h-rgb-ufloat\", // 4x4 block compressed texture. 16 bytes per block (8 bit/px). Variable sized pallet. 16 bit unsigned float RGB. Float in shader. Also known as BPTC (float).\n\tBC6HRGBFloat = \"bc6h-rgb-float\", // 4x4 block compressed texture. 16 bytes per block (8 bit/px). Variable sized pallet. 16 bit signed float RGB. Float in shader. Also known as BPTC (float).\n\tBC7RGBAUnorm = \"bc7-rgba-unorm\", // 4x4 block compressed texture. 16 bytes per block (8 bit/px). Variable sized pallet. 8 bit integer RGBA. Also known as BPTC (unorm).\n\tBC7RGBAUnormSRGB = \"bc7-rgba-unorm-srgb\", // 4x4 block compressed texture. 16 bytes per block (8 bit/px). Variable sized pallet. 8 bit integer RGBA. Also known as BPTC (unorm).\n\n\t// ETC2 compressed formats usable if \"texture-compression-etc2\" is both\n\t// supported by the device/user agent and enabled in requestDevice.\n\tETC2RGB8Unorm = \"etc2-rgb8unorm\", // 4x4 block compressed texture. 8 bytes per block (4 bit/px). Complex pallet. 8 bit integer RGB.\n\tETC2RGB8UnormSRGB = \"etc2-rgb8unorm-srgb\", // 4x4 block compressed texture. 8 bytes per block (4 bit/px). Complex pallet. 8 bit integer RGB.\n\tETC2RGB8A1Unorm = \"etc2-rgb8a1unorm\", // 4x4 block compressed texture. 8 bytes per block (4 bit/px). Complex pallet. 8 bit integer RGB + 1 bit alpha.\n\tETC2RGB8A1UnormSRGB = \"etc2-rgb8a1unorm-srgb\", // 4x4 block compressed texture. 8 bytes per block (4 bit/px). Complex pallet. 8 bit integer RGB + 1 bit alpha.\n\tETC2RGBA8Unorm = \"etc2-rgba8unorm\", // 4x4 block compressed texture. 16 bytes per block (8 bit/px). Complex pallet. 8 bit integer RGB + 8 bit alpha.\n\tETC2RGBA8UnormSRGB = \"etc2-rgba8unorm-srgb\", // 4x4 block compressed texture. 16 bytes per block (8 bit/px). Complex pallet. 8 bit integer RGB + 8 bit alpha.\n\tEACR11Unorm = \"eac-r11unorm\", // 4x4 block compressed texture. 8 bytes per block (4 bit/px). Complex pallet. 11 bit integer R.\n\tEACR11Snorm = \"eac-r11snorm\", // 4x4 block compressed texture. 8 bytes per block (4 bit/px). Complex pallet. 11 bit integer R.\n\tEACRG11Unorm = \"eac-rg11unorm\", // 4x4 block compressed texture. 16 bytes per block (8 bit/px). Complex pallet. 11 bit integer R + 11 bit integer G.\n\tEACRG11Snorm = \"eac-rg11snorm\", // 4x4 block compressed texture. 16 bytes per block (8 bit/px). Complex pallet. 11 bit integer R + 11 bit integer G.\n\n\t// ASTC compressed formats usable if \"texture-compression-astc\" is both\n\t// supported by the device/user agent and enabled in requestDevice.\n\tASTC4x4Unorm = \"astc-4x4-unorm\", // 4x4 block compressed texture. 16 bytes per block (8 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC4x4UnormSRGB = \"astc-4x4-unorm-srgb\", // 4x4 block compressed texture. 16 bytes per block (8 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC5x4Unorm = \"astc-5x4-unorm\", // 5x4 block compressed texture. 16 bytes per block (6.4 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC5x4UnormSRGB = \"astc-5x4-unorm-srgb\", // 5x4 block compressed texture. 16 bytes per block (6.4 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC5x5Unorm = \"astc-5x5-unorm\", // 5x5 block compressed texture. 16 bytes per block (5.12 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC5x5UnormSRGB = \"astc-5x5-unorm-srgb\", // 5x5 block compressed texture. 16 bytes per block (5.12 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC6x5Unorm = \"astc-6x5-unorm\", // 6x5 block compressed texture. 16 bytes per block (4.27 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC6x5UnormSRGB = \"astc-6x5-unorm-srgb\", // 6x5 block compressed texture. 16 bytes per block (4.27 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC6x6Unorm = \"astc-6x6-unorm\", // 6x6 block compressed texture. 16 bytes per block (3.56 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC6x6UnormSRGB = \"astc-6x6-unorm-srgb\", // 6x6 block compressed texture. 16 bytes per block (3.56 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC8x5Unorm = \"astc-8x5-unorm\", // 8x5 block compressed texture. 16 bytes per block (3.2 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC8x5UnormSRGB = \"astc-8x5-unorm-srgb\", // 8x5 block compressed texture. 16 bytes per block (3.2 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC8x6Unorm = \"astc-8x6-unorm\", // 8x6 block compressed texture. 16 bytes per block (2.67 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC8x6UnormSRGB = \"astc-8x6-unorm-srgb\", // 8x6 block compressed texture. 16 bytes per block (2.67 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC8x8Unorm = \"astc-8x8-unorm\", // 8x8 block compressed texture. 16 bytes per block (2 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC8x8UnormSRGB = \"astc-8x8-unorm-srgb\", // 8x8 block compressed texture. 16 bytes per block (2 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC10x5Unorm = \"astc-10x5-unorm\", // 10x5 block compressed texture. 16 bytes per block (2.56 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC10x5UnormSRGB = \"astc-10x5-unorm-srgb\", // 10x5 block compressed texture. 16 bytes per block (2.56 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC10x6Unorm = \"astc-10x6-unorm\", // 10x6 block compressed texture. 16 bytes per block (2.13 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC10x6UnormSRGB = \"astc-10x6-unorm-srgb\", // 10x6 block compressed texture. 16 bytes per block (2.13 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC10x8Unorm = \"astc-10x8-unorm\", // 10x8 block compressed texture. 16 bytes per block (1.6 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC10x8UnormSRGB = \"astc-10x8-unorm-srgb\", // 10x8 block compressed texture. 16 bytes per block (1.6 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC10x10Unorm = \"astc-10x10-unorm\", // 10x10 block compressed texture. 16 bytes per block (1.28 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC10x10UnormSRGB = \"astc-10x10-unorm-srgb\", // 10x10 block compressed texture. 16 bytes per block (1.28 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC12x10Unorm = \"astc-12x10-unorm\", // 12x10 block compressed texture. 16 bytes per block (1.07 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC12x10UnormSRGB = \"astc-12x10-unorm-srgb\", // 12x10 block compressed texture. 16 bytes per block (1.07 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC12x12Unorm = \"astc-12x12-unorm\", // 12x12 block compressed texture. 16 bytes per block (0.89 bit/px). Complex pallet. 8 bit integer RGBA.\n\tASTC12x12UnormSRGB = \"astc-12x12-unorm-srgb\", // 12x12 block compressed texture. 16 bytes per block (0.89 bit/px). Complex pallet. 8 bit integer RGBA.\n\n\t// \"depth24unorm-stencil8\" feature\n\tDepth24UnormStencil8 = \"depth24unorm-stencil8\",\n\n\t// \"depth32float-stencil8\" feature\n\tDepth32FloatStencil8 = \"depth32float-stencil8\"\n}\n\n/** @internal */\nexport enum AddressMode {\n\tClampToEdge = \"clamp-to-edge\",\n\tRepeat = \"repeat\",\n\tMirrorRepeat = \"mirror-repeat\"\n}\n\n/** @internal */\nexport enum FilterMode {\n\tNearest = \"nearest\",\n\tLinear = \"linear\"\n}\n\n/** @internal */\nexport enum CompareFunction {\n\tNever = \"never\",\n\tLess = \"less\",\n\tEqual = \"equal\",\n\tLessEqual = \"less-equal\",\n\tGreater = \"greater\",\n\tNotEqual = \"not-equal\",\n\tGreaterEqual = \"greater-equal\",\n\tAlways = \"always\"\n}\n\n/** @internal */\nexport enum ShaderStage {\n\tVertex = 1,\n\tFragment = 2,\n\tCompute = 4\n}\n\n/** @internal */\nexport enum BufferBindingType {\n\tUniform = \"uniform\",\n\tStorage = \"storage\",\n\tReadOnlyStorage = \"read-only-storage\"\n}\n\n/** @internal */\nexport enum SamplerBindingType {\n\tFiltering = \"filtering\",\n\tNonFiltering = \"non-filtering\",\n\tComparison = \"comparison\"\n}\n\n/** @internal */\nexport enum TextureSampleType {\n\tFloat = \"float\",\n\tUnfilterableFloat = \"unfilterable-float\",\n\tDepth = \"depth\",\n\tSint = \"sint\",\n\tUint = \"uint\"\n}\n\n/** @internal */\nexport enum StorageTextureAccess {\n\tWriteOnly = \"write-only\"\n}\n\n/** @internal */\nexport enum CompilationMessageType {\n\tError = \"error\",\n\tWarning = \"warning\",\n\tInfo = \"info\"\n}\n\n/** @internal */\nexport enum AutoLayoutMode {\n\tAuto = \"auto\"\n}\n\n/** @internal */\nexport enum PrimitiveTopology {\n\tPointList = \"point-list\",\n\tLineList = \"line-list\",\n\tLineStrip = \"line-strip\",\n\tTriangleList = \"triangle-list\",\n\tTriangleStrip = \"triangle-strip\"\n}\n\n/** @internal */\nexport enum FrontFace {\n\tCCW = \"ccw\",\n\tCW = \"cw\"\n}\n\n/** @internal */\nexport enum CullMode {\n\tNone = \"none\",\n\tFront = \"front\",\n\tBack = \"back\"\n}\n\n/** @internal */\nexport enum ColorWriteFlags {\n\tRed = 1,\n\tGreen = 2,\n\tBlue = 4,\n\tAlpha = 8,\n\tAll = 15\n}\n\n/** @internal */\nexport enum BlendFactor {\n\tZero = \"zero\",\n\tOne = \"one\",\n\tSrc = \"src\",\n\tOneMinusSrc = \"one-minus-src\",\n\tSrcAlpha = \"src-alpha\",\n\tOneMinusSrcAlpha = \"one-minus-src-alpha\",\n\tDst = \"dst\",\n\tOneMinusDst = \"one-minus-dst\",\n\tDstAlpha = \"dst-alpha\",\n\tOneMinusDstAlpha = \"one-minus-dst-alpha\",\n\tSrcAlphaSaturated = \"src-alpha-saturated\",\n\tConstant = \"constant\",\n\tOneMinusConstant = \"one-minus-constant\"\n}\n\n/** @internal */\nexport enum BlendOperation {\n\tAdd = \"add\",\n\tSubtract = \"subtract\",\n\tReverseSubtract = \"reverse-subtract\",\n\tMin = \"min\",\n\tMax = \"max\"\n}\n\n/** @internal */\nexport enum StencilOperation {\n\tKeep = \"keep\",\n\tZero = \"zero\",\n\tReplace = \"replace\",\n\tInvert = \"invert\",\n\tIncrementClamp = \"increment-clamp\",\n\tDecrementClamp = \"decrement-clamp\",\n\tIncrementWrap = \"increment-wrap\",\n\tDecrementWrap = \"decrement-wrap\"\n}\n\n/** @internal */\nexport enum IndexFormat {\n\tUint16 = \"uint16\",\n\tUint32 = \"uint32\"\n}\n\n/** @internal */\nexport enum VertexFormat {\n\tUint8x2 = \"uint8x2\",\n\tUint8x4 = \"uint8x4\",\n\tSint8x2 = \"sint8x2\",\n\tSint8x4 = \"sint8x4\",\n\tUnorm8x2 = \"unorm8x2\",\n\tUnorm8x4 = \"unorm8x4\",\n\tSnorm8x2 = \"snorm8x2\",\n\tSnorm8x4 = \"snorm8x4\",\n\tUint16x2 = \"uint16x2\",\n\tUint16x4 = \"uint16x4\",\n\tSint16x2 = \"sint16x2\",\n\tSint16x4 = \"sint16x4\",\n\tUnorm16x2 = \"unorm16x2\",\n\tUnorm16x4 = \"unorm16x4\",\n\tSnorm16x2 = \"snorm16x2\",\n\tSnorm16x4 = \"snorm16x4\",\n\tFloat16x2 = \"float16x2\",\n\tFloat16x4 = \"float16x4\",\n\tFloat32 = \"float32\",\n\tFloat32x2 = \"float32x2\",\n\tFloat32x3 = \"float32x3\",\n\tFloat32x4 = \"float32x4\",\n\tUint32 = \"uint32\",\n\tUint32x2 = \"uint32x2\",\n\tUint32x3 = \"uint32x3\",\n\tUint32x4 = \"uint32x4\",\n\tSint32 = \"sint32\",\n\tSint32x2 = \"sint32x2\",\n\tSint32x3 = \"sint32x3\",\n\tSint32x4 = \"sint32x4\"\n}\n\n/** @internal */\nexport enum InputStepMode {\n\tVertex = \"vertex\",\n\tInstance = \"instance\"\n}\n\n/** @internal */\nexport enum ComputePassTimestampLocation {\n\tBeginning = \"beginning\",\n\tEnd = \"end\"\n}\n\n/** @internal */\nexport enum RenderPassTimestampLocation {\n\tBeginning = \"beginning\",\n\tEnd = \"end\"\n}\n\n/** @internal */\nexport enum LoadOp {\n\tLoad = \"load\",\n\tClear = \"clear\"\n}\n\n/** @internal */\nexport enum StoreOp {\n\tStore = \"store\",\n\tDiscard = \"discard\"\n}\n\n/** @internal */\nexport enum QueryType {\n\tOcclusion = \"occlusion\",\n\tTimestamp = \"timestamp\"\n}\n\n/** @internal */\nexport enum CanvasAlphaMode {\n\tOpaque = \"opaque\",\n\tPremultiplied = \"premultiplied\"\n}\n\n/** @internal */\nexport enum DeviceLostReason {\n\tDestroyed = \"destroyed\"\n}\n\n/** @internal */\nexport enum ErrorFilter {\n\tOutOfMemory = \"out-of-memory\",\n\tValidation = \"validation\"\n}\n\nexport enum GPUColorWrite {\n\tRed = 0x1,\n\tGreen = 0x2,\n\tBlue = 0x4,\n\tAlpha = 0x8,\n\tAll = 0xf\n}\nexport enum CommandSubType {\n\tShadow = \"shadow\",\n\tPick = \"pick\"\n}\nexport enum Intersect {\n\tOUTSIDE = -1,\n\tINTERSECTING = 0,\n\tINSIDE = 1\n}\n","import { BufferUsage } from \"../core/WebGPUConstant\";\nclass Buffer {\n\tpublic gpuBuffer: GPUBuffer;\n\tdevice: GPUDevice;\n\tusage: number;\n\tdata: ArrayBufferView;\n\tsize: number;\n\tconstructor(\n\t\tlabel: string,\n\t\tdevice: GPUDevice,\n\t\tusage: GPUBufferUsageFlags,\n\t\tdata: ArrayBufferView | null,\n\t\tsize?: number\n\t) {\n\t\tthis.device = device;\n\t\tthis.usage = usage;\n\t\tthis.data = data;\n\t\tthis.size = size != undefined ? (size + 3) & ~3 : (data.byteLength + 3) & ~3; // 4 bytes alignments (because of the upload which requires this)\n\t\tthis.gpuBuffer = device.createBuffer({\n\t\t\tlabel: label || \"\",\n\t\t\tsize: this.size,\n\t\t\tusage\n\t\t});\n\t\tif (data) this.setSubData(0, data, this.size);\n\t}\n\tstatic create(\n\t\tlabel: string,\n\t\tdevice: GPUDevice,\n\t\tusage: GPUBufferUsageFlags,\n\t\tdata: ArrayBufferView | null,\n\t\tsize?: number\n\t) {\n\t\treturn new Buffer(label, device, usage, data, size);\n\t}\n\tstatic createVertexBuffer(label: string, device: GPUDevice, data: ArrayBufferView): Buffer {\n\t\treturn new Buffer(label, device, BufferUsage.Vertex | BufferUsage.CopyDst, data, data.byteLength);\n\t}\n\n\tstatic createIndexBuffer(label: string, device: GPUDevice, data: ArrayBufferView): Buffer {\n\t\treturn new Buffer(label, device, BufferUsage.Index | BufferUsage.CopyDst, data);\n\t}\n\n\tstatic createUniformBuffer(label: string, device: GPUDevice, size: number, usage?: BufferUsage): Buffer {\n\t\treturn new Buffer(label, device, usage, null, size);\n\t}\n\n\tstatic createStorageBuffer(label: string, device: GPUDevice, size: number, usage = BufferUsage.Storage): Buffer {\n\t\treturn new Buffer(label, device, usage, null, size);\n\t}\n\t// https://github.com/gpuweb/gpuweb/blob/main/design/BufferOperations.md\n\tpublic setSubData(offset: number, data: ArrayBufferView, size?: number): void {\n\t\tconst srcArrayBuffer = data.buffer;\n\t\tconst byteCount = size ?? srcArrayBuffer.byteLength;\n\t\tconst srcBuffer = this.device.createBuffer({\n\t\t\tmappedAtCreation: true,\n\t\t\tsize: byteCount,\n\t\t\tusage: GPUBufferUsage.COPY_SRC\n\t\t});\n\t\tconst arrayBuffer = srcBuffer.getMappedRange();\n\n\t\tnew Uint16Array(arrayBuffer).set(new Uint16Array(srcArrayBuffer)); // memcpy\n\t\tsrcBuffer.unmap();\n\n\t\tthis.copyToBuffer(srcBuffer, offset, byteCount);\n\n\t\tsrcBuffer.destroy();\n\t}\n\n\tpublic copyToBuffer(srcBuffer: GPUBuffer, offset: number, byteCount: number): void {\n\t\tconst commandEncoder = this.device.createCommandEncoder();\n\t\tcommandEncoder.copyBufferToBuffer(srcBuffer, 0, this.gpuBuffer, offset, byteCount);\n\t\tthis.device.queue.submit([commandEncoder.finish()]);\n\t}\n\n\tpublic copyToTexture(\n\t\tbytesPerRow: number,\n\t\trowsPerImage: number,\n\t\tdestination: GPUImageCopyTexture,\n\t\textent: GPUExtent3D\n\t): void {\n\t\tconst commandEncoder = this.device.createCommandEncoder();\n\t\tcommandEncoder.copyBufferToTexture(\n\t\t\t{\n\t\t\t\tbuffer: this.gpuBuffer,\n\t\t\t\tbytesPerRow,\n\t\t\t\trowsPerImage\n\t\t\t},\n\t\t\tdestination,\n\t\t\textent\n\t\t);\n\t\tthis.device.queue.submit([commandEncoder.finish()]);\n\t}\n\n\tpublic destroy(): void {\n\t\tthis.gpuBuffer.destroy();\n\t}\n}\n\nexport default Buffer;\n","import BindGroupLayout from \"./BindGroupLayout\";\r\n\r\nconst pipelineLayoutCache = new Map();\r\nexport class PipelineLayout {\r\n  public gpuPipelineLayout: GPUPipelineLayout;\r\n  index: number;\r\n  private constructor(\r\n    device: GPUDevice,\r\n    label: string,\r\n    public groupLayouts: BindGroupLayout[] = [],\r\n    index?: number\r\n  ) {\r\n    this.index = index || 0;\r\n    this.gpuPipelineLayout = device.createPipelineLayout({\r\n      label: label,\r\n      bindGroupLayouts: groupLayouts.map((layout) => {\r\n        return layout.gpuBindGroupLayout;\r\n      }),\r\n    });\r\n  }\r\n  static getPipelineLayoutFromCache(\r\n    device: GPUDevice,\r\n    label: string,\r\n    groupLayouts: BindGroupLayout[]\r\n  ): PipelineLayout {\r\n    if (pipelineLayoutCache.has(label)) {\r\n      return pipelineLayoutCache.get(label);\r\n    } else {\r\n      const bindGroupLayout = new PipelineLayout(device, label, groupLayouts);\r\n      pipelineLayoutCache.set(label, bindGroupLayout);\r\n      return bindGroupLayout;\r\n    }\r\n  }\r\n}\r\n","import BindGroupLayout from \"./BindGroupLayout\";\nimport { ComputeCommand } from \"./ComputeCommand\";\nimport DrawCommand from \"./DrawCommand\";\nimport { PipelineLayout } from \"./PipelineLayout\";\nimport { RenderState } from \"./RenderState\";\n\nconst renderPipelines = new Map();\nconst computePipelines = new Map();\nexport default class Pipeline {\n\tgpuPipeline: GPURenderPipeline | GPUComputePipeline;\n\ttype: string;\n\tdevice: GPUDevice;\n\tdescriptor: GPURenderPipelineDescriptor | GPUComputePipelineDescriptor;\n\tconstructor(\n\t\ttype: string,\n\t\tdevice: GPUDevice,\n\t\tdescriptor: GPURenderPipelineDescriptor | GPUComputePipelineDescriptor\n\t) {\n\t\tthis.type = type;\n\t\tthis.descriptor = descriptor;\n\t\tthis.device = device;\n\t\tthis.createPipeline();\n\t}\n\tprivate createPipeline() {\n\t\tif (this.type == \"render\") {\n\t\t\tthis.gpuPipeline = this.device.createRenderPipeline(this.descriptor as GPURenderPipelineDescriptor);\n\t\t} else {\n\t\t\tthis.gpuPipeline = this.device.createComputePipeline(this.descriptor as GPUComputePipelineDescriptor);\n\t\t}\n\t}\n\tpublic bind(passEncoder: GPURenderPassEncoder | GPUComputePassEncoder) {\n\t\tif (this.type == \"render\") {\n\t\t\t(passEncoder as GPURenderPassEncoder).setPipeline(this.gpuPipeline as GPURenderPipeline);\n\t\t} else {\n\t\t\t(passEncoder as GPUComputePassEncoder).setPipeline(this.gpuPipeline as GPUComputePipeline);\n\t\t}\n\t}\n\tstatic getRenderPipelineFromCache(\n\t\tdevice: GPUDevice,\n\t\tdrawComand: DrawCommand,\n\t\tgroupLayouts: BindGroupLayout[]\n\t): Pipeline {\n\t\tconst { renderState, shaderSource } = drawComand;\n\t\tconst rsStr = JSON.stringify(renderState);\n\t\tconst combineStr = shaderSource.uid.concat(rsStr);\n\t\tconst hashId = stringToHash(combineStr);\n\t\tconst combineLayouts = groupLayouts\n\t\t\t?.filter((layout) => layout != undefined)\n\t\t\t?.sort((layout1, layout2) => layout1.index - layout2.index);\n\t\tlet pipeline = renderPipelines.get(hashId);\n\t\tif (!pipeline) {\n\t\t\tconst descriptor = Pipeline.getPipelineDescriptor(\n\t\t\t\tdevice,\n\t\t\t\tdrawComand,\n\t\t\t\trenderState,\n\t\t\t\tcombineLayouts,\n\t\t\t\thashId.toString()\n\t\t\t);\n\t\t\tpipeline = new Pipeline(\"render\", device, descriptor);\n\t\t\trenderPipelines.set(hashId, pipeline);\n\t\t}\n\t\treturn pipeline;\n\t}\n\tstatic getComputePipelineFromCache(\n\t\tdevice: GPUDevice,\n\t\tcomputeCommad: ComputeCommand,\n\t\tgroupLayouts: BindGroupLayout[]\n\t): Pipeline {\n\t\tconst { shaderSource } = computeCommad;\n\t\tconst hashId = stringToHash(shaderSource.uid);\n\t\tlet pipeline = computePipelines.get(hashId);\n\t\tif (!pipeline) {\n\t\t\tpipeline = new Pipeline(\"compute\", device, {\n\t\t\t\tlayout: PipelineLayout.getPipelineLayoutFromCache(device, hashId.toString(), groupLayouts)\n\t\t\t\t\t.gpuPipelineLayout,\n\t\t\t\tcompute: {\n\t\t\t\t\tmodule: shaderSource.getShaderModule(device).compute,\n\t\t\t\t\tentryPoint: shaderSource?.compute?.computeMain || \"main\"\n\t\t\t\t}\n\t\t\t});\n\t\t\tcomputePipelines.set(hashId, pipeline);\n\t\t}\n\t\treturn pipeline;\n\t}\n\tprivate static getPipelineDescriptor(\n\t\tdevice: GPUDevice,\n\t\tdrawComand: DrawCommand,\n\t\trenderState: RenderState,\n\t\tgroupLayouts: BindGroupLayout[],\n\t\thashId: string\n\t): GPURenderPipelineDescriptor {\n\t\tconst { vertexBuffers, shaderSource } = drawComand;\n\t\tconst { vert, frag } = shaderSource.getShaderModule(device);\n\t\tconst pipelineDec = {\n\t\t\tlayout: PipelineLayout.getPipelineLayoutFromCache(device, hashId, groupLayouts).gpuPipelineLayout\n\t\t} as any;\n\t\tif (vert)\n\t\t\tpipelineDec.vertex = {\n\t\t\t\tmodule: vert,\n\t\t\t\tentryPoint: shaderSource?.render?.vertMain || \"main\",\n\t\t\t\tbuffers: vertexBuffers.map((vertexBuffer) => vertexBuffer.getBufferDes())\n\t\t\t};\n\t\tif (renderState.primitive) pipelineDec.primitive = renderState.primitive.getGPUPrimitiveDec();\n\t\tif (renderState.depthStencil) pipelineDec.depthStencil = renderState.depthStencil.getGPUDepthStencilDec();\n\t\tif (renderState.multisample) pipelineDec.multisample = renderState.multisample.getMultiSampleDec();\n\t\tif (frag)\n\t\t\tpipelineDec.fragment = {\n\t\t\t\tmodule: frag,\n\t\t\t\tentryPoint: shaderSource?.render?.fragMain || \"main\",\n\t\t\t\ttargets: renderState.targets.map((target) => {\n\t\t\t\t\treturn target.getGPUTargetDec();\n\t\t\t\t})\n\t\t\t};\n\t\treturn pipelineDec;\n\t}\n}\n// Borrowed from https://werxltd.com/wp/2010/05/13/javascript-implementation-of-javas-string-hashcode-method/\nfunction stringToHash(str) {\n\tlet hash = 0;\n\tif (str.length == 0) return hash;\n\tfor (let i = 0; i < str.length; i++) {\n\t\tconst char = str.charCodeAt(i);\n\t\thash = (hash << 5) - hash + char;\n\t\thash = hash & hash; // Convert to 32bit integer\n\t}\n\treturn hash;\n}\n","import Camera from \"../camera/Camera\";\nimport { DrawCommandParams } from \"../core/WebGPUTypes\";\nimport { Material } from \"../material/Material\";\nimport { ShaderSource } from \"../shader/ShaderSource\";\nimport Buffer from \"./Buffer\";\nimport { Command } from \"./Command\";\nimport Context from \"./Context\";\nimport IndexBuffer from \"./IndexBuffer\";\nimport Pipeline from \"./Pipeline\";\nimport QuerySet from \"./QuerySet\";\nimport { RenderState, ScissorTest, ViewPort } from \"./RenderState\";\nimport RenderTarget from \"./RenderTarget\";\nimport ShaderData from \"./ShaderData\";\nimport VertexBuffer from \"./VertexBuffer\";\n\nclass DrawCommand implements Command {\n\tpublic shaderData?: ShaderData;\n\n\tpublic renderTarget?: RenderTarget;\n\n\tpublic vertexBuffers?: Array<VertexBuffer>;\n\n\tpublic indexBuffer?: IndexBuffer;\n\n\tpublic renderState?: RenderState;\n\n\tpublic queryIndex?: number;\n\n\tpublic count?: number;\n\n\tpublic instances?: number;\n\n\tpublic shaderSource?: ShaderSource;\n\n\tpublic dirty?: boolean;\n\n\tpublic indirectBuffer?: Buffer;\n\n\tpublic indirectOffset?: number;\n\n\tpublic lightShaderData?: ShaderData;\n\n\tpublic useLight?: boolean;\n\n\tconstructor(options: DrawCommandParams) {\n\t\tthis.shaderData = options.shaderData;\n\n\t\tthis.renderTarget = options.renderTarget;\n\n\t\tthis.useLight = options.useLight;\n\n\t\tthis.vertexBuffers = options.vertexBuffers;\n\n\t\tthis.indexBuffer = options.indexBuffer;\n\n\t\tthis.renderState = options.renderState;\n\n\t\tthis.queryIndex = options.queryIndex;\n\n\t\tthis.count = options.count;\n\n\t\tthis.instances = options.instances;\n\n\t\tthis.shaderSource = options.shaderSource;\n\n\t\tthis.dirty = options.dirty;\n\n\t\tthis.lightShaderData = options.lightShaderData;\n\t}\n\tpublic shallowClone(material?: Material) {\n\t\tif (!material) return;\n\t\treturn new DrawCommand({\n\t\t\tvertexBuffers: this.vertexBuffers,\n\t\t\tindexBuffer: this.indexBuffer,\n\t\t\tshaderData: material.shaderData,\n\t\t\tinstances: this.instances,\n\t\t\tcount: this.count,\n\t\t\trenderState: material.renderState,\n\t\t\tshaderSource: material.shaderSource,\n\t\t\tlightShaderData: material.light ? this.lightShaderData : undefined,\n\t\t\tuseLight: material.light\n\t\t});\n\t}\n\tpublic render(params?: RenderParams): void {\n\t\tconst { device, passEncoder, camera, querySet, viewPort, scissorTest } = params || {};\n\t\tconst {\n\t\t\tshaderData,\n\t\t\trenderState,\n\t\t\tvertexBuffers,\n\t\t\tindexBuffer,\n\t\t\tlightShaderData,\n\t\t\tshaderSource,\n\t\t\tcount,\n\t\t\tinstances,\n\t\t\trenderTarget,\n\t\t\tuseLight,\n\t\t\tindirectOffset,\n\t\t\tindirectBuffer,\n\t\t\tqueryIndex\n\t\t} = this;\n\t\tconst currentPassEncoder = renderTarget?.beginRenderPass?.(device) ?? passEncoder;\n\t\tconst defines = Object.assign({}, lightShaderData?.defines ?? {}, camera?.shaderData?.defines ?? {});\n\n\t\tshaderData?.bind?.(device, currentPassEncoder);\n\n\t\tcamera?.shaderData?.bind(device, currentPassEncoder);\n\n\t\tuseLight && lightShaderData?.bind?.(device, currentPassEncoder);\n\n\t\trenderState?.bind?.({\n\t\t\tpassEncoder: currentPassEncoder,\n\t\t\tviewPort: viewPort as ViewPort,\n\t\t\tscissorTest: <ScissorTest>scissorTest\n\t\t});\n\n\t\tvertexBuffers?.forEach?.((vertexBuffer: VertexBuffer) => vertexBuffer?.bind?.(device, currentPassEncoder));\n\n\t\tindexBuffer?.bind?.(device, currentPassEncoder);\n\n\t\tshaderSource?.setDefines?.(defines);\n\n\t\tconst pipeline = Pipeline.getRenderPipelineFromCache(device, this, [\n\t\t\tshaderData?.groupLayout,\n\t\t\tlightShaderData?.groupLayout,\n\t\t\tcamera?.shaderData?.groupLayout\n\t\t]);\n\t\tif (queryIndex != undefined) querySet?.beginQuery(currentPassEncoder, queryIndex);\n\t\tpipeline.bind(currentPassEncoder);\n\t\tif (indexBuffer) {\n\t\t\tif (indirectBuffer) {\n\t\t\t\tcurrentPassEncoder.drawIndexedIndirect(indirectBuffer.gpuBuffer, indirectOffset || 0);\n\t\t\t} else {\n\t\t\t\tcurrentPassEncoder.drawIndexed(count || 0, instances || 1, 0, 0, 0);\n\t\t\t}\n\t\t} else if (count) {\n\t\t\tif (indirectBuffer) {\n\t\t\t\tcurrentPassEncoder.drawIndirect(indirectBuffer.gpuBuffer, indirectOffset);\n\t\t\t} else {\n\t\t\t\tcurrentPassEncoder.draw(count, instances || 1, 0, 0);\n\t\t\t}\n\t\t}\n\t\tif (queryIndex != undefined) querySet?.endQuery(currentPassEncoder);\n\t\trenderTarget?.endRenderPass?.();\n\t}\n}\nexport default DrawCommand;\ntype RenderParams = {\n\tcontext?: Context;\n\tdevice?: GPUDevice;\n\tpassEncoder?: GPURenderPassEncoder;\n\tcamera?: Camera;\n\tquerySet?: QuerySet;\n\tviewPort?: ViewPort;\n\tscissorTest?: ScissorTest;\n};\n","import { Light } from \"../light/Light\";\nimport { Mesh } from \"../mesh/Mesh\";\nimport PostEffect from \"../post-process/PostEffect\";\nimport BindGroupEntity from \"../render/BindGroupEntity\";\nimport BindGroupLayout from \"../render/BindGroupLayout\";\nimport Buffer from \"../render/Buffer\";\nimport IndexBuffer from \"../render/IndexBuffer\";\nimport { RenderState } from \"../render/RenderState\";\nimport RenderTarget from \"../render/RenderTarget\";\nimport Sampler from \"../render/Sampler\";\nimport ShaderData from \"../render/ShaderData\";\nimport Texture from \"../render/Texture\";\nimport VertexBuffer from \"../render/VertexBuffer\";\nimport { ShaderSource } from \"../shader/ShaderSource\";\nimport {\n\tBlendFactor,\n\tBlendOperation,\n\tColorWriteFlags,\n\tCompareFunction,\n\tCullMode,\n\tFrontFace,\n\tIndexFormat,\n\tInputStepMode,\n\tPrimitiveTopology,\n\tShaderStage,\n\tStencilOperation,\n\tStorageTextureAccess,\n\tTextureFormat\n} from \"./WebGPUConstant\";\nexport const GPUCanvasCompositingAlphaMode: {\n\t[key: string]: GPUCanvasCompositingAlphaMode;\n} = {\n\tOpaque: \"opaque\",\n\tPremultiplied: \"premultiplied\"\n};\nexport interface ContextState {\n\tdevice: GPUDevice;\n\tglslang: {\n\t\tcompileGLSL: (source: string, type: string) => string;\n\t};\n\tdebug: boolean;\n\terror: boolean;\n}\n\nexport interface ContextOptions {\n\tcanvas?: HTMLCanvasElement;\n\tcontainer?: HTMLDivElement;\n\tcontext?: GPUCanvasContext;\n\tpixelRatio?: number;\n}\n\nexport interface LightMangerOptions {\n\topenShadow: boolean;\n}\n\nexport interface BindGroupLayoutEntry extends GPUBindGroupLayoutEntry {\n\tname: string;\n\tuniforms?: any[];\n\tdimension?: GPUTextureDimension;\n}\n\nexport interface BindGroupOptions extends GPUBindGroupDescriptor {\n\tresources: GPUBindingResource[];\n}\n\nexport type ShaderStageName = \"vertex\" | \"fragment\" | \"compute\";\n\nexport type ShaderStageNameObjectKeys = {\n\t[key in ShaderStageName]?: string;\n};\nexport type ShaderStageBodyName = \"vertexBody\" | \"fragmentBody\" | \"computeBody\";\nexport type ShaderStageBodyNameObjectKeys = {\n\t[key in ShaderStageBodyName]?: string;\n};\nexport interface AttachmentOptions {\n\top?: GPUStoreOp;\n\ttexture?: Texture;\n\tresolveTarget?: Texture;\n\tstoreOp?: GPUStoreOp;\n\ttextureView?: () => GPUTextureView;\n}\n\nexport type PassType = \"render\" | \"compute\";\n\nexport type GPUBindingType =\n\t| GPUBufferBindingType\n\t| GPUSamplerBindingType\n\t| GPUTextureSampleType\n\t| GPUStorageTextureAccess;\n\nexport type BindGroupLayoutEntryType = {\n\tbinding: number;\n\tvisibility: GPUShaderStageFlags;\n\tuniforms?: any[];\n\tbuffer?: GPUBufferBindingLayout;\n\tsampler?: GPUSamplerBindingLayout;\n\ttexture?: GPUTextureBindingLayout;\n\tstorageTexture?: GPUStorageTextureBindingLayout;\n\texternalTexture?: GPUExternalTextureBindingLayout;\n};\nexport type BufferResourceType = {\n\tbuffer: GPUBufferBindingType;\n\toffset: number;\n\tsize: number;\n};\nexport type samplerBindEntityResourceType = {\n\tresource: GPUSampler;\n};\nexport type textureBindEntityResourceType = {\n\tresource: GPUTextureView;\n};\nexport type BindGroupEntityResourceType =\n\t| BufferResourceType\n\t| samplerBindEntityResourceType\n\t| textureBindEntityResourceType;\nexport type BindGroupEntityOptions = {\n\tbinding: number;\n\tresource: GPUBindingResource;\n};\nexport type BindGroupCacheOptions = {\n\tdevice: GPUDevice;\n\tlabel: string;\n\tlayout: BindGroupLayout;\n\tentires: BindGroupEntity[];\n\tindex?: number;\n\toffset?: number;\n\talignedSize?: number;\n\tmaxOffset?: number;\n\tdynamic?: boolean;\n};\nexport type ImageData = {\n\tsource: ImageBitmap | HTMLCanvasElement | Texture;\n\twidth?: number;\n\theight?: number;\n\tdepth?: number;\n\tsourceX?: number;\n\tsourceY?: number;\n\tmipLevel?: number;\n\tx?: number;\n\ty?: number;\n\tz?: number;\n\taspect?: \"all\" | \"stencil-only\" | \"depth-only\";\n\tcolorSpace?: \"srgb\";\n\tpremultipliedAlpha?: boolean;\n};\nexport type WebGPUTextureProps = {\n\tsize: textureSize;\n\n\tfixedSize?: boolean;\n\n\tformat: string;\n\n\tlabel?: string;\n\n\tusage?: number;\n\n\tsampler?: Sampler;\n\n\tdata?: ImageData | Array<ImageData>;\n\n\tmipLevelCount?: number;\n\n\tsampleCount?: number;\n\n\tdimension?: dimension;\n\n\tviewFormats?: string;\n\n\tsampleType?: string;\n\n\tneedMipMap?: boolean;\n\n\tdataIsTexture?: boolean;\n\n\taccess?: StorageTextureAccess;\n};\nexport type textureSize = {\n\twidth: number;\n\theight: number;\n\tdepth: number;\n};\nexport type dimension = \"1d\" | \"2d\" | \"3d\";\nexport type bufferLayoutType = {\n\ttype: string; // \"uniform\"\n\thasDynamicOffset?: boolean;\n\tminBindingSize?: number;\n};\n// renderstate\nexport type DepthStencil = {\n\tformat: TextureFormat;\n\tdepthWriteEnabled: boolean;\n\tdepthCompare: CompareFunction;\n\tstencilReadMask?: number;\n\tstencilWriteMask?: number;\n\tstencilFront?: {\n\t\tcompare: CompareFunction;\n\t\tfailOp: StencilOperation;\n\t\tdepthFailOp: StencilOperation;\n\t\tpassOp: StencilOperation;\n\t};\n\tstencilBack?: {\n\t\tcompare: CompareFunction;\n\t\tfailOp: StencilOperation;\n\t\tdepthFailOp: StencilOperation;\n\t\tpassOp: StencilOperation;\n\t};\n\tdepthBias?: number;\n\tdepthBiasSlopeScale?: number;\n\tdepthBiasClamp?: number;\n};\nexport type PrimitiveState = {\n\tfrontFace?: FrontFace;\n\tcullMode?: CullMode;\n\tunclippedDepth?: boolean;\n\ttopology?: PrimitiveTopology;\n\tstripIndexFormat?: IndexFormat;\n};\nexport type MultiSample = {\n\tcount?: number;\n\tmask?: number;\n\talphaToCoverageEnabled?: boolean;\n};\nexport type Target = {\n\tformat: TextureFormat;\n\tblend?: {\n\t\tcolor: {\n\t\t\toperation: BlendOperation;\n\t\t\tsrcFactor: BlendFactor;\n\t\t\tdstFactor: BlendFactor;\n\t\t};\n\t\talpha: {\n\t\t\toperation: BlendOperation;\n\t\t\tsrcFactor: BlendFactor;\n\t\t\tdstFactor: BlendFactor;\n\t\t};\n\t};\n\twriteMask: ColorWriteFlags;\n};\nexport type BlendConstant = {\n\tr: number;\n\tg: number;\n\tb: number;\n\ta: number;\n};\nexport type RenderStateProps = {\n\tdepthStencil?: DepthStencil;\n\tprimitive?: PrimitiveState;\n\tmultisample?: MultiSample;\n\tstencilReference?: number;\n\ttargets?: Array<Target>;\n\tviewport?: { x: number; y: number; width: number; height: number };\n\tblendConstant?: BlendConstant;\n\tscissorTestEnabled?: boolean;\n\tstencilEnabled?: boolean;\n};\nexport type ViewPort = {\n\tx?: number;\n\ty?: number;\n\twidth?: number;\n\theight?: number;\n\tminDepth?: number;\n\tmaxDepth?: number;\n};\nexport type ScissorTest = {\n\tx: number;\n\ty: number;\n\twidth: number;\n\theight: number;\n};\nexport type ShaderMaterialParms = {\n\ttype: string;\n\tfrag: string | ShaderFunc;\n\tvert: string | ShaderFunc;\n\tuniforms: { [uniform: string]: IUniform };\n\tdefines?: ShaderDefine;\n\tlight?: boolean;\n};\nexport interface IUniform<TValue = any> {\n\ttype: string;\n\tvalue: TValue;\n\tbinding?: number;\n\tvisibility?: number;\n\ttextureView?: GPUTextureView;\n}\nexport type Uniforms = { [uniform: string]: IUniform };\nexport type Instance = Mesh | PostEffect | Light;\n\nexport enum RenderObjectType {\n\tCamera = \"camera\",\n\tLight = \"light\",\n\tMesh = \"mesh\",\n\tSkinMesh = \"skinMesh\",\n\tNode = \"node\",\n\tAxes = \"axes\",\n\tSkybox = \"skyBox\",\n\tPostEffect = \"postEffect\",\n\tDebug = \"debug\"\n}\nexport enum LightType {\n\tSpotLight = \"spotLight\",\n\tPointLight = \"pointLight\",\n\tAmbientLight = \"ambientLight\",\n\tDirectionalLight = \"directionalLight\"\n}\nexport type ShaderDefine = { [prop: string]: boolean | number };\n\nexport type ShaderSourceParams = {\n\tshaderId?: string;\n\tdefines?: ShaderDefine;\n\tcompute?: computeParams;\n\trender?: renderParams;\n};\nexport type renderParams = {\n\tvertMain?: string;\n\tfragMain?: string;\n\tfragShader?: string | ShaderFunc;\n\tvertShader?: string | ShaderFunc;\n};\nexport type computeParams = {\n\tcomputeMain?: string;\n\tcomputeShader?: string | ShaderFunc;\n};\nexport interface GPUShaderModuleObject {\n\tvert: GPUShaderModule;\n\tfrag: GPUShaderModule;\n}\nexport type ShaderFunc = (defines?: ShaderDefine) => string;\nexport type ShaderString = {\n\tvert?: string;\n\tfrag?: string;\n\tcompute?: string;\n};\nexport type ShaderModule = {\n\tvert?: GPUShaderModule;\n\tfrag?: GPUShaderModule;\n\tcompute?: GPUShaderModule;\n};\nexport type UniformFunc = () => any;\n\nexport type DrawCommandParams = {\n\tshaderData?: ShaderData;\n\n\trenderTarget?: RenderTarget;\n\n\tvertexBuffers?: Array<VertexBuffer>;\n\n\tindexBuffer?: IndexBuffer;\n\n\trenderState?: RenderState;\n\n\tqueryIndex?: number;\n\n\tcount?: number;\n\n\tinstances?: number;\n\n\tshaderSource?: ShaderSource;\n\n\tdirty?: boolean;\n\n\tlightShaderData?: ShaderData;\n\n\tuseLight?: boolean;\n};\n\nexport type ModelParams = {\n\tshaderId?: string;\n\tfrag?: string;\n\tvert?: string;\n\tcompute?: string;\n\tvertexBuffers?: Array<VertexBufferProp>;\n\tuniformTextureAndSampler?: {\n\t\t[uniform: string]: IUniform<any>;\n\t};\n\tuniformBuffers?: Array<UniformBufferProp>;\n\trenderState?: RenderStateProp;\n\tcount?: number;\n\tinstances?: number;\n\tindices?: Array<number>;\n\tdraw?: DrawParmas;\n\tdispatch?: { x?: number; y?: number; z?: number };\n\trenderTarget?: RenderTarget;\n};\nexport type VertexBufferProp = {\n\tuid?: string;\n\tstepMode?: string;\n\tarrayStride?: number;\n\tattributes?: { [prop: string]: AttributeProp };\n};\nexport type UniformBufferProp = {\n\tuid?: string;\n\ttype?: string;\n\tusage?: number;\n\tbinding?: number;\n\tbuffer?: Buffer;\n\tbufferSize?: number;\n\tvisiblity?: ShaderStage;\n\tuniforms?: { [uniform: string]: IUniform<any> };\n};\nexport type AttributeProp = {\n\tsize?: number;\n\tvalue?: [];\n\tnames?: Array<string>;\n\titemSizes?: [];\n\tbuffer?: Buffer;\n};\nexport type RenderStateProp = {\n\tstencilReference: number;\n\tblendConstant?: {\n\t\tr: number;\n\t\tg: number;\n\t\tb: number;\n\t\ta: number;\n\t};\n\tmultiSample?: {\n\t\tcount: number;\n\t\tmask: number;\n\t\talphaToCoverageEnabled: boolean;\n\t};\n\tscissorTest?: {\n\t\tx: number;\n\t\ty: number;\n\t\twidth: number;\n\t\theight: number;\n\t};\n\tviewPort?: {\n\t\tx: number;\n\t\ty: number;\n\t\twidth: number;\n\t\theight: number;\n\t\tminDepth: number;\n\t\tmaxDepth: number;\n\t};\n\tprimitive?: {\n\t\tfrontFace: string;\n\t\tcullMode: string;\n\t\tunclippedDepth: boolean;\n\t\ttopology: string;\n\t};\n\tdepthStencil?: {\n\t\tformat: string;\n\t\tdepthWriteEnabled: boolean;\n\t\tdepthCompare: string;\n\t\tstencilReadMask: number;\n\t\tstencilWriteMask: number;\n\t\tstencilFrontCompare: string;\n\t\tstencilFrontFailOp: string;\n\t\tstencilFrontDepthFailOp: string;\n\t\tstencilFrontPassOp: string;\n\n\t\tstencilBackCompare: string;\n\t\tstencilBackFailOp: string;\n\t\tstencilBackDepthFailOp: string;\n\t\tstencilBackPassOp: string;\n\t\tdepthBias: number;\n\t\tdepthBiasSlopeScale: number;\n\t\tdepthBiasClamp: number;\n\t};\n\ttargets?: Array<{\n\t\tformat?: string;\n\t\tblendColorOperation?: string;\n\t\tblendColorSrcFactor?: string;\n\t\tblendColorDstFactor?: string;\n\t\tblendAlphaOperation?: string;\n\t\tblendAlphaSrcFactor?: string;\n\t\tblendAlphaDstFactor?: string;\n\t\twriteMask: GPUColorWrite;\n\t}>;\n};\nexport type DrawParmas = {\n\tcount?: number; // The number of indices to draw./The number of vertices to draw.\n\tinstanceCount?: number; // The number of instances to draw.\n\tfirstIndex?: number; // Offset into the index buffer, in indices, begin drawing\n\tfirstVertex?: number; // Offset into the vertex buffers, in vertices, to begin drawing from.\n\tbaseVertex?: number; //  Added to each index value before indexing into the vertex buffers.\n\tfirstInstance?: number; // First instance to draw.\n};\nexport type UniformStruct = {\n\t[uniform: string]: { type?: string; value?: object | Array<number>; offset?: number };\n};\nexport enum UniformEnum {\n\tFloat = \"f32\",\n\tFloatVec2 = \"vec2<f32>\",\n\tFloatVec3 = \"vec3<f32>\",\n\tFloatVec4 = \"vec4<f32>\",\n\tFloatArray = \"array<f32>\",\n\tMat2 = \"mat2x2<f32>\",\n\tMat3 = \"mat3x3<f32>\",\n\tMat4 = \"mat4x4<f32>\",\n\tColor = \"color\",\n\tMat4Array = \"array<mat4x4<f32>>\",\n\tVec2Array = \"array<vec2<f32>>\",\n\tVec3Array = \"array<vec3<f32>>\",\n\tVec4Array = \"array<vec4<f32>>\",\n\tUniformUint = \"u32\",\n\tPointLights = \"pointLights\",\n\tPointLightShadows = \"pointLightShadows\",\n\tSpotLights = \"spotLights\",\n\tSpotLightShadows = \"spotLightShadows\",\n\tDirtectLights = \"dirtectLights\",\n\tDirtectLightShadows = \"dirtectLightShadows\",\n\tUniformStructArray = \"StructArray\"\n}\nexport type VertexBufferParams = {\n\tlabel: string;\n\tindex?: number;\n\tlocationIndex?: number;\n\tstepMode?: InputStepMode;\n\tarrayStride?: number;\n};\n","import Texture from \"../render/Texture\";\n\nexport class MipmapGenerator {\n\tdevice: GPUDevice;\n\tsampler: GPUSampler;\n\tpipelines: object;\n\tmipmapShaderModule: GPUShaderModule;\n\tconstructor(device) {\n\t\tthis.device = device;\n\t\tthis.sampler = device.createSampler({ minFilter: \"linear\" });\n\t\t// We'll need a new pipeline for every texture format used.\n\t\tthis.pipelines = {};\n\t}\n\tprivate getMipmapPipeline(format) {\n\t\tlet pipeline = this.pipelines[format];\n\t\tif (!pipeline) {\n\t\t\t// Shader modules is shared between all pipelines, so only create once.\n\t\t\tif (!this.mipmapShaderModule) {\n\t\t\t\tthis.mipmapShaderModule = this.device.createShaderModule({\n\t\t\t\t\tcode: `\n              var<private> pos : array<vec2<f32>, 3> = array<vec2<f32>, 3>(\n                vec2<f32>(-1.0, -1.0), vec2<f32>(-1.0, 3.0), vec2<f32>(3.0, -1.0));\n              struct VertexOutput {\n                @builtin(position) position : vec4<f32>,\n                @location(0) texCoord : vec2<f32>,\n              };\n              @vertex\n              fn vertexMain(@builtin(vertex_index) vertexIndex : u32) -> VertexOutput {\n                var output : VertexOutput;\n                output.texCoord = pos[vertexIndex] * vec2<f32>(0.5, -0.5) + vec2<f32>(0.5);\n                output.position = vec4<f32>(pos[vertexIndex], 0.0, 1.0);\n                return output;\n              }\n              @group(0) @binding(0) var imgSampler : sampler;\n              @group(0) @binding(1) var img : texture_2d<f32>;\n              @fragment\n              fn fragmentMain(@location(0) texCoord : vec2<f32>) -> @location(0) vec4<f32> {\n                return textureSample(img, imgSampler, texCoord);\n              }\n            `\n\t\t\t\t});\n\t\t\t}\n\t\t\tpipeline = this.device.createRenderPipeline({\n\t\t\t\tlayout: \"auto\",\n\t\t\t\tvertex: {\n\t\t\t\t\tmodule: this.mipmapShaderModule,\n\t\t\t\t\tentryPoint: \"vertexMain\"\n\t\t\t\t},\n\t\t\t\tfragment: {\n\t\t\t\t\tmodule: this.mipmapShaderModule,\n\t\t\t\t\tentryPoint: \"fragmentMain\",\n\t\t\t\t\ttargets: [{ format }]\n\t\t\t\t}\n\t\t\t});\n\t\t\tthis.pipelines[format] = pipeline;\n\t\t}\n\t\treturn pipeline;\n\t}\n\n\t/**\n\t * Generates mipmaps for the given GPUTexture from the data in level 0.\n\t *\n\t * @param {module:External.GPUTexture} texture - Texture to generate mipmaps for.\n\t * @param {object} textureDescriptor - GPUTextureDescriptor the texture was created with.\n\t * @returns {module:External.GPUTexture} - The originally passed texture\n\t */\n\tgenerateMipmap(sourceTexture: Texture) {\n\t\tconst texture = sourceTexture.gpuTexture;\n\t\tconst textureDescriptor = sourceTexture.textureProp;\n\t\t// TODO: Does this need to handle sRGB formats differently?\n\t\tconst pipeline = this.getMipmapPipeline(textureDescriptor.format);\n\n\t\tif (textureDescriptor.dimension == \"3d\" || textureDescriptor.dimension == \"1d\") {\n\t\t\tthrow new Error(\"Generating mipmaps for non-2d textures is currently unsupported!\");\n\t\t}\n\n\t\tlet mipTexture = texture;\n\t\tconst arrayLayerCount = textureDescriptor.size.depth || 1; // Only valid for 2D textures.\n\n\t\t// If the texture was created with RENDER_ATTACHMENT usage we can render directly between mip levels.\n\t\tconst renderToSource = textureDescriptor.usage & GPUTextureUsage.RENDER_ATTACHMENT;\n\t\tif (!renderToSource) {\n\t\t\t// Otherwise we have to use a separate texture to render into. It can be one mip level smaller than the source\n\t\t\t// texture, since we already have the top level.\n\t\t\tconst mipTextureDescriptor = {\n\t\t\t\tsize: {\n\t\t\t\t\twidth: Math.ceil(textureDescriptor.size.width / 2),\n\t\t\t\t\theight: Math.ceil(textureDescriptor.size.height / 2),\n\t\t\t\t\tdepthOrArrayLayers: arrayLayerCount\n\t\t\t\t},\n\t\t\t\tformat: <GPUTextureFormat>textureDescriptor.format,\n\t\t\t\tusage: GPUTextureUsage.TEXTURE_BINDING | GPUTextureUsage.COPY_SRC | GPUTextureUsage.RENDER_ATTACHMENT,\n\t\t\t\tmipLevelCount: textureDescriptor.mipLevelCount - 1\n\t\t\t};\n\t\t\tmipTexture = this.device.createTexture(mipTextureDescriptor);\n\t\t}\n\n\t\tconst commandEncoder = this.device.createCommandEncoder({});\n\t\t// TODO: Consider making this static.\n\t\tconst bindGroupLayout = pipeline.getBindGroupLayout(0);\n\n\t\tfor (let arrayLayer = 0; arrayLayer < arrayLayerCount; ++arrayLayer) {\n\t\t\tlet srcView = texture.createView({\n\t\t\t\tbaseMipLevel: 0,\n\t\t\t\tmipLevelCount: 1,\n\t\t\t\tdimension: \"2d\",\n\t\t\t\tbaseArrayLayer: arrayLayer,\n\t\t\t\tarrayLayerCount: 1\n\t\t\t});\n\n\t\t\tlet dstMipLevel = renderToSource ? 1 : 0;\n\t\t\tfor (let i = 1; i < textureDescriptor.mipLevelCount; ++i) {\n\t\t\t\tconst dstView = mipTexture.createView({\n\t\t\t\t\tbaseMipLevel: dstMipLevel++,\n\t\t\t\t\tmipLevelCount: 1,\n\t\t\t\t\tdimension: \"2d\",\n\t\t\t\t\tbaseArrayLayer: arrayLayer,\n\t\t\t\t\tarrayLayerCount: 1\n\t\t\t\t});\n\n\t\t\t\tconst passEncoder = commandEncoder.beginRenderPass({\n\t\t\t\t\tcolorAttachments: [\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tview: dstView,\n\t\t\t\t\t\t\tloadOp: \"clear\",\n\t\t\t\t\t\t\tstoreOp: \"store\"\n\t\t\t\t\t\t}\n\t\t\t\t\t]\n\t\t\t\t});\n\n\t\t\t\tconst bindGroup = this.device.createBindGroup({\n\t\t\t\t\tlayout: bindGroupLayout,\n\t\t\t\t\tentries: [\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tbinding: 0,\n\t\t\t\t\t\t\tresource: this.sampler\n\t\t\t\t\t\t},\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tbinding: 1,\n\t\t\t\t\t\t\tresource: srcView\n\t\t\t\t\t\t}\n\t\t\t\t\t]\n\t\t\t\t});\n\n\t\t\t\tpassEncoder.setPipeline(pipeline);\n\t\t\t\tpassEncoder.setBindGroup(0, bindGroup);\n\t\t\t\tpassEncoder.draw(3, 1, 0, 0);\n\t\t\t\tpassEncoder.end();\n\n\t\t\t\tsrcView = dstView;\n\t\t\t}\n\t\t}\n\n\t\t// If we didn't render to the source texture, finish by copying the mip results from the temporary mipmap texture\n\t\t// to the source.\n\t\tif (!renderToSource) {\n\t\t\tconst mipLevelSize = {\n\t\t\t\twidth: Math.ceil(textureDescriptor.size.width / 2),\n\t\t\t\theight: Math.ceil(textureDescriptor.size.height / 2),\n\t\t\t\tdepthOrArrayLayers: arrayLayerCount\n\t\t\t};\n\n\t\t\tfor (let i = 1; i < textureDescriptor.mipLevelCount; ++i) {\n\t\t\t\tcommandEncoder.copyTextureToTexture(\n\t\t\t\t\t{\n\t\t\t\t\t\ttexture: mipTexture,\n\t\t\t\t\t\tmipLevel: i - 1\n\t\t\t\t\t},\n\t\t\t\t\t{\n\t\t\t\t\t\ttexture: texture,\n\t\t\t\t\t\tmipLevel: i\n\t\t\t\t\t},\n\t\t\t\t\tmipLevelSize\n\t\t\t\t);\n\n\t\t\t\tmipLevelSize.width = Math.ceil(mipLevelSize.width / 2);\n\t\t\t\tmipLevelSize.height = Math.ceil(mipLevelSize.height / 2);\n\t\t\t}\n\t\t}\n\n\t\tthis.device.queue.submit([commandEncoder.finish()]);\n\n\t\tif (!renderToSource) {\n\t\t\tmipTexture.destroy();\n\t\t}\n\n\t\treturn texture;\n\t}\n}\n","function defaultValue(a, b) {\n\tif (a !== undefined && a !== null) {\n\t\treturn a;\n\t}\n\treturn b;\n}\n\n/**\n * A frozen empty object that can be used as the default value for options passed as\n * an object literal.\n * @type {Object}\n * @memberof defaultValue\n */\ndefaultValue.EMPTY_OBJECT = Object.freeze({});\n\nexport default defaultValue;\n","import {\n\tBlendFactor,\n\tBlendOperation,\n\tTextureFormat,\n\tGPUColorWrite,\n\tCompareFunction,\n\tStencilOperation,\n\tFrontFace,\n\tCullMode,\n\tPrimitiveTopology\n} from \"../core/WebGPUConstant\";\n// import { BindRenderState } from \"../core/WebGPUTypes\";\nimport defaultValue from \"../utils/defaultValue\";\n\nexport class RenderState {\n\tscissorTest: ScissorTest;\n\tviewport: ViewPort;\n\ttargets: Array<Target>;\n\tdepthStencil: DepthStencil;\n\tblendConstant: BlendConstant;\n\tstencilReference: number;\n\tmultisample: MultiSample;\n\tprimitive: Primitive;\n\tstencilEnabled: boolean;\n\tscissorTestEnabled: boolean;\n\tconstructor(params?: RenderStateParams) {\n\t\tthis.scissorTest = params?.scissorTest;\n\t\tthis.viewport = params?.viewport;\n\t\tthis.depthStencil = params?.depthStencil;\n\t\tthis.blendConstant = params?.blendConstant;\n\t\tthis.stencilReference = params?.stencilReference;\n\t\tthis.multisample = params?.multisample;\n\t\tthis.primitive = params?.primitive;\n\t\tthis.stencilEnabled = false;\n\t\tthis.scissorTestEnabled = false;\n\t\tthis.targets = params?.targets;\n\t}\n\tbind(params: BindRenderState) {\n\t\tconst { passEncoder, viewPort, scissorTest } = params;\n\t\tconst finalViewport = this.viewport ?? viewPort;\n\t\tconst finalScissorTest = this.scissorTest ?? scissorTest;\n\t\tif (this.stencilReference) passEncoder.setStencilReference(this.stencilReference);\n\t\tif ((finalViewport as ViewPort)?.equalsAndUpdateCache(cacheViewPort)) {\n\t\t\tconst { x, y, width, height, minDepth, maxDepth } = finalViewport;\n\t\t\tpassEncoder.setViewport(x, y, width, height, minDepth, maxDepth);\n\t\t}\n\t\tif (this.blendConstant) passEncoder.setBlendConstant(this.blendConstant);\n\t\tif ((finalScissorTest as ScissorTest)?.equalsAndUpdateCache(cacheScissorTest)) {\n\t\t\tconst { x, y, width, height } = finalScissorTest;\n\t\t\tpassEncoder.setScissorRect(x, y, width, height);\n\t\t}\n\t}\n\tdestroy() {\n\t\tthis.scissorTest = undefined;\n\t\tthis.viewport = undefined;\n\t\tthis.depthStencil = undefined;\n\t\tthis.blendConstant = undefined;\n\t\tthis.stencilReference = -1;\n\t\tthis.multisample = undefined;\n\t\tthis.primitive = undefined;\n\t\tthis.stencilEnabled = false;\n\t\tthis.scissorTestEnabled = false;\n\t}\n}\nexport class BlendConstant {\n\tr: number;\n\tg: number;\n\tb: number;\n\ta: number;\n\tconstructor(r: number, g: number, b: number, a: number) {\n\t\tthis.r = r;\n\t\tthis.g = g;\n\t\tthis.b = b;\n\t\tthis.a = a;\n\t}\n}\nexport class MultiSample {\n\tcount: number;\n\tmask: number;\n\talphaToCoverageEnabled: boolean;\n\tconstructor(count = 1, mask = 0xffffffff, alphaToCoverageEnabled = false) {\n\t\tthis.count = count;\n\t\tthis.mask = mask;\n\t\tthis.alphaToCoverageEnabled = alphaToCoverageEnabled;\n\t}\n\tgetMultiSampleDec() {\n\t\treturn {\n\t\t\tcount: this.count,\n\t\t\tmask: this.mask,\n\t\t\talphaToCoverageEnabled: this.alphaToCoverageEnabled\n\t\t};\n\t}\n}\nexport class ScissorTest {\n\tx: number;\n\ty: number;\n\twidth: number;\n\theight: number;\n\tvariable: boolean;\n\tconstructor(x = 0, y = 0, width = 0, height = 0, variable = true) {\n\t\tthis.x = x;\n\t\tthis.y = y;\n\t\tthis.width = width;\n\t\tthis.height = height;\n\t\tthis.variable = variable;\n\t}\n\tset(x: number, y: number, width: number, height: number) {\n\t\tthis.x = x;\n\t\tthis.y = y;\n\t\tthis.width = width;\n\t\tthis.height = height;\n\t}\n\tequalsAndUpdateCache(scissorTest: ScissorTest): boolean {\n\t\tconst { x, y, width, height } = scissorTest;\n\t\tif (this.x != x || this.y != y || this.width != width || this.height != height) {\n\t\t\tscissorTest.set(this.x, this.y, this.width, this.height);\n\t\t\treturn true;\n\t\t}\n\t\treturn false;\n\t}\n}\nexport class ViewPort {\n\tx: number;\n\ty: number;\n\twidth: number;\n\theight: number;\n\tminDepth: number;\n\tmaxDepth: number;\n\tvariable: boolean;\n\tconstructor(x = 0, y = 0, width = 0, height = 0, minDepth = 0, maxDepth = 1, variable = true) {\n\t\tthis.x = x;\n\t\tthis.y = y;\n\t\tthis.width = width;\n\t\tthis.height = height;\n\t\tthis.minDepth = minDepth;\n\t\tthis.maxDepth = maxDepth;\n\t\tthis.variable = variable;\n\t}\n\tset(x: number, y: number, width: number, height: number, minDepth = 0, maxDepth = 1) {\n\t\tif (!this.variable) return;\n\t\tthis.x = x;\n\t\tthis.y = y;\n\t\tthis.width = width;\n\t\tthis.height = height;\n\t\tthis.minDepth = minDepth;\n\t\tthis.maxDepth = maxDepth;\n\t}\n\tequalsAndUpdateCache(viewPort: ViewPort): boolean {\n\t\tconst { x, y, width, height, minDepth, maxDepth } = viewPort;\n\t\tif (\n\t\t\tthis.x != x ||\n\t\t\tthis.y != y ||\n\t\t\tthis.width != width ||\n\t\t\tthis.height != height ||\n\t\t\tthis.minDepth != minDepth ||\n\t\t\tthis.maxDepth != maxDepth\n\t\t) {\n\t\t\tviewPort.set(this.x, this.y, this.width, this.height, this.minDepth, this.maxDepth);\n\t\t\treturn true;\n\t\t}\n\t\treturn false;\n\t}\n}\nexport class Primitive {\n\tfrontFace: FrontFace;\n\tcullMode: CullMode;\n\tunclippedDepth: boolean;\n\ttopology: PrimitiveTopology;\n\tconstructor(topology?: PrimitiveTopology, cullMode?: CullMode, frontFace?: FrontFace, unclippedDepth?: boolean) {\n\t\tthis.frontFace = defaultValue(frontFace, FrontFace.CCW);\n\t\tthis.cullMode = defaultValue(cullMode, CullMode.None);\n\t\tthis.unclippedDepth = defaultValue(unclippedDepth, false);\n\t\tthis.topology = defaultValue(topology, PrimitiveTopology.TriangleList);\n\t}\n\tgetGPUPrimitiveDec() {\n\t\treturn {\n\t\t\tfrontFace: this.frontFace,\n\t\t\tcullMode: this.cullMode,\n\t\t\tunclippedDepth: this.unclippedDepth,\n\t\t\ttopology: this.topology\n\t\t};\n\t}\n}\nexport class DepthStencil {\n\tformat: TextureFormat;\n\tdepthWriteEnabled: boolean;\n\tdepthCompare: CompareFunction;\n\tstencilReadMask: number;\n\tstencilWriteMask: number;\n\tstencilFrontCompare: CompareFunction;\n\tstencilFrontFailOp: StencilOperation;\n\tstencilFrontDepthFailOp: StencilOperation;\n\tstencilFrontPassOp: StencilOperation;\n\n\tstencilBackCompare: CompareFunction;\n\tstencilBackFailOp: StencilOperation;\n\tstencilBackDepthFailOp: StencilOperation;\n\tstencilBackPassOp: StencilOperation;\n\tdepthBias: number;\n\tdepthBiasSlopeScale: number;\n\tdepthBiasClamp: number;\n\tconstructor(options?: DepthStencilProps) {\n\t\tthis.format = defaultValue(options?.format, TextureFormat.Depth24Plus);\n\t\tthis.depthWriteEnabled = defaultValue(options?.depthWriteEnabled, true);\n\t\tthis.depthCompare = defaultValue(options?.depthCompare, CompareFunction.Less);\n\t\tthis.stencilReadMask = defaultValue(options?.stencilReadMask, 0xffffffff);\n\t\tthis.stencilWriteMask = defaultValue(options?.stencilWriteMask, 0xffffffff);\n\t\tthis.stencilFrontCompare = defaultValue(options?.stencilFrontCompare, CompareFunction.Always);\n\t\tthis.stencilFrontFailOp = defaultValue(options?.stencilFrontFailOp, StencilOperation.Keep);\n\t\tthis.stencilFrontDepthFailOp = defaultValue(options?.stencilFrontDepthFailOp, StencilOperation.Keep);\n\t\tthis.stencilFrontPassOp = defaultValue(options?.stencilFrontPassOp, StencilOperation.Keep);\n\t\tthis.stencilBackCompare = defaultValue(options?.stencilBackCompare, CompareFunction.Always);\n\t\tthis.stencilBackFailOp = defaultValue(options?.stencilBackFailOp, StencilOperation.Keep);\n\t\tthis.stencilBackDepthFailOp = defaultValue(options?.stencilBackDepthFailOp, StencilOperation.Keep);\n\t\tthis.stencilBackPassOp = defaultValue(options?.stencilBackPassOp, StencilOperation.Keep);\n\t\tthis.depthBias = defaultValue(options?.depthBias, 0);\n\t\tthis.depthBiasSlopeScale = defaultValue(options?.depthBiasSlopeScale, 0);\n\t\tthis.depthBiasClamp = defaultValue(options?.depthBiasClamp, 0);\n\t}\n\tgetGPUDepthStencilDec() {\n\t\treturn {\n\t\t\tformat: this.format,\n\t\t\tdepthWriteEnabled: this.depthWriteEnabled,\n\t\t\tdepthCompare: this.depthCompare,\n\t\t\tstencilReadMask: this.stencilReadMask,\n\t\t\tstencilWriteMask: this.stencilWriteMask,\n\t\t\tstencilFront: {\n\t\t\t\tcompare: this.stencilFrontCompare,\n\t\t\t\tfailOp: this.stencilFrontFailOp,\n\t\t\t\tdepthFailOp: this.stencilFrontDepthFailOp,\n\t\t\t\tpassOp: this.stencilFrontPassOp\n\t\t\t},\n\t\t\tstencilBack: {\n\t\t\t\tcompare: this.stencilBackCompare,\n\t\t\t\tfailOp: this.stencilBackFailOp,\n\t\t\t\tdepthFailOp: this.stencilBackDepthFailOp,\n\t\t\t\tpassOp: this.stencilBackPassOp\n\t\t\t},\n\t\t\tdepthBias: this.depthBias,\n\t\t\tdepthBiasSlopeScale: this.depthBiasSlopeScale,\n\t\t\tdepthBiasClamp: this.depthBiasClamp\n\t\t};\n\t}\n}\nexport class Target {\n\tformat: TextureFormat;\n\tblendColorOperation?: BlendOperation;\n\tblendColorSrcFactor?: BlendFactor;\n\tblendColorDstFactor?: BlendFactor;\n\tblendAlphaOperation?: BlendOperation;\n\tblendAlphaSrcFactor?: BlendFactor;\n\tblendAlphaDstFactor?: BlendFactor;\n\twriteMask: GPUColorWrite;\n\tconstructor(options?: TargetProps) {\n\t\tthis.format = defaultValue(options?.format, TextureFormat.BGRA8Unorm);\n\t\tthis.blendColorOperation = defaultValue(options?.blendColorOperation, BlendOperation.Add);\n\t\tthis.blendColorSrcFactor = defaultValue(options?.blendColorSrcFactor, BlendFactor?.SrcAlpha);\n\t\tthis.blendColorDstFactor = defaultValue(options?.blendColorDstFactor, BlendFactor.OneMinusSrcAlpha);\n\t\tthis.blendAlphaOperation = defaultValue(options?.blendAlphaOperation, BlendOperation.Add);\n\t\tthis.blendAlphaSrcFactor = defaultValue(options?.blendAlphaSrcFactor, BlendFactor.One);\n\t\tthis.blendAlphaDstFactor = defaultValue(options?.blendAlphaDstFactor, BlendFactor.One);\n\t\tthis.writeMask = defaultValue(options?.writeMask, GPUColorWrite.All);\n\t}\n\tgetGPUTargetDec() {\n\t\treturn {\n\t\t\tformat: this.format,\n\t\t\tblend: {\n\t\t\t\tcolor: {\n\t\t\t\t\toperation: this.blendColorOperation,\n\t\t\t\t\tsrcFactor: this.blendColorSrcFactor,\n\t\t\t\t\tdstFactor: this.blendColorDstFactor\n\t\t\t\t},\n\t\t\t\talpha: {\n\t\t\t\t\toperation: this.blendAlphaOperation,\n\t\t\t\t\tsrcFactor: this.blendAlphaSrcFactor,\n\t\t\t\t\tdstFactor: this.blendAlphaDstFactor\n\t\t\t\t}\n\t\t\t},\n\t\t\twriteMask: this.writeMask\n\t\t};\n\t}\n}\nconst cacheViewPort = new ViewPort();\nconst cacheScissorTest = new ScissorTest();\nexport type DepthStencilProps = {\n\tformat?: TextureFormat;\n\tdepthWriteEnabled?: boolean;\n\tdepthCompare?: CompareFunction;\n\tstencilReadMask?: number;\n\tstencilWriteMask?: number;\n\tstencilFrontCompare?: CompareFunction;\n\tstencilFrontFailOp?: StencilOperation;\n\tstencilFrontDepthFailOp?: StencilOperation;\n\tstencilFrontPassOp?: StencilOperation;\n\n\tstencilBackCompare?: CompareFunction;\n\tstencilBackFailOp?: StencilOperation;\n\tstencilBackDepthFailOp?: StencilOperation;\n\tstencilBackPassOp?: StencilOperation;\n\tdepthBias?: number;\n\tdepthBiasSlopeScale?: number;\n\tdepthBiasClamp?: number;\n};\nexport type TargetProps = {\n\tformat?: TextureFormat;\n\tblendColorOperation?: BlendOperation;\n\tblendColorSrcFactor?: BlendFactor;\n\tblendColorDstFactor?: BlendFactor;\n\tblendAlphaOperation?: BlendOperation;\n\tblendAlphaSrcFactor?: BlendFactor;\n\tblendAlphaDstFactor?: BlendFactor;\n\twriteMask?: GPUColorWrite;\n};\nexport type RenderStateParams = {\n\tscissorTest?: ScissorTest;\n\tviewport?: ViewPort;\n\ttargets?: Array<Target>;\n\tdepthStencil?: DepthStencil;\n\tblendConstant?: BlendConstant;\n\tstencilReference?: number;\n\tmultisample?: MultiSample;\n\tprimitive?: Primitive;\n\tstencilEnabled?: boolean;\n\tscissorTestEnabled?: boolean;\n};\nexport type BindRenderState = {\n\tpassEncoder: GPURenderPassEncoder;\n\tviewPort: ViewPort;\n\tscissorTest: ScissorTest;\n};\n","import { TextureUsage } from \"../core/WebGPUConstant\";\nimport { GPUCanvasCompositingAlphaMode, ContextOptions } from \"../core/WebGPUTypes\";\nimport { MipmapGenerator } from \"../utils/MipmapGenerator\";\nimport { ScissorTest, ViewPort } from \"./RenderState\";\n\nclass Context {\n\tpublic canvas: HTMLCanvasElement;\n\n\tpublic context: GPUCanvasContext;\n\n\tpublic pixelRatio: number;\n\n\tpublic device: GPUDevice;\n\n\tprivate adapter: GPUAdapter;\n\n\tpublic presentationSize: { width: number; height: number; depth: number };\n\n\tpublic presentationFormat: GPUTextureFormat;\n\n\tpublic mipmapTools: MipmapGenerator;\n\n\tprivate _viewPort: ViewPort;\n\n\tprivate _scissorTest: ScissorTest;\n\n\tpublic get viewPort(): ViewPort {\n\t\treturn this._viewPort;\n\t}\n\n\tpublic get scissorTest(): ScissorTest {\n\t\treturn this._scissorTest;\n\t}\n\tconstructor({ canvas, container, context, pixelRatio }: ContextOptions = {}) {\n\t\tif (!container.clientWidth || !container.clientHeight) throw new Error(\"container width or height illegality\");\n\t\tthis.canvas = canvas || document.createElement(\"canvas\");\n\t\t// this.canvas.style.display = \"block\";\n\t\tthis.pixelRatio = pixelRatio || window.devicePixelRatio || 1;\n\t\tconst width = container.clientWidth * this.pixelRatio;\n\t\tconst height = container.clientHeight * this.pixelRatio;\n\t\tthis.canvas.width = width;\n\t\tthis.canvas.height = height;\n\t\tthis.canvas.style.width = container.clientWidth + \"px\";\n\t\tthis.canvas.style.height = container.clientHeight + \"px\";\n\t\tcontainer.appendChild(this.canvas);\n\t\tthis.context = context || (this.canvas.getContext(\"webgpu\") as GPUCanvasContext);\n\n\t\tthis.device = undefined;\n\t}\n\n\tpublic async init(\n\t\trequestAdapter = {},\n\t\tdeviceDescriptor = {},\n\t\tpresentationContextDescriptor = {}\n\t): Promise<boolean> {\n\t\ttry {\n\t\t\tif (!this.context) {\n\t\t\t\tthrow new Error(`Failed to instantiate \"webgpu\" context.`);\n\t\t\t}\n\t\t\tif (!navigator.gpu) {\n\t\t\t\tthrow new Error(`Missing \"navigator.gpu\".`);\n\t\t\t}\n\n\t\t\tthis.adapter = await navigator.gpu.requestAdapter();\n\t\t\tthis.device = await this.adapter.requestDevice();\n\t\t\tthis.presentationSize = {\n\t\t\t\twidth: this.canvas.clientWidth * this.pixelRatio,\n\t\t\t\theight: this.canvas.clientHeight * this.pixelRatio,\n\t\t\t\tdepth: 1\n\t\t\t};\n\t\t\tthis.presentationFormat = navigator.gpu.getPreferredCanvasFormat();\n\t\t\tthis.device.addEventListener(\"uncapturederror\", (error) => {\n\t\t\t\tconsole.error(error);\n\t\t\t\t// State.error = true;\n\t\t\t});\n\t\t\tthis.mipmapTools = new MipmapGenerator(this.device);\n\t\t\tthis.context.configure({\n\t\t\t\tdevice: this.device,\n\t\t\t\tformat: this.presentationFormat,\n\t\t\t\tusage: TextureUsage.RenderAttachment,\n\t\t\t\talphaMode: \"premultiplied\",\n\t\t\t\t...presentationContextDescriptor\n\t\t\t});\n\t\t\tthis._viewPort = new ViewPort(\n\t\t\t\t0,\n\t\t\t\t0,\n\t\t\t\tthis.canvas.clientWidth * this.pixelRatio,\n\t\t\t\tthis.canvas.clientHeight * this.pixelRatio\n\t\t\t);\n\t\t\tthis._scissorTest = new ScissorTest(\n\t\t\t\t0,\n\t\t\t\t0,\n\t\t\t\tthis.canvas.clientWidth * this.pixelRatio,\n\t\t\t\tthis.canvas.clientHeight * this.pixelRatio\n\t\t\t);\n\t\t} catch (error) {\n\t\t\tconsole.error(error);\n\t\t\treturn false;\n\t\t}\n\n\t\treturn true;\n\t}\n\tpublic setViewPort(x: number, y: number, width: number, height: number) {\n\t\tthis._viewPort.set(x, y, width, height);\n\t}\n\n\tpublic resetViewPortToFullCanvas() {\n\t\tthis._viewPort.set(0, 0, this.canvas.clientWidth * this.pixelRatio, this.canvas.clientHeight * this.pixelRatio);\n\t}\n\n\tpublic setScissorTest(x: number, y: number, width: number, height: number) {\n\t\tthis._scissorTest.set(x, y, width, height);\n\t}\n\tpublic resize(width: number, height: number, presentationContextDescriptor = {}): void {\n\t\tconst w = width * this.pixelRatio;\n\t\tconst h = height * this.pixelRatio;\n\t\tthis.canvas.style.width = w + \"px\";\n\t\tthis.canvas.style.height = h + \"px\";\n\t\tthis.canvas.width = w;\n\t\tthis.canvas.height = h;\n\t\tthis.presentationSize = {\n\t\t\twidth: w,\n\t\t\theight: h,\n\t\t\tdepth: 1\n\t\t};\n\t\tthis.context.configure({\n\t\t\tdevice: this.device,\n\t\t\tformat: navigator.gpu.getPreferredCanvasFormat(),\n\t\t\tusage: TextureUsage.RenderAttachment,\n\t\t\talphaMode: GPUCanvasCompositingAlphaMode.Premultiplied,\n\t\t\t...presentationContextDescriptor\n\t\t});\n\t}\n}\n\nexport default Context;\n","import { StorageTextureAccess, TextureFormat } from \"../core/WebGPUConstant\";\nimport { WebGPUTextureProps, ImageData } from \"../core/WebGPUTypes\";\nimport defaultValue from \"../utils/defaultValue\";\nimport { MipmapGenerator } from \"../utils/MipmapGenerator\";\nimport Context from \"./Context\";\n\nexport default class Texture {\n\t[x: string]: any;\n\tprivate _textureView: GPUTextureView;\n\tpublic gpuTexture?: GPUTexture;\n\tpublic mipLevelCount?: number;\n\tpublic context?: Context;\n\tpublic device?: GPUDevice;\n\tpublic textureProp?: WebGPUTextureProps;\n\tpublic dirty: boolean;\n\tpublic fixedSize: boolean;\n\tpublic static mipmapTools: MipmapGenerator;\n\tconstructor(textureProp: WebGPUTextureProps) {\n\t\tthis.textureProp = Object.assign(\n\t\t\t{\n\t\t\t\tformat: TextureFormat.RGBA8Unorm,\n\t\t\t\tusage: GPUTextureUsage.TEXTURE_BINDING | GPUTextureUsage.COPY_DST | GPUTextureUsage.RENDER_ATTACHMENT,\n\t\t\t\tdataIsTexture: false\n\t\t\t},\n\t\t\ttextureProp\n\t\t);\n\t\tthis.dirty = true;\n\t\tthis.fixedSize = textureProp.fixedSize || false;\n\t}\n\tget layoutType() {\n\t\tconst { viewFormats, sampleType, sampleCount } = this.textureProp;\n\t\t// const\n\t\treturn {\n\t\t\tsampleType: defaultValue(sampleType, \"float\"),\n\t\t\tviewDimension: defaultValue(viewFormats, \"2d\"),\n\t\t\tmultisampled: sampleCount && sampleCount > 1 ? true : false\n\t\t};\n\t}\n\tget storageTextureLayoutType() {\n\t\tconst { access = StorageTextureAccess.WriteOnly, viewFormats, format } = this.textureProp;\n\t\treturn {\n\t\t\tviewDimension: defaultValue(viewFormats, \"2d\"),\n\t\t\taccess,\n\t\t\tformat\n\t\t};\n\t}\n\tget textureView() {\n\t\tif (!this._textureView)\n\t\t\tthis._textureView = this.gpuTexture.createView({\n\t\t\t\tdimension: <GPUTextureViewDimension>defaultValue(this.textureProp.viewFormats, \"2d\")\n\t\t\t});\n\t\treturn this._textureView;\n\t}\n\tupdate(device: GPUDevice) {\n\t\tif (!this.device) this.device = device;\n\t\tif (this.dirty) {\n\t\t\tthis.checkNeedCreateTexture();\n\t\t\tthis.dirty = false;\n\t\t\tif (this.textureProp.data) {\n\t\t\t\tif (Array.isArray(this.textureProp.data)) {\n\t\t\t\t\tthis.textureProp.data.forEach((imageData) => {\n\t\t\t\t\t\tthis.setData(imageData);\n\t\t\t\t\t});\n\t\t\t\t} else {\n\t\t\t\t\tthis.setData(this.textureProp.data);\n\t\t\t\t}\n\t\t\t}\n\t\t\tif (this.textureProp.needMipMap) {\n\t\t\t\tif (!Texture.mipmapTools) Texture.mipmapTools = new MipmapGenerator(this.device);\n\t\t\t\tthis.gpuTexture = Texture.mipmapTools.generateMipmap(this);\n\t\t\t}\n\t\t}\n\t}\n\tprivate setData(options: ImageData) {\n\t\tconst {\n\t\t\tsource,\n\t\t\twidth = options.source.width,\n\t\t\theight = options.source.height,\n\t\t\tdepth = 1,\n\t\t\tsourceX = 0,\n\t\t\tsourceY = 0,\n\t\t\tmipLevel = 0,\n\t\t\tx = 0,\n\t\t\ty = 0,\n\t\t\tz = 0,\n\t\t\taspect = \"all\",\n\t\t\tcolorSpace = \"srgb\",\n\t\t\tpremultipliedAlpha = false\n\t\t} = options;\n\t\tif (source instanceof Texture) {\n\t\t\tlet commandEncoder = this.device.createCommandEncoder();\n\t\t\tcommandEncoder.copyTextureToTexture(\n\t\t\t\t{\n\t\t\t\t\ttexture: <GPUTexture>source.gpuTexture,\n\t\t\t\t\torigin: [sourceX, sourceY]\n\t\t\t\t\t// aspect\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\ttexture: this.gpuTexture,\n\t\t\t\t\torigin: { x: 0, y: 0, z },\n\t\t\t\t\tmipLevel\n\t\t\t\t\t// aspect\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\twidth,\n\t\t\t\t\theight,\n\t\t\t\t\tdepthOrArrayLayers: 1\n\t\t\t\t}\n\t\t\t);\n\t\t\tthis.device.queue.submit([commandEncoder.finish()]);\n\t\t\tcommandEncoder = null;\n\t\t} else {\n\t\t\tthis.device.queue.copyExternalImageToTexture(\n\t\t\t\t{\n\t\t\t\t\tsource,\n\t\t\t\t\torigin: [sourceX, sourceY]\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\ttexture: this.gpuTexture,\n\t\t\t\t\torigin: [x, y, z],\n\t\t\t\t\tmipLevel,\n\t\t\t\t\taspect,\n\t\t\t\t\tcolorSpace,\n\t\t\t\t\tpremultipliedAlpha\n\t\t\t\t},\n\t\t\t\t[width, height, depth]\n\t\t\t);\n\t\t}\n\t}\n\tsetSize(width: number, height: number, depth?: number) {\n\t\tif (this.fixedSize) return;\n\t\tthis.textureProp.size.width = width;\n\t\tthis.textureProp.size.height = height;\n\t\tif (depth) this.textureProp.size.depth = depth;\n\t\tthis.dirty = true;\n\t}\n\tdestroy(): void {\n\t\tthis.gpuTexture.destroy();\n\t}\n\tprivate createGPUTexture() {\n\t\tif (typeof this.textureProp.format === \"number\") {\n\t\t\tthrow new Error(\"number format\");\n\t\t}\n\t\tconst { width, height, depth } = this.textureProp.size;\n\t\treturn this.device.createTexture({\n\t\t\tlabel: this.textureProp?.label || \"undefined\",\n\t\t\tsize: [width, height, depth],\n\t\t\tdimension: this.textureProp.dimension || \"2d\",\n\t\t\tformat: this.textureProp.format as GPUTextureFormat,\n\t\t\tusage: this.textureProp.usage,\n\t\t\tmipLevelCount: this.textureProp.mipLevelCount || 1,\n\t\t\tsampleCount: this.textureProp.sampleCount || 1\n\t\t});\n\t}\n\tprivate checkNeedCreateTexture() {\n\t\tconst { width, height, depth } = this.textureProp.size;\n\t\tif (this.gpuTexture) {\n\t\t\tif (width != this.gpuTexture.width || height != this.gpuTexture.height) {\n\t\t\t\tthis._textureView = undefined;\n\t\t\t\tthis.gpuTexture.destroy();\n\t\t\t\tthis.gpuTexture = this.createGPUTexture();\n\t\t\t}\n\t\t} else {\n\t\t\tthis.gpuTexture = this.createGPUTexture();\n\t\t}\n\t}\n}\n","class Sampler {\n\tpublic gpuSampler: GPUSampler;\n\tpublic layoutType: GPUSamplerBindingLayout;\n\n\tstatic baseSampler = new Sampler({\n\t\tmagFilter: \"linear\",\n\t\tminFilter: \"linear\"\n\t});\n\n\tconstructor(\n\t\tpublic descriptor?: GPUSamplerDescriptor,\n\t\tlayoutType: GPUSamplerBindingLayout = {\n\t\t\ttype: \"filtering\"\n\t\t}\n\t) {\n\t\tthis.descriptor = {};\n\t\tObject.assign(\n\t\t\tthis.descriptor,\n\t\t\t{\n\t\t\t\tmagFilter: \"linear\",\n\t\t\t\tminFilter: \"linear\",\n\t\t\t\t// mipmapFilter: \"linear\",\n\t\t\t\taddressModeU: \"clamp-to-edge\",\n\t\t\t\taddressModeV: \"clamp-to-edge\"\n\t\t\t\t// addressModeW: \"clamp-to-edge\",\n\t\t\t},\n\t\t\tdescriptor\n\t\t);\n\t\tthis.layoutType = layoutType;\n\t}\n\tupdate(device: GPUDevice) {\n\t\tif (!this.gpuSampler) this.gpuSampler = device.createSampler(this.descriptor);\n\t}\n}\n\nexport default Sampler;\n","import { AttachmentOptions } from \"../core/WebGPUTypes\";\nimport Texture from \"./Texture\";\n\nclass Attachment {\n\tpublic op: GPULoadOp = \"clear\";\n\tpublic storeOp: GPUStoreOp = \"store\";\n\n\tpublic texture?: Texture;\n\tpublic resolveTarget?: Texture;\n\tpublic textureView?: () => GPUTextureView;\n\tpublic readOnly?: boolean;\n\n\tconstructor(public value: GPUColorDict | GPUColor | number, options?: AttachmentOptions) {\n\t\tObject.assign(this, options);\n\t}\n}\n\nexport default Attachment;\n","export default function defined(value) {\n\treturn value !== undefined && value !== null;\n}\n","/*\n  https://github.com/banksean wrapped Makoto Matsumoto and Takuji Nishimura's code in a namespace\n  so it's better encapsulated. Now you can have multiple random number generators\n  and they won't stomp all over eachother's state.\n\n  If you want to use this as a substitute for Math.random(), use the random()\n  method like so:\n\n  var m = new MersenneTwister();\n  var randomNumber = m.random();\n\n  You can also call the other genrand_{foo}() methods on the instance.\n\n  If you want to use a specific seed in order to get a repeatable random\n  sequence, pass an integer into the constructor:\n\n  var m = new MersenneTwister(123);\n\n  and that will always produce the same random sequence.\n\n  Sean McCullough (banksean@gmail.com)\n*/\n\n/*\n   A C-program for MT19937, with initialization improved 2002/1/26.\n   Coded by Takuji Nishimura and Makoto Matsumoto.\n\n   Before using, initialize the state by using init_seed(seed)\n   or init_by_array(init_key, key_length).\n\n   Copyright (C) 1997 - 2002, Makoto Matsumoto and Takuji Nishimura,\n   All rights reserved.\n\n   Redistribution and use in source and binary forms, with or without\n   modification, are permitted provided that the following conditions\n   are met:\n\n     1. Redistributions of source code must retain the above copyright\n        notice, this list of conditions and the following disclaimer.\n\n     2. Redistributions in binary form must reproduce the above copyright\n        notice, this list of conditions and the following disclaimer in the\n        documentation and/or other materials provided with the distribution.\n\n     3. The names of its contributors may not be used to endorse or promote\n        products derived from this software without specific prior written\n        permission.\n\n   THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS\n   \"AS IS\" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT\n   LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR\n   A PARTICULAR PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE COPYRIGHT OWNER OR\n   CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,\n   EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,\n   PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR\n   PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n   LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n   NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\n   SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n\n\n   Any feedback is very welcome.\n   http://www.math.sci.hiroshima-u.ac.jp/~m-mat/MT/emt.html\n   email: m-mat @ math.sci.hiroshima-u.ac.jp (remove space)\n*/\n\nvar MersenneTwister = function(seed) {\n\tif (seed == undefined) {\n\t\tseed = new Date().getTime();\n\t}\n\n\t/* Period parameters */\n\tthis.N = 624;\n\tthis.M = 397;\n\tthis.MATRIX_A = 0x9908b0df;   /* constant vector a */\n\tthis.UPPER_MASK = 0x80000000; /* most significant w-r bits */\n\tthis.LOWER_MASK = 0x7fffffff; /* least significant r bits */\n\n\tthis.mt = new Array(this.N); /* the array for the state vector */\n\tthis.mti=this.N+1; /* mti==N+1 means mt[N] is not initialized */\n\n\tif (seed.constructor == Array) {\n\t\tthis.init_by_array(seed, seed.length);\n\t}\n\telse {\n\t\tthis.init_seed(seed);\n\t}\n}\n\n/* initializes mt[N] with a seed */\n/* origin name init_genrand */\nMersenneTwister.prototype.init_seed = function(s) {\n\tthis.mt[0] = s >>> 0;\n\tfor (this.mti=1; this.mti<this.N; this.mti++) {\n\t\tvar s = this.mt[this.mti-1] ^ (this.mt[this.mti-1] >>> 30);\n\t\tthis.mt[this.mti] = (((((s & 0xffff0000) >>> 16) * 1812433253) << 16) + (s & 0x0000ffff) * 1812433253)\n\t\t+ this.mti;\n\t\t/* See Knuth TAOCP Vol2. 3rd Ed. P.106 for multiplier. */\n\t\t/* In the previous versions, MSBs of the seed affect   */\n\t\t/* only MSBs of the array mt[].                        */\n\t\t/* 2002/01/09 modified by Makoto Matsumoto             */\n\t\tthis.mt[this.mti] >>>= 0;\n\t\t/* for >32 bit machines */\n\t}\n}\n\n/* initialize by an array with array-length */\n/* init_key is the array for initializing keys */\n/* key_length is its length */\n/* slight change for C++, 2004/2/26 */\nMersenneTwister.prototype.init_by_array = function(init_key, key_length) {\n\tvar i, j, k;\n\tthis.init_seed(19650218);\n\ti=1; j=0;\n\tk = (this.N>key_length ? this.N : key_length);\n\tfor (; k; k--) {\n\t\tvar s = this.mt[i-1] ^ (this.mt[i-1] >>> 30)\n\t\tthis.mt[i] = (this.mt[i] ^ (((((s & 0xffff0000) >>> 16) * 1664525) << 16) + ((s & 0x0000ffff) * 1664525)))\n\t\t+ init_key[j] + j; /* non linear */\n\t\tthis.mt[i] >>>= 0; /* for WORDSIZE > 32 machines */\n\t\ti++; j++;\n\t\tif (i>=this.N) { this.mt[0] = this.mt[this.N-1]; i=1; }\n\t\tif (j>=key_length) j=0;\n\t}\n\tfor (k=this.N-1; k; k--) {\n\t\tvar s = this.mt[i-1] ^ (this.mt[i-1] >>> 30);\n\t\tthis.mt[i] = (this.mt[i] ^ (((((s & 0xffff0000) >>> 16) * 1566083941) << 16) + (s & 0x0000ffff) * 1566083941))\n\t\t- i; /* non linear */\n\t\tthis.mt[i] >>>= 0; /* for WORDSIZE > 32 machines */\n\t\ti++;\n\t\tif (i>=this.N) { this.mt[0] = this.mt[this.N-1]; i=1; }\n\t}\n\n\tthis.mt[0] = 0x80000000; /* MSB is 1; assuring non-zero initial array */\n}\n\n/* generates a random number on [0,0xffffffff]-interval */\n/* origin name genrand_int32 */\nMersenneTwister.prototype.random_int = function() {\n\tvar y;\n\tvar mag01 = new Array(0x0, this.MATRIX_A);\n\t/* mag01[x] = x * MATRIX_A  for x=0,1 */\n\n\tif (this.mti >= this.N) { /* generate N words at one time */\n\t\tvar kk;\n\n\t\tif (this.mti == this.N+1)  /* if init_seed() has not been called, */\n\t\t\tthis.init_seed(5489);  /* a default initial seed is used */\n\n\t\tfor (kk=0;kk<this.N-this.M;kk++) {\n\t\t\ty = (this.mt[kk]&this.UPPER_MASK)|(this.mt[kk+1]&this.LOWER_MASK);\n\t\t\tthis.mt[kk] = this.mt[kk+this.M] ^ (y >>> 1) ^ mag01[y & 0x1];\n\t\t}\n\t\tfor (;kk<this.N-1;kk++) {\n\t\t\ty = (this.mt[kk]&this.UPPER_MASK)|(this.mt[kk+1]&this.LOWER_MASK);\n\t\t\tthis.mt[kk] = this.mt[kk+(this.M-this.N)] ^ (y >>> 1) ^ mag01[y & 0x1];\n\t\t}\n\t\ty = (this.mt[this.N-1]&this.UPPER_MASK)|(this.mt[0]&this.LOWER_MASK);\n\t\tthis.mt[this.N-1] = this.mt[this.M-1] ^ (y >>> 1) ^ mag01[y & 0x1];\n\n\t\tthis.mti = 0;\n\t}\n\n\ty = this.mt[this.mti++];\n\n\t/* Tempering */\n\ty ^= (y >>> 11);\n\ty ^= (y << 7) & 0x9d2c5680;\n\ty ^= (y << 15) & 0xefc60000;\n\ty ^= (y >>> 18);\n\n\treturn y >>> 0;\n}\n\n/* generates a random number on [0,0x7fffffff]-interval */\n/* origin name genrand_int31 */\nMersenneTwister.prototype.random_int31 = function() {\n\treturn (this.random_int()>>>1);\n}\n\n/* generates a random number on [0,1]-real-interval */\n/* origin name genrand_real1 */\nMersenneTwister.prototype.random_incl = function() {\n\treturn this.random_int()*(1.0/4294967295.0);\n\t/* divided by 2^32-1 */\n}\n\n/* generates a random number on [0,1)-real-interval */\nMersenneTwister.prototype.random = function() {\n\treturn this.random_int()*(1.0/4294967296.0);\n\t/* divided by 2^32 */\n}\n\n/* generates a random number on (0,1)-real-interval */\n/* origin name genrand_real3 */\nMersenneTwister.prototype.random_excl = function() {\n\treturn (this.random_int() + 0.5)*(1.0/4294967296.0);\n\t/* divided by 2^32 */\n}\n\n/* generates a random number on [0,1) with 53-bit resolution*/\n/* origin name genrand_res53 */\nMersenneTwister.prototype.random_long = function() {\n\tvar a=this.random_int()>>>5, b=this.random_int()>>>6;\n\treturn(a*67108864.0+b)*(1.0/9007199254740992.0);\n}\n\n/* These real versions are due to Isaku Wada, 2002/01/09 added */\n\nmodule.exports = MersenneTwister;\n","import MersenneTwister from \"mersenne-twister\";\r\nimport defaultValue from \"../utils/defaultValue\";\r\nimport defined from \"../utils/defined\";\r\n\r\nclass GMath {\r\n\tpublic static EPSILON1 = 0.1;\r\n\r\n\tpublic static EPSILON2 = 0.01;\r\n\r\n\tpublic static EPSILON3 = 0.001;\r\n\tpublic static EPSILON4 = 0.0001;\r\n\r\n\tpublic static EPSILON5 = 0.00001;\r\n\r\n\tpublic static EPSILON6 = 0.000001;\r\n\r\n\tpublic static EPSILON7 = 0.0000001;\r\n\r\n\tpublic static EPSILON8 = 0.00000001;\r\n\r\n\tpublic static EPSILON9 = 0.000000001;\r\n\r\n\tpublic static EPSILON10 = 0.0000000001;\r\n\r\n\tpublic static EPSILON11 = 0.00000000001;\r\n\r\n\tpublic static EPSILON12 = 0.000000000001;\r\n\r\n\tpublic static EPSILON13 = 0.0000000000001;\r\n\r\n\tpublic static EPSILON14 = 0.00000000000001;\r\n\r\n\tpublic static EPSILON15 = 0.000000000000001;\r\n\r\n\tpublic static EPSILON16 = 0.0000000000000001;\r\n\r\n\tpublic static EPSILON17 = 0.00000000000000001;\r\n\r\n\tpublic static EPSILON18 = 0.000000000000000001;\r\n\r\n\tpublic static EPSILON19 = 0.0000000000000000001;\r\n\r\n\tpublic static EPSILON20 = 0.00000000000000000001;\r\n\r\n\tpublic static EPSILON21 = 0.000000000000000000001;\r\n\r\n\tpublic static GRAVITATIONALPARAMETER = 3.986004418e14;\r\n\r\n\tpublic static SIXTY_FOUR_KILOBYTES = 64 * 1024;\r\n\r\n\tpublic static FOUR_GIGABYTES = 4 * 1024 * 1024 * 1024;\r\n\r\n\tstatic sign = defaultValue(Math.sign, function sign(value) {\r\n\t\tvalue = +value; // coerce to number\r\n\t\tif (value === 0 || value !== value) {\r\n\t\t\t// zero or NaN\r\n\t\t\treturn value;\r\n\t\t}\r\n\t\treturn value > 0 ? 1 : -1;\r\n\t});\r\n\r\n\tstatic signNotZero(value) {\r\n\t\treturn value < 0.0 ? -1.0 : 1.0;\r\n\t}\r\n\r\n\tstatic toSNorm(value: number, rangeMaximum: number): number {\r\n\t\trangeMaximum = defaultValue(rangeMaximum, 255);\r\n\t\treturn Math.round((GMath.clamp(value, -1.0, 1.0) * 0.5 + 0.5) * rangeMaximum);\r\n\t}\r\n\r\n\tstatic fromSNorm(value: number, rangeMaximum: number): number {\r\n\t\trangeMaximum = defaultValue(rangeMaximum, 255);\r\n\t\treturn (GMath.clamp(value, 0.0, rangeMaximum) / rangeMaximum) * 2.0 - 1.0;\r\n\t}\r\n\r\n\tstatic normalize(value: number, rangeMinimum: number, rangeMaximum: number): number {\r\n\t\trangeMaximum = Math.max(rangeMaximum - rangeMinimum, 0.0);\r\n\t\treturn rangeMaximum === 0.0 ? 0.0 : GMath.clamp((value - rangeMinimum) / rangeMaximum, 0.0, 1.0);\r\n\t}\r\n\r\n\tstatic sinh = defaultValue(Math.sinh, function sinh(value) {\r\n\t\treturn (Math.exp(value) - Math.exp(-value)) / 2.0;\r\n\t});\r\n\r\n\tstatic cosh = defaultValue(Math.cosh, function cosh(value) {\r\n\t\treturn (Math.exp(value) + Math.exp(-value)) / 2.0;\r\n\t});\r\n\r\n\tstatic lerp(p: number, q: number, time: number): number {\r\n\t\treturn (1.0 - time) * p + time * q;\r\n\t}\r\n\r\n\tstatic PI = Math.PI;\r\n\r\n\tstatic ONE_OVER_PI = 1.0 / Math.PI;\r\n\r\n\tstatic PI_OVER_TWO = Math.PI / 2.0;\r\n\r\n\tstatic PI_OVER_THREE = Math.PI / 3.0;\r\n\r\n\tstatic PI_OVER_FOUR = Math.PI / 4.0;\r\n\r\n\tstatic PI_OVER_SIX = Math.PI / 6.0;\r\n\r\n\tstatic THREE_PI_OVER_TWO = (3.0 * Math.PI) / 2.0;\r\n\r\n\tstatic TWO_PI = 2.0 * Math.PI;\r\n\r\n\tstatic ONE_OVER_TWO_PI = 1.0 / (2.0 * Math.PI);\r\n\r\n\tstatic RADIANS_PER_DEGREE = Math.PI / 180.0;\r\n\r\n\tstatic DEGREES_PER_RADIAN = 180.0 / Math.PI;\r\n\r\n\tstatic RADIANS_PER_ARCSECOND = GMath.RADIANS_PER_DEGREE / 3600.0;\r\n\r\n\tstatic toRadians(degrees: number): number {\r\n\t\tif (!defined(degrees)) {\r\n\t\t\tthrow new Error(\"degrees is required.\");\r\n\t\t}\r\n\t\treturn degrees * GMath.RADIANS_PER_DEGREE;\r\n\t}\r\n\r\n\tstatic toDegrees(radians: number): number {\r\n\t\tif (!defined(radians)) {\r\n\t\t\tthrow new Error(\"radians is required.\");\r\n\t\t}\r\n\t\treturn radians * GMath.DEGREES_PER_RADIAN;\r\n\t}\r\n\r\n\tstatic negativePiToPi(angle: number): number {\r\n\t\tif (!defined(angle)) {\r\n\t\t\tthrow new Error(\"angle is required.\");\r\n\t\t}\r\n\t\tif (angle >= -GMath.PI && angle <= GMath.PI) {\r\n\t\t\t// Early exit if the input is already inside the range. This avoids\r\n\t\t\t// unnecessary math which could introduce floating point error.\r\n\t\t\treturn angle;\r\n\t\t}\r\n\t\treturn GMath.zeroToTwoPi(angle + GMath.PI) - GMath.PI;\r\n\t}\r\n\r\n\tstatic zeroToTwoPi(angle: number): number {\r\n\t\tif (!defined(angle)) {\r\n\t\t\tthrow new Error(\"angle is required.\");\r\n\t\t}\r\n\t\tif (angle >= 0 && angle <= GMath.TWO_PI) {\r\n\t\t\t// Early exit if the input is already inside the range. This avoids\r\n\t\t\t// unnecessary math which could introduce floating point error.\r\n\t\t\treturn angle;\r\n\t\t}\r\n\t\tconst mod = GMath.mod(angle, GMath.TWO_PI);\r\n\t\tif (Math.abs(mod) < GMath.EPSILON14 && Math.abs(angle) > GMath.EPSILON14) {\r\n\t\t\treturn GMath.TWO_PI;\r\n\t\t}\r\n\t\treturn mod;\r\n\t}\r\n\r\n\tstatic mod(m: number, n: number): number {\r\n\t\tif (!defined(m)) {\r\n\t\t\tthrow new Error(\"m is required.\");\r\n\t\t}\r\n\t\tif (!defined(n)) {\r\n\t\t\tthrow new Error(\"n is required.\");\r\n\t\t}\r\n\t\tif (n === 0.0) {\r\n\t\t\tthrow new Error(\"divisor cannot be 0.\");\r\n\t\t}\r\n\t\tif (GMath.sign(m) === GMath.sign(n) && Math.abs(m) < Math.abs(n)) {\r\n\t\t\t// Early exit if the input does not need to be modded. This avoids\r\n\t\t\t// unnecessary math which could introduce floating point error.\r\n\t\t\treturn m;\r\n\t\t}\r\n\r\n\t\treturn ((m % n) + n) % n;\r\n\t}\r\n\r\n\tstatic equalsEpsilon(\r\n\t\tleft: number,\r\n\t\tright: number,\r\n\t\trelativeEpsilon: number,\r\n\t\tabsoluteEpsilon: number = relativeEpsilon\r\n\t): boolean {\r\n\t\tif (!defined(left)) {\r\n\t\t\tthrow new Error(\"left is required.\");\r\n\t\t}\r\n\t\tif (!defined(right)) {\r\n\t\t\tthrow new Error(\"right is required.\");\r\n\t\t}\r\n\r\n\t\trelativeEpsilon = defaultValue(relativeEpsilon, 0.0);\r\n\t\tabsoluteEpsilon = defaultValue(absoluteEpsilon, relativeEpsilon);\r\n\t\tconst absDiff = Math.abs(left - right);\r\n\t\treturn absDiff <= absoluteEpsilon || absDiff <= relativeEpsilon * Math.max(Math.abs(left), Math.abs(right));\r\n\t}\r\n\r\n\tstatic lessThan(left: number, right: number, absoluteEpsilon = 0): boolean {\r\n\t\tif (!defined(left)) {\r\n\t\t\tthrow new Error(\"first is required.\");\r\n\t\t}\r\n\t\tif (!defined(right)) {\r\n\t\t\tthrow new Error(\"second is required.\");\r\n\t\t}\r\n\t\tif (!defined(absoluteEpsilon)) {\r\n\t\t\tthrow new Error(\"absoluteEpsilon is required.\");\r\n\t\t}\r\n\t\treturn left - right < -absoluteEpsilon;\r\n\t}\r\n\r\n\tstatic lessThanOrEquals(left: number, right: number, absoluteEpsilon = 0): boolean {\r\n\t\tif (!defined(left)) {\r\n\t\t\tthrow new Error(\"first is required.\");\r\n\t\t}\r\n\t\tif (!defined(right)) {\r\n\t\t\tthrow new Error(\"second is required.\");\r\n\t\t}\r\n\t\tif (!defined(absoluteEpsilon)) {\r\n\t\t\tthrow new Error(\"absoluteEpsilon is required.\");\r\n\t\t}\r\n\t\treturn left - right < absoluteEpsilon;\r\n\t}\r\n\r\n\tstatic greaterThan(left: number, right: number, absoluteEpsilon = 0): boolean {\r\n\t\tif (!defined(left)) {\r\n\t\t\tthrow new Error(\"first is required.\");\r\n\t\t}\r\n\t\tif (!defined(right)) {\r\n\t\t\tthrow new Error(\"second is required.\");\r\n\t\t}\r\n\t\tif (!defined(absoluteEpsilon)) {\r\n\t\t\tthrow new Error(\"absoluteEpsilon is required.\");\r\n\t\t}\r\n\t\treturn left - right > absoluteEpsilon;\r\n\t}\r\n\r\n\tstatic greaterThanOrEquals(left: number, right: number, absoluteEpsilon = 0): boolean {\r\n\t\tif (!defined(left)) {\r\n\t\t\tthrow new Error(\"first is required.\");\r\n\t\t}\r\n\t\tif (!defined(right)) {\r\n\t\t\tthrow new Error(\"second is required.\");\r\n\t\t}\r\n\t\tif (!defined(absoluteEpsilon)) {\r\n\t\t\tthrow new Error(\"absoluteEpsilon is required.\");\r\n\t\t}\r\n\t\treturn left - right > -absoluteEpsilon;\r\n\t}\r\n\r\n\tstatic isPowerOfTwo(n: number): boolean {\r\n\t\t// >>includeStart('debug', pragmas.debug);\r\n\t\tif (typeof n !== \"number\" || n < 0 || n > 4294967295) {\r\n\t\t\tthrow new Error(\"A number between 0 and (2^32)-1 is required.\");\r\n\t\t}\r\n\t\t// >>includeEnd('debug');\r\n\r\n\t\treturn n !== 0 && (n & (n - 1)) === 0;\r\n\t}\r\n\r\n\tstatic nextPowerOfTwo(n: number): number {\r\n\t\tif (typeof n !== \"number\" || n < 0 || n > 2147483648) {\r\n\t\t\tthrow new Error(\"A number between 0 and 2^31 is required.\");\r\n\t\t}\r\n\t\t// From http://graphics.stanford.edu/~seander/bithacks.html#RoundUpPowerOf2\r\n\t\t--n;\r\n\t\tn |= n >> 1;\r\n\t\tn |= n >> 2;\r\n\t\tn |= n >> 4;\r\n\t\tn |= n >> 8;\r\n\t\tn |= n >> 16;\r\n\t\t++n;\r\n\r\n\t\treturn n;\r\n\t}\r\n\r\n\tstatic previousPowerOfTwo(n: number): number {\r\n\t\tif (typeof n !== \"number\" || n < 0 || n > 4294967295) {\r\n\t\t\tthrow new Error(\"A number between 0 and (2^32)-1 is required.\");\r\n\t\t}\r\n\r\n\t\tn |= n >> 1;\r\n\t\tn |= n >> 2;\r\n\t\tn |= n >> 4;\r\n\t\tn |= n >> 8;\r\n\t\tn |= n >> 16;\r\n\t\tn |= n >> 32;\r\n\r\n\t\t// The previous bitwise operations implicitly convert to signed 32-bit. Use `>>>` to convert to unsigned\r\n\t\tn = (n >>> 0) - (n >>> 1);\r\n\r\n\t\treturn n;\r\n\t}\r\n\r\n\tstatic clamp(value: number, min: number, max: number): number {\r\n\t\treturn value < min ? min : value > max ? max : value;\r\n\t}\r\n\r\n\tstatic nextRandomNumber = function (): number {\r\n\t\treturn randomNumberGenerator.random();\r\n\t};\r\n\r\n\tstatic randomBetween = function (min: number, max: number): number {\r\n\t\treturn GMath.nextRandomNumber() * (max - min) + min;\r\n\t};\r\n\r\n\tstatic acosClamped = function (value: number): number {\r\n\t\tif (!defined(value)) {\r\n\t\t\tthrow new Error(\"value is required.\");\r\n\t\t}\r\n\r\n\t\treturn Math.acos(GMath.clamp(value, -1.0, 1.0));\r\n\t};\r\n\r\n\tstatic asinClamped = function (value: number): number {\r\n\t\tif (!defined(value)) {\r\n\t\t\tthrow new Error(\"value is required.\");\r\n\t\t}\r\n\r\n\t\treturn Math.asin(GMath.clamp(value, -1.0, 1.0));\r\n\t};\r\n\r\n\tstatic chordLength = function (angle: number, radius: number): number {\r\n\t\tif (!defined(angle)) {\r\n\t\t\tthrow new Error(\"angle is required.\");\r\n\t\t}\r\n\t\tif (!defined(radius)) {\r\n\t\t\tthrow new Error(\"radius is required.\");\r\n\t\t}\r\n\r\n\t\treturn 2.0 * radius * Math.sin(angle * 0.5);\r\n\t};\r\n\r\n\tstatic logBase = function (number: number, base: number): number {\r\n\t\tif (!defined(number)) {\r\n\t\t\tthrow new Error(\"number is required.\");\r\n\t\t}\r\n\t\tif (!defined(base)) {\r\n\t\t\tthrow new Error(\"base is required.\");\r\n\t\t}\r\n\r\n\t\treturn Math.log(number) / Math.log(base);\r\n\t};\r\n\r\n\tstatic cbrt = defaultValue(Math.cbrt, function cbrt(number) {\r\n\t\tconst result = Math.pow(Math.abs(number), 1.0 / 3.0);\r\n\t\treturn number < 0.0 ? -result : result;\r\n\t});\r\n\tstatic log2 = defaultValue(Math.log2, function log2(number) {\r\n\t\treturn Math.log(number) * Math.LOG2E;\r\n\t});\r\n\r\n\t/**\r\n\t * @private\r\n\t */\r\n\tstatic fog(distanceToCamera: number, density: number): number {\r\n\t\tconst scalar = distanceToCamera * density;\r\n\t\treturn 1.0 - Math.exp(-(scalar * scalar));\r\n\t}\r\n}\r\nconst randomNumberGenerator = new MersenneTwister();\r\nconst factorials = [1];\r\nexport default GMath;\r\n","import { Attribute } from \"../render/Attribute\";\r\nimport defined from \"../utils/defined\";\r\nimport GMath from \"./Math\";\r\nimport Matrix3 from \"./Matrix3\";\r\n/**\r\n * A 2D Cartesian point.\r\n * @alias Vector2\r\n * @constructor\r\n *\r\n * @param {Number} [x=0.0] The X component.\r\n * @param {Number} [y=0.0] The Y component.\r\n *\r\n */\r\nclass Vector2 {\r\n\tpublic static ZERO = Object.freeze(new Vector2(0.0, 0.0));\r\n\r\n\tpublic static ONE = Object.freeze(new Vector2(1.0, 1.0));\r\n\r\n\tpublic static UNIT_X = Object.freeze(new Vector2(1.0, 0.0));\r\n\r\n\tpublic static UNIT_Y = Object.freeze(new Vector2(0.0, 1.0));\r\n\r\n\tconstructor(public x: number = 0.0, public y: number = 0.0) {\r\n\t\tthis.x = x;\r\n\t\tthis.y = y;\r\n\t}\r\n\tset(x: number, y: number): Vector2 {\r\n\t\tthis.x = x;\r\n\t\tthis.y = y;\r\n\t\treturn this;\r\n\t}\r\n\ttoArray() {\r\n\t\treturn [this.x, this.y];\r\n\t}\r\n\r\n\tclone(result: Vector2): Vector2 {\r\n\t\treturn Vector2.clone(this, result);\r\n\t}\r\n\r\n\tequals(right: Vector2): boolean {\r\n\t\treturn Vector2.equals(this, right);\r\n\t}\r\n\tequalsEpsilon(right: Vector2, relativeEpsilon = 0, absoluteEpsilon = 0): boolean {\r\n\t\treturn Vector2.equalsEpsilon(this, right, relativeEpsilon, absoluteEpsilon);\r\n\t}\r\n\r\n\ttoString() {\r\n\t\treturn `(${this.x}, ${this.y})`;\r\n\t}\r\n\tfromBufferAttribute(attribute: Attribute, index: number): Vector2 {\r\n\t\tthis.x = attribute.getX(index);\r\n\t\tthis.y = attribute.getY(index);\r\n\t\treturn this;\r\n\t}\r\n\tapplyMatrix3(matrix3: Matrix3): Vector2 {\r\n\t\tconst x = this.x,\r\n\t\t\ty = this.y;\r\n\t\tthis.x = matrix3[0] * x + matrix3[3] * y + matrix3[6];\r\n\t\tthis.y = matrix3[1] * x + matrix3[4] * y + matrix3[7];\r\n\t\treturn this;\r\n\t}\r\n\r\n\tstatic fromElements(x: number, y: number, result: Vector2): Vector2 {\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Vector2(x, y);\r\n\t\t}\r\n\r\n\t\tresult.x = x;\r\n\t\tresult.y = y;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic clone(cartesian: Vector2, result: Vector2): Vector2 {\r\n\t\tif (!defined(cartesian)) {\r\n\t\t\treturn undefined;\r\n\t\t}\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Vector2(cartesian.x, cartesian.y);\r\n\t\t}\r\n\r\n\t\tresult.x = cartesian.x;\r\n\t\tresult.y = cartesian.y;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic maximumComponent(cartesian: Vector2): number {\r\n\t\treturn Math.max(cartesian.x, cartesian.y);\r\n\t}\r\n\r\n\tstatic minimumComponent(cartesian: Vector2): number {\r\n\t\treturn Math.min(cartesian.x, cartesian.y);\r\n\t}\r\n\r\n\tstatic minimumByComponent(first: Vector2, second: Vector2, result: Vector2): Vector2 {\r\n\t\tresult.x = Math.min(first.x, second.x);\r\n\t\tresult.y = Math.min(first.y, second.y);\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic maximumByComponent(first: Vector2, second: Vector2, result: Vector2): Vector2 {\r\n\t\tresult.x = Math.max(first.x, second.x);\r\n\t\tresult.y = Math.max(first.y, second.y);\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic clamp(value: Vector2, min: Vector2, max: Vector2, result: Vector2): Vector2 {\r\n\t\tconst x = GMath.clamp(value.x, min.x, max.x);\r\n\t\tconst y = GMath.clamp(value.y, min.y, max.y);\r\n\r\n\t\tresult.x = x;\r\n\t\tresult.y = y;\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic magnitudeSquared(cartesian: Vector2): number {\r\n\t\treturn cartesian.x * cartesian.x + cartesian.y * cartesian.y;\r\n\t}\r\n\r\n\tstatic magnitude(cartesian: Vector2): number {\r\n\t\treturn Math.sqrt(Vector2.magnitudeSquared(cartesian));\r\n\t}\r\n\r\n\tstatic distance(left: Vector2, right: Vector2): number {\r\n\t\tVector2.subtract(left, right, distanceScratch);\r\n\t\treturn Vector2.magnitude(distanceScratch);\r\n\t}\r\n\r\n\tstatic distanceSquared(left: Vector2, right: Vector2): number {\r\n\t\tVector2.subtract(left, right, distanceScratch);\r\n\t\treturn Vector2.magnitudeSquared(distanceScratch);\r\n\t}\r\n\r\n\tstatic normalize(cartesian: Vector2, result: Vector2): Vector2 {\r\n\t\tconst magnitude = Vector2.magnitude(cartesian);\r\n\r\n\t\tresult.x = cartesian.x / magnitude;\r\n\t\tresult.y = cartesian.y / magnitude;\r\n\r\n\t\t// >>includeStart('debug', pragmas.debug);\r\n\t\tif (isNaN(result.x) || isNaN(result.y)) {\r\n\t\t\tthrow new Error(\"normalized result is not a number\");\r\n\t\t}\r\n\t\t// >>includeEnd('debug');\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic dot(left: Vector2, right: Vector2): number {\r\n\t\treturn left.x * right.x + left.y * right.y;\r\n\t}\r\n\r\n\tstatic cross(left: Vector2, right: Vector2): number {\r\n\t\treturn left.x * right.y - left.y * right.x;\r\n\t}\r\n\r\n\tstatic multiplyComponents(left: Vector2, right: Vector2, result: Vector2): Vector2 {\r\n\t\tresult.x = left.x * right.x;\r\n\t\tresult.y = left.y * right.y;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic divideComponents(left: Vector2, right: Vector2, result: Vector2): Vector2 {\r\n\t\tresult.x = left.x / right.x;\r\n\t\tresult.y = left.y / right.y;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic add(left: Vector2, right: Vector2, result: Vector2): Vector2 {\r\n\t\tresult.x = left.x + right.x;\r\n\t\tresult.y = left.y + right.y;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic subtract(left: Vector2, right: Vector2, result: Vector2): Vector2 {\r\n\t\tresult.x = left.x - right.x;\r\n\t\tresult.y = left.y - right.y;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic multiplyByScalar(cartesian: Vector2, scalar: number, result: Vector2): Vector2 {\r\n\t\tresult.x = cartesian.x * scalar;\r\n\t\tresult.y = cartesian.y * scalar;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic divideByScalar(cartesian: Vector2, scalar: number, result: Vector2): Vector2 {\r\n\t\tresult.x = cartesian.x / scalar;\r\n\t\tresult.y = cartesian.y / scalar;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic negate(cartesian: Vector2, result: Vector2): Vector2 {\r\n\t\tresult.x = -cartesian.x;\r\n\t\tresult.y = -cartesian.y;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic abs(cartesian: Vector2, result: Vector2): Vector2 {\r\n\t\tresult.x = Math.abs(cartesian.x);\r\n\t\tresult.y = Math.abs(cartesian.y);\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic lerp(start: Vector2, end: Vector2, t: number, result: Vector2): Vector2 {\r\n\t\tVector2.multiplyByScalar(end, t, lerpScratch);\r\n\t\tresult = Vector2.multiplyByScalar(start, 1.0 - t, result);\r\n\t\treturn Vector2.add(lerpScratch, result, result);\r\n\t}\r\n\r\n\tstatic angleBetween(left: Vector2, right: Vector2): number {\r\n\t\tVector2.normalize(left, angleBetweenScratch);\r\n\t\tVector2.normalize(right, angleBetweenScratch2);\r\n\t\treturn GMath.acosClamped(Vector2.dot(angleBetweenScratch, angleBetweenScratch2));\r\n\t}\r\n\r\n\tstatic mostOrthogonalAxis(cartesian: Vector2, result: Vector2): Vector2 {\r\n\t\tconst f = Vector2.normalize(cartesian, mostOrthogonalAxisScratch);\r\n\t\tVector2.abs(f, f);\r\n\r\n\t\tif (f.x <= f.y) {\r\n\t\t\tresult = Vector2.clone(Vector2.UNIT_X, result);\r\n\t\t} else {\r\n\t\t\tresult = Vector2.clone(Vector2.UNIT_Y, result);\r\n\t\t}\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic equals(left: Vector2, right: Vector2): boolean {\r\n\t\treturn left === right || (defined(left) && defined(right) && left.x === right.x && left.y === right.y);\r\n\t}\r\n\r\n\t/**\r\n\t * @private\r\n\t */\r\n\tstatic equalsArray(cartesian: Vector2, array: number[], offset: number): boolean {\r\n\t\treturn cartesian.x === array[offset] && cartesian.y === array[offset + 1];\r\n\t}\r\n\r\n\tstatic equalsEpsilon(left: Vector2, right: Vector2, relativeEpsilon = 0, absoluteEpsilon = 0): boolean {\r\n\t\treturn (\r\n\t\t\tleft === right ||\r\n\t\t\t(defined(left) &&\r\n\t\t\t\tdefined(right) &&\r\n\t\t\t\tGMath.equalsEpsilon(left.x, right.x, relativeEpsilon, absoluteEpsilon) &&\r\n\t\t\t\tGMath.equalsEpsilon(left.y, right.y, relativeEpsilon, absoluteEpsilon))\r\n\t\t);\r\n\t}\r\n}\r\nconst distanceScratch = new Vector2();\r\nconst lerpScratch = new Vector2();\r\nconst angleBetweenScratch = new Vector2();\r\nconst angleBetweenScratch2 = new Vector2();\r\nconst mostOrthogonalAxisScratch = new Vector2();\r\n\r\nexport default Vector2;\r\n","import { Attribute } from \"../render/Attribute\";\r\nimport defined from \"../utils/defined\";\r\nimport GMath from \"./Math\";\r\nimport Matrix3 from \"./Matrix3\";\r\nimport Matrix4 from \"./Matrix4\";\r\nimport { Quaternion } from \"./Quaternion\";\r\nimport { Spherical } from \"./Spherical\";\r\nimport Vector4 from \"./Vector4\";\r\nclass Vector3 {\r\n\tpublic static ZERO = Object.freeze(new Vector3(0.0, 0.0, 0.0));\r\n\r\n\tpublic static ONE = Object.freeze(new Vector3(1.0, 1.0, 1.0));\r\n\r\n\tpublic static UNIT_X = Object.freeze(new Vector3(1.0, 0.0, 0.0));\r\n\r\n\tpublic static UNIT_Y = Object.freeze(new Vector3(0.0, 1.0, 0.0));\r\n\r\n\tpublic static UNIT_Z = Object.freeze(new Vector3(0.0, 0.0, 1.0));\r\n\tx: number;\r\n\ty: number;\r\n\tz: number;\r\n\r\n\tconstructor(x = 0, y = 0, z = 0) {\r\n\t\tthis.x = x;\r\n\t\tthis.y = y;\r\n\t\tthis.z = z;\r\n\t}\r\n\tset(x: number, y: number, z: number): Vector3 {\r\n\t\tthis.x = x;\r\n\t\tthis.y = y;\r\n\t\tthis.z = z;\r\n\t\treturn this;\r\n\t}\r\n\ttoArray(): number[] {\r\n\t\treturn [this.x, this.y, this.z];\r\n\t}\r\n\r\n\tcopy(v: Vector3): Vector3 {\r\n\t\tthis.x = v.x;\r\n\t\tthis.y = v.y;\r\n\t\tthis.z = v.z;\r\n\t\treturn this;\r\n\t}\r\n\tlerp(end: Vector3, t: number): Vector3 {\r\n\t\tVector3.lerp(this, end, t, this);\r\n\t\treturn this;\r\n\t}\r\n\tadd(v: Vector3): Vector3 {\r\n\t\tVector3.add(this, v, this);\r\n\t\treturn this;\r\n\t}\r\n\taddScaledVector(v: Vector3, s: number): Vector3 {\r\n\t\tthis.x += v.x * s;\r\n\t\tthis.y += v.y * s;\r\n\t\tthis.z += v.z * s;\r\n\t\treturn this;\r\n\t}\r\n\tsubtract(v: Vector3): Vector3 {\r\n\t\tVector3.subtract(this, v, this);\r\n\t\treturn this;\r\n\t}\r\n\tapplyQuaternion(q: Quaternion): Vector3 {\r\n\t\tconst x = this.x,\r\n\t\t\ty = this.y,\r\n\t\t\tz = this.z;\r\n\t\tconst qx = q.x,\r\n\t\t\tqy = q.y,\r\n\t\t\tqz = q.z,\r\n\t\t\tqw = q.w;\r\n\r\n\t\t// calculate quat * vector\r\n\r\n\t\tconst ix = qw * x + qy * z - qz * y;\r\n\t\tconst iy = qw * y + qz * x - qx * z;\r\n\t\tconst iz = qw * z + qx * y - qy * x;\r\n\t\tconst iw = -qx * x - qy * y - qz * z;\r\n\r\n\t\t// calculate result * inverse quat\r\n\r\n\t\tthis.x = ix * qw + iw * -qx + iy * -qz - iz * -qy;\r\n\t\tthis.y = iy * qw + iw * -qy + iz * -qx - ix * -qz;\r\n\t\tthis.z = iz * qw + iw * -qz + ix * -qy - iy * -qx;\r\n\r\n\t\treturn this;\r\n\t}\r\n\tsetFromMatrixColumn(m: Matrix3 | Matrix4, index: number): Vector3 {\r\n\t\treturn this.fromArray(m, index * 4);\r\n\t}\r\n\tfromArray(array: Matrix3 | Matrix4, offset = 0): Vector3 {\r\n\t\tthis.x = array[offset];\r\n\t\tthis.y = array[offset + 1];\r\n\t\tthis.z = array[offset + 2];\r\n\r\n\t\treturn this;\r\n\t}\r\n\r\n\tmultiplyByScalar(scale: number): Vector3 {\r\n\t\tVector3.multiplyByScalar(this, scale, this);\r\n\t\treturn this;\r\n\t}\r\n\r\n\tclone(): Vector3 {\r\n\t\treturn Vector3.clone(this, new Vector3());\r\n\t}\r\n\tlength(): number {\r\n\t\treturn Math.sqrt(this.x * this.x + this.y * this.y + this.z * this.z);\r\n\t}\r\n\tapplyMatrix4(matrix: Matrix4): Vector3 {\r\n\t\tconst x = this.x,\r\n\t\t\ty = this.y,\r\n\t\t\tz = this.z;\r\n\t\tconst e = matrix;\r\n\t\tconst w = 1 / (e[3] * x + e[7] * y + e[11] * z + e[15]);\r\n\t\tthis.x = (e[0] * x + e[4] * y + e[8] * z + e[12]) * w;\r\n\t\tthis.y = (e[1] * x + e[5] * y + e[9] * z + e[13]) * w;\r\n\t\tthis.z = (e[2] * x + e[6] * y + e[10] * z + e[14]) * w;\r\n\t\treturn this;\r\n\t}\r\n\tapplyMatrix3(matrix: Matrix3): Vector3 {\r\n\t\tconst x = this.x,\r\n\t\t\ty = this.y,\r\n\t\t\tz = this.z;\r\n\t\tthis.x = x * matrix[0] + y * matrix[3] + z * matrix[6];\r\n\t\tthis.y = x * matrix[1] + y * matrix[4] + z * matrix[7];\r\n\t\tthis.z = x * matrix[2] + y * matrix[5] + z * matrix[8];\r\n\t\treturn this;\r\n\t}\r\n\ttransformDirection(matrix: Matrix3 | Matrix4): Vector3 {\r\n\t\tconst x = this.x,\r\n\t\t\ty = this.y,\r\n\t\t\tz = this.z;\r\n\t\tconst e = matrix;\r\n\t\tthis.x = e[0] * x + e[4] * y + e[8] * z;\r\n\t\tthis.y = e[1] * x + e[5] * y + e[9] * z;\r\n\t\tthis.z = e[2] * x + e[6] * y + e[10] * z;\r\n\t\treturn this.normalize();\r\n\t}\r\n\r\n\tsetFromMatrixPosition(matrix: Matrix4) {\r\n\t\tconst e = matrix;\r\n\r\n\t\tthis.x = e[12];\r\n\t\tthis.y = e[13];\r\n\t\tthis.z = e[14];\r\n\r\n\t\treturn this;\r\n\t}\r\n\r\n\tnormalize(): Vector3 {\r\n\t\tVector3.normalize(this, this);\r\n\t\treturn this;\r\n\t}\r\n\r\n\tequals(right: Vector3): boolean {\r\n\t\treturn Vector3.equals(this, right);\r\n\t}\r\n\r\n\tequalsEpsilon(right: Vector3, relativeEpsilon = 0, absoluteEpsilon = 0): boolean {\r\n\t\treturn Vector3.equalsEpsilon(this, right, relativeEpsilon, absoluteEpsilon);\r\n\t}\r\n\r\n\ttoString() {\r\n\t\treturn `(${this.x}, ${this.y}, ${this.z})`;\r\n\t}\r\n\tfromBufferAttribute(attribute: Attribute, index: number): Vector3 {\r\n\t\tthis.x = attribute.getX(index);\r\n\t\tthis.y = attribute.getY(index);\r\n\t\tthis.z = attribute.getZ(index);\r\n\t\treturn this;\r\n\t}\r\n\tstatic fromVector4(vec4: Vector4, result: Vector3): Vector3 {\r\n\t\tresult.x = vec4.x;\r\n\t\tresult.y = vec4.y;\r\n\t\tresult.z = vec4.z;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic fromSpherical(spherical: Spherical, result: Vector3): Vector3 {\r\n\t\tif (!defined(result)) {\r\n\t\t\tresult = new Vector3();\r\n\t\t}\r\n\t\tconst { phi, radius, theta } = spherical;\r\n\t\tconst sinPhiRadius = Math.sin(phi) * radius;\r\n\t\tresult.x = sinPhiRadius * Math.sin(theta);\r\n\t\tresult.y = Math.cos(phi) * radius;\r\n\t\tresult.z = sinPhiRadius * Math.cos(theta);\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic fromElements(x: number, y: number, z: number, result: Vector3): Vector3 {\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Vector3(x, y, z);\r\n\t\t}\r\n\r\n\t\tresult.x = x;\r\n\t\tresult.y = y;\r\n\t\tresult.z = z;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic clone(cartesian: Vector3, result: Vector3 = new Vector3()): Vector3 {\r\n\t\tif (!defined(cartesian)) {\r\n\t\t\treturn undefined;\r\n\t\t}\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Vector3(cartesian.x, cartesian.y, cartesian.z);\r\n\t\t}\r\n\r\n\t\tresult.x = cartesian.x;\r\n\t\tresult.y = cartesian.y;\r\n\t\tresult.z = cartesian.z;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic maximumComponent(cartesian: Vector3): number {\r\n\t\treturn Math.max(cartesian.x, cartesian.y, cartesian.z);\r\n\t}\r\n\r\n\tstatic minimumComponent(cartesian: Vector3): number {\r\n\t\treturn Math.min(cartesian.x, cartesian.y, cartesian.z);\r\n\t}\r\n\r\n\tstatic minimumByComponent(first: Vector3, second: Vector3, result: Vector3): Vector3 {\r\n\t\tresult.x = Math.min(first.x, second.x);\r\n\t\tresult.y = Math.min(first.y, second.y);\r\n\t\tresult.z = Math.min(first.z, second.z);\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic maximumByComponent(first: Vector3, second: Vector3, result: Vector3): Vector3 {\r\n\t\tresult.x = Math.max(first.x, second.x);\r\n\t\tresult.y = Math.max(first.y, second.y);\r\n\t\tresult.z = Math.max(first.z, second.z);\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic clamp(value: Vector3, min: Vector3, max: Vector3, result: Vector3): Vector3 {\r\n\t\tconst x = GMath.clamp(value.x, min.x, max.x);\r\n\t\tconst y = GMath.clamp(value.y, min.y, max.y);\r\n\t\tconst z = GMath.clamp(value.z, min.z, max.z);\r\n\r\n\t\tresult.x = x;\r\n\t\tresult.y = y;\r\n\t\tresult.z = z;\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic magnitudeSquared(cartesian: Vector3): number {\r\n\t\treturn cartesian.x * cartesian.x + cartesian.y * cartesian.y + cartesian.z * cartesian.z;\r\n\t}\r\n\r\n\tstatic magnitude(cartesian: Vector3): number {\r\n\t\treturn Math.sqrt(Vector3.magnitudeSquared(cartesian));\r\n\t}\r\n\r\n\tstatic distance(left: Vector3, right: Vector3): number {\r\n\t\tVector3.subtract(left, right, distanceScratch);\r\n\t\treturn Vector3.magnitude(distanceScratch);\r\n\t}\r\n\r\n\tstatic distanceSquared(left: Vector3, right: Vector3): number {\r\n\t\tVector3.subtract(left, right, distanceScratch);\r\n\t\treturn Vector3.magnitudeSquared(distanceScratch);\r\n\t}\r\n\r\n\tstatic normalize(cartesian: Vector3, result: Vector3): Vector3 {\r\n\t\tconst magnitude = Vector3.magnitude(cartesian);\r\n\r\n\t\tresult.x = cartesian.x / magnitude;\r\n\t\tresult.y = cartesian.y / magnitude;\r\n\t\tresult.z = cartesian.z / magnitude;\r\n\r\n\t\tif (isNaN(result.x) || isNaN(result.y) || isNaN(result.z)) {\r\n\t\t\tthrow new Error(\"normalized result is not a number\");\r\n\t\t}\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic dot(left: Vector3, right: Vector3): number {\r\n\t\treturn left.x * right.x + left.y * right.y + left.z * right.z;\r\n\t}\r\n\r\n\tstatic multiplyComponents(left: Vector3, right: Vector3, result: Vector3): Vector3 {\r\n\t\tresult.x = left.x * right.x;\r\n\t\tresult.y = left.y * right.y;\r\n\t\tresult.z = left.z * right.z;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic divideComponents(left: Vector3, right: Vector3, result: Vector3) {\r\n\t\tresult.x = left.x / right.x;\r\n\t\tresult.y = left.y / right.y;\r\n\t\tresult.z = left.z / right.z;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic add(left: Vector3, right: Vector3, result: Vector3): Vector3 {\r\n\t\tresult.x = left.x + right.x;\r\n\t\tresult.y = left.y + right.y;\r\n\t\tresult.z = left.z + right.z;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic subtract(left: Vector3, right: Vector3, result: Vector3): Vector3 {\r\n\t\tresult.x = left.x - right.x;\r\n\t\tresult.y = left.y - right.y;\r\n\t\tresult.z = left.z - right.z;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic multiplyByScalar(cartesian: Vector3, scalar: number, result: Vector3): Vector3 {\r\n\t\tresult.x = cartesian.x * scalar;\r\n\t\tresult.y = cartesian.y * scalar;\r\n\t\tresult.z = cartesian.z * scalar;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic divideByScalar(cartesian: Vector3, scalar: number, result: Vector3): Vector3 {\r\n\t\tresult.x = cartesian.x / scalar;\r\n\t\tresult.y = cartesian.y / scalar;\r\n\t\tresult.z = cartesian.z / scalar;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic negate(cartesian: Vector3, result: Vector3): Vector3 {\r\n\t\tresult.x = -cartesian.x;\r\n\t\tresult.y = -cartesian.y;\r\n\t\tresult.z = -cartesian.z;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic abs(cartesian: Vector3, result: Vector3): Vector3 {\r\n\t\tresult.x = Math.abs(cartesian.x);\r\n\t\tresult.y = Math.abs(cartesian.y);\r\n\t\tresult.z = Math.abs(cartesian.z);\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic lerp(start: Vector3, end: Vector3, t: number, result: Vector3): Vector3 {\r\n\t\tVector3.multiplyByScalar(end, t, lerpScratch);\r\n\t\tresult = Vector3.multiplyByScalar(start, 1.0 - t, result);\r\n\t\treturn Vector3.add(lerpScratch, result, result);\r\n\t}\r\n\r\n\tstatic angleBetween(left: Vector3, right: Vector3): number {\r\n\t\tVector3.normalize(left, angleBetweenScratch);\r\n\t\tVector3.normalize(right, angleBetweenScratch2);\r\n\t\tconst cosine = Vector3.dot(angleBetweenScratch, angleBetweenScratch2);\r\n\t\tconst sine = Vector3.magnitude(Vector3.cross(angleBetweenScratch, angleBetweenScratch2, angleBetweenScratch));\r\n\t\treturn Math.atan2(sine, cosine);\r\n\t}\r\n\r\n\tstatic mostOrthogonalAxis(cartesian: Vector3, result: Vector3): Vector3 {\r\n\t\tconst f = Vector3.normalize(cartesian, mostOrthogonalAxisScratch);\r\n\t\tVector3.abs(f, f);\r\n\r\n\t\tif (f.x <= f.y) {\r\n\t\t\tif (f.x <= f.z) {\r\n\t\t\t\tresult = Vector3.clone(Vector3.UNIT_X, result);\r\n\t\t\t} else {\r\n\t\t\t\tresult = Vector3.clone(Vector3.UNIT_Z, result);\r\n\t\t\t}\r\n\t\t} else if (f.y <= f.z) {\r\n\t\t\tresult = Vector3.clone(Vector3.UNIT_Y, result);\r\n\t\t} else {\r\n\t\t\tresult = Vector3.clone(Vector3.UNIT_Z, result);\r\n\t\t}\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic projectVector(a: Vector3, b: Vector3, result: Vector3): Vector3 {\r\n\t\tconst scalar = Vector3.dot(a, b) / Vector3.dot(b, b);\r\n\t\treturn Vector3.multiplyByScalar(b, scalar, result);\r\n\t}\r\n\r\n\tstatic equals(left: Vector3, right: Vector3): boolean {\r\n\t\treturn (\r\n\t\t\tleft === right ||\r\n\t\t\t(defined(left) && defined(right) && left.x === right.x && left.y === right.y && left.z === right.z)\r\n\t\t);\r\n\t}\r\n\r\n\t/**\r\n\t * @private\r\n\t */\r\n\tstatic equalsArray(cartesian: Vector3, array: number[], offset: number): boolean {\r\n\t\treturn cartesian.x === array[offset] && cartesian.y === array[offset + 1] && cartesian.z === array[offset + 2];\r\n\t}\r\n\r\n\tstatic equalsEpsilon(left: Vector3, right: Vector3, relativeEpsilon = 0, absoluteEpsilon = 0): boolean {\r\n\t\treturn (\r\n\t\t\tleft === right ||\r\n\t\t\t(defined(left) &&\r\n\t\t\t\tdefined(right) &&\r\n\t\t\t\tGMath.equalsEpsilon(left.x, right.x, relativeEpsilon, absoluteEpsilon) &&\r\n\t\t\t\tGMath.equalsEpsilon(left.y, right.y, relativeEpsilon, absoluteEpsilon) &&\r\n\t\t\t\tGMath.equalsEpsilon(left.z, right.z, relativeEpsilon, absoluteEpsilon))\r\n\t\t);\r\n\t}\r\n\r\n\tstatic cross(left: Vector3, right: Vector3, result: Vector3): Vector3 {\r\n\t\tconst leftX = left.x;\r\n\t\tconst leftY = left.y;\r\n\t\tconst leftZ = left.z;\r\n\t\tconst rightX = right.x;\r\n\t\tconst rightY = right.y;\r\n\t\tconst rightZ = right.z;\r\n\r\n\t\tconst x = leftY * rightZ - leftZ * rightY;\r\n\t\tconst y = leftZ * rightX - leftX * rightZ;\r\n\t\tconst z = leftX * rightY - leftY * rightX;\r\n\r\n\t\tresult.x = x;\r\n\t\tresult.y = y;\r\n\t\tresult.z = z;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic midpoint = function (left: Vector3, right: Vector3, result: Vector3): Vector3 {\r\n\t\tresult.x = (left.x + right.x) * 0.5;\r\n\t\tresult.y = (left.y + right.y) * 0.5;\r\n\t\tresult.z = (left.z + right.z) * 0.5;\r\n\r\n\t\treturn result;\r\n\t};\r\n}\r\nconst distanceScratch = new Vector3();\r\nconst lerpScratch = new Vector3();\r\nconst angleBetweenScratch = new Vector3();\r\nconst angleBetweenScratch2 = new Vector3();\r\nconst mostOrthogonalAxisScratch = new Vector3();\r\nexport default Vector3;\r\n","import { VertexFormat } from \"../core/WebGPUConstant\";\nimport Vector2 from \"../math/Vector2\";\nimport Vector3 from \"../math/Vector3\";\nimport Buffer from \"../render/Buffer\";\n\nexport class Attribute {\n\tpublic offset: number;\n\tpublic shaderLocation: number;\n\tpublic type: string;\n\tpublic format: string;\n\tpublic attributeByteSize: number;\n\tpublic attributeType: AttributeType;\n\tpublic dirty: boolean;\n\tpublic static v3 = new Vector3();\n\tpublic static v2 = new Vector2();\n\tconstructor(public name: string, public value: Array<number>, public itemSize: number) {\n\t\tthis.name = name;\n\t\tthis.offset = 0;\n\t\tthis.shaderLocation = 0;\n\t\tthis.attributeType = AttributeType.attribute;\n\t\tthis.dirty = true;\n\t}\n\tgetGPUAttribute(): Array<GPUAttribute> {\n\t\treturn [\n\t\t\t{\n\t\t\t\tshaderLocation: this.shaderLocation,\n\t\t\t\tformat: this.format,\n\t\t\t\toffset: this.offset\n\t\t\t}\n\t\t];\n\t}\n\tdestroy() {\n\t\tthis.value = [];\n\t}\n\tapplyMatrix3(matrix3) {\n\t\tif (this.itemSize === 2) {\n\t\t\tfor (let i = 0, l = this.value.length / this.itemSize; i < l; i++) {\n\t\t\t\tAttribute.v2.fromBufferAttribute(this, i);\n\t\t\t\tAttribute.v2.applyMatrix3(matrix3);\n\t\t\t\tthis.setXY(i, Attribute.v2.x, Attribute.v2.y);\n\t\t\t}\n\t\t} else if (this.itemSize === 3) {\n\t\t\tfor (let i = 0, l = this.value.length / this.itemSize; i < l; i++) {\n\t\t\t\tAttribute.v3.fromBufferAttribute(this, i);\n\t\t\t\tAttribute.v3.applyMatrix3(matrix3);\n\t\t\t\tthis.setXYZ(i, Attribute.v3.x, Attribute.v3.y, Attribute.v3.z);\n\t\t\t}\n\t\t}\n\t\treturn this;\n\t}\n\tapplyMatrix4(matrix4) {\n\t\tfor (let i = 0, l = this.value.length / this.itemSize; i < l; i++) {\n\t\t\tAttribute.v3.fromBufferAttribute(this, i);\n\t\t\tAttribute.v3.applyMatrix4(matrix4);\n\t\t\tthis.setXYZ(i, Attribute.v3.x, Attribute.v3.y, Attribute.v3.z);\n\t\t}\n\t\treturn this;\n\t}\n\tsetX(index, x) {\n\t\tthis.value[index * this.itemSize] = x;\n\t\treturn this;\n\t}\n\tgetX(index) {\n\t\tconst x = this.value[index * this.itemSize];\n\t\treturn x;\n\t}\n\tsetY(index, y) {\n\t\tthis.value[index * this.itemSize + 1] = y;\n\t\treturn this;\n\t}\n\tgetY(index) {\n\t\tconst y = this.value[index * this.itemSize + 1];\n\t\treturn y;\n\t}\n\tsetZ(index, z) {\n\t\tthis.value[index * this.itemSize + 2] = z;\n\t\treturn this;\n\t}\n\tgetZ(index) {\n\t\tconst z = this.value[index * this.itemSize + 2];\n\t\treturn z;\n\t}\n\tgetW(index) {\n\t\tconst w = this.value[index * this.itemSize + 3];\n\t\treturn w;\n\t}\n\tsetXY(index, x, y) {\n\t\tindex *= this.itemSize;\n\t\tthis.value[index + 0] = x;\n\t\tthis.value[index + 1] = y;\n\t\treturn this;\n\t}\n\tsetXYZ(index, x, y, z) {\n\t\tindex *= this.itemSize;\n\t\tthis.value[index + 0] = x;\n\t\tthis.value[index + 1] = y;\n\t\tthis.value[index + 2] = z;\n\t\treturn this;\n\t}\n\tsetXYZW(index, x, y, z, w) {\n\t\tindex *= this.itemSize;\n\t\tthis.value[index + 0] = x;\n\t\tthis.value[index + 1] = y;\n\t\tthis.value[index + 2] = z;\n\t\tthis.value[index + 3] = w;\n\t\treturn this;\n\t}\n}\n\nexport class InterleavedAttribute {\n\tpublic names: string[];\n\tpublic value: Array<number>;\n\tpublic itemSizes: number[];\n\tpublic format: string;\n\tpublic byteSize: number;\n\tpublic attributeType: AttributeType;\n\tpublic dirty: boolean;\n\tconstructor(names: string[], value: Array<number>, itemSizes: number[]) {\n\t\tthis.names = names;\n\t\tthis.itemSizes = itemSizes;\n\t\tthis.value = value;\n\t\tthis.attributeType = AttributeType.interleavedAttribute;\n\t\tthis.dirty = true;\n\t}\n\tgetGPUAttribute(): Array<GPUAttribute> {\n\t\tconst result = [];\n\t\tthis.itemSizes.reduce((total, current, index) => {\n\t\t\tresult.push({\n\t\t\t\tshaderLocation: index,\n\t\t\t\tformat: current == 1 ? `${this.format}` : `${this.format}x${current}`,\n\t\t\t\toffset: total * this.byteSize\n\t\t\t});\n\t\t\treturn (total += current);\n\t\t}, 0);\n\t\treturn result;\n\t}\n\tdestroy() {\n\t\tthis.value = null;\n\t\tthis.names = null;\n\t\tthis.itemSizes = null;\n\t}\n}\nexport class Float32Attribute extends Attribute {\n\tconstructor(name: string, value: Array<number>, itemSize: number) {\n\t\tsuper(name, value, itemSize);\n\t\tconst { format, totalByteSize } = getAttributeFormat(VertexFormat.Float32, itemSize);\n\t\tthis.format = format;\n\t\tthis.attributeByteSize = totalByteSize;\n\t}\n}\nexport class InterleavedFloat32Attribute extends InterleavedAttribute {\n\tconstructor(names: string[], value: Array<number>, itemSizes: number[]) {\n\t\tsuper(names, value, itemSizes);\n\t\tthis.format = VertexFormat.Float32;\n\t\tthis.byteSize = Float32Array.BYTES_PER_ELEMENT;\n\t}\n}\nexport class BufferFloat32Attribute extends InterleavedFloat32Attribute {\n\tpublic buffer: Buffer;\n\tconstructor(names: string[], buffer: Buffer, itemSizes: number[]) {\n\t\tsuper(names, undefined, itemSizes);\n\t\tthis.buffer = buffer;\n\t}\n}\nexport enum AttributeType {\n\tinterleavedAttribute = 0,\n\tattribute = 1\n}\nexport type GPUAttribute = {\n\tshaderLocation: number;\n\tformat: string;\n\toffset: number;\n};\nfunction getAttributeFormat(type: string, itemSize: number) {\n\tconst key = `${type}x${itemSize}`;\n\treturn {\n\t\t[VertexFormat.Float32]: {\n\t\t\tformat: \"float32\",\n\t\t\ttotalByteSize: Float32Array.BYTES_PER_ELEMENT * itemSize,\n\t\t\tbyteSize: Float32Array.BYTES_PER_ELEMENT\n\t\t},\n\t\t[VertexFormat.Float32x2]: {\n\t\t\tformat: \"float32x2\",\n\t\t\ttotalByteSize: Float32Array.BYTES_PER_ELEMENT * itemSize,\n\t\t\tbyteSize: Float32Array.BYTES_PER_ELEMENT\n\t\t},\n\t\t[VertexFormat.Float32x3]: {\n\t\t\tformat: \"float32x3\",\n\t\t\ttotalByteSize: Float32Array.BYTES_PER_ELEMENT * itemSize,\n\t\t\tbyteSize: Float32Array.BYTES_PER_ELEMENT\n\t\t},\n\t\t[VertexFormat.Float32x4]: {\n\t\t\tformat: \"float32x4\",\n\t\t\ttotalByteSize: Float32Array.BYTES_PER_ELEMENT * itemSize,\n\t\t\tbyteSize: Float32Array.BYTES_PER_ELEMENT\n\t\t}\n\t}[key];\n}\n","import { BindGroupCacheOptions } from \"../core/WebGPUTypes\";\nconst bindGroupCache = new Map();\nclass BindGroup {\n\tdevice: GPUDevice;\n\tgpuBindGroup: GPUBindGroup;\n\tlabel: string;\n\tindex: number;\n\tdirty: boolean;\n\toffset?: number;\n\t// const uniformBytes = 5 * Float32Array.BYTES_PER_ELEMENT;\n\t// const alignedSizeBytes = Math.ceil(uniformBytes / 256) * 256;\n\t// const alignedSize =alignedSizeBytes / Float32Array.BYTES_PER_ELEMENT;\n\talignedSize?: number;\n\tmaxOffset?: number;\n\tdynamic?: boolean;\n\tconstructor(options: BindGroupCacheOptions) {\n\t\tthis.index = options.index || 0;\n\t\tthis.offset = options.offset ?? 0;\n\t\tthis.alignedSize = options.alignedSize ?? 0;\n\t\tthis.maxOffset = options.maxOffset ?? 0;\n\t\tthis.dynamic = options.dynamic ?? false;\n\t\tthis.gpuBindGroup = options.device.createBindGroup({\n\t\t\tlabel: options.label,\n\t\t\tlayout: options.layout.gpuBindGroupLayout,\n\t\t\tentries: options.entires.map((entity) => ({\n\t\t\t\tbinding: entity.binding,\n\t\t\t\tresource: entity.resource\n\t\t\t}))\n\t\t});\n\t}\n\tbind(passEncoder: GPURenderPassEncoder | GPUComputePassEncoder) {\n\t\t// dynamic uniforms must bind multiple times\n\t\tif (this.dynamic) {\n\t\t\tconst dynamicOffsets = [0];\n\t\t\tdynamicOffsets[0] = this.offset * this.alignedSize;\n\t\t\tthis.offset = ++this.offset < this.maxOffset ? this.offset : 0;\n\t\t\tpassEncoder.setBindGroup(this.index, this.gpuBindGroup, dynamicOffsets);\n\t\t} else {\n\t\t\tpassEncoder.setBindGroup(this.index, this.gpuBindGroup);\n\t\t}\n\t}\n\tdestroy() {\n\t\tthis.gpuBindGroup = undefined;\n\t\tthis.device = undefined;\n\t}\n\tstatic getBindGroupFromCache(options: BindGroupCacheOptions): BindGroup {\n\t\tif (bindGroupCache.has(options.label)) {\n\t\t\treturn bindGroupCache.get(options.label);\n\t\t} else {\n\t\t\tconst bindGroup = new BindGroup(options);\n\t\t\tbindGroupCache.set(options.label, bindGroup);\n\t\t\treturn bindGroup;\n\t\t}\n\t}\n\tstatic removeBindGroupFromCache(bindGroup: BindGroup) {\n\t\tbindGroupCache.delete(bindGroup);\n\t}\n}\n\nexport default BindGroup;\n","import { BindGroupEntityOptions } from \"../core/WebGPUTypes\";\nexport default class BindGroupEntity {\n\tbinding: number;\n\tresource: GPUBindingResource;\n\tconstructor(options: BindGroupEntityOptions) {\n\t\tthis.binding = options.binding;\n\t\tthis.resource = options.resource;\n\t}\n\tpublic getGPUGroupEntity() {\n\t\treturn {\n\t\t\tbinding: this.binding,\n\t\t\tresource: this.resource\n\t\t};\n\t}\n}\n","import { PassType } from \"../core/WebGPUTypes\";\nimport Attachment from \"./Attachment\";\nimport QuerySet from \"./QuerySet\";\nimport Texture from \"./Texture\";\n\nexport default class RenderTarget {\n\tpublic device: GPUDevice;\n\tpublic commandEncoder: GPUCommandEncoder | null;\n\tprivate _renderPassDescriptor: GPURenderPassDescriptor;\n\tprivate renderEncoder: GPURenderPassEncoder;\n\tprivate computeEncoder: GPUComputePassEncoder;\n\tconstructor(\n\t\tpublic type: PassType,\n\t\tpublic colorAttachments: Attachment[],\n\t\tpublic depthAttachment?: Attachment,\n\t\tpublic stencilAttachment?: Attachment,\n\t\tpublic querySet?: QuerySet,\n\t\tpublic fixedSize?: boolean\n\t) {\n\t\tthis.renderEncoder = undefined;\n\t\tthis.computeEncoder = undefined;\n\t\tthis._renderPassDescriptor = undefined;\n\t\tthis.commandEncoder = undefined;\n\t\tthis.device = undefined;\n\t\tthis.fixedSize = false;\n\t}\n\tget renderPassDescriptor() {\n\t\tthis._renderPassDescriptor = this.getRenderPassDescriptor();\n\t\treturn this._renderPassDescriptor;\n\t}\n\tpublic getColorTexture(index = 0): Texture {\n\t\tconst colAtt = this.colorAttachments[index];\n\t\tif (colAtt) {\n\t\t\treturn colAtt.texture as Texture;\n\t\t} else {\n\t\t\treturn null;\n\t\t}\n\t}\n\tpublic getDepthTexture(): Texture {\n\t\tif (this.depthAttachment) {\n\t\t\treturn this.depthAttachment.texture as Texture;\n\t\t}\n\t}\n\tprivate getRenderPassDescriptor(): GPURenderPassDescriptor | null {\n\t\tthis.depthAttachment?.texture?.update(this.device);\n\t\tthis?.querySet?.update(this.device);\n\t\treturn {\n\t\t\t...(this.colorAttachments && {\n\t\t\t\tcolorAttachments: this.colorAttachments.map((colorAttachment) => {\n\t\t\t\t\tcolorAttachment?.texture?.update && colorAttachment?.texture?.update(this.device);\n\t\t\t\t\treturn {\n\t\t\t\t\t\tview:\n\t\t\t\t\t\t\t// 暂时这么写\n\t\t\t\t\t\t\tcolorAttachment?.textureView?.() ?? colorAttachment.texture.textureView,\n\t\t\t\t\t\tresolveTarget:\n\t\t\t\t\t\t\tcolorAttachment.resolveTarget != undefined\n\t\t\t\t\t\t\t\t? colorAttachment.resolveTarget.textureView\n\t\t\t\t\t\t\t\t: undefined,\n\t\t\t\t\t\tclearValue: colorAttachment.value,\n\t\t\t\t\t\tloadOp: colorAttachment.op,\n\t\t\t\t\t\tstoreOp: colorAttachment.storeOp\n\t\t\t\t\t} as GPURenderPassColorAttachment;\n\t\t\t\t})\n\t\t\t}),\n\t\t\t...((this.depthAttachment || this.stencilAttachment) && {\n\t\t\t\tdepthStencilAttachment: {\n\t\t\t\t\tview: this.depthAttachment?.texture?.textureView || undefined,\n\t\t\t\t\tdepthLoadOp: this.depthAttachment?.op || \"clear\",\n\t\t\t\t\tdepthClearValue: this.depthAttachment?.value || 1.0,\n\t\t\t\t\tdepthStoreOp: this.depthAttachment?.storeOp || \"store\",\n\t\t\t\t\tdepthReadOnly: this.depthAttachment?.readOnly || false\n\t\t\t\t\t// stencilLoadOp: this.stencilAttachment?.op || \"clear\",\n\t\t\t\t\t// stencilClearValue: this.stencilAttachment?.value || 0,\n\t\t\t\t\t// stencilStoreOp: this.stencilAttachment?.storeOp || \"store\",\n\t\t\t\t} as GPURenderPassDepthStencilAttachment\n\t\t\t}),\n\t\t\t...(this.querySet && { occlusionQuerySet: this.querySet.gpuQuerySet })\n\t\t};\n\t}\n\n\tpublic beginRenderPass(device: GPUDevice) {\n\t\tif (!this.device) this.device = device;\n\t\tthis.commandEncoder = this.device.createCommandEncoder();\n\t\tthis.renderEncoder = this.commandEncoder.beginRenderPass(this.renderPassDescriptor);\n\t\treturn this.renderEncoder;\n\t}\n\tpublic endRenderPass() {\n\t\tthis.renderEncoder?.end();\n\t\tthis.device.queue.submit([this.commandEncoder.finish()]);\n\t\tthis.commandEncoder = null;\n\t\tthis.renderEncoder = null;\n\t}\n\tpublic beginComputePassEncoder(device: GPUDevice) {\n\t\tif (!this.device) this.device = device;\n\t\tthis.commandEncoder = this.device.createCommandEncoder();\n\t\tthis.computeEncoder = this.commandEncoder.beginComputePass();\n\t\treturn this.computeEncoder;\n\t}\n\tpublic endComputePassEncoder() {\n\t\tthis.computeEncoder?.end();\n\t\tthis.device.queue.submit([this.commandEncoder.finish()]);\n\t\tthis.commandEncoder = null;\n\t\tthis.renderEncoder = null;\n\t}\n\tpublic setSize(width: number, height: number, depth = 1) {\n\t\tif (this.fixedSize) return;\n\t\tthis?.depthAttachment?.texture?.setSize?.(width, height, depth);\n\t\tthis?.colorAttachments?.forEach?.((colorAttachment) =>\n\t\t\tcolorAttachment?.texture?.setSize?.(width, height, depth)\n\t\t);\n\t}\n\tdestroy() {\n\t\tif (this.colorAttachments) {\n\t\t\tthis.colorAttachments.forEach((colorAttachment) => {\n\t\t\t\tif (colorAttachment.texture) {\n\t\t\t\t\tcolorAttachment.texture.destroy();\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\t\tif (this.depthAttachment.texture) this.depthAttachment.texture.destroy();\n\t}\n}\n","import defaultValue from \"../utils/defaultValue\";\r\nimport defined from \"../utils/defined\";\r\nimport GMath from \"./Math\";\r\nimport Matrix4 from \"./Matrix4\";\r\nimport { Quaternion } from \"./Quaternion\";\r\nimport Vector3 from \"./Vector3\";\r\n/**\r\n * A 3x3 matrix, indexable as a column-major order array.\r\n * @param {Number} [column0Row0=0.0] The value for column 0, row 0.\r\n * @param {Number} [column1Row0=0.0] The value for column 1, row 0.\r\n * @param {Number} [column2Row0=0.0] The value for column 2, row 0.\r\n * @param {Number} [column0Row1=0.0] The value for column 0, row 1.\r\n * @param {Number} [column1Row1=0.0] The value for column 1, row 1.\r\n * @param {Number} [column2Row1=0.0] The value for column 2, row 1.\r\n * @param {Number} [column0Row2=0.0] The value for column 0, row 2.\r\n * @param {Number} [column1Row2=0.0] The value for column 1, row 2.\r\n * @param {Number} [column2Row2=0.0] The value for column 2, row 2.\r\n */\r\nclass Matrix3 {\r\n\tconstructor(\r\n\t\tcolumn0Row0 = 0,\r\n\t\tcolumn1Row0 = 0,\r\n\t\tcolumn2Row0 = 0,\r\n\t\tcolumn0Row1 = 0,\r\n\t\tcolumn1Row1 = 0,\r\n\t\tcolumn2Row1 = 0,\r\n\t\tcolumn0Row2 = 0,\r\n\t\tcolumn1Row2 = 0,\r\n\t\tcolumn2Row2 = 0\r\n\t) {\r\n\t\tthis[0] = column0Row0;\r\n\t\tthis[1] = column0Row1;\r\n\t\tthis[2] = column0Row2;\r\n\t\tthis[3] = column1Row0;\r\n\t\tthis[4] = column1Row1;\r\n\t\tthis[5] = column1Row2;\r\n\t\tthis[6] = column2Row0;\r\n\t\tthis[7] = column2Row1;\r\n\t\tthis[8] = column2Row2;\r\n\t}\r\n\tsetFromMatrix4(matrix: Matrix4): Matrix3 {\r\n\t\tthis[0] = matrix[0];\r\n\t\tthis[1] = matrix[1];\r\n\t\tthis[2] = matrix[2];\r\n\t\tthis[3] = matrix[4];\r\n\t\tthis[4] = matrix[5];\r\n\t\tthis[5] = matrix[2];\r\n\t\tthis[6] = matrix[8];\r\n\t\tthis[7] = matrix[9];\r\n\t\tthis[8] = matrix[10];\r\n\t\treturn this;\r\n\t}\r\n\tgetNormalMatrix(matrix4: Matrix4): Matrix3 {\r\n\t\tthis.setFromMatrix4(matrix4);\r\n\t\tMatrix3.inverse(this, this);\r\n\t\tMatrix3.transpose(this, this);\r\n\t\treturn this;\r\n\t}\r\n\r\n\tstatic clone(matrix: Matrix3 | number[], result: Matrix3): Matrix3 {\r\n\t\tif (!defined(matrix)) {\r\n\t\t\treturn undefined;\r\n\t\t}\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Matrix3(\r\n\t\t\t\tmatrix[0],\r\n\t\t\t\tmatrix[3],\r\n\t\t\t\tmatrix[6],\r\n\t\t\t\tmatrix[1],\r\n\t\t\t\tmatrix[4],\r\n\t\t\t\tmatrix[7],\r\n\t\t\t\tmatrix[2],\r\n\t\t\t\tmatrix[5],\r\n\t\t\t\tmatrix[8]\r\n\t\t\t);\r\n\t\t}\r\n\t\tresult[0] = matrix[0];\r\n\t\tresult[1] = matrix[1];\r\n\t\tresult[2] = matrix[2];\r\n\t\tresult[3] = matrix[3];\r\n\t\tresult[4] = matrix[4];\r\n\t\tresult[5] = matrix[5];\r\n\t\tresult[6] = matrix[6];\r\n\t\tresult[7] = matrix[7];\r\n\t\tresult[8] = matrix[8];\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic fromColumnMajorArray(values: Array<number>, result?: Matrix3): Matrix3 {\r\n\t\tif (!defined(result)) {\r\n\t\t\tresult = new Matrix3();\r\n\t\t}\r\n\t\treturn Matrix3.clone(values, result);\r\n\t}\r\n\r\n\tstatic fromRowMajorArray(values: Array<number>, result?: Matrix3): Matrix3 {\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Matrix3(\r\n\t\t\t\tvalues[0],\r\n\t\t\t\tvalues[1],\r\n\t\t\t\tvalues[2],\r\n\t\t\t\tvalues[3],\r\n\t\t\t\tvalues[4],\r\n\t\t\t\tvalues[5],\r\n\t\t\t\tvalues[6],\r\n\t\t\t\tvalues[7],\r\n\t\t\t\tvalues[8]\r\n\t\t\t);\r\n\t\t}\r\n\t\tresult[0] = values[0];\r\n\t\tresult[1] = values[3];\r\n\t\tresult[2] = values[6];\r\n\t\tresult[3] = values[1];\r\n\t\tresult[4] = values[4];\r\n\t\tresult[5] = values[7];\r\n\t\tresult[6] = values[2];\r\n\t\tresult[7] = values[5];\r\n\t\tresult[8] = values[8];\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic fromQuaternion(quaternion: Quaternion, result?: Matrix3): Matrix3 {\r\n\t\tconst x2 = quaternion.x * quaternion.x;\r\n\t\tconst xy = quaternion.x * quaternion.y;\r\n\t\tconst xz = quaternion.x * quaternion.z;\r\n\t\tconst xw = quaternion.x * quaternion.w;\r\n\t\tconst y2 = quaternion.y * quaternion.y;\r\n\t\tconst yz = quaternion.y * quaternion.z;\r\n\t\tconst yw = quaternion.y * quaternion.w;\r\n\t\tconst z2 = quaternion.z * quaternion.z;\r\n\t\tconst zw = quaternion.z * quaternion.w;\r\n\t\tconst w2 = quaternion.w * quaternion.w;\r\n\r\n\t\tconst m00 = x2 - y2 - z2 + w2;\r\n\t\tconst m01 = 2.0 * (xy - zw);\r\n\t\tconst m02 = 2.0 * (xz + yw);\r\n\r\n\t\tconst m10 = 2.0 * (xy + zw);\r\n\t\tconst m11 = -x2 + y2 - z2 + w2;\r\n\t\tconst m12 = 2.0 * (yz - xw);\r\n\r\n\t\tconst m20 = 2.0 * (xz - yw);\r\n\t\tconst m21 = 2.0 * (yz + xw);\r\n\t\tconst m22 = -x2 - y2 + z2 + w2;\r\n\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Matrix3(m00, m01, m02, m10, m11, m12, m20, m21, m22);\r\n\t\t}\r\n\t\tresult[0] = m00;\r\n\t\tresult[1] = m10;\r\n\t\tresult[2] = m20;\r\n\t\tresult[3] = m01;\r\n\t\tresult[4] = m11;\r\n\t\tresult[5] = m21;\r\n\t\tresult[6] = m02;\r\n\t\tresult[7] = m12;\r\n\t\tresult[8] = m22;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic fromScale(scale: Vector3, result: Matrix3): Matrix3 {\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Matrix3(scale.x, 0.0, 0.0, 0.0, scale.y, 0.0, 0.0, 0.0, scale.z);\r\n\t\t}\r\n\r\n\t\tresult[0] = scale.x;\r\n\t\tresult[1] = 0.0;\r\n\t\tresult[2] = 0.0;\r\n\t\tresult[3] = 0.0;\r\n\t\tresult[4] = scale.y;\r\n\t\tresult[5] = 0.0;\r\n\t\tresult[6] = 0.0;\r\n\t\tresult[7] = 0.0;\r\n\t\tresult[8] = scale.z;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic fromRotationX(angle: number, result: Matrix3): Matrix3 {\r\n\t\tconst cosAngle = Math.cos(angle);\r\n\t\tconst sinAngle = Math.sin(angle);\r\n\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Matrix3(1.0, 0.0, 0.0, 0.0, cosAngle, -sinAngle, 0.0, sinAngle, cosAngle);\r\n\t\t}\r\n\r\n\t\tresult[0] = 1.0;\r\n\t\tresult[1] = 0.0;\r\n\t\tresult[2] = 0.0;\r\n\t\tresult[3] = 0.0;\r\n\t\tresult[4] = cosAngle;\r\n\t\tresult[5] = sinAngle;\r\n\t\tresult[6] = 0.0;\r\n\t\tresult[7] = -sinAngle;\r\n\t\tresult[8] = cosAngle;\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic fromRotationY(angle: number, result: Matrix3): Matrix3 {\r\n\t\tconst cosAngle = Math.cos(angle);\r\n\t\tconst sinAngle = Math.sin(angle);\r\n\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Matrix3(cosAngle, 0.0, sinAngle, 0.0, 1.0, 0.0, -sinAngle, 0.0, cosAngle);\r\n\t\t}\r\n\r\n\t\tresult[0] = cosAngle;\r\n\t\tresult[1] = 0.0;\r\n\t\tresult[2] = -sinAngle;\r\n\t\tresult[3] = 0.0;\r\n\t\tresult[4] = 1.0;\r\n\t\tresult[5] = 0.0;\r\n\t\tresult[6] = sinAngle;\r\n\t\tresult[7] = 0.0;\r\n\t\tresult[8] = cosAngle;\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic fromRotationZstatic(angle: number, result: Matrix3): Matrix3 {\r\n\t\tconst cosAngle = Math.cos(angle);\r\n\t\tconst sinAngle = Math.sin(angle);\r\n\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Matrix3(cosAngle, -sinAngle, 0.0, sinAngle, cosAngle, 0.0, 0.0, 0.0, 1.0);\r\n\t\t}\r\n\r\n\t\tresult[0] = cosAngle;\r\n\t\tresult[1] = sinAngle;\r\n\t\tresult[2] = 0.0;\r\n\t\tresult[3] = -sinAngle;\r\n\t\tresult[4] = cosAngle;\r\n\t\tresult[5] = 0.0;\r\n\t\tresult[6] = 0.0;\r\n\t\tresult[7] = 0.0;\r\n\t\tresult[8] = 1.0;\r\n\r\n\t\treturn result;\r\n\t}\r\n\ttoArray() {\r\n\t\tconst result = [];\r\n\t\tMatrix3.toArray(this, result);\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic toArray(matrix: Matrix3, result: number[]): number[] {\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn [matrix[0], matrix[1], matrix[2], matrix[3], matrix[4], matrix[5], matrix[6], matrix[7], matrix[8]];\r\n\t\t}\r\n\t\tresult[0] = matrix[0];\r\n\t\tresult[1] = matrix[1];\r\n\t\tresult[2] = matrix[2];\r\n\t\tresult[3] = matrix[3];\r\n\t\tresult[4] = matrix[4];\r\n\t\tresult[5] = matrix[5];\r\n\t\tresult[6] = matrix[6];\r\n\t\tresult[7] = matrix[7];\r\n\t\tresult[8] = matrix[8];\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic getElementIndex(column: number, row: number): number {\r\n\t\treturn column * 3 + row;\r\n\t}\r\n\r\n\tstatic getColumn(matrix: Matrix3, index: number, result: Vector3): Vector3 {\r\n\t\tconst startIndex = index * 3;\r\n\t\tconst x = matrix[startIndex];\r\n\t\tconst y = matrix[startIndex + 1];\r\n\t\tconst z = matrix[startIndex + 2];\r\n\r\n\t\tresult.x = x;\r\n\t\tresult.y = y;\r\n\t\tresult.z = z;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic setColumn(matrix: Matrix3, index: number, cartesian: Vector3, result: Matrix3): Matrix3 {\r\n\t\tresult = Matrix3.clone(matrix, result);\r\n\t\tconst startIndex = index * 3;\r\n\t\tresult[startIndex] = cartesian.x;\r\n\t\tresult[startIndex + 1] = cartesian.y;\r\n\t\tresult[startIndex + 2] = cartesian.z;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic getRow(matrix: Matrix3, index: number, result: Vector3): Vector3 {\r\n\t\tconst x = matrix[index];\r\n\t\tconst y = matrix[index + 3];\r\n\t\tconst z = matrix[index + 6];\r\n\r\n\t\tresult.x = x;\r\n\t\tresult.y = y;\r\n\t\tresult.z = z;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic setRow(matrix: Matrix3, index: number, cartesian: Vector3, result: Matrix3): Matrix3 {\r\n\t\tresult = Matrix3.clone(matrix, result);\r\n\t\tresult[index] = cartesian.x;\r\n\t\tresult[index + 3] = cartesian.y;\r\n\t\tresult[index + 6] = cartesian.z;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic setScale(matrix: Matrix3, scale: Vector3, result: Matrix3): Matrix3 {\r\n\t\tconst existingScale = Matrix3.getScale(matrix, scaleScratch1);\r\n\t\tconst scaleRatioX = scale.x / existingScale.x;\r\n\t\tconst scaleRatioY = scale.y / existingScale.y;\r\n\t\tconst scaleRatioZ = scale.z / existingScale.z;\r\n\r\n\t\tresult[0] = matrix[0] * scaleRatioX;\r\n\t\tresult[1] = matrix[1] * scaleRatioX;\r\n\t\tresult[2] = matrix[2] * scaleRatioX;\r\n\t\tresult[3] = matrix[3] * scaleRatioY;\r\n\t\tresult[4] = matrix[4] * scaleRatioY;\r\n\t\tresult[5] = matrix[5] * scaleRatioY;\r\n\t\tresult[6] = matrix[6] * scaleRatioZ;\r\n\t\tresult[7] = matrix[7] * scaleRatioZ;\r\n\t\tresult[8] = matrix[8] * scaleRatioZ;\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic getScale(matrix: Matrix3, result: Vector3): Vector3 {\r\n\t\tresult.x = Vector3.magnitude(Vector3.fromElements(matrix[0], matrix[1], matrix[2], scratchColumn));\r\n\t\tresult.y = Vector3.magnitude(Vector3.fromElements(matrix[3], matrix[4], matrix[5], scratchColumn));\r\n\t\tresult.z = Vector3.magnitude(Vector3.fromElements(matrix[6], matrix[7], matrix[8], scratchColumn));\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic getMaximumScale(matrix: Matrix3): number {\r\n\t\tMatrix3.getScale(matrix, scaleScratch3);\r\n\t\treturn Vector3.maximumComponent(scaleScratch3);\r\n\t}\r\n\r\n\tstatic setRotation(matrix: Matrix3, rotation: Matrix3, result: Matrix3): Matrix3 {\r\n\t\tconst scale = Matrix3.getScale(matrix, scaleScratch4);\r\n\r\n\t\tresult[0] = rotation[0] * scale.x;\r\n\t\tresult[1] = rotation[1] * scale.x;\r\n\t\tresult[2] = rotation[2] * scale.x;\r\n\t\tresult[3] = rotation[3] * scale.y;\r\n\t\tresult[4] = rotation[4] * scale.y;\r\n\t\tresult[5] = rotation[5] * scale.y;\r\n\t\tresult[6] = rotation[6] * scale.z;\r\n\t\tresult[7] = rotation[7] * scale.z;\r\n\t\tresult[8] = rotation[8] * scale.z;\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic getRotation(matrix: Matrix3, result: Matrix3): Matrix3 {\r\n\t\tconst scale = Matrix3.getScale(matrix, scaleScratch5);\r\n\r\n\t\tresult[0] = matrix[0] / scale.x;\r\n\t\tresult[1] = matrix[1] / scale.x;\r\n\t\tresult[2] = matrix[2] / scale.x;\r\n\t\tresult[3] = matrix[3] / scale.y;\r\n\t\tresult[4] = matrix[4] / scale.y;\r\n\t\tresult[5] = matrix[5] / scale.y;\r\n\t\tresult[6] = matrix[6] / scale.z;\r\n\t\tresult[7] = matrix[7] / scale.z;\r\n\t\tresult[8] = matrix[8] / scale.z;\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic multiply(left: Matrix3, right: Matrix3, result: Matrix3): Matrix3 {\r\n\t\tconst column0Row0 = left[0] * right[0] + left[3] * right[1] + left[6] * right[2];\r\n\t\tconst column0Row1 = left[1] * right[0] + left[4] * right[1] + left[7] * right[2];\r\n\t\tconst column0Row2 = left[2] * right[0] + left[5] * right[1] + left[8] * right[2];\r\n\r\n\t\tconst column1Row0 = left[0] * right[3] + left[3] * right[4] + left[6] * right[5];\r\n\t\tconst column1Row1 = left[1] * right[3] + left[4] * right[4] + left[7] * right[5];\r\n\t\tconst column1Row2 = left[2] * right[3] + left[5] * right[4] + left[8] * right[5];\r\n\r\n\t\tconst column2Row0 = left[0] * right[6] + left[3] * right[7] + left[6] * right[8];\r\n\t\tconst column2Row1 = left[1] * right[6] + left[4] * right[7] + left[7] * right[8];\r\n\t\tconst column2Row2 = left[2] * right[6] + left[5] * right[7] + left[8] * right[8];\r\n\r\n\t\tresult[0] = column0Row0;\r\n\t\tresult[1] = column0Row1;\r\n\t\tresult[2] = column0Row2;\r\n\t\tresult[3] = column1Row0;\r\n\t\tresult[4] = column1Row1;\r\n\t\tresult[5] = column1Row2;\r\n\t\tresult[6] = column2Row0;\r\n\t\tresult[7] = column2Row1;\r\n\t\tresult[8] = column2Row2;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic add(left: Matrix3, right: Matrix3, result: Matrix3): Matrix3 {\r\n\t\tresult[0] = left[0] + right[0];\r\n\t\tresult[1] = left[1] + right[1];\r\n\t\tresult[2] = left[2] + right[2];\r\n\t\tresult[3] = left[3] + right[3];\r\n\t\tresult[4] = left[4] + right[4];\r\n\t\tresult[5] = left[5] + right[5];\r\n\t\tresult[6] = left[6] + right[6];\r\n\t\tresult[7] = left[7] + right[7];\r\n\t\tresult[8] = left[8] + right[8];\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic subtract(left: Matrix3, right: Matrix3, result: Matrix3) {\r\n\t\tresult[0] = left[0] - right[0];\r\n\t\tresult[1] = left[1] - right[1];\r\n\t\tresult[2] = left[2] - right[2];\r\n\t\tresult[3] = left[3] - right[3];\r\n\t\tresult[4] = left[4] - right[4];\r\n\t\tresult[5] = left[5] - right[5];\r\n\t\tresult[6] = left[6] - right[6];\r\n\t\tresult[7] = left[7] - right[7];\r\n\t\tresult[8] = left[8] - right[8];\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic multiplyByVector(matrix: Matrix3, cartesian: Vector3, result: Vector3): Vector3 {\r\n\t\tconst vX = cartesian.x;\r\n\t\tconst vY = cartesian.y;\r\n\t\tconst vZ = cartesian.z;\r\n\r\n\t\tconst x = matrix[0] * vX + matrix[3] * vY + matrix[6] * vZ;\r\n\t\tconst y = matrix[1] * vX + matrix[4] * vY + matrix[7] * vZ;\r\n\t\tconst z = matrix[2] * vX + matrix[5] * vY + matrix[8] * vZ;\r\n\r\n\t\tresult.x = x;\r\n\t\tresult.y = y;\r\n\t\tresult.z = z;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic multiplyByScalar(matrix: Matrix3, scalar: number, result: Matrix3): Matrix3 {\r\n\t\tresult[0] = matrix[0] * scalar;\r\n\t\tresult[1] = matrix[1] * scalar;\r\n\t\tresult[2] = matrix[2] * scalar;\r\n\t\tresult[3] = matrix[3] * scalar;\r\n\t\tresult[4] = matrix[4] * scalar;\r\n\t\tresult[5] = matrix[5] * scalar;\r\n\t\tresult[6] = matrix[6] * scalar;\r\n\t\tresult[7] = matrix[7] * scalar;\r\n\t\tresult[8] = matrix[8] * scalar;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic multiplyByScale(matrix: Matrix3, scale: Vector3, result: Matrix3): Matrix3 {\r\n\t\tresult[0] = matrix[0] * scale.x;\r\n\t\tresult[1] = matrix[1] * scale.x;\r\n\t\tresult[2] = matrix[2] * scale.x;\r\n\t\tresult[3] = matrix[3] * scale.y;\r\n\t\tresult[4] = matrix[4] * scale.y;\r\n\t\tresult[5] = matrix[5] * scale.y;\r\n\t\tresult[6] = matrix[6] * scale.z;\r\n\t\tresult[7] = matrix[7] * scale.z;\r\n\t\tresult[8] = matrix[8] * scale.z;\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic negate(matrix: Matrix3, result: Matrix3): Matrix3 {\r\n\t\tresult[0] = -matrix[0];\r\n\t\tresult[1] = -matrix[1];\r\n\t\tresult[2] = -matrix[2];\r\n\t\tresult[3] = -matrix[3];\r\n\t\tresult[4] = -matrix[4];\r\n\t\tresult[5] = -matrix[5];\r\n\t\tresult[6] = -matrix[6];\r\n\t\tresult[7] = -matrix[7];\r\n\t\tresult[8] = -matrix[8];\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic transpose(matrix: Matrix3, result: Matrix3): Matrix3 {\r\n\t\tconst column0Row0 = matrix[0];\r\n\t\tconst column0Row1 = matrix[3];\r\n\t\tconst column0Row2 = matrix[6];\r\n\t\tconst column1Row0 = matrix[1];\r\n\t\tconst column1Row1 = matrix[4];\r\n\t\tconst column1Row2 = matrix[7];\r\n\t\tconst column2Row0 = matrix[2];\r\n\t\tconst column2Row1 = matrix[5];\r\n\t\tconst column2Row2 = matrix[8];\r\n\r\n\t\tresult[0] = column0Row0;\r\n\t\tresult[1] = column0Row1;\r\n\t\tresult[2] = column0Row2;\r\n\t\tresult[3] = column1Row0;\r\n\t\tresult[4] = column1Row1;\r\n\t\tresult[5] = column1Row2;\r\n\t\tresult[6] = column2Row0;\r\n\t\tresult[7] = column2Row1;\r\n\t\tresult[8] = column2Row2;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic abs(matrix: Matrix3, result: Matrix3): Matrix3 {\r\n\t\tresult[0] = Math.abs(matrix[0]);\r\n\t\tresult[1] = Math.abs(matrix[1]);\r\n\t\tresult[2] = Math.abs(matrix[2]);\r\n\t\tresult[3] = Math.abs(matrix[3]);\r\n\t\tresult[4] = Math.abs(matrix[4]);\r\n\t\tresult[5] = Math.abs(matrix[5]);\r\n\t\tresult[6] = Math.abs(matrix[6]);\r\n\t\tresult[7] = Math.abs(matrix[7]);\r\n\t\tresult[8] = Math.abs(matrix[8]);\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic determinant(matrix: Matrix3): number {\r\n\t\tconst m11 = matrix[0];\r\n\t\tconst m21 = matrix[3];\r\n\t\tconst m31 = matrix[6];\r\n\t\tconst m12 = matrix[1];\r\n\t\tconst m22 = matrix[4];\r\n\t\tconst m32 = matrix[7];\r\n\t\tconst m13 = matrix[2];\r\n\t\tconst m23 = matrix[5];\r\n\t\tconst m33 = matrix[8];\r\n\r\n\t\treturn m11 * (m22 * m33 - m23 * m32) + m12 * (m23 * m31 - m21 * m33) + m13 * (m21 * m32 - m22 * m31);\r\n\t}\r\n\r\n\tstatic inverse(matrix: Matrix3, result: Matrix3): Matrix3 {\r\n\t\tconst m11 = matrix[0];\r\n\t\tconst m21 = matrix[1];\r\n\t\tconst m31 = matrix[2];\r\n\t\tconst m12 = matrix[3];\r\n\t\tconst m22 = matrix[4];\r\n\t\tconst m32 = matrix[5];\r\n\t\tconst m13 = matrix[6];\r\n\t\tconst m23 = matrix[7];\r\n\t\tconst m33 = matrix[8];\r\n\r\n\t\tconst determinant = Matrix3.determinant(matrix);\r\n\r\n\t\t// >>includeStart('debug', pragmas.debug);\r\n\t\tif (Math.abs(determinant) <= GMath.EPSILON15) {\r\n\t\t\tthrow new Error(\"matrix is not invertible\");\r\n\t\t}\r\n\t\t// >>includeEnd('debug');\r\n\r\n\t\tresult[0] = m22 * m33 - m23 * m32;\r\n\t\tresult[1] = m23 * m31 - m21 * m33;\r\n\t\tresult[2] = m21 * m32 - m22 * m31;\r\n\t\tresult[3] = m13 * m32 - m12 * m33;\r\n\t\tresult[4] = m11 * m33 - m13 * m31;\r\n\t\tresult[5] = m12 * m31 - m11 * m32;\r\n\t\tresult[6] = m12 * m23 - m13 * m22;\r\n\t\tresult[7] = m13 * m21 - m11 * m23;\r\n\t\tresult[8] = m11 * m22 - m12 * m21;\r\n\r\n\t\tconst scale = 1.0 / determinant;\r\n\t\treturn Matrix3.multiplyByScalar(result, scale, result);\r\n\t}\r\n\r\n\tstatic inverseTranspose(matrix: Matrix3, result: Matrix3) {\r\n\t\treturn Matrix3.inverse(Matrix3.transpose(matrix, scratchTransposeMatrix), result);\r\n\t}\r\n\r\n\tstatic equals(left: Matrix3, right: Matrix3): boolean {\r\n\t\treturn (\r\n\t\t\tleft === right ||\r\n\t\t\t(defined(left) &&\r\n\t\t\t\tdefined(right) &&\r\n\t\t\t\tleft[0] === right[0] &&\r\n\t\t\t\tleft[1] === right[1] &&\r\n\t\t\t\tleft[2] === right[2] &&\r\n\t\t\t\tleft[3] === right[3] &&\r\n\t\t\t\tleft[4] === right[4] &&\r\n\t\t\t\tleft[5] === right[5] &&\r\n\t\t\t\tleft[6] === right[6] &&\r\n\t\t\t\tleft[7] === right[7] &&\r\n\t\t\t\tleft[8] === right[8])\r\n\t\t);\r\n\t}\r\n\r\n\tstatic equalsEpsilon(left: Matrix3, right: Matrix3, epsilon = 0): boolean {\r\n\t\tepsilon = defaultValue(epsilon, 0);\r\n\r\n\t\treturn (\r\n\t\t\tleft === right ||\r\n\t\t\t(defined(left) &&\r\n\t\t\t\tdefined(right) &&\r\n\t\t\t\tMath.abs(left[0] - right[0]) <= epsilon &&\r\n\t\t\t\tMath.abs(left[1] - right[1]) <= epsilon &&\r\n\t\t\t\tMath.abs(left[2] - right[2]) <= epsilon &&\r\n\t\t\t\tMath.abs(left[3] - right[3]) <= epsilon &&\r\n\t\t\t\tMath.abs(left[4] - right[4]) <= epsilon &&\r\n\t\t\t\tMath.abs(left[5] - right[5]) <= epsilon &&\r\n\t\t\t\tMath.abs(left[6] - right[6]) <= epsilon &&\r\n\t\t\t\tMath.abs(left[7] - right[7]) <= epsilon &&\r\n\t\t\t\tMath.abs(left[8] - right[8]) <= epsilon)\r\n\t\t);\r\n\t}\r\n\r\n\tstatic IDENTITY = Object.freeze(new Matrix3(1.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 1.0));\r\n\r\n\tstatic ZERO = Object.freeze(new Matrix3(0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0));\r\n\r\n\tclone(result: Matrix3): Matrix3 {\r\n\t\treturn Matrix3.clone(this, result);\r\n\t}\r\n\r\n\tequals(right: Matrix3): boolean {\r\n\t\treturn Matrix3.equals(this, right);\r\n\t}\r\n\r\n\t/**\r\n\t * @private\r\n\t */\r\n\tequalsArray(matrix: Matrix3 | number[], array: number[], offset: number): boolean {\r\n\t\treturn (\r\n\t\t\tmatrix[0] === array[offset] &&\r\n\t\t\tmatrix[1] === array[offset + 1] &&\r\n\t\t\tmatrix[2] === array[offset + 2] &&\r\n\t\t\tmatrix[3] === array[offset + 3] &&\r\n\t\t\tmatrix[4] === array[offset + 4] &&\r\n\t\t\tmatrix[5] === array[offset + 5] &&\r\n\t\t\tmatrix[6] === array[offset + 6] &&\r\n\t\t\tmatrix[7] === array[offset + 7] &&\r\n\t\t\tmatrix[8] === array[offset + 8]\r\n\t\t);\r\n\t}\r\n\r\n\t/**\r\n\t * Compares this matrix to the provided matrix componentwise and returns\r\n\t * <code>true</code> if they are within the provided epsilon,\r\n\t * <code>false</code> otherwise.\r\n\t *\r\n\t * @param {Matrix3} [right] The right hand side matrix.\r\n\t * @param {Number} [epsilon=0] The epsilon to use for equality testing.\r\n\t * @returns {Boolean} <code>true</code> if they are within the provided epsilon, <code>false</code> otherwise.\r\n\t */\r\n\tequalsEpsilon(right, epsilon) {\r\n\t\treturn Matrix3.equalsEpsilon(this, right, epsilon);\r\n\t}\r\n\r\n\ttoString() {\r\n\t\treturn (\r\n\t\t\t`(${this[0]}, ${this[3]}, ${this[6]})\\n` +\r\n\t\t\t`(${this[1]}, ${this[4]}, ${this[7]})\\n` +\r\n\t\t\t`(${this[2]}, ${this[5]}, ${this[8]})`\r\n\t\t);\r\n\t}\r\n}\r\n\r\nconst scaleScratch1 = new Vector3();\r\nconst scaleScratch2 = new Vector3();\r\nconst scratchColumn = new Vector3();\r\nconst scaleScratch3 = new Vector3();\r\nconst scaleScratch4 = new Vector3();\r\nconst scaleScratch5 = new Vector3();\r\n\r\nfunction computeFrobeniusNorm(matrix) {\r\n\tlet norm = 0.0;\r\n\tfor (let i = 0; i < 9; ++i) {\r\n\t\tconst temp = matrix[i];\r\n\t\tnorm += temp * temp;\r\n\t}\r\n\r\n\treturn Math.sqrt(norm);\r\n}\r\n\r\nconst rowVal = [1, 0, 0];\r\nconst colVal = [2, 2, 1];\r\n\r\nfunction offDiagonalFrobeniusNorm(matrix) {\r\n\t// Computes the \"off-diagonal\" Frobenius norm.\r\n\t// Assumes matrix is symmetric.\r\n\r\n\tlet norm = 0.0;\r\n\tfor (let i = 0; i < 3; ++i) {\r\n\t\tconst temp = matrix[Matrix3.getElementIndex(colVal[i], rowVal[i])];\r\n\t\tnorm += 2.0 * temp * temp;\r\n\t}\r\n\r\n\treturn Math.sqrt(norm);\r\n}\r\n\r\nfunction shurDecomposition(matrix, result) {\r\n\t// This routine was created based upon Matrix Computations, 3rd ed., by Golub and Van Loan,\r\n\t// section 8.4.2 The 2by2 Symmetric Schur Decomposition.\r\n\t//\r\n\t// The routine takes a matrix, which is assumed to be symmetric, and\r\n\t// finds the largest off-diagonal term, and then creates\r\n\t// a matrix (result) which can be used to help reduce it\r\n\r\n\tconst tolerance = GMath.EPSILON15;\r\n\r\n\tlet maxDiagonal = 0.0;\r\n\tlet rotAxis = 1;\r\n\r\n\t// find pivot (rotAxis) based on max diagonal of matrix\r\n\tfor (let i = 0; i < 3; ++i) {\r\n\t\tconst temp = Math.abs(matrix[Matrix3.getElementIndex(colVal[i], rowVal[i])]);\r\n\t\tif (temp > maxDiagonal) {\r\n\t\t\trotAxis = i;\r\n\t\t\tmaxDiagonal = temp;\r\n\t\t}\r\n\t}\r\n\r\n\tlet c = 1.0;\r\n\tlet s = 0.0;\r\n\r\n\tconst p = rowVal[rotAxis];\r\n\tconst q = colVal[rotAxis];\r\n\r\n\tif (Math.abs(matrix[Matrix3.getElementIndex(q, p)]) > tolerance) {\r\n\t\tconst qq = matrix[Matrix3.getElementIndex(q, q)];\r\n\t\tconst pp = matrix[Matrix3.getElementIndex(p, p)];\r\n\t\tconst qp = matrix[Matrix3.getElementIndex(q, p)];\r\n\r\n\t\tconst tau = (qq - pp) / 2.0 / qp;\r\n\t\tlet t;\r\n\r\n\t\tif (tau < 0.0) {\r\n\t\t\tt = -1.0 / (-tau + Math.sqrt(1.0 + tau * tau));\r\n\t\t} else {\r\n\t\t\tt = 1.0 / (tau + Math.sqrt(1.0 + tau * tau));\r\n\t\t}\r\n\r\n\t\tc = 1.0 / Math.sqrt(1.0 + t * t);\r\n\t\ts = t * c;\r\n\t}\r\n\r\n\tresult = Matrix3.clone(Matrix3.IDENTITY, result);\r\n\r\n\tresult[Matrix3.getElementIndex(p, p)] = result[Matrix3.getElementIndex(q, q)] = c;\r\n\tresult[Matrix3.getElementIndex(q, p)] = s;\r\n\tresult[Matrix3.getElementIndex(p, q)] = -s;\r\n\r\n\treturn result;\r\n}\r\nconst scratchTransposeMatrix = new Matrix3();\r\nexport default Matrix3;\r\n","import { Attribute } from \"../render/Attribute\";\r\nimport defined from \"../utils/defined\";\r\nimport GMath from \"./Math\";\r\n\r\nclass Vector4 {\r\n\tpublic static ZERO = Object.freeze(new Vector4(0.0, 0.0, 0.0, 0.0));\r\n\r\n\tpublic static ONE = Object.freeze(new Vector4(1.0, 1.0, 1.0, 1.0));\r\n\r\n\tpublic static UNIT_X = Object.freeze(new Vector4(1.0, 0.0, 0.0, 0.0));\r\n\r\n\tpublic static UNIT_Y = Object.freeze(new Vector4(0.0, 1.0, 0.0, 0.0));\r\n\r\n\tpublic static UNIT_Z = Object.freeze(new Vector4(0.0, 0.0, 1.0, 0.0));\r\n\r\n\tpublic static UNIT_W = Object.freeze(new Vector4(0.0, 0.0, 0.0, 1.0));\r\n\tx: number;\r\n\ty: number;\r\n\tz: number;\r\n\tw: number;\r\n\tconstructor(x = 0, y = 0, z = 0, w = 0) {\r\n\t\tthis.x = x;\r\n\t\tthis.y = y;\r\n\t\tthis.z = z;\r\n\t\tthis.w = w;\r\n\t}\r\n\tset(x: number, y: number, z: number, w: number): void {\r\n\t\tthis.x = x;\r\n\t\tthis.y = y;\r\n\t\tthis.z = z;\r\n\t\tthis.w = w;\r\n\t}\r\n\ttoArray(): number[] {\r\n\t\treturn [this.x, this.y, this.z, this.w];\r\n\t}\r\n\r\n\tclone(result: Vector4): Vector4 {\r\n\t\treturn Vector4.clone(this, result);\r\n\t}\r\n\r\n\tequals(right: Vector4): boolean {\r\n\t\treturn Vector4.equals(this, right);\r\n\t}\r\n\r\n\tequalsEpsilon(right: Vector4, relativeEpsilon = 0, absoluteEpsilon = 0): boolean {\r\n\t\treturn Vector4.equalsEpsilon(this, right, relativeEpsilon, absoluteEpsilon);\r\n\t}\r\n\r\n\ttoString(): string {\r\n\t\treturn `(${this.x}, ${this.y}, ${this.z}, ${this.w})`;\r\n\t}\r\n\tfromBufferAttribute(attribute: Attribute, index: number): Vector4 {\r\n\t\tthis.x = attribute.getX(index);\r\n\t\tthis.y = attribute.getY(index);\r\n\t\tthis.z = attribute.getZ(index);\r\n\t\tthis.w = attribute.getW(index);\r\n\r\n\t\treturn this;\r\n\t}\r\n\r\n\tstatic fromElements(x: number, y: number, z: number, w: number, result: Vector4): Vector4 {\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Vector4(x, y, z, w);\r\n\t\t}\r\n\r\n\t\tresult.x = x;\r\n\t\tresult.y = y;\r\n\t\tresult.z = z;\r\n\t\tresult.w = w;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic clone(cartesian: Vector4, result: Vector4): Vector4 {\r\n\t\tif (!defined(cartesian)) {\r\n\t\t\treturn undefined;\r\n\t\t}\r\n\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Vector4(cartesian.x, cartesian.y, cartesian.z, cartesian.w);\r\n\t\t}\r\n\r\n\t\tresult.x = cartesian.x;\r\n\t\tresult.y = cartesian.y;\r\n\t\tresult.z = cartesian.z;\r\n\t\tresult.w = cartesian.w;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic maximumComponent(cartesian: Vector4): number {\r\n\t\treturn Math.max(cartesian.x, cartesian.y, cartesian.z, cartesian.w);\r\n\t}\r\n\r\n\tstatic minimumComponent(cartesian: Vector4): number {\r\n\t\treturn Math.min(cartesian.x, cartesian.y, cartesian.z, cartesian.w);\r\n\t}\r\n\r\n\tstatic minimumByComponent(first: Vector4, second: Vector4, result: Vector4): Vector4 {\r\n\t\tresult.x = Math.min(first.x, second.x);\r\n\t\tresult.y = Math.min(first.y, second.y);\r\n\t\tresult.z = Math.min(first.z, second.z);\r\n\t\tresult.w = Math.min(first.w, second.w);\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic maximumByComponent(first: Vector4, second: Vector4, result: Vector4): Vector4 {\r\n\t\tresult.x = Math.max(first.x, second.x);\r\n\t\tresult.y = Math.max(first.y, second.y);\r\n\t\tresult.z = Math.max(first.z, second.z);\r\n\t\tresult.w = Math.max(first.w, second.w);\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic clamp(value: Vector4, min: Vector4, max: Vector4, result: Vector4): Vector4 {\r\n\t\tconst x = GMath.clamp(value.x, min.x, max.x);\r\n\t\tconst y = GMath.clamp(value.y, min.y, max.y);\r\n\t\tconst z = GMath.clamp(value.z, min.z, max.z);\r\n\t\tconst w = GMath.clamp(value.w, min.w, max.w);\r\n\r\n\t\tresult.x = x;\r\n\t\tresult.y = y;\r\n\t\tresult.z = z;\r\n\t\tresult.w = w;\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic magnitudeSquared(cartesian: Vector4): number {\r\n\t\treturn (\r\n\t\t\tcartesian.x * cartesian.x +\r\n\t\t\tcartesian.y * cartesian.y +\r\n\t\t\tcartesian.z * cartesian.z +\r\n\t\t\tcartesian.w * cartesian.w\r\n\t\t);\r\n\t}\r\n\r\n\tstatic magnitude(cartesian: Vector4): number {\r\n\t\treturn Math.sqrt(Vector4.magnitudeSquared(cartesian));\r\n\t}\r\n\r\n\tstatic distance(left: Vector4, right: Vector4): number {\r\n\t\tVector4.subtract(left, right, distanceScratch);\r\n\t\treturn Vector4.magnitude(distanceScratch);\r\n\t}\r\n\r\n\tstatic distanceSquared(left: Vector4, right: Vector4): number {\r\n\t\tVector4.subtract(left, right, distanceScratch);\r\n\t\treturn Vector4.magnitudeSquared(distanceScratch);\r\n\t}\r\n\r\n\tstatic normalize(cartesian: Vector4, result: Vector4): Vector4 {\r\n\t\tconst magnitude = Vector4.magnitude(cartesian);\r\n\r\n\t\tresult.x = cartesian.x / magnitude;\r\n\t\tresult.y = cartesian.y / magnitude;\r\n\t\tresult.z = cartesian.z / magnitude;\r\n\t\tresult.w = cartesian.w / magnitude;\r\n\r\n\t\t// >>includeStart('debug', pragmas.debug);\r\n\t\tif (isNaN(result.x) || isNaN(result.y) || isNaN(result.z) || isNaN(result.w)) {\r\n\t\t\tthrow new Error(\"normalized result is not a number\");\r\n\t\t}\r\n\t\t// >>includeEnd('debug');\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic dot(left: Vector4, right: Vector4): number {\r\n\t\treturn left.x * right.x + left.y * right.y + left.z * right.z + left.w * right.w;\r\n\t}\r\n\r\n\tstatic multiplyComponents(left: Vector4, right: Vector4, result: Vector4): Vector4 {\r\n\t\tresult.x = left.x * right.x;\r\n\t\tresult.y = left.y * right.y;\r\n\t\tresult.z = left.z * right.z;\r\n\t\tresult.w = left.w * right.w;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic divideComponents(left: Vector4, right: Vector4, result: Vector4): Vector4 {\r\n\t\tresult.x = left.x / right.x;\r\n\t\tresult.y = left.y / right.y;\r\n\t\tresult.z = left.z / right.z;\r\n\t\tresult.w = left.w / right.w;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic add(left: Vector4, right: Vector4, result: Vector4): Vector4 {\r\n\t\tresult.x = left.x + right.x;\r\n\t\tresult.y = left.y + right.y;\r\n\t\tresult.z = left.z + right.z;\r\n\t\tresult.w = left.w + right.w;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic subtract(left: Vector4, right: Vector4, result: Vector4): Vector4 {\r\n\t\tresult.x = left.x - right.x;\r\n\t\tresult.y = left.y - right.y;\r\n\t\tresult.z = left.z - right.z;\r\n\t\tresult.w = left.w - right.w;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic multiplyByScalar(cartesian: Vector4, scalar: number, result: Vector4): Vector4 {\r\n\t\tresult.x = cartesian.x * scalar;\r\n\t\tresult.y = cartesian.y * scalar;\r\n\t\tresult.z = cartesian.z * scalar;\r\n\t\tresult.w = cartesian.w * scalar;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic divideByScalar(cartesian: Vector4, scalar: number, result: Vector4): Vector4 {\r\n\t\tresult.x = cartesian.x / scalar;\r\n\t\tresult.y = cartesian.y / scalar;\r\n\t\tresult.z = cartesian.z / scalar;\r\n\t\tresult.w = cartesian.w / scalar;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic negate(cartesian: Vector4, result: Vector4): Vector4 {\r\n\t\tresult.x = -cartesian.x;\r\n\t\tresult.y = -cartesian.y;\r\n\t\tresult.z = -cartesian.z;\r\n\t\tresult.w = -cartesian.w;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic abs(cartesian: Vector4, result: Vector4): Vector4 {\r\n\t\tresult.x = Math.abs(cartesian.x);\r\n\t\tresult.y = Math.abs(cartesian.y);\r\n\t\tresult.z = Math.abs(cartesian.z);\r\n\t\tresult.w = Math.abs(cartesian.w);\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic lerp(start: Vector4, end: Vector4, t: number, result: Vector4): Vector4 {\r\n\t\tVector4.multiplyByScalar(end, t, lerpScratch);\r\n\t\tresult = Vector4.multiplyByScalar(start, 1.0 - t, result);\r\n\t\treturn Vector4.add(lerpScratch, result, result);\r\n\t}\r\n\r\n\tstatic equals(left: Vector4, right: Vector4): boolean {\r\n\t\treturn (\r\n\t\t\tleft === right ||\r\n\t\t\t(defined(left) &&\r\n\t\t\t\tdefined(right) &&\r\n\t\t\t\tleft.x === right.x &&\r\n\t\t\t\tleft.y === right.y &&\r\n\t\t\t\tleft.z === right.z &&\r\n\t\t\t\tleft.w === right.w)\r\n\t\t);\r\n\t}\r\n\r\n\tstatic equalsArray(cartesian: Vector4, array: number[], offset: number): boolean {\r\n\t\treturn (\r\n\t\t\tcartesian.x === array[offset] &&\r\n\t\t\tcartesian.y === array[offset + 1] &&\r\n\t\t\tcartesian.z === array[offset + 2] &&\r\n\t\t\tcartesian.w === array[offset + 3]\r\n\t\t);\r\n\t}\r\n\r\n\tstatic equalsEpsilon(left: Vector4, right: Vector4, relativeEpsilon = 0, absoluteEpsilon = 0): boolean {\r\n\t\treturn (\r\n\t\t\tleft === right ||\r\n\t\t\t(defined(left) &&\r\n\t\t\t\tdefined(right) &&\r\n\t\t\t\tGMath.equalsEpsilon(left.x, right.x, relativeEpsilon, absoluteEpsilon) &&\r\n\t\t\t\tGMath.equalsEpsilon(left.y, right.y, relativeEpsilon, absoluteEpsilon) &&\r\n\t\t\t\tGMath.equalsEpsilon(left.z, right.z, relativeEpsilon, absoluteEpsilon) &&\r\n\t\t\t\tGMath.equalsEpsilon(left.w, right.w, relativeEpsilon, absoluteEpsilon))\r\n\t\t);\r\n\t}\r\n}\r\n\r\n// scratchU8Array and scratchF32Array are views into the same buffer\r\nconst scratchF32Array = new Float32Array(1);\r\nconst scratchU8Array = new Uint8Array(scratchF32Array.buffer);\r\n\r\nconst testU32 = new Uint32Array([0x11223344]);\r\nconst testU8 = new Uint8Array(testU32.buffer);\r\nconst littleEndian = testU8[0] === 0x44;\r\nconst distanceScratch = new Vector4();\r\nconst lerpScratch = new Vector4();\r\nconst mostOrthogonalAxisScratch = new Vector4();\r\n\r\nexport default Vector4;\r\n","import defaultValue from \"../utils/defaultValue\";\nimport defined from \"../utils/defined\";\nimport GMath from \"./Math\";\nimport Matrix3 from \"./Matrix3\";\nimport { Quaternion } from \"./Quaternion\";\nimport Vector3 from \"./Vector3\";\nimport Vector4 from \"./Vector4\";\nclass Matrix4 {\n\tpublic static IDENTITY = Object.freeze(\n\t\tnew Matrix4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0)\n\t);\n\tpublic static ZERO = Object.freeze(\n\t\tnew Matrix4(0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0)\n\t);\n\t/**\n\t * A 4x4 matrix, indexable as a column-major order array.\n\t * @param {Number} [column0Row0=0.0] The value for column 0, row 0.\n\t * @param {Number} [column1Row0=0.0] The value for column 1, row 0.\n\t * @param {Number} [column2Row0=0.0] The value for column 2, row 0.\n\t * @param {Number} [column3Row0=0.0] The value for column 3, row 0.\n\t * @param {Number} [column0Row1=0.0] The value for column 0, row 1.\n\t * @param {Number} [column1Row1=0.0] The value for column 1, row 1.\n\t * @param {Number} [column2Row1=0.0] The value for column 2, row 1.\n\t * @param {Number} [column3Row1=0.0] The value for column 3, row 1.\n\t * @param {Number} [column0Row2=0.0] The value for column 0, row 2.\n\t * @param {Number} [column1Row2=0.0] The value for column 1, row 2.\n\t * @param {Number} [column2Row2=0.0] The value for column 2, row 2.\n\t * @param {Number} [column3Row2=0.0] The value for column 3, row 2.\n\t * @param {Number} [column0Row3=0.0] The value for column 0, row 3.\n\t * @param {Number} [column1Row3=0.0] The value for column 1, row 3.\n\t * @param {Number} [column2Row3=0.0] The value for column 2, row 3.\n\t * @param {Number} [column3Row3=0.0] The value for column 3, row 3.\n\t */\n\tconstructor(\n\t\tcolumn0Row0 = 0,\n\t\tcolumn1Row0 = 0,\n\t\tcolumn2Row0 = 0,\n\t\tcolumn3Row0 = 0,\n\t\tcolumn0Row1 = 0,\n\t\tcolumn1Row1 = 0,\n\t\tcolumn2Row1 = 0,\n\t\tcolumn3Row1 = 0,\n\t\tcolumn0Row2 = 0,\n\t\tcolumn1Row2 = 0,\n\t\tcolumn2Row2 = 0,\n\t\tcolumn3Row2 = 0,\n\t\tcolumn0Row3 = 0,\n\t\tcolumn1Row3 = 0,\n\t\tcolumn2Row3 = 0,\n\t\tcolumn3Row3 = 0\n\t) {\n\t\tthis[0] = column0Row0;\n\t\tthis[1] = column0Row1;\n\t\tthis[2] = column0Row2;\n\t\tthis[3] = column0Row3;\n\t\tthis[4] = column1Row0;\n\t\tthis[5] = column1Row1;\n\t\tthis[6] = column1Row2;\n\t\tthis[7] = column1Row3;\n\t\tthis[8] = column2Row0;\n\t\tthis[9] = column2Row1;\n\t\tthis[10] = column2Row2;\n\t\tthis[11] = column2Row3;\n\t\tthis[12] = column3Row0;\n\t\tthis[13] = column3Row1;\n\t\tthis[14] = column3Row2;\n\t\tthis[15] = column3Row3;\n\t}\n\t// ????\n\tclone(result: Matrix4 = new Matrix4()): Matrix4 {\n\t\treturn Matrix4.clone(this, result);\n\t}\n\tset(mat4: Matrix4) {\n\t\tMatrix4.clone(mat4, this);\n\t\treturn this;\n\t}\n\tequals(right: Matrix4): boolean {\n\t\treturn Matrix4.equals(this, right);\n\t}\n\tcompose(position: Vector3, quaternion: Quaternion, scale: Vector3): Matrix4 {\n\t\tconst te = this;\n\n\t\tconst x = quaternion.x,\n\t\t\ty = quaternion.y,\n\t\t\tz = quaternion.z,\n\t\t\tw = quaternion.w;\n\t\tconst x2 = x + x,\n\t\t\ty2 = y + y,\n\t\t\tz2 = z + z;\n\t\tconst xx = x * x2,\n\t\t\txy = x * y2,\n\t\t\txz = x * z2;\n\t\tconst yy = y * y2,\n\t\t\tyz = y * z2,\n\t\t\tzz = z * z2;\n\t\tconst wx = w * x2,\n\t\t\twy = w * y2,\n\t\t\twz = w * z2;\n\n\t\tconst sx = scale.x,\n\t\t\tsy = scale.y,\n\t\t\tsz = scale.z;\n\n\t\tte[0] = (1 - (yy + zz)) * sx;\n\t\tte[1] = (xy + wz) * sx;\n\t\tte[2] = (xz - wy) * sx;\n\t\tte[3] = 0;\n\n\t\tte[4] = (xy - wz) * sy;\n\t\tte[5] = (1 - (xx + zz)) * sy;\n\t\tte[6] = (yz + wx) * sy;\n\t\tte[7] = 0;\n\n\t\tte[8] = (xz + wy) * sz;\n\t\tte[9] = (yz - wx) * sz;\n\t\tte[10] = (1 - (xx + yy)) * sz;\n\t\tte[11] = 0;\n\n\t\tte[12] = position.x;\n\t\tte[13] = position.y;\n\t\tte[14] = position.z;\n\t\tte[15] = 1;\n\n\t\treturn this;\n\t}\n\tequalsEpsilon(right: Matrix4, epsilon = 0): boolean {\n\t\treturn Matrix4.equalsEpsilon(this, right, epsilon);\n\t}\n\tlookAt(eye: Vector3, target: Vector3, up: Vector3): Matrix4 {\n\t\tconst matrix = this;\n\t\tVector3.subtract(eye, target, z);\n\t\tif (z.length() === 0) {\n\t\t\t// eye and target are in the same position\n\t\t\tz.z = 1;\n\t\t}\n\t\tz.normalize();\n\t\tVector3.cross(up, z, x);\n\t\tif (x.length() === 0) {\n\t\t\t// up and z are parallel\n\n\t\t\tif (Math.abs(up.z) === 1) {\n\t\t\t\tz.x += 0.0001;\n\t\t\t} else {\n\t\t\t\tz.z += 0.0001;\n\t\t\t}\n\t\t\tz.normalize();\n\t\t\tVector3.cross(up, z, x);\n\t\t}\n\t\tx.normalize();\n\t\tVector3.cross(z, x, y);\n\t\tmatrix[0] = x.x;\n\t\tmatrix[4] = y.x;\n\t\tmatrix[8] = z.x;\n\t\tmatrix[1] = x.y;\n\t\tmatrix[5] = y.y;\n\t\tmatrix[9] = z.y;\n\t\tmatrix[2] = x.z;\n\t\tmatrix[6] = y.z;\n\t\tmatrix[10] = z.z;\n\n\t\treturn this;\n\t}\n\ttoString() {\n\t\treturn (\n\t\t\t`(${this[0]}, ${this[4]}, ${this[8]}, ${this[12]})\\n` +\n\t\t\t`(${this[1]}, ${this[5]}, ${this[9]}, ${this[13]})\\n` +\n\t\t\t`(${this[2]}, ${this[6]}, ${this[10]}, ${this[14]})\\n` +\n\t\t\t`(${this[3]}, ${this[7]}, ${this[11]}, ${this[15]})`\n\t\t);\n\t}\n\tstatic clone(matrix: Matrix4 | number[], result: Matrix4): Matrix4 {\n\t\tif (!defined(matrix)) {\n\t\t\treturn undefined;\n\t\t}\n\t\tif (!defined(result)) {\n\t\t\treturn new Matrix4(\n\t\t\t\tmatrix[0],\n\t\t\t\tmatrix[4],\n\t\t\t\tmatrix[8],\n\t\t\t\tmatrix[12],\n\t\t\t\tmatrix[1],\n\t\t\t\tmatrix[5],\n\t\t\t\tmatrix[9],\n\t\t\t\tmatrix[13],\n\t\t\t\tmatrix[2],\n\t\t\t\tmatrix[6],\n\t\t\t\tmatrix[10],\n\t\t\t\tmatrix[14],\n\t\t\t\tmatrix[3],\n\t\t\t\tmatrix[7],\n\t\t\t\tmatrix[11],\n\t\t\t\tmatrix[15]\n\t\t\t);\n\t\t}\n\t\tresult[0] = matrix[0];\n\t\tresult[1] = matrix[1];\n\t\tresult[2] = matrix[2];\n\t\tresult[3] = matrix[3];\n\t\tresult[4] = matrix[4];\n\t\tresult[5] = matrix[5];\n\t\tresult[6] = matrix[6];\n\t\tresult[7] = matrix[7];\n\t\tresult[8] = matrix[8];\n\t\tresult[9] = matrix[9];\n\t\tresult[10] = matrix[10];\n\t\tresult[11] = matrix[11];\n\t\tresult[12] = matrix[12];\n\t\tresult[13] = matrix[13];\n\t\tresult[14] = matrix[14];\n\t\tresult[15] = matrix[15];\n\t\treturn result;\n\t}\n\n\tstatic fromColumnMajorArray(values: number[], result: Matrix4): Matrix4 {\n\t\treturn Matrix4.clone(values, result);\n\t}\n\n\tstatic fromRowMajorArray(values: number[], result: Matrix4): Matrix4 {\n\t\tif (!defined(result)) {\n\t\t\treturn new Matrix4(\n\t\t\t\tvalues[0],\n\t\t\t\tvalues[1],\n\t\t\t\tvalues[2],\n\t\t\t\tvalues[3],\n\t\t\t\tvalues[4],\n\t\t\t\tvalues[5],\n\t\t\t\tvalues[6],\n\t\t\t\tvalues[7],\n\t\t\t\tvalues[8],\n\t\t\t\tvalues[9],\n\t\t\t\tvalues[10],\n\t\t\t\tvalues[11],\n\t\t\t\tvalues[12],\n\t\t\t\tvalues[13],\n\t\t\t\tvalues[14],\n\t\t\t\tvalues[15]\n\t\t\t);\n\t\t}\n\t\tresult[0] = values[0];\n\t\tresult[1] = values[4];\n\t\tresult[2] = values[8];\n\t\tresult[3] = values[12];\n\t\tresult[4] = values[1];\n\t\tresult[5] = values[5];\n\t\tresult[6] = values[9];\n\t\tresult[7] = values[13];\n\t\tresult[8] = values[2];\n\t\tresult[9] = values[6];\n\t\tresult[10] = values[10];\n\t\tresult[11] = values[14];\n\t\tresult[12] = values[3];\n\t\tresult[13] = values[7];\n\t\tresult[14] = values[11];\n\t\tresult[15] = values[15];\n\t\treturn result;\n\t}\n\n\tstatic fromRotationTranslation(rotation: Matrix3, translation: Vector3, result: Matrix4): Matrix4 {\n\t\ttranslation = defaultValue(translation, Vector3.ZERO);\n\n\t\tif (!defined(result)) {\n\t\t\treturn new Matrix4(\n\t\t\t\trotation[0],\n\t\t\t\trotation[3],\n\t\t\t\trotation[6],\n\t\t\t\ttranslation.x,\n\t\t\t\trotation[1],\n\t\t\t\trotation[4],\n\t\t\t\trotation[7],\n\t\t\t\ttranslation.y,\n\t\t\t\trotation[2],\n\t\t\t\trotation[5],\n\t\t\t\trotation[8],\n\t\t\t\ttranslation.z,\n\t\t\t\t0.0,\n\t\t\t\t0.0,\n\t\t\t\t0.0,\n\t\t\t\t1.0\n\t\t\t);\n\t\t}\n\n\t\tresult[0] = rotation[0];\n\t\tresult[1] = rotation[1];\n\t\tresult[2] = rotation[2];\n\t\tresult[3] = 0.0;\n\t\tresult[4] = rotation[3];\n\t\tresult[5] = rotation[4];\n\t\tresult[6] = rotation[5];\n\t\tresult[7] = 0.0;\n\t\tresult[8] = rotation[6];\n\t\tresult[9] = rotation[7];\n\t\tresult[10] = rotation[8];\n\t\tresult[11] = 0.0;\n\t\tresult[12] = translation.x;\n\t\tresult[13] = translation.y;\n\t\tresult[14] = translation.z;\n\t\tresult[15] = 1.0;\n\t\treturn result;\n\t}\n\n\tstatic fromTranslationQuaternionRotationScale(\n\t\ttranslation: Vector3,\n\t\trotation: Quaternion,\n\t\tscale: Vector3,\n\t\tresult: Matrix4\n\t): Matrix4 {\n\t\tif (!defined(result)) {\n\t\t\tresult = new Matrix4();\n\t\t}\n\n\t\tconst scaleX = scale.x;\n\t\tconst scaleY = scale.y;\n\t\tconst scaleZ = scale.z;\n\n\t\tconst x2 = rotation.x * rotation.x;\n\t\tconst xy = rotation.x * rotation.y;\n\t\tconst xz = rotation.x * rotation.z;\n\t\tconst xw = rotation.x * rotation.w;\n\t\tconst y2 = rotation.y * rotation.y;\n\t\tconst yz = rotation.y * rotation.z;\n\t\tconst yw = rotation.y * rotation.w;\n\t\tconst z2 = rotation.z * rotation.z;\n\t\tconst zw = rotation.z * rotation.w;\n\t\tconst w2 = rotation.w * rotation.w;\n\n\t\tconst m00 = x2 - y2 - z2 + w2;\n\t\tconst m01 = 2.0 * (xy - zw);\n\t\tconst m02 = 2.0 * (xz + yw);\n\n\t\tconst m10 = 2.0 * (xy + zw);\n\t\tconst m11 = -x2 + y2 - z2 + w2;\n\t\tconst m12 = 2.0 * (yz - xw);\n\n\t\tconst m20 = 2.0 * (xz - yw);\n\t\tconst m21 = 2.0 * (yz + xw);\n\t\tconst m22 = -x2 - y2 + z2 + w2;\n\n\t\tresult[0] = m00 * scaleX;\n\t\tresult[1] = m10 * scaleX;\n\t\tresult[2] = m20 * scaleX;\n\t\tresult[3] = 0.0;\n\t\tresult[4] = m01 * scaleY;\n\t\tresult[5] = m11 * scaleY;\n\t\tresult[6] = m21 * scaleY;\n\t\tresult[7] = 0.0;\n\t\tresult[8] = m02 * scaleZ;\n\t\tresult[9] = m12 * scaleZ;\n\t\tresult[10] = m22 * scaleZ;\n\t\tresult[11] = 0.0;\n\t\tresult[12] = translation.x;\n\t\tresult[13] = translation.y;\n\t\tresult[14] = translation.z;\n\t\tresult[15] = 1.0;\n\n\t\treturn result;\n\t}\n\n\tstatic fromTranslationRotationScale(\n\t\ttranslationRotationScale: {\n\t\t\ttranslation: Vector3;\n\t\t\trotation: Quaternion;\n\t\t\tscale: Vector3;\n\t\t},\n\t\tresult: Matrix4\n\t): Matrix4 {\n\t\treturn Matrix4.fromTranslationQuaternionRotationScale(\n\t\t\ttranslationRotationScale.translation,\n\t\t\ttranslationRotationScale.rotation,\n\t\t\ttranslationRotationScale.scale,\n\t\t\tresult\n\t\t);\n\t}\n\n\tstatic fromTranslation(translation: Vector3, result: Matrix4): Matrix4 {\n\t\treturn Matrix4.fromRotationTranslation(Matrix3.IDENTITY, translation, result);\n\t}\n\n\tstatic fromScale(scale: Vector3, result: Matrix4): Matrix4 {\n\t\tif (!defined(result)) {\n\t\t\treturn new Matrix4(\n\t\t\t\tscale.x,\n\t\t\t\t0.0,\n\t\t\t\t0.0,\n\t\t\t\t0.0,\n\t\t\t\t0.0,\n\t\t\t\tscale.y,\n\t\t\t\t0.0,\n\t\t\t\t0.0,\n\t\t\t\t0.0,\n\t\t\t\t0.0,\n\t\t\t\tscale.z,\n\t\t\t\t0.0,\n\t\t\t\t0.0,\n\t\t\t\t0.0,\n\t\t\t\t0.0,\n\t\t\t\t1.0\n\t\t\t);\n\t\t}\n\n\t\tresult[0] = scale.x;\n\t\tresult[1] = 0.0;\n\t\tresult[2] = 0.0;\n\t\tresult[3] = 0.0;\n\t\tresult[4] = 0.0;\n\t\tresult[5] = scale.y;\n\t\tresult[6] = 0.0;\n\t\tresult[7] = 0.0;\n\t\tresult[8] = 0.0;\n\t\tresult[9] = 0.0;\n\t\tresult[10] = scale.z;\n\t\tresult[11] = 0.0;\n\t\tresult[12] = 0.0;\n\t\tresult[13] = 0.0;\n\t\tresult[14] = 0.0;\n\t\tresult[15] = 1.0;\n\t\treturn result;\n\t}\n\n\tstatic fromRotation(rotation: Matrix3, result: Matrix4): Matrix4 {\n\t\tif (!defined(result)) {\n\t\t\tresult = new Matrix4();\n\t\t}\n\t\tresult[0] = rotation[0];\n\t\tresult[1] = rotation[1];\n\t\tresult[2] = rotation[2];\n\t\tresult[3] = 0.0;\n\n\t\tresult[4] = rotation[3];\n\t\tresult[5] = rotation[4];\n\t\tresult[6] = rotation[5];\n\t\tresult[7] = 0.0;\n\n\t\tresult[8] = rotation[6];\n\t\tresult[9] = rotation[7];\n\t\tresult[10] = rotation[8];\n\t\tresult[11] = 0.0;\n\n\t\tresult[12] = 0.0;\n\t\tresult[13] = 0.0;\n\t\tresult[14] = 0.0;\n\t\tresult[15] = 1.0;\n\n\t\treturn result;\n\t}\n\n\tstatic makePerspective(\n\t\tleft: number,\n\t\tright: number,\n\t\ttop: number,\n\t\tbottom: number,\n\t\tnear: number,\n\t\tfar: number\n\t): Matrix4 {\n\t\t// from three.js\n\t\tconst matrix = new Matrix4();\n\t\tconst x = (2 * near) / (right - left);\n\t\tconst y = (2 * near) / (top - bottom);\n\n\t\tconst a = (right + left) / (right - left);\n\t\tconst b = (top + bottom) / (top - bottom);\n\t\tconst c = -far / (far - near);\n\t\tconst d = (-far * near) / (far - near);\n\n\t\tmatrix[0] = x;\n\t\tmatrix[4] = 0;\n\t\tmatrix[8] = a;\n\t\tmatrix[12] = 0;\n\t\tmatrix[1] = 0;\n\t\tmatrix[5] = y;\n\t\tmatrix[9] = b;\n\t\tmatrix[13] = 0;\n\t\tmatrix[2] = 0;\n\t\tmatrix[6] = 0;\n\t\tmatrix[10] = c;\n\t\tmatrix[14] = d;\n\t\tmatrix[3] = 0;\n\t\tmatrix[7] = 0;\n\t\tmatrix[11] = -1;\n\t\tmatrix[15] = 0;\n\t\treturn matrix;\n\t}\n\tstatic makeOrthographic(\n\t\tleft: number,\n\t\tright: number,\n\t\ttop: number,\n\t\tbottom: number,\n\t\tnear: number,\n\t\tfar: number\n\t): Matrix4 {\n\t\tconst matrix = new Matrix4();\n\t\tconst w = 1.0 / (right - left);\n\t\tconst h = 1.0 / (top - bottom);\n\t\tconst p = 1.0 / (far - near);\n\n\t\tconst x = (right + left) * w;\n\t\tconst y = (top + bottom) * h;\n\t\tconst z = near * p;\n\n\t\tmatrix[0] = 2 * w;\n\t\tmatrix[4] = 0;\n\t\tmatrix[8] = 0;\n\t\tmatrix[12] = -x;\n\t\tmatrix[1] = 0;\n\t\tmatrix[5] = 2 * h;\n\t\tmatrix[9] = 0;\n\t\tmatrix[13] = -y;\n\t\tmatrix[2] = 0;\n\t\tmatrix[6] = 0;\n\t\tmatrix[10] = -1 * p;\n\t\tmatrix[14] = -z;\n\t\tmatrix[3] = 0;\n\t\tmatrix[7] = 0;\n\t\tmatrix[11] = 0;\n\t\tmatrix[15] = 1;\n\t\treturn matrix;\n\t}\n\ttoArray() {\n\t\tconst result = [];\n\t\tMatrix4.toArray(this, result);\n\t\treturn result;\n\t}\n\t/**\n\t * Computes an Array from the provided Matrix4 instance.\n\t * The array will be in column-major order.\n\t * @example\n\t * //create an array from an instance of Matrix4\n\t * // m = [10.0, 14.0, 18.0, 22.0]\n\t * //     [11.0, 15.0, 19.0, 23.0]\n\t * //     [12.0, 16.0, 20.0, 24.0]\n\t * //     [13.0, 17.0, 21.0, 25.0]\n\t * const a = Matrix4.toArray(m);\n\t *\n\t * // m remains the same\n\t * //creates a = [10.0, 11.0, 12.0, 13.0, 14.0, 15.0, 16.0, 17.0, 18.0, 19.0, 20.0, 21.0, 22.0, 23.0, 24.0, 25.0]\n\t */\n\tstatic toArray(matrix: Array<number> | Matrix4, result: Array<number>): Array<number> {\n\t\tif (!defined(result)) {\n\t\t\treturn [\n\t\t\t\tmatrix[0],\n\t\t\t\tmatrix[1],\n\t\t\t\tmatrix[2],\n\t\t\t\tmatrix[3],\n\t\t\t\tmatrix[4],\n\t\t\t\tmatrix[5],\n\t\t\t\tmatrix[6],\n\t\t\t\tmatrix[7],\n\t\t\t\tmatrix[8],\n\t\t\t\tmatrix[9],\n\t\t\t\tmatrix[10],\n\t\t\t\tmatrix[11],\n\t\t\t\tmatrix[12],\n\t\t\t\tmatrix[13],\n\t\t\t\tmatrix[14],\n\t\t\t\tmatrix[15]\n\t\t\t];\n\t\t}\n\t\tresult[0] = matrix[0];\n\t\tresult[1] = matrix[1];\n\t\tresult[2] = matrix[2];\n\t\tresult[3] = matrix[3];\n\t\tresult[4] = matrix[4];\n\t\tresult[5] = matrix[5];\n\t\tresult[6] = matrix[6];\n\t\tresult[7] = matrix[7];\n\t\tresult[8] = matrix[8];\n\t\tresult[9] = matrix[9];\n\t\tresult[10] = matrix[10];\n\t\tresult[11] = matrix[11];\n\t\tresult[12] = matrix[12];\n\t\tresult[13] = matrix[13];\n\t\tresult[14] = matrix[14];\n\t\tresult[15] = matrix[15];\n\t\treturn result;\n\t}\n\n\tstatic getElementIndex(column: number, row: number): number {\n\t\treturn column * 4 + row;\n\t}\n\n\tstatic getColumn(matrix: Matrix4, index: number, result: Vector4): Vector4 {\n\t\tconst startIndex = index * 4;\n\t\tconst x = matrix[startIndex];\n\t\tconst y = matrix[startIndex + 1];\n\t\tconst z = matrix[startIndex + 2];\n\t\tconst w = matrix[startIndex + 3];\n\n\t\tresult.x = x;\n\t\tresult.y = y;\n\t\tresult.z = z;\n\t\tresult.w = w;\n\t\treturn result;\n\t}\n\n\tstatic setColumn(matrix: Matrix4, index: number, cartesian: Vector4, result: Matrix4): Matrix4 {\n\t\tresult = Matrix4.clone(matrix, result);\n\t\tconst startIndex = index * 4;\n\t\tresult[startIndex] = cartesian.x;\n\t\tresult[startIndex + 1] = cartesian.y;\n\t\tresult[startIndex + 2] = cartesian.z;\n\t\tresult[startIndex + 3] = cartesian.w;\n\t\treturn result;\n\t}\n\n\tstatic getRow(matrix: Matrix4, index: number, result: Vector4): Vector4 {\n\t\tconst x = matrix[index];\n\t\tconst y = matrix[index + 4];\n\t\tconst z = matrix[index + 8];\n\t\tconst w = matrix[index + 12];\n\n\t\tresult.x = x;\n\t\tresult.y = y;\n\t\tresult.z = z;\n\t\tresult.w = w;\n\t\treturn result;\n\t}\n\n\tstatic setRow(matrix: Matrix4, index: number, cartesian: Vector4, result: Matrix4): Matrix4 {\n\t\tresult = Matrix4.clone(matrix, result);\n\t\tresult[index] = cartesian.x;\n\t\tresult[index + 4] = cartesian.y;\n\t\tresult[index + 8] = cartesian.z;\n\t\tresult[index + 12] = cartesian.w;\n\t\treturn result;\n\t}\n\n\tstatic setTranslation(matrix: Matrix4, translation: Vector3, result: Matrix4): Matrix4 {\n\t\tresult[0] = matrix[0];\n\t\tresult[1] = matrix[1];\n\t\tresult[2] = matrix[2];\n\t\tresult[3] = matrix[3];\n\n\t\tresult[4] = matrix[4];\n\t\tresult[5] = matrix[5];\n\t\tresult[6] = matrix[6];\n\t\tresult[7] = matrix[7];\n\n\t\tresult[8] = matrix[8];\n\t\tresult[9] = matrix[9];\n\t\tresult[10] = matrix[10];\n\t\tresult[11] = matrix[11];\n\n\t\tresult[12] = translation.x;\n\t\tresult[13] = translation.y;\n\t\tresult[14] = translation.z;\n\t\tresult[15] = matrix[15];\n\n\t\treturn result;\n\t}\n\n\tstatic setScale(matrix: Matrix4, scale: Vector3, result: Matrix4): Matrix4 {\n\t\tconst existingScale = Matrix4.getScale(matrix, scaleScratch1);\n\t\tconst scaleRatioX = scale.x / existingScale.x;\n\t\tconst scaleRatioY = scale.y / existingScale.y;\n\t\tconst scaleRatioZ = scale.z / existingScale.z;\n\n\t\tresult[0] = matrix[0] * scaleRatioX;\n\t\tresult[1] = matrix[1] * scaleRatioX;\n\t\tresult[2] = matrix[2] * scaleRatioX;\n\t\tresult[3] = matrix[3];\n\n\t\tresult[4] = matrix[4] * scaleRatioY;\n\t\tresult[5] = matrix[5] * scaleRatioY;\n\t\tresult[6] = matrix[6] * scaleRatioY;\n\t\tresult[7] = matrix[7];\n\n\t\tresult[8] = matrix[8] * scaleRatioZ;\n\t\tresult[9] = matrix[9] * scaleRatioZ;\n\t\tresult[10] = matrix[10] * scaleRatioZ;\n\t\tresult[11] = matrix[11];\n\n\t\tresult[12] = matrix[12];\n\t\tresult[13] = matrix[13];\n\t\tresult[14] = matrix[14];\n\t\tresult[15] = matrix[15];\n\n\t\treturn result;\n\t}\n\n\tstatic getScale(matrix: Matrix4, result: Vector3): Vector3 {\n\t\tresult.x = Vector3.magnitude(Vector3.fromElements(matrix[0], matrix[1], matrix[2], scratchColumn));\n\t\tresult.y = Vector3.magnitude(Vector3.fromElements(matrix[4], matrix[5], matrix[6], scratchColumn));\n\t\tresult.z = Vector3.magnitude(Vector3.fromElements(matrix[8], matrix[9], matrix[10], scratchColumn));\n\t\treturn result;\n\t}\n\n\tstatic getMaximumScale(matrix: Matrix4): number {\n\t\tMatrix4.getScale(matrix, scaleScratch3);\n\t\treturn Vector3.maximumComponent(scaleScratch3);\n\t}\n\n\tstatic setRotation(matrix: Matrix4, rotation: Matrix3, result: Matrix4): Matrix4 {\n\t\tconst scale = Matrix4.getScale(matrix, scaleScratch4);\n\n\t\tresult[0] = rotation[0] * scale.x;\n\t\tresult[1] = rotation[1] * scale.x;\n\t\tresult[2] = rotation[2] * scale.x;\n\t\tresult[3] = matrix[3];\n\n\t\tresult[4] = rotation[3] * scale.y;\n\t\tresult[5] = rotation[4] * scale.y;\n\t\tresult[6] = rotation[5] * scale.y;\n\t\tresult[7] = matrix[7];\n\n\t\tresult[8] = rotation[6] * scale.z;\n\t\tresult[9] = rotation[7] * scale.z;\n\t\tresult[10] = rotation[8] * scale.z;\n\t\tresult[11] = matrix[11];\n\n\t\tresult[12] = matrix[12];\n\t\tresult[13] = matrix[13];\n\t\tresult[14] = matrix[14];\n\t\tresult[15] = matrix[15];\n\n\t\treturn result;\n\t}\n\n\tstatic getRotation(matrix: Matrix4, result: Quaternion): Quaternion {\n\t\tconst scale = Matrix4.getScale(matrix, scaleScratch5);\n\n\t\tconst is1 = 1 / scale.x;\n\t\tconst is2 = 1 / scale.y;\n\t\tconst is3 = 1 / scale.z;\n\n\t\tconst sm11 = matrix[0] * is1;\n\t\tconst sm12 = matrix[1] * is2;\n\t\tconst sm13 = matrix[2] * is3;\n\t\tconst sm21 = matrix[4] * is1;\n\t\tconst sm22 = matrix[5] * is2;\n\t\tconst sm23 = matrix[6] * is3;\n\t\tconst sm31 = matrix[8] * is1;\n\t\tconst sm32 = matrix[9] * is2;\n\t\tconst sm33 = matrix[10] * is3;\n\n\t\tconst trace = sm11 + sm22 + sm33;\n\t\tlet S = 0;\n\n\t\tif (trace > 0) {\n\t\t\tS = Math.sqrt(trace + 1.0) * 2;\n\t\t\tresult.w = 0.25 * S;\n\t\t\tresult.x = (sm23 - sm32) / S;\n\t\t\tresult.y = (sm31 - sm13) / S;\n\t\t\tresult.z = (sm12 - sm21) / S;\n\t\t} else if (sm11 > sm22 && sm11 > sm33) {\n\t\t\tS = Math.sqrt(1.0 + sm11 - sm22 - sm33) * 2;\n\t\t\tresult.w = (sm23 - sm32) / S;\n\t\t\tresult.x = 0.25 * S;\n\t\t\tresult.y = (sm12 + sm21) / S;\n\t\t\tresult.z = (sm31 + sm13) / S;\n\t\t} else if (sm22 > sm33) {\n\t\t\tS = Math.sqrt(1.0 + sm22 - sm11 - sm33) * 2;\n\t\t\tresult.w = (sm31 - sm13) / S;\n\t\t\tresult.x = (sm12 + sm21) / S;\n\t\t\tresult.y = 0.25 * S;\n\t\t\tresult.z = (sm23 + sm32) / S;\n\t\t} else {\n\t\t\tS = Math.sqrt(1.0 + sm33 - sm11 - sm22) * 2;\n\t\t\tresult.w = (sm12 - sm21) / S;\n\t\t\tresult.x = (sm31 + sm13) / S;\n\t\t\tresult.y = (sm23 + sm32) / S;\n\t\t\tresult.z = 0.25 * S;\n\t\t}\n\t\treturn result;\n\t}\n\n\tstatic multiply(left: Matrix4, right: Matrix4, result: Matrix4): Matrix4 {\n\t\tconst left0 = left[0];\n\t\tconst left1 = left[1];\n\t\tconst left2 = left[2];\n\t\tconst left3 = left[3];\n\t\tconst left4 = left[4];\n\t\tconst left5 = left[5];\n\t\tconst left6 = left[6];\n\t\tconst left7 = left[7];\n\t\tconst left8 = left[8];\n\t\tconst left9 = left[9];\n\t\tconst left10 = left[10];\n\t\tconst left11 = left[11];\n\t\tconst left12 = left[12];\n\t\tconst left13 = left[13];\n\t\tconst left14 = left[14];\n\t\tconst left15 = left[15];\n\n\t\tconst right0 = right[0];\n\t\tconst right1 = right[1];\n\t\tconst right2 = right[2];\n\t\tconst right3 = right[3];\n\t\tconst right4 = right[4];\n\t\tconst right5 = right[5];\n\t\tconst right6 = right[6];\n\t\tconst right7 = right[7];\n\t\tconst right8 = right[8];\n\t\tconst right9 = right[9];\n\t\tconst right10 = right[10];\n\t\tconst right11 = right[11];\n\t\tconst right12 = right[12];\n\t\tconst right13 = right[13];\n\t\tconst right14 = right[14];\n\t\tconst right15 = right[15];\n\n\t\tconst column0Row0 = left0 * right0 + left4 * right1 + left8 * right2 + left12 * right3;\n\t\tconst column0Row1 = left1 * right0 + left5 * right1 + left9 * right2 + left13 * right3;\n\t\tconst column0Row2 = left2 * right0 + left6 * right1 + left10 * right2 + left14 * right3;\n\t\tconst column0Row3 = left3 * right0 + left7 * right1 + left11 * right2 + left15 * right3;\n\n\t\tconst column1Row0 = left0 * right4 + left4 * right5 + left8 * right6 + left12 * right7;\n\t\tconst column1Row1 = left1 * right4 + left5 * right5 + left9 * right6 + left13 * right7;\n\t\tconst column1Row2 = left2 * right4 + left6 * right5 + left10 * right6 + left14 * right7;\n\t\tconst column1Row3 = left3 * right4 + left7 * right5 + left11 * right6 + left15 * right7;\n\n\t\tconst column2Row0 = left0 * right8 + left4 * right9 + left8 * right10 + left12 * right11;\n\t\tconst column2Row1 = left1 * right8 + left5 * right9 + left9 * right10 + left13 * right11;\n\t\tconst column2Row2 = left2 * right8 + left6 * right9 + left10 * right10 + left14 * right11;\n\t\tconst column2Row3 = left3 * right8 + left7 * right9 + left11 * right10 + left15 * right11;\n\n\t\tconst column3Row0 = left0 * right12 + left4 * right13 + left8 * right14 + left12 * right15;\n\t\tconst column3Row1 = left1 * right12 + left5 * right13 + left9 * right14 + left13 * right15;\n\t\tconst column3Row2 = left2 * right12 + left6 * right13 + left10 * right14 + left14 * right15;\n\t\tconst column3Row3 = left3 * right12 + left7 * right13 + left11 * right14 + left15 * right15;\n\n\t\tresult[0] = column0Row0;\n\t\tresult[1] = column0Row1;\n\t\tresult[2] = column0Row2;\n\t\tresult[3] = column0Row3;\n\t\tresult[4] = column1Row0;\n\t\tresult[5] = column1Row1;\n\t\tresult[6] = column1Row2;\n\t\tresult[7] = column1Row3;\n\t\tresult[8] = column2Row0;\n\t\tresult[9] = column2Row1;\n\t\tresult[10] = column2Row2;\n\t\tresult[11] = column2Row3;\n\t\tresult[12] = column3Row0;\n\t\tresult[13] = column3Row1;\n\t\tresult[14] = column3Row2;\n\t\tresult[15] = column3Row3;\n\t\treturn result;\n\t}\n\n\tstatic add(left: Matrix4, right: Matrix4, result: Matrix4): Matrix4 {\n\t\tresult[0] = left[0] + right[0];\n\t\tresult[1] = left[1] + right[1];\n\t\tresult[2] = left[2] + right[2];\n\t\tresult[3] = left[3] + right[3];\n\t\tresult[4] = left[4] + right[4];\n\t\tresult[5] = left[5] + right[5];\n\t\tresult[6] = left[6] + right[6];\n\t\tresult[7] = left[7] + right[7];\n\t\tresult[8] = left[8] + right[8];\n\t\tresult[9] = left[9] + right[9];\n\t\tresult[10] = left[10] + right[10];\n\t\tresult[11] = left[11] + right[11];\n\t\tresult[12] = left[12] + right[12];\n\t\tresult[13] = left[13] + right[13];\n\t\tresult[14] = left[14] + right[14];\n\t\tresult[15] = left[15] + right[15];\n\t\treturn result;\n\t}\n\n\tstatic subtract(left: Matrix4, right: Matrix4, result: Matrix4) {\n\t\tresult[0] = left[0] - right[0];\n\t\tresult[1] = left[1] - right[1];\n\t\tresult[2] = left[2] - right[2];\n\t\tresult[3] = left[3] - right[3];\n\t\tresult[4] = left[4] - right[4];\n\t\tresult[5] = left[5] - right[5];\n\t\tresult[6] = left[6] - right[6];\n\t\tresult[7] = left[7] - right[7];\n\t\tresult[8] = left[8] - right[8];\n\t\tresult[9] = left[9] - right[9];\n\t\tresult[10] = left[10] - right[10];\n\t\tresult[11] = left[11] - right[11];\n\t\tresult[12] = left[12] - right[12];\n\t\tresult[13] = left[13] - right[13];\n\t\tresult[14] = left[14] - right[14];\n\t\tresult[15] = left[15] - right[15];\n\t\treturn result;\n\t}\n\n\tstatic multiplyTransformation(left: Matrix4, right: Matrix4, result: Matrix4): Matrix4 {\n\t\tconst left0 = left[0];\n\t\tconst left1 = left[1];\n\t\tconst left2 = left[2];\n\t\tconst left4 = left[4];\n\t\tconst left5 = left[5];\n\t\tconst left6 = left[6];\n\t\tconst left8 = left[8];\n\t\tconst left9 = left[9];\n\t\tconst left10 = left[10];\n\t\tconst left12 = left[12];\n\t\tconst left13 = left[13];\n\t\tconst left14 = left[14];\n\n\t\tconst right0 = right[0];\n\t\tconst right1 = right[1];\n\t\tconst right2 = right[2];\n\t\tconst right4 = right[4];\n\t\tconst right5 = right[5];\n\t\tconst right6 = right[6];\n\t\tconst right8 = right[8];\n\t\tconst right9 = right[9];\n\t\tconst right10 = right[10];\n\t\tconst right12 = right[12];\n\t\tconst right13 = right[13];\n\t\tconst right14 = right[14];\n\n\t\tconst column0Row0 = left0 * right0 + left4 * right1 + left8 * right2;\n\t\tconst column0Row1 = left1 * right0 + left5 * right1 + left9 * right2;\n\t\tconst column0Row2 = left2 * right0 + left6 * right1 + left10 * right2;\n\n\t\tconst column1Row0 = left0 * right4 + left4 * right5 + left8 * right6;\n\t\tconst column1Row1 = left1 * right4 + left5 * right5 + left9 * right6;\n\t\tconst column1Row2 = left2 * right4 + left6 * right5 + left10 * right6;\n\n\t\tconst column2Row0 = left0 * right8 + left4 * right9 + left8 * right10;\n\t\tconst column2Row1 = left1 * right8 + left5 * right9 + left9 * right10;\n\t\tconst column2Row2 = left2 * right8 + left6 * right9 + left10 * right10;\n\n\t\tconst column3Row0 = left0 * right12 + left4 * right13 + left8 * right14 + left12;\n\t\tconst column3Row1 = left1 * right12 + left5 * right13 + left9 * right14 + left13;\n\t\tconst column3Row2 = left2 * right12 + left6 * right13 + left10 * right14 + left14;\n\n\t\tresult[0] = column0Row0;\n\t\tresult[1] = column0Row1;\n\t\tresult[2] = column0Row2;\n\t\tresult[3] = 0.0;\n\t\tresult[4] = column1Row0;\n\t\tresult[5] = column1Row1;\n\t\tresult[6] = column1Row2;\n\t\tresult[7] = 0.0;\n\t\tresult[8] = column2Row0;\n\t\tresult[9] = column2Row1;\n\t\tresult[10] = column2Row2;\n\t\tresult[11] = 0.0;\n\t\tresult[12] = column3Row0;\n\t\tresult[13] = column3Row1;\n\t\tresult[14] = column3Row2;\n\t\tresult[15] = 1.0;\n\t\treturn result;\n\t}\n\n\tstatic multiplyByMatrix3(matrix: Matrix4, rotation: Matrix3, result: Matrix4): Matrix4 {\n\t\tconst left0 = matrix[0];\n\t\tconst left1 = matrix[1];\n\t\tconst left2 = matrix[2];\n\t\tconst left4 = matrix[4];\n\t\tconst left5 = matrix[5];\n\t\tconst left6 = matrix[6];\n\t\tconst left8 = matrix[8];\n\t\tconst left9 = matrix[9];\n\t\tconst left10 = matrix[10];\n\n\t\tconst right0 = rotation[0];\n\t\tconst right1 = rotation[1];\n\t\tconst right2 = rotation[2];\n\t\tconst right4 = rotation[3];\n\t\tconst right5 = rotation[4];\n\t\tconst right6 = rotation[5];\n\t\tconst right8 = rotation[6];\n\t\tconst right9 = rotation[7];\n\t\tconst right10 = rotation[8];\n\n\t\tconst column0Row0 = left0 * right0 + left4 * right1 + left8 * right2;\n\t\tconst column0Row1 = left1 * right0 + left5 * right1 + left9 * right2;\n\t\tconst column0Row2 = left2 * right0 + left6 * right1 + left10 * right2;\n\n\t\tconst column1Row0 = left0 * right4 + left4 * right5 + left8 * right6;\n\t\tconst column1Row1 = left1 * right4 + left5 * right5 + left9 * right6;\n\t\tconst column1Row2 = left2 * right4 + left6 * right5 + left10 * right6;\n\n\t\tconst column2Row0 = left0 * right8 + left4 * right9 + left8 * right10;\n\t\tconst column2Row1 = left1 * right8 + left5 * right9 + left9 * right10;\n\t\tconst column2Row2 = left2 * right8 + left6 * right9 + left10 * right10;\n\n\t\tresult[0] = column0Row0;\n\t\tresult[1] = column0Row1;\n\t\tresult[2] = column0Row2;\n\t\tresult[3] = 0.0;\n\t\tresult[4] = column1Row0;\n\t\tresult[5] = column1Row1;\n\t\tresult[6] = column1Row2;\n\t\tresult[7] = 0.0;\n\t\tresult[8] = column2Row0;\n\t\tresult[9] = column2Row1;\n\t\tresult[10] = column2Row2;\n\t\tresult[11] = 0.0;\n\t\tresult[12] = matrix[12];\n\t\tresult[13] = matrix[13];\n\t\tresult[14] = matrix[14];\n\t\tresult[15] = matrix[15];\n\t\treturn result;\n\t}\n\n\tstatic multiplyByTranslation(matrix: Matrix4, translation: Vector3, result: Matrix4): Matrix4 {\n\t\tconst x = translation.x;\n\t\tconst y = translation.y;\n\t\tconst z = translation.z;\n\n\t\tconst tx = x * matrix[0] + y * matrix[4] + z * matrix[8] + matrix[12];\n\t\tconst ty = x * matrix[1] + y * matrix[5] + z * matrix[9] + matrix[13];\n\t\tconst tz = x * matrix[2] + y * matrix[6] + z * matrix[10] + matrix[14];\n\n\t\tresult[0] = matrix[0];\n\t\tresult[1] = matrix[1];\n\t\tresult[2] = matrix[2];\n\t\tresult[3] = matrix[3];\n\t\tresult[4] = matrix[4];\n\t\tresult[5] = matrix[5];\n\t\tresult[6] = matrix[6];\n\t\tresult[7] = matrix[7];\n\t\tresult[8] = matrix[8];\n\t\tresult[9] = matrix[9];\n\t\tresult[10] = matrix[10];\n\t\tresult[11] = matrix[11];\n\t\tresult[12] = tx;\n\t\tresult[13] = ty;\n\t\tresult[14] = tz;\n\t\tresult[15] = matrix[15];\n\t\treturn result;\n\t}\n\n\tstatic multiplyByScale(matrix: Matrix4, scale: Vector3, result: Matrix4): Matrix4 {\n\t\tconst scaleX = scale.x;\n\t\tconst scaleY = scale.y;\n\t\tconst scaleZ = scale.z;\n\n\t\t// Faster than Vector3.equals\n\t\tif (scaleX === 1.0 && scaleY === 1.0 && scaleZ === 1.0) {\n\t\t\treturn Matrix4.clone(matrix, result);\n\t\t}\n\n\t\tresult[0] = scaleX * matrix[0];\n\t\tresult[1] = scaleX * matrix[1];\n\t\tresult[2] = scaleX * matrix[2];\n\t\tresult[3] = matrix[3];\n\n\t\tresult[4] = scaleY * matrix[4];\n\t\tresult[5] = scaleY * matrix[5];\n\t\tresult[6] = scaleY * matrix[6];\n\t\tresult[7] = matrix[7];\n\n\t\tresult[8] = scaleZ * matrix[8];\n\t\tresult[9] = scaleZ * matrix[9];\n\t\tresult[10] = scaleZ * matrix[10];\n\t\tresult[11] = matrix[11];\n\n\t\tresult[12] = matrix[12];\n\t\tresult[13] = matrix[13];\n\t\tresult[14] = matrix[14];\n\t\tresult[15] = matrix[15];\n\n\t\treturn result;\n\t}\n\n\tstatic multiplyByUniformScale(matrix: Matrix4, scale: number, result: Matrix4): Matrix4 {\n\t\tresult[0] = matrix[0] * scale;\n\t\tresult[1] = matrix[1] * scale;\n\t\tresult[2] = matrix[2] * scale;\n\t\tresult[3] = matrix[3];\n\n\t\tresult[4] = matrix[4] * scale;\n\t\tresult[5] = matrix[5] * scale;\n\t\tresult[6] = matrix[6] * scale;\n\t\tresult[7] = matrix[7];\n\n\t\tresult[8] = matrix[8] * scale;\n\t\tresult[9] = matrix[9] * scale;\n\t\tresult[10] = matrix[10] * scale;\n\t\tresult[11] = matrix[11];\n\n\t\tresult[12] = matrix[12];\n\t\tresult[13] = matrix[13];\n\t\tresult[14] = matrix[14];\n\t\tresult[15] = matrix[15];\n\n\t\treturn result;\n\t}\n\n\tstatic multiplyByVector(matrix: Matrix4, cartesian: Vector4, result: Vector4): Vector4 {\n\t\tconst vX = cartesian.x;\n\t\tconst vY = cartesian.y;\n\t\tconst vZ = cartesian.z;\n\t\tconst vW = cartesian.w;\n\n\t\tconst x = matrix[0] * vX + matrix[4] * vY + matrix[8] * vZ + matrix[12] * vW;\n\t\tconst y = matrix[1] * vX + matrix[5] * vY + matrix[9] * vZ + matrix[13] * vW;\n\t\tconst z = matrix[2] * vX + matrix[6] * vY + matrix[10] * vZ + matrix[14] * vW;\n\t\tconst w = matrix[3] * vX + matrix[7] * vY + matrix[11] * vZ + matrix[15] * vW;\n\n\t\tresult.x = x;\n\t\tresult.y = y;\n\t\tresult.z = z;\n\t\tresult.w = w;\n\t\treturn result;\n\t}\n\n\tstatic multiplyByPointAsVector(matrix: Matrix4, cartesian: Vector3, result: Vector3): Vector3 {\n\t\tconst vX = cartesian.x;\n\t\tconst vY = cartesian.y;\n\t\tconst vZ = cartesian.z;\n\n\t\tconst x = matrix[0] * vX + matrix[4] * vY + matrix[8] * vZ;\n\t\tconst y = matrix[1] * vX + matrix[5] * vY + matrix[9] * vZ;\n\t\tconst z = matrix[2] * vX + matrix[6] * vY + matrix[10] * vZ;\n\n\t\tresult.x = x;\n\t\tresult.y = y;\n\t\tresult.z = z;\n\t\treturn result;\n\t}\n\n\tstatic multiplyByPoint(matrix: Matrix4, cartesian: Vector3, result: Vector3): Vector3 {\n\t\tconst vX = cartesian.x;\n\t\tconst vY = cartesian.y;\n\t\tconst vZ = cartesian.z;\n\n\t\tconst x = matrix[0] * vX + matrix[4] * vY + matrix[8] * vZ + matrix[12];\n\t\tconst y = matrix[1] * vX + matrix[5] * vY + matrix[9] * vZ + matrix[13];\n\t\tconst z = matrix[2] * vX + matrix[6] * vY + matrix[10] * vZ + matrix[14];\n\n\t\tresult.x = x;\n\t\tresult.y = y;\n\t\tresult.z = z;\n\t\treturn result;\n\t}\n\n\tstatic multiplyByScalar(matrix: Matrix4, scalar: number, result: Matrix4): Matrix4 {\n\t\tresult[0] = matrix[0] * scalar;\n\t\tresult[1] = matrix[1] * scalar;\n\t\tresult[2] = matrix[2] * scalar;\n\t\tresult[3] = matrix[3] * scalar;\n\t\tresult[4] = matrix[4] * scalar;\n\t\tresult[5] = matrix[5] * scalar;\n\t\tresult[6] = matrix[6] * scalar;\n\t\tresult[7] = matrix[7] * scalar;\n\t\tresult[8] = matrix[8] * scalar;\n\t\tresult[9] = matrix[9] * scalar;\n\t\tresult[10] = matrix[10] * scalar;\n\t\tresult[11] = matrix[11] * scalar;\n\t\tresult[12] = matrix[12] * scalar;\n\t\tresult[13] = matrix[13] * scalar;\n\t\tresult[14] = matrix[14] * scalar;\n\t\tresult[15] = matrix[15] * scalar;\n\t\treturn result;\n\t}\n\n\tstatic negate(matrix: Matrix4, result: Matrix4): Matrix4 {\n\t\tresult[0] = -matrix[0];\n\t\tresult[1] = -matrix[1];\n\t\tresult[2] = -matrix[2];\n\t\tresult[3] = -matrix[3];\n\t\tresult[4] = -matrix[4];\n\t\tresult[5] = -matrix[5];\n\t\tresult[6] = -matrix[6];\n\t\tresult[7] = -matrix[7];\n\t\tresult[8] = -matrix[8];\n\t\tresult[9] = -matrix[9];\n\t\tresult[10] = -matrix[10];\n\t\tresult[11] = -matrix[11];\n\t\tresult[12] = -matrix[12];\n\t\tresult[13] = -matrix[13];\n\t\tresult[14] = -matrix[14];\n\t\tresult[15] = -matrix[15];\n\t\treturn result;\n\t}\n\n\tstatic transpose(matrix: Matrix4, result: Matrix4): Matrix4 {\n\t\tconst matrix1 = matrix[1];\n\t\tconst matrix2 = matrix[2];\n\t\tconst matrix3 = matrix[3];\n\t\tconst matrix6 = matrix[6];\n\t\tconst matrix7 = matrix[7];\n\t\tconst matrix11 = matrix[11];\n\n\t\tresult[0] = matrix[0];\n\t\tresult[1] = matrix[4];\n\t\tresult[2] = matrix[8];\n\t\tresult[3] = matrix[12];\n\t\tresult[4] = matrix1;\n\t\tresult[5] = matrix[5];\n\t\tresult[6] = matrix[9];\n\t\tresult[7] = matrix[13];\n\t\tresult[8] = matrix2;\n\t\tresult[9] = matrix6;\n\t\tresult[10] = matrix[10];\n\t\tresult[11] = matrix[14];\n\t\tresult[12] = matrix3;\n\t\tresult[13] = matrix7;\n\t\tresult[14] = matrix11;\n\t\tresult[15] = matrix[15];\n\t\treturn result;\n\t}\n\n\tstatic abs(matrix: Matrix4, result: Matrix4) {\n\t\tresult[0] = Math.abs(matrix[0]);\n\t\tresult[1] = Math.abs(matrix[1]);\n\t\tresult[2] = Math.abs(matrix[2]);\n\t\tresult[3] = Math.abs(matrix[3]);\n\t\tresult[4] = Math.abs(matrix[4]);\n\t\tresult[5] = Math.abs(matrix[5]);\n\t\tresult[6] = Math.abs(matrix[6]);\n\t\tresult[7] = Math.abs(matrix[7]);\n\t\tresult[8] = Math.abs(matrix[8]);\n\t\tresult[9] = Math.abs(matrix[9]);\n\t\tresult[10] = Math.abs(matrix[10]);\n\t\tresult[11] = Math.abs(matrix[11]);\n\t\tresult[12] = Math.abs(matrix[12]);\n\t\tresult[13] = Math.abs(matrix[13]);\n\t\tresult[14] = Math.abs(matrix[14]);\n\t\tresult[15] = Math.abs(matrix[15]);\n\n\t\treturn result;\n\t}\n\n\tstatic equals(left: Matrix4, right: Matrix4): boolean {\n\t\t// Given that most matrices will be transformation matrices, the elements\n\t\t// are tested in order such that the test is likely to fail as early\n\t\t// as possible.  I _think_ this is just as friendly to the L1 cache\n\t\t// as testing in index order.  It is certainty faster in practice.\n\t\treturn (\n\t\t\tleft === right ||\n\t\t\t(defined(left) &&\n\t\t\t\tdefined(right) &&\n\t\t\t\t// Translation\n\t\t\t\tleft[12] === right[12] &&\n\t\t\t\tleft[13] === right[13] &&\n\t\t\t\tleft[14] === right[14] &&\n\t\t\t\t// Rotation/scale\n\t\t\t\tleft[0] === right[0] &&\n\t\t\t\tleft[1] === right[1] &&\n\t\t\t\tleft[2] === right[2] &&\n\t\t\t\tleft[4] === right[4] &&\n\t\t\t\tleft[5] === right[5] &&\n\t\t\t\tleft[6] === right[6] &&\n\t\t\t\tleft[8] === right[8] &&\n\t\t\t\tleft[9] === right[9] &&\n\t\t\t\tleft[10] === right[10] &&\n\t\t\t\t// Bottom row\n\t\t\t\tleft[3] === right[3] &&\n\t\t\t\tleft[7] === right[7] &&\n\t\t\t\tleft[11] === right[11] &&\n\t\t\t\tleft[15] === right[15])\n\t\t);\n\t}\n\n\tstatic equalsEpsilon(left: Matrix4, right: Matrix4, epsilon: number): boolean {\n\t\tepsilon = defaultValue(epsilon, 0);\n\n\t\treturn (\n\t\t\tleft === right ||\n\t\t\t(defined(left) &&\n\t\t\t\tdefined(right) &&\n\t\t\t\tMath.abs(left[0] - right[0]) <= epsilon &&\n\t\t\t\tMath.abs(left[1] - right[1]) <= epsilon &&\n\t\t\t\tMath.abs(left[2] - right[2]) <= epsilon &&\n\t\t\t\tMath.abs(left[3] - right[3]) <= epsilon &&\n\t\t\t\tMath.abs(left[4] - right[4]) <= epsilon &&\n\t\t\t\tMath.abs(left[5] - right[5]) <= epsilon &&\n\t\t\t\tMath.abs(left[6] - right[6]) <= epsilon &&\n\t\t\t\tMath.abs(left[7] - right[7]) <= epsilon &&\n\t\t\t\tMath.abs(left[8] - right[8]) <= epsilon &&\n\t\t\t\tMath.abs(left[9] - right[9]) <= epsilon &&\n\t\t\t\tMath.abs(left[10] - right[10]) <= epsilon &&\n\t\t\t\tMath.abs(left[11] - right[11]) <= epsilon &&\n\t\t\t\tMath.abs(left[12] - right[12]) <= epsilon &&\n\t\t\t\tMath.abs(left[13] - right[13]) <= epsilon &&\n\t\t\t\tMath.abs(left[14] - right[14]) <= epsilon &&\n\t\t\t\tMath.abs(left[15] - right[15]) <= epsilon)\n\t\t);\n\t}\n\n\tstatic getTranslation(matrix: Matrix4, result: Vector3): Vector3 {\n\t\tresult.x = matrix[12];\n\t\tresult.y = matrix[13];\n\t\tresult.z = matrix[14];\n\t\treturn result;\n\t}\n\n\tstatic getMatrix3(matrix: Matrix4, result: Matrix3): Matrix3 {\n\t\tresult[0] = matrix[0];\n\t\tresult[1] = matrix[1];\n\t\tresult[2] = matrix[2];\n\t\tresult[3] = matrix[4];\n\t\tresult[4] = matrix[5];\n\t\tresult[5] = matrix[6];\n\t\tresult[6] = matrix[8];\n\t\tresult[7] = matrix[9];\n\t\tresult[8] = matrix[10];\n\t\treturn result;\n\t}\n\n\tstatic inverse(matrix: Matrix4, result: Matrix4) {\n\t\t//\n\t\t// Ported from:\n\t\t//   ftp://download.intel.com/design/PentiumIII/sml/24504301.pdf\n\t\t//\n\t\tconst src0 = matrix[0];\n\t\tconst src1 = matrix[4];\n\t\tconst src2 = matrix[8];\n\t\tconst src3 = matrix[12];\n\t\tconst src4 = matrix[1];\n\t\tconst src5 = matrix[5];\n\t\tconst src6 = matrix[9];\n\t\tconst src7 = matrix[13];\n\t\tconst src8 = matrix[2];\n\t\tconst src9 = matrix[6];\n\t\tconst src10 = matrix[10];\n\t\tconst src11 = matrix[14];\n\t\tconst src12 = matrix[3];\n\t\tconst src13 = matrix[7];\n\t\tconst src14 = matrix[11];\n\t\tconst src15 = matrix[15];\n\n\t\t// calculate pairs for first 8 elements (cofactors)\n\t\tlet tmp0 = src10 * src15;\n\t\tlet tmp1 = src11 * src14;\n\t\tlet tmp2 = src9 * src15;\n\t\tlet tmp3 = src11 * src13;\n\t\tlet tmp4 = src9 * src14;\n\t\tlet tmp5 = src10 * src13;\n\t\tlet tmp6 = src8 * src15;\n\t\tlet tmp7 = src11 * src12;\n\t\tlet tmp8 = src8 * src14;\n\t\tlet tmp9 = src10 * src12;\n\t\tlet tmp10 = src8 * src13;\n\t\tlet tmp11 = src9 * src12;\n\n\t\t// calculate first 8 elements (cofactors)\n\t\tconst dst0 = tmp0 * src5 + tmp3 * src6 + tmp4 * src7 - (tmp1 * src5 + tmp2 * src6 + tmp5 * src7);\n\t\tconst dst1 = tmp1 * src4 + tmp6 * src6 + tmp9 * src7 - (tmp0 * src4 + tmp7 * src6 + tmp8 * src7);\n\t\tconst dst2 = tmp2 * src4 + tmp7 * src5 + tmp10 * src7 - (tmp3 * src4 + tmp6 * src5 + tmp11 * src7);\n\t\tconst dst3 = tmp5 * src4 + tmp8 * src5 + tmp11 * src6 - (tmp4 * src4 + tmp9 * src5 + tmp10 * src6);\n\t\tconst dst4 = tmp1 * src1 + tmp2 * src2 + tmp5 * src3 - (tmp0 * src1 + tmp3 * src2 + tmp4 * src3);\n\t\tconst dst5 = tmp0 * src0 + tmp7 * src2 + tmp8 * src3 - (tmp1 * src0 + tmp6 * src2 + tmp9 * src3);\n\t\tconst dst6 = tmp3 * src0 + tmp6 * src1 + tmp11 * src3 - (tmp2 * src0 + tmp7 * src1 + tmp10 * src3);\n\t\tconst dst7 = tmp4 * src0 + tmp9 * src1 + tmp10 * src2 - (tmp5 * src0 + tmp8 * src1 + tmp11 * src2);\n\n\t\t// calculate pairs for second 8 elements (cofactors)\n\t\ttmp0 = src2 * src7;\n\t\ttmp1 = src3 * src6;\n\t\ttmp2 = src1 * src7;\n\t\ttmp3 = src3 * src5;\n\t\ttmp4 = src1 * src6;\n\t\ttmp5 = src2 * src5;\n\t\ttmp6 = src0 * src7;\n\t\ttmp7 = src3 * src4;\n\t\ttmp8 = src0 * src6;\n\t\ttmp9 = src2 * src4;\n\t\ttmp10 = src0 * src5;\n\t\ttmp11 = src1 * src4;\n\n\t\t// calculate second 8 elements (cofactors)\n\t\tconst dst8 = tmp0 * src13 + tmp3 * src14 + tmp4 * src15 - (tmp1 * src13 + tmp2 * src14 + tmp5 * src15);\n\t\tconst dst9 = tmp1 * src12 + tmp6 * src14 + tmp9 * src15 - (tmp0 * src12 + tmp7 * src14 + tmp8 * src15);\n\t\tconst dst10 = tmp2 * src12 + tmp7 * src13 + tmp10 * src15 - (tmp3 * src12 + tmp6 * src13 + tmp11 * src15);\n\t\tconst dst11 = tmp5 * src12 + tmp8 * src13 + tmp11 * src14 - (tmp4 * src12 + tmp9 * src13 + tmp10 * src14);\n\t\tconst dst12 = tmp2 * src10 + tmp5 * src11 + tmp1 * src9 - (tmp4 * src11 + tmp0 * src9 + tmp3 * src10);\n\t\tconst dst13 = tmp8 * src11 + tmp0 * src8 + tmp7 * src10 - (tmp6 * src10 + tmp9 * src11 + tmp1 * src8);\n\t\tconst dst14 = tmp6 * src9 + tmp11 * src11 + tmp3 * src8 - (tmp10 * src11 + tmp2 * src8 + tmp7 * src9);\n\t\tconst dst15 = tmp10 * src10 + tmp4 * src8 + tmp9 * src9 - (tmp8 * src9 + tmp11 * src10 + tmp5 * src8);\n\n\t\t// calculate determinant\n\t\tlet det = src0 * dst0 + src1 * dst1 + src2 * dst2 + src3 * dst3;\n\n\t\tif (Math.abs(det) < GMath.EPSILON21) {\n\t\t\t// Special case for a zero scale matrix that can occur, for example,\n\t\t\t// when a model's node has a [0, 0, 0] scale.\n\t\t\tif (\n\t\t\t\tMatrix3.equalsEpsilon(\n\t\t\t\t\tMatrix4.getMatrix3(matrix, scratchInverseRotation),\n\t\t\t\t\tscratchMatrix3Zero,\n\t\t\t\t\tGMath.EPSILON7\n\t\t\t\t) &&\n\t\t\t\tVector4.equals(Matrix4.getRow(matrix, 3, scratchBottomRow), scratchExpectedBottomRow)\n\t\t\t) {\n\t\t\t\tresult[0] = 0.0;\n\t\t\t\tresult[1] = 0.0;\n\t\t\t\tresult[2] = 0.0;\n\t\t\t\tresult[3] = 0.0;\n\t\t\t\tresult[4] = 0.0;\n\t\t\t\tresult[5] = 0.0;\n\t\t\t\tresult[6] = 0.0;\n\t\t\t\tresult[7] = 0.0;\n\t\t\t\tresult[8] = 0.0;\n\t\t\t\tresult[9] = 0.0;\n\t\t\t\tresult[10] = 0.0;\n\t\t\t\tresult[11] = 0.0;\n\t\t\t\tresult[12] = -matrix[12];\n\t\t\t\tresult[13] = -matrix[13];\n\t\t\t\tresult[14] = -matrix[14];\n\t\t\t\tresult[15] = 1.0;\n\t\t\t\treturn result;\n\t\t\t}\n\n\t\t\tthrow new Error(\"matrix is not invertible because its determinate is zero.\");\n\t\t}\n\n\t\t// calculate matrix inverse\n\t\tdet = 1.0 / det;\n\n\t\tresult[0] = dst0 * det;\n\t\tresult[1] = dst1 * det;\n\t\tresult[2] = dst2 * det;\n\t\tresult[3] = dst3 * det;\n\t\tresult[4] = dst4 * det;\n\t\tresult[5] = dst5 * det;\n\t\tresult[6] = dst6 * det;\n\t\tresult[7] = dst7 * det;\n\t\tresult[8] = dst8 * det;\n\t\tresult[9] = dst9 * det;\n\t\tresult[10] = dst10 * det;\n\t\tresult[11] = dst11 * det;\n\t\tresult[12] = dst12 * det;\n\t\tresult[13] = dst13 * det;\n\t\tresult[14] = dst14 * det;\n\t\tresult[15] = dst15 * det;\n\t\treturn result;\n\t}\n\n\tstatic inverseTransformation(matrix: Matrix4, result: Matrix4): Matrix4 {\n\t\t// This function is an optimized version of the below 4 lines.\n\t\t// const rT = Matrix3.transpose(Matrix4.getMatrix3(matrix));\n\t\t// const rTN = Matrix3.negate(rT);\n\t\t// const rTT = Matrix3.multiplyByVector(rTN, Matrix4.getTranslation(matrix));\n\t\t// return Matrix4.fromRotationTranslation(rT, rTT, result);\n\n\t\tconst matrix0 = matrix[0];\n\t\tconst matrix1 = matrix[1];\n\t\tconst matrix2 = matrix[2];\n\t\tconst matrix4 = matrix[4];\n\t\tconst matrix5 = matrix[5];\n\t\tconst matrix6 = matrix[6];\n\t\tconst matrix8 = matrix[8];\n\t\tconst matrix9 = matrix[9];\n\t\tconst matrix10 = matrix[10];\n\n\t\tconst vX = matrix[12];\n\t\tconst vY = matrix[13];\n\t\tconst vZ = matrix[14];\n\n\t\tconst x = -matrix0 * vX - matrix1 * vY - matrix2 * vZ;\n\t\tconst y = -matrix4 * vX - matrix5 * vY - matrix6 * vZ;\n\t\tconst z = -matrix8 * vX - matrix9 * vY - matrix10 * vZ;\n\n\t\tresult[0] = matrix0;\n\t\tresult[1] = matrix4;\n\t\tresult[2] = matrix8;\n\t\tresult[3] = 0.0;\n\t\tresult[4] = matrix1;\n\t\tresult[5] = matrix5;\n\t\tresult[6] = matrix9;\n\t\tresult[7] = 0.0;\n\t\tresult[8] = matrix2;\n\t\tresult[9] = matrix6;\n\t\tresult[10] = matrix10;\n\t\tresult[11] = 0.0;\n\t\tresult[12] = x;\n\t\tresult[13] = y;\n\t\tresult[14] = z;\n\t\tresult[15] = 1.0;\n\t\treturn result;\n\t}\n\n\tstatic inverseTranspose(matrix: Matrix4, result: Matrix4): Matrix4 {\n\t\treturn Matrix4.inverse(Matrix4.transpose(matrix, scratchTransposeMatrix), result);\n\t}\n\t/**\n\t * @private\n\t */\n\tstatic equalsArray(matrix: Matrix4, array: Array<number>, offset: number): boolean {\n\t\treturn (\n\t\t\tmatrix[0] === array[offset] &&\n\t\t\tmatrix[1] === array[offset + 1] &&\n\t\t\tmatrix[2] === array[offset + 2] &&\n\t\t\tmatrix[3] === array[offset + 3] &&\n\t\t\tmatrix[4] === array[offset + 4] &&\n\t\t\tmatrix[5] === array[offset + 5] &&\n\t\t\tmatrix[6] === array[offset + 6] &&\n\t\t\tmatrix[7] === array[offset + 7] &&\n\t\t\tmatrix[8] === array[offset + 8] &&\n\t\t\tmatrix[9] === array[offset + 9] &&\n\t\t\tmatrix[10] === array[offset + 10] &&\n\t\t\tmatrix[11] === array[offset + 11] &&\n\t\t\tmatrix[12] === array[offset + 12] &&\n\t\t\tmatrix[13] === array[offset + 13] &&\n\t\t\tmatrix[14] === array[offset + 14] &&\n\t\t\tmatrix[15] === array[offset + 15]\n\t\t);\n\t}\n}\n\nconst scratchTransposeMatrix = new Matrix4();\n\nconst fromCameraF = new Vector3();\nconst fromCameraR = new Vector3();\nconst fromCameraU = new Vector3();\n\nconst scaleScratch1 = new Vector3();\nconst scaleScratch2 = new Vector3();\nconst scratchColumn = new Vector3();\nconst scaleScratch3 = new Vector3();\nconst scaleScratch4 = new Vector3();\nconst scaleScratch5 = new Vector3();\nconst scratchInverseRotation = new Matrix3();\nconst scratchMatrix3Zero = new Matrix3();\nconst scratchBottomRow = new Vector4();\nconst scratchExpectedBottomRow = new Vector4(0.0, 0.0, 0.0, 1.0);\nconst x = new Vector3();\nconst y = new Vector3();\nconst z = new Vector3();\nexport default Matrix4;\n","import Camera from \"../camera/Camera\";\nimport Matrix4 from \"../math/Matrix4\";\nimport Plane from \"../math/Plane\";\nimport Vector3 from \"../math/Vector3\";\nimport defaultValue from \"../utils/defaultValue\";\nimport defined from \"../utils/defined\";\nimport { Intersect } from \"./WebGPUConstant\";\n\nexport default class BoundingSphere {\n\tradius: number;\n\tcenter: Vector3;\n\toriginRadius: number;\n\toriginCenter: Vector3;\n\tconstructor(center: Vector3 = new Vector3(0, 0, 0), radius = 0) {\n\t\tthis.center = center;\n\t\tthis.radius = radius;\n\t\tthis.originCenter = this.center.clone();\n\t\tthis.originRadius = radius;\n\t}\n\t/**\n\t * @param {Vector3[]} [positions] An array of points that the bounding sphere will enclose.  Each point must have <code>x</code>, <code>y</code>, and <code>z</code> properties.\n\t * @returns {BoundingSphere} The modified result parameter or a new BoundingSphere instance if one was not provided.\n\t */\n\tstatic fromPoints(positions: Vector3[]) {\n\t\tconst result = new BoundingSphere();\n\n\t\tif (!defined(positions) || positions.length === 0) {\n\t\t\tresult.center = Vector3.clone(Vector3.ZERO, result.center);\n\t\t\tresult.radius = 0.0;\n\t\t\treturn result;\n\t\t}\n\n\t\tconst currentPos = Vector3.clone(positions[0], fromPointsCurrentPos);\n\n\t\tconst xMin = Vector3.clone(currentPos, fromPointsXMin);\n\t\tconst yMin = Vector3.clone(currentPos, fromPointsYMin);\n\t\tconst zMin = Vector3.clone(currentPos, fromPointsZMin);\n\n\t\tconst xMax = Vector3.clone(currentPos, fromPointsXMax);\n\t\tconst yMax = Vector3.clone(currentPos, fromPointsYMax);\n\t\tconst zMax = Vector3.clone(currentPos, fromPointsZMax);\n\n\t\tconst numPositions = positions.length;\n\t\tlet i;\n\t\tfor (i = 1; i < numPositions; i++) {\n\t\t\tVector3.clone(positions[i], currentPos);\n\n\t\t\tconst x = currentPos.x;\n\t\t\tconst y = currentPos.y;\n\t\t\tconst z = currentPos.z;\n\n\t\t\t// Store points containing the the smallest and largest components\n\t\t\tif (x < xMin.x) {\n\t\t\t\tVector3.clone(currentPos, xMin);\n\t\t\t}\n\n\t\t\tif (x > xMax.x) {\n\t\t\t\tVector3.clone(currentPos, xMax);\n\t\t\t}\n\n\t\t\tif (y < yMin.y) {\n\t\t\t\tVector3.clone(currentPos, yMin);\n\t\t\t}\n\n\t\t\tif (y > yMax.y) {\n\t\t\t\tVector3.clone(currentPos, yMax);\n\t\t\t}\n\n\t\t\tif (z < zMin.z) {\n\t\t\t\tVector3.clone(currentPos, zMin);\n\t\t\t}\n\n\t\t\tif (z > zMax.z) {\n\t\t\t\tVector3.clone(currentPos, zMax);\n\t\t\t}\n\t\t}\n\n\t\t// Compute x-, y-, and z-spans (Squared distances b/n each component's min. and max.).\n\t\tconst xSpan = Vector3.magnitudeSquared(Vector3.subtract(xMax, xMin, fromPointsScratch));\n\t\tconst ySpan = Vector3.magnitudeSquared(Vector3.subtract(yMax, yMin, fromPointsScratch));\n\t\tconst zSpan = Vector3.magnitudeSquared(Vector3.subtract(zMax, zMin, fromPointsScratch));\n\n\t\t// Set the diameter endpoints to the largest span.\n\t\tlet diameter1 = xMin;\n\t\tlet diameter2 = xMax;\n\t\tlet maxSpan = xSpan;\n\t\tif (ySpan > maxSpan) {\n\t\t\tmaxSpan = ySpan;\n\t\t\tdiameter1 = yMin;\n\t\t\tdiameter2 = yMax;\n\t\t}\n\t\tif (zSpan > maxSpan) {\n\t\t\tmaxSpan = zSpan;\n\t\t\tdiameter1 = zMin;\n\t\t\tdiameter2 = zMax;\n\t\t}\n\n\t\t// Calculate the center of the initial sphere found by Ritter's algorithm\n\t\tconst ritterCenter = fromPointsRitterCenter;\n\t\tritterCenter.x = (diameter1.x + diameter2.x) * 0.5;\n\t\tritterCenter.y = (diameter1.y + diameter2.y) * 0.5;\n\t\tritterCenter.z = (diameter1.z + diameter2.z) * 0.5;\n\n\t\t// Calculate the radius of the initial sphere found by Ritter's algorithm\n\t\tlet radiusSquared = Vector3.magnitudeSquared(Vector3.subtract(diameter2, ritterCenter, fromPointsScratch));\n\t\tlet ritterRadius = Math.sqrt(radiusSquared);\n\n\t\t// Find the center of the sphere found using the Naive method.\n\t\tconst minBoxPt = fromPointsMinBoxPt;\n\t\tminBoxPt.x = xMin.x;\n\t\tminBoxPt.y = yMin.y;\n\t\tminBoxPt.z = zMin.z;\n\n\t\tconst maxBoxPt = fromPointsMaxBoxPt;\n\t\tmaxBoxPt.x = xMax.x;\n\t\tmaxBoxPt.y = yMax.y;\n\t\tmaxBoxPt.z = zMax.z;\n\n\t\tconst naiveCenter = Vector3.midpoint(minBoxPt, maxBoxPt, fromPointsNaiveCenterScratch);\n\n\t\t// Begin 2nd pass to find naive radius and modify the ritter sphere.\n\t\tlet naiveRadius = 0;\n\t\tfor (i = 0; i < numPositions; i++) {\n\t\t\tVector3.clone(positions[i], currentPos);\n\n\t\t\t// Find the furthest point from the naive center to calculate the naive radius.\n\t\t\tconst r = Vector3.magnitude(Vector3.subtract(currentPos, naiveCenter, fromPointsScratch));\n\t\t\tif (r > naiveRadius) {\n\t\t\t\tnaiveRadius = r;\n\t\t\t}\n\n\t\t\t// Make adjustments to the Ritter Sphere to include all points.\n\t\t\tconst oldCenterToPointSquared = Vector3.magnitudeSquared(\n\t\t\t\tVector3.subtract(currentPos, ritterCenter, fromPointsScratch)\n\t\t\t);\n\t\t\tif (oldCenterToPointSquared > radiusSquared) {\n\t\t\t\tconst oldCenterToPoint = Math.sqrt(oldCenterToPointSquared);\n\t\t\t\t// Calculate new radius to include the point that lies outside\n\t\t\t\tritterRadius = (ritterRadius + oldCenterToPoint) * 0.5;\n\t\t\t\tradiusSquared = ritterRadius * ritterRadius;\n\t\t\t\t// Calculate center of new Ritter sphere\n\t\t\t\tconst oldToNew = oldCenterToPoint - ritterRadius;\n\t\t\t\tritterCenter.x = (ritterRadius * ritterCenter.x + oldToNew * currentPos.x) / oldCenterToPoint;\n\t\t\t\tritterCenter.y = (ritterRadius * ritterCenter.y + oldToNew * currentPos.y) / oldCenterToPoint;\n\t\t\t\tritterCenter.z = (ritterRadius * ritterCenter.z + oldToNew * currentPos.z) / oldCenterToPoint;\n\t\t\t}\n\t\t}\n\n\t\tif (ritterRadius < naiveRadius) {\n\t\t\tVector3.clone(ritterCenter, result.center);\n\t\t\tresult.radius = ritterRadius;\n\t\t} else {\n\t\t\tVector3.clone(naiveCenter, result.center);\n\t\t\tresult.radius = naiveRadius;\n\t\t}\n\n\t\treturn result;\n\t}\n\t/**\n\t * Computes a tight-fitting bounding sphere enclosing a list of 3D points, where the points are\n\t * stored in a flat array in X, Y, Z, order.  The bounding sphere is computed by running two\n\t * algorithms, a naive algorithm and Ritter's algorithm. The smaller of the two spheres is used to\n\t * ensure a tight fit.\n\t *\n\t * @param {Number[]} [positions] An array of points that the bounding sphere will enclose.  Each point\n\t *        is formed from three elements in the array in the order X, Y, Z.\n\t * @param {Vector3} [center=Vector3.ZERO] The position to which the positions are relative, which need not be the\n\t *        origin of the coordinate system.  This is useful when the positions are to be used for\n\t *        relative-to-center (RTC) rendering.\n\t * @param {Number} [stride=3] The number of array elements per vertex.  It must be at least 3, but it may\n\t *        be higher.  Regardless of the value of this parameter, the X coordinate of the first position\n\t *        is at array index 0, the Y coordinate is at array index 1, and the Z coordinate is at array index\n\t *        2.  When stride is 3, the X coordinate of the next position then begins at array index 3.  If\n\t *        the stride is 5, however, two array elements are skipped and the next position begins at array\n\t *        index 5.\n\t * @param {BoundingSphere} [result] The object onto which to store the result.\n\t * @returns {BoundingSphere} The modified result parameter or a new BoundingSphere instance if one was not provided.\n\t *\n\t * @example\n\t * // Compute the bounding sphere from 3 positions, each specified relative to a center.\n\t * // In addition to the X, Y, and Z coordinates, the points array contains two additional\n\t * // elements per point which are ignored for the purpose of computing the bounding sphere.\n\t * const center = new Vector3(1.0, 2.0, 3.0);\n\t * const points = [1.0, 2.0, 3.0, 0.1, 0.2,\n\t *               4.0, 5.0, 6.0, 0.1, 0.2,\n\t *               7.0, 8.0, 9.0, 0.1, 0.2];\n\t * const sphere = BoundingSphere.fromVertices(points, center, 5);\n\t *\n\t */\n\tstatic fromVertices(positions: number[], center: Vector3 = Vector3.ZERO, stride = 3) {\n\t\tconst result = new BoundingSphere();\n\n\t\tif (!defined(positions) || positions.length === 0) {\n\t\t\tresult.center = Vector3.clone(Vector3.ZERO, result.center);\n\t\t\tresult.radius = 0.0;\n\t\t\treturn result;\n\t\t}\n\n\t\tcenter = defaultValue(center, Vector3.ZERO);\n\n\t\tstride = defaultValue(stride, 3);\n\n\t\tconst currentPos = fromPointsCurrentPos;\n\t\tcurrentPos.x = positions[0] + center.x;\n\t\tcurrentPos.y = positions[1] + center.y;\n\t\tcurrentPos.z = positions[2] + center.z;\n\n\t\tconst xMin = Vector3.clone(currentPos, fromPointsXMin);\n\t\tconst yMin = Vector3.clone(currentPos, fromPointsYMin);\n\t\tconst zMin = Vector3.clone(currentPos, fromPointsZMin);\n\n\t\tconst xMax = Vector3.clone(currentPos, fromPointsXMax);\n\t\tconst yMax = Vector3.clone(currentPos, fromPointsYMax);\n\t\tconst zMax = Vector3.clone(currentPos, fromPointsZMax);\n\n\t\tconst numElements = positions.length;\n\t\tlet i;\n\t\tfor (i = 0; i < numElements; i += stride) {\n\t\t\tconst x = positions[i] + center.x;\n\t\t\tconst y = positions[i + 1] + center.y;\n\t\t\tconst z = positions[i + 2] + center.z;\n\n\t\t\tcurrentPos.x = x;\n\t\t\tcurrentPos.y = y;\n\t\t\tcurrentPos.z = z;\n\n\t\t\t// Store points containing the the smallest and largest components\n\t\t\tif (x < xMin.x) {\n\t\t\t\tVector3.clone(currentPos, xMin);\n\t\t\t}\n\n\t\t\tif (x > xMax.x) {\n\t\t\t\tVector3.clone(currentPos, xMax);\n\t\t\t}\n\n\t\t\tif (y < yMin.y) {\n\t\t\t\tVector3.clone(currentPos, yMin);\n\t\t\t}\n\n\t\t\tif (y > yMax.y) {\n\t\t\t\tVector3.clone(currentPos, yMax);\n\t\t\t}\n\n\t\t\tif (z < zMin.z) {\n\t\t\t\tVector3.clone(currentPos, zMin);\n\t\t\t}\n\n\t\t\tif (z > zMax.z) {\n\t\t\t\tVector3.clone(currentPos, zMax);\n\t\t\t}\n\t\t}\n\n\t\t// Compute x-, y-, and z-spans (Squared distances b/n each component's min. and max.).\n\t\tconst xSpan = Vector3.magnitudeSquared(Vector3.subtract(xMax, xMin, fromPointsScratch));\n\t\tconst ySpan = Vector3.magnitudeSquared(Vector3.subtract(yMax, yMin, fromPointsScratch));\n\t\tconst zSpan = Vector3.magnitudeSquared(Vector3.subtract(zMax, zMin, fromPointsScratch));\n\n\t\t// Set the diameter endpoints to the largest span.\n\t\tlet diameter1 = xMin;\n\t\tlet diameter2 = xMax;\n\t\tlet maxSpan = xSpan;\n\t\tif (ySpan > maxSpan) {\n\t\t\tmaxSpan = ySpan;\n\t\t\tdiameter1 = yMin;\n\t\t\tdiameter2 = yMax;\n\t\t}\n\t\tif (zSpan > maxSpan) {\n\t\t\tmaxSpan = zSpan;\n\t\t\tdiameter1 = zMin;\n\t\t\tdiameter2 = zMax;\n\t\t}\n\n\t\t// Calculate the center of the initial sphere found by Ritter's algorithm\n\t\tconst ritterCenter = fromPointsRitterCenter;\n\t\tritterCenter.x = (diameter1.x + diameter2.x) * 0.5;\n\t\tritterCenter.y = (diameter1.y + diameter2.y) * 0.5;\n\t\tritterCenter.z = (diameter1.z + diameter2.z) * 0.5;\n\n\t\t// Calculate the radius of the initial sphere found by Ritter's algorithm\n\t\tlet radiusSquared = Vector3.magnitudeSquared(Vector3.subtract(diameter2, ritterCenter, fromPointsScratch));\n\t\tlet ritterRadius = Math.sqrt(radiusSquared);\n\n\t\t// Find the center of the sphere found using the Naive method.\n\t\tconst minBoxPt = fromPointsMinBoxPt;\n\t\tminBoxPt.x = xMin.x;\n\t\tminBoxPt.y = yMin.y;\n\t\tminBoxPt.z = zMin.z;\n\n\t\tconst maxBoxPt = fromPointsMaxBoxPt;\n\t\tmaxBoxPt.x = xMax.x;\n\t\tmaxBoxPt.y = yMax.y;\n\t\tmaxBoxPt.z = zMax.z;\n\n\t\tconst naiveCenter = Vector3.midpoint(minBoxPt, maxBoxPt, fromPointsNaiveCenterScratch);\n\n\t\t// Begin 2nd pass to find naive radius and modify the ritter sphere.\n\t\tlet naiveRadius = 0;\n\t\tfor (i = 0; i < numElements; i += stride) {\n\t\t\tcurrentPos.x = positions[i] + center.x;\n\t\t\tcurrentPos.y = positions[i + 1] + center.y;\n\t\t\tcurrentPos.z = positions[i + 2] + center.z;\n\n\t\t\t// Find the furthest point from the naive center to calculate the naive radius.\n\t\t\tconst r = Vector3.magnitude(Vector3.subtract(currentPos, naiveCenter, fromPointsScratch));\n\t\t\tif (r > naiveRadius) {\n\t\t\t\tnaiveRadius = r;\n\t\t\t}\n\n\t\t\t// Make adjustments to the Ritter Sphere to include all points.\n\t\t\tconst oldCenterToPointSquared = Vector3.magnitudeSquared(\n\t\t\t\tVector3.subtract(currentPos, ritterCenter, fromPointsScratch)\n\t\t\t);\n\t\t\tif (oldCenterToPointSquared > radiusSquared) {\n\t\t\t\tconst oldCenterToPoint = Math.sqrt(oldCenterToPointSquared);\n\t\t\t\t// Calculate new radius to include the point that lies outside\n\t\t\t\tritterRadius = (ritterRadius + oldCenterToPoint) * 0.5;\n\t\t\t\tradiusSquared = ritterRadius * ritterRadius;\n\t\t\t\t// Calculate center of new Ritter sphere\n\t\t\t\tconst oldToNew = oldCenterToPoint - ritterRadius;\n\t\t\t\tritterCenter.x = (ritterRadius * ritterCenter.x + oldToNew * currentPos.x) / oldCenterToPoint;\n\t\t\t\tritterCenter.y = (ritterRadius * ritterCenter.y + oldToNew * currentPos.y) / oldCenterToPoint;\n\t\t\t\tritterCenter.z = (ritterRadius * ritterCenter.z + oldToNew * currentPos.z) / oldCenterToPoint;\n\t\t\t}\n\t\t}\n\n\t\tif (ritterRadius < naiveRadius) {\n\t\t\tVector3.clone(ritterCenter, result.center);\n\t\t\tresult.radius = ritterRadius;\n\t\t} else {\n\t\t\tVector3.clone(naiveCenter, result.center);\n\t\t\tresult.radius = naiveRadius;\n\t\t}\n\n\t\treturn result;\n\t}\n\n\tintersectPlane(plane: Plane) {\n\t\tconst center = this.center;\n\t\tconst radius = this.radius;\n\t\tconst normal = plane.normal;\n\t\tconst distanceToPlane = Vector3.dot(normal, center) + plane.distance;\n\n\t\tif (distanceToPlane < -radius) {\n\t\t\t// The center point is negative side of the plane normal\n\t\t\treturn Intersect.OUTSIDE;\n\t\t} else if (distanceToPlane < radius) {\n\t\t\t// The center point is positive side of the plane, but radius extends beyond it; partial overlap\n\t\t\treturn Intersect.INTERSECTING;\n\t\t}\n\t\treturn Intersect.INSIDE;\n\t}\n\tupdate(transform: Matrix4) {\n\t\tMatrix4.multiplyByPoint(transform, this.originCenter, this.center);\n\t\tthis.radius = Matrix4.getMaximumScale(transform) * this.originRadius;\n\t}\n\tdistanceToCamera(camera: Camera) {\n\t\treturn Math.max(0.0, Vector3.distance(this.center, camera.position) - this.radius);\n\t}\n}\nconst fromPointsXMin = new Vector3();\nconst fromPointsYMin = new Vector3();\nconst fromPointsZMin = new Vector3();\nconst fromPointsXMax = new Vector3();\nconst fromPointsYMax = new Vector3();\nconst fromPointsZMax = new Vector3();\nconst fromPointsCurrentPos = new Vector3();\nconst fromPointsScratch = new Vector3();\nconst fromPointsRitterCenter = new Vector3();\nconst fromPointsMinBoxPt = new Vector3();\nconst fromPointsMaxBoxPt = new Vector3();\nconst fromPointsNaiveCenterScratch = new Vector3();\n","import { IndexFormat } from \"../core/WebGPUConstant\";\r\nimport Buffer from \"./Buffer\";\r\nexport default class IndexBuffer {\r\n\tbuffer: Buffer;\r\n\tindices: Array<number>;\r\n\tindexFormat: GPUIndexFormat;\r\n\tdirty: boolean;\r\n\tprivate label: string;\r\n\tconstructor(label: string, indices?: Array<number>) {\r\n\t\tthis.label = label;\r\n\t\tthis.indices = indices;\r\n\t\tthis.indexFormat = IndexFormat.Uint16;\r\n\t\tthis.dirty = true;\r\n\t}\r\n\tsetIndices(indices) {\r\n\t\tthis.indices = indices;\r\n\t\tthis.dirty = true;\r\n\t}\r\n\tbind(device: GPUDevice, passEncoder: GPURenderPassEncoder) {\r\n\t\tif (this.dirty) {\r\n\t\t\tthis.dirty = false;\r\n\t\t\tthis.buffer = Buffer.createIndexBuffer(\r\n\t\t\t\tthis.label,\r\n\t\t\t\tdevice,\r\n\t\t\t\tthis.indexFormat == IndexFormat.Uint16 ? new Uint16Array(this.indices) : new Uint32Array(this.indices)\r\n\t\t\t);\r\n\t\t}\r\n\t\tpassEncoder.setIndexBuffer(this.buffer.gpuBuffer, this.indexFormat);\r\n\t}\r\n\tdestroy() {\r\n\t\tthis.buffer.destroy();\r\n\t}\r\n}\r\n","import { Attribute, AttributeType, BufferFloat32Attribute, InterleavedAttribute } from \"./Attribute\";\nimport Buffer from \"./Buffer\";\nexport default class Attributes {\n\tpublic interleave: boolean;\n\tprivate _attributes: Map<string, Attribute | InterleavedAttribute>;\n\tprivate shaderLocation: number;\n\tprivate offset: number;\n\tconstructor(shaderLocation = 0) {\n\t\tthis._attributes = new Map();\n\t\tthis.shaderLocation = shaderLocation;\n\t\tthis.offset = 0;\n\t\tthis.interleave = false;\n\t}\n\tget dirty(): boolean {\n\t\tlet result = false;\n\t\tthis._attributes.forEach((attribute) => (!result ? (result = attribute.dirty) : false));\n\t\treturn result;\n\t}\n\tset dirty(value: boolean) {\n\t\tthis._attributes.forEach((attribute) => (attribute.dirty = value));\n\t}\n\tget values(): Map<string, Attribute | InterleavedAttribute> {\n\t\treturn this._attributes;\n\t}\n\tgetAttribute(name): Attribute | InterleavedAttribute {\n\t\treturn this._attributes.get(name);\n\t}\n\tsetAttribute(attribute: Attribute | InterleavedAttribute) {\n\t\tif (attribute.attributeType === AttributeType.attribute) {\n\t\t\tthis.setNotInterleavedAttribute(attribute as Attribute);\n\t\t} else {\n\t\t\tthis.setInterleavedAttribute(attribute as InterleavedAttribute);\n\t\t}\n\t}\n\tprivate setNotInterleavedAttribute(attribute: Attribute) {\n\t\tif (this._attributes.has(attribute.name)) return;\n\t\tattribute.shaderLocation = this.shaderLocation;\n\t\tthis.shaderLocation += 1;\n\t\tattribute.offset = this.offset;\n\t\tthis.offset += attribute.attributeByteSize;\n\t\tthis._attributes.set(attribute.name, attribute);\n\t}\n\tprivate setInterleavedAttribute(attribute: InterleavedAttribute) {\n\t\tif (this._attributes.has(attribute.names.toString())) return;\n\t\tthis._attributes.set(attribute.names.toString(), attribute);\n\t}\n\tgetGPUAttributesDes() {\n\t\tconst result = [];\n\t\tthis._attributes.forEach((attribute) => {\n\t\t\tresult.push(...attribute.getGPUAttribute());\n\t\t});\n\t\treturn result;\n\t}\n\tgetAtrributeValues(): {\n\t\tarrayStride: number;\n\t\ttypeArray: Float32Array;\n\t\tbuffer?: Buffer;\n\t} {\n\t\tconst arrayStrides = [];\n\t\tlet arrayStride = 0;\n\t\tlet buffer = undefined;\n\t\tlet values = null;\n\t\tconst arrays = [];\n\t\tthis._attributes.forEach((attribute: Attribute | InterleavedAttribute) => {\n\t\t\tif (attribute.attributeType === AttributeType.attribute) {\n\t\t\t\tarrayStrides.push((attribute as Attribute).itemSize);\n\t\t\t\tarrays.push(attribute.value);\n\t\t\t\tarrayStride += (attribute as Attribute).itemSize;\n\t\t\t} else {\n\t\t\t\tif (!this.interleave) this.interleave = true;\n\t\t\t\tvalues = values ?? attribute.value;\n\t\t\t\tbuffer = (attribute as BufferFloat32Attribute)?.buffer;\n\t\t\t\tarrayStride = (attribute as InterleavedAttribute).itemSizes.reduce(\n\t\t\t\t\t(total, current) => (total += current),\n\t\t\t\t\t0\n\t\t\t\t);\n\t\t\t}\n\t\t});\n\n\t\tconst typeArray = this.interleave\n\t\t\t? new Float32Array(values)\n\t\t\t: this.interleaveTypedArray(Float32Array, arrayStrides, ...arrays);\n\t\treturn {\n\t\t\tarrayStride: arrayStride * typeArray.BYTES_PER_ELEMENT,\n\t\t\ttypeArray,\n\t\t\tbuffer\n\t\t};\n\t}\n\tdestroy() {\n\t\tthis._attributes.forEach((attribute) => {\n\t\t\tattribute.destroy();\n\t\t});\n\t}\n\t/**\n\t * Interleave n typed arrays\n\t * @alias module:interleaveTypedArray\n\t * @param {TypedArray} ResultConstructor Returned typed array constructor\n\t * @param {Array} elements Number of elements to group for each typed array\n\t * @param {...TypedArray} arrays Arrays to interleave\n\t * @returns {TypedArray}\n\t */\n\tinterleaveTypedArray(ResultConstructor, elements, ...arrays) {\n\t\tconst totalLength = arrays.reduce((total, arr) => total + arr.length, 0);\n\t\tconst result = new ResultConstructor(totalLength);\n\t\tconst stride = elements.reduce((a, b) => a + b);\n\n\t\tfor (let i = 0; i < totalLength; i++) {\n\t\t\tlet offset = 0;\n\t\t\tfor (let j = 0; j < elements.length; j++) {\n\t\t\t\tfor (let k = 0; k < elements[j]; k++) {\n\t\t\t\t\tresult[i * stride + offset] = arrays[j][elements[j] * i + k];\n\t\t\t\t\toffset++;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\treturn result;\n\t}\n}\n","import { InputStepMode } from \"../core/WebGPUConstant\";\nimport { VertexBufferParams } from \"../core/WebGPUTypes\";\nimport { Attribute, AttributeType, InterleavedAttribute, InterleavedFloat32Attribute } from \"./Attribute\";\nimport Attributes from \"./Attributes\";\nimport Buffer from \"./Buffer\";\nexport default class VertexBuffer {\n\tpublic index: number;\n\tpublic arrayStride: number;\n\tpublic stepMode: string;\n\tpublic buffer: Buffer;\n\tpublic attributes: Attributes;\n\tpublic dirty: boolean;\n\tpublic defines: { [prop: string]: boolean | number };\n\tpublic locationIndex: number;\n\tprivate label: string;\n\t//\n\tconstructor(params: VertexBufferParams) {\n\t\tconst { label, index, locationIndex = 0, stepMode = InputStepMode.Vertex, arrayStride } = params;\n\t\tthis.index = index || 0;\n\t\tthis.attributes = new Attributes(locationIndex);\n\t\tthis.stepMode = stepMode;\n\t\tthis.dirty = true;\n\t\tthis.label = label?.concat(`_${index}_VertexBuffer`);\n\t\tthis.arrayStride = arrayStride;\n\t\tthis.defines = {};\n\t\tthis.locationIndex = locationIndex;\n\t}\n\tpublic getBufferDes() {\n\t\tconst result = {\n\t\t\tarrayStride: this.arrayStride,\n\t\t\tstepMode: this.stepMode,\n\t\t\tattributes: this.attributes.getGPUAttributesDes()\n\t\t};\n\t\treturn result;\n\t}\n\tpublic setAttribute(attribute: Attribute | InterleavedAttribute) {\n\t\tif (attribute.attributeType === AttributeType.attribute) {\n\t\t\tthis.setLocationIndex((attribute as Attribute).name);\n\t\t} else {\n\t\t\t(attribute as InterleavedFloat32Attribute)?.names.forEach((name: string) => this.setLocationIndex(name));\n\t\t}\n\t\tthis.attributes.setAttribute(attribute);\n\t\tthis.dirty = true;\n\t}\n\tpublic getAttribute(name: string): Attribute | InterleavedAttribute {\n\t\treturn this.attributes.getAttribute(name);\n\t}\n\tpublic containAttribute(name: string): boolean {\n\t\treturn this.defines[name?.concat(\"Location\")] != undefined ? true : false;\n\t}\n\tpublic bind(device: GPUDevice, passEncoder: GPURenderPassEncoder) {\n\t\tif (this.attributes.dirty) {\n\t\t\tthis.attributes.dirty = false;\n\t\t\tconst { arrayStride, typeArray, buffer } = this.attributes.getAtrributeValues();\n\t\t\tif (this.arrayStride === undefined) this.arrayStride = arrayStride;\n\t\t\tif (!this.buffer) {\n\t\t\t\tthis.buffer = buffer ?? Buffer.createVertexBuffer(this.label, device, typeArray);\n\t\t\t} else {\n\t\t\t\t// update Buffer\n\t\t\t\tif (typeArray) this.buffer.setSubData(0, typeArray);\n\t\t\t}\n\t\t}\n\t\tpassEncoder.setVertexBuffer(this.index, this.buffer.gpuBuffer);\n\t}\n\tprivate setLocationIndex(name: string) {\n\t\tif (this.defines[name?.concat(\"Location\")] || !name) return;\n\t\tthis.defines[name?.concat(\"Location\")] = this.locationIndex;\n\t\tthis.locationIndex += 1;\n\t}\n\tdestroy() {\n\t\tthis.buffer.destroy();\n\t\tthis.attributes.destroy();\n\t}\n}\n","import defaultValue from \"./defaultValue\";\nimport defined from \"./defined\";\n\n/**\n * Merges two objects, copying their properties onto a new combined object. When two objects have the same\n * property, the value of the property on the first object is used.  If either object is undefined,\n * it will be treated as an empty object.\n *\n * @example\n * const object1 = {\n *     propOne : 1,\n *     propTwo : {\n *         value1 : 10\n *     }\n * }\n * const object2 = {\n *     propTwo : 2\n * }\n * const final = combine(object1, object2);\n *\n * // final === {\n * //     propOne : 1,\n * //     propTwo : {\n * //         value1 : 10\n * //     }\n * // }\n *\n * @param {Object} [object1] The first object to merge.\n * @param {Object} [object2] The second object to merge.\n * @param {Boolean} [deep=false] Perform a recursive merge.\n * @returns {Object} The combined object containing all properties from both objects.\n *\n * @function\n */\nfunction combine(object1, object2, deep) {\n\tdeep = defaultValue(deep, false);\n\n\tconst result = {};\n\n\tconst object1Defined = defined(object1);\n\tconst object2Defined = defined(object2);\n\tlet property;\n\tlet object1Value;\n\tlet object2Value;\n\tif (object1Defined) {\n\t\tfor (property in object1) {\n\t\t\tif (object1.hasOwnProperty(property)) {\n\t\t\t\tobject1Value = object1[property];\n\t\t\t\tif (object2Defined && deep && typeof object1Value === \"object\" && object2.hasOwnProperty(property)) {\n\t\t\t\t\tobject2Value = object2[property];\n\t\t\t\t\tif (typeof object2Value === \"object\") {\n\t\t\t\t\t\tresult[property] = combine(object1Value, object2Value, deep);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tresult[property] = object1Value;\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\tresult[property] = object1Value;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\tif (object2Defined) {\n\t\tfor (property in object2) {\n\t\t\tif (object2.hasOwnProperty(property) && !result.hasOwnProperty(property)) {\n\t\t\t\tobject2Value = object2[property];\n\t\t\t\tresult[property] = object2Value;\n\t\t\t}\n\t\t}\n\t}\n\treturn result;\n}\nexport default combine;\n","import BoundingBox from \"../core/BoundingBox\";\nimport BoundingSphere from \"../core/BoundingSphere\";\nimport { FrameState } from \"../core/FrameState\";\nimport Vector2 from \"../math/Vector2\";\nimport Vector3 from \"../math/Vector3\";\nimport Vector4 from \"../math/Vector4\";\nimport { Attribute, InterleavedFloat32Attribute } from \"../render/Attribute\";\nimport IndexBuffer from \"../render/IndexBuffer\";\nimport VertexBuffer from \"../render/VertexBuffer\";\nimport combine from \"../utils/combine\";\nexport default class Geometry {\n\tnormals: number[];\n\tuvs: number[];\n\tpositions: number[];\n\tindices: number[];\n\ttangents: number[];\n\ttype: string;\n\tdirty: boolean;\n\tindexBuffer?: IndexBuffer;\n\tdefaultVertexBuffer: VertexBuffer;\n\tcount: number;\n\tboundingSphere?: BoundingSphere;\n\tboundingBox?: BoundingBox;\n\tprivate _defines: { [prop: string]: boolean | number };\n\tpublic vertexBuffers: Array<VertexBuffer>;\n\tdefinesDirty: boolean;\n\tget defines() {\n\t\treturn Object.assign({}, this._defines, ...this.vertexBuffers.map((vertexBuffer) => vertexBuffer.defines));\n\t}\n\tset defines(value) {\n\t\tthis.definesDirty = true;\n\t\tthis._defines = combine(value, this._defines, false);\n\t}\n\tget currentLocationIndex(): number {\n\t\treturn this?.vertexBuffers?.reduce(\n\t\t\t(max, current) => (current.locationIndex > max ? (max = current.locationIndex) : max),\n\t\t\t0\n\t\t);\n\t}\n\tget vertexBufferCount(): number {\n\t\treturn this.vertexBuffers.length;\n\t}\n\tconstructor(options?: { type?: string }) {\n\t\tthis.type = options.type || undefined;\n\t\tthis.boundingSphere = undefined;\n\t\tthis.dirty = false;\n\t\tthis.definesDirty = true;\n\t\tthis.defaultVertexBuffer = new VertexBuffer({\n\t\t\tlabel: this.type,\n\t\t\tindex: 0\n\t\t});\n\t\tthis.vertexBuffers = [this.defaultVertexBuffer];\n\t\tthis._defines = {};\n\t\tthis.normals = [];\n\t\tthis.uvs = [];\n\t\tthis.positions = [];\n\t\tthis.indices = [];\n\t\tthis.tangents = [];\n\t}\n\tgetAttribute(name: string) {\n\t\treturn this.defaultVertexBuffer.getAttribute(name);\n\t}\n\tsetAttribute(attribute: Attribute | InterleavedFloat32Attribute) {\n\t\tthis.defaultVertexBuffer.setAttribute(attribute);\n\t}\n\tsetIndice(indices: Array<number>) {\n\t\tthis.indices = indices;\n\t\tif (!this.indexBuffer) this.indexBuffer = new IndexBuffer(this.type + \"IndexBuffer\");\n\t\tthis.indexBuffer.setIndices(indices);\n\t}\n\tupdate(frameState: FrameState) {\n\t\t// todo\n\t}\n\tcomputeBoundingSphere(positions: number[], stride = 3) {\n\t\tthis.boundingSphere = BoundingSphere.fromVertices(positions, new Vector3(0, 0, 0), stride);\n\t}\n\t/**\n\t * Calculate mesh tangent.\n\t * @remark need to set positions(with or not with indices), normals, uv before calculation.\n\t * @remark based on http://foundationsofgameenginedev.com/FGED2-sample.pdf\n\t */\n\tcalculateTangents(): void {\n\t\tif (!this.normals || !this.uvs) {\n\t\t\tthrow \"Set normal and uv before calculation.\";\n\t\t}\n\t\tconst { indices, positions, normals, uvs } = this;\n\t\tconst tempPos0 = new Vector3(),\n\t\t\ttempPos1 = new Vector3(),\n\t\t\ttempPos2 = new Vector3(),\n\t\t\ttempUV0 = new Vector2(),\n\t\t\ttempUV1 = new Vector2(),\n\t\t\ttempUV2 = new Vector2();\n\t\tconst e1 = new Vector3(),\n\t\t\te2 = new Vector3(),\n\t\t\tt = new Vector3(),\n\t\t\tb = new Vector3(),\n\t\t\ttemp = new Vector3();\n\t\tconst vertexCount = this.indices.length;\n\t\tconst triangleCount = indices ? indices.length / 3 : positions.length / 3;\n\t\tconst tangents = new Array<Vector4>(vertexCount);\n\t\tconst biTangents = new Array<Vector3>(vertexCount);\n\t\tthis.tangents = [];\n\t\tfor (let i = 0; i < vertexCount; i++) {\n\t\t\ttangents[i] = new Vector4();\n\t\t\tbiTangents[i] = new Vector3();\n\t\t}\n\n\t\t// Calculate tangent and bi-tangent for each triangle and add to all three vertices.\n\t\tfor (let k = 0; k < triangleCount; k++) {\n\t\t\tlet i0 = 3 * k;\n\t\t\tlet i1 = 3 * k + 1;\n\t\t\tlet i2 = 3 * k + 2;\n\t\t\tif (indices) {\n\t\t\t\ti0 = indices[i0];\n\t\t\t\ti1 = indices[i1];\n\t\t\t\ti2 = indices[i2];\n\t\t\t}\n\n\t\t\tconst p0 = tempPos0.set(positions[i0], positions[i0 + 1], positions[i0 + 2]);\n\t\t\tconst p1 = tempPos1.set(positions[i1], positions[i1 + 1], positions[i1 + 2]);\n\t\t\tconst p2 = tempPos2.set(positions[i2], positions[i2 + 1], positions[i2 + 2]);\n\t\t\tconst w0 = tempUV0.set(uvs[i0], uvs[i0 + 1]);\n\t\t\tconst w1 = tempUV1.set(uvs[i1], uvs[i1 + 1]);\n\t\t\tconst w2 = tempUV2.set(uvs[i2], uvs[i2 + 1]);\n\n\t\t\tVector3.subtract(p1, p0, e1);\n\t\t\tVector3.subtract(p2, p0, e2);\n\t\t\tconst x1 = w1.x - w0.x;\n\t\t\tconst x2 = w2.x - w0.x;\n\t\t\tconst y1 = w1.y - w0.y;\n\t\t\tconst y2 = w2.y - w0.y;\n\t\t\tconst r = 1.0 / (x1 * y2 - x2 * y1);\n\n\t\t\tVector3.multiplyByScalar(e1, y2 * r, t);\n\t\t\tVector3.multiplyByScalar(e2, y1 * r, temp);\n\t\t\tVector3.subtract(t, temp, t);\n\t\t\tVector3.multiplyByScalar(e2, x1 * r, b);\n\t\t\tVector3.multiplyByScalar(e1, x2 * r, temp);\n\t\t\tVector3.subtract(b, temp, b);\n\n\t\t\tlet tangent = tangents[i0];\n\t\t\ttangent.set(tangent.x + t.x, tangent.y + t.y, tangent.z + t.z, 1.0);\n\n\t\t\ttangent = tangents[i1];\n\t\t\ttangent.set(tangent.x + t.x, tangent.y + t.y, tangent.z + t.z, 1.0);\n\n\t\t\ttangent = tangents[i2];\n\t\t\ttangent.set(tangent.x + t.x, tangent.y + t.y, tangent.z + t.z, 1.0);\n\t\t\tbiTangents[i0].add(b);\n\t\t\tbiTangents[i1].add(b);\n\t\t\tbiTangents[i2].add(b);\n\t\t}\n\n\t\t// Orthonormalize each tangent and calculate the handedness.\n\t\tfor (let i = 0; i < vertexCount; i++) {\n\t\t\tconst n = new Vector3(normals[3 * i], normals[3 * i + 1], normals[3 * i + 2]);\n\t\t\tconst b = biTangents[i];\n\t\t\tconst tangent = tangents[i];\n\t\t\tt.set(tangent.x, tangent.y, tangent.z);\n\n\t\t\tVector3.cross(t, b, temp);\n\t\t\tconst w = Vector3.dot(temp, n) > 0.0 ? 1 : -1;\n\t\t\tVector3.multiplyByScalar(n, Vector3.dot(t, n), temp);\n\t\t\tVector3.subtract(t, temp, t);\n\t\t\tVector3.normalize(t, t);\n\t\t\t// t.normalize();\n\t\t\ttangent.set(t.x, t.y, t.z, w);\n\t\t\tthis.tangents.push(t.x, t.y, t.z, w);\n\t\t}\n\t\t// this.setTangents(tangents);\n\t}\n\tdestroy() {\n\t\tthis?.indexBuffer.destroy();\n\t\tthis.defaultVertexBuffer.destroy();\n\t\tthis.normals = null;\n\t\tthis.uvs = null;\n\t\tthis.positions = null;\n\t\tthis.indices = null;\n\t\tthis.tangents = null;\n\t\tthis.boundingSphere = undefined;\n\t}\n}\n","import { Float32Attribute } from \"../render/Attribute\";\nimport Geometry from \"./Geometry\";\nexport default class PlaneGeometry extends Geometry {\n\tconstructor(public width: number = 10, public height: number = 10) {\n\t\tsuper({\n\t\t\ttype: \"planeGeometry\"\n\t\t});\n\t\tthis.defines = {\n\t\t\tHAS_NORMAL: true\n\t\t};\n\t\tthis.init();\n\t}\n\tprivate init() {\n\t\t// generate pos uv normal so on\n\t\tconst { indices, normals, uvs, vertices } = this.createGrid(this.width, this.height);\n\t\tthis.computeBoundingSphere(vertices);\n\t\tthis.setAttribute(new Float32Attribute(\"position\", vertices, 3));\n\t\tthis.setAttribute(new Float32Attribute(\"normal\", normals, 3));\n\t\tthis.setAttribute(new Float32Attribute(\"uv\", uvs, 2));\n\t\tthis.setIndice(indices);\n\t\tthis.count = indices.length;\n\t}\n\tprivate createGrid(width = 1, height = 1, widthSegments = 1, heightSegments = 1) {\n\t\tconst width_half = width / 2;\n\t\tconst height_half = height / 2;\n\n\t\tconst gridX = Math.floor(widthSegments);\n\t\tconst gridY = Math.floor(heightSegments);\n\n\t\tconst gridX1 = gridX + 1;\n\t\tconst gridY1 = gridY + 1;\n\n\t\tconst segment_width = width / gridX;\n\t\tconst segment_height = height / gridY;\n\n\t\t//\n\n\t\tconst indices = [];\n\t\tconst vertices = [];\n\t\tconst normals = [];\n\t\tconst uvs = [];\n\n\t\tfor (let iy = 0; iy < gridY1; iy++) {\n\t\t\tconst y = iy * segment_height - height_half;\n\n\t\t\tfor (let ix = 0; ix < gridX1; ix++) {\n\t\t\t\tconst x = ix * segment_width - width_half;\n\n\t\t\t\tvertices.push(x, -y, 0);\n\n\t\t\t\tnormals.push(0, 0, 1);\n\n\t\t\t\tuvs.push(ix / gridX);\n\t\t\t\tuvs.push(1 - iy / gridY);\n\t\t\t}\n\t\t}\n\n\t\tfor (let iy = 0; iy < gridY; iy++) {\n\t\t\tfor (let ix = 0; ix < gridX; ix++) {\n\t\t\t\tconst a = ix + gridX1 * iy;\n\t\t\t\tconst b = ix + gridX1 * (iy + 1);\n\t\t\t\tconst c = ix + 1 + gridX1 * (iy + 1);\n\t\t\t\tconst d = ix + 1 + gridX1 * iy;\n\n\t\t\t\tindices.push(a, b, d);\n\t\t\t\tindices.push(b, c, d);\n\t\t\t}\n\t\t}\n\t\treturn { indices, normals, uvs, vertices };\n\t}\n}\n","import defaultValue from \"../utils/defaultValue\";\r\nimport defined from \"../utils/defined\";\r\nimport GMath from \"./Math\";\r\nimport Matrix4 from \"./Matrix4\";\r\nimport Vector3 from \"./Vector3\";\r\n/**\r\n * A set of 4-dimensional coordinates used to represent rotation in 3-dimensional space.\r\n * @alias Quaternion\r\n * @constructor\r\n *\r\n * @param {Number} [x=0.0] The X component.\r\n * @param {Number} [y=0.0] The Y component.\r\n * @param {Number} [z=0.0] The Z component.\r\n * @param {Number} [w=0.0] The W component.\r\n *\r\n * @see PackableForInterpolation\r\n */\r\nexport class Quaternion {\r\n\tpublic static ZERO = Object.freeze(new Quaternion(0.0, 0.0, 0.0, 0.0));\r\n\r\n\tpublic static IDENTITY = Object.freeze(new Quaternion(0.0, 0.0, 0.0, 1.0));\r\n\r\n\tconstructor(public x: number = 0, public y: number = 0, public z: number = 0, public w: number = 1) {}\r\n\tset(x, y, z, w) {\r\n\t\tthis.x = x;\r\n\t\tthis.y = y;\r\n\t\tthis.z = z;\r\n\t\tthis.w = w;\r\n\t}\r\n\tnormalize() {\r\n\t\tconst inverseMagnitude = 1.0 / Quaternion.magnitude(this);\r\n\t\tconst x = this.x * inverseMagnitude;\r\n\t\tconst y = this.y * inverseMagnitude;\r\n\t\tconst z = this.z * inverseMagnitude;\r\n\t\tconst w = this.w * inverseMagnitude;\r\n\r\n\t\tthis.x = x;\r\n\t\tthis.y = y;\r\n\t\tthis.z = z;\r\n\t\tthis.w = w;\r\n\t\treturn this;\r\n\t}\r\n\tinvert() {\r\n\t\tthis.x *= -1;\r\n\t\tthis.y *= -1;\r\n\t\tthis.z *= -1;\r\n\r\n\t\treturn this;\r\n\t}\r\n\tdot(v: Quaternion): number {\r\n\t\treturn this.x * v.x + this.y * v.y + this.z * v.z + this.w * v.w;\r\n\t}\r\n\tsetFromUnitVectors(vFrom: Vector3, vTo: Vector3): Quaternion {\r\n\t\t// assumes direction vectors vFrom and vTo are normalized\r\n\t\tlet r = Vector3.dot(vFrom, vTo) + 1;\r\n\t\tif (r < Number.EPSILON) {\r\n\t\t\t// vFrom and vTo point in opposite directions\r\n\r\n\t\t\tr = 0;\r\n\r\n\t\t\tif (Math.abs(vFrom.x) > Math.abs(vFrom.z)) {\r\n\t\t\t\tthis.x = -vFrom.y;\r\n\t\t\t\tthis.y = vFrom.x;\r\n\t\t\t\tthis.z = 0;\r\n\t\t\t\tthis.w = r;\r\n\t\t\t} else {\r\n\t\t\t\tthis.x = 0;\r\n\t\t\t\tthis.y = -vFrom.z;\r\n\t\t\t\tthis.z = vFrom.y;\r\n\t\t\t\tthis.w = r;\r\n\t\t\t}\r\n\t\t} else {\r\n\t\t\t// crossVectors( vFrom, vTo ); // inlined to avoid cyclic dependency on Vector3\r\n\r\n\t\t\tthis.x = vFrom.y * vTo.z - vFrom.z * vTo.y;\r\n\t\t\tthis.y = vFrom.z * vTo.x - vFrom.x * vTo.z;\r\n\t\t\tthis.z = vFrom.x * vTo.y - vFrom.y * vTo.x;\r\n\t\t\tthis.w = r;\r\n\t\t}\r\n\r\n\t\treturn this.normalize();\r\n\t}\r\n\tsetFromRotationMatrix(matrix: Matrix4): Quaternion {\r\n\t\tconst te = matrix,\r\n\t\t\tm11 = te[0],\r\n\t\t\tm12 = te[4],\r\n\t\t\tm13 = te[8],\r\n\t\t\tm21 = te[1],\r\n\t\t\tm22 = te[5],\r\n\t\t\tm23 = te[9],\r\n\t\t\tm31 = te[2],\r\n\t\t\tm32 = te[6],\r\n\t\t\tm33 = te[10],\r\n\t\t\ttrace = m11 + m22 + m33;\r\n\r\n\t\tif (trace > 0) {\r\n\t\t\tconst s = 0.5 / Math.sqrt(trace + 1.0);\r\n\r\n\t\t\tthis.w = 0.25 / s;\r\n\t\t\tthis.x = (m32 - m23) * s;\r\n\t\t\tthis.y = (m13 - m31) * s;\r\n\t\t\tthis.z = (m21 - m12) * s;\r\n\t\t} else if (m11 > m22 && m11 > m33) {\r\n\t\t\tconst s = 2.0 * Math.sqrt(1.0 + m11 - m22 - m33);\r\n\r\n\t\t\tthis.w = (m32 - m23) / s;\r\n\t\t\tthis.x = 0.25 * s;\r\n\t\t\tthis.y = (m12 + m21) / s;\r\n\t\t\tthis.z = (m13 + m31) / s;\r\n\t\t} else if (m22 > m33) {\r\n\t\t\tconst s = 2.0 * Math.sqrt(1.0 + m22 - m11 - m33);\r\n\r\n\t\t\tthis.w = (m13 - m31) / s;\r\n\t\t\tthis.x = (m12 + m21) / s;\r\n\t\t\tthis.y = 0.25 * s;\r\n\t\t\tthis.z = (m23 + m32) / s;\r\n\t\t} else {\r\n\t\t\tconst s = 2.0 * Math.sqrt(1.0 + m33 - m11 - m22);\r\n\r\n\t\t\tthis.w = (m21 - m12) / s;\r\n\t\t\tthis.x = (m13 + m31) / s;\r\n\t\t\tthis.y = (m23 + m32) / s;\r\n\t\t\tthis.z = 0.25 * s;\r\n\t\t}\r\n\t\treturn this;\r\n\t}\r\n\tclone() {\r\n\t\treturn Quaternion.clone(this, this);\r\n\t}\r\n\r\n\tequals(right: Quaternion): boolean {\r\n\t\treturn Quaternion.equals(this, right);\r\n\t}\r\n\r\n\tequalsEpsilon(right: Quaternion, epsilon = 0): boolean {\r\n\t\treturn Quaternion.equalsEpsilon(this, right, epsilon);\r\n\t}\r\n\ttoArray(): number[] {\r\n\t\tconst { x, y, z, w } = this;\r\n\t\treturn [x, y, z, w];\r\n\t}\r\n\tstatic fromAxisAngle(axis: Vector3, angle: number): Quaternion {\r\n\t\tconst halfAngle = angle / 2.0;\r\n\t\tconst s = Math.sin(halfAngle);\r\n\t\tfromAxisAngleScratch = Vector3.normalize(axis, fromAxisAngleScratch);\r\n\r\n\t\tconst x = fromAxisAngleScratch.x * s;\r\n\t\tconst y = fromAxisAngleScratch.y * s;\r\n\t\tconst z = fromAxisAngleScratch.z * s;\r\n\t\tconst w = Math.cos(halfAngle);\r\n\t\t// if (!defined(result)) {\r\n\t\t//   return\r\n\t\t// }\r\n\t\tconst result = new Quaternion(x, y, z, w);\r\n\t\tresult.x = x;\r\n\t\tresult.y = y;\r\n\t\tresult.z = z;\r\n\t\tresult.w = w;\r\n\t\treturn result;\r\n\t}\r\n\r\n\t// static fromRotationMatrix(matrix: Matrix3, result: Quaternion): Quaternion {\r\n\t// \tlet root;\r\n\t// \tlet x;\r\n\t// \tlet y;\r\n\t// \tlet z;\r\n\t// \tlet w;\r\n\r\n\t// \tconst m00 = matrix[Matrix3.COLUMN0ROW0];\r\n\t// \tconst m11 = matrix[Matrix3.COLUMN1ROW1];\r\n\t// \tconst m22 = matrix[Matrix3.COLUMN2ROW2];\r\n\t// \tconst trace = m00 + m11 + m22;\r\n\r\n\t// \tif (trace > 0.0) {\r\n\t// \t\t// |w| > 1/2, may as well choose w > 1/2\r\n\t// \t\troot = Math.sqrt(trace + 1.0); // 2w\r\n\t// \t\tw = 0.5 * root;\r\n\t// \t\troot = 0.5 / root; // 1/(4w)\r\n\r\n\t// \t\tx = (matrix[Matrix3.COLUMN1ROW2] - matrix[Matrix3.COLUMN2ROW1]) * root;\r\n\t// \t\ty = (matrix[Matrix3.COLUMN2ROW0] - matrix[Matrix3.COLUMN0ROW2]) * root;\r\n\t// \t\tz = (matrix[Matrix3.COLUMN0ROW1] - matrix[Matrix3.COLUMN1ROW0]) * root;\r\n\t// \t} else {\r\n\t// \t\t// |w| <= 1/2\r\n\t// \t\tconst next = fromRotationMatrixNext;\r\n\r\n\t// \t\tlet i = 0;\r\n\t// \t\tif (m11 > m00) {\r\n\t// \t\t\ti = 1;\r\n\t// \t\t}\r\n\t// \t\tif (m22 > m00 && m22 > m11) {\r\n\t// \t\t\ti = 2;\r\n\t// \t\t}\r\n\t// \t\tconst j = next[i];\r\n\t// \t\tconst k = next[j];\r\n\r\n\t// \t\troot = Math.sqrt(\r\n\t// \t\t\tmatrix[Matrix3.getElementIndex(i, i)] -\r\n\t// \t\t\t\tmatrix[Matrix3.getElementIndex(j, j)] -\r\n\t// \t\t\t\tmatrix[Matrix3.getElementIndex(k, k)] +\r\n\t// \t\t\t\t1.0\r\n\t// \t\t);\r\n\r\n\t// \t\tconst quat = fromRotationMatrixQuat;\r\n\t// \t\tquat[i] = 0.5 * root;\r\n\t// \t\troot = 0.5 / root;\r\n\t// \t\tw = (matrix[Matrix3.getElementIndex(k, j)] - matrix[Matrix3.getElementIndex(j, k)]) * root;\r\n\t// \t\tquat[j] = (matrix[Matrix3.getElementIndex(j, i)] + matrix[Matrix3.getElementIndex(i, j)]) * root;\r\n\t// \t\tquat[k] = (matrix[Matrix3.getElementIndex(k, i)] + matrix[Matrix3.getElementIndex(i, k)]) * root;\r\n\r\n\t// \t\tx = -quat[0];\r\n\t// \t\ty = -quat[1];\r\n\t// \t\tz = -quat[2];\r\n\t// \t}\r\n\r\n\t// \tif (!defined(result)) {\r\n\t// \t\treturn new Quaternion(x, y, z, w);\r\n\t// \t}\r\n\t// \tresult.x = x;\r\n\t// \tresult.y = y;\r\n\t// \tresult.z = z;\r\n\t// \tresult.w = w;\r\n\t// \treturn result;\r\n\t// }\r\n\r\n\tstatic clone(quaternion: Quaternion, result: Quaternion): Quaternion {\r\n\t\tif (!defined(quaternion)) {\r\n\t\t\treturn undefined;\r\n\t\t}\r\n\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Quaternion(quaternion.x, quaternion.y, quaternion.z, quaternion.w);\r\n\t\t}\r\n\r\n\t\tresult.x = quaternion.x;\r\n\t\tresult.y = quaternion.y;\r\n\t\tresult.z = quaternion.z;\r\n\t\tresult.w = quaternion.w;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic conjugate(quaternion: Quaternion, result: Quaternion): Quaternion {\r\n\t\tresult.x = -quaternion.x;\r\n\t\tresult.y = -quaternion.y;\r\n\t\tresult.z = -quaternion.z;\r\n\t\tresult.w = quaternion.w;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic magnitudeSquared(quaternion: Quaternion): number {\r\n\t\treturn (\r\n\t\t\tquaternion.x * quaternion.x +\r\n\t\t\tquaternion.y * quaternion.y +\r\n\t\t\tquaternion.z * quaternion.z +\r\n\t\t\tquaternion.w * quaternion.w\r\n\t\t);\r\n\t}\r\n\r\n\tstatic magnitude(quaternion: Quaternion): number {\r\n\t\treturn Math.sqrt(Quaternion.magnitudeSquared(quaternion));\r\n\t}\r\n\r\n\tstatic normalize(quaternion: Quaternion, result: Quaternion): Quaternion {\r\n\t\tconst inverseMagnitude = 1.0 / Quaternion.magnitude(quaternion);\r\n\t\tconst x = quaternion.x * inverseMagnitude;\r\n\t\tconst y = quaternion.y * inverseMagnitude;\r\n\t\tconst z = quaternion.z * inverseMagnitude;\r\n\t\tconst w = quaternion.w * inverseMagnitude;\r\n\r\n\t\tresult.x = x;\r\n\t\tresult.y = y;\r\n\t\tresult.z = z;\r\n\t\tresult.w = w;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic inverse(quaternion: Quaternion, result: Quaternion): Quaternion {\r\n\t\tconst magnitudeSquared = Quaternion.magnitudeSquared(quaternion);\r\n\t\tresult = Quaternion.conjugate(quaternion, result);\r\n\t\treturn Quaternion.multiplyByScalar(result, 1.0 / magnitudeSquared, result);\r\n\t}\r\n\r\n\tstatic add(left: Quaternion, right: Quaternion, result: Quaternion): Quaternion {\r\n\t\tresult.x = left.x + right.x;\r\n\t\tresult.y = left.y + right.y;\r\n\t\tresult.z = left.z + right.z;\r\n\t\tresult.w = left.w + right.w;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic subtract(left: Quaternion, right: Quaternion, result: Quaternion): Quaternion {\r\n\t\tresult.x = left.x - right.x;\r\n\t\tresult.y = left.y - right.y;\r\n\t\tresult.z = left.z - right.z;\r\n\t\tresult.w = left.w - right.w;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic negate(quaternion: Quaternion, result: Quaternion): Quaternion {\r\n\t\tresult.x = -quaternion.x;\r\n\t\tresult.y = -quaternion.y;\r\n\t\tresult.z = -quaternion.z;\r\n\t\tresult.w = -quaternion.w;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic dot(left: Quaternion, right: Quaternion): number {\r\n\t\treturn left.x * right.x + left.y * right.y + left.z * right.z + left.w * right.w;\r\n\t}\r\n\r\n\tstatic multiply(left: Quaternion, right: Quaternion, result: Quaternion): Quaternion {\r\n\t\tconst leftX = left.x;\r\n\t\tconst leftY = left.y;\r\n\t\tconst leftZ = left.z;\r\n\t\tconst leftW = left.w;\r\n\r\n\t\tconst rightX = right.x;\r\n\t\tconst rightY = right.y;\r\n\t\tconst rightZ = right.z;\r\n\t\tconst rightW = right.w;\r\n\r\n\t\tconst x = leftW * rightX + leftX * rightW + leftY * rightZ - leftZ * rightY;\r\n\t\tconst y = leftW * rightY - leftX * rightZ + leftY * rightW + leftZ * rightX;\r\n\t\tconst z = leftW * rightZ + leftX * rightY - leftY * rightX + leftZ * rightW;\r\n\t\tconst w = leftW * rightW - leftX * rightX - leftY * rightY - leftZ * rightZ;\r\n\r\n\t\tresult.x = x;\r\n\t\tresult.y = y;\r\n\t\tresult.z = z;\r\n\t\tresult.w = w;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic multiplyByScalar(quaternion: Quaternion, scalar: number, result: Quaternion): Quaternion {\r\n\t\tresult.x = quaternion.x * scalar;\r\n\t\tresult.y = quaternion.y * scalar;\r\n\t\tresult.z = quaternion.z * scalar;\r\n\t\tresult.w = quaternion.w * scalar;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic divideByScalar(quaternion: Quaternion, scalar: number, result: Quaternion): Quaternion {\r\n\t\tresult.x = quaternion.x / scalar;\r\n\t\tresult.y = quaternion.y / scalar;\r\n\t\tresult.z = quaternion.z / scalar;\r\n\t\tresult.w = quaternion.w / scalar;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic computeAxis(quaternion: Quaternion, result: Vector3): Vector3 {\r\n\t\tconst w = quaternion.w;\r\n\t\tif (Math.abs(w - 1.0) < GMath.EPSILON6) {\r\n\t\t\tresult.x = result.y = result.z = 0;\r\n\t\t\treturn result;\r\n\t\t}\r\n\r\n\t\tconst scalar = 1.0 / Math.sqrt(1.0 - w * w);\r\n\r\n\t\tresult.x = quaternion.x * scalar;\r\n\t\tresult.y = quaternion.y * scalar;\r\n\t\tresult.z = quaternion.z * scalar;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic computeAngle(quaternion: Quaternion): number {\r\n\t\tif (Math.abs(quaternion.w - 1.0) < GMath.EPSILON6) {\r\n\t\t\treturn 0.0;\r\n\t\t}\r\n\t\treturn 2.0 * Math.acos(quaternion.w);\r\n\t}\r\n\r\n\tstatic lerp(start: Quaternion, end: Quaternion, t: number, result: Quaternion): Quaternion {\r\n\t\tlerpScratch = Quaternion.multiplyByScalar(end, t, lerpScratch);\r\n\t\tresult = Quaternion.multiplyByScalar(start, 1.0 - t, result);\r\n\t\treturn Quaternion.add(lerpScratch, result, result);\r\n\t}\r\n\r\n\tstatic slerp(start: Quaternion, end: Quaternion, t: number, result: Quaternion): Quaternion {\r\n\t\tlet dot = Quaternion.dot(start, end);\r\n\r\n\t\t// The angle between start must be acute. Since q and -q represent\r\n\t\t// the same rotation, negate q to get the acute angle.\r\n\t\tlet r = end;\r\n\t\tif (dot < 0.0) {\r\n\t\t\tdot = -dot;\r\n\t\t\tr = slerpEndNegated = Quaternion.negate(end, slerpEndNegated);\r\n\t\t}\r\n\r\n\t\t// dot > 0, as the dot product approaches 1, the angle between the\r\n\t\t// quaternions vanishes. use linear interpolation.\r\n\t\tif (1.0 - dot < GMath.EPSILON6) {\r\n\t\t\treturn Quaternion.lerp(start, r, t, result);\r\n\t\t}\r\n\r\n\t\tconst theta = Math.acos(dot);\r\n\t\tslerpScaledP = Quaternion.multiplyByScalar(start, Math.sin((1 - t) * theta), slerpScaledP);\r\n\t\tslerpScaledR = Quaternion.multiplyByScalar(r, Math.sin(t * theta), slerpScaledR);\r\n\t\tresult = Quaternion.add(slerpScaledP, slerpScaledR, result);\r\n\t\treturn Quaternion.multiplyByScalar(result, 1.0 / Math.sin(theta), result);\r\n\t}\r\n\r\n\tstatic squad(\r\n\t\tq0: Quaternion,\r\n\t\tq1: Quaternion,\r\n\t\ts0: Quaternion,\r\n\t\ts1: Quaternion,\r\n\t\tt: number,\r\n\t\tresult: Quaternion\r\n\t): Quaternion {\r\n\t\tconst slerp0 = Quaternion.slerp(q0, q1, t, squadScratchQuaternion0);\r\n\t\tconst slerp1 = Quaternion.slerp(s0, s1, t, squadScratchQuaternion1);\r\n\t\treturn Quaternion.slerp(slerp0, slerp1, 2.0 * t * (1.0 - t), result);\r\n\t}\r\n\tstatic equals(left: Quaternion, right: Quaternion): boolean {\r\n\t\treturn (\r\n\t\t\tleft === right ||\r\n\t\t\t(defined(left) &&\r\n\t\t\t\tdefined(right) &&\r\n\t\t\t\tleft.x === right.x &&\r\n\t\t\t\tleft.y === right.y &&\r\n\t\t\t\tleft.z === right.z &&\r\n\t\t\t\tleft.w === right.w)\r\n\t\t);\r\n\t}\r\n\r\n\tstatic equalsEpsilon(left: Quaternion, right: Quaternion, epsilon = 0): boolean {\r\n\t\tepsilon = defaultValue(epsilon, 0);\r\n\r\n\t\treturn (\r\n\t\t\tleft === right ||\r\n\t\t\t(defined(left) &&\r\n\t\t\t\tdefined(right) &&\r\n\t\t\t\tMath.abs(left.x - right.x) <= epsilon &&\r\n\t\t\t\tMath.abs(left.y - right.y) <= epsilon &&\r\n\t\t\t\tMath.abs(left.z - right.z) <= epsilon &&\r\n\t\t\t\tMath.abs(left.w - right.w) <= epsilon)\r\n\t\t);\r\n\t}\r\n\r\n\tstatic exp(cartesian: Vector3, result: Quaternion): Quaternion {\r\n\t\tconst theta = Vector3.magnitude(cartesian);\r\n\t\tlet sinThetaOverTheta = 0.0;\r\n\r\n\t\tif (theta !== 0.0) {\r\n\t\t\tsinThetaOverTheta = Math.sin(theta) / theta;\r\n\t\t}\r\n\r\n\t\tresult.x = cartesian.x * sinThetaOverTheta;\r\n\t\tresult.y = cartesian.y * sinThetaOverTheta;\r\n\t\tresult.z = cartesian.z * sinThetaOverTheta;\r\n\t\tresult.w = Math.cos(theta);\r\n\r\n\t\treturn result;\r\n\t}\r\n}\r\n\r\nlet fromAxisAngleScratch = new Vector3();\r\n\r\nconst fromRotationMatrixNext = [1, 2, 0];\r\nconst fromRotationMatrixQuat = new Array(3);\r\n\r\nlet lerpScratch = new Quaternion();\r\n\r\nlet slerpEndNegated = new Quaternion();\r\nlet slerpScaledP = new Quaternion();\r\nlet slerpScaledR = new Quaternion();\r\n\r\nconst squadScratchCartesian0 = new Vector3();\r\nconst squadScratchCartesian1 = new Vector3();\r\nconst squadScratchQuaternion0 = new Quaternion();\r\nconst squadScratchQuaternion1 = new Quaternion();\r\n","import Matrix4 from \"../math/Matrix4\";\nimport { Quaternion } from \"../math/Quaternion\";\nimport Vector3 from \"../math/Vector3\";\nimport IClone from \"./IClone\";\nimport { RenderObjectType } from \"./WebGPUTypes\";\n\nexport default class RenderObject implements IClone {\n\tpublic up: Vector3;\n\tprotected _position: Vector3;\n\tprotected _scale: Vector3;\n\tprotected _quaternion: Quaternion;\n\tprotected _target: Vector3;\n\tprivate _normalMatrix: Matrix4;\n\tmodelMatrix: Matrix4;\n\tparent: RenderObject;\n\ttype: RenderObjectType;\n\tname: string;\n\tconstructor() {\n\t\tthis._position = new Vector3();\n\t\tthis._scale = new Vector3(1, 1, 1);\n\t\tthis._quaternion = new Quaternion();\n\t\tthis.modelMatrix = Matrix4.clone(Matrix4.IDENTITY, new Matrix4());\n\t\tthis._normalMatrix = Matrix4.clone(Matrix4.IDENTITY, new Matrix4());\n\t\tthis.up = new Vector3(0, 1, 0);\n\t\tthis._target = new Vector3(0, 0, 0);\n\t}\n\tpublic get normalMatrix(): Matrix4 {\n\t\treturn this._normalMatrix;\n\t}\n\n\tpublic get position(): Vector3 {\n\t\treturn this._position;\n\t}\n\tpublic get scale(): Vector3 {\n\t\treturn this._scale;\n\t}\n\tpublic get quaternion(): Quaternion {\n\t\treturn this._quaternion;\n\t}\n\tprivate updateNormalMatrix() {\n\t\tMatrix4.inverse(this.modelMatrix, this._normalMatrix);\n\t\tMatrix4.transpose(this._normalMatrix, this._normalMatrix);\n\t}\n\tupdateMatrix(matrix?: Matrix4) {\n\t\tthis.modelMatrix.compose(this.position, this.quaternion, this.scale);\n\t\tif (matrix) Matrix4.multiply(matrix, this.modelMatrix, this.modelMatrix);\n\t\tthis.updateNormalMatrix();\n\t}\n\tlookAt(x, y, z) {\n\t\tthis._target.set(x, y, z);\n\t\tif (this.type == RenderObjectType.Camera || this.type == RenderObjectType.Light) {\n\t\t\t_m1.lookAt(this.position, this._target, this.up);\n\t\t} else {\n\t\t\t_m1.lookAt(this._target, this.position, this.up);\n\t\t}\n\t\tthis.quaternion.setFromRotationMatrix(_m1);\n\t}\n\trotateOnAxis(axis, angle) {\n\t\tconst quat = Quaternion.fromAxisAngle(axis, angle);\n\t\tQuaternion.multiply(this.quaternion, quat, this.quaternion);\n\t}\n\trotateX(angle) {\n\t\treturn this.rotateOnAxis(_xAxis, angle);\n\t}\n\trotateY(angle) {\n\t\treturn this.rotateOnAxis(_yAxis, angle);\n\t}\n\trotateZ(angle) {\n\t\treturn this.rotateOnAxis(_zAxis, angle);\n\t}\n}\nconst _xAxis = new Vector3(1, 0, 0);\nconst _yAxis = new Vector3(0, 1, 0);\nconst _zAxis = new Vector3(0, 0, 1);\nconst _m1 = new Matrix4();\n","import RenderObject from \"../core/RenderObject\";\r\nimport { LightType, RenderObjectType } from \"../core/WebGPUTypes\";\r\nimport Vector3 from \"../math/Vector3\";\r\nimport { BaseShadow } from \"./shadows/BaseShadow\";\r\n\r\nexport class Light extends RenderObject {\r\n\tprivate _color: Vector3;\r\n\ttype: RenderObjectType;\r\n\tprivate _intensity: number;\r\n\tdirty: boolean;\r\n\tcolorDirty: boolean;\r\n\tshadowDirty: boolean;\r\n\tintensityDirty: boolean;\r\n\tpositionDirty: boolean;\r\n\tpublic _shadow: BaseShadow;\r\n\tpublic targetDirty: boolean;\r\n\tpublic lightType: LightType;\r\n\r\n\tconstructor(color: Vector3, intensity: number) {\r\n\t\tsuper();\r\n\t\tthis.type = RenderObjectType.Light;\r\n\t\tthis._color = Vector3.multiplyByScalar(color, intensity, new Vector3());\r\n\t\tthis._intensity = intensity;\r\n\t\tthis._position = new Vector3(0, 1, 0);\r\n\t\tthis._target = new Vector3();\r\n\t\tthis.positionDirty = true;\r\n\t\tthis.targetDirty = true;\r\n\t\tthis.colorDirty = true;\r\n\t\tthis.shadowDirty = true;\r\n\t\tthis.intensityDirty = true;\r\n\t\tthis._shadow = null;\r\n\t}\r\n\r\n\tget position() {\r\n\t\treturn this._position;\r\n\t}\r\n\r\n\tset position(value) {\r\n\t\tthis.positionDirty = true;\r\n\t\tthis._position = value;\r\n\t}\r\n\r\n\tget target() {\r\n\t\treturn this._target;\r\n\t}\r\n\r\n\tset target(value) {\r\n\t\tthis.targetDirty = true;\r\n\t\tthis._target = value;\r\n\t}\r\n\r\n\tget color() {\r\n\t\treturn this._color;\r\n\t}\r\n\r\n\tset color(value) {\r\n\t\tthis.colorDirty = true;\r\n\t\tthis._color = value;\r\n\t}\r\n\r\n\tset intensity(value) {\r\n\t\tthis.color = Vector3.multiplyByScalar(this.color, value, new Vector3());\r\n\t\tthis.intensityDirty = true;\r\n\t\tthis._intensity = value;\r\n\t}\r\n\r\n\tget intensity() {\r\n\t\treturn this._intensity;\r\n\t}\r\n\r\n\tget shadow() {\r\n\t\treturn this._shadow;\r\n\t}\r\n\r\n\tset shadow(value) {\r\n\t\tthis.shadowDirty = true;\r\n\t\tthis._shadow = value;\r\n\t}\r\n}\r\n","import defaultValue from \"../utils/defaultValue\";\r\nimport defined from \"../utils/defined\";\r\nimport GMath from \"./Math\";\r\n// #rgba\r\nconst rgbaMatcher = /^#([0-9a-f])([0-9a-f])([0-9a-f])([0-9a-f])?$/i;\r\n// #rrggbbaa\r\nconst rrggbbaaMatcher = /^#([0-9a-f]{2})([0-9a-f]{2})([0-9a-f]{2})([0-9a-f]{2})?$/i;\r\n// rgb(), rgba(), or rgb%()\r\nconst rgbParenthesesMatcher = /^rgba?\\(\\s*([0-9.]+%?)\\s*,\\s*([0-9.]+%?)\\s*,\\s*([0-9.]+%?)(?:\\s*,\\s*([0-9.]+))?\\s*\\)$/i;\r\n// hsl() or hsla()\r\nconst hslParenthesesMatcher = /^hsla?\\(\\s*([0-9.]+)\\s*,\\s*([0-9.]+%)\\s*,\\s*([0-9.]+%)(?:\\s*,\\s*([0-9.]+))?\\s*\\)$/i;\r\nfunction hue2rgb(m1, m2, h) {\r\n\tif (h < 0) {\r\n\t\th += 1;\r\n\t}\r\n\tif (h > 1) {\r\n\t\th -= 1;\r\n\t}\r\n\tif (h * 6 < 1) {\r\n\t\treturn m1 + (m2 - m1) * 6 * h;\r\n\t}\r\n\tif (h * 2 < 1) {\r\n\t\treturn m2;\r\n\t}\r\n\tif (h * 3 < 2) {\r\n\t\treturn m1 + (m2 - m1) * (2 / 3 - h) * 6;\r\n\t}\r\n\treturn m1;\r\n}\r\n\r\nclass Color {\r\n\tgreen: number;\r\n\tred: number;\r\n\tblue: number;\r\n\tconstructor(red = 1.0, green = 1.0, blue = 1.0) {\r\n\t\t/**\r\n\t\t * The red component.\r\n\t\t * @type {Number}\r\n\t\t * @default 1.0\r\n\t\t */\r\n\t\tthis.red = red;\r\n\t\t/**\r\n\t\t * The green component.\r\n\t\t * @type {Number}\r\n\t\t * @default 1.0\r\n\t\t */\r\n\t\tthis.green = green;\r\n\t\t/**\r\n\t\t * The blue component.\r\n\t\t * @type {Number}\r\n\t\t * @default 1.0\r\n\t\t */\r\n\t\tthis.blue = blue;\r\n\t}\r\n\tset(value: string): Color {\r\n\t\tif (typeof value === \"string\") {\r\n\t\t\tColor.fromCssColorString(value, this);\r\n\t\t}\r\n\t\treturn this;\r\n\t}\r\n\ttoArray(): number[] {\r\n\t\treturn [this.red, this.green, this.blue];\r\n\t}\r\n\r\n\tclone(result: Color): Color {\r\n\t\treturn Color.clone(this, result);\r\n\t}\r\n\r\n\tequals(other: Color): boolean {\r\n\t\treturn Color.equals(this, other);\r\n\t}\r\n\r\n\ttoCssHexString(): string {\r\n\t\tlet r = Color.floatToByte(this.red).toString(16);\r\n\t\tif (r.length < 2) {\r\n\t\t\tr = `0${r}`;\r\n\t\t}\r\n\t\tlet g = Color.floatToByte(this.green).toString(16);\r\n\t\tif (g.length < 2) {\r\n\t\t\tg = `0${g}`;\r\n\t\t}\r\n\t\tlet b = Color.floatToByte(this.blue).toString(16);\r\n\t\tif (b.length < 2) {\r\n\t\t\tb = `0${b}`;\r\n\t\t}\r\n\t\treturn `#${r}${g}${b}`;\r\n\t}\r\n\r\n\ttoBytes(result: number[]): number[] {\r\n\t\tconst red = Color.floatToByte(this.red);\r\n\t\tconst green = Color.floatToByte(this.green);\r\n\t\tconst blue = Color.floatToByte(this.blue);\r\n\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn [red, green, blue];\r\n\t\t}\r\n\t\tresult[0] = red;\r\n\t\tresult[1] = green;\r\n\t\tresult[2] = blue;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic fromBytes(red: number, green: number, blue: number, result: Color): Color {\r\n\t\tred = Color.byteToFloat(defaultValue(red, 255.0));\r\n\t\tgreen = Color.byteToFloat(defaultValue(green, 255.0));\r\n\t\tblue = Color.byteToFloat(defaultValue(blue, 255.0));\r\n\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Color(red, green, blue);\r\n\t\t}\r\n\r\n\t\tresult.red = red;\r\n\t\tresult.green = green;\r\n\t\tresult.blue = blue;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic fromHsl(hue: number, saturation: number, lightness: number, result: Color): Color {\r\n\t\thue = defaultValue(hue, 0.0) % 1.0;\r\n\t\tsaturation = defaultValue(saturation, 0.0);\r\n\t\tlightness = defaultValue(lightness, 0.0);\r\n\t\tlet red = lightness;\r\n\t\tlet green = lightness;\r\n\t\tlet blue = lightness;\r\n\r\n\t\tif (saturation !== 0) {\r\n\t\t\tlet m2;\r\n\t\t\tif (lightness < 0.5) {\r\n\t\t\t\tm2 = lightness * (1 + saturation);\r\n\t\t\t} else {\r\n\t\t\t\tm2 = lightness + saturation - lightness * saturation;\r\n\t\t\t}\r\n\r\n\t\t\tconst m1 = 2.0 * lightness - m2;\r\n\t\t\tred = hue2rgb(m1, m2, hue + 1 / 3);\r\n\t\t\tgreen = hue2rgb(m1, m2, hue);\r\n\t\t\tblue = hue2rgb(m1, m2, hue - 1 / 3);\r\n\t\t}\r\n\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Color(red, green, blue);\r\n\t\t}\r\n\r\n\t\tresult.red = red;\r\n\t\tresult.green = green;\r\n\t\tresult.blue = blue;\r\n\t\treturn result;\r\n\t}\r\n\r\n\t/**\r\n\t * Creates a random color using the provided options. For reproducible random colors, you should\r\n\t * call {@link GMath#setRandomNumberSeed} once at the beginning of your application.\r\n\t *\r\n\t * @param {Object} [options] Object with the following properties:\r\n\t * @param {Number} [options.red] If specified, the red component to use instead of a randomized value.\r\n\t * @param {Number} [options.minimumRed=0.0] The maximum red value to generate if none was specified.\r\n\t * @param {Number} [options.maximumRed=1.0] The minimum red value to generate if none was specified.\r\n\t * @param {Number} [options.green] If specified, the green component to use instead of a randomized value.\r\n\t * @param {Number} [options.minimumGreen=0.0] The maximum green value to generate if none was specified.\r\n\t * @param {Number} [options.maximumGreen=1.0] The minimum green value to generate if none was specified.\r\n\t * @param {Number} [options.blue] If specified, the blue component to use instead of a randomized value.\r\n\t * @param {Number} [options.minimumBlue=0.0] The maximum blue value to generate if none was specified.\r\n\t * @param {Number} [options.maximumBlue=1.0] The minimum blue value to generate if none was specified.\r\n\t * @param {Color} [result] The object to store the result in, if undefined a new instance will be created.\r\n\t * @returns {Color} The modified result parameter or a new instance if result was undefined.\r\n\t *\r\n\t * @example\r\n\t * //Create a completely random color\r\n\t * const color = Color.fromRandom();\r\n\t *\r\n\t * //Create a random shade of yellow.\r\n\t * const color1 = Color.fromRandom({\r\n\t *     red : 1.0,\r\n\t *     green : 1.0,\r\n\t * });\r\n\t *\r\n\t * //Create a random bright color.\r\n\t * const color2 = Color.fromRandom({\r\n\t *     minimumRed : 0.75,\r\n\t *     minimumGreen : 0.75,\r\n\t *     minimumBlue : 0.75,\r\n\t * });\r\n\t */\r\n\tstatic fromRandom(options, result: Color): Color {\r\n\t\toptions = defaultValue(options, defaultValue.EMPTY_OBJECT);\r\n\r\n\t\tlet red = options.red;\r\n\t\tif (!defined(red)) {\r\n\t\t\tconst minimumRed = defaultValue(options.minimumRed, 0);\r\n\t\t\tconst maximumRed = defaultValue(options.maximumRed, 1.0);\r\n\r\n\t\t\tred = minimumRed + GMath.nextRandomNumber() * (maximumRed - minimumRed);\r\n\t\t}\r\n\r\n\t\tlet green = options.green;\r\n\t\tif (!defined(green)) {\r\n\t\t\tconst minimumGreen = defaultValue(options.minimumGreen, 0);\r\n\t\t\tconst maximumGreen = defaultValue(options.maximumGreen, 1.0);\r\n\r\n\t\t\tgreen = minimumGreen + GMath.nextRandomNumber() * (maximumGreen - minimumGreen);\r\n\t\t}\r\n\r\n\t\tlet blue = options.blue;\r\n\t\tif (!defined(blue)) {\r\n\t\t\tconst minimumBlue = defaultValue(options.minimumBlue, 0);\r\n\t\t\tconst maximumBlue = defaultValue(options.maximumBlue, 1.0);\r\n\r\n\t\t\tblue = minimumBlue + GMath.nextRandomNumber() * (maximumBlue - minimumBlue);\r\n\t\t}\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Color(red, green, blue);\r\n\t\t}\r\n\r\n\t\tresult.red = red;\r\n\t\tresult.green = green;\r\n\t\tresult.blue = blue;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic fromCssColorString(color: string, result: Color = new Color()): Color {\r\n\t\t// Remove all whitespaces from the color string\r\n\t\tcolor = color.replace(/\\s/g, \"\");\r\n\r\n\t\tconst namedColor = Color[color.toUpperCase()];\r\n\t\tif (defined(namedColor)) {\r\n\t\t\tColor.clone(namedColor, result);\r\n\t\t\treturn result;\r\n\t\t}\r\n\r\n\t\tlet matches = rgbaMatcher.exec(color);\r\n\t\tif (matches !== null) {\r\n\t\t\tresult.red = parseInt(matches[1], 16) / 15;\r\n\t\t\tresult.green = parseInt(matches[2], 16) / 15.0;\r\n\t\t\tresult.blue = parseInt(matches[3], 16) / 15.0;\r\n\t\t\treturn result;\r\n\t\t}\r\n\r\n\t\tmatches = rrggbbaaMatcher.exec(color);\r\n\t\tif (matches !== null) {\r\n\t\t\tresult.red = parseInt(matches[1], 16) / 255.0;\r\n\t\t\tresult.green = parseInt(matches[2], 16) / 255.0;\r\n\t\t\tresult.blue = parseInt(matches[3], 16) / 255.0;\r\n\t\t\treturn result;\r\n\t\t}\r\n\r\n\t\tmatches = rgbParenthesesMatcher.exec(color);\r\n\t\tif (matches !== null) {\r\n\t\t\tresult.red = parseFloat(matches[1]) / (\"%\" === matches[1].substr(-1) ? 100.0 : 255.0);\r\n\t\t\tresult.green = parseFloat(matches[2]) / (\"%\" === matches[2].substr(-1) ? 100.0 : 255.0);\r\n\t\t\tresult.blue = parseFloat(matches[3]) / (\"%\" === matches[3].substr(-1) ? 100.0 : 255.0);\r\n\t\t\treturn result;\r\n\t\t}\r\n\r\n\t\tmatches = hslParenthesesMatcher.exec(color);\r\n\t\tif (matches !== null) {\r\n\t\t\treturn Color.fromHsl(\r\n\t\t\t\tparseFloat(matches[1]) / 360.0,\r\n\t\t\t\tparseFloat(matches[2]) / 100.0,\r\n\t\t\t\tparseFloat(matches[3]) / 100.0,\r\n\t\t\t\tresult\r\n\t\t\t);\r\n\t\t}\r\n\r\n\t\tresult = undefined;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic byteToFloat(value: number): number {\r\n\t\treturn value / 255.0;\r\n\t}\r\n\r\n\tstatic floatToByte(value: number): number {\r\n\t\treturn value === 1.0 ? 255.0 : (value * 256.0) | 0;\r\n\t}\r\n\r\n\tstatic clone(color: Color, result: Color): Color {\r\n\t\tif (!defined(color)) {\r\n\t\t\treturn undefined;\r\n\t\t}\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Color(color.red, color.green, color.blue);\r\n\t\t}\r\n\t\tresult.red = color.red;\r\n\t\tresult.green = color.green;\r\n\t\tresult.blue = color.blue;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic equals(left: Color, right: Color): boolean {\r\n\t\treturn (\r\n\t\t\tleft === right || //\r\n\t\t\t(defined(left) && //\r\n\t\t\t\tdefined(right) && //\r\n\t\t\t\tleft.red === right.red && //\r\n\t\t\t\tleft.green === right.green && //\r\n\t\t\t\tleft.blue === right.blue)\r\n\t\t);\r\n\t}\r\n\r\n\t/**\r\n\t * @private\r\n\t */\r\n\tstatic equalsArray(color: Color, array: number[], offset: number): boolean {\r\n\t\treturn color.red === array[offset] && color.green === array[offset + 1] && color.blue === array[offset + 2];\r\n\t}\r\n}\r\nexport default Color;\r\n","import defaultValue from \"../utils/defaultValue\";\r\nimport defined from \"../utils/defined\";\r\nimport Vector2 from \"./Vector2\";\r\n\r\n/**\r\n * A 2x2 matrix, indexable as a column-major order array.\r\n * @param {Number} [column0Row0=0.0] The value for column 0, row 0.\r\n * @param {Number} [column1Row0=0.0] The value for column 1, row 0.\r\n * @param {Number} [column0Row1=0.0] The value for column 0, row 1.\r\n * @param {Number} [column1Row1=0.0] The value for column 1, row 1.\r\n */\r\nclass Matrix2 {\r\n\tconstructor(column0Row0 = 0, column1Row0 = 0, column0Row1 = 0, column1Row1 = 0) {\r\n\t\tthis[0] = column0Row0;\r\n\t\tthis[1] = column0Row1;\r\n\t\tthis[2] = column1Row0;\r\n\t\tthis[3] = column1Row1;\r\n\t}\r\n\r\n\tstatic clone(matrix: Matrix2 | number[], result: Matrix2): Matrix2 {\r\n\t\tif (!defined(matrix)) {\r\n\t\t\treturn undefined;\r\n\t\t}\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Matrix2(matrix[0], matrix[2], matrix[1], matrix[3]);\r\n\t\t}\r\n\t\tresult[0] = matrix[0];\r\n\t\tresult[1] = matrix[1];\r\n\t\tresult[2] = matrix[2];\r\n\t\tresult[3] = matrix[3];\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic fromColumnMajorArray(values: number[], result: Matrix2): Matrix2 {\r\n\t\treturn Matrix2.clone(values, result);\r\n\t}\r\n\r\n\tstatic fromRowMajorArray(values: number, result: Matrix2): Matrix2 {\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Matrix2(values[0], values[1], values[2], values[3]);\r\n\t\t}\r\n\t\tresult[0] = values[0];\r\n\t\tresult[1] = values[2];\r\n\t\tresult[2] = values[1];\r\n\t\tresult[3] = values[3];\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic fromScale(scale: Vector2, result: Matrix2): Matrix2 {\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Matrix2(scale.x, 0.0, 0.0, scale.y);\r\n\t\t}\r\n\r\n\t\tresult[0] = scale.x;\r\n\t\tresult[1] = 0.0;\r\n\t\tresult[2] = 0.0;\r\n\t\tresult[3] = scale.y;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic fromRotation(angle: number, result: Matrix2): Matrix2 {\r\n\t\tconst cosAngle = Math.cos(angle);\r\n\t\tconst sinAngle = Math.sin(angle);\r\n\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Matrix2(cosAngle, -sinAngle, sinAngle, cosAngle);\r\n\t\t}\r\n\t\tresult[0] = cosAngle;\r\n\t\tresult[1] = sinAngle;\r\n\t\tresult[2] = -sinAngle;\r\n\t\tresult[3] = cosAngle;\r\n\t\treturn result;\r\n\t}\r\n\ttoArray() {\r\n\t\tconst result = [];\r\n\t\tMatrix2.toArray(this, result);\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic toArray(matrix: Matrix2, result: number[]): number[] {\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn [matrix[0], matrix[1], matrix[2], matrix[3]];\r\n\t\t}\r\n\t\tresult[0] = matrix[0];\r\n\t\tresult[1] = matrix[1];\r\n\t\tresult[2] = matrix[2];\r\n\t\tresult[3] = matrix[3];\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic getElementIndex(column: number, row: number): number {\r\n\t\treturn column * 2 + row;\r\n\t}\r\n\r\n\tstatic getColumn(matrix: Matrix2, index: number, result: Vector2): Vector2 {\r\n\t\tconst startIndex = index * 2;\r\n\t\tconst x = matrix[startIndex];\r\n\t\tconst y = matrix[startIndex + 1];\r\n\r\n\t\tresult.x = x;\r\n\t\tresult.y = y;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic setColumn(matrix: Matrix2, index: number, cartesian: Vector2, result: Matrix2): Matrix2 {\r\n\t\tresult = Matrix2.clone(matrix, result);\r\n\t\tconst startIndex = index * 2;\r\n\t\tresult[startIndex] = cartesian.x;\r\n\t\tresult[startIndex + 1] = cartesian.y;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic getRow(matrix: Matrix2, index: number, result: Vector2): Vector2 {\r\n\t\tconst x = matrix[index];\r\n\t\tconst y = matrix[index + 2];\r\n\r\n\t\tresult.x = x;\r\n\t\tresult.y = y;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic setRow(matrix: Matrix2, index: number, cartesian: Vector2, result: Matrix2): Matrix2 {\r\n\t\tresult = Matrix2.clone(matrix, result);\r\n\t\tresult[index] = cartesian.x;\r\n\t\tresult[index + 2] = cartesian.y;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic setScale(matrix: Matrix2, scale: Vector2, result: Matrix2): Matrix2 {\r\n\t\tconst existingScale = Matrix2.getScale(matrix, scaleScratch1);\r\n\t\tconst scaleRatioX = scale.x / existingScale.x;\r\n\t\tconst scaleRatioY = scale.y / existingScale.y;\r\n\r\n\t\tresult[0] = matrix[0] * scaleRatioX;\r\n\t\tresult[1] = matrix[1] * scaleRatioX;\r\n\t\tresult[2] = matrix[2] * scaleRatioY;\r\n\t\tresult[3] = matrix[3] * scaleRatioY;\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic getScale(matrix: Matrix2, result: Vector2): Vector2 {\r\n\t\tresult.x = Vector2.magnitude(Vector2.fromElements(matrix[0], matrix[1], scratchColumn));\r\n\t\tresult.y = Vector2.magnitude(Vector2.fromElements(matrix[2], matrix[3], scratchColumn));\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic getMaximumScale(matrix: Matrix2): number {\r\n\t\tMatrix2.getScale(matrix, scaleScratch3);\r\n\t\treturn Vector2.maximumComponent(scaleScratch3);\r\n\t}\r\n\r\n\tstatic setRotation(matrix: Matrix2, rotation: Matrix2, result: Matrix2): Matrix2 {\r\n\t\tconst scale = Matrix2.getScale(matrix, scaleScratch4);\r\n\r\n\t\tresult[0] = rotation[0] * scale.x;\r\n\t\tresult[1] = rotation[1] * scale.x;\r\n\t\tresult[2] = rotation[2] * scale.y;\r\n\t\tresult[3] = rotation[3] * scale.y;\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic getRotation(matrix: Matrix2, result: Matrix2): Matrix2 {\r\n\t\tconst scale = Matrix2.getScale(matrix, scaleScratch5);\r\n\r\n\t\tresult[0] = matrix[0] / scale.x;\r\n\t\tresult[1] = matrix[1] / scale.x;\r\n\t\tresult[2] = matrix[2] / scale.y;\r\n\t\tresult[3] = matrix[3] / scale.y;\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic multiply(left: Matrix2, right: Matrix2, result: Matrix2): Matrix2 {\r\n\t\tconst column0Row0 = left[0] * right[0] + left[2] * right[1];\r\n\t\tconst column1Row0 = left[0] * right[2] + left[2] * right[3];\r\n\t\tconst column0Row1 = left[1] * right[0] + left[3] * right[1];\r\n\t\tconst column1Row1 = left[1] * right[2] + left[3] * right[3];\r\n\r\n\t\tresult[0] = column0Row0;\r\n\t\tresult[1] = column0Row1;\r\n\t\tresult[2] = column1Row0;\r\n\t\tresult[3] = column1Row1;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic add(left: Matrix2, right: Matrix2, result: Matrix2) {\r\n\t\tresult[0] = left[0] + right[0];\r\n\t\tresult[1] = left[1] + right[1];\r\n\t\tresult[2] = left[2] + right[2];\r\n\t\tresult[3] = left[3] + right[3];\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic subtract(left: Matrix2, right: Matrix2, result: Matrix2): Matrix2 {\r\n\t\tresult[0] = left[0] - right[0];\r\n\t\tresult[1] = left[1] - right[1];\r\n\t\tresult[2] = left[2] - right[2];\r\n\t\tresult[3] = left[3] - right[3];\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic multiplyByVector(matrix: Matrix2, cartesian: Vector2, result: Vector2): Vector2 {\r\n\t\tconst x = matrix[0] * cartesian.x + matrix[2] * cartesian.y;\r\n\t\tconst y = matrix[1] * cartesian.x + matrix[3] * cartesian.y;\r\n\r\n\t\tresult.x = x;\r\n\t\tresult.y = y;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic multiplyByScalar(matrix: Matrix2, scalar: number, result: Matrix2): Matrix2 {\r\n\t\tresult[0] = matrix[0] * scalar;\r\n\t\tresult[1] = matrix[1] * scalar;\r\n\t\tresult[2] = matrix[2] * scalar;\r\n\t\tresult[3] = matrix[3] * scalar;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic multiplyByScale(matrix: Matrix2, scale: Vector2, result: Matrix2): Matrix2 {\r\n\t\tresult[0] = matrix[0] * scale.x;\r\n\t\tresult[1] = matrix[1] * scale.x;\r\n\t\tresult[2] = matrix[2] * scale.y;\r\n\t\tresult[3] = matrix[3] * scale.y;\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic negate(matrix: Matrix2, result: Matrix2): Matrix2 {\r\n\t\tresult[0] = -matrix[0];\r\n\t\tresult[1] = -matrix[1];\r\n\t\tresult[2] = -matrix[2];\r\n\t\tresult[3] = -matrix[3];\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic transpose(matrix: Matrix2, result: Matrix2): Matrix2 {\r\n\t\tconst column0Row0 = matrix[0];\r\n\t\tconst column0Row1 = matrix[2];\r\n\t\tconst column1Row0 = matrix[1];\r\n\t\tconst column1Row1 = matrix[3];\r\n\r\n\t\tresult[0] = column0Row0;\r\n\t\tresult[1] = column0Row1;\r\n\t\tresult[2] = column1Row0;\r\n\t\tresult[3] = column1Row1;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic abs(matrix: Matrix2, result: Matrix2): Matrix2 {\r\n\t\tresult[0] = Math.abs(matrix[0]);\r\n\t\tresult[1] = Math.abs(matrix[1]);\r\n\t\tresult[2] = Math.abs(matrix[2]);\r\n\t\tresult[3] = Math.abs(matrix[3]);\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic equals(left: Matrix2, right: Matrix2): boolean {\r\n\t\treturn (\r\n\t\t\tleft === right ||\r\n\t\t\t(defined(left) &&\r\n\t\t\t\tdefined(right) &&\r\n\t\t\t\tleft[0] === right[0] &&\r\n\t\t\t\tleft[1] === right[1] &&\r\n\t\t\t\tleft[2] === right[2] &&\r\n\t\t\t\tleft[3] === right[3])\r\n\t\t);\r\n\t}\r\n\r\n\t/**\r\n\t * @private\r\n\t */\r\n\tstatic equalsArray(matrix: Matrix2, array: number[], offset: number): boolean {\r\n\t\treturn (\r\n\t\t\tmatrix[0] === array[offset] &&\r\n\t\t\tmatrix[1] === array[offset + 1] &&\r\n\t\t\tmatrix[2] === array[offset + 2] &&\r\n\t\t\tmatrix[3] === array[offset + 3]\r\n\t\t);\r\n\t}\r\n\r\n\tstatic equalsEpsilon(left: Matrix2, right: Matrix2, epsilon = 0): boolean {\r\n\t\tepsilon = defaultValue(epsilon, 0);\r\n\t\treturn (\r\n\t\t\tleft === right ||\r\n\t\t\t(defined(left) &&\r\n\t\t\t\tdefined(right) &&\r\n\t\t\t\tMath.abs(left[0] - right[0]) <= epsilon &&\r\n\t\t\t\tMath.abs(left[1] - right[1]) <= epsilon &&\r\n\t\t\t\tMath.abs(left[2] - right[2]) <= epsilon &&\r\n\t\t\t\tMath.abs(left[3] - right[3]) <= epsilon)\r\n\t\t);\r\n\t}\r\n\r\n\tpublic static IDENTITY = Object.freeze(new Matrix2(1.0, 0.0, 0.0, 1.0));\r\n\r\n\tpublic static ZERO = Object.freeze(new Matrix2(0.0, 0.0, 0.0, 0.0));\r\n\r\n\tclone(result: Matrix2): Matrix2 {\r\n\t\treturn Matrix2.clone(this, result);\r\n\t}\r\n\r\n\tequals(right: Matrix2): boolean {\r\n\t\treturn Matrix2.equals(this, right);\r\n\t}\r\n\r\n\tequalsEpsilon(right: Matrix2, epsilon = 0): boolean {\r\n\t\treturn Matrix2.equalsEpsilon(this, right, epsilon);\r\n\t}\r\n\r\n\ttoString() {\r\n\t\treturn `(${this[0]}, ${this[2]})\\n` + `(${this[1]}, ${this[3]})`;\r\n\t}\r\n}\r\nconst scaleScratch1 = new Vector2();\r\nconst scaleScratch2 = new Vector2();\r\nconst scaleScratch3 = new Vector2();\r\nconst scaleScratch4 = new Vector2();\r\nconst scratchColumn = new Vector2();\r\nconst scaleScratch5 = new Vector2();\r\nexport default Matrix2;\r\n","import { ShaderStage } from \"../core/WebGPUConstant\";\nimport { UniformFunc, UniformEnum, UniformStruct } from \"../core/WebGPUTypes\";\nimport { DirectionalLight } from \"../light/DirectionalLight\";\nimport { PointLight } from \"../light/PointLight\";\nimport { SpotLight } from \"../light/SpotLight\";\nimport Color from \"../math/Color\";\nimport Matrix2 from \"../math/Matrix2\";\nimport Matrix3 from \"../math/Matrix3\";\nimport Matrix4 from \"../math/Matrix4\";\nimport Vector2 from \"../math/Vector2\";\nimport Vector3 from \"../math/Vector3\";\nimport Vector4 from \"../math/Vector4\";\nimport defaultValue from \"../utils/defaultValue\";\nimport Sampler from \"./Sampler\";\nimport Texture from \"./Texture\";\nimport UniformBuffer from \"./UniformBuffer\";\nexport class Uniform<T> {\n\t_value: T;\n\tname: string;\n\tvalue: T;\n\toffset: number;\n\tbuffer: Float32Array | Uint16Array | Uint32Array | Uint8Array | Float64Array;\n\tcb: UniformFunc | number | object;\n\tbyteSize: number;\n\ttype?: string;\n\tdirty?: boolean;\n\n\tconstructor(uniformName: string, cb?: UniformFunc | number | object, offset?: number) {\n\t\tthis.name = uniformName;\n\t\tthis.cb = cb;\n\t\tthis.offset = defaultValue(offset, 0);\n\t\tthis.type = \"number\";\n\t}\n\tsetBuffer(array: Array<number>, offset = 0) {\n\t\tfor (let i = 0; i < array.length; i++) {\n\t\t\tthis.buffer[i + offset] = array[i];\n\t\t}\n\t}\n\tset() {\n\t\treturn undefined;\n\t}\n\tgetValue() {\n\t\tlet result;\n\t\tconst cbType = typeof this.cb;\n\t\tswitch (cbType) {\n\t\t\tcase \"object\":\n\t\t\t\tresult = this.cb[this.name] || this.cb;\n\t\t\t\tbreak;\n\t\t\tcase \"function\":\n\t\t\t\t// @ts-ignore\n\t\t\t\tresult = this.cb();\n\t\t\t\tbreak;\n\t\t\tcase \"number\":\n\t\t\t\tresult = this.cb;\n\t\t\t\tbreak;\n\t\t\tdefault:\n\t\t\t\tthrow new Error(\"type is error\");\n\t\t}\n\t\treturn result;\n\t}\n\t// compare array\n\tequals(v) {\n\t\tif ((this._value as Array<number>).length !== v.length) return false;\n\t\tfor (let i = 0; i < v.length; i++) {\n\t\t\tif (v[i] !== this._value[i]) {\n\t\t\t\treturn false;\n\t\t\t}\n\t\t}\n\t\treturn true;\n\t}\n}\n\nexport class UniformUint extends Uniform<number> {\n\tstatic align = 4;\n\tconstructor(\n\t\tuniformName: string,\n\t\tbuffer: Float32Array,\n\t\tbyteOffset: number,\n\t\tcb: UniformFunc | number | object,\n\t\toffset?: number\n\t) {\n\t\tsuper(uniformName, cb, offset);\n\t\tthis.value = undefined;\n\t\tthis._value = 0;\n\t\tthis.byteSize = 4;\n\t\tthis.buffer = new Uint32Array(buffer.buffer, byteOffset, 1);\n\t\tthis.type = \"uint\";\n\t}\n\tset() {\n\t\tif (this.cb != undefined) this.value = this.getValue();\n\t\tif (this.value !== this._value) {\n\t\t\tthis._value = this.value;\n\t\t\tthis.buffer[0] = this.value;\n\t\t\treturn true;\n\t\t}\n\t\treturn false;\n\t}\n}\n\nexport class UniformFloat extends Uniform<number> {\n\tstatic align = 4;\n\tconstructor(\n\t\tuniformName: string,\n\t\tbuffer: Float32Array,\n\t\tbyteOffset: number,\n\t\tcb: UniformFunc | number | object,\n\t\toffset?: number\n\t) {\n\t\tsuper(uniformName, cb, offset);\n\t\tthis.value = undefined;\n\t\tthis._value = 0;\n\t\tthis.byteSize = 4;\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, 1);\n\t\tthis.type = \"vec1\";\n\t}\n\tset() {\n\t\tif (this.cb != undefined) this.value = this.getValue();\n\t\tif (this.value !== this._value) {\n\t\t\tthis._value = this.value;\n\t\t\tthis.buffer[0] = this.value;\n\t\t\treturn true;\n\t\t}\n\t\treturn false;\n\t}\n}\nexport class UniformFloatVec2 extends Uniform<Vector2> {\n\tstatic align = 8;\n\tconstructor(\n\t\tuniformName: string,\n\t\tbuffer: Float32Array,\n\t\tbyteOffset: number,\n\t\tcb: UniformFunc | number | object,\n\t\toffset?: number\n\t) {\n\t\tsuper(uniformName, cb, offset);\n\t\tthis.value = undefined;\n\t\tthis._value = new Vector2();\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, 2);\n\t\tthis.byteSize = 8;\n\t\tthis.type = \"vec2\";\n\t}\n\tset(): boolean {\n\t\tif (this.cb != undefined) this.value = this.getValue();\n\t\tconst v = this.value;\n\t\tif (v instanceof Vector2) {\n\t\t\tif (Vector2.equals(v, this._value)) return false;\n\t\t\tVector2.clone(v, this._value);\n\t\t\tthis.setBuffer(this._value.toArray());\n\t\t\treturn true;\n\t\t} else {\n\t\t\tif (this.equals(v)) return false;\n\t\t\tthis._value = v;\n\t\t\tthis.setBuffer(v);\n\t\t\treturn true;\n\t\t}\n\t}\n}\nexport class UniformFloatVec3 extends Uniform<Vector3> {\n\tstatic align = 16;\n\tconstructor(\n\t\tuniformName: string,\n\t\tbuffer: Float32Array,\n\t\tbyteOffset: number,\n\t\tcb: UniformFunc | number | object,\n\t\toffset?: number\n\t) {\n\t\tsuper(uniformName, cb, offset);\n\t\tthis.value = undefined;\n\t\tthis._value = new Vector3();\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, 3);\n\t\tthis.byteSize = 12;\n\t\tthis.type = \"vec3\";\n\t}\n\tset(): boolean {\n\t\tif (this.cb != undefined) this.value = this.getValue();\n\t\tconst v = this.value;\n\t\tif (v instanceof Vector3) {\n\t\t\tif (Vector3.equals(v, this._value)) return false;\n\t\t\tVector3.clone(v, this._value);\n\t\t\tthis.setBuffer(this._value.toArray());\n\t\t\treturn true;\n\t\t} else {\n\t\t\tif (this.equals(v)) return false;\n\t\t\tthis._value = v;\n\t\t\tthis.setBuffer(v);\n\t\t\treturn true;\n\t\t}\n\t}\n}\nexport class UniformFloatVec4 extends Uniform<Vector4> {\n\tstatic align = 16;\n\tconstructor(\n\t\tuniformName: string,\n\t\tbuffer: Float32Array,\n\t\tbyteOffset: number,\n\t\tcb: UniformFunc | number | object,\n\t\toffset?: number\n\t) {\n\t\tsuper(uniformName, cb, offset);\n\t\tthis.value = undefined;\n\t\tthis._value = new Vector4();\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, 4);\n\t\tthis.byteSize = 16;\n\t\tthis.type = \"vec4\";\n\t}\n\tset(): boolean {\n\t\tif (this.cb != undefined) this.value = this.getValue();\n\t\tconst v = this.value;\n\t\tif (v instanceof Vector4) {\n\t\t\tif (Vector4.equals(v, this._value)) return false;\n\t\t\tVector4.clone(v, this._value);\n\t\t\tthis.setBuffer(this._value.toArray());\n\t\t\treturn true;\n\t\t} else {\n\t\t\tif (this.equals(v)) return false;\n\t\t\tthis._value = v;\n\t\t\tthis.setBuffer(v);\n\t\t\treturn true;\n\t\t}\n\t}\n}\nexport class UniformColor extends Uniform<Color> {\n\tstatic align = 16;\n\tconstructor(\n\t\tuniformName: string,\n\t\tbuffer: Float32Array,\n\t\tbyteOffset: number,\n\t\tcb: UniformFunc | number | object,\n\t\toffset?: number\n\t) {\n\t\tsuper(uniformName, cb, offset);\n\t\tthis.value = undefined;\n\t\tthis._value = new Color();\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, 3);\n\t\tthis.byteSize = 12;\n\t\tthis.type = \"vec3\";\n\t}\n\tset(): boolean {\n\t\tif (this.cb != undefined) this.value = this.getValue();\n\t\tconst v = this.value;\n\t\tif (v instanceof Color) {\n\t\t\tif (Color.equals(v, this._value)) return false;\n\t\t\tColor.clone(v, this._value);\n\t\t\tthis.setBuffer(this._value.toArray());\n\t\t\treturn true;\n\t\t} else {\n\t\t\tif (this.equals(v)) return false;\n\t\t\tthis._value = v;\n\t\t\tthis.setBuffer(v);\n\t\t\treturn true;\n\t\t}\n\t}\n}\n\nexport class UniformMat2 extends Uniform<Matrix2> {\n\tstatic align = 8;\n\tconstructor(\n\t\tuniformName: string,\n\t\tbuffer: Float32Array,\n\t\tbyteOffset: number,\n\t\tcb: UniformFunc | number | object,\n\t\toffset?: number\n\t) {\n\t\tsuper(uniformName, cb, offset);\n\t\tthis.value = undefined;\n\t\tthis._value = new Matrix2();\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, 4);\n\t\tthis.byteSize = 16;\n\t\tthis.type = \"mat2\";\n\t}\n\tset(): boolean {\n\t\tif (this.cb != undefined) this.value = this.getValue();\n\t\tconst v = this.value;\n\t\tif (v instanceof Matrix2) {\n\t\t\tif (Matrix2.equals(v, this._value)) return false;\n\t\t\tMatrix2.clone(v, this._value);\n\t\t\tthis.setBuffer(this._value.toArray());\n\t\t\treturn true;\n\t\t} else {\n\t\t\tif (this.equals(v)) return false;\n\t\t\tthis._value = v;\n\t\t\tthis.setBuffer(v);\n\t\t\treturn true;\n\t\t}\n\t}\n}\nexport class UniformMat3 extends Uniform<Matrix3> {\n\tstatic align = 16;\n\tconstructor(\n\t\tuniformName: string,\n\t\tbuffer: Float32Array,\n\t\tbyteOffset: number,\n\t\tcb: UniformFunc | number | object,\n\t\toffset?: number\n\t) {\n\t\tsuper(uniformName, cb, offset);\n\t\tthis.value = undefined;\n\t\tthis._value = new Matrix3();\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, 9);\n\t\tthis.byteSize = 48;\n\t\tthis.type = \"mat3\";\n\t}\n\tset(): boolean {\n\t\tif (this.cb != undefined) this.value = this.getValue();\n\t\tconst v = this.value;\n\t\tif (v instanceof Matrix3) {\n\t\t\tif (Matrix3.equals(v, this._value)) return false;\n\t\t\tMatrix3.clone(v, this._value);\n\t\t\tthis.setBuffer(this._value.toArray());\n\t\t\treturn true;\n\t\t} else {\n\t\t\tif (this.equals(v)) return false;\n\t\t\tthis._value = v;\n\t\t\tthis.setBuffer(v);\n\t\t\treturn true;\n\t\t}\n\t}\n}\nexport class UniformMat4 extends Uniform<Matrix4> {\n\tstatic align = 16;\n\tconstructor(\n\t\tuniformName: string,\n\t\tbuffer: Float32Array,\n\t\tbyteOffset: number,\n\t\tcb: UniformFunc | number | object,\n\t\toffset?: number\n\t) {\n\t\tsuper(uniformName, cb, offset);\n\t\tthis.value = undefined;\n\t\tthis._value = new Matrix4();\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, 16);\n\t\tthis.byteSize = 64;\n\t\tthis.type = \"mat4\";\n\t}\n\tset(): boolean {\n\t\tif (this.cb != undefined) this.value = this.getValue();\n\t\tconst v = this.value;\n\t\tif (v instanceof Matrix4) {\n\t\t\tif (Matrix4.equals(v, this._value)) return false;\n\t\t\tMatrix4.clone(v, this._value);\n\t\t\tthis.setBuffer(this._value.toArray());\n\t\t\treturn true;\n\t\t} else {\n\t\t\t// if(this.equals(v)) return false;\n\t\t\tthis._value = v;\n\t\t\tthis.setBuffer(v);\n\t\t\treturn true;\n\t\t}\n\t}\n}\nexport class UniformMatrix4Array extends Uniform<Array<Matrix4>> {\n\tstatic align = 16;\n\tconstructor(\n\t\tuniformName: string,\n\t\tbuffer: Float32Array,\n\t\tbyteOffset: number,\n\t\tcb: UniformFunc | number | object,\n\t\tcount?: number\n\t) {\n\t\tsuper(uniformName, cb, 0);\n\t\tthis.byteSize = count * 64;\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, this.byteSize / 4);\n\t\tthis.type = \"mat4-array\";\n\t}\n\tset(): boolean {\n\t\tthis.value = this.getValue();\n\t\tif (!this.value) return false;\n\t\tfor (let i = 0; i < this.value.length; i++) {\n\t\t\tthis.setBuffer(this.value[i].toArray(), i * 16);\n\t\t}\n\t\treturn true;\n\t}\n}\nexport class UniformFloatArray extends Uniform<Array<number>> {\n\tstatic align = 4;\n\t// cb: Function;\n\tconstructor(\n\t\tuniformName: string,\n\t\tbuffer: Float32Array,\n\t\tbyteOffset: number,\n\t\tcb: UniformFunc | number | object,\n\t\tcount?: number\n\t) {\n\t\tsuper(uniformName, cb, 0);\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, count);\n\t\tthis.byteSize = 4 * count;\n\t\tthis.type = \"float-array\";\n\t}\n\tset(): boolean {\n\t\tthis.value = this.getValue();\n\t\tfor (let i = 0; i < this.value.length; i++) {\n\t\t\tthis.buffer[i] = this.value[i];\n\t\t}\n\t\treturn true;\n\t}\n}\nexport class UniformVec2Array extends Uniform<Array<Vector2>> {\n\tstatic align = 8;\n\tconstructor(\n\t\tuniformName: string,\n\t\tbuffer: Float32Array,\n\t\tbyteOffset: number,\n\t\tcb: UniformFunc | number | object,\n\t\tcount?: number\n\t) {\n\t\tsuper(uniformName, cb, 0);\n\t\tthis.byteSize = count * 8;\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, this.byteSize / 4);\n\t\tthis.type = \"vec2-array\";\n\t}\n\tset(): boolean {\n\t\t// this.value = this.cb();\n\t\tthis.value = this.getValue();\n\t\tlet j = 0;\n\t\tfor (let i = 0; i < this.value.length; i++) {\n\t\t\tthis.buffer[j] = this.value[i].x;\n\t\t\tthis.buffer[j + 1] = this.value[i].y;\n\t\t\tj += 2;\n\t\t}\n\t\treturn true;\n\t}\n}\nexport class UniformVec3Array extends Uniform<Array<Vector3>> {\n\tstatic align = 16;\n\t// cb: Function;\n\tconstructor(\n\t\tuniformName: string,\n\t\tbuffer: Float32Array,\n\t\tbyteOffset: number,\n\t\tcb: UniformFunc | number | object,\n\t\tcount?: number\n\t) {\n\t\tsuper(uniformName, cb, 0);\n\t\tthis.byteSize = count * 16;\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, this.byteSize / 4);\n\t\tthis.type = \"vec3-array\";\n\t}\n\tset(): boolean {\n\t\t// this.value = this.cb();\n\t\tthis.value = this.getValue();\n\t\tlet j = 0;\n\t\tfor (let i = 0; i < this.value.length; i++) {\n\t\t\tthis.buffer[j] = this.value[i].x;\n\t\t\tthis.buffer[j + 1] = this.value[i].y;\n\t\t\tthis.buffer[j + 2] = this.value[i].z;\n\t\t\tthis.buffer[j + 3] = 0;\n\t\t\tj += 4;\n\t\t}\n\t\treturn true;\n\t}\n}\nexport class UniformVec4Array extends Uniform<Array<Vector4>> {\n\tstatic align = 16;\n\t// cb: Function;\n\tconstructor(\n\t\tuniformName: string,\n\t\tbuffer: Float32Array,\n\t\tbyteOffset: number,\n\t\tcb: UniformFunc | number | object,\n\t\tcount?: number\n\t) {\n\t\tsuper(uniformName, cb, 0);\n\t\tthis.byteSize = count * 16;\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, this.byteSize / 4);\n\t\tthis.type = \"vec4-array\";\n\t}\n\tset(): boolean {\n\t\tthis.value = this.getValue();\n\t\tlet j = 0;\n\t\tfor (let i = 0; i < this.value.length; i++) {\n\t\t\tthis.buffer[j] = this.value[i].x;\n\t\t\tthis.buffer[j + 1] = this.value[i].y;\n\t\t\tthis.buffer[j + 2] = this.value[i].z;\n\t\t\tthis.buffer[j + 3] = this.value[i].w;\n\t\t\tj += 4;\n\t\t}\n\t\treturn true;\n\t}\n}\nexport class UniformTexture extends Uniform<Texture> {\n\tpublic binding: number;\n\tpublic type: string;\n\tpublic visibility: ShaderStage;\n\tpublic name: string;\n\tpublic texture: Texture;\n\tpublic isTexture: boolean;\n\tpublic textureView?: GPUTextureView;\n\tprivate _texture: UniformFunc | Texture;\n\tconstructor(\n\t\tuniformName: string,\n\t\tbinding: number,\n\t\ttexture: UniformFunc | Texture,\n\t\ttype?: string,\n\t\tvisibility?: ShaderStage,\n\t\ttextureView?: GPUTextureView\n\t) {\n\t\tsuper(uniformName, undefined, 0);\n\t\tthis.binding = binding;\n\t\tthis.visibility = defaultValue(visibility, ShaderStage.Vertex | ShaderStage.Fragment);\n\t\tthis.textureView = textureView;\n\t\tthis.type = type ?? \"texture\";\n\t\tthis.isTexture = true;\n\t\tthis._texture = texture;\n\t}\n\tget layoutType() {\n\t\treturn this.texture?.layoutType || \"not yet bind\";\n\t}\n\tget storageTextureLayoutType() {\n\t\treturn this.texture?.storageTextureLayoutType || \"not yet bind\";\n\t}\n\tbind(device: GPUDevice) {\n\t\tif (!this._texture) return;\n\t\tthis.texture = this._texture instanceof Function ? this._texture() : this._texture;\n\t\tthis.texture.update(device);\n\t}\n}\nexport class UniformSampler extends Uniform<Sampler> {\n\tpublic binding: number;\n\tpublic type: string;\n\tpublic visibility: ShaderStage;\n\tpublic name: string;\n\tpublic sampler: Sampler;\n\tpublic isSampler: boolean;\n\tprivate _sampler: UniformFunc | Sampler;\n\tconstructor(uniformName: string, binding: number, sampler: UniformFunc | Sampler, visibility?: ShaderStage) {\n\t\tsuper(uniformName, undefined, 0);\n\t\tthis.visibility = defaultValue(visibility, ShaderStage.Vertex | ShaderStage.Fragment);\n\t\tthis.name = uniformName;\n\t\tthis.binding = binding;\n\t\tthis.type = \"sampler\";\n\t\tthis.isSampler = true;\n\t\tthis._sampler = sampler;\n\t}\n\tget layoutType() {\n\t\treturn this.sampler?.layoutType || \"not yet bind\";\n\t}\n\tbind(device: GPUDevice) {\n\t\tthis.sampler = this._sampler instanceof Function ? this._sampler() : this._sampler;\n\t\tthis.sampler.update(device);\n\t}\n}\nexport class UniformStructArray extends Uniform<UniformStruct> {\n\tstatic align = 16;\n\tstatic aligns = {\n\t\t[UniformEnum.UniformUint]: 4,\n\t\t[UniformEnum.Float]: 4,\n\t\t[UniformEnum.FloatVec2]: 8,\n\t\t[UniformEnum.FloatVec3]: 16,\n\t\t[UniformEnum.FloatVec4]: 16,\n\t\t[UniformEnum.Mat2]: 8,\n\t\t[UniformEnum.Mat3]: 16,\n\t\t[UniformEnum.Mat4]: 16,\n\t\t[UniformEnum.Color]: 16\n\t};\n\tstatic byteSizes = {\n\t\t[UniformEnum.UniformUint]: 4,\n\t\t[UniformEnum.Float]: 4,\n\t\t[UniformEnum.FloatVec2]: 8,\n\t\t[UniformEnum.FloatVec3]: 12,\n\t\t[UniformEnum.FloatVec4]: 16,\n\t\t[UniformEnum.Mat2]: 16,\n\t\t[UniformEnum.Mat3]: 48,\n\t\t[UniformEnum.Mat4]: 64,\n\t\t[UniformEnum.Color]: 12\n\t};\n\tbyteOffset?: number;\n\tsourceBuffer?: Float32Array;\n\tstructArray?: Array<UniformStruct>;\n\tconstructor(\n\t\tuniformName: string,\n\t\tbuffer: Float32Array,\n\t\tbyteOffset: number,\n\t\tcb: UniformFunc | number | object,\n\t\toffset?: number\n\t) {\n\t\tsuper(uniformName, cb, offset);\n\t\tthis.cb = cb;\n\t\tthis.type = \"struct-array\";\n\t\tthis.dirty = false;\n\t\tthis.byteOffset = byteOffset;\n\t\tthis.sourceBuffer = buffer;\n\t}\n\tset() {\n\t\t//\n\t\tthis.structArray = this.getValue();\n\t\tthis.byteSize = this.getStructSize();\n\t\tthis.buffer = new Float32Array(this.sourceBuffer.buffer, this.byteOffset, this.byteSize / 4);\n\t\tthis.setSubData();\n\t\treturn true;\n\t}\n\tprivate setSubData() {\n\t\tthis.structArray.forEach((struct) => {\n\t\t\tconst keys = Object.keys(struct);\n\t\t\tkeys.forEach((key) => {\n\t\t\t\tconst data = Array.isArray(struct[key]?.value)\n\t\t\t\t\t? struct[key]?.value\n\t\t\t\t\t: (struct[key]?.value as any).toArray();\n\t\t\t\tsetDataToTypeArray(this.buffer, data, struct[key].offset);\n\t\t\t});\n\t\t});\n\t}\n\tprivate getStructSize() {\n\t\tlet byteOffset = 0;\n\t\tthis.structArray.forEach((struct) => {\n\t\t\tconst keys = Object.keys(struct);\n\t\t\tkeys.forEach((key) => {\n\t\t\t\tbyteOffset += UniformBuffer.checkUniformOffset(byteOffset, UniformStructArray.aligns[struct[key].type]);\n\t\t\t\tstruct[key].offset = byteOffset;\n\t\t\t\tthis.byteOffset += UniformStructArray.byteSizes[struct[key].type];\n\t\t\t});\n\t\t});\n\t\treturn byteOffset;\n\t}\n}\nexport class UniformSpotLights extends Uniform<SpotLight> {\n\tstatic align = 16;\n\tlights: Array<SpotLight>;\n\t// cb: Function;\n\tconstructor(\n\t\tuniformName: string,\n\t\tbuffer: Float32Array,\n\t\tbyteOffset: number,\n\t\tcb: UniformFunc | number | object,\n\t\tcount?: number\n\t) {\n\t\tsuper(uniformName, cb, 0);\n\t\tthis.cb = cb;\n\t\tthis.byteSize = count * 64;\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, this.byteSize / 4);\n\t\tthis.type = \"spotsLight\";\n\t\tthis.dirty = false;\n\t}\n\tset() {\n\t\tthis.lights = this.getValue();\n\t\tthis.lights.forEach((spotLight, index) => {\n\t\t\tthis.setSubData(spotLight, index);\n\t\t});\n\t\treturn this.dirty;\n\t}\n\tprivate setSubData(spotLight: SpotLight, index: number) {\n\t\tconst offset = index * 16;\n\t\tif (spotLight.positionDirty) {\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, spotLight.position.toArray(), offset + 0); // byteOffset=0;\n\t\t}\n\t\tif (spotLight.distanceDirty) {\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, spotLight.distance, offset + 3); // byteOffset=12;\n\t\t}\n\t\tif (spotLight.dirtectDirty) {\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, spotLight.directional.toArray(), offset + 4); // byteOffset=16;\n\t\t}\n\t\tif (spotLight.coneCosDirty) {\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, spotLight.coneCos, offset + 7); // byteOffset=28;\n\t\t}\n\t\tif (spotLight.colorDirty) {\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, spotLight.color.toArray(), offset + 8); // byteOffset=32;\n\t\t}\n\t\tif (spotLight.penumbraCosDirty) {\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, spotLight.penumbraCos, offset + 11); // byteOffset=44;\n\t\t}\n\t\tif (spotLight.decayDirty) {\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, spotLight.decay, offset + 12); // byteOffset=48;\n\t\t}\n\n\t\tspotLight.positionDirty = false;\n\t\tspotLight.distanceDirty = false;\n\t\tspotLight.dirtectDirty = false;\n\t\tspotLight.coneCosDirty = false;\n\t\tspotLight.colorDirty = false;\n\t\tspotLight.penumbraCosDirty = false;\n\t\tspotLight.decayDirty = false;\n\t}\n}\n\nexport class UniformSpotLightShadows extends Uniform<SpotLight> {\n\tstatic align = 16;\n\tstatic uniformSize = 18;\n\tlights: Array<SpotLight>;\n\t// cb: Function;\n\tprivate _nearValue: number;\n\tprivate _farValue: number;\n\tprivate _subDataSize: number;\n\n\tconstructor(\n\t\tuniformName: string,\n\t\tbuffer: Float32Array,\n\t\tbyteOffset: number,\n\t\tcb: UniformFunc | number | object,\n\t\tcount?: number\n\t) {\n\t\tsuper(uniformName, cb, 0);\n\t\tconst bytesPerElement = Float32Array.BYTES_PER_ELEMENT;\n\t\tthis._subDataSize = UniformSpotLightShadows.uniformSize;\n\t\tthis.byteSize = count * this._subDataSize * bytesPerElement;\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, this.byteSize / 4);\n\t\tthis.type = \"spotLightShadows\";\n\t\tthis._nearValue = null;\n\t\tthis._farValue = null;\n\t}\n\tset() {\n\t\tthis.lights = this.getValue();\n\t\tthis.lights.forEach((spotLight, index) => {\n\t\t\tthis.setSubData(spotLight, index);\n\t\t});\n\t\treturn this.dirty;\n\t}\n\tprivate setSubData(spotLight: SpotLight, index: number) {\n\t\tconst offset = index * this._subDataSize;\n\t\tif (spotLight.shadow.vpMatrixDirty) {\n\t\t\tspotLight.shadow.vpMatrixDirty = false;\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, spotLight.shadow.camera.vpMatrix.toArray(), offset + 0); // byteOffset=0;\n\t\t}\n\t\tconst nearValue = spotLight.shadow.camera.near;\n\t\tif (nearValue != this._nearValue) {\n\t\t\tthis._nearValue = nearValue;\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, this._nearValue, offset + 16); // byteOffset=0;\n\t\t}\n\t\tconst farValue = spotLight.shadow.camera.far;\n\t\tif (farValue != this._farValue) {\n\t\t\tthis._farValue = farValue;\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, this._farValue, offset + 17); // byteOffset=0;\n\t\t}\n\t}\n}\nexport class UniformPointLights extends Uniform<PointLight> {\n\tstatic align = 16;\n\tlights: Array<PointLight>;\n\t// cb: Function;\n\tconstructor(\n\t\tuniformName: string,\n\t\tbuffer: Float32Array,\n\t\tbyteOffset: number,\n\t\tcb: UniformFunc | number | object,\n\t\tcount?: number\n\t) {\n\t\tsuper(uniformName, cb, 0);\n\t\tthis.byteSize = count * 32;\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, this.byteSize / 4);\n\t\tthis.type = \"pointsLight\";\n\t}\n\tset() {\n\t\tthis.lights = this.getValue();\n\t\tthis.lights.forEach((pointLight, index) => {\n\t\t\tthis.setSubData(pointLight, index);\n\t\t});\n\t\treturn this.dirty;\n\t}\n\tprivate setSubData(pointLight: PointLight, index: number) {\n\t\tconst offset = index * 8;\n\t\tif (pointLight.positionDirty) {\n\t\t\tpointLight.positionDirty = false;\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, pointLight.position.toArray(), offset + 0); // byteOffset=0;\n\t\t}\n\t\tif (pointLight.distanceDirty) {\n\t\t\tpointLight.distanceDirty = false;\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, pointLight.distance, offset + 3); // byteOffset=12;\n\t\t}\n\t\tif (pointLight.colorDirty) {\n\t\t\tpointLight.colorDirty = false;\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, pointLight.color.toArray(), offset + 4); // byteOffset=32;\n\t\t}\n\t\tif (pointLight.decayDirty) {\n\t\t\tpointLight.decayDirty = false;\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, pointLight.decay, offset + 7); // byteOffset=12;\n\t\t}\n\t}\n}\n\nexport class UniformPointLightShadows extends Uniform<PointLight> {\n\tstatic align = 16;\n\tstatic uniformSize = 122;\n\tlights: Array<PointLight>;\n\t// cb: Function;\n\tprivate _nearValue: number;\n\tprivate _farValue: number;\n\tprivate _subDataSize: number;\n\n\tconstructor(\n\t\tuniformName: string,\n\t\tbuffer: Float32Array,\n\t\tbyteOffset: number,\n\t\tcb: UniformFunc | number | object,\n\t\tcount?: number\n\t) {\n\t\tsuper(uniformName, cb, 0);\n\t\tconst bytesPerElement = Float32Array.BYTES_PER_ELEMENT;\n\t\tthis._subDataSize = UniformPointLightShadows.uniformSize;\n\t\tthis.byteSize = count * bytesPerElement * this._subDataSize;\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, this.byteSize / 4);\n\t\tthis.type = \"pointLightShadows\";\n\t\tthis._nearValue = null;\n\t\tthis._farValue = null;\n\t}\n\tset() {\n\t\tthis.lights = this.getValue();\n\t\tthis.lights.forEach((pointLight, index) => {\n\t\t\tthis.setSubData(pointLight, index);\n\t\t});\n\t\treturn this.dirty;\n\t}\n\tprivate setSubData(pointLight: PointLight, index: number) {\n\t\tconst offset = index * this._subDataSize;\n\n\t\tif (pointLight.shadow.vpMatrixArrayDirty) {\n\t\t\tpointLight.shadow.vpMatrixArrayDirty = false;\n\t\t\tconst vpMatrixArray = pointLight.shadow.camera.vpMatrixArray;\n\t\t\tfor (let i = 0; i < vpMatrixArray.length; i++) {\n\t\t\t\tconst vpMatrix = vpMatrixArray[i];\n\t\t\t\tthis.dirty = setDataToTypeArray(this.buffer, vpMatrix.toArray(), offset + 0 + 16 * i); // byteOffset=98 * 4;\n\t\t\t}\n\t\t}\n\n\t\tif (pointLight.shadow.viewPortDirty) {\n\t\t\tpointLight.shadow.viewPortDirty = false;\n\t\t\tfor (let i = 0; i < 6; i++) {\n\t\t\t\tthis.dirty = setDataToTypeArray(\n\t\t\t\t\tthis.buffer,\n\t\t\t\t\tpointLight.shadow.viewports[i].toArray(),\n\t\t\t\t\toffset + 96 + 4 * i\n\t\t\t\t); // byteOffset=0;\n\t\t\t}\n\t\t}\n\n\t\tconst nearValue = pointLight.shadow.camera.near;\n\t\tif (nearValue != this._nearValue) {\n\t\t\tthis._nearValue = nearValue;\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, this._nearValue, offset + 120); // byteOffset=0;\n\t\t}\n\t\tconst farValue = pointLight.shadow.camera.far;\n\t\tif (farValue != this._farValue) {\n\t\t\tthis._farValue = farValue;\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, this._farValue, offset + 121); // byteOffset=1;\n\t\t}\n\t}\n}\nexport class UniformDirtectLights extends Uniform<DirectionalLight> {\n\tstatic align = 16;\n\tlights: Array<DirectionalLight>;\n\tconstructor(\n\t\tuniformName: string,\n\t\tbuffer: Float32Array,\n\t\tbyteOffset: number,\n\t\tcb: UniformFunc | number | object,\n\t\tcount?: number\n\t) {\n\t\tsuper(uniformName, cb, 0);\n\t\tthis.cb = cb;\n\t\tthis.byteSize = count * 32;\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, this.byteSize / 4);\n\t\tthis.type = \"dirtectLights\";\n\t}\n\tset() {\n\t\tthis.lights = this.getValue();\n\t\tthis.lights.forEach((directionalLight, index) => {\n\t\t\tthis.setSubData(directionalLight, index);\n\t\t});\n\t\treturn this.dirty;\n\t}\n\tprivate setSubData(directionalLight: DirectionalLight, index: number) {\n\t\tconst offset = index * 8;\n\t\tif (directionalLight.dirtectDirty) {\n\t\t\tdirectionalLight.dirtectDirty = false;\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, directionalLight.directional.toArray(), offset + 0); // byteOffset=16;\n\t\t}\n\t\tif (directionalLight.colorDirty) {\n\t\t\tdirectionalLight.colorDirty = false;\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, directionalLight.color.toArray(), offset + 4); // byteOffset=32;\n\t\t}\n\t}\n}\n\nexport class UniformDirtectLightShadows extends Uniform<DirectionalLight> {\n\tstatic align = 16;\n\tstatic uniformSize = 16;\n\tlights: Array<DirectionalLight>;\n\tprivate _subDataSize: number;\n\n\tconstructor(\n\t\tuniformName: string,\n\t\tbuffer: Float32Array,\n\t\tbyteOffset: number,\n\t\tcb: UniformFunc | number | object,\n\t\tcount?: number\n\t) {\n\t\tsuper(uniformName, cb, 0);\n\t\tconst bytesPerElement = Float32Array.BYTES_PER_ELEMENT;\n\t\tthis._subDataSize = UniformDirtectLightShadows.uniformSize;\n\t\tthis.byteSize = count * bytesPerElement * this._subDataSize;\n\t\tthis.buffer = new Float32Array(buffer.buffer, byteOffset, this.byteSize / 4);\n\t\tthis.type = \"dirtectLightShadows\";\n\t}\n\tset() {\n\t\tthis.lights = this.getValue();\n\t\tthis.lights.forEach((directionalLight, index) => {\n\t\t\tthis.setSubData(directionalLight, index);\n\t\t});\n\t\treturn this.dirty;\n\t}\n\tprivate setSubData(directionalLight: DirectionalLight, index: number) {\n\t\tconst offset = index * this._subDataSize;\n\t\tif (directionalLight.shadow.vpMatrixDirty) {\n\t\t\tdirectionalLight.shadow.vpMatrixDirty = false;\n\t\t\tthis.dirty = setDataToTypeArray(this.buffer, directionalLight.shadow.camera.vpMatrix.toArray(), offset + 0); // byteOffset=16;\n\t\t}\n\t}\n}\nfunction setDataToTypeArray(buffer, data, offset) {\n\tif (Array.isArray(data)) {\n\t\tdata.forEach((value, index) => {\n\t\t\tbuffer[index + offset] = value;\n\t\t});\n\t} else {\n\t\tbuffer[offset] = data;\n\t}\n\treturn true;\n}\n","import { BufferBindingType, BufferUsage, ShaderStage } from \"../core/WebGPUConstant\";\nimport { UniformFunc, UniformEnum } from \"../core/WebGPUTypes\";\nimport defaultValue from \"../utils/defaultValue\";\nimport Buffer from \"./Buffer\";\n\nimport {\n\tUniform,\n\tUniformColor,\n\tUniformDirtectLights,\n\tUniformDirtectLightShadows,\n\tUniformFloat,\n\tUniformFloatArray,\n\tUniformFloatVec2,\n\tUniformFloatVec3,\n\tUniformFloatVec4,\n\tUniformMat2,\n\tUniformMat3,\n\tUniformMat4,\n\tUniformMatrix4Array,\n\tUniformPointLights,\n\tUniformPointLightShadows,\n\tUniformSpotLights,\n\tUniformSpotLightShadows,\n\tUniformUint,\n\tUniformVec2Array,\n\tUniformVec3Array,\n\tUniformVec4Array,\n\tUniformStructArray\n} from \"./Uniforms\";\nexport default class UniformBuffer {\n\tpublic type: string;\n\tpublic hasDynamicOffset: boolean;\n\tpublic minBindingSize: number;\n\tprivate _uniformStruct: Map<string, Uniform<any>>;\n\tprivate _bufferSize: number;\n\tprivate label: string;\n\tpublic byteOffset: number;\n\tpublic uniformDirty: boolean;\n\tpublic binding: number;\n\tpublic visibility: ShaderStage;\n\tpublic usage: BufferUsage;\n\tpublic buffer: Buffer;\n\tpublic dataBuffer: Float32Array;\n\tpublic offset: number;\n\tpublic maxOffset: number;\n\tpublic isUniformBuffer: boolean;\n\tpublic name: string;\n\tprivate static UniformType = {\n\t\t[UniformEnum.UniformUint]: UniformUint,\n\t\t[UniformEnum.Float]: UniformFloat,\n\t\t[UniformEnum.FloatVec2]: UniformFloatVec2,\n\t\t[UniformEnum.FloatVec3]: UniformFloatVec3,\n\t\t[UniformEnum.FloatVec4]: UniformFloatVec4,\n\t\t[UniformEnum.Mat2]: UniformMat2,\n\t\t[UniformEnum.Mat3]: UniformMat3,\n\t\t[UniformEnum.Mat4]: UniformMat4,\n\t\t[UniformEnum.Color]: UniformColor,\n\t\t[UniformEnum.FloatArray]: UniformFloatArray,\n\t\t[UniformEnum.Vec2Array]: UniformVec2Array,\n\t\t[UniformEnum.Vec3Array]: UniformVec3Array,\n\t\t[UniformEnum.Vec4Array]: UniformVec4Array,\n\t\t[UniformEnum.Mat4Array]: UniformMatrix4Array,\n\t\t[UniformEnum.PointLights]: UniformPointLights,\n\t\t[UniformEnum.SpotLights]: UniformSpotLights,\n\t\t[UniformEnum.DirtectLights]: UniformDirtectLights,\n\t\t[UniformEnum.PointLightShadows]: UniformPointLightShadows,\n\t\t[UniformEnum.SpotLightShadows]: UniformSpotLightShadows,\n\t\t[UniformEnum.DirtectLightShadows]: UniformDirtectLightShadows,\n\t\t[UniformEnum.UniformStructArray]: UniformStructArray\n\t};\n\tconstructor(options: UniformBufferParams) {\n\t\tthis.type = defaultValue(options.type, \"uniform\");\n\t\tthis.label = defaultValue(options.label, \"\");\n\t\tthis.name = defaultValue(options.label, \"\");\n\t\tthis.hasDynamicOffset = options.hasDynamicOffset ?? false;\n\t\tthis.minBindingSize = options.minBindingSize ?? 0;\n\t\tthis.binding = options.binding ?? 0;\n\t\tthis.visibility = defaultValue(options.visibility, ShaderStage.Fragment | ShaderStage.Vertex);\n\t\tthis.usage = defaultValue(options.usage, BufferUsage.Uniform | BufferUsage.CopyDst);\n\t\tthis._uniformStruct = new Map();\n\t\tthis.uniformDirty = true;\n\t\tthis._bufferSize = options.size;\n\t\tthis.buffer = options.buffer;\n\t\tthis.offset = 0;\n\t\tthis.dataBuffer = defaultValue(options.dataBuffer, new Float32Array(defaultValue(this._bufferSize, 400)));\n\t\tthis.byteOffset = 0;\n\t\tthis.isUniformBuffer = true;\n\t\tthis.maxOffset = options.maxOffset ?? 0;\n\t}\n\tget layoutType() {\n\t\treturn {\n\t\t\ttype: this.type,\n\t\t\thasDynamicOffset: this.hasDynamicOffset,\n\t\t\tminBindingSize: this.minBindingSize\n\t\t};\n\t}\n\tget bufferSize() {\n\t\treturn this._bufferSize ?? this.uniformsSize * 4;\n\t}\n\tget uniformsSize() {\n\t\t// https://gpuweb.github.io/gpuweb/wgsl/#address-space-layout-constraints\n\t\treturn this._bufferSize != undefined ? this._bufferSize / 4 : Math.ceil(this.byteOffset / 16) * 16;\n\t}\n\tbind(device: GPUDevice) {\n\t\tthis._uniformStruct.forEach((uniform) => {\n\t\t\tconst result = uniform.set();\n\t\t\tif (uniform?.dirty != undefined) uniform.dirty = false;\n\t\t\tif (result != undefined && this.uniformDirty == false) this.uniformDirty = result;\n\t\t});\n\t\tif (this.uniformDirty) {\n\t\t\tthis.uniformDirty = false;\n\t\t\tif (!this.buffer) this.buffer = Buffer.createUniformBuffer(this.label, device, this.bufferSize, this.usage);\n\t\t\tif (this.type != BufferBindingType.Storage)\n\t\t\t\tthis.buffer.setSubData(\n\t\t\t\t\t0,\n\t\t\t\t\tthis.dataBuffer.slice(0, defaultValue(this?.bufferSize / 4, this.uniformsSize))\n\t\t\t\t);\n\t\t}\n\t}\n\tpublic getUniformBufferStruct() {\n\t\tlet uniformStruct = `struct MaterialUniform {\\n `;\n\t\tthis._uniformStruct.forEach((uniform) => {\n\t\t\tuniformStruct += this.createUniformString(uniform);\n\t\t});\n\t\tuniformStruct += `}\\n`;\n\t\treturn uniformStruct;\n\t}\n\tprivate createUniformString(uniform) {\n\t\tlet result = ``;\n\t\tswitch (uniform.type) {\n\t\t\tcase \"vec1\":\n\t\t\t\tresult = `${uniform.name} :f32,\\n`;\n\t\t\t\tbreak;\n\t\t\tcase \"vec2\":\n\t\t\t\tresult = `${uniform.name} :vec2<f32>,\\n`;\n\t\t\t\tbreak;\n\t\t\tcase \"vec3\":\n\t\t\t\tresult = `${uniform.name} :vec3<f32>,\\n`;\n\t\t\t\tbreak;\n\t\t\tcase \"vec4\":\n\t\t\t\tresult = `${uniform.name} :vec4<f32>,\\n`;\n\t\t\t\tbreak;\n\t\t\tcase \"mat2\":\n\t\t\t\tresult = `${uniform.name} :mat2x2<f32>,\\n`;\n\t\t\t\tbreak;\n\t\t\tcase \"mat3\":\n\t\t\t\tresult = `${uniform.name} :mat3x3<f32>,\\n`;\n\t\t\t\tbreak;\n\t\t\tcase \"mat4\":\n\t\t\t\tresult = `${uniform.name} :mat4x4<f32>,\\n`;\n\t\t\t\tbreak;\n\t\t}\n\t\treturn result;\n\t}\n\tcontains(name: string): Uniform<any> {\n\t\treturn this._uniformStruct.get(name);\n\t}\n\treplaceUniformValue(name: string, value: UniformFunc | number | object) {\n\t\tconst uniform = this._uniformStruct.get(name);\n\t\tif (!uniform) return;\n\t\tuniform.cb = value;\n\t}\n\t// uniformBuffer.setVec3Array('test',()=>{return [new Vector3(1,0,0),new Vector3(1,0.8,0.5)]},2);\n\t// uniformBuffer.setFloatArray('test1',()=>{return [0.5,0.5,1.0]},3);\n\t// uniformBuffer.setVec4Array('test4',()=>{return [new Vector4(0.5,0.6,0.2,1.0),new Vector4(0.5,0.8,0.8,1.0)]},2);\n\t// uniformBuffer.setVec2Array('test2',()=>{return [new Vector2(0.5,0.6),new Vector2(0.5,0.8,)]},2);\n\tsetUniform(name: string, value: UniformFunc | number | object, uniformType: UniformEnum, count?: number) {\n\t\tif (this._uniformStruct.get(name)) return;\n\t\tconst TypeUniform = UniformBuffer.UniformType[uniformType];\n\t\tthis.byteOffset += UniformBuffer.checkUniformOffset(this.byteOffset, TypeUniform.align);\n\t\tconst uniform =\n\t\t\tcount != undefined\n\t\t\t\t? new TypeUniform(name, this.dataBuffer, this.byteOffset, value, count)\n\t\t\t\t: new TypeUniform(name, this.dataBuffer, this.byteOffset, value);\n\t\tthis._uniformStruct.set(name, uniform);\n\t\tthis.byteOffset += uniform.byteSize;\n\t}\n\tstatic checkUniformOffset(byteSize: number, Align: number): number {\n\t\t// from https://gpuweb.github.io/gpuweb/wgsl/#address-space-layout-constraints\n\t\t// return this.hasDynamicOffset\n\t\t// \t? Math.ceil(byteSize / 256) * 256 - byteSize\n\t\t// \t: Math.ceil(byteSize / Align) * Align - byteSize;\n\t\treturn Math.ceil(byteSize / Align) * Align - byteSize;\n\t}\n\tdestroy() {\n\t\tthis?.buffer?.destroy();\n\t}\n}\ntype UniformBufferParams = {\n\tlabel: string;\n\ttype?: string;\n\tusage?: BufferUsage;\n\tsize?: number;\n\tdataBuffer?: Float32Array;\n\tbinding?: number;\n\thasDynamicOffset?: boolean;\n\tminBindingSize?: number;\n\tmaxOffset?: number;\n\tbuffer?: Buffer;\n\tvisibility?: ShaderStage;\n};\n","// import Color from \"../../math/Color\";\r\n\r\nexport default function colorFrag(defines) {\r\n  return `\r\n    struct VertexOutput {\r\n        @builtin(position) position: vec4<f32>,\r\n        @location(0) color: vec4<f32>,\r\n    };\r\n    @fragment\r\n    fn main(input:VertexOutput) -> @location(0) vec4<f32> {\r\n      return input.color;\r\n    }\r\n    `;\r\n}\r\n","export default function colorVert(defines) {\n\treturn `\n   struct VertexInput {\n        @location(${defines.positionLocation}) position: vec3<f32>,       \n        @location(${defines.colorLocation}) color: vec4<f32>,\n   }\n   struct VertexOutput {\n        @builtin(position) position: vec4<f32>,\n        @location(0) color: vec4<f32>,\n    };\n   struct SelfUniform {\n      modelMatrix: mat4x4<f32>,\n   }\n   struct SystemUniform {\n      projectionMatrix: mat4x4<f32>,\n      viewMatrix: mat4x4<f32>,\n      inverseViewMatrix: mat4x4<f32>,\n      cameraPosition: vec3<f32>,\n   }; \n   @binding(${defines.colorBinding}) @group(0) var<uniform> selfUniform : SelfUniform;\n   @binding(${defines.cameraBinding}) @group(1) var<uniform> systemUniform : SystemUniform;\n   @vertex\n   fn main(input: VertexInput) -> VertexOutput {\n    var output:VertexOutput;\n    output.color=input.color;\n    output.position = systemUniform.projectionMatrix * systemUniform.viewMatrix *selfUniform.modelMatrix*vec4<f32>(input.position,1.0);\n    return output;\n   }\n   `;\n}\n","const preprocessorSymbols = /#([^\\s]*)(\\s*)/gm;\n// Template literal tag that handles simple preprocessor symbols for WGSL\n// shaders. Supports #if/elif/else/endif statements.\nexport function wgslParseDefines(strings, ...values) {\n\tconst stateStack = [];\n\tlet state = { frag: \"\", elseIsValid: false, expression: true };\n\tlet depth = 1;\n\n\tfor (let i = 0; i < strings.length; ++i) {\n\t\tconst frag = strings[i];\n\t\tconst matchedSymbols = frag.matchAll(preprocessorSymbols);\n\n\t\tlet lastIndex = 0;\n\t\tlet valueConsumed = false;\n\n\t\tfor (const match of matchedSymbols) {\n\t\t\tstate.frag += frag.substring(lastIndex, match.index);\n\n\t\t\tswitch (match[1]) {\n\t\t\t\tcase \"if\":\n\t\t\t\t\tif (match.index + match[0].length != frag.length) {\n\t\t\t\t\t\tthrow new Error(\"#if must be immediately followed by a template expression (ie: ${value})\");\n\t\t\t\t\t}\n\t\t\t\t\tvalueConsumed = true;\n\t\t\t\t\tstateStack.push(state);\n\t\t\t\t\tdepth++;\n\t\t\t\t\tstate = { frag: \"\", elseIsValid: true, expression: !!values[i] };\n\t\t\t\t\tbreak;\n\t\t\t\tcase \"elif\":\n\t\t\t\t\tif (match.index + match[0].length != frag.length) {\n\t\t\t\t\t\tthrow new Error(\"#elif must be immediately followed by a template expression (ie: ${value})\");\n\t\t\t\t\t} else if (!state.elseIsValid) {\n\t\t\t\t\t\tthrow new Error(\"#elif not preceeded by an #if or #elif\");\n\t\t\t\t\t}\n\t\t\t\t\tvalueConsumed = true;\n\t\t\t\t\tif (state.expression && stateStack.length != depth) {\n\t\t\t\t\t\tstateStack.push(state);\n\t\t\t\t\t}\n\t\t\t\t\tstate = { frag: \"\", elseIsValid: true, expression: !!values[i] };\n\t\t\t\t\tbreak;\n\t\t\t\tcase \"else\":\n\t\t\t\t\tif (!state.elseIsValid) {\n\t\t\t\t\t\tthrow new Error(\"#else not preceeded by an #if or #elif\");\n\t\t\t\t\t}\n\t\t\t\t\tif (state.expression && stateStack.length != depth) {\n\t\t\t\t\t\tstateStack.push(state);\n\t\t\t\t\t}\n\t\t\t\t\tstate = { frag: match[2], elseIsValid: false, expression: true };\n\t\t\t\t\tbreak;\n\t\t\t\tcase \"endif\":\n\t\t\t\t\tif (!stateStack.length) {\n\t\t\t\t\t\tthrow new Error(\"#endif not preceeded by an #if\");\n\t\t\t\t\t}\n\t\t\t\t\tconst branchState = stateStack.length == depth ? stateStack.pop() : state;\n\t\t\t\t\tstate = stateStack.pop();\n\t\t\t\t\tdepth--;\n\t\t\t\t\tif (branchState.expression) {\n\t\t\t\t\t\tstate.frag += branchState.frag;\n\t\t\t\t\t}\n\t\t\t\t\tstate.frag += match[2];\n\t\t\t\t\tbreak;\n\t\t\t\tdefault:\n\t\t\t\t\t// Unknown preprocessor symbol. Emit it back into the output frag unchanged.\n\t\t\t\t\tstate.frag += match[0];\n\t\t\t\t\tbreak;\n\t\t\t}\n\n\t\t\tlastIndex = match.index + match[0].length;\n\t\t}\n\n\t\t// If the frag didn't end on one of the preprocessor symbols append the rest of it here.\n\t\tif (lastIndex != frag.length) {\n\t\t\tstate.frag += frag.substring(lastIndex, frag.length);\n\t\t}\n\n\t\t// If the next value wasn't consumed by the preprocessor symbol, append it here.\n\t\tif (!valueConsumed && values.length > i) {\n\t\t\tstate.frag += values[i];\n\t\t}\n\t}\n\n\tif (stateStack.length) {\n\t\tthrow new Error(\"Mismatched #if/#endif count\");\n\t}\n\n\treturn state.frag;\n}\n","import { wgslParseDefines } from \"../WgslPreprocessor\";\nexport default function pbr_fs(defines) {\n\treturn wgslParseDefines`\n        // reference: https://github.com/KhronosGroup/glTF-WebGL-PBR/blob/master/shaders/pbr-frag.glsl\n        #include <pbrUtils>\n        #include <light>\n        #include <brdf>\n        #include <PbrMaterialStruct>\n        #include <SystemUniform> \n        #include <FragInput>   \n        struct PhysicalMaterial {\n            diffuseColor:vec3<f32>,\n            roughness:f32,\n            specularColor:vec3<f32>,\n           #if ${defines.USE_CLEARCOAT}\n               clearcoat:f32,\n               clearcoatRoughness:f32,\n               clearcoatF0:vec3<f32>,\n               clearcoatF90:f32,\n           #endif\n\n           #if ${defines.USE_IRIDESCENCE}\n               iridescence:f32,\n               iridescenceIOR:f32,\n               iridescenceThickness:f32,\n               iridescenceFresnel:vec3<f32>,\n               iridescenceF0:vec3<f32>,\n           #endif\n\n           #if ${defines.USE_SHEEN}\n               sheenColor:vec3<f32>,\n               sheenRoughness:f32,\n           #endif\n\n           #if ${defines.IOR}\n                ior:f32,\n           #endif\n\n           #if ${defines.USE_TRANSMISSION}\n               transmission:f32,\n               transmissionAlpha:f32,\n               thickness:f32,\n               attenuationDistance:f32,\n               attenuationColor:vec3<f32>,\n           #endif\n       };\n        const M_PI:f32 = 3.141592653589793;\n        const c_MinRoughness:f32 = 0.04;\n        #include <TextureAndSamplerDefine>\n        #if ${defines.USE_IBL}\n            #include <ibl>\n        #endif\n        @binding(${defines.pbrBinding}) @group(0) var<uniform> materialUniform : MaterialUniform;\n        @binding(${defines.cameraBinding}) @group(1) var<uniform> systemUniform : SystemUniform;\n        @fragment\n        fn main(input:FragInput) -> @location(0) vec4<f32> \n        {\n            var perceptualRoughness:f32 = materialUniform.roughness;\n            var metallic:f32 = materialUniform.metallic;\n\n            #if ${defines.USE_METALNESSTEXTURE}\n                let mrSample:vec4<f32> = textureSample(metalnessRoughnessTexture,metalnessRoughnessSampler, input.uv);\n                perceptualRoughness = mrSample.g * perceptualRoughness;\n                metallic = mrSample.b * metallic;\n            #endif\n            perceptualRoughness = clamp(perceptualRoughness, c_MinRoughness, 1.0);\n            metallic = clamp(metallic, 0.0, 1.0);\n            let alphaRoughness:f32 = perceptualRoughness * perceptualRoughness;\n\n\n            // The albedo may be defined from a base texture or a flat color\n            #if ${defines.USE_TEXTURE}\n                let baseColor:vec4<f32> = textureSample(baseColorTexture,baseColorSampler, input.uv) ;\n            #else\n                let baseColor:vec4<f32> = vec4<f32>(materialUniform.color,1.0);\n            #endif\n\n            #if ${defines.USE_NORMALTEXTURE}\n                let n:vec3<f32> = getNormalByNormalTexture(input);  \n            #else\n                let n:vec3<f32> = getNormal(input);\n            #endif\n            var material:PhysicalMaterial;\n            material.diffuseColor=baseColor.rgb*( 1.0 - metallic );\n            material.roughness=perceptualRoughness;\n            material.specularColor=mix( vec3<f32>( 0.04), baseColor.rgb, metallic );\n            var geometry:Geometry;\n            geometry.normal=n;\n            geometry.viewDir=normalize(systemUniform.cameraPosition - input.worldPos);\n            geometry.position=input.worldPos;\n            geometry.dotNV = saturate(dot(geometry.normal, geometry.viewDir) );\n            //light shading\n            var reflectedLight=parseLights(geometry,material);\n            var color=reflectedLight.directDiffuse+reflectedLight.directSpecular;\n            //IBL\n            #if ${defines.USE_IBL && defines.HAS_UV}\n                var reflectedLightDiffuse=indirectDiffuse_Physical(geometry,material);\n                var reflectedLightSpecular=indirectSpecular_Physical(geometry,material);\n                color+=reflectedLightDiffuse.indirectDiffuse;\n                color+=reflectedLightSpecular.indirectSpecular;\n            #endif\n            #if ${defines.USE_AOTEXTURE}\n                let ao:f32 = textureSample(aoTexture,aoSampler, input.uv).r;\n                color = mix(color, color * ao, materialUniform.occlusionStrength);\n            #endif\n\n            #if ${defines.USE_EMISSIVETEXTURE}\n                let emissive:vec3<f32> = textureSample(emissiveTexture, emissiveSampler,input.uv).rgb ;\n                color += emissive;\n            #endif\n       return vec4<f32>(color, baseColor.a);\n    }\n   `;\n}\n","import { wgslParseDefines } from \"../WgslPreprocessor\";\nexport default function pbr_vs(defines) {\n\treturn wgslParseDefines`\n    #include <PbrMaterialStruct>\n    #include <SystemUniform>\n    #include <VertexInput>\n    #include <VertexOutput> \n    #include <skinVertHeader>\n    #include <instanceVertHeader>\n    @binding(${defines.pbrBinding}) @group(0) var<uniform> materialUniform : MaterialUniform;\n    @binding(${defines.cameraBinding}) @group(1) var<uniform> systemUniform : SystemUniform;\n    @vertex\n    fn main(input: VertexInput)-> VertexOutput\n   {\n        var output: VertexOutput;\n        #if ${defines.HAS_UV}\n            output.uv = input.uv;\n        #endif\n        var modelMatrix:mat4x4<f32>;\n        var vNormalView:vec3<f32>;\n        vNormalView = normalize(materialUniform.normalMatrix * vec4<f32>(input.normal,0.0)).xyz;\n        modelMatrix=materialUniform.modelMatrix;   \n        #include <skinVertMain>\n        #include <instanceVertMain>  \n        output.normal = vNormalView.xyz;\n        output.position = systemUniform.projectionMatrix * systemUniform.viewMatrix *modelMatrix* vec4<f32>(input.position, 1.0);\n        let modelPos=modelMatrix *vec4<f32>(input.position,1.0);\n        output.worldPos = modelPos.xyz/modelPos.w;\n        return output;   \n   }\n   `;\n}\n","import { wgslParseDefines } from \"../WgslPreprocessor\";\r\n\r\nexport default function pbrFrag(defines) {\r\n\treturn wgslParseDefines`\r\n    #include <lightCommon>\r\n    #include <light>\r\n    #include <brdf>\r\n    #include <pbrStruct>\r\n    #include <pbrUtils>\r\n    #include <pbrFunction>\r\n    #include <pbrTexture>\r\n    #include <environment>\r\n    struct SystemUniform {\r\n        projectionMatrix: mat4x4<f32>,\r\n        viewMatrix: mat4x4<f32>,\r\n        inverseViewMatrix: mat4x4<f32>,\r\n        cameraPosition: vec3<f32>,\r\n    }; \r\n    // uniform vec3 lightProbe[9],\r\n////////////////////////////////////\r\nstruct VertexOutput {\r\n    @builtin(position) position: vec4<f32>,\r\n    @builtin(front_facing) is_front: bool,\r\n    @location(0) vUv: vec2<f32>,\r\n    @location(1) vViewPosition: vec3<f32>, // Vector from vertex to camera.\r\n    @location(2) vWorldPosition: vec3<f32>,\r\n    @location(3) vNormal: vec3<f32>,\r\n    // 可选\r\n    #if ${defines.USE_LIGHTTEXTURE || defines.USE_AOTEXTURE}\r\n        @location(${defines.vUv2OutLocation}) vUv2: vec2<f32>,\r\n    #endif\r\n\r\n    #if ${defines.USE_COLOR_ALPHA}\r\n        @location(${defines.vColorOutLocation}) vColor: vec4<f32>,\r\n    #elif ${defines.USE_COLOR || defines.USE_INSTANCING_COLOR}\r\n        @location(${defines.vColorOutLocation}) vColor: vec3<f32>,\r\n    #endif\r\n\r\n    #if ${defines.USE_TANGENT}\r\n        @location(${defines.vTangentOutLocation}) vTangent: vec3<f32>,\r\n        @location(${defines.vBitangentOutLocation}) vBitangent: vec3<f32>,\r\n    #endif\r\n};\r\n        struct PhysicalMaterial {\r\n             diffuseColor:vec3<f32>,\r\n             roughness:f32,\r\n             specularColor:vec3<f32>,\r\n             specularF90:f32,\r\n            #if ${defines.USE_CLEARCOAT}\r\n                clearcoat:f32,\r\n                clearcoatRoughness:f32,\r\n                clearcoatF0:vec3<f32>,\r\n                clearcoatF90:f32,\r\n            #endif\r\n\r\n            #if ${defines.USE_IRIDESCENCE}\r\n                iridescence:f32,\r\n                iridescenceIOR:f32,\r\n                iridescenceThickness:f32,\r\n                iridescenceFresnel:vec3<f32>,\r\n                iridescenceF0:vec3<f32>,\r\n            #endif\r\n\r\n            #if ${defines.USE_SHEEN}\r\n                sheenColor:vec3<f32>,\r\n                sheenRoughness:f32,\r\n            #endif\r\n\r\n            #if ${defines.IOR}\r\n                 ior:f32,\r\n            #endif\r\n\r\n            #if ${defines.USE_TRANSMISSION}\r\n                transmission:f32,\r\n                transmissionAlpha:f32,\r\n                thickness:f32,\r\n                attenuationDistance:f32,\r\n                attenuationColor:vec3<f32>,\r\n            #endif\r\n        };\r\n@binding(0) @group(0) var<uniform> materialUniform : MaterialUniform;\r\n@binding(0) @group(1) var<uniform> systemUniform : SystemUniform;\r\n@fragment\r\nfn main(input:VertexOutput)-> @location(0) vec4<f32> {\r\n        var diffuseColor:vec4<f32> = vec4(materialUniform.diffuse, materialUniform.opacity );\r\n       // ReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );\r\n        var reflectedLight:ReflectedLight;\r\n        var totalEmissiveRadiance:vec3<f32> = materialUniform.emissive;\r\n        #if ${defines.USE_TEXTURE}\r\n            var sampledDiffuseColor:vec4<f32> =textureSample(baseTexture, baseSampler, input.vUv);\r\n            #if ${defines.DECODE_VIDEO_TEXTURE}\r\n                sampledDiffuseColor = vec4<f32>( mix( pow( sampledDiffuseColor.rgb * 0.9478672986 + vec3<f32>( 0.0521327014 ), vec3<f32>( 2.4 ) ), sampledDiffuseColor.rgb * 0.0773993808, vec3<f32>( lessThanEqual( sampledDiffuseColor.rgb, vec3<f32>( 0.04045 ) ) ) ), sampledDiffuseColor.w );\r\n            #endif\r\n\r\n            diffuseColor *= sampledDiffuseColor;\r\n        #endif\r\n\r\n        var roughnessFactor:f32 = materialUniform.roughness;\r\n    \r\n        #if ${defines.USE_ROUGHNESSTEXTURE}\r\n            let texelRoughness:vec4<f32>=textureSample(roughnessTexture, baseSampler, input.vUv);\r\n            roughnessFactor *= texelRoughness.g;\r\n        #endif\r\n\r\n        var metalnessFactor:f32 = materialUniform.metalness;\r\n    \r\n        #if ${defines.USE_METALNESSTEXTURE}\r\n            let texelMetalness:vec4<f32> =textureSample(metalnessTexture, baseSampler, input.vUv);\r\n            metalnessFactor *= texelMetalness.b;\r\n        #endif\r\n\r\n        let faceDirection:f32 =select(-1.0,1.0,input.is_front);\r\n        #if ${defines.FLAT_SHADED}\r\n            let fdx:vec3<f32> = dpdx( input.vViewPosition );\r\n            let fdy:vec3<f32> = dpdy( input.vViewPosition );\r\n            let normal:vec3<f32> = normalize( cross( fdy, fdx ) );\r\n        #else\r\n            let normal:vec3<f32> = normalize( input.vNormal );\r\n            #if ${defines.DOUBLE_SIDED}\r\n                normal = normal * faceDirection;\r\n            #endif\r\n            #if ${defines.USE_TANGENT}\r\n                let tangent:vec3<f32> = normalize( input.vTangent );\r\n                let bitangent:vec3<f32> = normalize( input.vBitangent );\r\n                #if ${defines.DOUBLE_SIDED}\r\n                    tangent = tangent * faceDirection;\r\n                    bitangent = bitangent * faceDirection;\r\n                #endif\r\n                #if ${defines.TANGENTSPACE_NORMALTEXTURE || defines.USE_CLEARCOAT_NORMALTEXTURE}\r\n                    let vTBN:mat3x3<f32> = mat3x3<f32>( tangent, bitangent, normal );\r\n                #endif\r\n            #endif\r\n        #endif\r\n    \r\n        let geometryNormal:vec3<f32> = normal;\r\n\r\n        #if ${defines.OBJECTSPACE_NORMALTEXTURE}\r\n            normal =textureSample(normalTexture, baseSampler, input.vUv).xyz * 2.0 - 1.0;\r\n            #if ${defines.FLIP_SIDED}\r\n                normal = - normal;\r\n            #endif\r\n            #if ${defines.DOUBLE_SIDED}\r\n                normal = normal * faceDirection;\r\n            #endif\r\n\r\n            normal = normalize(materialUniform.normalMatrix * normal );\r\n\r\n            #elif ${defines.TANGENTSPACE_NORMALTEXTURE}\r\n            let tempMapN:vec3<f32> =textureSample(normalTexture, baseSampler, input.vUv).xyz * 2.0 - 1.0;\r\n            let mapN:vec3<f32> =tempMapN.xy *= materialUniform.normalScale;\r\n            #if ${defines.USE_TANGENT}\r\n                normal = normalize( vTBN * mapN );\r\n            #else\r\n                normal = perturbNormal2Arb( - input.vViewPosition, normal, mapN, faceDirection );\r\n            #endif\r\n\r\n            #elif ${defines.USE_BUMPTEXTURE}\r\n\r\n                normal = perturbNormalArb( - input.vViewPosition, normal, dHdxy_fwd(), faceDirection );\r\n        #endif\r\n\r\n        #if ${defines.USE_CLEARCOAT}\r\n            var clearcoatNormal:vec3<f32> = geometryNormal;\r\n        #endif\r\n        #if ${defines.USE_CLEARCOAT_NORMALTEXTURE}\r\n            var clearcoatMapN:vec3<f32> =textureSample(clearcoatNormalTexture, baseSampler, input.vUv).xyz * 2.0 - 1.0;\r\n            clearcoatMapN.xy *= materialUniform.clearcoatNormalScale;\r\n            #if ${defines.USE_TANGENT}\r\n                clearcoatNormal = normalize( vTBN * clearcoatMapN );\r\n            #else\r\n                clearcoatNormal = perturbNormal2Arb( - input.vViewPosition, clearcoatNormal, clearcoatMapN, faceDirection );\r\n            #endif\r\n        #endif\r\n        #if ${defines.USE_EMISSIVETEXTURE}\r\n            let emissiveColor:vec4<f32> =textureSample(emissiveTexture, baseSampler, input.vUv);\r\n            totalEmissiveRadiance *= emissiveColor.rgb;\r\n        #endif\r\n\r\n        var material:PhysicalMaterial;\r\n        material.diffuseColor = diffuseColor.rgb * ( 1.0 - metalnessFactor );\r\n        let dxy:vec3<f32> = max( abs( dpdx( geometryNormal ) ), abs( dpdy( geometryNormal ) ) );\r\n        let geometryRoughness:f32 = max( max( dxy.x, dxy.y ), dxy.z );\r\n        material.roughness = max( roughnessFactor, 0.0525 );\r\n        material.roughness += geometryRoughness;\r\n        material.roughness = min( material.roughness, 1.0 );\r\n\r\n        #if ${defines.IOR}\r\n            material.ior = materialUniform.ior;\r\n            #if ${defines.SPECULAR}\r\n                let specularIntensityFactor:f32 = materialUniform.specularIntensity;\r\n                let specularColorFactor:vec3<f32> = materialUniform.specularColor;\r\n                #if ${defines.USE_SPECULARINTENSITYTEXTURE}\r\n                    specularIntensityFactor *=textureSample(specularIntensityTexture, baseSampler, input.vUv).a;\r\n                #endif\r\n\r\n                #if ${defines.USE_SPECULARCOLORTEXTURE}\r\n                    specularColorFactor *=textureSample(specularColorTexture, baseSampler, input.vUv).rgb;\r\n                #endif\r\n\r\n                material.specularF90 = mix( specularIntensityFactor, 1.0, metalnessFactor );\r\n            #else\r\n                let specularIntensityFactor:f32 = 1.0;\r\n                let specularColorFactor:vec3<f32> = vec3<f32>( 1.0 );\r\n                material.specularF90 = 1.0;\r\n            #endif\r\n            material.specularColor = mix( min( pow2( ( material.ior - 1.0 ) / ( material.ior + 1.0 ) ) * specularColorFactor, vec3( 1.0 ) ) * specularIntensityFactor, diffuseColor.rgb, metalnessFactor );\r\n        #else\r\n            material.specularColor = mix( vec3<f32>( 0.04 ), diffuseColor.rgb, metalnessFactor );\r\n            material.specularF90 = 1.0;\r\n        #endif\r\n        #if ${defines.USE_CLEARCOAT}\r\n            material.clearcoat = materialUniform.clearcoat;\r\n            material.clearcoatRoughness = materialUniform.clearcoatRoughness;\r\n            material.clearcoatF0 = vec3<f32>( 0.04 );\r\n            material.clearcoatF90 = 1.0;\r\n            #if ${defines.USE_CLEARCOATTEXTURE}\r\n                material.clearcoat *=textureSample(clearcoatTexture, baseSampler, input.vUv).x;\r\n            #endif\r\n            #if ${defines.USE_CLEARCOAT_ROUGHNESSTEXTURE}\r\n                material.clearcoatRoughness *=textureSample(clearcoatRoughnessTexture, baseSampler, input.vUv).y;\r\n            #endif\r\n            material.clearcoat = saturate( material.clearcoat );\r\n            material.clearcoatRoughness = max( material.clearcoatRoughness, 0.0525 );\r\n            material.clearcoatRoughness += geometryRoughness;\r\n            material.clearcoatRoughness = min( material.clearcoatRoughness, 1.0 );\r\n        #endif\r\n        #if ${defines.USE_IRIDESCENCE}\r\n            material.iridescence = materialUniform.iridescence;\r\n            material.iridescenceIOR = materialUniform.iridescenceIOR;\r\n            #if ${defines.USE_IRIDESCENCETEXTURE}\r\n                material.iridescence *=textureSample(iridescenceTexture, baseSampler, input.vUv).r;\r\n            #endif\r\n            #if ${defines.USE_IRIDESCENCE_THICKNESSTEXTURE}\r\n                material.iridescenceThickness = (materialUniform.iridescenceThicknessMaximum - materialUniform.iridescenceThicknessMinimum) * textureSample(iridescenceThicknessTexture, baseSampler, input.vUv).g + materialUniform.iridescenceThicknessMinimum;\r\n            #else\r\n                material.iridescenceThickness = materialUniform.iridescenceThicknessMaximum;\r\n            #endif\r\n        #endif\r\n        #if ${defines.USE_SHEEN}\r\n            material.sheenColor = materialUniform.sheenColor;\r\n            #if ${defines.USE_SHEENCOLORTEXTURE}\r\n                material.sheenColor *=textureSample(sheenColorTexture, baseSampler, input.vUv).rgb;\r\n            #endif\r\n            material.sheenRoughness = clamp( materialUniform.sheenRoughness, 0.07, 1.0 );\r\n            #if ${defines.USE_SHEENROUGHNESSTEXTURE}\r\n                material.sheenRoughness *=textureSample(sheenRoughnessTexture, baseSampler, input.vUv).a;\r\n            #endif\r\n        #endif\r\n        \r\n        var geometry:GeometricContext;\r\n        geometry.position = - input.vViewPosition;\r\n        geometry.normal = normal;\r\n       // geometry.viewDir = ( isOrthographic ) ? vec3( 0, 0, 1 ) : normalize( input.vViewPosition );\r\n        geometry.viewDir = normalize( input.vViewPosition); \r\n\r\n        #if ${defines.USE_CLEARCOAT}\r\n            geometry.clearcoatNormal = clearcoatNormal;\r\n        #endif\r\n\r\n        #if ${defines.USE_IRIDESCENCE}\r\n            let dotNVi:f32 = saturate( dot( normal, geometry.viewDir ) );\r\n            if ( material.iridescenceThickness == 0.0 ) {\r\n                material.iridescence = 0.0;\r\n            }\r\n            else {\r\n                material.iridescence = saturate( material.iridescence );\r\n            }\r\n            if ( material.iridescence > 0.0 ) {\r\n                material.iridescenceFresnel = evalIridescence( 1.0, material.iridescenceIOR, dotNVi, material.iridescenceThickness, material.specularColor );\r\n                material.iridescenceF0 = Schlick_to_F0( material.iridescenceFresnel, 1.0, dotNVi );\r\n            }\r\n        #endif\r\n\r\n        var iblIrradiance:vec3<f32> = vec3<f32>( 0.0 );\r\n        var irradiance:vec3<f32> = getAmbientLightIrradiance(commonLightsParms.ambient);\r\n        //irradiance += getLightProbeIrradiance( lightProbe, geometry.normal,systemUniform.viewMatrix );\r\n\r\n        var radiance:vec3<f32> = vec3<f32>( 0.0 );\r\n        var clearcoatRadiance:vec3<f32> = vec3<f32>( 0.0 );\r\n\r\n        #if ${defines.USE_LIGHTTEXTURE}\r\n            let lightMapTexel:vec4<f32> =textureSample(lightTexture, baseSampler, input.vUv2);\r\n            let lightMapIrradiance:vec3<f32> = lightMapTexel.rgb * materialUniform.lightTextureIntensity;\r\n            irradiance += lightMapIrradiance;\r\n        #endif\r\n        //&& defines.STANDARD&&defines.ENVTEXTURE_TYPE_CUBE_UV\r\n        #if ${defines.USE_ENVTEXTURE} \r\n            iblIrradiance += getIBLIrradiance( geometry.normal,baseSampler,systemUniform.viewMatrix );\r\n        #endif\r\n        #if ${defines.USE_ENVTEXTURE}\r\n            radiance += getIBLRadiance( geometry.viewDir,baseSampler,systemUniform.viewMatrix, geometry.normal, materialUniform.roughness );\r\n            #if ${defines.USE_CLEARCOAT}\r\n                clearcoatRadiance += getIBLRadiance( geometry.viewDir,baseSampler,systemUniform.viewMatrix, geometry.clearcoatNormal, material.clearcoatRoughness );\r\n            #endif\r\n        #endif\r\n        //直接光照\r\n            let dirReflectedLight:ReflectedLight= parseLights(geometry,material);\r\n            reflectedLight.directDiffuse +=dirReflectedLight.directDiffuse;\r\n            reflectedLight.directSpecular +=dirReflectedLight.directSpecular;\r\n        //间接漫反射\r\n            let indirectDiffuseLight:ReflectedLight= RE_IndirectDiffuse_Physical( irradiance, geometry, material);\r\n            reflectedLight.directDiffuse +=indirectDiffuseLight.indirectDiffuse;\r\n            reflectedLight.directSpecular +=indirectDiffuseLight.indirectSpecular;\r\n        //间接高光\r\n            let indirectSpecularLight:ReflectedLight=RE_IndirectSpecular_Physical( radiance, iblIrradiance, clearcoatRadiance, geometry, material);\r\n            reflectedLight.directDiffuse +=indirectSpecularLight.indirectDiffuse;\r\n            reflectedLight.directSpecular +=indirectSpecularLight.indirectSpecular;\r\n        //环境光遮蔽\r\n        #if ${defines.USE_AOTEXTURE}\r\n            let ambientOcclusion:f32 = (textureSample(aoTexture, baseSampler, input.vUv2).r - 1.0 ) * materialUniform.aoTextureIntensity + 1.0;\r\n\r\n            reflectedLight.indirectDiffuse *= ambientOcclusion;\r\n            //&&defines.STANDARD\r\n            #if ${defines.USE_ENVTEXTURE} \r\n                let dotNV:f32 = saturate( dot( geometry.normal, geometry.viewDir ) );\r\n                reflectedLight.indirectSpecular *= computeSpecularOcclusion( dotNV, ambientOcclusion, material.roughness );\r\n            #endif\r\n        #endif\r\n\r\n        var totalDiffuse:vec3<f32> = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse;\r\n        var totalSpecular:vec3<f32> = reflectedLight.directSpecular + reflectedLight.indirectSpecular;\r\n        //透射\r\n        #if ${defines.USE_TRANSMISSION}\r\n            material.transmission = materialUniform.transmission;\r\n            material.transmissionAlpha = 1.0;\r\n            material.thickness = materialUniform.thickness;\r\n            material.attenuationDistance = materialUniform.attenuationDistance;\r\n            material.attenuationColor = materialUniform.attenuationColor;\r\n            #if ${defines.USE_TRANSMISSIONTEXTURE}\r\n                material.transmission *=textureSample(transmissionTexture, baseSampler, input.vUv).r;\r\n            #endif\r\n            #if ${defines.USE_THICKNESSTEXTURE}\r\n                material.thickness *=textureSample(thicknessTexture, baseSampler, input.vUv).g;\r\n            #endif\r\n            let pos:vec3<f32> = vWorldPosition;\r\n            let v:vec3<f32> = normalize( cameraPosition - pos );\r\n            let n:vec3<f32> = inverseTransformDirection( normal, systemUniform.viewMatrix );\r\n            let transmission:vec4<f32> = getIBLVolumeRefraction(\r\n            n, v, material.roughness, material.diffuseColor, material.specularColor, material.specularF90, pos, modelMatrix, systemUniform.viewMatrix, systemUniform.projectionMatrix, material.ior, material.thickness, material.attenuationColor, material.attenuationDistance );\r\n            material.transmissionAlpha = mix( material.transmissionAlpha, transmission.a, material.transmission );\r\n            totalDiffuse = mix( totalDiffuse, transmission.rgb, material.transmission );\r\n        #endif\r\n\r\n        let outgoingLight:vec3<f32> = totalDiffuse + totalSpecular + totalEmissiveRadiance;\r\n\r\n        #if ${defines.USE_SHEEN}\r\n            let sheenEnergyComp:f32 = 1.0 - 0.157 * max3( material.sheenColor );\r\n            outgoingLight = outgoingLight * sheenEnergyComp + sheenSpecular;\r\n        #endif\r\n\r\n        #if ${defines.USE_CLEARCOAT}\r\n            let dotNVcc:f32 = saturate( dot( geometry.clearcoatNormal, geometry.viewDir ) );\r\n            let Fcc:vec3<f32> = F_Schlick( material.clearcoatF0, material.clearcoatF90, dotNVcc );\r\n            outgoingLight = outgoingLight * ( 1.0 - material.clearcoat * Fcc ) + clearcoatSpecular * material.clearcoat;\r\n        #endif\r\n\r\n        #if ${defines.USE_TRANSMISSION}\r\n            diffuseColor.a *= material.transmissionAlpha + 0.1;\r\n        #endif\r\n\r\n        var finnalColor:vec4<f32>;\r\n        finnalColor = vec4<f32>( outgoingLight, diffuseColor.a );\r\n        #if ${defines.TONE_MAPPING}\r\n           finnalColor.rgb = toneMapping( finnalColor.rgb,materialUniform.toneMappingExposure );\r\n        #endif\r\n\r\n          finnalColor = linearToOutputTexel( finnalColor);\r\n\r\n        #if ${defines.PREMULTIPLIED_ALPHA}\r\n            finnalColor.rgb *= finnalColor.a;\r\n        #endif\r\n        #if ${defines.DITHERING}\r\n            finnalColor.rgb = dithering( finnalColor.rgb );\r\n        #endif\r\n        return finnalColor;\r\n    }`;\r\n}\r\n","import { wgslParseDefines } from \"../WgslPreprocessor\";\r\n\r\nexport default function pbrVert(defines) {\r\n  return wgslParseDefines`\r\n    #include <pbrStruct>\r\n    struct VertexOutput {\r\n        @builtin(position) position: vec4<f32>,\r\n        @location(0) vUv: vec2<f32>,\r\n        @location(1) vViewPosition: vec3<f32>, // Vector from vertex to camera.\r\n        @location(2) vWorldPosition: vec3<f32>,\r\n        @location(3) vNormal: vec3<f32>,\r\n        // 可选\r\n        #if ${defines.USE_LIGHTTEXTURE || defines.USE_AOTEXTURE}\r\n            @location(${defines.vUv2OutLocation}) vUv2: vec2<f32>,\r\n        #endif\r\n\r\n        #if ${defines.USE_COLOR_ALPHA}\r\n            @location(${defines.vColorOutLocation}) vColor: vec4<f32>,\r\n        #elif ${defines.USE_COLOR || defines.USE_INSTANCING_COLOR}\r\n            @location(${defines.vColorOutLocation}) vColor: vec3<f32>,\r\n        #endif\r\n\r\n        #if ${defines.USE_TANGENT}\r\n            @location(${defines.vTangentOutLocation}) vTangent: vec3<f32>,\r\n            @location(${defines.vBitangentOutLocation}) vBitangent: vec3<f32>,\r\n        #endif\r\n    };\r\n    struct GlobalUniform {\r\n        projectionMatrix: mat4x4<f32>,\r\n        viewMatrix: mat4x4<f32>,\r\n        inverseViewMatrix: mat4x4<f32>,\r\n        cameraPosition: vec3<f32>,\r\n    };\r\n\r\n    //texture and sampler\r\n    // @group(0) @binding(${defines.samplerBinding}) var baseSampler: sampler;\r\n    #if ${defines.USE_SKINNING}\r\n        //uniform highp sampler2D boneTexture;\r\n        @group(0) @binding(${\r\n          defines.boneTextureBinding\r\n        }) var boneTexture: texture_2d<f32>;\r\n    #endif\r\n\r\n    #if ${defines.USE_DISPLACEMENTTEXTURE}\r\n        //uniform sampler2D displacementMap;\r\n        @group(0) @binding(${\r\n          defines.displacementTextureBinding\r\n        }) var displacementMap: texture_2d<f32>;\r\n    #endif\r\n\r\n    #if ${defines.MORPHTARGETS_TEXTURE}\r\n        //uniform sampler2DArray morphTargetsTexture;\r\n        @group(0) @binding(${\r\n          defines.morphTargetsTextureBinding\r\n        }) var morphTargetsTexture: texture_2d_array<f32>;\r\n    #endif\r\n\r\n    struct VertexInput {\r\n        @location(0) position: vec3<f32>,  \r\n\r\n        @location(1) normal: vec3<f32>,\r\n\r\n        @location(2) uv: vec2<f32>,\r\n        #if ${defines.USE_LIGHTTEXTURE || defines.USE_AOTEXTURE}\r\n            @location(${defines.uv2Location}) uv2:vec2<f32>,\r\n        #endif\r\n        #if ${defines.USE_INSTANCING}\r\n            @location(${\r\n              defines.instanceMatrixLocation\r\n            }) instanceMatrix:mat4x4<f32>,\r\n        #endif\r\n        #if ${defines.USE_INSTANCING_COLOR}\r\n            @location(${defines.instanceColorLocation}) instanceColor:vec3<f32>,\r\n        #endif\r\n        \r\n        #if ${defines.USE_TANGENT}\r\n            @location(${defines.tangentLocation}) tangent:vec4<f32>,\r\n        #endif\r\n        #if ${defines.USE_COLOR_ALPHA}\r\n            @location(${defines.colorLocation}) color:vec4<f32>,\r\n        #elif ${defines.USE_COLOR}\r\n            @location(${defines.colorLocation}) color:vec3<f32>,\r\n        #endif\r\n\r\n        #if ${defines.USE_MORPHTARGETS && !defines.MORPHTARGETS_TEXTURE}\r\n            @location(${defines.morphTarget0Location}) morphTarget0:vec3<f32>,\r\n\r\n            @location(${defines.morphTarget1Location}) morphTarget1:vec3<f32>,\r\n\r\n            @location(${defines.morphTarget2Location}) morphTarget2:vec3<f32>,\r\n\r\n            @location(${defines.morphTarget3Location}) morphTarget3:vec3<f32>,\r\n            #if ${defines.USE_MORPHNORMALS}\r\n                @location(${\r\n                  defines.morphNormal0Location\r\n                }) morphNormal0:vec3<f32>,\r\n\r\n                @location(${\r\n                  defines.morphNormal1Location\r\n                }) morphNormal1:vec3<f32>,\r\n\r\n                @location(${\r\n                  defines.morphNormal2Location\r\n                }) morphNormal2:vec3<f32>,\r\n\r\n                @location(${\r\n                  defines.morphNormal3Location\r\n                }) morphNormal3:vec3<f32>,\r\n            #else\r\n                @location(${\r\n                  defines.morphTarget4Location\r\n                }) morphTarget4:vec3<f32>,\r\n\r\n                @location(${\r\n                  defines.morphTarget5Location\r\n                }) morphTarget5:vec3<f32>,\r\n\r\n                @location(${\r\n                  defines.morphTarget6Location\r\n                }) morphTarget6:vec3<f32>,\r\n\r\n                @location(${\r\n                  defines.morphTarget7Location\r\n                }) morphTarget7:vec3<f32>,\r\n            #endif\r\n        #endif\r\n        #if ${defines.USE_SKINNING}\r\n            @location(${defines.skinIndexLocation}) skinIndex:vec4<f32>,\r\n            @location(${defines.skinWeightLocation}) skinWeight:vec4<f32>,\r\n        #endif\r\n  }\r\n\r\n    #if ${defines.MORPHTARGETS_TEXTURE}\r\n        fn getMorph( vertexIndex:u32, morphTargetIndex:u32,offset:u32 )->vec4<f32> {\r\n            let texelIndex:u32 = vertexIndex * MORPHTARGETS_TEXTURE_STRIDE + offset;\r\n            let y:u32 = texelIndex / materialUniform.morphTargetsTextureSize.x;\r\n            let x:u32 = texelIndex - y * materialUniform.morphTargetsTextureSize.x;\r\n            let morphUV:vec3<u32> = vec3<u32>( x, y, morphTargetIndex );\r\n            //textureLoad\r\n            //return texelFetch( morphTargetsTexture, morphUV, 0 );\r\n            return textureLoad( morphTargetsTexture, morphUV, 0 );\r\n        }\r\n    #endif\r\n    #if ${defines.USE_SKINNING}\r\n        fn getBoneMatrix( i:f32 )->mat4x4<f32> {\r\n            let j:f32 = i * 4.0;\r\n            let x:f32 = j%f32( materialUniform.boneTextureSize );\r\n            let y:f32 = floor( j / f32( materialUniform.boneTextureSize ) );\r\n            let dx:f32 = 1.0 / f32( materialUniform.boneTextureSize );\r\n            let dy:f32 = 1.0 / f32( materialUniform.boneTextureSize );\r\n            y = dy * ( y + 0.5 );\r\n            \r\n            let v1:vec4<f32> = textureSample(boneTexture, baseSampler, vec2<f32>( dx * ( x + 0.5 ), y ) );\r\n            let v2:vec4<f32> = textureSample(boneTexture, baseSampler, vec2<f32>( dx * ( x + 1.5 ), y ) );\r\n            let v3:vec4<f32> = textureSample(boneTexture, baseSampler, vec2<f32>( dx * ( x + 2.5 ), y ) );\r\n            let v4:vec4<f32> = textureSample(boneTexture, baseSampler, vec2<f32>( dx * ( x + 3.5 ), y ) );\r\n            let bone:mat4x4<f32> = mat4x4<f32>( v1, v2, v3, v4 );\r\n            return bone;\r\n        }\r\n    #endif\r\n\r\n    @binding(0) @group(0) var<uniform> materialUniform : MaterialUniform;\r\n    @binding(0) @group(1) var<uniform> globalUniform : GlobalUniform;\r\n    @vertex\r\n    fn main(input:VertexInput)->VertexOutput {\r\n        var vertexOutput:VertexOutput;\r\n        #if ${defines.USE_TEXTURE}\r\n            vertexOutput.vUv = input.uv;\r\n        #endif\r\n        #if ${defines.USE_LIGHTTEXTURE || defines.USE_AOTEXTURE}\r\n            vertexOutput.vUv2 input.uv2;\r\n        #endif\r\n        #if ${defines.USE_COLOR_ALPHA}\r\n            vertexOutput.vColor = vec4( 1.0 );\r\n            #elif ${defines.USE_COLOR || defines.USE_INSTANCING_COLOR}\r\n            vertexOutput.vColor = vec3( 1.0 );\r\n        #endif\r\n        #if ${defines.USE_COLOR}\r\n            vertexOutput.vColor *= input.color;\r\n        #endif\r\n        #if ${defines.USE_INSTANCING_COLOR}\r\n            vertexOutput.vColor.xyz *= input.instanceColor.xyz;\r\n        #endif\r\n        #if ${defines.USE_MORPHCOLORS && defines.MORPHTARGETS_TEXTURE}\r\n            vertexOutput.vColor *= materialUniform.morphTargetBaseInfluence;\r\n            for (let i : u32 = 0u; i < materialUniform.MORPHTARGETS_COUNT; i = i + 1u ) {\r\n                #if ${defines.USE_COLOR_ALPHA}\r\n                    if ( materialUniform.morphTargetInfluences[ i ] ! = 0.0 ) vertexOutput.vColor += getMorph( gl_VertexID, i, 2 ) * materialUniform.morphTargetInfluences[ i ];\r\n                    #elif ${defines.USE_COLOR}\r\n                    if ( materialUniform.morphTargetInfluences[ i ] ! = 0.0 ) vertexOutput.vColor += getMorph( gl_VertexID, i, 2 ).rgb * materialUniform.morphTargetInfluences[ i ];\r\n                #endif\r\n            }\r\n        #endif\r\n        var objectNormal:vec3<f32> = vec3<f32>(input.normal);\r\n        #if ${defines.USE_TANGENT}\r\n            let objectTangent:vec3<f32> = vec3<f32>( input.tangent.xyz );\r\n        #endif\r\n        #if ${defines.USE_MORPHNORMALS}\r\n            objectNormal *= materialUniform.morphTargetBaseInfluence;\r\n            #if ${defines.MORPHTARGETS_TEXTURE}\r\n                for ( let i : u32 = 0u; i < materialUniform.MORPHTARGETS_COUNT; i = i + 1u) {\r\n                    if ( materialUniform.morphTargetInfluences[ i ] ! = 0.0 ) objectNormal += getMorph( gl_VertexID, i, 1 ).xyz * materialUniform.morphTargetInfluences[ i ];\r\n                }\r\n            #else\r\n                objectNormal += morphNormal0 * materialUniform.morphTargetInfluences[ 0 ];\r\n                objectNormal += morphNormal1 * materialUniform.morphTargetInfluences[ 1 ];\r\n                objectNormal += morphNormal2 * materialUniform.morphTargetInfluences[ 2 ];\r\n                objectNormal += morphNormal3 * materialUniform.morphTargetInfluences[ 3 ];\r\n            #endif\r\n        #endif\r\n        #if ${defines.USE_SKINNING}\r\n            let boneMatX:mat4x4<f32> = getBoneMatrix( input.skinIndex.x );\r\n            let boneMatY:mat4x4<f32> = getBoneMatrix( input.skinIndex.y );\r\n            let boneMatZ:mat4x4<f32> = getBoneMatrix( input.skinIndex.z );\r\n            let boneMatW:mat4x4<f32> = getBoneMatrix( input.skinIndex.w );\r\n        #endif\r\n        #if ${defines.USE_SKINNING}\r\n            let skinMatrix:mat4x4<f32> = mat4x4<f32>( 0.0 );\r\n            skinMatrix += input.skinWeight.x * boneMatX;\r\n            skinMatrix += input.skinWeight.y * boneMatY;\r\n            skinMatrix += input.skinWeight.z * boneMatZ;\r\n            skinMatrix += input.skinWeight.w * boneMatW;\r\n            skinMatrix = materialUniform.bindMatrixInverse * skinMatrix * materialUniform.bindMatrix;\r\n            objectNormal = vec4<f32>( skinMatrix * vec4<f32>( objectNormal, 0.0 ) ).xyz;\r\n            #if ${defines.USE_TANGENT}\r\n                objectTangent = vec4<f32>( skinMatrix * vec4<f32>( objectTangent, 0.0 ) ).xyz;\r\n            #endif\r\n        #endif\r\n        var transformedNormal:vec3<f32> = objectNormal;\r\n        // transformedNormal+=vec3<f32>(0.0);\r\n        #if ${defines.USE_INSTANCING}\r\n            let m:mat3x3<f32> = mat3x3<f32>( input.instanceMatrix );\r\n            transformedNormal /= vec3<f32>( dot( m[ 0 ], m[ 0 ] ), dot( m[ 1 ], m[ 1 ] ), dot( m[ 2 ], m[ 2 ] ) );\r\n            transformedNormal = m * transformedNormal;\r\n        #endif\r\n        transformedNormal = materialUniform.normalMatrix * transformedNormal;\r\n        #if ${defines.FLIP_SIDED}\r\n            transformedNormal = - transformedNormal;\r\n        #endif\r\n        #if ${defines.USE_TANGENT}\r\n            let transformedTangent:vec3<f32> = (globalUniform.viewMatrix*materialUniform.modelMatrix * vec4<f32>( objectTangent, 0.0 ) ).xyz;\r\n            #if ${defines.FLIP_SIDED}\r\n                transformedTangent = - transformedTangent;\r\n            #endif\r\n        #endif\r\n        vertexOutput.vNormal = normalize( transformedNormal );\r\n        #if ${defines.FLAT_SHADED}\r\n            #if ${defines.USE_TANGENT}\r\n                vTangent = normalize( transformedTangent );\r\n                vBitangent = normalize( cross( vNormal, vTangent ) * input.tangent.w );\r\n            #endif\r\n        #endif\r\n        let transformed:vec3<f32> = vec3<f32>( input.position );\r\n        #if ${defines.USE_MORPHTARGETS}\r\n            transformed *= materialUniform.morphTargetBaseInfluence;\r\n            #if ${defines.MORPHTARGETS_TEXTURE}\r\n                for ( let i : u32 = 0u; i < materialUniform.MORPHTARGETS_COUNT; i = i + 1u ) {\r\n                    if ( materialUniform.morphTargetInfluences[ i ] ! = 0.0 ) transformed += getMorph( gl_VertexID, i, 0 ).xyz * morphTargetInfluences[ i ];\r\n                }\r\n            #else\r\n                transformed += input.morphTarget0 * materialUniform.morphTargetInfluences[ 0 ];\r\n                transformed += input.morphTarget1 * materialUniform.morphTargetInfluences[ 1 ];\r\n                transformed += input.morphTarget2 * materialUniform.morphTargetInfluences[ 2 ];\r\n                transformed += input.morphTarget3 * materialUniform.morphTargetInfluences[ 3 ];\r\n                #if ${defines.USE_MORPHNORMALS}\r\n                    transformed += input.morphTarget4 * materialUniform.morphTargetInfluences[ 4 ];\r\n                    transformed += input.morphTarget5 * materialUniform.morphTargetInfluences[ 5 ];\r\n                    transformed += input.morphTarget6 * materialUniform.morphTargetInfluences[ 6 ];\r\n                    transformed += input.morphTarget7 * materialUniform.morphTargetInfluences[ 7 ];\r\n                #endif\r\n            #endif\r\n        #endif\r\n        #if ${defines.USE_SKINNING}\r\n            let skinVertex:vec4<f32> = materialUniform.bindMatrix * vec4<f32>( transformed, 1.0 );\r\n            let skinned:vec4<f32> = vec4<f32>( 0.0 );\r\n            skinned += boneMatX * skinVertex * input.skinWeight.x;\r\n            skinned += boneMatY * skinVertex * input.skinWeight.y;\r\n            skinned += boneMatZ * skinVertex * input.skinWeight.z;\r\n            skinned += boneMatW * skinVertex * input.skinWeight.w;\r\n            transformed = ( materialUniform.bindMatrixInverse * skinned ).xyz;\r\n        #endif\r\n        #if ${defines.USE_DISPLACEMENTTEXTURE} \r\n            transformed += normalize( objectNormal ) * (textureSample(displacementMap, baseSampler, vUv).x * materialUniform.displacementScale + materialUniform.displacementBias );\r\n        #endif\r\n        var mvPosition:vec4<f32> = vec4<f32>( transformed, 1.0 );\r\n        #if ${defines.USE_INSTANCING}\r\n            mvPosition = input.instanceMatrix * mvPosition;\r\n        #endif\r\n        mvPosition = globalUniform.viewMatrix*materialUniform.modelMatrix * mvPosition;\r\n        vertexOutput.position = globalUniform.projectionMatrix * mvPosition;\r\n        vertexOutput.vViewPosition = - mvPosition.xyz/mvPosition.w;\r\n        #if ${\r\n          defines.USE_ENVTEXTURE || defines.DISTANCE || defines.USE_TRANSMISSION\r\n        } \r\n            var worldPosition:vec4<f32> = vec4<f32>( transformed, 1.0 );\r\n            #if ${defines.USE_INSTANCING}\r\n                worldPosition = input.instanceMatrix * worldPosition;\r\n            #endif\r\n            worldPosition = materialUniform.modelMatrix * worldPosition;\r\n        #endif\r\n        #if ${defines.USE_TRANSMISSION}\r\n            vertexOutput.vWorldPosition = worldPosition.xyz;\r\n        #endif\r\n        return vertexOutput;\r\n    }\r\n    `;\r\n}\r\n","import { wgslParseDefines } from \"../WgslPreprocessor\";\nexport default function phongFrag(defines) {\n\treturn wgslParseDefines`  \n    struct MaterialUniform {\n      modelMatrix: mat4x4<f32>,\n      color: vec3<f32>,\n      opacity:f32,\n      normalMatrix: mat4x4<f32>,\n      emissive:vec3<f32>,\n      shininess:f32,\n      specular:vec3<f32>,      \n   }\n    #include <FragInput>\n    #include <SystemUniform>\n    #include <TextureAndSamplerDefine>\n    #include <light>\n    @binding(${defines.phongBinding}) @group(0) var<uniform> materialUniform : MaterialUniform;\n    @binding(${defines.cameraBinding}) @group(1) var<uniform> systemUniform : SystemUniform;\n    @fragment\n    fn main(input:FragInput) -> @location(0) vec4<f32> {\n        var totalEmissiveRadiance:vec3<f32> = materialUniform.emissive;\n        var color:vec4<f32>;\n        #if${defines.USE_COLORTEXTURE}\n            color= vec4<f32>(textureSample(baseColorTexture, baseColorSampler, input.uv).rgb+materialUniform.color,materialUniform.opacity);\n        #else\n            color=vec4<f32>(materialUniform.color,materialUniform.opacity);\n        #endif     \n        let  V:vec3<f32> =  normalize( systemUniform.cameraPosition - input.worldPos);\n        #if ${defines.USE_NORMALTEXTURE}\n            let N:vec3<f32> = getNormalByNormalTexture(input);  \n        #else\n            let N:vec3<f32> = getNormal(input);\n        #endif\n        var geometry:Geometry;\n        geometry.normal=N;\n        geometry.viewDir=V;\n        geometry.position=input.worldPos;\n        let lightColor:ReflectedLight=parseLights(geometry,materialUniform.shininess);\n        // var finnalColor:vec3<f32>=color.xyz + (lightColor.directDiffuse + lightColor.directSpecular + lightColor.ambient);\n        var finnalColor:vec3<f32>=color.xyz * (lightColor.directDiffuse + lightColor.directSpecular + lightColor.ambient);\n\n        // finnalColor = lightColor.testColor.xyz;\n\n        return vec4<f32>(finnalColor,color.a);\n    }`;\n}\n","import { wgslParseDefines } from \"../WgslPreprocessor\";\nexport default function phongVert(defines) {\n\treturn wgslParseDefines`\n      struct MaterialUniform {\n            modelMatrix: mat4x4<f32>,\n            color: vec3<f32>,\n            opacity:f32,\n            normalMatrix: mat4x4<f32>,\n            emissive:vec3<f32>,\n            specular:vec3<f32>,\n            shininess:f32,\n      }\n      #include <VertexOutput>\n      #include <SystemUniform>\n      #include <VertexInput>\n      @binding(${defines.phongBinding}) @group(0) var<uniform> selfUniform : MaterialUniform;\n      @binding(${defines.cameraBinding}) @group(1) var<uniform> systemUniform : SystemUniform;\n      @vertex\n      fn main(input: VertexInput) -> VertexOutput {\n            var output: VertexOutput;\n            #if ${defines.HAS_UV}\n               output.uv = input.uv;\n            #endif \n            let modelPos=selfUniform.modelMatrix *vec4<f32>(input.position,1.0);\n            output.worldPos = modelPos.xyz/modelPos.w;\n            let vNormalView = selfUniform.normalMatrix * vec4<f32>(input.normal,0.0);\n            output.normal =  vNormalView.xyz;\n            output.view = systemUniform.cameraPosition.xyz - modelPos.xyz;\n            let viewPosition=systemUniform.viewMatrix * modelPos;\n            output.viewPosition = -viewPosition.xyz;\n            output.position = systemUniform.projectionMatrix * systemUniform.viewMatrix * modelPos;\n            return output;\n      }`;\n}\n","import { wgslParseDefines } from \"../WgslPreprocessor\";\n\nexport function point_fs(defines) {\n\treturn wgslParseDefines`\n  #include <PointFragInput>\n  struct SelfUniform {\n    modelMatrix: mat4x4<f32>,\n    color:vec3<f32>,\n    size:f32,\n    opacity:f32,\n  }\n  @binding(${defines.pointBinding}) @group(0) var<uniform> selfUniform : SelfUniform;\n  #if${defines.USE_COLORTEXTURE}\n    @group(0) @binding(${defines.baseColorSamplerBinding}) var baseColorSampler: sampler;\n    @group(0) @binding(${defines.baseColorTextureBinding}) var baseColorTexture: texture_2d<f32>;\n  #endif\n  @fragment\n  fn main(input:PointFragInput) -> @location(0) vec4<f32> {\n    var color:vec4<f32>=vec4<f32>(selfUniform.color,selfUniform.opacity);\n    #if${defines.USE_COLORTEXTURE}\n      color=textureSample(baseColorTexture, baseColorSampler, input.uv);\n    #endif\n    #if${defines.HAS_COLOR}\n      color=vec4<f32>(input.color,selfUniform.opacity);\n    #endif\n    return color;\n  }\n  `;\n}\n","import { wgslParseDefines } from \"../WgslPreprocessor\";\n\nexport function point_vs(defines) {\n\treturn wgslParseDefines`\n    #include <PointVertOutput>\n    #include <SystemUniform>\n    #include <PointVertInput>\n    struct SelfUniform {\n      modelMatrix: mat4x4<f32>,\n      color:vec3<f32>,\n      size:f32,\n      opacity:f32,\n    }\n    @binding(${defines.pointBinding}) @group(0) var<uniform> selfUniform : SelfUniform;\n    @binding(${defines.cameraBinding}) @group(1) var<uniform> systemUniform : SystemUniform;\n    @vertex\n      fn main(input: PointVertInput) -> PointVertOutput {\n      var output:PointVertOutput;\n      let mvPosition:vec4<f32>= ystemUniform.viewMatrix *selfUniform.modelMatrix*vec4<f32>(0.0,0.0,0.0, 1.0 );\n      #if ${defines.HAS_UV}\n          output.uv=input.uv;\n      #endif\n      #if ${defines.HAS_COLOR}\n          output.color=input.color;\n      #endif\n      #if ${defines.HAS_SIZE}\n          output.size=input.size;\n      #endif\n      vec2 alignedPosition = input.position.xy* selfUniform.size;\n      mvPosition.xy += alignedPosition;\n      output.position = systemUniform.projectionMatrix * mvPosition;\n      return output;\n      }\n   `;\n}\n","export default function quadFrag(defines) {\r\n\treturn `\r\n    @group(0) @binding(1) var baseSampler: sampler;\r\n    @group(0) @binding(0) var colorTexture: texture_2d<f32>;\r\n    struct VertexOutput {\r\n        @builtin(position) position: vec4<f32>,\r\n        @location(0) uv: vec2<f32>,\r\n    };\r\n    @fragment\r\n    fn main(input:VertexOutput) -> @location(0) vec4<f32> {\r\n      return textureSample(colorTexture, baseSampler, vec2<f32>(input.uv.x,1.0-input.uv.y));\r\n    }\r\n    `;\r\n}\r\n","export default function quadVert(defines) {\n\treturn `\n    struct VertexInput {\n         @location(${defines.positionLocation}) position: vec2<f32>,       \n    }\n    struct VertexOutput {\n         @builtin(position) position: vec4<f32>,\n         @location(0) uv: vec2<f32>,\n     };\n    @vertex\n    fn main(input: VertexInput) -> VertexOutput {\n     var output:VertexOutput;\n     output.uv = input.position * 0.5 + 0.5;\n     output.position = vec4<f32>(input.position, 0.0, 1.0);;\n     return output;\n    }\n    `;\n}\n","export default function skyBoxFrag(defines) {\r\n  return `\r\n    fn lessThanEqual(a:vec3<f32>,b:vec3<f32>)->vec3<f32>{\r\n        let xValue:f32=select(b.x,a.x,a.x<=b.x);\r\n        let yValue:f32=select(b.y,a.y,a.y<=b.y);\r\n        let zValue:f32=select(b.z,a.z,a.z<=b.z);\r\n        return vec3<f32>(xValue,yValue,zValue);    \r\n     }\r\n    fn LinearTosRGB( value:vec4<f32> )->vec4<f32> {\r\n        return vec4<f32>( mix( pow( value.rgb, vec3<f32>( 0.41666 ) ) * 1.055 - vec3<f32>( 0.055 ), value.rgb * 12.92, vec3<f32>( lessThanEqual( value.rgb, vec3<f32>( 0.0031308 ) ) ) ), value.a );\r\n    }\r\n  struct FragmentInput {\r\n    @location(0) texCoord : vec3<f32>\r\n  };\r\n  @group(0) @binding(2) var defaultSampler: sampler;\r\n  @group(0) @binding(1) var skyboxTexture: texture_cube<f32>;\r\n  @fragment\r\n  fn main(input : FragmentInput) -> @location(0) vec4<f32> {\r\n    let color = textureSample(skyboxTexture, defaultSampler, input.texCoord);\r\n    return LinearTosRGB(color);\r\n  }\r\n`;\r\n}\r\n","export default function skyBoxVert(defines) {\n\treturn `\n   struct SystemUniform {\n       projectionMatrix: mat4x4<f32>,\n       viewMatrix: mat4x4<f32>,\n       inverseViewMatrix: mat4x4<f32>,\n       cameraPosition: vec3<f32>,\n   }; \n   struct MaterialUniform {\n    modelMatrix: mat4x4<f32>,\n }\n   @binding(${defines.skyboxBinding}) @group(0) var<uniform> selfUniform : MaterialUniform;\n   @binding(${defines.cameraBinding}) @group(1) var<uniform> systemUniform : SystemUniform;\n     struct VertexInput {\n       @location(${defines.positionLocation}) position : vec3<f32>,\n     };\n     struct VertexOutput {\n       @builtin(position) position : vec4<f32>,\n       @location(0) texCoord : vec3<f32>,\n     };\n     @vertex\n     fn main(input : VertexInput) -> VertexOutput {\n       var output : VertexOutput;\n       output.texCoord = input.position.xyz;\n       var modelView = systemUniform.viewMatrix;\n       // Drop the translation portion of the modelView matrix\n       modelView[3] = vec4(0.0, 0.0, 0.0, modelView[3].w);\n       output.position = systemUniform.projectionMatrix * modelView * vec4<f32>(input.position,1.0);\n       output.position = output.position.xyww;\n       return output;\n     }\n   `;\n}\n","import { wgslParseDefines } from \"../WgslPreprocessor\";\n\nexport function sprite_fs(defines) {\n\treturn wgslParseDefines`\n  #include <VertexOutput>\n  struct SelfUniform {\n    modelMatrix: mat4x4<f32>,\n    color:vec3<f32>,\n    rotation:f32,\n    center:vec2<f32>,\n    opacity:f32,\n  }\n  @binding(${defines.spriteBinding}) @group(0) var<uniform> selfUniform : SelfUniform;\n  #if${defines.USE_COLORTEXTURE}\n    @group(0) @binding(${defines.baseColorSamplerBinding}) var baseColorSampler: sampler;\n    @group(0) @binding(${defines.baseColorTextureBinding}) var baseColorTexture: texture_2d<f32>;\n  #endif\n  @fragment\n  fn main(input:VertexOutput) -> @location(0) vec4<f32> {\n    #if${defines.USE_COLORTEXTURE}\n      return textureSample(baseColorTexture, baseColorSampler, input.uv);\n    #else\n      return vec4<f32>(selfUniform.color,selfUniform.opacity);\n    #endif\n  }\n  `;\n}\n","import { wgslParseDefines } from \"../WgslPreprocessor\";\nexport function sprite_vs(defines) {\n\treturn wgslParseDefines`\n\n  #include <VertexInput>\n  #include <VertexOutput>\n  #include <SystemUniform>\n  struct SelfUniform {\n    modelMatrix: mat4x4<f32>,\n    color:vec3<f32>,\n    rotation:f32,\n    center:vec2<f32>,\n    opacity:f32,\n  }\n  @binding(${defines.spriteBinding}) @group(0) var<uniform> selfUniform : SelfUniform;\n  @binding(${defines.cameraBinding}) @group(1) var<uniform> systemUniform : SystemUniform;\n  @vertex\n  fn main(input: VertexInput) -> VertexOutput {\n      var output:VertexOutput;\n      var mvPosition:vec4<f32>= systemUniform.viewMatrix *selfUniform.modelMatrix*vec4<f32>(0.0,0.0,0.0,1.0);\n      #if ${defines.HAS_UV}\n        output.uv=input.uv;\n      #endif\n      var scale:vec2<f32>;\n      scale.x = length(vec3<f32>(selfUniform.modelMatrix[0].x, selfUniform.modelMatrix[0].y, selfUniform.modelMatrix[0].z));\n      scale.y = length(vec3<f32>(selfUniform.modelMatrix[1].x, selfUniform.modelMatrix[1].y, selfUniform.modelMatrix[1].z));\n      // scale *= - mvPosition.z;\n      var alignedPosition:vec2<f32> =(input.position.xy- (selfUniform.center - vec2<f32>(0.5,0.5))) * scale;\n      let rotatedPositionX = cos(selfUniform.rotation) * alignedPosition.x - sin( selfUniform.rotation ) * alignedPosition.y;\n      let rotatedPositionY = sin(selfUniform.rotation) * alignedPosition.x + cos( selfUniform.rotation ) * alignedPosition.y;\n      var rotatedPosition=vec2<f32>(rotatedPositionX,rotatedPositionY);\n      let newPoint =mvPosition.xy+ rotatedPosition;\n      output.position = systemUniform.projectionMatrix * vec4<f32>(newPoint.x,newPoint.y,mvPosition.z,mvPosition.w);\n      return output;\n  }\n  `;\n}\n","export default function blendFrag(defines) {\r\n\treturn `\r\n    struct FragInput {\r\n        @location(0) uv: vec2<f32>,\r\n    };\r\n    @group(0) @binding({{tDiffuseBinding}}) var tDiffuse: texture_2d<f32>;\r\n    @group(0) @binding({{baseColorTextureBinding}}) var baseColorTexture: texture_2d<f32>;\r\n    @group(0) @binding({{tSamplerBinding}}) var tSampler: sampler;\r\n    @fragment\r\n    fn main(input:FragInput) -> @location(0) vec4<f32> {\r\n        let postColor:vec4<f32> = textureSample(tDiffuse, tSampler, input.uv);\r\n        let baseColor:vec4<f32> = textureSample(baseColorTexture, tSampler, input.uv);\r\n      return baseColor+postColor;\r\n    }   \r\n    `;\r\n}\r\n","export default function Blur(defines) {\r\n\treturn `\r\n    struct FragInput {\r\n        @location(0) uv: vec2<f32>,\r\n    }\r\n    struct BlurUniforms {\r\n        direction:vec2<f32>,\r\n    }\r\n    fn gaussianPdf(x:f32, sigma:f32)->f32 {\r\n        return 0.39894 * exp( -0.5 * x * x/( sigma * sigma))/sigma;\r\n    }\r\n    @group(0) @binding(0)  var<uniform> blurUniforms : BlurUniforms;\r\n    @group(0) @binding({{tDiffuseBinding}}) var tDiffuse: texture_2d<f32>;\r\n    @group(0) @binding({{tSamplerBinding}}) var tSampler: sampler;\r\n    @fragment\r\n    fn main(input:FragInput) -> @location(0) vec4<f32> {\r\n        let invSize:vec2<f32> = vec2<f32>(1.0,1.0) / vec2<f32>(textureDimensions(tDiffuse));\r\n        let fSigma:f32 =f32(${defines.SIGMA});\r\n        var weightSum:f32 = gaussianPdf(0.0, fSigma);\r\n        let baseColor=textureSample(tDiffuse, tSampler, input.uv);\r\n        var diffuseSum:vec3<f32> = baseColor.rgb * weightSum;\r\n        let uvOffset:vec2<f32> = blurUniforms.direction * invSize;\r\n        for( var i : u32 = 1; i < ${defines.KERNEL_RADIUS};i = i + 1 ) {\r\n            let x:f32 = f32(i);\r\n            let w:f32 = gaussianPdf(x, fSigma);\r\n            let sample1:vec3<f32>=textureSample(tDiffuse, tSampler, input.uv+ uvOffset*x).rgb;\r\n            let sample2:vec3<f32>=textureSample(tDiffuse, tSampler, input.uv- uvOffset*x).rgb;\r\n            diffuseSum =diffuseSum+ (sample2+sample2)* w;\r\n            weightSum += 2.0 * w;\r\n        }\r\n        diffuseSum/=weightSum;\r\n      return vec4<f32>(diffuseSum,baseColor.a);\r\n    }\r\n  `;\r\n}\r\n","export default function LuminosityHigh(defines) {\r\n\treturn `\r\n    struct LuminosityUniforms{\r\n        luminosityThreshold:f32,\r\n        smoothWidth:f32,\r\n        defaultColor:vec3<f32>,\r\n        defaultOpacity:f32,\r\n    }\r\n    struct FragInput {\r\n        @location(0) uv: vec2<f32>,\r\n    };\r\n    @group(0) @binding(0)  var<uniform> luminosityUniforms : LuminosityUniforms;\r\n    @group(0) @binding({{tDiffuseBinding}}) var tDiffuse: texture_2d<f32>;\r\n    @group(0) @binding({{tSamplerBinding}}) var tSampler: sampler;\r\n    @fragment\r\n    fn main(input:FragInput)-> @location(0) vec4<f32> {\r\n\r\n        let texel:vec4<f32> = textureSample(tDiffuse, tSampler, input.uv);\r\n\r\n        let luma:vec3<f32> = vec3<f32>( 0.299,0.587,0.114 );\r\n\r\n        let v:f32 = dot( texel.xyz, luma );\r\n\r\n        let outputColor:vec4<f32> = vec4<f32>( luminosityUniforms.defaultColor.rgb, luminosityUniforms.defaultOpacity );\r\n\r\n        let alpha:f32 = smoothstep( luminosityUniforms.luminosityThreshold, luminosityUniforms.luminosityThreshold + luminosityUniforms.smoothWidth, v );\r\n\r\n       return mix( outputColor, texel, alpha );\r\n    }\r\n    `;\r\n}\r\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\n\nexport function FragInput(defines) {\n\treturn wgslParseDefines`\n    struct FragInput {\n      @builtin(front_facing) frontFacing: bool,\n      @location(0) worldPos:vec3<f32>,\n      @location(1) normal:vec3<f32>,\n      @location(2) uv:vec2<f32>,\n      @location(3) view: vec3<f32>, // Vector from vertex to camera.\n      @location(4) color: vec4<f32>,\n      @location(5) viewPosition: vec3<f32>,\n  } \n  `;\n}\n","export function PointFragInput(defines) {\n\treturn `\n      struct PointFragInput{\n        @location(0) uv:vec2<f32>,\n        @location(1) color: vec4<f32>,\n        @location(2) size: f32,\n      }\n    `;\n}\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\n\nexport function PointVertInput(defines) {\n\treturn wgslParseDefines`\n  struct PointVertInput {\n    @location(${defines.positionLocation}) position: vec3<f32>,       \n    @location(${defines.uvLocation}) uv: vec2<f32>,\n    #if${defines.HAS_COLOR} \n        @location(${defines.colorLocation}) color: vec3<f32>,\n    #endif\n    #if ${defines.HAS_SIZE}\n        @location(${defines.sizeLocation}) size: f32,\n    #endif\n    #if ${defines.USE_INSTANCE}\n        @builtin(instance_index) instanceIdx : u32\n    #endif\n  }\n  `;\n}\n","export function PointVertOutput(defines) {\n\treturn `\n    struct PointVertOutput{\n        @builtin(position) position:vec4<f32>,\n        @location(0) uv:vec2<f32>,\n        @location(1) color: vec4<f32>,\n        @location(2) size: f32,\n    }\n   `;\n}\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\n\nexport function VertexInput(defines) {\n\treturn wgslParseDefines`\n        struct VertexInput {\n            @location(${defines.positionLocation}) position: vec3<f32>,   \n            #if${defines.HAS_NORMAL}  \n                @location(${defines.normalLocation}) normal: vec3<f32>,\n            #endif\n            #if${defines.HAS_COLOR} \n                @location(${defines.colorLocation}) color: vec3<f32>,\n            #endif\n            #if ${defines.HAS_UV}\n                @location(${defines.uvLocation}) uv: vec2<f32>,\n            #endif\n            #if${defines.HAS_SKIN} \n                @location(${defines.joint0Location}) joint0:vec4<f32>,\n                @location(${defines.weight0Location}) weight0:vec4<f32>,\n            #endif\n            #if ${defines.USE_INSTANCE}\n                @builtin(instance_index) instanceIdx : u32\n            #endif\n        }\n   `;\n}\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\n\nexport function VertexOutput(defines) {\n\treturn wgslParseDefines`\n    struct VertexOutput {\n        @builtin(position) position:vec4<f32>,\n        @location(0) worldPos:vec3<f32>,\n        @location(1) normal:vec3<f32>,\n        @location(2) uv:vec2<f32>,\n        @location(3) view: vec3<f32>, // Vector from vertex to camera.\n        @location(4) color: vec4<f32>,\n        @location(5) viewPosition: vec3<f32>,\n    } \n    `;\n}\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\n\nexport function SystemUniform(defines) {\n\treturn wgslParseDefines`\n      struct SystemUniform {\n          projectionMatrix: mat4x4<f32>,\n          viewMatrix: mat4x4<f32>,\n          inverseViewMatrix: mat4x4<f32>,\n          cameraPosition: vec3<f32>,\n      }; \n  `;\n}\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\n\nexport function TextureAndSamplerDefine(defines) {\n\treturn wgslParseDefines`\n    #if ${defines.USE_IBL}\n      @group(0) @binding(${defines.specularEnvTextureBinding}) var specularEnvTexture: texture_cube<f32>;\n      @group(0) @binding(${defines.specularEnvSamplerBinding}) var specularEnvSampler: sampler;\n    #endif\n    #if ${defines.USE_TEXTURE}\n      @group(0) @binding(${defines.baseColorTextureBinding}) var baseColorTexture: texture_2d<f32>;\n      @group(0) @binding(${defines.baseColorSamplerBinding}) var baseColorSampler: sampler;\n    #endif\n    // normal map\n    #if ${defines.USE_NORMALTEXTURE}\n      @group(0) @binding(${defines.normalTextureBinding}) var normalTexture: texture_2d<f32>;\n      @group(0) @binding(${defines.normalSamplerBinding}) var normalSampler: sampler;\n    #endif\n    // emmisve map\n    #if ${defines.USE_EMISSIVETEXTURE}\n      @group(0) @binding(${defines.emissiveTextureBinding}) var emissiveTexture: texture_2d<f32>;\n      @group(0) @binding(${defines.emissiveSamplerBinding}) var emissiveSampler: sampler;\n    #endif\n\n    // metal roughness\n    #if ${defines.USE_METALNESSTEXTURE}\n      @group(0) @binding(${defines.metalnessRoughnessTextureBinding}) var metalnessRoughnessTexture: texture_2d<f32>;\n      @group(0) @binding(${defines.metalnessRoughnessSamplerBinding}) var metalnessRoughnessSampler: sampler;\n    #endif\n    // occlusion texture\n    #if ${defines.USE_AOTEXTURE}\n      @group(0) @binding(${defines.aoTextureBinding}) var aoTexture: texture_2d<f32>;\n      @group(0) @binding(${defines.aoSamplerBinding}) var aoSampler: sampler;\n    #endif\n    #if ${defines.USE_NORMALTEXTURE}\n      #include <getTBN>\n      #include <getNormalByNormalTexture>\n    #else\n      #include <getNormal>\n    #endif\n  `;\n}\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\r\nexport default function environment(defines) {\r\n  return wgslParseDefines`\r\n   #if ${defines.ENVTEXTURE_TYPE_CUBE_UV}\r\n        const cubeUV_minMipLevel:f32= 4.0;\r\n        const cubeUV_minTileSize:f32= 16.0;\r\n        const CUBEUV_MAX_MIP:f32=6.0;\r\n        const CUBEUV_TEXEL_WIDTH:f32=1.0/256.0;\r\n        const CUBEUV_TEXEL_HEIGHT:f32=1.0/256.0;\r\n        fn getFace(direction:vec3<f32> )->f32 {\r\n            let absDirection:vec3<f32> = abs( direction );\r\n            var face:f32 = - 1.0;\r\n            if ( absDirection.x > absDirection.z ) {\r\n                if ( absDirection.x > absDirection.y ){\r\n                    face =select(3.0,0.0,direction.x > 0.0);\r\n                }else{\r\n                    face =select(4.0,1.0,direction.y > 0.0);\r\n                }\r\n                \r\n            }\r\n            else {\r\n                if ( absDirection.z > absDirection.y ){\r\n                    face =select(5.0,2.0,direction.z > 0.0);\r\n                }else{\r\n                    face =select(4.0,1.0,direction.y > 0.0);\r\n                }       \r\n            }\r\n            return face;\r\n        }\r\n        fn getUV( direction:vec3<f32>, face:f32 )->vec2<f32> {\r\n            var uv:vec2<f32>;\r\n            if ( face == 0.0 ) {\r\n                uv = vec2<f32>( direction.z, direction.y ) / abs( direction.x );\r\n            }\r\n            else if ( face == 1.0 ) {\r\n                uv = vec2<f32>( - direction.x, - direction.z ) / abs( direction.y );\r\n            }\r\n            else if ( face == 2.0 ) {\r\n                uv = vec2<f32>( - direction.x, direction.y ) / abs( direction.z );\r\n            }\r\n            else if ( face == 3.0 ) {\r\n                uv = vec2<f32>( - direction.z, direction.y ) / abs( direction.x );\r\n            }\r\n            else if ( face == 4.0 ) {\r\n                uv = vec2<f32>( - direction.x, direction.z ) / abs( direction.y );\r\n            }\r\n            else {\r\n                uv = vec2<f32>( direction.x, direction.y ) / abs( direction.z );\r\n            }\r\n            return 0.5 * ( uv + 1.0 );\r\n        }\r\n        fn bilinearCubeUV(envTexture:texture_cube<f32>,baseSampler:sampler,direction:vec3<f32>, mipInt:f32 )->vec3<f32> {\r\n            var face:f32 = getFace( direction );\r\n            let filterInt:f32 = max( cubeUV_minMipLevel - mipInt, 0.0 );\r\n            let tempMipInt = max( mipInt, cubeUV_minMipLevel );\r\n            let faceSize:f32 = exp2( tempMipInt );\r\n            var uv:vec2<f32> = getUV( direction, face ) * ( faceSize - 2.0 ) + 1.0;\r\n            if ( face > 2.0 ) {\r\n                uv.y += faceSize;\r\n                face -= 3.0;\r\n            }\r\n            uv.x += face * faceSize;\r\n            uv.x += filterInt * 3.0 * cubeUV_minTileSize;\r\n            uv.y += 4.0 * ( exp2( CUBEUV_MAX_MIP ) - faceSize );\r\n            uv.x *= CUBEUV_TEXEL_WIDTH;\r\n            uv.y *= CUBEUV_TEXEL_HEIGHT;\r\n            return textureSample(envTexture,baseSampler,direction).rgb;\r\n        }\r\n        const cubeUV_r0:f32= 1.0;\r\n        const cubeUV_v0:f32= 0.339;\r\n        const cubeUV_m0:f32= - 2.0;\r\n        const cubeUV_r1:f32= 0.8;\r\n        const cubeUV_v1:f32= 0.276;\r\n        const cubeUV_m1:f32= - 1.0;\r\n        const cubeUV_r4:f32= 0.4;\r\n        const cubeUV_v4:f32= 0.046;\r\n        const cubeUV_m4:f32= 2.0;\r\n        const cubeUV_r5:f32= 0.305;\r\n        const cubeUV_v5:f32= 0.016;\r\n        const cubeUV_m5:f32= 3.0;\r\n        const cubeUV_r6:f32= 0.21;\r\n        const cubeUV_v6:f32= 0.0038;\r\n        const cubeUV_m6:f32= 4.0;\r\n        fn roughnessToMip( roughness:f32)->f32 {\r\n            var mip:f32 = 0.0;\r\n            if ( roughness >= cubeUV_r1 ) {\r\n                mip = ( cubeUV_r0 - roughness ) * ( cubeUV_m1 - cubeUV_m0 ) / ( cubeUV_r0 - cubeUV_r1 ) + cubeUV_m0;\r\n            }\r\n            else if ( roughness >= cubeUV_r4 ) {\r\n                mip = ( cubeUV_r1 - roughness ) * ( cubeUV_m4 - cubeUV_m1 ) / ( cubeUV_r1 - cubeUV_r4 ) + cubeUV_m1;\r\n            }\r\n            else if ( roughness >= cubeUV_r5 ) {\r\n                mip = ( cubeUV_r4 - roughness ) * ( cubeUV_m5 - cubeUV_m4 ) / ( cubeUV_r4 - cubeUV_r5 ) + cubeUV_m4;\r\n            }\r\n            else if ( roughness >= cubeUV_r6 ) {\r\n                mip = ( cubeUV_r5 - roughness ) * ( cubeUV_m6 - cubeUV_m5 ) / ( cubeUV_r5 - cubeUV_r6 ) + cubeUV_m5;\r\n            }\r\n            else {\r\n                mip = - 2.0 * log2( 1.16 * roughness );\r\n            }\r\n            return mip;\r\n        }\r\n        fn textureCubeUV(envTexture:texture_cube<f32>, baseSampler:sampler,sampleDir:vec3<f32>,roughness:f32 )->vec4<f32> {\r\n            let mip = clamp( roughnessToMip( roughness ), cubeUV_m0, CUBEUV_MAX_MIP );\r\n            let mipF = fract( mip );\r\n            let mipInt = floor( mip );\r\n            let color0:vec3<f32> = bilinearCubeUV( envTexture,baseSampler,sampleDir, mipInt );\r\n            if ( mipF == 0.0 ) {\r\n                return vec4<f32>(color0, 1.0 );\r\n            }\r\n            else {\r\n                let color1:vec3<f32> = bilinearCubeUV( envTexture,baseSampler, sampleDir, mipInt + 1.0 );\r\n                return vec4<f32>(mix( color0, color1, mipF ), 1.0 );\r\n            }\r\n        \r\n        }\r\n   #endif\r\n   #if ${defines.USE_ENVTEXTURE}\r\n        fn getIBLIrradiance( normal:vec3<f32>,baseSampler:sampler,viewMatrix:mat4x4<f32>)->vec3<f32> {\r\n            #if ${defines.ENVTEXTURE_TYPE_CUBE_UV}\r\n                let worldNormal:vec3<f32> = inverseTransformDirection( normal, viewMatrix );\r\n                let envTextureColor:vec4<f32> = textureCubeUV( envTexture,baseSampler, worldNormal, 1.0 );\r\n                return PI * envTextureColor.rgb * materialUniform.envTextureIntensity;\r\n            #else\r\n                return vec3<f32>( 0.0 );\r\n            #endif\r\n        }\r\n        fn getIBLRadiance( viewDir:vec3<f32>,baseSampler:sampler,viewMatrix:mat4x4<f32>,normal:vec3<f32>, roughness:f32 )->vec3<f32> {\r\n            #if ${defines.ENVTEXTURE_TYPE_CUBE_UV}\r\n                var reflectVec:vec3<f32> = reflect( - viewDir, normal );\r\n                reflectVec = normalize( mix( reflectVec, normal, roughness * roughness) );\r\n                reflectVec = inverseTransformDirection( reflectVec, viewMatrix );\r\n                let envTextureColor:vec4<f32> = textureCubeUV( envTexture,baseSampler, reflectVec, roughness );\r\n                return envTextureColor.rgb * materialUniform.envTextureIntensity;\r\n            #else\r\n                return vec3<f32>( 0.0 );\r\n            #endif\r\n            }\r\n    #endif\r\n   `;\r\n}\r\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\n\nexport function instanceVertHeader(defines) {\n\treturn wgslParseDefines`\n   #if ${defines.USE_INSTANCE}\n      struct InstancesUniform {\n         instanceMatrixs:  array<mat4x4<f32>, ${defines.instanceCount}>,\n      };\n      @group(0) @binding(${defines.instanceMatrixsBufferBinding}) var<storage, read> instancesUniform: InstancesUniform;\n    #endif\n   `;\n}\nexport function instanceVertMain(defines) {\n\treturn wgslParseDefines`\n      #if ${defines.USE_INSTANCE}\n         modelMatrix=instancesUniform.instanceMatrixs[input.instanceIdx];\n      #endif\n   `;\n}\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\r\nexport default function light(defines) {\r\n\treturn wgslParseDefines` \r\n    struct ReflectedLight {\r\n        ambient: vec3<f32>,\r\n        directDiffuse:vec3<f32>,\r\n        directSpecular:vec3<f32>,\r\n        indirectDiffuse:vec3<f32>,\r\n        indirectSpecular:vec3<f32>,\r\n        testColor: vec3<f32>,\r\n    }; \r\n    struct IncidentLight {\r\n        color: vec3<f32>,\r\n        direction: vec3<f32>,\r\n        visible: bool,\r\n    };\r\n    struct Geometry {\r\n        position: vec3<f32>,\r\n        normal: vec3<f32>,\r\n        viewDir: vec3<f32>,\r\n        dotNV:f32,\r\n        #if ${defines.USE_CLEARCOAT}\r\n            vec3 clearcoatNormal;\r\n        #endif\r\n    };\r\n\r\n    #if ${defines.spotLightsCount > 0}\r\n        struct SpotLight {\r\n            position: vec3<f32>,\r\n            distance: f32,\r\n            direction: vec3<f32>,\r\n            coneCos: f32,\r\n            color: vec3<f32>,\r\n            penumbraCos: f32,\r\n            decay: f32,\r\n        };\r\n        fn getSpotLightInfo(spotLight:SpotLight,worldPos:vec3<f32>,shininess:f32,N:vec3<f32>,V:vec3<f32>)->ReflectedLight{\r\n                var direction:vec3<f32> = spotLight.position - worldPos;\r\n                var lightColor:ReflectedLight;\r\n                let lightDistance:f32 = length(direction);\r\n                direction = normalize(direction);\r\n                let angleCos:f32 = dot( direction, spotLight.direction );\r\n                let decay:f32 = clamp(1.0 - pow(lightDistance/spotLight.distance, spotLight.decay), 0.0, 1.0);\r\n                let spotEffect:f32 = smoothstep( spotLight.penumbraCos, spotLight.coneCos, angleCos );\r\n                let decayTotal:f32 = decay * spotEffect;\r\n                let d:f32 = max( dot( N, direction ), 0.0 )  * decayTotal;\r\n                lightColor.directDiffuse= spotLight.color * d;\r\n                let halfDir:vec3<f32> = normalize( V + direction );\r\n                let s:f32 = pow( clamp( dot( N, halfDir ), 0.0, 1.0 ), shininess ) * decayTotal;\r\n                lightColor.directSpecular= spotLight.color * s;\r\n                return lightColor;\r\n        }\r\n        fn getSpotLightIncidentLight(spotLight:SpotLight, geometry:Geometry)->IncidentLight {\r\n            var incidentLight:IncidentLight;\r\n            let lVector:vec3<f32> = spotLight.position - geometry.position;\r\n            incidentLight.direction = normalize( lVector );\r\n    \r\n            let lightDistance:f32 = length( lVector );\r\n            let angleCos:f32 = dot( incidentLight.direction, spotLight.direction );\r\n    \r\n            let spotEffect:f32 = smoothstep( spotLight.penumbraCos, spotLight.coneCos, angleCos );\r\n            let decayEffect:f32 = clamp(1.0 - pow(lightDistance/spotLight.distance, 4.0), 0.0, 1.0);\r\n    \r\n            incidentLight.color=spotLight.color*spotEffect * decayEffect; \r\n            return  incidentLight;\r\n        }\r\n\r\n    #endif \r\n\r\n    #if ${defines.pointLightsCount > 0}\r\n        struct PointLight {\r\n            position: vec3<f32>,\r\n            distance: f32,\r\n            color: vec3<f32>,\r\n            decay: f32,\r\n        };\r\n        fn getPointLightInfo(pointLight:PointLight,worldPos:vec3<f32>,shininess:f32,N:vec3<f32>,V:vec3<f32>)->ReflectedLight{\r\n            var lightColor:ReflectedLight;\r\n            var direction:vec3<f32> = worldPos - pointLight.position;\r\n            let dist:f32 = length( direction );\r\n            direction = normalize(direction);\r\n            let decay = clamp(1.0 - pow(dist / pointLight.distance, pointLight.decay), 0.0, 1.0);\r\n    \r\n            let d =  max( dot( N, -direction ), 0.0 ) * decay;\r\n            lightColor.directDiffuse = pointLight.color * d;\r\n    \r\n            let halfDir:vec3<f32> = normalize( V - direction );\r\n            let s:f32 = pow( clamp( dot( N, halfDir ), 0.0, 1.0 ), shininess )  * decay;\r\n            lightColor.directSpecular = pointLight.color * s;\r\n            return lightColor;\r\n        }\r\n        fn getPointLightIncidentLight(pointLight:PointLight, geometry:Geometry)->IncidentLight {\r\n            var incidentLight:IncidentLight;\r\n            let lVector:vec3<f32> = pointLight.position-geometry.position;\r\n            incidentLight.direction= normalize( lVector );\r\n            let lightDistance:f32 = length( lVector );\r\n            // let weight:f32=1.0 - pow(lightDistance/pointLight.distance, 4.0);\r\n            incidentLight.color=pointLight.color*clamp(1.0 - pow(lightDistance/pointLight.distance, 4.0), 0.0, 1.0);\r\n            return incidentLight;\r\n        }\r\n    #endif\r\n    #if ${defines.dirtectLightsCount > 0}\r\n        struct DirectionalLight {\r\n            direction: vec3<f32>,\r\n            color: vec3<f32>,\r\n        };\r\n        fn getDirectLightInfo(directionalLight:DirectionalLight,shininess:f32,N:vec3<f32>,V:vec3<f32>)->ReflectedLight{\r\n            var lightColor:ReflectedLight;\r\n            let d:f32 = max(dot(N, -directionalLight.direction), 0.0);\r\n            lightColor.directDiffuse += directionalLight.color * d;\r\n    \r\n            let halfDir:vec3<f32> = normalize( V - directionalLight.direction );\r\n            let s:f32 = pow( clamp( dot( N, halfDir ), 0.0, 1.0 ), shininess );\r\n            lightColor.directSpecular += directionalLight.color * s;\r\n            return lightColor;\r\n        }\r\n        fn getDirectionalDirectLightIncidentLight(directionalLight:DirectionalLight,geometry:Geometry)->IncidentLight {\r\n            var incidentLight:IncidentLight;\r\n            incidentLight.color = directionalLight.color;\r\n            incidentLight.direction = normalize(directionalLight.direction);\r\n            return incidentLight;         \r\n        }\r\n    #endif\r\n\r\n    #if ${defines.openShadow} \r\n        struct LightInfo {\r\n            direction: vec3<f32>,\r\n            viewport: vec4<f32>,\r\n        };\r\n        \r\n        fn linearizeDepth(depth: f32, near: f32, far: f32)->f32 {\r\n            return 2 * (near * far) / (far + near - depth * (far - near));\r\n        }\r\n\r\n        fn getCubeFace(v : vec3<f32>) -> i32{\r\n            let vAbs = abs(v);\r\n        \r\n            if (vAbs.z >= vAbs.x && vAbs.z >= vAbs.y) {\r\n              if (v.z < 0.0) {\r\n                return 3;\r\n              }\r\n              return 2;\r\n            }\r\n        \r\n            if (vAbs.y >= vAbs.x) {\r\n              if (v.y < 0.0) {\r\n                return 5;\r\n              }\r\n              return 4;\r\n            }\r\n        \r\n            if (v.x < 0.0) {\r\n              return 1;\r\n            }\r\n            return 0;\r\n        }\r\n\r\n        fn getShadowValue(shadowMapArray:texture_depth_2d_array, shadowSampler:sampler_comparison, lightPos:vec4<f32>, geometry:Geometry, lightInfo:LightInfo, index:u32, isPointLight: bool, near: f32, far: f32)->f32 {\r\n            var visibility = 0.0;\r\n            var projectPos: vec3<f32> = lightPos.xyz / lightPos.w;\r\n            var shadowPos: vec3<f32> = vec3(projectPos.xy * vec2(0.5, -0.5) + vec2(0.5), projectPos.z);\r\n            var d:f32 = dot(geometry.normal, -lightInfo.direction);\r\n            var bias = max(0.012 * (1.0 - d), 0.001) / lightPos.w;\r\n            let oneOverShadowDepthTextureSize = 1.0 / 1024.0;\r\n            // var depth = select(shadowPos.z, (linearizeDepth(shadowPos.z, near, far) - near) / (far- near), isPerspectiveCamera);\r\n            var depth = shadowPos.z;\r\n\r\n            if (isPointLight) {\r\n                shadowPos.x = shadowPos.x * lightInfo.viewport.z;\r\n                shadowPos.y = shadowPos.y * lightInfo.viewport.w;\r\n                var viewportX = lightInfo.viewport.x * lightInfo.viewport.z;\r\n                var viewportY = lightInfo.viewport.y * lightInfo.viewport.w;\r\n                var uvOffset = 1.5 / 1024.0;\r\n                shadowPos.x = clamp(shadowPos.x + viewportX, viewportX + uvOffset, viewportX + lightInfo.viewport.z - uvOffset);\r\n                shadowPos.y = clamp(shadowPos.y + viewportY, viewportY + uvOffset, viewportY + lightInfo.viewport.w - uvOffset);\r\n            }\r\n\r\n            for (var y = -1; y <= 1; y++) {\r\n                for (var x = -1; x <= 1; x++) {\r\n                    let offset = vec2<f32>(vec2(x, y)) * oneOverShadowDepthTextureSize;\r\n                \r\n                    visibility += textureSampleCompare(\r\n                        shadowMapArray, shadowSampler,\r\n                        shadowPos.xy + offset, index, depth - bias);\r\n                }\r\n            }\r\n            visibility /= 9.0;\r\n            var inFrustum = shadowPos.x >= 0.0 && shadowPos.x <= 1.0 && shadowPos.y >= 0.0 && shadowPos.y <= 1.0;\r\n            if (!inFrustum || depth > 1.0) {\r\n                visibility = 1.0;\r\n            }\r\n            return visibility;\r\n        }\r\n    #endif\r\n\r\n    #if ${\r\n\t\tdefines.ambientLightCount || defines.spotLightsCount || defines.pointLightsCount || defines.dirtectLightsCount\r\n\t}\r\n        struct LightUniforms{\r\n            #if ${defines.ambientLightCount}\r\n                ambient:vec4<f32>,\r\n            #endif\r\n            #if ${defines.spotLightsCount}\r\n                spotLights:array<SpotLight,${defines.spotLightsCount}>,\r\n            #endif\r\n            #if ${defines.pointLightsCount}\r\n                pointLights:array<PointLight,${defines.pointLightsCount}>,\r\n            #endif\r\n            #if ${defines.dirtectLightsCount}\r\n                dirtectLights:array<DirectionalLight,${defines.dirtectLightsCount}>,\r\n            #endif\r\n        }\r\n        @group(2) @binding(${defines.lightBinding}) var<storage, read> lightUniforms: LightUniforms;\r\n\r\n        #if ${defines.openShadow}\r\n            #if ${defines.spotLightShadowMapsCount}\r\n                struct SpotLightShadow {\r\n                    shadowCameraVPMatrix: mat4x4<f32>,\r\n                    shadowCameraNear: f32,\r\n                    shadowCameraFar: f32\r\n                }\r\n            #endif\r\n            #if ${defines.pointLightShadowMapsCount}\r\n                struct PointLightShadow {\r\n                    shadowCameraVPMatrixArray: array<mat4x4<f32>, 6>,\r\n                    shadowCameraViewportArray: array<vec4<f32>, 6>,\r\n                    shadowCameraNear: f32,\r\n                    shadowCameraFar: f32,\r\n                    // shadowCameraVPMatrix: mat4x4<f32>,\r\n                    // shadowCameraVPMatrixArray: array<mat4x4<f32>, 6>,\r\n                    // shadowCameraViewportArray: array<vec4<f32>, 6>,\r\n                }\r\n            #endif\r\n            #if ${defines.directLightShadowMapsCount}\r\n                struct DirectLightShadow {\r\n                    shadowCameraVPMatrix: mat4x4<f32>,\r\n                }\r\n            #endif\r\n            struct ShadowUniforms{\r\n                #if ${defines.spotLightShadowMapsCount}\r\n                    spotLightShadows:array<SpotLightShadow,${defines.spotLightShadowMapsCount}>,\r\n                #endif\r\n                #if ${defines.pointLightShadowMapsCount}\r\n                    pointLightShadows:array<PointLightShadow,${defines.pointLightShadowMapsCount}>,\r\n                #endif\r\n                #if ${defines.directLightShadowMapsCount}\r\n                    directLightShadows:array<DirectLightShadow,${defines.directLightShadowMapsCount}>,\r\n                #endif\r\n            }\r\n            @group(2) @binding(${defines.shadowBinding}) var<storage, read> shadowUniforms: ShadowUniforms;\r\n\r\n            #if ${defines.spotLightShadowMapTextureArrayBinding}\r\n                @group(2) @binding(${\r\n\t\t\t\t\tdefines.spotLightShadowMapTextureArrayBinding\r\n\t\t\t\t}) var spotLightShadowMapTextureArray: texture_depth_2d_array;\r\n            #endif\r\n            #if ${defines.pointLightShadowMapTextureArrayBinding}\r\n                @group(2) @binding(${\r\n\t\t\t\t\tdefines.pointLightShadowMapTextureArrayBinding\r\n\t\t\t\t}) var pointLightShadowMapTextureArray: texture_depth_2d_array;\r\n            #endif\r\n            #if ${defines.directLightShadowMapTextureArrayBinding}\r\n                @group(2) @binding(${\r\n\t\t\t\t\tdefines.directLightShadowMapTextureArrayBinding\r\n\t\t\t\t}) var directLightShadowMapTextureArray: texture_depth_2d_array;\r\n            #endif\r\n            @group(2) @binding(${defines.shadowSamplerBinding}) var shadowSampler: sampler_comparison;\r\n        #endif\r\n\r\n    #endif\r\n    #if ${defines.materialPhong}\r\n        fn parseLights(geometry:Geometry,shininess:f32)->ReflectedLight {\r\n    #elif ${defines.materialPbr}\r\n        fn parseLights(geometry:Geometry,material:PhysicalMaterial)->ReflectedLight{\r\n    #endif\r\n        var reflectedLight:ReflectedLight;\r\n        var shadowValue:f32 = 1.0;\r\n        #if ${defines.ambientLightCount > 0}\r\n            //处理环境光\r\n            var ambientColor:vec3<f32> = lightUniforms.ambient.xyz * lightUniforms.ambient.w;\r\n            reflectedLight.ambient += ambientColor;\r\n        #endif\r\n\r\n        #if ${defines.spotLightsCount > 0}\r\n            //处理聚光灯\r\n            var spotLight:SpotLight;\r\n            for (var k = 0u; k < ${defines.spotLightsCount}; k = k + 1u) {\r\n                spotLight= lightUniforms.spotLights[k];\r\n                #if ${defines.materialPhong && defines.openShadow && defines.spotLightShadowMapsCount}\r\n                    if k < textureNumLayers(spotLightShadowMapTextureArray) {\r\n                        var spotLightShadow:SpotLightShadow = shadowUniforms.spotLightShadows[k];\r\n                        var lightPos: vec4<f32> = spotLightShadow.shadowCameraVPMatrix * vec4<f32>(geometry.position,1.0);\r\n                        var lightInfo:LightInfo;\r\n                        lightInfo.direction = normalize(geometry.position - spotLight.position);\r\n\r\n                        shadowValue = getShadowValue(spotLightShadowMapTextureArray, shadowSampler, lightPos, geometry, lightInfo, k, false,\r\n                            spotLightShadow.shadowCameraNear, spotLightShadow.shadowCameraFar);\r\n                    }\r\n                    spotLight.color *= shadowValue;\r\n                #endif\r\n                #if ${defines.materialPhong}\r\n                    let spReflectedLight=getSpotLightInfo(spotLight,geometry.position,shininess,geometry.normal,geometry.viewDir);\r\n                #elif ${defines.materialPbr}\r\n                    let incidentLight=getSpotLightIncidentLight(spotLight,geometry);\r\n                    let spReflectedLight=direct_Physical(incidentLight, geometry, material);\r\n                #endif\r\n\r\n                reflectedLight.directDiffuse+=spReflectedLight.directDiffuse;\r\n                reflectedLight.directSpecular+=spReflectedLight.directSpecular;\r\n            }\r\n        #endif\r\n        #if ${defines.pointLightsCount > 0}\r\n            //处理点光源\r\n            var pointLight:PointLight;\r\n            for (var j = 0u; j < ${defines.pointLightsCount};j = j + 1u) {\r\n                pointLight = lightUniforms.pointLights[j];\r\n                #if ${defines.materialPhong && defines.openShadow && defines.pointLightShadowMapsCount}\r\n                    if j < textureNumLayers(pointLightShadowMapTextureArray) {\r\n                        var pointLightShadow:PointLightShadow = shadowUniforms.pointLightShadows[j];\r\n                        var lightInfo:LightInfo;\r\n                        lightInfo.direction = normalize(geometry.position - pointLight.position);\r\n                        var cubeFace = getCubeFace(lightInfo.direction);\r\n                        var lightPos: vec4<f32> = pointLightShadow.shadowCameraVPMatrixArray[cubeFace] * vec4<f32>(geometry.position,1.0);\r\n                        lightInfo.viewport = pointLightShadow.shadowCameraViewportArray[cubeFace];\r\n\r\n                        // var lightPos: vec4<f32> = pointLightShadow.shadowCameraVPMatrix * vec4<f32>(geometry.position,1.0);\r\n\r\n                        shadowValue = getShadowValue(pointLightShadowMapTextureArray, shadowSampler, lightPos, geometry, lightInfo, j, true,\r\n                            pointLightShadow.shadowCameraNear, pointLightShadow.shadowCameraFar);\r\n                        \r\n                        // reflectedLight.testColor = vec3(pointLightShadow.shadowCameraFar / 1000, \r\n                        //     pointLightShadow.shadowCameraVPMatrixArray[5][3][2] / 255, pointLightShadow.shadowCameraVPMatrixArray[5][3][3] / 255);\r\n                        // reflectedLight.testColor = vec3(pointLightShadow.shadowCameraNear, pointLightShadow.shadowCameraNear, pointLightShadow.shadowCameraNear);\r\n                    }\r\n                    pointLight.color *= shadowValue;\r\n                #endif\r\n                #if ${defines.materialPhong}\r\n                    let poiReflectedLight=getPointLightInfo(pointLight,geometry.position,shininess,geometry.normal,geometry.viewDir);\r\n                #elif ${defines.materialPbr}\r\n                   let incidentLight=getPointLightIncidentLight(pointLight,geometry);\r\n                   let poiReflectedLight=direct_Physical(incidentLight, geometry, material);\r\n                #endif\r\n\r\n                reflectedLight.directDiffuse+=poiReflectedLight.directDiffuse;\r\n                reflectedLight.directSpecular+=poiReflectedLight.directSpecular;\r\n            }\r\n        #endif\r\n        #if ${defines.dirtectLightsCount > 0}\r\n            //处理方向光\r\n            var directionalLight:DirectionalLight;\r\n            for (var i= 0u; i <${defines.dirtectLightsCount}; i = i + 1u) {\r\n                directionalLight = lightUniforms.dirtectLights[i];\r\n                #if ${defines.materialPhong && defines.openShadow && defines.directLightShadowMapsCount}\r\n                    if i < textureNumLayers(directLightShadowMapTextureArray) {\r\n                        var directLightShadow:DirectLightShadow = shadowUniforms.directLightShadows[i];\r\n                        var lightPos: vec4<f32> = directLightShadow.shadowCameraVPMatrix * vec4<f32>(geometry.position,1.0);\r\n                        var lightInfo:LightInfo;\r\n                        lightInfo.direction = directionalLight.direction;\r\n                            \r\n                        shadowValue = getShadowValue(directLightShadowMapTextureArray, shadowSampler, lightPos, geometry, lightInfo, i, false, 0, 0);\r\n                    }\r\n                    directionalLight.color *= shadowValue;\r\n                #endif\r\n            \r\n                #if ${defines.materialPhong}\r\n                    let dirReflectedLight=getDirectLightInfo(directionalLight,shininess,geometry.normal,geometry.viewDir);\r\n                #elif ${defines.materialPbr}\r\n                    let incidentLight=getDirectionalDirectLightIncidentLight(directionalLight,geometry);\r\n                    let dirReflectedLight=direct_Physical(incidentLight, geometry, material);\r\n                #endif\r\n\r\n                reflectedLight.directDiffuse+=dirReflectedLight.directDiffuse;\r\n                reflectedLight.directSpecular+=dirReflectedLight.directSpecular;\r\n            }\r\n        #endif\r\n        return reflectedLight;\r\n    }`;\r\n}\r\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\r\nexport default function lightCommon(defines) {\r\n\treturn wgslParseDefines`\r\n    struct ReflectedLight {\r\n        directDiffuse:vec3<f32>,\r\n        directSpecular:vec3<f32>,\r\n        indirectDiffuse:vec3<f32>,\r\n        indirectSpecular:vec3<f32>,\r\n    };\r\n    struct Geometry {\r\n        position: vec3<f32>,\r\n        normal: vec3<f32>,\r\n        viewDir: vec3<f32>,\r\n        #if ${defines.USE_CLEARCOAT}\r\n            vec3 clearcoatNormal;\r\n        #endif\r\n    };\r\n    fn getAmbientLightIrradiance(ambientLightColor: vec3<f32>) -> vec3<f32> {\r\n        let irradiance = ambientLightColor;\r\n        return irradiance;\r\n    }\r\n    fn getDistanceAttenuation(lightDistance: f32, cutoffDistance: f32, decayExponent: f32) -> f32 {\r\n        if (cutoffDistance > 0.0 && decayExponent > 0.0) {\r\n            let x:f32 = saturate(- lightDistance / cutoffDistance + 1.0);\r\n            return pow(x, decayExponent);\r\n        }\r\n        return 1.0;\r\n    }\r\n    fn getSpotAttenuation(coneCosine: f32, penumbraCosine: f32, angleCosine: f32) -> f32 {\r\n        return smoothstep(coneCosine, penumbraCosine, angleCosine);\r\n    }\r\n    fn shGetIrradianceAt( normal:vec3<f32>, shCoefficients:array<vec3<f32>,9>)->vec3<f32> {\r\n        let x:f32 = normal.x; \r\n        let y:f32 = normal.y; \r\n        let z:f32 = normal.z;\r\n        var result:vec3<f32> = shCoefficients[ 0 ] * 0.886227;\r\n        result += shCoefficients[ 1 ] * 2.0 * 0.511664 * y;\r\n        result += shCoefficients[ 2 ] * 2.0 * 0.511664 * z;\r\n        result += shCoefficients[ 3 ] * 2.0 * 0.511664 * x;\r\n        result += shCoefficients[ 4 ] * 2.0 * 0.429043 * x * y;\r\n        result += shCoefficients[ 5 ] * 2.0 * 0.429043 * y * z;\r\n        result += shCoefficients[ 6 ] * ( 0.743125 * z * z - 0.247708 );\r\n        result += shCoefficients[ 7 ] * 2.0 * 0.429043 * x * z;\r\n        result += shCoefficients[ 8 ] * 0.429043 * ( x * x - y * y );\r\n        return result;\r\n    }\r\n    fn inverseTransformDirection( dir:vec3<f32>, matrix:mat4x4<f32> )->vec3<f32> {\r\n        return normalize( ( vec4<f32>( dir, 0.0 ) * matrix ).xyz );\r\n    }\r\n `;\r\n}\r\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\nexport function getNormal(defines) {\n\treturn wgslParseDefines`\n      fn getNormal(input:FragInput)->vec3<f32>{\n        var normal:vec3<f32>;\n        #if ${defines.HAS_NORMAL}\n            normal= input.normal;\n        #else\n          let pos_dx = dpdx(input.worldPos);\n          let pos_dy = dpdy(input.worldPos);\n          normal = normalize( cross(pos_dy, pos_dx) );\n        #endif\n        return normal*(f32(input.frontFacing) * 2.0 - 1.0);\n      }\n    `;\n}\nexport function getNormalByNormalTexture(defines) {\n\treturn wgslParseDefines`\n      fn getNormalByNormalTexture(input:FragInput)->vec3<f32>{\n        var n:vec3<f32> = textureSample(normalTexture,normalSampler, input.uv).rgb;\n        let tbn:mat3x3<f32> =getTBN(input);\n        n = normalize(tbn * (2.0 * n - vec3(1.0)));\n        n=n*(f32(input.frontFacing) * 2.0 - 1.0);\n        return n;\n      }\n    `;\n}\nexport function getTBN(defines) {\n\treturn wgslParseDefines`\n        fn getTBN(input:FragInput)->mat3x3<f32>{\n        #if ${defines.HAS_TANGENT}\n            let tbn:mat3x3<f32> = input.tbn;\n        #else\n            let normal:vec3<f32> =normalize(input.normal);\n            let uv:vec2<f32> = select(-input.uv,input.uv,input.frontFacing);\n              // ref: http://www.thetenthplanet.de/archives/1180\n              // get edge vectors of the pixel triangle\n              let dp1:vec3<f32> =  vec3<f32>(dpdx(input.worldPos.x), dpdx(input.worldPos.y), dpdx(input.worldPos.z));\n              let dp2:vec3<f32> =  vec3<f32>(dpdy(input.worldPos.x), dpdy(input.worldPos.y), dpdy(input.worldPos.z));\n              let duv1:vec2<f32> = dpdx(uv);\n              let duv2:vec2<f32> = dpdy(uv);\n\n              // solve the linear system\n              let dp2perp:vec3<f32> = cross(dp2, normal);\n              let dp1perp:vec3<f32> = cross(normal, dp1);\n              let tangent:vec3<f32> = dp2perp * duv1.x + dp1perp * duv2.x;\n              let binormal:vec3<f32> = dp2perp * duv1.y + dp1perp * duv2.y;\n              // construct a scale-invariant frame \n              let result:f32=max(dot(tangent, tangent), dot(binormal, binormal));\n              let invmax:f32 = 1.0/sqrt(result);\n              let tbn:mat3x3<f32> = mat3x3<f32>(tangent * invmax, binormal * invmax, normal);\n        #endif\n        return tbn;\n      }\n  `;\n}\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\r\nexport default function brdf(defines) {\r\n\treturn wgslParseDefines`\r\n        #if ${defines.USE_SHEEN}\r\n                fn D_Charlie( roughness:f32,dotNH:f32 )->f32 {\r\n                    let alpha:f32 = pow2( roughness );\r\n                    let invAlpha:f32 = 1.0 / alpha;\r\n                    let cos2h:f32 = dotNH * dotNH;\r\n                    let sin2h:f32 = max( 1.0 - cos2h, 0.0078125 );\r\n                    return ( 2.0 + invAlpha ) * pow( sin2h, invAlpha * 0.5 ) / ( 2.0 * PI );\r\n                }\r\n                fn V_Neubelt( dotNV:f32, dotNL:f32 )->f32 {\r\n                    return saturate( 1.0 / ( 4.0 * ( dotNL + dotNV - dotNL * dotNV ) ) );\r\n                }\r\n                fn BRDF_Sheen(lightDir:vec3<f32>, viewDir:vec3<f32>, normal:vec3<f32>,sheenColor:vec3<f32>,sheenRoughness:f32 )->vec3<f32> {\r\n                    let halfDir:vec3<f32> = normalize( lightDir + viewDir );\r\n                    let dotNL:f32 = saturate( dot( normal, lightDir ) );\r\n                    let dotNV:f32 = saturate( dot( normal, viewDir ) );\r\n                    let dotNH:f32 = saturate( dot( normal, halfDir ) );\r\n                    let D:f32 = D_Charlie( sheenRoughness, dotNH );\r\n                    let V:f32 = V_Neubelt( dotNV, dotNL );\r\n                    return sheenColor * ( D * V );\r\n                }\r\n        #endif\r\n        fn BRDF_Lambert(diffuseColor:vec3<f32>)->vec3<f32> {\r\n\r\n            return RECIPROCAL_PI * diffuseColor;\r\n\r\n        } // validated\r\n\r\n        fn F_Schlick( f0:vec3<f32>, dotVH:f32 )->vec3<f32> {\r\n\r\n            // Original approximation by Christophe Schlick '94\r\n            // float fresnel = pow( 1.0 - dotVH, 5.0 );\r\n\r\n            // Optimized variant (presented by Epic at SIGGRAPH '13)\r\n            // https://cdn2.unrealengine.com/Resources/files/2013SiggraphPresentationsNotes-26915738.pdf\r\n           let fresnel = exp2( ( - 5.55473 * dotVH - 6.98316 ) * dotVH );\r\n           return ( 1.0 - f0 ) * fresnel + f0;\r\n\r\n        } // validated\r\n\r\n        fn Schlick_to_F0(f:vec3<f32>, f90:f32, dotVH:f32 )->vec3<f32> {\r\n            let x:f32 = clamp( 1.0 - dotVH, 0.0, 1.0 );\r\n            let x2:f32 = x * x;\r\n            let x5:f32 = clamp( x * x2 * x2, 0.0, 0.9999 );\r\n\r\n            return ( f - vec3( f90 ) * x5 ) / ( 1.0 - x5 );\r\n        }\r\n        fn V_GGX_SmithCorrelated( alpha:f32, dotNL:f32,dotNV:f32 )->f32 {\r\n\r\n            let a2 :f32= pow2( alpha );\r\n\r\n            let gv:f32 = dotNL * sqrt( a2 + ( 1.0 - a2 ) * pow2( dotNV ) );\r\n            let gl:f32 = dotNV * sqrt( a2 + ( 1.0 - a2 ) * pow2( dotNL ) );\r\n\r\n            return 0.5 / max((gv + gl), 0.000000001 );\r\n\r\n        }\r\n        fn D_GGX( alpha:f32, dotNH:f32 )->f32 {\r\n\r\n            let a2:f32 = pow2( alpha );\r\n\r\n            let denom:f32 = pow2( dotNH ) * ( a2 - 1.0 ) + 1.0; // avoid alpha = 0 with dotNH = 1\r\n\r\n            return RECIPROCAL_PI * a2 / pow2( denom );\r\n\r\n        }\r\n        fn BRDF_GGX( lightDir:vec3<f32>, viewDir:vec3<f32>, normal:vec3<f32>, f0:vec3<f32>,  roughness:f32 )->vec3<f32> {\r\n\r\n            let alpha:f32 = pow2( roughness ); // UE4's roughness\r\n\r\n            let halfDir = normalize( lightDir + viewDir );\r\n\r\n            let dotNL:f32 = saturate( dot( normal, lightDir ) );\r\n            let dotNV:f32 = saturate( dot( normal, viewDir ) );\r\n            let dotNH:f32 = saturate( dot( normal, halfDir ) );\r\n            let dotVH:f32 = saturate( dot( lightDir, halfDir ) );\r\n\r\n            let F = F_Schlick( f0,  dotVH );\r\n\r\n            let V = V_GGX_SmithCorrelated( alpha, dotNL, dotNV );\r\n\r\n            let D = D_GGX( alpha, dotNH );\r\n\r\n            return F * ( V * D );\r\n\r\n        }\r\n        fn direct_Physical( directLight:IncidentLight, geometry:Geometry,material:PhysicalMaterial)->ReflectedLight {\r\n            var reflectedLight:ReflectedLight;\r\n            let dotNL:f32 = saturate(dot( geometry.normal,geometry.viewDir));\r\n            let irradiance:vec3<f32> = dotNL * directLight.color*3.1415926;\r\n            reflectedLight.directSpecular = irradiance * BRDF_GGX( directLight.direction, geometry.viewDir, geometry.normal, material.specularColor, material.roughness );\r\n            reflectedLight.directDiffuse = irradiance * BRDF_Lambert( material.diffuseColor );\r\n            return reflectedLight;\r\n        }\r\n  `;\r\n}\r\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\r\nexport default function ibl(defines) {\r\n\treturn wgslParseDefines`\r\n  fn getLightProbeRadiance( viewDir:vec3<f32>,normal:vec3<f32>, roughness:f32 )->vec3<f32>{\r\n    var reflectVec:vec3<f32> = reflect( -viewDir, normal );\r\n    reflectVec.x = -reflectVec.x; // TextureCube is left-hand,so x need inverse\r\n    let mipCount:f32 = 10.0; // resolution of 256x256\r\n    let lod:f32 = roughness * mipCount;\r\n    let specularLight:vec3<f32> = textureSampleLevel(specularEnvTexture,specularEnvSampler, reflectVec, lod).rgb;\r\n    return specularLight;\r\n  }\r\n  fn getLightProbeIrradiance( lightProbe:array<vec3<f32>,9>, normal:vec3<f32>)->vec3<f32> {\r\n    var worldNormal:vec3<f32> = normal;\r\n    worldNormal.x = -normal.x;\r\n    var irradiance:vec3<f32> = lightProbe[0];\r\n    irradiance+=lightProbe[1] * (normal.y);\r\n    irradiance+=lightProbe[2] * (normal.z) ;\r\n    irradiance+=lightProbe[3] * (normal.x) ;\r\n\r\n    irradiance+=lightProbe[4] * (normal.y * normal.x) ;\r\n    irradiance+=lightProbe[5] * (normal.y * normal.z) ;\r\n    irradiance+=lightProbe[6] * (3.0 * normal.z * normal.z - 1.0);\r\n    irradiance+=lightProbe[7] * (normal.z * normal.x) ;\r\n    irradiance+=lightProbe[8] * (normal.x * normal.x - normal.y * normal.y);\r\n\r\n    return max(irradiance, vec3<f32>(0.0,0.0,0.0));\r\n  }\r\n  fn DFGApprox( specularColor:vec3<f32>, roughness:f32,dotNV:f32 )->vec3<f32> {\r\n    const c0:vec4<f32> = vec4<f32>( - 1, - 0.0275, - 0.572, 0.022 );\r\n    let c1:vec4<f32> = vec4<f32>( 1, 0.0425, 1.04, - 0.04 );\r\n    let r:vec4<f32> = roughness * c0 + c1;\r\n    let a004:f32 = min( r.x * r.x, exp2( - 9.28 * dotNV ) ) * r.x + r.y;\r\n    let fab:vec2<f32> = vec2<f32>( - 1.04, 1.04 ) * a004 + r.zw;\r\n    return specularColor * fab.x + fab.y;\r\n  }\r\n  //间接光照\r\n  fn indirectDiffuse_Physical(geometry:Geometry, material:PhysicalMaterial )->ReflectedLight {\r\n      var reflectedLight:ReflectedLight;\r\n      var irradiance:vec3<f32> = lightUniforms.ambient.xyz*lightUniforms.ambient.w;\r\n      irradiance *= PI;\r\n      reflectedLight.indirectDiffuse += irradiance * BRDF_Lambert( material.diffuseColor );\r\n      return reflectedLight;\r\n  }\r\n  //间接高光\r\n  fn indirectSpecular_Physical(geometry:Geometry, material:PhysicalMaterial)->ReflectedLight {\r\n      var reflectedLight:ReflectedLight;\r\n      // IBL specular\r\n      let radiance:vec3<f32> = getLightProbeRadiance(geometry.viewDir, geometry.normal, material.roughness);\r\n      let radianceAttenuation:f32 = 1.0;\r\n      reflectedLight.indirectSpecular += radianceAttenuation * radiance * DFGApprox(material.specularColor, material.roughness, geometry.dotNV );\r\n      return reflectedLight;\r\n    }\r\n  `;\r\n}\r\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\r\n\r\nexport default function pbrFunction(defines) {\r\n\treturn wgslParseDefines`\r\n\r\n    #if ${defines.DITHERING}\r\n        fn dithering(color:vec3<f32> )->vec3<f32> {\r\n            let grid_position:f32 = rand( gl_FragCoord.xy );\r\n            let dither_shift_RGB:vec3<f32> = vec3<f32>( 0.25 / 255.0, -0.25 / 255.0, 0.25 / 255.0 );\r\n            dither_shift_RGB = mix( 2.0 * dither_shift_RGB, -2.0 * dither_shift_RGB, grid_position );\r\n            return color + dither_shift_RGB;\r\n        }\r\n    #endif\r\n\r\n    #if ${defines.USE_IRIDESCENCE}\r\n        fn BRDF_GGX_Iridescence( lightDir:vec3<f32>, viewDir:vec3<f32>,normal:vec3<f32>, f0:vec3<f32>, f90:f32,iridescence:f32, iridescenceFresnel:vec3<f32>,roughness:f32 )->vec3<f32> {\r\n            let alpha:f32 = pow2( roughness );\r\n            let halfDir:vec3<f32> = normalize( lightDir + viewDir );\r\n            let dotNL:f32 = saturate( dot( normal, lightDir ) );\r\n            let dotNV:f32 = saturate( dot( normal, viewDir ) );\r\n            let dotNH:f32 = saturate( dot( normal, halfDir ) );\r\n            let dotVH:f32 = saturate( dot( viewDir, halfDir ) );\r\n            let F:vec3<f32> = mix( F_Schlick( f0, f90, dotVH ), iridescenceFresnel, iridescence );\r\n            let V:f32 = V_GGX_SmithCorrelated( alpha, dotNL, dotNV );\r\n            let D:f32 = D_GGX( alpha, dotNH );\r\n            return F * ( V * D );\r\n        }\r\n    #endif\r\n\r\n    #if ${defines.USE_SHEEN}\r\n        fn D_Charlie( roughness:f32,dotNH:f32 )->f32 {\r\n            let alpha:f32 = pow2( roughness );\r\n            let invAlpha:f32 = 1.0 / alpha;\r\n            let cos2h:f32 = dotNH * dotNH;\r\n            let sin2h:f32 = max( 1.0 - cos2h, 0.0078125 );\r\n            return ( 2.0 + invAlpha ) * pow( sin2h, invAlpha * 0.5 ) / ( 2.0 * PI );\r\n        }\r\n        fn V_Neubelt( dotNV:f32, dotNL:f32 )->f32 {\r\n            return saturate( 1.0 / ( 4.0 * ( dotNL + dotNV - dotNL * dotNV ) ) );\r\n        }\r\n        fn BRDF_Sheen(lightDir:vec3<f32>, viewDir:vec3<f32>, normal:vec3<f32>,sheenColor:vec3<f32>,sheenRoughness:f32 )->vec3<f32> {\r\n            let halfDir:vec3<f32> = normalize( lightDir + viewDir );\r\n            let dotNL:f32 = saturate( dot( normal, lightDir ) );\r\n            let dotNV:f32 = saturate( dot( normal, viewDir ) );\r\n            let dotNH:f32 = saturate( dot( normal, halfDir ) );\r\n            let D:f32 = D_Charlie( sheenRoughness, dotNH );\r\n            let V:f32 = V_Neubelt( dotNV, dotNL );\r\n            return sheenColor * ( D * V );\r\n        }\r\n    #endif\r\n\r\n    #if ${defines.USE_IRIDESCENCE}\r\n        let XYZ_TO_REC709: mat3x3<f32> = mat3x3<f32>(\r\n        3.2404542, -0.9692660, 0.0556434, -1.5371385, 1.8760108, -0.2040259, -0.4985314, 0.0415560, 1.0572252\r\n        );\r\n        fn Fresnel0ToIor( fresnel0:vec3<f32> )->vec3<f32> {\r\n            let sqrtF0:vec3<f32> = sqrt( fresnel0 );\r\n            return ( vec3<f32>( 1.0 ) + sqrtF0 ) / ( vec3<f32>( 1.0 ) - sqrtF0 );\r\n        }\r\n        fn IorToFresnel0(transmittedIor:vec3<f32>,incidentIor:f32 )->vec3<f32> {\r\n            return pow2Vector( ( transmittedIor - vec3<f32>( incidentIor ) ) / ( transmittedIor + vec3<f32>( incidentIor ) ) );\r\n        }\r\n        fn IorToFresnel0(transmittedIor:f32, incidentIor:f32 )->f32 {\r\n            return pow2Vector( ( transmittedIor - incidentIor ) / ( transmittedIor + incidentIor ));\r\n        }\r\n        fn evalSensitivity(OPD:f32,shift:vec3<f32> )->vec3<f32> {\r\n            let phase:f32 = 2.0 * PI * OPD * 1.0e-9;\r\n            let val:vec3<f32> = vec3<f32>( 5.4856e-13, 4.4201e-13, 5.2481e-13 );\r\n            let pos:vec3<f32> = vec3<f32>( 1.6810e+06, 1.7953e+06, 2.2084e+06 );\r\n            let vart:vec3<f32> = vec3<f32>( 4.3278e+09, 9.3046e+09, 6.6121e+09 );\r\n            let xyz:vec3<f32> = val * sqrt( 2.0 * PI * vart ) * cos( pos * phase + shift ) * exp( - pow2( phase ) * vart );\r\n            xyz.x += 9.7470e-14 * sqrt( 2.0 * PI * 4.5282e+09 ) * cos( 2.2399e+06 * phase + shift[ 0 ] ) * exp( - 4.5282e+09 * pow2( phase ) );\r\n            xyz /= 1.0685e-7;\r\n            let rgb:vec3<f32> = XYZ_TO_REC709 * xyz;\r\n            return rgb;\r\n        }\r\n        fn evalIridescence(outsideIOR:f32, eta2:f32,cosTheta1:f32,thinFilmThickness:f32,baseF0:vec3<f32> )->vec3<f32> {\r\n            var I:vec3<f32>;\r\n            let iridescenceIOR:f32 = mix( outsideIOR, eta2, smoothstep( 0.0, 0.03, thinFilmThickness ) );\r\n            let sinTheta2Sq:f32 = pow2( outsideIOR / iridescenceIOR ) * ( 1.0 - pow2( cosTheta1 ) );\r\n            let cosTheta2Sq:f32 = 1.0 - sinTheta2Sq;\r\n            if ( cosTheta2Sq < 0.0 ) {\r\n                return vec3<f32>( 1.0 );\r\n            }\r\n            let cosTheta2:f32 = sqrt( cosTheta2Sq );\r\n            let R0:f32 = IorToFresnel0( iridescenceIOR, outsideIOR );\r\n            let R12:f32 = F_Schlick( R0, 1.0, cosTheta1 );\r\n            let R21:f32 = R12;\r\n            let T121:f32 = 1.0 - R12;\r\n            let phi12:f32 = 0.0;\r\n            if ( iridescenceIOR < outsideIOR ) phi12 = PI;\r\n            let phi21:f32 = PI - phi12;\r\n            let baseIOR:vec3<f32> = Fresnel0ToIor( clamp( baseF0, 0.0, 0.9999 ) );\r\n            let R1:vec3<f32> = IorToFresnel0( baseIOR, iridescenceIOR );\r\n            let R23:vec3<f32> = F_Schlick( R1, 1.0, cosTheta2 );\r\n            let phi23:vec3<f32> = vec3<f32>( 0.0 );\r\n            if ( baseIOR[ 0 ] < iridescenceIOR ) phi23[ 0 ] = PI;\r\n            if ( baseIOR[ 1 ] < iridescenceIOR ) phi23[ 1 ] = PI;\r\n            if ( baseIOR[ 2 ] < iridescenceIOR ) phi23[ 2 ] = PI;\r\n            let OPD:f32 = 2.0 * iridescenceIOR * thinFilmThickness * cosTheta2;\r\n            let phi:vec3<f32> = vec3<f32>( phi21 ) + phi23;\r\n            let R123:vec3<f32> = clamp( R12 * R23, 1e-5, 0.9999 );\r\n            let r123:vec3<f32> = sqrt( R123 );\r\n            let Rs:vec3<f32> = pow2( T121 ) * R23 / ( vec3<f32>( 1.0 ) - R123 );\r\n            let C0:vec3<f32> = R12 + Rs;\r\n            I = C0;\r\n            let Cm:vec3<f32> = Rs - T121;\r\n            for ( let m : u32 = 1;m <= 2; ++ m ) {\r\n                Cm *= r123;\r\n                Sm:vec3<f32> = 2.0 * evalSensitivity( f32( m ) * OPD, f32( m ) * phi );\r\n                I += Cm * Sm;\r\n            }\r\n            return max( I, vec3<f32>( 0.0 ) );\r\n        }\r\n    #endif\r\n    const clearcoatSpecular:vec3<f32> = vec3<f32>( 0.0 );\r\n    const sheenSpecular:vec3<f32> = vec3<f32>( 0.0 );\r\n\r\n    fn IBLSheenBRDF( normal:vec3<f32>, viewDir:vec3<f32>, roughness:f32 )->f32 {\r\n        let dotNV:f32 = saturate( dot( normal, viewDir ) );\r\n        let r2:f32 = roughness * roughness;\r\n        let a:f32 =select(-8.48 * r2 + 14.3 * roughness - 9.95,-339.2 * r2 + 161.4 * roughness - 25.9,roughness < 0.25);\r\n        //let a:f32 = roughness < 0.25 ? -339.2 * r2 + 161.4 * roughness - 25.9 : -8.48 * r2 + 14.3 * roughness - 9.95;\r\n        let b:f32=select(1.97 * r2 - 3.27 * roughness + 0.72,44.0 * r2 - 23.7 * roughness + 3.26, roughness < 0.25);\r\n        //let b:f32 = roughness < 0.25 ? 44.0 * r2 - 23.7 * roughness + 3.26 : 1.97 * r2 - 3.27 * roughness + 0.72;\r\n        //let DG:f32 = exp( a * dotNV + b ) + ( roughness < 0.25 ? 0.0 : 0.1 * ( roughness - 0.25 ) );\r\n        let DG:f32 = exp( a * dotNV + b ) + select(0.1 * ( roughness - 0.25 ),0.0,roughness < 0.25);\r\n        return saturate( DG * RECIPROCAL_PI );\r\n    }\r\n    fn DFGApprox( specularColor:vec3<f32>, roughness:f32,dotNV:f32 )->vec3<f32> {\r\n        const c0:vec4<f32> = vec4<f32>( - 1, - 0.0275, - 0.572, 0.022 );\r\n        let c1:vec4<f32> = vec4<f32>( 1, 0.0425, 1.04, - 0.04 );\r\n        let r:vec4<f32> = roughness * c0 + c1;\r\n        let a004:f32 = min( r.x * r.x, exp2( - 9.28 * dotNV ) ) * r.x + r.y;\r\n        let fab:vec2<f32> = vec2<f32>( - 1.04, 1.04 ) * a004 + r.zw;\r\n        return specularColor * fab.x + fab.y;\r\n    }\r\n    fn EnvironmentBRDF( normal:vec3<f32>,viewDir:vec3<f32>,specularColor:vec3<f32>, specularF90:f32,roughness:f32 )->vec3<f32> {\r\n        let fab:vec2<f32> = DFGApprox( normal, viewDir, roughness );\r\n        return specularColor * fab.x + specularF90 * fab.y;\r\n    }\r\n\r\n\r\n    fn computeSpecularOcclusion( dotNV:f32, ambientOcclusion:f32, roughness:f32 )->f32 {\r\n        return saturate( pow( dotNV + ambientOcclusion, exp2( - 16.0 * roughness - 1.0 ) ) - 1.0 + ambientOcclusion );\r\n    }\r\n    #if ${defines.USE_TRANSMISSION}\r\n\r\n    fn getVolumeTransmissionRay( n:vec3<f32>, v:vec3<f32>, thickness:f32, ior:f32, modelMatrix:mat4x4:f32)->vec3<f32> {\r\n        var refractionVector:vec3<f32> = refract( - v, normalize( n ), 1.0 / ior );\r\n        var modelScale:vec3<f32>;\r\n        modelScale.x = length( vec3<f32>( modelMatrix[0].xyz ) );\r\n        modelScale.y = length( vec3<f32>( modelMatrix[1].xyz ) );\r\n        modelScale.z = length( vec3<f32>( modelMatrix[2].xyz ) );\r\n        return normalize( refractionVector ) * thickness * modelScale;\r\n    }\r\n    fn applyIorToRoughness(roughness:f32, ior:f32 )->f32 {\r\n        return roughness * clamp( ior * 2.0 - 2.0, 0.0, 1.0 );\r\n    }\r\n    fn getTransmissionSample( fragCoord:vec2<f32>, roughness:f32,ior:f32 )->vec4<f32> {\r\n        let framebufferLod:f32 = log2( materialUniform.transmissionSamplerSize.x ) * applyIorToRoughness( roughness, ior );\r\n        return textureSampleLevel(transmissionSamplerTexture,baseSampler,fragCoord.xy, framebufferLod);\r\n\r\n    }\r\n    fn applyVolumeAttenuation( radiance:vec3<vec3>, transmissionDistance:f32,attenuationColor:vec3<f32>,attenuationDistance:f32 )->vec3<f32> {\r\n        if ( isinf( attenuationDistance ) ) {\r\n            return radiance;\r\n        }\r\n        else {\r\n            let attenuationCoefficient:vec3<f32> = -log( attenuationColor ) / attenuationDistance;\r\n            let transmittance:vec3<f32> = exp( - attenuationCoefficient * transmissionDistance );\r\n            return transmittance * radiance;\r\n        }\r\n    \r\n    }\r\n    fn getIBLVolumeRefraction( n:vec3<f32>,v:vec3<f32>, roughness:f32, diffuseColor:vec3<f32>,specularColor:vec3<f32>, specularF90:f32,position:vec3<f32>, modelMatrix:mat4x4<f32>, viewMatrix:mat4x4<f32>,projMatrix:mat4x4<f32>,ior:f32, thickness:f32,attenuationColor:vec3<f32>,attenuationDistance:f32 )->vec4<f32> {\r\n        let transmissionRay:vec3<f32> = getVolumeTransmissionRay( n, v, thickness, ior, modelMatrix );\r\n        let refractedRayExit:vec3<f32> = position + transmissionRay;\r\n        let ndcPos:vec4<f32> = projMatrix * viewMatrix * vec4( refractedRayExit, 1.0 );\r\n        let refractionCoords:vec2<f32> = ndcPos.xy / ndcPos.w;\r\n        refractionCoords += 1.0;\r\n        refractionCoords /= 2.0;\r\n        let transmittedLight:vec4<f32> = getTransmissionSample( refractionCoords, roughness, ior );\r\n        let attenuatedColor:vec3<f32> = applyVolumeAttenuation( transmittedLight.rgb, length( transmissionRay ), attenuationColor, attenuationDistance );\r\n        let F:vec3<f32> = EnvironmentBRDF( n, v, specularColor, specularF90, roughness );\r\n        return vec4<f32>( ( 1.0 - F ) * attenuatedColor * diffuseColor, transmittedLight.a );\r\n    }\r\n    #endif\r\n\r\n    #if ${defines.USE_BUMPTEXTURE}\r\n        fn dHdxy_fwd()->vec2<f32> {\r\n            let dSTdx:vec2<f32> = dpdx( vUv );\r\n            let dSTdy:vec2<f32> = dpdy( vUv );\r\n\r\n            let Hll:f32 = materialUniform.bumpScale * textureSample(bumpTexture, baseSampler, vUv).x;\r\n            let dBx:f32 = materialUniform.bumpScale * textureSample(bumpTexture, baseSampler, vUv + dSTdx).x - Hll;\r\n            let dBy:f32 = materialUniform.bumpScale * textureSample(bumpTexture, baseSampler, vUv + dSTdy).x - Hll;\r\n            return vec2<f32>( dBx, dBy );\r\n        }\r\n        fn perturbNormalArb( surf_pos:vec3<f32>, surf_norm:vec3<f32>, dHdxy:vec2<f32>, faceDirection:f32 )->vec3<f32> {\r\n            let vSigmaX:vec3<f32> = dpdx( surf_pos.xyz );\r\n            let vSigmaY:vec3<f32> = dpdy( surf_pos.xyz );\r\n            let vN:vec3<f32> = surf_norm;\r\n            let R1:vec3<f32> = cross( vSigmaY, vN );\r\n            let R2:vec3<f32> = cross( vN, vSigmaX );\r\n            let fDet:f32 = dot( vSigmaX, R1 ) * faceDirection;\r\n            let vGrad:vec3<f32> = sign( fDet ) * ( dHdxy.x * R1 + dHdxy.y * R2 );\r\n            return normalize( abs( fDet ) * surf_norm - vGrad );\r\n        }\r\n    #endif\r\n\r\n    //! defined ( USE_TANGENT ) && ( defined ( TANGENTSPACE_NORMALTEXTURE ) || defined ( USE_CLEARCOAT_NORMALTEXTURE ) )\r\n    #if ${(!defines.USE_TANGENT && defines.TANGENTSPACE_NORMALTEXTURE) || defines.USE_CLEARCOAT_NORMALTEXTURE}\r\n    fn perturbNormal2Arb( eye_pos:vec3<f32>, surf_norm:vec3<f32>, textureN:vec3<f32>, faceDirection:f32 )->vec3<f32> {\r\n        let q0:vec3<f32> = dpdx( eye_pos.xyz );\r\n        let q1:vec3<f32> = dpdy( eye_pos.xyz );\r\n        let st0:vec2<f32> = dpdx( vUv.st );\r\n        let st1:vec2<f32> = dpdy( vUv.st );\r\n        let N:vec3<f32> = surf_norm;\r\n        let q1perp:vec3<f32> = cross( q1, N );\r\n        let q0perp:vec3<f32> = cross( N, q0 );\r\n        let T:vec3<f32> = q1perp * st0.x + q0perp * st1.x;\r\n        let B:vec3<f32> = q1perp * st0.y + q0perp * st1.y;\r\n        let det:f32 = max( dot( T, T ), dot( B, B ) );\r\n        let scale:f32 = ( det == 0.0 ) ? 0.0 : faceDirection * inversesqrt( det );\r\n        return normalize( T * ( textureN.x * scale ) + B * ( textureN.y * scale ) + N * textureN.z );\r\n    }\r\n    #endif\r\n    struct MultiAndSingleScatter{\r\n        multiScatter:vec3<f32>,\r\n        singleScatter:vec3<f32>\r\n    }\r\n   #if ${defines.USE_IRIDESCENCE}\r\n   ////////inout vec3 singleScatter, inout vec3 multiScatter\r\n       fn computeMultiscatteringIridescence( normal:vec3<f32>, viewDir:vec3<f32>, specularColor:vec3<f32>, specularF90:f32, iridescence:f32,iridescenceF0:vec3<f32>, roughness:f32 )->MultiAndSingleScatter {\r\n   #else\r\n   ////////inout vec3 singleScatter, inout vec3 multiScatter\r\n       fn computeMultiscattering( normal:vec3<f32>,viewDir:vec3<f32>, specularColor:vec3<f32>, specularF90:f32, roughness:f32)->MultiAndSingleScatter {\r\n   #endif\r\n   let fab:vec2<f32> = DFGApprox( normal, viewDir, roughness );\r\n\r\n   var multiAndSingleScatter:MultiAndSingleScatter;\r\n\r\n   #if ${defines.USE_IRIDESCENCE}\r\n       let Fr:vec3<f32> = mix( specularColor, iridescenceF0, iridescence );\r\n   #else\r\n       let Fr:vec3<f32> = specularColor;\r\n   #endif\r\n       let FssEss:vec3<f32> = Fr * fab.x + specularF90 * fab.y;\r\n       let Ess:f32 = fab.x + fab.y;\r\n       let Ems:f32 = 1.0 - Ess;\r\n       let Favg:vec3<f32> = Fr + ( 1.0 - Fr ) * 0.047619;\r\n       let Fms:vec3<f32> = FssEss * Favg / ( 1.0 - Ems * Favg );\r\n    //    singleScatter += FssEss;\r\n    //    multiScatter += Fms * Ems;\r\n       multiAndSingleScatter.multiScatter=Fms * Ems;\r\n       multiAndSingleScatter.singleScatter=FssEss;\r\n       return multiAndSingleScatter;\r\n   }\r\n   //直接光照\r\n   fn RE_Direct_Physical( directLight:IncidentLight, geometry:GeometricContext,  material:PhysicalMaterial)->ReflectedLight {\r\n       var reflectedLight:ReflectedLight;\r\n       let dotNL:f32 = saturate(dot( geometry.normal, directLight.direction));\r\n       let irradiance:vec3<f32> = dotNL * directLight.color;\r\n       #if ${defines.USE_CLEARCOAT}\r\n           let dotNLcc:f32 = saturate( dot( geometry.clearcoatNormal, directLight.direction ) );\r\n           let ccIrradiance:vec3<f32> = dotNLcc * directLight.color;\r\n           clearcoatSpecular += ccIrradiance * BRDF_GGX( directLight.direction, geometry.viewDir, geometry.clearcoatNormal, material.clearcoatF0, material.clearcoatF90, material.clearcoatRoughness );\r\n       #endif\r\n\r\n       #if ${defines.USE_SHEEN}\r\n           sheenSpecular += irradiance * BRDF_Sheen( directLight.direction, geometry.viewDir, geometry.normal, material.sheenColor, material.sheenRoughness );\r\n       #endif\r\n\r\n       #if ${defines.USE_IRIDESCENCE}\r\n           reflectedLight.directSpecular = irradiance * BRDF_GGX_Iridescence( directLight.direction, geometry.viewDir, geometry.normal, material.specularColor, material.specularF90, material.iridescence, material.iridescenceFresnel, material.roughness );\r\n       #else\r\n           reflectedLight.directSpecular = irradiance * BRDF_GGX( directLight.direction, geometry.viewDir, geometry.normal, material.specularColor, material.specularF90, material.roughness );\r\n       #endif\r\n       reflectedLight.directDiffuse = irradiance * BRDF_Lambert( material.diffuseColor );\r\n       return reflectedLight;\r\n   }\r\n   //间接光照\r\n   fn RE_IndirectDiffuse_Physical( irradiance:vec3<f32>, geometry:GeometricContext, material:PhysicalMaterial )->ReflectedLight {\r\n       var reflectedLight:ReflectedLight;\r\n       reflectedLight.indirectDiffuse = irradiance * BRDF_Lambert( material.diffuseColor );\r\n       return reflectedLight;\r\n   }\r\n   //间接高光\r\n   fn RE_IndirectSpecular_Physical( radiance:vec3<f32>, irradiance:vec3<f32>, clearcoatRadiance:vec3<f32>, geometry:GeometricContext, material:PhysicalMaterial)->ReflectedLight {\r\n       var reflectedLight:ReflectedLight;\r\n       #if ${defines.USE_CLEARCOAT}\r\n           clearcoatSpecular += clearcoatRadiance * EnvironmentBRDF( geometry.clearcoatNormal, geometry.viewDir, material.clearcoatF0, material.clearcoatF90, material.clearcoatRoughness );\r\n       #endif\r\n       #if ${defines.USE_SHEEN}\r\n           sheenSpecular += irradiance * material.sheenColor * IBLSheenBRDF( geometry.normal, geometry.viewDir, material.sheenRoughness );\r\n       #endif\r\n       var singleScattering:vec3<f32>;\r\n       var multiScattering:vec3<f32>;\r\n       let cosineWeightedIrradiance:vec3<f32> = irradiance * RECIPROCAL_PI;\r\n       var tempMultiAndSingleScatter:MultiAndSingleScatter;\r\n       #if ${defines.USE_IRIDESCENCE}\r\n             tempMultiAndSingleScatter=computeMultiscatteringIridescence( geometry.normal, geometry.viewDir, material.specularColor, material.specularF90, material.iridescence, material.iridescenceFresnel, material.roughness );\r\n       #else\r\n            tempMultiAndSingleScatter= computeMultiscattering( geometry.normal, geometry.viewDir, material.specularColor, material.specularF90, material.roughness );\r\n       #endif\r\n       singleScattering=tempMultiAndSingleScatter.singleScatter; \r\n       multiScattering=tempMultiAndSingleScatter.multiScatter;\r\n       let totalScattering:vec3<f32> = singleScattering + multiScattering;\r\n       let diffuse:vec3<f32> = material.diffuseColor * ( 1.0 - max( max( totalScattering.r, totalScattering.g ), totalScattering.b ) );\r\n       reflectedLight.indirectSpecular = radiance * singleScattering;\r\n       reflectedLight.indirectSpecular = multiScattering * cosineWeightedIrradiance;\r\n       reflectedLight.indirectDiffuse = diffuse * cosineWeightedIrradiance;\r\n       return reflectedLight;\r\n   }\r\n   `;\r\n}\r\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\r\n\r\nexport default function pbrStruct(defines) {\r\n  return wgslParseDefines`\r\n        struct MaterialUniform{\r\n\r\n            modelMatrix: mat4x4<f32>,\r\n    \r\n            diffuse:vec3<f32>,\r\n    \r\n            opacity:f32,\r\n    \r\n            normalMatrix: mat3x3<f32>,\r\n    \r\n            emissive:vec3<f32>,\r\n    \r\n            roughness:f32,\r\n    \r\n            metalness:f32,\r\n    \r\n            #if ${defines.TONE_MAPPING}\r\n                toneMappingExposure:f32,\r\n            #endif\r\n           \r\n            #if ${defines.SPECULAR}\r\n    \r\n                 specularColor:vec3<f32>,\r\n    \r\n                 specularIntensity:f32,\r\n            #endif\r\n            \r\n            #if ${defines.USE_SHEEN}\r\n    \r\n                sheenColor:vec3<f32>,\r\n    \r\n                sheenRoughness:f32,\r\n            #endif\r\n\r\n            #if ${defines.USE_TRANSMISSION}\r\n    \r\n                attenuationColor:vec3<f32>,\r\n    \r\n                transmission:f32,\r\n    \r\n                transmissionSamplerSize:vec2<f32>,\r\n    \r\n                thickness:f32,\r\n    \r\n                attenuationDistance:f32,\r\n                \r\n            #endif\r\n\r\n            #if ${defines.USE_SKINNING}\r\n    \r\n                bindMatrix:mat4x4<f32>,\r\n    \r\n                bindMatrixInverse:mat4x4<f32>,\r\n    \r\n                boneTextureSize:u32,\r\n            #endif\r\n\r\n            #if ${defines.USE_NORMALTEXTURE}\r\n                 normalScale:vec2<f32>,\r\n            #endif\r\n    \r\n            #if ${defines.IOR}\r\n                ior:f32,\r\n            #endif\r\n    \r\n            #if ${defines.USE_CLEARCOAT}\r\n    \r\n                #if ${defines.USE_CLEARCOAT_NORMALTEXTURE}\r\n                    clearcoatNormalScale:vec2<f32>,\r\n                #endif\r\n    \r\n                 clearcoat:f32,\r\n    \r\n                 clearcoatRoughness:f32,\r\n            #endif\r\n    \r\n            #if ${defines.USE_IRIDESCENCE}\r\n                iridescence:f32,\r\n    \r\n                iridescenceIOR:f32,\r\n    \r\n                iridescenceThicknessMinimum:f32,\r\n    \r\n                iridescenceThicknessMaximum:f32,\r\n    \r\n            #endif\r\n\r\n            #if ${defines.USE_AOTEXTURE}\r\n                 aoTextureIntensity:f32,\r\n            #endif\r\n\r\n            #if ${defines.USE_LIGHTTEXTURE}\r\n                 lightTextureIntensity:f32,\r\n            #endif\r\n    \r\n            #if ${defines.USE_ENVTEXTURE}\r\n                envTextureIntensity:f32,\r\n    \r\n                flipEnvTexture:f32,\r\n            #endif\r\n\r\n            #if ${defines.USE_BUMPTEXTURE}\r\n                bumpScale:f32;\r\n            #endif\r\n\r\n            #if ${defines.USE_DISPLACEMENTTEXTURE}\r\n    \r\n                displacementScale:f32,\r\n    \r\n                displacementBias:f32,\r\n            #endif\r\n            \r\n            #if ${defines.USE_MORPHTARGETS}\r\n    \r\n                morphTargetBaseInfluence:f32,\r\n    \r\n                #if ${defines.MORPHTARGETS_TEXTURE} \r\n    \r\n                    morphTargetsTextureSize:vec2<u32>,\r\n    \r\n                    MORPHTARGETS_COUNT:u32,\r\n    \r\n                #endif\r\n    \r\n                morphTargetInfluences:array<f32>,\r\n                    \r\n            #endif\r\n        }\r\n\r\n   `;\r\n}\r\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\r\n\r\nexport default function pbrTexture(defines) {\r\n  return wgslParseDefines`        \r\n            #if ${defines.USE_BUMPTEXTURE}\r\n                @group(0) @binding(${defines.bumpTextureBinding}) var bumpTexture: texture_2d<f32>;\r\n            #endif\r\n            #if ${defines.USE_TRANSMISSION}\r\n                #if ${defines.USE_TRANSMISSIONTEXTURE}\r\n                    @group(0) @binding(${defines.transmissionTextureBinding}) var transmissionTexture: texture_2d<f32>;\r\n                #endif\r\n                #if ${defines.USE_THICKNESSTEXTURE}\r\n                    @group(0) @binding(${defines.thicknessTextureBinding}) var thicknessTexture: texture_2d<f32>;\r\n                #endif\r\n                @group(0) @binding(${defines.transmissionSamplerTextureBinding}) var transmissionSamplerTexture: texture_2d<f32>;\r\n            #endif\r\n            #if ${defines.USE_ENVTEXTURE}\r\n                @group(0) @binding(${defines.envTextureBinding}) var envTexture: texture_cube<f32>;\r\n            #endif\r\n            #if ${defines.USE_NORMALTEXTURE}\r\n                @group(0) @binding(${defines.normalTextureBinding}) var normalTexture: texture_2d<f32>;\r\n            #endif\r\n            \r\n            #if ${defines.USE_CLEARCOATTEXTURE}\r\n                @group(0) @binding(${defines.clearcoatTextureBinding}) var clearcoatTexture: texture_2d<f32>;\r\n            #endif\r\n            \r\n            #if ${defines.USE_CLEARCOAT_ROUGHNESSTEXTURE}\r\n                @group(0) @binding(${defines.clearcoatRclearcoatRoughnessTextureBinding}) var clearcoatRoughnessTexture: texture_2d<f32>;\r\n            #endif\r\n            \r\n            #if ${defines.USE_CLEARCOAT_NORMALTEXTURE}\r\n                @group(0) @binding(${defines.clearcoatNormalTextureBinding}) var clearcoatNormalTexture: texture_2d<f32>;\r\n            #endif\r\n            \r\n            #if ${defines.USE_IRIDESCENCETEXTURE}\r\n                @group(0) @binding(${defines.iridescenceTextureBinding}) var iridescenceTexture: texture_2d<f32>;\r\n            #endif\r\n            \r\n            #if ${defines.USE_IRIDESCENCE_THICKNESSTEXTURE}\r\n                @group(0) @binding(${defines.iridescenceThicknessTextureBinding}) var iridescenceThicknessTexture: texture_2d<f32>;\r\n            #endif\r\n            \r\n            #if ${defines.USE_ROUGHNESSTEXTURE}\r\n                @group(0) @binding(${defines.roughnessTextureBinding}) var roughnessTexture: texture_2d<f32>;\r\n            #endif\r\n            \r\n            #if ${defines.USE_METALNESSTEXTURE}\r\n                @group(0) @binding(${defines.metalnessTextureBinding}) var metalnessTexture: texture_2d<f32>;\r\n            #endif\r\n\r\n            #if ${defines.SPECULAR}\r\n                #if ${defines.USE_SPECULARINTENSITYTEXTURE}\r\n                    @group(0) @binding(${defines.specularIntensityTextureBinding}) var specularIntensityTexture: texture_2d<f32>;\r\n                #endif\r\n\r\n                #if ${defines.USE_SPECULARCOLORTEXTURE}\r\n                    @group(0) @binding(${defines.specularColorTextureBinding}) var specularColorTexture: texture_2d<f32>;\r\n                #endif\r\n            #endif\r\n\r\n            #if ${defines.USE_SHEEN}\r\n                #if ${defines.USE_SHEENCOLORTEXTURE}\r\n                    @group(0) @binding(${defines.sheenColorTextureBinding}) var sheenColorTexture: texture_2d<f32>;\r\n                #endif\r\n                #if ${defines.USE_SHEENROUGHNESSTEXTURE}\r\n                    @group(0) @binding(${defines.sheenRoughnessTextureBinding}) var sheenRoughnessTexture: texture_2d<f32>;\r\n                #endif\r\n            #endif\r\n\r\n            #if ${defines.USE_TEXTURE}\r\n                @group(0) @binding(${defines.baseSamplerBinding}) var baseSampler: sampler;\r\n                @group(0) @binding(${defines.baseTextureBinding}) var baseTexture: texture_2d<f32>;\r\n            #endif\r\n\r\n            #if ${defines.USE_ALPHATEXTURE}\r\n                @group(0) @binding(${defines.alphaTextureBinding}) var alphaTexture: texture_2d<f32>;\r\n            #endif\r\n\r\n            #if ${defines.USE_AOTEXTURE}\r\n                @group(0) @binding(${defines.aoTextureBinding}) var aoTexture: texture_2d<f32>;\r\n                \r\n            #endif\r\n            #if ${defines.USE_LIGHTTEXTURE}\r\n                @group(0) @binding(${defines.lightTextureBinding}) var lightTexture: texture_2d<f32>;\r\n            #endif\r\n\r\n            #if ${defines.USE_EMISSIVETEXTURE}\r\n                @group(0) @binding(${defines.emissiveTextureBinding}) var emissiveTexture: texture_2d<f32>;\r\n            #endif\r\n     `;\r\n}\r\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\r\n\r\nexport default function pbrUtils(defines) {\r\n  return wgslParseDefines`\r\n    const PI:f32= 3.141592653589793;\r\n    const PI2:f32= 6.283185307179586;\r\n    const PI_HALF:f32= 1.5707963267948966;\r\n    const RECIPROCAL_PI:f32= 0.3183098861837907;\r\n    const RECIPROCAL_PI2:f32= 0.15915494309189535;\r\n    const EPSILON:f32= 1e-6;\r\n\r\n    fn pow2(x:f32 )->f32 {\r\n        return x*x;\r\n    }\r\n    fn pow2Vector(x:vec3<f32> )->vec3<f32> {\r\n        return x*x;\r\n    }\r\n    fn pow3( x:f32 )->f32 {\r\n        return x*x*x;\r\n    }\r\n    fn pow4( x:f32 )->f32 {\r\n        let x2:f32 = x*x;\r\n        return x2*x2;\r\n    }\r\n    fn max3( v:vec3<f32> )->f32 {\r\n        return max( max( v.x, v.y ), v.z );\r\n    }\r\n    fn average(v:vec3<f32> )->f32 {\r\n        return dot( v, vec3<f32>( 0.3333333 ) );\r\n    }\r\n    fn rand( uv:vec2<f32> )->f32 {\r\n        let a:f32 = 12.9898;\r\n        let b:f32 = 78.233;\r\n        let c:f32 = 43758.5453;\r\n        let dt:f32 = dot( uv.xy, vec2<f32>( a, b ) );\r\n        let sn:f32 = dt % PI;\r\n        return fract( sin( sn ) * c );\r\n    }\r\n    fn transformDirection( dir:vec3<f32>, matrix:mat4x4<f32> )->vec3<f32> {\r\n        return normalize( ( matrix * vec4<f32>( dir, 0.0 ) ).xyz );\r\n    }\r\n\r\n    fn transposeMat3( m:mat3x3<f32> )->mat3x3<f32> {\r\n        var tmp:mat3x3<f32>;\r\n        tmp[ 0 ] = vec3<f32>( m[ 0 ].x, m[ 1 ].x, m[ 2 ].x );\r\n        tmp[ 1 ] = vec3<f32>( m[ 0 ].y, m[ 1 ].y, m[ 2 ].y );\r\n        tmp[ 2 ] = vec3<f32>( m[ 0 ].z, m[ 1 ].z, m[ 2 ].z );\r\n        return tmp;\r\n    }\r\n    fn luminance( rgb:vec3<f32> )->f32 {\r\n        let weights:vec3<f32> = vec3<f32>(0.2126729, 0.7151522, 0.0721750 );\r\n        return dot( weights, rgb );\r\n    }\r\n    fn LinearToneMapping( color:vec3<f32>,toneMappingExposure:f32  )->vec3<f32> {\r\n        return toneMappingExposure * color;\r\n    }\r\n\r\n    fn ReinhardToneMapping( color:vec3<f32>,toneMappingExposure:f32 )->vec3<f32> {\r\n        var tempColor:vec3<f32>;\r\n        tempColor=color;\r\n        tempColor *= toneMappingExposure;\r\n        return saturate( tempColor / ( vec3<f32>( 1.0 ) + tempColor ) );\r\n    }\r\n    fn CustomToneMapping( color:vec3<f32> )->vec3<f32> {\r\n        return color;\r\n    }\r\n    fn toneMapping( color:vec3<f32>,toneMappingExposure:f32  )->vec3<f32> {\r\n        return ReinhardToneMapping( color,toneMappingExposure );\r\n    }\r\n\r\n    fn LinearToLinear( value:vec4<f32> )->vec4<f32> {\r\n        return value;\r\n    }\r\n    fn lessThanEqual(a:vec3<f32>,b:vec3<f32>)->vec3<f32>{\r\n       let xValue:f32=select(b.x,a.x,a.x<=b.x);\r\n       let yValue:f32=select(b.y,a.y,a.y<=b.y);\r\n       let zValue:f32=select(b.z,a.z,a.z<=b.z);\r\n       return vec3<f32>(xValue,yValue,zValue);    \r\n    }\r\n    fn LinearTosRGB( value:vec4<f32> )->vec4<f32> {\r\n        return vec4<f32>( mix( pow( value.rgb, vec3<f32>( 0.41666 ) ) * 1.055 - vec3<f32>( 0.055 ), value.rgb * 12.92, vec3<f32>( lessThanEqual( value.rgb, vec3<f32>( 0.0031308 ) ) ) ), value.a );\r\n    }\r\n    fn linearToOutputTexel(value:vec4<f32> )->vec4<f32> {\r\n        return LinearTosRGB( value );\r\n    }\r\n    `;\r\n}\r\n","export default function blinn_phong(defines) {\r\n\treturn `\r\n       fn getPointLightInfo(pointLight:PointLight,worldPos:vec3<f32>,shininess:f32,N:vec3<f32>,V:vec3<f32>)->vec3<f32>{\r\n        var color=vec3<f32>(0.0,0.0,0.0);\r\n        var direction:vec3<f32> = worldPos - pointLight.position;\r\n        let dist:f32 = length( direction );\r\n        direction = normalize(direction);\r\n        let decay = clamp(1.0 - pow(dist / pointLight.distance, 4.0), 0.0, 1.0);\r\n\r\n        let d =  max( dot( N, -direction ), 0.0 ) * decay;\r\n        color += pointLight.color * d;\r\n\r\n        let halfDir:vec3<f32> = normalize( V - direction );\r\n        let s:f32 = pow( clamp( dot( N, halfDir ), 0.0, 1.0 ), shininess )  * decay;\r\n        color += pointLight.color * s;\r\n        return color;\r\n       }\r\n       fn getSpotLightInfo(spotLight:SpotLight,worldPos:vec3<f32>,shininess:f32,N:vec3<f32>,V:vec3<f32>)->vec3<f32>{\r\n        var color=vec3<f32>(0.0,0.0,0.0);\r\n            var direction:vec3<f32> = spotLight.position - worldPos;\r\n            let lightDistance:f32 = length(direction);\r\n            direction = normalize(direction);\r\n            let angleCos:f32 = dot( direction, -spotLight.direction );\r\n            let decay:f32 = clamp(1.0 - pow(lightDistance/spotLight.distance, 4.0), 0.0, 1.0);\r\n            let spotEffect:f32 = smoothstep( spotLight.penumbraCos, spotLight.coneCos, angleCos );\r\n            let decayTotal:f32 = decay * spotEffect;\r\n            let d:f32 = max( dot( N, direction ), 0.0 )  * decayTotal;\r\n            color += spotLight.color * d;\r\n            let halfDir:vec3<f32> = normalize( V + direction );\r\n            let s:f32 = pow( clamp( dot( N, halfDir ), 0.0, 1.0 ), shininess ) * decayTotal;\r\n            color += spotLight.color * s;\r\n            return color;\r\n       }\r\n    struct DirectionalLight {\r\n        direction: vec3<f32>,\r\n        color: vec3<f32>,\r\n    };\r\n      fn getDirectLightInfo(directionalLight:DirectionalLight,shininess:f32,N:vec3<f32>,V:vec3<f32>)->vec3<f32>{\r\n        var color=vec3<f32>(0.0,0.0,0.0);\r\n        let d:f32 = max(dot(N, -directionalLight.direction), 0.0);\r\n        color += directionalLight.color * d;\r\n\r\n        let halfDir:vec3<f32> = normalize( V - directionalLight.direction );\r\n        let s:f32 = pow( clamp( dot( N, halfDir ), 0.0, 1.0 ), shininess );\r\n        color += directionalLight.color * s;\r\n        return color;\r\n       }\r\n    `;\r\n}\r\n","export default function phongFunction(defines) {\r\n  return `\r\n    fn G_BlinnPhong_Implicit( )->f32 {\r\n\r\n        // geometry term is (n dot l)(n dot v) / 4(n dot l)(n dot v)\r\n        return 0.25;\r\n\r\n    }\r\n    fn D_BlinnPhong( shininess:f32, dotNH:f32 )->f32 {\r\n\r\n        return RECIPROCAL_PI * ( shininess * 0.5 + 1.0 ) * pow(dotNH, shininess);\r\n\r\n    }\r\n    fn BRDF_BlinnPhong( lightDir:vec3<f32>, viewDir:vec3<f32>, normal:vec3<f32>, specularColor:vec3<f32>, shininess:f32 )->vec3<f32> {\r\n\r\n        let  halfDir = normalize( lightDir + viewDir );\r\n\r\n        let  dotNH:f32 = saturate( dot( normal, halfDir ) );\r\n        let dotVH:f32 = saturate( dot( viewDir, halfDir ) );\r\n\r\n        let F = F_Schlick( specularColor, 1.0, dotVH );\r\n\r\n        let G:f32 = G_BlinnPhong_Implicit( );\r\n\r\n        let D = D_BlinnPhong( shininess, dotNH );\r\n\r\n        return F * ( G * D );\r\n\r\n    } \r\n    fn RE_Direct_BlinnPhong(  directLight:IncidentLight,geometry:GeometricContext, material:BlinnPhongMaterial )->ReflectedLight{\r\n        var reflectedLight:ReflectedLight; \r\n        let dotNL:f32 = saturate(dot(geometry.normal, directLight.direction));\r\n        let irradiance:vec3<f32> = dotNL*directLight.color;\r\n\r\n        reflectedLight.directDiffuse= irradiance * BRDF_Lambert( material.diffuseColor );\r\n\r\n        reflectedLight.directSpecular= irradiance * BRDF_BlinnPhong( directLight.direction, geometry.viewDir, geometry.normal, material.specularColor, material.specularShininess ) * material.specularStrength;\r\n        return reflectedLight;\r\n    }\r\n    fn RE_IndirectDiffuse_BlinnPhong( irradiance:vec3<f32>, geometry:GeometricContext, material:BlinnPhongMaterial)->ReflectedLight {\r\n        var reflectedLight:ReflectedLight; \r\n        reflectedLight.indirectDiffuse += irradiance * BRDF_Lambert( material.diffuseColor );\r\n        return reflectedLight;\r\n    }\r\n    `;\r\n}\r\n","export default function phongUtils(defines) {\r\n  return `\r\n   struct BlinnPhongMaterial {\r\n        diffuseColor:vec3<f32>,\r\n        specularColor:vec3<f32>,\r\n        specularShininess:f32,\r\n        specularStrength:f32,\r\n    };\r\n    const RECIPROCAL_PI:f32= 0.3183098861837907;\r\n   fn pow2( x:f32 )->f32 { return x*x; }\r\n   fn pow3( x:f32 )->f32 { return x*x*x; }\r\n   fn pow4(x:f32 )->f32 { let x2 = x*x; return x2*x2; }\r\n   fn max3( v:vec3<f32> )->f32 { return max( max( v.x, v.y ), v.z ); }\r\n   fn average(v:vec3<f32> )->f32 { \r\n       let result=vec3<f32>( 0.3333333,  0.3333333, 0.3333333);\r\n       return dot( v,result ); \r\n   }\r\n   `;\r\n}\r\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\n\nexport function getSkinMatrix(defines) {\n\treturn wgslParseDefines`\n   #if ${defines.HAS_SKIN} \n        struct JointsUniform{\n             matrixs:array<mat4x4f>,\n        }\n        struct InverseBindMatricesUniform{\n            matrixs:array<mat4x4f>,\n        }\n        @binding(${defines.skinJointsBufferBinding}) @group(0) var<storage, read> jointsUniform : JointsUniform;\n        @binding(${defines.invsBufferBinding}) @group(0) var<storage, read> inverseBindMatricesUniform : InverseBindMatricesUniform;\n        fn getSkinMatrix(joints: vec4f, weights: vec4f) -> mat4x4<f32> {\n            let joint0 = jointsUniform.matrixs[u32(joints.x)] * inverseBindMatricesUniform.matrixs[u32(joints.x)];\n            let joint1 = jointsUniform.matrixs[u32(joints.y)] * inverseBindMatricesUniform.matrixs[u32(joints.y)];\n            let joint2 = jointsUniform.matrixs[u32(joints.z)] * inverseBindMatricesUniform.matrixs[u32(joints.z)];\n            let joint3 = jointsUniform.matrixs[u32(joints.w)] * inverseBindMatricesUniform.matrixs[u32(joints.w)];\n        \n            let skinMatrix = joint0 * weights.x +\n                            joint1 * weights.y +\n                            joint2 * weights.z +\n                            joint3 * weights.w;\n            return skinMatrix;\n        }\n        #endif\n   `;\n}\nexport function skinVertHeader(defines) {\n\treturn wgslParseDefines`\n   #if ${defines.HAS_SKIN} \n        struct JointsUniform{\n             matrixs:array<mat4x4f>,\n        }\n        struct InverseBindMatricesUniform{\n            matrixs:array<mat4x4f>,\n        }\n        @binding(${defines.skinJointsBufferBinding}) @group(0) var<storage, read> jointsUniform : JointsUniform;\n        @binding(${defines.invsBufferBinding}) @group(0) var<storage, read> inverseBindMatricesUniform : InverseBindMatricesUniform;\n        fn getSkinMatrix(joints: vec4f, weights: vec4f) -> mat4x4<f32> {\n            let joint0 = jointsUniform.matrixs[u32(joints.x)] * inverseBindMatricesUniform.matrixs[u32(joints.x)];\n            let joint1 = jointsUniform.matrixs[u32(joints.y)] * inverseBindMatricesUniform.matrixs[u32(joints.y)];\n            let joint2 = jointsUniform.matrixs[u32(joints.z)] * inverseBindMatricesUniform.matrixs[u32(joints.z)];\n            let joint3 = jointsUniform.matrixs[u32(joints.w)] * inverseBindMatricesUniform.matrixs[u32(joints.w)];\n        \n            let skinMatrix = joint0 * weights.x +\n                            joint1 * weights.y +\n                            joint2 * weights.z +\n                            joint3 * weights.w;\n            return skinMatrix;\n        }\n        #endif\n   `;\n}\nexport function skinVertMain(defines) {\n\treturn wgslParseDefines`\n        #if ${defines.HAS_SKIN}\n            modelMatrix =getSkinMatrix(input.joint0,input.weight0);\n            vNormalView = normalize((materialUniform.normalMatrix * modelMatrix * vec4<f32>(input.normal, 0.0)).xyz);\n        #endif\n  `;\n}\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\n\nexport function PbrMaterialStruct(defines) {\n\treturn wgslParseDefines`\n    struct MaterialUniform {\n          modelMatrix: mat4x4<f32>,\n          color: vec3<f32>,\n          opacity:f32,\n          normalMatrix: mat4x4<f32>,\n          emissive:vec3<f32>,\n          metallic:f32,\n          roughness:f32,\n          #if ${defines.USE_NORMALTEXTURE}\n              normalTextureScale:vec2<f32>,\n          #endif\n          #if ${defines.USE_AOTEXTURE}\n              occlusionStrength:f32,\n          #endif\n      }\n   `;\n}\n","import { FragInput } from \"./attribute/FragInput\";\nimport { PointFragInput } from \"./attribute/PointFragInput\";\nimport { PointVertInput } from \"./attribute/PointVertInput\";\nimport { PointVertOutput } from \"./attribute/PointVertOutput\";\nimport { VertexInput } from \"./attribute/VertexInput\";\nimport { VertexOutput } from \"./attribute/VertexOutput\";\nimport { SystemUniform } from \"./common/SystemUniform\";\nimport { TextureAndSamplerDefine } from \"./common/TextureAndSamplerDefine\";\nimport environment from \"./environment/environment\";\nimport { instanceVertHeader, instanceVertMain } from \"./instance/Instance\";\nimport light from \"./light/light\";\nimport lightCommon from \"./light/lightCommon\";\nimport { getNormalByNormalTexture, getTBN, getNormal } from \"./normal/getNormalBackUp\";\nimport brdf from \"./pbr/brdf\";\nimport ibl from \"./pbr/ibl\";\nimport pbrFunction from \"./pbr/pbrFunction\";\nimport pbrStruct from \"./pbr/pbrStruct\";\nimport pbrTexture from \"./pbr/pbrTexture\";\nimport pbrUtils from \"./pbr/pbrUtils\";\nimport blinn_phong from \"./phong/blinn_phong\";\nimport phongFunction from \"./phong/phongFunction\";\nimport phongUtils from \"./phong/phongUtils\";\n// import getNormal from \"./normal/getNormal\";\nimport { skinVertHeader, skinVertMain } from \"./skin/SkinVert\";\nimport { PbrMaterialStruct } from \"./struct/PbrMaterialStruct\";\nconst ShaderChunk = {\n\tlight,\n\tbrdf,\n\tphongFunction,\n\tphongUtils,\n\tlightCommon,\n\tpbrStruct,\n\tpbrFunction,\n\tpbrTexture,\n\tpbrUtils,\n\tenvironment,\n\tblinn_phong,\n\tgetNormal,\n\tgetTBN,\n\tgetNormalByNormalTexture,\n\tibl,\n\tskinVertMain,\n\tskinVertHeader,\n\tFragInput,\n\tVertexInput,\n\tVertexOutput,\n\tPbrMaterialStruct,\n\tSystemUniform,\n\tinstanceVertMain,\n\tinstanceVertHeader,\n\tTextureAndSamplerDefine,\n\tPointVertInput,\n\tPointVertOutput,\n\tPointFragInput\n};\nexport default ShaderChunk;\n","export default function shadowMapDebuggerFrag(defines) {\r\n\treturn `\r\n    @group(0) @binding(1) var shadowSampler: sampler;\r\n    @group(0) @binding(0) var shadowMap: texture_depth_2d;\r\n    \r\n    // @group(0) @binding(0) var shadowMap: texture_depth_2d_array;\r\n    // @group(0) @binding(0) var shadowMap: texture_2d<f32>;\r\n\r\n    struct VertexOutput {\r\n        @builtin(position) position: vec4<f32>,\r\n        @location(0) uv: vec2<f32>,\r\n    };\r\n\r\n    fn linearizeDepth(depth: f32, near: f32, far: f32)->f32 {\r\n      return 2 * (near * far) / (far + near - depth * (far - near));\r\n    }\r\n\r\n    @fragment\r\n    fn main(input:VertexOutput) -> @location(0) vec4<f32> {\r\n\t\t\tlet color: vec4<f32> = textureGather(shadowMap, shadowSampler, vec2<f32>(input.uv.x,1.0-input.uv.y));\r\n      let depth = (linearizeDepth(color.r, 0.1, 500) - 0.1) / (500 - 0.1);\r\n      return vec4(vec3(depth), 1.0); // PerspectiveCamera\r\n      // return color;\r\n\r\n      // return textureSample(shadowMap, shadowSampler, vec2<f32>(input.uv.x,1.0-input.uv.y));\r\n\r\n    }\r\n    `;\r\n}\r\n","export default function shadowMapDebuggerVert(defines) {\r\n\treturn `\r\n    struct VertexInput {\r\n         @location(${defines.positionLocation}) position: vec2<f32>,       \r\n    }\r\n    struct VertexOutput {\r\n         @builtin(position) position: vec4<f32>,\r\n         @location(0) uv: vec2<f32>,\r\n     };\r\n    @vertex\r\n    fn main(input: VertexInput) -> VertexOutput {\r\n     var output:VertexOutput;\r\n     output.uv = input.position * 0.5 + 0.5;\r\n     output.position = vec4<f32>(input.position, 0.0, 1.0);;\r\n     return output;\r\n    }\r\n    `;\r\n}\r\n","// import Color from \"../../math/Color\";\r\n\r\nexport default function shadowMapFrag(defines) {\r\n\treturn `\r\n    struct VertexOutput {\r\n        @builtin(position) position: vec4<f32>,\r\n        @location(0) color: vec4<f32>,\r\n    };\r\n    @fragment\r\n    fn main(input:VertexOutput) -> @location(0) vec4<f32> {\r\n      return input.color;\r\n    }\r\n    `;\r\n}\r\n","import { wgslParseDefines } from \"../../WgslPreprocessor\";\r\nexport default function shadowMapVert(defines) {\r\n\treturn wgslParseDefines`\r\n   struct VertexInput {\r\n      @location(${defines.positionLocation}) position: vec3<f32>,       \r\n   };\r\n   struct VertexOutput {\r\n      @builtin(position) position: vec4<f32>,\r\n    };\r\n   struct SelfUniform {\r\n      modelMatrix: mat4x4<f32>,\r\n   };\r\n   struct SystemUniform {\r\n      projectionMatrix: mat4x4<f32>,\r\n      viewMatrix: mat4x4<f32>,\r\n      inverseViewMatrix: mat4x4<f32>,\r\n      cameraPosition: vec3<f32>,\r\n   };\r\n\r\n   #if ${defines.isPointLightShadowMap}\r\n      struct PointLightUniform {\r\n         vpMatrix: mat4x4<f32>,\r\n         // vpMatrixArray: array<mat4x4<f32>, 6>,\r\n      };\r\n      @group(1) @binding(${defines.pointLightShadowCameraBinding}) var<storage, read> pointLightUniform: PointLightUniform;\r\n   #endif\r\n\r\n   @group(0) @binding(${defines.selfBinding}) var<uniform> selfUniform : SelfUniform;\r\n   @group(1) @binding(${defines.cameraBinding}) var<uniform> systemUniform : SystemUniform;\r\n\r\n   @vertex\r\n   fn main(input: VertexInput) -> VertexOutput {\r\n      var output:VertexOutput;\r\n      #if ${defines.isPointLightShadowMap}\r\n         output.position = pointLightUniform.vpMatrix * selfUniform.modelMatrix * vec4<f32>(input.position,1.0);\r\n      #else\r\n         output.position = systemUniform.projectionMatrix * systemUniform.viewMatrix * selfUniform.modelMatrix * vec4<f32>(input.position,1.0);\r\n      #endif\r\n      return output;\r\n   }\r\n   `;\r\n}\r\n","import colorFrag from \"./material/colorFrag\";\nimport colorVert from \"./material/colorVert\";\nimport pbr_fs from \"./material/pbr_fs\";\nimport pbr_vs from \"./material/pbr_vs\";\nimport pbrFrag from \"./material/pbrFrag\";\nimport pbrVert from \"./material/pbrVert\";\nimport phongFrag from \"./material/phongFrag\";\nimport phongVert from \"./material/phongVert\";\nimport { point_fs } from \"./material/point_fs\";\nimport { point_vs } from \"./material/point_vs\";\nimport quadFrag from \"./material/quadFrag\";\nimport quadVert from \"./material/quadVert\";\nimport skyBoxFrag from \"./material/skyBoxFrag\";\nimport skyBoxVert from \"./material/skyBoxVert\";\nimport { sprite_fs } from \"./material/sprite_fs\";\nimport { sprite_vs } from \"./material/sprite_vs\";\nimport blendFrag from \"./postProcess/blend/blendFrag\";\nimport Blur from \"./postProcess/bloom/Blur\";\nimport LuminosityHigh from \"./postProcess/bloom/LuminosityHigh\";\nimport ShaderChunk from \"./shaderChunk/ShaderChunk\";\nimport shadowMapDebuggerFrag from \"./shaderChunk/shadow/shadowMapDebuggerFrag\";\nimport shadowMapDebuggerVert from \"./shaderChunk/shadow/shadowMapDebuggerVert\";\nimport shadowMapFrag from \"./shaderChunk/shadow/shadowMapFrag\";\nimport shadowMapVert from \"./shaderChunk/shadow/shadowMapVert\";\n\nfunction reduceComma(shader) {\n\t// 对所有的include处理\n\treturn shader != undefined ? resolveIncludes(shader) : undefined;\n}\nconst includePattern = /^[ \\t]*#include +<([\\w\\d./]+)>/gm;\nlet currentDefines = {};\nconst shaders = {\n\tphong: {\n\t\tfrag: phongFrag,\n\t\tvert: phongVert\n\t},\n\tcolor: {\n\t\tfrag: colorFrag,\n\t\tvert: colorVert\n\t},\n\tpbr: {\n\t\tfrag: pbrFrag,\n\t\tvert: pbrVert\n\t},\n\tskybox: {\n\t\tfrag: skyBoxFrag,\n\t\tvert: skyBoxVert\n\t},\n\tresolve: {\n\t\tfrag: quadFrag,\n\t\tvert: quadVert\n\t},\n\tpbr_mat: {\n\t\tfrag: pbr_fs,\n\t\tvert: pbr_vs\n\t},\n\tblur: {\n\t\tfrag: Blur,\n\t\tvert: quadVert\n\t},\n\tluminosityHigh: {\n\t\tfrag: LuminosityHigh,\n\t\tvert: quadVert\n\t},\n\tblend: {\n\t\tfrag: blendFrag,\n\t\tvert: quadVert\n\t},\n\tshadowMapDebugger: {\n\t\tfrag: shadowMapDebuggerFrag,\n\t\tvert: shadowMapDebuggerVert\n\t},\n\tshadowMap: {\n\t\tvert: shadowMapVert,\n\t\tfrag: shadowMapFrag\n\t},\n\tsprite: {\n\t\tvert: sprite_vs,\n\t\tfrag: sprite_fs\n\t},\n\tpoint: {\n\t\tvert: point_vs,\n\t\tfrag: point_fs\n\t}\n};\n\nfunction resolveIncludes(string) {\n\treturn string.replace(includePattern, includeReplacer);\n}\n\nfunction includeReplacer(match, include) {\n\tconst excute = ShaderChunk[include];\n\tif (excute === undefined) {\n\t\tthrow new Error(`Can not resolve #include <${include}>`);\n\t}\n\tconst result = excute(currentDefines);\n\treturn resolveIncludes(result);\n}\nexport default function getVertFrag(type, defines = {}) {\n\tconst excuteFunc = shaders[type];\n\tcurrentDefines = defines;\n\treturn {\n\t\tvert: reduceComma(excuteFunc?.vert(currentDefines)),\n\t\tfrag: reduceComma(excuteFunc?.frag(currentDefines))\n\t};\n}\n","import {\n\tShaderDefine,\n\tShaderString,\n\tcomputeParams,\n\trenderParams,\n\tShaderModule,\n\tShaderSourceParams,\n\tShaderFunc\n} from \"../core/WebGPUTypes\";\nimport getVertFrag from \"./Shaders\";\nexport class ShaderSource {\n\tpublic compute: computeParams;\n\tpublic render: renderParams;\n\tpublic shaderId: string;\n\tpublic dirty: boolean;\n\tpublic defines?: ShaderDefine;\n\tprivate _uid: string;\n\tprivate _shaderModule: ShaderModule;\n\tconstructor(options: ShaderSourceParams) {\n\t\tthis.shaderId = options.shaderId;\n\t\tthis.defines = options.defines || {};\n\t\tthis.render = options.render;\n\t\tthis.compute = options.compute;\n\t\tthis.dirty = true;\n\t}\n\tget uid() {\n\t\tthis._uid = this.shaderId.concat(JSON.stringify(this.defines));\n\t\treturn this._uid;\n\t}\n\tpublic setDefines(defines) {\n\t\tif (!defines) return;\n\t\tthis.dirty = true;\n\t\tthis.defines = Object.assign(this.defines, defines);\n\t}\n\tpublic getShaderModule(device: GPUDevice): ShaderModule {\n\t\tif (this.dirty) {\n\t\t\tconst { vert, frag, compute } = this.getShaderStr() || {};\n\t\t\tconst vertGPUModule = vert ? device.createShaderModule({ code: vert }) : undefined;\n\t\t\tconst fragGPUModule = frag ? device.createShaderModule({ code: frag }) : undefined;\n\t\t\tconst computeGPUModule = compute ? device.createShaderModule({ code: compute }) : undefined;\n\t\t\tthis._shaderModule = {\n\t\t\t\tvert: vertGPUModule,\n\t\t\t\tfrag: fragGPUModule,\n\t\t\t\tcompute: computeGPUModule\n\t\t\t};\n\t\t\tthis.dirty = false;\n\t\t}\n\t\treturn this._shaderModule;\n\t}\n\tpublic destroy() {\n\t\tthis.render = null;\n\t\tthis.compute = null;\n\t\tthis._shaderModule = null;\n\t\tthis.defines = null;\n\t}\n\tprivate getShaderStr(): ShaderString {\n\t\tconst { fragShader, vertShader } = this.render || {};\n\t\tconst { computeShader } = this.compute || {};\n\t\tconst source = getVertFrag(this.shaderId, this.defines);\n\t\tconst vert =\n\t\t\tsource?.vert ?? (vertShader instanceof Function ? (<ShaderFunc>vertShader)(this.defines) : vertShader);\n\t\tconst frag =\n\t\t\tsource?.frag ?? (fragShader instanceof Function ? (<ShaderFunc>fragShader)(this.defines) : fragShader);\n\t\tconst compute = computeShader instanceof Function ? (computeShader as ShaderFunc)(this.defines) : computeShader;\n\t\treturn {\n\t\t\tvert,\n\t\t\tfrag,\n\t\t\tcompute\n\t\t};\n\t}\n\tstatic replaceMain(source: string, renamedMain: string) {\n\t\trenamedMain = `void ${renamedMain}()`;\n\t\treturn source.replace(/void\\s+main\\s*\\(\\s*(?:void)?\\s*\\)/g, renamedMain);\n\t}\n}\n","import { IUniform, UniformEnum } from \"../core/WebGPUTypes\";\nimport { Mesh } from \"../mesh/Mesh\";\nimport ShaderData from \"../render/ShaderData\";\nimport UniformBuffer from \"../render/UniformBuffer\";\nconst uniformArrayNames = [\"array<f32>\", \"array<vec2<f32>>\", \"array<vec3<f32>>\", \"array<vec4<f32>>\"];\nexport function checkContainFloatType(uniforms) {\n\tlet result = 0;\n\tlet hasArraytype = false;\n\tconst uniformsNames = Object.getOwnPropertyNames(uniforms);\n\tuniformsNames.map((uniformsName) => {\n\t\tif (uniforms[uniformsName].type == \"texture\" || uniforms[uniformsName].type == \"sampler\") {\n\t\t\tresult += 0;\n\t\t} else {\n\t\t\tif (\n\t\t\t\tuniformArrayNames.find((name) => {\n\t\t\t\t\treturn name === uniforms[uniformsName].type;\n\t\t\t\t})\n\t\t\t) {\n\t\t\t\thasArraytype = true;\n\t\t\t} else {\n\t\t\t\tresult += 1;\n\t\t\t}\n\t\t}\n\t});\n\treturn {\n\t\thasFloat: result,\n\t\thasArraytype\n\t};\n}\nexport function addUniformToShaderData(\n\tname: string,\n\tuniform: IUniform,\n\tshaderData: ShaderData,\n\tmesh?: Mesh,\n\tuniformBuffer?: UniformBuffer\n) {\n\tconst valueIsFunc = uniform?.value instanceof Function;\n\tswitch (uniform.type) {\n\t\tcase \"f32\":\n\t\t\tuniformBuffer.setUniform(\n\t\t\t\tname,\n\t\t\t\tvalueIsFunc\n\t\t\t\t\t? uniform.value\n\t\t\t\t\t: () => {\n\t\t\t\t\t\t\treturn uniform.value;\n\t\t\t\t\t  },\n\t\t\t\tUniformEnum.Float\n\t\t\t);\n\t\t\tbreak;\n\t\tcase \"vec2<f32>\":\n\t\t\tuniformBuffer.setUniform(\n\t\t\t\tname,\n\t\t\t\tvalueIsFunc\n\t\t\t\t\t? uniform.value\n\t\t\t\t\t: () => {\n\t\t\t\t\t\t\treturn uniform.value;\n\t\t\t\t\t  },\n\t\t\t\tUniformEnum.FloatVec2\n\t\t\t);\n\t\t\tbreak;\n\t\tcase \"vec3<f32>\":\n\t\t\tuniformBuffer.setUniform(\n\t\t\t\tname,\n\t\t\t\tvalueIsFunc\n\t\t\t\t\t? uniform.value\n\t\t\t\t\t: () => {\n\t\t\t\t\t\t\treturn uniform.value;\n\t\t\t\t\t  },\n\t\t\t\tUniformEnum.FloatVec3\n\t\t\t);\n\t\t\tbreak;\n\t\tcase \"color\":\n\t\t\tuniformBuffer.setUniform(\n\t\t\t\tname,\n\t\t\t\tvalueIsFunc\n\t\t\t\t\t? uniform.value\n\t\t\t\t\t: () => {\n\t\t\t\t\t\t\treturn uniform.value;\n\t\t\t\t\t  },\n\t\t\t\tUniformEnum.Color\n\t\t\t);\n\t\t\tbreak;\n\t\tcase \"vec4<f32>\":\n\t\t\tuniformBuffer.setUniform(\n\t\t\t\tname,\n\t\t\t\tvalueIsFunc\n\t\t\t\t\t? uniform.value\n\t\t\t\t\t: () => {\n\t\t\t\t\t\t\treturn uniform.value;\n\t\t\t\t\t  },\n\t\t\t\tUniformEnum.FloatVec4\n\t\t\t);\n\t\t\tbreak;\n\t\tcase \"mat2x2<f32>\":\n\t\t\tuniformBuffer.setUniform(\n\t\t\t\tname,\n\t\t\t\tvalueIsFunc\n\t\t\t\t\t? uniform.value\n\t\t\t\t\t: () => {\n\t\t\t\t\t\t\treturn uniform.value;\n\t\t\t\t\t  },\n\t\t\t\tUniformEnum.Mat2\n\t\t\t);\n\t\t\tbreak;\n\t\tcase \"mat3x3<f32>\":\n\t\t\tuniformBuffer.setUniform(\n\t\t\t\tname,\n\t\t\t\tvalueIsFunc\n\t\t\t\t\t? uniform.value\n\t\t\t\t\t: () => {\n\t\t\t\t\t\t\treturn uniform.value;\n\t\t\t\t\t  },\n\t\t\t\tUniformEnum.Mat3\n\t\t\t);\n\t\t\tbreak;\n\t\tcase \"mat4x4<f32>\":\n\t\t\tuniformBuffer.setUniform(\n\t\t\t\tname,\n\t\t\t\tvalueIsFunc\n\t\t\t\t\t? uniform.value\n\t\t\t\t\t: () =>\n\t\t\t\t\t\t\tname == \"modelMatrix\"\n\t\t\t\t\t\t\t\t? mesh?.modelMatrix\n\t\t\t\t\t\t\t\t: name === \"normalMatrix\"\n\t\t\t\t\t\t\t\t? mesh?.normalMatrix\n\t\t\t\t\t\t\t\t: uniform.value,\n\t\t\t\tUniformEnum.Mat4\n\t\t\t);\n\t\t\tbreak;\n\t\tcase \"array<f32>\":\n\t\t\tuniformBuffer.setUniform(\n\t\t\t\tname,\n\t\t\t\tvalueIsFunc\n\t\t\t\t\t? uniform.value\n\t\t\t\t\t: () => {\n\t\t\t\t\t\t\treturn uniform.value;\n\t\t\t\t\t  },\n\t\t\t\tUniformEnum.FloatArray,\n\t\t\t\tuniform.value.length\n\t\t\t);\n\t\t\tbreak;\n\t\tcase \"array<vec2<f32>>\":\n\t\t\tuniformBuffer.setUniform(\n\t\t\t\tname,\n\t\t\t\tvalueIsFunc\n\t\t\t\t\t? uniform.value\n\t\t\t\t\t: () => {\n\t\t\t\t\t\t\treturn uniform.value;\n\t\t\t\t\t  },\n\t\t\t\tUniformEnum.Vec2Array,\n\t\t\t\tuniform.value.length\n\t\t\t);\n\t\t\tbreak;\n\t\tcase \"array<vec3<f32>>\":\n\t\t\tuniformBuffer.setUniform(\n\t\t\t\tname,\n\t\t\t\tvalueIsFunc\n\t\t\t\t\t? uniform.value\n\t\t\t\t\t: () => {\n\t\t\t\t\t\t\treturn uniform.value;\n\t\t\t\t\t  },\n\t\t\t\tUniformEnum.Vec3Array,\n\t\t\t\tuniform.value.length\n\t\t\t);\n\t\t\tbreak;\n\t\tcase \"array<vec4<f32>>\":\n\t\t\tuniformBuffer.setUniform(\n\t\t\t\tname,\n\t\t\t\tvalueIsFunc\n\t\t\t\t\t? uniform.value\n\t\t\t\t\t: () => {\n\t\t\t\t\t\t\treturn uniform.value;\n\t\t\t\t\t  },\n\t\t\t\tUniformEnum.Vec4Array,\n\t\t\t\tuniform.value.length\n\t\t\t);\n\t\t\tbreak;\n\t\tcase \"texture\":\n\t\tcase \"storageTexture\":\n\t\t\tshaderData.setTexture(\n\t\t\t\tname,\n\t\t\t\tvalueIsFunc\n\t\t\t\t\t? uniform.value\n\t\t\t\t\t: () => {\n\t\t\t\t\t\t\treturn uniform.value;\n\t\t\t\t\t  },\n\t\t\t\tuniform?.binding,\n\t\t\t\tuniform?.type,\n\t\t\t\tuniform?.visibility,\n\t\t\t\tuniform?.textureView\n\t\t\t);\n\t\t\tbreak;\n\t\tcase \"sampler\":\n\t\t\tshaderData.setSampler(\n\t\t\t\tname,\n\t\t\t\tvalueIsFunc\n\t\t\t\t\t? uniform.value\n\t\t\t\t\t: () => {\n\t\t\t\t\t\t\treturn uniform.value;\n\t\t\t\t\t  },\n\t\t\t\tuniform?.binding,\n\t\t\t\tuniform?.visibility\n\t\t\t);\n\t\t\tbreak;\n\t\tdefault:\n\t\t\tthrow new Error(\"not match unifrom type\");\n\t}\n}\n","import BindGroupLayoutEntry from \"./BindGroupLayoutEntry\";\r\nconst layoutCache = new Map();\r\nclass BindGroupLayout {\r\n\tpublic gpuBindGroupLayout: GPUBindGroupLayout;\r\n\tindex: number;\r\n\tprivate constructor(device: GPUDevice, label: string, public entries: BindGroupLayoutEntry[] = [], index = 0) {\r\n\t\tthis.index = index || 0;\r\n\t\tthis.gpuBindGroupLayout = device.createBindGroupLayout({\r\n\t\t\tlabel: label,\r\n\t\t\tentries: entries.map(({ visibility, buffer, sampler, texture, storageTexture, binding }) => ({\r\n\t\t\t\tbinding,\r\n\t\t\t\tvisibility,\r\n\t\t\t\tbuffer,\r\n\t\t\t\tsampler,\r\n\t\t\t\ttexture,\r\n\t\t\t\tstorageTexture\r\n\t\t\t}))\r\n\t\t});\r\n\t}\r\n\tstatic getBindGroupLayoutFromCache(\r\n\t\tdevice: GPUDevice,\r\n\t\tlabel: string,\r\n\t\tentires: BindGroupLayoutEntry[],\r\n\t\tindex\r\n\t): BindGroupLayout {\r\n\t\tif (layoutCache.has(label)) {\r\n\t\t\treturn layoutCache.get(label);\r\n\t\t} else {\r\n\t\t\tconst bindGroupLayout = new BindGroupLayout(device, label, entires, index);\r\n\t\t\tlayoutCache.set(label, bindGroupLayout);\r\n\t\t\treturn bindGroupLayout;\r\n\t\t}\r\n\t}\r\n\tstatic removeBindGroupLayoutFromCache(bindGroupLayout: BindGroupLayout) {\r\n\t\tlayoutCache.delete(bindGroupLayout);\r\n\t}\r\n}\r\n\r\nexport default BindGroupLayout;\r\n","import { BindGroupLayoutEntryType } from \"../core/WebGPUTypes\";\nexport default class BindGroupLayoutEntry {\n\tbinding: number;\n\tvisibility: GPUShaderStageFlags;\n\tuniforms?: any[];\n\tbuffer?: GPUBufferBindingLayout;\n\tsampler?: GPUSamplerBindingLayout;\n\ttexture?: GPUTextureBindingLayout;\n\tstorageTexture?: GPUStorageTextureBindingLayout;\n\texternalTexture?: GPUExternalTextureBindingLayout;\n\tconstructor(options: BindGroupLayoutEntryType) {\n\t\tthis.binding = options.binding;\n\t\tthis.visibility = options.visibility;\n\t\tthis.buffer = options.buffer;\n\t\tthis.sampler = options.sampler;\n\t\tthis.texture = options.texture;\n\t\tthis.storageTexture = options.storageTexture;\n\t\tthis.externalTexture = options.externalTexture;\n\t}\n\tgetGPULayoutEntity() {\n\t\treturn {\n\t\t\tbinding: this.binding,\n\t\t\tvisibility: this.visibility,\n\t\t\tbuffer: this.buffer,\n\t\t\tsampler: this.sampler,\n\t\t\ttexture: this.texture,\n\t\t\texternalTexture: this.externalTexture,\n\t\t\tstorageTexture: this.storageTexture\n\t\t};\n\t}\n}\n","import { ShaderStage } from \"../core/WebGPUConstant\";\nimport { UniformFunc, ShaderDefine } from \"../core/WebGPUTypes\";\nimport defaultValue from \"../utils/defaultValue\";\nimport BindGroup from \"./BindGroup\";\nimport BindGroupEntity from \"./BindGroupEntity\";\nimport BindGroupLayout from \"./BindGroupLayout\";\nimport BindGroupLayoutEntry from \"./BindGroupLayoutEntry\";\nimport Sampler from \"./Sampler\";\nimport Texture from \"./Texture\";\nimport UniformBuffer from \"./UniformBuffer\";\nimport { UniformSampler, UniformTexture } from \"./Uniforms\";\nexport default class ShaderData {\n\tcurrentBinding: number;\n\n\tdefines: ShaderDefine;\n\n\tdefineDirty: boolean;\n\n\tlabel: string;\n\n\tbindGroup: BindGroup;\n\n\tgroupLayout: BindGroupLayout;\n\n\tlayoutIndex: number;\n\n\tgroupIndex: number;\n\n\tprotected _uniforms: Map<string, any>;\n\n\tconstructor(label: string, size?: number, layoutIndex?: number, groupIndex?) {\n\t\tthis.label = label;\n\t\tthis.currentBinding = 0;\n\t\tthis.defineDirty = true;\n\t\tthis.defines = {};\n\t\tthis._uniforms = new Map();\n\t\tthis.groupIndex = defaultValue(groupIndex, 0);\n\t\tthis.layoutIndex = defaultValue(layoutIndex, 0);\n\t}\n\tgetUniformBuffer(name: string): UniformBuffer {\n\t\treturn this._uniforms.get(name);\n\t}\n\tgetTexture(name: string): Texture {\n\t\treturn this._uniforms.get(name);\n\t}\n\tgetSampler(name: string): Sampler {\n\t\treturn this._uniforms.get(name);\n\t}\n\tsetUniformBuffer(name: string, uniformBuffer: UniformBuffer, binding?: number) {\n\t\tif (this._uniforms.get(name)) return;\n\t\tuniformBuffer.binding = this.currentBinding;\n\t\tthis.setDefine(name.concat(\"Binding\"), binding ?? this.currentBinding);\n\t\tthis.currentBinding += 1;\n\t\tthis._uniforms.set(name, uniformBuffer);\n\t}\n\tsetTexture(\n\t\tname: string,\n\t\tvalue: UniformFunc | Texture,\n\t\tbinding?: number,\n\t\ttype?: string,\n\t\tvisibility?: ShaderStage,\n\t\ttextureView?: GPUTextureView\n\t) {\n\t\tif (this._uniforms.get(name)) return;\n\t\tconst uniform = new UniformTexture(name, binding ?? this.currentBinding, value, type, visibility, textureView);\n\t\tthis.setDefine(name.concat(\"Binding\"), binding ?? this.currentBinding);\n\t\tthis.currentBinding += 1;\n\t\tthis._uniforms.set(name, uniform);\n\t}\n\tsetSampler(name: string, value: UniformFunc | Sampler, binding?: number, visibility?: ShaderStage) {\n\t\tif (this._uniforms.get(name)) return;\n\t\tconst uniform = new UniformSampler(name, binding ?? this.currentBinding, value, visibility);\n\t\tthis.setDefine(name.concat(\"Binding\"), binding ?? this.currentBinding);\n\t\tthis.currentBinding += 1;\n\t\tthis._uniforms.set(name, uniform);\n\t}\n\tsetDefine(name: string, value: boolean | number) {\n\t\tif (this.defines[name] === undefined) {\n\t\t\tthis.defineDirty = true;\n\t\t\tthis.defines[name] = value;\n\t\t} else {\n\t\t\tif (this.defines[name] === value) {\n\t\t\t\treturn;\n\t\t\t} else {\n\t\t\t\tthis.defineDirty = true;\n\t\t\t\tthis.defines[name] = value;\n\t\t\t}\n\t\t}\n\t}\n\treplaceUniformBufferValue(name: string, value: UniformFunc | number | object) {\n\t\tthis._uniforms.forEach((uniform) => {\n\t\t\tif (uniform?.isUniformBuffer) {\n\t\t\t\tuniform.replaceUniformValue(name, value);\n\t\t\t}\n\t\t});\n\t}\n\tbind(device: GPUDevice, passEncoder: GPURenderPassEncoder | GPUComputePassEncoder) {\n\t\tthis.uploadUniform(device);\n\t\tif (!this.groupLayout) this.groupLayout = this.createBindGroupLayout(device, this.label, this.layoutIndex);\n\t\tif (!this.bindGroup) this.bindGroup = this.createBindGroup(device, this.label, this.groupIndex);\n\t\tthis.bindGroup.bind(passEncoder);\n\t}\n\tdestroy() {\n\t\tthis._uniforms.forEach((uniform) => {\n\t\t\tif (uniform.destroy) uniform?.destroy();\n\t\t});\n\t\tthis.label = undefined;\n\t\tthis.currentBinding = 1;\n\t\tthis.defineDirty = true;\n\t\tthis.defines = undefined;\n\t\tthis._uniforms.clear();\n\t\tBindGroupLayout.removeBindGroupLayoutFromCache(this.groupLayout);\n\t\tthis.bindGroup = undefined;\n\t}\n\tprivate createBindGroup(device: GPUDevice, label: string, groupIndex?: number) {\n\t\tconst { entities, dynamic, alignedSize, maxOffset } = this.createBindGroupEntity();\n\t\tconst bindGroup = new BindGroup({\n\t\t\tlabel: label,\n\t\t\tentires: entities,\n\t\t\tdevice: device,\n\t\t\tlayout: this.groupLayout,\n\t\t\tindex: groupIndex || 0, // 后续改成groupIndex\n\t\t\tdynamic,\n\t\t\talignedSize,\n\t\t\tmaxOffset\n\t\t});\n\t\treturn bindGroup;\n\t}\n\tprivate createBindGroupLayout(device: GPUDevice, label: string, layoutIndex?: number) {\n\t\tconst result = this.createBindGroupLayoutEntry();\n\t\tconst groupLayout = BindGroupLayout.getBindGroupLayoutFromCache(\n\t\t\tdevice,\n\t\t\tlabel + \"-\" + result.uid,\n\t\t\tresult.layouts,\n\t\t\tlayoutIndex || 0\n\t\t);\n\t\treturn groupLayout;\n\t}\n\tprotected uploadUniform(device: GPUDevice) {\n\t\tthis._uniforms.forEach((uniform) => {\n\t\t\tuniform.bind(device);\n\t\t});\n\t}\n\tprivate createBindGroupLayoutEntry() {\n\t\tlet uid = \"\";\n\t\tconst result = new Map();\n\t\tthis._uniforms.forEach((uniform) => {\n\t\t\tif (!result.has(uniform.name)) {\n\t\t\t\tuid = uid === \"\" ? uid.concat(uniform.name) : uid.concat(\", \").concat(uniform.name);\n\t\t\t\tresult.set(uniform.name, this.createOneLayoutEntry(uniform));\n\t\t\t}\n\t\t});\n\t\tuid = `uniforms[${uid}]`;\n\t\treturn { uid, layouts: [...result.values()] };\n\t}\n\tprivate createBindGroupEntity() {\n\t\tconst result = new Map();\n\t\tlet dynamic = false,\n\t\t\talignedSize = 0,\n\t\t\tmaxOffset = 0;\n\t\tthis._uniforms.forEach((uniform) => {\n\t\t\tif (!result.has(uniform.name)) {\n\t\t\t\tif (uniform?.hasDynamicOffset) {\n\t\t\t\t\tdynamic = true;\n\t\t\t\t\tmaxOffset = uniform.maxOffset;\n\t\t\t\t\talignedSize = Math.ceil(uniform.uniformsSize / (4 * 256)) * 256;\n\t\t\t\t}\n\t\t\t\tresult.set(uniform.name, this.creayeOneGroupEntity(uniform));\n\t\t\t}\n\t\t});\n\t\treturn {\n\t\t\tentities: [...result.values()],\n\t\t\tdynamic,\n\t\t\talignedSize,\n\t\t\tmaxOffset\n\t\t};\n\t}\n\tprivate createOneLayoutEntry(uniform) {\n\t\tlet layoutEntity;\n\t\tif (uniform.isUniformBuffer) {\n\t\t\tlayoutEntity = new BindGroupLayoutEntry({\n\t\t\t\tbinding: uniform.binding,\n\t\t\t\tbuffer: uniform.layoutType,\n\t\t\t\tvisibility: uniform.visibility\n\t\t\t});\n\t\t} else if (uniform.isTexture) {\n\t\t\tlayoutEntity = new BindGroupLayoutEntry({\n\t\t\t\tbinding: uniform.binding,\n\t\t\t\tvisibility: uniform.visibility,\n\t\t\t\ttexture: uniform.type == \"texture\" ? uniform.layoutType : undefined,\n\t\t\t\tstorageTexture: uniform.type == \"storageTexture\" ? uniform.storageTextureLayoutType : undefined\n\t\t\t});\n\t\t} else if (uniform.isSampler) {\n\t\t\tlayoutEntity = new BindGroupLayoutEntry({\n\t\t\t\tbinding: uniform.binding,\n\t\t\t\tvisibility: uniform.visibility,\n\t\t\t\tsampler: uniform.layoutType\n\t\t\t});\n\t\t}\n\t\treturn layoutEntity;\n\t}\n\tprivate creayeOneGroupEntity(uniform) {\n\t\tlet groupEntity;\n\t\tif (uniform.isUniformBuffer) {\n\t\t\tgroupEntity = new BindGroupEntity({\n\t\t\t\tbinding: uniform.binding,\n\t\t\t\tresource: {\n\t\t\t\t\tbuffer: uniform.buffer.gpuBuffer,\n\t\t\t\t\toffset: uniform.offset,\n\t\t\t\t\tsize: uniform.bufferSize\n\t\t\t\t}\n\t\t\t});\n\t\t} else if (uniform.isTexture) {\n\t\t\tgroupEntity = new BindGroupEntity({\n\t\t\t\tbinding: uniform.binding,\n\t\t\t\tresource: uniform?.textureView ?? uniform.texture.textureView\n\t\t\t});\n\t\t} else if (uniform.isSampler) {\n\t\t\tgroupEntity = new BindGroupEntity({\n\t\t\t\tbinding: uniform.binding,\n\t\t\t\tresource: uniform.sampler.gpuSampler\n\t\t\t});\n\t\t}\n\t\treturn groupEntity;\n\t}\n}\n","import { FrameState } from \"../core/FrameState\";\nimport { CullMode, PrimitiveTopology } from \"../core/WebGPUConstant\";\nimport Color from \"../math/Color\";\nimport { Mesh } from \"../mesh/Mesh\";\nimport { DepthStencil, RenderState, Target, Primitive } from \"../render/RenderState\";\nimport Sampler from \"../render/Sampler\";\nimport ShaderData from \"../render/ShaderData\";\nimport Texture from \"../render/Texture\";\nimport { ShaderSource } from \"../shader/ShaderSource\";\nexport class Material {\n\tpublic shaderData: ShaderData;\n\n\tcolor?: Color;\n\n\tbaseSampler?: Sampler;\n\n\tbaseTexture?: Texture;\n\n\ttype: string;\n\n\tlabel: string;\n\n\tshaderSource: ShaderSource;\n\n\ttransparent: boolean;\n\n\tdirty: boolean;\n\n\tlight: boolean;\n\n\tready: boolean;\n\n\tprivate _emissive: Color;\n\n\tprivate _opacity: number;\n\n\tprivate _emissiveIntensity: number;\n\n\tprivate _diffuse: Color;\n\n\tprivate _renderState: RenderState;\n\n\tprivate _doubleSided: boolean;\n\n\tconstructor() {\n\t\tthis.label = undefined;\n\t\tthis.type = undefined;\n\t\tthis.baseTexture = undefined;\n\t\tthis.baseSampler = undefined;\n\t\tthis._diffuse = new Color(0.0, 0.0, 0.0);\n\t\tthis._opacity = 1.0;\n\t\t// Buffer\n\t\tthis.shaderData = undefined;\n\t\tthis.shaderSource = undefined;\n\t\tthis.dirty = true;\n\t\tthis._emissive = new Color(0.0, 0.0, 0);\n\t\tthis._emissiveIntensity = 1.0;\n\t\tthis._doubleSided = true;\n\t\tthis.light = false;\n\t\tthis.ready = false;\n\t\tthis.init();\n\t}\n\tpublic set wireframe(value: boolean) {\n\t\tthis.renderState.primitive.topology = value ? PrimitiveTopology.LineList : PrimitiveTopology.TriangleList;\n\t}\n\tpublic set topology(value: PrimitiveTopology) {\n\t\tthis.renderState.primitive.topology = value;\n\t}\n\tpublic get doubleSided() {\n\t\treturn this._doubleSided;\n\t}\n\tpublic set doubleSided(value: boolean) {\n\t\tthis._renderState.primitive.cullMode = value ? CullMode.None : CullMode.Back;\n\t\tthis._doubleSided = value;\n\t}\n\tpublic get renderState() {\n\t\treturn this._renderState;\n\t}\n\tpublic set renderState(value: RenderState) {\n\t\tthis._renderState = value;\n\t}\n\tpublic get diffuse(): Color {\n\t\treturn this._diffuse;\n\t}\n\tpublic set diffuse(v: Color) {\n\t\tthis._diffuse = v;\n\t}\n\tpublic get emissive(): Color {\n\t\treturn this._emissive;\n\t}\n\tpublic set emissive(v: Color) {\n\t\tthis._emissive = v;\n\t}\n\tpublic get emissiveIntensity(): number {\n\t\treturn this._emissiveIntensity;\n\t}\n\tpublic set emissiveIntensity(v: number) {\n\t\tthis._emissiveIntensity = v;\n\t}\n\tpublic get opacity(): number {\n\t\treturn this._opacity;\n\t}\n\tpublic set opacity(v: number) {\n\t\tthis._opacity = v;\n\t}\n\tonBeforeRender() {\n\t\t// callback\n\t}\n\n\tonBeforeCompile() {\n\t\t// callback\n\t}\n\tclone(): Material {\n\t\treturn null;\n\t}\n\tupdate(frameState?: FrameState, mesh?: Mesh) {\n\t\t// update material\n\t}\n\tprotected createShaderData() {\n\t\tif (this.shaderData) this.shaderData.destroy();\n\t\tthis.shaderData = new ShaderData(this.type, 0);\n\t\tthis.ready = true;\n\t}\n\tprivate init() {\n\t\t// 默认渲染状态\n\t\tconst primitive = new Primitive();\n\t\tconst target = new Target();\n\t\tconst depthStencil = new DepthStencil();\n\t\tthis._renderState = new RenderState();\n\t\tthis._renderState.primitive = primitive;\n\t\tthis._renderState.targets = [target];\n\t\tthis._renderState.depthStencil = depthStencil;\n\t}\n\tpublic destroy() {\n\t\tthis.label = undefined;\n\t\tthis.type = undefined;\n\t\tthis.baseTexture = undefined;\n\t\tthis.baseSampler = undefined;\n\t\tthis.color = undefined;\n\t}\n}\n","import { FrameState } from \"../core/FrameState\";\nimport { BufferBindingType, BufferUsage } from \"../core/WebGPUConstant\";\nimport { ShaderMaterialParms, Uniforms } from \"../core/WebGPUTypes\";\nimport { Mesh } from \"../mesh/Mesh\";\nimport UniformBuffer from \"../render/UniformBuffer\";\nimport { ShaderSource } from \"../shader/ShaderSource\";\nimport defaultValue from \"../utils/defaultValue\";\nimport { addUniformToShaderData, checkContainFloatType } from \"../utils/uniformUtils\";\nimport { Material } from \"./Material\";\n\nexport default class ShaderMaterial extends Material {\n\tuniforms: Uniforms;\n\tuniformBuffer: UniformBuffer;\n\tprivate shaderMaterialParms: ShaderMaterialParms;\n\tconstructor(options: ShaderMaterialParms) {\n\t\tsuper();\n\t\tconst { type, frag, vert, defines, light } = options;\n\t\tthis.type = type;\n\t\tthis.shaderMaterialParms = options;\n\t\tthis.shaderSource = new ShaderSource({\n\t\t\tshaderId: type,\n\t\t\trender: {\n\t\t\t\tfragShader: frag,\n\t\t\t\tvertShader: vert\n\t\t\t},\n\t\t\tdefines: defaultValue(defines, {})\n\t\t});\n\t\tthis.uniforms = options.uniforms;\n\t\tthis.uniformBuffer = undefined;\n\t\tthis.light = light || false;\n\t}\n\tupdate(frameState?: FrameState, mesh?: Mesh) {\n\t\tif (!this.shaderData || this.dirty) this.createShaderData(mesh);\n\t}\n\tclone() {\n\t\treturn new ShaderMaterial(this.shaderMaterialParms);\n\t}\n\tprotected createShaderData(mesh?: Mesh) {\n\t\tsuper.createShaderData();\n\t\tconst result = checkContainFloatType(this.uniforms);\n\t\tif (result.hasFloat) {\n\t\t\tthis.uniformBuffer = result.hasArraytype\n\t\t\t\t? new UniformBuffer({\n\t\t\t\t\t\tlabel: this.type + \"UniformBuffer\",\n\t\t\t\t\t\ttype: BufferBindingType.ReadOnlyStorage,\n\t\t\t\t\t\tusage: BufferUsage.Storage | BufferUsage.CopyDst\n\t\t\t\t  })\n\t\t\t\t: new UniformBuffer({ label: this.type + \"UniformBuffer\" });\n\t\t\tthis.shaderData.setUniformBuffer(this.type, this.uniformBuffer);\n\t\t}\n\t\tconst uniformsNames = Object.getOwnPropertyNames(this.uniforms);\n\t\tuniformsNames.map((uniformsName) => {\n\t\t\taddUniformToShaderData(\n\t\t\t\tuniformsName,\n\t\t\t\tthis.uniforms[uniformsName],\n\t\t\t\tthis.shaderData,\n\t\t\t\tmesh,\n\t\t\t\tthis.uniformBuffer\n\t\t\t);\n\t\t});\n\t}\n}\n","function createGuid() {\r\n  // http://stackoverflow.com/questions/105034/how-to-create-a-guid-uuid-in-javascript\r\n  return \"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx\".replace(/[xy]/g, function (c) {\r\n    const r = (Math.random() * 16) | 0;\r\n    const v = c === \"x\" ? r : (r & 0x3) | 0x8;\r\n    return v.toString(16);\r\n  });\r\n}\r\nexport default createGuid;\r\n","import Camera from \"../camera/Camera\";\nimport { FrameState } from \"../core/FrameState\";\nimport LightManger from \"../core/LightManger\";\nimport RenderObject from \"../core/RenderObject\";\nimport { CommandSubType, Intersect } from \"../core/WebGPUConstant\";\nimport { RenderObjectType } from \"../core/WebGPUTypes\";\nimport Geometry from \"../geometry/Geometry\";\nimport { Material } from \"../material/Material\";\nimport DrawCommand from \"../render/DrawCommand\";\nimport createGuid from \"../utils/createGuid\";\nexport class Mesh extends RenderObject {\n\t[x: string]: any;\n\tuid: string;\n\tfrustumCull: boolean;\n\tsubCommands: { [prop: string]: DrawCommand };\n\tgeometry?: Geometry;\n\tmaterial?: Material;\n\tinstanceCount?: number;\n\tpriority?: number;\n\tdrawCommand?: DrawCommand;\n\tdistanceToCamera?: number;\n\tconstructor(geometry?: Geometry, material?: Material) {\n\t\tsuper();\n\t\tthis.geometry = geometry;\n\t\tthis.material = material;\n\t\tthis.type = RenderObjectType.Mesh;\n\t\tthis.frustumCull = true;\n\t\tthis.uid = createGuid();\n\t\tthis.subCommands = {};\n\t}\n\tget ready() {\n\t\treturn this.material.ready;\n\t}\n\tupdate(frameState: FrameState, camera?: Camera) {\n\t\t// update matrix\n\t\tthis.updateMatrix(this?.parent?.modelMatrix);\n\t\t// create\n\t\tthis.geometry.update(frameState);\n\t\tthis.material.update(frameState, this);\n\t\t// update boundingSphere\n\t\tthis.geometry.boundingSphere.update(this.modelMatrix);\n\t\tthis.material.shaderSource.setDefines(frameState.defines);\n\t\tif (this.type == RenderObjectType.Debug) {\n\t\t\tframeState.renderQueue.debugQueue.push(this);\n\t\t\treturn;\n\t\t}\n\t\tthis.distanceToCamera = this.geometry.boundingSphere.distanceToCamera(camera);\n\n\t\tconst visibility = frameState.cullingVolume.computeVisibility(this.geometry.boundingSphere);\n\t\t// 视锥剔除\n\t\tif (visibility === Intersect.OUTSIDE || !this.frustumCull) return;\n\t\tif (this.material.transparent) {\n\t\t\tframeState.renderQueue.transparent.push(this);\n\t\t} else {\n\t\t\tframeState.renderQueue.opaque.push(this);\n\t\t}\n\t}\n\tbeforeRender() {\n\t\t// before render\n\t}\n\tafterRender() {\n\t\t// after render\n\t}\n\tpublic getDrawCommand(overrideMaterial?: Material, commandSubType?: CommandSubType, lightManger?: LightManger) {\n\t\tif (!this.drawCommand || this.material.dirty) {\n\t\t\tthis.material.shaderSource.setDefines(\n\t\t\t\tObject.assign({}, this.material.shaderData.defines, this.geometry.defines)\n\t\t\t);\n\t\t\tif (this.material.dirty) this.material.dirty = false;\n\t\t\tthis.drawCommand = new DrawCommand({\n\t\t\t\tvertexBuffers: this.geometry.vertexBuffers,\n\t\t\t\tindexBuffer: this.geometry.indexBuffer,\n\t\t\t\tshaderData: this.material.shaderData,\n\t\t\t\tinstances: this.instanceCount,\n\t\t\t\tcount: this.geometry.count,\n\t\t\t\trenderState: this.material.renderState,\n\t\t\t\tshaderSource: this.material.shaderSource,\n\t\t\t\tlightShaderData: this.material.light ? lightManger?.lightShaderData : undefined,\n\t\t\t\tuseLight: this.material.light\n\t\t\t});\n\t\t}\n\t\tif (overrideMaterial) {\n\t\t\tif (!this.subCommands[commandSubType]) {\n\t\t\t\tconst copyMat = overrideMaterial.clone();\n\t\t\t\tcopyMat.update(undefined, this);\n\t\t\t\tif (copyMat.dirty) copyMat.dirty = false;\n\t\t\t\tthis.subCommands[commandSubType] = this.drawCommand.shallowClone(copyMat);\n\t\t\t}\n\t\t\treturn this.subCommands[commandSubType];\n\t\t}\n\t\treturn this.drawCommand;\n\t}\n\tdestroy() {\n\t\tthis.geometry.destroy();\n\t\tthis.material.destroy();\n\t}\n}\n","import { RenderObjectType } from \"../core/WebGPUTypes\";\r\nimport Geometry from \"../geometry/Geometry\";\r\nimport PlaneGeometry from \"../geometry/PlaneGeometry\";\r\nimport { Light } from \"../light/Light\";\r\nimport ShaderMaterial from \"../material/ShaderMaterial\";\r\nimport { Mesh } from \"../mesh/Mesh\";\r\nimport { ViewPort } from \"../render/RenderState\";\r\nimport Sampler from \"../render/Sampler\";\r\nimport { Scene } from \"../Scene\";\r\nimport getVertFrag from \"../shader/Shaders\";\r\n\r\nexport class ShadowMapDebugger {\r\n\tprivate mesh: Mesh;\r\n\tprivate debuggerSize: { width: number; height: number };\r\n\tpublic light: Light;\r\n\tprivate geometry: Geometry;\r\n\tprivate material: ShaderMaterial;\r\n\tprivate scene: Scene;\r\n\r\n\tconstructor(light: Light, scene: Scene) {\r\n\t\tif (!light || !(light instanceof Light)) throw new Error(\"The parameter must be Light instance\");\r\n\r\n\t\tthis.light = light;\r\n\t\tthis.scene = scene;\r\n\t\tthis.debuggerSize = {\r\n\t\t\twidth: 256,\r\n\t\t\theight: 256\r\n\t\t};\r\n\r\n\t\tthis.mesh = this._createShadowMapMesh();\r\n\t\tconst shadowMap = this.light.shadow.getShadowMapTexture();\r\n\t\tthis.material.uniforms.texture.value = shadowMap;\r\n\t\tthis.mesh.type = RenderObjectType.Debug;\r\n\t\tthis.scene.add(this.mesh);\r\n\t}\r\n\r\n\t_createShadowMapMesh() {\r\n\t\tconst shader = getVertFrag(\"shadowMapDebugger\", {\r\n\t\t\tpositionLocation: 0\r\n\t\t});\r\n\t\tthis.geometry = new PlaneGeometry(2, 2);\r\n\t\tthis.material = new ShaderMaterial({\r\n\t\t\ttype: \"shadowMapDebugger\",\r\n\t\t\tfrag: shader.frag,\r\n\t\t\tvert: shader.vert,\r\n\t\t\tuniforms: {\r\n\t\t\t\ttexture: {\r\n\t\t\t\t\ttype: \"texture\",\r\n\t\t\t\t\tvalue: undefined\r\n\t\t\t\t},\r\n\t\t\t\tsampler: {\r\n\t\t\t\t\ttype: \"sampler\",\r\n\t\t\t\t\tvalue: new Sampler({\r\n\t\t\t\t\t\tmagFilter: \"linear\",\r\n\t\t\t\t\t\tminFilter: \"linear\"\r\n\t\t\t\t\t})\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t});\r\n\t\tthis.material.renderState.viewport = new ViewPort(0, 0, this.debuggerSize.width, this.debuggerSize.height);\r\n\t\treturn new Mesh(this.geometry, this.material);\r\n\t}\r\n\r\n\tsetSize(width: number, height: number) {\r\n\t\tif (!width || !height) return;\r\n\t\tthis.debuggerSize.width = width;\r\n\t\tthis.debuggerSize.height = height;\r\n\t\tthis.update();\r\n\t}\r\n\r\n\tupdate() {\r\n\t\tthis.material.renderState.viewport = new ViewPort(0, 0, this.debuggerSize.width, this.debuggerSize.height);\r\n\t}\r\n}\r\n","import { FrameState } from \"../core/FrameState\";\nimport { UniformEnum } from \"../core/WebGPUTypes\";\nimport { Mesh } from \"../mesh/Mesh\";\nimport UniformBuffer from \"../render/UniformBuffer\";\nimport { ShaderSource } from \"../shader/ShaderSource\";\nimport { Material } from \"./Material\";\nexport default class ColorMaterial extends Material {\n\tconstructor() {\n\t\tsuper();\n\t\tthis.type = \"color\";\n\t\tthis.shaderSource = new ShaderSource({\n\t\t\tshaderId: this.type,\n\t\t\tdefines: {}\n\t\t});\n\t}\n\tupdate(frameState?: FrameState, mesh?: Mesh) {\n\t\tif (!this.shaderData || this.dirty) this.createShaderData();\n\t\tconst uniformBuffer = new UniformBuffer({ label: \"color\" });\n\t\tuniformBuffer.setUniform(\n\t\t\t\"modelMatrix\",\n\t\t\t() => {\n\t\t\t\treturn mesh.modelMatrix;\n\t\t\t},\n\t\t\tUniformEnum.Mat4\n\t\t);\n\t\tthis.shaderData.setUniformBuffer(\"color\", uniformBuffer);\n\t}\n}\n","import { FrameState } from \"../core/FrameState\";\r\nimport { RenderObjectType } from \"../core/WebGPUTypes\";\r\nimport Geometry from \"../geometry/Geometry\";\r\nimport ColorMaterial from \"../material/ColorMaterial\";\r\nimport { Float32Attribute } from \"../render/Attribute\";\r\nimport { Mesh } from \"./Mesh\";\r\nexport default class Axes extends Mesh {\r\n\tmaterial: ColorMaterial;\r\n\tconstructor() {\r\n\t\tsuper();\r\n\t\tthis.type = RenderObjectType.Axes;\r\n\t\tthis.distanceToCamera = 10;\r\n\t\tthis.material = new ColorMaterial();\r\n\t\tthis.material.wireframe = true;\r\n\t\tthis.init();\r\n\t}\r\n\tupdate(frameState: FrameState) {\r\n\t\tthis.updateMatrix();\r\n\t\tthis.material.update(frameState, this);\r\n\t\tframeState.renderQueue.opaque.push(this);\r\n\t}\r\n\tprivate init() {\r\n\t\tconst position = [0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1];\r\n\t\tconst colors = [1, 0, 0, 1, 1, 0.5, 0.5, 1, 0, 1, 0, 1, 0.5, 1, 0.5, 1, 0, 0, 1, 1, 0.5, 0.5, 1, 1];\r\n\t\tconst indices = [0, 1, 2, 3, 4, 5];\r\n\t\tthis.geometry = new Geometry({});\r\n\t\tthis.geometry.setAttribute(new Float32Attribute(\"position\", position, 3));\r\n\t\tthis.geometry.setAttribute(new Float32Attribute(\"color\", colors, 4));\r\n\t\tthis.geometry.setIndice(indices);\r\n\t\tthis.geometry.count = indices.length;\r\n\t}\r\n}\r\n","import { Float32Attribute } from \"../render/Attribute\";\nimport Geometry from \"./Geometry\";\nexport default class SkyBoxGeometry extends Geometry {\n\tconstructor() {\n\t\tsuper({\n\t\t\ttype: \"skyBoxGeometry\"\n\t\t});\n\t\tthis.init();\n\t}\n\tpublic init() {\n\t\tconst positions = [\n\t\t\t1.0,\n\t\t\t1.0,\n\t\t\t1.0, // 0\n\t\t\t-1.0,\n\t\t\t1.0,\n\t\t\t1.0, // 1\n\t\t\t1.0,\n\t\t\t-1.0,\n\t\t\t1.0, // 2\n\t\t\t-1.0,\n\t\t\t-1.0,\n\t\t\t1.0, // 3\n\t\t\t1.0,\n\t\t\t1.0,\n\t\t\t-1.0, // 4\n\t\t\t-1.0,\n\t\t\t1.0,\n\t\t\t-1.0, // 5\n\t\t\t1.0,\n\t\t\t-1.0,\n\t\t\t-1.0, // 6\n\t\t\t-1.0,\n\t\t\t-1.0,\n\t\t\t-1.0 // 7\n\t\t];\n\t\tconst indices = [\n\t\t\t// PosX (Right)\n\t\t\t0, 2, 4, 6, 4, 2,\n\n\t\t\t// NegX (Left)\n\t\t\t5, 3, 1, 3, 5, 7,\n\n\t\t\t// PosY (Top)\n\t\t\t4, 1, 0, 1, 4, 5,\n\n\t\t\t// NegY (Bottom)\n\t\t\t2, 3, 6, 7, 6, 3,\n\n\t\t\t// PosZ (Front)\n\t\t\t0, 1, 2, 3, 2, 1,\n\n\t\t\t// NegZ (Back)\n\t\t\t6, 5, 4, 5, 6, 7\n\t\t];\n\t\tthis.setAttribute(new Float32Attribute(\"position\", positions, 3));\n\t\tthis.setIndice(indices);\n\t\tthis.count = indices.length;\n\t}\n}\n","function returnTrue() {\r\n\treturn true;\r\n}\r\nexport function destroyObject(object) {\r\n\t// message =message||\"This object was destroyed, i.e., destroy() was called.\";\r\n\r\n\tfunction throwOnDestroyed() {\r\n\t\tthrow new Error(\"This object was destroyed, i.e., destroy() was called.\");\r\n\t}\r\n\r\n\tfor (const key in object) {\r\n\t\tif (typeof object[key] === \"function\") {\r\n\t\t\tobject[key] = throwOnDestroyed;\r\n\t\t}\r\n\t}\r\n\r\n\tobject.isDestroyed = returnTrue;\r\n\r\n\treturn undefined;\r\n}\r\n","import Sampler from \"../render/Sampler\";\nimport Texture from \"../render/Texture\";\nimport defined from \"../utils/defined\";\nimport { destroyObject } from \"../utils/destroyObject\";\ntype TextureCacheProp = {\n\ttexture: Texture;\n\tcount: number;\n};\nclass TextureCache {\n\tpublic defaultSampler: Sampler;\n\tprivate _numberOfTextures: number;\n\tprivate _textures: Map<string, TextureCacheProp>;\n\tprivate _texturesToRelease: Map<string, TextureCacheProp>;\n\tconstructor() {\n\t\tthis._numberOfTextures = 0;\n\t\tthis._textures = new Map();\n\t\tthis._numberOfTextures = 0;\n\t\tthis._texturesToRelease = new Map();\n\t\tthis.defaultSampler = new Sampler({\n\t\t\tmagFilter: \"linear\",\n\t\t\tminFilter: \"linear\",\n\t\t\taddressModeU: \"repeat\",\n\t\t\taddressModeV: \"repeat\"\n\t\t});\n\t}\n\tget numberOfTextures(): number {\n\t\treturn this._numberOfTextures;\n\t}\n\tgetTexture(keyword) {\n\t\tconst cachedTexture = this._textures.get(keyword);\n\t\tif (!defined(cachedTexture)) {\n\t\t\treturn undefined;\n\t\t}\n\t\t// No longer want to release this if it was previously released.\n\t\tdelete this._texturesToRelease[keyword];\n\n\t\t++cachedTexture.count;\n\t\treturn cachedTexture.texture;\n\t}\n\taddTexture(keyword, texture) {\n\t\tconst cachedTexture = {\n\t\t\ttexture: texture,\n\t\t\tcount: 1\n\t\t};\n\n\t\ttexture.finalDestroy = texture.destroy;\n\n\t\t// const that = this;\n\t\ttexture.destroy = () => {\n\t\t\tif (--cachedTexture.count === 0) {\n\t\t\t\tthis._texturesToRelease.set(keyword, cachedTexture);\n\t\t\t}\n\t\t};\n\n\t\tthis._textures.set(keyword, cachedTexture);\n\t\t++this._numberOfTextures;\n\t}\n\treleasedTextures() {\n\t\tthis._texturesToRelease.forEach((cacheTexture) => {\n\t\t\tcacheTexture.texture?.finalDestroy();\n\t\t\t--this._numberOfTextures;\n\t\t});\n\n\t\tthis._texturesToRelease.clear();\n\t}\n\tdestroy() {\n\t\tthis._textures.forEach((cachedTexture) => {\n\t\t\tcachedTexture.texture?.finalDestroy();\n\t\t});\n\t\treturn destroyObject(this);\n\t}\n}\nconst textureCache = new TextureCache();\nexport default textureCache;\n","import Sampler from \"../render/Sampler\";\nimport Texture from \"../render/Texture\";\n\nexport default async function CubeTextureLoader(urls) {\n\tconst promises = urls.map((src) => {\n\t\tconst img = document.createElement(\"img\");\n\t\timg.src = src;\n\t\treturn img.decode().then(() => createImageBitmap(img));\n\t});\n\tconst images = await Promise.all(promises);\n\tawait Promise.all(images);\n\tconst baseSampler = new Sampler({\n\t\tmagFilter: \"linear\",\n\t\tminFilter: \"linear\"\n\t});\n\tconst data = images.map((image, i) => {\n\t\treturn {\n\t\t\tsource: image,\n\t\t\twidth: image.width,\n\t\t\theight: image.height,\n\t\t\tdepth: 1,\n\t\t\tx: 0,\n\t\t\ty: 0,\n\t\t\tz: i\n\t\t};\n\t});\n\tconst baseTexture = new Texture({\n\t\tsize: {\n\t\t\twidth: images[0].width,\n\t\t\theight: images[0].height,\n\t\t\tdepth: 6\n\t\t},\n\t\tformat: \"rgba8unorm\",\n\t\tusage: GPUTextureUsage.TEXTURE_BINDING | GPUTextureUsage.COPY_DST | GPUTextureUsage.RENDER_ATTACHMENT,\n\t\tdata,\n\t\tviewFormats: \"cube\",\n\t\tmipLevelCount: 6,\n\t\tneedMipMap: true\n\t});\n\treturn {\n\t\ttexture: baseTexture,\n\t\tsampler: baseSampler\n\t};\n}\n","import { FrameState } from \"../core/FrameState\";\nimport textureCache from \"../core/TextureCache\";\nimport { CompareFunction } from \"../core/WebGPUConstant\";\nimport { UniformEnum } from \"../core/WebGPUTypes\";\nimport CubeTextureLoader from \"../loader/CubeTextureLoader\";\nimport { Mesh } from \"../mesh/Mesh\";\nimport UniformBuffer from \"../render/UniformBuffer\";\nimport { ShaderSource } from \"../shader/ShaderSource\";\nimport { Material } from \"./Material\";\nexport default class SkyBoxMaterial extends Material {\n\tloadFish: boolean;\n\tconstructor() {\n\t\tsuper();\n\t\tthis.type = \"skybox\";\n\t\tthis.shaderSource = new ShaderSource({\n\t\t\tshaderId: this.type,\n\t\t\tdefines: {}\n\t\t});\n\t\tthis.loadFish = false;\n\t\tthis.renderState.depthStencil.depthWriteEnabled = false;\n\t\tthis.renderState.depthStencil.depthCompare = CompareFunction.LessEqual;\n\t}\n\tasync loadTexture(urls) {\n\t\tconst result = await CubeTextureLoader(urls);\n\t\tthis.loadFish = true;\n\t\ttextureCache.addTexture(\"specular\", result.texture);\n\t\tthis.baseTexture = result.texture;\n\t\tthis.baseSampler = result.sampler;\n\t}\n\tupdate(frameState?: FrameState, mesh?: Mesh) {\n\t\tif (!this.loadFish) return;\n\t\tif (!this.shaderData) {\n\t\t\tthis.createShaderData(mesh);\n\t\t}\n\t}\n\tprotected createShaderData(mesh?: Mesh) {\n\t\tsuper.createShaderData();\n\t\tconst uniformBuffer = new UniformBuffer({ label: \"skybox\" });\n\t\tuniformBuffer.setUniform(\n\t\t\t\"modelMatrix\",\n\t\t\t() => {\n\t\t\t\treturn mesh.modelMatrix;\n\t\t\t},\n\t\t\tUniformEnum.Mat4\n\t\t);\n\t\tthis.shaderData.setUniformBuffer(\"skybox\", uniformBuffer);\n\t\tthis.shaderData.setTexture(\"baseTexture\", this.baseTexture);\n\t\tthis.shaderData.setSampler(\"baseSampler\", this.baseSampler);\n\t}\n}\n","import { FrameState } from \"../core/FrameState\";\r\nimport { RenderObjectType } from \"../core/WebGPUTypes\";\r\nimport SkyBoxGeometry from \"../geometry/SkyBoxGeometry\";\r\nimport SkyBoxMaterial from \"../material/SkyBoxMaterial\";\r\nimport { Mesh } from \"./Mesh\";\r\nexport default class SkyBox extends Mesh {\r\n\tmaterial: SkyBoxMaterial;\r\n\tpublic visibility: boolean;\r\n\tconstructor(urls?: Array<string>) {\r\n\t\tsuper();\r\n\t\tthis.type = RenderObjectType.Skybox;\r\n\t\tthis.visibility = true;\r\n\t\tthis.material = new SkyBoxMaterial();\r\n\t\tif (urls) this.material.loadTexture(urls);\r\n\t\tthis.geometry = new SkyBoxGeometry();\r\n\t\tthis.isSkyBox = true;\r\n\t}\r\n\tupdate(frameState: FrameState) {\r\n\t\tthis.updateMatrix();\r\n\t\tthis.geometry.update(frameState);\r\n\t\tthis.material.update(frameState, this);\r\n\t\tif (this.visibility) frameState.renderQueue.pre.push(this);\r\n\t}\r\n}\r\n","import RenderObject from \"../core/RenderObject\";\nimport Matrix4 from \"../math/Matrix4\";\nimport createGuid from \"../utils/createGuid\";\n\nexport class Instance extends RenderObject {\n\tpublic id: string | number;\n\tpublic visiblity: boolean;\n\tprivate _notUpdateMatrix: boolean;\n\tconstructor() {\n\t\tsuper();\n\t\tthis._notUpdateMatrix = false;\n\t\tthis.visiblity = false;\n\t\tthis.id = createGuid();\n\t}\n\tsetMatrix4(mat4: Matrix4) {\n\t\tthis.modelMatrix.set(mat4);\n\t\tthis._notUpdateMatrix = true;\n\t}\n\tupdateMatrix(matrix?: Matrix4) {\n\t\tif (this._notUpdateMatrix) return;\n\t\tsuper.updateMatrix(matrix);\n\t}\n}\n","import Camera from \"../camera/Camera\";\nimport { FrameState } from \"../core/FrameState\";\nimport { BufferBindingType, BufferUsage, Intersect } from \"../core/WebGPUConstant\";\nimport { UniformEnum } from \"../core/WebGPUTypes\";\nimport Geometry from \"../geometry/Geometry\";\nimport { Material } from \"../material/Material\";\nimport UniformBuffer from \"../render/UniformBuffer\";\nimport { Instance } from \"./Instance\";\nimport { Mesh } from \"./Mesh\";\n\nexport class InstanceMesh extends Mesh {\n\tprivate instances: Map<string | number, Instance>;\n\tprivate renderInstances: Array<Instance>;\n\tprivate hasAddInstances: boolean;\n\tconstructor(geo: Geometry, mat: Material) {\n\t\tsuper(geo, mat);\n\t\tthis.instances = new Map();\n\t\tthis.renderInstances = [];\n\t\tthis.hasAddInstances = false;\n\t}\n\tupdate(frameState: FrameState, camera?: Camera) {\n\t\t// update instances visiblity\n\t\tthis.checkInstancesVisiblity({ frameState, camera });\n\t\tthis.geometry.update(frameState);\n\t\tthis.material.update(frameState, this);\n\t\tif (!this.hasAddInstances) this.addUniformsToMaterial();\n\t\tthis.instanceCount = this.renderInstances.length;\n\t\tif (this.renderInstances.length < 1) return;\n\t\tif (this.material.transparent) {\n\t\t\tframeState.renderQueue.transparent.push(this);\n\t\t} else {\n\t\t\tframeState.renderQueue.opaque.push(this);\n\t\t}\n\t}\n\taddInstance(instance: Instance) {\n\t\tif (this.instances.get(instance.id)) return;\n\t\tthis.instances.set(instance.id, instance);\n\t}\n\tremoveInstance(key: number | string) {\n\t\treturn this.instances.delete(key);\n\t}\n\tgetInstance(key: number | string) {\n\t\treturn this.instances.get(key);\n\t}\n\tprivate checkInstancesVisiblity(options: { frameState: FrameState; camera: Camera }) {\n\t\tconst { frameState, camera } = options;\n\t\tconst preFrameInstanceCount = this.renderInstances.length;\n\t\tthis.renderInstances = [];\n\t\tthis.instances.forEach((instance: Instance) => {\n\t\t\tinstance.updateMatrix(this?.parent?.modelMatrix);\n\t\t\tinstance.visiblity = this.getInstanceVisiblity({ instance, frameState, camera });\n\t\t\tif (instance.visiblity) this.renderInstances.push(instance);\n\t\t});\n\t\tthis.material.dirty = this.renderInstances.length === preFrameInstanceCount;\n\t\t// rebuild instanceMatrixsBuffer\n\t\tif (this.material.dirty) this.hasAddInstances = false;\n\t}\n\tprivate getInstanceVisiblity(options: { instance: Instance; frameState: FrameState; camera: Camera }): boolean {\n\t\tconst { instance, frameState, camera } = options;\n\t\tthis.geometry.boundingSphere.update(instance.modelMatrix);\n\t\tthis.distanceToCamera = this.geometry.boundingSphere.distanceToCamera(camera);\n\t\tconst visibility = frameState.cullingVolume.computeVisibility(this.geometry.boundingSphere);\n\t\treturn visibility === Intersect.INTERSECTING || visibility === Intersect.INSIDE;\n\t}\n\tprivate addUniformsToMaterial() {\n\t\tif (!this.material.shaderData) return;\n\t\tthis.hasAddInstances = true;\n\t\tconst instanceMatrixsBuffer = new UniformBuffer({\n\t\t\tlabel: \"instanceMatrixsBuffer\",\n\t\t\ttype: BufferBindingType.ReadOnlyStorage,\n\t\t\tusage: BufferUsage.Storage | BufferUsage.CopyDst,\n\t\t\tsize: this.instances.size * 64\n\t\t});\n\t\tinstanceMatrixsBuffer.setUniform(\n\t\t\t\"instanceMatrixs\",\n\t\t\t() => {\n\t\t\t\treturn this?.renderInstances?.map((renderInstance: Instance) => renderInstance.modelMatrix);\n\t\t\t},\n\t\t\tUniformEnum.Mat4Array,\n\t\t\tthis?.renderInstances?.length\n\t\t);\n\t\tthis.material.shaderData.setUniformBuffer(\"instanceMatrixsBuffer\", instanceMatrixsBuffer);\n\t\tthis.material.shaderData.setDefine(\"USE_INSTANCE\", true);\n\t\tthis.material.shaderData.setDefine(\"instanceCount\", this?.renderInstances?.length);\n\t}\n}\n","import { ShaderSource } from \"../shader/ShaderSource\";\nimport { Command } from \"./Command\";\nimport Pipeline from \"./Pipeline\";\nimport ShaderData from \"./ShaderData\";\n\nexport class ComputeCommand implements Command {\n\tpublic dispatch?: { x?: number; y?: number; z?: number };\n\tpublic shaderSource?: ShaderSource;\n\tpublic shaderData?: ShaderData;\n\tconstructor(options: ComputeCommandType) {\n\t\tthis.dispatch = options.dispatch;\n\t\tthis.shaderData = options.shaderData;\n\t\tthis.shaderSource = options.shaderSource;\n\t}\n\trender(params?: ComputeParams): void {\n\t\tconst { device, passEncoder } = params;\n\t\tthis.shaderData?.bind?.(device, passEncoder);\n\t\tconst pipeline = Pipeline.getComputePipelineFromCache(device, this, [this.shaderData.groupLayout]);\n\t\tpipeline.bind(passEncoder);\n\t\tconst { x, y, z } = this.dispatch;\n\t\tpassEncoder.dispatchWorkgroups(x, y, z);\n\t}\n}\ntype ComputeCommandType = {\n\tdispatch?: { x?: number; y?: number; z?: number };\n\n\tshaderSource?: ShaderSource;\n\n\tshaderData?: ShaderData;\n};\ntype ComputeParams = {\n\tdevice?: GPUDevice;\n\tpassEncoder?: GPUComputePassEncoder;\n};\n","import {\n\tBufferBindingType,\n\tBufferUsage,\n\tCullMode,\n\tFrontFace,\n\tInputStepMode,\n\tPrimitiveTopology\n} from \"../core/WebGPUConstant\";\nimport { ModelParams } from \"../core/WebGPUTypes\";\nimport { BufferFloat32Attribute, Float32Attribute, InterleavedFloat32Attribute } from \"../render/Attribute\";\nimport { ComputeCommand } from \"../render/ComputeCommand\";\nimport DrawCommand from \"../render/DrawCommand\";\nimport IndexBuffer from \"../render/IndexBuffer\";\nimport {\n\tBlendConstant,\n\tDepthStencil,\n\tDepthStencilProps,\n\tMultiSample,\n\tPrimitive,\n\tRenderState,\n\tScissorTest,\n\tTarget,\n\tViewPort\n} from \"../render/RenderState\";\nimport ShaderData from \"../render/ShaderData\";\nimport Texture from \"../render/Texture\";\nimport UniformBuffer from \"../render/UniformBuffer\";\nimport VertexBuffer from \"../render/VertexBuffer\";\nimport { ShaderSource } from \"../shader/ShaderSource\";\nimport { addUniformToShaderData } from \"../utils/uniformUtils\";\n\nexport class Model {\n\tpublic modelParams: ModelParams;\n\tpublic command: DrawCommand | ComputeCommand;\n\tpublic renderType: string;\n\tprivate vertexBuffers: Map<string, VertexBuffer>;\n\tprivate shaderData: ShaderData;\n\tconstructor(params: ModelParams) {\n\t\tthis.modelParams = params;\n\t\tthis.renderType = this.modelParams.compute != undefined ? \"compute\" : \"render\";\n\t\tthis.vertexBuffers = new Map();\n\t}\n\trender(params: renderModelParams) {\n\t\tconst { device, passEncoder } = params;\n\t\tif (!this.command)\n\t\t\tthis.command = this.renderType === \"render\" ? this.createDrawCommand() : this.createComputeCommand();\n\t\tif (this.renderType === \"render\") {\n\t\t\t(this.command as DrawCommand).render({\n\t\t\t\tdevice,\n\t\t\t\tpassEncoder: <GPURenderPassEncoder>passEncoder\n\t\t\t});\n\t\t} else {\n\t\t\t(this.command as ComputeCommand).render({\n\t\t\t\tdevice,\n\t\t\t\tpassEncoder: <GPUComputePassEncoder>passEncoder\n\t\t\t});\n\t\t}\n\t}\n\tcompute(params: renderModelParams) {\n\t\tconst { device, passEncoder } = params;\n\t\tif (!this.command) this.command = this.createComputeCommand();\n\t\t(this.command as ComputeCommand).render({\n\t\t\tdevice,\n\t\t\tpassEncoder: <GPUComputePassEncoder>passEncoder\n\t\t});\n\t}\n\tpublic getVertexBufferByUid(uid: string): VertexBuffer {\n\t\treturn this.vertexBuffers.get(uid);\n\t}\n\tpublic getUniformBufferByUid(uid: string): UniformBuffer {\n\t\treturn this.shaderData.getUniformBuffer(uid);\n\t}\n\tpublic getTextureByName(name: string): Texture {\n\t\treturn this.shaderData.getTexture(name);\n\t}\n\tpublic getSamplerByName(name: string) {\n\t\treturn this.shaderData.getSampler(name);\n\t}\n\tpublic destroy() {\n\t\tthis?.vertexBuffers.clear();\n\t\tthis?.shaderData.destroy();\n\t\tthis.command = null;\n\t\tthis.modelParams = null;\n\t}\n\tprivate createDrawCommand() {\n\t\tconst { count, instances } = this.modelParams;\n\t\tconst vertexBuffers = this.createVertexBuffer();\n\t\tthis.shaderData = this.createShaderData();\n\t\tconst indexBuffer = this.createIndexBuffer();\n\t\tconst shaderSource = this.createShaderSource();\n\t\tconst renderState = this.createRenderState();\n\t\treturn new DrawCommand({\n\t\t\tvertexBuffers,\n\t\t\tshaderData: this.shaderData,\n\t\t\tindexBuffer,\n\t\t\tshaderSource,\n\t\t\trenderState,\n\t\t\tcount,\n\t\t\tinstances\n\t\t});\n\t}\n\tprivate createComputeCommand() {\n\t\tconst { dispatch } = this.modelParams;\n\t\tconst shaderData = this.createShaderData();\n\t\tconst shaderSource = this.createShaderSource();\n\t\treturn new ComputeCommand({\n\t\t\tdispatch,\n\t\t\tshaderData,\n\t\t\tshaderSource\n\t\t});\n\t}\n\tprivate createVertexBuffer() {\n\t\tconst { vertexBuffers, shaderId } = this.modelParams;\n\t\tlet locationIndex = 0;\n\t\treturn (\n\t\t\tvertexBuffers?.map((vertexBufferObject, index) => {\n\t\t\t\tconst { attributes, stepMode, uid, arrayStride } = vertexBufferObject;\n\t\t\t\tconst vertexBuffer = new VertexBuffer({\n\t\t\t\t\tlabel: shaderId,\n\t\t\t\t\tindex,\n\t\t\t\t\tlocationIndex,\n\t\t\t\t\tstepMode: <InputStepMode>stepMode,\n\t\t\t\t\tarrayStride\n\t\t\t\t});\n\t\t\t\tconst attributeKeys = Object.keys(attributes);\n\t\t\t\tattributeKeys.forEach((key: string) => {\n\t\t\t\t\tconst { size, value, names, itemSizes, buffer } = attributes[key];\n\t\t\t\t\tvertexBuffer.setAttribute(\n\t\t\t\t\t\tnames?.length > 0\n\t\t\t\t\t\t\t? buffer\n\t\t\t\t\t\t\t\t? new BufferFloat32Attribute(names, buffer, itemSizes)\n\t\t\t\t\t\t\t\t: new InterleavedFloat32Attribute(names, value, itemSizes)\n\t\t\t\t\t\t\t: new Float32Attribute(key, value, size)\n\t\t\t\t\t);\n\t\t\t\t\tconst count = names?.length > 0 ? names?.length : 1;\n\t\t\t\t\tlocationIndex += count;\n\t\t\t\t});\n\t\t\t\tthis.vertexBuffers.set(uid, vertexBuffer);\n\t\t\t\treturn vertexBuffer;\n\t\t\t}) || []\n\t\t);\n\t}\n\tprivate createShaderSource() {\n\t\tconst { vert, frag, compute, shaderId } = this.modelParams;\n\t\treturn new ShaderSource({\n\t\t\tshaderId,\n\t\t\trender: {\n\t\t\t\tvertShader: vert,\n\t\t\t\tfragShader: frag\n\t\t\t},\n\t\t\tcompute: {\n\t\t\t\tcomputeShader: compute\n\t\t\t}\n\t\t});\n\t}\n\tprivate createShaderData() {\n\t\tconst { shaderId, uniformBuffers, uniformTextureAndSampler } = this.modelParams;\n\t\tconst shaderData = new ShaderData(shaderId);\n\t\t// fill uniformBuffer\n\t\tuniformBuffers.forEach((uniformBuffer) => this.createUniformBuffer(uniformBuffer, shaderData, shaderId));\n\t\t// fill texture and sampler\n\t\tthis.addUniformToShaderData(uniformTextureAndSampler, shaderData, undefined);\n\t\treturn shaderData;\n\t}\n\tprivate createRenderState() {\n\t\tconst {\n\t\t\tblendConstant,\n\t\t\tdepthStencil,\n\t\t\tviewPort,\n\t\t\tscissorTest,\n\t\t\ttargets,\n\t\t\tmultiSample,\n\t\t\tprimitive,\n\t\t\tstencilReference\n\t\t} = this.modelParams.renderState;\n\t\treturn new RenderState({\n\t\t\tscissorTest: scissorTest\n\t\t\t\t? new ScissorTest(scissorTest.x, scissorTest.y, scissorTest.width, scissorTest.height)\n\t\t\t\t: undefined,\n\t\t\tviewport: viewPort ? new ViewPort(viewPort.x, viewPort.y, viewPort.width, viewPort.height) : undefined,\n\t\t\ttargets: targets?.map((target) => {\n\t\t\t\treturn new Target(target as any);\n\t\t\t}),\n\t\t\tdepthStencil: depthStencil ? new DepthStencil(<DepthStencilProps>depthStencil) : undefined,\n\t\t\tblendConstant: blendConstant\n\t\t\t\t? new BlendConstant(blendConstant.r, blendConstant.g, blendConstant.b, blendConstant.a)\n\t\t\t\t: undefined,\n\t\t\tstencilReference: stencilReference || 0,\n\t\t\tmultisample: multiSample\n\t\t\t\t? new MultiSample(multiSample.count, multiSample.mask, multiSample.alphaToCoverageEnabled)\n\t\t\t\t: undefined,\n\t\t\tprimitive: primitive\n\t\t\t\t? new Primitive(\n\t\t\t\t\t\t<PrimitiveTopology>primitive.topology,\n\t\t\t\t\t\t<CullMode>primitive.cullMode,\n\t\t\t\t\t\t<FrontFace>primitive.frontFace,\n\t\t\t\t\t\tprimitive.unclippedDepth\n\t\t\t\t  )\n\t\t\t\t: undefined,\n\t\t\tstencilEnabled: false,\n\t\t\tscissorTestEnabled: false\n\t\t});\n\t}\n\tprivate createIndexBuffer() {\n\t\tconst { indices, shaderId } = this.modelParams;\n\t\tlet indexBuffer = undefined;\n\t\tif (indices) {\n\t\t\tindexBuffer = new IndexBuffer(shaderId + \"IndexBuffer\");\n\t\t\tindexBuffer.setIndices(indices);\n\t\t}\n\n\t\treturn indexBuffer;\n\t}\n\tprivate createUniformBuffer(uniformBufferParams, shaderData: ShaderData, shaderId: string) {\n\t\tconst {\n\t\t\ttype = \"uniform\",\n\t\t\tusage = BufferUsage.Uniform | BufferUsage.CopyDst,\n\t\t\tuniforms,\n\t\t\tuid,\n\t\t\tbinding,\n\t\t\tbuffer,\n\t\t\tbufferSize,\n\t\t\tvisibility\n\t\t} = uniformBufferParams;\n\t\tconst uniformBuffer = new UniformBuffer({\n\t\t\tlabel: uid + \"_UniformBuffer\",\n\t\t\ttype: <BufferBindingType>type,\n\t\t\tusage: <BufferUsage>usage,\n\t\t\tbinding,\n\t\t\tbuffer,\n\t\t\tvisibility,\n\t\t\tsize: buffer?.size ?? bufferSize\n\t\t});\n\t\tshaderData.setUniformBuffer(uid, uniformBuffer);\n\t\tif (!buffer) this.addUniformToShaderData(uniforms, shaderData, uniformBuffer);\n\t}\n\tprivate addUniformToShaderData(uniforms, shaderData: ShaderData, uniformBuffer: UniformBuffer) {\n\t\tif (!uniforms) return;\n\t\tconst uniformsNames = Object.getOwnPropertyNames(uniforms);\n\t\tuniformsNames.map((uniformsName) => {\n\t\t\taddUniformToShaderData(uniformsName, uniforms[uniformsName], shaderData, undefined, uniformBuffer);\n\t\t});\n\t}\n}\n\nexport type renderModelParams = {\n\tdevice: GPUDevice;\n\tpassEncoder: GPURenderPassEncoder | GPUComputePassEncoder;\n};\n","import { InterleavedFloat32Attribute } from \"../render/Attribute\";\nimport Geometry from \"./Geometry\";\nexport class SpriteGeometry extends Geometry {\n\tconstructor() {\n\t\tsuper({\n\t\t\ttype: \"spriteGeometry\"\n\t\t});\n\t\tthis.init();\n\t}\n\tprivate init() {\n\t\t// xyz、uv\n\t\tconst vertices = [-0.5, -0.5, 0, 0, 0, 0.5, -0.5, 0, 1, 0, 0.5, 0.5, 0, 1, 1, -0.5, 0.5, 0, 0, 1];\n\t\tconst indices = [0, 1, 2, 0, 2, 3];\n\t\tthis.computeBoundingSphere(vertices, 5);\n\t\tthis.setAttribute(new InterleavedFloat32Attribute([\"position\", \"uv\"], vertices, [3, 2]));\n\t\tthis.setIndice(indices);\n\t\tthis.count = indices.length;\n\t}\n}\n","import { FrameState } from \"../core/FrameState\";\nimport textureCache from \"../core/TextureCache\";\nimport { UniformEnum } from \"../core/WebGPUTypes\";\nimport Color from \"../math/Color\";\nimport Vector2 from \"../math/Vector2\";\nimport { Mesh } from \"../mesh/Mesh\";\nimport UniformBuffer from \"../render/UniformBuffer\";\nimport { ShaderSource } from \"../shader/ShaderSource\";\nimport { Material } from \"./Material\";\n\nexport class SpriteMaterial extends Material {\n\tpublic rotation: number;\n\tpublic center: Vector2;\n\tconstructor() {\n\t\tsuper();\n\t\tthis.type = \"sprite\";\n\t\tthis.shaderSource = new ShaderSource({\n\t\t\tshaderId: this.type,\n\t\t\tdefines: {\n\t\t\t\tHAS_UV: true\n\t\t\t}\n\t\t});\n\t\tthis.rotation = Math.PI;\n\t\tthis.opacity = 1;\n\t\tthis.center = new Vector2(0, 0);\n\t\tthis.color = new Color(1, 0, 0);\n\t}\n\tupdate(frameState?: FrameState, mesh?: Mesh) {\n\t\tif (!this.shaderData || this.dirty) this.createShaderData(mesh);\n\t}\n\tprotected createShaderData(mesh?: Mesh) {\n\t\tsuper.createShaderData();\n\t\tconst uniformBuffer = new UniformBuffer({ label: \"sprite\" });\n\t\tuniformBuffer.setUniform(\n\t\t\t\"modelMatrix\",\n\t\t\t() => {\n\t\t\t\treturn mesh.modelMatrix;\n\t\t\t},\n\t\t\tUniformEnum.Mat4\n\t\t);\n\t\tuniformBuffer.setUniform(\"color\", this, UniformEnum.Color);\n\t\tuniformBuffer.setUniform(\"rotation\", this, UniformEnum.Float);\n\t\tuniformBuffer.setUniform(\"center\", this, UniformEnum.FloatVec2);\n\t\tuniformBuffer.setUniform(\"opacity\", this, UniformEnum.Float);\n\t\tthis.shaderData.setUniformBuffer(\"sprite\", uniformBuffer);\n\t\tif (this.baseTexture) {\n\t\t\tthis.shaderData.setDefine(\"USE_COLORTEXTURE\", true);\n\t\t\tthis.shaderData.setTexture(\"baseColorTexture\", this.baseTexture);\n\t\t\tthis.shaderData.setSampler(\"baseColorSampler\", this.baseSampler || textureCache.defaultSampler);\n\t\t}\n\t}\n\tdestroy() {\n\t\tthis?.baseTexture?.destroy();\n\t\tsuper.destroy();\n\t}\n}\n","import { SpriteGeometry } from \"../geometry/SpriteGeometry\";\nimport { SpriteMaterial } from \"../material/SpriteMaterial\";\nimport Sampler from \"../render/Sampler\";\nimport Texture from \"../render/Texture\";\nimport { Mesh } from \"./Mesh\";\n\nexport class Sprite extends Mesh {\n\tconstructor() {\n\t\tsuper();\n\t\tthis.material = new SpriteMaterial();\n\t\tthis.geometry = new SpriteGeometry();\n\t}\n\tsetTexture(texture: Texture) {\n\t\tthis.material.baseTexture = texture;\n\t}\n\tsetSampler(sampler: Sampler) {\n\t\tthis.material.baseSampler = sampler;\n\t}\n}\n","/**\r\n * Ensure first argument passed to the primitive functions is an object\r\n * @param {...*} args\r\n */\r\nfunction checkArguments(args) {\r\n\tconst argumentType = typeof args[0];\r\n\tif (argumentType !== \"object\" && argumentType !== \"undefined\") {\r\n\t\tconsole.error(\"First argument must be an object.\");\r\n\t}\r\n}\r\n\r\n/**\r\n * @private\r\n */\r\nlet TYPED_ARRAY_TYPE;\r\n\r\n/**\r\n * Select cells typed array from a size determined by amount of vertices.\r\n *\r\n * @param {number} size The max value expected\r\n * @returns {(Uint8Array|Uint16Array|Uint32Array)}\r\n * @see [MDN TypedArray objects]{@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/TypedArray#typedarray_objects}\r\n */\r\nconst getCellsTypedArray = (size) =>\r\n\tTYPED_ARRAY_TYPE || (size <= 255 ? Uint8Array : size <= 65535 ? Uint16Array : Uint32Array);\r\n\r\n/**\r\n * @private\r\n */\r\nconst PLANE_DIRECTIONS = {\r\n\tz: [0, 1, 2, 1, -1, 1],\r\n\t\"-z\": [0, 1, 2, -1, -1, -1],\r\n\t\"-x\": [2, 1, 0, 1, -1, -1],\r\n\tx: [2, 1, 0, -1, -1, 1],\r\n\ty: [0, 2, 1, 1, 1, 1],\r\n\t\"-y\": [0, 2, 1, 1, -1, -1]\r\n};\r\n\r\n/**\r\n * @private\r\n */\r\nfunction computePlane(\r\n\tgeometry,\r\n\tindices,\r\n\tsu,\r\n\tsv,\r\n\tnu,\r\n\tnv,\r\n\tdirection = \"z\",\r\n\tpw = 0,\r\n\tquads = false,\r\n\tuvScale = [1, 1],\r\n\tuvOffset = [0, 0],\r\n\tcenter = [0, 0, 0],\r\n\tccw = true\r\n) {\r\n\tconst { positions, normals, uvs, cells } = geometry;\r\n\tconst [u, v, w, flipU, flipV, normal] = PLANE_DIRECTIONS[direction];\r\n\r\n\tconst vertexOffset = indices.vertex;\r\n\r\n\tfor (let j = 0; j <= nv; j++) {\r\n\t\tfor (let i = 0; i <= nu; i++) {\r\n\t\t\tpositions[indices.vertex * 3 + u] = (-su / 2 + (i * su) / nu) * flipU + center[u];\r\n\t\t\tpositions[indices.vertex * 3 + v] = (-sv / 2 + (j * sv) / nv) * flipV + center[v];\r\n\t\t\tpositions[indices.vertex * 3 + w] = pw + center[w];\r\n\r\n\t\t\tnormals[indices.vertex * 3 + w] = normal;\r\n\r\n\t\t\tuvs[indices.vertex * 2] = (i / nu) * uvScale[0] + uvOffset[0];\r\n\t\t\tuvs[indices.vertex * 2 + 1] = (1 - j / nv) * uvScale[1] + uvOffset[1];\r\n\r\n\t\t\tindices.vertex++;\r\n\r\n\t\t\tif (j < nv && i < nu) {\r\n\t\t\t\tconst n = vertexOffset + j * (nu + 1) + i;\r\n\t\t\t\tif (quads) {\r\n\t\t\t\t\tconst o = vertexOffset + (j + 1) * (nu + 1) + i;\r\n\t\t\t\t\tcells[indices.cell] = n;\r\n\t\t\t\t\tcells[indices.cell + 1] = o;\r\n\t\t\t\t\tcells[indices.cell + 2] = o + 1;\r\n\t\t\t\t\tcells[indices.cell + 3] = n + 1;\r\n\t\t\t\t} else {\r\n\t\t\t\t\tcells[indices.cell] = n;\r\n\t\t\t\t\tcells[indices.cell + (ccw ? 1 : 2)] = n + nu + 1;\r\n\t\t\t\t\tcells[indices.cell + (ccw ? 2 : 1)] = n + nu + 2;\r\n\r\n\t\t\t\t\tcells[indices.cell + 3] = n;\r\n\t\t\t\t\tcells[indices.cell + (ccw ? 4 : 5)] = n + nu + 2;\r\n\t\t\t\t\tcells[indices.cell + (ccw ? 5 : 4)] = n + 1;\r\n\t\t\t\t}\r\n\t\t\t\tindices.cell += quads ? 4 : 6;\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\treturn geometry;\r\n}\r\n/**\r\n * @typedef {Object} CubeOptions\r\n * @property {number} [sx=1]\r\n * @property {number} [sy=sx]\r\n * @property {number} [sz=sx]\r\n * @property {number} [nx=1]\r\n * @property {number} [ny=nx]\r\n * @property {number} [nz=nx]\r\n */\r\nexport function createCube({ sx = 1, sy = 1, sz = 1, nx = 1, ny = 1, nz = 1 } = {}) {\r\n\tcheckArguments(arguments);\r\n\r\n\tconst size = (nx + 1) * (ny + 1) * 2 + (nx + 1) * (nz + 1) * 2 + (nz + 1) * (ny + 1) * 2;\r\n\r\n\tconst geometry = {\r\n\t\tpositions: new Float32Array(size * 3),\r\n\t\tnormals: new Float32Array(size * 3),\r\n\t\tuvs: new Float32Array(size * 2),\r\n\t\tcells: new (getCellsTypedArray(size))((nx * ny * 2 + nx * nz * 2 + nz * ny * 2) * 6)\r\n\t};\r\n\r\n\tconst halfSX = sx * 0.5;\r\n\tconst halfSY = sy * 0.5;\r\n\tconst halfSZ = sz * 0.5;\r\n\r\n\tconst indices = { vertex: 0, cell: 0 };\r\n\r\n\tcomputePlane(geometry, indices, sx, sy, nx, ny, \"z\", halfSZ);\r\n\tcomputePlane(geometry, indices, sx, sy, nx, ny, \"-z\", -halfSZ);\r\n\tcomputePlane(geometry, indices, sz, sy, nz, ny, \"-x\", -halfSX);\r\n\tcomputePlane(geometry, indices, sz, sy, nz, ny, \"x\", halfSX);\r\n\tcomputePlane(geometry, indices, sx, sz, nx, nz, \"y\", halfSY);\r\n\tcomputePlane(geometry, indices, sx, sz, nx, nz, \"-y\", -halfSY);\r\n\r\n\treturn geometry;\r\n}\r\n\r\nexport function createBox(options) {\r\n\toptions = options || {};\r\n\r\n\tconst dimensions = options.dimensions || [1, 1, 1];\r\n\tconst position = options.position || [-dimensions[0] / 2, -dimensions[1] / 2, -dimensions[2] / 2];\r\n\tconst x = position[0];\r\n\tconst y = position[1];\r\n\tconst z = position[2];\r\n\tconst width = dimensions[0];\r\n\tconst height = dimensions[1];\r\n\tconst depth = dimensions[2];\r\n\r\n\tconst fbl = { x: x, y: y, z: z + depth };\r\n\tconst fbr = { x: x + width, y: y, z: z + depth };\r\n\tconst ftl = { x: x, y: y + height, z: z + depth };\r\n\tconst ftr = { x: x + width, y: y + height, z: z + depth };\r\n\tconst bbl = { x: x, y: y, z: z };\r\n\tconst bbr = { x: x + width, y: y, z: z };\r\n\tconst btl = { x: x, y: y + height, z: z };\r\n\tconst btr = { x: x + width, y: y + height, z: z };\r\n\r\n\tconst positions = [\r\n\t\t// front\r\n\t\tfbl.x,\r\n\t\tfbl.y,\r\n\t\tfbl.z,\r\n\t\tfbr.x,\r\n\t\tfbr.y,\r\n\t\tfbr.z,\r\n\t\tftl.x,\r\n\t\tftl.y,\r\n\t\tftl.z,\r\n\t\tftl.x,\r\n\t\tftl.y,\r\n\t\tftl.z,\r\n\t\tfbr.x,\r\n\t\tfbr.y,\r\n\t\tfbr.z,\r\n\t\tftr.x,\r\n\t\tftr.y,\r\n\t\tftr.z,\r\n\r\n\t\t// right\r\n\t\tfbr.x,\r\n\t\tfbr.y,\r\n\t\tfbr.z,\r\n\t\tbbr.x,\r\n\t\tbbr.y,\r\n\t\tbbr.z,\r\n\t\tftr.x,\r\n\t\tftr.y,\r\n\t\tftr.z,\r\n\t\tftr.x,\r\n\t\tftr.y,\r\n\t\tftr.z,\r\n\t\tbbr.x,\r\n\t\tbbr.y,\r\n\t\tbbr.z,\r\n\t\tbtr.x,\r\n\t\tbtr.y,\r\n\t\tbtr.z,\r\n\r\n\t\t// back\r\n\t\tfbr.x,\r\n\t\tbbr.y,\r\n\t\tbbr.z,\r\n\t\tbbl.x,\r\n\t\tbbl.y,\r\n\t\tbbl.z,\r\n\t\tbtr.x,\r\n\t\tbtr.y,\r\n\t\tbtr.z,\r\n\t\tbtr.x,\r\n\t\tbtr.y,\r\n\t\tbtr.z,\r\n\t\tbbl.x,\r\n\t\tbbl.y,\r\n\t\tbbl.z,\r\n\t\tbtl.x,\r\n\t\tbtl.y,\r\n\t\tbtl.z,\r\n\r\n\t\t// left\r\n\t\tbbl.x,\r\n\t\tbbl.y,\r\n\t\tbbl.z,\r\n\t\tfbl.x,\r\n\t\tfbl.y,\r\n\t\tfbl.z,\r\n\t\tbtl.x,\r\n\t\tbtl.y,\r\n\t\tbtl.z,\r\n\t\tbtl.x,\r\n\t\tbtl.y,\r\n\t\tbtl.z,\r\n\t\tfbl.x,\r\n\t\tfbl.y,\r\n\t\tfbl.z,\r\n\t\tftl.x,\r\n\t\tftl.y,\r\n\t\tftl.z,\r\n\r\n\t\t// top\r\n\t\tftl.x,\r\n\t\tftl.y,\r\n\t\tftl.z,\r\n\t\tftr.x,\r\n\t\tftr.y,\r\n\t\tftr.z,\r\n\t\tbtl.x,\r\n\t\tbtl.y,\r\n\t\tbtl.z,\r\n\t\tbtl.x,\r\n\t\tbtl.y,\r\n\t\tbtl.z,\r\n\t\tftr.x,\r\n\t\tftr.y,\r\n\t\tftr.z,\r\n\t\tbtr.x,\r\n\t\tbtr.y,\r\n\t\tbtr.z,\r\n\r\n\t\t// bottom\r\n\t\tbbl.x,\r\n\t\tbbl.y,\r\n\t\tbbl.z,\r\n\t\tbbr.x,\r\n\t\tbbr.y,\r\n\t\tbbr.z,\r\n\t\tfbl.x,\r\n\t\tfbl.y,\r\n\t\tfbl.z,\r\n\t\tfbl.x,\r\n\t\tfbl.y,\r\n\t\tfbl.z,\r\n\t\tbbr.x,\r\n\t\tbbr.y,\r\n\t\tbbr.z,\r\n\t\tfbr.x,\r\n\t\tfbr.y,\r\n\t\tfbr.z\r\n\t];\r\n\r\n\tconst uvs = [\r\n\t\t// front\r\n\t\t0, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1,\r\n\r\n\t\t// right\r\n\t\t0, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1,\r\n\r\n\t\t// back\r\n\t\t0, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1,\r\n\r\n\t\t// left\r\n\t\t0, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1,\r\n\r\n\t\t// top\r\n\t\t0, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1,\r\n\r\n\t\t// bottom\r\n\t\t0, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1\r\n\t];\r\n\r\n\tconst normals = [\r\n\t\t// front\r\n\t\t0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1,\r\n\r\n\t\t// right\r\n\t\t1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0,\r\n\r\n\t\t// back\r\n\t\t0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, -1,\r\n\r\n\t\t// left\r\n\t\t-1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0,\r\n\r\n\t\t// top\r\n\t\t0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0,\r\n\r\n\t\t// bottom\r\n\t\t0, -1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0\r\n\t];\r\n\treturn {\r\n\t\tpositions: positions,\r\n\t\tnormals: normals,\r\n\t\tuvs: uvs\r\n\t};\r\n}\r\n\r\nexport function createSphere(options) {\r\n\toptions = options || {};\r\n\r\n\tconst longBands = options.longBands || 32;\r\n\tconst latBands = options.latBands || 32;\r\n\tconst radius = options.radius || 1;\r\n\tconst lat_step = Math.PI / latBands;\r\n\tconst long_step = (2 * Math.PI) / longBands;\r\n\tconst num_positions = longBands * latBands * 4;\r\n\tconst num_indices = longBands * latBands * 6;\r\n\tlet lat_angle, long_angle;\r\n\tconst positions = new Array(num_positions * 3);\r\n\tconst normals = new Array(num_positions * 3);\r\n\tconst uvs = new Array(num_positions * 2);\r\n\tconst indices = new Array(num_indices);\r\n\tlet x1, x2, x3, x4, y1, y2, z1, z2, z3, z4, u1, u2, v1, v2;\r\n\tlet i, j;\r\n\tlet k = 0,\r\n\t\tl = 0;\r\n\tlet vi, ti;\r\n\r\n\tfor (i = 0; i < latBands; i++) {\r\n\t\tlat_angle = i * lat_step;\r\n\t\ty1 = Math.cos(lat_angle);\r\n\t\ty2 = Math.cos(lat_angle + lat_step);\r\n\t\tfor (j = 0; j < longBands; j++) {\r\n\t\t\tlong_angle = j * long_step;\r\n\t\t\tx1 = Math.sin(lat_angle) * Math.cos(long_angle);\r\n\t\t\tx2 = Math.sin(lat_angle) * Math.cos(long_angle + long_step);\r\n\t\t\tx3 = Math.sin(lat_angle + lat_step) * Math.cos(long_angle);\r\n\t\t\tx4 = Math.sin(lat_angle + lat_step) * Math.cos(long_angle + long_step);\r\n\t\t\tz1 = Math.sin(lat_angle) * Math.sin(long_angle);\r\n\t\t\tz2 = Math.sin(lat_angle) * Math.sin(long_angle + long_step);\r\n\t\t\tz3 = Math.sin(lat_angle + lat_step) * Math.sin(long_angle);\r\n\t\t\tz4 = Math.sin(lat_angle + lat_step) * Math.sin(long_angle + long_step);\r\n\t\t\tu1 = 1 - j / longBands;\r\n\t\t\tu2 = 1 - (j + 1) / longBands;\r\n\t\t\tv1 = 1 - i / latBands;\r\n\t\t\tv2 = 1 - (i + 1) / latBands;\r\n\t\t\tvi = k * 3;\r\n\t\t\tti = k * 2;\r\n\r\n\t\t\tpositions[vi] = x1 * radius;\r\n\t\t\tpositions[vi + 1] = y1 * radius;\r\n\t\t\tpositions[vi + 2] = z1 * radius; // v0\r\n\r\n\t\t\tpositions[vi + 3] = x2 * radius;\r\n\t\t\tpositions[vi + 4] = y1 * radius;\r\n\t\t\tpositions[vi + 5] = z2 * radius; // v1\r\n\r\n\t\t\tpositions[vi + 6] = x3 * radius;\r\n\t\t\tpositions[vi + 7] = y2 * radius;\r\n\t\t\tpositions[vi + 8] = z3 * radius; // v2\r\n\r\n\t\t\tpositions[vi + 9] = x4 * radius;\r\n\t\t\tpositions[vi + 10] = y2 * radius;\r\n\t\t\tpositions[vi + 11] = z4 * radius; // v3\r\n\r\n\t\t\tnormals[vi] = x1;\r\n\t\t\tnormals[vi + 1] = y1;\r\n\t\t\tnormals[vi + 2] = z1;\r\n\r\n\t\t\tnormals[vi + 3] = x2;\r\n\t\t\tnormals[vi + 4] = y1;\r\n\t\t\tnormals[vi + 5] = z2;\r\n\r\n\t\t\tnormals[vi + 6] = x3;\r\n\t\t\tnormals[vi + 7] = y2;\r\n\t\t\tnormals[vi + 8] = z3;\r\n\r\n\t\t\tnormals[vi + 9] = x4;\r\n\t\t\tnormals[vi + 10] = y2;\r\n\t\t\tnormals[vi + 11] = z4;\r\n\r\n\t\t\tuvs[ti] = u1;\r\n\t\t\tuvs[ti + 1] = v1;\r\n\r\n\t\t\tuvs[ti + 2] = u2;\r\n\t\t\tuvs[ti + 3] = v1;\r\n\r\n\t\t\tuvs[ti + 4] = u1;\r\n\t\t\tuvs[ti + 5] = v2;\r\n\r\n\t\t\tuvs[ti + 6] = u2;\r\n\t\t\tuvs[ti + 7] = v2;\r\n\r\n\t\t\tindices[l] = k;\r\n\t\t\tindices[l + 1] = k + 1;\r\n\t\t\tindices[l + 2] = k + 2;\r\n\t\t\tindices[l + 3] = k + 2;\r\n\t\t\tindices[l + 4] = k + 1;\r\n\t\t\tindices[l + 5] = k + 3;\r\n\r\n\t\t\tk += 4;\r\n\t\t\tl += 6;\r\n\t\t}\r\n\t}\r\n\r\n\treturn {\r\n\t\tpositions: positions,\r\n\t\tnormals: normals,\r\n\t\tuvs: uvs,\r\n\t\tindices: indices\r\n\t};\r\n}\r\n","import { Float32Attribute } from \"../render/Attribute\";\r\nimport { createSphere } from \"../utils/GeometryUtils\";\r\nimport Geometry from \"./Geometry\";\r\n\r\nexport default class SphereGeometry extends Geometry {\r\n\tradius: number;\r\n\tconstructor(radius: number) {\r\n\t\tsuper({\r\n\t\t\ttype: \"sphereGeometry\"\r\n\t\t});\r\n\t\tthis.defines = {\r\n\t\t\tHAS_NORMAL: true\r\n\t\t};\r\n\t\tthis.radius = radius;\r\n\t\tthis.init();\r\n\t}\r\n\tprivate init() {\r\n\t\tconst { positions, normals, uvs, indices } = createSphere({ radius: this.radius });\r\n\t\t// this.positions = positions;\r\n\t\t// this.normals = normals;\r\n\t\t// this.uvs = uvs;\r\n\t\t// this.indices = indices;\r\n\t\tthis.computeBoundingSphere(positions);\r\n\t\tthis.setAttribute(new Float32Attribute(\"position\", positions, 3));\r\n\t\tthis.setAttribute(new Float32Attribute(\"normal\", normals, 3));\r\n\t\tthis.setAttribute(new Float32Attribute(\"uv\", uvs, 2));\r\n\r\n\t\tthis.setIndice(indices);\r\n\t\tthis.count = indices.length;\r\n\t}\r\n}\r\n","import { Float32Attribute } from \"../render/Attribute\";\nimport { createBox } from \"../utils/GeometryUtils\";\nimport Geometry from \"./Geometry\";\nexport default class BoxGeometry extends Geometry {\n\tconstructor(public width: number = 10, public height: number = 10, public depth: number = 10) {\n\t\tsuper({\n\t\t\ttype: \"boxGeometry\"\n\t\t});\n\t\tthis.defines = {\n\t\t\tHAS_NORMAL: true\n\t\t};\n\t\tthis.init();\n\t}\n\tprivate init() {\n\t\t// generate pos uv normal so on\n\t\tconst { positions, normals, uvs } = createBox({\n\t\t\tdimensions: [this.depth, this.width, this.height]\n\t\t});\n\t\tthis.computeBoundingSphere(positions);\n\t\tthis.setAttribute(new Float32Attribute(\"position\", positions, 3));\n\t\tthis.setAttribute(new Float32Attribute(\"normal\", normals, 3));\n\t\tthis.setAttribute(new Float32Attribute(\"uv\", uvs, 2));\n\t\tthis.count = 36;\n\t}\n}\n","import Vector3 from \"../math/Vector3\";\nimport { Float32Attribute } from \"../render/Attribute\";\nimport Geometry from \"./Geometry\";\nexport default class TorusKnotGeometry extends Geometry {\n\tradius: number;\n\ttube: number;\n\ttubularSegments: number;\n\tradialSegments: number;\n\tp: number;\n\tq: number;\n\tconstructor(radius = 1, tube = 0.4, tubularSegments = 64, radialSegments = 8, p = 2, q = 3) {\n\t\tsuper({\n\t\t\ttype: \"torusKnotGeometry\"\n\t\t});\n\t\tthis.defines = {\n\t\t\tHAS_NORMAL: true\n\t\t};\n\t\tthis.radius = radius;\n\t\tthis.tube = tube;\n\t\tthis.tubularSegments = tubularSegments;\n\t\tthis.radialSegments = radialSegments;\n\t\tthis.p = p;\n\t\tthis.q = q;\n\t\tthis.init();\n\t}\n\tprivate init() {\n\t\tconst { normals, uvs, positions, indices } = this.createGeometry();\n\t\tthis.computeBoundingSphere(positions);\n\t\tthis.setAttribute(new Float32Attribute(\"position\", positions, 3));\n\t\tthis.setAttribute(new Float32Attribute(\"normal\", normals, 3));\n\t\tthis.setAttribute(new Float32Attribute(\"uv\", uvs, 2));\n\t\tthis.setIndice(indices);\n\t\tthis.count = indices.length;\n\t}\n\tprivate createGeometry() {\n\t\tconst positions = [],\n\t\t\tnormals = [],\n\t\t\tuvs = [],\n\t\t\tindices = [];\n\t\tconst tubularSegments = Math.floor(this.tubularSegments);\n\t\tconst radialSegments = Math.floor(this.radialSegments);\n\t\t// helper variables\n\n\t\tconst vertex = new Vector3();\n\t\tconst normal = new Vector3();\n\n\t\tconst P1 = new Vector3();\n\t\tconst P2 = new Vector3();\n\n\t\tconst B = new Vector3();\n\t\tconst T = new Vector3();\n\t\tconst N = new Vector3();\n\n\t\t// generate vertices, normals and uvs\n\n\t\tfor (let i = 0; i <= tubularSegments; ++i) {\n\t\t\t// the radian \"u\" is used to calculate the position on the torus curve of the current tubular segment\n\n\t\t\tconst u = (i / tubularSegments) * this.p * Math.PI * 2;\n\n\t\t\t// now we calculate two points. P1 is our current position on the curve, P2 is a little farther ahead.\n\t\t\t// these points are used to create a special \"coordinate space\", which is necessary to calculate the correct vertex positions\n\n\t\t\tcalculatePositionOnCurve(u, this.p, this.q, this.radius, P1);\n\t\t\tcalculatePositionOnCurve(u + 0.01, this.p, this.q, this.radius, P2);\n\n\t\t\t// calculate orthonormal basis\n\n\t\t\tVector3.subtract(P2, P1, T);\n\t\t\t// T.subVectors( P2, P1 );\n\t\t\tVector3.add(P2, P1, N);\n\t\t\t// N.addVectors( P2, P1 );\n\t\t\tVector3.cross(T, N, B);\n\t\t\t// B.crossVectors( T, N );\n\t\t\tVector3.cross(B, T, N);\n\t\t\t// N.crossVectors( B, T );\n\n\t\t\t// normalize B, N. T can be ignored, we don't use it\n\n\t\t\tB.normalize();\n\t\t\tN.normalize();\n\n\t\t\tfor (let j = 0; j <= radialSegments; ++j) {\n\t\t\t\t// now calculate the vertices. they are nothing more than an extrusion of the torus curve.\n\t\t\t\t// because we extrude a shape in the xy-plane, there is no need to calculate a z-value.\n\n\t\t\t\tconst v = (j / radialSegments) * Math.PI * 2;\n\t\t\t\tconst cx = -this.tube * Math.cos(v);\n\t\t\t\tconst cy = this.tube * Math.sin(v);\n\n\t\t\t\t// now calculate the final vertex position.\n\t\t\t\t// first we orient the extrusion with our basis vectors, then we add it to the current position on the curve\n\n\t\t\t\tvertex.x = P1.x + (cx * N.x + cy * B.x);\n\t\t\t\tvertex.y = P1.y + (cx * N.y + cy * B.y);\n\t\t\t\tvertex.z = P1.z + (cx * N.z + cy * B.z);\n\n\t\t\t\tpositions.push(vertex.x, vertex.y, vertex.z);\n\n\t\t\t\t// normal (P1 is always the center/origin of the extrusion, thus we can use it to calculate the normal)\n\t\t\t\tVector3.subtract(vertex, P1, normal);\n\t\t\t\tnormal.normalize();\n\n\t\t\t\tnormals.push(normal.x, normal.y, normal.z);\n\n\t\t\t\t// uv\n\n\t\t\t\tuvs.push(i / tubularSegments);\n\t\t\t\tuvs.push(j / radialSegments);\n\t\t\t}\n\t\t}\n\n\t\t// generate indices\n\n\t\tfor (let j = 1; j <= tubularSegments; j++) {\n\t\t\tfor (let i = 1; i <= radialSegments; i++) {\n\t\t\t\t// indices\n\n\t\t\t\tconst a = (radialSegments + 1) * (j - 1) + (i - 1);\n\t\t\t\tconst b = (radialSegments + 1) * j + (i - 1);\n\t\t\t\tconst c = (radialSegments + 1) * j + i;\n\t\t\t\tconst d = (radialSegments + 1) * (j - 1) + i;\n\n\t\t\t\t// faces\n\n\t\t\t\tindices.push(a, b, d);\n\t\t\t\tindices.push(b, c, d);\n\t\t\t}\n\t\t}\n\t\treturn {\n\t\t\tnormals,\n\t\t\tuvs,\n\t\t\tpositions,\n\t\t\tindices\n\t\t};\n\t}\n}\nfunction calculatePositionOnCurve(u, p, q, radius, position) {\n\tconst cu = Math.cos(u);\n\tconst su = Math.sin(u);\n\tconst quOverP = (q / p) * u;\n\tconst cs = Math.cos(quOverP);\n\n\tposition.x = radius * (2 + cs) * 0.5 * cu;\n\tposition.y = radius * (2 + cs) * su * 0.5;\n\tposition.z = radius * Math.sin(quOverP) * 0.5;\n}\n","import { FrameState } from \"../core/FrameState\";\nimport textureCache from \"../core/TextureCache\";\nimport { UniformEnum } from \"../core/WebGPUTypes\";\nimport Color from \"../math/Color\";\nimport { Mesh } from \"../mesh/Mesh\";\nimport Sampler from \"../render/Sampler\";\nimport Texture from \"../render/Texture\";\nimport UniformBuffer from \"../render/UniformBuffer\";\nimport { ShaderSource } from \"../shader/ShaderSource\";\nimport { Material } from \"./Material\";\nexport default class BlinnPhongMaterial extends Material {\n\tpublic specular: Color;\n\tpublic shininess: number;\n\tpublic normalTexture: Texture;\n\tpublic normalSampler: Sampler;\n\tconstructor() {\n\t\tsuper();\n\t\tthis.type = \"phong\";\n\t\tthis.color = new Color(1.0, 0.0, 0.0);\n\t\tthis.shaderSource = new ShaderSource({\n\t\t\tshaderId: this.type,\n\t\t\tdefines: {\n\t\t\t\tmaterialPhong: true\n\t\t\t}\n\t\t});\n\t\tthis.light = true;\n\t\tthis.specular = new Color(1.0, 1.0, 1.0);\n\t\tthis.shininess = 30.0;\n\t\tthis.baseTexture = undefined;\n\t\tthis.baseSampler = undefined;\n\t}\n\tupdate(frameState?: FrameState, mesh?: Mesh) {\n\t\tif (!this.shaderData || this.dirty) this.createShaderData(mesh);\n\t}\n\tprotected createShaderData(mesh?: Mesh) {\n\t\tsuper.createShaderData();\n\t\tconst uniformBuffer = new UniformBuffer({ label: \"phong\" });\n\t\tuniformBuffer.setUniform(\n\t\t\t\"modelMatrix\",\n\t\t\t() => {\n\t\t\t\treturn mesh.modelMatrix;\n\t\t\t},\n\t\t\tUniformEnum.Mat4\n\t\t);\n\t\tuniformBuffer.setUniform(\"color\", this, UniformEnum.Color);\n\t\tuniformBuffer.setUniform(\"opacity\", this, UniformEnum.Float);\n\t\tuniformBuffer.setUniform(\n\t\t\t\"normalMtrix\",\n\t\t\t() => {\n\t\t\t\treturn mesh.normalMatrix;\n\t\t\t},\n\t\t\tUniformEnum.Mat4\n\t\t);\n\t\tuniformBuffer.setUniform(\"emissive\", this, UniformEnum.Color);\n\t\tuniformBuffer.setUniform(\"shininess\", this, UniformEnum.Float);\n\t\tuniformBuffer.setUniform(\"specular\", this, UniformEnum.Color);\n\t\tthis.shaderData.setUniformBuffer(\"phong\", uniformBuffer);\n\t\tif (this.baseTexture) {\n\t\t\tthis.shaderData.setDefine(\"USE_COLORTEXTURE\", true);\n\t\t\tthis.shaderData.setTexture(\"baseColorTexture\", this.baseTexture);\n\t\t\tthis.shaderData.setSampler(\"baseColorSampler\", this.baseSampler || textureCache.defaultSampler);\n\t\t}\n\t\tif (this.normalTexture) {\n\t\t\tthis.shaderData.setDefine(\"USE_NORMALTEXTURE\", true);\n\t\t\tthis.shaderData.setTexture(\"normalTexture\", this.normalTexture);\n\t\t\tthis.shaderData.setSampler(\"normalSampler\", this.normalSampler || textureCache.defaultSampler);\n\t\t}\n\t}\n\tdestroy() {\n\t\tthis?.baseTexture?.destroy();\n\t\tsuper.destroy();\n\t}\n}\n","import { FrameState } from \"../core/FrameState\";\nimport textureCache from \"../core/TextureCache\";\nimport { CullMode } from \"../core/WebGPUConstant\";\nimport { UniformEnum } from \"../core/WebGPUTypes\";\nimport Vector2 from \"../math/Vector2\";\nimport { Mesh } from \"../mesh/Mesh\";\nimport Sampler from \"../render/Sampler\";\nimport Texture from \"../render/Texture\";\nimport UniformBuffer from \"../render/UniformBuffer\";\nimport { ShaderSource } from \"../shader/ShaderSource\";\nimport { Material } from \"./Material\";\n\nexport default class PbrMaterial extends Material {\n\tpublic specularEnvTexture: Texture;\n\n\tpublic specularEnvSampler: Sampler;\n\n\tpublic emissiveTexture: Texture;\n\n\tpublic emissiveSampler: Sampler;\n\n\tpublic normalTexture: Texture;\n\n\tpublic normalSampler: Sampler;\n\n\tpublic aoTexture: Texture;\n\n\tpublic aoSampler: Sampler;\n\n\tpublic metalnessRoughnessTexture: Texture;\n\n\tpublic metalnessRoughnessSampler: Sampler;\n\n\tprivate _roughness: number;\n\n\tprivate _metalness: number;\n\n\tprivate _aoTextureIntensity: number;\n\n\tprivate _normalScale: Vector2;\n\n\tprivate _IBLRender: boolean;\n\n\tpublic get roughness(): number {\n\t\treturn this._roughness;\n\t}\n\tpublic set roughness(value) {\n\t\tthis._roughness = value;\n\t}\n\tpublic get metalness(): number {\n\t\treturn this._metalness;\n\t}\n\tpublic set metalness(v: number) {\n\t\tthis._metalness = v;\n\t}\n\tpublic get aoTextureIntensity(): number {\n\t\treturn this._aoTextureIntensity;\n\t}\n\tpublic set aoTextureIntensity(v: number) {\n\t\tthis._aoTextureIntensity = v;\n\t}\n\tpublic get normalScale(): Vector2 {\n\t\tif (this.renderState && this.renderState.primitive) {\n\t\t\tif (this.renderState.primitive.cullMode == CullMode.Back) {\n\t\t\t\treturn Vector2.negate(this._normalScale, new Vector2());\n\t\t\t}\n\t\t}\n\t\treturn this._normalScale;\n\t}\n\tpublic set normalScale(v: Vector2) {\n\t\tthis._normalScale = v;\n\t}\n\tpublic set IBLRender(value) {\n\t\tthis._IBLRender = value;\n\t\tthis.shaderSource.setDefines({\n\t\t\tUSE_IBL: this._IBLRender\n\t\t});\n\t\tthis.dirty = true;\n\t}\n\tconstructor() {\n\t\tsuper();\n\t\tthis.type = \"pbr_mat\";\n\n\t\tthis._roughness = 0.1;\n\n\t\tthis._metalness = 0.1;\n\n\t\tthis._aoTextureIntensity = 1.0;\n\t\tthis.light = true;\n\t\tthis._normalScale = new Vector2(1, 1);\n\t\tthis._IBLRender = true;\n\t\tthis.shaderSource = new ShaderSource({\n\t\t\tshaderId: this.type,\n\t\t\tdefines: {\n\t\t\t\tmaterialPbr: true,\n\t\t\t\tUSE_IBL: this._IBLRender\n\t\t\t}\n\t\t});\n\t}\n\tupdate(frameState?: FrameState, mesh?: Mesh) {\n\t\tif (!textureCache.getTexture(\"specular\")) return;\n\t\tif (!this.shaderData || this.dirty) {\n\t\t\tthis.createShaderData(mesh);\n\t\t}\n\t}\n\tprotected createShaderData(mesh?: Mesh) {\n\t\tsuper.createShaderData();\n\t\tconst uniformBuffer = new UniformBuffer({ label: \"pbr\" });\n\t\tuniformBuffer.setUniform(\n\t\t\t\"modelMatrix\",\n\t\t\t() => {\n\t\t\t\treturn mesh.modelMatrix;\n\t\t\t},\n\t\t\tUniformEnum.Mat4\n\t\t);\n\t\tuniformBuffer.setUniform(\"color\", this, UniformEnum.Color);\n\t\tuniformBuffer.setUniform(\"opacity\", this, UniformEnum.Float);\n\t\tuniformBuffer.setUniform(\n\t\t\t\"normalMtrix\",\n\t\t\t() => {\n\t\t\t\treturn mesh.normalMatrix;\n\t\t\t},\n\t\t\tUniformEnum.Mat4\n\t\t);\n\t\tuniformBuffer.setUniform(\"emissive\", this, UniformEnum.Color);\n\t\tuniformBuffer.setUniform(\"metalness\", this, UniformEnum.Float);\n\t\tuniformBuffer.setUniform(\"roughness\", this, UniformEnum.Float);\n\t\tthis.shaderData.setUniformBuffer(\"pbr\", uniformBuffer);\n\t\tthis.specularEnvTexture = textureCache.getTexture(\"specular\");\n\t\tif (this.baseTexture) {\n\t\t\tthis.shaderData.setDefine(\"USE_TEXTURE\", true);\n\t\t\tthis.shaderData.setTexture(\"baseColorTexture\", this.baseTexture);\n\t\t\tthis.shaderData.setSampler(\"baseColorSampler\", this.baseSampler || textureCache.defaultSampler);\n\t\t}\n\t\tif (this.metalnessRoughnessTexture) {\n\t\t\tthis.shaderData.setDefine(\"USE_METALNESSTEXTURE\", true);\n\t\t\tthis.shaderData.setTexture(\"metalnessRoughnessTexture\", this.metalnessRoughnessTexture);\n\t\t\tthis.shaderData.setSampler(\n\t\t\t\t\"metalnessRoughnessSampler\",\n\t\t\t\tthis.metalnessRoughnessSampler || textureCache.defaultSampler\n\t\t\t);\n\t\t}\n\t\tif (this.normalTexture) {\n\t\t\tuniformBuffer.setUniform(\"normalScale\", this, UniformEnum.FloatVec2);\n\t\t\tthis.shaderData.setDefine(\"USE_NORMALTEXTURE\", true);\n\t\t\tthis.shaderData.setTexture(\"normalTexture\", this.normalTexture);\n\t\t\tthis.shaderData.setSampler(\"normalSampler\", this.normalSampler || textureCache.defaultSampler);\n\t\t}\n\t\tif (this.aoTexture) {\n\t\t\tthis.shaderData.setDefine(\"USE_AOTEXTURE\", true);\n\t\t\tthis.shaderData.setTexture(\"aoTexture\", this.aoTexture);\n\t\t\tthis.shaderData.setSampler(\"aoSampler\", this.aoSampler || textureCache.defaultSampler);\n\t\t\tuniformBuffer.setUniform(\"aoTextureIntensity\", this, UniformEnum.Float);\n\t\t}\n\t\tif (this.emissiveTexture) {\n\t\t\tthis.shaderData.setDefine(\"USE_EMISSIVETEXTURE\", true);\n\t\t\tthis.shaderData.setTexture(\"emissiveTexture\", this.emissiveTexture);\n\t\t\tthis.shaderData.setSampler(\"emissiveSampler\", this.emissiveSampler || textureCache.defaultSampler);\n\t\t}\n\t\tif (this.specularEnvTexture && this._IBLRender) {\n\t\t\tthis.shaderData.setTexture(\"specularEnvTexture\", this.specularEnvTexture);\n\t\t\tthis.shaderData.setSampler(\"specularEnvSampler\", this.specularEnvSampler || textureCache.defaultSampler);\n\t\t}\n\t}\n\tdestroy() {\n\t\tthis?.aoTexture?.destroy();\n\t\tthis?.baseTexture?.destroy();\n\t\tthis?.emissiveTexture?.destroy();\n\t\tthis?.normalTexture?.destroy();\n\t\tthis.specularEnvTexture = undefined;\n\t}\n}\n","export class EventDispatcher {\r\n\tprivate _listeners: object;\r\n\tconstructor() {\r\n\t\tthis._listeners = {};\r\n\t}\r\n\r\n\taddEventListener(type, listener) {\r\n\t\tif (this._listeners === undefined) this._listeners = {};\r\n\r\n\t\tconst listeners = this._listeners;\r\n\r\n\t\tif (listeners[type] === undefined) {\r\n\t\t\tlisteners[type] = [];\r\n\t\t}\r\n\r\n\t\tif (listeners[type].indexOf(listener) === -1) {\r\n\t\t\tlisteners[type].push(listener);\r\n\t\t}\r\n\t}\r\n\r\n\thasEventListener(type, listener) {\r\n\t\tif (this._listeners === undefined) return false;\r\n\r\n\t\tconst listeners = this._listeners;\r\n\r\n\t\treturn listeners[type] !== undefined && listeners[type].indexOf(listener) !== -1;\r\n\t}\r\n\r\n\tremoveEventListener(type, listener) {\r\n\t\tif (this._listeners === undefined) return;\r\n\r\n\t\tconst listeners = this._listeners;\r\n\t\tconst listenerArray = listeners[type];\r\n\r\n\t\tif (listenerArray !== undefined) {\r\n\t\t\tconst index = listenerArray.indexOf(listener);\r\n\r\n\t\t\tif (index !== -1) {\r\n\t\t\t\tlistenerArray.splice(index, 1);\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\tdispatchEvent(event) {\r\n\t\tif (this._listeners === undefined) return;\r\n\r\n\t\tconst listeners = this._listeners;\r\n\t\tconst listenerArray = listeners[event.type];\r\n\r\n\t\tif (listenerArray !== undefined) {\r\n\t\t\tevent.target = this;\r\n\r\n\t\t\tconst array = listenerArray.slice(0);\r\n\r\n\t\t\tfor (let i = 0, l = array.length; i < l; i++) {\r\n\t\t\t\tarray[i].call(this, event);\r\n\t\t\t}\r\n\t\t\tevent.target = null;\r\n\t\t}\r\n\t}\r\n}\r\n","import Camera from \"../camera/Camera\";\nimport { Compute } from \"../compute/Compute\";\nimport { Material } from \"../material/Material\";\nimport { Mesh } from \"../mesh/Mesh\";\nimport { ComputeCommand } from \"../render/ComputeCommand\";\nimport Context from \"../render/Context\";\nimport DrawCommand from \"../render/DrawCommand\";\nimport LightManger from \"./LightManger\";\nimport { CommandSubType } from \"./WebGPUConstant\";\nexport default class RenderQueue {\n\tpublic pre: Array<Mesh>;\n\tpublic opaque: Array<Mesh>;\n\tpublic transparent: Array<Mesh>;\n\tpublic debugQueue: Array<Mesh>;\n\tpublic computes: Array<Compute>;\n\tconstructor() {\n\t\tthis.pre = [];\n\t\tthis.opaque = [];\n\t\tthis.transparent = [];\n\t\tthis.computes = [];\n\t\tthis.debugQueue = [];\n\t}\n\tsort() {\n\t\tRenderQueue.sort(this.opaque, 0, this.opaque.length, RenderQueue._compareFromNearToFar);\n\t\tRenderQueue.sort(this.transparent, 0, this.transparent.length, RenderQueue._compareFromFarToNear);\n\t}\n\topaqueRender(\n\t\tcamera: Camera,\n\t\tcontext: Context,\n\t\tpassEncoder?: GPURenderPassEncoder,\n\t\treplaceMaterial?: Material,\n\t\tcommandSubType?: CommandSubType,\n\t\tlightManger?: LightManger\n\t) {\n\t\tthis.opaque.map((mesh) => {\n\t\t\tif (!mesh.ready) return;\n\t\t\tmesh.beforeRender();\n\t\t\tRenderQueue.excuteCommand(\n\t\t\t\tmesh.getDrawCommand(replaceMaterial, commandSubType, lightManger),\n\t\t\t\tcontext,\n\t\t\t\tpassEncoder,\n\t\t\t\tcamera\n\t\t\t);\n\t\t\tmesh.afterRender();\n\t\t});\n\t}\n\ttransparentRender(\n\t\tcamera: Camera,\n\t\tcontext: Context,\n\t\tpassEncoder?: GPURenderPassEncoder,\n\t\treplaceMaterial?: Material,\n\t\tcommandSubType?: CommandSubType,\n\t\tlightManger?: LightManger\n\t) {\n\t\tthis.transparent.map((mesh) => {\n\t\t\tif (!mesh.ready) return;\n\t\t\tmesh.beforeRender();\n\t\t\tRenderQueue.excuteCommand(\n\t\t\t\tmesh.getDrawCommand(replaceMaterial, commandSubType, lightManger),\n\t\t\t\tcontext,\n\t\t\t\tpassEncoder,\n\t\t\t\tcamera\n\t\t\t);\n\t\t\tmesh.afterRender();\n\t\t});\n\t}\n\tcomputeRender(context: Context, passEncoder?: GPUComputePassEncoder) {\n\t\tthis.computes.map((compute) => {\n\t\t\tRenderQueue.excuteCompute(compute.getCommand(), context, passEncoder);\n\t\t});\n\t}\n\tdebugQueueRender(\n\t\tcamera: Camera,\n\t\tcontext: Context,\n\t\tpassEncoder?: GPURenderPassEncoder,\n\t\treplaceMaterial?: Material,\n\t\tcommandSubType?: CommandSubType\n\t) {\n\t\tthis.debugQueue.map((mesh) => {\n\t\t\tif (!mesh.ready) return;\n\t\t\tmesh.beforeRender();\n\t\t\tRenderQueue.excuteCommand(\n\t\t\t\tmesh.getDrawCommand(replaceMaterial, commandSubType),\n\t\t\t\tcontext,\n\t\t\t\tpassEncoder,\n\t\t\t\tcamera\n\t\t\t);\n\t\t\tmesh.afterRender();\n\t\t});\n\t}\n\tpreRender(camera: Camera, context: Context, passEncoder?: GPURenderPassEncoder, replaceMaterial?: Material) {\n\t\tthis.pre.map((mesh) => {\n\t\t\tif (!mesh.ready) return;\n\t\t\tmesh.beforeRender();\n\t\t\tRenderQueue.excuteCommand(mesh.getDrawCommand(), context, passEncoder, camera);\n\t\t\tmesh.afterRender();\n\t\t});\n\t}\n\tstatic excuteCommand(command: DrawCommand, context?: Context, passEncoder?: GPURenderPassEncoder, camera?: Camera) {\n\t\tcommand.render({\n\t\t\tdevice: context.device,\n\t\t\tpassEncoder,\n\t\t\tcamera,\n\t\t\tviewPort: context?.viewPort,\n\t\t\tscissorTest: context?.scissorTest\n\t\t});\n\t}\n\tstatic excuteCompute(command: ComputeCommand, context?: Context, passEncoder?: GPUComputePassEncoder) {\n\t\tcommand.render({ device: context.device, passEncoder });\n\t}\n\treset() {\n\t\tthis.pre = [];\n\t\tthis.opaque = [];\n\t\tthis.transparent = [];\n\t\tthis.computes = [];\n\t\tthis.debugQueue = [];\n\t}\n\tstatic _compareFromNearToFar(a: Mesh, b: Mesh): number {\n\t\treturn a.priority - b.priority || a.distanceToCamera - b.distanceToCamera;\n\t}\n\n\tstatic _compareFromFarToNear(a: Mesh, b: Mesh): number {\n\t\treturn a.priority - b.priority || b.distanceToCamera - a.distanceToCamera;\n\t}\n\t// according to camera distance\n\tstatic sort<T>(insatnce: T[], from: number, to: number, compareFunc: Function): void {\n\t\tRenderQueue._quickSort(insatnce, from, to, compareFunc);\n\t}\n\t// from https://github.com/oasis-engine/engine/blob/main/packages/core/src/RenderPipeline/RenderQueue.ts\n\tprivate static _quickSort<T>(a: T[], from: number, to: number, compareFunc: Function): void {\n\t\twhile (true) {\n\t\t\t// Insertion sort is faster for short arrays.\n\t\t\tif (to - from <= 10) {\n\t\t\t\tRenderQueue._insertionSort(a, from, to, compareFunc);\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tconst third_index = (from + to) >> 1;\n\t\t\t// Find a pivot as the median of first, last and middle element.\n\t\t\tlet v0 = a[from];\n\t\t\tlet v1 = a[to - 1];\n\t\t\tlet v2 = a[third_index];\n\t\t\tconst c01 = compareFunc(v0, v1);\n\t\t\tif (c01 > 0) {\n\t\t\t\t// v1 < v0, so swap them.\n\t\t\t\tconst tmp = v0;\n\t\t\t\tv0 = v1;\n\t\t\t\tv1 = tmp;\n\t\t\t} // v0 <= v1.\n\t\t\tconst c02 = compareFunc(v0, v2);\n\t\t\tif (c02 >= 0) {\n\t\t\t\t// v2 <= v0 <= v1.\n\t\t\t\tconst tmp = v0;\n\t\t\t\tv0 = v2;\n\t\t\t\tv2 = v1;\n\t\t\t\tv1 = tmp;\n\t\t\t} else {\n\t\t\t\t// v0 <= v1 && v0 < v2\n\t\t\t\tconst c12 = compareFunc(v1, v2);\n\t\t\t\tif (c12 > 0) {\n\t\t\t\t\t// v0 <= v2 < v1\n\t\t\t\t\tconst tmp = v1;\n\t\t\t\t\tv1 = v2;\n\t\t\t\t\tv2 = tmp;\n\t\t\t\t}\n\t\t\t}\n\t\t\t// v0 <= v1 <= v2\n\t\t\ta[from] = v0;\n\t\t\ta[to - 1] = v2;\n\t\t\tconst pivot = v1;\n\t\t\tlet low_end = from + 1; // Upper bound of elements lower than pivot.\n\t\t\tlet high_start = to - 1; // Lower bound of elements greater than pivot.\n\t\t\ta[third_index] = a[low_end];\n\t\t\ta[low_end] = pivot;\n\n\t\t\t// From low_end to i are elements equal to pivot.\n\t\t\t// From i to high_start are elements that haven't been compared yet.\n\t\t\tpartition: for (let i = low_end + 1; i < high_start; i++) {\n\t\t\t\tlet element = a[i];\n\t\t\t\tlet order = compareFunc(element, pivot);\n\t\t\t\tif (order < 0) {\n\t\t\t\t\ta[i] = a[low_end];\n\t\t\t\t\ta[low_end] = element;\n\t\t\t\t\tlow_end++;\n\t\t\t\t} else if (order > 0) {\n\t\t\t\t\tdo {\n\t\t\t\t\t\thigh_start--;\n\t\t\t\t\t\tif (high_start == i) break partition;\n\t\t\t\t\t\tconst top_elem = a[high_start];\n\t\t\t\t\t\torder = compareFunc(top_elem, pivot);\n\t\t\t\t\t} while (order > 0);\n\t\t\t\t\ta[i] = a[high_start];\n\t\t\t\t\ta[high_start] = element;\n\t\t\t\t\tif (order < 0) {\n\t\t\t\t\t\telement = a[i];\n\t\t\t\t\t\ta[i] = a[low_end];\n\t\t\t\t\t\ta[low_end] = element;\n\t\t\t\t\t\tlow_end++;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\tif (to - high_start < low_end - from) {\n\t\t\t\tthis._quickSort(a, high_start, to, compareFunc);\n\t\t\t\tto = low_end;\n\t\t\t} else {\n\t\t\t\tthis._quickSort(a, from, low_end, compareFunc);\n\t\t\t\tfrom = high_start;\n\t\t\t}\n\t\t}\n\t}\n\tprivate static _insertionSort<T>(a: T[], from: number, to: number, compareFunc: Function): void {\n\t\tfor (let i = from + 1; i < to; i++) {\n\t\t\tlet j;\n\t\t\tconst element = a[i];\n\t\t\tfor (j = i - 1; j >= from; j--) {\n\t\t\t\tconst tmp = a[j];\n\t\t\t\tconst order = compareFunc(tmp, element);\n\t\t\t\tif (order > 0) {\n\t\t\t\t\ta[j + 1] = tmp;\n\t\t\t\t} else {\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t}\n\t\t\ta[j + 1] = element;\n\t\t}\n\t}\n}\n","import { Scene } from \"../Scene\";\r\nimport Camera from \"../camera/Camera\";\r\nimport Color from \"../math/Color\";\r\nimport Pass from \"../pass/Pass\";\r\nimport Context from \"../render/Context\";\r\nimport Texture from \"../render/Texture\";\r\nimport combine from \"../utils/combine\";\r\nimport CullingVolume from \"./CullingVolume\";\r\nimport LightManger from \"./LightManger\";\r\nimport RenderQueue from \"./RenderQueue\";\r\n\r\ninterface FrameStateOptions {\r\n\tbackground?: Background;\r\n}\r\n\r\nexport interface Background {\r\n\tvalue: Color | Texture;\r\n\topacity: number;\r\n}\r\n\r\nexport class FrameState {\r\n\tpublic background: Background;\r\n\tpublic pass: Pass;\r\n\tpublic renderQueue: RenderQueue;\r\n\tpublic drawCallnums: number;\r\n\tpublic geometryMemory: number;\r\n\tpublic textureMemory: number;\r\n\tpublic frameNumber: number;\r\n\tpublic cullingVolume: CullingVolume;\r\n\tpublic definesDirty: boolean;\r\n\tprivate _defines: object;\r\n\tconstructor(public context: Context, public lightManger?: LightManger, options: FrameStateOptions = {}) {\r\n\t\tthis.background = options.background;\r\n\t\tthis.renderQueue = new RenderQueue();\r\n\t\tthis.geometryMemory = 0;\r\n\t\tthis.textureMemory = 0;\r\n\t\tthis.frameNumber = 0;\r\n\t\tthis._defines = {};\r\n\t\tthis.definesDirty = true;\r\n\t}\r\n\tget defines() {\r\n\t\treturn this._defines;\r\n\t}\r\n\tset defines(value) {\r\n\t\tthis.definesDirty = true;\r\n\t\tthis._defines = combine(value, this._defines, false);\r\n\t}\r\n\tupdate(camera: Camera, options: FrameStateOptions = {}) {\r\n\t\tthis.background = options.background;\r\n\r\n\t\tthis.renderQueue.reset();\r\n\t\tthis?.lightManger?.update?.(this, camera);\r\n\t\tthis.cullingVolume = camera.getCullingVolume();\r\n\t\tthis.frameNumber += 1;\r\n\t}\r\n\r\n\tresetCullingVolume(camera: Camera) {\r\n\t\tthis.cullingVolume = camera.getCullingVolume();\r\n\t}\r\n\r\n\tstatic getFrameStateOptionsByScene(sceneInstance: Scene) {\r\n\t\treturn {\r\n\t\t\tbackground: sceneInstance.background\r\n\t\t};\r\n\t}\r\n}\r\n","import { LightType } from \"../core/WebGPUTypes\";\r\nimport Vector3 from \"../math/Vector3\";\r\nimport Vector4 from \"../math/Vector4\";\r\nimport { Light } from \"./Light\";\r\n\r\nexport class AmbientLight extends Light {\r\n\tprivate _colorAndIntensity: Vector4;\r\n\tconstructor(color: Vector3, intensity: number) {\r\n\t\tsuper(color, intensity);\r\n\t\tthis.lightType = LightType.AmbientLight;\r\n\t\tthis._colorAndIntensity = new Vector4(color.x, color.y, color.z, intensity);\r\n\t}\r\n\tget ColorAndIntensity() {\r\n\t\tthis._colorAndIntensity.set(this.color.x, this.color.y, this.color.z, this.intensity);\r\n\t\treturn this._colorAndIntensity;\r\n\t}\r\n}\r\n// light.color ).multiplyScalar( light.intensity * scaleFactor );\r\n","import Camera from \"../camera/Camera\";\nimport { LightMangerOptions, LightType, UniformEnum } from \"../core/WebGPUTypes\";\nimport { AmbientLight } from \"../light/AmbientLight\";\nimport { DirectionalLight } from \"../light/DirectionalLight\";\nimport { Light } from \"../light/Light\";\nimport { PointLight } from \"../light/PointLight\";\nimport { SpotLight } from \"../light/SpotLight\";\nimport Vector3 from \"../math/Vector3\";\nimport Sampler from \"../render/Sampler\";\nimport ShaderData from \"../render/ShaderData\";\nimport Texture from \"../render/Texture\";\nimport UniformBuffer from \"../render/UniformBuffer\";\nimport { FrameState } from \"./FrameState\";\nimport {\n\tTextureUsage,\n\tBufferUsage,\n\tTextureFormat,\n\tCompareFunction,\n\tSamplerBindingType,\n\tTextureSampleType,\n\tTextureViewDimension,\n\tBufferBindingType\n} from \"./WebGPUConstant\";\n\nexport default class LightManger {\n\tlightUniformBuffer: UniformBuffer;\n\tshadowUniformBuffer: UniformBuffer;\n\tpointLights: PointLight[];\n\n\tspotLights: SpotLight[];\n\n\tdirectLights: DirectionalLight[];\n\n\tambientLight: AmbientLight;\n\n\tlightShaderData: ShaderData;\n\n\tlightCountDirty: boolean;\n\n\tprivate openShadow: boolean;\n\tspotLightShadowMapTextureArray: Texture;\n\tpointLightShadowMapTextureArray: Texture;\n\tdirectLightShadowMapTextureArray: Texture;\n\t_testTexture: Texture;\n\n\tconstructor(options: LightMangerOptions) {\n\t\tthis.spotLights = [];\n\t\tthis.pointLights = [];\n\t\tthis.directLights = [];\n\t\tthis.ambientLight = new AmbientLight(new Vector3(1.0, 1.0, 1.0), 0.2);\n\t\tthis.lightCountDirty = true;\n\t\tthis.openShadow = options.openShadow;\n\t}\n\tupdate(frameState: FrameState, camera: Camera) {\n\t\tthis.checkLightShadowState();\n\t\tthis.updateLight(camera);\n\t}\n\tadd(light: Light) {\n\t\tthis.lightCountDirty = true;\n\t\tif (light.lightType == LightType.AmbientLight) {\n\t\t\tthis.ambientLight = <AmbientLight>light;\n\t\t} else if (light.lightType == LightType.DirectionalLight) {\n\t\t\tthis.directLights.push(<DirectionalLight>light);\n\t\t} else if (light.lightType == LightType.PointLight) {\n\t\t\tthis.pointLights.push(<PointLight>light);\n\t\t} else if (light.lightType == LightType.SpotLight) {\n\t\t\tthis.spotLights.push(<SpotLight>light);\n\t\t}\n\t}\n\tremove(light: Light) {\n\t\tthis.lightCountDirty = true;\n\t\tif (light.lightType == LightType.AmbientLight) {\n\t\t\tthis.ambientLight = new AmbientLight(new Vector3(1.0, 1.0, 1.0), 1.0);\n\t\t} else if (light.lightType == LightType.DirectionalLight) {\n\t\t\tthis.directLights.splice(this.directLights.indexOf(<DirectionalLight>light), 1);\n\t\t} else if (light.lightType == LightType.PointLight) {\n\t\t\tthis.pointLights.splice(this.pointLights.indexOf(<PointLight>light), 1);\n\t\t} else if (light.lightType == LightType.SpotLight) {\n\t\t\tthis.spotLights.splice(this.spotLights.indexOf(<SpotLight>light), 1);\n\t\t}\n\t}\n\tcheckLightShadowState() {\n\t\tconst lights = this.getAllLights();\n\t\tfor (let i = 0; i < lights.length; i++) {\n\t\t\tconst light = lights[i];\n\t\t\tif (light.shadowDirty) {\n\t\t\t\tlight.shadowDirty = false;\n\t\t\t\tthis.lightCountDirty = true;\n\t\t\t}\n\t\t}\n\t}\n\n\tupdateLightShadow() {\n\t\tif (this.spotLightShadowMapTextureArray) this.spotLightShadowMapTextureArray.dirty = true;\n\n\t\tif (this.pointLightShadowMapTextureArray) this.pointLightShadowMapTextureArray.dirty = true;\n\n\t\tif (this.directLightShadowMapTextureArray) this.directLightShadowMapTextureArray.dirty = true;\n\t}\n\n\tprivate updateLight(camera: Camera) {\n\t\tif (this.lightCountDirty) {\n\t\t\tthis.lightCountDirty = false;\n\t\t\tif (this.lightShaderData) this.lightShaderData.destroy();\n\t\t\tthis.createLightShaderData();\n\t\t}\n\t}\n\tprivate createLightShaderData() {\n\t\tthis.lightShaderData = new ShaderData(\"light\", 0, 2, 2);\n\t\tthis.lightUniformBuffer = new UniformBuffer({\n\t\t\tlabel: \"light\",\n\t\t\ttype: BufferBindingType.ReadOnlyStorage,\n\t\t\tusage: BufferUsage.Storage | BufferUsage.CopyDst\n\t\t});\n\n\t\tthis.lightShaderData.setDefine(\"spotLightsCount\", this.spotLights.length);\n\t\tthis.lightShaderData.setDefine(\"pointLightsCount\", this.pointLights.length);\n\t\tthis.lightShaderData.setDefine(\"dirtectLightsCount\", this.directLights.length);\n\t\tthis.lightShaderData.setDefine(\"ambientLightCount\", 1);\n\t\tif (this.ambientLight)\n\t\t\tthis.lightUniformBuffer.setUniform(\n\t\t\t\t\"ambientLight\",\n\t\t\t\t() => {\n\t\t\t\t\treturn this.ambientLight.ColorAndIntensity;\n\t\t\t\t},\n\t\t\t\tUniformEnum.FloatVec4\n\t\t\t);\n\t\tif (this.spotLights.length) {\n\t\t\t// 初始化聚光灯\n\t\t\tthis.lightUniformBuffer.setUniform(\n\t\t\t\t\"spotLights\",\n\t\t\t\t() => {\n\t\t\t\t\treturn this.spotLights;\n\t\t\t\t},\n\t\t\t\tUniformEnum.SpotLights,\n\t\t\t\tthis.spotLights.length\n\t\t\t);\n\t\t}\n\t\tif (this.pointLights.length) {\n\t\t\t// 点光源\n\t\t\tthis.lightUniformBuffer.setUniform(\n\t\t\t\t\"pointLights\",\n\t\t\t\t() => {\n\t\t\t\t\treturn this.pointLights;\n\t\t\t\t},\n\t\t\t\tUniformEnum.PointLights,\n\t\t\t\tthis.pointLights.length\n\t\t\t);\n\t\t}\n\t\tif (this.directLights.length) {\n\t\t\t// 方向光\n\t\t\tthis.lightUniformBuffer.setUniform(\n\t\t\t\t\"directLights\",\n\t\t\t\t() => {\n\t\t\t\t\treturn this.directLights;\n\t\t\t\t},\n\t\t\t\tUniformEnum.DirtectLights,\n\t\t\t\tthis.directLights.length\n\t\t\t);\n\t\t}\n\n\t\tshadowShaderData: {\n\t\t\tif (this.openShadow) {\n\t\t\t\tconst spotLightShadowMapTextureArray = (this.spotLightShadowMapTextureArray =\n\t\t\t\t\tthis.createShadowMapTextureArray(this.spotLights));\n\t\t\t\tconst pointLightShadowMapTextureArray = (this.pointLightShadowMapTextureArray =\n\t\t\t\t\tthis.createShadowMapTextureArray(this.pointLights));\n\t\t\t\tconst directLightShadowMapTextureArray = (this.directLightShadowMapTextureArray =\n\t\t\t\t\tthis.createShadowMapTextureArray(this.directLights));\n\t\t\t\tif (\n\t\t\t\t\t!spotLightShadowMapTextureArray &&\n\t\t\t\t\t!pointLightShadowMapTextureArray &&\n\t\t\t\t\t!directLightShadowMapTextureArray\n\t\t\t\t)\n\t\t\t\t\tbreak shadowShaderData;\n\n\t\t\t\t// define\n\t\t\t\tthis.lightShaderData.setDefine(\"openShadow\", this.openShadow);\n\n\t\t\t\t// shadowUniformBuffer\n\t\t\t\tthis.shadowUniformBuffer = new UniformBuffer({\n\t\t\t\t\tlabel: \"shadow\",\n\t\t\t\t\ttype: BufferBindingType.ReadOnlyStorage,\n\t\t\t\t\tusage: BufferUsage.Storage | BufferUsage.CopyDst\n\t\t\t\t});\n\n\t\t\t\t// matrix,near,far...\n\t\t\t\tconst spotLightWithShadowCount = this.setShadowUniform(\n\t\t\t\t\t\"spotLightShadows\",\n\t\t\t\t\tthis.spotLights,\n\t\t\t\t\tUniformEnum.SpotLightShadows\n\t\t\t\t);\n\t\t\t\tconst pointLightWithShadowCount = this.setShadowUniform(\n\t\t\t\t\t\"pointLightShadows\",\n\t\t\t\t\tthis.pointLights,\n\t\t\t\t\tUniformEnum.PointLightShadows\n\t\t\t\t);\n\t\t\t\tconst directLightWithShadowCount = this.setShadowUniform(\n\t\t\t\t\t\"directLightShadows\",\n\t\t\t\t\tthis.directLights,\n\t\t\t\t\tUniformEnum.DirtectLightShadows\n\t\t\t\t);\n\t\t\t\tthis.lightShaderData.setUniformBuffer(\"shadow\", this.shadowUniformBuffer);\n\n\t\t\t\tthis.lightShaderData.setDefine(\"spotLightShadowMapsCount\", spotLightWithShadowCount);\n\t\t\t\tthis.lightShaderData.setDefine(\"pointLightShadowMapsCount\", pointLightWithShadowCount);\n\t\t\t\tthis.lightShaderData.setDefine(\"directLightShadowMapsCount\", directLightWithShadowCount);\n\n\t\t\t\t// texture,sample\n\t\t\t\tif (spotLightShadowMapTextureArray !== undefined) {\n\t\t\t\t\tif (spotLightShadowMapTextureArray.textureProp.size.depth != spotLightWithShadowCount)\n\t\t\t\t\t\tconsole.warn(\"spotLightShadowMap align has problem\");\n\t\t\t\t\tthis.lightShaderData.setTexture(\"spotLightShadowMapTextureArray\", spotLightShadowMapTextureArray);\n\t\t\t\t\t// this._testTexture = spotLightShadowMapTextureArray\n\t\t\t\t}\n\t\t\t\tif (pointLightShadowMapTextureArray !== undefined) {\n\t\t\t\t\tif (pointLightShadowMapTextureArray.textureProp.size.depth != pointLightWithShadowCount)\n\t\t\t\t\t\tconsole.warn(\"pointLightShadowMap align has problem\");\n\t\t\t\t\tthis.lightShaderData.setTexture(\"pointLightShadowMapTextureArray\", pointLightShadowMapTextureArray);\n\t\t\t\t\t// this._testTexture = pointLightShadowMapTextureArray;\n\t\t\t\t}\n\t\t\t\tif (directLightShadowMapTextureArray !== undefined) {\n\t\t\t\t\tif (directLightShadowMapTextureArray.textureProp.size.depth != directLightWithShadowCount)\n\t\t\t\t\t\tconsole.warn(\"directLightShadowMap align has problem\");\n\t\t\t\t\tthis.lightShaderData.setTexture(\n\t\t\t\t\t\t\"directLightShadowMapTextureArray\",\n\t\t\t\t\t\tdirectLightShadowMapTextureArray\n\t\t\t\t\t);\n\t\t\t\t\t// this._testTexture = directLightShadowMapTextureArray\n\t\t\t\t}\n\t\t\t\tthis.lightShaderData.setSampler(\n\t\t\t\t\t\"shadowSampler\",\n\t\t\t\t\tnew Sampler({ compare: CompareFunction.Less }, { type: SamplerBindingType.Comparison })\n\t\t\t\t);\n\t\t\t\t// this.lightShaderData.setSampler(\"shadowSampler\", new Sampler());\n\t\t\t}\n\t\t}\n\n\t\tthis.lightShaderData.setUniformBuffer(\"light\", this.lightUniformBuffer);\n\t}\n\n\tpublic getAllLights(): Array<Light> {\n\t\tconst result = [];\n\t\treturn result.concat(this.spotLights, this.pointLights, this.directLights);\n\t}\n\n\tdestroy() {\n\t\tthis.lightShaderData.destroy();\n\t\tthis.lightUniformBuffer.destroy();\n\t}\n\n\tcreateShadowMapTextureArray(lights: Array<Light>) {\n\t\tif (lights.length <= 0) return undefined;\n\t\tconst shadowMapSources = [];\n\t\tfor (let i = 0; i < lights.length; i++) {\n\t\t\tconst light = lights[i];\n\t\t\tif (light.shadow) {\n\t\t\t\tconst shadowMapTexture = light.shadow.getShadowMapTexture();\n\t\t\t\tconst shadowMapSource = {\n\t\t\t\t\tsource: shadowMapTexture,\n\t\t\t\t\twidth: shadowMapTexture.textureProp.size.width,\n\t\t\t\t\theight: shadowMapTexture.textureProp.size.height,\n\t\t\t\t\tdepth: 1,\n\t\t\t\t\tx: 0,\n\t\t\t\t\ty: 0,\n\t\t\t\t\tz: i\n\t\t\t\t};\n\t\t\t\tshadowMapSources.push(shadowMapSource);\n\t\t\t}\n\t\t}\n\n\t\tif (shadowMapSources.length <= 0) return undefined;\n\n\t\tconst shadowMapTextureArray = new Texture({\n\t\t\tsize: {\n\t\t\t\twidth: shadowMapSources[0].width,\n\t\t\t\theight: shadowMapSources[0].height,\n\t\t\t\tdepth: shadowMapSources.length\n\t\t\t},\n\t\t\tfixedSize: true,\n\t\t\tsampleType: TextureSampleType.Depth,\n\t\t\tformat: TextureFormat.Depth24Plus,\n\t\t\tusage: TextureUsage.TextureBinding | TextureUsage.CopyDst,\n\t\t\tdata: shadowMapSources,\n\t\t\tviewFormats: TextureViewDimension.E2dArray\n\t\t});\n\n\t\treturn shadowMapTextureArray;\n\t}\n\n\tsetShadowUniform(uniformName: string, lights: Array<Light>, uniformType: UniformEnum) {\n\t\tif (lights.length) {\n\t\t\tconst lightWithShadowArray = [];\n\t\t\tfor (let i = 0; i < lights.length; i++) {\n\t\t\t\tconst light = lights[i];\n\t\t\t\tif (!light.shadow) continue;\n\t\t\t\tlightWithShadowArray.push(light);\n\t\t\t}\n\n\t\t\tthis.shadowUniformBuffer.setUniform(\n\t\t\t\tuniformName,\n\t\t\t\t() => {\n\t\t\t\t\treturn lightWithShadowArray;\n\t\t\t\t},\n\t\t\t\tuniformType,\n\t\t\t\tlightWithShadowArray.length\n\t\t\t);\n\n\t\t\treturn lightWithShadowArray.length;\n\t\t}\n\t}\n}\n","import Camera from \"../camera/Camera\";\nimport { Mesh } from \"../mesh/Mesh\";\nimport { FrameState } from \"./FrameState\";\nexport default class MeshManger {\n\tprivate _list: Map<string | number, Mesh>;\n\tconstructor() {\n\t\tthis._list = new Map();\n\t}\n\tget length() {\n\t\treturn this._list.size;\n\t}\n\tupdate(frameState: FrameState, camera: Camera): void {\n\t\tthis._list.forEach((instance) => {\n\t\t\tinstance.update(frameState, camera);\n\t\t});\n\t}\n\tadd(instance: Mesh): Mesh {\n\t\tif (this._list.get(instance.uid)) return this._list.get(instance.uid);\n\t\tthis._list.set(instance.uid, instance);\n\t\treturn instance;\n\t}\n\tremove(instance: Mesh): boolean {\n\t\tif (this._list.get(instance.uid)) {\n\t\t\tinstance.destroy();\n\t\t\tthis._list.delete(instance.uid);\n\t\t\treturn true;\n\t\t}\n\t\treturn false;\n\t}\n\tcontains(instance: Mesh) {\n\t\treturn !!this._list.get(instance.uid);\n\t}\n}\n","import { TextureFormat, TextureUsage } from \"../core/WebGPUConstant\";\nimport Geometry from \"../geometry/Geometry\";\nimport ShaderMaterial from \"../material/ShaderMaterial\";\nimport { Mesh } from \"../mesh/Mesh\";\nimport Attachment from \"../render/Attachment\";\nimport { Float32Attribute } from \"../render/Attribute\";\nimport Context from \"../render/Context\";\nimport RenderTarget from \"../render/RenderTarget\";\nimport Sampler from \"../render/Sampler\";\nimport Texture from \"../render/Texture\";\nimport getVertFrag from \"../shader/Shaders\";\nexport default class ResolveFrame {\n\tcanvasRenderTarget: RenderTarget;\n\tmaterial: ShaderMaterial;\n\tgeometry: Geometry;\n\tquadMesh: Mesh;\n\tconstructor() {\n\t\tthis.geometry = new Geometry({});\n\t\tthis.geometry.setAttribute(\n\t\t\tnew Float32Attribute(\"position\", [-1.0, 1.0, -1.0, -1.0, 1.0, -1.0, 1.0, -1.0, 1.0, 1.0, -1.0, 1.0], 2)\n\t\t);\n\t\tthis.geometry.count = 6;\n\t\tconst shader = getVertFrag(\"resolve\", { positionLocation: 0 });\n\t\tthis.material = new ShaderMaterial({\n\t\t\ttype: \"resolve\",\n\t\t\tfrag: shader.frag,\n\t\t\tvert: shader.vert,\n\t\t\tuniforms: {\n\t\t\t\ttexture: {\n\t\t\t\t\ttype: \"texture\",\n\t\t\t\t\tvalue: undefined\n\t\t\t\t},\n\t\t\t\tsampler: {\n\t\t\t\t\ttype: \"sampler\",\n\t\t\t\t\tvalue: new Sampler({\n\t\t\t\t\t\tmagFilter: \"linear\",\n\t\t\t\t\t\tminFilter: \"linear\"\n\t\t\t\t\t})\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t\tthis.quadMesh = new Mesh(this.geometry, this.material);\n\t}\n\tsetSize(width: number, height: number) {\n\t\tthis.canvasRenderTarget.setSize(width, height);\n\t\tthis.material.dirty = true;\n\t}\n\trender(context: Context, colorTexture?: Texture) {\n\t\tif (!this.canvasRenderTarget) this.initRenderTarget(context);\n\t\t// this.material\n\t\tthis.material.uniforms.texture.value = colorTexture;\n\n\t\tthis.material.update(undefined, this.quadMesh);\n\n\t\tconst drawComand = this.quadMesh.getDrawCommand();\n\n\t\tconst currentRenderPassEncoder = this.canvasRenderTarget.beginRenderPass(context.device);\n\n\t\tdrawComand.render({ device: context.device, passEncoder: currentRenderPassEncoder });\n\n\t\tthis.canvasRenderTarget.endRenderPass();\n\t}\n\tprivate initRenderTarget(context: Context) {\n\t\tconst { width, height, depth } = context.presentationSize;\n\t\tconst colorAttachment = new Attachment(\n\t\t\t{ r: 0.0, g: 0.0, b: 0.0, a: 0 },\n\t\t\t{\n\t\t\t\ttextureView: () => {\n\t\t\t\t\treturn context.context.getCurrentTexture().createView();\n\t\t\t\t}\n\t\t\t}\n\t\t);\n\t\tconst depthTexture = new Texture({\n\t\t\tlabel: \"resolveDepth\",\n\t\t\tsize: { width, height, depth },\n\t\t\tformat: TextureFormat.Depth24Plus,\n\t\t\tusage: TextureUsage.RenderAttachment\n\t\t});\n\t\tconst depthAttachment = new Attachment(1.0, { texture: depthTexture });\n\t\tthis.canvasRenderTarget = new RenderTarget(\"render\", [colorAttachment], depthAttachment);\n\t}\n}\n","import Context from \"../render/Context\";\nimport Texture from \"../render/Texture\";\nimport PostEffect from \"./PostEffect\";\nimport ResolveFrame from \"./ResolveFrame\";\n\nexport default class PostEffectCollection {\n\tprivate _postEffects: Map<string, PostEffect>;\n\tpublic currentColorTexture: Texture;\n\tprivate resolveFrame: ResolveFrame;\n\tconstructor() {\n\t\tthis._postEffects = new Map();\n\t\tthis.currentColorTexture = undefined;\n\t\tthis.resolveFrame = new ResolveFrame();\n\t}\n\tadd(postEffect: PostEffect) {\n\t\tthis._postEffects.set(postEffect.id, postEffect);\n\t}\n\tremove(postEffect: PostEffect) {\n\t\tthis._postEffects.delete(postEffect.id);\n\t\tpostEffect.destroy();\n\t}\n\trender(context: Context, colorTexture: Texture): void {\n\t\tthis.currentColorTexture = colorTexture;\n\t\tthis._postEffects.forEach((postEffect) => {\n\t\t\tthis.currentColorTexture = postEffect.render(context, this.currentColorTexture);\n\t\t});\n\t\tthis.resolveFrame.render(context, this.currentColorTexture);\n\t}\n\tsetSize(width: number, height: number) {\n\t\tthis._postEffects.forEach((postEffect) => postEffect.setSize(width, height));\n\t\tthis.resolveFrame.setSize(width, height);\n\t}\n\tprivate postEffectsSort() {\n\t\t// this._postEffects.sort()\n\t}\n}\n","import { FrameState } from \"../core/FrameState.js\";\nimport { Material } from \"../material/Material.js\";\nimport Context from \"../render/Context.js\";\nimport { Target } from \"../render/RenderState\";\nimport RenderTarget from \"../render/RenderTarget.js\";\nimport Texture from \"../render/Texture.js\";\n\nclass Pass {\n\tpublic renderTarget: RenderTarget;\n\tpublic computeTarget: RenderTarget;\n\tpublic context: Context;\n\tpublic overrideMaterial?: Material;\n\tpublic colorTargets?: Array<Target>;\n\tpublic passRenderEncoder: GPURenderPassEncoder | null;\n\tpublic passComputeEncoder: GPUComputePassEncoder;\n\tconstructor(context: Context) {\n\t\tthis.context = context;\n\t}\n\tupdate(frameState: FrameState): void {\n\t\t// todo;\n\t}\n\tsetSize(width: number, height: number): void {\n\t\t// todo ;\n\t}\n\tbeforeRender(options?: any) {\n\t\tthis.passRenderEncoder = this.renderTarget.beginRenderPass(this.context.device);\n\t\tif (this.computeTarget)\n\t\t\tthis.passComputeEncoder = this.computeTarget.beginComputePassEncoder(this.context.device);\n\t}\n\tgetColorTexture(index = 0): Texture {\n\t\treturn this.renderTarget.getColorTexture(index) as Texture;\n\t}\n\tgetDepthTexture(): Texture | { gpuTexture: GPUTexture } {\n\t\treturn this.renderTarget.getDepthTexture();\n\t}\n\tafterRender() {\n\t\tthis.renderTarget.endRenderPass();\n\t\tif (this.computeTarget) this.computeTarget.endComputePassEncoder();\n\t}\n}\n\nexport default Pass;\n","import Camera from \"../camera/Camera\";\nimport { FrameState } from \"../core/FrameState\";\nimport { TextureFormat, TextureUsage } from \"../core/WebGPUConstant\";\nimport Color from \"../math/Color\";\nimport Attachment from \"../render/Attachment\";\nimport Context from \"../render/Context\";\nimport DrawCommand from \"../render/DrawCommand\";\nimport RenderTarget from \"../render/RenderTarget\";\nimport Texture from \"../render/Texture\";\nimport Pass from \"./Pass\";\n\nexport class BasicPass extends Pass {\n\tskyboxDrawComand: DrawCommand;\n\tconstructor(context: Context) {\n\t\tsuper(context);\n\t\tthis.init(context);\n\t}\n\n\tbeforeRender(frameState: FrameState) {\n\t\tthis.updateRenderTarget(frameState);\n\n\t\tsuper.beforeRender();\n\t}\n\n\trender(frameState: FrameState, camera?: Camera) {\n\t\tconst { renderQueue, lightManger } = frameState;\n\n\t\trenderQueue.sort();\n\t\trenderQueue.preRender(camera, this.context, this.passRenderEncoder);\n\t\trenderQueue.transparentRender(camera, this.context, this.passRenderEncoder, undefined, undefined, lightManger);\n\t\trenderQueue.opaqueRender(camera, this.context, this.passRenderEncoder, undefined, undefined, lightManger);\n\t\trenderQueue.debugQueueRender(camera, this.context, this.passRenderEncoder);\n\t}\n\tprivate init(context: Context) {\n\t\tthis.createRenderTarget(context);\n\t}\n\tprivate createRenderTarget(context: Context) {\n\t\tconst { width, height, depth } = context.presentationSize;\n\t\tconst colorTexture = new Texture({\n\t\t\tlabel: \"basicPassColor\",\n\t\t\tsize: { width, height, depth },\n\t\t\tformat: this.context.presentationFormat,\n\t\t\tusage: TextureUsage.RenderAttachment | TextureUsage.TextureBinding\n\t\t});\n\t\tconst depthTexture = new Texture({\n\t\t\tlabel: \"basicPassDepth\",\n\t\t\tsize: { width, height, depth },\n\t\t\tformat: TextureFormat.Depth24Plus,\n\t\t\tusage: TextureUsage.RenderAttachment\n\t\t});\n\t\tconst colorAttachment = new Attachment({ r: 0.0, g: 0.0, b: 0.0, a: 0.0 }, { texture: colorTexture });\n\t\tconst depthAttachment = new Attachment(1.0, { texture: depthTexture });\n\t\tthis.renderTarget = new RenderTarget(\"render\", [colorAttachment], depthAttachment);\n\t}\n\tpublic setSize(width: number, height: number): void {\n\t\tthis.renderTarget.setSize(width, height, 1);\n\t}\n\tprivate updateRenderTarget(frameState: FrameState) {\n\t\tif (frameState?.background?.value instanceof Color) {\n\t\t\tconst { red, green, blue } = frameState.background.value;\n\t\t\tconst opacity = frameState.background?.opacity;\n\t\t\tconst clearValue = {\n\t\t\t\tr: red,\n\t\t\t\tg: green,\n\t\t\t\tb: blue,\n\t\t\t\ta: opacity ?? 1.0\n\t\t\t};\n\t\t\tthis.renderTarget.colorAttachments[0].value = clearValue;\n\t\t}\n\t}\n}\n","import defined from \"../utils/defined\";\r\nimport GMath from \"./Math\";\r\nimport Matrix4 from \"./Matrix4\";\r\nimport Vector3 from \"./Vector3\";\r\nimport Vector4 from \"./Vector4\";\r\n\r\n/**\r\n * A plane in Hessian Normal Form defined by\r\n * <pre>\r\n * ax + by + cz + d = 0\r\n * </pre>\r\n * where (a, b, c) is the plane's <code>normal</code>, d is the signed\r\n * <code>distance</code> to the plane, and (x, y, z) is any point on\r\n * the plane.\r\n *\r\n * @alias Plane\r\n * @constructor\r\n *\r\n * @param {Vector3} normal The plane's normal (normalized).\r\n * @param {Number} distance The shortest distance from the origin to the plane.  The sign of\r\n * @example\r\n * // The plane x=0\r\n * const plane = new Plane(Vector3.UNIT_X, 0.0);\r\n *\r\n * @exception {DeveloperError} Normal must be normalized\r\n */\r\nclass Plane {\r\n\tnormal: Vector3;\r\n\tdistance: number;\r\n\tpublic static ORIGIN_XY_PLANE = Object.freeze(new Plane(Vector3.UNIT_Z, 0.0));\r\n\r\n\tpublic static ORIGIN_YZ_PLANE = Object.freeze(new Plane(Vector3.UNIT_X, 0.0));\r\n\r\n\tpublic static ORIGIN_ZX_PLANE = Object.freeze(new Plane(Vector3.UNIT_Y, 0.0));\r\n\tconstructor(normal: Vector3, distance: number) {\r\n\t\tthis.normal = Vector3.clone(normal);\r\n\r\n\t\tthis.distance = distance;\r\n\t}\r\n\tnormalize() {\r\n\t\tconst inverseNormalLength = 1.0 / this.normal.length();\r\n\t\tthis.normal = Vector3.multiplyByScalar(this.normal, inverseNormalLength, this.normal);\r\n\t\tthis.distance *= inverseNormalLength;\r\n\t\treturn this;\r\n\t}\r\n\r\n\tstatic fromPointNormal(point: Vector3, normal: Vector3, result: Plane): Plane {\r\n\t\tif (!GMath.equalsEpsilon(Vector3.magnitude(normal), 1.0, GMath.EPSILON6)) {\r\n\t\t\tthrow new Error(\"normal must be normalized.\");\r\n\t\t}\r\n\t\t// >>includeEnd('debug');\r\n\r\n\t\tconst distance = -Vector3.dot(normal, point);\r\n\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Plane(normal, distance);\r\n\t\t}\r\n\r\n\t\tVector3.clone(normal, result.normal);\r\n\t\tresult.distance = distance;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic fromVector4(coefficients: Vector4, result: Plane): Plane {\r\n\t\tconst normal = Vector3.fromVector4(coefficients, scratchNormal);\r\n\t\tconst distance = coefficients.w;\r\n\r\n\t\t// >>includeStart('debug', pragmas.debug);\r\n\t\tif (!GMath.equalsEpsilon(Vector3.magnitude(normal), 1.0, GMath.EPSILON6)) {\r\n\t\t\tthrow new Error(\"normal must be normalized.\");\r\n\t\t}\r\n\t\t// >>includeEnd('debug');\r\n\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Plane(normal, distance);\r\n\t\t}\r\n\t\tVector3.clone(normal, result.normal);\r\n\t\tresult.distance = distance;\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic getPointDistance(plane: Plane, point: Vector3): number {\r\n\t\treturn Vector3.dot(plane.normal, point) + plane.distance;\r\n\t}\r\n\r\n\tstatic projectPointOntoPlane(plane: Plane, point: Vector3, result: Vector3): Vector3 {\r\n\t\tif (!defined(result)) {\r\n\t\t\tresult = new Vector3();\r\n\t\t}\r\n\r\n\t\t// projectedPoint = point - (normal.point + scale) * normal\r\n\t\tconst pointDistance = Plane.getPointDistance(plane, point);\r\n\t\tconst scaledNormal = Vector3.multiplyByScalar(plane.normal, pointDistance, scratchCartesian);\r\n\r\n\t\treturn Vector3.subtract(point, scaledNormal, result);\r\n\t}\r\n\r\n\tstatic transform(plane: Plane, transform: Matrix4, result: Plane): Plane {\r\n\t\tconst normal = plane.normal;\r\n\t\tconst distance = plane.distance;\r\n\t\tconst inverseTranspose = Matrix4.inverseTranspose(transform, scratchInverseTranspose);\r\n\t\tlet planeAsCartesian4 = Vector4.fromElements(normal.x, normal.y, normal.z, distance, scratchPlaneCartesian4);\r\n\t\tplaneAsCartesian4 = Matrix4.multiplyByVector(inverseTranspose, planeAsCartesian4, planeAsCartesian4);\r\n\r\n\t\t// Convert the transformed plane to Hessian Normal Form\r\n\t\tconst transformedNormal = Vector3.fromVector4(planeAsCartesian4, scratchTransformNormal);\r\n\r\n\t\tplaneAsCartesian4 = Vector4.divideByScalar(\r\n\t\t\tplaneAsCartesian4,\r\n\t\t\tVector3.magnitude(transformedNormal),\r\n\t\t\tplaneAsCartesian4\r\n\t\t);\r\n\r\n\t\treturn Plane.fromVector4(planeAsCartesian4, result);\r\n\t}\r\n\r\n\tstatic clone(plane: Plane, result: Plane): Plane {\r\n\t\tif (!defined(result)) {\r\n\t\t\treturn new Plane(plane.normal, plane.distance);\r\n\t\t}\r\n\r\n\t\tVector3.clone(plane.normal, result.normal);\r\n\t\tresult.distance = plane.distance;\r\n\r\n\t\treturn result;\r\n\t}\r\n\r\n\tstatic equals(left: Plane, right: Plane): boolean {\r\n\t\treturn left.distance === right.distance && Vector3.equals(left.normal, right.normal);\r\n\t}\r\n}\r\nconst scratchNormal = new Vector3();\r\nconst scratchCartesian = new Vector3();\r\nconst scratchInverseTranspose = new Matrix4();\r\nconst scratchPlaneCartesian4 = new Vector4();\r\nconst scratchTransformNormal = new Vector3();\r\n\r\nexport default Plane;\r\n","import Vector3 from \"../math/Vector3\";\r\nimport Vector4 from \"../math/Vector4\";\r\nimport defaultValue from \"../utils/defaultValue\";\r\nimport defined from \"../utils/defined\";\r\nimport { Intersect } from \"./WebGPUConstant\";\r\nimport Plane from \"../math/Plane\";\r\n\r\n/**\r\n * The culling volume defined by planes.\r\n *\r\n * @alias CullingVolume\r\n * @constructor\r\n *\r\n * @param {Vector4[]} [planes] An array of clipping planes.\r\n */\r\nclass CullingVolume {\r\n\tplanes: Plane[];\r\n\r\n\tpublic static MASK_OUTSIDE = 0xffffffff;\r\n\r\n\tpublic static MASK_INSIDE = 0x00000000;\r\n\r\n\tpublic static MASK_INDETERMINATE = 0x7fffffff;\r\n\r\n\tconstructor(planes?: Plane[]) {\r\n\t\tthis.planes = defaultValue(planes, [\r\n\t\t\tnew Plane(Vector3.UNIT_Z, 0.0),\r\n\t\t\tnew Plane(Vector3.UNIT_Z, 0.0),\r\n\t\t\tnew Plane(Vector3.UNIT_Z, 0.0),\r\n\t\t\tnew Plane(Vector3.UNIT_Z, 0.0),\r\n\t\t\tnew Plane(Vector3.UNIT_Z, 0.0),\r\n\t\t\tnew Plane(Vector3.UNIT_Z, 0.0)\r\n\t\t]);\r\n\t}\r\n\t/**\r\n\t * Constructs a culling volume from a bounding sphere. Creates six planes that create a box containing the sphere.\r\n\t * The planes are aligned to the x, y, and z axes in world coordinates.\r\n\t *\r\n\t * @param {BoundingSphere} boundingSphere The bounding sphere used to create the culling volume.\r\n\t * @param {CullingVolume} [result] The object onto which to store the result.\r\n\t * @returns {CullingVolume} The culling volume created from the bounding sphere.\r\n\t */\r\n\tstatic fromBoundingSphere(boundingSphere, result) {\r\n\t\tif (!defined(boundingSphere)) {\r\n\t\t\tthrow new Error(\"boundingSphere is required.\");\r\n\t\t}\r\n\t\tif (!defined(result)) {\r\n\t\t\tresult = new CullingVolume();\r\n\t\t}\r\n\r\n\t\tconst length = faces.length;\r\n\t\tconst planes = result.planes;\r\n\t\tplanes.length = 2 * length;\r\n\r\n\t\tconst center = boundingSphere.center;\r\n\t\tconst radius = boundingSphere.radius;\r\n\r\n\t\tlet planeIndex = 0;\r\n\r\n\t\tfor (let i = 0; i < length; ++i) {\r\n\t\t\tconst faceNormal = faces[i];\r\n\r\n\t\t\tlet plane0 = planes[planeIndex];\r\n\t\t\tlet plane1 = planes[planeIndex + 1];\r\n\r\n\t\t\tif (!defined(plane0)) {\r\n\t\t\t\tplane0 = planes[planeIndex] = new Vector4();\r\n\t\t\t}\r\n\t\t\tif (!defined(plane1)) {\r\n\t\t\t\tplane1 = planes[planeIndex + 1] = new Vector4();\r\n\t\t\t}\r\n\r\n\t\t\tVector3.multiplyByScalar(faceNormal, -radius, scratchPlaneCenter);\r\n\t\t\tVector3.add(center, scratchPlaneCenter, scratchPlaneCenter);\r\n\r\n\t\t\tplane0.x = faceNormal.x;\r\n\t\t\tplane0.y = faceNormal.y;\r\n\t\t\tplane0.z = faceNormal.z;\r\n\t\t\tplane0.w = -Vector3.dot(faceNormal, scratchPlaneCenter);\r\n\r\n\t\t\tVector3.multiplyByScalar(faceNormal, radius, scratchPlaneCenter);\r\n\t\t\tVector3.add(center, scratchPlaneCenter, scratchPlaneCenter);\r\n\r\n\t\t\tplane1.x = -faceNormal.x;\r\n\t\t\tplane1.y = -faceNormal.y;\r\n\t\t\tplane1.z = -faceNormal.z;\r\n\t\t\tplane1.w = -Vector3.dot(Vector3.negate(faceNormal, scratchPlaneNormal), scratchPlaneCenter);\r\n\r\n\t\t\tplaneIndex += 2;\r\n\t\t}\r\n\r\n\t\treturn result;\r\n\t}\r\n\t/**\r\n\t * Determines whether a bounding volume intersects the culling volume.\r\n\t *\r\n\t * @param {Object} boundingVolume The bounding volume whose intersection with the culling volume is to be tested.\r\n\t * @returns {Intersect}  Intersect.OUTSIDE, Intersect.INTERSECTING, or Intersect.INSIDE.\r\n\t */\r\n\tcomputeVisibility(boundingVolume) {\r\n\t\tif (!defined(boundingVolume)) {\r\n\t\t\tthrow new Error(\"boundingVolume is required.\");\r\n\t\t}\r\n\t\tconst planes = this.planes;\r\n\t\tlet intersecting = false;\r\n\t\tfor (let k = 0, len = planes.length; k < len; ++k) {\r\n\t\t\tconst result = boundingVolume.intersectPlane(planes[k]);\r\n\t\t\tif (result === Intersect.OUTSIDE) {\r\n\t\t\t\treturn Intersect.OUTSIDE;\r\n\t\t\t} else if (result === Intersect.INTERSECTING) {\r\n\t\t\t\tintersecting = true;\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\treturn intersecting ? Intersect.INTERSECTING : Intersect.INSIDE;\r\n\t}\r\n}\r\n\r\nconst faces = [new Vector3(), new Vector3(), new Vector3()];\r\nVector3.clone(Vector3.UNIT_X, faces[0]);\r\nVector3.clone(Vector3.UNIT_Y, faces[1]);\r\nVector3.clone(Vector3.UNIT_Z, faces[2]);\r\n\r\nconst scratchPlaneCenter = new Vector3();\r\nconst scratchPlaneNormal = new Vector3();\r\nconst scratchPlanes = new Vector4();\r\nconst scratchPlane = new Plane(new Vector3(1.0, 0.0, 0.0), 0.0);\r\n\r\nexport default CullingVolume;\r\n","import CullingVolume from \"../core/CullingVolume\";\nimport RenderObject from \"../core/RenderObject\";\nimport { RenderObjectType, UniformEnum } from \"../core/WebGPUTypes\";\nimport Matrix4 from \"../math/Matrix4\";\nimport Plane from \"../math/Plane\";\nimport Vector3 from \"../math/Vector3\";\nimport ShaderData from \"../render/ShaderData\";\nimport UniformBuffer from \"../render/UniformBuffer\";\n\nexport default class Camera extends RenderObject {\n\tprivate _viewMatrix: Matrix4;\n\tprotected _projectionMatrix: Matrix4;\n\tprivate _vpMatrix: Matrix4;\n\tcullingVolume: CullingVolume;\n\tprojectMatrixDirty: boolean;\n\tshaderData: ShaderData;\n\tnear: number;\n\tfar: number;\n\tconstructor() {\n\t\tsuper();\n\t\tthis._viewMatrix = undefined;\n\t\tthis.type = RenderObjectType.Camera;\n\t\tthis.cullingVolume = new CullingVolume();\n\t\tthis._viewMatrix = new Matrix4();\n\t\tthis._vpMatrix = new Matrix4();\n\t\tthis.projectMatrixDirty = true;\n\t\tthis.createShaderData();\n\t}\n\tget viewMatrix() {\n\t\tthis.updateMatrix();\n\t\tMatrix4.inverse(this.modelMatrix, this._viewMatrix);\n\t\treturn this._viewMatrix;\n\t}\n\tget projectionMatrix() {\n\t\tthis.updateProjectionMatrix();\n\t\treturn this._projectionMatrix;\n\t}\n\n\tget vpMatrix() {\n\t\tMatrix4.multiply(this.projectionMatrix, this.viewMatrix, this._vpMatrix);\n\t\treturn this._vpMatrix;\n\t}\n\n\tget inverseViewMatrix() {\n\t\tthis.updateMatrix();\n\t\treturn this.modelMatrix;\n\t}\n\tpublic updateProjectionMatrix() {}\n\t/**\n\t * get a culling volume for this frustum.\n\t */\n\tgetCullingVolume() {\n\t\tconst cloneViewMatrix = this.viewMatrix.clone(new Matrix4());\n\t\tconst vpMatrix = Matrix4.multiply(this.projectionMatrix, cloneViewMatrix, new Matrix4());\n\t\tconst planes = this.cullingVolume.planes;\n\t\tconst me = vpMatrix;\n\t\tconst me0 = me[0],\n\t\t\tme1 = me[1],\n\t\t\tme2 = me[2],\n\t\t\tme3 = me[3];\n\t\tconst me4 = me[4],\n\t\t\tme5 = me[5],\n\t\t\tme6 = me[6],\n\t\t\tme7 = me[7];\n\t\tconst me8 = me[8],\n\t\t\tme9 = me[9],\n\t\t\tme10 = me[10],\n\t\t\tme11 = me[11];\n\t\tconst me12 = me[12],\n\t\t\tme13 = me[13],\n\t\t\tme14 = me[14],\n\t\t\tme15 = me[15];\n\t\tplanes[0] = new Plane(new Vector3(me3 - me0, me7 - me4, me11 - me8), me15 - me12);\n\t\tplanes[0].normalize();\n\t\tplanes[1] = new Plane(new Vector3(me3 + me0, me7 + me4, me11 + me8), me15 + me12);\n\t\tplanes[1].normalize();\n\n\t\tplanes[2] = new Plane(new Vector3(me3 + me1, me7 + me5, me11 + me9), me15 + me13);\n\t\tplanes[2].normalize();\n\n\t\tplanes[3] = new Plane(new Vector3(me3 - me1, me7 - me5, me11 - me9), me15 - me13);\n\t\tplanes[3].normalize();\n\n\t\tplanes[4] = new Plane(new Vector3(me3 - me2, me7 - me6, me11 - me10), me15 - me14);\n\t\tplanes[4].normalize();\n\n\t\tplanes[5] = new Plane(new Vector3(me3 + me2, me7 + me6, me11 + me10), me15 + me14);\n\t\tplanes[5].normalize();\n\n\t\treturn this.cullingVolume;\n\t}\n\n\tcreateShaderData() {\n\t\tthis.shaderData = new ShaderData(\"camera\", 0, 1, 1);\n\t\tconst uniformBuffer = new UniformBuffer({ label: \"camera\" });\n\t\tuniformBuffer.setUniform(\n\t\t\t\"projectionMatrix\",\n\t\t\t() => {\n\t\t\t\treturn this.projectionMatrix;\n\t\t\t},\n\t\t\tUniformEnum.Mat4\n\t\t);\n\t\tuniformBuffer.setUniform(\n\t\t\t\"viewMatrix\",\n\t\t\t() => {\n\t\t\t\treturn this.viewMatrix;\n\t\t\t},\n\t\t\tUniformEnum.Mat4\n\t\t);\n\t\tuniformBuffer.setUniform(\n\t\t\t\"inverseViewMatrix\",\n\t\t\t() => {\n\t\t\t\treturn this.inverseViewMatrix;\n\t\t\t},\n\t\t\tUniformEnum.Mat4\n\t\t);\n\t\tuniformBuffer.setUniform(\n\t\t\t\"position\",\n\t\t\t() => {\n\t\t\t\treturn this.position;\n\t\t\t},\n\t\t\tUniformEnum.FloatVec3\n\t\t);\n\t\tthis.shaderData.setUniformBuffer(\"camera\", uniformBuffer);\n\t}\n}\n","import CullingVolume from \"../core/CullingVolume\";\r\nimport GMath from \"../math/Math\";\r\nimport Matrix4 from \"../math/Matrix4\";\r\nimport Camera from \"./Camera\";\r\nexport default class PerspectiveCamera extends Camera {\r\n\txOffset: number;\r\n\tyOffset: number;\r\n\tcullingVolume: CullingVolume;\r\n\tprivate _aspect: number;\r\n\tprivate _fov: number;\r\n\theight: number;\r\n\twidth: number;\r\n\tisPerspectiveCamera: boolean;\r\n\tnear: number;\r\n\tfar: number;\r\n\ttop: number;\r\n\tleft: number;\r\n\tconstructor(fov = 50, aspect = 1, near = 0.1, far = 2000) {\r\n\t\tsuper();\r\n\t\tthis._aspect = aspect;\r\n\t\tthis.fov = fov;\r\n\t\tthis.near = near;\r\n\t\tthis.far = far;\r\n\t\tthis.xOffset = 0;\r\n\t\tthis.yOffset = 0;\r\n\t\tthis.projectMatrixDirty = true;\r\n\t\tthis.updateCameraParms();\r\n\t\tthis.cullingVolume = new CullingVolume();\r\n\t\tthis.isPerspectiveCamera = true;\r\n\t}\r\n\tget aspect(): number {\r\n\t\treturn this._aspect;\r\n\t}\r\n\r\n\tset aspect(v: number) {\r\n\t\tthis.projectMatrixDirty = true;\r\n\t\tthis._aspect = v;\r\n\t}\r\n\tget fov(): number {\r\n\t\treturn this._fov;\r\n\t}\r\n\r\n\tset fov(v: number) {\r\n\t\tthis.projectMatrixDirty = true;\r\n\t\tthis._fov = v;\r\n\t}\r\n\tprivate updateCameraParms() {\r\n\t\tthis.top = this.near * Math.tan(0.5 * GMath.RADIANS_PER_DEGREE * this.fov);\r\n\t\tthis.height = 2 * this.top;\r\n\t\tthis.width = this.aspect * this.height;\r\n\t\tthis.left = -0.5 * this.width;\r\n\t}\r\n\tpublic updateProjectionMatrix() {\r\n\t\tif (this.projectMatrixDirty) {\r\n\t\t\tthis.updateCameraParms();\r\n\t\t\tthis._projectionMatrix = Matrix4.makePerspective(\r\n\t\t\t\tthis.left,\r\n\t\t\t\tthis.left + this.width,\r\n\t\t\t\tthis.top,\r\n\t\t\t\tthis.top - this.height,\r\n\t\t\t\tthis.near,\r\n\t\t\t\tthis.far\r\n\t\t\t);\r\n\t\t\tthis.projectMatrixDirty = false;\r\n\t\t}\r\n\t}\r\n}\r\n","import { BufferUsage } from \"../core/WebGPUConstant\";\nimport { UniformEnum } from \"../core/WebGPUTypes\";\nimport Matrix4 from \"../math/Matrix4\";\nimport ShaderData from \"../render/ShaderData\";\nimport UniformBuffer from \"../render/UniformBuffer\";\nimport PerspectiveCamera from \"./PerspectiveCamera\";\n\nexport default class PointLightShadowCamera extends PerspectiveCamera {\n\tpublic vpMatrixArray: Array<Matrix4>;\n\tpublic vpMatrixIndexArray: Array<number>;\n\n\tconstructor(fov = 50, aspect = 1, near = 0.1, far = 2000) {\n\t\tsuper(fov, aspect, near, far);\n\t\tthis.vpMatrixArray = [new Matrix4(), new Matrix4(), new Matrix4(), new Matrix4(), new Matrix4(), new Matrix4()];\n\t}\n\n\t// createShaderData() {\n\t// \tthis.shaderData = new ShaderData(\"camera\", 0, 1, 1);\n\n\t// \tconst uniformBuffer = new UniformBuffer({\n\t// \t\tlabel: \"pointLightShadowCamera\",\n\t// \t\ttype: \"read-only-storage\",\n\t// \t\tusage: BufferUsage.Storage | BufferUsage.CopyDst,\n\t// \t\thasDynamicOffset: true,\n\t// \t\tminBindingSize: 64,\n\t// \t\tmaxOffset: 6,\n\t// \t\tsize: 256 * 6\n\t// \t});\n\t// \tuniformBuffer.setMatrix4Array(\n\t// \t\t\"vpMatrixArray\",\n\t// \t\t() => {\n\t// \t\t\tif (this.vpMatrixArray.length != 6) throw new Error(\"pointLightShadowCamera uniformBuffer has Error\");\n\n\t// \t\t\treturn this.vpMatrixArray;\n\t// \t\t},\n\t// \t\t6,\n\t// \t\t256\n\t// \t);\n\n\t// \tthis.shaderData.setUniformBuffer(\"pointLightShadowCamera\", uniformBuffer);\n\t// \tthis.shaderData.setDefine(\"isPointLightShadowMap\", true);\n\t// }\n\n\tcreateShaderData() {\n\t\tthis.shaderData = new ShaderData(\"camera\", 0, 1, 1);\n\n\t\tconst uniformBuffer = new UniformBuffer({\n\t\t\tlabel: \"pointLightShadowCamera\",\n\t\t\ttype: \"read-only-storage\",\n\t\t\tusage: BufferUsage.Storage | BufferUsage.CopyDst\n\t\t});\n\t\tuniformBuffer.setUniform(\n\t\t\t\"vpMatrix\",\n\t\t\t() => {\n\t\t\t\treturn this.vpMatrix;\n\t\t\t},\n\t\t\tUniformEnum.Mat4\n\t\t);\n\n\t\tthis.shaderData.setUniformBuffer(\"pointLightShadowCamera\", uniformBuffer);\n\t\tthis.shaderData.setDefine(\"isPointLightShadowMap\", true);\n\t}\n\n\tupdateVpMatrixArrayAndIndex(index: number) {\n\t\tMatrix4.clone(this.vpMatrix, this.vpMatrixArray[index]);\n\t}\n}\n","import Camera from \"../../camera/Camera\";\r\nimport { TextureFormat, TextureSampleType, TextureUsage } from \"../../core/WebGPUConstant\";\r\nimport Vector2 from \"../../math/Vector2\";\r\nimport Vector4 from \"../../math/Vector4\";\r\nimport Texture from \"../../render/Texture\";\r\nimport { Light } from \"../Light\";\r\nexport class BaseShadow {\r\n\tprotected _shadowMapSize: Vector2;\r\n\tprotected _camera: Camera;\r\n\tprotected _shadowMap: Texture;\r\n\tpublic type: string;\r\n\tpublic _viewports: Array<Vector4>;\r\n\tpublic viewportSize: Vector2;\r\n\tpublic currentViewportIndex: number;\r\n\tpublic viewPortDirty: boolean;\r\n\tpublic vpMatrixDirty: boolean;\r\n\r\n\tconstructor(shadowMapSize: Vector2, camera: Camera) {\r\n\t\tthis._shadowMapSize = shadowMapSize;\r\n\t\tthis._camera = camera;\r\n\t\tthis.viewPortDirty = true;\r\n\t\tthis.vpMatrixDirty = true;\r\n\r\n\t\tthis._init();\r\n\t}\r\n\r\n\tget camera() {\r\n\t\treturn this._camera;\r\n\t}\r\n\r\n\tget shadowMapSize() {\r\n\t\treturn this._shadowMapSize;\r\n\t}\r\n\r\n\tget viewports() {\r\n\t\treturn this._viewports;\r\n\t}\r\n\r\n\tpublic getShadowMapTexture() {\r\n\t\treturn this._shadowMap;\r\n\t}\r\n\r\n\tprotected _init() {\r\n\t\tthis._initShadowMapTexture();\r\n\t}\r\n\r\n\tprotected _initShadowMapTexture() {\r\n\t\tthis._createShadowMapTexture();\r\n\t}\r\n\r\n\tprotected _createShadowMapTexture() {\r\n\t\tthis._shadowMap = new Texture({\r\n\t\t\tsize: {\r\n\t\t\t\twidth: this._shadowMapSize.x,\r\n\t\t\t\theight: this._shadowMapSize.y,\r\n\t\t\t\tdepth: 1\r\n\t\t\t},\r\n\t\t\tfixedSize: true,\r\n\t\t\tsampleType: TextureSampleType.Depth,\r\n\t\t\tformat: TextureFormat.Depth24Plus,\r\n\t\t\tusage: TextureUsage.RenderAttachment | TextureUsage.TextureBinding | TextureUsage.CopySrc\r\n\t\t});\r\n\t}\r\n\r\n\tpublic update(light: Light) {}\r\n}\r\n","import PointLightShadowCamera from \"../../camera/PointLightShadowCamera\";\r\nimport Vector2 from \"../../math/Vector2\";\r\nimport Vector3 from \"../../math/Vector3\";\r\nimport Vector4 from \"../../math/Vector4\";\r\nimport { PointLight } from \"../PointLight\";\r\nimport { BaseShadow } from \"./BaseShadow\";\r\n\r\nexport class PointLightShadow extends BaseShadow {\r\n\tpublic type: string;\r\n\tprivate _pointLightShadowLookDirections: Array<Vector3>;\r\n\tprivate _pointLightShadowUps: Array<Vector3>;\r\n\tvpMatrixArrayDirty: boolean;\r\n\r\n\tget camera(): PointLightShadowCamera {\r\n\t\treturn this._camera as PointLightShadowCamera;\r\n\t}\r\n\r\n\tconstructor() {\r\n\t\tconst camera = new PointLightShadowCamera(90, 1, 0.1, 500);\r\n\t\tsuper(new Vector2(1536, 1024), camera);\r\n\t\tthis.viewportSize = new Vector2(512, 512);\r\n\t\tthis.currentViewportIndex = 0;\r\n\t\tthis.type = \"pointLightShadow\";\r\n\t\tthis.vpMatrixArrayDirty = true;\r\n\r\n\t\tthis._viewports = [\r\n\t\t\t// positive X 0\r\n\t\t\tnew Vector4(0, 0, 1 / 3, 1 / 2),\r\n\t\t\t// negative X 1\r\n\t\t\tnew Vector4(1, 0, 1 / 3, 1 / 2),\r\n\t\t\t// positive Z 2\r\n\t\t\tnew Vector4(2, 0, 1 / 3, 1 / 2),\r\n\t\t\t// negative Z 3\r\n\t\t\tnew Vector4(0, 1, 1 / 3, 1 / 2),\r\n\t\t\t// positive Y 4\r\n\t\t\tnew Vector4(1, 1, 1 / 3, 1 / 2),\r\n\t\t\t// negative Y 5\r\n\t\t\tnew Vector4(2, 1, 1 / 3, 1 / 2)\r\n\t\t];\r\n\r\n\t\tthis._pointLightShadowLookDirections = [\r\n\t\t\tnew Vector3(1, 0, 0),\r\n\t\t\tnew Vector3(-1, 0, 0),\r\n\t\t\tnew Vector3(0, 0, 1),\r\n\t\t\tnew Vector3(0, 0, -1),\r\n\t\t\tnew Vector3(0, 1, 0),\r\n\t\t\tnew Vector3(0, -1, 0)\r\n\t\t];\r\n\r\n\t\tthis._pointLightShadowUps = [\r\n\t\t\tnew Vector3(0, 1, 0),\r\n\t\t\tnew Vector3(0, 1, 0),\r\n\t\t\tnew Vector3(0, 1, 0),\r\n\t\t\tnew Vector3(0, 1, 0),\r\n\t\t\tnew Vector3(0, 0, 1),\r\n\t\t\tnew Vector3(0, 0, -1)\r\n\t\t];\r\n\t}\r\n\r\n\tpublic update(light: PointLight) {\r\n\t\tthis.updateMatrices(light);\r\n\t}\r\n\r\n\tupdateMatrices(light: PointLight) {\r\n\t\tif (this.camera instanceof PointLightShadowCamera) {\r\n\t\t\tthis.camera.position.copy(light.position);\r\n\t\t\tconst target = Vector3.clone(light.position);\r\n\t\t\ttarget.add(this._pointLightShadowLookDirections[this.currentViewportIndex]);\r\n\t\t\tthis.camera.up.copy(this._pointLightShadowUps[this.currentViewportIndex]);\r\n\t\t\tconst { x, y, z } = target;\r\n\t\t\tthis.camera.lookAt(x, y, z);\r\n\t\t\tthis.camera.updateMatrix();\r\n\t\t\tthis.camera.updateVpMatrixArrayAndIndex(this.currentViewportIndex);\r\n\t\t\tif (this.currentViewportIndex == 5) this.vpMatrixArrayDirty = true;\r\n\t\t}\r\n\t}\r\n}\r\n","import { LightType } from \"../core/WebGPUTypes\";\r\nimport Vector3 from \"../math/Vector3\";\r\nimport { Light } from \"./Light\";\r\nimport { PointLightShadow } from \"./shadows/PointLightShadow\";\r\n\r\nexport class PointLight extends Light {\r\n\tprivate _distance: number;\r\n\tprivate _decay: number;\r\n\tdistanceDirty: boolean;\r\n\tdecayDirty: boolean;\r\n\r\n\tget shadow(): PointLightShadow {\r\n\t\treturn this._shadow as PointLightShadow;\r\n\t}\r\n\r\n\tset shadow(value: PointLightShadow) {\r\n\t\tthis.shadowDirty = true;\r\n\t\tthis._shadow = value;\r\n\t}\r\n\r\n\tconstructor(color: Vector3, intensity: number, distance = 0, decay = 4, openShadow = true) {\r\n\t\tsuper(color, intensity);\r\n\t\tthis._distance = distance;\r\n\t\tthis._decay = decay;\r\n\t\tthis.distanceDirty = true;\r\n\t\tthis.decayDirty = true;\r\n\t\tthis.lightType = LightType.PointLight;\r\n\t\tif (openShadow) this.shadow = new PointLightShadow();\r\n\t}\r\n\tset distance(value) {\r\n\t\tthis.distanceDirty = true;\r\n\t\tthis._distance = value;\r\n\t}\r\n\tget distance() {\r\n\t\treturn this._distance;\r\n\t}\r\n\tset decay(value) {\r\n\t\tthis.decayDirty = true;\r\n\t\tthis._decay = value;\r\n\t}\r\n\tget decay() {\r\n\t\treturn this._decay;\r\n\t}\r\n}\r\n// uniform\r\n// color: {},\r\n// position: {},\r\n// decay: {},\r\n// distance: {}\r\n","import Camera from \"../camera/Camera\";\nimport { FrameState } from \"../core/FrameState\";\nimport LightManger from \"../core/LightManger\";\nimport RenderQueue from \"../core/RenderQueue\";\nimport { CommandSubType } from \"../core/WebGPUConstant\";\nimport { Light } from \"../light/Light\";\nimport { PointLight } from \"../light/PointLight\";\nimport { BaseShadow } from \"../light/shadows/BaseShadow\";\nimport { PointLightShadow } from \"../light/shadows/PointLightShadow\";\nimport ShaderMaterial from \"../material/ShaderMaterial\";\nimport Attachment from \"../render/Attachment\";\nimport Context from \"../render/Context\";\nimport RenderTarget from \"../render/RenderTarget\";\nimport Texture from \"../render/Texture\";\nimport getVertFrag from \"../shader/Shaders\";\nimport Pass from \"./Pass\";\nexport class ShadowPass extends Pass {\n\tpublic shadowMaterial: ShaderMaterial;\n\t_testTexture: Texture;\n\tconstructor(context: Context) {\n\t\tsuper(context);\n\t\tthis.init(context);\n\t}\n\trender(frameState: FrameState, camera?: Camera) {\n\t\tconst { renderQueue, context, lightManger } = frameState;\n\t\tconst lights = lightManger.getAllLights();\n\t\tif (lights.length === 0) return;\n\n\t\tfor (let i = 0; i < lights.length; i++) {\n\t\t\tconst light: PointLight | Light = lights[i];\n\t\t\tconst shadow = light.shadow;\n\t\t\tif (!shadow) continue;\n\t\t\t// this._testTexture = context.lightManger._testTexture\n\t\t\t// this.beforeRender({ shadow });\n\t\t\tif (shadow instanceof PointLightShadow && light instanceof PointLight) {\n\t\t\t\tfor (let i = 0; i < shadow.viewports.length; i++) {\n\t\t\t\t\t// 动态buffer暂未调通，先以此种方式解决\n\t\t\t\t\tswitch (i) {\n\t\t\t\t\t\tcase 0:\n\t\t\t\t\t\t\tthis.renderTarget.depthAttachment.op = \"clear\";\n\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\tdefault:\n\t\t\t\t\t\t\tthis.renderTarget.depthAttachment.op = \"load\";\n\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t\tthis.beforeRender({ shadow });\n\n\t\t\t\t\tconst viewport = shadow.viewports[i];\n\t\t\t\t\tconst viewportSize = shadow.viewportSize;\n\t\t\t\t\tshadow.currentViewportIndex = i;\n\t\t\t\t\tshadow.update(light);\n\t\t\t\t\t// light.forceUpdate = true;\n\t\t\t\t\tcontext.setViewPort(\n\t\t\t\t\t\tviewport.x * viewportSize.x,\n\t\t\t\t\t\tviewport.y * viewportSize.y,\n\t\t\t\t\t\tviewportSize.x,\n\t\t\t\t\t\tviewportSize.y\n\t\t\t\t\t);\n\t\t\t\t\tcontext.setScissorTest(\n\t\t\t\t\t\tviewport.x * viewportSize.x,\n\t\t\t\t\t\tviewport.y * viewportSize.y,\n\t\t\t\t\t\tviewportSize.x,\n\t\t\t\t\t\tviewportSize.y\n\t\t\t\t\t);\n\t\t\t\t\tthis.subRender(renderQueue, shadow, lightManger);\n\t\t\t\t\tsuper.afterRender();\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tthis.renderTarget.depthAttachment.op = \"clear\";\n\t\t\t\tthis.beforeRender({ shadow });\n\t\t\t\tshadow.update(light);\n\t\t\t\tcontext.setViewPort(0, 0, shadow.shadowMapSize.x, shadow.shadowMapSize.y);\n\t\t\t\tcontext.setScissorTest(0, 0, shadow.shadowMapSize.x, shadow.shadowMapSize.y);\n\t\t\t\tthis.subRender(renderQueue, shadow, lightManger);\n\t\t\t\tsuper.afterRender();\n\t\t\t}\n\t\t}\n\t\t// super.afterRender();\n\t\tlightManger.updateLightShadow();\n\t\tcontext.resetViewPortToFullCanvas();\n\t}\n\n\tsubRender(renderQueue: RenderQueue, shadow: BaseShadow, lightManger: LightManger) {\n\t\trenderQueue.sort();\n\t\t// renderQueue.preRender(shadow.camera, this.context, this.passRenderEncoder);\n\t\trenderQueue.transparentRender(\n\t\t\tshadow.camera,\n\t\t\tthis.context,\n\t\t\tthis.passRenderEncoder,\n\t\t\tthis.shadowMaterial,\n\t\t\tCommandSubType.Shadow,\n\t\t\tlightManger\n\t\t);\n\t\trenderQueue.opaqueRender(\n\t\t\tshadow.camera,\n\t\t\tthis.context,\n\t\t\tthis.passRenderEncoder,\n\t\t\tthis.shadowMaterial,\n\t\t\tCommandSubType.Shadow,\n\t\t\tlightManger\n\t\t);\n\t}\n\n\t// getDepthTexture(): Texture {\n\t// \treturn this._testTexture;\n\t// }\n\tbeforeRender(options: { shadow: BaseShadow }) {\n\t\tconst { shadow } = options;\n\t\tthis.setRenderTarget(shadow);\n\t\tsuper.beforeRender();\n\t}\n\tpublic setSize(width: number, height: number): void {\n\t\tthis.renderTarget.setSize(width, height, 1);\n\t}\n\tprivate setRenderTarget(shadow: BaseShadow) {\n\t\tthis.renderTarget.depthAttachment.texture = shadow.getShadowMapTexture();\n\t}\n\n\tprivate init(context: Context) {\n\t\tthis.createRenderTarget(context);\n\t\tthis.createShadowMaterial();\n\t}\n\tprivate createRenderTarget(context: Context) {\n\t\tconst depthAttachment = new Attachment(1.0, { texture: undefined });\n\t\tthis.renderTarget = new RenderTarget(\"render\", [], depthAttachment);\n\t}\n\n\tprivate createShadowMaterial() {\n\t\tconst shadowMapShaderFunction = (defines = {}) => {\n\t\t\tconst finalDefines = Object.assign(\n\t\t\t\t{\n\t\t\t\t\tselfBinding: 0,\n\t\t\t\t\tcameraBinding: 0,\n\t\t\t\t\tpositionLocation: 0\n\t\t\t\t},\n\t\t\t\tdefines\n\t\t\t);\n\t\t\treturn getVertFrag(\"shadowMap\", finalDefines).vert;\n\t\t};\n\n\t\tthis.shadowMaterial = new ShaderMaterial({\n\t\t\ttype: \"shadowMaterial\",\n\t\t\tuniforms: {\n\t\t\t\tmodelMatrix: { type: \"mat4x4<f32>\", value: null }\n\t\t\t},\n\t\t\tvert: shadowMapShaderFunction,\n\t\t\tfrag: undefined,\n\t\t\tlight: false // TODO:先true，false有显示bug\n\t\t});\n\t}\n}\n","import Camera from \"../camera/Camera\";\nimport { FrameState } from \"../core/FrameState\";\nimport { BasicPass } from \"../pass/BasicPass\";\nimport { ShadowPass } from \"../pass/ShadowPass\";\nimport Context from \"../render/Context\";\nimport Texture from \"../render/Texture\";\nimport IBaseRenderLine from \"./IBaseRenderLine\";\n\nexport default class ForwardRenderLine implements IBaseRenderLine {\n\tprivate basicPass: BasicPass;\n\tprotected shadowPass: ShadowPass;\n\tconstructor(public context: Context) {\n\t\tthis.basicPass = new BasicPass(context);\n\t\tthis.shadowPass = new ShadowPass(context);\n\t}\n\tgetOutputTexture(): Texture {\n\t\treturn this.basicPass.getColorTexture(0);\n\t\t// return this.shadowPass.getDepthTexture()\n\t}\n\trender(frameState: FrameState, camera?: Camera) {\n\t\tthis.shadowPass.render(frameState, camera);\n\n\t\tthis.basicPass.beforeRender(frameState);\n\t\tthis.basicPass.render(frameState, camera);\n\t\tthis.basicPass.afterRender();\n\t}\n\tsetSize(width: number, height: number) {\n\t\tthis.basicPass.setSize(width, height);\n\t\tthis.shadowPass.setSize(width, height);\n\t}\n\tdestroy() {\n\t\tthis.basicPass = undefined;\n\t}\n}\n","import Camera from \"./camera/Camera\";\nimport PerspectiveCamera from \"./camera/PerspectiveCamera\";\nimport { EventDispatcher } from \"./core/EventDispatcher\";\nimport { FrameState, Background } from \"./core/FrameState\";\nimport LightManger from \"./core/LightManger\";\nimport MeshManger from \"./core/MeshManger\";\nimport textureCache from \"./core/TextureCache\";\nimport { Instance, RenderObjectType } from \"./core/WebGPUTypes\";\nimport { Light } from \"./light/Light\";\nimport { Mesh } from \"./mesh/Mesh\";\nimport Node from \"./mesh/Node\";\nimport PostEffect from \"./post-process/PostEffect\";\nimport PostEffectCollection from \"./post-process/PostEffectCollection\";\nimport Context from \"./render/Context\";\nimport { ViewPort } from \"./render/RenderState\";\nimport ForwardRenderLine from \"./renderpipeline/ForwardRenderLine\";\nimport IBaseRenderLine from \"./renderpipeline/IBaseRenderLine\";\n\nexport class Scene extends EventDispatcher {\n\tcamera: PerspectiveCamera;\n\tcontext: Context;\n\trequestAdapter: object;\n\tdeviceDescriptor: object;\n\tpresentationContextDescriptor: object;\n\tcontainer: HTMLDivElement;\n\tframeState: FrameState;\n\tcurrentRenderPipeline: IBaseRenderLine;\n\tviewport: ViewPort;\n\tbackground: Background;\n\tprivate ready: boolean;\n\tprivate inited: boolean;\n\tprivate meshManger: MeshManger;\n\tprivate postEffectCollection: PostEffectCollection;\n\tprivate lightManger: LightManger;\n\tconstructor(options) {\n\t\tsuper();\n\t\tthis.container =\n\t\t\toptions.container instanceof HTMLDivElement\n\t\t\t\t? options.container\n\t\t\t\t: document.getElementById(options.container);\n\t\tthis.meshManger = new MeshManger();\n\t\tthis.postEffectCollection = new PostEffectCollection();\n\t\tthis.context = new Context({\n\t\t\tcanvas: null,\n\t\t\tcontainer: this.container,\n\t\t\tpixelRatio: 1\n\t\t});\n\t\tthis.requestAdapter = options.requestAdapter || {};\n\t\tthis.deviceDescriptor = options.deviceDescriptor || {};\n\t\tthis.presentationContextDescriptor = options.presentationContextDescriptor;\n\t\tthis.ready = false;\n\t\tthis.inited = false;\n\t\tthis.lightManger = new LightManger({ openShadow: true });\n\t\tthis.background = options.background;\n\t}\n\tprivate async init() {\n\t\tawait this.context.init(this.requestAdapter, this.deviceDescriptor, this.presentationContextDescriptor);\n\t\tthis.currentRenderPipeline = new ForwardRenderLine(this.context);\n\t\tthis.frameState = new FrameState(this.context, this.lightManger, FrameState.getFrameStateOptionsByScene(this));\n\t\tthis.viewport = new ViewPort(0, 0, this.context.presentationSize.width, this.context.presentationSize.height);\n\t\tthis.ready = true;\n\t}\n\tadd(instance: Instance) {\n\t\tif (\n\t\t\t[RenderObjectType.Node, RenderObjectType.Skybox, RenderObjectType.Mesh, RenderObjectType.Debug].includes(\n\t\t\t\tinstance.type\n\t\t\t)\n\t\t) {\n\t\t\tthis.meshManger.add(<Mesh>instance);\n\t\t} else if (instance.type == RenderObjectType.Light) {\n\t\t\tthis.lightManger.add(<Light>instance);\n\t\t} else if (instance.type == RenderObjectType.PostEffect) {\n\t\t\tthis.postEffectCollection.add(<PostEffect>instance);\n\t\t}\n\t}\n\tremove(instance: Instance) {\n\t\tif ([RenderObjectType.Node, RenderObjectType.Skybox, RenderObjectType.Mesh].includes(instance.type)) {\n\t\t\tthis.meshManger.remove(<Mesh>instance);\n\t\t} else if (instance.type == RenderObjectType.Light) {\n\t\t\tthis.lightManger.remove(<Light>instance);\n\t\t} else if (instance.type == RenderObjectType.PostEffect) {\n\t\t\tthis.postEffectCollection.remove(<PostEffect>instance);\n\t\t}\n\t}\n\tsetCamera(camera) {\n\t\tthis.camera = camera;\n\t}\n\tresize(width: number, height: number) {\n\t\tthis.context.resize(width, height);\n\t\tthis?.currentRenderPipeline?.setSize(width, height);\n\t\tthis?.postEffectCollection?.setSize(width, height);\n\t}\n\tasync render(node?: Node, camera?: Camera) {\n\t\tif (!this.inited) {\n\t\t\tthis.inited = true;\n\t\t\tawait this.init();\n\t\t\tthis.update(node, camera);\n\t\t\tthis.afterRender();\n\t\t} else {\n\t\t\tthis.update(node, camera);\n\t\t\tthis.afterRender();\n\t\t}\n\t}\n\n\tafterRender() {\n\t\t// TODO\n\t}\n\n\tpublic setViewPort(x: number, y: number, width: number, height: number): boolean {\n\t\tif (!this.ready) return false;\n\t\tthis.context.setViewPort(x, y, width, height);\n\t\treturn true;\n\t}\n\tpublic setScissorTest(x: number, y: number, width: number, height: number): boolean {\n\t\tif (!this.ready) return false;\n\t\tthis.context.setScissorTest(x, y, width, height);\n\t\treturn true;\n\t}\n\tprivate update(node?: Node, camera?: Camera) {\n\t\tif (!this.ready) return;\n\t\t// 释放纹理\n\t\ttextureCache.releasedTextures();\n\t\t// 更新FrameState\n\t\tthis.frameState.update(camera ?? this.camera, FrameState.getFrameStateOptionsByScene(this));\n\t\t// update primitive and select\n\t\t(node ?? this.meshManger).update(this.frameState, camera ?? this.camera);\n\t\t// selct renderPipeline\n\t\tthis.currentRenderPipeline.render(this.frameState, camera ?? this.camera);\n\t\t// 后处理\n\t\tthis.postEffectCollection.render(this.context, this.currentRenderPipeline.getOutputTexture());\n\t}\n}\n","import IClone from \"../core/IClone\";\nimport { RenderObjectType } from \"../core/WebGPUTypes\";\nimport Geometry from \"../geometry/Geometry\";\nimport { Mesh } from \"../mesh/Mesh\";\nimport { Float32Attribute } from \"../render/Attribute\";\nimport Context from \"../render/Context\";\nimport { Primitive, RenderState, Target } from \"../render/RenderState\";\nimport RenderTarget from \"../render/RenderTarget\";\nimport Sampler from \"../render/Sampler\";\nimport Texture from \"../render/Texture\";\n\nexport default class PostEffect implements IClone {\n\twidth: number;\n\n\theight: number;\n\n\tdefaultSampler: Sampler;\n\n\tresolveToCanvas: boolean;\n\n\tcurrentRenderTarget: RenderTarget;\n\n\tfullScreenQuad: Mesh;\n\n\trenderState: RenderState;\n\n\tid: string;\n\n\tpriority: number;\n\n\tisPostEffect: boolean;\n\n\ttype: RenderObjectType;\n\n\tconstructor(width: number, height: number, id: string) {\n\t\tthis.width = width;\n\t\tthis.height = height;\n\t\tthis.initDefaultParms();\n\t\tthis.id = id;\n\t\tthis.priority = 0;\n\t\tthis.isPostEffect = true;\n\t\tthis.type = RenderObjectType.PostEffect;\n\t}\n\trender(context: Context, colorTexture: Texture): Texture {\n\t\treturn null;\n\t}\n\tsetSize(width: number, height: number): void {\n\t\t// todo ;\n\t}\n\tdestroy() {\n\t\tthis?.currentRenderTarget?.destroy();\n\t}\n\tprotected renderMesh(context: Context) {\n\t\tthis.fullScreenQuad.material.dirty = true;\n\t\tthis.fullScreenQuad.material.update();\n\t\tconst drawComand = this.fullScreenQuad.getDrawCommand();\n\t\tconst currentRenderPassEncoder = this.currentRenderTarget.beginRenderPass(context.device);\n\t\tdrawComand.render({ device: context.device, passEncoder: currentRenderPassEncoder });\n\t\tthis.currentRenderTarget.endRenderPass();\n\t}\n\tprivate initDefaultParms() {\n\t\tconst geometry = new Geometry({});\n\t\tgeometry.setAttribute(\n\t\t\tnew Float32Attribute(\"position\", [-1.0, 1.0, -1.0, -1.0, 1.0, -1.0, 1.0, -1.0, 1.0, 1.0, -1.0, 1.0], 2)\n\t\t);\n\t\tgeometry.count = 6;\n\t\t// rs\n\t\tconst primitive = new Primitive();\n\t\tconst target = new Target();\n\t\t// target.format=TextureFormat.RGBA8Unorm\n\t\tconst renderState = new RenderState();\n\t\trenderState.primitive = primitive;\n\t\trenderState.targets = [target];\n\t\tthis.renderState = renderState;\n\t\tthis.fullScreenQuad = new Mesh(geometry);\n\n\t\tthis.defaultSampler = new Sampler();\n\t}\n}\n","import { TextureFormat, TextureUsage } from \"../core/WebGPUConstant\";\nimport { Uniforms } from \"../core/WebGPUTypes\";\nimport ShaderMaterial from \"../material/ShaderMaterial\";\nimport Color from \"../math/Color\";\nimport Vector2 from \"../math/Vector2\";\nimport Vector3 from \"../math/Vector3\";\nimport Attachment from \"../render/Attachment\";\nimport Context from \"../render/Context\";\nimport RenderTarget from \"../render/RenderTarget\";\nimport Texture from \"../render/Texture\";\nimport getVertFrag from \"../shader/Shaders\";\nimport PostEffect from \"./PostEffect\";\n\nexport default class BloomPostEffect extends PostEffect {\n\tstatic BlurDirectionX = new Vector2(1.0, 0.0);\n\tstatic BlurDirectionY = new Vector2(0.0, 1.0);\n\tstrength: number;\n\tradius: number;\n\tthreshold: number;\n\trenderTargetsHorizontal: RenderTarget[];\n\trenderTargetsVertical: RenderTarget[];\n\tnMips: number;\n\trenderTargetBright: RenderTarget;\n\tmaterialHighPassFilter: ShaderMaterial;\n\thighPassUniforms: Uniforms;\n\tcompositeMaterial: ShaderMaterial;\n\tseparableBlurMaterials: ShaderMaterial[];\n\tseparableBlurYMaterials: ShaderMaterial[];\n\tblendUniforms: Uniforms;\n\tblendMaterial: ShaderMaterial;\n\tblendTarget: RenderTarget;\n\n\tconstructor(options: BloomPostEffectProps) {\n\t\tsuper(options.width, options.height, \"bloom\");\n\t\tthis.strength = options.strength;\n\t\tthis.radius = options.radius;\n\t\tthis.threshold = options.threshold;\n\t\tthis.init();\n\t}\n\tdestroy() {\n\t\tthis.renderTargetBright.destroy();\n\t}\n\trender(context: Context, colorTexture: Texture): Texture {\n\t\t// 1. Extract Bright Areas\n\t\tthis.currentRenderTarget = this.renderTargetBright;\n\t\tthis.highPassUniforms.tDiffuse.value = colorTexture;\n\t\tthis.fullScreenQuad.material = this.materialHighPassFilter;\n\t\tthis.renderMesh(context);\n\t\t// 2. Blur All the mips progressively\n\t\tlet inputRenderTarget = this.renderTargetBright;\n\t\tfor (let i = 0; i < this.nMips; i++) {\n\t\t\tthis.fullScreenQuad.material = this.separableBlurMaterials[i];\n\n\t\t\tthis.separableBlurMaterials[i].uniforms.tDiffuse.value = inputRenderTarget.getColorTexture();\n\t\t\tthis.separableBlurMaterials[i].uniforms.direction.value = BloomPostEffect.BlurDirectionX;\n\t\t\tthis.currentRenderTarget = this.renderTargetsHorizontal[i];\n\n\t\t\tthis.renderMesh(context);\n\t\t\tthis.fullScreenQuad.material = this.separableBlurYMaterials[i];\n\t\t\tthis.separableBlurYMaterials[i].uniforms.tDiffuse.value = this.renderTargetsHorizontal[i].getColorTexture();\n\t\t\tthis.separableBlurYMaterials[i].uniforms.direction.value = BloomPostEffect.BlurDirectionY;\n\t\t\tthis.currentRenderTarget = this.renderTargetsVertical[i];\n\n\t\t\tthis.renderMesh(context);\n\n\t\t\tinputRenderTarget = this.renderTargetsVertical[i];\n\t\t}\n\t\t// Composite All the mips\n\t\tthis.fullScreenQuad.material = this.compositeMaterial;\n\t\tthis.currentRenderTarget = this.renderTargetsHorizontal[0];\n\t\tthis.renderMesh(context);\n\t\t// blend\n\t\tthis.blendUniforms.baseColorTexture.value = colorTexture;\n\t\tthis.fullScreenQuad.material = this.blendMaterial;\n\t\tthis.currentRenderTarget = this.blendTarget;\n\t\tthis.renderMesh(context);\n\t\treturn this.currentRenderTarget.getColorTexture();\n\t}\n\tsetSize(width: number, height: number): void {\n\t\tthis?.renderTargetsHorizontal?.forEach((renderTarget) => renderTarget.setSize(width, height, 1));\n\t\tthis?.renderTargetsVertical?.forEach((renderTarget) => renderTarget.setSize(width, height, 1));\n\t\tthis?.renderTargetBright?.setSize?.(width, height, 1);\n\t\tthis?.blendTarget?.setSize?.(width, height, 1);\n\t}\n\tprivate init() {\n\t\tthis.renderTargetsHorizontal = [];\n\t\tthis.renderTargetsVertical = [];\n\t\tthis.nMips = 5;\n\t\tlet resx = Math.round(this.width / 2);\n\t\tlet resy = Math.round(this.height / 2);\n\n\t\tthis.renderTargetBright = new RenderTarget(\"render\", [this.createColorAttachment(resx, resy)]);\n\n\t\tfor (let i = 0; i < this.nMips; i++) {\n\t\t\tconst renderTargetHorizonal = new RenderTarget(\"render\", [this.createColorAttachment(resx, resy)]);\n\t\t\tthis.renderTargetsHorizontal.push(renderTargetHorizonal);\n\t\t\tconst renderTargetVertical = new RenderTarget(\"render\", [this.createColorAttachment(resx, resy)]);\n\t\t\tthis.renderTargetsVertical.push(renderTargetVertical);\n\t\t\tresx = Math.round(resx / 2);\n\t\t\tresy = Math.round(resy / 2);\n\t\t}\n\t\t// luminosity high pass material\n\t\tthis.highPassUniforms = {\n\t\t\ttDiffuse: { type: \"texture\", value: null },\n\t\t\ttSampler: {\n\t\t\t\ttype: \"sampler\",\n\t\t\t\tvalue: this.defaultSampler\n\t\t\t},\n\t\t\tluminosityThreshol: { type: \"float\", value: this.threshold },\n\t\t\tsmoothWidth: { type: \"float\", value: 0.01 },\n\t\t\tdefaultColor: { type: \"color\", value: new Color(0.0, 0, 0) },\n\t\t\tdefaultOpacity: { type: \"float\", value: 1.0 }\n\t\t};\n\t\tconst shader = getVertFrag(\"luminosityHigh\", { positionLocation: 0 });\n\t\tthis.materialHighPassFilter = new ShaderMaterial({\n\t\t\ttype: \"bloom\",\n\t\t\tuniforms: this.highPassUniforms,\n\t\t\tvert: shader.vert,\n\t\t\tfrag: shader.frag\n\t\t});\n\t\t// Gaussian Blur Materials\n\t\tthis.materialHighPassFilter.renderState = this.renderState;\n\t\tthis.separableBlurMaterials = [];\n\t\tthis.separableBlurYMaterials = [];\n\t\tconst kernelSizeArray = [3, 5, 7, 9, 11];\n\t\tresx = Math.round(this.width / 2);\n\t\tresy = Math.round(this.height / 2);\n\n\t\tfor (let i = 0; i < this.nMips; i++) {\n\t\t\tthis.separableBlurMaterials.push(this.getSeperableBlurMaterial(kernelSizeArray[i], \"BlurMaterial\" + i));\n\t\t\tthis.separableBlurYMaterials.push(this.getSeperableBlurMaterial(kernelSizeArray[i], \"BlurMaterialY\" + i));\n\t\t\tresx = Math.round(resx / 2);\n\n\t\t\tresy = Math.round(resy / 2);\n\t\t}\n\t\t// Composite material\n\t\tthis.compositeMaterial = this.getCompositeMaterial(this.nMips, \"compositeMaterial\");\n\t\tthis.compositeMaterial.renderState = this.renderState;\n\t\tthis.blendUniforms = {\n\t\t\ttDiffuse: { type: \"texture\", value: this.renderTargetsHorizontal[0].getColorTexture() },\n\t\t\tbaseColorTexture: { type: \"texture\", value: null },\n\t\t\ttSampler: {\n\t\t\t\ttype: \"sampler\",\n\t\t\t\tvalue: this.defaultSampler\n\t\t\t}\n\t\t};\n\t\tconst blendShader = getVertFrag(\"blend\", { positionLocation: 0 });\n\t\tthis.blendMaterial = new ShaderMaterial({\n\t\t\ttype: \"postBlend\",\n\t\t\tuniforms: this.blendUniforms,\n\t\t\tvert: blendShader.vert,\n\t\t\tfrag: blendShader.frag\n\t\t});\n\t\tthis.blendMaterial.renderState = this.renderState;\n\t\tthis.blendTarget = new RenderTarget(\"render\", [this.createColorAttachment(this.width, this.height)]);\n\t}\n\tprivate createColorAttachment(width: number, height: number): Attachment {\n\t\tconst colorTexture = new Texture({\n\t\t\tsize: { width, height, depth: 1 },\n\t\t\tformat: TextureFormat.BGRA8Unorm,\n\t\t\tusage: TextureUsage.RenderAttachment | TextureUsage.TextureBinding\n\t\t});\n\t\tconst colorAttachment = new Attachment({ r: 0.0, g: 0.0, b: 0.0, a: 0.0 }, { texture: colorTexture });\n\t\treturn colorAttachment;\n\t}\n\tprivate getCompositeMaterial(nMips: number, type): ShaderMaterial {\n\t\treturn new ShaderMaterial({\n\t\t\ttype,\n\t\t\tuniforms: {\n\t\t\t\tblurTexture1: { type: \"texture\", value: this.renderTargetsVertical[0].getColorTexture() },\n\t\t\t\tblurTexture2: { type: \"texture\", value: this.renderTargetsVertical[1].getColorTexture() },\n\t\t\t\tblurTexture3: { type: \"texture\", value: this.renderTargetsVertical[2].getColorTexture() },\n\t\t\t\tblurTexture4: { type: \"texture\", value: this.renderTargetsVertical[3].getColorTexture() },\n\t\t\t\tblurTexture5: { type: \"texture\", value: this.renderTargetsVertical[4].getColorTexture() },\n\t\t\t\ttSampler: {\n\t\t\t\t\ttype: \"sampler\",\n\t\t\t\t\tvalue: this.defaultSampler\n\t\t\t\t},\n\t\t\t\tbloomStrength: { type: \"f32\", value: this.strength },\n\t\t\t\tbloomRadius: { type: \"f32\", value: this.radius },\n\t\t\t\tbloomFactors: { type: \"array<f32>\", value: [1.0, 0.8, 0.6, 0.4, 0.2] },\n\t\t\t\tbloomTintColors: {\n\t\t\t\t\ttype: \"array<f32>\",\n\t\t\t\t\tvalue: [\n\t\t\t\t\t\tnew Vector3(1, 1, 1),\n\t\t\t\t\t\tnew Vector3(1, 1, 1),\n\t\t\t\t\t\tnew Vector3(1, 1, 1),\n\t\t\t\t\t\tnew Vector3(1, 1, 1),\n\t\t\t\t\t\tnew Vector3(1, 1, 1)\n\t\t\t\t\t]\n\t\t\t\t}\n\t\t\t},\n\n\t\t\tvert: () => {\n\t\t\t\treturn `\n              struct VertexInput {\n                    @location(0) position: vec2<f32>,       \n               }\n               struct VertexOutput {\n                    @builtin(position) position: vec4<f32>,\n                    @location(0) uv: vec2<f32>,\n                };\n               @vertex\n               fn main(input: VertexInput) -> VertexOutput {\n                var output:VertexOutput;\n                output.uv = input.position * 0.5 + 0.5;\n                output.position = vec4<f32>(input.position, 0.0, 1.0);;\n                return output;\n               }\n                `;\n\t\t\t},\n\n\t\t\tfrag: (defines) => {\n\t\t\t\treturn `\n                struct FragInput {\n                    @location(0) uv: vec2<f32>,\n                };\n                struct BloomUniforms{\n                    bloomStrength:f32,\n                    bloomRadius:f32,\n                    bloomFactors : array<f32,5>,\n                    bloomTintColors : array<vec3<f32>,5>\n                }  \n                @group(0) @binding(0)  var<storage, read> bloomUniforms : BloomUniforms;\n\n                @group(0) @binding(${defines.blurTexture1Binding}) var blurTexture1: texture_2d<f32>;\n                @group(0) @binding(${defines.blurTexture2Binding}) var blurTexture2: texture_2d<f32>;\n                @group(0) @binding(${defines.blurTexture3Binding}) var blurTexture3: texture_2d<f32>;\n                @group(0) @binding(${defines.blurTexture4Binding}) var blurTexture4: texture_2d<f32>;\n                @group(0) @binding(${defines.blurTexture5Binding}) var blurTexture5: texture_2d<f32>;\n                @group(0) @binding(${defines.tSamplerBinding}}) var tSampler: sampler;\n\n\t\t\t\tfn lerpBloomFactor(factor:f32)->f32 {\n\t\t\t\t\tlet mirrorFactor:f32 = 1.2 - factor;\n\t\t\t\t\treturn mix(factor, mirrorFactor, bloomUniforms.bloomRadius);\n\t\t\t\t}\n                @fragment\n\t\t\t\tfn main(input:FragInput)-> @location(0) vec4<f32>  {\n\t\t\t\t\treturn bloomUniforms.bloomStrength * ( lerpBloomFactor(bloomUniforms.bloomFactors[0]) * vec4(bloomUniforms.bloomTintColors[0], 1.0) * textureSample(blurTexture1, tSampler, input.uv) +\n\t\t\t\t\t\tlerpBloomFactor(bloomUniforms.bloomFactors[1]) * vec4<f32>(bloomUniforms.bloomTintColors[1], 1.0) * textureSample(blurTexture2, tSampler, input.uv) +\n\t\t\t\t\t\tlerpBloomFactor(bloomUniforms.bloomFactors[2]) * vec4<f32>(bloomUniforms.bloomTintColors[2], 1.0) * textureSample(blurTexture3, tSampler, input.uv) +\n\t\t\t\t\t\tlerpBloomFactor(bloomUniforms.bloomFactors[3]) * vec4<f32>(bloomUniforms.bloomTintColors[3], 1.0) * textureSample(blurTexture4, tSampler, input.uv) +\n\t\t\t\t\t\tlerpBloomFactor(bloomUniforms.bloomFactors[4]) * vec4<f32>(bloomUniforms.bloomTintColors[4], 1.0) * textureSample(blurTexture5, tSampler, input.uv) );\n\t\t\t\t}`;\n\t\t\t}\n\t\t});\n\t}\n\tprivate getSeperableBlurMaterial(kernelRadius, type) {\n\t\tconst shader = getVertFrag(\"blur\", {\n\t\t\tKERNEL_RADIUS: kernelRadius,\n\t\t\tSIGMA: kernelRadius,\n\t\t\tpositionLocation: 0\n\t\t});\n\t\tconst mat = new ShaderMaterial({\n\t\t\ttype,\n\t\t\tuniforms: {\n\t\t\t\ttDiffuse: { type: \"texture\", value: null },\n\t\t\t\tdirection: { type: \"vec2<f32>\", value: new Vector2(0.0, 0.0) },\n\t\t\t\ttSampler: {\n\t\t\t\t\ttype: \"sampler\",\n\t\t\t\t\tvalue: this.defaultSampler\n\t\t\t\t}\n\t\t\t},\n\n\t\t\tvert: shader.vert,\n\n\t\t\tfrag: shader.frag\n\t\t});\n\t\tmat.renderState = this.renderState;\n\t\treturn mat;\n\t}\n}\n\ntype BloomPostEffectProps = {\n\twidth: number;\n\theight: number;\n\tstrength: number;\n\tradius: number;\n\tthreshold: number;\n};\n","import Matrix4 from \"../math/Matrix4\";\r\nimport Camera from \"./Camera\";\r\nexport default class OrthographicCamera extends Camera {\r\n\tright: number;\r\n\tisOrthographicCamera: boolean;\r\n\tbottom: number;\r\n\tleft: number;\r\n\tnear: number;\r\n\tfar: number;\r\n\ttop: number;\r\n\tconstructor(left = -1, right = 1, top = 1, bottom = -1, near = 0.1, far = 2000) {\r\n\t\tsuper();\r\n\t\tthis.near = near;\r\n\t\tthis.far = far;\r\n\t\tthis.left = left;\r\n\t\tthis.top = top;\r\n\t\tthis.bottom = bottom;\r\n\t\tthis.right = right;\r\n\t\tthis.isOrthographicCamera = true;\r\n\t}\r\n\tprivate updateCameraParms() {\r\n\t\tconst dx = (this.right - this.left) / 2;\r\n\t\tconst dy = (this.top - this.bottom) / 2;\r\n\t\tconst cx = (this.right + this.left) / 2;\r\n\t\tconst cy = (this.top + this.bottom) / 2;\r\n\t\treturn {\r\n\t\t\tleft: cx - dx,\r\n\t\t\tright: cx + dx,\r\n\t\t\ttop: cy + dy,\r\n\t\t\tbottom: cy - dy\r\n\t\t};\r\n\t}\r\n\tpublic updateProjectionMatrix() {\r\n\t\tif (this.projectMatrixDirty) {\r\n\t\t\tconst { left, right, top, bottom } = this.updateCameraParms();\r\n\t\t\tthis._projectionMatrix = Matrix4.makeOrthographic(left, right, top, bottom, this.near, this.far);\r\n\t\t\tthis.projectMatrixDirty = false;\r\n\t\t}\r\n\t}\r\n}\r\n","import PerspectiveCamera from \"../../camera/PerspectiveCamera\";\nimport Vector2 from \"../../math/Vector2\";\nimport { SpotLight } from \"../SpotLight\";\nimport { BaseShadow } from \"./BaseShadow\";\n\nexport class SpotLightShadow extends BaseShadow {\n\tpublic type: string;\n\tconstructor() {\n\t\tconst camera = new PerspectiveCamera(60, 1, 0.1, 500);\n\t\tsuper(new Vector2(1024, 1024), camera);\n\t\tthis.type = \"spotLightShadow\";\n\t}\n\n\tpublic update(light: SpotLight) {\n\t\tthis.updateMatrices(light);\n\t}\n\n\tupdateMatrices(light: SpotLight) {\n\t\tthis.camera.position.copy(light.position);\n\t\tconst { x, y, z } = light.target;\n\t\tthis.camera.lookAt(x, y, z);\n\t\tthis.camera.updateMatrix();\n\t\tthis.vpMatrixDirty = true;\n\t}\n}\n","import { LightType } from \"../core/WebGPUTypes\";\r\nimport Vector3 from \"../math/Vector3\";\r\nimport { Light } from \"./Light\";\r\nimport { SpotLightShadow } from \"./shadows/SpotLightShadow\";\r\n\r\nexport class SpotLight extends Light {\r\n\tprivate _distance: number;\r\n\tprivate _angle: number;\r\n\tprivate _penumbra: number;\r\n\tprivate _decay: number;\r\n\tdecayDirty: boolean;\r\n\tdistanceDirty: boolean;\r\n\tprivate _coneCos: number;\r\n\tprivate _penumbraCos: number;\r\n\tconeCosDirty: boolean;\r\n\tpenumbraDirty: boolean;\r\n\tangleDirty: boolean;\r\n\tpenumbraCosDirty: boolean;\r\n\tconstructor(color, intensity, distance = 0, angle = 60, penumbra = 60, decay = 4, openShadow = true) {\r\n\t\tsuper(color, intensity);\r\n\t\tthis._distance = distance;\r\n\t\tthis._angle = (angle / 180) * Math.PI;\r\n\t\tthis._penumbra = (penumbra / 180) * Math.PI;\r\n\t\tthis._decay = decay;\r\n\t\tthis.lightType = LightType.SpotLight;\r\n\t\tthis.angleDirty = true;\r\n\t\tthis.penumbraDirty = true;\r\n\t\tthis.distanceDirty = true;\r\n\t\tthis.decayDirty = true;\r\n\t\tthis.coneCosDirty = true;\r\n\t\tthis.penumbraCosDirty = true;\r\n\t\tif (openShadow) this.shadow = new SpotLightShadow();\r\n\t\tthis.updateConeCosOrPenumbraCos();\r\n\t}\r\n\r\n\tget dirtectDirty() {\r\n\t\treturn this.positionDirty || this.targetDirty;\r\n\t}\r\n\r\n\tset dirtectDirty(value) {\r\n\t\tthis.positionDirty = value;\r\n\t\tthis.targetDirty = value;\r\n\t}\r\n\r\n\tget directional() {\r\n\t\tconst result = new Vector3();\r\n\t\tVector3.subtract(this.position, this.target, result);\r\n\t\treturn Vector3.normalize(result, new Vector3());\r\n\t}\r\n\tget angle() {\r\n\t\treturn this._angle;\r\n\t}\r\n\tset angle(value) {\r\n\t\tthis.angleDirty = true;\r\n\t\tthis._angle = (value / 180) * Math.PI;\r\n\t\tthis.updateConeCosOrPenumbraCos();\r\n\t}\r\n\tget penumbra() {\r\n\t\treturn this._penumbra;\r\n\t}\r\n\tset penumbra(value) {\r\n\t\tthis.penumbraDirty = true;\r\n\t\tthis._penumbra = (value / 180) * Math.PI;\r\n\t\tthis.updateConeCosOrPenumbraCos();\r\n\t}\r\n\tset distance(value) {\r\n\t\tthis.distanceDirty = true;\r\n\t\tthis._distance = value;\r\n\t}\r\n\tget distance() {\r\n\t\treturn this._distance;\r\n\t}\r\n\tset decay(value) {\r\n\t\tthis.decayDirty = true;\r\n\t\tthis._decay = value;\r\n\t}\r\n\tget decay() {\r\n\t\treturn this._decay;\r\n\t}\r\n\tset coneCos(value) {\r\n\t\tthis.coneCosDirty = true;\r\n\t\tthis._coneCos = value;\r\n\t}\r\n\tget coneCos() {\r\n\t\treturn this._coneCos;\r\n\t}\r\n\tset penumbraCos(value) {\r\n\t\tthis.penumbraCosDirty = true;\r\n\t\tthis._penumbraCos = value;\r\n\t}\r\n\tget penumbraCos() {\r\n\t\treturn this._penumbraCos;\r\n\t}\r\n\tprivate updateConeCosOrPenumbraCos() {\r\n\t\tthis._coneCos = Math.cos(this.angle);\r\n\t\tthis._penumbraCos = Math.cos(this.angle + this.penumbra);\r\n\t}\r\n}\r\n// uniform\r\n// color: {},\r\n// position: {},\r\n// direction: {},\r\n// distance: {},\r\n// coneCos: {},\r\n// penumbraCos: {},\r\n// decay: {}\r\n","import OrthographicCamera from \"../../camera/OrthographicCamera\";\nimport Vector2 from \"../../math/Vector2\";\nimport { DirectionalLight } from \"../DirectionalLight\";\nimport { BaseShadow } from \"./BaseShadow\";\n\nexport class DirectionalLightShadow extends BaseShadow {\n\tpublic type: string;\n\tconstructor() {\n\t\tconst camera = new OrthographicCamera(-50, 50, 50, -50, 0, 100);\n\t\tsuper(new Vector2(1024, 1024), camera);\n\t\tthis.type = \"directionalLightShadow\";\n\t}\n\n\tpublic update(light: DirectionalLight) {\n\t\tthis.updateMatrices(light);\n\t}\n\n\tupdateMatrices(light: DirectionalLight) {\n\t\tthis.camera.position.copy(light.position);\n\t\tconst { x, y, z } = light.target;\n\t\tthis.camera.lookAt(x, y, z);\n\t\tthis.camera.updateMatrix();\n\t\tthis.vpMatrixDirty = true;\n\t}\n}\n","import { LightType } from \"../core/WebGPUTypes\";\nimport Vector3 from \"../math/Vector3\";\nimport { Light } from \"./Light\";\nimport { DirectionalLightShadow } from \"./shadows/DirectionalLightShadow\";\n\nexport class DirectionalLight extends Light {\n\tconstructor(color: Vector3, intensity: number, openShadow = true) {\n\t\tsuper(color, intensity);\n\t\tthis.lightType = LightType.DirectionalLight;\n\t\tif (openShadow) this.shadow = new DirectionalLightShadow();\n\t}\n\n\tget dirtectDirty() {\n\t\treturn this.positionDirty || this.targetDirty;\n\t}\n\n\tset dirtectDirty(value) {\n\t\tthis.positionDirty = value;\n\t\tthis.targetDirty = value;\n\t}\n\n\tget directional() {\n\t\tconst result = new Vector3();\n\t\tVector3.subtract(this.target, this.position, result);\n\t\treturn result.normalize();\n\t}\n}\n// uniform\n// direction: {},\n// color: {}\n","import Camera from \"../camera/Camera\";\r\nimport { FrameState } from \"../core/FrameState\";\r\nimport RenderObject from \"../core/RenderObject\";\r\nimport { RenderObjectType } from \"../core/WebGPUTypes\";\r\nimport createGuid from \"../utils/createGuid\";\r\nimport { Mesh } from \"./Mesh\";\r\n\r\nexport default class Node extends RenderObject {\r\n\tuid: string;\r\n\tchildren: Map<string, Node | Mesh>;\r\n\tname: string;\r\n\tconstructor() {\r\n\t\tsuper();\r\n\t\tthis.type = RenderObjectType.Node;\r\n\t\tthis.children = new Map();\r\n\t\tthis.parent = null;\r\n\t\tthis.uid = createGuid();\r\n\t}\r\n\tadd(node: Node | Mesh) {\r\n\t\tnode.parent = this;\r\n\t\tthis.children.set(node.uid, node);\r\n\t}\r\n\tremove(node: Node | Mesh) {\r\n\t\tthis.children.delete(node.uid);\r\n\t}\r\n\tupdate(frameState: FrameState, camera?: Camera) {\r\n\t\tthis.updateMatrix(this?.parent?.modelMatrix?.clone());\r\n\t\tthis?.children?.forEach?.((node) => {\r\n\t\t\tnode.update(frameState, camera);\r\n\t\t});\r\n\t}\r\n\tdestroy() {\r\n\t\tthis.children.forEach((node) => {\r\n\t\t\tnode.destroy();\r\n\t\t});\r\n\t\tthis?.children?.clear();\r\n\t}\r\n\ttraverse(traverseFunction: Function, param: { [prop: string]: any }): void {\r\n\t\tfor (let i = 0, len = this.children.size; i < len; i++) {\r\n\t\t\tthis.children.forEach((child) => {\r\n\t\t\t\tchild.traverse(traverseFunction, param);\r\n\t\t\t});\r\n\t\t}\r\n\t}\r\n}\r\n","import Camera from \"../camera/Camera\";\nimport { FrameState } from \"../core/FrameState\";\nimport { BufferBindingType, BufferUsage } from \"../core/WebGPUConstant\";\nimport { RenderObjectType, UniformEnum } from \"../core/WebGPUTypes\";\nimport Geometry from \"../geometry/Geometry\";\nimport { Material } from \"../material/Material\";\nimport Matrix4 from \"../math/Matrix4\";\nimport UniformBuffer from \"../render/UniformBuffer\";\nimport { Mesh } from \"./Mesh\";\nimport Node from \"./Node\";\n\nexport class SKinMesh extends Mesh {\n\tinverseBindMatrices: Array<Matrix4>;\n\tuniformMatrixs: Array<Matrix4>;\n\tjoints: Array<Node>;\n\tprivate hasAddJoints: boolean;\n\tconstructor(geometry?: Geometry, material?: Material) {\n\t\tsuper(geometry, material);\n\t\tthis.type = RenderObjectType.SkinMesh;\n\t\tthis.uniformMatrixs = [];\n\t\tthis.hasAddJoints = false;\n\t}\n\tsetSkinData(data: SkinDataType) {\n\t\tthis.inverseBindMatrices = data.inverseBindMatrices;\n\t\tthis.joints = data.joints;\n\t}\n\tupdate(frameState: FrameState, camera?: Camera) {\n\t\tthis.uniformMatrixs = this.joints.map((joint) => (joint as Node).modelMatrix);\n\t\tsuper.update(frameState, camera);\n\t\tif (!this.hasAddJoints) this.addUniformsToMaterial();\n\t}\n\tprivate addUniformsToMaterial() {\n\t\tif (!this.material.shaderData) return;\n\t\tthis.hasAddJoints = true;\n\t\tif (this.joints) {\n\t\t\tconst skinJointsBuffer = new UniformBuffer({\n\t\t\t\tlabel: \"skinJointsBuffer\",\n\t\t\t\ttype: BufferBindingType.ReadOnlyStorage,\n\t\t\t\tusage: BufferUsage.Storage | BufferUsage.CopyDst,\n\t\t\t\tsize: 3000\n\t\t\t});\n\t\t\tconst invsBuffer = new UniformBuffer({\n\t\t\t\tlabel: \"invsBuffer\",\n\t\t\t\ttype: BufferBindingType.ReadOnlyStorage,\n\t\t\t\tusage: BufferUsage.Storage | BufferUsage.CopyDst,\n\t\t\t\tsize: 3000\n\t\t\t});\n\t\t\tskinJointsBuffer.setUniform(\n\t\t\t\t\"joints\",\n\t\t\t\t() => {\n\t\t\t\t\treturn this.uniformMatrixs;\n\t\t\t\t},\n\t\t\t\tUniformEnum.Mat4Array,\n\t\t\t\tthis.uniformMatrixs.length\n\t\t\t);\n\t\t\tinvsBuffer.setUniform(\n\t\t\t\t\"jointsInv\",\n\t\t\t\t() => {\n\t\t\t\t\treturn this.inverseBindMatrices;\n\t\t\t\t},\n\t\t\t\tUniformEnum.Mat4Array,\n\t\t\t\tthis.inverseBindMatrices.length\n\t\t\t);\n\t\t\tthis.material.shaderData.setUniformBuffer(\"skinJointsBuffer\", skinJointsBuffer);\n\t\t\tthis.material.shaderData.setUniformBuffer(\"invsBuffer\", invsBuffer);\n\t\t}\n\t}\n}\nexport type SkinDataType = {\n\tinverseBindMatrices?: Array<Matrix4>;\n\tjoints?: Array<Node>;\n};\n","import { Quaternion } from \"../math/Quaternion\";\r\nimport Vector2 from \"../math/Vector2\";\r\nimport Vector3 from \"../math/Vector3\";\r\n\r\nexport function clamp(num: number, min: number, max: number) {\r\n\treturn Math.min(Math.max(num, min), max);\r\n}\r\n\r\nexport function toFloat(num: number | undefined, defaultValue = 1) {\r\n\tconst n = num !== undefined ? num : defaultValue;\r\n\tif (Number.isInteger(n)) {\r\n\t\treturn `${n}.0`;\r\n\t}\r\n\treturn n;\r\n}\r\n\r\nexport type TypedArray = Int8Array | Uint8Array | Int16Array | Uint16Array | Uint32Array | Float32Array;\r\n\r\nexport function newTypedArray(type: number, buffer: ArrayBuffer, byteOffset: number, length: number) {\r\n\tswitch (type) {\r\n\t\tcase 5120:\r\n\t\t\treturn new Int8Array(buffer, byteOffset, length);\r\n\t\tcase 5121:\r\n\t\t\treturn new Uint8Array(buffer, byteOffset, length);\r\n\t\tcase 5122:\r\n\t\t\treturn new Int16Array(buffer, byteOffset, length);\r\n\t\tcase 5123:\r\n\t\t\treturn new Uint16Array(buffer, byteOffset, length);\r\n\t\tcase 5124:\r\n\t\t\treturn new Int32Array(buffer, byteOffset, length);\r\n\t\tcase 5125:\r\n\t\t\treturn new Uint32Array(buffer, byteOffset, length);\r\n\t\tcase 5126:\r\n\t\t\treturn new Float32Array(buffer, byteOffset, length);\r\n\t\tdefault:\r\n\t\t\tthrow new Error(\"invalid component type\");\r\n\t}\r\n}\r\n\r\nexport function toIndices(array: TypedArray): Uint16Array | Uint32Array {\r\n\tif (array instanceof Uint16Array || array instanceof Uint32Array) {\r\n\t\treturn array;\r\n\t}\r\n\tlet toArray;\r\n\tif (array instanceof Float32Array) {\r\n\t\ttoArray = new Uint32Array(array.length);\r\n\t} else {\r\n\t\ttoArray = new Uint16Array(array.length);\r\n\t}\r\n\tarray.forEach((element, index) => {\r\n\t\ttoArray[index] = element;\r\n\t});\r\n\treturn toArray;\r\n}\r\n\r\nexport function joinArray(arrays: Array<Float32Array>) {\r\n\tlet length = 0;\r\n\tarrays.forEach((array) => {\r\n\t\tlength += array.length;\r\n\t});\r\n\tconst joined = new Float32Array(length);\r\n\tlength = 0;\r\n\tarrays.forEach((array) => {\r\n\t\tjoined.set(array, length);\r\n\t\tlength += array.length;\r\n\t});\r\n\treturn joined;\r\n}\r\n\r\nexport function createGPUBuffer(array: TypedArray, usage: number, device: GPUDevice) {\r\n\tconst buffer = device.createBuffer({\r\n\t\tsize: (array.byteLength + 3) & ~3, // eslint-disable-line no-bitwise\r\n\t\tusage,\r\n\t\tmappedAtCreation: true\r\n\t});\r\n\tlet writeArary;\r\n\tif (array instanceof Int8Array) {\r\n\t\twriteArary = new Int8Array(buffer.getMappedRange());\r\n\t} else if (array instanceof Uint8Array) {\r\n\t\twriteArary = new Uint8Array(buffer.getMappedRange());\r\n\t} else if (array instanceof Int16Array) {\r\n\t\twriteArary = new Int16Array(buffer.getMappedRange());\r\n\t} else if (array instanceof Uint16Array) {\r\n\t\twriteArary = new Uint16Array(buffer.getMappedRange());\r\n\t} else if (array instanceof Uint32Array) {\r\n\t\twriteArary = new Uint32Array(buffer.getMappedRange());\r\n\t} else {\r\n\t\twriteArary = new Float32Array(buffer.getMappedRange());\r\n\t}\r\n\twriteArary.set(array);\r\n\tbuffer.unmap();\r\n\treturn buffer;\r\n}\r\n\r\nexport function generateNormals(indices: TypedArray | null, positions: TypedArray) {\r\n\tconst normals = new Float32Array(positions.length);\r\n\tconst vertexCount = indices ? indices.length : positions.length;\r\n\tfor (let i = 0; i < vertexCount; i += 3) {\r\n\t\tconst triIndices = [];\r\n\t\tfor (let n = 0; n < 3; n += 1) {\r\n\t\t\tif (indices) {\r\n\t\t\t\ttriIndices.push(indices[i + n]);\r\n\t\t\t} else {\r\n\t\t\t\ttriIndices.push(i + n);\r\n\t\t\t}\r\n\t\t}\r\n\t\tconst triangle = triIndices.map((vertexIndex) => {\r\n\t\t\tconst index = vertexIndex * 3;\r\n\t\t\treturn new Vector3(positions[index], positions[index + 1], positions[index + 2]);\r\n\t\t});\r\n\t\tconst dv1 = new Vector3();\r\n\t\tVector3.subtract(triangle[1], triangle[0], dv1);\r\n\t\tconst dv2 = new Vector3();\r\n\t\tVector3.subtract(triangle[2], triangle[0], dv2);\r\n\t\tconst normal = new Vector3();\r\n\t\tVector3.cross(dv1.normalize(), dv2.normalize(), normal);\r\n\t\tfor (let n = 0; n < 3; n += 1) {\r\n\t\t\tconst index = (i + n) * 3;\r\n\t\t\tnormals[index + 0] += normal.x;\r\n\t\t\tnormals[index + 1] += normal.y;\r\n\t\t\tnormals[index + 2] += normal.z;\r\n\t\t}\r\n\t}\r\n\treturn normals;\r\n}\r\n\r\nexport function generateTangents(\r\n\tindices: TypedArray | null,\r\n\tpositions: TypedArray,\r\n\tnormals: TypedArray,\r\n\tuvs: TypedArray\r\n) {\r\n\tconst tangents = new Float32Array((normals.length / 3) * 4);\r\n\tconst vertexCount = indices ? indices.length : positions.length;\r\n\tfor (let i = 0; i < vertexCount; i += 3) {\r\n\t\tconst triIndices = [];\r\n\t\tfor (let n = 0; n < 3; n += 1) {\r\n\t\t\tif (indices) {\r\n\t\t\t\ttriIndices.push(indices[i + n]);\r\n\t\t\t} else {\r\n\t\t\t\ttriIndices.push(i + n);\r\n\t\t\t}\r\n\t\t}\r\n\t\tconst pos = triIndices.map((vertexIndex) => {\r\n\t\t\tconst index = vertexIndex * 3;\r\n\t\t\treturn new Vector3(positions[index], positions[index + 1], positions[index + 2]);\r\n\t\t});\r\n\t\tconst uv = triIndices.map((vertexIndex) => {\r\n\t\t\tconst index = vertexIndex * 2;\r\n\t\t\treturn new Vector2(uvs?.[index], uvs?.[index + 1]);\r\n\t\t});\r\n\r\n\t\tconst dv1 = new Vector3();\r\n\t\tVector3.subtract(pos[1], pos[0], dv1);\r\n\t\tconst dv2 = new Vector3();\r\n\t\tVector3.subtract(pos[2], pos[0], dv2);\r\n\t\tconst duv1 = new Vector2();\r\n\t\tVector2.subtract(uv[1], uv[0], duv1);\r\n\t\tconst duv2 = new Vector2();\r\n\t\tVector2.subtract(uv[2], uv[0], duv2);\r\n\r\n\t\tconst tangent = new Vector3();\r\n\t\tVector3.multiplyByScalar(dv1, duv1.y, dv1);\r\n\t\tVector3.multiplyByScalar(dv2, duv2.y, dv2);\r\n\t\tVector3.subtract(dv1, dv2, tangent);\r\n\r\n\t\tVector3.multiplyByScalar(tangent, duv2.y * duv1.x - duv1.y * duv2.x, tangent);\r\n\r\n\t\ttangent.normalize();\r\n\t\tfor (let n = 0; n < 3; n += 1) {\r\n\t\t\tconst index = (i + n) * 4;\r\n\r\n\t\t\ttangents[index + 0] += tangent.x;\r\n\t\t\ttangents[index + 1] += tangent.y;\r\n\t\t\ttangents[index + 2] += tangent.z;\r\n\t\t\ttangents[index + 3] = 1;\r\n\t\t}\r\n\t}\r\n\treturn tangents;\r\n}\r\n\r\nfunction lerp(a: number, b: number, x: number) {\r\n\tif (x < a) {\r\n\t\treturn 0;\r\n\t}\r\n\tif (x > b) {\r\n\t\treturn 1;\r\n\t}\r\n\treturn (x - a) / (b - a);\r\n}\r\n\r\nexport function interpQuat(input: TypedArray, o: TypedArray, time: number, method: string) {\r\n\tlet index = 1;\r\n\twhile (index < input.length - 1 && time >= input[index]) {\r\n\t\tindex += 1;\r\n\t}\r\n\tconst t = lerp(input[index - 1], input[index], time);\r\n\r\n\tif (method === \"CUBICSPLINE\") {\r\n\t\tconst td = input[index] - input[index - 1];\r\n\t\tconst t2 = t * t;\r\n\t\tconst t3 = t2 * t;\r\n\t\tconst i = 12 * index;\r\n\r\n\t\tconst v0 = new Quaternion(o[i - 8], o[i - 7], o[i - 6], o[i - 5]);\r\n\t\tconst b0 = new Quaternion(o[i - 4], o[i - 3], o[i - 2], o[i - 1]);\r\n\t\tconst v1 = new Quaternion(o[i + 4], o[i + 5], o[i + 6], o[i + 7]);\r\n\t\tconst a1 = new Quaternion(o[i], o[i + 1], o[i + 2], o[i + 3]);\r\n\t\tQuaternion.multiplyByScalar(v0, 2 * t3 - 3 * t2 + 1, v0);\r\n\t\tQuaternion.multiplyByScalar(b0, td * (t3 - 2 * t2 + t), b0);\r\n\t\tQuaternion.multiplyByScalar(v1, -2 * t3 + 3 * t2, v1);\r\n\t\tQuaternion.multiplyByScalar(a1, td * (t3 - t2), a1);\r\n\r\n\t\tconst result = new Quaternion();\r\n\t\tQuaternion.add(result, v0, result);\r\n\t\tQuaternion.add(result, b0, result);\r\n\t\tQuaternion.add(result, v1, result);\r\n\t\tQuaternion.add(result, a1, result);\r\n\t\tQuaternion.normalize(result, result);\r\n\t\treturn result;\r\n\t}\r\n\r\n\tconst q = [];\r\n\tfor (let n = -1; n < 1; n += 1) {\r\n\t\tconst i = 4 * (index + n);\r\n\t\tq.push(new Quaternion(o[i], o[i + 1], o[i + 2], o[i + 3]));\r\n\t}\r\n\r\n\tif (method === \"STEP\") {\r\n\t\treturn t < 1 ? q[0] : q[1];\r\n\t}\r\n\tconst result = new Quaternion();\r\n\tQuaternion.slerp(q[0], q[1], t, result);\r\n\treturn result;\r\n}\r\n\r\nexport function interpVec3(input: TypedArray, output: TypedArray, time: number, method: string) {\r\n\tlet index = 1;\r\n\twhile (index < input.length - 1 && time >= input[index]) {\r\n\t\tindex += 1;\r\n\t}\r\n\tconst t = lerp(input[index - 1], input[index], time);\r\n\r\n\tif (method === \"CUBICSPLINE\") {\r\n\t\tconst td = input[index] - input[index - 1];\r\n\t\tconst t2 = t * t;\r\n\t\tconst t3 = t2 * t;\r\n\t\tconst i = 9 * index;\r\n\t\tconst v0 = new Vector3(output[i - 6], output[i - 5], output[i - 4]);\r\n\t\tconst b0 = new Vector3(output[i - 3], output[i - 2], output[i - 1]);\r\n\t\tconst v1 = new Vector3(output[i + 3], output[i + 4], output[i + 5]);\r\n\t\tconst a1 = new Vector3(output[i], output[i + 1], output[i + 2]);\r\n\t\tVector3.multiplyByScalar(v0, 2 * t3 - 3 * t2 + 1, v0);\r\n\t\tVector3.multiplyByScalar(b0, td * (t3 - 2 * t2 + t), b0);\r\n\t\tVector3.multiplyByScalar(v1, -2 * t3 + 3 * t2, v1);\r\n\t\tVector3.multiplyByScalar(a1, td * (t3 - t2), a1);\r\n\t\tconst result = new Vector3();\r\n\t\tVector3.add(result, v0, result);\r\n\t\tVector3.add(result, b0, result);\r\n\t\tVector3.add(result, v1, result);\r\n\t\tVector3.add(result, a1, result);\r\n\t\treturn result;\r\n\t}\r\n\r\n\tconst v = [];\r\n\tfor (let n = -1; n < 1; n += 1) {\r\n\t\tconst i = 3 * (index + n);\r\n\t\tv.push(new Vector3(output[i], output[i + 1], output[i + 2]));\r\n\t}\r\n\r\n\tif (method === \"STEP\") {\r\n\t\treturn t < 1 ? v[0] : v[1];\r\n\t}\r\n\tconst result = new Vector3();\r\n\treturn Vector3.lerp(v[0], v[1], t, result);\r\n}\r\n\r\nexport const gltfEnum: { [key: string]: string | number } = {\r\n\tSCALAR: 1,\r\n\tVEC2: 2,\r\n\tVEC3: 3,\r\n\tVEC4: 4,\r\n\tMAT2: 4,\r\n\tMAT3: 9,\r\n\tMAT4: 16,\r\n\t5120: 1,\r\n\t5121: 1,\r\n\t5122: 2,\r\n\t5123: 2,\r\n\t5125: 4,\r\n\t5126: 4,\r\n\t9728: \"nearest\",\r\n\t9729: \"linear\",\r\n\t9984: \"linear\",\r\n\t9985: \"linear\",\r\n\t9986: \"linear\",\r\n\t9987: \"linear\",\r\n\t33071: \"clamp-to-edge\",\r\n\t33648: \"mirror-repeat\",\r\n\t10497: \"repeat\"\r\n};\r\n","import Matrix4 from \"../../../math/Matrix4\";\r\nimport Vector4 from \"../../../math/Vector4\";\r\n\r\nexport class Accessor {\r\n\tvalues: any;\r\n\tid: number;\r\n\tcount: number;\r\n\tcomponentType: number;\r\n\ttype: number;\r\n\tmin: number[];\r\n\tmax: number[];\r\n\tconstructor(options: AccessorParms) {\r\n\t\tthis.values = options.values ?? [];\r\n\t\tthis.id = options.id;\r\n\t\tthis.count = options.count;\r\n\t\tthis.componentType = options.componentType;\r\n\t\tthis.type = options.type;\r\n\t\tthis.min = options.min;\r\n\t\tthis.max = options.max;\r\n\t}\r\n\tgetArray(): number[] {\r\n\t\treturn Array.from(this.values);\r\n\t}\r\n\tgetVec4Array(): Vector4[] {\r\n\t\tconst result = [];\r\n\t\tfor (let i = 0; i < this.values.length; i += 4) {\r\n\t\t\tresult.push(new Vector4(this.values[i], this.values[i + 1], this.values[i + 2], this.values[i + 3]));\r\n\t\t}\r\n\t\treturn result;\r\n\t}\r\n\tgetMat4Array(): Matrix4[] {\r\n\t\tconst result = [];\r\n\t\tfor (let i = 0; i < this.values.length; i += 16) {\r\n\t\t\tconst mat4 = new Matrix4();\r\n\t\t\tMatrix4.fromColumnMajorArray(this.values.slice(i, i + 16), mat4);\r\n\t\t\tresult.push(mat4);\r\n\t\t}\r\n\t\treturn result;\r\n\t}\r\n}\r\nexport type AccessorParms = Partial<Accessor>;\r\n","import { Quaternion } from \"../../../math/Quaternion\";\nimport Vector4 from \"../../../math/Vector4\";\nimport { AnimationChannel } from \"./AnimationChannel\";\nimport { AnimationSampler } from \"./AnimationSampler\";\n\nexport class Animation {\n\tconstructor(public name: string, public samplers: AnimationSampler[], public channels: AnimationChannel[]) {}\n\tplay(time: number) {\n\t\tlet node, animationSampler, target;\n\t\tthis?.channels?.map((channel) => {\n\t\t\tanimationSampler = channel.sampler;\n\t\t\tanimationSampler.getValue(time);\n\t\t\ttarget = channel.target;\n\t\t\tnode = target.node;\n\t\t\tswitch (target.path) {\n\t\t\t\tcase \"rotation\":\n\t\t\t\t\tQuaternion.clone(animationSampler.currentValue, node.quaternion);\n\t\t\t\t\tbreak;\n\t\t\t\tcase \"translation\":\n\t\t\t\t\tVector4.clone(animationSampler.currentValue, node.position);\n\t\t\t\t\tbreak;\n\t\t\t\tcase \"scale\":\n\t\t\t\t\tVector4.clone(animationSampler.currentValue, node.scale);\n\t\t\t\t\tbreak;\n\t\t\t}\n\t\t});\n\t}\n}\n","import { AnimationChannelTarget } from \"./AnimationChannelTarget\";\nimport { AnimationSampler } from \"./AnimationSampler\";\n\nexport class AnimationChannel {\n\tsampler: AnimationSampler;\n\ttarget: AnimationChannelTarget;\n\tconstructor() {}\n}\n","import Node from \"../../../mesh/Node\";\n\nexport class AnimationChannelTarget {\n\tnode: Node;\n\tpath: \"translation\" | \"rotation\" | \"scale\" | \"weights\";\n\tconstructor(node, path) {\n\t\tthis.node = node;\n\t\tthis.path = path;\n\t}\n}\n","export enum Type2NumOfComponent {\r\n\t\"SCALAR\" = 1,\r\n\t\"VEC2\" = 2,\r\n\t\"VEC3\" = 3,\r\n\t\"VEC4\" = 4,\r\n\t\"MAT2\" = 4,\r\n\t\"MAT3\" = 9,\r\n\t\"MAT4\" = 16\r\n}\r\n","import { Quaternion } from \"../../../math/Quaternion\";\r\nimport Vector4 from \"../../../math/Vector4\";\r\nimport { Type2NumOfComponent } from \"../types/gltfType\";\r\nexport class AnimationSampler {\r\n\tinput: any;\r\n\tinterpolation: \"LINEAR\" | \"STEP\" | \"CUBICSPLINE\";\r\n\toutput: any;\r\n\tcurrentIndex: number;\r\n\tstartTime: number;\r\n\tendTime: number;\r\n\tcurrentValue: Vector4 | Quaternion;\r\n\tduration: number;\r\n\tinputMax: number;\r\n\tprivate inputType: string;\r\n\tprivate outputType: string;\r\n\tconstructor() {}\r\n\tformGltf(gltf, sampler) {\r\n\t\tthis.input = gltf.accessors[sampler.input].values; //required, accessor object\r\n\t\tthis.output = gltf.accessors[sampler.output].values; //required, accessor object\r\n\t\tthis.interpolation = sampler.interpolation !== undefined ? sampler.interpolation : \"LINEAR\";\r\n\t\tthis.currentIndex = 0;\r\n\t\t// this.currentValue=new Vector4();\r\n\t\tthis.endTime = this.input[this.input.length - 1];\r\n\t\tthis.inputMax = this.endTime - this.input[0];\r\n\t\tthis.inputType = gltf?.json?.accessors[sampler.input]?.type;\r\n\t\tthis.outputType = gltf?.json?.accessors[sampler.output]?.type;\r\n\t}\r\n\tgetValue(time: number): void {\r\n\t\tif (time > this.endTime) {\r\n\t\t\ttime -= this.inputMax * Math.ceil((time - this.endTime) / this.inputMax);\r\n\t\t\tthis.currentIndex = 0;\r\n\t\t}\r\n\r\n\t\tconst len = this.input.length;\r\n\t\twhile (this.currentIndex <= len - 2 && time >= this.input[this.currentIndex + 1]) {\r\n\t\t\tthis.currentIndex++;\r\n\t\t}\r\n\r\n\t\tif (this.currentIndex >= len - 1) {\r\n\t\t\t// loop\r\n\t\t\ttime -= this.inputMax;\r\n\t\t\tthis.currentIndex = 0;\r\n\t\t}\r\n\r\n\t\t// @tmp: assume no stride\r\n\t\tconst count = Type2NumOfComponent[this.outputType];\r\n\r\n\t\tconst animationOutputValueVec4a = count === 4 ? new Quaternion() : new Vector4();\r\n\t\tconst animationOutputValueVec4b = count === 4 ? new Quaternion() : new Vector4();\r\n\t\tif (!this.currentValue) this.currentValue = count === 4 ? new Quaternion() : new Vector4();\r\n\t\tconst i = this.currentIndex;\r\n\t\tconst o = i * count;\r\n\t\tconst on = o + count;\r\n\r\n\t\tconst u = Math.max(0, time - this.input[i]) / (this.input[i + 1] - this.input[i]);\r\n\t\tanimationOutputValueVec4a.set(this.output[o + 0], this.output[o + 1], this.output[o + 2], this.output[o + 3]);\r\n\t\tanimationOutputValueVec4b.set(\r\n\t\t\tthis.output[on + 0],\r\n\t\t\tthis.output[on + 1],\r\n\t\t\tthis.output[on + 2],\r\n\t\t\tthis.output[on + 3]\r\n\t\t);\r\n\t\tswitch (this.interpolation) {\r\n\t\t\tcase \"LINEAR\":\r\n\t\t\t\tcount === 4\r\n\t\t\t\t\t? Quaternion.slerp(\r\n\t\t\t\t\t\t\t<Quaternion>animationOutputValueVec4a,\r\n\t\t\t\t\t\t\t<Quaternion>animationOutputValueVec4b,\r\n\t\t\t\t\t\t\tu,\r\n\t\t\t\t\t\t\t<Quaternion>this.currentValue\r\n\t\t\t\t\t  )\r\n\t\t\t\t\t: Vector4.lerp(\r\n\t\t\t\t\t\t\t<Vector4>animationOutputValueVec4a,\r\n\t\t\t\t\t\t\t<Vector4>animationOutputValueVec4b,\r\n\t\t\t\t\t\t\tu,\r\n\t\t\t\t\t\t\t<Vector4>this.currentValue\r\n\t\t\t\t\t  );\r\n\t\t\t\tbreak;\r\n\t\t\tdefault:\r\n\t\t\t\tbreak;\r\n\t\t}\r\n\t}\r\n}\r\n","import { RenderObjectType } from \"../core/WebGPUTypes\";\r\nimport Geometry from \"../geometry/Geometry\";\r\nimport PbrMaterial from \"../material/PbrMaterial\";\r\nimport Color from \"../math/Color\";\r\nimport Matrix4 from \"../math/Matrix4\";\r\nimport { Quaternion } from \"../math/Quaternion\";\r\nimport Vector3 from \"../math/Vector3\";\r\nimport { Mesh } from \"../mesh/Mesh\";\r\nimport Node from \"../mesh/Node\";\r\nimport { SKinMesh } from \"../mesh/SKinMesh\";\r\nimport { Float32Attribute } from \"../render/Attribute\";\r\nimport Sampler from \"../render/Sampler\";\r\nimport Texture from \"../render/Texture\";\r\nimport { generateNormals, gltfEnum, newTypedArray, toIndices, TypedArray } from \"../utils/gltfUtils\";\r\nimport { Accessor } from \"./gltf/libs/Accessor\";\r\nimport { Animation } from \"./gltf/libs/Animation\";\r\nimport { AnimationChannel } from \"./gltf/libs/AnimationChannel\";\r\nimport { AnimationChannelTarget } from \"./gltf/libs/AnimationChannelTarget\";\r\nimport { AnimationSampler } from \"./gltf/libs/AnimationSampler\";\r\n\r\nexport type GLTFPrimitive = {\r\n\tvertexCount: number;\r\n\tindices: Uint16Array | Uint32Array | null;\r\n\tpositions: TypedArray;\r\n\tnormals: TypedArray;\r\n\tuvs: TypedArray | null;\r\n\tuv1s: TypedArray | null;\r\n\ttangents: TypedArray | null;\r\n\tcolors: TypedArray | null;\r\n\tmaterial: any;\r\n\tboundingBox: {\r\n\t\tmax: [number, number, number];\r\n\t\tmin: [number, number, number];\r\n\t};\r\n};\r\n\r\nexport type GLTFMesh = Array<GLTFPrimitive>;\r\n\r\nexport type GLTFAnimation = {\r\n\tchannels: Array<{\r\n\t\tinput: TypedArray;\r\n\t\toutput: TypedArray;\r\n\t\tinterpolation: string;\r\n\t\tnode: number;\r\n\t\tpath: string;\r\n\t}>;\r\n\tlength: number;\r\n};\r\n\r\nexport class GLTF {\r\n\tscenes: Array<Node>;\r\n\r\n\tnodes: Array<any>;\r\n\r\n\tcameras: Array<any>;\r\n\r\n\tmeshes: Array<any>;\r\n\r\n\timages: Array<ImageBitmap>;\r\n\r\n\tanimations: Array<GLTFAnimation>;\r\n\r\n\tprivate glbOffset: number;\r\n\r\n\tprivate buffers: ArrayBuffer[];\r\n\r\n\tprivate bufferViews: any;\r\n\r\n\taccessors: any;\r\n\r\n\tjson: any;\r\n\r\n\tprivate materials: any;\r\n\r\n\tprivate glbBin?: ArrayBuffer;\r\n\r\n\tprivate rootUrl: string;\r\n\r\n\ttextures: any[];\r\n\r\n\tsamplers: Sampler[];\r\n\r\n\tconstructor(json: any, rootUrl: string, glbOffset = 0, glbBin?: ArrayBuffer) {\r\n\t\tthis.json = json;\r\n\t\tthis.bufferViews = json.bufferViews;\r\n\t\tthis.glbOffset = glbOffset;\r\n\t\tthis.rootUrl = rootUrl;\r\n\t\tthis.scenes = json.scenes;\r\n\t\tthis.cameras = json.cameras || [];\r\n\t\tthis.glbBin = glbBin;\r\n\t\tthis.meshes = [];\r\n\t}\r\n\tasync parseData() {\r\n\t\tthis.buffers = await this.loadBuffes();\r\n\t\tthis.images = await this.loadImages();\r\n\t\tthis.parseSamplers();\r\n\t\tthis.parseTextures();\r\n\t\tthis.parseMaterials();\r\n\t\tthis.parseAccessors();\r\n\t\tthis.parseMeshs();\r\n\t\tthis.parseNodes();\r\n\t\tthis.normalizeData();\r\n\t\tthis.parseScenes();\r\n\t\tthis.parseAnimations();\r\n\t}\r\n\tprivate getAccessor(index: number) {\r\n\t\treturn this.accessors[index];\r\n\t}\r\n\tprivate parseSamplers() {\r\n\t\tthis.samplers = this.json.samplers\r\n\t\t\t? (this.json.samplers as Array<any>).map((sampler) => this.getSampler(sampler))\r\n\t\t\t: [];\r\n\t}\r\n\tprivate parseScenes() {\r\n\t\tthis.scenes = this.json.scenes.map((scene) => {\r\n\t\t\tconst nodes = scene?.nodes?.map((nodeId) => {\r\n\t\t\t\treturn this.nodes[nodeId];\r\n\t\t\t});\r\n\t\t\treturn nodes;\r\n\t\t});\r\n\t}\r\n\tprivate parseTextures() {\r\n\t\tthis.textures = this.json.textures\r\n\t\t\t? (this.json.textures as Array<any>).map((texture) => {\r\n\t\t\t\t\treturn {\r\n\t\t\t\t\t\tsampler: texture.sampler !== undefined ? this.samplers[texture.sampler] : this.getSampler({}),\r\n\t\t\t\t\t\ttexture: this.createTexture(texture.source)\r\n\t\t\t\t\t};\r\n\t\t\t  })\r\n\t\t\t: [];\r\n\t}\r\n\tprivate parseMaterials() {\r\n\t\tthis.materials = this.json.materials\r\n\t\t\t? (this.json.materials as Array<any>).map((material) => {\r\n\t\t\t\t\tconst mat = new PbrMaterial();\r\n\t\t\t\t\tconst {\r\n\t\t\t\t\t\tbaseColorFactor,\r\n\t\t\t\t\t\tmetallicFactor,\r\n\t\t\t\t\t\tmetallicRoughnessTexture,\r\n\t\t\t\t\t\tbaseColorTexture,\r\n\t\t\t\t\t\troughnessFactor\r\n\t\t\t\t\t} = material.pbrMetallicRoughness;\r\n\t\t\t\t\tif (material.normalTexture) mat.normalTexture = this.textures[material.normalTexture.index].texture;\r\n\t\t\t\t\tif (material.occlusionTexture)\r\n\t\t\t\t\t\tmat.aoTexture = this.textures[material.occlusionTexture.index].texture;\r\n\t\t\t\t\tif (material.emissiveTexture)\r\n\t\t\t\t\t\tmat.emissiveTexture = this.textures[material.emissiveTexture.index].texture;\r\n\t\t\t\t\tif (baseColorTexture) mat.baseTexture = this.textures[baseColorTexture.index].texture;\r\n\t\t\t\t\tif (metallicRoughnessTexture)\r\n\t\t\t\t\t\tmat.metalnessRoughnessTexture = this.textures[metallicRoughnessTexture.index].texture;\r\n\t\t\t\t\tif (baseColorFactor)\r\n\t\t\t\t\t\tmat.color = new Color(baseColorFactor[0], baseColorFactor[1], baseColorFactor[2]);\r\n\t\t\t\t\tmat.metalness = metallicFactor ?? 1.0;\r\n\t\t\t\t\tmat.roughness = roughnessFactor ?? 0.0;\r\n\t\t\t\t\tmat.baseSampler = new Sampler({\r\n\t\t\t\t\t\tmagFilter: \"linear\",\r\n\t\t\t\t\t\tminFilter: \"linear\",\r\n\t\t\t\t\t\taddressModeU: \"repeat\",\r\n\t\t\t\t\t\taddressModeV: \"repeat\"\r\n\t\t\t\t\t});\r\n\t\t\t\t\treturn mat;\r\n\t\t\t  })\r\n\t\t\t: [];\r\n\t}\r\n\tprivate parseAccessors() {\r\n\t\tthis.accessors = (this.json.accessors as Array<any>).map((accessor, index) => {\r\n\t\t\tconst n = gltfEnum[accessor.type] as number;\r\n\t\t\tlet array;\r\n\t\t\tif (accessor.bufferView === undefined) {\r\n\t\t\t\tarray = newTypedArray(\r\n\t\t\t\t\taccessor.componentType,\r\n\t\t\t\t\tnew ArrayBuffer(n * accessor.count * (gltfEnum[accessor.componentType] as number)),\r\n\t\t\t\t\t0,\r\n\t\t\t\t\taccessor.count * n\r\n\t\t\t\t);\r\n\t\t\t} else {\r\n\t\t\t\tarray = this.getBufferView(accessor, n);\r\n\t\t\t}\r\n\r\n\t\t\tif (accessor.sparse) {\r\n\t\t\t\taccessor.sparse.indices.count = accessor.sparse.count;\r\n\t\t\t\taccessor.sparse.values.count = accessor.sparse.count;\r\n\t\t\t\taccessor.sparse.values.componentType = accessor.componentType;\r\n\t\t\t\tconst indices = this.getBufferView(accessor.sparse.indices, 1);\r\n\t\t\t\tconst values = this.getBufferView(accessor.sparse.values, n);\r\n\t\t\t\tfor (let i = 0; i < accessor.sparse.count; i += 1) {\r\n\t\t\t\t\tfor (let j = 0; j < n; j += 1) {\r\n\t\t\t\t\t\tarray[indices[i] * n + j] = values[i * n + j];\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\treturn new Accessor({\r\n\t\t\t\tcomponentType: <number>gltfEnum[accessor.componentType],\r\n\t\t\t\tcount: accessor.count,\r\n\t\t\t\ttype: n,\r\n\t\t\t\tvalues: array,\r\n\t\t\t\tid: index,\r\n\t\t\t\tmin: accessor?.min,\r\n\t\t\t\tmax: accessor?.max\r\n\t\t\t});\r\n\t\t});\r\n\t}\r\n\tprivate parseAnimations() {\r\n\t\tthis.animations = this?.json?.animations?.map((gltfAnimation, index) => {\r\n\t\t\tconst samplers = gltfAnimation?.samplers?.map((gltfSampler) => {\r\n\t\t\t\tconst sampler = new AnimationSampler();\r\n\t\t\t\tsampler.formGltf(this, gltfSampler);\r\n\t\t\t\treturn sampler;\r\n\t\t\t});\r\n\t\t\tconst channels = gltfAnimation?.channels?.map((gltfChannel) => {\r\n\t\t\t\tconst animationChannel = new AnimationChannel();\r\n\t\t\t\tanimationChannel.sampler = samplers[gltfChannel.sampler];\r\n\t\t\t\tanimationChannel.target = new AnimationChannelTarget(\r\n\t\t\t\t\tthis.nodes[gltfChannel.target.node],\r\n\t\t\t\t\tgltfChannel.target.path\r\n\t\t\t\t);\r\n\t\t\t\treturn animationChannel;\r\n\t\t\t});\r\n\t\t\tconst animation = new Animation(index.toString(), samplers, channels);\r\n\t\t\treturn animation;\r\n\t\t});\r\n\t}\r\n\tprivate parseMeshs() {\r\n\t\tthis.meshes = this?.json?.meshes?.map?.((gltfmesh) => {\r\n\t\t\treturn {\r\n\t\t\t\tname: gltfmesh.name,\r\n\t\t\t\tprimitives: gltfmesh?.primitives?.map?.((primitive) => {\r\n\t\t\t\t\tconst material =\r\n\t\t\t\t\t\tprimitive.material !== undefined\r\n\t\t\t\t\t\t\t? this.materials[primitive.material]\r\n\t\t\t\t\t\t\t: { pbrMetallicRoughness: {} };\r\n\t\t\t\t\tconst geo = this.createGeometry(primitive, material);\r\n\t\t\t\t\tconst mesh = new Mesh(geo, material);\r\n\t\t\t\t\tmesh.name = gltfmesh.name;\r\n\t\t\t\t\treturn mesh;\r\n\t\t\t\t})\r\n\t\t\t};\r\n\t\t});\r\n\t}\r\n\tprivate getSampler(samplerJson: any) {\r\n\t\treturn new Sampler({\r\n\t\t\tmagFilter: gltfEnum[samplerJson.magFilter || 9729] as GPUFilterMode,\r\n\t\t\tminFilter: gltfEnum[samplerJson.minFilter || 9729] as GPUFilterMode,\r\n\t\t\taddressModeU: gltfEnum[samplerJson.wrapS || 10497] as GPUAddressMode,\r\n\t\t\taddressModeV: gltfEnum[samplerJson.wrapT || 10497] as GPUAddressMode\r\n\t\t});\r\n\t}\r\n\tprivate getBufferView(accessor: any, n: number) {\r\n\t\tconst bufferView = this.bufferViews[accessor.bufferView];\r\n\t\tconst offset = (bufferView.byteOffset || 0) + (accessor.byteOffset || 0);\r\n\t\tconst stride = Math.max(bufferView.byteStride / 4 || 0, n);\r\n\t\tlet array = newTypedArray(\r\n\t\t\taccessor.componentType,\r\n\t\t\tthis.buffers[bufferView.buffer],\r\n\t\t\tbufferView.buffer === 0 ? offset + this.glbOffset : offset,\r\n\t\t\t(accessor.count - 1) * stride + n\r\n\t\t);\r\n\t\tif (stride > n) {\r\n\t\t\tconst TypedArrayConstructor = array.constructor as {\r\n\t\t\t\tnew (...args: any): TypedArray;\r\n\t\t\t};\r\n\t\t\tconst strided = new TypedArrayConstructor(accessor.count * n);\r\n\t\t\tfor (let i = 0, j = 0; i < strided.length; i += n, j += stride) {\r\n\t\t\t\tfor (let k = 0; k < n; k += 1) {\r\n\t\t\t\t\tstrided[i + k] = array[j + k];\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\tarray = strided;\r\n\t\t}\r\n\t\treturn array;\r\n\t}\r\n\tprivate createGeometry(primitive, material) {\r\n\t\tlet indices = null;\r\n\t\tlet accessor = null;\r\n\t\tconst defines: { [prop: string]: boolean | number } = { HAS_NORMAL: true };\r\n\t\tlet vertexCount;\r\n\t\taccessor = this.getAccessor(primitive.attributes.POSITION);\r\n\t\tconst positions = accessor.getArray();\r\n\t\tvertexCount = accessor.count;\r\n\t\t// const { max, min } = accessor;\r\n\t\t// const boundingBox = { max, min };\r\n\t\tif (primitive.indices !== undefined) {\r\n\t\t\taccessor = this.getAccessor(primitive.indices);\r\n\t\t\tindices = toIndices(accessor.getArray());\r\n\t\t\tvertexCount = accessor.count;\r\n\t\t}\r\n\t\tlet normals;\r\n\r\n\t\tif (primitive.attributes.NORMAL !== undefined) {\r\n\t\t\taccessor = this.getAccessor(primitive.attributes.NORMAL);\r\n\t\t\tnormals = accessor.getArray();\r\n\t\t} else {\r\n\t\t\tnormals = generateNormals(indices, positions);\r\n\t\t}\r\n\r\n\t\tlet uvs = null;\r\n\t\tif (primitive.attributes.TEXCOORD_0 !== undefined) {\r\n\t\t\taccessor = this.getAccessor(primitive.attributes.TEXCOORD_0);\r\n\t\t\tuvs = accessor.getArray();\r\n\t\t\tdefines.HAS_UV = true;\r\n\t\t}\r\n\t\tlet uv1s = null;\r\n\t\tif (primitive.attributes.TEXCOORD_1 !== undefined) {\r\n\t\t\taccessor = this.getAccessor(primitive.attributes.TEXCOORD_1);\r\n\t\t\tuv1s = accessor.getArray();\r\n\t\t\tdefines.HAS_UV1 = true;\r\n\t\t}\r\n\r\n\t\tlet tangents = null;\r\n\t\tif (primitive.attributes.TANGENT !== undefined && primitive.attributes.NORMAL !== undefined) {\r\n\t\t\taccessor = this.getAccessor(primitive.attributes.TANGENT);\r\n\t\t\ttangents = accessor.getArray();\r\n\t\t\t// defines.HAS_TANGENT = true;\r\n\t\t} else if (material.normalTexture) {\r\n\t\t\t// tangents = generateTangents(indices, positions, normals, uvs!);\r\n\t\t}\r\n\t\tlet colors = null,\r\n\t\t\tcolorSize = 3;\r\n\t\tif (primitive.attributes.COLOR_0 !== undefined) {\r\n\t\t\taccessor = this.accessors[primitive.attributes.COLOR_0];\r\n\t\t\tcolors = accessor.getArray();\r\n\t\t\tcolorSize = accessor.type;\r\n\t\t\tdefines.HAS_COLOR = true;\r\n\t\t}\r\n\t\tlet joints = null;\r\n\t\tif (primitive.attributes.JOINTS_0 !== undefined) {\r\n\t\t\taccessor = this.getAccessor(primitive.attributes.JOINTS_0);\r\n\t\t\tjoints = accessor.getArray();\r\n\t\t\tdefines.HAS_SKIN = true;\r\n\t\t}\r\n\t\tlet weights = null;\r\n\t\tif (primitive.attributes.WEIGHTS_0 !== undefined) {\r\n\t\t\taccessor = this.getAccessor(primitive.attributes.WEIGHTS_0);\r\n\t\t\tweights = accessor.getArray();\r\n\t\t}\r\n\t\tconst geo = new Geometry({ type: \"pbrGeomtry\" });\r\n\t\tif (indices) geo.setIndice(Array.from(indices));\r\n\t\tif (positions) geo.setAttribute(new Float32Attribute(\"position\", Array.from(positions), 3));\r\n\t\tif (normals) geo.setAttribute(new Float32Attribute(\"normal\", Array.from(normals), 3));\r\n\t\tif (colors) geo.setAttribute(new Float32Attribute(\"color\", Array.from(colors), colorSize));\r\n\t\tif (uvs) geo.setAttribute(new Float32Attribute(\"uv\", Array.from(uvs), 2));\r\n\t\tif (joints) geo.setAttribute(new Float32Attribute(\"joint0\", Array.from(joints), 4));\r\n\t\tif (weights) geo.setAttribute(new Float32Attribute(\"weight0\", Array.from(weights), 4));\r\n\t\tgeo.defines = defines;\r\n\t\tgeo.computeBoundingSphere(Array.from(positions));\r\n\t\tgeo.count = vertexCount;\r\n\t\treturn geo;\r\n\t}\r\n\tprivate createTexture(source: number) {\r\n\t\treturn new Texture({\r\n\t\t\tsize: {\r\n\t\t\t\twidth: this.images[source].width,\r\n\t\t\t\theight: this.images[source].height,\r\n\t\t\t\tdepth: 1\r\n\t\t\t},\r\n\t\t\tdata: {\r\n\t\t\t\tsource: this.images[source]\r\n\t\t\t},\r\n\t\t\tformat: \"rgba8unorm\",\r\n\t\t\tusage: GPUTextureUsage.TEXTURE_BINDING | GPUTextureUsage.COPY_DST | GPUTextureUsage.RENDER_ATTACHMENT\r\n\t\t});\r\n\t}\r\n\tprivate async loadImages() {\r\n\t\tconst images: Array<ImageBitmap> = [];\r\n\t\tlet loadExternalImages: Promise<any> = Promise.resolve();\r\n\t\tif (this.json.images) {\r\n\t\t\tloadExternalImages = Promise.all(\r\n\t\t\t\tthis.json.images.map(async (image: any, index: number) => {\r\n\t\t\t\t\tif (image.uri) {\r\n\t\t\t\t\t\tconst imageUrl = image.uri.slice(0, 5) === \"data:\" ? image.uri : `${this.rootUrl}/${image.uri}`;\r\n\t\t\t\t\t\timages[index] = await fetch(imageUrl)\r\n\t\t\t\t\t\t\t.then((response) => response.blob())\r\n\t\t\t\t\t\t\t.then((blob) =>\r\n\t\t\t\t\t\t\t\tcreateImageBitmap(blob, {\r\n\t\t\t\t\t\t\t\t\tcolorSpaceConversion: \"none\"\r\n\t\t\t\t\t\t\t\t})\r\n\t\t\t\t\t\t\t);\r\n\t\t\t\t\t}\r\n\t\t\t\t})\r\n\t\t\t);\r\n\t\t}\r\n\t\tlet loadInternalImages: Promise<any> = Promise.resolve();\r\n\t\tif (this.json.images) {\r\n\t\t\tloadInternalImages = Promise.all(\r\n\t\t\t\tthis.json.images.map(async (image: any, index: number) => {\r\n\t\t\t\t\tif (image.bufferView !== undefined) {\r\n\t\t\t\t\t\tconst { buffer, byteOffset, byteLength } = this.json.bufferViews[image.bufferView];\r\n\t\t\t\t\t\tconst array = new Uint8Array(\r\n\t\t\t\t\t\t\tthis.buffers[buffer],\r\n\t\t\t\t\t\t\tbuffer === 0 ? byteOffset + this.glbOffset : byteOffset,\r\n\t\t\t\t\t\t\tbyteLength\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\t\tlet type;\r\n\t\t\t\t\t\tif (image.mimeType) {\r\n\t\t\t\t\t\t\ttype = image.mimeType;\r\n\t\t\t\t\t\t} else {\r\n\t\t\t\t\t\t\ttype = array[0] === 0xff ? \"image/jpeg\" : \"image/png\";\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t\tconst blob = new Blob([array], { type });\r\n\t\t\t\t\t\timages[index] = await createImageBitmap(blob, {\r\n\t\t\t\t\t\t\tcolorSpaceConversion: \"none\"\r\n\t\t\t\t\t\t});\r\n\t\t\t\t\t}\r\n\t\t\t\t})\r\n\t\t\t);\r\n\t\t}\r\n\r\n\t\tawait Promise.all([loadExternalImages, loadInternalImages]);\r\n\t\treturn images;\r\n\t}\r\n\tprivate async loadBuffes() {\r\n\t\tconst buffers: Array<ArrayBuffer> = [];\r\n\t\tawait Promise.all(\r\n\t\t\tthis.json.buffers.map((buffer: any, index: number) => {\r\n\t\t\t\tif (!buffer.uri) {\r\n\t\t\t\t\tif (index !== 0) {\r\n\t\t\t\t\t\tthrow new Error(\"buffer uri undefined\");\r\n\t\t\t\t\t}\r\n\t\t\t\t\tbuffers[index] = this.glbBin!;\r\n\t\t\t\t\treturn Promise.resolve();\r\n\t\t\t\t}\r\n\t\t\t\tconst bufferUrl = buffer.uri.slice(0, 5) === \"data:\" ? buffer.uri : `${this.rootUrl}/${buffer.uri}`;\r\n\t\t\t\treturn fetch(bufferUrl)\r\n\t\t\t\t\t.then((response) => response.arrayBuffer())\r\n\t\t\t\t\t.then((arrayBuffer: ArrayBuffer) => {\r\n\t\t\t\t\t\tbuffers[index] = arrayBuffer;\r\n\t\t\t\t\t});\r\n\t\t\t})\r\n\t\t);\r\n\t\treturn buffers;\r\n\t}\r\n\tprivate parseNodes() {\r\n\t\tthis.nodes = this?.json?.nodes?.map((gltfNode) => {\r\n\t\t\tconst node = new Node();\r\n\t\t\tthis.parseNodeTRS(node, gltfNode);\r\n\t\t\tif (gltfNode.name) node.name = gltfNode.name;\r\n\t\t\tif (gltfNode.mesh != undefined) {\r\n\t\t\t\tlet gltfSkin = undefined,\r\n\t\t\t\t\tisSkinMesh = false;\r\n\t\t\t\tif (gltfNode.skin != undefined) {\r\n\t\t\t\t\tgltfSkin = this.json.skins[gltfNode.skin];\r\n\t\t\t\t\tisSkinMesh = true;\r\n\t\t\t\t}\r\n\t\t\t\tthis.meshes[gltfNode.mesh].primitives.forEach((primitive: Mesh, index: number, source: Array<Mesh>) => {\r\n\t\t\t\t\tconst tempPrimitive =\r\n\t\t\t\t\t\tisSkinMesh && primitive.type == RenderObjectType.Mesh\r\n\t\t\t\t\t\t\t? new SKinMesh(primitive.geometry, primitive.material)\r\n\t\t\t\t\t\t\t: primitive;\r\n\t\t\t\t\tif (isSkinMesh && primitive.type == RenderObjectType.Mesh) {\r\n\t\t\t\t\t\tsource[index] = tempPrimitive;\r\n\t\t\t\t\t\ttempPrimitive.setSkinData({\r\n\t\t\t\t\t\t\tinverseBindMatrices: this.getAccessor(gltfSkin.inverseBindMatrices).getMat4Array(),\r\n\t\t\t\t\t\t\tjoints: gltfSkin.joints\r\n\t\t\t\t\t\t\t// name: gltfSkin.name,\r\n\t\t\t\t\t\t\t// skeleton: gltfSkin.skeleton\r\n\t\t\t\t\t\t});\r\n\t\t\t\t\t}\r\n\t\t\t\t\tnode.add(tempPrimitive);\r\n\t\t\t\t});\r\n\t\t\t}\r\n\t\t\treturn node;\r\n\t\t});\r\n\t}\r\n\tprivate parseNodeTRS(node: Node, gltfNode: GLTFNodeParms): Node {\r\n\t\tlet { matrix, rotation, translation, scale } = gltfNode;\r\n\t\tif (matrix) {\r\n\t\t\tconst tempMatrix4 = new Matrix4(),\r\n\t\t\t\ttempScale = new Vector3(),\r\n\t\t\t\ttempTranslation = new Vector3(),\r\n\t\t\t\ttempRotation = new Quaternion();\r\n\t\t\tMatrix4.fromColumnMajorArray(matrix, tempMatrix4);\r\n\t\t\tMatrix4.getScale(tempMatrix4, tempScale);\r\n\t\t\tMatrix4.getTranslation(tempMatrix4, tempTranslation);\r\n\t\t\tMatrix4.getRotation(tempMatrix4, tempRotation);\r\n\t\t\trotation = tempRotation.toArray();\r\n\t\t\ttranslation = tempTranslation.toArray();\r\n\t\t\tscale = tempScale.toArray();\r\n\t\t}\r\n\t\tif (rotation) node.quaternion.set(rotation[0], rotation[1], rotation[2], rotation[3]);\r\n\t\tif (translation) node.position.set(translation[0], translation[1], translation[2]);\r\n\t\tif (scale) node.scale.set(scale[0], scale[1], scale[2]);\r\n\t\treturn node;\r\n\t}\r\n\tprivate normalizeData() {\r\n\t\tthis?.nodes?.map?.((node: Node, index) => {\r\n\t\t\tthis.json?.nodes[index]?.children?.map((nodeId: number) => {\r\n\t\t\t\tconst childNode = this.nodes[nodeId];\r\n\t\t\t\tnode.add(childNode);\r\n\t\t\t});\r\n\t\t});\r\n\t\tthis.meshes.map((mesh) => {\r\n\t\t\tmesh.primitives.map((primitive) => {\r\n\t\t\t\tif (primitive.type == RenderObjectType.SkinMesh)\r\n\t\t\t\t\tprimitive.joints = primitive.joints.map((joint) => {\r\n\t\t\t\t\t\treturn this.nodes[<number>joint];\r\n\t\t\t\t\t});\r\n\t\t\t});\r\n\t\t});\r\n\t}\r\n}\r\nexport async function loadGLTF(url: string) {\r\n\tlet gltf;\r\n\tconst ext = url.split(\".\").pop();\r\n\tconst rootUrl = url.substring(0, url.lastIndexOf(\"/\"));\r\n\tif (ext === \"gltf\") {\r\n\t\tconst json = await fetch(url).then((response) => response.json());\r\n\t\tgltf = new GLTF(json, rootUrl, 0);\r\n\t} else {\r\n\t\tconst glb = await fetch(url).then((response) => response.arrayBuffer());\r\n\t\tconst jsonLength = new Uint32Array(glb, 12, 1)[0];\r\n\t\tconst jsonChunk = new Uint8Array(glb, 20, jsonLength);\r\n\t\tconst json = JSON.parse(new TextDecoder(\"utf-8\").decode(jsonChunk));\r\n\t\tgltf = new GLTF(json, rootUrl, 28 + jsonLength, glb);\r\n\t}\r\n\tawait gltf.parseData();\r\n\treturn gltf;\r\n}\r\ntype GLTFNodeParms = {\r\n\tchildren?: number[];\r\n\tmatrix?: number[];\r\n\tscale?: number[];\r\n\trotation?: number[];\r\n\ttranslation?: number[];\r\n};\r\n","import Texture from \"../render/Texture\";\r\nexport async function loadPbrTexture(brdf, diffuse, specular) {\r\n\tif (!brdf) return;\r\n\tconst brdfTexture = await loadTexture(brdf);\r\n\tconst diffuseTexture = await loadCubeTexture(diffuse);\r\n\tconst specularTexture = await loadCubeTexture(specular);\r\n\treturn {\r\n\t\tbrdfTexture,\r\n\t\tdiffuseTexture,\r\n\t\tspecularTexture\r\n\t};\r\n}\r\nexport async function loadCubeTexture(urls) {\r\n\tconst promises = urls.map((src) => {\r\n\t\tconst img = document.createElement(\"img\");\r\n\t\timg.src = src;\r\n\t\treturn img.decode().then(() => createImageBitmap(img));\r\n\t});\r\n\tconst images = await Promise.all(promises);\r\n\tawait Promise.all(images);\r\n\tconst data = images.map((image, i) => {\r\n\t\treturn {\r\n\t\t\tsource: image,\r\n\t\t\twidth: image.width,\r\n\t\t\theight: image.height,\r\n\t\t\tdepth: 1,\r\n\t\t\tx: 0,\r\n\t\t\ty: 0,\r\n\t\t\tz: i\r\n\t\t};\r\n\t});\r\n\treturn new Texture({\r\n\t\tsize: {\r\n\t\t\twidth: images[0].width,\r\n\t\t\theight: images[0].height,\r\n\t\t\tdepth: 6\r\n\t\t},\r\n\t\tformat: \"rgba8unorm\",\r\n\t\tusage: GPUTextureUsage.TEXTURE_BINDING | GPUTextureUsage.COPY_DST | GPUTextureUsage.RENDER_ATTACHMENT,\r\n\t\tdata,\r\n\t\tviewFormats: \"cube\",\r\n\t\tmipLevelCount: 6,\r\n\t\tneedMipMap: true\r\n\t});\r\n}\r\nexport async function loadTexture(url) {\r\n\tconst img = document.createElement(\"img\");\r\n\timg.src = url;\r\n\tawait img.decode();\r\n\tconst imageBitmap = await createImageBitmap(img);\r\n\tconst baseTexture = new Texture({\r\n\t\tsize: { width: imageBitmap.width, height: imageBitmap.height, depth: 1 },\r\n\t\tdata: {\r\n\t\t\tsource: imageBitmap\r\n\t\t},\r\n\t\tformat: \"rgba8unorm\"\r\n\t});\r\n\treturn baseTexture;\r\n}\r\n","import GMath from \"./Math.js\";\nimport Vector3 from \"./Vector3.js\";\n// from three.js\nclass Spherical {\n\tradius: number;\n\tphi: number;\n\ttheta: number;\n\n\tconstructor(radius = 1, phi = 0, theta = 0) {\n\t\tthis.radius = radius;\n\t\tthis.phi = phi; // polar angle\n\t\tthis.theta = theta; // azimuthal angle\n\n\t\treturn this;\n\t}\n\tset(radius: number, phi: number, theta: number): Spherical {\n\t\tthis.radius = radius;\n\t\tthis.phi = phi;\n\t\tthis.theta = theta;\n\n\t\treturn this;\n\t}\n\tcopy(other: Spherical): Spherical {\n\t\tthis.radius = other.radius;\n\t\tthis.phi = other.phi;\n\t\tthis.theta = other.theta;\n\n\t\treturn this;\n\t}\n\t// restrict phi to be between EPS and PI-EPS\n\tmakeSafe(): Spherical {\n\t\tconst EPS = 0.000001;\n\t\tthis.phi = Math.max(EPS, Math.min(Math.PI - EPS, this.phi));\n\n\t\treturn this;\n\t}\n\n\tsetFromVector3(v: Vector3): Spherical {\n\t\treturn this.setFromCartesianCoords(v.x, v.y, v.z);\n\t}\n\tsetFromCartesianCoords(x: number, y: number, z: number): Spherical {\n\t\tthis.radius = Math.sqrt(x * x + y * y + z * z);\n\n\t\tif (this.radius === 0) {\n\t\t\tthis.theta = 0;\n\t\t\tthis.phi = 0;\n\t\t} else {\n\t\t\tthis.theta = Math.atan2(x, z);\n\t\t\tthis.phi = Math.acos(GMath.clamp(y / this.radius, -1, 1));\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tclone(): Spherical {\n\t\treturn new Spherical(this.radius, this.phi, this.theta);\n\t}\n}\n\nexport { Spherical };\n","import { EventDispatcher } from \"../core/EventDispatcher\";\r\nimport { Quaternion } from \"../math/Quaternion\";\r\nimport { Spherical } from \"../math/Spherical\";\r\nimport Vector2 from \"../math/Vector2\";\r\nimport Vector3 from \"../math/Vector3\";\r\n//from three.js\r\n\r\nconst _changeEvent = { type: \"change\" };\r\nconst _startEvent = { type: \"start\" };\r\nconst _endEvent = { type: \"end\" };\r\n\r\nexport default class OrbitControl extends EventDispatcher {\r\n  domElement: any;\r\n  object: any;\r\n  enabled: boolean;\r\n  target: any;\r\n  minDistance: number;\r\n  maxDistance: number;\r\n  minZoom: number;\r\n  maxZoom: number;\r\n  minPolarAngle: number;\r\n  maxPolarAngle: number;\r\n  minAzimuthAngle: number;\r\n  maxAzimuthAngle: number;\r\n  enableDamping: boolean;\r\n  dampingFactor: number;\r\n  enableZoom: boolean;\r\n  zoomSpeed: number;\r\n  enableRotate: boolean;\r\n  rotateSpeed: number;\r\n  enablePan: boolean;\r\n  panSpeed: number;\r\n  screenSpacePanning: boolean;\r\n  keyPanSpeed: number;\r\n  autoRotate: boolean;\r\n  autoRotateSpeed: number;\r\n  keys: { LEFT: string; UP: string; RIGHT: string; BOTTOM: string };\r\n  mouseButtons: { LEFT: any; MIDDLE: any; RIGHT: any };\r\n  touches: { ONE: any; TWO: any };\r\n  target0: any;\r\n  position0: any;\r\n  zoom0: any;\r\n  private _domElementKeyEvents: any;\r\n  spherical: any;\r\n  onPointerMove: (event: any) => void;\r\n  onPointerUp: (event: any) => void;\r\n  onContextMenu: (event: any) => void;\r\n  onPointerDown: (event: any) => void;\r\n  onMouseWheel: (event: any) => void;\r\n  onKeyDown: (event: any) => void;\r\n  getAutoRotationAngle: () => number;\r\n  update: () => boolean;\r\n  constructor(object, domElement) {\r\n    super();\r\n\r\n    if (domElement === undefined)\r\n      console.warn(\r\n        'OrbitControls: The second parameter \"domElement\" is now mandatory.'\r\n      );\r\n    if (domElement === document)\r\n      console.error(\r\n        'OrbitControls: \"document\" should not be used as the target \"domElement\". Please use \"renderer.domElement\" instead.'\r\n      );\r\n\r\n    this.object = object;\r\n    this.domElement = domElement;\r\n    this.domElement.style.touchAction = \"none\"; // disable touch scroll\r\n\r\n    // Set to false to disable this control\r\n    this.enabled = true;\r\n\r\n    // \"target\" sets the location of focus, where the object orbits around\r\n    this.target = new Vector3();\r\n\r\n    // How far you can dolly in and out ( PerspectiveCamera only )\r\n    this.minDistance = 0;\r\n    this.maxDistance = Infinity;\r\n\r\n    // How far you can zoom in and out ( OrthographicCamera only )\r\n    this.minZoom = 0;\r\n    this.maxZoom = Infinity;\r\n\r\n    // How far you can orbit vertically, upper and lower limits.\r\n    // Range is 0 to Math.PI radians.\r\n    this.minPolarAngle = 0; // radians\r\n    this.maxPolarAngle = Math.PI; // radians\r\n\r\n    // How far you can orbit horizontally, upper and lower limits.\r\n    // If set, the interval [ min, max ] must be a sub-interval of [ - 2 PI, 2 PI ], with ( max - min < 2 PI )\r\n    this.minAzimuthAngle = -Infinity; // radians\r\n    this.maxAzimuthAngle = Infinity; // radians\r\n\r\n    // Set to true to enable damping (inertia)\r\n    // If damping is enabled, you must call controls.update() in your animation loop\r\n    this.enableDamping = false;\r\n    this.dampingFactor = 0.05;\r\n\r\n    // This option actually enables dollying in and out; left as \"zoom\" for backwards compatibility.\r\n    // Set to false to disable zooming\r\n    this.enableZoom = true;\r\n    this.zoomSpeed = 1.0;\r\n\r\n    // Set to false to disable rotating\r\n    this.enableRotate = true;\r\n    this.rotateSpeed = 1.0;\r\n\r\n    // Set to false to disable panning\r\n    this.enablePan = true;\r\n    this.panSpeed = 1.0;\r\n    this.screenSpacePanning = false; // if false, pan orthogonal to world-space direction camera.up\r\n    this.keyPanSpeed = 7.0; // pixels moved per arrow key push\r\n\r\n    // Set to true to automatically rotate around the target\r\n    // If auto-rotate is enabled, you must call controls.update() in your animation loop\r\n    this.autoRotate = false;\r\n    this.autoRotateSpeed = 2.0; // 30 seconds per orbit when fps is 60\r\n\r\n    // The four arrow keys\r\n    this.keys = {\r\n      LEFT: \"ArrowLeft\",\r\n      UP: \"ArrowUp\",\r\n      RIGHT: \"ArrowRight\",\r\n      BOTTOM: \"ArrowDown\",\r\n    };\r\n\r\n    // Mouse buttons\r\n    this.mouseButtons = {\r\n      LEFT: MOUSE.ROTATE,\r\n      MIDDLE: MOUSE.DOLLY,\r\n      RIGHT: MOUSE.PAN,\r\n    };\r\n\r\n    // Touch fingers\r\n    this.touches = { ONE: TOUCH.ROTATE, TWO: TOUCH.DOLLY_PAN };\r\n\r\n    // for reset\r\n    this.target0 = this.target.clone();\r\n    this.position0 = this.object.position.clone();\r\n    this.zoom0 = this.object.zoom;\r\n\r\n    // the target DOM element for key events\r\n    this._domElementKeyEvents = null;\r\n\r\n    //\r\n    // public methods\r\n    //\r\n    // this method is exposed, but perhaps it would be better if we can make it private...\r\n    const that = this;\r\n    this.update = (function () {\r\n      const offset = new Vector3();\r\n      // so camera.up is the orbit axis\r\n      const quat = new Quaternion().setFromUnitVectors(\r\n        that.object.up,\r\n        new Vector3(0, 1, 0)\r\n      );\r\n      const quatInverse = quat.clone().invert();\r\n\r\n      const lastPosition = new Vector3();\r\n      const lastQuaternion = new Quaternion();\r\n\r\n      const twoPI = 2 * Math.PI;\r\n      return function update() {\r\n        const position = that.object.position;\r\n\r\n        offset.copy(position).subtract(that.target);\r\n\r\n        // rotate offset to \"y-axis-is-up\" space\r\n        offset.applyQuaternion(quat);\r\n\r\n        // angle from z-axis around y-axis\r\n        spherical.setFromVector3(offset);\r\n\r\n        if (that.autoRotate && state === STATE.NONE) {\r\n          rotateLeft(that.getAutoRotationAngle());\r\n        }\r\n\r\n        if (that.enableDamping) {\r\n          spherical.theta += sphericalDelta.theta * that.dampingFactor;\r\n          spherical.phi += sphericalDelta.phi * that.dampingFactor;\r\n        } else {\r\n          spherical.theta += sphericalDelta.theta;\r\n          spherical.phi += sphericalDelta.phi;\r\n        }\r\n\r\n        // restrict theta to be between desired limits\r\n\r\n        let min = that.minAzimuthAngle;\r\n        let max = that.maxAzimuthAngle;\r\n\r\n        if (isFinite(min) && isFinite(max)) {\r\n          if (min < -Math.PI) min += twoPI;\r\n          else if (min > Math.PI) min -= twoPI;\r\n\r\n          if (max < -Math.PI) max += twoPI;\r\n          else if (max > Math.PI) max -= twoPI;\r\n\r\n          if (min <= max) {\r\n            spherical.theta = Math.max(min, Math.min(max, spherical.theta));\r\n          } else {\r\n            spherical.theta =\r\n              spherical.theta > (min + max) / 2\r\n                ? Math.max(min, spherical.theta)\r\n                : Math.min(max, spherical.theta);\r\n          }\r\n        }\r\n\r\n        // restrict phi to be between desired limits\r\n        spherical.phi = Math.max(\r\n          that.minPolarAngle,\r\n          Math.min(that.maxPolarAngle, spherical.phi)\r\n        );\r\n\r\n        spherical.makeSafe();\r\n\r\n        spherical.radius *= scale;\r\n\r\n        // restrict radius to be between desired limits\r\n        spherical.radius = Math.max(\r\n          that.minDistance,\r\n          Math.min(that.maxDistance, spherical.radius)\r\n        );\r\n\r\n        // move target to panned location\r\n\r\n        if (that.enableDamping === true) {\r\n          that.target.addScaledVector(panOffset, that.dampingFactor);\r\n        } else {\r\n          that.target.add(panOffset);\r\n        }\r\n        Vector3.fromSpherical(spherical, offset);\r\n        // rotate offset back to \"camera-up-vector-is-up\" space\r\n        offset.applyQuaternion(quatInverse);\r\n\r\n        position.copy(that.target).add(offset);\r\n\r\n        that.object.lookAt(that.target.x, that.target.y, that.target.z);\r\n\r\n        if (that.enableDamping === true) {\r\n          sphericalDelta.theta *= 1 - that.dampingFactor;\r\n          sphericalDelta.phi *= 1 - that.dampingFactor;\r\n\r\n          Vector3.multiplyByScalar(\r\n            panOffset,\r\n            1 - that.dampingFactor,\r\n            panOffset\r\n          );\r\n          // panOffset.multiplyScalar( 1 - this.dampingFactor );\r\n        } else {\r\n          sphericalDelta.set(0, 0, 0);\r\n\r\n          panOffset.set(0, 0, 0);\r\n        }\r\n\r\n        scale = 1;\r\n\r\n        // update condition is:\r\n        // min(camera displacement, camera rotation in radians)^2 > EPS\r\n        // using small-angle approximation cos(x/2) = 1 - x^2 / 8\r\n\r\n        if (\r\n          zoomChanged ||\r\n          Vector3.distanceSquared(lastPosition, that.object.position) > EPS ||\r\n          8 * (1 - lastQuaternion.dot(that.object.quaternion)) > EPS\r\n        ) {\r\n          that.dispatchEvent(_changeEvent);\r\n\r\n          //lastPosition.copy( this.object.position );\r\n          Vector3.clone(that.object.position, lastPosition);\r\n          Quaternion.clone(that.object.quaternion, lastQuaternion);\r\n          //lastQuaternion.copy( this.object.quaternion );\r\n          zoomChanged = false;\r\n\r\n          return true;\r\n        }\r\n\r\n        return false;\r\n      };\r\n    })();\r\n    this.init();\r\n  }\r\n  getPolarAngle() {\r\n    return this.spherical.phi;\r\n  }\r\n  getAzimuthalAngle() {\r\n    return this.spherical.theta;\r\n  }\r\n\r\n  getDistance() {\r\n    return Vector3.distance(this.object.position, this.target);\r\n  }\r\n\r\n  listenToKeyEvents(domElement) {\r\n    domElement.addEventListener(\"keydown\", this.onKeyDown);\r\n    this._domElementKeyEvents = domElement;\r\n  }\r\n\r\n  saveState() {\r\n    Vector3.clone(this.target, this.target0);\r\n    //this.target0.copy( this.target );\r\n    Vector3.clone(this.object.position, this.position0);\r\n    //this.position0.copy( this.object.position );\r\n    this.zoom0 = this.object.zoom;\r\n  }\r\n\r\n  reset() {\r\n    Vector3.clone(this.target0, this.target);\r\n    //this.target.copy( this.target0 );\r\n    Vector3.clone(this.position0, this.object.position);\r\n    //this.object.position.copy( this.position0 );\r\n    this.object.zoom = this.zoom0;\r\n\r\n    this.object.updateProjectionMatrix();\r\n    this.dispatchEvent(_changeEvent);\r\n\r\n    this.update();\r\n\r\n    state = STATE.NONE;\r\n  }\r\n\r\n  private init() {\r\n    const that = this;\r\n    const panLeft = (function () {\r\n      const v = new Vector3();\r\n      return function panLeft(distance, objectMatrix) {\r\n        v.setFromMatrixColumn(objectMatrix, 0); // get X column of objectMatrix\r\n        v.multiplyByScalar(-distance);\r\n        panOffset.add(v);\r\n      };\r\n    })();\r\n    const panUp = (function () {\r\n      const panUpV = new Vector3();\r\n      return function panUp(distance, objectMatrix) {\r\n        if (that.screenSpacePanning === true) {\r\n          panUpV.setFromMatrixColumn(objectMatrix, 1);\r\n        } else {\r\n          panUpV.setFromMatrixColumn(objectMatrix, 0);\r\n          //panUpV.crossVectors( this.object.up, panUpV );\r\n          Vector3.cross(that.object.up, panUpV, panUpV);\r\n        }\r\n\r\n        panUpV.multiplyByScalar(distance);\r\n\r\n        panOffset.add(panUpV);\r\n      };\r\n    })();\r\n    // deltaX and deltaY are in pixels; right and down are positive\r\n    const pan = (function () {\r\n      const offset = new Vector3();\r\n      return function pan(deltaX, deltaY) {\r\n        const element = that.domElement;\r\n        if (that.object.isPerspectiveCamera) {\r\n          // perspective\r\n          const position = that.object.position;\r\n          offset.copy(position).subtract(that.target);\r\n          let targetDistance = offset.length();\r\n\r\n          // half of the fov is center to top of screen\r\n          targetDistance *= Math.tan(((that.object.fov / 2) * Math.PI) / 180.0);\r\n\r\n          // we use only clientHeight here so aspect ratio does not distort speed\r\n          panLeft(\r\n            (2 * deltaX * targetDistance) / element.clientHeight,\r\n            that.object.modelMatrix\r\n          );\r\n          panUp(\r\n            (2 * deltaY * targetDistance) / element.clientHeight,\r\n            that.object.modelMatrix\r\n          );\r\n        } else if (that.object.isOrthographicCamera) {\r\n          // orthographic\r\n          panLeft(\r\n            (deltaX * (that.object.right - that.object.left)) /\r\n              that.object.zoom /\r\n              element.clientWidth,\r\n            that.object.modelMatrix\r\n          );\r\n          panUp(\r\n            (deltaY * (that.object.top - that.object.bottom)) /\r\n              that.object.zoom /\r\n              element.clientHeight,\r\n            that.object.modelMatrix\r\n          );\r\n        } else {\r\n          // camera neither orthographic nor perspective\r\n          console.warn(\r\n            \"WARNING: OrbitControls.js encountered an unknown camera type - pan disabled.\"\r\n          );\r\n          that.enablePan = false;\r\n        }\r\n      };\r\n    })();\r\n    const dollyOut = (dollyScale) => {\r\n      if (this.object.isPerspectiveCamera) {\r\n        scale /= dollyScale;\r\n      } else if (this.object.isOrthographicCamera) {\r\n        this.object.zoom = Math.max(\r\n          this.minZoom,\r\n          Math.min(this.maxZoom, this.object.zoom * dollyScale)\r\n        );\r\n        this.object.updateProjectionMatrix();\r\n        zoomChanged = true;\r\n      } else {\r\n        console.warn(\r\n          \"WARNING: OrbitControls.js encountered an unknown camera type - dolly/zoom disabled.\"\r\n        );\r\n        this.enableZoom = false;\r\n      }\r\n    };\r\n\r\n    const dollyIn = (dollyScale) => {\r\n      if (this.object.isPerspectiveCamera) {\r\n        scale *= dollyScale;\r\n      } else if (this.object.isOrthographicCamera) {\r\n        this.object.zoom = Math.max(\r\n          this.minZoom,\r\n          Math.min(this.maxZoom, this.object.zoom / dollyScale)\r\n        );\r\n        this.object.updateProjectionMatrix();\r\n        zoomChanged = true;\r\n      } else {\r\n        console.warn(\r\n          \"WARNING: OrbitControls.js encountered an unknown camera type - dolly/zoom disabled.\"\r\n        );\r\n        this.enableZoom = false;\r\n      }\r\n    };\r\n    const handleMouseMoveRotate = (event) => {\r\n      rotateEnd.set(event.clientX, event.clientY);\r\n\r\n      Vector2.subtract(rotateEnd, rotateStart, rotateDelta);\r\n      Vector2.multiplyByScalar(rotateDelta, this.rotateSpeed, rotateDelta);\r\n      //rotateDelta.subVectors( rotateEnd, rotateStart ).multiplyScalar( this.rotateSpeed );\r\n\r\n      const element = this.domElement;\r\n\r\n      rotateLeft((2 * Math.PI * rotateDelta.x) / element.clientHeight); // yes, height\r\n\r\n      rotateUp((2 * Math.PI * rotateDelta.y) / element.clientHeight);\r\n\r\n      Vector2.clone(rotateEnd, rotateStart);\r\n      //rotateStart.copy( rotateEnd );\r\n\r\n      this.update();\r\n    };\r\n\r\n    const handleMouseMoveDolly = (event) => {\r\n      dollyEnd.set(event.clientX, event.clientY);\r\n\r\n      Vector2.subtract(dollyEnd, dollyStart, dollyDelta);\r\n      // dollyDelta.subVectors( dollyEnd, dollyStart );\r\n\r\n      if (dollyDelta.y > 0) {\r\n        dollyOut(getZoomScale());\r\n      } else if (dollyDelta.y < 0) {\r\n        dollyIn(getZoomScale());\r\n      }\r\n\r\n      Vector2.clone(dollyEnd, dollyStart);\r\n      // dollyStart.copy( dollyEnd );\r\n\r\n      this.update();\r\n    };\r\n\r\n    const handleMouseMovePan = (event) => {\r\n      panEnd.set(event.clientX, event.clientY);\r\n\r\n      Vector2.subtract(panEnd, panStart, panDelta);\r\n      Vector2.multiplyByScalar(panDelta, this.panSpeed, panDelta);\r\n      //panDelta.subVectors( panEnd, panStart ).multiplyScalar( this.panSpeed );\r\n\r\n      pan(panDelta.x, panDelta.y);\r\n\r\n      Vector2.clone(panEnd, panStart);\r\n      //panStart.copy( panEnd );\r\n\r\n      this.update();\r\n    };\r\n\r\n    const handleMouseWheel = (event) => {\r\n      if (event.deltaY < 0) {\r\n        dollyIn(getZoomScale());\r\n      } else if (event.deltaY > 0) {\r\n        dollyOut(getZoomScale());\r\n      }\r\n\r\n      this.update();\r\n    };\r\n\r\n    const handleKeyDown = (event) => {\r\n      let needsUpdate = false;\r\n\r\n      switch (event.code) {\r\n        case this.keys.UP:\r\n          pan(0, this.keyPanSpeed);\r\n          needsUpdate = true;\r\n          break;\r\n\r\n        case this.keys.BOTTOM:\r\n          pan(0, -this.keyPanSpeed);\r\n          needsUpdate = true;\r\n          break;\r\n\r\n        case this.keys.LEFT:\r\n          pan(this.keyPanSpeed, 0);\r\n          needsUpdate = true;\r\n          break;\r\n\r\n        case this.keys.RIGHT:\r\n          pan(-this.keyPanSpeed, 0);\r\n          needsUpdate = true;\r\n          break;\r\n      }\r\n\r\n      if (needsUpdate) {\r\n        // prevent the browser from scrolling on cursor keys\r\n        event.preventDefault();\r\n\r\n        this.update();\r\n      }\r\n    };\r\n\r\n    const handleTouchStartDollyPan = () => {\r\n      if (this.enableZoom) handleTouchStartDolly();\r\n\r\n      if (this.enablePan) handleTouchStartPan();\r\n    };\r\n    const handleTouchStartDollyRotate = () => {\r\n      if (this.enableZoom) handleTouchStartDolly();\r\n\r\n      if (this.enableRotate) handleTouchStartRotate();\r\n    };\r\n\r\n    const handleTouchMoveRotate = (event) => {\r\n      if (pointers.length == 1) {\r\n        rotateEnd.set(event.pageX, event.pageY);\r\n      } else {\r\n        const position = getSecondPointerPosition(event);\r\n\r\n        const x = 0.5 * (event.pageX + position.x);\r\n        const y = 0.5 * (event.pageY + position.y);\r\n\r\n        rotateEnd.set(x, y);\r\n      }\r\n\r\n      Vector2.subtract(rotateEnd, rotateStart, rotateDelta);\r\n      Vector2.multiplyByScalar(rotateDelta, this.rotateSpeed, rotateDelta);\r\n      //rotateDelta.subVectors( rotateEnd, rotateStart ).multiplyScalar( this.rotateSpeed );\r\n\r\n      const element = this.domElement;\r\n\r\n      rotateLeft((2 * Math.PI * rotateDelta.x) / element.clientHeight); // yes, height\r\n\r\n      rotateUp((2 * Math.PI * rotateDelta.y) / element.clientHeight);\r\n      Vector2.clone(rotateEnd, rotateStart);\r\n      //rotateStart.copy( rotateEnd );\r\n    };\r\n\r\n    const handleTouchMovePan = (event) => {\r\n      if (pointers.length === 1) {\r\n        panEnd.set(event.pageX, event.pageY);\r\n      } else {\r\n        const position = getSecondPointerPosition(event);\r\n\r\n        const x = 0.5 * (event.pageX + position.x);\r\n        const y = 0.5 * (event.pageY + position.y);\r\n\r\n        panEnd.set(x, y);\r\n      }\r\n      Vector2.subtract(panEnd, panStart, panDelta);\r\n      Vector2.multiplyByScalar(panDelta, this.panSpeed, panDelta);\r\n\r\n      //panDelta.subVectors( panEnd, panStart ).multiplyScalar( this.panSpeed );\r\n\r\n      pan(panDelta.x, panDelta.y);\r\n\r\n      Vector2.clone(panEnd, panStart);\r\n      // panStart.copy( panEnd );\r\n    };\r\n\r\n    const handleTouchMoveDolly = (event) => {\r\n      const position = getSecondPointerPosition(event);\r\n\r\n      const dx = event.pageX - position.x;\r\n      const dy = event.pageY - position.y;\r\n\r\n      const distance = Math.sqrt(dx * dx + dy * dy);\r\n\r\n      dollyEnd.set(0, distance);\r\n\r\n      dollyDelta.set(0, Math.pow(dollyEnd.y / dollyStart.y, this.zoomSpeed));\r\n\r\n      dollyOut(dollyDelta.y);\r\n\r\n      Vector2.clone(dollyEnd, dollyStart);\r\n      //dollyStart.copy( dollyEnd );\r\n    };\r\n\r\n    const handleTouchMoveDollyPan = (event) => {\r\n      if (this.enableZoom) handleTouchMoveDolly(event);\r\n\r\n      if (this.enablePan) handleTouchMovePan(event);\r\n    };\r\n\r\n    const handleTouchMoveDollyRotate = (event) => {\r\n      if (this.enableZoom) handleTouchMoveDolly(event);\r\n\r\n      if (this.enableRotate) handleTouchMoveRotate(event);\r\n    };\r\n\r\n    //\r\n    // event handlers - FSM: listen for events and reset state\r\n    //\r\n\r\n    this.onPointerDown = (event) => {\r\n      if (this.enabled === false) return;\r\n\r\n      if (pointers.length === 0) {\r\n        this.domElement.setPointerCapture(event.pointerId);\r\n\r\n        this.domElement.addEventListener(\"pointermove\", this.onPointerMove);\r\n        this.domElement.addEventListener(\"pointerup\", this.onPointerUp);\r\n      }\r\n\r\n      //\r\n\r\n      addPointer(event);\r\n\r\n      if (event.pointerType === \"touch\") {\r\n        onTouchStart(event);\r\n      } else {\r\n        onMouseDown(event);\r\n      }\r\n    };\r\n\r\n    this.onPointerMove = (event) => {\r\n      if (this.enabled === false) return;\r\n\r\n      if (event.pointerType === \"touch\") {\r\n        onTouchMove(event);\r\n      } else {\r\n        onMouseMove(event);\r\n      }\r\n    };\r\n\r\n    this.onPointerUp = (event) => {\r\n      removePointer(event);\r\n\r\n      if (pointers.length === 0) {\r\n        this.domElement.releasePointerCapture(event.pointerId);\r\n\r\n        this.domElement.removeEventListener(\"pointermove\", this.onPointerMove);\r\n        this.domElement.removeEventListener(\"pointerup\", this.onPointerUp);\r\n      }\r\n\r\n      this.dispatchEvent(_endEvent);\r\n\r\n      state = STATE.NONE;\r\n    };\r\n\r\n    const onMouseDown = (event) => {\r\n      let mouseAction;\r\n\r\n      switch (event.button) {\r\n        case 0:\r\n          mouseAction = this.mouseButtons.LEFT;\r\n          break;\r\n\r\n        case 1:\r\n          mouseAction = this.mouseButtons.MIDDLE;\r\n          break;\r\n\r\n        case 2:\r\n          mouseAction = this.mouseButtons.RIGHT;\r\n          break;\r\n\r\n        default:\r\n          mouseAction = -1;\r\n      }\r\n\r\n      switch (mouseAction) {\r\n        case MOUSE.DOLLY:\r\n          if (this.enableZoom === false) return;\r\n\r\n          handleMouseDownDolly(event);\r\n\r\n          state = STATE.DOLLY;\r\n\r\n          break;\r\n\r\n        case MOUSE.ROTATE:\r\n          if (event.ctrlKey || event.metaKey || event.shiftKey) {\r\n            if (this.enablePan === false) return;\r\n\r\n            handleMouseDownPan(event);\r\n\r\n            state = STATE.PAN;\r\n          } else {\r\n            if (this.enableRotate === false) return;\r\n\r\n            handleMouseDownRotate(event);\r\n\r\n            state = STATE.ROTATE;\r\n          }\r\n\r\n          break;\r\n\r\n        case MOUSE.PAN:\r\n          if (event.ctrlKey || event.metaKey || event.shiftKey) {\r\n            if (this.enableRotate === false) return;\r\n\r\n            handleMouseDownRotate(event);\r\n\r\n            state = STATE.ROTATE;\r\n          } else {\r\n            if (this.enablePan === false) return;\r\n\r\n            handleMouseDownPan(event);\r\n\r\n            state = STATE.PAN;\r\n          }\r\n\r\n          break;\r\n\r\n        default:\r\n          state = STATE.NONE;\r\n      }\r\n\r\n      if (state !== STATE.NONE) {\r\n        this.dispatchEvent(_startEvent);\r\n      }\r\n    };\r\n\r\n    const onMouseMove = (event) => {\r\n      switch (state) {\r\n        case STATE.ROTATE:\r\n          if (this.enableRotate === false) return;\r\n\r\n          handleMouseMoveRotate(event);\r\n\r\n          break;\r\n\r\n        case STATE.DOLLY:\r\n          if (this.enableZoom === false) return;\r\n\r\n          handleMouseMoveDolly(event);\r\n\r\n          break;\r\n\r\n        case STATE.PAN:\r\n          if (this.enablePan === false) return;\r\n\r\n          handleMouseMovePan(event);\r\n\r\n          break;\r\n      }\r\n    };\r\n\r\n    this.onMouseWheel = (event) => {\r\n      if (\r\n        this.enabled === false ||\r\n        this.enableZoom === false ||\r\n        state !== STATE.NONE\r\n      )\r\n        return;\r\n\r\n      event.preventDefault();\r\n\r\n      this.dispatchEvent(_startEvent);\r\n\r\n      handleMouseWheel(event);\r\n\r\n      this.dispatchEvent(_endEvent);\r\n    };\r\n\r\n    this.onKeyDown = (event) => {\r\n      if (this.enabled === false || this.enablePan === false) return;\r\n\r\n      handleKeyDown(event);\r\n    };\r\n\r\n    const onTouchStart = (event) => {\r\n      trackPointer(event);\r\n\r\n      switch (pointers.length) {\r\n        case 1:\r\n          switch (this.touches.ONE) {\r\n            case TOUCH.ROTATE:\r\n              if (this.enableRotate === false) return;\r\n\r\n              handleTouchStartRotate();\r\n\r\n              state = STATE.TOUCH_ROTATE;\r\n\r\n              break;\r\n\r\n            case TOUCH.PAN:\r\n              if (this.enablePan === false) return;\r\n\r\n              handleTouchStartPan();\r\n\r\n              state = STATE.TOUCH_PAN;\r\n\r\n              break;\r\n\r\n            default:\r\n              state = STATE.NONE;\r\n          }\r\n\r\n          break;\r\n\r\n        case 2:\r\n          switch (this.touches.TWO) {\r\n            case TOUCH.DOLLY_PAN:\r\n              if (this.enableZoom === false && this.enablePan === false) return;\r\n\r\n              handleTouchStartDollyPan();\r\n\r\n              state = STATE.TOUCH_DOLLY_PAN;\r\n\r\n              break;\r\n\r\n            case TOUCH.DOLLY_ROTATE:\r\n              if (this.enableZoom === false && this.enableRotate === false)\r\n                return;\r\n\r\n              handleTouchStartDollyRotate();\r\n\r\n              state = STATE.TOUCH_DOLLY_ROTATE;\r\n\r\n              break;\r\n\r\n            default:\r\n              state = STATE.NONE;\r\n          }\r\n\r\n          break;\r\n\r\n        default:\r\n          state = STATE.NONE;\r\n      }\r\n\r\n      if (state !== STATE.NONE) {\r\n        this.dispatchEvent(_startEvent);\r\n      }\r\n    };\r\n\r\n    const onTouchMove = (event) => {\r\n      trackPointer(event);\r\n\r\n      switch (state) {\r\n        case STATE.TOUCH_ROTATE:\r\n          if (this.enableRotate === false) return;\r\n\r\n          handleTouchMoveRotate(event);\r\n\r\n          this.update();\r\n\r\n          break;\r\n\r\n        case STATE.TOUCH_PAN:\r\n          if (this.enablePan === false) return;\r\n\r\n          handleTouchMovePan(event);\r\n\r\n          this.update();\r\n\r\n          break;\r\n\r\n        case STATE.TOUCH_DOLLY_PAN:\r\n          if (this.enableZoom === false && this.enablePan === false) return;\r\n\r\n          handleTouchMoveDollyPan(event);\r\n\r\n          this.update();\r\n\r\n          break;\r\n\r\n        case STATE.TOUCH_DOLLY_ROTATE:\r\n          if (this.enableZoom === false && this.enableRotate === false) return;\r\n\r\n          handleTouchMoveDollyRotate(event);\r\n\r\n          this.update();\r\n\r\n          break;\r\n\r\n        default:\r\n          state = STATE.NONE;\r\n      }\r\n    };\r\n\r\n    this.onContextMenu = (event) => {\r\n      if (this.enabled === false) return;\r\n\r\n      event.preventDefault();\r\n    };\r\n    this.getAutoRotationAngle = () => {\r\n      return ((2 * Math.PI) / 60 / 60) * this.autoRotateSpeed;\r\n    };\r\n\r\n    const getZoomScale = () => {\r\n      return Math.pow(0.95, this.zoomSpeed);\r\n    };\r\n    this.domElement.addEventListener(\"contextmenu\", this.onContextMenu);\r\n\r\n    this.domElement.addEventListener(\"pointerdown\", this.onPointerDown);\r\n    this.domElement.addEventListener(\"pointercancel\", onPointerCancel);\r\n    this.domElement.addEventListener(\"wheel\", this.onMouseWheel, {\r\n      passive: false,\r\n    });\r\n  }\r\n  dispose() {\r\n    this.domElement.removeEventListener(\"contextmenu\", this.onContextMenu);\r\n\r\n    this.domElement.removeEventListener(\"pointerdown\", this.onPointerDown);\r\n    this.domElement.removeEventListener(\"pointercancel\", onPointerCancel);\r\n    this.domElement.removeEventListener(\"wheel\", this.onMouseWheel);\r\n\r\n    this.domElement.removeEventListener(\"pointermove\", this.onPointerMove);\r\n    this.domElement.removeEventListener(\"pointerup\", this.onPointerUp);\r\n\r\n    if (this._domElementKeyEvents !== null) {\r\n      this._domElementKeyEvents.removeEventListener(\"keydown\", this.onKeyDown);\r\n    }\r\n\r\n    //this.dispatchEvent( { type: 'dispose' } ); // should this be added here?\r\n  }\r\n}\r\nconst STATE = {\r\n  NONE: -1,\r\n  ROTATE: 0,\r\n  DOLLY: 1,\r\n  PAN: 2,\r\n  TOUCH_ROTATE: 3,\r\n  TOUCH_PAN: 4,\r\n  TOUCH_DOLLY_PAN: 5,\r\n  TOUCH_DOLLY_ROTATE: 6,\r\n};\r\n\r\nlet state = STATE.NONE;\r\n\r\nconst EPS = 0.000001;\r\n\r\n// current position in spherical coordinates\r\nconst spherical = new Spherical();\r\nconst sphericalDelta = new Spherical();\r\n\r\nlet scale = 1;\r\nconst panOffset = new Vector3();\r\nlet zoomChanged = false;\r\n\r\nconst rotateStart = new Vector2();\r\nconst rotateEnd = new Vector2();\r\nconst rotateDelta = new Vector2();\r\n\r\nconst panStart = new Vector2();\r\nconst panEnd = new Vector2();\r\nconst panDelta = new Vector2();\r\n\r\nconst dollyStart = new Vector2();\r\nconst dollyEnd = new Vector2();\r\nconst dollyDelta = new Vector2();\r\n\r\nconst pointers = [];\r\nconst pointerPositions = {};\r\nexport enum MOUSE {\r\n  LEFT = 0,\r\n  MIDDLE = 1,\r\n  RIGHT = 2,\r\n  ROTATE = 0,\r\n  DOLLY = 1,\r\n  PAN = 2,\r\n}\r\n\r\nexport enum TOUCH {\r\n  ROTATE,\r\n  PAN,\r\n  DOLLY_PAN,\r\n  DOLLY_ROTATE,\r\n}\r\nfunction rotateLeft(angle) {\r\n  sphericalDelta.theta -= angle;\r\n}\r\n\r\nfunction rotateUp(angle) {\r\n  sphericalDelta.phi -= angle;\r\n}\r\n\r\nfunction addPointer(event) {\r\n  pointers.push(event);\r\n}\r\n\r\nfunction removePointer(event) {\r\n  delete pointerPositions[event.pointerId];\r\n\r\n  for (let i = 0; i < pointers.length; i++) {\r\n    if (pointers[i].pointerId == event.pointerId) {\r\n      pointers.splice(i, 1);\r\n      return;\r\n    }\r\n  }\r\n}\r\n\r\nfunction trackPointer(event) {\r\n  let position = pointerPositions[event.pointerId];\r\n\r\n  if (position === undefined) {\r\n    position = new Vector2();\r\n    pointerPositions[event.pointerId] = position;\r\n  }\r\n\r\n  position.set(event.pageX, event.pageY);\r\n}\r\n\r\nfunction getSecondPointerPosition(event) {\r\n  const pointer =\r\n    event.pointerId === pointers[0].pointerId ? pointers[1] : pointers[0];\r\n\r\n  return pointerPositions[pointer.pointerId];\r\n}\r\n\r\nfunction handleMouseDownRotate(event) {\r\n  rotateStart.set(event.clientX, event.clientY);\r\n}\r\n\r\nfunction handleMouseDownDolly(event) {\r\n  dollyStart.set(event.clientX, event.clientY);\r\n}\r\n\r\nfunction handleMouseDownPan(event) {\r\n  panStart.set(event.clientX, event.clientY);\r\n}\r\nfunction onPointerCancel(event) {\r\n  removePointer(event);\r\n}\r\nfunction handleTouchStartRotate() {\r\n  if (pointers.length === 1) {\r\n    rotateStart.set(pointers[0].pageX, pointers[0].pageY);\r\n  } else {\r\n    const x = 0.5 * (pointers[0].pageX + pointers[1].pageX);\r\n    const y = 0.5 * (pointers[0].pageY + pointers[1].pageY);\r\n\r\n    rotateStart.set(x, y);\r\n  }\r\n}\r\n\r\nfunction handleTouchStartPan() {\r\n  if (pointers.length === 1) {\r\n    panStart.set(pointers[0].pageX, pointers[0].pageY);\r\n  } else {\r\n    const x = 0.5 * (pointers[0].pageX + pointers[1].pageX);\r\n    const y = 0.5 * (pointers[0].pageY + pointers[1].pageY);\r\n\r\n    panStart.set(x, y);\r\n  }\r\n}\r\n\r\nfunction handleTouchStartDolly() {\r\n  const dx = pointers[0].pageX - pointers[1].pageX;\r\n  const dy = pointers[0].pageY - pointers[1].pageY;\r\n\r\n  const distance = Math.sqrt(dx * dx + dy * dy);\r\n\r\n  dollyStart.set(0, distance);\r\n}\r\n"],"names":["MersenneTwister","distanceScratch","lerpScratch","angleBetweenScratch","angleBetweenScratch2","mostOrthogonalAxisScratch","scaleScratch1","scratchColumn","scaleScratch3","scaleScratch4","scaleScratch5","scratchTransposeMatrix"],"mappings":"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AAK,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAEjF,QAAA,MAAM,WAAW,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AACjF,QAAA,MAAM,WAAW,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AACjF,QAAA,MAAM,WAAW,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAEjF,QAAA,MAAM,WAAW,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AACjF,QAAA,MAAM,WAAW,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AACjF,QAAA,MAAM,WAAW,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAEjF,QAAA,MAAM,CAAC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,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAC/B,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAC/B,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAC/B,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAC/B,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAC/B,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAC/B,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAC/B,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAC/B,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAC/B,QAAA,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAC/B,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,EAAE,CAAC,CAAC;AAClC,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,EAAE,CAAC,CAAC;AAClC,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,EAAE,CAAC,CAAC;AAClC,QAAA,MAAM,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,EAAE,CAAC,CAAC;A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G,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;;AAGL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;;AAGL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;;AAGL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;AACL,QAAA,GAAG,CAAC,CAAC;KACL,CAAC;AAEF,IAAA,MAAM,GAAG,GAAG;;QAEX,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;;QAGlC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;;QAGlC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;;QAGlC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;;QAGlC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;;QAGlC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;KAClC,CAAC;AAEF,IAAA,MAAM,OAAO,GAAG;;AAEf,QAAA,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;;AAGpD,QAAA,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;;AAGpD,QAAA,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;;AAG1D,QAAA,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC;;AAG1D,QAAA,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;;AAGpD,QAAA,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC;KAC1D,CAAC;IACF,OAAO;AACN,QAAA,SAAS,EAAE,SAAS;AACpB,QAAA,OAAO,EAAE,OAAO;AAChB,QAAA,GAAG,EAAE,GAAG;KACR,CAAC;AACH,CAAC;AAEK,SAAU,YAAY,CAAC,OAAO,EAAA;AACnC,IAAA,OAAO,GAAG,OAAO,IAAI,EAAE,CAAC;AAExB,IAAA,MAAM,SAAS,GAAG,OAAO,CAAC,SAAS,IAAI,EAAE,CAAC;AAC1C,IAAA,MAAM,QAAQ,GAAG,OAAO,CAAC,QAAQ,IAAI,EAAE,CAAC;AACxC,IAAA,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM,IAAI,CAAC,CAAC;AACnC,IAAA,MAAM,QAAQ,GAAG,IAAI,CAAC,EAAE,GAAG,QAAQ,CAAC;IACpC,MAAM,SAAS,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,EAAE,IAAI,SAAS,CAAC;AAC5C,IAAA,MAAM,aAAa,GAAG,SAAS,GAAG,QAAQ,GAAG,CAAC,CAAC;AAC/C,IAAA,MAAM,WAAW,GAAG,SAAS,GAAG,QAAQ,GAAG,CAAC,CAAC;IAC7C,IAAI,SAAS,EAAE,UAAU,CAAC;IAC1B,MAAM,SAAS,GAAG,IAAI,KAAK,CAAC,aAAa,GAAG,CAAC,CAAC,CAAC;IAC/C,MAAM,OAAO,GAAG,IAAI,KAAK,CAAC,aAAa,GAAG,CAAC,CAAC,CAAC;IAC7C,MAAM,GAAG,GAAG,IAAI,KAAK,CAAC,aAAa,GAAG,CAAC,CAAC,CAAC;AACzC,IAAA,MAAM,OAAO,GAAG,IAAI,KAAK,CAAC,WAAW,CAAC,CAAC;IACvC,IAAI,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC;IAC3D,IAAI,CAAC,EAAE,CAAC,CAAC;AACT,IAAA,IAAI,CAAC,GAAG,CAAC,EACR,CAAC,GAAG,CAAC,CAAC;IACP,IAAI,EAAE,EAAE,EAAE,CAAC;IAEX,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,QAAQ,EAAE,CAAC,EAAE,EAAE;AAC9B,QAAA,SAAS,GAAG,CAAC,GAAG,QAAQ,CAAC;AACzB,QAAA,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QACzB,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,SAAS,GAAG,QAAQ,CAAC,CAAC;QACpC,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,SAAS,EAAE,CAAC,EAAE,EAAE;AAC/B,YAAA,UAAU,GAAG,CAAC,GAAG,SAAS,CAAC;AAC3B,YAAA,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;AAChD,YAAA,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,UAAU,GAAG,SAAS,CAAC,CAAC;AAC5D,YAAA,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,SAAS,GAAG,QAAQ,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;AAC3D,YAAA,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,SAAS,GAAG,QAAQ,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,UAAU,GAAG,SAAS,CAAC,CAAC;AACvE,YAAA,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;AAChD,YAAA,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,UAAU,GAAG,SAAS,CAAC,CAAC;AAC5D,YAAA,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,SAAS,GAAG,QAAQ,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;AAC3D,YAAA,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,SAAS,GAAG,QAAQ,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,UAAU,GAAG,SAAS,CAAC,CAAC;AACvE,YAAA,EAAE,GAAG,CAAC,GAAG,CAAC,GAAG,SAAS,CAAC;YACvB,EAAE,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,IAAI,SAAS,CAAC;AAC7B,YAAA,EAAE,GAAG,CAAC,GAAG,CAAC,GAAG,QAAQ,CAAC;YACtB,EAAE,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,IAAI,QAAQ,CAAC;AAC5B,YAAA,EAAE,GAAG,CAAC,GAAG,CAAC,CAAC;AACX,YAAA,EAAE,GAAG,CAAC,GAAG,CAAC,CAAC;AAEX,YAAA,SAAS,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC;YAC5B,SAAS,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC;YAChC,SAAS,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC;YAEhC,SAAS,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC;YAChC,SAAS,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC;YAChC,SAAS,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC;YAEhC,SAAS,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC;YAChC,SAAS,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC;YAChC,SAAS,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC;YAEhC,SAAS,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC;YAChC,SAAS,CAAC,EAAE,GAAG,EAAE,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC;YACjC,SAAS,CAAC,EAAE,GAAG,EAAE,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC;AAEjC,YAAA,OAAO,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC;AACjB,YAAA,OAAO,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC;AACrB,YAAA,OAAO,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC;AAErB,YAAA,OAAO,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC;AACrB,YAAA,OAAO,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC;AACrB,YAAA,OAAO,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC;AAErB,YAAA,OAAO,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC;AACrB,YAAA,OAAO,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC;AACrB,YAAA,OAAO,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC;AAErB,YAAA,OAAO,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC;AACrB,YAAA,OAAO,CAAC,EAAE,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC;AACtB,YAAA,OAAO,CAAC,EAAE,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC;AAEtB,YAAA,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC;AACb,YAAA,GAAG,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC;AAEjB,YAAA,GAAG,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC;AACjB,YAAA,GAAG,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC;AAEjB,YAAA,GAAG,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC;AACjB,YAAA,GAAG,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC;AAEjB,YAAA,GAAG,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC;AACjB,YAAA,GAAG,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC;AAEjB,YAAA,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;YACf,OAAO,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;YACvB,OAAO,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;YACvB,OAAO,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;YACvB,OAAO,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;YACvB,OAAO,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;YAEvB,CAAC,IAAI,CAAC,CAAC;YACP,CAAC,IAAI,CAAC,CAAC;AACP,SAAA;AACD,KAAA;IAED,OAAO;AACN,QAAA,SAAS,EAAE,SAAS;AACpB,QAAA,OAAO,EAAE,OAAO;AAChB,QAAA,GAAG,EAAE,GAAG;AACR,QAAA,OAAO,EAAE,OAAO;KAChB,CAAC;AACH;;ACxaqB,MAAA,cAAe,SAAQ,QAAQ,CAAA;AAEnD,IAAA,WAAA,CAAY,MAAc,EAAA;AACzB,QAAA,KAAK,CAAC;AACL,YAAA,IAAI,EAAE,gBAAgB;AACtB,SAAA,CAAC,CAAC;QACH,IAAI,CAAC,OAAO,GAAG;AACd,YAAA,UAAU,EAAE,IAAI;SAChB,CAAC;AACF,QAAA,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,IAAI,EAAE,CAAC;KACZ;IACO,IAAI,GAAA;QACX,MAAM,EAAE,SAAS,EAAE,OAAO,EAAE,GAAG,EAAE,OAAO,EAAE,GAAG,YAAY,CAAC,EAAE,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;;;;;AAKnF,QAAA,IAAI,CAAC,qBAAqB,CAAC,SAAS,CAAC,CAAC;AACtC,QAAA,IAAI,CAAC,YAAY,CAAC,IAAI,gBAAgB,CAAC,UAAU,EAAE,SAAS,EAAE,CAAC,CAAC,CAAC,CAAC;AAClE,QAAA,IAAI,CAAC,YAAY,CAAC,IAAI,gBAAgB,CAAC,QAAQ,EAAE,OAAO,EAAE,CAAC,CAAC,CAAC,CAAC;AAC9D,QAAA,IAAI,CAAC,YAAY,CAAC,IAAI,gBAAgB,CAAC,IAAI,EAAE,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC;AAEtD,QAAA,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;AACxB,QAAA,IAAI,CAAC,KAAK,GAAG,OAAO,CAAC,MAAM,CAAC;KAC5B;AACD;;AC3BoB,MAAA,WAAY,SAAQ,QAAQ,CAAA;AAChD,IAAA,WAAA,CAAmB,QAAgB,EAAE,EAAS,SAAiB,EAAE,EAAS,QAAgB,EAAE,EAAA;AAC3F,QAAA,KAAK,CAAC;AACL,YAAA,IAAI,EAAE,aAAa;AACnB,SAAA,CAAC,CAAC;QAHe,IAAK,CAAA,KAAA,GAAL,KAAK,CAAa;QAAS,IAAM,CAAA,MAAA,GAAN,MAAM,CAAa;QAAS,IAAK,CAAA,KAAA,GAAL,KAAK,CAAa;QAI3F,IAAI,CAAC,OAAO,GAAG;AACd,YAAA,UAAU,EAAE,IAAI;SAChB,CAAC;QACF,IAAI,CAAC,IAAI,EAAE,CAAC;KACZ;IACO,IAAI,GAAA;;QAEX,MAAM,EAAE,SAAS,EAAE,OAAO,EAAE,GAAG,EAAE,GAAG,SAAS,CAAC;AAC7C,YAAA,UAAU,EAAE,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC;AACjD,SAAA,CAAC,CAAC;AACH,QAAA,IAAI,CAAC,qBAAqB,CAAC,SAAS,CAAC,CAAC;AACtC,QAAA,IAAI,CAAC,YAAY,CAAC,IAAI,gBAAgB,CAAC,UAAU,EAAE,SAAS,EAAE,CAAC,CAAC,CAAC,CAAC;AAClE,QAAA,IAAI,CAAC,YAAY,CAAC,IAAI,gBAAgB,CAAC,QAAQ,EAAE,OAAO,EAAE,CAAC,CAAC,CAAC,CAAC;AAC9D,QAAA,IAAI,CAAC,YAAY,CAAC,IAAI,gBAAgB,CAAC,IAAI,EAAE,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC;AACtD,QAAA,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC;KAChB;AACD;;ACrBoB,MAAA,iBAAkB,SAAQ,QAAQ,CAAA;IAOtD,WAAY,CAAA,MAAM,GAAG,CAAC,EAAE,IAAI,GAAG,GAAG,EAAE,eAAe,GAAG,EAAE,EAAE,cAAc,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAA;AACzF,QAAA,KAAK,CAAC;AACL,YAAA,IAAI,EAAE,mBAAmB;AACzB,SAAA,CAAC,CAAC;QACH,IAAI,CAAC,OAAO,GAAG;AACd,YAAA,UAAU,EAAE,IAAI;SAChB,CAAC;AACF,QAAA,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;AACrB,QAAA,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;AACjB,QAAA,IAAI,CAAC,eAAe,GAAG,eAAe,CAAC;AACvC,QAAA,IAAI,CAAC,cAAc,GAAG,cAAc,CAAC;AACrC,QAAA,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;AACX,QAAA,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;QACX,IAAI,CAAC,IAAI,EAAE,CAAC;KACZ;IACO,IAAI,GAAA;AACX,QAAA,MAAM,EAAE,OAAO,EAAE,GAAG,EAAE,SAAS,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC;AACnE,QAAA,IAAI,CAAC,qBAAqB,CAAC,SAAS,CAAC,CAAC;AACtC,QAAA,IAAI,CAAC,YAAY,CAAC,IAAI,gBAAgB,CAAC,UAAU,EAAE,SAAS,EAAE,CAAC,CAAC,CAAC,CAAC;AAClE,QAAA,IAAI,CAAC,YAAY,CAAC,IAAI,gBAAgB,CAAC,QAAQ,EAAE,OAAO,EAAE,CAAC,CAAC,CAAC,CAAC;AAC9D,QAAA,IAAI,CAAC,YAAY,CAAC,IAAI,gBAAgB,CAAC,IAAI,EAAE,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC;AACtD,QAAA,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;AACxB,QAAA,IAAI,CAAC,KAAK,GAAG,OAAO,CAAC,MAAM,CAAC;KAC5B;IACO,cAAc,GAAA;AACrB,QAAA,MAAM,SAAS,GAAG,EAAE,EACnB,OAAO,GAAG,EAAE,EACZ,GAAG,GAAG,EAAE,EACR,OAAO,GAAG,EAAE,CAAC;QACd,MAAM,eAAe,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;QACzD,MAAM,cAAc,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;;AAGvD,QAAA,MAAM,MAAM,GAAG,IAAI,OAAO,EAAE,CAAC;AAC7B,QAAA,MAAM,MAAM,GAAG,IAAI,OAAO,EAAE,CAAC;AAE7B,QAAA,MAAM,EAAE,GAAG,IAAI,OAAO,EAAE,CAAC;AACzB,QAAA,MAAM,EAAE,GAAG,IAAI,OAAO,EAAE,CAAC;AAEzB,QAAA,MAAM,CAAC,GAAG,IAAI,OAAO,EAAE,CAAC;AACxB,QAAA,MAAM,CAAC,GAAG,IAAI,OAAO,EAAE,CAAC;AACxB,QAAA,MAAM,CAAC,GAAG,IAAI,OAAO,EAAE,CAAC;;QAIxB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,eAAe,EAAE,EAAE,CAAC,EAAE;;AAG1C,YAAA,MAAM,CAAC,GAAG,CAAC,CAAC,GAAG,eAAe,IAAI,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,EAAE,GAAG,CAAC,CAAC;;;AAKvD,YAAA,wBAAwB,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,EAAE,IAAI,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;AAC7D,YAAA,wBAAwB,CAAC,CAAC,GAAG,IAAI,EAAE,IAAI,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,EAAE,IAAI,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;;YAIpE,OAAO,CAAC,QAAQ,CAAC,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;;YAE5B,OAAO,CAAC,GAAG,CAAC,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;;YAEvB,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;;YAEvB,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;;;YAKvB,CAAC,CAAC,SAAS,EAAE,CAAC;YACd,CAAC,CAAC,SAAS,EAAE,CAAC;YAEd,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,cAAc,EAAE,EAAE,CAAC,EAAE;;;AAIzC,gBAAA,MAAM,CAAC,GAAG,CAAC,CAAC,GAAG,cAAc,IAAI,IAAI,CAAC,EAAE,GAAG,CAAC,CAAC;AAC7C,gBAAA,MAAM,EAAE,GAAG,CAAC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;AACpC,gBAAA,MAAM,EAAE,GAAG,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;;;gBAKnC,MAAM,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;gBACxC,MAAM,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;gBACxC,MAAM,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;AAExC,gBAAA,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC;;gBAG7C,OAAO,CAAC,QAAQ,CAAC,MAAM,EAAE,EAAE,EAAE,MAAM,CAAC,CAAC;gBACrC,MAAM,CAAC,SAAS,EAAE,CAAC;AAEnB,gBAAA,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC;;AAI3C,gBAAA,GAAG,CAAC,IAAI,CAAC,CAAC,GAAG,eAAe,CAAC,CAAC;AAC9B,gBAAA,GAAG,CAAC,IAAI,CAAC,CAAC,GAAG,cAAc,CAAC,CAAC;AAC7B,aAAA;AACD,SAAA;;QAID,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,eAAe,EAAE,CAAC,EAAE,EAAE;YAC1C,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,cAAc,EAAE,CAAC,EAAE,EAAE;;AAGzC,gBAAA,MAAM,CAAC,GAAG,CAAC,cAAc,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;AACnD,gBAAA,MAAM,CAAC,GAAG,CAAC,cAAc,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;gBAC7C,MAAM,CAAC,GAAG,CAAC,cAAc,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;AACvC,gBAAA,MAAM,CAAC,GAAG,CAAC,cAAc,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;;gBAI7C,OAAO,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;gBACtB,OAAO,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;AACtB,aAAA;AACD,SAAA;QACD,OAAO;YACN,OAAO;YACP,GAAG;YACH,SAAS;YACT,OAAO;SACP,CAAC;KACF;AACD,CAAA;AACD,SAAS,wBAAwB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,MAAM,EAAE,QAAQ,EAAA;IAC1D,MAAM,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IACvB,MAAM,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IACvB,MAAM,OAAO,GAAG,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IAC5B,MAAM,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;AAE7B,IAAA,QAAQ,CAAC,CAAC,GAAG,MAAM,IAAI,CAAC,GAAG,EAAE,CAAC,GAAG,GAAG,GAAG,EAAE,CAAC;AAC1C,IAAA,QAAQ,CAAC,CAAC,GAAG,MAAM,IAAI,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,GAAG,GAAG,CAAC;AAC1C,IAAA,QAAQ,CAAC,CAAC,GAAG,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,GAAG,GAAG,CAAC;AAC/C;;ACxIqB,MAAA,kBAAmB,SAAQ,QAAQ,CAAA;AAKvD,IAAA,WAAA,GAAA;AACC,QAAA,KAAK,EAAE,CAAC;AACR,QAAA,IAAI,CAAC,IAAI,GAAG,OAAO,CAAC;AACpB,QAAA,IAAI,CAAC,KAAK,GAAG,IAAI,KAAK,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC;AACtC,QAAA,IAAI,CAAC,YAAY,GAAG,IAAI,YAAY,CAAC;YACpC,QAAQ,EAAE,IAAI,CAAC,IAAI;AACnB,YAAA,OAAO,EAAE;AACR,gBAAA,aAAa,EAAE,IAAI;AACnB,aAAA;AACD,SAAA,CAAC,CAAC;AACH,QAAA,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;AAClB,QAAA,IAAI,CAAC,QAAQ,GAAG,IAAI,KAAK,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC;AACzC,QAAA,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;AACtB,QAAA,IAAI,CAAC,WAAW,GAAG,SAAS,CAAC;AAC7B,QAAA,IAAI,CAAC,WAAW,GAAG,SAAS,CAAC;KAC7B;IACD,MAAM,CAAC,UAAuB,EAAE,IAAW,EAAA;AAC1C,QAAA,IAAI,CAAC,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,KAAK;AAAE,YAAA,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC;KAChE;AACS,IAAA,gBAAgB,CAAC,IAAW,EAAA;QACrC,KAAK,CAAC,gBAAgB,EAAE,CAAC;QACzB,MAAM,aAAa,GAAG,IAAI,aAAa,CAAC,EAAE,KAAK,EAAE,OAAO,EAAE,CAAC,CAAC;AAC5D,QAAA,aAAa,CAAC,UAAU,CACvB,aAAa,EACb,MAAK;YACJ,OAAO,IAAI,CAAC,WAAW,CAAC;AACzB,SAAC,EACD,WAAW,CAAC,IAAI,CAChB,CAAC;QACF,aAAa,CAAC,UAAU,CAAC,OAAO,EAAE,IAAI,EAAE,WAAW,CAAC,KAAK,CAAC,CAAC;QAC3D,aAAa,CAAC,UAAU,CAAC,SAAS,EAAE,IAAI,EAAE,WAAW,CAAC,KAAK,CAAC,CAAC;AAC7D,QAAA,aAAa,CAAC,UAAU,CACvB,aAAa,EACb,MAAK;YACJ,OAAO,IAAI,CAAC,YAAY,CAAC;AAC1B,SAAC,EACD,WAAW,CAAC,IAAI,CAChB,CAAC;QACF,aAAa,CAAC,UAAU,CAAC,UAAU,EAAE,IAAI,EAAE,WAAW,CAAC,KAAK,CAAC,CAAC;QAC9D,aAAa,CAAC,UAAU,CAAC,WAAW,EAAE,IAAI,EAAE,WAAW,CAAC,KAAK,CAAC,CAAC;QAC/D,aAAa,CAAC,UAAU,CAAC,UAAU,EAAE,IAAI,EAAE,WAAW,CAAC,KAAK,CAAC,CAAC;QAC9D,IAAI,CAAC,UAAU,CAAC,gBAAgB,CAAC,OAAO,EAAE,aAAa,CAAC,CAAC;QACzD,IAAI,IAAI,CAAC,WAAW,EAAE;YACrB,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,kBAAkB,EAAE,IAAI,CAAC,CAAC;YACpD,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,kBAAkB,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;AACjE,YAAA,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,kBAAkB,EAAE,IAAI,CAAC,WAAW,IAAI,YAAY,CAAC,cAAc,CAAC,CAAC;AAChG,SAAA;QACD,IAAI,IAAI,CAAC,aAAa,EAAE;YACvB,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,mBAAmB,EAAE,IAAI,CAAC,CAAC;YACrD,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,eAAe,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;AAChE,YAAA,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,eAAe,EAAE,IAAI,CAAC,aAAa,IAAI,YAAY,CAAC,cAAc,CAAC,CAAC;AAC/F,SAAA;KACD;IACD,OAAO,GAAA;AACN,QAAA,IAAI,EAAE,WAAW,EAAE,OAAO,EAAE,CAAC;QAC7B,KAAK,CAAC,OAAO,EAAE,CAAC;KAChB;AACD;;AC5DoB,MAAA,WAAY,SAAQ,QAAQ,CAAA;AA+BhD,IAAA,IAAW,SAAS,GAAA;QACnB,OAAO,IAAI,CAAC,UAAU,CAAC;KACvB;IACD,IAAW,SAAS,CAAC,KAAK,EAAA;AACzB,QAAA,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;KACxB;AACD,IAAA,IAAW,SAAS,GAAA;QACnB,OAAO,IAAI,CAAC,UAAU,CAAC;KACvB;IACD,IAAW,SAAS,CAAC,CAAS,EAAA;AAC7B,QAAA,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC;KACpB;AACD,IAAA,IAAW,kBAAkB,GAAA;QAC5B,OAAO,IAAI,CAAC,mBAAmB,CAAC;KAChC;IACD,IAAW,kBAAkB,CAAC,CAAS,EAAA;AACtC,QAAA,IAAI,CAAC,mBAAmB,GAAG,CAAC,CAAC;KAC7B;AACD,IAAA,IAAW,WAAW,GAAA;QACrB,IAAI,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,WAAW,CAAC,SAAS,EAAE;YACnD,IAAI,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,QAAQ,IAAI,QAAQ,CAAC,IAAI,EAAE;AACzD,gBAAA,OAAO,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,YAAY,EAAE,IAAI,OAAO,EAAE,CAAC,CAAC;AACxD,aAAA;AACD,SAAA;QACD,OAAO,IAAI,CAAC,YAAY,CAAC;KACzB;IACD,IAAW,WAAW,CAAC,CAAU,EAAA;AAChC,QAAA,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC;KACtB;IACD,IAAW,SAAS,CAAC,KAAK,EAAA;AACzB,QAAA,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;AACxB,QAAA,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC;YAC5B,OAAO,EAAE,IAAI,CAAC,UAAU;AACxB,SAAA,CAAC,CAAC;AACH,QAAA,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;KAClB;AACD,IAAA,WAAA,GAAA;AACC,QAAA,KAAK,EAAE,CAAC;AACR,QAAA,IAAI,CAAC,IAAI,GAAG,SAAS,CAAC;AAEtB,QAAA,IAAI,CAAC,UAAU,GAAG,GAAG,CAAC;AAEtB,QAAA,IAAI,CAAC,UAAU,GAAG,GAAG,CAAC;AAEtB,QAAA,IAAI,CAAC,mBAAmB,GAAG,GAAG,CAAC;AAC/B,QAAA,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;QAClB,IAAI,CAAC,YAAY,GAAG,IAAI,OAAO,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;AACtC,QAAA,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;AACvB,QAAA,IAAI,CAAC,YAAY,GAAG,IAAI,YAAY,CAAC;YACpC,QAAQ,EAAE,IAAI,CAAC,IAAI;AACnB,YAAA,OAAO,EAAE;AACR,gBAAA,WAAW,EAAE,IAAI;gBACjB,OAAO,EAAE,IAAI,CAAC,UAAU;AACxB,aAAA;AACD,SAAA,CAAC,CAAC;KACH;IACD,MAAM,CAAC,UAAuB,EAAE,IAAW,EAAA;AAC1C,QAAA,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,UAAU,CAAC;YAAE,OAAO;QACjD,IAAI,CAAC,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,KAAK,EAAE;AACnC,YAAA,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC;AAC5B,SAAA;KACD;AACS,IAAA,gBAAgB,CAAC,IAAW,EAAA;QACrC,KAAK,CAAC,gBAAgB,EAAE,CAAC;QACzB,MAAM,aAAa,GAAG,IAAI,aAAa,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC;AAC1D,QAAA,aAAa,CAAC,UAAU,CACvB,aAAa,EACb,MAAK;YACJ,OAAO,IAAI,CAAC,WAAW,CAAC;AACzB,SAAC,EACD,WAAW,CAAC,IAAI,CAChB,CAAC;QACF,aAAa,CAAC,UAAU,CAAC,OAAO,EAAE,IAAI,EAAE,WAAW,CAAC,KAAK,CAAC,CAAC;QAC3D,aAAa,CAAC,UAAU,CAAC,SAAS,EAAE,IAAI,EAAE,WAAW,CAAC,KAAK,CAAC,CAAC;AAC7D,QAAA,aAAa,CAAC,UAAU,CACvB,aAAa,EACb,MAAK;YACJ,OAAO,IAAI,CAAC,YAAY,CAAC;AAC1B,SAAC,EACD,WAAW,CAAC,IAAI,CAChB,CAAC;QACF,aAAa,CAAC,UAAU,CAAC,UAAU,EAAE,IAAI,EAAE,WAAW,CAAC,KAAK,CAAC,CAAC;QAC9D,aAAa,CAAC,UAAU,CAAC,WAAW,EAAE,IAAI,EAAE,WAAW,CAAC,KAAK,CAAC,CAAC;QAC/D,aAAa,CAAC,UAAU,CAAC,WAAW,EAAE,IAAI,EAAE,WAAW,CAAC,KAAK,CAAC,CAAC;QAC/D,IAAI,CAAC,UAAU,CAAC,gBAAgB,CAAC,KAAK,EAAE,aAAa,CAAC,CAAC;QACvD,IAAI,CAAC,kBAAkB,GAAG,YAAY,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC;QAC9D,IAAI,IAAI,CAAC,WAAW,EAAE;YACrB,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,aAAa,EAAE,IAAI,CAAC,CAAC;YAC/C,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,kBAAkB,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;AACjE,YAAA,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,kBAAkB,EAAE,IAAI,CAAC,WAAW,IAAI,YAAY,CAAC,cAAc,CAAC,CAAC;AAChG,SAAA;QACD,IAAI,IAAI,CAAC,yBAAyB,EAAE;YACnC,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,sBAAsB,EAAE,IAAI,CAAC,CAAC;YACxD,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,2BAA2B,EAAE,IAAI,CAAC,yBAAyB,CAAC,CAAC;AACxF,YAAA,IAAI,CAAC,UAAU,CAAC,UAAU,CACzB,2BAA2B,EAC3B,IAAI,CAAC,yBAAyB,IAAI,YAAY,CAAC,cAAc,CAC7D,CAAC;AACF,SAAA;QACD,IAAI,IAAI,CAAC,aAAa,EAAE;YACvB,aAAa,CAAC,UAAU,CAAC,aAAa,EAAE,IAAI,EAAE,WAAW,CAAC,SAAS,CAAC,CAAC;YACrE,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,mBAAmB,EAAE,IAAI,CAAC,CAAC;YACrD,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,eAAe,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;AAChE,YAAA,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,eAAe,EAAE,IAAI,CAAC,aAAa,IAAI,YAAY,CAAC,cAAc,CAAC,CAAC;AAC/F,SAAA;QACD,IAAI,IAAI,CAAC,SAAS,EAAE;YACnB,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,eAAe,EAAE,IAAI,CAAC,CAAC;YACjD,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,WAAW,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;AACxD,YAAA,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,WAAW,EAAE,IAAI,CAAC,SAAS,IAAI,YAAY,CAAC,cAAc,CAAC,CAAC;YACvF,aAAa,CAAC,UAAU,CAAC,oBAAoB,EAAE,IAAI,EAAE,WAAW,CAAC,KAAK,CAAC,CAAC;AACxE,SAAA;QACD,IAAI,IAAI,CAAC,eAAe,EAAE;YACzB,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,qBAAqB,EAAE,IAAI,CAAC,CAAC;YACvD,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,iBAAiB,EAAE,IAAI,CAAC,eAAe,CAAC,CAAC;AACpE,YAAA,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,iBAAiB,EAAE,IAAI,CAAC,eAAe,IAAI,YAAY,CAAC,cAAc,CAAC,CAAC;AACnG,SAAA;AACD,QAAA,IAAI,IAAI,CAAC,kBAAkB,IAAI,IAAI,CAAC,UAAU,EAAE;YAC/C,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,oBAAoB,EAAE,IAAI,CAAC,kBAAkB,CAAC,CAAC;AAC1E,YAAA,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,oBAAoB,EAAE,IAAI,CAAC,kBAAkB,IAAI,YAAY,CAAC,cAAc,CAAC,CAAC;AACzG,SAAA;KACD;IACD,OAAO,GAAA;AACN,QAAA,IAAI,EAAE,SAAS,EAAE,OAAO,EAAE,CAAC;AAC3B,QAAA,IAAI,EAAE,WAAW,EAAE,OAAO,EAAE,CAAC;AAC7B,QAAA,IAAI,EAAE,eAAe,EAAE,OAAO,EAAE,CAAC;AACjC,QAAA,IAAI,EAAE,aAAa,EAAE,OAAO,EAAE,CAAC;AAC/B,QAAA,IAAI,CAAC,kBAAkB,GAAG,SAAS,CAAC;KACpC;AACD;;MC3KY,eAAe,CAAA;AAE3B,IAAA,WAAA,GAAA;AACC,QAAA,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;KACrB;IAED,gBAAgB,CAAC,IAAI,EAAE,QAAQ,EAAA;AAC9B,QAAA,IAAI,IAAI,CAAC,UAAU,KAAK,SAAS;AAAE,YAAA,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;AAExD,QAAA,MAAM,SAAS,GAAG,IAAI,CAAC,UAAU,CAAC;AAElC,QAAA,IAAI,SAAS,CAAC,IAAI,CAAC,KAAK,SAAS,EAAE;AAClC,YAAA,SAAS,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC;AACrB,SAAA;AAED,QAAA,IAAI,SAAS,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,EAAE;YAC7C,SAAS,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;AAC/B,SAAA;KACD;IAED,gBAAgB,CAAC,IAAI,EAAE,QAAQ,EAAA;AAC9B,QAAA,IAAI,IAAI,CAAC,UAAU,KAAK,SAAS;AAAE,YAAA,OAAO,KAAK,CAAC;AAEhD,QAAA,MAAM,SAAS,GAAG,IAAI,CAAC,UAAU,CAAC;AAElC,QAAA,OAAO,SAAS,CAAC,IAAI,CAAC,KAAK,SAAS,IAAI,SAAS,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC;KACjF;IAED,mBAAmB,CAAC,IAAI,EAAE,QAAQ,EAAA;AACjC,QAAA,IAAI,IAAI,CAAC,UAAU,KAAK,SAAS;YAAE,OAAO;AAE1C,QAAA,MAAM,SAAS,GAAG,IAAI,CAAC,UAAU,CAAC;AAClC,QAAA,MAAM,aAAa,GAAG,SAAS,CAAC,IAAI,CAAC,CAAC;QAEtC,IAAI,aAAa,KAAK,SAAS,EAAE;YAChC,MAAM,KAAK,GAAG,aAAa,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;AAE9C,YAAA,IAAI,KAAK,KAAK,CAAC,CAAC,EAAE;AACjB,gBAAA,aAAa,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;AAC/B,aAAA;AACD,SAAA;KACD;AAED,IAAA,aAAa,CAAC,KAAK,EAAA;AAClB,QAAA,IAAI,IAAI,CAAC,UAAU,KAAK,SAAS;YAAE,OAAO;AAE1C,QAAA,MAAM,SAAS,GAAG,IAAI,CAAC,UAAU,CAAC;QAClC,MAAM,aAAa,GAAG,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QAE5C,IAAI,aAAa,KAAK,SAAS,EAAE;AAChC,YAAA,KAAK,CAAC,MAAM,GAAG,IAAI,CAAC;YAEpB,MAAM,KAAK,GAAG,aAAa,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;AAErC,YAAA,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE;gBAC7C,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;AAC3B,aAAA;AACD,YAAA,KAAK,CAAC,MAAM,GAAG,IAAI,CAAC;AACpB,SAAA;KACD;AACD;;ACnDa,MAAO,WAAW,CAAA;AAM/B,IAAA,WAAA,GAAA;AACC,QAAA,IAAI,CAAC,GAAG,GAAG,EAAE,CAAC;AACd,QAAA,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC;AACjB,QAAA,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC;AACtB,QAAA,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;AACnB,QAAA,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;KACrB;IACD,IAAI,GAAA;AACH,QAAA,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,WAAW,CAAC,qBAAqB,CAAC,CAAC;AACxF,QAAA,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,EAAE,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,WAAW,CAAC,qBAAqB,CAAC,CAAC;KAClG;IACD,YAAY,CACX,MAAc,EACd,OAAgB,EAChB,WAAkC,EAClC,eAA0B,EAC1B,cAA+B,EAC/B,WAAyB,EAAA;QAEzB,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,KAAI;YACxB,IAAI,CAAC,IAAI,CAAC,KAAK;gBAAE,OAAO;YACxB,IAAI,CAAC,YAAY,EAAE,CAAC;YACpB,WAAW,CAAC,aAAa,CACxB,IAAI,CAAC,cAAc,CAAC,eAAe,EAAE,cAAc,EAAE,WAAW,CAAC,EACjE,OAAO,EACP,WAAW,EACX,MAAM,CACN,CAAC;YACF,IAAI,CAAC,WAAW,EAAE,CAAC;AACpB,SAAC,CAAC,CAAC;KACH;IACD,iBAAiB,CAChB,MAAc,EACd,OAAgB,EAChB,WAAkC,EAClC,eAA0B,EAC1B,cAA+B,EAC/B,WAAyB,EAAA;QAEzB,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,IAAI,KAAI;YAC7B,IAAI,CAAC,IAAI,CAAC,KAAK;gBAAE,OAAO;YACxB,IAAI,CAAC,YAAY,EAAE,CAAC;YACpB,WAAW,CAAC,aAAa,CACxB,IAAI,CAAC,cAAc,CAAC,eAAe,EAAE,cAAc,EAAE,WAAW,CAAC,EACjE,OAAO,EACP,WAAW,EACX,MAAM,CACN,CAAC;YACF,IAAI,CAAC,WAAW,EAAE,CAAC;AACpB,SAAC,CAAC,CAAC;KACH;IACD,aAAa,CAAC,OAAgB,EAAE,WAAmC,EAAA;QAClE,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,OAAO,KAAI;AAC7B,YAAA,WAAW,CAAC,aAAa,CAAC,OAAO,CAAC,UAAU,EAAE,EAAE,OAAO,EAAE,WAAW,CAAC,CAAC;AACvE,SAAC,CAAC,CAAC;KACH;IACD,gBAAgB,CACf,MAAc,EACd,OAAgB,EAChB,WAAkC,EAClC,eAA0B,EAC1B,cAA+B,EAAA;QAE/B,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,IAAI,KAAI;YAC5B,IAAI,CAAC,IAAI,CAAC,KAAK;gBAAE,OAAO;YACxB,IAAI,CAAC,YAAY,EAAE,CAAC;AACpB,YAAA,WAAW,CAAC,aAAa,CACxB,IAAI,CAAC,cAAc,CAAC,eAAe,EAAE,cAAc,CAAC,EACpD,OAAO,EACP,WAAW,EACX,MAAM,CACN,CAAC;YACF,IAAI,CAAC,WAAW,EAAE,CAAC;AACpB,SAAC,CAAC,CAAC;KACH;AACD,IAAA,SAAS,CAAC,MAAc,EAAE,OAAgB,EAAE,WAAkC,EAAE,eAA0B,EAAA;QACzG,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,IAAI,KAAI;YACrB,IAAI,CAAC,IAAI,CAAC,KAAK;gBAAE,OAAO;YACxB,IAAI,CAAC,YAAY,EAAE,CAAC;AACpB,YAAA,WAAW,CAAC,aAAa,CAAC,IAAI,CAAC,cAAc,EAAE,EAAE,OAAO,EAAE,WAAW,EAAE,MAAM,CAAC,CAAC;YAC/E,IAAI,CAAC,WAAW,EAAE,CAAC;AACpB,SAAC,CAAC,CAAC;KACH;IACD,OAAO,aAAa,CAAC,OAAoB,EAAE,OAAiB,EAAE,WAAkC,EAAE,MAAe,EAAA;QAChH,OAAO,CAAC,MAAM,CAAC;YACd,MAAM,EAAE,OAAO,CAAC,MAAM;YACtB,WAAW;YACX,MAAM;YACN,QAAQ,EAAE,OAAO,EAAE,QAAQ;YAC3B,WAAW,EAAE,OAAO,EAAE,WAAW;AACjC,SAAA,CAAC,CAAC;KACH;AACD,IAAA,OAAO,aAAa,CAAC,OAAuB,EAAE,OAAiB,EAAE,WAAmC,EAAA;AACnG,QAAA,OAAO,CAAC,MAAM,CAAC,EAAE,MAAM,EAAE,OAAO,CAAC,MAAM,EAAE,WAAW,EAAE,CAAC,CAAC;KACxD;IACD,KAAK,GAAA;AACJ,QAAA,IAAI,CAAC,GAAG,GAAG,EAAE,CAAC;AACd,QAAA,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC;AACjB,QAAA,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC;AACtB,QAAA,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;AACnB,QAAA,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;KACrB;AACD,IAAA,OAAO,qBAAqB,CAAC,CAAO,EAAE,CAAO,EAAA;AAC5C,QAAA,OAAO,CAAC,CAAC,QAAQ,GAAG,CAAC,CAAC,QAAQ,IAAI,CAAC,CAAC,gBAAgB,GAAG,CAAC,CAAC,gBAAgB,CAAC;KAC1E;AAED,IAAA,OAAO,qBAAqB,CAAC,CAAO,EAAE,CAAO,EAAA;AAC5C,QAAA,OAAO,CAAC,CAAC,QAAQ,GAAG,CAAC,CAAC,QAAQ,IAAI,CAAC,CAAC,gBAAgB,GAAG,CAAC,CAAC,gBAAgB,CAAC;KAC1E;;IAED,OAAO,IAAI,CAAI,QAAa,EAAE,IAAY,EAAE,EAAU,EAAE,WAAqB,EAAA;QAC5E,WAAW,CAAC,UAAU,CAAC,QAAQ,EAAE,IAAI,EAAE,EAAE,EAAE,WAAW,CAAC,CAAC;KACxD;;IAEO,OAAO,UAAU,CAAI,CAAM,EAAE,IAAY,EAAE,EAAU,EAAE,WAAqB,EAAA;AACnF,QAAA,OAAO,IAAI,EAAE;;AAEZ,YAAA,IAAI,EAAE,GAAG,IAAI,IAAI,EAAE,EAAE;gBACpB,WAAW,CAAC,cAAc,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,WAAW,CAAC,CAAC;gBACrD,OAAO;AACP,aAAA;YACD,MAAM,WAAW,GAAG,CAAC,IAAI,GAAG,EAAE,KAAK,CAAC,CAAC;;AAErC,YAAA,IAAI,EAAE,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC;YACjB,IAAI,EAAE,GAAG,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC;AACnB,YAAA,IAAI,EAAE,GAAG,CAAC,CAAC,WAAW,CAAC,CAAC;YACxB,MAAM,GAAG,GAAG,WAAW,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC;YAChC,IAAI,GAAG,GAAG,CAAC,EAAE;;gBAEZ,MAAM,GAAG,GAAG,EAAE,CAAC;gBACf,EAAE,GAAG,EAAE,CAAC;gBACR,EAAE,GAAG,GAAG,CAAC;AACT,aAAA;YACD,MAAM,GAAG,GAAG,WAAW,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC;YAChC,IAAI,GAAG,IAAI,CAAC,EAAE;;gBAEb,MAAM,GAAG,GAAG,EAAE,CAAC;gBACf,EAAE,GAAG,EAAE,CAAC;gBACR,EAAE,GAAG,EAAE,CAAC;gBACR,EAAE,GAAG,GAAG,CAAC;AACT,aAAA;AAAM,iBAAA;;gBAEN,MAAM,GAAG,GAAG,WAAW,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC;gBAChC,IAAI,GAAG,GAAG,CAAC,EAAE;;oBAEZ,MAAM,GAAG,GAAG,EAAE,CAAC;oBACf,EAAE,GAAG,EAAE,CAAC;oBACR,EAAE,GAAG,GAAG,CAAC;AACT,iBAAA;AACD,aAAA;;AAED,YAAA,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC;AACb,YAAA,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC;YACf,MAAM,KAAK,GAAG,EAAE,CAAC;AACjB,YAAA,IAAI,OAAO,GAAG,IAAI,GAAG,CAAC,CAAC;AACvB,YAAA,IAAI,UAAU,GAAG,EAAE,GAAG,CAAC,CAAC;YACxB,CAAC,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC;AAC5B,YAAA,CAAC,CAAC,OAAO,CAAC,GAAG,KAAK,CAAC;;;AAInB,YAAA,SAAS,EAAE,KAAK,IAAI,CAAC,GAAG,OAAO,GAAG,CAAC,EAAE,CAAC,GAAG,UAAU,EAAE,CAAC,EAAE,EAAE;AACzD,gBAAA,IAAI,OAAO,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;gBACnB,IAAI,KAAK,GAAG,WAAW,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;gBACxC,IAAI,KAAK,GAAG,CAAC,EAAE;oBACd,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC;AAClB,oBAAA,CAAC,CAAC,OAAO,CAAC,GAAG,OAAO,CAAC;AACrB,oBAAA,OAAO,EAAE,CAAC;AACV,iBAAA;qBAAM,IAAI,KAAK,GAAG,CAAC,EAAE;oBACrB,GAAG;AACF,wBAAA,UAAU,EAAE,CAAC;wBACb,IAAI,UAAU,IAAI,CAAC;AAAE,4BAAA,MAAM,SAAS,CAAC;AACrC,wBAAA,MAAM,QAAQ,GAAG,CAAC,CAAC,UAAU,CAAC,CAAC;AAC/B,wBAAA,KAAK,GAAG,WAAW,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;qBACrC,QAAQ,KAAK,GAAG,CAAC,EAAE;oBACpB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,UAAU,CAAC,CAAC;AACrB,oBAAA,CAAC,CAAC,UAAU,CAAC,GAAG,OAAO,CAAC;oBACxB,IAAI,KAAK,GAAG,CAAC,EAAE;AACd,wBAAA,OAAO,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;wBACf,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC;AAClB,wBAAA,CAAC,CAAC,OAAO,CAAC,GAAG,OAAO,CAAC;AACrB,wBAAA,OAAO,EAAE,CAAC;AACV,qBAAA;AACD,iBAAA;AACD,aAAA;AACD,YAAA,IAAI,EAAE,GAAG,UAAU,GAAG,OAAO,GAAG,IAAI,EAAE;gBACrC,IAAI,CAAC,UAAU,CAAC,CAAC,EAAE,UAAU,EAAE,EAAE,EAAE,WAAW,CAAC,CAAC;gBAChD,EAAE,GAAG,OAAO,CAAC;AACb,aAAA;AAAM,iBAAA;gBACN,IAAI,CAAC,UAAU,CAAC,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,WAAW,CAAC,CAAC;gBAC/C,IAAI,GAAG,UAAU,CAAC;AAClB,aAAA;AACD,SAAA;KACD;IACO,OAAO,cAAc,CAAI,CAAM,EAAE,IAAY,EAAE,EAAU,EAAE,WAAqB,EAAA;AACvF,QAAA,KAAK,IAAI,CAAC,GAAG,IAAI,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,EAAE,EAAE;AACnC,YAAA,IAAI,CAAC,CAAC;AACN,YAAA,MAAM,OAAO,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;AACrB,YAAA,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,IAAI,EAAE,CAAC,EAAE,EAAE;AAC/B,gBAAA,MAAM,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;gBACjB,MAAM,KAAK,GAAG,WAAW,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC;gBACxC,IAAI,KAAK,GAAG,CAAC,EAAE;AACd,oBAAA,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC;AACf,iBAAA;AAAM,qBAAA;oBACN,MAAM;AACN,iBAAA;AACD,aAAA;AACD,YAAA,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,OAAO,CAAC;AACnB,SAAA;KACD;AACD;;MC7MY,UAAU,CAAA;AAWtB,IAAA,WAAA,CAAmB,OAAgB,EAAS,WAAyB,EAAE,UAA6B,EAAE,EAAA;QAAnF,IAAO,CAAA,OAAA,GAAP,OAAO,CAAS;QAAS,IAAW,CAAA,WAAA,GAAX,WAAW,CAAc;AACpE,QAAA,IAAI,CAAC,UAAU,GAAG,OAAO,CAAC,UAAU,CAAC;AACrC,QAAA,IAAI,CAAC,WAAW,GAAG,IAAI,WAAW,EAAE,CAAC;AACrC,QAAA,IAAI,CAAC,cAAc,GAAG,CAAC,CAAC;AACxB,QAAA,IAAI,CAAC,aAAa,GAAG,CAAC,CAAC;AACvB,QAAA,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC;AACrB,QAAA,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;AACnB,QAAA,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;KACzB;AACD,IAAA,IAAI,OAAO,GAAA;QACV,OAAO,IAAI,CAAC,QAAQ,CAAC;KACrB;IACD,IAAI,OAAO,CAAC,KAAK,EAAA;AAChB,QAAA,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;AACzB,QAAA,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC,KAAK,EAAE,IAAI,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;KACrD;AACD,IAAA,MAAM,CAAC,MAAc,EAAE,OAAA,GAA6B,EAAE,EAAA;AACrD,QAAA,IAAI,CAAC,UAAU,GAAG,OAAO,CAAC,UAAU,CAAC;AAErC,QAAA,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,CAAC;QACzB,IAAI,EAAE,WAAW,EAAE,MAAM,GAAG,IAAI,EAAE,MAAM,CAAC,CAAC;AAC1C,QAAA,IAAI,CAAC,aAAa,GAAG,MAAM,CAAC,gBAAgB,EAAE,CAAC;AAC/C,QAAA,IAAI,CAAC,WAAW,IAAI,CAAC,CAAC;KACtB;AAED,IAAA,kBAAkB,CAAC,MAAc,EAAA;AAChC,QAAA,IAAI,CAAC,aAAa,GAAG,MAAM,CAAC,gBAAgB,EAAE,CAAC;KAC/C;IAED,OAAO,2BAA2B,CAAC,aAAoB,EAAA;QACtD,OAAO;YACN,UAAU,EAAE,aAAa,CAAC,UAAU;SACpC,CAAC;KACF;AACD;;AC5DK,MAAO,YAAa,SAAQ,KAAK,CAAA;IAEtC,WAAY,CAAA,KAAc,EAAE,SAAiB,EAAA;AAC5C,QAAA,KAAK,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;AACxB,QAAA,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC,YAAY,CAAC;QACxC,IAAI,CAAC,kBAAkB,GAAG,IAAI,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC;KAC5E;AACD,IAAA,IAAI,iBAAiB,GAAA;QACpB,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;QACtF,OAAO,IAAI,CAAC,kBAAkB,CAAC;KAC/B;AACD,CAAA;AACD;;ACOc,MAAO,WAAW,CAAA;AAqB/B,IAAA,WAAA,CAAY,OAA2B,EAAA;AACtC,QAAA,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;AACrB,QAAA,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC;AACtB,QAAA,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;AACvB,QAAA,IAAI,CAAC,YAAY,GAAG,IAAI,YAAY,CAAC,IAAI,OAAO,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,GAAG,CAAC,CAAC;AACtE,QAAA,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;AAC5B,QAAA,IAAI,CAAC,UAAU,GAAG,OAAO,CAAC,UAAU,CAAC;KACrC;IACD,MAAM,CAAC,UAAsB,EAAE,MAAc,EAAA;QAC5C,IAAI,CAAC,qBAAqB,EAAE,CAAC;AAC7B,QAAA,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;KACzB;AACD,IAAA,GAAG,CAAC,KAAY,EAAA;AACf,QAAA,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;AAC5B,QAAA,IAAI,KAAK,CAAC,SAAS,IAAI,SAAS,CAAC,YAAY,EAAE;AAC9C,YAAA,IAAI,CAAC,YAAY,GAAiB,KAAK,CAAC;AACxC,SAAA;AAAM,aAAA,IAAI,KAAK,CAAC,SAAS,IAAI,SAAS,CAAC,gBAAgB,EAAE;AACzD,YAAA,IAAI,CAAC,YAAY,CAAC,IAAI,CAAmB,KAAK,CAAC,CAAC;AAChD,SAAA;AAAM,aAAA,IAAI,KAAK,CAAC,SAAS,IAAI,SAAS,CAAC,UAAU,EAAE;AACnD,YAAA,IAAI,CAAC,WAAW,CAAC,IAAI,CAAa,KAAK,CAAC,CAAC;AACzC,SAAA;AAAM,aAAA,IAAI,KAAK,CAAC,SAAS,IAAI,SAAS,CAAC,SAAS,EAAE;AAClD,YAAA,IAAI,CAAC,UAAU,CAAC,IAAI,CAAY,KAAK,CAAC,CAAC;AACvC,SAAA;KACD;AACD,IAAA,MAAM,CAAC,KAAY,EAAA;AAClB,QAAA,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;AAC5B,QAAA,IAAI,KAAK,CAAC,SAAS,IAAI,SAAS,CAAC,YAAY,EAAE;AAC9C,YAAA,IAAI,CAAC,YAAY,GAAG,IAAI,YAAY,CAAC,IAAI,OAAO,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,GAAG,CAAC,CAAC;AACtE,SAAA;AAAM,aAAA,IAAI,KAAK,CAAC,SAAS,IAAI,SAAS,CAAC,gBAAgB,EAAE;AACzD,YAAA,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,OAAO,CAAmB,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC;AAChF,SAAA;AAAM,aAAA,IAAI,KAAK,CAAC,SAAS,IAAI,SAAS,CAAC,UAAU,EAAE;AACnD,YAAA,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAa,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC;AACxE,SAAA;AAAM,aAAA,IAAI,KAAK,CAAC,SAAS,IAAI,SAAS,CAAC,SAAS,EAAE;AAClD,YAAA,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,OAAO,CAAY,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC;AACrE,SAAA;KACD;IACD,qBAAqB,GAAA;AACpB,QAAA,MAAM,MAAM,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;AACnC,QAAA,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;AACvC,YAAA,MAAM,KAAK,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;YACxB,IAAI,KAAK,CAAC,WAAW,EAAE;AACtB,gBAAA,KAAK,CAAC,WAAW,GAAG,KAAK,CAAC;AAC1B,gBAAA,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;AAC5B,aAAA;AACD,SAAA;KACD;IAED,iBAAiB,GAAA;QAChB,IAAI,IAAI,CAAC,8BAA8B;AAAE,YAAA,IAAI,CAAC,8BAA8B,CAAC,KAAK,GAAG,IAAI,CAAC;QAE1F,IAAI,IAAI,CAAC,+BAA+B;AAAE,YAAA,IAAI,CAAC,+BAA+B,CAAC,KAAK,GAAG,IAAI,CAAC;QAE5F,IAAI,IAAI,CAAC,gCAAgC;AAAE,YAAA,IAAI,CAAC,gCAAgC,CAAC,KAAK,GAAG,IAAI,CAAC;KAC9F;AAEO,IAAA,WAAW,CAAC,MAAc,EAAA;QACjC,IAAI,IAAI,CAAC,eAAe,EAAE;AACzB,YAAA,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;YAC7B,IAAI,IAAI,CAAC,eAAe;AAAE,gBAAA,IAAI,CAAC,eAAe,CAAC,OAAO,EAAE,CAAC;YACzD,IAAI,CAAC,qBAAqB,EAAE,CAAC;AAC7B,SAAA;KACD;IACO,qBAAqB,GAAA;AAC5B,QAAA,IAAI,CAAC,eAAe,GAAG,IAAI,UAAU,CAAC,OAAO,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;AACxD,QAAA,IAAI,CAAC,kBAAkB,GAAG,IAAI,aAAa,CAAC;AAC3C,YAAA,KAAK,EAAE,OAAO;YACd,IAAI,EAAE,iBAAiB,CAAC,eAAe;AACvC,YAAA,KAAK,EAAE,WAAW,CAAC,OAAO,GAAG,WAAW,CAAC,OAAO;AAChD,SAAA,CAAC,CAAC;AAEH,QAAA,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,iBAAiB,EAAE,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;AAC1E,QAAA,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,kBAAkB,EAAE,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;AAC5E,QAAA,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,oBAAoB,EAAE,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;QAC/E,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,mBAAmB,EAAE,CAAC,CAAC,CAAC;QACvD,IAAI,IAAI,CAAC,YAAY;YACpB,IAAI,CAAC,kBAAkB,CAAC,UAAU,CACjC,cAAc,EACd,MAAK;AACJ,gBAAA,OAAO,IAAI,CAAC,YAAY,CAAC,iBAAiB,CAAC;AAC5C,aAAC,EACD,WAAW,CAAC,SAAS,CACrB,CAAC;AACH,QAAA,IAAI,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE;;YAE3B,IAAI,CAAC,kBAAkB,CAAC,UAAU,CACjC,YAAY,EACZ,MAAK;gBACJ,OAAO,IAAI,CAAC,UAAU,CAAC;aACvB,EACD,WAAW,CAAC,UAAU,EACtB,IAAI,CAAC,UAAU,CAAC,MAAM,CACtB,CAAC;AACF,SAAA;AACD,QAAA,IAAI,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE;;YAE5B,IAAI,CAAC,kBAAkB,CAAC,UAAU,CACjC,aAAa,EACb,MAAK;gBACJ,OAAO,IAAI,CAAC,WAAW,CAAC;aACxB,EACD,WAAW,CAAC,WAAW,EACvB,IAAI,CAAC,WAAW,CAAC,MAAM,CACvB,CAAC;AACF,SAAA;AACD,QAAA,IAAI,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE;;YAE7B,IAAI,CAAC,kBAAkB,CAAC,UAAU,CACjC,cAAc,EACd,MAAK;gBACJ,OAAO,IAAI,CAAC,YAAY,CAAC;aACzB,EACD,WAAW,CAAC,aAAa,EACzB,IAAI,CAAC,YAAY,CAAC,MAAM,CACxB,CAAC;AACF,SAAA;AAED,QAAA,gBAAgB,EAAE;YACjB,IAAI,IAAI,CAAC,UAAU,EAAE;AACpB,gBAAA,MAAM,8BAA8B,IAAI,IAAI,CAAC,8BAA8B;oBAC1E,IAAI,CAAC,2BAA2B,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC;AACpD,gBAAA,MAAM,+BAA+B,IAAI,IAAI,CAAC,+BAA+B;oBAC5E,IAAI,CAAC,2BAA2B,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC;AACrD,gBAAA,MAAM,gCAAgC,IAAI,IAAI,CAAC,gCAAgC;oBAC9E,IAAI,CAAC,2BAA2B,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC;AACtD,gBAAA,IACC,CAAC,8BAA8B;AAC/B,oBAAA,CAAC,+BAA+B;AAChC,oBAAA,CAAC,gCAAgC;AAEjC,oBAAA,MAAM,gBAAgB,CAAC;;gBAGxB,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,YAAY,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;;AAG9D,gBAAA,IAAI,CAAC,mBAAmB,GAAG,IAAI,aAAa,CAAC;AAC5C,oBAAA,KAAK,EAAE,QAAQ;oBACf,IAAI,EAAE,iBAAiB,CAAC,eAAe;AACvC,oBAAA,KAAK,EAAE,WAAW,CAAC,OAAO,GAAG,WAAW,CAAC,OAAO;AAChD,iBAAA,CAAC,CAAC;;AAGH,gBAAA,MAAM,wBAAwB,GAAG,IAAI,CAAC,gBAAgB,CACrD,kBAAkB,EAClB,IAAI,CAAC,UAAU,EACf,WAAW,CAAC,gBAAgB,CAC5B,CAAC;AACF,gBAAA,MAAM,yBAAyB,GAAG,IAAI,CAAC,gBAAgB,CACtD,mBAAmB,EACnB,IAAI,CAAC,WAAW,EAChB,WAAW,CAAC,iBAAiB,CAC7B,CAAC;AACF,gBAAA,MAAM,0BAA0B,GAAG,IAAI,CAAC,gBAAgB,CACvD,oBAAoB,EACpB,IAAI,CAAC,YAAY,EACjB,WAAW,CAAC,mBAAmB,CAC/B,CAAC;gBACF,IAAI,CAAC,eAAe,CAAC,gBAAgB,CAAC,QAAQ,EAAE,IAAI,CAAC,mBAAmB,CAAC,CAAC;gBAE1E,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,0BAA0B,EAAE,wBAAwB,CAAC,CAAC;gBACrF,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,2BAA2B,EAAE,yBAAyB,CAAC,CAAC;gBACvF,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,4BAA4B,EAAE,0BAA0B,CAAC,CAAC;;gBAGzF,IAAI,8BAA8B,KAAK,SAAS,EAAE;oBACjD,IAAI,8BAA8B,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,IAAI,wBAAwB;AACpF,wBAAA,OAAO,CAAC,IAAI,CAAC,sCAAsC,CAAC,CAAC;oBACtD,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,gCAAgC,EAAE,8BAA8B,CAAC,CAAC;;AAElG,iBAAA;gBACD,IAAI,+BAA+B,KAAK,SAAS,EAAE;oBAClD,IAAI,+BAA+B,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,IAAI,yBAAyB;AACtF,wBAAA,OAAO,CAAC,IAAI,CAAC,uCAAuC,CAAC,CAAC;oBACvD,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,iCAAiC,EAAE,+BAA+B,CAAC,CAAC;;AAEpG,iBAAA;gBACD,IAAI,gCAAgC,KAAK,SAAS,EAAE;oBACnD,IAAI,gCAAgC,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,IAAI,0BAA0B;AACxF,wBAAA,OAAO,CAAC,IAAI,CAAC,wCAAwC,CAAC,CAAC;oBACxD,IAAI,CAAC,eAAe,CAAC,UAAU,CAC9B,kCAAkC,EAClC,gCAAgC,CAChC,CAAC;;AAEF,iBAAA;gBACD,IAAI,CAAC,eAAe,CAAC,UAAU,CAC9B,eAAe,EACf,IAAI,OAAO,CAAC,EAAE,OAAO,EAAE,eAAe,CAAC,IAAI,EAAE,EAAE,EAAE,IAAI,EAAE,kBAAkB,CAAC,UAAU,EAAE,CAAC,CACvF,CAAC;;AAEF,aAAA;AACD,SAAA;QAED,IAAI,CAAC,eAAe,CAAC,gBAAgB,CAAC,OAAO,EAAE,IAAI,CAAC,kBAAkB,CAAC,CAAC;KACxE;IAEM,YAAY,GAAA;QAClB,MAAM,MAAM,GAAG,EAAE,CAAC;AAClB,QAAA,OAAO,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;KAC3E;IAED,OAAO,GAAA;AACN,QAAA,IAAI,CAAC,eAAe,CAAC,OAAO,EAAE,CAAC;AAC/B,QAAA,IAAI,CAAC,kBAAkB,CAAC,OAAO,EAAE,CAAC;KAClC;AAED,IAAA,2BAA2B,CAAC,MAAoB,EAAA;AAC/C,QAAA,IAAI,MAAM,CAAC,MAAM,IAAI,CAAC;AAAE,YAAA,OAAO,SAAS,CAAC;QACzC,MAAM,gBAAgB,GAAG,EAAE,CAAC;AAC5B,QAAA,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;AACvC,YAAA,MAAM,KAAK,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;YACxB,IAAI,KAAK,CAAC,MAAM,EAAE;gBACjB,MAAM,gBAAgB,GAAG,KAAK,CAAC,MAAM,CAAC,mBAAmB,EAAE,CAAC;AAC5D,gBAAA,MAAM,eAAe,GAAG;AACvB,oBAAA,MAAM,EAAE,gBAAgB;AACxB,oBAAA,KAAK,EAAE,gBAAgB,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK;AAC9C,oBAAA,MAAM,EAAE,gBAAgB,CAAC,WAAW,CAAC,IAAI,CAAC,MAAM;AAChD,oBAAA,KAAK,EAAE,CAAC;AACR,oBAAA,CAAC,EAAE,CAAC;AACJ,oBAAA,CAAC,EAAE,CAAC;AACJ,oBAAA,CAAC,EAAE,CAAC;iBACJ,CAAC;AACF,gBAAA,gBAAgB,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;AACvC,aAAA;AACD,SAAA;AAED,QAAA,IAAI,gBAAgB,CAAC,MAAM,IAAI,CAAC;AAAE,YAAA,OAAO,SAAS,CAAC;AAEnD,QAAA,MAAM,qBAAqB,GAAG,IAAI,OAAO,CAAC;AACzC,YAAA,IAAI,EAAE;AACL,gBAAA,KAAK,EAAE,gBAAgB,CAAC,CAAC,CAAC,CAAC,KAAK;AAChC,gBAAA,MAAM,EAAE,gBAAgB,CAAC,CAAC,CAAC,CAAC,MAAM;gBAClC,KAAK,EAAE,gBAAgB,CAAC,MAAM;AAC9B,aAAA;AACD,YAAA,SAAS,EAAE,IAAI;YACf,UAAU,EAAE,iBAAiB,CAAC,KAAK;YACnC,MAAM,EAAE,aAAa,CAAC,WAAW;AACjC,YAAA,KAAK,EAAE,YAAY,CAAC,cAAc,GAAG,YAAY,CAAC,OAAO;AACzD,YAAA,IAAI,EAAE,gBAAgB;YACtB,WAAW,EAAE,oBAAoB,CAAC,QAAQ;AAC1C,SAAA,CAAC,CAAC;AAEH,QAAA,OAAO,qBAAqB,CAAC;KAC7B;AAED,IAAA,gBAAgB,CAAC,WAAmB,EAAE,MAAoB,EAAE,WAAwB,EAAA;QACnF,IAAI,MAAM,CAAC,MAAM,EAAE;YAClB,MAAM,oBAAoB,GAAG,EAAE,CAAC;AAChC,YAAA,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;AACvC,gBAAA,MAAM,KAAK,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;gBACxB,IAAI,CAAC,KAAK,CAAC,MAAM;oBAAE,SAAS;AAC5B,gBAAA,oBAAoB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;AACjC,aAAA;YAED,IAAI,CAAC,mBAAmB,CAAC,UAAU,CAClC,WAAW,EACX,MAAK;AACJ,gBAAA,OAAO,oBAAoB,CAAC;AAC7B,aAAC,EACD,WAAW,EACX,oBAAoB,CAAC,MAAM,CAC3B,CAAC;YAEF,OAAO,oBAAoB,CAAC,MAAM,CAAC;AACnC,SAAA;KACD;AACD;;ACpTa,MAAO,UAAU,CAAA;AAE9B,IAAA,WAAA,GAAA;AACC,QAAA,IAAI,CAAC,KAAK,GAAG,IAAI,GAAG,EAAE,CAAC;KACvB;AACD,IAAA,IAAI,MAAM,GAAA;AACT,QAAA,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC;KACvB;IACD,MAAM,CAAC,UAAsB,EAAE,MAAc,EAAA;QAC5C,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,QAAQ,KAAI;AAC/B,YAAA,QAAQ,CAAC,MAAM,CAAC,UAAU,EAAE,MAAM,CAAC,CAAC;AACrC,SAAC,CAAC,CAAC;KACH;AACD,IAAA,GAAG,CAAC,QAAc,EAAA;QACjB,IAAI,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC;YAAE,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;QACtE,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC;AACvC,QAAA,OAAO,QAAQ,CAAC;KAChB;AACD,IAAA,MAAM,CAAC,QAAc,EAAA;QACpB,IAAI,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE;YACjC,QAAQ,CAAC,OAAO,EAAE,CAAC;YACnB,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;AAChC,YAAA,OAAO,IAAI,CAAC;AACZ,SAAA;AACD,QAAA,OAAO,KAAK,CAAC;KACb;AACD,IAAA,QAAQ,CAAC,QAAc,EAAA;AACtB,QAAA,OAAO,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;KACtC;AACD;;ACrBa,MAAO,YAAY,CAAA;AAKhC,IAAA,WAAA,GAAA;QACC,IAAI,CAAC,QAAQ,GAAG,IAAI,QAAQ,CAAC,EAAE,CAAC,CAAC;QACjC,IAAI,CAAC,QAAQ,CAAC,YAAY,CACzB,IAAI,gBAAgB,CAAC,UAAU,EAAE,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,GAAG,EAAE,CAAC,GAAG,EAAE,GAAG,EAAE,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CACvG,CAAC;AACF,QAAA,IAAI,CAAC,QAAQ,CAAC,KAAK,GAAG,CAAC,CAAC;AACxB,QAAA,MAAM,MAAM,GAAG,WAAW,CAAC,SAAS,EAAE,EAAE,gBAAgB,EAAE,CAAC,EAAE,CAAC,CAAC;AAC/D,QAAA,IAAI,CAAC,QAAQ,GAAG,IAAI,cAAc,CAAC;AAClC,YAAA,IAAI,EAAE,SAAS;YACf,IAAI,EAAE,MAAM,CAAC,IAAI;YACjB,IAAI,EAAE,MAAM,CAAC,IAAI;AACjB,YAAA,QAAQ,EAAE;AACT,gBAAA,OAAO,EAAE;AACR,oBAAA,IAAI,EAAE,SAAS;AACf,oBAAA,KAAK,EAAE,SAAS;AAChB,iBAAA;AACD,gBAAA,OAAO,EAAE;AACR,oBAAA,IAAI,EAAE,SAAS;oBACf,KAAK,EAAE,IAAI,OAAO,CAAC;AAClB,wBAAA,SAAS,EAAE,QAAQ;AACnB,wBAAA,SAAS,EAAE,QAAQ;qBACnB,CAAC;AACF,iBAAA;AACD,aAAA;AACD,SAAA,CAAC,CAAC;AACH,QAAA,IAAI,CAAC,QAAQ,GAAG,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;KACvD;IACD,OAAO,CAAC,KAAa,EAAE,MAAc,EAAA;QACpC,IAAI,CAAC,kBAAkB,CAAC,OAAO,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;AAC/C,QAAA,IAAI,CAAC,QAAQ,CAAC,KAAK,GAAG,IAAI,CAAC;KAC3B;IACD,MAAM,CAAC,OAAgB,EAAE,YAAsB,EAAA;QAC9C,IAAI,CAAC,IAAI,CAAC,kBAAkB;AAAE,YAAA,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC;;QAE7D,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,OAAO,CAAC,KAAK,GAAG,YAAY,CAAC;QAEpD,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,SAAS,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;QAE/C,MAAM,UAAU,GAAG,IAAI,CAAC,QAAQ,CAAC,cAAc,EAAE,CAAC;AAElD,QAAA,MAAM,wBAAwB,GAAG,IAAI,CAAC,kBAAkB,CAAC,eAAe,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;AAEzF,QAAA,UAAU,CAAC,MAAM,CAAC,EAAE,MAAM,EAAE,OAAO,CAAC,MAAM,EAAE,WAAW,EAAE,wBAAwB,EAAE,CAAC,CAAC;AAErF,QAAA,IAAI,CAAC,kBAAkB,CAAC,aAAa,EAAE,CAAC;KACxC;AACO,IAAA,gBAAgB,CAAC,OAAgB,EAAA;QACxC,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,OAAO,CAAC,gBAAgB,CAAC;QAC1D,MAAM,eAAe,GAAG,IAAI,UAAU,CACrC,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,CAAC,EAAE,EAChC;YACC,WAAW,EAAE,MAAK;gBACjB,OAAO,OAAO,CAAC,OAAO,CAAC,iBAAiB,EAAE,CAAC,UAAU,EAAE,CAAC;aACxD;AACD,SAAA,CACD,CAAC;AACF,QAAA,MAAM,YAAY,GAAG,IAAI,OAAO,CAAC;AAChC,YAAA,KAAK,EAAE,cAAc;AACrB,YAAA,IAAI,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE;YAC9B,MAAM,EAAE,aAAa,CAAC,WAAW;YACjC,KAAK,EAAE,YAAY,CAAC,gBAAgB;AACpC,SAAA,CAAC,CAAC;AACH,QAAA,MAAM,eAAe,GAAG,IAAI,UAAU,CAAC,GAAG,EAAE,EAAE,OAAO,EAAE,YAAY,EAAE,CAAC,CAAC;AACvE,QAAA,IAAI,CAAC,kBAAkB,GAAG,IAAI,YAAY,CAAC,QAAQ,EAAE,CAAC,eAAe,CAAC,EAAE,eAAe,CAAC,CAAC;KACzF;AACD;;AC5Ea,MAAO,oBAAoB,CAAA;AAIxC,IAAA,WAAA,GAAA;AACC,QAAA,IAAI,CAAC,YAAY,GAAG,IAAI,GAAG,EAAE,CAAC;AAC9B,QAAA,IAAI,CAAC,mBAAmB,GAAG,SAAS,CAAC;AACrC,QAAA,IAAI,CAAC,YAAY,GAAG,IAAI,YAAY,EAAE,CAAC;KACvC;AACD,IAAA,GAAG,CAAC,UAAsB,EAAA;QACzB,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,UAAU,CAAC,EAAE,EAAE,UAAU,CAAC,CAAC;KACjD;AACD,IAAA,MAAM,CAAC,UAAsB,EAAA;QAC5B,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC;QACxC,UAAU,CAAC,OAAO,EAAE,CAAC;KACrB;IACD,MAAM,CAAC,OAAgB,EAAE,YAAqB,EAAA;AAC7C,QAAA,IAAI,CAAC,mBAAmB,GAAG,YAAY,CAAC;QACxC,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,UAAU,KAAI;AACxC,YAAA,IAAI,CAAC,mBAAmB,GAAG,UAAU,CAAC,MAAM,CAAC,OAAO,EAAE,IAAI,CAAC,mBAAmB,CAAC,CAAC;AACjF,SAAC,CAAC,CAAC;QACH,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,OAAO,EAAE,IAAI,CAAC,mBAAmB,CAAC,CAAC;KAC5D;IACD,OAAO,CAAC,KAAa,EAAE,MAAc,EAAA;AACpC,QAAA,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,UAAU,KAAK,UAAU,CAAC,OAAO,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC,CAAC;QAC7E,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;KACzC;IACO,eAAe,GAAA;;KAEtB;AACD;;AC5BD,MAAM,IAAI,CAAA;AAQT,IAAA,WAAA,CAAY,OAAgB,EAAA;AAC3B,QAAA,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;KACvB;AACD,IAAA,MAAM,CAAC,UAAsB,EAAA;;KAE5B;IACD,OAAO,CAAC,KAAa,EAAE,MAAc,EAAA;;KAEpC;AACD,IAAA,YAAY,CAAC,OAAa,EAAA;AACzB,QAAA,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,YAAY,CAAC,eAAe,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;QAChF,IAAI,IAAI,CAAC,aAAa;AACrB,YAAA,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,aAAa,CAAC,uBAAuB,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;KAC3F;IACD,eAAe,CAAC,KAAK,GAAG,CAAC,EAAA;QACxB,OAAO,IAAI,CAAC,YAAY,CAAC,eAAe,CAAC,KAAK,CAAY,CAAC;KAC3D;IACD,eAAe,GAAA;AACd,QAAA,OAAO,IAAI,CAAC,YAAY,CAAC,eAAe,EAAE,CAAC;KAC3C;IACD,WAAW,GAAA;AACV,QAAA,IAAI,CAAC,YAAY,CAAC,aAAa,EAAE,CAAC;QAClC,IAAI,IAAI,CAAC,aAAa;AAAE,YAAA,IAAI,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC;KACnE;AACD;;AC5BK,MAAO,SAAU,SAAQ,IAAI,CAAA;AAElC,IAAA,WAAA,CAAY,OAAgB,EAAA;QAC3B,KAAK,CAAC,OAAO,CAAC,CAAC;AACf,QAAA,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;KACnB;AAED,IAAA,YAAY,CAAC,UAAsB,EAAA;AAClC,QAAA,IAAI,CAAC,kBAAkB,CAAC,UAAU,CAAC,CAAC;QAEpC,KAAK,CAAC,YAAY,EAAE,CAAC;KACrB;IAED,MAAM,CAAC,UAAsB,EAAE,MAAe,EAAA;AAC7C,QAAA,MAAM,EAAE,WAAW,EAAE,WAAW,EAAE,GAAG,UAAU,CAAC;QAEhD,WAAW,CAAC,IAAI,EAAE,CAAC;AACnB,QAAA,WAAW,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,iBAAiB,CAAC,CAAC;AACpE,QAAA,WAAW,CAAC,iBAAiB,CAAC,MAAM,EAAE,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,iBAAiB,EAAE,SAAS,EAAE,SAAS,EAAE,WAAW,CAAC,CAAC;AAC/G,QAAA,WAAW,CAAC,YAAY,CAAC,MAAM,EAAE,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,iBAAiB,EAAE,SAAS,EAAE,SAAS,EAAE,WAAW,CAAC,CAAC;AAC1G,QAAA,WAAW,CAAC,gBAAgB,CAAC,MAAM,EAAE,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,iBAAiB,CAAC,CAAC;KAC3E;AACO,IAAA,IAAI,CAAC,OAAgB,EAAA;AAC5B,QAAA,IAAI,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAC;KACjC;AACO,IAAA,kBAAkB,CAAC,OAAgB,EAAA;QAC1C,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,OAAO,CAAC,gBAAgB,CAAC;AAC1D,QAAA,MAAM,YAAY,GAAG,IAAI,OAAO,CAAC;AAChC,YAAA,KAAK,EAAE,gBAAgB;AACvB,YAAA,IAAI,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE;AAC9B,YAAA,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,kBAAkB;AACvC,YAAA,KAAK,EAAE,YAAY,CAAC,gBAAgB,GAAG,YAAY,CAAC,cAAc;AAClE,SAAA,CAAC,CAAC;AACH,QAAA,MAAM,YAAY,GAAG,IAAI,OAAO,CAAC;AAChC,YAAA,KAAK,EAAE,gBAAgB;AACvB,YAAA,IAAI,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE;YAC9B,MAAM,EAAE,aAAa,CAAC,WAAW;YACjC,KAAK,EAAE,YAAY,CAAC,gBAAgB;AACpC,SAAA,CAAC,CAAC;AACH,QAAA,MAAM,eAAe,GAAG,IAAI,UAAU,CAAC,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE,OAAO,EAAE,YAAY,EAAE,CAAC,CAAC;AACtG,QAAA,MAAM,eAAe,GAAG,IAAI,UAAU,CAAC,GAAG,EAAE,EAAE,OAAO,EAAE,YAAY,EAAE,CAAC,CAAC;AACvE,QAAA,IAAI,CAAC,YAAY,GAAG,IAAI,YAAY,CAAC,QAAQ,EAAE,CAAC,eAAe,CAAC,EAAE,eAAe,CAAC,CAAC;KACnF;IACM,OAAO,CAAC,KAAa,EAAE,MAAc,EAAA;QAC3C,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,KAAK,EAAE,MAAM,EAAE,CAAC,CAAC,CAAC;KAC5C;AACO,IAAA,kBAAkB,CAAC,UAAsB,EAAA;AAChD,QAAA,IAAI,UAAU,EAAE,UAAU,EAAE,KAAK,YAAY,KAAK,EAAE;AACnD,YAAA,MAAM,EAAE,GAAG,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,UAAU,CAAC,UAAU,CAAC,KAAK,CAAC;AACzD,YAAA,MAAM,OAAO,GAAG,UAAU,CAAC,UAAU,EAAE,OAAO,CAAC;AAC/C,YAAA,MAAM,UAAU,GAAG;AAClB,gBAAA,CAAC,EAAE,GAAG;AACN,gBAAA,CAAC,EAAE,KAAK;AACR,gBAAA,CAAC,EAAE,IAAI;gBACP,CAAC,EAAE,OAAO,IAAI,GAAG;aACjB,CAAC;YACF,IAAI,CAAC,YAAY,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,KAAK,GAAG,UAAU,CAAC;AACzD,SAAA;KACD;AACD;;AChED;;;;;;;;;;;;;;;;;;;AAmBG;AACH,MAAM,KAAK,CAAA;IAQV,WAAY,CAAA,MAAe,EAAE,QAAgB,EAAA;QAC5C,IAAI,CAAC,MAAM,GAAG,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;AAEpC,QAAA,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;KACzB;IACD,SAAS,GAAA;QACR,MAAM,mBAAmB,GAAG,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC;AACvD,QAAA,IAAI,CAAC,MAAM,GAAG,OAAO,CAAC,gBAAgB,CAAC,IAAI,CAAC,MAAM,EAAE,mBAAmB,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;AACtF,QAAA,IAAI,CAAC,QAAQ,IAAI,mBAAmB,CAAC;AACrC,QAAA,OAAO,IAAI,CAAC;KACZ;AAED,IAAA,OAAO,eAAe,CAAC,KAAc,EAAE,MAAe,EAAE,MAAa,EAAA;AACpE,QAAA,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,OAAO,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,GAAG,EAAE,KAAK,CAAC,QAAQ,CAAC,EAAE;AACzE,YAAA,MAAM,IAAI,KAAK,CAAC,4BAA4B,CAAC,CAAC;AAC9C,SAAA;;QAGD,MAAM,QAAQ,GAAG,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;AAE7C,QAAA,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;AACrB,YAAA,OAAO,IAAI,KAAK,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;AACnC,SAAA;QAED,OAAO,CAAC,KAAK,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC;AACrC,QAAA,MAAM,CAAC,QAAQ,GAAG,QAAQ,CAAC;AAC3B,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,WAAW,CAAC,YAAqB,EAAE,MAAa,EAAA;QACtD,MAAM,MAAM,GAAG,OAAO,CAAC,WAAW,CAAC,YAAY,EAAE,aAAa,CAAC,CAAC;AAChE,QAAA,MAAM,QAAQ,GAAG,YAAY,CAAC,CAAC,CAAC;;AAGhC,QAAA,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,OAAO,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,GAAG,EAAE,KAAK,CAAC,QAAQ,CAAC,EAAE;AACzE,YAAA,MAAM,IAAI,KAAK,CAAC,4BAA4B,CAAC,CAAC;AAC9C,SAAA;;AAGD,QAAA,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;AACrB,YAAA,OAAO,IAAI,KAAK,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;AACnC,SAAA;QACD,OAAO,CAAC,KAAK,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC;AACrC,QAAA,MAAM,CAAC,QAAQ,GAAG,QAAQ,CAAC;AAC3B,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,gBAAgB,CAAC,KAAY,EAAE,KAAc,EAAA;AACnD,QAAA,OAAO,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,EAAE,KAAK,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAC;KACzD;AAED,IAAA,OAAO,qBAAqB,CAAC,KAAY,EAAE,KAAc,EAAE,MAAe,EAAA;AACzE,QAAA,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;AACrB,YAAA,MAAM,GAAG,IAAI,OAAO,EAAE,CAAC;AACvB,SAAA;;QAGD,MAAM,aAAa,GAAG,KAAK,CAAC,gBAAgB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;AAC3D,QAAA,MAAM,YAAY,GAAG,OAAO,CAAC,gBAAgB,CAAC,KAAK,CAAC,MAAM,EAAE,aAAa,EAAE,gBAAgB,CAAC,CAAC;QAE7F,OAAO,OAAO,CAAC,QAAQ,CAAC,KAAK,EAAE,YAAY,EAAE,MAAM,CAAC,CAAC;KACrD;AAED,IAAA,OAAO,SAAS,CAAC,KAAY,EAAE,SAAkB,EAAE,MAAa,EAAA;AAC/D,QAAA,MAAM,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC;AAC5B,QAAA,MAAM,QAAQ,GAAG,KAAK,CAAC,QAAQ,CAAC;QAChC,MAAM,gBAAgB,GAAG,OAAO,CAAC,gBAAgB,CAAC,SAAS,EAAE,uBAAuB,CAAC,CAAC;QACtF,IAAI,iBAAiB,GAAG,OAAO,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,EAAE,QAAQ,EAAE,sBAAsB,CAAC,CAAC;QAC7G,iBAAiB,GAAG,OAAO,CAAC,gBAAgB,CAAC,gBAAgB,EAAE,iBAAiB,EAAE,iBAAiB,CAAC,CAAC;;QAGrG,MAAM,iBAAiB,GAAG,OAAO,CAAC,WAAW,CAAC,iBAAiB,EAAE,sBAAsB,CAAC,CAAC;AAEzF,QAAA,iBAAiB,GAAG,OAAO,CAAC,cAAc,CACzC,iBAAiB,EACjB,OAAO,CAAC,SAAS,CAAC,iBAAiB,CAAC,EACpC,iBAAiB,CACjB,CAAC;QAEF,OAAO,KAAK,CAAC,WAAW,CAAC,iBAAiB,EAAE,MAAM,CAAC,CAAC;KACpD;AAED,IAAA,OAAO,KAAK,CAAC,KAAY,EAAE,MAAa,EAAA;AACvC,QAAA,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;YACrB,OAAO,IAAI,KAAK,CAAC,KAAK,CAAC,MAAM,EAAE,KAAK,CAAC,QAAQ,CAAC,CAAC;AAC/C,SAAA;QAED,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC;AAC3C,QAAA,MAAM,CAAC,QAAQ,GAAG,KAAK,CAAC,QAAQ,CAAC;AAEjC,QAAA,OAAO,MAAM,CAAC;KACd;AAED,IAAA,OAAO,MAAM,CAAC,IAAW,EAAE,KAAY,EAAA;QACtC,OAAO,IAAI,CAAC,QAAQ,KAAK,KAAK,CAAC,QAAQ,IAAI,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC;KACrF;;AApGa,KAAA,CAAA,eAAe,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC,CAAC;AAEhE,KAAA,CAAA,eAAe,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC,CAAC;AAEhE,KAAA,CAAA,eAAe,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC,CAAC;AAkG/E,MAAM,aAAa,GAAG,IAAI,OAAO,EAAE,CAAC;AACpC,MAAM,gBAAgB,GAAG,IAAI,OAAO,EAAE,CAAC;AACvC,MAAM,uBAAuB,GAAG,IAAI,OAAO,EAAE,CAAC;AAC9C,MAAM,sBAAsB,GAAG,IAAI,OAAO,EAAE,CAAC;AAC7C,MAAM,sBAAsB,GAAG,IAAI,OAAO,EAAE;;AChI5C;;;;;;;AAOG;AACH,MAAM,aAAa,CAAA;AASlB,IAAA,WAAA,CAAY,MAAgB,EAAA;AAC3B,QAAA,IAAI,CAAC,MAAM,GAAG,YAAY,CAAC,MAAM,EAAE;AAClC,YAAA,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,EAAE,GAAG,CAAC;AAC9B,YAAA,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,EAAE,GAAG,CAAC;AAC9B,YAAA,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,EAAE,GAAG,CAAC;AAC9B,YAAA,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,EAAE,GAAG,CAAC;AAC9B,YAAA,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,EAAE,GAAG,CAAC;AAC9B,YAAA,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,EAAE,GAAG,CAAC;AAC9B,SAAA,CAAC,CAAC;KACH;AACD;;;;;;;AAOG;AACH,IAAA,OAAO,kBAAkB,CAAC,cAAc,EAAE,MAAM,EAAA;AAC/C,QAAA,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,EAAE;AAC7B,YAAA,MAAM,IAAI,KAAK,CAAC,6BAA6B,CAAC,CAAC;AAC/C,SAAA;AACD,QAAA,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;AACrB,YAAA,MAAM,GAAG,IAAI,aAAa,EAAE,CAAC;AAC7B,SAAA;AAED,QAAA,MAAM,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC;AAC5B,QAAA,MAAM,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC;AAC7B,QAAA,MAAM,CAAC,MAAM,GAAG,CAAC,GAAG,MAAM,CAAC;AAE3B,QAAA,MAAM,MAAM,GAAG,cAAc,CAAC,MAAM,CAAC;AACrC,QAAA,MAAM,MAAM,GAAG,cAAc,CAAC,MAAM,CAAC;QAErC,IAAI,UAAU,GAAG,CAAC,CAAC;QAEnB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,EAAE,EAAE,CAAC,EAAE;AAChC,YAAA,MAAM,UAAU,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;AAE5B,YAAA,IAAI,MAAM,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;YAChC,IAAI,MAAM,GAAG,MAAM,CAAC,UAAU,GAAG,CAAC,CAAC,CAAC;AAEpC,YAAA,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;gBACrB,MAAM,GAAG,MAAM,CAAC,UAAU,CAAC,GAAG,IAAI,OAAO,EAAE,CAAC;AAC5C,aAAA;AACD,YAAA,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;gBACrB,MAAM,GAAG,MAAM,CAAC,UAAU,GAAG,CAAC,CAAC,GAAG,IAAI,OAAO,EAAE,CAAC;AAChD,aAAA;YAED,OAAO,CAAC,gBAAgB,CAAC,UAAU,EAAE,CAAC,MAAM,EAAE,kBAAkB,CAAC,CAAC;YAClE,OAAO,CAAC,GAAG,CAAC,MAAM,EAAE,kBAAkB,EAAE,kBAAkB,CAAC,CAAC;AAE5D,YAAA,MAAM,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC;AACxB,YAAA,MAAM,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC;AACxB,YAAA,MAAM,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC;AACxB,YAAA,MAAM,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,GAAG,CAAC,UAAU,EAAE,kBAAkB,CAAC,CAAC;YAExD,OAAO,CAAC,gBAAgB,CAAC,UAAU,EAAE,MAAM,EAAE,kBAAkB,CAAC,CAAC;YACjE,OAAO,CAAC,GAAG,CAAC,MAAM,EAAE,kBAAkB,EAAE,kBAAkB,CAAC,CAAC;AAE5D,YAAA,MAAM,CAAC,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC;AACzB,YAAA,MAAM,CAAC,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC;AACzB,YAAA,MAAM,CAAC,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC;AACzB,YAAA,MAAM,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,MAAM,CAAC,UAAU,EAAE,kBAAkB,CAAC,EAAE,kBAAkB,CAAC,CAAC;YAE5F,UAAU,IAAI,CAAC,CAAC;AAChB,SAAA;AAED,QAAA,OAAO,MAAM,CAAC;KACd;AACD;;;;;AAKG;AACH,IAAA,iBAAiB,CAAC,cAAc,EAAA;AAC/B,QAAA,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,EAAE;AAC7B,YAAA,MAAM,IAAI,KAAK,CAAC,6BAA6B,CAAC,CAAC;AAC/C,SAAA;AACD,QAAA,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;QAC3B,IAAI,YAAY,GAAG,KAAK,CAAC;AACzB,QAAA,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,GAAG,GAAG,EAAE,EAAE,CAAC,EAAE;YAClD,MAAM,MAAM,GAAG,cAAc,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;AACxD,YAAA,IAAI,MAAM,KAAK,SAAS,CAAC,OAAO,EAAE;gBACjC,OAAO,SAAS,CAAC,OAAO,CAAC;AACzB,aAAA;AAAM,iBAAA,IAAI,MAAM,KAAK,SAAS,CAAC,YAAY,EAAE;gBAC7C,YAAY,GAAG,IAAI,CAAC;AACpB,aAAA;AACD,SAAA;AAED,QAAA,OAAO,YAAY,GAAG,SAAS,CAAC,YAAY,GAAG,SAAS,CAAC,MAAM,CAAC;KAChE;;AAjGa,aAAY,CAAA,YAAA,GAAG,UAAU,CAAC;AAE1B,aAAW,CAAA,WAAA,GAAG,UAAU,CAAC;AAEzB,aAAkB,CAAA,kBAAA,GAAG,UAAU,CAAC;AAgG/C,MAAM,KAAK,GAAG,CAAC,IAAI,OAAO,EAAE,EAAE,IAAI,OAAO,EAAE,EAAE,IAAI,OAAO,EAAE,CAAC,CAAC;AAC5D,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;AACxC,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;AACxC,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;AAExC,MAAM,kBAAkB,GAAG,IAAI,OAAO,EAAE,CAAC;AACzC,MAAM,kBAAkB,GAAG,IAAI,OAAO,EAAE,CAAC;AACnB,IAAI,OAAO,GAAG;AACf,IAAI,KAAK,CAAC,IAAI,OAAO,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,GAAG;;ACrHzC,MAAA,MAAO,SAAQ,YAAY,CAAA;AAS/C,IAAA,WAAA,GAAA;AACC,QAAA,KAAK,EAAE,CAAC;AACR,QAAA,IAAI,CAAC,WAAW,GAAG,SAAS,CAAC;AAC7B,QAAA,IAAI,CAAC,IAAI,GAAG,gBAAgB,CAAC,MAAM,CAAC;AACpC,QAAA,IAAI,CAAC,aAAa,GAAG,IAAI,aAAa,EAAE,CAAC;AACzC,QAAA,IAAI,CAAC,WAAW,GAAG,IAAI,OAAO,EAAE,CAAC;AACjC,QAAA,IAAI,CAAC,SAAS,GAAG,IAAI,OAAO,EAAE,CAAC;AAC/B,QAAA,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC;QAC/B,IAAI,CAAC,gBAAgB,EAAE,CAAC;KACxB;AACD,IAAA,IAAI,UAAU,GAAA;QACb,IAAI,CAAC,YAAY,EAAE,CAAC;QACpB,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;QACpD,OAAO,IAAI,CAAC,WAAW,CAAC;KACxB;AACD,IAAA,IAAI,gBAAgB,GAAA;QACnB,IAAI,CAAC,sBAAsB,EAAE,CAAC;QAC9B,OAAO,IAAI,CAAC,iBAAiB,CAAC;KAC9B;AAED,IAAA,IAAI,QAAQ,GAAA;AACX,QAAA,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,gBAAgB,EAAE,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;QACzE,OAAO,IAAI,CAAC,SAAS,CAAC;KACtB;AAED,IAAA,IAAI,iBAAiB,GAAA;QACpB,IAAI,CAAC,YAAY,EAAE,CAAC;QACpB,OAAO,IAAI,CAAC,WAAW,CAAC;KACxB;AACM,IAAA,sBAAsB,MAAK;AAClC;;AAEG;IACH,gBAAgB,GAAA;AACf,QAAA,MAAM,eAAe,GAAG,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,IAAI,OAAO,EAAE,CAAC,CAAC;AAC7D,QAAA,MAAM,QAAQ,GAAG,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,gBAAgB,EAAE,eAAe,EAAE,IAAI,OAAO,EAAE,CAAC,CAAC;AACzF,QAAA,MAAM,MAAM,GAAG,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC;QACzC,MAAM,EAAE,GAAG,QAAQ,CAAC;QACpB,MAAM,GAAG,GAAG,EAAE,CAAC,CAAC,CAAC,EAChB,GAAG,GAAG,EAAE,CAAC,CAAC,CAAC,EACX,GAAG,GAAG,EAAE,CAAC,CAAC,CAAC,EACX,GAAG,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC;QACb,MAAM,GAAG,GAAG,EAAE,CAAC,CAAC,CAAC,EAChB,GAAG,GAAG,EAAE,CAAC,CAAC,CAAC,EACX,GAAG,GAAG,EAAE,CAAC,CAAC,CAAC,EACX,GAAG,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC;QACb,MAAM,GAAG,GAAG,EAAE,CAAC,CAAC,CAAC,EAChB,GAAG,GAAG,EAAE,CAAC,CAAC,CAAC,EACX,IAAI,GAAG,EAAE,CAAC,EAAE,CAAC,EACb,IAAI,GAAG,EAAE,CAAC,EAAE,CAAC,CAAC;QACf,MAAM,IAAI,GAAG,EAAE,CAAC,EAAE,CAAC,EAClB,IAAI,GAAG,EAAE,CAAC,EAAE,CAAC,EACb,IAAI,GAAG,EAAE,CAAC,EAAE,CAAC,EACb,IAAI,GAAG,EAAE,CAAC,EAAE,CAAC,CAAC;QACf,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,KAAK,CAAC,IAAI,OAAO,CAAC,GAAG,GAAG,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,IAAI,GAAG,GAAG,CAAC,EAAE,IAAI,GAAG,IAAI,CAAC,CAAC;AAClF,QAAA,MAAM,CAAC,CAAC,CAAC,CAAC,SAAS,EAAE,CAAC;QACtB,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,KAAK,CAAC,IAAI,OAAO,CAAC,GAAG,GAAG,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,IAAI,GAAG,GAAG,CAAC,EAAE,IAAI,GAAG,IAAI,CAAC,CAAC;AAClF,QAAA,MAAM,CAAC,CAAC,CAAC,CAAC,SAAS,EAAE,CAAC;QAEtB,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,KAAK,CAAC,IAAI,OAAO,CAAC,GAAG,GAAG,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,IAAI,GAAG,GAAG,CAAC,EAAE,IAAI,GAAG,IAAI,CAAC,CAAC;AAClF,QAAA,MAAM,CAAC,CAAC,CAAC,CAAC,SAAS,EAAE,CAAC;QAEtB,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,KAAK,CAAC,IAAI,OAAO,CAAC,GAAG,GAAG,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,IAAI,GAAG,GAAG,CAAC,EAAE,IAAI,GAAG,IAAI,CAAC,CAAC;AAClF,QAAA,MAAM,CAAC,CAAC,CAAC,CAAC,SAAS,EAAE,CAAC;QAEtB,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,KAAK,CAAC,IAAI,OAAO,CAAC,GAAG,GAAG,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,IAAI,GAAG,IAAI,CAAC,EAAE,IAAI,GAAG,IAAI,CAAC,CAAC;AACnF,QAAA,MAAM,CAAC,CAAC,CAAC,CAAC,SAAS,EAAE,CAAC;QAEtB,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,KAAK,CAAC,IAAI,OAAO,CAAC,GAAG,GAAG,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,IAAI,GAAG,IAAI,CAAC,EAAE,IAAI,GAAG,IAAI,CAAC,CAAC;AACnF,QAAA,MAAM,CAAC,CAAC,CAAC,CAAC,SAAS,EAAE,CAAC;QAEtB,OAAO,IAAI,CAAC,aAAa,CAAC;KAC1B;IAED,gBAAgB,GAAA;AACf,QAAA,IAAI,CAAC,UAAU,GAAG,IAAI,UAAU,CAAC,QAAQ,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QACpD,MAAM,aAAa,GAAG,IAAI,aAAa,CAAC,EAAE,KAAK,EAAE,QAAQ,EAAE,CAAC,CAAC;AAC7D,QAAA,aAAa,CAAC,UAAU,CACvB,kBAAkB,EAClB,MAAK;YACJ,OAAO,IAAI,CAAC,gBAAgB,CAAC;AAC9B,SAAC,EACD,WAAW,CAAC,IAAI,CAChB,CAAC;AACF,QAAA,aAAa,CAAC,UAAU,CACvB,YAAY,EACZ,MAAK;YACJ,OAAO,IAAI,CAAC,UAAU,CAAC;AACxB,SAAC,EACD,WAAW,CAAC,IAAI,CAChB,CAAC;AACF,QAAA,aAAa,CAAC,UAAU,CACvB,mBAAmB,EACnB,MAAK;YACJ,OAAO,IAAI,CAAC,iBAAiB,CAAC;AAC/B,SAAC,EACD,WAAW,CAAC,IAAI,CAChB,CAAC;AACF,QAAA,aAAa,CAAC,UAAU,CACvB,UAAU,EACV,MAAK;YACJ,OAAO,IAAI,CAAC,QAAQ,CAAC;AACtB,SAAC,EACD,WAAW,CAAC,SAAS,CACrB,CAAC;QACF,IAAI,CAAC,UAAU,CAAC,gBAAgB,CAAC,QAAQ,EAAE,aAAa,CAAC,CAAC;KAC1D;AACD;;ACzHoB,MAAA,iBAAkB,SAAQ,MAAM,CAAA;AAapD,IAAA,WAAA,CAAY,GAAG,GAAG,EAAE,EAAE,MAAM,GAAG,CAAC,EAAE,IAAI,GAAG,GAAG,EAAE,GAAG,GAAG,IAAI,EAAA;AACvD,QAAA,KAAK,EAAE,CAAC;AACR,QAAA,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC;AACtB,QAAA,IAAI,CAAC,GAAG,GAAG,GAAG,CAAC;AACf,QAAA,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;AACjB,QAAA,IAAI,CAAC,GAAG,GAAG,GAAG,CAAC;AACf,QAAA,IAAI,CAAC,OAAO,GAAG,CAAC,CAAC;AACjB,QAAA,IAAI,CAAC,OAAO,GAAG,CAAC,CAAC;AACjB,QAAA,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC;QAC/B,IAAI,CAAC,iBAAiB,EAAE,CAAC;AACzB,QAAA,IAAI,CAAC,aAAa,GAAG,IAAI,aAAa,EAAE,CAAC;AACzC,QAAA,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC;KAChC;AACD,IAAA,IAAI,MAAM,GAAA;QACT,OAAO,IAAI,CAAC,OAAO,CAAC;KACpB;IAED,IAAI,MAAM,CAAC,CAAS,EAAA;AACnB,QAAA,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC;AAC/B,QAAA,IAAI,CAAC,OAAO,GAAG,CAAC,CAAC;KACjB;AACD,IAAA,IAAI,GAAG,GAAA;QACN,OAAO,IAAI,CAAC,IAAI,CAAC;KACjB;IAED,IAAI,GAAG,CAAC,CAAS,EAAA;AAChB,QAAA,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC;AAC/B,QAAA,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC;KACd;IACO,iBAAiB,GAAA;QACxB,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,GAAG,KAAK,CAAC,kBAAkB,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC;QAC3E,IAAI,CAAC,MAAM,GAAG,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC;QAC3B,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;QACvC,IAAI,CAAC,IAAI,GAAG,CAAC,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC;KAC9B;IACM,sBAAsB,GAAA;QAC5B,IAAI,IAAI,CAAC,kBAAkB,EAAE;YAC5B,IAAI,CAAC,iBAAiB,EAAE,CAAC;AACzB,YAAA,IAAI,CAAC,iBAAiB,GAAG,OAAO,CAAC,eAAe,CAC/C,IAAI,CAAC,IAAI,EACT,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,KAAK,EACtB,IAAI,CAAC,GAAG,EACR,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,MAAM,EACtB,IAAI,CAAC,IAAI,EACT,IAAI,CAAC,GAAG,CACR,CAAC;AACF,YAAA,IAAI,CAAC,kBAAkB,GAAG,KAAK,CAAC;AAChC,SAAA;KACD;AACD;;AC3DoB,MAAA,sBAAuB,SAAQ,iBAAiB,CAAA;AAIpE,IAAA,WAAA,CAAY,GAAG,GAAG,EAAE,EAAE,MAAM,GAAG,CAAC,EAAE,IAAI,GAAG,GAAG,EAAE,GAAG,GAAG,IAAI,EAAA;QACvD,KAAK,CAAC,GAAG,EAAE,MAAM,EAAE,IAAI,EAAE,GAAG,CAAC,CAAC;AAC9B,QAAA,IAAI,CAAC,aAAa,GAAG,CAAC,IAAI,OAAO,EAAE,EAAE,IAAI,OAAO,EAAE,EAAE,IAAI,OAAO,EAAE,EAAE,IAAI,OAAO,EAAE,EAAE,IAAI,OAAO,EAAE,EAAE,IAAI,OAAO,EAAE,CAAC,CAAC;KAChH;;;;;;;;;;;;;;;;;;;;;;;;IA6BD,gBAAgB,GAAA;AACf,QAAA,IAAI,CAAC,UAAU,GAAG,IAAI,UAAU,CAAC,QAAQ,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;AAEpD,QAAA,MAAM,aAAa,GAAG,IAAI,aAAa,CAAC;AACvC,YAAA,KAAK,EAAE,wBAAwB;AAC/B,YAAA,IAAI,EAAE,mBAAmB;AACzB,YAAA,KAAK,EAAE,WAAW,CAAC,OAAO,GAAG,WAAW,CAAC,OAAO;AAChD,SAAA,CAAC,CAAC;AACH,QAAA,aAAa,CAAC,UAAU,CACvB,UAAU,EACV,MAAK;YACJ,OAAO,IAAI,CAAC,QAAQ,CAAC;AACtB,SAAC,EACD,WAAW,CAAC,IAAI,CAChB,CAAC;QAEF,IAAI,CAAC,UAAU,CAAC,gBAAgB,CAAC,wBAAwB,EAAE,aAAa,CAAC,CAAC;QAC1E,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,uBAAuB,EAAE,IAAI,CAAC,CAAC;KACzD;AAED,IAAA,2BAA2B,CAAC,KAAa,EAAA;AACxC,QAAA,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC,CAAC;KACxD;AACD;;MC5DY,UAAU,CAAA;IAWtB,WAAY,CAAA,aAAsB,EAAE,MAAc,EAAA;AACjD,QAAA,IAAI,CAAC,cAAc,GAAG,aAAa,CAAC;AACpC,QAAA,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC;AACtB,QAAA,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;AAC1B,QAAA,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;QAE1B,IAAI,CAAC,KAAK,EAAE,CAAC;KACb;AAED,IAAA,IAAI,MAAM,GAAA;QACT,OAAO,IAAI,CAAC,OAAO,CAAC;KACpB;AAED,IAAA,IAAI,aAAa,GAAA;QAChB,OAAO,IAAI,CAAC,cAAc,CAAC;KAC3B;AAED,IAAA,IAAI,SAAS,GAAA;QACZ,OAAO,IAAI,CAAC,UAAU,CAAC;KACvB;IAEM,mBAAmB,GAAA;QACzB,OAAO,IAAI,CAAC,UAAU,CAAC;KACvB;IAES,KAAK,GAAA;QACd,IAAI,CAAC,qBAAqB,EAAE,CAAC;KAC7B;IAES,qBAAqB,GAAA;QAC9B,IAAI,CAAC,uBAAuB,EAAE,CAAC;KAC/B;IAES,uBAAuB,GAAA;AAChC,QAAA,IAAI,CAAC,UAAU,GAAG,IAAI,OAAO,CAAC;AAC7B,YAAA,IAAI,EAAE;AACL,gBAAA,KAAK,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC;AAC5B,gBAAA,MAAM,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC;AAC7B,gBAAA,KAAK,EAAE,CAAC;AACR,aAAA;AACD,YAAA,SAAS,EAAE,IAAI;YACf,UAAU,EAAE,iBAAiB,CAAC,KAAK;YACnC,MAAM,EAAE,aAAa,CAAC,WAAW;YACjC,KAAK,EAAE,YAAY,CAAC,gBAAgB,GAAG,YAAY,CAAC,cAAc,GAAG,YAAY,CAAC,OAAO;AACzF,SAAA,CAAC,CAAC;KACH;IAEM,MAAM,CAAC,KAAY,EAAA,GAAI;AAC9B;;AC1DK,MAAO,gBAAiB,SAAQ,UAAU,CAAA;AAM/C,IAAA,IAAI,MAAM,GAAA;QACT,OAAO,IAAI,CAAC,OAAiC,CAAC;KAC9C;AAED,IAAA,WAAA,GAAA;AACC,QAAA,MAAM,MAAM,GAAG,IAAI,sBAAsB,CAAC,EAAE,EAAE,CAAC,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC;QAC3D,KAAK,CAAC,IAAI,OAAO,CAAC,IAAI,EAAE,IAAI,CAAC,EAAE,MAAM,CAAC,CAAC;QACvC,IAAI,CAAC,YAAY,GAAG,IAAI,OAAO,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;AAC1C,QAAA,IAAI,CAAC,oBAAoB,GAAG,CAAC,CAAC;AAC9B,QAAA,IAAI,CAAC,IAAI,GAAG,kBAAkB,CAAC;AAC/B,QAAA,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC;QAE/B,IAAI,CAAC,UAAU,GAAG;;AAEjB,YAAA,IAAI,OAAO,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC;;AAE/B,YAAA,IAAI,OAAO,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC;;AAE/B,YAAA,IAAI,OAAO,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC;;AAE/B,YAAA,IAAI,OAAO,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC;;AAE/B,YAAA,IAAI,OAAO,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC;;AAE/B,YAAA,IAAI,OAAO,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC;SAC/B,CAAC;QAEF,IAAI,CAAC,+BAA+B,GAAG;AACtC,YAAA,IAAI,OAAO,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;YACpB,IAAI,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;AACrB,YAAA,IAAI,OAAO,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;YACpB,IAAI,OAAO,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;AACrB,YAAA,IAAI,OAAO,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;YACpB,IAAI,OAAO,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;SACrB,CAAC;QAEF,IAAI,CAAC,oBAAoB,GAAG;AAC3B,YAAA,IAAI,OAAO,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;AACpB,YAAA,IAAI,OAAO,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;AACpB,YAAA,IAAI,OAAO,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;AACpB,YAAA,IAAI,OAAO,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;AACpB,YAAA,IAAI,OAAO,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;YACpB,IAAI,OAAO,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;SACrB,CAAC;KACF;AAEM,IAAA,MAAM,CAAC,KAAiB,EAAA;AAC9B,QAAA,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;KAC3B;AAED,IAAA,cAAc,CAAC,KAAiB,EAAA;AAC/B,QAAA,IAAI,IAAI,CAAC,MAAM,YAAY,sBAAsB,EAAE;YAClD,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;YAC1C,MAAM,MAAM,GAAG,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;AAC7C,YAAA,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,+BAA+B,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC,CAAC;AAC5E,YAAA,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC,CAAC;YAC1E,MAAM,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,GAAG,MAAM,CAAC;YAC3B,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;AAC5B,YAAA,IAAI,CAAC,MAAM,CAAC,YAAY,EAAE,CAAC;YAC3B,IAAI,CAAC,MAAM,CAAC,2BAA2B,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC;AACnE,YAAA,IAAI,IAAI,CAAC,oBAAoB,IAAI,CAAC;AAAE,gBAAA,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC;AACnE,SAAA;KACD;AACD;;ACvEK,MAAO,UAAW,SAAQ,KAAK,CAAA;AAMpC,IAAA,IAAI,MAAM,GAAA;QACT,OAAO,IAAI,CAAC,OAA2B,CAAC;KACxC;IAED,IAAI,MAAM,CAAC,KAAuB,EAAA;AACjC,QAAA,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;AACxB,QAAA,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;KACrB;AAED,IAAA,WAAA,CAAY,KAAc,EAAE,SAAiB,EAAE,QAAQ,GAAG,CAAC,EAAE,KAAK,GAAG,CAAC,EAAE,UAAU,GAAG,IAAI,EAAA;AACxF,QAAA,KAAK,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;AACxB,QAAA,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;AAC1B,QAAA,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;AACpB,QAAA,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;AAC1B,QAAA,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;AACvB,QAAA,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC,UAAU,CAAC;AACtC,QAAA,IAAI,UAAU;AAAE,YAAA,IAAI,CAAC,MAAM,GAAG,IAAI,gBAAgB,EAAE,CAAC;KACrD;IACD,IAAI,QAAQ,CAAC,KAAK,EAAA;AACjB,QAAA,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;AAC1B,QAAA,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;KACvB;AACD,IAAA,IAAI,QAAQ,GAAA;QACX,OAAO,IAAI,CAAC,SAAS,CAAC;KACtB;IACD,IAAI,KAAK,CAAC,KAAK,EAAA;AACd,QAAA,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;AACvB,QAAA,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;KACpB;AACD,IAAA,IAAI,KAAK,GAAA;QACR,OAAO,IAAI,CAAC,MAAM,CAAC;KACnB;AACD,CAAA;AACD;AACA;AACA;AACA;AACA;;AChCM,MAAO,UAAW,SAAQ,IAAI,CAAA;AAGnC,IAAA,WAAA,CAAY,OAAgB,EAAA;QAC3B,KAAK,CAAC,OAAO,CAAC,CAAC;AACf,QAAA,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;KACnB;IACD,MAAM,CAAC,UAAsB,EAAE,MAAe,EAAA;QAC7C,MAAM,EAAE,WAAW,EAAE,OAAO,EAAE,WAAW,EAAE,GAAG,UAAU,CAAC;AACzD,QAAA,MAAM,MAAM,GAAG,WAAW,CAAC,YAAY,EAAE,CAAC;AAC1C,QAAA,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC;YAAE,OAAO;AAEhC,QAAA,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;AACvC,YAAA,MAAM,KAAK,GAAuB,MAAM,CAAC,CAAC,CAAC,CAAC;AAC5C,YAAA,MAAM,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC;AAC5B,YAAA,IAAI,CAAC,MAAM;gBAAE,SAAS;;;AAGtB,YAAA,IAAI,MAAM,YAAY,gBAAgB,IAAI,KAAK,YAAY,UAAU,EAAE;AACtE,gBAAA,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;;AAEjD,oBAAA,QAAQ,CAAC;AACR,wBAAA,KAAK,CAAC;4BACL,IAAI,CAAC,YAAY,CAAC,eAAe,CAAC,EAAE,GAAG,OAAO,CAAC;4BAC/C,MAAM;AAEP,wBAAA;4BACC,IAAI,CAAC,YAAY,CAAC,eAAe,CAAC,EAAE,GAAG,MAAM,CAAC;4BAC9C,MAAM;AACP,qBAAA;AACD,oBAAA,IAAI,CAAC,YAAY,CAAC,EAAE,MAAM,EAAE,CAAC,CAAC;oBAE9B,MAAM,QAAQ,GAAG,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;AACrC,oBAAA,MAAM,YAAY,GAAG,MAAM,CAAC,YAAY,CAAC;AACzC,oBAAA,MAAM,CAAC,oBAAoB,GAAG,CAAC,CAAC;AAChC,oBAAA,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;;oBAErB,OAAO,CAAC,WAAW,CAClB,QAAQ,CAAC,CAAC,GAAG,YAAY,CAAC,CAAC,EAC3B,QAAQ,CAAC,CAAC,GAAG,YAAY,CAAC,CAAC,EAC3B,YAAY,CAAC,CAAC,EACd,YAAY,CAAC,CAAC,CACd,CAAC;oBACF,OAAO,CAAC,cAAc,CACrB,QAAQ,CAAC,CAAC,GAAG,YAAY,CAAC,CAAC,EAC3B,QAAQ,CAAC,CAAC,GAAG,YAAY,CAAC,CAAC,EAC3B,YAAY,CAAC,CAAC,EACd,YAAY,CAAC,CAAC,CACd,CAAC;oBACF,IAAI,CAAC,SAAS,CAAC,WAAW,EAAE,MAAM,EAAE,WAAW,CAAC,CAAC;oBACjD,KAAK,CAAC,WAAW,EAAE,CAAC;AACpB,iBAAA;AACD,aAAA;AAAM,iBAAA;gBACN,IAAI,CAAC,YAAY,CAAC,eAAe,CAAC,EAAE,GAAG,OAAO,CAAC;AAC/C,gBAAA,IAAI,CAAC,YAAY,CAAC,EAAE,MAAM,EAAE,CAAC,CAAC;AAC9B,gBAAA,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;AACrB,gBAAA,OAAO,CAAC,WAAW,CAAC,CAAC,EAAE,CAAC,EAAE,MAAM,CAAC,aAAa,CAAC,CAAC,EAAE,MAAM,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC;AAC1E,gBAAA,OAAO,CAAC,cAAc,CAAC,CAAC,EAAE,CAAC,EAAE,MAAM,CAAC,aAAa,CAAC,CAAC,EAAE,MAAM,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC;gBAC7E,IAAI,CAAC,SAAS,CAAC,WAAW,EAAE,MAAM,EAAE,WAAW,CAAC,CAAC;gBACjD,KAAK,CAAC,WAAW,EAAE,CAAC;AACpB,aAAA;AACD,SAAA;;QAED,WAAW,CAAC,iBAAiB,EAAE,CAAC;QAChC,OAAO,CAAC,yBAAyB,EAAE,CAAC;KACpC;AAED,IAAA,SAAS,CAAC,WAAwB,EAAE,MAAkB,EAAE,WAAwB,EAAA;QAC/E,WAAW,CAAC,IAAI,EAAE,CAAC;;QAEnB,WAAW,CAAC,iBAAiB,CAC5B,MAAM,CAAC,MAAM,EACb,IAAI,CAAC,OAAO,EACZ,IAAI,CAAC,iBAAiB,EACtB,IAAI,CAAC,cAAc,EACnB,cAAc,CAAC,MAAM,EACrB,WAAW,CACX,CAAC;QACF,WAAW,CAAC,YAAY,CACvB,MAAM,CAAC,MAAM,EACb,IAAI,CAAC,OAAO,EACZ,IAAI,CAAC,iBAAiB,EACtB,IAAI,CAAC,cAAc,EACnB,cAAc,CAAC,MAAM,EACrB,WAAW,CACX,CAAC;KACF;;;;AAKD,IAAA,YAAY,CAAC,OAA+B,EAAA;AAC3C,QAAA,MAAM,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC;AAC3B,QAAA,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC;QAC7B,KAAK,CAAC,YAAY,EAAE,CAAC;KACrB;IACM,OAAO,CAAC,KAAa,EAAE,MAAc,EAAA;QAC3C,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,KAAK,EAAE,MAAM,EAAE,CAAC,CAAC,CAAC;KAC5C;AACO,IAAA,eAAe,CAAC,MAAkB,EAAA;QACzC,IAAI,CAAC,YAAY,CAAC,eAAe,CAAC,OAAO,GAAG,MAAM,CAAC,mBAAmB,EAAE,CAAC;KACzE;AAEO,IAAA,IAAI,CAAC,OAAgB,EAAA;AAC5B,QAAA,IAAI,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAC;QACjC,IAAI,CAAC,oBAAoB,EAAE,CAAC;KAC5B;AACO,IAAA,kBAAkB,CAAC,OAAgB,EAAA;AAC1C,QAAA,MAAM,eAAe,GAAG,IAAI,UAAU,CAAC,GAAG,EAAE,EAAE,OAAO,EAAE,SAAS,EAAE,CAAC,CAAC;AACpE,QAAA,IAAI,CAAC,YAAY,GAAG,IAAI,YAAY,CAAC,QAAQ,EAAE,EAAE,EAAE,eAAe,CAAC,CAAC;KACpE;IAEO,oBAAoB,GAAA;AAC3B,QAAA,MAAM,uBAAuB,GAAG,CAAC,OAAO,GAAG,EAAE,KAAI;AAChD,YAAA,MAAM,YAAY,GAAG,MAAM,CAAC,MAAM,CACjC;AACC,gBAAA,WAAW,EAAE,CAAC;AACd,gBAAA,aAAa,EAAE,CAAC;AAChB,gBAAA,gBAAgB,EAAE,CAAC;aACnB,EACD,OAAO,CACP,CAAC;YACF,OAAO,WAAW,CAAC,WAAW,EAAE,YAAY,CAAC,CAAC,IAAI,CAAC;AACpD,SAAC,CAAC;AAEF,QAAA,IAAI,CAAC,cAAc,GAAG,IAAI,cAAc,CAAC;AACxC,YAAA,IAAI,EAAE,gBAAgB;AACtB,YAAA,QAAQ,EAAE;gBACT,WAAW,EAAE,EAAE,IAAI,EAAE,aAAa,EAAE,KAAK,EAAE,IAAI,EAAE;AACjD,aAAA;AACD,YAAA,IAAI,EAAE,uBAAuB;AAC7B,YAAA,IAAI,EAAE,SAAS;YACf,KAAK,EAAE,KAAK;AACZ,SAAA,CAAC,CAAC;KACH;AACD;;AC/Ia,MAAO,iBAAiB,CAAA;AAGrC,IAAA,WAAA,CAAmB,OAAgB,EAAA;QAAhB,IAAO,CAAA,OAAA,GAAP,OAAO,CAAS;QAClC,IAAI,CAAC,SAAS,GAAG,IAAI,SAAS,CAAC,OAAO,CAAC,CAAC;QACxC,IAAI,CAAC,UAAU,GAAG,IAAI,UAAU,CAAC,OAAO,CAAC,CAAC;KAC1C;IACD,gBAAgB,GAAA;QACf,OAAO,IAAI,CAAC,SAAS,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC;;KAEzC;IACD,MAAM,CAAC,UAAsB,EAAE,MAAe,EAAA;QAC7C,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,UAAU,EAAE,MAAM,CAAC,CAAC;AAE3C,QAAA,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,UAAU,CAAC,CAAC;QACxC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,UAAU,EAAE,MAAM,CAAC,CAAC;AAC1C,QAAA,IAAI,CAAC,SAAS,CAAC,WAAW,EAAE,CAAC;KAC7B;IACD,OAAO,CAAC,KAAa,EAAE,MAAc,EAAA;QACpC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;QACtC,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;KACvC;IACD,OAAO,GAAA;AACN,QAAA,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;KAC3B;AACD;;ACfK,MAAO,KAAM,SAAQ,eAAe,CAAA;AAgBzC,IAAA,WAAA,CAAY,OAAO,EAAA;AAClB,QAAA,KAAK,EAAE,CAAC;AACR,QAAA,IAAI,CAAC,SAAS;YACb,OAAO,CAAC,SAAS,YAAY,cAAc;kBACxC,OAAO,CAAC,SAAS;kBACjB,QAAQ,CAAC,cAAc,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;AAC/C,QAAA,IAAI,CAAC,UAAU,GAAG,IAAI,UAAU,EAAE,CAAC;AACnC,QAAA,IAAI,CAAC,oBAAoB,GAAG,IAAI,oBAAoB,EAAE,CAAC;AACvD,QAAA,IAAI,CAAC,OAAO,GAAG,IAAI,OAAO,CAAC;AAC1B,YAAA,MAAM,EAAE,IAAI;YACZ,SAAS,EAAE,IAAI,CAAC,SAAS;AACzB,YAAA,UAAU,EAAE,CAAC;AACb,SAAA,CAAC,CAAC;QACH,IAAI,CAAC,cAAc,GAAG,OAAO,CAAC,cAAc,IAAI,EAAE,CAAC;QACnD,IAAI,CAAC,gBAAgB,GAAG,OAAO,CAAC,gBAAgB,IAAI,EAAE,CAAC;AACvD,QAAA,IAAI,CAAC,6BAA6B,GAAG,OAAO,CAAC,6BAA6B,CAAC;AAC3E,QAAA,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;AACnB,QAAA,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;AACpB,QAAA,IAAI,CAAC,WAAW,GAAG,IAAI,WAAW,CAAC,EAAE,UAAU,EAAE,IAAI,EAAE,CAAC,CAAC;AACzD,QAAA,IAAI,CAAC,UAAU,GAAG,OAAO,CAAC,UAAU,CAAC;KACrC;AACO,IAAA,MAAM,IAAI,GAAA;AACjB,QAAA,MAAM,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,IAAI,CAAC,gBAAgB,EAAE,IAAI,CAAC,6BAA6B,CAAC,CAAC;QACxG,IAAI,CAAC,qBAAqB,GAAG,IAAI,iBAAiB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACjE,IAAI,CAAC,UAAU,GAAG,IAAI,UAAU,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,WAAW,EAAE,UAAU,CAAC,2BAA2B,CAAC,IAAI,CAAC,CAAC,CAAC;QAC/G,IAAI,CAAC,QAAQ,GAAG,IAAI,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,KAAK,EAAE,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC;AAC9G,QAAA,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;KAClB;AACD,IAAA,GAAG,CAAC,QAAkB,EAAA;QACrB,IACC,CAAC,gBAAgB,CAAC,IAAI,EAAE,gBAAgB,CAAC,MAAM,EAAE,gBAAgB,CAAC,IAAI,EAAE,gBAAgB,CAAC,KAAK,CAAC,CAAC,QAAQ,CACvG,QAAQ,CAAC,IAAI,CACb,EACA;AACD,YAAA,IAAI,CAAC,UAAU,CAAC,GAAG,CAAO,QAAQ,CAAC,CAAC;AACpC,SAAA;AAAM,aAAA,IAAI,QAAQ,CAAC,IAAI,IAAI,gBAAgB,CAAC,KAAK,EAAE;AACnD,YAAA,IAAI,CAAC,WAAW,CAAC,GAAG,CAAQ,QAAQ,CAAC,CAAC;AACtC,SAAA;AAAM,aAAA,IAAI,QAAQ,CAAC,IAAI,IAAI,gBAAgB,CAAC,UAAU,EAAE;AACxD,YAAA,IAAI,CAAC,oBAAoB,CAAC,GAAG,CAAa,QAAQ,CAAC,CAAC;AACpD,SAAA;KACD;AACD,IAAA,MAAM,CAAC,QAAkB,EAAA;QACxB,IAAI,CAAC,gBAAgB,CAAC,IAAI,EAAE,gBAAgB,CAAC,MAAM,EAAE,gBAAgB,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE;AACpG,YAAA,IAAI,CAAC,UAAU,CAAC,MAAM,CAAO,QAAQ,CAAC,CAAC;AACvC,SAAA;AAAM,aAAA,IAAI,QAAQ,CAAC,IAAI,IAAI,gBAAgB,CAAC,KAAK,EAAE;AACnD,YAAA,IAAI,CAAC,WAAW,CAAC,MAAM,CAAQ,QAAQ,CAAC,CAAC;AACzC,SAAA;AAAM,aAAA,IAAI,QAAQ,CAAC,IAAI,IAAI,gBAAgB,CAAC,UAAU,EAAE;AACxD,YAAA,IAAI,CAAC,oBAAoB,CAAC,MAAM,CAAa,QAAQ,CAAC,CAAC;AACvD,SAAA;KACD;AACD,IAAA,SAAS,CAAC,MAAM,EAAA;AACf,QAAA,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;KACrB;IACD,MAAM,CAAC,KAAa,EAAE,MAAc,EAAA;QACnC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;QACnC,IAAI,EAAE,qBAAqB,EAAE,OAAO,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;QACpD,IAAI,EAAE,oBAAoB,EAAE,OAAO,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;KACnD;AACD,IAAA,MAAM,MAAM,CAAC,IAAW,EAAE,MAAe,EAAA;AACxC,QAAA,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;AACjB,YAAA,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;AACnB,YAAA,MAAM,IAAI,CAAC,IAAI,EAAE,CAAC;AAClB,YAAA,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;YAC1B,IAAI,CAAC,WAAW,EAAE,CAAC;AACnB,SAAA;AAAM,aAAA;AACN,YAAA,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;YAC1B,IAAI,CAAC,WAAW,EAAE,CAAC;AACnB,SAAA;KACD;IAED,WAAW,GAAA;;KAEV;AAEM,IAAA,WAAW,CAAC,CAAS,EAAE,CAAS,EAAE,KAAa,EAAE,MAAc,EAAA;QACrE,IAAI,CAAC,IAAI,CAAC,KAAK;AAAE,YAAA,OAAO,KAAK,CAAC;AAC9B,QAAA,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,EAAE,CAAC,EAAE,KAAK,EAAE,MAAM,CAAC,CAAC;AAC9C,QAAA,OAAO,IAAI,CAAC;KACZ;AACM,IAAA,cAAc,CAAC,CAAS,EAAE,CAAS,EAAE,KAAa,EAAE,MAAc,EAAA;QACxE,IAAI,CAAC,IAAI,CAAC,KAAK;AAAE,YAAA,OAAO,KAAK,CAAC;AAC9B,QAAA,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC,EAAE,CAAC,EAAE,KAAK,EAAE,MAAM,CAAC,CAAC;AACjD,QAAA,OAAO,IAAI,CAAC;KACZ;IACO,MAAM,CAAC,IAAW,EAAE,MAAe,EAAA;QAC1C,IAAI,CAAC,IAAI,CAAC,KAAK;YAAE,OAAO;;QAExB,YAAY,CAAC,gBAAgB,EAAE,CAAC;;AAEhC,QAAA,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,EAAE,UAAU,CAAC,2BAA2B,CAAC,IAAI,CAAC,CAAC,CAAC;;AAE5F,QAAA,CAAC,IAAI,IAAI,IAAI,CAAC,UAAU,EAAE,MAAM,CAAC,IAAI,CAAC,UAAU,EAAE,MAAM,IAAI,IAAI,CAAC,MAAM,CAAC,CAAC;;AAEzE,QAAA,IAAI,CAAC,qBAAqB,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,EAAE,MAAM,IAAI,IAAI,CAAC,MAAM,CAAC,CAAC;;AAE1E,QAAA,IAAI,CAAC,oBAAoB,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,qBAAqB,CAAC,gBAAgB,EAAE,CAAC,CAAC;KAC9F;AACD;;ACxHa,MAAO,UAAU,CAAA;AAuB9B,IAAA,WAAA,CAAY,KAAa,EAAE,MAAc,EAAE,EAAU,EAAA;AACpD,QAAA,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;AACnB,QAAA,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,gBAAgB,EAAE,CAAC;AACxB,QAAA,IAAI,CAAC,EAAE,GAAG,EAAE,CAAC;AACb,QAAA,IAAI,CAAC,QAAQ,GAAG,CAAC,CAAC;AAClB,QAAA,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;AACzB,QAAA,IAAI,CAAC,IAAI,GAAG,gBAAgB,CAAC,UAAU,CAAC;KACxC;IACD,MAAM,CAAC,OAAgB,EAAE,YAAqB,EAAA;AAC7C,QAAA,OAAO,IAAI,CAAC;KACZ;IACD,OAAO,CAAC,KAAa,EAAE,MAAc,EAAA;;KAEpC;IACD,OAAO,GAAA;AACN,QAAA,IAAI,EAAE,mBAAmB,EAAE,OAAO,EAAE,CAAC;KACrC;AACS,IAAA,UAAU,CAAC,OAAgB,EAAA;QACpC,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,KAAK,GAAG,IAAI,CAAC;AAC1C,QAAA,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC;QACtC,MAAM,UAAU,GAAG,IAAI,CAAC,cAAc,CAAC,cAAc,EAAE,CAAC;AACxD,QAAA,MAAM,wBAAwB,GAAG,IAAI,CAAC,mBAAmB,CAAC,eAAe,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;AAC1F,QAAA,UAAU,CAAC,MAAM,CAAC,EAAE,MAAM,EAAE,OAAO,CAAC,MAAM,EAAE,WAAW,EAAE,wBAAwB,EAAE,CAAC,CAAC;AACrF,QAAA,IAAI,CAAC,mBAAmB,CAAC,aAAa,EAAE,CAAC;KACzC;IACO,gBAAgB,GAAA;AACvB,QAAA,MAAM,QAAQ,GAAG,IAAI,QAAQ,CAAC,EAAE,CAAC,CAAC;AAClC,QAAA,QAAQ,CAAC,YAAY,CACpB,IAAI,gBAAgB,CAAC,UAAU,EAAE,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,GAAG,EAAE,CAAC,GAAG,EAAE,GAAG,EAAE,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CACvG,CAAC;AACF,QAAA,QAAQ,CAAC,KAAK,GAAG,CAAC,CAAC;;AAEnB,QAAA,MAAM,SAAS,GAAG,IAAI,SAAS,EAAE,CAAC;AAClC,QAAA,MAAM,MAAM,GAAG,IAAI,MAAM,EAAE,CAAC;;AAE5B,QAAA,MAAM,WAAW,GAAG,IAAI,WAAW,EAAE,CAAC;AACtC,QAAA,WAAW,CAAC,SAAS,GAAG,SAAS,CAAC;AAClC,QAAA,WAAW,CAAC,OAAO,GAAG,CAAC,MAAM,CAAC,CAAC;AAC/B,QAAA,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;QAC/B,IAAI,CAAC,cAAc,GAAG,IAAI,IAAI,CAAC,QAAQ,CAAC,CAAC;AAEzC,QAAA,IAAI,CAAC,cAAc,GAAG,IAAI,OAAO,EAAE,CAAC;KACpC;AACD;;ACjEoB,MAAA,eAAgB,SAAQ,UAAU,CAAA;AAmBtD,IAAA,WAAA,CAAY,OAA6B,EAAA;QACxC,KAAK,CAAC,OAAO,CAAC,KAAK,EAAE,OAAO,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;AAC9C,QAAA,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC,QAAQ,CAAC;AACjC,QAAA,IAAI,CAAC,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;AAC7B,QAAA,IAAI,CAAC,SAAS,GAAG,OAAO,CAAC,SAAS,CAAC;QACnC,IAAI,CAAC,IAAI,EAAE,CAAC;KACZ;IACD,OAAO,GAAA;AACN,QAAA,IAAI,CAAC,kBAAkB,CAAC,OAAO,EAAE,CAAC;KAClC;IACD,MAAM,CAAC,OAAgB,EAAE,YAAqB,EAAA;;AAE7C,QAAA,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,kBAAkB,CAAC;QACnD,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,KAAK,GAAG,YAAY,CAAC;QACpD,IAAI,CAAC,cAAc,CAAC,QAAQ,GAAG,IAAI,CAAC,sBAAsB,CAAC;AAC3D,QAAA,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;;AAEzB,QAAA,IAAI,iBAAiB,GAAG,IAAI,CAAC,kBAAkB,CAAC;AAChD,QAAA,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,KAAK,EAAE,CAAC,EAAE,EAAE;YACpC,IAAI,CAAC,cAAc,CAAC,QAAQ,GAAG,IAAI,CAAC,sBAAsB,CAAC,CAAC,CAAC,CAAC;AAE9D,YAAA,IAAI,CAAC,sBAAsB,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,KAAK,GAAG,iBAAiB,CAAC,eAAe,EAAE,CAAC;AAC7F,YAAA,IAAI,CAAC,sBAAsB,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,SAAS,CAAC,KAAK,GAAG,eAAe,CAAC,cAAc,CAAC;YACzF,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,uBAAuB,CAAC,CAAC,CAAC,CAAC;AAE3D,YAAA,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;YACzB,IAAI,CAAC,cAAc,CAAC,QAAQ,GAAG,IAAI,CAAC,uBAAuB,CAAC,CAAC,CAAC,CAAC;YAC/D,IAAI,CAAC,uBAAuB,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,KAAK,GAAG,IAAI,CAAC,uBAAuB,CAAC,CAAC,CAAC,CAAC,eAAe,EAAE,CAAC;AAC5G,YAAA,IAAI,CAAC,uBAAuB,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,SAAS,CAAC,KAAK,GAAG,eAAe,CAAC,cAAc,CAAC;YAC1F,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;AAEzD,YAAA,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;AAEzB,YAAA,iBAAiB,GAAG,IAAI,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;AAClD,SAAA;;QAED,IAAI,CAAC,cAAc,CAAC,QAAQ,GAAG,IAAI,CAAC,iBAAiB,CAAC;QACtD,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,uBAAuB,CAAC,CAAC,CAAC,CAAC;AAC3D,QAAA,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;;QAEzB,IAAI,CAAC,aAAa,CAAC,gBAAgB,CAAC,KAAK,GAAG,YAAY,CAAC;QACzD,IAAI,CAAC,cAAc,CAAC,QAAQ,GAAG,IAAI,CAAC,aAAa,CAAC;AAClD,QAAA,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,WAAW,CAAC;AAC5C,QAAA,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;AACzB,QAAA,OAAO,IAAI,CAAC,mBAAmB,CAAC,eAAe,EAAE,CAAC;KAClD;IACD,OAAO,CAAC,KAAa,EAAE,MAAc,EAAA;QACpC,IAAI,EAAE,uBAAuB,EAAE,OAAO,CAAC,CAAC,YAAY,KAAK,YAAY,CAAC,OAAO,CAAC,KAAK,EAAE,MAAM,EAAE,CAAC,CAAC,CAAC,CAAC;QACjG,IAAI,EAAE,qBAAqB,EAAE,OAAO,CAAC,CAAC,YAAY,KAAK,YAAY,CAAC,OAAO,CAAC,KAAK,EAAE,MAAM,EAAE,CAAC,CAAC,CAAC,CAAC;AAC/F,QAAA,IAAI,EAAE,kBAAkB,EAAE,OAAO,GAAG,KAAK,EAAE,MAAM,EAAE,CAAC,CAAC,CAAC;AACtD,QAAA,IAAI,EAAE,WAAW,EAAE,OAAO,GAAG,KAAK,EAAE,MAAM,EAAE,CAAC,CAAC,CAAC;KAC/C;IACO,IAAI,GAAA;AACX,QAAA,IAAI,CAAC,uBAAuB,GAAG,EAAE,CAAC;AAClC,QAAA,IAAI,CAAC,qBAAqB,GAAG,EAAE,CAAC;AAChC,QAAA,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC;AACf,QAAA,IAAI,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC;AACtC,QAAA,IAAI,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;AAEvC,QAAA,IAAI,CAAC,kBAAkB,GAAG,IAAI,YAAY,CAAC,QAAQ,EAAE,CAAC,IAAI,CAAC,qBAAqB,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC;AAE/F,QAAA,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,KAAK,EAAE,CAAC,EAAE,EAAE;AACpC,YAAA,MAAM,qBAAqB,GAAG,IAAI,YAAY,CAAC,QAAQ,EAAE,CAAC,IAAI,CAAC,qBAAqB,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC;AACnG,YAAA,IAAI,CAAC,uBAAuB,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC;AACzD,YAAA,MAAM,oBAAoB,GAAG,IAAI,YAAY,CAAC,QAAQ,EAAE,CAAC,IAAI,CAAC,qBAAqB,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC;AAClG,YAAA,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC;YACtD,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC;YAC5B,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC;AAC5B,SAAA;;QAED,IAAI,CAAC,gBAAgB,GAAG;YACvB,QAAQ,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,KAAK,EAAE,IAAI,EAAE;AAC1C,YAAA,QAAQ,EAAE;AACT,gBAAA,IAAI,EAAE,SAAS;gBACf,KAAK,EAAE,IAAI,CAAC,cAAc;AAC1B,aAAA;YACD,kBAAkB,EAAE,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,IAAI,CAAC,SAAS,EAAE;YAC5D,WAAW,EAAE,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE;AAC3C,YAAA,YAAY,EAAE,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,IAAI,KAAK,CAAC,GAAG,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE;YAC5D,cAAc,EAAE,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,GAAG,EAAE;SAC7C,CAAC;AACF,QAAA,MAAM,MAAM,GAAG,WAAW,CAAC,gBAAgB,EAAE,EAAE,gBAAgB,EAAE,CAAC,EAAE,CAAC,CAAC;AACtE,QAAA,IAAI,CAAC,sBAAsB,GAAG,IAAI,cAAc,CAAC;AAChD,YAAA,IAAI,EAAE,OAAO;YACb,QAAQ,EAAE,IAAI,CAAC,gBAAgB;YAC/B,IAAI,EAAE,MAAM,CAAC,IAAI;YACjB,IAAI,EAAE,MAAM,CAAC,IAAI;AACjB,SAAA,CAAC,CAAC;;QAEH,IAAI,CAAC,sBAAsB,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC;AAC3D,QAAA,IAAI,CAAC,sBAAsB,GAAG,EAAE,CAAC;AACjC,QAAA,IAAI,CAAC,uBAAuB,GAAG,EAAE,CAAC;AAClC,QAAA,MAAM,eAAe,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC;QACzC,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC;QAClC,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;AAEnC,QAAA,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,KAAK,EAAE,CAAC,EAAE,EAAE;AACpC,YAAA,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,IAAI,CAAC,wBAAwB,CAAC,eAAe,CAAC,CAAC,CAAC,EAAE,cAAc,GAAG,CAAC,CAAC,CAAC,CAAC;AACxG,YAAA,IAAI,CAAC,uBAAuB,CAAC,IAAI,CAAC,IAAI,CAAC,wBAAwB,CAAC,eAAe,CAAC,CAAC,CAAC,EAAE,eAAe,GAAG,CAAC,CAAC,CAAC,CAAC;YAC1G,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC;YAE5B,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC;AAC5B,SAAA;;AAED,QAAA,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,KAAK,EAAE,mBAAmB,CAAC,CAAC;QACpF,IAAI,CAAC,iBAAiB,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC;QACtD,IAAI,CAAC,aAAa,GAAG;AACpB,YAAA,QAAQ,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,KAAK,EAAE,IAAI,CAAC,uBAAuB,CAAC,CAAC,CAAC,CAAC,eAAe,EAAE,EAAE;YACvF,gBAAgB,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,KAAK,EAAE,IAAI,EAAE;AAClD,YAAA,QAAQ,EAAE;AACT,gBAAA,IAAI,EAAE,SAAS;gBACf,KAAK,EAAE,IAAI,CAAC,cAAc;AAC1B,aAAA;SACD,CAAC;AACF,QAAA,MAAM,WAAW,GAAG,WAAW,CAAC,OAAO,EAAE,EAAE,gBAAgB,EAAE,CAAC,EAAE,CAAC,CAAC;AAClE,QAAA,IAAI,CAAC,aAAa,GAAG,IAAI,cAAc,CAAC;AACvC,YAAA,IAAI,EAAE,WAAW;YACjB,QAAQ,EAAE,IAAI,CAAC,aAAa;YAC5B,IAAI,EAAE,WAAW,CAAC,IAAI;YACtB,IAAI,EAAE,WAAW,CAAC,IAAI;AACtB,SAAA,CAAC,CAAC;QACH,IAAI,CAAC,aAAa,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC;QAClD,IAAI,CAAC,WAAW,GAAG,IAAI,YAAY,CAAC,QAAQ,EAAE,CAAC,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;KACrG;IACO,qBAAqB,CAAC,KAAa,EAAE,MAAc,EAAA;AAC1D,QAAA,MAAM,YAAY,GAAG,IAAI,OAAO,CAAC;YAChC,IAAI,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,EAAE;YACjC,MAAM,EAAE,aAAa,CAAC,UAAU;AAChC,YAAA,KAAK,EAAE,YAAY,CAAC,gBAAgB,GAAG,YAAY,CAAC,cAAc;AAClE,SAAA,CAAC,CAAC;AACH,QAAA,MAAM,eAAe,GAAG,IAAI,UAAU,CAAC,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE,OAAO,EAAE,YAAY,EAAE,CAAC,CAAC;AACtG,QAAA,OAAO,eAAe,CAAC;KACvB;IACO,oBAAoB,CAAC,KAAa,EAAE,IAAI,EAAA;QAC/C,OAAO,IAAI,cAAc,CAAC;YACzB,IAAI;AACJ,YAAA,QAAQ,EAAE;AACT,gBAAA,YAAY,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,KAAK,EAAE,IAAI,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC,eAAe,EAAE,EAAE;AACzF,gBAAA,YAAY,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,KAAK,EAAE,IAAI,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC,eAAe,EAAE,EAAE;AACzF,gBAAA,YAAY,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,KAAK,EAAE,IAAI,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC,eAAe,EAAE,EAAE;AACzF,gBAAA,YAAY,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,KAAK,EAAE,IAAI,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC,eAAe,EAAE,EAAE;AACzF,gBAAA,YAAY,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,KAAK,EAAE,IAAI,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC,eAAe,EAAE,EAAE;AACzF,gBAAA,QAAQ,EAAE;AACT,oBAAA,IAAI,EAAE,SAAS;oBACf,KAAK,EAAE,IAAI,CAAC,cAAc;AAC1B,iBAAA;gBACD,aAAa,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,IAAI,CAAC,QAAQ,EAAE;gBACpD,WAAW,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,IAAI,CAAC,MAAM,EAAE;AAChD,gBAAA,YAAY,EAAE,EAAE,IAAI,EAAE,YAAY,EAAE,KAAK,EAAE,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE;AACtE,gBAAA,eAAe,EAAE;AAChB,oBAAA,IAAI,EAAE,YAAY;AAClB,oBAAA,KAAK,EAAE;AACN,wBAAA,IAAI,OAAO,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;AACpB,wBAAA,IAAI,OAAO,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;AACpB,wBAAA,IAAI,OAAO,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;AACpB,wBAAA,IAAI,OAAO,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;AACpB,wBAAA,IAAI,OAAO,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;AACpB,qBAAA;AACD,iBAAA;AACD,aAAA;YAED,IAAI,EAAE,MAAK;gBACV,OAAO,CAAA;;;;;;;;;;;;;;;iBAeM,CAAC;aACd;AAED,YAAA,IAAI,EAAE,CAAC,OAAO,KAAI;gBACjB,OAAO,CAAA;;;;;;;;;;;;AAY0B,mCAAA,EAAA,OAAO,CAAC,mBAAmB,CAAA;AAC3B,mCAAA,EAAA,OAAO,CAAC,mBAAmB,CAAA;AAC3B,mCAAA,EAAA,OAAO,CAAC,mBAAmB,CAAA;AAC3B,mCAAA,EAAA,OAAO,CAAC,mBAAmB,CAAA;AAC3B,mCAAA,EAAA,OAAO,CAAC,mBAAmB,CAAA;AAC3B,mCAAA,EAAA,OAAO,CAAC,eAAe,CAAA;;;;;;;;;;;;;MAatD,CAAC;aACH;AACD,SAAA,CAAC,CAAC;KACH;IACO,wBAAwB,CAAC,YAAY,EAAE,IAAI,EAAA;AAClD,QAAA,MAAM,MAAM,GAAG,WAAW,CAAC,MAAM,EAAE;AAClC,YAAA,aAAa,EAAE,YAAY;AAC3B,YAAA,KAAK,EAAE,YAAY;AACnB,YAAA,gBAAgB,EAAE,CAAC;AACnB,SAAA,CAAC,CAAC;AACH,QAAA,MAAM,GAAG,GAAG,IAAI,cAAc,CAAC;YAC9B,IAAI;AACJ,YAAA,QAAQ,EAAE;gBACT,QAAQ,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,KAAK,EAAE,IAAI,EAAE;AAC1C,gBAAA,SAAS,EAAE,EAAE,IAAI,EAAE,WAAW,EAAE,KAAK,EAAE,IAAI,OAAO,CAAC,GAAG,EAAE,GAAG,CAAC,EAAE;AAC9D,gBAAA,QAAQ,EAAE;AACT,oBAAA,IAAI,EAAE,SAAS;oBACf,KAAK,EAAE,IAAI,CAAC,cAAc;AAC1B,iBAAA;AACD,aAAA;YAED,IAAI,EAAE,MAAM,CAAC,IAAI;YAEjB,IAAI,EAAE,MAAM,CAAC,IAAI;AACjB,SAAA,CAAC,CAAC;AACH,QAAA,GAAG,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC;AACnC,QAAA,OAAO,GAAG,CAAC;KACX;;AAhQM,eAAc,CAAA,cAAA,GAAG,IAAI,OAAO,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;AACvC,eAAc,CAAA,cAAA,GAAG,IAAI,OAAO,CAAC,GAAG,EAAE,GAAG,CAAC;;ACbzB,MAAA,kBAAmB,SAAQ,MAAM,CAAA;IAQrD,WAAY,CAAA,IAAI,GAAG,CAAC,CAAC,EAAE,KAAK,GAAG,CAAC,EAAE,GAAG,GAAG,CAAC,EAAE,MAAM,GAAG,CAAC,CAAC,EAAE,IAAI,GAAG,GAAG,EAAE,GAAG,GAAG,IAAI,EAAA;AAC7E,QAAA,KAAK,EAAE,CAAC;AACR,QAAA,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;AACjB,QAAA,IAAI,CAAC,GAAG,GAAG,GAAG,CAAC;AACf,QAAA,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;AACjB,QAAA,IAAI,CAAC,GAAG,GAAG,GAAG,CAAC;AACf,QAAA,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;AACrB,QAAA,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;AACnB,QAAA,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC;KACjC;IACO,iBAAiB,GAAA;AACxB,QAAA,MAAM,EAAE,GAAG,CAAC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,IAAI,IAAI,CAAC,CAAC;AACxC,QAAA,MAAM,EAAE,GAAG,CAAC,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,MAAM,IAAI,CAAC,CAAC;AACxC,QAAA,MAAM,EAAE,GAAG,CAAC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,IAAI,IAAI,CAAC,CAAC;AACxC,QAAA,MAAM,EAAE,GAAG,CAAC,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,MAAM,IAAI,CAAC,CAAC;QACxC,OAAO;YACN,IAAI,EAAE,EAAE,GAAG,EAAE;YACb,KAAK,EAAE,EAAE,GAAG,EAAE;YACd,GAAG,EAAE,EAAE,GAAG,EAAE;YACZ,MAAM,EAAE,EAAE,GAAG,EAAE;SACf,CAAC;KACF;IACM,sBAAsB,GAAA;QAC5B,IAAI,IAAI,CAAC,kBAAkB,EAAE;AAC5B,YAAA,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC,iBAAiB,EAAE,CAAC;YAC9D,IAAI,CAAC,iBAAiB,GAAG,OAAO,CAAC,gBAAgB,CAAC,IAAI,EAAE,KAAK,EAAE,GAAG,EAAE,MAAM,EAAE,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC;AACjG,YAAA,IAAI,CAAC,kBAAkB,GAAG,KAAK,CAAC;AAChC,SAAA;KACD;AACD;;AClCK,MAAO,eAAgB,SAAQ,UAAU,CAAA;AAE9C,IAAA,WAAA,GAAA;AACC,QAAA,MAAM,MAAM,GAAG,IAAI,iBAAiB,CAAC,EAAE,EAAE,CAAC,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC;QACtD,KAAK,CAAC,IAAI,OAAO,CAAC,IAAI,EAAE,IAAI,CAAC,EAAE,MAAM,CAAC,CAAC;AACvC,QAAA,IAAI,CAAC,IAAI,GAAG,iBAAiB,CAAC;KAC9B;AAEM,IAAA,MAAM,CAAC,KAAgB,EAAA;AAC7B,QAAA,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;KAC3B;AAED,IAAA,cAAc,CAAC,KAAgB,EAAA;QAC9B,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;QAC1C,MAAM,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,GAAG,KAAK,CAAC,MAAM,CAAC;QACjC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;AAC5B,QAAA,IAAI,CAAC,MAAM,CAAC,YAAY,EAAE,CAAC;AAC3B,QAAA,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;KAC1B;AACD;;ACnBK,MAAO,SAAU,SAAQ,KAAK,CAAA;IAanC,WAAY,CAAA,KAAK,EAAE,SAAS,EAAE,QAAQ,GAAG,CAAC,EAAE,KAAK,GAAG,EAAE,EAAE,QAAQ,GAAG,EAAE,EAAE,KAAK,GAAG,CAAC,EAAE,UAAU,GAAG,IAAI,EAAA;AAClG,QAAA,KAAK,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;AACxB,QAAA,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;AAC1B,QAAA,IAAI,CAAC,MAAM,GAAG,CAAC,KAAK,GAAG,GAAG,IAAI,IAAI,CAAC,EAAE,CAAC;AACtC,QAAA,IAAI,CAAC,SAAS,GAAG,CAAC,QAAQ,GAAG,GAAG,IAAI,IAAI,CAAC,EAAE,CAAC;AAC5C,QAAA,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;AACpB,QAAA,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC,SAAS,CAAC;AACrC,QAAA,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;AACvB,QAAA,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;AAC1B,QAAA,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;AAC1B,QAAA,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;AACvB,QAAA,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;AACzB,QAAA,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC;AAC7B,QAAA,IAAI,UAAU;AAAE,YAAA,IAAI,CAAC,MAAM,GAAG,IAAI,eAAe,EAAE,CAAC;QACpD,IAAI,CAAC,0BAA0B,EAAE,CAAC;KAClC;AAED,IAAA,IAAI,YAAY,GAAA;AACf,QAAA,OAAO,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,WAAW,CAAC;KAC9C;IAED,IAAI,YAAY,CAAC,KAAK,EAAA;AACrB,QAAA,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;AAC3B,QAAA,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;KACzB;AAED,IAAA,IAAI,WAAW,GAAA;AACd,QAAA,MAAM,MAAM,GAAG,IAAI,OAAO,EAAE,CAAC;AAC7B,QAAA,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;QACrD,OAAO,OAAO,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,OAAO,EAAE,CAAC,CAAC;KAChD;AACD,IAAA,IAAI,KAAK,GAAA;QACR,OAAO,IAAI,CAAC,MAAM,CAAC;KACnB;IACD,IAAI,KAAK,CAAC,KAAK,EAAA;AACd,QAAA,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;AACvB,QAAA,IAAI,CAAC,MAAM,GAAG,CAAC,KAAK,GAAG,GAAG,IAAI,IAAI,CAAC,EAAE,CAAC;QACtC,IAAI,CAAC,0BAA0B,EAAE,CAAC;KAClC;AACD,IAAA,IAAI,QAAQ,GAAA;QACX,OAAO,IAAI,CAAC,SAAS,CAAC;KACtB;IACD,IAAI,QAAQ,CAAC,KAAK,EAAA;AACjB,QAAA,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;AAC1B,QAAA,IAAI,CAAC,SAAS,GAAG,CAAC,KAAK,GAAG,GAAG,IAAI,IAAI,CAAC,EAAE,CAAC;QACzC,IAAI,CAAC,0BAA0B,EAAE,CAAC;KAClC;IACD,IAAI,QAAQ,CAAC,KAAK,EAAA;AACjB,QAAA,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;AAC1B,QAAA,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;KACvB;AACD,IAAA,IAAI,QAAQ,GAAA;QACX,OAAO,IAAI,CAAC,SAAS,CAAC;KACtB;IACD,IAAI,KAAK,CAAC,KAAK,EAAA;AACd,QAAA,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;AACvB,QAAA,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;KACpB;AACD,IAAA,IAAI,KAAK,GAAA;QACR,OAAO,IAAI,CAAC,MAAM,CAAC;KACnB;IACD,IAAI,OAAO,CAAC,KAAK,EAAA;AAChB,QAAA,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;AACzB,QAAA,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;KACtB;AACD,IAAA,IAAI,OAAO,GAAA;QACV,OAAO,IAAI,CAAC,QAAQ,CAAC;KACrB;IACD,IAAI,WAAW,CAAC,KAAK,EAAA;AACpB,QAAA,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC;AAC7B,QAAA,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;KAC1B;AACD,IAAA,IAAI,WAAW,GAAA;QACd,OAAO,IAAI,CAAC,YAAY,CAAC;KACzB;IACO,0BAA0B,GAAA;QACjC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;AACrC,QAAA,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC;KACzD;AACD,CAAA;AACD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpGM,MAAO,sBAAuB,SAAQ,UAAU,CAAA;AAErD,IAAA,WAAA,GAAA;AACC,QAAA,MAAM,MAAM,GAAG,IAAI,kBAAkB,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,GAAG,CAAC,CAAC;QAChE,KAAK,CAAC,IAAI,OAAO,CAAC,IAAI,EAAE,IAAI,CAAC,EAAE,MAAM,CAAC,CAAC;AACvC,QAAA,IAAI,CAAC,IAAI,GAAG,wBAAwB,CAAC;KACrC;AAEM,IAAA,MAAM,CAAC,KAAuB,EAAA;AACpC,QAAA,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;KAC3B;AAED,IAAA,cAAc,CAAC,KAAuB,EAAA;QACrC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;QAC1C,MAAM,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,GAAG,KAAK,CAAC,MAAM,CAAC;QACjC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;AAC5B,QAAA,IAAI,CAAC,MAAM,CAAC,YAAY,EAAE,CAAC;AAC3B,QAAA,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;KAC1B;AACD;;ACnBK,MAAO,gBAAiB,SAAQ,KAAK,CAAA;AAC1C,IAAA,WAAA,CAAY,KAAc,EAAE,SAAiB,EAAE,UAAU,GAAG,IAAI,EAAA;AAC/D,QAAA,KAAK,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;AACxB,QAAA,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC,gBAAgB,CAAC;AAC5C,QAAA,IAAI,UAAU;AAAE,YAAA,IAAI,CAAC,MAAM,GAAG,IAAI,sBAAsB,EAAE,CAAC;KAC3D;AAED,IAAA,IAAI,YAAY,GAAA;AACf,QAAA,OAAO,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,WAAW,CAAC;KAC9C;IAED,IAAI,YAAY,CAAC,KAAK,EAAA;AACrB,QAAA,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;AAC3B,QAAA,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;KACzB;AAED,IAAA,IAAI,WAAW,GAAA;AACd,QAAA,MAAM,MAAM,GAAG,IAAI,OAAO,EAAE,CAAC;AAC7B,QAAA,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC;AACrD,QAAA,OAAO,MAAM,CAAC,SAAS,EAAE,CAAC;KAC1B;AACD,CAAA;AACD;AACA;AACA;;ACtBqB,MAAA,IAAK,SAAQ,YAAY,CAAA;AAI7C,IAAA,WAAA,GAAA;AACC,QAAA,KAAK,EAAE,CAAC;AACR,QAAA,IAAI,CAAC,IAAI,GAAG,gBAAgB,CAAC,IAAI,CAAC;AAClC,QAAA,IAAI,CAAC,QAAQ,GAAG,IAAI,GAAG,EAAE,CAAC;AAC1B,QAAA,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;AACnB,QAAA,IAAI,CAAC,GAAG,GAAG,UAAU,EAAE,CAAC;KACxB;AACD,IAAA,GAAG,CAAC,IAAiB,EAAA;AACpB,QAAA,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;QACnB,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;KAClC;AACD,IAAA,MAAM,CAAC,IAAiB,EAAA;QACvB,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;KAC/B;IACD,MAAM,CAAC,UAAsB,EAAE,MAAe,EAAA;AAC7C,QAAA,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,MAAM,EAAE,WAAW,EAAE,KAAK,EAAE,CAAC,CAAC;QACtD,IAAI,EAAE,QAAQ,EAAE,OAAO,GAAG,CAAC,IAAI,KAAI;AAClC,YAAA,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE,MAAM,CAAC,CAAC;AACjC,SAAC,CAAC,CAAC;KACH;IACD,OAAO,GAAA;QACN,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,IAAI,KAAI;YAC9B,IAAI,CAAC,OAAO,EAAE,CAAC;AAChB,SAAC,CAAC,CAAC;AACH,QAAA,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC;KACxB;IACD,QAAQ,CAAC,gBAA0B,EAAE,KAA8B,EAAA;AAClE,QAAA,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,EAAE,EAAE;YACvD,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,KAAK,KAAI;AAC/B,gBAAA,KAAK,CAAC,QAAQ,CAAC,gBAAgB,EAAE,KAAK,CAAC,CAAC;AACzC,aAAC,CAAC,CAAC;AACH,SAAA;KACD;AACD;;ACjCK,MAAO,QAAS,SAAQ,IAAI,CAAA;IAKjC,WAAY,CAAA,QAAmB,EAAE,QAAmB,EAAA;AACnD,QAAA,KAAK,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;AAC1B,QAAA,IAAI,CAAC,IAAI,GAAG,gBAAgB,CAAC,QAAQ,CAAC;AACtC,QAAA,IAAI,CAAC,cAAc,GAAG,EAAE,CAAC;AACzB,QAAA,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;KAC1B;AACD,IAAA,WAAW,CAAC,IAAkB,EAAA;AAC7B,QAAA,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,mBAAmB,CAAC;AACpD,QAAA,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;KAC1B;IACD,MAAM,CAAC,UAAsB,EAAE,MAAe,EAAA;AAC7C,QAAA,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,KAAM,KAAc,CAAC,WAAW,CAAC,CAAC;AAC9E,QAAA,KAAK,CAAC,MAAM,CAAC,UAAU,EAAE,MAAM,CAAC,CAAC;QACjC,IAAI,CAAC,IAAI,CAAC,YAAY;YAAE,IAAI,CAAC,qBAAqB,EAAE,CAAC;KACrD;IACO,qBAAqB,GAAA;AAC5B,QAAA,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,UAAU;YAAE,OAAO;AACtC,QAAA,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;QACzB,IAAI,IAAI,CAAC,MAAM,EAAE;AAChB,YAAA,MAAM,gBAAgB,GAAG,IAAI,aAAa,CAAC;AAC1C,gBAAA,KAAK,EAAE,kBAAkB;gBACzB,IAAI,EAAE,iBAAiB,CAAC,eAAe;AACvC,gBAAA,KAAK,EAAE,WAAW,CAAC,OAAO,GAAG,WAAW,CAAC,OAAO;AAChD,gBAAA,IAAI,EAAE,IAAI;AACV,aAAA,CAAC,CAAC;AACH,YAAA,MAAM,UAAU,GAAG,IAAI,aAAa,CAAC;AACpC,gBAAA,KAAK,EAAE,YAAY;gBACnB,IAAI,EAAE,iBAAiB,CAAC,eAAe;AACvC,gBAAA,KAAK,EAAE,WAAW,CAAC,OAAO,GAAG,WAAW,CAAC,OAAO;AAChD,gBAAA,IAAI,EAAE,IAAI;AACV,aAAA,CAAC,CAAC;AACH,YAAA,gBAAgB,CAAC,UAAU,CAC1B,QAAQ,EACR,MAAK;gBACJ,OAAO,IAAI,CAAC,cAAc,CAAC;aAC3B,EACD,WAAW,CAAC,SAAS,EACrB,IAAI,CAAC,cAAc,CAAC,MAAM,CAC1B,CAAC;AACF,YAAA,UAAU,CAAC,UAAU,CACpB,WAAW,EACX,MAAK;gBACJ,OAAO,IAAI,CAAC,mBAAmB,CAAC;aAChC,EACD,WAAW,CAAC,SAAS,EACrB,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAC/B,CAAC;YACF,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,gBAAgB,CAAC,kBAAkB,EAAE,gBAAgB,CAAC,CAAC;YAChF,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,gBAAgB,CAAC,YAAY,EAAE,UAAU,CAAC,CAAC;AACpE,SAAA;KACD;AACD;;ACjDK,SAAU,aAAa,CAAC,IAAY,EAAE,MAAmB,EAAE,UAAkB,EAAE,MAAc,EAAA;AAClG,IAAA,QAAQ,IAAI;AACX,QAAA,KAAK,IAAI;YACR,OAAO,IAAI,SAAS,CAAC,MAAM,EAAE,UAAU,EAAE,MAAM,CAAC,CAAC;AAClD,QAAA,KAAK,IAAI;YACR,OAAO,IAAI,UAAU,CAAC,MAAM,EAAE,UAAU,EAAE,MAAM,CAAC,CAAC;AACnD,QAAA,KAAK,IAAI;YACR,OAAO,IAAI,UAAU,CAAC,MAAM,EAAE,UAAU,EAAE,MAAM,CAAC,CAAC;AACnD,QAAA,KAAK,IAAI;YACR,OAAO,IAAI,WAAW,CAAC,MAAM,EAAE,UAAU,EAAE,MAAM,CAAC,CAAC;AACpD,QAAA,KAAK,IAAI;YACR,OAAO,IAAI,UAAU,CAAC,MAAM,EAAE,UAAU,EAAE,MAAM,CAAC,CAAC;AACnD,QAAA,KAAK,IAAI;YACR,OAAO,IAAI,WAAW,CAAC,MAAM,EAAE,UAAU,EAAE,MAAM,CAAC,CAAC;AACpD,QAAA,KAAK,IAAI;YACR,OAAO,IAAI,YAAY,CAAC,MAAM,EAAE,UAAU,EAAE,MAAM,CAAC,CAAC;AACrD,QAAA;AACC,YAAA,MAAM,IAAI,KAAK,CAAC,wBAAwB,CAAC,CAAC;AAC3C,KAAA;AACF,CAAC;AAEK,SAAU,SAAS,CAAC,KAAiB,EAAA;AAC1C,IAAA,IAAI,KAAK,YAAY,WAAW,IAAI,KAAK,YAAY,WAAW,EAAE;AACjE,QAAA,OAAO,KAAK,CAAC;AACb,KAAA;AACD,IAAA,IAAI,OAAO,CAAC;IACZ,IAAI,KAAK,YAAY,YAAY,EAAE;QAClC,OAAO,GAAG,IAAI,WAAW,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;AACxC,KAAA;AAAM,SAAA;QACN,OAAO,GAAG,IAAI,WAAW,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;AACxC,KAAA;IACD,KAAK,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,KAAK,KAAI;AAChC,QAAA,OAAO,CAAC,KAAK,CAAC,GAAG,OAAO,CAAC;AAC1B,KAAC,CAAC,CAAC;AACH,IAAA,OAAO,OAAO,CAAC;AAChB,CAAC;AAyCe,SAAA,eAAe,CAAC,OAA0B,EAAE,SAAqB,EAAA;IAChF,MAAM,OAAO,GAAG,IAAI,YAAY,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;AACnD,IAAA,MAAM,WAAW,GAAG,OAAO,GAAG,OAAO,CAAC,MAAM,GAAG,SAAS,CAAC,MAAM,CAAC;AAChE,IAAA,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,WAAW,EAAE,CAAC,IAAI,CAAC,EAAE;QACxC,MAAM,UAAU,GAAG,EAAE,CAAC;AACtB,QAAA,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE;AAC9B,YAAA,IAAI,OAAO,EAAE;gBACZ,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;AAChC,aAAA;AAAM,iBAAA;AACN,gBAAA,UAAU,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;AACvB,aAAA;AACD,SAAA;QACD,MAAM,QAAQ,GAAG,UAAU,CAAC,GAAG,CAAC,CAAC,WAAW,KAAI;AAC/C,YAAA,MAAM,KAAK,GAAG,WAAW,GAAG,CAAC,CAAC;YAC9B,OAAO,IAAI,OAAO,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,SAAS,CAAC,KAAK,GAAG,CAAC,CAAC,EAAE,SAAS,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC;AAClF,SAAC,CAAC,CAAC;AACH,QAAA,MAAM,GAAG,GAAG,IAAI,OAAO,EAAE,CAAC;AAC1B,QAAA,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;AAChD,QAAA,MAAM,GAAG,GAAG,IAAI,OAAO,EAAE,CAAC;AAC1B,QAAA,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;AAChD,QAAA,MAAM,MAAM,GAAG,IAAI,OAAO,EAAE,CAAC;AAC7B,QAAA,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,SAAS,EAAE,EAAE,GAAG,CAAC,SAAS,EAAE,EAAE,MAAM,CAAC,CAAC;AACxD,QAAA,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE;YAC9B,MAAM,KAAK,GAAG,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;YAC1B,OAAO,CAAC,KAAK,GAAG,CAAC,CAAC,IAAI,MAAM,CAAC,CAAC,CAAC;YAC/B,OAAO,CAAC,KAAK,GAAG,CAAC,CAAC,IAAI,MAAM,CAAC,CAAC,CAAC;YAC/B,OAAO,CAAC,KAAK,GAAG,CAAC,CAAC,IAAI,MAAM,CAAC,CAAC,CAAC;AAC/B,SAAA;AACD,KAAA;AACD,IAAA,OAAO,OAAO,CAAC;AAChB,CAAC;AAyJM,MAAM,QAAQ,GAAuC;AAC3D,IAAA,MAAM,EAAE,CAAC;AACT,IAAA,IAAI,EAAE,CAAC;AACP,IAAA,IAAI,EAAE,CAAC;AACP,IAAA,IAAI,EAAE,CAAC;AACP,IAAA,IAAI,EAAE,CAAC;AACP,IAAA,IAAI,EAAE,CAAC;AACP,IAAA,IAAI,EAAE,EAAE;AACR,IAAA,IAAI,EAAE,CAAC;AACP,IAAA,IAAI,EAAE,CAAC;AACP,IAAA,IAAI,EAAE,CAAC;AACP,IAAA,IAAI,EAAE,CAAC;AACP,IAAA,IAAI,EAAE,CAAC;AACP,IAAA,IAAI,EAAE,CAAC;AACP,IAAA,IAAI,EAAE,SAAS;AACf,IAAA,IAAI,EAAE,QAAQ;AACd,IAAA,IAAI,EAAE,QAAQ;AACd,IAAA,IAAI,EAAE,QAAQ;AACd,IAAA,IAAI,EAAE,QAAQ;AACd,IAAA,IAAI,EAAE,QAAQ;AACd,IAAA,KAAK,EAAE,eAAe;AACtB,IAAA,KAAK,EAAE,eAAe;AACtB,IAAA,KAAK,EAAE,QAAQ;CACf;;MCzSY,QAAQ,CAAA;AAQpB,IAAA,WAAA,CAAY,OAAsB,EAAA;QACjC,IAAI,CAAC,MAAM,GAAG,OAAO,CAAC,MAAM,IAAI,EAAE,CAAC;AACnC,QAAA,IAAI,CAAC,EAAE,GAAG,OAAO,CAAC,EAAE,CAAC;AACrB,QAAA,IAAI,CAAC,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC;AAC3B,QAAA,IAAI,CAAC,aAAa,GAAG,OAAO,CAAC,aAAa,CAAC;AAC3C,QAAA,IAAI,CAAC,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;AACzB,QAAA,IAAI,CAAC,GAAG,GAAG,OAAO,CAAC,GAAG,CAAC;AACvB,QAAA,IAAI,CAAC,GAAG,GAAG,OAAO,CAAC,GAAG,CAAC;KACvB;IACD,QAAQ,GAAA;QACP,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;KAC/B;IACD,YAAY,GAAA;QACX,MAAM,MAAM,GAAG,EAAE,CAAC;AAClB,QAAA,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,EAAE;AAC/C,YAAA,MAAM,CAAC,IAAI,CAAC,IAAI,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;AACrG,SAAA;AACD,QAAA,OAAO,MAAM,CAAC;KACd;IACD,YAAY,GAAA;QACX,MAAM,MAAM,GAAG,EAAE,CAAC;AAClB,QAAA,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,IAAI,EAAE,EAAE;AAChD,YAAA,MAAM,IAAI,GAAG,IAAI,OAAO,EAAE,CAAC;AAC3B,YAAA,OAAO,CAAC,oBAAoB,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,EAAE,IAAI,CAAC,CAAC;AACjE,YAAA,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AAClB,SAAA;AACD,QAAA,OAAO,MAAM,CAAC;KACd;AACD;;MClCY,SAAS,CAAA;AACrB,IAAA,WAAA,CAAmB,IAAY,EAAS,QAA4B,EAAS,QAA4B,EAAA;QAAtF,IAAI,CAAA,IAAA,GAAJ,IAAI,CAAQ;QAAS,IAAQ,CAAA,QAAA,GAAR,QAAQ,CAAoB;QAAS,IAAQ,CAAA,QAAA,GAAR,QAAQ,CAAoB;KAAI;AAC7G,IAAA,IAAI,CAAC,IAAY,EAAA;AAChB,QAAA,IAAI,IAAI,EAAE,gBAAgB,EAAE,MAAM,CAAC;QACnC,IAAI,EAAE,QAAQ,EAAE,GAAG,CAAC,CAAC,OAAO,KAAI;AAC/B,YAAA,gBAAgB,GAAG,OAAO,CAAC,OAAO,CAAC;AACnC,YAAA,gBAAgB,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;AAChC,YAAA,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;AACxB,YAAA,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC;YACnB,QAAQ,MAAM,CAAC,IAAI;AAClB,gBAAA,KAAK,UAAU;oBACd,UAAU,CAAC,KAAK,CAAC,gBAAgB,CAAC,YAAY,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;oBACjE,MAAM;AACP,gBAAA,KAAK,aAAa;oBACjB,OAAO,CAAC,KAAK,CAAC,gBAAgB,CAAC,YAAY,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;oBAC5D,MAAM;AACP,gBAAA,KAAK,OAAO;oBACX,OAAO,CAAC,KAAK,CAAC,gBAAgB,CAAC,YAAY,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;oBACzD,MAAM;AACP,aAAA;AACF,SAAC,CAAC,CAAC;KACH;AACD;;MCxBY,gBAAgB,CAAA;AAG5B,IAAA,WAAA,GAAA,GAAgB;AAChB;;MCLY,sBAAsB,CAAA;IAGlC,WAAY,CAAA,IAAI,EAAE,IAAI,EAAA;AACrB,QAAA,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;AACjB,QAAA,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;KACjB;AACD;;ACTD,IAAY,mBAQX,CAAA;AARD,CAAA,UAAY,mBAAmB,EAAA;AAC9B,IAAA,mBAAA,CAAA,mBAAA,CAAA,QAAA,CAAA,GAAA,CAAA,CAAA,GAAA,QAAY,CAAA;AACZ,IAAA,mBAAA,CAAA,mBAAA,CAAA,MAAA,CAAA,GAAA,CAAA,CAAA,GAAA,MAAU,CAAA;AACV,IAAA,mBAAA,CAAA,mBAAA,CAAA,MAAA,CAAA,GAAA,CAAA,CAAA,GAAA,MAAU,CAAA;AACV,IAAA,mBAAA,CAAA,mBAAA,CAAA,MAAA,CAAA,GAAA,CAAA,CAAA,GAAA,MAAU,CAAA;AACV,IAAA,mBAAA,CAAA,mBAAA,CAAA,MAAA,CAAA,GAAA,CAAA,CAAA,GAAA,MAAU,CAAA;AACV,IAAA,mBAAA,CAAA,mBAAA,CAAA,MAAA,CAAA,GAAA,CAAA,CAAA,GAAA,MAAU,CAAA;AACV,IAAA,mBAAA,CAAA,mBAAA,CAAA,MAAA,CAAA,GAAA,EAAA,CAAA,GAAA,MAAW,CAAA;AACZ,CAAC,EARW,mBAAmB,KAAnB,mBAAmB,GAQ9B,EAAA,CAAA,CAAA;;MCLY,gBAAgB,CAAA;AAY5B,IAAA,WAAA,GAAA,GAAgB;IAChB,QAAQ,CAAC,IAAI,EAAE,OAAO,EAAA;AACrB,QAAA,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC;AAClD,QAAA,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC;AACpD,QAAA,IAAI,CAAC,aAAa,GAAG,OAAO,CAAC,aAAa,KAAK,SAAS,GAAG,OAAO,CAAC,aAAa,GAAG,QAAQ,CAAC;AAC5F,QAAA,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC;;AAEtB,QAAA,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;AACjD,QAAA,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;AAC7C,QAAA,IAAI,CAAC,SAAS,GAAG,IAAI,EAAE,IAAI,EAAE,SAAS,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,IAAI,CAAC;AAC5D,QAAA,IAAI,CAAC,UAAU,GAAG,IAAI,EAAE,IAAI,EAAE,SAAS,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,IAAI,CAAC;KAC9D;AACD,IAAA,QAAQ,CAAC,IAAY,EAAA;AACpB,QAAA,IAAI,IAAI,GAAG,IAAI,CAAC,OAAO,EAAE;YACxB,IAAI,IAAI,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,IAAI,GAAG,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,QAAQ,CAAC,CAAC;AACzE,YAAA,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC;AACtB,SAAA;AAED,QAAA,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC;QAC9B,OAAO,IAAI,CAAC,YAAY,IAAI,GAAG,GAAG,CAAC,IAAI,IAAI,IAAI,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC,EAAE;YACjF,IAAI,CAAC,YAAY,EAAE,CAAC;AACpB,SAAA;AAED,QAAA,IAAI,IAAI,CAAC,YAAY,IAAI,GAAG,GAAG,CAAC,EAAE;;AAEjC,YAAA,IAAI,IAAI,IAAI,CAAC,QAAQ,CAAC;AACtB,YAAA,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC;AACtB,SAAA;;QAGD,MAAM,KAAK,GAAG,mBAAmB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;AAEnD,QAAA,MAAM,yBAAyB,GAAG,KAAK,KAAK,CAAC,GAAG,IAAI,UAAU,EAAE,GAAG,IAAI,OAAO,EAAE,CAAC;AACjF,QAAA,MAAM,yBAAyB,GAAG,KAAK,KAAK,CAAC,GAAG,IAAI,UAAU,EAAE,GAAG,IAAI,OAAO,EAAE,CAAC;QACjF,IAAI,CAAC,IAAI,CAAC,YAAY;AAAE,YAAA,IAAI,CAAC,YAAY,GAAG,KAAK,KAAK,CAAC,GAAG,IAAI,UAAU,EAAE,GAAG,IAAI,OAAO,EAAE,CAAC;AAC3F,QAAA,MAAM,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC;AAC5B,QAAA,MAAM,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;AACpB,QAAA,MAAM,EAAE,GAAG,CAAC,GAAG,KAAK,CAAC;AAErB,QAAA,MAAM,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;AAClF,QAAA,yBAAyB,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;AAC9G,QAAA,yBAAyB,CAAC,GAAG,CAC5B,IAAI,CAAC,MAAM,CAAC,EAAE,GAAG,CAAC,CAAC,EACnB,IAAI,CAAC,MAAM,CAAC,EAAE,GAAG,CAAC,CAAC,EACnB,IAAI,CAAC,MAAM,CAAC,EAAE,GAAG,CAAC,CAAC,EACnB,IAAI,CAAC,MAAM,CAAC,EAAE,GAAG,CAAC,CAAC,CACnB,CAAC;QACF,QAAQ,IAAI,CAAC,aAAa;AACzB,YAAA,KAAK,QAAQ;AACZ,gBAAA,KAAK,KAAK,CAAC;AACV,sBAAE,UAAU,CAAC,KAAK,CACJ,yBAAyB,EACzB,yBAAyB,EACrC,CAAC,EACW,IAAI,CAAC,YAAY,CAC5B;AACH,sBAAE,OAAO,CAAC,IAAI,CACH,yBAAyB,EACzB,yBAAyB,EAClC,CAAC,EACQ,IAAI,CAAC,YAAY,CACzB,CAAC;gBACL,MAAM;AAGP,SAAA;KACD;AACD;;MCjCY,IAAI,CAAA;IAiChB,WAAY,CAAA,IAAS,EAAE,OAAe,EAAE,SAAS,GAAG,CAAC,EAAE,MAAoB,EAAA;AAC1E,QAAA,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;AACjB,QAAA,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC;AACpC,QAAA,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;AAC3B,QAAA,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;AACvB,QAAA,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;QAC1B,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,IAAI,EAAE,CAAC;AAClC,QAAA,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;AACrB,QAAA,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC;KACjB;AACD,IAAA,MAAM,SAAS,GAAA;QACd,IAAI,CAAC,OAAO,GAAG,MAAM,IAAI,CAAC,UAAU,EAAE,CAAC;QACvC,IAAI,CAAC,MAAM,GAAG,MAAM,IAAI,CAAC,UAAU,EAAE,CAAC;QACtC,IAAI,CAAC,aAAa,EAAE,CAAC;QACrB,IAAI,CAAC,aAAa,EAAE,CAAC;QACrB,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAI,CAAC,UAAU,EAAE,CAAC;QAClB,IAAI,CAAC,UAAU,EAAE,CAAC;QAClB,IAAI,CAAC,aAAa,EAAE,CAAC;QACrB,IAAI,CAAC,WAAW,EAAE,CAAC;QACnB,IAAI,CAAC,eAAe,EAAE,CAAC;KACvB;AACO,IAAA,WAAW,CAAC,KAAa,EAAA;AAChC,QAAA,OAAO,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;KAC7B;IACO,aAAa,GAAA;AACpB,QAAA,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,QAAQ;cAC9B,IAAI,CAAC,IAAI,CAAC,QAAuB,CAAC,GAAG,CAAC,CAAC,OAAO,KAAK,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;cAC7E,EAAE,CAAC;KACN;IACO,WAAW,GAAA;AAClB,QAAA,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,KAAI;YAC5C,MAAM,KAAK,GAAG,KAAK,EAAE,KAAK,EAAE,GAAG,CAAC,CAAC,MAAM,KAAI;AAC1C,gBAAA,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;AAC3B,aAAC,CAAC,CAAC;AACH,YAAA,OAAO,KAAK,CAAC;AACd,SAAC,CAAC,CAAC;KACH;IACO,aAAa,GAAA;AACpB,QAAA,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,QAAQ;AACjC,cAAG,IAAI,CAAC,IAAI,CAAC,QAAuB,CAAC,GAAG,CAAC,CAAC,OAAO,KAAI;gBACnD,OAAO;oBACN,OAAO,EAAE,OAAO,CAAC,OAAO,KAAK,SAAS,GAAG,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC;oBAC7F,OAAO,EAAE,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,MAAM,CAAC;iBAC3C,CAAC;AACF,aAAC,CAAC;cACF,EAAE,CAAC;KACN;IACO,cAAc,GAAA;AACrB,QAAA,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,SAAS;AACnC,cAAG,IAAI,CAAC,IAAI,CAAC,SAAwB,CAAC,GAAG,CAAC,CAAC,QAAQ,KAAI;AACrD,gBAAA,MAAM,GAAG,GAAG,IAAI,WAAW,EAAE,CAAC;AAC9B,gBAAA,MAAM,EACL,eAAe,EACf,cAAc,EACd,wBAAwB,EACxB,gBAAgB,EAChB,eAAe,EACf,GAAG,QAAQ,CAAC,oBAAoB,CAAC;gBAClC,IAAI,QAAQ,CAAC,aAAa;AAAE,oBAAA,GAAG,CAAC,aAAa,GAAG,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC;gBACpG,IAAI,QAAQ,CAAC,gBAAgB;AAC5B,oBAAA,GAAG,CAAC,SAAS,GAAG,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC;gBACxE,IAAI,QAAQ,CAAC,eAAe;AAC3B,oBAAA,GAAG,CAAC,eAAe,GAAG,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC;AAC7E,gBAAA,IAAI,gBAAgB;AAAE,oBAAA,GAAG,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC;AACtF,gBAAA,IAAI,wBAAwB;AAC3B,oBAAA,GAAG,CAAC,yBAAyB,GAAG,IAAI,CAAC,QAAQ,CAAC,wBAAwB,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC;AACvF,gBAAA,IAAI,eAAe;oBAClB,GAAG,CAAC,KAAK,GAAG,IAAI,KAAK,CAAC,eAAe,CAAC,CAAC,CAAC,EAAE,eAAe,CAAC,CAAC,CAAC,EAAE,eAAe,CAAC,CAAC,CAAC,CAAC,CAAC;AACnF,gBAAA,GAAG,CAAC,SAAS,GAAG,cAAc,IAAI,GAAG,CAAC;AACtC,gBAAA,GAAG,CAAC,SAAS,GAAG,eAAe,IAAI,GAAG,CAAC;AACvC,gBAAA,GAAG,CAAC,WAAW,GAAG,IAAI,OAAO,CAAC;AAC7B,oBAAA,SAAS,EAAE,QAAQ;AACnB,oBAAA,SAAS,EAAE,QAAQ;AACnB,oBAAA,YAAY,EAAE,QAAQ;AACtB,oBAAA,YAAY,EAAE,QAAQ;AACtB,iBAAA,CAAC,CAAC;AACH,gBAAA,OAAO,GAAG,CAAC;AACX,aAAC,CAAC;cACF,EAAE,CAAC;KACN;IACO,cAAc,GAAA;AACrB,QAAA,IAAI,CAAC,SAAS,GAAI,IAAI,CAAC,IAAI,CAAC,SAAwB,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,KAAK,KAAI;YAC5E,MAAM,CAAC,GAAG,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAW,CAAC;AAC5C,YAAA,IAAI,KAAK,CAAC;AACV,YAAA,IAAI,QAAQ,CAAC,UAAU,KAAK,SAAS,EAAE;AACtC,gBAAA,KAAK,GAAG,aAAa,CACpB,QAAQ,CAAC,aAAa,EACtB,IAAI,WAAW,CAAC,CAAC,GAAG,QAAQ,CAAC,KAAK,GAAI,QAAQ,CAAC,QAAQ,CAAC,aAAa,CAAY,CAAC,EAClF,CAAC,EACD,QAAQ,CAAC,KAAK,GAAG,CAAC,CAClB,CAAC;AACF,aAAA;AAAM,iBAAA;gBACN,KAAK,GAAG,IAAI,CAAC,aAAa,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC;AACxC,aAAA;YAED,IAAI,QAAQ,CAAC,MAAM,EAAE;AACpB,gBAAA,QAAQ,CAAC,MAAM,CAAC,OAAO,CAAC,KAAK,GAAG,QAAQ,CAAC,MAAM,CAAC,KAAK,CAAC;AACtD,gBAAA,QAAQ,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,GAAG,QAAQ,CAAC,MAAM,CAAC,KAAK,CAAC;gBACrD,QAAQ,CAAC,MAAM,CAAC,MAAM,CAAC,aAAa,GAAG,QAAQ,CAAC,aAAa,CAAC;AAC9D,gBAAA,MAAM,OAAO,GAAG,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;AAC/D,gBAAA,MAAM,MAAM,GAAG,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;AAC7D,gBAAA,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,QAAQ,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,IAAI,CAAC,EAAE;AAClD,oBAAA,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE;AAC9B,wBAAA,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC;AAC9C,qBAAA;AACD,iBAAA;AACD,aAAA;YACD,OAAO,IAAI,QAAQ,CAAC;AACnB,gBAAA,aAAa,EAAU,QAAQ,CAAC,QAAQ,CAAC,aAAa,CAAC;gBACvD,KAAK,EAAE,QAAQ,CAAC,KAAK;AACrB,gBAAA,IAAI,EAAE,CAAC;AACP,gBAAA,MAAM,EAAE,KAAK;AACb,gBAAA,EAAE,EAAE,KAAK;gBACT,GAAG,EAAE,QAAQ,EAAE,GAAG;gBAClB,GAAG,EAAE,QAAQ,EAAE,GAAG;AAClB,aAAA,CAAC,CAAC;AACJ,SAAC,CAAC,CAAC;KACH;IACO,eAAe,GAAA;AACtB,QAAA,IAAI,CAAC,UAAU,GAAG,IAAI,EAAE,IAAI,EAAE,UAAU,EAAE,GAAG,CAAC,CAAC,aAAa,EAAE,KAAK,KAAI;YACtE,MAAM,QAAQ,GAAG,aAAa,EAAE,QAAQ,EAAE,GAAG,CAAC,CAAC,WAAW,KAAI;AAC7D,gBAAA,MAAM,OAAO,GAAG,IAAI,gBAAgB,EAAE,CAAC;AACvC,gBAAA,OAAO,CAAC,QAAQ,CAAC,IAAI,EAAE,WAAW,CAAC,CAAC;AACpC,gBAAA,OAAO,OAAO,CAAC;AAChB,aAAC,CAAC,CAAC;YACH,MAAM,QAAQ,GAAG,aAAa,EAAE,QAAQ,EAAE,GAAG,CAAC,CAAC,WAAW,KAAI;AAC7D,gBAAA,MAAM,gBAAgB,GAAG,IAAI,gBAAgB,EAAE,CAAC;gBAChD,gBAAgB,CAAC,OAAO,GAAG,QAAQ,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;gBACzD,gBAAgB,CAAC,MAAM,GAAG,IAAI,sBAAsB,CACnD,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,MAAM,CAAC,IAAI,CAAC,EACnC,WAAW,CAAC,MAAM,CAAC,IAAI,CACvB,CAAC;AACF,gBAAA,OAAO,gBAAgB,CAAC;AACzB,aAAC,CAAC,CAAC;AACH,YAAA,MAAM,SAAS,GAAG,IAAI,SAAS,CAAC,KAAK,CAAC,QAAQ,EAAE,EAAE,QAAQ,EAAE,QAAQ,CAAC,CAAC;AACtE,YAAA,OAAO,SAAS,CAAC;AAClB,SAAC,CAAC,CAAC;KACH;IACO,UAAU,GAAA;AACjB,QAAA,IAAI,CAAC,MAAM,GAAG,IAAI,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,GAAG,CAAC,QAAQ,KAAI;YACpD,OAAO;gBACN,IAAI,EAAE,QAAQ,CAAC,IAAI;gBACnB,UAAU,EAAE,QAAQ,EAAE,UAAU,EAAE,GAAG,GAAG,CAAC,SAAS,KAAI;AACrD,oBAAA,MAAM,QAAQ,GACb,SAAS,CAAC,QAAQ,KAAK,SAAS;0BAC7B,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,QAAQ,CAAC;AACpC,0BAAE,EAAE,oBAAoB,EAAE,EAAE,EAAE,CAAC;oBACjC,MAAM,GAAG,GAAG,IAAI,CAAC,cAAc,CAAC,SAAS,EAAE,QAAQ,CAAC,CAAC;oBACrD,MAAM,IAAI,GAAG,IAAI,IAAI,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC;AACrC,oBAAA,IAAI,CAAC,IAAI,GAAG,QAAQ,CAAC,IAAI,CAAC;AAC1B,oBAAA,OAAO,IAAI,CAAC;AACb,iBAAC,CAAC;aACF,CAAC;AACH,SAAC,CAAC,CAAC;KACH;AACO,IAAA,UAAU,CAAC,WAAgB,EAAA;QAClC,OAAO,IAAI,OAAO,CAAC;YAClB,SAAS,EAAE,QAAQ,CAAC,WAAW,CAAC,SAAS,IAAI,IAAI,CAAkB;YACnE,SAAS,EAAE,QAAQ,CAAC,WAAW,CAAC,SAAS,IAAI,IAAI,CAAkB;YACnE,YAAY,EAAE,QAAQ,CAAC,WAAW,CAAC,KAAK,IAAI,KAAK,CAAmB;YACpE,YAAY,EAAE,QAAQ,CAAC,WAAW,CAAC,KAAK,IAAI,KAAK,CAAmB;AACpE,SAAA,CAAC,CAAC;KACH;IACO,aAAa,CAAC,QAAa,EAAE,CAAS,EAAA;QAC7C,MAAM,UAAU,GAAG,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC;AACzD,QAAA,MAAM,MAAM,GAAG,CAAC,UAAU,CAAC,UAAU,IAAI,CAAC,KAAK,QAAQ,CAAC,UAAU,IAAI,CAAC,CAAC,CAAC;AACzE,QAAA,MAAM,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,UAAU,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC;QAC3D,IAAI,KAAK,GAAG,aAAa,CACxB,QAAQ,CAAC,aAAa,EACtB,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,MAAM,CAAC,EAC/B,UAAU,CAAC,MAAM,KAAK,CAAC,GAAG,MAAM,GAAG,IAAI,CAAC,SAAS,GAAG,MAAM,EAC1D,CAAC,QAAQ,CAAC,KAAK,GAAG,CAAC,IAAI,MAAM,GAAG,CAAC,CACjC,CAAC;QACF,IAAI,MAAM,GAAG,CAAC,EAAE;AACf,YAAA,MAAM,qBAAqB,GAAG,KAAK,CAAC,WAEnC,CAAC;YACF,MAAM,OAAO,GAAG,IAAI,qBAAqB,CAAC,QAAQ,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC;YAC9D,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,MAAM,EAAE;AAC/D,gBAAA,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE;AAC9B,oBAAA,OAAO,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;AAC9B,iBAAA;AACD,aAAA;YACD,KAAK,GAAG,OAAO,CAAC;AAChB,SAAA;AACD,QAAA,OAAO,KAAK,CAAC;KACb;IACO,cAAc,CAAC,SAAS,EAAE,QAAQ,EAAA;QACzC,IAAI,OAAO,GAAG,IAAI,CAAC;QACnB,IAAI,QAAQ,GAAG,IAAI,CAAC;AACpB,QAAA,MAAM,OAAO,GAAyC,EAAE,UAAU,EAAE,IAAI,EAAE,CAAC;AAC3E,QAAA,IAAI,WAAW,CAAC;QAChB,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;AAC3D,QAAA,MAAM,SAAS,GAAG,QAAQ,CAAC,QAAQ,EAAE,CAAC;AACtC,QAAA,WAAW,GAAG,QAAQ,CAAC,KAAK,CAAC;;;AAG7B,QAAA,IAAI,SAAS,CAAC,OAAO,KAAK,SAAS,EAAE;YACpC,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;YAC/C,OAAO,GAAG,SAAS,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC,CAAC;AACzC,YAAA,WAAW,GAAG,QAAQ,CAAC,KAAK,CAAC;AAC7B,SAAA;AACD,QAAA,IAAI,OAAO,CAAC;AAEZ,QAAA,IAAI,SAAS,CAAC,UAAU,CAAC,MAAM,KAAK,SAAS,EAAE;YAC9C,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;AACzD,YAAA,OAAO,GAAG,QAAQ,CAAC,QAAQ,EAAE,CAAC;AAC9B,SAAA;AAAM,aAAA;AACN,YAAA,OAAO,GAAG,eAAe,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC;AAC9C,SAAA;QAED,IAAI,GAAG,GAAG,IAAI,CAAC;AACf,QAAA,IAAI,SAAS,CAAC,UAAU,CAAC,UAAU,KAAK,SAAS,EAAE;YAClD,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC;AAC7D,YAAA,GAAG,GAAG,QAAQ,CAAC,QAAQ,EAAE,CAAC;AAC1B,YAAA,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC;AACtB,SAAA;AAED,QAAA,IAAI,SAAS,CAAC,UAAU,CAAC,UAAU,KAAK,SAAS,EAAE;YAClD,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC;AAC7D,YAAO,QAAQ,CAAC,QAAQ,EAAE,CAAC;AAC3B,YAAA,OAAO,CAAC,OAAO,GAAG,IAAI,CAAC;AACvB,SAAA;AAGD,QAAA,IAAI,SAAS,CAAC,UAAU,CAAC,OAAO,KAAK,SAAS,IAAI,SAAS,CAAC,UAAU,CAAC,MAAM,KAAK,SAAS,EAAE;YAC5F,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;AAC1D,YAAW,QAAQ,CAAC,QAAQ,EAAE,CAAC;;AAE/B,SAAA;aAAM,IAAI,QAAQ,CAAC,aAAa,EAAE,CAElC;AACD,QAAA,IAAI,MAAM,GAAG,IAAI,EAChB,SAAS,GAAG,CAAC,CAAC;AACf,QAAA,IAAI,SAAS,CAAC,UAAU,CAAC,OAAO,KAAK,SAAS,EAAE;YAC/C,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;AACxD,YAAA,MAAM,GAAG,QAAQ,CAAC,QAAQ,EAAE,CAAC;AAC7B,YAAA,SAAS,GAAG,QAAQ,CAAC,IAAI,CAAC;AAC1B,YAAA,OAAO,CAAC,SAAS,GAAG,IAAI,CAAC;AACzB,SAAA;QACD,IAAI,MAAM,GAAG,IAAI,CAAC;AAClB,QAAA,IAAI,SAAS,CAAC,UAAU,CAAC,QAAQ,KAAK,SAAS,EAAE;YAChD,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;AAC3D,YAAA,MAAM,GAAG,QAAQ,CAAC,QAAQ,EAAE,CAAC;AAC7B,YAAA,OAAO,CAAC,QAAQ,GAAG,IAAI,CAAC;AACxB,SAAA;QACD,IAAI,OAAO,GAAG,IAAI,CAAC;AACnB,QAAA,IAAI,SAAS,CAAC,UAAU,CAAC,SAAS,KAAK,SAAS,EAAE;YACjD,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC;AAC5D,YAAA,OAAO,GAAG,QAAQ,CAAC,QAAQ,EAAE,CAAC;AAC9B,SAAA;QACD,MAAM,GAAG,GAAG,IAAI,QAAQ,CAAC,EAAE,IAAI,EAAE,YAAY,EAAE,CAAC,CAAC;AACjD,QAAA,IAAI,OAAO;YAAE,GAAG,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC;AAChD,QAAA,IAAI,SAAS;AAAE,YAAA,GAAG,CAAC,YAAY,CAAC,IAAI,gBAAgB,CAAC,UAAU,EAAE,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;AAC5F,QAAA,IAAI,OAAO;AAAE,YAAA,GAAG,CAAC,YAAY,CAAC,IAAI,gBAAgB,CAAC,QAAQ,EAAE,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;AACtF,QAAA,IAAI,MAAM;AAAE,YAAA,GAAG,CAAC,YAAY,CAAC,IAAI,gBAAgB,CAAC,OAAO,EAAE,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,SAAS,CAAC,CAAC,CAAC;AAC3F,QAAA,IAAI,GAAG;AAAE,YAAA,GAAG,CAAC,YAAY,CAAC,IAAI,gBAAgB,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;AAC1E,QAAA,IAAI,MAAM;AAAE,YAAA,GAAG,CAAC,YAAY,CAAC,IAAI,gBAAgB,CAAC,QAAQ,EAAE,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;AACpF,QAAA,IAAI,OAAO;AAAE,YAAA,GAAG,CAAC,YAAY,CAAC,IAAI,gBAAgB,CAAC,SAAS,EAAE,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;AACvF,QAAA,GAAG,CAAC,OAAO,GAAG,OAAO,CAAC;QACtB,GAAG,CAAC,qBAAqB,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC;AACjD,QAAA,GAAG,CAAC,KAAK,GAAG,WAAW,CAAC;AACxB,QAAA,OAAO,GAAG,CAAC;KACX;AACO,IAAA,aAAa,CAAC,MAAc,EAAA;QACnC,OAAO,IAAI,OAAO,CAAC;AAClB,YAAA,IAAI,EAAE;gBACL,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,KAAK;gBAChC,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,MAAM;AAClC,gBAAA,KAAK,EAAE,CAAC;AACR,aAAA;AACD,YAAA,IAAI,EAAE;AACL,gBAAA,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC;AAC3B,aAAA;AACD,YAAA,MAAM,EAAE,YAAY;YACpB,KAAK,EAAE,eAAe,CAAC,eAAe,GAAG,eAAe,CAAC,QAAQ,GAAG,eAAe,CAAC,iBAAiB;AACrG,SAAA,CAAC,CAAC;KACH;AACO,IAAA,MAAM,UAAU,GAAA;QACvB,MAAM,MAAM,GAAuB,EAAE,CAAC;AACtC,QAAA,IAAI,kBAAkB,GAAiB,OAAO,CAAC,OAAO,EAAE,CAAC;AACzD,QAAA,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;AACrB,YAAA,kBAAkB,GAAG,OAAO,CAAC,GAAG,CAC/B,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,OAAO,KAAU,EAAE,KAAa,KAAI;gBACxD,IAAI,KAAK,CAAC,GAAG,EAAE;AACd,oBAAA,MAAM,QAAQ,GAAG,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,OAAO,GAAG,KAAK,CAAC,GAAG,GAAG,CAAG,EAAA,IAAI,CAAC,OAAO,CAAI,CAAA,EAAA,KAAK,CAAC,GAAG,EAAE,CAAC;oBAChG,MAAM,CAAC,KAAK,CAAC,GAAG,MAAM,KAAK,CAAC,QAAQ,CAAC;yBACnC,IAAI,CAAC,CAAC,QAAQ,KAAK,QAAQ,CAAC,IAAI,EAAE,CAAC;yBACnC,IAAI,CAAC,CAAC,IAAI,KACV,iBAAiB,CAAC,IAAI,EAAE;AACvB,wBAAA,oBAAoB,EAAE,MAAM;AAC5B,qBAAA,CAAC,CACF,CAAC;AACH,iBAAA;aACD,CAAC,CACF,CAAC;AACF,SAAA;AACD,QAAA,IAAI,kBAAkB,GAAiB,OAAO,CAAC,OAAO,EAAE,CAAC;AACzD,QAAA,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;AACrB,YAAA,kBAAkB,GAAG,OAAO,CAAC,GAAG,CAC/B,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,OAAO,KAAU,EAAE,KAAa,KAAI;AACxD,gBAAA,IAAI,KAAK,CAAC,UAAU,KAAK,SAAS,EAAE;AACnC,oBAAA,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE,UAAU,EAAE,GAAG,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;AACnF,oBAAA,MAAM,KAAK,GAAG,IAAI,UAAU,CAC3B,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,EACpB,MAAM,KAAK,CAAC,GAAG,UAAU,GAAG,IAAI,CAAC,SAAS,GAAG,UAAU,EACvD,UAAU,CACV,CAAC;AACF,oBAAA,IAAI,IAAI,CAAC;oBACT,IAAI,KAAK,CAAC,QAAQ,EAAE;AACnB,wBAAA,IAAI,GAAG,KAAK,CAAC,QAAQ,CAAC;AACtB,qBAAA;AAAM,yBAAA;AACN,wBAAA,IAAI,GAAG,KAAK,CAAC,CAAC,CAAC,KAAK,IAAI,GAAG,YAAY,GAAG,WAAW,CAAC;AACtD,qBAAA;AACD,oBAAA,MAAM,IAAI,GAAG,IAAI,IAAI,CAAC,CAAC,KAAK,CAAC,EAAE,EAAE,IAAI,EAAE,CAAC,CAAC;oBACzC,MAAM,CAAC,KAAK,CAAC,GAAG,MAAM,iBAAiB,CAAC,IAAI,EAAE;AAC7C,wBAAA,oBAAoB,EAAE,MAAM;AAC5B,qBAAA,CAAC,CAAC;AACH,iBAAA;aACD,CAAC,CACF,CAAC;AACF,SAAA;QAED,MAAM,OAAO,CAAC,GAAG,CAAC,CAAC,kBAAkB,EAAE,kBAAkB,CAAC,CAAC,CAAC;AAC5D,QAAA,OAAO,MAAM,CAAC;KACd;AACO,IAAA,MAAM,UAAU,GAAA;QACvB,MAAM,OAAO,GAAuB,EAAE,CAAC;AACvC,QAAA,MAAM,OAAO,CAAC,GAAG,CAChB,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,MAAW,EAAE,KAAa,KAAI;AACpD,YAAA,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE;gBAChB,IAAI,KAAK,KAAK,CAAC,EAAE;AAChB,oBAAA,MAAM,IAAI,KAAK,CAAC,sBAAsB,CAAC,CAAC;AACxC,iBAAA;AACD,gBAAA,OAAO,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,MAAO,CAAC;AAC9B,gBAAA,OAAO,OAAO,CAAC,OAAO,EAAE,CAAC;AACzB,aAAA;AACD,YAAA,MAAM,SAAS,GAAG,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,OAAO,GAAG,MAAM,CAAC,GAAG,GAAG,CAAG,EAAA,IAAI,CAAC,OAAO,CAAI,CAAA,EAAA,MAAM,CAAC,GAAG,EAAE,CAAC;YACpG,OAAO,KAAK,CAAC,SAAS,CAAC;iBACrB,IAAI,CAAC,CAAC,QAAQ,KAAK,QAAQ,CAAC,WAAW,EAAE,CAAC;AAC1C,iBAAA,IAAI,CAAC,CAAC,WAAwB,KAAI;AAClC,gBAAA,OAAO,CAAC,KAAK,CAAC,GAAG,WAAW,CAAC;AAC9B,aAAC,CAAC,CAAC;SACJ,CAAC,CACF,CAAC;AACF,QAAA,OAAO,OAAO,CAAC;KACf;IACO,UAAU,GAAA;AACjB,QAAA,IAAI,CAAC,KAAK,GAAG,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,CAAC,CAAC,QAAQ,KAAI;AAChD,YAAA,MAAM,IAAI,GAAG,IAAI,IAAI,EAAE,CAAC;AACxB,YAAA,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;YAClC,IAAI,QAAQ,CAAC,IAAI;AAAE,gBAAA,IAAI,CAAC,IAAI,GAAG,QAAQ,CAAC,IAAI,CAAC;AAC7C,YAAA,IAAI,QAAQ,CAAC,IAAI,IAAI,SAAS,EAAE;AAC/B,gBAAA,IAAI,QAAQ,GAAG,SAAS,EACvB,UAAU,GAAG,KAAK,CAAC;AACpB,gBAAA,IAAI,QAAQ,CAAC,IAAI,IAAI,SAAS,EAAE;oBAC/B,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;oBAC1C,UAAU,GAAG,IAAI,CAAC;AAClB,iBAAA;AACD,gBAAA,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,SAAe,EAAE,KAAa,EAAE,MAAmB,KAAI;oBACrG,MAAM,aAAa,GAClB,UAAU,IAAI,SAAS,CAAC,IAAI,IAAI,gBAAgB,CAAC,IAAI;0BAClD,IAAI,QAAQ,CAAC,SAAS,CAAC,QAAQ,EAAE,SAAS,CAAC,QAAQ,CAAC;0BACpD,SAAS,CAAC;oBACd,IAAI,UAAU,IAAI,SAAS,CAAC,IAAI,IAAI,gBAAgB,CAAC,IAAI,EAAE;AAC1D,wBAAA,MAAM,CAAC,KAAK,CAAC,GAAG,aAAa,CAAC;wBAC9B,aAAa,CAAC,WAAW,CAAC;4BACzB,mBAAmB,EAAE,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,mBAAmB,CAAC,CAAC,YAAY,EAAE;4BAClF,MAAM,EAAE,QAAQ,CAAC,MAAM;;;AAGvB,yBAAA,CAAC,CAAC;AACH,qBAAA;AACD,oBAAA,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC;AACzB,iBAAC,CAAC,CAAC;AACH,aAAA;AACD,YAAA,OAAO,IAAI,CAAC;AACb,SAAC,CAAC,CAAC;KACH;IACO,YAAY,CAAC,IAAU,EAAE,QAAuB,EAAA;QACvD,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,WAAW,EAAE,KAAK,EAAE,GAAG,QAAQ,CAAC;AACxD,QAAA,IAAI,MAAM,EAAE;YACX,MAAM,WAAW,GAAG,IAAI,OAAO,EAAE,EAChC,SAAS,GAAG,IAAI,OAAO,EAAE,EACzB,eAAe,GAAG,IAAI,OAAO,EAAE,EAC/B,YAAY,GAAG,IAAI,UAAU,EAAE,CAAC;AACjC,YAAA,OAAO,CAAC,oBAAoB,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;AAClD,YAAA,OAAO,CAAC,QAAQ,CAAC,WAAW,EAAE,SAAS,CAAC,CAAC;AACzC,YAAA,OAAO,CAAC,cAAc,CAAC,WAAW,EAAE,eAAe,CAAC,CAAC;AACrD,YAAA,OAAO,CAAC,WAAW,CAAC,WAAW,EAAE,YAAY,CAAC,CAAC;AAC/C,YAAA,QAAQ,GAAG,YAAY,CAAC,OAAO,EAAE,CAAC;AAClC,YAAA,WAAW,GAAG,eAAe,CAAC,OAAO,EAAE,CAAC;AACxC,YAAA,KAAK,GAAG,SAAS,CAAC,OAAO,EAAE,CAAC;AAC5B,SAAA;AACD,QAAA,IAAI,QAAQ;YAAE,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC;AACtF,QAAA,IAAI,WAAW;YAAE,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE,WAAW,CAAC,CAAC,CAAC,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;AACnF,QAAA,IAAI,KAAK;YAAE,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;AACxD,QAAA,OAAO,IAAI,CAAC;KACZ;IACO,aAAa,GAAA;QACpB,IAAI,EAAE,KAAK,EAAE,GAAG,GAAG,CAAC,IAAU,EAAE,KAAK,KAAI;AACxC,YAAA,IAAI,CAAC,IAAI,EAAE,KAAK,CAAC,KAAK,CAAC,EAAE,QAAQ,EAAE,GAAG,CAAC,CAAC,MAAc,KAAI;gBACzD,MAAM,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;AACrC,gBAAA,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;AACrB,aAAC,CAAC,CAAC;AACJ,SAAC,CAAC,CAAC;QACH,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,KAAI;YACxB,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,SAAS,KAAI;AACjC,gBAAA,IAAI,SAAS,CAAC,IAAI,IAAI,gBAAgB,CAAC,QAAQ;AAC9C,oBAAA,SAAS,CAAC,MAAM,GAAG,SAAS,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,KAAI;AACjD,wBAAA,OAAO,IAAI,CAAC,KAAK,CAAS,KAAK,CAAC,CAAC;AAClC,qBAAC,CAAC,CAAC;AACL,aAAC,CAAC,CAAC;AACJ,SAAC,CAAC,CAAC;KACH;AACD,CAAA;AACM,eAAe,QAAQ,CAAC,GAAW,EAAA;AACzC,IAAA,IAAI,IAAI,CAAC;IACT,MAAM,GAAG,GAAG,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC;AACjC,IAAA,MAAM,OAAO,GAAG,GAAG,CAAC,SAAS,CAAC,CAAC,EAAE,GAAG,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC;IACvD,IAAI,GAAG,KAAK,MAAM,EAAE;QACnB,MAAM,IAAI,GAAG,MAAM,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC,QAAQ,KAAK,QAAQ,CAAC,IAAI,EAAE,CAAC,CAAC;QAClE,IAAI,GAAG,IAAI,IAAI,CAAC,IAAI,EAAE,OAAO,EAAE,CAAC,CAAC,CAAC;AAClC,KAAA;AAAM,SAAA;QACN,MAAM,GAAG,GAAG,MAAM,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC,QAAQ,KAAK,QAAQ,CAAC,WAAW,EAAE,CAAC,CAAC;AACxE,QAAA,MAAM,UAAU,GAAG,IAAI,WAAW,CAAC,GAAG,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAClD,MAAM,SAAS,GAAG,IAAI,UAAU,CAAC,GAAG,EAAE,EAAE,EAAE,UAAU,CAAC,CAAC;AACtD,QAAA,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,WAAW,CAAC,OAAO,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC;AACpE,QAAA,IAAI,GAAG,IAAI,IAAI,CAAC,IAAI,EAAE,OAAO,EAAE,EAAE,GAAG,UAAU,EAAE,GAAG,CAAC,CAAC;AACrD,KAAA;AACD,IAAA,MAAM,IAAI,CAAC,SAAS,EAAE,CAAC;AACvB,IAAA,OAAO,IAAI,CAAC;AACb;;ACvdO,eAAe,WAAW,CAAC,GAAG,EAAA;IACpC,MAAM,GAAG,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;AAC1C,IAAA,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC;AACd,IAAA,MAAM,GAAG,CAAC,MAAM,EAAE,CAAC;AACnB,IAAA,MAAM,WAAW,GAAG,MAAM,iBAAiB,CAAC,GAAG,CAAC,CAAC;AACjD,IAAA,MAAM,WAAW,GAAG,IAAI,OAAO,CAAC;AAC/B,QAAA,IAAI,EAAE,EAAE,KAAK,EAAE,WAAW,CAAC,KAAK,EAAE,MAAM,EAAE,WAAW,CAAC,MAAM,EAAE,KAAK,EAAE,CAAC,EAAE;AACxE,QAAA,IAAI,EAAE;AACL,YAAA,MAAM,EAAE,WAAW;AACnB,SAAA;AACD,QAAA,MAAM,EAAE,YAAY;AACpB,KAAA,CAAC,CAAC;AACH,IAAA,OAAO,WAAW,CAAC;AACpB;;ACxDA;AACA,MAAM,SAAS,CAAA;IAKd,WAAY,CAAA,MAAM,GAAG,CAAC,EAAE,GAAG,GAAG,CAAC,EAAE,KAAK,GAAG,CAAC,EAAA;AACzC,QAAA,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;AACrB,QAAA,IAAI,CAAC,GAAG,GAAG,GAAG,CAAC;AACf,QAAA,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;AAEnB,QAAA,OAAO,IAAI,CAAC;KACZ;AACD,IAAA,GAAG,CAAC,MAAc,EAAE,GAAW,EAAE,KAAa,EAAA;AAC7C,QAAA,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;AACrB,QAAA,IAAI,CAAC,GAAG,GAAG,GAAG,CAAC;AACf,QAAA,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;AAEnB,QAAA,OAAO,IAAI,CAAC;KACZ;AACD,IAAA,IAAI,CAAC,KAAgB,EAAA;AACpB,QAAA,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC;AAC3B,QAAA,IAAI,CAAC,GAAG,GAAG,KAAK,CAAC,GAAG,CAAC;AACrB,QAAA,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC;AAEzB,QAAA,OAAO,IAAI,CAAC;KACZ;;IAED,QAAQ,GAAA;QACP,MAAM,GAAG,GAAG,QAAQ,CAAC;QACrB,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,GAAG,GAAG,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;AAE5D,QAAA,OAAO,IAAI,CAAC;KACZ;AAED,IAAA,cAAc,CAAC,CAAU,EAAA;AACxB,QAAA,OAAO,IAAI,CAAC,sBAAsB,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;KAClD;AACD,IAAA,sBAAsB,CAAC,CAAS,EAAE,CAAS,EAAE,CAAS,EAAA;AACrD,QAAA,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC;AAE/C,QAAA,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC,EAAE;AACtB,YAAA,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC;AACf,YAAA,IAAI,CAAC,GAAG,GAAG,CAAC,CAAC;AACb,SAAA;AAAM,aAAA;YACN,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;YAC9B,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;AAC1D,SAAA;AAED,QAAA,OAAO,IAAI,CAAC;KACZ;IAED,KAAK,GAAA;AACJ,QAAA,OAAO,IAAI,SAAS,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;KACxD;AACD;;ACpDD;AAEA,MAAM,YAAY,GAAG,EAAE,IAAI,EAAE,QAAQ,EAAE,CAAC;AACxC,MAAM,WAAW,GAAG,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC;AACtC,MAAM,SAAS,GAAG,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC;AAEb,MAAA,YAAa,SAAQ,eAAe,CAAA;IAyCvD,WAAY,CAAA,MAAM,EAAE,UAAU,EAAA;AAC5B,QAAA,KAAK,EAAE,CAAC;QAER,IAAI,UAAU,KAAK,SAAS;AAC1B,YAAA,OAAO,CAAC,IAAI,CACV,oEAAoE,CACrE,CAAC;QACJ,IAAI,UAAU,KAAK,QAAQ;AACzB,YAAA,OAAO,CAAC,KAAK,CACX,oHAAoH,CACrH,CAAC;AAEJ,QAAA,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;AACrB,QAAA,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;QAC7B,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,WAAW,GAAG,MAAM,CAAC;;AAG3C,QAAA,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;;AAGpB,QAAA,IAAI,CAAC,MAAM,GAAG,IAAI,OAAO,EAAE,CAAC;;AAG5B,QAAA,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC;AACrB,QAAA,IAAI,CAAC,WAAW,GAAG,QAAQ,CAAC;;AAG5B,QAAA,IAAI,CAAC,OAAO,GAAG,CAAC,CAAC;AACjB,QAAA,IAAI,CAAC,OAAO,GAAG,QAAQ,CAAC;;;AAIxB,QAAA,IAAI,CAAC,aAAa,GAAG,CAAC,CAAC;QACvB,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,EAAE,CAAC;;;AAI7B,QAAA,IAAI,CAAC,eAAe,GAAG,CAAC,QAAQ,CAAC;AACjC,QAAA,IAAI,CAAC,eAAe,GAAG,QAAQ,CAAC;;;AAIhC,QAAA,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;AAC3B,QAAA,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;;;AAI1B,QAAA,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;AACvB,QAAA,IAAI,CAAC,SAAS,GAAG,GAAG,CAAC;;AAGrB,QAAA,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;AACzB,QAAA,IAAI,CAAC,WAAW,GAAG,GAAG,CAAC;;AAGvB,QAAA,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;AACtB,QAAA,IAAI,CAAC,QAAQ,GAAG,GAAG,CAAC;AACpB,QAAA,IAAI,CAAC,kBAAkB,GAAG,KAAK,CAAC;AAChC,QAAA,IAAI,CAAC,WAAW,GAAG,GAAG,CAAC;;;AAIvB,QAAA,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;AACxB,QAAA,IAAI,CAAC,eAAe,GAAG,GAAG,CAAC;;QAG3B,IAAI,CAAC,IAAI,GAAG;AACV,YAAA,IAAI,EAAE,WAAW;AACjB,YAAA,EAAE,EAAE,SAAS;AACb,YAAA,KAAK,EAAE,YAAY;AACnB,YAAA,MAAM,EAAE,WAAW;SACpB,CAAC;;QAGF,IAAI,CAAC,YAAY,GAAG;YAClB,IAAI,EAAE,KAAK,CAAC,MAAM;YAClB,MAAM,EAAE,KAAK,CAAC,KAAK;YACnB,KAAK,EAAE,KAAK,CAAC,GAAG;SACjB,CAAC;;AAGF,QAAA,IAAI,CAAC,OAAO,GAAG,EAAE,GAAG,EAAE,KAAK,CAAC,MAAM,EAAE,GAAG,EAAE,KAAK,CAAC,SAAS,EAAE,CAAC;;QAG3D,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC;QACnC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC;QAC9C,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC;;AAG9B,QAAA,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC;;;;;QAMjC,MAAM,IAAI,GAAG,IAAI,CAAC;QAClB,IAAI,CAAC,MAAM,GAAG,CAAC,YAAA;AACb,YAAA,MAAM,MAAM,GAAG,IAAI,OAAO,EAAE,CAAC;;YAE7B,MAAM,IAAI,GAAG,IAAI,UAAU,EAAE,CAAC,kBAAkB,CAC9C,IAAI,CAAC,MAAM,CAAC,EAAE,EACd,IAAI,OAAO,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CACrB,CAAC;YACF,MAAM,WAAW,GAAG,IAAI,CAAC,KAAK,EAAE,CAAC,MAAM,EAAE,CAAC;AAE1C,YAAA,MAAM,YAAY,GAAG,IAAI,OAAO,EAAE,CAAC;AACnC,YAAA,MAAM,cAAc,GAAG,IAAI,UAAU,EAAE,CAAC;AAExC,YAAA,MAAM,KAAK,GAAG,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC;AAC1B,YAAA,OAAO,SAAS,MAAM,GAAA;AACpB,gBAAA,MAAM,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC;AAEtC,gBAAA,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;;AAG5C,gBAAA,MAAM,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;;AAG7B,gBAAA,SAAS,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC;gBAEjC,IAAI,IAAI,CAAC,UAAU,IAAI,KAAK,KAAK,KAAK,CAAC,IAAI,EAAE;AAC3C,oBAAA,UAAU,CAAC,IAAI,CAAC,oBAAoB,EAAE,CAAC,CAAC;AACzC,iBAAA;gBAED,IAAI,IAAI,CAAC,aAAa,EAAE;oBACtB,SAAS,CAAC,KAAK,IAAI,cAAc,CAAC,KAAK,GAAG,IAAI,CAAC,aAAa,CAAC;oBAC7D,SAAS,CAAC,GAAG,IAAI,cAAc,CAAC,GAAG,GAAG,IAAI,CAAC,aAAa,CAAC;AAC1D,iBAAA;AAAM,qBAAA;AACL,oBAAA,SAAS,CAAC,KAAK,IAAI,cAAc,CAAC,KAAK,CAAC;AACxC,oBAAA,SAAS,CAAC,GAAG,IAAI,cAAc,CAAC,GAAG,CAAC;AACrC,iBAAA;;AAID,gBAAA,IAAI,GAAG,GAAG,IAAI,CAAC,eAAe,CAAC;AAC/B,gBAAA,IAAI,GAAG,GAAG,IAAI,CAAC,eAAe,CAAC;gBAE/B,IAAI,QAAQ,CAAC,GAAG,CAAC,IAAI,QAAQ,CAAC,GAAG,CAAC,EAAE;AAClC,oBAAA,IAAI,GAAG,GAAG,CAAC,IAAI,CAAC,EAAE;wBAAE,GAAG,IAAI,KAAK,CAAC;AAC5B,yBAAA,IAAI,GAAG,GAAG,IAAI,CAAC,EAAE;wBAAE,GAAG,IAAI,KAAK,CAAC;AAErC,oBAAA,IAAI,GAAG,GAAG,CAAC,IAAI,CAAC,EAAE;wBAAE,GAAG,IAAI,KAAK,CAAC;AAC5B,yBAAA,IAAI,GAAG,GAAG,IAAI,CAAC,EAAE;wBAAE,GAAG,IAAI,KAAK,CAAC;oBAErC,IAAI,GAAG,IAAI,GAAG,EAAE;wBACd,SAAS,CAAC,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC;AACjE,qBAAA;AAAM,yBAAA;AACL,wBAAA,SAAS,CAAC,KAAK;4BACb,SAAS,CAAC,KAAK,GAAG,CAAC,GAAG,GAAG,GAAG,IAAI,CAAC;kCAC7B,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,SAAS,CAAC,KAAK,CAAC;kCAC9B,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,SAAS,CAAC,KAAK,CAAC,CAAC;AACtC,qBAAA;AACF,iBAAA;;gBAGD,SAAS,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,CACtB,IAAI,CAAC,aAAa,EAClB,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,aAAa,EAAE,SAAS,CAAC,GAAG,CAAC,CAC5C,CAAC;gBAEF,SAAS,CAAC,QAAQ,EAAE,CAAC;AAErB,gBAAA,SAAS,CAAC,MAAM,IAAI,KAAK,CAAC;;gBAG1B,SAAS,CAAC,MAAM,GAAG,IAAI,CAAC,GAAG,CACzB,IAAI,CAAC,WAAW,EAChB,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,WAAW,EAAE,SAAS,CAAC,MAAM,CAAC,CAC7C,CAAC;;AAIF,gBAAA,IAAI,IAAI,CAAC,aAAa,KAAK,IAAI,EAAE;oBAC/B,IAAI,CAAC,MAAM,CAAC,eAAe,CAAC,SAAS,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;AAC5D,iBAAA;AAAM,qBAAA;AACL,oBAAA,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;AAC5B,iBAAA;AACD,gBAAA,OAAO,CAAC,aAAa,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC;;AAEzC,gBAAA,MAAM,CAAC,eAAe,CAAC,WAAW,CAAC,CAAC;AAEpC,gBAAA,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;gBAEvC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;AAEhE,gBAAA,IAAI,IAAI,CAAC,aAAa,KAAK,IAAI,EAAE;oBAC/B,cAAc,CAAC,KAAK,IAAI,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC;oBAC/C,cAAc,CAAC,GAAG,IAAI,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC;AAE7C,oBAAA,OAAO,CAAC,gBAAgB,CACtB,SAAS,EACT,CAAC,GAAG,IAAI,CAAC,aAAa,EACtB,SAAS,CACV,CAAC;;AAEH,iBAAA;AAAM,qBAAA;oBACL,cAAc,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;oBAE5B,SAAS,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;AACxB,iBAAA;gBAED,KAAK,GAAG,CAAC,CAAC;;;;AAMV,gBAAA,IACE,WAAW;AACX,oBAAA,OAAO,CAAC,eAAe,CAAC,YAAY,EAAE,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,GAAG,GAAG;AACjE,oBAAA,CAAC,IAAI,CAAC,GAAG,cAAc,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,GAAG,GAAG,EAC1D;AACA,oBAAA,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,CAAC;;oBAGjC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,YAAY,CAAC,CAAC;oBAClD,UAAU,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE,cAAc,CAAC,CAAC;;oBAEzD,WAAW,GAAG,KAAK,CAAC;AAEpB,oBAAA,OAAO,IAAI,CAAC;AACb,iBAAA;AAED,gBAAA,OAAO,KAAK,CAAC;AACf,aAAC,CAAC;SACH,GAAG,CAAC;QACL,IAAI,CAAC,IAAI,EAAE,CAAC;KACb;IACD,aAAa,GAAA;AACX,QAAA,OAAO,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC;KAC3B;IACD,iBAAiB,GAAA;AACf,QAAA,OAAO,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC;KAC7B;IAED,WAAW,GAAA;AACT,QAAA,OAAO,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;KAC5D;AAED,IAAA,iBAAiB,CAAC,UAAU,EAAA;QAC1B,UAAU,CAAC,gBAAgB,CAAC,SAAS,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;AACvD,QAAA,IAAI,CAAC,oBAAoB,GAAG,UAAU,CAAC;KACxC;IAED,SAAS,GAAA;QACP,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;;AAEzC,QAAA,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;;QAEpD,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC;KAC/B;IAED,KAAK,GAAA;QACH,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;;AAEzC,QAAA,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;;QAEpD,IAAI,CAAC,MAAM,CAAC,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC;AAE9B,QAAA,IAAI,CAAC,MAAM,CAAC,sBAAsB,EAAE,CAAC;AACrC,QAAA,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,CAAC;QAEjC,IAAI,CAAC,MAAM,EAAE,CAAC;AAEd,QAAA,KAAK,GAAG,KAAK,CAAC,IAAI,CAAC;KACpB;IAEO,IAAI,GAAA;QACV,MAAM,IAAI,GAAG,IAAI,CAAC;QAClB,MAAM,OAAO,GAAG,CAAC,YAAA;AACf,YAAA,MAAM,CAAC,GAAG,IAAI,OAAO,EAAE,CAAC;AACxB,YAAA,OAAO,SAAS,OAAO,CAAC,QAAQ,EAAE,YAAY,EAAA;gBAC5C,CAAC,CAAC,mBAAmB,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC;AACvC,gBAAA,CAAC,CAAC,gBAAgB,CAAC,CAAC,QAAQ,CAAC,CAAC;AAC9B,gBAAA,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;AACnB,aAAC,CAAC;SACH,GAAG,CAAC;QACL,MAAM,KAAK,GAAG,CAAC,YAAA;AACb,YAAA,MAAM,MAAM,GAAG,IAAI,OAAO,EAAE,CAAC;AAC7B,YAAA,OAAO,SAAS,KAAK,CAAC,QAAQ,EAAE,YAAY,EAAA;AAC1C,gBAAA,IAAI,IAAI,CAAC,kBAAkB,KAAK,IAAI,EAAE;AACpC,oBAAA,MAAM,CAAC,mBAAmB,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC;AAC7C,iBAAA;AAAM,qBAAA;AACL,oBAAA,MAAM,CAAC,mBAAmB,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC;;AAE5C,oBAAA,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC;AAC/C,iBAAA;AAED,gBAAA,MAAM,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CAAC;AAElC,gBAAA,SAAS,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;AACxB,aAAC,CAAC;SACH,GAAG,CAAC;;QAEL,MAAM,GAAG,GAAG,CAAC,YAAA;AACX,YAAA,MAAM,MAAM,GAAG,IAAI,OAAO,EAAE,CAAC;AAC7B,YAAA,OAAO,SAAS,GAAG,CAAC,MAAM,EAAE,MAAM,EAAA;AAChC,gBAAA,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC;AAChC,gBAAA,IAAI,IAAI,CAAC,MAAM,CAAC,mBAAmB,EAAE;;AAEnC,oBAAA,MAAM,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC;AACtC,oBAAA,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;AAC5C,oBAAA,IAAI,cAAc,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC;;oBAGrC,cAAc,IAAI,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,GAAG,CAAC,IAAI,IAAI,CAAC,EAAE,IAAI,KAAK,CAAC,CAAC;;AAGtE,oBAAA,OAAO,CACL,CAAC,CAAC,GAAG,MAAM,GAAG,cAAc,IAAI,OAAO,CAAC,YAAY,EACpD,IAAI,CAAC,MAAM,CAAC,WAAW,CACxB,CAAC;AACF,oBAAA,KAAK,CACH,CAAC,CAAC,GAAG,MAAM,GAAG,cAAc,IAAI,OAAO,CAAC,YAAY,EACpD,IAAI,CAAC,MAAM,CAAC,WAAW,CACxB,CAAC;AACH,iBAAA;AAAM,qBAAA,IAAI,IAAI,CAAC,MAAM,CAAC,oBAAoB,EAAE;;AAE3C,oBAAA,OAAO,CACL,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC;wBAC9C,IAAI,CAAC,MAAM,CAAC,IAAI;wBAChB,OAAO,CAAC,WAAW,EACrB,IAAI,CAAC,MAAM,CAAC,WAAW,CACxB,CAAC;AACF,oBAAA,KAAK,CACH,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,CAAC,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC;wBAC9C,IAAI,CAAC,MAAM,CAAC,IAAI;wBAChB,OAAO,CAAC,YAAY,EACtB,IAAI,CAAC,MAAM,CAAC,WAAW,CACxB,CAAC;AACH,iBAAA;AAAM,qBAAA;;AAEL,oBAAA,OAAO,CAAC,IAAI,CACV,8EAA8E,CAC/E,CAAC;AACF,oBAAA,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;AACxB,iBAAA;AACH,aAAC,CAAC;SACH,GAAG,CAAC;AACL,QAAA,MAAM,QAAQ,GAAG,CAAC,UAAU,KAAI;AAC9B,YAAA,IAAI,IAAI,CAAC,MAAM,CAAC,mBAAmB,EAAE;gBACnC,KAAK,IAAI,UAAU,CAAC;AACrB,aAAA;AAAM,iBAAA,IAAI,IAAI,CAAC,MAAM,CAAC,oBAAoB,EAAE;AAC3C,gBAAA,IAAI,CAAC,MAAM,CAAC,IAAI,GAAG,IAAI,CAAC,GAAG,CACzB,IAAI,CAAC,OAAO,EACZ,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,MAAM,CAAC,IAAI,GAAG,UAAU,CAAC,CACtD,CAAC;AACF,gBAAA,IAAI,CAAC,MAAM,CAAC,sBAAsB,EAAE,CAAC;gBACrC,WAAW,GAAG,IAAI,CAAC;AACpB,aAAA;AAAM,iBAAA;AACL,gBAAA,OAAO,CAAC,IAAI,CACV,qFAAqF,CACtF,CAAC;AACF,gBAAA,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;AACzB,aAAA;AACH,SAAC,CAAC;AAEF,QAAA,MAAM,OAAO,GAAG,CAAC,UAAU,KAAI;AAC7B,YAAA,IAAI,IAAI,CAAC,MAAM,CAAC,mBAAmB,EAAE;gBACnC,KAAK,IAAI,UAAU,CAAC;AACrB,aAAA;AAAM,iBAAA,IAAI,IAAI,CAAC,MAAM,CAAC,oBAAoB,EAAE;AAC3C,gBAAA,IAAI,CAAC,MAAM,CAAC,IAAI,GAAG,IAAI,CAAC,GAAG,CACzB,IAAI,CAAC,OAAO,EACZ,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,MAAM,CAAC,IAAI,GAAG,UAAU,CAAC,CACtD,CAAC;AACF,gBAAA,IAAI,CAAC,MAAM,CAAC,sBAAsB,EAAE,CAAC;gBACrC,WAAW,GAAG,IAAI,CAAC;AACpB,aAAA;AAAM,iBAAA;AACL,gBAAA,OAAO,CAAC,IAAI,CACV,qFAAqF,CACtF,CAAC;AACF,gBAAA,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;AACzB,aAAA;AACH,SAAC,CAAC;AACF,QAAA,MAAM,qBAAqB,GAAG,CAAC,KAAK,KAAI;YACtC,SAAS,CAAC,GAAG,CAAC,KAAK,CAAC,OAAO,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC;YAE5C,OAAO,CAAC,QAAQ,CAAC,SAAS,EAAE,WAAW,EAAE,WAAW,CAAC,CAAC;YACtD,OAAO,CAAC,gBAAgB,CAAC,WAAW,EAAE,IAAI,CAAC,WAAW,EAAE,WAAW,CAAC,CAAC;;AAGrE,YAAA,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC;AAEhC,YAAA,UAAU,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,EAAE,GAAG,WAAW,CAAC,CAAC,IAAI,OAAO,CAAC,YAAY,CAAC,CAAC;AAEjE,YAAA,QAAQ,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,EAAE,GAAG,WAAW,CAAC,CAAC,IAAI,OAAO,CAAC,YAAY,CAAC,CAAC;AAE/D,YAAA,OAAO,CAAC,KAAK,CAAC,SAAS,EAAE,WAAW,CAAC,CAAC;;YAGtC,IAAI,CAAC,MAAM,EAAE,CAAC;AAChB,SAAC,CAAC;AAEF,QAAA,MAAM,oBAAoB,GAAG,CAAC,KAAK,KAAI;YACrC,QAAQ,CAAC,GAAG,CAAC,KAAK,CAAC,OAAO,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC;YAE3C,OAAO,CAAC,QAAQ,CAAC,QAAQ,EAAE,UAAU,EAAE,UAAU,CAAC,CAAC;;AAGnD,YAAA,IAAI,UAAU,CAAC,CAAC,GAAG,CAAC,EAAE;AACpB,gBAAA,QAAQ,CAAC,YAAY,EAAE,CAAC,CAAC;AAC1B,aAAA;AAAM,iBAAA,IAAI,UAAU,CAAC,CAAC,GAAG,CAAC,EAAE;AAC3B,gBAAA,OAAO,CAAC,YAAY,EAAE,CAAC,CAAC;AACzB,aAAA;AAED,YAAA,OAAO,CAAC,KAAK,CAAC,QAAQ,EAAE,UAAU,CAAC,CAAC;;YAGpC,IAAI,CAAC,MAAM,EAAE,CAAC;AAChB,SAAC,CAAC;AAEF,QAAA,MAAM,kBAAkB,GAAG,CAAC,KAAK,KAAI;YACnC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,OAAO,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC;YAEzC,OAAO,CAAC,QAAQ,CAAC,MAAM,EAAE,QAAQ,EAAE,QAAQ,CAAC,CAAC;YAC7C,OAAO,CAAC,gBAAgB,CAAC,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;;YAG5D,GAAG,CAAC,QAAQ,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC,CAAC,CAAC;AAE5B,YAAA,OAAO,CAAC,KAAK,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;;YAGhC,IAAI,CAAC,MAAM,EAAE,CAAC;AAChB,SAAC,CAAC;AAEF,QAAA,MAAM,gBAAgB,GAAG,CAAC,KAAK,KAAI;AACjC,YAAA,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE;AACpB,gBAAA,OAAO,CAAC,YAAY,EAAE,CAAC,CAAC;AACzB,aAAA;AAAM,iBAAA,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE;AAC3B,gBAAA,QAAQ,CAAC,YAAY,EAAE,CAAC,CAAC;AAC1B,aAAA;YAED,IAAI,CAAC,MAAM,EAAE,CAAC;AAChB,SAAC,CAAC;AAEF,QAAA,MAAM,aAAa,GAAG,CAAC,KAAK,KAAI;YAC9B,IAAI,WAAW,GAAG,KAAK,CAAC;YAExB,QAAQ,KAAK,CAAC,IAAI;AAChB,gBAAA,KAAK,IAAI,CAAC,IAAI,CAAC,EAAE;AACf,oBAAA,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;oBACzB,WAAW,GAAG,IAAI,CAAC;oBACnB,MAAM;AAER,gBAAA,KAAK,IAAI,CAAC,IAAI,CAAC,MAAM;oBACnB,GAAG,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;oBAC1B,WAAW,GAAG,IAAI,CAAC;oBACnB,MAAM;AAER,gBAAA,KAAK,IAAI,CAAC,IAAI,CAAC,IAAI;AACjB,oBAAA,GAAG,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC;oBACzB,WAAW,GAAG,IAAI,CAAC;oBACnB,MAAM;AAER,gBAAA,KAAK,IAAI,CAAC,IAAI,CAAC,KAAK;oBAClB,GAAG,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC;oBAC1B,WAAW,GAAG,IAAI,CAAC;oBACnB,MAAM;AACT,aAAA;AAED,YAAA,IAAI,WAAW,EAAE;;gBAEf,KAAK,CAAC,cAAc,EAAE,CAAC;gBAEvB,IAAI,CAAC,MAAM,EAAE,CAAC;AACf,aAAA;AACH,SAAC,CAAC;QAEF,MAAM,wBAAwB,GAAG,MAAK;YACpC,IAAI,IAAI,CAAC,UAAU;AAAE,gBAAA,qBAAqB,EAAE,CAAC;YAE7C,IAAI,IAAI,CAAC,SAAS;AAAE,gBAAA,mBAAmB,EAAE,CAAC;AAC5C,SAAC,CAAC;QACF,MAAM,2BAA2B,GAAG,MAAK;YACvC,IAAI,IAAI,CAAC,UAAU;AAAE,gBAAA,qBAAqB,EAAE,CAAC;YAE7C,IAAI,IAAI,CAAC,YAAY;AAAE,gBAAA,sBAAsB,EAAE,CAAC;AAClD,SAAC,CAAC;AAEF,QAAA,MAAM,qBAAqB,GAAG,CAAC,KAAK,KAAI;AACtC,YAAA,IAAI,QAAQ,CAAC,MAAM,IAAI,CAAC,EAAE;gBACxB,SAAS,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,EAAE,KAAK,CAAC,KAAK,CAAC,CAAC;AACzC,aAAA;AAAM,iBAAA;AACL,gBAAA,MAAM,QAAQ,GAAG,wBAAwB,CAAC,KAAK,CAAC,CAAC;AAEjD,gBAAA,MAAM,CAAC,GAAG,GAAG,IAAI,KAAK,CAAC,KAAK,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;AAC3C,gBAAA,MAAM,CAAC,GAAG,GAAG,IAAI,KAAK,CAAC,KAAK,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;AAE3C,gBAAA,SAAS,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;AACrB,aAAA;YAED,OAAO,CAAC,QAAQ,CAAC,SAAS,EAAE,WAAW,EAAE,WAAW,CAAC,CAAC;YACtD,OAAO,CAAC,gBAAgB,CAAC,WAAW,EAAE,IAAI,CAAC,WAAW,EAAE,WAAW,CAAC,CAAC;;AAGrE,YAAA,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC;AAEhC,YAAA,UAAU,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,EAAE,GAAG,WAAW,CAAC,CAAC,IAAI,OAAO,CAAC,YAAY,CAAC,CAAC;AAEjE,YAAA,QAAQ,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,EAAE,GAAG,WAAW,CAAC,CAAC,IAAI,OAAO,CAAC,YAAY,CAAC,CAAC;AAC/D,YAAA,OAAO,CAAC,KAAK,CAAC,SAAS,EAAE,WAAW,CAAC,CAAC;;AAExC,SAAC,CAAC;AAEF,QAAA,MAAM,kBAAkB,GAAG,CAAC,KAAK,KAAI;AACnC,YAAA,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE;gBACzB,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,EAAE,KAAK,CAAC,KAAK,CAAC,CAAC;AACtC,aAAA;AAAM,iBAAA;AACL,gBAAA,MAAM,QAAQ,GAAG,wBAAwB,CAAC,KAAK,CAAC,CAAC;AAEjD,gBAAA,MAAM,CAAC,GAAG,GAAG,IAAI,KAAK,CAAC,KAAK,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;AAC3C,gBAAA,MAAM,CAAC,GAAG,GAAG,IAAI,KAAK,CAAC,KAAK,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;AAE3C,gBAAA,MAAM,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;AAClB,aAAA;YACD,OAAO,CAAC,QAAQ,CAAC,MAAM,EAAE,QAAQ,EAAE,QAAQ,CAAC,CAAC;YAC7C,OAAO,CAAC,gBAAgB,CAAC,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;;YAI5D,GAAG,CAAC,QAAQ,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC,CAAC,CAAC;AAE5B,YAAA,OAAO,CAAC,KAAK,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;;AAElC,SAAC,CAAC;AAEF,QAAA,MAAM,oBAAoB,GAAG,CAAC,KAAK,KAAI;AACrC,YAAA,MAAM,QAAQ,GAAG,wBAAwB,CAAC,KAAK,CAAC,CAAC;YAEjD,MAAM,EAAE,GAAG,KAAK,CAAC,KAAK,GAAG,QAAQ,CAAC,CAAC,CAAC;YACpC,MAAM,EAAE,GAAG,KAAK,CAAC,KAAK,GAAG,QAAQ,CAAC,CAAC,CAAC;AAEpC,YAAA,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC,CAAC;AAE9C,YAAA,QAAQ,CAAC,GAAG,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC;YAE1B,UAAU,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC;AAEvE,YAAA,QAAQ,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;AAEvB,YAAA,OAAO,CAAC,KAAK,CAAC,QAAQ,EAAE,UAAU,CAAC,CAAC;;AAEtC,SAAC,CAAC;AAEF,QAAA,MAAM,uBAAuB,GAAG,CAAC,KAAK,KAAI;YACxC,IAAI,IAAI,CAAC,UAAU;gBAAE,oBAAoB,CAAC,KAAK,CAAC,CAAC;YAEjD,IAAI,IAAI,CAAC,SAAS;gBAAE,kBAAkB,CAAC,KAAK,CAAC,CAAC;AAChD,SAAC,CAAC;AAEF,QAAA,MAAM,0BAA0B,GAAG,CAAC,KAAK,KAAI;YAC3C,IAAI,IAAI,CAAC,UAAU;gBAAE,oBAAoB,CAAC,KAAK,CAAC,CAAC;YAEjD,IAAI,IAAI,CAAC,YAAY;gBAAE,qBAAqB,CAAC,KAAK,CAAC,CAAC;AACtD,SAAC,CAAC;;;;AAMF,QAAA,IAAI,CAAC,aAAa,GAAG,CAAC,KAAK,KAAI;AAC7B,YAAA,IAAI,IAAI,CAAC,OAAO,KAAK,KAAK;gBAAE,OAAO;AAEnC,YAAA,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE;gBACzB,IAAI,CAAC,UAAU,CAAC,iBAAiB,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;gBAEnD,IAAI,CAAC,UAAU,CAAC,gBAAgB,CAAC,aAAa,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;gBACpE,IAAI,CAAC,UAAU,CAAC,gBAAgB,CAAC,WAAW,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;AACjE,aAAA;;YAID,UAAU,CAAC,KAAK,CAAC,CAAC;AAElB,YAAA,IAAI,KAAK,CAAC,WAAW,KAAK,OAAO,EAAE;gBACjC,YAAY,CAAC,KAAK,CAAC,CAAC;AACrB,aAAA;AAAM,iBAAA;gBACL,WAAW,CAAC,KAAK,CAAC,CAAC;AACpB,aAAA;AACH,SAAC,CAAC;AAEF,QAAA,IAAI,CAAC,aAAa,GAAG,CAAC,KAAK,KAAI;AAC7B,YAAA,IAAI,IAAI,CAAC,OAAO,KAAK,KAAK;gBAAE,OAAO;AAEnC,YAAA,IAAI,KAAK,CAAC,WAAW,KAAK,OAAO,EAAE;gBACjC,WAAW,CAAC,KAAK,CAAC,CAAC;AACpB,aAAA;AAAM,iBAAA;gBACL,WAAW,CAAC,KAAK,CAAC,CAAC;AACpB,aAAA;AACH,SAAC,CAAC;AAEF,QAAA,IAAI,CAAC,WAAW,GAAG,CAAC,KAAK,KAAI;YAC3B,aAAa,CAAC,KAAK,CAAC,CAAC;AAErB,YAAA,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE;gBACzB,IAAI,CAAC,UAAU,CAAC,qBAAqB,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;gBAEvD,IAAI,CAAC,UAAU,CAAC,mBAAmB,CAAC,aAAa,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;gBACvE,IAAI,CAAC,UAAU,CAAC,mBAAmB,CAAC,WAAW,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;AACpE,aAAA;AAED,YAAA,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC;AAE9B,YAAA,KAAK,GAAG,KAAK,CAAC,IAAI,CAAC;AACrB,SAAC,CAAC;AAEF,QAAA,MAAM,WAAW,GAAG,CAAC,KAAK,KAAI;AAC5B,YAAA,IAAI,WAAW,CAAC;YAEhB,QAAQ,KAAK,CAAC,MAAM;AAClB,gBAAA,KAAK,CAAC;AACJ,oBAAA,WAAW,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC;oBACrC,MAAM;AAER,gBAAA,KAAK,CAAC;AACJ,oBAAA,WAAW,GAAG,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC;oBACvC,MAAM;AAER,gBAAA,KAAK,CAAC;AACJ,oBAAA,WAAW,GAAG,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC;oBACtC,MAAM;AAER,gBAAA;oBACE,WAAW,GAAG,CAAC,CAAC,CAAC;AACpB,aAAA;AAED,YAAA,QAAQ,WAAW;gBACjB,KAAK,KAAK,CAAC,KAAK;AACd,oBAAA,IAAI,IAAI,CAAC,UAAU,KAAK,KAAK;wBAAE,OAAO;oBAEtC,oBAAoB,CAAC,KAAK,CAAC,CAAC;AAE5B,oBAAA,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC;oBAEpB,MAAM;gBAER,KAAK,KAAK,CAAC,MAAM;oBACf,IAAI,KAAK,CAAC,OAAO,IAAI,KAAK,CAAC,OAAO,IAAI,KAAK,CAAC,QAAQ,EAAE;AACpD,wBAAA,IAAI,IAAI,CAAC,SAAS,KAAK,KAAK;4BAAE,OAAO;wBAErC,kBAAkB,CAAC,KAAK,CAAC,CAAC;AAE1B,wBAAA,KAAK,GAAG,KAAK,CAAC,GAAG,CAAC;AACnB,qBAAA;AAAM,yBAAA;AACL,wBAAA,IAAI,IAAI,CAAC,YAAY,KAAK,KAAK;4BAAE,OAAO;wBAExC,qBAAqB,CAAC,KAAK,CAAC,CAAC;AAE7B,wBAAA,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC;AACtB,qBAAA;oBAED,MAAM;gBAER,KAAK,KAAK,CAAC,GAAG;oBACZ,IAAI,KAAK,CAAC,OAAO,IAAI,KAAK,CAAC,OAAO,IAAI,KAAK,CAAC,QAAQ,EAAE;AACpD,wBAAA,IAAI,IAAI,CAAC,YAAY,KAAK,KAAK;4BAAE,OAAO;wBAExC,qBAAqB,CAAC,KAAK,CAAC,CAAC;AAE7B,wBAAA,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC;AACtB,qBAAA;AAAM,yBAAA;AACL,wBAAA,IAAI,IAAI,CAAC,SAAS,KAAK,KAAK;4BAAE,OAAO;wBAErC,kBAAkB,CAAC,KAAK,CAAC,CAAC;AAE1B,wBAAA,KAAK,GAAG,KAAK,CAAC,GAAG,CAAC;AACnB,qBAAA;oBAED,MAAM;AAER,gBAAA;AACE,oBAAA,KAAK,GAAG,KAAK,CAAC,IAAI,CAAC;AACtB,aAAA;AAED,YAAA,IAAI,KAAK,KAAK,KAAK,CAAC,IAAI,EAAE;AACxB,gBAAA,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC,CAAC;AACjC,aAAA;AACH,SAAC,CAAC;AAEF,QAAA,MAAM,WAAW,GAAG,CAAC,KAAK,KAAI;AAC5B,YAAA,QAAQ,KAAK;gBACX,KAAK,KAAK,CAAC,MAAM;AACf,oBAAA,IAAI,IAAI,CAAC,YAAY,KAAK,KAAK;wBAAE,OAAO;oBAExC,qBAAqB,CAAC,KAAK,CAAC,CAAC;oBAE7B,MAAM;gBAER,KAAK,KAAK,CAAC,KAAK;AACd,oBAAA,IAAI,IAAI,CAAC,UAAU,KAAK,KAAK;wBAAE,OAAO;oBAEtC,oBAAoB,CAAC,KAAK,CAAC,CAAC;oBAE5B,MAAM;gBAER,KAAK,KAAK,CAAC,GAAG;AACZ,oBAAA,IAAI,IAAI,CAAC,SAAS,KAAK,KAAK;wBAAE,OAAO;oBAErC,kBAAkB,CAAC,KAAK,CAAC,CAAC;oBAE1B,MAAM;AACT,aAAA;AACH,SAAC,CAAC;AAEF,QAAA,IAAI,CAAC,YAAY,GAAG,CAAC,KAAK,KAAI;AAC5B,YAAA,IACE,IAAI,CAAC,OAAO,KAAK,KAAK;gBACtB,IAAI,CAAC,UAAU,KAAK,KAAK;gBACzB,KAAK,KAAK,KAAK,CAAC,IAAI;gBAEpB,OAAO;YAET,KAAK,CAAC,cAAc,EAAE,CAAC;AAEvB,YAAA,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC,CAAC;YAEhC,gBAAgB,CAAC,KAAK,CAAC,CAAC;AAExB,YAAA,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC;AAChC,SAAC,CAAC;AAEF,QAAA,IAAI,CAAC,SAAS,GAAG,CAAC,KAAK,KAAI;YACzB,IAAI,IAAI,CAAC,OAAO,KAAK,KAAK,IAAI,IAAI,CAAC,SAAS,KAAK,KAAK;gBAAE,OAAO;YAE/D,aAAa,CAAC,KAAK,CAAC,CAAC;AACvB,SAAC,CAAC;AAEF,QAAA,MAAM,YAAY,GAAG,CAAC,KAAK,KAAI;YAC7B,YAAY,CAAC,KAAK,CAAC,CAAC;YAEpB,QAAQ,QAAQ,CAAC,MAAM;AACrB,gBAAA,KAAK,CAAC;AACJ,oBAAA,QAAQ,IAAI,CAAC,OAAO,CAAC,GAAG;wBACtB,KAAK,KAAK,CAAC,MAAM;AACf,4BAAA,IAAI,IAAI,CAAC,YAAY,KAAK,KAAK;gCAAE,OAAO;AAExC,4BAAA,sBAAsB,EAAE,CAAC;AAEzB,4BAAA,KAAK,GAAG,KAAK,CAAC,YAAY,CAAC;4BAE3B,MAAM;wBAER,KAAK,KAAK,CAAC,GAAG;AACZ,4BAAA,IAAI,IAAI,CAAC,SAAS,KAAK,KAAK;gCAAE,OAAO;AAErC,4BAAA,mBAAmB,EAAE,CAAC;AAEtB,4BAAA,KAAK,GAAG,KAAK,CAAC,SAAS,CAAC;4BAExB,MAAM;AAER,wBAAA;AACE,4BAAA,KAAK,GAAG,KAAK,CAAC,IAAI,CAAC;AACtB,qBAAA;oBAED,MAAM;AAER,gBAAA,KAAK,CAAC;AACJ,oBAAA,QAAQ,IAAI,CAAC,OAAO,CAAC,GAAG;wBACtB,KAAK,KAAK,CAAC,SAAS;4BAClB,IAAI,IAAI,CAAC,UAAU,KAAK,KAAK,IAAI,IAAI,CAAC,SAAS,KAAK,KAAK;gCAAE,OAAO;AAElE,4BAAA,wBAAwB,EAAE,CAAC;AAE3B,4BAAA,KAAK,GAAG,KAAK,CAAC,eAAe,CAAC;4BAE9B,MAAM;wBAER,KAAK,KAAK,CAAC,YAAY;4BACrB,IAAI,IAAI,CAAC,UAAU,KAAK,KAAK,IAAI,IAAI,CAAC,YAAY,KAAK,KAAK;gCAC1D,OAAO;AAET,4BAAA,2BAA2B,EAAE,CAAC;AAE9B,4BAAA,KAAK,GAAG,KAAK,CAAC,kBAAkB,CAAC;4BAEjC,MAAM;AAER,wBAAA;AACE,4BAAA,KAAK,GAAG,KAAK,CAAC,IAAI,CAAC;AACtB,qBAAA;oBAED,MAAM;AAER,gBAAA;AACE,oBAAA,KAAK,GAAG,KAAK,CAAC,IAAI,CAAC;AACtB,aAAA;AAED,YAAA,IAAI,KAAK,KAAK,KAAK,CAAC,IAAI,EAAE;AACxB,gBAAA,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC,CAAC;AACjC,aAAA;AACH,SAAC,CAAC;AAEF,QAAA,MAAM,WAAW,GAAG,CAAC,KAAK,KAAI;YAC5B,YAAY,CAAC,KAAK,CAAC,CAAC;AAEpB,YAAA,QAAQ,KAAK;gBACX,KAAK,KAAK,CAAC,YAAY;AACrB,oBAAA,IAAI,IAAI,CAAC,YAAY,KAAK,KAAK;wBAAE,OAAO;oBAExC,qBAAqB,CAAC,KAAK,CAAC,CAAC;oBAE7B,IAAI,CAAC,MAAM,EAAE,CAAC;oBAEd,MAAM;gBAER,KAAK,KAAK,CAAC,SAAS;AAClB,oBAAA,IAAI,IAAI,CAAC,SAAS,KAAK,KAAK;wBAAE,OAAO;oBAErC,kBAAkB,CAAC,KAAK,CAAC,CAAC;oBAE1B,IAAI,CAAC,MAAM,EAAE,CAAC;oBAEd,MAAM;gBAER,KAAK,KAAK,CAAC,eAAe;oBACxB,IAAI,IAAI,CAAC,UAAU,KAAK,KAAK,IAAI,IAAI,CAAC,SAAS,KAAK,KAAK;wBAAE,OAAO;oBAElE,uBAAuB,CAAC,KAAK,CAAC,CAAC;oBAE/B,IAAI,CAAC,MAAM,EAAE,CAAC;oBAEd,MAAM;gBAER,KAAK,KAAK,CAAC,kBAAkB;oBAC3B,IAAI,IAAI,CAAC,UAAU,KAAK,KAAK,IAAI,IAAI,CAAC,YAAY,KAAK,KAAK;wBAAE,OAAO;oBAErE,0BAA0B,CAAC,KAAK,CAAC,CAAC;oBAElC,IAAI,CAAC,MAAM,EAAE,CAAC;oBAEd,MAAM;AAER,gBAAA;AACE,oBAAA,KAAK,GAAG,KAAK,CAAC,IAAI,CAAC;AACtB,aAAA;AACH,SAAC,CAAC;AAEF,QAAA,IAAI,CAAC,aAAa,GAAG,CAAC,KAAK,KAAI;AAC7B,YAAA,IAAI,IAAI,CAAC,OAAO,KAAK,KAAK;gBAAE,OAAO;YAEnC,KAAK,CAAC,cAAc,EAAE,CAAC;AACzB,SAAC,CAAC;AACF,QAAA,IAAI,CAAC,oBAAoB,GAAG,MAAK;AAC/B,YAAA,OAAO,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,EAAE,IAAI,EAAE,GAAG,EAAE,IAAI,IAAI,CAAC,eAAe,CAAC;AAC1D,SAAC,CAAC;QAEF,MAAM,YAAY,GAAG,MAAK;YACxB,OAAO,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;AACxC,SAAC,CAAC;QACF,IAAI,CAAC,UAAU,CAAC,gBAAgB,CAAC,aAAa,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;QAEpE,IAAI,CAAC,UAAU,CAAC,gBAAgB,CAAC,aAAa,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;QACpE,IAAI,CAAC,UAAU,CAAC,gBAAgB,CAAC,eAAe,EAAE,eAAe,CAAC,CAAC;QACnE,IAAI,CAAC,UAAU,CAAC,gBAAgB,CAAC,OAAO,EAAE,IAAI,CAAC,YAAY,EAAE;AAC3D,YAAA,OAAO,EAAE,KAAK;AACf,SAAA,CAAC,CAAC;KACJ;IACD,OAAO,GAAA;QACL,IAAI,CAAC,UAAU,CAAC,mBAAmB,CAAC,aAAa,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;QAEvE,IAAI,CAAC,UAAU,CAAC,mBAAmB,CAAC,aAAa,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;QACvE,IAAI,CAAC,UAAU,CAAC,mBAAmB,CAAC,eAAe,EAAE,eAAe,CAAC,CAAC;QACtE,IAAI,CAAC,UAAU,CAAC,mBAAmB,CAAC,OAAO,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;QAEhE,IAAI,CAAC,UAAU,CAAC,mBAAmB,CAAC,aAAa,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;QACvE,IAAI,CAAC,UAAU,CAAC,mBAAmB,CAAC,WAAW,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;AAEnE,QAAA,IAAI,IAAI,CAAC,oBAAoB,KAAK,IAAI,EAAE;YACtC,IAAI,CAAC,oBAAoB,CAAC,mBAAmB,CAAC,SAAS,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;AAC1E,SAAA;;KAGF;AACF,CAAA;AACD,MAAM,KAAK,GAAG;IACZ,IAAI,EAAE,CAAC,CAAC;AACR,IAAA,MAAM,EAAE,CAAC;AACT,IAAA,KAAK,EAAE,CAAC;AACR,IAAA,GAAG,EAAE,CAAC;AACN,IAAA,YAAY,EAAE,CAAC;AACf,IAAA,SAAS,EAAE,CAAC;AACZ,IAAA,eAAe,EAAE,CAAC;AAClB,IAAA,kBAAkB,EAAE,CAAC;CACtB,CAAC;AAEF,IAAI,KAAK,GAAG,KAAK,CAAC,IAAI,CAAC;AAEvB,MAAM,GAAG,GAAG,QAAQ,CAAC;AAErB;AACA,MAAM,SAAS,GAAG,IAAI,SAAS,EAAE,CAAC;AAClC,MAAM,cAAc,GAAG,IAAI,SAAS,EAAE,CAAC;AAEvC,IAAI,KAAK,GAAG,CAAC,CAAC;AACd,MAAM,SAAS,GAAG,IAAI,OAAO,EAAE,CAAC;AAChC,IAAI,WAAW,GAAG,KAAK,CAAC;AAExB,MAAM,WAAW,GAAG,IAAI,OAAO,EAAE,CAAC;AAClC,MAAM,SAAS,GAAG,IAAI,OAAO,EAAE,CAAC;AAChC,MAAM,WAAW,GAAG,IAAI,OAAO,EAAE,CAAC;AAElC,MAAM,QAAQ,GAAG,IAAI,OAAO,EAAE,CAAC;AAC/B,MAAM,MAAM,GAAG,IAAI,OAAO,EAAE,CAAC;AAC7B,MAAM,QAAQ,GAAG,IAAI,OAAO,EAAE,CAAC;AAE/B,MAAM,UAAU,GAAG,IAAI,OAAO,EAAE,CAAC;AACjC,MAAM,QAAQ,GAAG,IAAI,OAAO,EAAE,CAAC;AAC/B,MAAM,UAAU,GAAG,IAAI,OAAO,EAAE,CAAC;AAEjC,MAAM,QAAQ,GAAG,EAAE,CAAC;AACpB,MAAM,gBAAgB,GAAG,EAAE,CAAC;AAC5B,IAAY,KAOX,CAAA;AAPD,CAAA,UAAY,KAAK,EAAA;AACf,IAAA,KAAA,CAAA,KAAA,CAAA,MAAA,CAAA,GAAA,CAAA,CAAA,GAAA,MAAQ,CAAA;AACR,IAAA,KAAA,CAAA,KAAA,CAAA,QAAA,CAAA,GAAA,CAAA,CAAA,GAAA,QAAU,CAAA;AACV,IAAA,KAAA,CAAA,KAAA,CAAA,OAAA,CAAA,GAAA,CAAA,CAAA,GAAA,OAAS,CAAA;AACT,IAAA,KAAA,CAAA,KAAA,CAAA,QAAA,CAAA,GAAA,CAAA,CAAA,GAAA,QAAU,CAAA;AACV,IAAA,KAAA,CAAA,KAAA,CAAA,OAAA,CAAA,GAAA,CAAA,CAAA,GAAA,OAAS,CAAA;AACT,IAAA,KAAA,CAAA,KAAA,CAAA,KAAA,CAAA,GAAA,CAAA,CAAA,GAAA,KAAO,CAAA;AACT,CAAC,EAPW,KAAK,KAAL,KAAK,GAOhB,EAAA,CAAA,CAAA,CAAA;AAED,IAAY,KAKX,CAAA;AALD,CAAA,UAAY,KAAK,EAAA;AACf,IAAA,KAAA,CAAA,KAAA,CAAA,QAAA,CAAA,GAAA,CAAA,CAAA,GAAA,QAAM,CAAA;AACN,IAAA,KAAA,CAAA,KAAA,CAAA,KAAA,CAAA,GAAA,CAAA,CAAA,GAAA,KAAG,CAAA;AACH,IAAA,KAAA,CAAA,KAAA,CAAA,WAAA,CAAA,GAAA,CAAA,CAAA,GAAA,WAAS,CAAA;AACT,IAAA,KAAA,CAAA,KAAA,CAAA,cAAA,CAAA,GAAA,CAAA,CAAA,GAAA,cAAY,CAAA;AACd,CAAC,EALW,KAAK,KAAL,KAAK,GAKhB,EAAA,CAAA,CAAA,CAAA;AACD,SAAS,UAAU,CAAC,KAAK,EAAA;AACvB,IAAA,cAAc,CAAC,KAAK,IAAI,KAAK,CAAC;AAChC,CAAC;AAED,SAAS,QAAQ,CAAC,KAAK,EAAA;AACrB,IAAA,cAAc,CAAC,GAAG,IAAI,KAAK,CAAC;AAC9B,CAAC;AAED,SAAS,UAAU,CAAC,KAAK,EAAA;AACvB,IAAA,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;AACvB,CAAC;AAED,SAAS,aAAa,CAAC,KAAK,EAAA;AAC1B,IAAA,OAAO,gBAAgB,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;AAEzC,IAAA,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,QAAQ,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;QACxC,IAAI,QAAQ,CAAC,CAAC,CAAC,CAAC,SAAS,IAAI,KAAK,CAAC,SAAS,EAAE;AAC5C,YAAA,QAAQ,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;YACtB,OAAO;AACR,SAAA;AACF,KAAA;AACH,CAAC;AAED,SAAS,YAAY,CAAC,KAAK,EAAA;IACzB,IAAI,QAAQ,GAAG,gBAAgB,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;IAEjD,IAAI,QAAQ,KAAK,SAAS,EAAE;AAC1B,QAAA,QAAQ,GAAG,IAAI,OAAO,EAAE,CAAC;AACzB,QAAA,gBAAgB,CAAC,KAAK,CAAC,SAAS,CAAC,GAAG,QAAQ,CAAC;AAC9C,KAAA;IAED,QAAQ,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,EAAE,KAAK,CAAC,KAAK,CAAC,CAAC;AACzC,CAAC;AAED,SAAS,wBAAwB,CAAC,KAAK,EAAA;IACrC,MAAM,OAAO,GACX,KAAK,CAAC,SAAS,KAAK,QAAQ,CAAC,CAAC,CAAC,CAAC,SAAS,GAAG,QAAQ,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;AAExE,IAAA,OAAO,gBAAgB,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;AAC7C,CAAC;AAED,SAAS,qBAAqB,CAAC,KAAK,EAAA;IAClC,WAAW,CAAC,GAAG,CAAC,KAAK,CAAC,OAAO,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC;AAChD,CAAC;AAED,SAAS,oBAAoB,CAAC,KAAK,EAAA;IACjC,UAAU,CAAC,GAAG,CAAC,KAAK,CAAC,OAAO,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC;AAC/C,CAAC;AAED,SAAS,kBAAkB,CAAC,KAAK,EAAA;IAC/B,QAAQ,CAAC,GAAG,CAAC,KAAK,CAAC,OAAO,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC;AAC7C,CAAC;AACD,SAAS,eAAe,CAAC,KAAK,EAAA;IAC5B,aAAa,CAAC,KAAK,CAAC,CAAC;AACvB,CAAC;AACD,SAAS,sBAAsB,GAAA;AAC7B,IAAA,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE;AACzB,QAAA,WAAW,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;AACvD,KAAA;AAAM,SAAA;AACL,QAAA,MAAM,CAAC,GAAG,GAAG,IAAI,QAAQ,CAAC,CAAC,CAAC,CAAC,KAAK,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;AACxD,QAAA,MAAM,CAAC,GAAG,GAAG,IAAI,QAAQ,CAAC,CAAC,CAAC,CAAC,KAAK,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;AAExD,QAAA,WAAW,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;AACvB,KAAA;AACH,CAAC;AAED,SAAS,mBAAmB,GAAA;AAC1B,IAAA,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE;AACzB,QAAA,QAAQ,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;AACpD,KAAA;AAAM,SAAA;AACL,QAAA,MAAM,CAAC,GAAG,GAAG,IAAI,QAAQ,CAAC,CAAC,CAAC,CAAC,KAAK,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;AACxD,QAAA,MAAM,CAAC,GAAG,GAAG,IAAI,QAAQ,CAAC,CAAC,CAAC,CAAC,KAAK,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;AAExD,QAAA,QAAQ,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;AACpB,KAAA;AACH,CAAC;AAED,SAAS,qBAAqB,GAAA;AAC5B,IAAA,MAAM,EAAE,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC,KAAK,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;AACjD,IAAA,MAAM,EAAE,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC,KAAK,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;AAEjD,IAAA,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC,CAAC;AAE9C,IAAA,UAAU,CAAC,GAAG,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC;AAC9B;;;;"} diff --git a/example/mesh/instance.html b/example/mesh/instance.html index 4f05a1d..58a6beb 100644 --- a/example/mesh/instance.html +++ b/example/mesh/instance.html @@ -3,12 +3,7 @@ - - webworkerTask - + instance -
-
-
+