@itwin/core-frontend 3.0.0-dev.140 → 3.0.0-dev.145
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/cjs/RealityDataSource.d.ts +14 -7
- package/lib/cjs/RealityDataSource.d.ts.map +1 -1
- package/lib/cjs/RealityDataSource.js +25 -25
- package/lib/cjs/RealityDataSource.js.map +1 -1
- package/lib/cjs/core-frontend.js.map +1 -1
- package/lib/cjs/render/MockRender.d.ts +3 -1
- package/lib/cjs/render/MockRender.d.ts.map +1 -1
- package/lib/cjs/render/MockRender.js.map +1 -1
- package/lib/cjs/render/RenderSystem.d.ts +3 -1
- package/lib/cjs/render/RenderSystem.d.ts.map +1 -1
- package/lib/cjs/render/RenderSystem.js +4 -2
- package/lib/cjs/render/RenderSystem.js.map +1 -1
- package/lib/cjs/render/primitives/EdgeParams.d.ts +50 -0
- package/lib/cjs/render/primitives/EdgeParams.d.ts.map +1 -0
- package/lib/cjs/render/primitives/EdgeParams.js +116 -0
- package/lib/cjs/render/primitives/EdgeParams.js.map +1 -0
- package/lib/cjs/render/primitives/PointStringParams.d.ts +16 -0
- package/lib/cjs/render/primitives/PointStringParams.d.ts.map +1 -0
- package/lib/cjs/render/primitives/PointStringParams.js +43 -0
- package/lib/cjs/render/primitives/PointStringParams.js.map +1 -0
- package/lib/cjs/render/primitives/PolylineParams.d.ts +44 -0
- package/lib/cjs/render/primitives/PolylineParams.d.ts.map +1 -0
- package/lib/cjs/render/primitives/PolylineParams.js +205 -0
- package/lib/cjs/render/primitives/PolylineParams.js.map +1 -0
- package/lib/cjs/render/primitives/SurfaceParams.d.ts +46 -0
- package/lib/cjs/render/primitives/SurfaceParams.d.ts.map +1 -0
- package/lib/cjs/render/primitives/SurfaceParams.js +42 -0
- package/lib/cjs/render/primitives/SurfaceParams.js.map +1 -0
- package/lib/cjs/render/primitives/VertexTable.d.ts +3 -123
- package/lib/cjs/render/primitives/VertexTable.d.ts.map +1 -1
- package/lib/cjs/render/primitives/VertexTable.js +10 -351
- package/lib/cjs/render/primitives/VertexTable.js.map +1 -1
- package/lib/cjs/render/webgl/CachedGeometry.d.ts +4 -2
- package/lib/cjs/render/webgl/CachedGeometry.d.ts.map +1 -1
- package/lib/cjs/render/webgl/CachedGeometry.js.map +1 -1
- package/lib/cjs/render/webgl/EdgeGeometry.d.ts +73 -0
- package/lib/cjs/render/webgl/EdgeGeometry.d.ts.map +1 -0
- package/lib/cjs/render/webgl/EdgeGeometry.js +141 -0
- package/lib/cjs/render/webgl/EdgeGeometry.js.map +1 -0
- package/lib/cjs/render/webgl/InstancedGeometry.d.ts +4 -4
- package/lib/cjs/render/webgl/InstancedGeometry.d.ts.map +1 -1
- package/lib/cjs/render/webgl/Material.d.ts +1 -1
- package/lib/cjs/render/webgl/Material.d.ts.map +1 -1
- package/lib/cjs/render/webgl/Material.js.map +1 -1
- package/lib/cjs/render/webgl/Mesh.d.ts +6 -162
- package/lib/cjs/render/webgl/Mesh.d.ts.map +1 -1
- package/lib/cjs/render/webgl/Mesh.js +11 -456
- package/lib/cjs/render/webgl/Mesh.js.map +1 -1
- package/lib/cjs/render/webgl/MeshData.d.ts +38 -0
- package/lib/cjs/render/webgl/MeshData.d.ts.map +1 -0
- package/lib/cjs/render/webgl/MeshData.js +66 -0
- package/lib/cjs/render/webgl/MeshData.js.map +1 -0
- package/lib/cjs/render/webgl/MeshGeometry.d.ts +38 -0
- package/lib/cjs/render/webgl/MeshGeometry.d.ts.map +1 -0
- package/lib/cjs/render/webgl/MeshGeometry.js +60 -0
- package/lib/cjs/render/webgl/MeshGeometry.js.map +1 -0
- package/lib/cjs/render/webgl/PointString.d.ts +1 -1
- package/lib/cjs/render/webgl/PointString.d.ts.map +1 -1
- package/lib/cjs/render/webgl/PointString.js.map +1 -1
- package/lib/cjs/render/webgl/Polyline.d.ts +1 -1
- package/lib/cjs/render/webgl/Polyline.d.ts.map +1 -1
- package/lib/cjs/render/webgl/Polyline.js.map +1 -1
- package/lib/cjs/render/webgl/RenderCommands.js +4 -4
- package/lib/cjs/render/webgl/RenderCommands.js.map +1 -1
- package/lib/cjs/render/webgl/SurfaceGeometry.d.ts +54 -0
- package/lib/cjs/render/webgl/SurfaceGeometry.d.ts.map +1 -0
- package/lib/cjs/render/webgl/SurfaceGeometry.js +240 -0
- package/lib/cjs/render/webgl/SurfaceGeometry.js.map +1 -0
- package/lib/cjs/render/webgl/System.d.ts +5 -3
- package/lib/cjs/render/webgl/System.d.ts.map +1 -1
- package/lib/cjs/render/webgl/System.js +10 -4
- package/lib/cjs/render/webgl/System.js.map +1 -1
- package/lib/cjs/render/webgl/glsl/Surface.js +3 -3
- package/lib/cjs/render/webgl/glsl/Surface.js.map +1 -1
- package/lib/cjs/render-primitives.d.ts +5 -1
- package/lib/cjs/render-primitives.d.ts.map +1 -1
- package/lib/cjs/render-primitives.js +5 -1
- package/lib/cjs/render-primitives.js.map +1 -1
- package/lib/cjs/tile/ImdlReader.d.ts.map +1 -1
- package/lib/cjs/tile/ImdlReader.js +8 -5
- package/lib/cjs/tile/ImdlReader.js.map +1 -1
- package/lib/cjs/tile/RealityModelTileTree.js +1 -1
- package/lib/cjs/tile/RealityModelTileTree.js.map +1 -1
- package/lib/cjs/webgl.d.ts +4 -0
- package/lib/cjs/webgl.d.ts.map +1 -1
- package/lib/cjs/webgl.js +4 -0
- package/lib/cjs/webgl.js.map +1 -1
- package/lib/esm/RealityDataSource.d.ts +14 -7
- package/lib/esm/RealityDataSource.d.ts.map +1 -1
- package/lib/esm/RealityDataSource.js +23 -23
- package/lib/esm/RealityDataSource.js.map +1 -1
- package/lib/esm/core-frontend.js.map +1 -1
- package/lib/esm/render/MockRender.d.ts +3 -1
- package/lib/esm/render/MockRender.d.ts.map +1 -1
- package/lib/esm/render/MockRender.js.map +1 -1
- package/lib/esm/render/RenderSystem.d.ts +3 -1
- package/lib/esm/render/RenderSystem.d.ts.map +1 -1
- package/lib/esm/render/RenderSystem.js +3 -1
- package/lib/esm/render/RenderSystem.js.map +1 -1
- package/lib/esm/render/primitives/EdgeParams.d.ts +50 -0
- package/lib/esm/render/primitives/EdgeParams.d.ts.map +1 -0
- package/lib/esm/render/primitives/EdgeParams.js +113 -0
- package/lib/esm/render/primitives/EdgeParams.js.map +1 -0
- package/lib/esm/render/primitives/PointStringParams.d.ts +16 -0
- package/lib/esm/render/primitives/PointStringParams.d.ts.map +1 -0
- package/lib/esm/render/primitives/PointStringParams.js +39 -0
- package/lib/esm/render/primitives/PointStringParams.js.map +1 -0
- package/lib/esm/render/primitives/PolylineParams.d.ts +44 -0
- package/lib/esm/render/primitives/PolylineParams.d.ts.map +1 -0
- package/lib/esm/render/primitives/PolylineParams.js +199 -0
- package/lib/esm/render/primitives/PolylineParams.js.map +1 -0
- package/lib/esm/render/primitives/SurfaceParams.d.ts +46 -0
- package/lib/esm/render/primitives/SurfaceParams.d.ts.map +1 -0
- package/lib/esm/render/primitives/SurfaceParams.js +37 -0
- package/lib/esm/render/primitives/SurfaceParams.js.map +1 -0
- package/lib/esm/render/primitives/VertexTable.d.ts +3 -123
- package/lib/esm/render/primitives/VertexTable.d.ts.map +1 -1
- package/lib/esm/render/primitives/VertexTable.js +5 -341
- package/lib/esm/render/primitives/VertexTable.js.map +1 -1
- package/lib/esm/render/webgl/CachedGeometry.d.ts +4 -2
- package/lib/esm/render/webgl/CachedGeometry.d.ts.map +1 -1
- package/lib/esm/render/webgl/CachedGeometry.js.map +1 -1
- package/lib/esm/render/webgl/EdgeGeometry.d.ts +73 -0
- package/lib/esm/render/webgl/EdgeGeometry.d.ts.map +1 -0
- package/lib/esm/render/webgl/EdgeGeometry.js +135 -0
- package/lib/esm/render/webgl/EdgeGeometry.js.map +1 -0
- package/lib/esm/render/webgl/InstancedGeometry.d.ts +4 -4
- package/lib/esm/render/webgl/InstancedGeometry.d.ts.map +1 -1
- package/lib/esm/render/webgl/Material.d.ts +1 -1
- package/lib/esm/render/webgl/Material.d.ts.map +1 -1
- package/lib/esm/render/webgl/Material.js.map +1 -1
- package/lib/esm/render/webgl/Mesh.d.ts +6 -162
- package/lib/esm/render/webgl/Mesh.d.ts.map +1 -1
- package/lib/esm/render/webgl/Mesh.js +5 -443
- package/lib/esm/render/webgl/Mesh.js.map +1 -1
- package/lib/esm/render/webgl/MeshData.d.ts +38 -0
- package/lib/esm/render/webgl/MeshData.d.ts.map +1 -0
- package/lib/esm/render/webgl/MeshData.js +62 -0
- package/lib/esm/render/webgl/MeshData.js.map +1 -0
- package/lib/esm/render/webgl/MeshGeometry.d.ts +38 -0
- package/lib/esm/render/webgl/MeshGeometry.d.ts.map +1 -0
- package/lib/esm/render/webgl/MeshGeometry.js +56 -0
- package/lib/esm/render/webgl/MeshGeometry.js.map +1 -0
- package/lib/esm/render/webgl/PointString.d.ts +1 -1
- package/lib/esm/render/webgl/PointString.d.ts.map +1 -1
- package/lib/esm/render/webgl/PointString.js.map +1 -1
- package/lib/esm/render/webgl/Polyline.d.ts +1 -1
- package/lib/esm/render/webgl/Polyline.d.ts.map +1 -1
- package/lib/esm/render/webgl/Polyline.js.map +1 -1
- package/lib/esm/render/webgl/RenderCommands.js +1 -1
- package/lib/esm/render/webgl/RenderCommands.js.map +1 -1
- package/lib/esm/render/webgl/SurfaceGeometry.d.ts +54 -0
- package/lib/esm/render/webgl/SurfaceGeometry.d.ts.map +1 -0
- package/lib/esm/render/webgl/SurfaceGeometry.js +235 -0
- package/lib/esm/render/webgl/SurfaceGeometry.js.map +1 -0
- package/lib/esm/render/webgl/System.d.ts +5 -3
- package/lib/esm/render/webgl/System.d.ts.map +1 -1
- package/lib/esm/render/webgl/System.js +10 -4
- package/lib/esm/render/webgl/System.js.map +1 -1
- package/lib/esm/render/webgl/glsl/Surface.js +1 -1
- package/lib/esm/render/webgl/glsl/Surface.js.map +1 -1
- package/lib/esm/render-primitives.d.ts +5 -1
- package/lib/esm/render-primitives.d.ts.map +1 -1
- package/lib/esm/render-primitives.js +5 -1
- package/lib/esm/render-primitives.js.map +1 -1
- package/lib/esm/tile/ImdlReader.d.ts.map +1 -1
- package/lib/esm/tile/ImdlReader.js +4 -1
- package/lib/esm/tile/ImdlReader.js.map +1 -1
- package/lib/esm/tile/RealityModelTileTree.js +1 -1
- package/lib/esm/tile/RealityModelTileTree.js.map +1 -1
- package/lib/esm/webgl.d.ts +4 -0
- package/lib/esm/webgl.d.ts.map +1 -1
- package/lib/esm/webgl.js +4 -0
- package/lib/esm/webgl.js.map +1 -1
- package/package.json +22 -22
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"System.js","sourceRoot":"","sources":["../../../../src/render/webgl/System.ts"],"names":[],"mappings":"AAAA;;;+FAG+F;AAC/F;;GAEG;AAEH,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,UAAU,EAAE,OAAO,EAAE,IAAI,EAAc,MAAM,qBAAqB,CAAC;AAEnG,OAAO,EACmC,QAAQ,EAAE,WAAW,EAAE,iBAAiB,EAAE,iBAAiB,EAAE,WAAW,EAAsC,aAAa,GACpK,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAE,YAAY,EAAE,SAAS,EAAgB,MAAM,4BAA4B,CAAC;AACnF,OAAO,EAAE,2BAA2B,EAAE,MAAM,iBAAiB,CAAC;AAC9D,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAC5C,OAAO,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAM1D,OAAO,EAAE,gBAAgB,EAAE,MAAM,4CAA4C,CAAC;AAQ9E,OAAO,EAAmE,mBAAmB,EAAE,MAAM,kBAAkB,CAAC;AACxH,OAAO,EACuE,iBAAiB,EAC7F,YAAY,GACb,MAAM,iBAAiB,CAAC;AAGzB,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,EAAE,mBAAmB,EAAE,6BAA6B,EAAE,MAAM,kBAAkB,CAAC;AACtF,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC1C,OAAO,EAAE,wBAAwB,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AAC/E,OAAO,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAEtC,OAAO,EAAe,gBAAgB,EAAE,MAAM,eAAe,CAAC;AAC9D,OAAO,EAAE,EAAE,EAAE,MAAM,MAAM,CAAC;AAC1B,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,wBAAwB,EAAE,KAAK,EAAE,MAAM,EAAW,YAAY,EAAE,aAAa,EAAE,MAAM,WAAW,CAAC;AAC1G,OAAO,EAAE,KAAK,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAChD,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AACtC,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AACtC,OAAO,EAAE,WAAW,EAAE,kBAAkB,EAAE,MAAM,QAAQ,CAAC;AACzD,OAAO,EAAE,kBAAkB,EAAE,MAAM,cAAc,CAAC;AAClD,OAAO,EAAE,mBAAmB,EAAE,MAAM,eAAe,CAAC;AACpD,OAAO,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AAC9C,OAAO,EAAE,SAAS,EAAE,gBAAgB,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAC;AAC9E,OAAO,EAAE,YAAY,EAAE,uBAAuB,EAAE,MAAM,gBAAgB,CAAC;AACvE,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,EAAE,8BAA8B,EAAE,kBAAkB,EAAE,MAAM,qBAAqB,CAAC;AACzF,OAAO,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,UAAU,CAAC;AAC3D,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AACzC,OAAO,EAAE,mBAAmB,EAAE,MAAM,eAAe,CAAC;AACpD,OAAO,EAAE,qBAAqB,EAAE,OAAO,EAAE,aAAa,EAAE,MAAM,WAAW,CAAC;AAE1E,OAAO,EAAE,kBAAkB,EAAE,MAAM,cAAc,CAAC;AAWlD;;GAEG;AACH,MAAe,eAAe;IAE5B,YAAmB,MAAc;QAC/B,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC;IACxB,CAAC;IACD,IAAW,MAAM,KAAK,OAAO,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC;CAK7C;AAED;;GAEG;AACH,MAAM,gBAAiB,SAAQ,eAAe;IAI5C,YAAmB,MAAc,EAAE,cAA8C,EAAE,aAAiD;QAClI,KAAK,CAAC,MAAM,CAAC,CAAC;QACd,IAAI,CAAC,qBAAqB,GAAG,cAAc,CAAC;QAC5C,IAAI,CAAC,oBAAoB,GAAG,aAAa,CAAC;IAC5C,CAAC;IAEM,cAAc,CAAC,WAAqB;QACzC,kJAAkJ;QAClJ,IAAI,SAAS,KAAK,IAAI,CAAC,qBAAqB;YAC1C,IAAI,CAAC,qBAAqB,CAAC,gBAAgB,CAAC,WAAW,CAAC,CAAC;IAC7D,CAAC;IAEM,mBAAmB,CAAC,KAAa,EAAE,OAAe;QACvD,MAAM,CAAC,SAAS,KAAK,IAAI,CAAC,oBAAoB,CAAC,CAAC;QAChD,IAAI,CAAC,oBAAoB,CAAC,wBAAwB,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;IACrE,CAAC;IAEM,cAAc,CAAC,IAAsB,EAAE,KAAa,EAAE,KAAa,EAAE,YAAoB;QAC9F,IAAI,SAAS,KAAK,IAAI,CAAC,oBAAoB,EAAE;YAC3C,IAAI,CAAC,oBAAoB,CAAC,wBAAwB,CAAC,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,YAAY,CAAC,CAAC;SACtF;IACH,CAAC;IAEM,qBAAqB,CAAC,YAAsB,IAAU,CAAC,CAAC,2BAA2B;CAC3F;AAED;;GAEG;AACH,MAAM,gBAAiB,SAAQ,eAAe;IAE5C,YAAmB,MAAc;QAC/B,KAAK,CAAC,MAAM,CAAC,CAAC;QACd,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC,OAAiC,CAAC;IAC3D,CAAC;IAEM,cAAc,CAAC,WAAqB;QACzC,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC;IACzC,CAAC;IAEM,mBAAmB,CAAC,KAAa,EAAE,OAAe;QACvD,IAAI,CAAC,QAAQ,CAAC,mBAAmB,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;IACpD,CAAC;IAEM,cAAc,CAAC,IAAsB,EAAE,KAAa,EAAE,KAAa,EAAE,YAAoB,IAAU,IAAI,CAAC,QAAQ,CAAC,mBAAmB,CAAC,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,YAAY,CAAC,CAAC,CAAC,CAAC;IAEzK,qBAAqB,CAAC,WAAqB;QAChD,IAAI,CAAC,QAAQ,CAAC,qBAAqB,CAAC,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE,WAAW,CAAC,CAAC;IAC9E,CAAC;CACF;AAED;;GAEG;AACH,MAAM,OAAO,KAAK;IAWhB,YAAmB,MAAwB;QAT3C,gDAAgD;QAChC,cAAS,GAAG,IAAI,GAAG,EAA0B,CAAC;QAC9D,+CAA+C;QAC/B,aAAQ,GAAG,IAAI,GAAG,EAAyB,CAAC;QAC5D,oDAAoD;QACpC,cAAS,GAAG,IAAI,UAAU,CAA+B,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QACpG,mIAAmI;QACnH,6BAAwB,GAAG,IAAI,GAAG,EAA8C,CAAC;QAG/F,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC;IACxB,CAAC;IAED,IAAW,UAAU;QACnB,OAAO,CAAC,KAAK,IAAI,CAAC,QAAQ,CAAC,IAAI,IAAI,CAAC,KAAK,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC;IAC/D,CAAC;IAEM,OAAO;QACZ,MAAM,UAAU,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC,CAAC;QACtD,MAAM,WAAW,GAAG,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE,CAAC,MAAM,CAAC;QAE1D,KAAK,MAAM,OAAO,IAAI,UAAU;YAC9B,OAAO,CAAC,OAAO,CAAC,CAAC;QAEnB,KAAK,MAAM,QAAQ,IAAI,WAAW;YAChC,OAAO,CAAC,QAAQ,CAAC,CAAC;QAEpB,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC;QACtB,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC;QACvB,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC;IACzB,CAAC;IAED,mEAAmE;IAC5D,WAAW,CAAC,QAAwB;QACzC,IAAI,QAAQ,CAAC,GAAG;YACd,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC;IAC/C,CAAC;IAED,kEAAkE;IAC3D,UAAU,CAAC,OAAsB;QACtC,MAAM,CAAC,OAAO,YAAY,OAAO,CAAC,CAAC;QACnC,IAAI,OAAO,CAAC,GAAG;YACb,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,OAAO,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC;IAC5C,CAAC;IAED,4DAA4D;IACrD,WAAW,CAAC,YAA2B,EAAE,OAAsB;QACpE,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,YAAY,EAAE,OAAO,CAAC,CAAC;IAC5C,CAAC;IAED,6EAA6E;IACtE,YAAY,CAAC,GAAW;QAC7B,OAAO,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;IACjC,CAAC;IAED,4FAA4F;IACrF,YAAY,CAAC,IAAmB;QACrC,OAAO,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IAClC,CAAC;IAED,iHAAiH;IAC1G,WAAW,CAAC,MAA6B;QAC9C,IAAI,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,GAAG,CAAC,EAAI,mCAAmC;YACrF,OAAO,IAAI,QAAQ,CAAC,MAAM,CAAC,CAAC;QAE9B,IAAI,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;QAC9C,IAAI,CAAC,QAAQ,EAAE;YACb,QAAQ,GAAG,IAAI,QAAQ,CAAC,MAAM,CAAC,CAAC;YAChC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,MAAM,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC;SAC1C;QACD,OAAO,QAAQ,CAAC;IAClB,CAAC;IAEM,WAAW,CAAC,GAA4B;QAC7C,IAAI,SAAS,KAAK,GAAG;YACnB,OAAO,SAAS,CAAC;aACd,IAAI,OAAO,GAAG,KAAK,QAAQ;YAC9B,OAAO,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;;YAE9B,OAAO,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC;IAClC,CAAC;IAED,mDAAmD;IAC5C,qBAAqB,CAAC,GAAe,EAAE,MAAwB,EAAE,MAA4B,EAAE,MAAyB;QAC7H,IAAI,GAAG,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;QACvC,IAAI,GAAG;YACL,OAAO,GAAG,CAAC;QAEb,MAAM,MAAM,GAAG,aAAa,CAAC,gBAAgB,CAAC,GAAG,EAAE,MAAM,EAAE,MAAM,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;QAChF,IAAI,CAAC,MAAM;YACT,OAAO,SAAS,CAAC;QAEnB,GAAG,GAAG,IAAI,OAAO,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,CAAC,IAAI,EAAE,SAAS,EAAE,EAAE,GAAG,EAAE,MAAM,EAAE,EAAE,CAAC,CAAC;QAC7E,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC;QACrB,OAAO,GAAG,CAAC;IACb,CAAC;IAEM,KAAK,CAAC,yBAAyB,CAAC,IAAiC,EAAE,GAAW;QACnF,MAAM,OAAO,GAAG,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;QACtC,IAAI,OAAO;YACT,OAAO,OAAO,CAAC;QAEjB,wDAAwD;QACxD,IAAI,OAAO,GAAG,IAAI,CAAC,wBAAwB,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;QACrD,IAAI,OAAO;YACT,OAAO,OAAO,CAAC;QAEjB,OAAO,GAAG,IAAI,CAAC,4BAA4B,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;QACvD,IAAI,CAAC,wBAAwB,CAAC,GAAG,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC;QAChD,OAAO,OAAO,CAAC;IACjB,CAAC;IAEM,KAAK,CAAC,4BAA4B,CAAC,IAAiC,EAAE,GAAW;;QACtF,oCAAoC;QACpC,MAAM,YAAY,GAAG,iBAAiB,CAAC,IAAI,KAAK,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,mBAAmB,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAA,IAAI,CAAC,YAAY,mCAAI,mBAAmB,CAAC,WAAW,CAAC,CAAC;QACzJ,IAAI;YACF,MAAM,KAAK,GAAG,MAAM,2BAA2B,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YAC7D,IAAI,CAAC,SAAS,CAAC,eAAe;gBAC5B,OAAO,SAAS,CAAC;YAEnB,OAAO,SAAS,CAAC,YAAY,CAAC,aAAa,CAAC;gBAC1C,IAAI,EAAE,IAAI,CAAC,IAAI;gBACf,SAAS,EAAE,IAAI,CAAC,SAAS;gBACzB,KAAK,EAAE;oBACL,MAAM,EAAE,KAAK;oBACb,YAAY;iBACb;aACF,CAAC,CAAC;SACJ;QAAC,MAAM;YACN,OAAO,SAAS,CAAC;SAClB;gBAAS;YACR,IAAI,CAAC,wBAAwB,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;SAC3C;IACH,CAAC;IAED,mDAAmD;IAC5C,wBAAwB,CAAC,IAAsB,EAAE,IAAsB,EAAE,IAAsB,EAAE,IAAsB,EAAE,IAAsB,EAAE,IAAsB,EAAE,MAA4B;QAC1M,IAAI,GAAG,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;QACvC,IAAI,GAAG;YACL,OAAO,GAAG,CAAC;QAEb,MAAM,MAAM,GAAG,aAAa,CAAC,mBAAmB,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;QACrF,IAAI,CAAC,MAAM;YACT,OAAO,SAAS,CAAC;QAEnB,MAAM,SAAS,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,GAAG,EAAE,MAAM,CAAC,GAAG,EAAE,MAAM,EAAE,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC;QACrH,GAAG,GAAG,IAAI,OAAO,CAAC,EAAE,MAAM,EAAE,SAAS,EAAE,IAAI,EAAE,MAAM,CAAC,IAAI,EAAE,CAAC,CAAC;QAC5D,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC;QACrB,OAAO,GAAG,CAAC;IACb,CAAC;IAEM,iBAAiB,CAAC,KAA8B;QACrD,KAAK,MAAM,OAAO,IAAI,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE;YAC1C,IAAI,OAAO,YAAY,OAAO;gBAC5B,KAAK,CAAC,UAAU,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;QAExC,KAAK,MAAM,QAAQ,IAAI,IAAI,CAAC,SAAS;YACnC,IAAI,QAAQ,YAAY,OAAO;gBAC7B,KAAK,CAAC,UAAU,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;IAC3C,CAAC;CACF;AAgBD,gBAAgB;AAChB,MAAM,OAAO,MAAO,SAAQ,YAAY;IAuZtC,YAAsB,MAAyB,EAAE,OAAqB,EAAE,YAA0B,EAAE,OAA6B;QAC/H,KAAK,CAAC,OAAO,CAAC,CAAC;QAtZD,uBAAkB,GAAG,IAAI,WAAW,EAAE,CAAC;QAEvC,qBAAgB,GAAG,IAAI,gBAAgB,EAAE,CAAC,CAAE,4CAA4C;QAKvF,qBAAgB,GAAqB,EAAE,CAAC;QAGzD,gHAAgH;QAC/F,2BAAsB,GAAwB;;;;SAI9D,CAAC;QACe,4BAAuB,GAAwB;;;;SAI/D,CAAC;QAOc,qBAAgB,GAAsB,EAAE,CAAC;QA4XvD,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;QACvB,IAAI,CAAC,YAAY,GAAG,YAAY,CAAC;QACjC,IAAI,CAAC,aAAa,GAAG,IAAI,GAAG,EAA2B,CAAC;QACxD,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QACpC,IAAI,YAAY,CAAC,QAAQ;YACvB,IAAI,CAAC,WAAW,GAAG,IAAI,gBAAgB,CAAC,IAAI,CAAC,CAAC;aAC3C;YACH,MAAM,oBAAoB,GAAG,YAAY,CAAC,oBAAoB,CAAqB,oBAAoB,CAAC,CAAC;YACzG,MAAM,mBAAmB,GAAG,YAAY,CAAC,oBAAoB,CAAyB,wBAAwB,CAAC,CAAC;YAChH,IAAI,CAAC,WAAW,GAAG,IAAI,gBAAgB,CAAC,IAAI,EAAE,oBAAoB,EAAE,mBAAmB,CAAC,CAAC;SAC1F;QAED,0EAA0E;QAC1E,IAAI,CAAC,oBAAoB,GAAG,gBAAgB,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC,CAAC;QAE3G,MAAM,CAAC,gBAAgB,CAAC,kBAAkB,EAAE,KAAK,IAAI,EAAE,CAAC,YAAY,CAAC,kBAAkB,EAAE,EAAE,KAAK,CAAC,CAAC;IACpG,CAAC;IA3YM,MAAM,KAAK,QAAQ,KAAK,OAAO,SAAS,CAAC,YAAsB,CAAC,CAAC,CAAC;IAEzE,IAAW,OAAO,KAAc,OAAO,IAAI,CAAC,MAAM,KAAK,SAAS,CAAC,CAAC,CAAC;IACnE,IAAW,eAAe,KAAK,OAAO,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC;IAC9D,IAAW,YAAY,KAAK,OAAO,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC;IAExD,IAAW,UAAU;QACnB,MAAM,CAAC,SAAS,KAAK,IAAI,CAAC,WAAW,CAAC,CAAC;QACvC,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;IAED,IAAW,kBAAkB;QAC3B,MAAM,CAAC,SAAS,KAAK,IAAI,CAAC,mBAAmB,CAAC,CAAC;QAC/C,OAAO,IAAI,CAAC,mBAAmB,CAAC;IAClC,CAAC;IAED,IAAoB,cAAc,KAAa,OAAO,IAAI,CAAC,YAAY,CAAC,cAAc,CAAC,CAAC,CAAC;IACzF,IAAoB,kBAAkB,KAAc,OAAO,IAAI,CAAC,YAAY,CAAC,kBAAkB,CAAC,CAAC,CAAC;IAClG,IAAoB,kCAAkC,KAAc,OAAO,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC,CAAC;IACxG,IAAW,QAAQ,KAAc,OAAO,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC,CAAC;IACrE,IAAoB,QAAQ,KAAc,OAAO,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC,CAAC;IAEvE,cAAc,CAAC,WAAqB,IAAU,IAAI,CAAC,WAAW,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;IAE7F,UAAU;QACf,OAAO,IAAI,CAAC,UAAU,CAAC,qBAAqB,EAAE,CAAC;IACjD,CAAC;IAED,gIAAgI;IAChH,KAAK,CAAC,0BAA0B;QAC9C,MAAM,YAAY,GAAG,qBAAqB,CAAC,QAAQ,CAAC;QACpD,IAAI,YAAY,CAAC,iBAAiB,GAAG,CAAC,IAAI,YAAY,CAAC,kBAAkB,GAAG,CAAC;YAC3E,OAAO,OAAO,CAAC,OAAO,EAAE,CAAC;QAC3B,MAAM,OAAO,GAAG,IAAI,OAAO,CAAO,CAAC,OAAY,EAAE,EAAE;YACjD,YAAY,CAAC,gBAAgB,CAAC,OAAO,CAAC,GAAG,EAAE;gBACzC,OAAO,EAAE,CAAC;YACZ,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;QACH,OAAO,OAAO,CAAC;IACjB,CAAC;IAED,sFAAsF;IAC/E,MAAM,CAAC,aAAa,CAAC,MAAyB,EAAE,SAAkB,EAAE,sBAA+C;QACxH,IAAI,iBAAiB,GAA2B,EAAE,eAAe,EAAE,kBAAkB,EAAE,CAAC;QACxF,IAAI,SAAS,KAAK,sBAAsB,EAAE;YACxC,gHAAgH;YAChH,iBAAiB,GAAG,EAAE,GAAG,iBAAiB,EAAE,GAAG,sBAAsB,EAAE,CAAC;SACzE;QAED,sDAAsD;QACtD,IAAI,OAAO,GAAG,IAAI,CAAC;QACnB,IAAI,SAAS;YACX,OAAO,GAAG,MAAM,CAAC,UAAU,CAAC,QAAQ,EAAE,iBAAiB,CAAC,CAAC;QAE3D,oCAAoC;QACpC,IAAI,IAAI,KAAK,OAAO;YAClB,OAAO,GAAG,MAAM,CAAC,UAAU,CAAC,OAAO,EAAE,iBAAiB,CAAC,CAAC;QAE1D,OAAO,OAAO,aAAP,OAAO,cAAP,OAAO,GAAI,SAAS,CAAC;IAC9B,CAAC;IAEM,MAAM,CAAC,MAAM,CAAC,SAAgC;QACnD,MAAM,OAAO,GAAyB,SAAS,KAAK,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC;QAC/E,MAAM,MAAM,GAAG,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;QAChD,IAAI,IAAI,KAAK,MAAM;YACjB,MAAM,IAAI,WAAW,CAAC,aAAa,CAAC,KAAK,EAAE,oCAAoC,CAAC,CAAC;QAEnF,MAAM,SAAS,GAAG,CAAC,SAAS,KAAK,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;QAC/E,MAAM,OAAO,GAAG,IAAI,CAAC,aAAa,CAAC,MAAM,EAAE,SAAS,EAAE,SAAS,aAAT,SAAS,uBAAT,SAAS,CAAE,iBAAiB,CAAC,CAAC;QACpF,IAAI,SAAS,KAAK,OAAO,EAAE;YACzB,MAAM,IAAI,WAAW,CAAC,aAAa,CAAC,KAAK,EAAE,gCAAgC,CAAC,CAAC;SAC9E;QAED,MAAM,YAAY,GAAG,YAAY,CAAC,MAAM,CAAC,OAAO,EAAE,OAAO,CAAC,kBAAkB,CAAC,CAAC;QAC9E,IAAI,SAAS,KAAK,YAAY;YAC5B,MAAM,IAAI,WAAW,CAAC,aAAa,CAAC,KAAK,EAAE,6CAA6C,CAAC,CAAC;QAE5F,sDAAsD;QACtD,OAAO,CAAC,SAAS,CAAC,EAAE,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAE,cAAc;QAExD,IAAI,CAAC,YAAY,CAAC,kBAAkB;YAClC,OAAO,CAAC,mBAAmB,GAAG,KAAK,CAAC;QACtC,IAAI,CAAC,YAAY,CAAC,iBAAiB;YACjC,OAAO,CAAC,sBAAsB,GAAG,KAAK,CAAC;QACzC,IAAI,CAAC,YAAY,CAAC,gCAAgC,EAAE;YAClD,OAAO,CAAC,iBAAiB,GAAG,KAAK,CAAC;YAClC,OAAO,CAAC,sBAAsB,GAAG,KAAK,CAAC;SACxC;QACD,OAAO,IAAI,IAAI,CAAC,MAAM,EAAE,OAAO,EAAE,YAAY,EAAE,OAAO,CAAC,CAAC;IAC1D,CAAC;IAED,IAAW,UAAU;QACnB,OAAO,SAAS,KAAK,IAAI,CAAC,WAAW;eAChC,SAAS,KAAK,IAAI,CAAC,gBAAgB;eACnC,SAAS,KAAK,IAAI,CAAC,aAAa;eAChC,SAAS,KAAK,IAAI,CAAC,mBAAmB,CAAC;IAC9C,CAAC;IAED,+HAA+H;IACxH,OAAO;QACZ,IAAI,CAAC,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QAC7C,IAAI,CAAC,mBAAmB,GAAG,OAAO,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;QAC7D,IAAI,CAAC,gBAAgB,GAAG,OAAO,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;QACvD,IAAI,CAAC,aAAa,GAAG,OAAO,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QAEjD,8GAA8G;QAC9G,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,KAAY,EAAE,EAAE;YAC1C,OAAO,CAAC,KAAK,CAAC,CAAC;QACjB,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;QAC3B,IAAI,SAAS,KAAK,IAAI,CAAC,oBAAoB,EAAE;YAC3C,IAAI,CAAC,oBAAoB,EAAE,CAAC;YAC5B,IAAI,CAAC,oBAAoB,GAAG,SAAS,CAAC;SACvC;IACH,CAAC;IAEe,aAAa;QAC3B,IAAI,CAAC,WAAW,GAAG,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAEnD,MAAM,QAAQ,GAAG,CAAC,CAAC;QACnB,MAAM,QAAQ,GAAG,IAAI,UAAU,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,EAAE,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;QAC7G,IAAI,CAAC,aAAa,GAAG,aAAa,CAAC,aAAa,CAAC,QAAQ,EAAE,QAAQ,EAAE,QAAQ,EAAE,KAAK,EAAE,EAAE,CAAC,OAAO,CAAC,QAAQ,CAAC,MAAM,EAAE,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;QAC/I,MAAM,CAAC,SAAS,KAAK,IAAI,CAAC,aAAa,EAAE,kCAAkC,CAAC,CAAC;QAE7E,IAAI,CAAC,gBAAgB,GAAG,aAAa,CAAC,aAAa,CAAC,QAAQ,CAAC,IAAI,EAAE,QAAQ,CAAC,KAAK,EAAE,IAAI,UAAU,CAAC,QAAQ,CAAC,YAAY,CAAC,EAAE,KAAK,EAAE,EAAE,CAAC,OAAO,CAAC,QAAQ,CAAC,MAAM,EAAE,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;QAC1L,MAAM,CAAC,SAAS,KAAK,IAAI,CAAC,gBAAgB,EAAE,qCAAqC,CAAC,CAAC;QAEnF,IAAI,CAAC,mBAAmB,GAAG,IAAI,kBAAkB,EAAE,CAAC;IACtD,CAAC;IAEM,YAAY,CAAC,MAAyB;QAC3C,OAAO,IAAI,cAAc,CAAC,MAAM,CAAC,CAAC;IACpC,CAAC;IAEM,qBAAqB,CAAC,IAAc;QACzC,OAAO,IAAI,eAAe,CAAC,IAAI,CAAC,CAAC;IACnC,CAAC;IAEM,aAAa,CAAC,OAAoE;QACvF,OAAO,IAAI,gBAAgB,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;IAC7C,CAAC;IAEe,gBAAgB,CAAC,OAAgB,EAAE,IAAqB;QACtE,OAAO,kBAAkB,CAAC,MAAM,CAAC,OAAO,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;IACxD,CAAC;IAEe,4BAA4B,CAAC,WAAiC,EAAE,SAAqB;QACnG,OAAO,mBAAmB,CAAC,qBAAqB,CAAC,WAAW,EAAE,SAAS,CAAC,CAAC;IAC3E,CAAC;IAEe,wBAAwB,CAAC,eAAoC,EAAE,YAAgC,EAAE,MAA0B,EAAE,SAA+B,EAAE,eAAwB,EAAE,QAA2B;QACjO,OAAO,mBAAmB,CAAC,aAAa,CAAC,IAAI,EAAE,eAAe,EAAE,YAAY,EAAE,MAAM,EAAE,SAAS,EAAE,eAAe,EAAE,QAAQ,CAAC,CAAC;IAC9H,CAAC;IACe,iBAAiB,CAAC,WAAiC;QACjE,MAAM,IAAI,GAAG,mBAAmB,CAAC,qBAAqB,CAAC,WAAW,CAAC,CAAC;QACpE,OAAO,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;IACnD,CAAC;IAEe,kBAAkB,CAAC,MAAkB,EAAE,QAAkB;QACvE,OAAO,kBAAkB,CAAC,MAAM,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;IACrD,CAAC;IAEe,sBAAsB,CAAC,MAAsB,EAAE,QAAkB;QAC/E,OAAO,gBAAgB,CAAC,MAAM,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;IACnD,CAAC;IAEe,yBAAyB,CAAC,MAAyB,EAAE,QAAkB;QACrF,OAAO,mBAAmB,CAAC,MAAM,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;IACtD,CAAC;IAEe,iBAAiB,CAAC,MAA4B;QAC5D,OAAO,cAAc,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;IACvC,CAAC;IAEe,mBAAmB,CAAC,QAAwB,EAAE,SAAsD;QAClH,IAAI,CAAC,CAAC,QAAQ,YAAY,kBAAkB,CAAC,EAAE;YAC7C,IAAI,QAAQ,YAAY,gBAAgB,IAAI,QAAQ,YAAY,mBAAmB;gBACjF,OAAO,SAAS,CAAC,MAAM,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAC;YAE/C,MAAM,CAAC,KAAK,EAAE,uDAAuD,CAAC,CAAC;YACvE,OAAO,SAAS,CAAC;SAClB;QAED,MAAM,CAAC,CAAC,SAAS,IAAI,SAAS,YAAY,cAAc,IAAI,wBAAwB,CAAC,SAAS,CAAC,CAAC,CAAC;QACjG,OAAO,WAAW,CAAC,MAAM,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAC;IACjD,CAAC;IAEe,gBAAgB,CAAC,IAAoB;QACnD,OAAO,SAAS,CAAC,MAAM,CAAC,IAAI,kBAAkB,CAAC,IAAI,CAAC,CAAC,CAAC;IACxD,CAAC;IAEM,iBAAiB,CAAC,UAA2B;QAClD,OAAO,IAAI,aAAa,CAAC,UAAU,CAAC,CAAC;IACvC,CAAC;IAEM,mBAAmB,CAAC,MAAqB,EAAE,SAAoB,EAAE,OAA8B;QACpG,OAAO,IAAI,MAAM,CAAC,MAAM,EAAE,SAAS,EAAE,SAAS,EAAE,OAAO,CAAC,CAAC;IAC3D,CAAC;IAEe,4BAA4B,CAAC,OAAsB,EAAE,MAAc;QACjF,OAAO,IAAI,wBAAwB,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;IACvD,CAAC;IAEM,WAAW,CAAC,OAAsB,EAAE,QAA4B,EAAE,KAA0B,EAAE,OAAsB;QACzH,OAAO,IAAI,KAAK,CAAC,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,OAAO,CAAC,CAAC;IACtD,CAAC;IAEe,kBAAkB,CAAC,KAAoB;QACrD,OAAO,IAAI,YAAY,CAAC,KAAgB,CAAC,CAAC;IAC5C,CAAC;IAEe,kBAAkB,CAAC,OAAsB,EAAE,OAAe;QACxE,OAAO,IAAI,KAAK,CAAC,OAAkB,EAAE,OAAO,CAAC,CAAC;IAChD,CAAC;IAEe,2BAA2B,CAAC,OAAsB,EAAE,aAAsB,EAAE,YAAoB,EAAE,SAAiB;QACjI,OAAO,IAAI,cAAc,CAAC,OAAkB,EAAE,aAAa,EAAE,YAAY,EAAE,SAAS,CAAC,CAAC;IACxF,CAAC;IAEe,YAAY,CAAC,MAA0B;QACrD,IAAI,MAAM,KAAK,MAAM,CAAC,IAAI;YACxB,OAAO,gBAAgB,CAAC,MAAM,CAAC,mBAAmB,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC;QAE7E,OAAO,kBAAkB,CAAC,MAAM,CAAC,6BAA6B,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,CAAC;IACzF,CAAC;IAEe,8BAA8B,CAAC,MAAsC;QACnF,OAAO,8BAA8B,CAAC,MAAM,CAAC,CAAC;IAChD,CAAC;IAEM,gBAAgB,CAAC,QAAqB;QAC3C,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;QACxC,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;IAC7C,CAAC;IAEM,iBAAiB,CAAC,KAAa,EAAE,MAAc,EAAE,aAAqB,CAAC;QAC5E,+GAA+G;QAC/G,QAAQ,IAAI,CAAC,YAAY,CAAC,YAAY,EAAE;YACtC,KAAK,SAAS,CAAC,2BAA2B,CAAC,CAAC;gBAC1C,OAAO,YAAY,CAAC,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;aAC3C;YACD,KAAK,SAAS,CAAC,oBAAoB,CAAC,CAAC;gBACnC,OAAO,aAAa,CAAC,mBAAmB,CAAC,KAAK,EAAE,MAAM,EAAE,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,cAAc,EAAE,EAAE,CAAC,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC;aAC5H;YACD,KAAK,SAAS,CAAC,4BAA4B,CAAC,CAAC;gBAC3C,IAAI,IAAI,CAAC,YAAY,CAAC,QAAQ,EAAE;oBAC9B,IAAI,UAAU,GAAG,CAAC,EAAE;wBAClB,OAAO,uBAAuB,CAAC,MAAM,CAAC,KAAK,EAAE,MAAM,EAAE,sBAAsB,CAAC,gBAAgB,EAAE,UAAU,CAAC,CAAC;qBAC3G;yBAAM;wBACL,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAiC,CAAC;wBACxD,OAAO,aAAa,CAAC,mBAAmB,CAAC,KAAK,EAAE,MAAM,EAAE,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,YAAY,EAAE,QAAQ,CAAC,iBAAiB,CAAC,CAAC;qBACrH;iBACF;qBAAM;oBACL,MAAM,KAAK,GAAoC,IAAI,CAAC,YAAY,CAAC,oBAAoB,CAAsB,qBAAqB,CAAC,CAAC;oBAClI,OAAO,aAAa,CAAC,mBAAmB,CAAC,KAAK,EAAE,MAAM,EAAE,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,YAAY,EAAE,KAAM,CAAC,uBAAuB,CAAC,CAAC;iBACzH;aACF;YACD,OAAO,CAAC,CAAC;gBACP,MAAM,CAAC,KAAK,CAAC,CAAC;gBACd,OAAO,SAAS,CAAC;aAClB;SACF;IACH,CAAC;IAED,sGAAsG;IAC/F,eAAe,CAAC,MAAwB;QAC7C,IAAI,KAAK,GAAG,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;QAC3C,IAAI,CAAC,KAAK,EAAE;YACV,KAAK,GAAG,IAAI,KAAK,CAAC,MAAM,CAAC,CAAC;YAC1B,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;SACvC;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IAED,kFAAkF;IAC1E,eAAe,CAAC,MAAwB;QAC9C,MAAM,KAAK,GAAG,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;QAC7C,IAAI,KAAK,KAAK,SAAS;YACrB,OAAO;QACT,OAAO,CAAC,KAAK,CAAC,CAAC;QACf,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;IACpC,CAAC;IAED,4FAA4F;IAC5E,cAAc,CAAC,MAA6B,EAAE,MAAwB;QACpF,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;QACpC,MAAM,QAAQ,GAAG,KAAK,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;QAC3C,OAAO,QAAQ,CAAC;IAClB,CAAC;IAED,wEAAwE;IACxD,YAAY,CAAC,GAAW,EAAE,MAAwB;QAChE,MAAM,KAAK,GAAG,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;QAC7C,IAAI,CAAC,KAAK;YACR,OAAO,SAAS,CAAC;QACnB,OAAO,KAAK,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC;IACjC,CAAC;IAEO,mBAAmB,CAAC,IAAuB;QACjD,MAAM,KAAK,GAAG,SAAS,KAAK,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,SAAS,KAAK,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC;QACzG,OAAO,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,GAAG,EAAE,KAAK,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC;IACpF,CAAC;IAEe,aAAa,CAAC,IAAuB;;QACnD,MAAM,IAAI,GAAG,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC;QAC5C,MAAM,QAAQ,GAAG,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,KAAK,CAAC,WAAW,CAAC,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,GAAG,CAAC,CAAC;QACpD,IAAI,QAAQ;YACV,OAAO,QAAQ,CAAC;QAElB,MAAM,IAAI,GAAG,MAAA,IAAI,CAAC,IAAI,mCAAI,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC;QACpD,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC;QAEjC,8DAA8D;QAC9D,IAAI,MAAM,CAAC;QACX,IAAI,MAAM,YAAY,WAAW;YAC/B,MAAM,GAAG,aAAa,CAAC,oBAAoB,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC,CAAC,qCAAqC;;YAEhG,MAAM,GAAG,aAAa,CAAC,cAAc,CAAC,MAAM,EAAE,mBAAmB,CAAC,MAAM,KAAK,IAAI,CAAC,KAAK,CAAC,YAAY,EAAE,IAAI,CAAC,CAAC;QAE9G,IAAI,CAAC,MAAM;YACT,OAAO,SAAS,CAAC;QAEnB,MAAM,OAAO,GAAG,IAAI,OAAO,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC;QACzE,IAAI,OAAO,IAAI,IAAI;YACjB,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;QAEjC,OAAO,OAAO,CAAC;IACjB,CAAC;IAEe,KAAK,CAAC,uBAAuB,CAAC,IAAiC;QAC7E,IAAI,OAAO,IAAI,CAAC,SAAS,KAAK,QAAQ;YACpC,OAAO,KAAK,CAAC,uBAAuB,CAAC,IAAI,CAAC,CAAC;QAE7C,OAAO,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,yBAAyB,CAAC,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;IAClG,CAAC;IAED,mDAAmD;IACnC,wBAAwB,CAAC,EAAc,EAAE,MAAwB,EAAE,MAA4B,EAAE,MAAyB;QACxI,OAAO,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,qBAAqB,CAAC,EAAE,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC;IACjF,CAAC;IAED,mDAAmD;IACnC,2BAA2B,CAAC,IAAsB,EAAE,IAAsB,EAAE,IAAsB,EAAE,IAAsB,EAAE,IAAsB,EAAE,IAAsB,EAAE,MAAwB,EAAE,MAA4B;QAChP,OAAO,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,wBAAwB,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,CAAC,CAAC;IACpG,CAAC;IAED,4DAA4D;IAC5C,kBAAkB,CAAC,IAAmB,EAAE,MAAyB;QAC/E,MAAM,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QAC3C,OAAO,IAAI,CAAC,aAAa,CAAC;YACxB,KAAK,EAAE;gBACL,MAAM;gBACN,YAAY,EAAE,iBAAiB,CAAC,IAAI,KAAK,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,mBAAmB,CAAC,WAAW,CAAC,CAAC,CAAC,mBAAmB,CAAC,MAAM;aACtH;YACD,SAAS,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,MAAM,EAAE,GAAG,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,SAAS;YACrD,IAAI,EAAE,aAAa,CAAC,IAAI,CAAC,MAAM;SAChC,CAAC,CAAC;IACL,CAAC;IAED,uEAAuE;IACvD,WAAW,CAAC,GAAoB,EAAE,MAAwB;QACxE,MAAM,KAAK,GAAG,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;QAC7C,IAAI,CAAC,KAAK;YACR,OAAO,SAAS,CAAC;QAEnB,OAAO,KAAK,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;IAChC,CAAC;IAEe,gBAAgB,CAAC,UAAsB;QACrD,OAAO,UAAU,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;IACvC,CAAC;IACe,wBAAwB,CAAC,UAA6B,EAAE,OAA6B;QACnG,OAAO,kBAAkB,CAAC,MAAM,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC;IACxD,CAAC;IAuBD,kCAAkC;IAC3B,QAAQ,CAAC,MAAwB;QACtC,MAAM,GAAG,GAAG,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;QAC3C,OAAO,SAAS,KAAK,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC;IAChE,CAAC;IAEO,WAAW,CAAC,IAAiB,EAAE,MAAyB,EAAE,OAAuB,EAAE,UAAmB;QAC5G,MAAM,KAAK,GAAG,IAAI,GAAG,WAAW,CAAC,IAAI,CAAC;QACtC,IAAI,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,KAAK,OAAO,EAAE;YAC5C,IAAI,UAAU;gBACZ,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;YAEnC,OAAO;SACR;QAED,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,GAAG,OAAO,CAAC;QACvC,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;QACjC,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,MAAM,EAAE,SAAS,KAAK,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;IAC3E,CAAC;IAED,wGAAwG;IACjG,aAAa,CAAC,IAAiB,EAAE,OAAuB,IAAI,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC;IACtI,wGAAwG;IACjG,kBAAkB,CAAC,IAAiB,EAAE,OAAuB,IAAI,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,EAAE,OAAO,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC;IAC5I,iGAAiG;IAC1F,iBAAiB,CAAC,IAAiB,EAAE,OAAuB,IAAI,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC;IACzI,iGAAiG;IAC1F,sBAAsB,CAAC,IAAiB,EAAE,OAAuB,IAAI,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC;IAE/I,oFAAoF;IAC7E,kBAAkB,CAAC,OAAsB,EAAE,IAAiB;QACjE,IAAI,CAAC,eAAgB,CAAC,WAAW,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;IACnD,CAAC;IACD,IAAoB,uBAAuB,KAAK,OAAO,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC,mBAAmB,EAAE,IAAI,CAAC,YAAY,CAAC,mBAAmB,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAEtJ,cAAc,CAAC,OAAqB;QACzC,MAAM,CAAC,QAAQ,CAAC,OAAO,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;QAC/C,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,gBAAgB,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YACrD,IAAI,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,KAAK,OAAO,EAAE;gBACxC,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,GAAG,SAAS,CAAC;gBACrC,MAAM;aACP;SACF;IACH,CAAC;IAED,0EAA0E;IAC1E,kHAAkH;IAClH,qHAAqH;IAC9G,uBAAuB,CAAC,EAAU,EAAE,SAAkB;QAC3D,MAAM,CAAC,EAAE,GAAG,IAAI,CAAC,uBAAuB,CAAC,MAAM,EAAE,+DAA+D,CAAC,CAAC;QAClH,MAAM,CAAC,EAAE,GAAG,IAAI,CAAC,sBAAsB,CAAC,MAAM,EAAE,+DAA+D,CAAC,CAAC;QAEjH,IAAI,CAAC,uBAAuB,CAAC,EAAE,CAAC,GAAG,SAAS,CAAC,CAAC,0BAAoC,CAAC,gBAA0B,CAAC;IAChH,CAAC;IAEM,wBAAwB;QAC7B,MAAM,GAAG,GAAG,IAAI,CAAC,sBAAsB,CAAC;QACxC,MAAM,IAAI,GAAG,IAAI,CAAC,uBAAuB,CAAC;QAC1C,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;QAE7B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YACpC,MAAM,QAAQ,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC;YACxB,MAAM,QAAQ,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;YACzB,IAAI,QAAQ,KAAK,QAAQ,EAAE;gBACzB,0CAA0C;gBAC1C,MAAM,UAAU,GAAG,CAAC,KAAK,CAAC,kBAA4B,QAAQ,CAAC,CAAC;gBAChE,MAAM,UAAU,GAAG,CAAC,KAAK,CAAC,kBAA4B,QAAQ,CAAC,CAAC;gBAChE,IAAI,UAAU,KAAK,UAAU,EAAE;oBAC7B,IAAI,UAAU,EAAE;wBACd,OAAO,CAAC,uBAAuB,CAAC,CAAC,CAAC,CAAC;qBACpC;yBAAM;wBACL,OAAO,CAAC,wBAAwB,CAAC,CAAC,CAAC,CAAC;qBACrC;iBACF;gBAED,uDAAuD;gBACvD,IAAI,UAAU,EAAE;oBACd,MAAM,YAAY,GAAG,CAAC,KAAK,CAAC,oBAA8B,QAAQ,CAAC,CAAC;oBACpE,MAAM,YAAY,GAAG,CAAC,KAAK,CAAC,oBAA8B,QAAQ,CAAC,CAAC;oBACpE,IAAI,YAAY,KAAK,YAAY,EAAE;wBACjC,IAAI,CAAC,mBAAmB,CAAC,CAAC,EAAE,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;qBACnD;iBACF;gBAED,GAAG,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC;aACnB;YAED,gEAAgE;YAChE,IAAI,CAAC,CAAC,CAAC,IAAI,gBAA0B,CAAC;SACvC;IACH,CAAC;IAEM,mBAAmB,CAAC,KAAa,EAAE,OAAe,IAAI,IAAI,CAAC,WAAW,CAAC,mBAAmB,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC;IAE7G,UAAU,CAAC,IAAsB,EAAE,KAAa,EAAE,KAAa,EAAE,YAAoB;QAC1F,IAAI,CAAC,KAAK,YAAY,EAAE;YACtB,IAAI,CAAC,WAAW,CAAC,cAAc,CAAC,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,YAAY,CAAC,CAAC;SACnE;aAAM;YACL,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,IAAI,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;SAC7C;IACH,CAAC;IAEM,qBAAqB,CAAC,WAAqB,IAAU,IAAI,CAAC,WAAW,CAAC,qBAAqB,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;IAElG,iBAAiB,CAAC,MAAyB;QACzD,KAAK,CAAC,YAAY,GAAG,iBAAiB,CAAC,IAAI,KAAK,CAAC,MAAM,GAAG,iBAAiB,CAAC,WAAW,CAAC,CAAC;QACzF,KAAK,CAAC,eAAe,GAAG,iBAAiB,CAAC,IAAI,KAAK,CAAC,MAAM,GAAG,iBAAiB,CAAC,KAAK,CAAC,CAAC;IACxF,CAAC;IAED,2BAA2B;IAC3B,IAAoB,YAAY,KAA+B,OAAO,IAAI,CAAC,CAAC,CAAC;IAG7E,IAAoB,WAAW,aAAc,OAAO,MAAA,IAAI,CAAC,YAAY,mCAAI,KAAK,CAAC,WAAW,CAAC,CAAC,CAAC;IAC7F,IAAoB,WAAW,CAAC,QAAiB,IAAI,IAAI,CAAC,YAAY,GAAG,QAAQ,CAAC,CAAC,CAAC;IAE7E,WAAW;QAChB,MAAM,GAAG,GAAG,IAAI,CAAC,YAAY,CAAC,oBAAoB,CAAqB,oBAAoB,CAAC,CAAC;QAC7F,IAAI,SAAS,KAAK,GAAG;YACnB,OAAO,KAAK,CAAC;QAEf,GAAG,CAAC,WAAW,EAAE,CAAC;QAClB,OAAO,IAAI,CAAC;IACd,CAAC;IAEM,iBAAiB;QACtB,OAAO,IAAI,CAAC,UAAU,CAAC,cAAc,EAAE,CAAC;IAC1C,CAAC;IAED,IAAW,kBAAkB,KAAc,OAAO,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC;IAC7E,IAAW,eAAe,CAAC,QAA2C;QACpE,IAAI,CAAC,OAAO,CAAC,eAAe,GAAG,QAAQ,CAAC;IAC1C,CAAC;IAEe,iBAAiB,CAAC,KAA8B;QAC9D,IAAI,SAAS,KAAK,IAAI,CAAC,gBAAgB;YACrC,KAAK,CAAC,UAAU,CAAC,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,CAAC;QAEpD,IAAI,SAAS,KAAK,IAAI,CAAC,aAAa;YAClC,KAAK,CAAC,UAAU,CAAC,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC;QAEjD,KAAK,MAAM,KAAK,IAAI,IAAI,CAAC,aAAa,CAAC,MAAM,EAAE;YAC7C,KAAK,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC;IACnC,CAAC;IAEM,gBAAgB,CAAC,GAAuB;QAC7C,IAAI,CAAC,YAAY,CAAC,gBAAgB,CAAC,GAAG,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;IACxD,CAAC;CACF","sourcesContent":["/*---------------------------------------------------------------------------------------------\r\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\r\n* See LICENSE.md in the project root for license terms and full copyright notice.\r\n*--------------------------------------------------------------------------------------------*/\r\n/** @packageDocumentation\r\n * @module WebGL\r\n */\r\n\r\nimport { assert, BentleyStatus, Dictionary, dispose, Id64, Id64String } from \"@itwin/core-bentley\";\r\nimport { ClipVector, Point3d, Transform } from \"@itwin/core-geometry\";\r\nimport {\r\n ColorDef, ElementAlignedBox3d, Frustum, Gradient, ImageBuffer, ImageBufferFormat, ImageSourceFormat, IModelError, PackedFeatureTable, RenderMaterial, RenderTexture,\r\n} from \"@itwin/core-common\";\r\nimport { Capabilities, DepthType, WebGLContext } from \"@itwin/webgl-compatibility\";\r\nimport { imageElementFromImageSource } from \"../../ImageUtil\";\r\nimport { IModelApp } from \"../../IModelApp\";\r\nimport { IModelConnection } from \"../../IModelConnection\";\r\nimport { MapTileTreeReference, TileTreeReference } from \"../../tile/internal\";\r\nimport { ViewRect } from \"../../ViewRect\";\r\nimport { GraphicBranch, GraphicBranchOptions } from \"../GraphicBranch\";\r\nimport { BatchOptions, CustomGraphicBuilderOptions, GraphicBuilder, ViewportGraphicBuilderOptions } from \"../GraphicBuilder\";\r\nimport { InstancedGraphicParams, PatternGraphicParams } from \"../InstancedGraphicParams\";\r\nimport { PrimitiveBuilder } from \"../primitives/geometry/GeometryListBuilder\";\r\nimport { RealityMeshPrimitive } from \"../primitives/mesh/RealityMeshPrimitive\";\r\nimport { TerrainMeshPrimitive } from \"../primitives/mesh/TerrainMeshPrimitive\";\r\nimport { PointCloudArgs } from \"../primitives/PointCloudPrimitive\";\r\nimport { MeshParams, PointStringParams, PolylineParams } from \"../primitives/VertexTable\";\r\nimport { RenderClipVolume } from \"../RenderClipVolume\";\r\nimport { RenderGraphic, RenderGraphicOwner } from \"../RenderGraphic\";\r\nimport { RenderMemory } from \"../RenderMemory\";\r\nimport { CreateTextureArgs, CreateTextureFromSourceArgs, TextureCacheKey, TextureTransparency } from \"../RenderTexture\";\r\nimport {\r\n DebugShaderFile, GLTimerResultCallback, PlanarGridProps, RenderAreaPattern, RenderDiagnostics, RenderGeometry, RenderSkyBoxParams,\r\n RenderSystem, RenderSystemDebugControl, TerrainTexture,\r\n} from \"../RenderSystem\";\r\nimport { RenderTarget } from \"../RenderTarget\";\r\nimport { ScreenSpaceEffectBuilder, ScreenSpaceEffectBuilderParams } from \"../ScreenSpaceEffectBuilder\";\r\nimport { BackgroundMapDrape } from \"./BackgroundMapDrape\";\r\nimport { SkyBoxQuadsGeometry, SkySphereViewportQuadGeometry } from \"./CachedGeometry\";\r\nimport { ClipVolume } from \"./ClipVolume\";\r\nimport { isInstancedGraphicParams, PatternBuffers } from \"./InstancedGeometry\";\r\nimport { Debug } from \"./Diagnostics\";\r\nimport { WebGLDisposable } from \"./Disposable\";\r\nimport { DepthBuffer, FrameBufferStack } from \"./FrameBuffer\";\r\nimport { GL } from \"./GL\";\r\nimport { GLTimer } from \"./GLTimer\";\r\nimport { AnimationTransformBranch, Batch, Branch, Graphic, GraphicOwner, GraphicsArray } from \"./Graphic\";\r\nimport { Layer, LayerContainer } from \"./Layer\";\r\nimport { LineCode } from \"./LineCode\";\r\nimport { Material } from \"./Material\";\r\nimport { MeshGraphic, MeshRenderGeometry } from \"./Mesh\";\r\nimport { PointCloudGeometry } from \"./PointCloud\";\r\nimport { PointStringGeometry } from \"./PointString\";\r\nimport { PolylineGeometry } from \"./Polyline\";\r\nimport { Primitive, SkyCubePrimitive, SkySpherePrimitive } from \"./Primitive\";\r\nimport { RenderBuffer, RenderBufferMultiSample } from \"./RenderBuffer\";\r\nimport { TextureUnit } from \"./RenderFlags\";\r\nimport { RenderState } from \"./RenderState\";\r\nimport { createScreenSpaceEffectBuilder, ScreenSpaceEffects } from \"./ScreenSpaceEffect\";\r\nimport { OffScreenTarget, OnScreenTarget } from \"./Target\";\r\nimport { Techniques } from \"./Technique\";\r\nimport { RealityMeshGeometry } from \"./RealityMesh\";\r\nimport { ExternalTextureLoader, Texture, TextureHandle } from \"./Texture\";\r\nimport { UniformHandle } from \"./UniformHandle\";\r\nimport { PlanarGridGeometry } from \"./PlanarGrid\";\r\n\r\n/* eslint-disable no-restricted-syntax */\r\n\r\n/** @internal */\r\nexport const enum ContextState {\r\n Uninitialized,\r\n Success,\r\n Error,\r\n}\r\n\r\n/** Describes WebGL extension methods.\r\n * @internal\r\n */\r\nabstract class WebGLExtensions {\r\n private _system: System;\r\n public constructor(system: System) {\r\n this._system = system;\r\n }\r\n public get system() { return this._system; }\r\n public abstract setDrawBuffers(attachments: GLenum[]): void;\r\n public abstract vertexAttribDivisor(index: number, divisor: number): void;\r\n public abstract drawArraysInst(type: GL.PrimitiveType, first: number, count: number, numInstances: number): void;\r\n public abstract invalidateFrameBuffer(_attachments: number[]): void;\r\n}\r\n\r\n/** Describes WebGL1 extension methods.\r\n * @internal\r\n */\r\nclass WebGL1Extensions extends WebGLExtensions {\r\n private readonly _drawBuffersExtension?: WEBGL_draw_buffers;\r\n private readonly _instancingExtension?: ANGLE_instanced_arrays;\r\n\r\n public constructor(system: System, drawBuffersExt: WEBGL_draw_buffers | undefined, instancingExt: ANGLE_instanced_arrays | undefined) {\r\n super(system);\r\n this._drawBuffersExtension = drawBuffersExt;\r\n this._instancingExtension = instancingExt;\r\n }\r\n\r\n public setDrawBuffers(attachments: GLenum[]): void {\r\n // NB: The WEBGL_draw_buffers member is not exported directly because that type name is not available in some contexts (e.g. test-imodel-service).\r\n if (undefined !== this._drawBuffersExtension)\r\n this._drawBuffersExtension.drawBuffersWEBGL(attachments);\r\n }\r\n\r\n public vertexAttribDivisor(index: number, divisor: number): void {\r\n assert(undefined !== this._instancingExtension);\r\n this._instancingExtension.vertexAttribDivisorANGLE(index, divisor);\r\n }\r\n\r\n public drawArraysInst(type: GL.PrimitiveType, first: number, count: number, numInstances: number): void {\r\n if (undefined !== this._instancingExtension) {\r\n this._instancingExtension.drawArraysInstancedANGLE(type, first, count, numInstances);\r\n }\r\n }\r\n\r\n public invalidateFrameBuffer(_attachments: number[]): void { } // does not exist in WebGL1\r\n}\r\n\r\n/** Describes WebGL2 extension methods.\r\n * @internal\r\n */\r\nclass WebGL2Extensions extends WebGLExtensions {\r\n private _context: WebGL2RenderingContext;\r\n public constructor(system: System) {\r\n super(system);\r\n this._context = system.context as WebGL2RenderingContext;\r\n }\r\n\r\n public setDrawBuffers(attachments: GLenum[]): void {\r\n this._context.drawBuffers(attachments);\r\n }\r\n\r\n public vertexAttribDivisor(index: number, divisor: number): void {\r\n this._context.vertexAttribDivisor(index, divisor);\r\n }\r\n\r\n public drawArraysInst(type: GL.PrimitiveType, first: number, count: number, numInstances: number): void { this._context.drawArraysInstanced(type, first, count, numInstances); }\r\n\r\n public invalidateFrameBuffer(attachments: number[]): void {\r\n this._context.invalidateFramebuffer(this._context.FRAMEBUFFER, attachments);\r\n }\r\n}\r\n\r\n/** Id map holds key value pairs for both materials and textures, useful for caching such objects.\r\n * @internal\r\n */\r\nexport class IdMap implements WebGLDisposable {\r\n private readonly _iModel: IModelConnection;\r\n /** Mapping of materials by their key values. */\r\n public readonly materials = new Map<string, RenderMaterial>();\r\n /** Mapping of textures by their key values. */\r\n public readonly textures = new Map<string, RenderTexture>();\r\n /** Mapping of textures using gradient symbology. */\r\n public readonly gradients = new Dictionary<Gradient.Symb, RenderTexture>(Gradient.Symb.compareSymb);\r\n /** Pending promises to create a texture from an ImageSource. This prevents us from decoding the same ImageSource multiple times */\r\n public readonly texturesFromImageSources = new Map<string, Promise<RenderTexture | undefined>>();\r\n\r\n public constructor(iModel: IModelConnection) {\r\n this._iModel = iModel;\r\n }\r\n\r\n public get isDisposed(): boolean {\r\n return 0 === this.textures.size && 0 === this.gradients.size;\r\n }\r\n\r\n public dispose() {\r\n const textureArr = Array.from(this.textures.values());\r\n const gradientArr = this.gradients.extractArrays().values;\r\n\r\n for (const texture of textureArr)\r\n dispose(texture);\r\n\r\n for (const gradient of gradientArr)\r\n dispose(gradient);\r\n\r\n this.textures.clear();\r\n this.gradients.clear();\r\n this.materials.clear();\r\n }\r\n\r\n /** Add a material to this IdMap, given that it has a valid key. */\r\n public addMaterial(material: RenderMaterial) {\r\n if (material.key)\r\n this.materials.set(material.key, material);\r\n }\r\n\r\n /** Add a texture to this IdMap, given that it has a valid key. */\r\n public addTexture(texture: RenderTexture) {\r\n assert(texture instanceof Texture);\r\n if (texture.key)\r\n this.textures.set(texture.key, texture);\r\n }\r\n\r\n /** Add a texture to this IdMap using gradient symbology. */\r\n public addGradient(gradientSymb: Gradient.Symb, texture: RenderTexture) {\r\n this.gradients.set(gradientSymb, texture);\r\n }\r\n\r\n /** Find a cached material using its key. If not found, returns undefined. */\r\n public findMaterial(key: string): RenderMaterial | undefined {\r\n return this.materials.get(key);\r\n }\r\n\r\n /** Find a cached gradient using the gradient symbology. If not found, returns undefined. */\r\n public findGradient(symb: Gradient.Symb): RenderTexture | undefined {\r\n return this.gradients.get(symb);\r\n }\r\n\r\n /** Find or create a new material given material parameters. This will cache the material if its key is valid. */\r\n public getMaterial(params: RenderMaterial.Params): RenderMaterial {\r\n if (!params.key || !Id64.isValidId64(params.key)) // Only cache persistent materials.\r\n return new Material(params);\r\n\r\n let material = this.materials.get(params.key);\r\n if (!material) {\r\n material = new Material(params);\r\n this.materials.set(params.key, material);\r\n }\r\n return material;\r\n }\r\n\r\n public findTexture(key?: string | Gradient.Symb): RenderTexture | undefined {\r\n if (undefined === key)\r\n return undefined;\r\n else if (typeof key === \"string\")\r\n return this.textures.get(key);\r\n else\r\n return this.findGradient(key);\r\n }\r\n\r\n // eslint-disable-next-line deprecation/deprecation\r\n public getTextureFromElement(key: Id64String, iModel: IModelConnection, params: RenderTexture.Params, format: ImageSourceFormat): RenderTexture | undefined {\r\n let tex = this.findTexture(params.key);\r\n if (tex)\r\n return tex;\r\n\r\n const handle = TextureHandle.createForElement(key, iModel, params.type, format);\r\n if (!handle)\r\n return undefined;\r\n\r\n tex = new Texture({ handle, type: params.type, ownership: { key, iModel } });\r\n this.addTexture(tex);\r\n return tex;\r\n }\r\n\r\n public async getTextureFromImageSource(args: CreateTextureFromSourceArgs, key: string): Promise<RenderTexture | undefined> {\r\n const texture = this.findTexture(key);\r\n if (texture)\r\n return texture;\r\n\r\n // Are we already in the process of decoding this image?\r\n let promise = this.texturesFromImageSources.get(key);\r\n if (promise)\r\n return promise;\r\n\r\n promise = this.createTextureFromImageSource(args, key);\r\n this.texturesFromImageSources.set(key, promise);\r\n return promise;\r\n }\r\n\r\n public async createTextureFromImageSource(args: CreateTextureFromSourceArgs, key: string): Promise<RenderTexture | undefined> {\r\n // JPEGs don't support transparency.\r\n const transparency = ImageSourceFormat.Jpeg === args.source.format ? TextureTransparency.Opaque : (args.transparency ?? TextureTransparency.Translucent);\r\n try {\r\n const image = await imageElementFromImageSource(args.source);\r\n if (!IModelApp.hasRenderSystem)\r\n return undefined;\r\n\r\n return IModelApp.renderSystem.createTexture({\r\n type: args.type,\r\n ownership: args.ownership,\r\n image: {\r\n source: image,\r\n transparency,\r\n },\r\n });\r\n } catch {\r\n return undefined;\r\n } finally {\r\n this.texturesFromImageSources.delete(key);\r\n }\r\n }\r\n\r\n // eslint-disable-next-line deprecation/deprecation\r\n public getTextureFromCubeImages(posX: HTMLImageElement, negX: HTMLImageElement, posY: HTMLImageElement, negY: HTMLImageElement, posZ: HTMLImageElement, negZ: HTMLImageElement, params: RenderTexture.Params): RenderTexture | undefined {\r\n let tex = this.findTexture(params.key);\r\n if (tex)\r\n return tex;\r\n\r\n const handle = TextureHandle.createForCubeImages(posX, negX, posY, negY, posZ, negZ);\r\n if (!handle)\r\n return undefined;\r\n\r\n const ownership = params.key ? { key: params.key, iModel: this._iModel } : (params.isOwned ? \"external\" : undefined);\r\n tex = new Texture({ handle, ownership, type: params.type });\r\n this.addTexture(tex);\r\n return tex;\r\n }\r\n\r\n public collectStatistics(stats: RenderMemory.Statistics): void {\r\n for (const texture of this.textures.values())\r\n if (texture instanceof Texture)\r\n stats.addTexture(texture.bytesUsed);\r\n\r\n for (const gradient of this.gradients)\r\n if (gradient instanceof Texture)\r\n stats.addTexture(gradient.bytesUsed);\r\n }\r\n}\r\n\r\nexport type TextureBinding = WebGLTexture | undefined;\r\n\r\nconst enum VertexAttribState {\r\n Disabled = 0,\r\n Enabled = 1 << 0,\r\n Instanced = 1 << 2,\r\n InstancedEnabled = Instanced | Enabled,\r\n}\r\n\r\ninterface TextureCacheInfo {\r\n idMap: IdMap;\r\n key: TextureCacheKey;\r\n}\r\n\r\n/** @internal */\r\nexport class System extends RenderSystem implements RenderSystemDebugControl, RenderMemory.Consumer, WebGLDisposable {\r\n public readonly canvas: HTMLCanvasElement;\r\n public readonly currentRenderState = new RenderState();\r\n public readonly context: WebGLContext;\r\n public readonly frameBufferStack = new FrameBufferStack(); // frame buffers are not owned by the system\r\n public readonly capabilities: Capabilities;\r\n public readonly resourceCache: Map<IModelConnection, IdMap>;\r\n public readonly glTimer: GLTimer;\r\n private readonly _extensions: WebGLExtensions;\r\n private readonly _textureBindings: TextureBinding[] = [];\r\n private _removeEventListener?: () => void;\r\n\r\n // NB: Increase the size of these arrays when the maximum number of attributes used by any one shader increases.\r\n private readonly _curVertexAttribStates: VertexAttribState[] = [\r\n VertexAttribState.Disabled, VertexAttribState.Disabled, VertexAttribState.Disabled, VertexAttribState.Disabled,\r\n VertexAttribState.Disabled, VertexAttribState.Disabled, VertexAttribState.Disabled, VertexAttribState.Disabled,\r\n VertexAttribState.Disabled, VertexAttribState.Disabled, VertexAttribState.Disabled, VertexAttribState.Disabled,\r\n ];\r\n private readonly _nextVertexAttribStates: VertexAttribState[] = [\r\n VertexAttribState.Disabled, VertexAttribState.Disabled, VertexAttribState.Disabled, VertexAttribState.Disabled,\r\n VertexAttribState.Disabled, VertexAttribState.Disabled, VertexAttribState.Disabled, VertexAttribState.Disabled,\r\n VertexAttribState.Disabled, VertexAttribState.Disabled, VertexAttribState.Disabled, VertexAttribState.Disabled,\r\n ];\r\n\r\n // The following are initialized immediately after the System is constructed.\r\n private _lineCodeTexture?: TextureHandle;\r\n private _noiseTexture?: TextureHandle;\r\n private _techniques?: Techniques;\r\n private _screenSpaceEffects?: ScreenSpaceEffects;\r\n public readonly debugShaderFiles: DebugShaderFile[] = [];\r\n\r\n public static get instance() { return IModelApp.renderSystem as System; }\r\n\r\n public get isValid(): boolean { return this.canvas !== undefined; }\r\n public get lineCodeTexture() { return this._lineCodeTexture; }\r\n public get noiseTexture() { return this._noiseTexture; }\r\n\r\n public get techniques() {\r\n assert(undefined !== this._techniques);\r\n return this._techniques;\r\n }\r\n\r\n public get screenSpaceEffects() {\r\n assert(undefined !== this._screenSpaceEffects);\r\n return this._screenSpaceEffects;\r\n }\r\n\r\n public override get maxTextureSize(): number { return this.capabilities.maxTextureSize; }\r\n public override get supportsInstancing(): boolean { return this.capabilities.supportsInstancing; }\r\n public override get supportsNonuniformScaledInstancing(): boolean { return this.capabilities.isWebGL2; }\r\n public get isWebGL2(): boolean { return this.capabilities.isWebGL2; }\r\n public override get isMobile(): boolean { return this.capabilities.isMobile; }\r\n\r\n public setDrawBuffers(attachments: GLenum[]): void { this._extensions.setDrawBuffers(attachments); }\r\n\r\n public doIdleWork(): boolean {\r\n return this.techniques.idleCompileNextShader();\r\n }\r\n\r\n /** Return a Promise which when resolved indicates that all pending external textures have finished loading from the backend. */\r\n public override async waitForAllExternalTextures(): Promise<void> {\r\n const extTexLoader = ExternalTextureLoader.instance;\r\n if (extTexLoader.numActiveRequests < 1 && extTexLoader.numPendingRequests < 1)\r\n return Promise.resolve();\r\n const promise = new Promise<void>((resolve: any) => {\r\n extTexLoader.onTexturesLoaded.addOnce(() => {\r\n resolve();\r\n });\r\n });\r\n return promise;\r\n }\r\n\r\n /** Attempt to create a WebGLRenderingContext, returning undefined if unsuccessful. */\r\n public static createContext(canvas: HTMLCanvasElement, useWebGL2: boolean, inputContextAttributes?: WebGLContextAttributes): WebGLContext | undefined {\r\n let contextAttributes: WebGLContextAttributes = { powerPreference: \"high-performance\" };\r\n if (undefined !== inputContextAttributes) {\r\n // NOTE: Order matters with spread operator - if caller wants to override powerPreference, he should be able to.\r\n contextAttributes = { ...contextAttributes, ...inputContextAttributes };\r\n }\r\n\r\n // If requested, first try obtaining a WebGL2 context.\r\n let context = null;\r\n if (useWebGL2)\r\n context = canvas.getContext(\"webgl2\", contextAttributes);\r\n\r\n // Fall back to WebGL1 if necessary.\r\n if (null === context)\r\n context = canvas.getContext(\"webgl\", contextAttributes);\r\n\r\n return context ?? undefined;\r\n }\r\n\r\n public static create(optionsIn?: RenderSystem.Options): System {\r\n const options: RenderSystem.Options = undefined !== optionsIn ? optionsIn : {};\r\n const canvas = document.createElement(\"canvas\");\r\n if (null === canvas)\r\n throw new IModelError(BentleyStatus.ERROR, \"Failed to obtain HTMLCanvasElement\");\r\n\r\n const useWebGL2 = (undefined === options.useWebGL2 ? true : options.useWebGL2);\r\n const context = this.createContext(canvas, useWebGL2, optionsIn?.contextAttributes);\r\n if (undefined === context) {\r\n throw new IModelError(BentleyStatus.ERROR, \"Failed to obtain WebGL context\");\r\n }\r\n\r\n const capabilities = Capabilities.create(context, options.disabledExtensions);\r\n if (undefined === capabilities)\r\n throw new IModelError(BentleyStatus.ERROR, \"Failed to initialize rendering capabilities\");\r\n\r\n // set actual gl state to match desired state defaults\r\n context.depthFunc(GL.DepthFunc.Default); // LessOrEqual\r\n\r\n if (!capabilities.supportsShadowMaps)\r\n options.displaySolarShadows = false;\r\n if (!capabilities.supportsFragDepth)\r\n options.logarithmicDepthBuffer = false;\r\n if (!capabilities.supportsTextureFilterAnisotropic) {\r\n options.filterMapTextures = false;\r\n options.filterMapDrapeTextures = false;\r\n }\r\n return new this(canvas, context, capabilities, options);\r\n }\r\n\r\n public get isDisposed(): boolean {\r\n return undefined === this._techniques\r\n && undefined === this._lineCodeTexture\r\n && undefined === this._noiseTexture\r\n && undefined === this._screenSpaceEffects;\r\n }\r\n\r\n // Note: FrameBuffers inside of the FrameBufferStack are not owned by the System, and are only used as a central storage device\r\n public dispose() {\r\n this._techniques = dispose(this._techniques);\r\n this._screenSpaceEffects = dispose(this._screenSpaceEffects);\r\n this._lineCodeTexture = dispose(this._lineCodeTexture);\r\n this._noiseTexture = dispose(this._noiseTexture);\r\n\r\n // We must attempt to dispose of each idmap in the resourceCache (if idmap is already disposed, has no effect)\r\n this.resourceCache.forEach((idMap: IdMap) => {\r\n dispose(idMap);\r\n });\r\n\r\n this.resourceCache.clear();\r\n if (undefined !== this._removeEventListener) {\r\n this._removeEventListener();\r\n this._removeEventListener = undefined;\r\n }\r\n }\r\n\r\n public override onInitialized(): void {\r\n this._techniques = Techniques.create(this.context);\r\n\r\n const noiseDim = 4;\r\n const noiseArr = new Uint8Array([152, 235, 94, 173, 219, 215, 115, 176, 73, 205, 43, 201, 10, 81, 205, 198]);\r\n this._noiseTexture = TextureHandle.createForData(noiseDim, noiseDim, noiseArr, false, GL.Texture.WrapMode.Repeat, GL.Texture.Format.Luminance);\r\n assert(undefined !== this._noiseTexture, \"System.noiseTexture not created.\");\r\n\r\n this._lineCodeTexture = TextureHandle.createForData(LineCode.size, LineCode.count, new Uint8Array(LineCode.lineCodeData), false, GL.Texture.WrapMode.Repeat, GL.Texture.Format.Luminance);\r\n assert(undefined !== this._lineCodeTexture, \"System.lineCodeTexture not created.\");\r\n\r\n this._screenSpaceEffects = new ScreenSpaceEffects();\r\n }\r\n\r\n public createTarget(canvas: HTMLCanvasElement): RenderTarget {\r\n return new OnScreenTarget(canvas);\r\n }\r\n\r\n public createOffscreenTarget(rect: ViewRect): RenderTarget {\r\n return new OffScreenTarget(rect);\r\n }\r\n\r\n public createGraphic(options: CustomGraphicBuilderOptions | ViewportGraphicBuilderOptions): GraphicBuilder {\r\n return new PrimitiveBuilder(this, options);\r\n }\r\n\r\n public override createPlanarGrid(frustum: Frustum, grid: PlanarGridProps): RenderGraphic | undefined {\r\n return PlanarGridGeometry.create(frustum, grid, this);\r\n }\r\n\r\n public override createRealityMeshFromTerrain(terrainMesh: TerrainMeshPrimitive, transform?: Transform): RealityMeshGeometry | undefined {\r\n return RealityMeshGeometry.createFromTerrainMesh(terrainMesh, transform);\r\n }\r\n\r\n public override createRealityMeshGraphic(terrainGeometry: RealityMeshGeometry, featureTable: PackedFeatureTable, tileId: string | undefined, baseColor: ColorDef | undefined, baseTransparent: boolean, textures?: TerrainTexture[]): RenderGraphic | undefined {\r\n return RealityMeshGeometry.createGraphic(this, terrainGeometry, featureTable, tileId, baseColor, baseTransparent, textures);\r\n }\r\n public override createRealityMesh(realityMesh: RealityMeshPrimitive): RenderGraphic | undefined {\r\n const geom = RealityMeshGeometry.createFromRealityMesh(realityMesh);\r\n return geom ? Primitive.create(geom) : undefined;\r\n }\r\n\r\n public override createMeshGeometry(params: MeshParams, viOrigin?: Point3d): MeshRenderGeometry | undefined {\r\n return MeshRenderGeometry.create(params, viOrigin);\r\n }\r\n\r\n public override createPolylineGeometry(params: PolylineParams, viOrigin?: Point3d): PolylineGeometry | undefined {\r\n return PolylineGeometry.create(params, viOrigin);\r\n }\r\n\r\n public override createPointStringGeometry(params: PointStringParams, viOrigin?: Point3d): PointStringGeometry | undefined {\r\n return PointStringGeometry.create(params, viOrigin);\r\n }\r\n\r\n public override createAreaPattern(params: PatternGraphicParams): PatternBuffers | undefined {\r\n return PatternBuffers.create(params);\r\n }\r\n\r\n public override createRenderGraphic(geometry: RenderGeometry, instances?: InstancedGraphicParams | RenderAreaPattern): RenderGraphic | undefined {\r\n if (!(geometry instanceof MeshRenderGeometry)) {\r\n if (geometry instanceof PolylineGeometry || geometry instanceof PointStringGeometry)\r\n return Primitive.create(geometry, instances);\r\n\r\n assert(false, \"Invalid RenderGeometry for System.createRenderGraphic\");\r\n return undefined;\r\n }\r\n\r\n assert(!instances || instances instanceof PatternBuffers || isInstancedGraphicParams(instances));\r\n return MeshGraphic.create(geometry, instances);\r\n }\r\n\r\n public override createPointCloud(args: PointCloudArgs): RenderGraphic | undefined {\r\n return Primitive.create(new PointCloudGeometry(args));\r\n }\r\n\r\n public createGraphicList(primitives: RenderGraphic[]): RenderGraphic {\r\n return new GraphicsArray(primitives);\r\n }\r\n\r\n public createGraphicBranch(branch: GraphicBranch, transform: Transform, options?: GraphicBranchOptions): RenderGraphic {\r\n return new Branch(branch, transform, undefined, options);\r\n }\r\n\r\n public override createAnimationTransformNode(graphic: RenderGraphic, nodeId: number): RenderGraphic {\r\n return new AnimationTransformBranch(graphic, nodeId);\r\n }\r\n\r\n public createBatch(graphic: RenderGraphic, features: PackedFeatureTable, range: ElementAlignedBox3d, options?: BatchOptions): RenderGraphic {\r\n return new Batch(graphic, features, range, options);\r\n }\r\n\r\n public override createGraphicOwner(owned: RenderGraphic): RenderGraphicOwner {\r\n return new GraphicOwner(owned as Graphic);\r\n }\r\n\r\n public override createGraphicLayer(graphic: RenderGraphic, layerId: string) {\r\n return new Layer(graphic as Graphic, layerId);\r\n }\r\n\r\n public override createGraphicLayerContainer(graphic: RenderGraphic, drawAsOverlay: boolean, transparency: number, elevation: number) {\r\n return new LayerContainer(graphic as Graphic, drawAsOverlay, transparency, elevation);\r\n }\r\n\r\n public override createSkyBox(params: RenderSkyBoxParams): RenderGraphic | undefined {\r\n if (\"cube\" === params.type)\r\n return SkyCubePrimitive.create(SkyBoxQuadsGeometry.create(params.texture));\r\n\r\n return SkySpherePrimitive.create(SkySphereViewportQuadGeometry.createGeometry(params));\r\n }\r\n\r\n public override createScreenSpaceEffectBuilder(params: ScreenSpaceEffectBuilderParams): ScreenSpaceEffectBuilder {\r\n return createScreenSpaceEffectBuilder(params);\r\n }\r\n\r\n public applyRenderState(newState: RenderState) {\r\n newState.apply(this.currentRenderState);\r\n this.currentRenderState.copyFrom(newState);\r\n }\r\n\r\n public createDepthBuffer(width: number, height: number, numSamples: number = 1): DepthBuffer | undefined {\r\n // Note: The buffer/texture created here have ownership passed to the caller (system will not dispose of these)\r\n switch (this.capabilities.maxDepthType) {\r\n case DepthType.RenderBufferUnsignedShort16: {\r\n return RenderBuffer.create(width, height);\r\n }\r\n case DepthType.TextureUnsignedInt32: {\r\n return TextureHandle.createForAttachment(width, height, GL.Texture.Format.DepthComponent, GL.Texture.DataType.UnsignedInt);\r\n }\r\n case DepthType.TextureUnsignedInt24Stencil8: {\r\n if (this.capabilities.isWebGL2) {\r\n if (numSamples > 1) {\r\n return RenderBufferMultiSample.create(width, height, WebGL2RenderingContext.DEPTH24_STENCIL8, numSamples);\r\n } else {\r\n const context2 = this.context as WebGL2RenderingContext;\r\n return TextureHandle.createForAttachment(width, height, GL.Texture.Format.DepthStencil, context2.UNSIGNED_INT_24_8);\r\n }\r\n } else {\r\n const dtExt: WEBGL_depth_texture | undefined = this.capabilities.queryExtensionObject<WEBGL_depth_texture>(\"WEBGL_depth_texture\");\r\n return TextureHandle.createForAttachment(width, height, GL.Texture.Format.DepthStencil, dtExt!.UNSIGNED_INT_24_8_WEBGL);\r\n }\r\n }\r\n default: {\r\n assert(false);\r\n return undefined;\r\n }\r\n }\r\n }\r\n\r\n /** Returns the corresponding IdMap for an IModelConnection. Creates a new one if it doesn't exist. */\r\n public createIModelMap(imodel: IModelConnection): IdMap {\r\n let idMap = this.resourceCache.get(imodel);\r\n if (!idMap) {\r\n idMap = new IdMap(imodel);\r\n this.resourceCache.set(imodel, idMap);\r\n }\r\n return idMap;\r\n }\r\n\r\n /** Removes an IModelConnection-IdMap pairing from the system's resource cache. */\r\n private removeIModelMap(imodel: IModelConnection) {\r\n const idMap = this.resourceCache.get(imodel);\r\n if (idMap === undefined)\r\n return;\r\n dispose(idMap);\r\n this.resourceCache.delete(imodel);\r\n }\r\n\r\n /** Attempt to create a material for the given iModel using a set of material parameters. */\r\n public override createMaterial(params: RenderMaterial.Params, imodel: IModelConnection): RenderMaterial | undefined {\r\n const idMap = this.getIdMap(imodel);\r\n const material = idMap.getMaterial(params);\r\n return material;\r\n }\r\n\r\n /** Using its key, search for an existing material of an open iModel. */\r\n public override findMaterial(key: string, imodel: IModelConnection): RenderMaterial | undefined {\r\n const idMap = this.resourceCache.get(imodel);\r\n if (!idMap)\r\n return undefined;\r\n return idMap.findMaterial(key);\r\n }\r\n\r\n private getTextureCacheInfo(args: CreateTextureArgs): TextureCacheInfo | undefined {\r\n const owner = undefined !== args.ownership && args.ownership !== \"external\" ? args.ownership : undefined;\r\n return owner ? { idMap: this.getIdMap(owner.iModel), key: owner.key } : undefined;\r\n }\r\n\r\n public override createTexture(args: CreateTextureArgs): RenderTexture | undefined {\r\n const info = this.getTextureCacheInfo(args);\r\n const existing = info?.idMap.findTexture(info?.key);\r\n if (existing)\r\n return existing;\r\n\r\n const type = args.type ?? RenderTexture.Type.Normal;\r\n const source = args.image.source;\r\n\r\n // ###TODO createForImageBuffer should take args.transparency.\r\n let handle;\r\n if (source instanceof ImageBuffer)\r\n handle = TextureHandle.createForImageBuffer(source, type); // ###TODO use transparency from args\r\n else\r\n handle = TextureHandle.createForImage(source, TextureTransparency.Opaque !== args.image.transparency, type);\r\n\r\n if (!handle)\r\n return undefined;\r\n\r\n const texture = new Texture({ handle, type, ownership: args.ownership });\r\n if (texture && info)\r\n info.idMap.addTexture(texture);\r\n\r\n return texture;\r\n }\r\n\r\n public override async createTextureFromSource(args: CreateTextureFromSourceArgs): Promise<RenderTexture | undefined> {\r\n if (typeof args.ownership !== \"object\")\r\n return super.createTextureFromSource(args);\r\n\r\n return this.getIdMap(args.ownership.iModel).getTextureFromImageSource(args, args.ownership.key);\r\n }\r\n\r\n // eslint-disable-next-line deprecation/deprecation\r\n public override createTextureFromElement(id: Id64String, imodel: IModelConnection, params: RenderTexture.Params, format: ImageSourceFormat): RenderTexture | undefined {\r\n return this.getIdMap(imodel).getTextureFromElement(id, imodel, params, format);\r\n }\r\n\r\n // eslint-disable-next-line deprecation/deprecation\r\n public override createTextureFromCubeImages(posX: HTMLImageElement, negX: HTMLImageElement, posY: HTMLImageElement, negY: HTMLImageElement, posZ: HTMLImageElement, negZ: HTMLImageElement, imodel: IModelConnection, params: RenderTexture.Params): RenderTexture | undefined {\r\n return this.getIdMap(imodel).getTextureFromCubeImages(posX, negX, posY, negY, posZ, negZ, params);\r\n }\r\n\r\n /** Attempt to create a texture using gradient symbology. */\r\n public override getGradientTexture(symb: Gradient.Symb, iModel?: IModelConnection): RenderTexture | undefined {\r\n const source = symb.getImage(0x100, 0x100);\r\n return this.createTexture({\r\n image: {\r\n source,\r\n transparency: ImageBufferFormat.Rgba === source.format ? TextureTransparency.Translucent : TextureTransparency.Opaque,\r\n },\r\n ownership: iModel ? { iModel, key: symb } : undefined,\r\n type: RenderTexture.Type.Normal,\r\n });\r\n }\r\n\r\n /** Using its key, search for an existing texture of an open iModel. */\r\n public override findTexture(key: TextureCacheKey, imodel: IModelConnection): RenderTexture | undefined {\r\n const idMap = this.resourceCache.get(imodel);\r\n if (!idMap)\r\n return undefined;\r\n\r\n return idMap.findTexture(key);\r\n }\r\n\r\n public override createClipVolume(clipVector: ClipVector): RenderClipVolume | undefined {\r\n return ClipVolume.create(clipVector);\r\n }\r\n public override createBackgroundMapDrape(drapedTree: TileTreeReference, mapTree: MapTileTreeReference) {\r\n return BackgroundMapDrape.create(drapedTree, mapTree);\r\n }\r\n\r\n protected constructor(canvas: HTMLCanvasElement, context: WebGLContext, capabilities: Capabilities, options: RenderSystem.Options) {\r\n super(options);\r\n this.canvas = canvas;\r\n this.context = context;\r\n this.capabilities = capabilities;\r\n this.resourceCache = new Map<IModelConnection, IdMap>();\r\n this.glTimer = GLTimer.create(this);\r\n if (capabilities.isWebGL2)\r\n this._extensions = new WebGL2Extensions(this);\r\n else {\r\n const drawBuffersExtension = capabilities.queryExtensionObject<WEBGL_draw_buffers>(\"WEBGL_draw_buffers\");\r\n const instancingExtension = capabilities.queryExtensionObject<ANGLE_instanced_arrays>(\"ANGLE_instanced_arrays\");\r\n this._extensions = new WebGL1Extensions(this, drawBuffersExtension, instancingExtension);\r\n }\r\n\r\n // Make this System a subscriber to the the IModelConnection onClose event\r\n this._removeEventListener = IModelConnection.onClose.addListener((imodel) => this.removeIModelMap(imodel));\r\n\r\n canvas.addEventListener(\"webglcontextlost\", async () => RenderSystem.contextLossHandler(), false);\r\n }\r\n\r\n /** Exposed strictly for tests. */\r\n public getIdMap(imodel: IModelConnection): IdMap {\r\n const map = this.resourceCache.get(imodel);\r\n return undefined !== map ? map : this.createIModelMap(imodel);\r\n }\r\n\r\n private bindTexture(unit: TextureUnit, target: GL.Texture.Target, texture: TextureBinding, makeActive: boolean): void {\r\n const index = unit - TextureUnit.Zero;\r\n if (this._textureBindings[index] === texture) {\r\n if (makeActive)\r\n this.context.activeTexture(unit);\r\n\r\n return;\r\n }\r\n\r\n this._textureBindings[index] = texture;\r\n this.context.activeTexture(unit);\r\n this.context.bindTexture(target, undefined !== texture ? texture : null);\r\n }\r\n\r\n /** Bind the specified texture to the specified unit. This may *or may not* make the texture *active* */\r\n public bindTexture2d(unit: TextureUnit, texture: TextureBinding) { this.bindTexture(unit, GL.Texture.Target.TwoDee, texture, false); }\r\n /** Bind the specified texture to the specified unit. This may *or may not* make the texture *active* */\r\n public bindTextureCubeMap(unit: TextureUnit, texture: TextureBinding) { this.bindTexture(unit, GL.Texture.Target.CubeMap, texture, false); }\r\n /** Bind the specified texture to the specified unit. This *always* makes the texture *active* */\r\n public activateTexture2d(unit: TextureUnit, texture: TextureBinding) { this.bindTexture(unit, GL.Texture.Target.TwoDee, texture, true); }\r\n /** Bind the specified texture to the specified unit. This *always* makes the texture *active* */\r\n public activateTextureCubeMap(unit: TextureUnit, texture: TextureBinding) { this.bindTexture(unit, GL.Texture.Target.CubeMap, texture, true); }\r\n\r\n // Ensure *something* is bound to suppress 'no texture assigned to unit x' warnings.\r\n public ensureSamplerBound(uniform: UniformHandle, unit: TextureUnit): void {\r\n this.lineCodeTexture!.bindSampler(uniform, unit);\r\n }\r\n public override get maxRealityImageryLayers() { return Math.min(this.capabilities.maxFragTextureUnits, this.capabilities.maxVertTextureUnits) < 16 ? 3 : 6; }\r\n\r\n public disposeTexture(texture: WebGLTexture) {\r\n System.instance.context.deleteTexture(texture);\r\n for (let i = 0; i < this._textureBindings.length; i++) {\r\n if (this._textureBindings[i] === texture) {\r\n this._textureBindings[i] = undefined;\r\n break;\r\n }\r\n }\r\n }\r\n\r\n // System keeps track of current enabled state of vertex attribute arrays.\r\n // This prevents errors caused by leaving a vertex attrib array enabled after disposing of the buffer bound to it;\r\n // also prevents unnecessarily 'updating' the enabled state of a vertex attrib array when it hasn't actually changed.\r\n public enableVertexAttribArray(id: number, instanced: boolean): void {\r\n assert(id < this._nextVertexAttribStates.length, \"if you add new vertex attributes you must update array length\");\r\n assert(id < this._curVertexAttribStates.length, \"if you add new vertex attributes you must update array length\");\r\n\r\n this._nextVertexAttribStates[id] = instanced ? VertexAttribState.InstancedEnabled : VertexAttribState.Enabled;\r\n }\r\n\r\n public updateVertexAttribArrays(): void {\r\n const cur = this._curVertexAttribStates;\r\n const next = this._nextVertexAttribStates;\r\n const context = this.context;\r\n\r\n for (let i = 0; i < next.length; i++) {\r\n const oldState = cur[i];\r\n const newState = next[i];\r\n if (oldState !== newState) {\r\n // Update the enabled state if it changed.\r\n const wasEnabled = 0 !== (VertexAttribState.Enabled & oldState);\r\n const nowEnabled = 0 !== (VertexAttribState.Enabled & newState);\r\n if (wasEnabled !== nowEnabled) {\r\n if (nowEnabled) {\r\n context.enableVertexAttribArray(i);\r\n } else {\r\n context.disableVertexAttribArray(i);\r\n }\r\n }\r\n\r\n // Only update the divisor if the attribute is enabled.\r\n if (nowEnabled) {\r\n const wasInstanced = 0 !== (VertexAttribState.Instanced & oldState);\r\n const nowInstanced = 0 !== (VertexAttribState.Instanced & newState);\r\n if (wasInstanced !== nowInstanced) {\r\n this.vertexAttribDivisor(i, nowInstanced ? 1 : 0);\r\n }\r\n }\r\n\r\n cur[i] = newState;\r\n }\r\n\r\n // Set the attribute back to disabled, but preserve the divisor.\r\n next[i] &= ~VertexAttribState.Enabled;\r\n }\r\n }\r\n\r\n public vertexAttribDivisor(index: number, divisor: number) { this._extensions.vertexAttribDivisor(index, divisor); }\r\n\r\n public drawArrays(type: GL.PrimitiveType, first: number, count: number, numInstances: number): void {\r\n if (0 !== numInstances) {\r\n this._extensions.drawArraysInst(type, first, count, numInstances);\r\n } else {\r\n this.context.drawArrays(type, first, count);\r\n }\r\n }\r\n\r\n public invalidateFrameBuffer(attachments: number[]): void { this._extensions.invalidateFrameBuffer(attachments); }\r\n\r\n public override enableDiagnostics(enable: RenderDiagnostics): void {\r\n Debug.printEnabled = RenderDiagnostics.None !== (enable & RenderDiagnostics.DebugOutput);\r\n Debug.evaluateEnabled = RenderDiagnostics.None !== (enable & RenderDiagnostics.WebGL);\r\n }\r\n\r\n // RenderSystemDebugControl\r\n public override get debugControl(): RenderSystemDebugControl { return this; }\r\n\r\n private _dpiAwareLOD?: boolean;\r\n public override get dpiAwareLOD(): boolean { return this._dpiAwareLOD ?? super.dpiAwareLOD; }\r\n public override set dpiAwareLOD(dpiAware: boolean) { this._dpiAwareLOD = dpiAware; }\r\n\r\n public loseContext(): boolean {\r\n const ext = this.capabilities.queryExtensionObject<WEBGL_lose_context>(\"WEBGL_lose_context\");\r\n if (undefined === ext)\r\n return false;\r\n\r\n ext.loseContext();\r\n return true;\r\n }\r\n\r\n public compileAllShaders(): boolean {\r\n return this.techniques.compileShaders();\r\n }\r\n\r\n public get isGLTimerSupported(): boolean { return this.glTimer.isSupported; }\r\n public set resultsCallback(callback: GLTimerResultCallback | undefined) {\r\n this.glTimer.resultsCallback = callback;\r\n }\r\n\r\n public override collectStatistics(stats: RenderMemory.Statistics): void {\r\n if (undefined !== this._lineCodeTexture)\r\n stats.addTexture(this._lineCodeTexture.bytesUsed);\r\n\r\n if (undefined !== this._noiseTexture)\r\n stats.addTexture(this._noiseTexture.bytesUsed);\r\n\r\n for (const idMap of this.resourceCache.values())\r\n idMap.collectStatistics(stats);\r\n }\r\n\r\n public setMaxAnisotropy(max: number | undefined): void {\r\n this.capabilities.setMaxAnisotropy(max, this.context);\r\n }\r\n}\r\n"]}
|
|
1
|
+
{"version":3,"file":"System.js","sourceRoot":"","sources":["../../../../src/render/webgl/System.ts"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\r\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\r\n* See LICENSE.md in the project root for license terms and full copyright notice.\r\n*--------------------------------------------------------------------------------------------*/\r\n/** @packageDocumentation\r\n * @module WebGL\r\n */\r\n\r\nimport { assert, BentleyStatus, Dictionary, dispose, Id64, Id64String } from \"@itwin/core-bentley\";\r\nimport { ClipVector, Point3d, Transform } from \"@itwin/core-geometry\";\r\nimport {\r\n ColorDef, ElementAlignedBox3d, Frustum, Gradient, ImageBuffer, ImageBufferFormat, ImageSourceFormat, IModelError, PackedFeatureTable, RenderMaterial, RenderTexture,\r\n} from \"@itwin/core-common\";\r\nimport { Capabilities, DepthType, WebGLContext } from \"@itwin/webgl-compatibility\";\r\nimport { imageElementFromImageSource } from \"../../ImageUtil\";\r\nimport { IModelApp } from \"../../IModelApp\";\r\nimport { IModelConnection } from \"../../IModelConnection\";\r\nimport { MapTileTreeReference, TileTreeReference } from \"../../tile/internal\";\r\nimport { ViewRect } from \"../../ViewRect\";\r\nimport { GraphicBranch, GraphicBranchOptions } from \"../GraphicBranch\";\r\nimport { BatchOptions, CustomGraphicBuilderOptions, GraphicBuilder, ViewportGraphicBuilderOptions } from \"../GraphicBuilder\";\r\nimport { InstancedGraphicParams, PatternGraphicParams } from \"../InstancedGraphicParams\";\r\nimport { PrimitiveBuilder } from \"../primitives/geometry/GeometryListBuilder\";\r\nimport { RealityMeshPrimitive } from \"../primitives/mesh/RealityMeshPrimitive\";\r\nimport { TerrainMeshPrimitive } from \"../primitives/mesh/TerrainMeshPrimitive\";\r\nimport { PointCloudArgs } from \"../primitives/PointCloudPrimitive\";\r\nimport { MeshParams } from \"../primitives/VertexTable\";\r\nimport { PointStringParams } from \"../primitives/PointStringParams\";\r\nimport { PolylineParams } from \"../primitives/PolylineParams\";\r\nimport { RenderClipVolume } from \"../RenderClipVolume\";\r\nimport { RenderGraphic, RenderGraphicOwner } from \"../RenderGraphic\";\r\nimport { RenderMemory } from \"../RenderMemory\";\r\nimport { CreateTextureArgs, CreateTextureFromSourceArgs, TextureCacheKey, TextureTransparency } from \"../RenderTexture\";\r\nimport {\r\n DebugShaderFile, GLTimerResultCallback, PlanarGridProps, RenderAreaPattern, RenderDiagnostics, RenderGeometry, RenderSkyBoxParams,\r\n RenderSystem, RenderSystemDebugControl, TerrainTexture,\r\n} from \"../RenderSystem\";\r\nimport { RenderTarget } from \"../RenderTarget\";\r\nimport { ScreenSpaceEffectBuilder, ScreenSpaceEffectBuilderParams } from \"../ScreenSpaceEffectBuilder\";\r\nimport { BackgroundMapDrape } from \"./BackgroundMapDrape\";\r\nimport { SkyBoxQuadsGeometry, SkySphereViewportQuadGeometry } from \"./CachedGeometry\";\r\nimport { ClipVolume } from \"./ClipVolume\";\r\nimport { isInstancedGraphicParams, PatternBuffers } from \"./InstancedGeometry\";\r\nimport { Debug } from \"./Diagnostics\";\r\nimport { WebGLDisposable } from \"./Disposable\";\r\nimport { DepthBuffer, FrameBufferStack } from \"./FrameBuffer\";\r\nimport { GL } from \"./GL\";\r\nimport { GLTimer } from \"./GLTimer\";\r\nimport { AnimationTransformBranch, Batch, Branch, Graphic, GraphicOwner, GraphicsArray } from \"./Graphic\";\r\nimport { Layer, LayerContainer } from \"./Layer\";\r\nimport { LineCode } from \"./LineCode\";\r\nimport { Material } from \"./Material\";\r\nimport { MeshGraphic, MeshRenderGeometry } from \"./Mesh\";\r\nimport { PointCloudGeometry } from \"./PointCloud\";\r\nimport { PointStringGeometry } from \"./PointString\";\r\nimport { PolylineGeometry } from \"./Polyline\";\r\nimport { Primitive, SkyCubePrimitive, SkySpherePrimitive } from \"./Primitive\";\r\nimport { RenderBuffer, RenderBufferMultiSample } from \"./RenderBuffer\";\r\nimport { TextureUnit } from \"./RenderFlags\";\r\nimport { RenderState } from \"./RenderState\";\r\nimport { createScreenSpaceEffectBuilder, ScreenSpaceEffects } from \"./ScreenSpaceEffect\";\r\nimport { OffScreenTarget, OnScreenTarget } from \"./Target\";\r\nimport { Techniques } from \"./Technique\";\r\nimport { RealityMeshGeometry } from \"./RealityMesh\";\r\nimport { ExternalTextureLoader, Texture, TextureHandle } from \"./Texture\";\r\nimport { UniformHandle } from \"./UniformHandle\";\r\nimport { PlanarGridGeometry } from \"./PlanarGrid\";\r\n\r\n/* eslint-disable no-restricted-syntax */\r\n\r\n/** @internal */\r\nexport const enum ContextState {\r\n Uninitialized,\r\n Success,\r\n Error,\r\n}\r\n\r\n/** Describes WebGL extension methods.\r\n * @internal\r\n */\r\nabstract class WebGLExtensions {\r\n private _system: System;\r\n public constructor(system: System) {\r\n this._system = system;\r\n }\r\n public get system() { return this._system; }\r\n public abstract setDrawBuffers(attachments: GLenum[]): void;\r\n public abstract vertexAttribDivisor(index: number, divisor: number): void;\r\n public abstract drawArraysInst(type: GL.PrimitiveType, first: number, count: number, numInstances: number): void;\r\n public abstract invalidateFrameBuffer(_attachments: number[]): void;\r\n}\r\n\r\n/** Describes WebGL1 extension methods.\r\n * @internal\r\n */\r\nclass WebGL1Extensions extends WebGLExtensions {\r\n private readonly _drawBuffersExtension?: WEBGL_draw_buffers;\r\n private readonly _instancingExtension?: ANGLE_instanced_arrays;\r\n\r\n public constructor(system: System, drawBuffersExt: WEBGL_draw_buffers | undefined, instancingExt: ANGLE_instanced_arrays | undefined) {\r\n super(system);\r\n this._drawBuffersExtension = drawBuffersExt;\r\n this._instancingExtension = instancingExt;\r\n }\r\n\r\n public setDrawBuffers(attachments: GLenum[]): void {\r\n // NB: The WEBGL_draw_buffers member is not exported directly because that type name is not available in some contexts (e.g. test-imodel-service).\r\n if (undefined !== this._drawBuffersExtension)\r\n this._drawBuffersExtension.drawBuffersWEBGL(attachments);\r\n }\r\n\r\n public vertexAttribDivisor(index: number, divisor: number): void {\r\n assert(undefined !== this._instancingExtension);\r\n this._instancingExtension.vertexAttribDivisorANGLE(index, divisor);\r\n }\r\n\r\n public drawArraysInst(type: GL.PrimitiveType, first: number, count: number, numInstances: number): void {\r\n if (undefined !== this._instancingExtension) {\r\n this._instancingExtension.drawArraysInstancedANGLE(type, first, count, numInstances);\r\n }\r\n }\r\n\r\n public invalidateFrameBuffer(_attachments: number[]): void { } // does not exist in WebGL1\r\n}\r\n\r\n/** Describes WebGL2 extension methods.\r\n * @internal\r\n */\r\nclass WebGL2Extensions extends WebGLExtensions {\r\n private _context: WebGL2RenderingContext;\r\n public constructor(system: System) {\r\n super(system);\r\n this._context = system.context as WebGL2RenderingContext;\r\n }\r\n\r\n public setDrawBuffers(attachments: GLenum[]): void {\r\n this._context.drawBuffers(attachments);\r\n }\r\n\r\n public vertexAttribDivisor(index: number, divisor: number): void {\r\n this._context.vertexAttribDivisor(index, divisor);\r\n }\r\n\r\n public drawArraysInst(type: GL.PrimitiveType, first: number, count: number, numInstances: number): void { this._context.drawArraysInstanced(type, first, count, numInstances); }\r\n\r\n public invalidateFrameBuffer(attachments: number[]): void {\r\n this._context.invalidateFramebuffer(this._context.FRAMEBUFFER, attachments);\r\n }\r\n}\r\n\r\n/** Id map holds key value pairs for both materials and textures, useful for caching such objects.\r\n * @internal\r\n */\r\nexport class IdMap implements WebGLDisposable {\r\n private readonly _iModel: IModelConnection;\r\n /** Mapping of materials by their key values. */\r\n public readonly materials = new Map<string, RenderMaterial>();\r\n /** Mapping of textures by their key values. */\r\n public readonly textures = new Map<string, RenderTexture>();\r\n /** Mapping of textures using gradient symbology. */\r\n public readonly gradients = new Dictionary<Gradient.Symb, RenderTexture>(Gradient.Symb.compareSymb);\r\n /** Pending promises to create a texture from an ImageSource. This prevents us from decoding the same ImageSource multiple times */\r\n public readonly texturesFromImageSources = new Map<string, Promise<RenderTexture | undefined>>();\r\n\r\n public constructor(iModel: IModelConnection) {\r\n this._iModel = iModel;\r\n }\r\n\r\n public get isDisposed(): boolean {\r\n return 0 === this.textures.size && 0 === this.gradients.size;\r\n }\r\n\r\n public dispose() {\r\n const textureArr = Array.from(this.textures.values());\r\n const gradientArr = this.gradients.extractArrays().values;\r\n\r\n for (const texture of textureArr)\r\n dispose(texture);\r\n\r\n for (const gradient of gradientArr)\r\n dispose(gradient);\r\n\r\n this.textures.clear();\r\n this.gradients.clear();\r\n this.materials.clear();\r\n }\r\n\r\n /** Add a material to this IdMap, given that it has a valid key. */\r\n public addMaterial(material: RenderMaterial) {\r\n if (material.key)\r\n this.materials.set(material.key, material);\r\n }\r\n\r\n /** Add a texture to this IdMap, given that it has a valid string key. If specified, it will instead use the key parameter, which could also be a gradient symb. */\r\n public addTexture(texture: RenderTexture, key?: TextureCacheKey) {\r\n assert(texture instanceof Texture);\r\n if (undefined !== key) {\r\n if (\"string\" === typeof key)\r\n this.textures.set(key, texture);\r\n else\r\n this.addGradient(key, texture);\r\n } else if (texture.key)\r\n this.textures.set(texture.key, texture);\r\n }\r\n\r\n /** Add a texture to this IdMap using gradient symbology. */\r\n public addGradient(gradientSymb: Gradient.Symb, texture: RenderTexture) {\r\n this.gradients.set(gradientSymb, texture);\r\n }\r\n\r\n /** Find a cached material using its key. If not found, returns undefined. */\r\n public findMaterial(key: string): RenderMaterial | undefined {\r\n return this.materials.get(key);\r\n }\r\n\r\n /** Find a cached gradient using the gradient symbology. If not found, returns undefined. */\r\n public findGradient(symb: Gradient.Symb): RenderTexture | undefined {\r\n return this.gradients.get(symb);\r\n }\r\n\r\n /** Find or create a new material given material parameters. This will cache the material if its key is valid. */\r\n public getMaterial(params: RenderMaterial.Params): RenderMaterial {\r\n if (!params.key || !Id64.isValidId64(params.key)) // Only cache persistent materials.\r\n return new Material(params);\r\n\r\n let material = this.materials.get(params.key);\r\n if (!material) {\r\n material = new Material(params);\r\n this.materials.set(params.key, material);\r\n }\r\n return material;\r\n }\r\n\r\n public findTexture(key?: string | Gradient.Symb): RenderTexture | undefined {\r\n if (undefined === key)\r\n return undefined;\r\n else if (typeof key === \"string\")\r\n return this.textures.get(key);\r\n else\r\n return this.findGradient(key);\r\n }\r\n\r\n // eslint-disable-next-line deprecation/deprecation\r\n public getTextureFromElement(key: Id64String, iModel: IModelConnection, params: RenderTexture.Params, format: ImageSourceFormat): RenderTexture | undefined {\r\n let tex = this.findTexture(params.key);\r\n if (tex)\r\n return tex;\r\n\r\n const handle = TextureHandle.createForElement(key, iModel, params.type, format);\r\n if (!handle)\r\n return undefined;\r\n\r\n tex = new Texture({ handle, type: params.type, ownership: { key, iModel } });\r\n this.addTexture(tex);\r\n return tex;\r\n }\r\n\r\n public async getTextureFromImageSource(args: CreateTextureFromSourceArgs, key: string): Promise<RenderTexture | undefined> {\r\n const texture = this.findTexture(key);\r\n if (texture)\r\n return texture;\r\n\r\n // Are we already in the process of decoding this image?\r\n let promise = this.texturesFromImageSources.get(key);\r\n if (promise)\r\n return promise;\r\n\r\n promise = this.createTextureFromImageSource(args, key);\r\n this.texturesFromImageSources.set(key, promise);\r\n return promise;\r\n }\r\n\r\n public async createTextureFromImageSource(args: CreateTextureFromSourceArgs, key: string): Promise<RenderTexture | undefined> {\r\n // JPEGs don't support transparency.\r\n const transparency = ImageSourceFormat.Jpeg === args.source.format ? TextureTransparency.Opaque : (args.transparency ?? TextureTransparency.Translucent);\r\n try {\r\n const image = await imageElementFromImageSource(args.source);\r\n if (!IModelApp.hasRenderSystem)\r\n return undefined;\r\n\r\n return IModelApp.renderSystem.createTexture({\r\n type: args.type,\r\n ownership: args.ownership,\r\n image: {\r\n source: image,\r\n transparency,\r\n },\r\n });\r\n } catch {\r\n return undefined;\r\n } finally {\r\n this.texturesFromImageSources.delete(key);\r\n }\r\n }\r\n\r\n // eslint-disable-next-line deprecation/deprecation\r\n public getTextureFromCubeImages(posX: HTMLImageElement, negX: HTMLImageElement, posY: HTMLImageElement, negY: HTMLImageElement, posZ: HTMLImageElement, negZ: HTMLImageElement, params: RenderTexture.Params): RenderTexture | undefined {\r\n let tex = this.findTexture(params.key);\r\n if (tex)\r\n return tex;\r\n\r\n const handle = TextureHandle.createForCubeImages(posX, negX, posY, negY, posZ, negZ);\r\n if (!handle)\r\n return undefined;\r\n\r\n const ownership = params.key ? { key: params.key, iModel: this._iModel } : (params.isOwned ? \"external\" : undefined);\r\n tex = new Texture({ handle, ownership, type: params.type });\r\n this.addTexture(tex);\r\n return tex;\r\n }\r\n\r\n public collectStatistics(stats: RenderMemory.Statistics): void {\r\n for (const texture of this.textures.values())\r\n if (texture instanceof Texture)\r\n stats.addTexture(texture.bytesUsed);\r\n\r\n for (const gradient of this.gradients)\r\n if (gradient instanceof Texture)\r\n stats.addTexture(gradient.bytesUsed);\r\n }\r\n}\r\n\r\nexport type TextureBinding = WebGLTexture | undefined;\r\n\r\nconst enum VertexAttribState {\r\n Disabled = 0,\r\n Enabled = 1 << 0,\r\n Instanced = 1 << 2,\r\n InstancedEnabled = Instanced | Enabled,\r\n}\r\n\r\ninterface TextureCacheInfo {\r\n idMap: IdMap;\r\n key: TextureCacheKey;\r\n}\r\n\r\n/** @internal */\r\nexport class System extends RenderSystem implements RenderSystemDebugControl, RenderMemory.Consumer, WebGLDisposable {\r\n public readonly canvas: HTMLCanvasElement;\r\n public readonly currentRenderState = new RenderState();\r\n public readonly context: WebGLContext;\r\n public readonly frameBufferStack = new FrameBufferStack(); // frame buffers are not owned by the system\r\n public readonly capabilities: Capabilities;\r\n public readonly resourceCache: Map<IModelConnection, IdMap>;\r\n public readonly glTimer: GLTimer;\r\n private readonly _extensions: WebGLExtensions;\r\n private readonly _textureBindings: TextureBinding[] = [];\r\n private _removeEventListener?: () => void;\r\n\r\n // NB: Increase the size of these arrays when the maximum number of attributes used by any one shader increases.\r\n private readonly _curVertexAttribStates: VertexAttribState[] = [\r\n VertexAttribState.Disabled, VertexAttribState.Disabled, VertexAttribState.Disabled, VertexAttribState.Disabled,\r\n VertexAttribState.Disabled, VertexAttribState.Disabled, VertexAttribState.Disabled, VertexAttribState.Disabled,\r\n VertexAttribState.Disabled, VertexAttribState.Disabled, VertexAttribState.Disabled, VertexAttribState.Disabled,\r\n ];\r\n private readonly _nextVertexAttribStates: VertexAttribState[] = [\r\n VertexAttribState.Disabled, VertexAttribState.Disabled, VertexAttribState.Disabled, VertexAttribState.Disabled,\r\n VertexAttribState.Disabled, VertexAttribState.Disabled, VertexAttribState.Disabled, VertexAttribState.Disabled,\r\n VertexAttribState.Disabled, VertexAttribState.Disabled, VertexAttribState.Disabled, VertexAttribState.Disabled,\r\n ];\r\n\r\n // The following are initialized immediately after the System is constructed.\r\n private _lineCodeTexture?: TextureHandle;\r\n private _noiseTexture?: TextureHandle;\r\n private _techniques?: Techniques;\r\n private _screenSpaceEffects?: ScreenSpaceEffects;\r\n public readonly debugShaderFiles: DebugShaderFile[] = [];\r\n\r\n public static get instance() { return IModelApp.renderSystem as System; }\r\n\r\n public get isValid(): boolean { return this.canvas !== undefined; }\r\n public get lineCodeTexture() { return this._lineCodeTexture; }\r\n public get noiseTexture() { return this._noiseTexture; }\r\n\r\n public get techniques() {\r\n assert(undefined !== this._techniques);\r\n return this._techniques;\r\n }\r\n\r\n public get screenSpaceEffects() {\r\n assert(undefined !== this._screenSpaceEffects);\r\n return this._screenSpaceEffects;\r\n }\r\n\r\n public override get maxTextureSize(): number { return this.capabilities.maxTextureSize; }\r\n public override get supportsInstancing(): boolean { return this.capabilities.supportsInstancing; }\r\n public override get supportsNonuniformScaledInstancing(): boolean { return this.capabilities.isWebGL2; }\r\n public get isWebGL2(): boolean { return this.capabilities.isWebGL2; }\r\n public override get isMobile(): boolean { return this.capabilities.isMobile; }\r\n\r\n public setDrawBuffers(attachments: GLenum[]): void { this._extensions.setDrawBuffers(attachments); }\r\n\r\n public doIdleWork(): boolean {\r\n return this.techniques.idleCompileNextShader();\r\n }\r\n\r\n /** Return a Promise which when resolved indicates that all pending external textures have finished loading from the backend. */\r\n public override async waitForAllExternalTextures(): Promise<void> {\r\n const extTexLoader = ExternalTextureLoader.instance;\r\n if (extTexLoader.numActiveRequests < 1 && extTexLoader.numPendingRequests < 1)\r\n return Promise.resolve();\r\n const promise = new Promise<void>((resolve: any) => {\r\n extTexLoader.onTexturesLoaded.addOnce(() => {\r\n resolve();\r\n });\r\n });\r\n return promise;\r\n }\r\n\r\n /** Attempt to create a WebGLRenderingContext, returning undefined if unsuccessful. */\r\n public static createContext(canvas: HTMLCanvasElement, useWebGL2: boolean, inputContextAttributes?: WebGLContextAttributes): WebGLContext | undefined {\r\n let contextAttributes: WebGLContextAttributes = { powerPreference: \"high-performance\" };\r\n if (undefined !== inputContextAttributes) {\r\n // NOTE: Order matters with spread operator - if caller wants to override powerPreference, he should be able to.\r\n contextAttributes = { ...contextAttributes, ...inputContextAttributes };\r\n }\r\n\r\n // If requested, first try obtaining a WebGL2 context.\r\n let context = null;\r\n if (useWebGL2)\r\n context = canvas.getContext(\"webgl2\", contextAttributes);\r\n\r\n // Fall back to WebGL1 if necessary.\r\n if (null === context)\r\n context = canvas.getContext(\"webgl\", contextAttributes);\r\n\r\n return context ?? undefined;\r\n }\r\n\r\n public static create(optionsIn?: RenderSystem.Options): System {\r\n const options: RenderSystem.Options = undefined !== optionsIn ? optionsIn : {};\r\n const canvas = document.createElement(\"canvas\");\r\n if (null === canvas)\r\n throw new IModelError(BentleyStatus.ERROR, \"Failed to obtain HTMLCanvasElement\");\r\n\r\n const useWebGL2 = (undefined === options.useWebGL2 ? true : options.useWebGL2);\r\n const context = this.createContext(canvas, useWebGL2, optionsIn?.contextAttributes);\r\n if (undefined === context) {\r\n throw new IModelError(BentleyStatus.ERROR, \"Failed to obtain WebGL context\");\r\n }\r\n\r\n const capabilities = Capabilities.create(context, options.disabledExtensions);\r\n if (undefined === capabilities)\r\n throw new IModelError(BentleyStatus.ERROR, \"Failed to initialize rendering capabilities\");\r\n\r\n // set actual gl state to match desired state defaults\r\n context.depthFunc(GL.DepthFunc.Default); // LessOrEqual\r\n\r\n if (!capabilities.supportsShadowMaps)\r\n options.displaySolarShadows = false;\r\n if (!capabilities.supportsFragDepth)\r\n options.logarithmicDepthBuffer = false;\r\n if (!capabilities.supportsTextureFilterAnisotropic) {\r\n options.filterMapTextures = false;\r\n options.filterMapDrapeTextures = false;\r\n }\r\n return new this(canvas, context, capabilities, options);\r\n }\r\n\r\n public get isDisposed(): boolean {\r\n return undefined === this._techniques\r\n && undefined === this._lineCodeTexture\r\n && undefined === this._noiseTexture\r\n && undefined === this._screenSpaceEffects;\r\n }\r\n\r\n // Note: FrameBuffers inside of the FrameBufferStack are not owned by the System, and are only used as a central storage device\r\n public dispose() {\r\n this._techniques = dispose(this._techniques);\r\n this._screenSpaceEffects = dispose(this._screenSpaceEffects);\r\n this._lineCodeTexture = dispose(this._lineCodeTexture);\r\n this._noiseTexture = dispose(this._noiseTexture);\r\n\r\n // We must attempt to dispose of each idmap in the resourceCache (if idmap is already disposed, has no effect)\r\n this.resourceCache.forEach((idMap: IdMap) => {\r\n dispose(idMap);\r\n });\r\n\r\n this.resourceCache.clear();\r\n if (undefined !== this._removeEventListener) {\r\n this._removeEventListener();\r\n this._removeEventListener = undefined;\r\n }\r\n }\r\n\r\n public override onInitialized(): void {\r\n this._techniques = Techniques.create(this.context);\r\n\r\n const noiseDim = 4;\r\n const noiseArr = new Uint8Array([152, 235, 94, 173, 219, 215, 115, 176, 73, 205, 43, 201, 10, 81, 205, 198]);\r\n this._noiseTexture = TextureHandle.createForData(noiseDim, noiseDim, noiseArr, false, GL.Texture.WrapMode.Repeat, GL.Texture.Format.Luminance);\r\n assert(undefined !== this._noiseTexture, \"System.noiseTexture not created.\");\r\n\r\n this._lineCodeTexture = TextureHandle.createForData(LineCode.size, LineCode.count, new Uint8Array(LineCode.lineCodeData), false, GL.Texture.WrapMode.Repeat, GL.Texture.Format.Luminance);\r\n assert(undefined !== this._lineCodeTexture, \"System.lineCodeTexture not created.\");\r\n\r\n this._screenSpaceEffects = new ScreenSpaceEffects();\r\n }\r\n\r\n public createTarget(canvas: HTMLCanvasElement): RenderTarget {\r\n return new OnScreenTarget(canvas);\r\n }\r\n\r\n public createOffscreenTarget(rect: ViewRect): RenderTarget {\r\n return new OffScreenTarget(rect);\r\n }\r\n\r\n public createGraphic(options: CustomGraphicBuilderOptions | ViewportGraphicBuilderOptions): GraphicBuilder {\r\n return new PrimitiveBuilder(this, options);\r\n }\r\n\r\n public override createPlanarGrid(frustum: Frustum, grid: PlanarGridProps): RenderGraphic | undefined {\r\n return PlanarGridGeometry.create(frustum, grid, this);\r\n }\r\n\r\n public override createRealityMeshFromTerrain(terrainMesh: TerrainMeshPrimitive, transform?: Transform): RealityMeshGeometry | undefined {\r\n return RealityMeshGeometry.createFromTerrainMesh(terrainMesh, transform);\r\n }\r\n\r\n public override createRealityMeshGraphic(terrainGeometry: RealityMeshGeometry, featureTable: PackedFeatureTable, tileId: string | undefined, baseColor: ColorDef | undefined, baseTransparent: boolean, textures?: TerrainTexture[]): RenderGraphic | undefined {\r\n return RealityMeshGeometry.createGraphic(this, terrainGeometry, featureTable, tileId, baseColor, baseTransparent, textures);\r\n }\r\n public override createRealityMesh(realityMesh: RealityMeshPrimitive): RenderGraphic | undefined {\r\n const geom = RealityMeshGeometry.createFromRealityMesh(realityMesh);\r\n return geom ? Primitive.create(geom) : undefined;\r\n }\r\n\r\n public override createMeshGeometry(params: MeshParams, viOrigin?: Point3d): MeshRenderGeometry | undefined {\r\n return MeshRenderGeometry.create(params, viOrigin);\r\n }\r\n\r\n public override createPolylineGeometry(params: PolylineParams, viOrigin?: Point3d): PolylineGeometry | undefined {\r\n return PolylineGeometry.create(params, viOrigin);\r\n }\r\n\r\n public override createPointStringGeometry(params: PointStringParams, viOrigin?: Point3d): PointStringGeometry | undefined {\r\n return PointStringGeometry.create(params, viOrigin);\r\n }\r\n\r\n public override createAreaPattern(params: PatternGraphicParams): PatternBuffers | undefined {\r\n return PatternBuffers.create(params);\r\n }\r\n\r\n public override createRenderGraphic(geometry: RenderGeometry, instances?: InstancedGraphicParams | RenderAreaPattern): RenderGraphic | undefined {\r\n if (!(geometry instanceof MeshRenderGeometry)) {\r\n if (geometry instanceof PolylineGeometry || geometry instanceof PointStringGeometry)\r\n return Primitive.create(geometry, instances);\r\n\r\n assert(false, \"Invalid RenderGeometry for System.createRenderGraphic\");\r\n return undefined;\r\n }\r\n\r\n assert(!instances || instances instanceof PatternBuffers || isInstancedGraphicParams(instances));\r\n return MeshGraphic.create(geometry, instances);\r\n }\r\n\r\n public override createPointCloud(args: PointCloudArgs): RenderGraphic | undefined {\r\n return Primitive.create(new PointCloudGeometry(args));\r\n }\r\n\r\n public createGraphicList(primitives: RenderGraphic[]): RenderGraphic {\r\n return new GraphicsArray(primitives);\r\n }\r\n\r\n public createGraphicBranch(branch: GraphicBranch, transform: Transform, options?: GraphicBranchOptions): RenderGraphic {\r\n return new Branch(branch, transform, undefined, options);\r\n }\r\n\r\n public override createAnimationTransformNode(graphic: RenderGraphic, nodeId: number): RenderGraphic {\r\n return new AnimationTransformBranch(graphic, nodeId);\r\n }\r\n\r\n public createBatch(graphic: RenderGraphic, features: PackedFeatureTable, range: ElementAlignedBox3d, options?: BatchOptions): RenderGraphic {\r\n return new Batch(graphic, features, range, options);\r\n }\r\n\r\n public override createGraphicOwner(owned: RenderGraphic): RenderGraphicOwner {\r\n return new GraphicOwner(owned as Graphic);\r\n }\r\n\r\n public override createGraphicLayer(graphic: RenderGraphic, layerId: string) {\r\n return new Layer(graphic as Graphic, layerId);\r\n }\r\n\r\n public override createGraphicLayerContainer(graphic: RenderGraphic, drawAsOverlay: boolean, transparency: number, elevation: number) {\r\n return new LayerContainer(graphic as Graphic, drawAsOverlay, transparency, elevation);\r\n }\r\n\r\n public override createSkyBox(params: RenderSkyBoxParams): RenderGraphic | undefined {\r\n if (\"cube\" === params.type)\r\n return SkyCubePrimitive.create(SkyBoxQuadsGeometry.create(params.texture));\r\n\r\n return SkySpherePrimitive.create(SkySphereViewportQuadGeometry.createGeometry(params));\r\n }\r\n\r\n public override createScreenSpaceEffectBuilder(params: ScreenSpaceEffectBuilderParams): ScreenSpaceEffectBuilder {\r\n return createScreenSpaceEffectBuilder(params);\r\n }\r\n\r\n public applyRenderState(newState: RenderState) {\r\n newState.apply(this.currentRenderState);\r\n this.currentRenderState.copyFrom(newState);\r\n }\r\n\r\n public createDepthBuffer(width: number, height: number, numSamples: number = 1): DepthBuffer | undefined {\r\n // Note: The buffer/texture created here have ownership passed to the caller (system will not dispose of these)\r\n switch (this.capabilities.maxDepthType) {\r\n case DepthType.RenderBufferUnsignedShort16: {\r\n return RenderBuffer.create(width, height);\r\n }\r\n case DepthType.TextureUnsignedInt32: {\r\n return TextureHandle.createForAttachment(width, height, GL.Texture.Format.DepthComponent, GL.Texture.DataType.UnsignedInt);\r\n }\r\n case DepthType.TextureUnsignedInt24Stencil8: {\r\n if (this.capabilities.isWebGL2) {\r\n if (numSamples > 1) {\r\n return RenderBufferMultiSample.create(width, height, WebGL2RenderingContext.DEPTH24_STENCIL8, numSamples);\r\n } else {\r\n const context2 = this.context as WebGL2RenderingContext;\r\n return TextureHandle.createForAttachment(width, height, GL.Texture.Format.DepthStencil, context2.UNSIGNED_INT_24_8);\r\n }\r\n } else {\r\n const dtExt: WEBGL_depth_texture | undefined = this.capabilities.queryExtensionObject<WEBGL_depth_texture>(\"WEBGL_depth_texture\");\r\n return TextureHandle.createForAttachment(width, height, GL.Texture.Format.DepthStencil, dtExt!.UNSIGNED_INT_24_8_WEBGL);\r\n }\r\n }\r\n default: {\r\n assert(false);\r\n return undefined;\r\n }\r\n }\r\n }\r\n\r\n /** Returns the corresponding IdMap for an IModelConnection. Creates a new one if it doesn't exist. */\r\n public createIModelMap(imodel: IModelConnection): IdMap {\r\n let idMap = this.resourceCache.get(imodel);\r\n if (!idMap) {\r\n idMap = new IdMap(imodel);\r\n this.resourceCache.set(imodel, idMap);\r\n }\r\n return idMap;\r\n }\r\n\r\n /** Removes an IModelConnection-IdMap pairing from the system's resource cache. */\r\n private removeIModelMap(imodel: IModelConnection) {\r\n const idMap = this.resourceCache.get(imodel);\r\n if (idMap === undefined)\r\n return;\r\n dispose(idMap);\r\n this.resourceCache.delete(imodel);\r\n }\r\n\r\n /** Attempt to create a material for the given iModel using a set of material parameters. */\r\n public override createMaterial(params: RenderMaterial.Params, imodel: IModelConnection): RenderMaterial | undefined {\r\n const idMap = this.getIdMap(imodel);\r\n const material = idMap.getMaterial(params);\r\n return material;\r\n }\r\n\r\n /** Using its key, search for an existing material of an open iModel. */\r\n public override findMaterial(key: string, imodel: IModelConnection): RenderMaterial | undefined {\r\n const idMap = this.resourceCache.get(imodel);\r\n if (!idMap)\r\n return undefined;\r\n return idMap.findMaterial(key);\r\n }\r\n\r\n private getTextureCacheInfo(args: CreateTextureArgs): TextureCacheInfo | undefined {\r\n const owner = undefined !== args.ownership && args.ownership !== \"external\" ? args.ownership : undefined;\r\n return owner ? { idMap: this.getIdMap(owner.iModel), key: owner.key } : undefined;\r\n }\r\n\r\n public override createTexture(args: CreateTextureArgs): RenderTexture | undefined {\r\n const info = this.getTextureCacheInfo(args);\r\n const existing = info?.idMap.findTexture(info?.key);\r\n if (existing)\r\n return existing;\r\n\r\n const type = args.type ?? RenderTexture.Type.Normal;\r\n const source = args.image.source;\r\n\r\n // ###TODO createForImageBuffer should take args.transparency.\r\n let handle;\r\n if (source instanceof ImageBuffer)\r\n handle = TextureHandle.createForImageBuffer(source, type); // ###TODO use transparency from args\r\n else\r\n handle = TextureHandle.createForImage(source, TextureTransparency.Opaque !== args.image.transparency, type);\r\n\r\n if (!handle)\r\n return undefined;\r\n\r\n const texture = new Texture({ handle, type, ownership: args.ownership });\r\n if (texture && info)\r\n info.idMap.addTexture(texture, info.key);\r\n\r\n return texture;\r\n }\r\n\r\n public override async createTextureFromSource(args: CreateTextureFromSourceArgs): Promise<RenderTexture | undefined> {\r\n if (typeof args.ownership !== \"object\")\r\n return super.createTextureFromSource(args);\r\n\r\n return this.getIdMap(args.ownership.iModel).getTextureFromImageSource(args, args.ownership.key);\r\n }\r\n\r\n // eslint-disable-next-line deprecation/deprecation\r\n public override createTextureFromElement(id: Id64String, imodel: IModelConnection, params: RenderTexture.Params, format: ImageSourceFormat): RenderTexture | undefined {\r\n return this.getIdMap(imodel).getTextureFromElement(id, imodel, params, format);\r\n }\r\n\r\n // eslint-disable-next-line deprecation/deprecation\r\n public override createTextureFromCubeImages(posX: HTMLImageElement, negX: HTMLImageElement, posY: HTMLImageElement, negY: HTMLImageElement, posZ: HTMLImageElement, negZ: HTMLImageElement, imodel: IModelConnection, params: RenderTexture.Params): RenderTexture | undefined {\r\n return this.getIdMap(imodel).getTextureFromCubeImages(posX, negX, posY, negY, posZ, negZ, params);\r\n }\r\n\r\n /** Attempt to create a texture using gradient symbology. */\r\n public override getGradientTexture(symb: Gradient.Symb, iModel?: IModelConnection): RenderTexture | undefined {\r\n const source = symb.getImage(0x100, 0x100);\r\n return this.createTexture({\r\n image: {\r\n source,\r\n transparency: ImageBufferFormat.Rgba === source.format ? TextureTransparency.Translucent : TextureTransparency.Opaque,\r\n },\r\n ownership: iModel ? { iModel, key: symb } : undefined,\r\n type: RenderTexture.Type.Normal,\r\n });\r\n }\r\n\r\n /** Using its key, search for an existing texture of an open iModel. */\r\n public override findTexture(key: TextureCacheKey, imodel: IModelConnection): RenderTexture | undefined {\r\n const idMap = this.resourceCache.get(imodel);\r\n if (!idMap)\r\n return undefined;\r\n\r\n return idMap.findTexture(key);\r\n }\r\n\r\n public override createClipVolume(clipVector: ClipVector): RenderClipVolume | undefined {\r\n return ClipVolume.create(clipVector);\r\n }\r\n public override createBackgroundMapDrape(drapedTree: TileTreeReference, mapTree: MapTileTreeReference) {\r\n return BackgroundMapDrape.create(drapedTree, mapTree);\r\n }\r\n\r\n protected constructor(canvas: HTMLCanvasElement, context: WebGLContext, capabilities: Capabilities, options: RenderSystem.Options) {\r\n super(options);\r\n this.canvas = canvas;\r\n this.context = context;\r\n this.capabilities = capabilities;\r\n this.resourceCache = new Map<IModelConnection, IdMap>();\r\n this.glTimer = GLTimer.create(this);\r\n if (capabilities.isWebGL2)\r\n this._extensions = new WebGL2Extensions(this);\r\n else {\r\n const drawBuffersExtension = capabilities.queryExtensionObject<WEBGL_draw_buffers>(\"WEBGL_draw_buffers\");\r\n const instancingExtension = capabilities.queryExtensionObject<ANGLE_instanced_arrays>(\"ANGLE_instanced_arrays\");\r\n this._extensions = new WebGL1Extensions(this, drawBuffersExtension, instancingExtension);\r\n }\r\n\r\n // Make this System a subscriber to the the IModelConnection onClose event\r\n this._removeEventListener = IModelConnection.onClose.addListener((imodel) => this.removeIModelMap(imodel));\r\n\r\n canvas.addEventListener(\"webglcontextlost\", async () => RenderSystem.contextLossHandler(), false);\r\n }\r\n\r\n /** Exposed strictly for tests. */\r\n public getIdMap(imodel: IModelConnection): IdMap {\r\n const map = this.resourceCache.get(imodel);\r\n return undefined !== map ? map : this.createIModelMap(imodel);\r\n }\r\n\r\n private bindTexture(unit: TextureUnit, target: GL.Texture.Target, texture: TextureBinding, makeActive: boolean): void {\r\n const index = unit - TextureUnit.Zero;\r\n if (this._textureBindings[index] === texture) {\r\n if (makeActive)\r\n this.context.activeTexture(unit);\r\n\r\n return;\r\n }\r\n\r\n this._textureBindings[index] = texture;\r\n this.context.activeTexture(unit);\r\n this.context.bindTexture(target, undefined !== texture ? texture : null);\r\n }\r\n\r\n /** Bind the specified texture to the specified unit. This may *or may not* make the texture *active* */\r\n public bindTexture2d(unit: TextureUnit, texture: TextureBinding) { this.bindTexture(unit, GL.Texture.Target.TwoDee, texture, false); }\r\n /** Bind the specified texture to the specified unit. This may *or may not* make the texture *active* */\r\n public bindTextureCubeMap(unit: TextureUnit, texture: TextureBinding) { this.bindTexture(unit, GL.Texture.Target.CubeMap, texture, false); }\r\n /** Bind the specified texture to the specified unit. This *always* makes the texture *active* */\r\n public activateTexture2d(unit: TextureUnit, texture: TextureBinding) { this.bindTexture(unit, GL.Texture.Target.TwoDee, texture, true); }\r\n /** Bind the specified texture to the specified unit. This *always* makes the texture *active* */\r\n public activateTextureCubeMap(unit: TextureUnit, texture: TextureBinding) { this.bindTexture(unit, GL.Texture.Target.CubeMap, texture, true); }\r\n\r\n // Ensure *something* is bound to suppress 'no texture assigned to unit x' warnings.\r\n public ensureSamplerBound(uniform: UniformHandle, unit: TextureUnit): void {\r\n this.lineCodeTexture!.bindSampler(uniform, unit);\r\n }\r\n public override get maxRealityImageryLayers() { return Math.min(this.capabilities.maxFragTextureUnits, this.capabilities.maxVertTextureUnits) < 16 ? 3 : 6; }\r\n\r\n public disposeTexture(texture: WebGLTexture) {\r\n System.instance.context.deleteTexture(texture);\r\n for (let i = 0; i < this._textureBindings.length; i++) {\r\n if (this._textureBindings[i] === texture) {\r\n this._textureBindings[i] = undefined;\r\n break;\r\n }\r\n }\r\n }\r\n\r\n // System keeps track of current enabled state of vertex attribute arrays.\r\n // This prevents errors caused by leaving a vertex attrib array enabled after disposing of the buffer bound to it;\r\n // also prevents unnecessarily 'updating' the enabled state of a vertex attrib array when it hasn't actually changed.\r\n public enableVertexAttribArray(id: number, instanced: boolean): void {\r\n assert(id < this._nextVertexAttribStates.length, \"if you add new vertex attributes you must update array length\");\r\n assert(id < this._curVertexAttribStates.length, \"if you add new vertex attributes you must update array length\");\r\n\r\n this._nextVertexAttribStates[id] = instanced ? VertexAttribState.InstancedEnabled : VertexAttribState.Enabled;\r\n }\r\n\r\n public updateVertexAttribArrays(): void {\r\n const cur = this._curVertexAttribStates;\r\n const next = this._nextVertexAttribStates;\r\n const context = this.context;\r\n\r\n for (let i = 0; i < next.length; i++) {\r\n const oldState = cur[i];\r\n const newState = next[i];\r\n if (oldState !== newState) {\r\n // Update the enabled state if it changed.\r\n const wasEnabled = 0 !== (VertexAttribState.Enabled & oldState);\r\n const nowEnabled = 0 !== (VertexAttribState.Enabled & newState);\r\n if (wasEnabled !== nowEnabled) {\r\n if (nowEnabled) {\r\n context.enableVertexAttribArray(i);\r\n } else {\r\n context.disableVertexAttribArray(i);\r\n }\r\n }\r\n\r\n // Only update the divisor if the attribute is enabled.\r\n if (nowEnabled) {\r\n const wasInstanced = 0 !== (VertexAttribState.Instanced & oldState);\r\n const nowInstanced = 0 !== (VertexAttribState.Instanced & newState);\r\n if (wasInstanced !== nowInstanced) {\r\n this.vertexAttribDivisor(i, nowInstanced ? 1 : 0);\r\n }\r\n }\r\n\r\n cur[i] = newState;\r\n }\r\n\r\n // Set the attribute back to disabled, but preserve the divisor.\r\n next[i] &= ~VertexAttribState.Enabled;\r\n }\r\n }\r\n\r\n public vertexAttribDivisor(index: number, divisor: number) { this._extensions.vertexAttribDivisor(index, divisor); }\r\n\r\n public drawArrays(type: GL.PrimitiveType, first: number, count: number, numInstances: number): void {\r\n if (0 !== numInstances) {\r\n this._extensions.drawArraysInst(type, first, count, numInstances);\r\n } else {\r\n this.context.drawArrays(type, first, count);\r\n }\r\n }\r\n\r\n public invalidateFrameBuffer(attachments: number[]): void { this._extensions.invalidateFrameBuffer(attachments); }\r\n\r\n public override enableDiagnostics(enable: RenderDiagnostics): void {\r\n Debug.printEnabled = RenderDiagnostics.None !== (enable & RenderDiagnostics.DebugOutput);\r\n Debug.evaluateEnabled = RenderDiagnostics.None !== (enable & RenderDiagnostics.WebGL);\r\n }\r\n\r\n // RenderSystemDebugControl\r\n public override get debugControl(): RenderSystemDebugControl { return this; }\r\n\r\n private _dpiAwareLOD?: boolean;\r\n public override get dpiAwareLOD(): boolean { return this._dpiAwareLOD ?? super.dpiAwareLOD; }\r\n public override set dpiAwareLOD(dpiAware: boolean) { this._dpiAwareLOD = dpiAware; }\r\n\r\n public loseContext(): boolean {\r\n const ext = this.capabilities.queryExtensionObject<WEBGL_lose_context>(\"WEBGL_lose_context\");\r\n if (undefined === ext)\r\n return false;\r\n\r\n ext.loseContext();\r\n return true;\r\n }\r\n\r\n public compileAllShaders(): boolean {\r\n return this.techniques.compileShaders();\r\n }\r\n\r\n public get isGLTimerSupported(): boolean { return this.glTimer.isSupported; }\r\n public set resultsCallback(callback: GLTimerResultCallback | undefined) {\r\n this.glTimer.resultsCallback = callback;\r\n }\r\n\r\n public override collectStatistics(stats: RenderMemory.Statistics): void {\r\n if (undefined !== this._lineCodeTexture)\r\n stats.addTexture(this._lineCodeTexture.bytesUsed);\r\n\r\n if (undefined !== this._noiseTexture)\r\n stats.addTexture(this._noiseTexture.bytesUsed);\r\n\r\n for (const idMap of this.resourceCache.values())\r\n idMap.collectStatistics(stats);\r\n }\r\n\r\n public setMaxAnisotropy(max: number | undefined): void {\r\n this.capabilities.setMaxAnisotropy(max, this.context);\r\n }\r\n}\r\n"]}
|
|
@@ -26,7 +26,7 @@ import { addSolarShadowMap } from "./SolarShadowMapping";
|
|
|
26
26
|
import { addThematicDisplay, getComputeThematicIndex } from "./Thematic";
|
|
27
27
|
import { addTranslucency } from "./Translucency";
|
|
28
28
|
import { addFeatureAndMaterialLookup, addModelViewMatrix, addNormalMatrix, addProjectionMatrix } from "./Vertex";
|
|
29
|
-
import { wantMaterials } from "../
|
|
29
|
+
import { wantMaterials } from "../SurfaceGeometry";
|
|
30
30
|
import { addWiremesh } from "./Wiremesh";
|
|
31
31
|
// NB: Textures do not contain pre-multiplied alpha.
|
|
32
32
|
const sampleSurfaceTexture = `
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Surface.js","sourceRoot":"","sources":["../../../../../src/render/webgl/glsl/Surface.ts"],"names":[],"mappings":"AAAA;;;+FAG+F;AAC/F;;GAEG;AAEH,OAAO,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AAC7C,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AACvC,OAAO,EAAiC,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC5E,OAAO,EAA2B,cAAc,EAA0E,MAAM,kBAAkB,CAAC;AACnJ,OAAO,EAAE,MAAM,EAAE,MAAM,WAAW,CAAC;AAInC,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAC3C,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AACzC,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AACnC,OAAO,EAAE,6BAA6B,EAAE,gBAAgB,EAAE,UAAU,EAAE,cAAc,EAAE,MAAM,UAAU,CAAC;AACvG,OAAO,EAAE,2BAA2B,EAAE,cAAc,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AACrF,OAAO,EACL,mBAAmB,EAAE,WAAW,EAAE,cAAc,EAAE,uBAAuB,EAAE,iBAAiB,EAAE,iBAAiB,GAChH,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EACL,uBAAuB,EAAE,kCAAkC,EAAE,oBAAoB,EAAE,uBAAuB,EAAE,eAAe,GAC5H,MAAM,YAAY,CAAC;AACpB,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AACzC,OAAO,EAAE,oBAAoB,EAAE,MAAM,cAAc,CAAC;AACpD,OAAO,EAAE,wBAAwB,EAAE,0BAA0B,EAAE,yBAAyB,EAAE,0BAA0B,EAAE,MAAM,wBAAwB,CAAC;AACrJ,OAAO,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAC7C,OAAO,EAAE,iBAAiB,EAAE,MAAM,sBAAsB,CAAC;AACzD,OAAO,EAAE,kBAAkB,EAAE,uBAAuB,EAAE,MAAM,YAAY,CAAC;AACzE,OAAO,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC;AACjD,OAAO,EAAE,2BAA2B,EAAE,kBAAkB,EAAE,eAAe,EAAE,mBAAmB,EAAE,MAAM,UAAU,CAAC;AACjH,OAAO,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;AACxC,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAEzC,oDAAoD;AACpD,MAAM,oBAAoB,GAAG;;;;CAI5B,CAAC;AAEF,MAAM,kBAAkB,GAAG;;;;;CAK1B,CAAC;AAEF,kGAAkG;AAClG,wDAAwD;AACxD,8CAA8C;AAC9C,kDAAkD;AAClD,wDAAwD;AACxD,MAAM,kBAAkB,GAAG;;;;;;;;;CAS1B,CAAC;AAEF,MAAM,wBAAwB,GAAG;;;;;;;;;;CAUhC,CAAC;AAEF,MAAM,mBAAmB,GAAG;;;;;CAK3B,CAAC;AAEF,2CAA2C;AAC3C,MAAM,qBAAqB,GAAG;;;CAG7B,CAAC;AAEF,sFAAsF;AACtF,MAAM,iBAAiB,GAAG;;;;;;;;;;;;;;;;;;;;;;;;;;;CA2BzB,CAAC;AAEF,MAAM,eAAe,GAAG;;;;;;;CAOvB,CAAC;AAEF,SAAS,WAAW,CAAC,OAAuB;IAC1C,MAAM,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;IAC1B,MAAM,CAAC,SAAS,KAAK,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC;IAElD,IAAI,CAAC,SAAS,CAAC,oBAAoB,gBAAqB,CAAC;IACzD,IAAI,CAAC,SAAS,CAAC,aAAa,eAAoB,CAAC,CAAC,oBAAoB;IACtE,IAAI,CAAC,SAAS,CAAC,cAAc,eAAoB,CAAC,CAAC,gBAAgB;IAEnE,2BAA2B,CAAC,IAAI,CAAC,CAAC;IAClC,IAAI,CAAC,WAAW,CAAC,wBAAwB,CAAC,CAAC;IAC3C,IAAI,CAAC,cAAc,CAAC,yCAAyC,CAAC,CAAC;IAE/D,6BAA6B,CAAC,IAAI,CAAC,CAAC;IACpC,IAAI,CAAC,GAAG,iCAAiD,kBAAkB,CAAC,CAAC;IAE7E,MAAM,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;IAC1B,IAAI,CAAC,SAAS,CAAC,SAAS,eAAoB,CAAC,CAAC,kCAAkC;IAChF,IAAI,CAAC,SAAS,CAAC,WAAW,eAAoB,CAAC,CAAC,kCAAkC;IAClF,IAAI,CAAC,SAAS,CAAC,cAAc,kBAAuB,CAAC;IACrD,IAAI,MAAM,CAAC,QAAQ,CAAC,YAAY,CAAC,QAAQ;QACvC,IAAI,CAAC,cAAc,CAAC,qEAAqE,CAAC,CAAC;;QAE3F,IAAI,CAAC,cAAc,CAAC,sEAAsE,CAAC,CAAC;IAE9F,mBAAmB;IACnB,IAAI,CAAC,WAAW,CAAC,mBAAmB,CAAC,CAAC;IACtC,IAAI,CAAC,UAAU,CAAC,iBAAiB,gBAAqB,CAAC,IAAI,EAAE,EAAE;QAC7D,IAAI,CAAC,iBAAiB,CAAC,iBAAiB,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YAC5D,MAAM,IAAI,GAAG,aAAa,CAAC,MAAM,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,CAAC,SAAS,CAAC;YACtG,MAAM,GAAG,GAAG,SAAS,KAAK,IAAI,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC;YAC1E,OAAO,CAAC,aAAa,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QAClC,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,UAAU,CAAC,kBAAkB,gBAAqB,CAAC,IAAI,EAAE,EAAE;QAC9D,IAAI,CAAC,iBAAiB,CAAC,kBAAkB,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YAC7D,MAAM,IAAI,GAAG,aAAa,CAAC,MAAM,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,CAAC,SAAS,CAAC;YACtG,MAAM,GAAG,GAAG,SAAS,KAAK,IAAI,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC;YAC1E,OAAO,CAAC,aAAa,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;QAC1C,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,iBAAiB;IACjB,2BAA2B,CAAC,IAAI,CAAC,CAAC;IAClC,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC;IAC9B,IAAI,CAAC,WAAW,CAAC,iBAAiB,CAAC,CAAC;IACpC,IAAI,CAAC,UAAU,CAAC,aAAa,iBAAsB,CAAC,IAAI,EAAE,EAAE;QAC1D,IAAI,CAAC,iBAAiB,CAAC,aAAa,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YACxD,MAAM,IAAI,GAAG,MAAM,CAAC,QAAQ,CAAC,YAAY,CAAC;YAC1C,MAAM,SAAS,GAAG,SAAS,KAAK,IAAI,IAAI,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,CAAC,CAAC;YAClF,OAAO,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC;QAClC,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,SAAS,CAAC,kBAAkB,eAAoB,CAAC;IACtD,IAAI,CAAC,GAAG,0BAAwC,eAAe,CAAC,CAAC;IACjE,IAAI,CAAC,GAAG,6BAA2C,kBAAkB,CAAC,CAAC;IACvE,OAAO,CAAC,0BAA0B,CAAC,kBAAkB,gBAAqB,uBAAuB,EAAE,qBAAqB,CAAC,CAAC;AAC5H,CAAC;AAED,MAAM,sBAAsB,GAAG;;CAE9B,CAAC;AAEF,mIAAmI;AACnI,uHAAuH;AACvH,mIAAmI;AACnI,kJAAkJ;AAClJ,4FAA4F;AAC5F,MAAM,cAAc,GAAG;;;;;CAKtB,CAAC;AAEF,MAAM,uBAAuB,GAAG;;CAE/B,CAAC;AAEF,SAAS,YAAY,CAAC,SAAsB,EAAE,QAAoB,EAAE,UAAwB,EAAE,UAAsB,EAAE,SAAkB;IACtI,MAAM,OAAO,GAAG,YAAY,CAAC,gBAAgB,kBAAsB,gBAAoB,SAAS,CAAC,CAAC;IAClG,MAAM,OAAO,GAAG,IAAI,cAAc,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC,8BAAyC,CAAC,oBAA+B,CAAC,CAAC;IAClI,MAAM,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;IAE1B,IAAI,QAAQ;QACV,YAAY,CAAC,IAAI,EAAE,IAAI,EAAE,UAAU,CAAC,CAAC;IAEvC,IAAI,UAAU;QACZ,iBAAiB,CAAC,OAAO,CAAC,CAAC;IAE7B,mBAAmB,CAAC,IAAI,CAAC,CAAC;IAC1B,kBAAkB,CAAC,IAAI,CAAC,CAAC;IAEzB,IAAI,eAAe,CAAC;IACpB,IAAI,SAAS,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,kBAAkB,EAAE;QACpD,eAAe,GAAG,sBAAsB,GAAG,uBAAuB,CAAC;KACpE;SAAM;QACL,UAAU,CAAC,OAAO,CAAC,CAAC;QACpB,cAAc,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAC7B,uBAAuB,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QACtC,OAAO,CAAC,UAAU,CAAC,YAAY,eAAoB,CAAC;QACpD,eAAe,GAAG,sBAAsB,GAAG,cAAc,GAAG,uBAAuB,CAAC;KACrF;IAED,IAAI,CAAC,GAAG,0BAAwC,eAAe,CAAC,CAAC;IAEjE,OAAO,OAAO,CAAC;AACjB,CAAC;AAED,gBAAgB;AAChB,MAAM,UAAU,oBAAoB,CAAC,SAAsB,EAAE,UAAwB;IACnF,MAAM,OAAO,GAAG,YAAY,CAAC,SAAS,sCAAiD,IAAI,CAAC,CAAC;IAE7F,eAAe,CAAC,OAAO,EAAE,IAAI,EAAE,KAAK,CAAC,CAAC;IACtC,UAAU,CAAC,OAAO,yBAA+B,CAAC;IAClD,IAAI,UAAU,EAAE;QACd,yBAAyB,CAAC,OAAO,CAAC,CAAC;QACnC,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,yBAAyB,mBAAwB,OAAO,CAAC,CAAC;QACjF,OAAO,CAAC,IAAI,CAAC,GAAG,0BAAyC,eAAe,CAAC,CAAC;KAC3E;SAAM;QACL,iBAAiB,CAAC,OAAO,CAAC,CAAC;KAC5B;IAED,OAAO,OAAO,CAAC;AACjB,CAAC;AAED,MAAM,eAAe,GAAG;;CAEvB,CAAC;AACF,MAAM,gBAAgB,GAAG;;CAExB,CAAC;AAEF,gBAAgB;AAChB,SAAS,qBAAqB,CAAC,OAAsB;IACnD,OAAO,CAAC,WAAW,CAAC,6BAA6B,eAAoB,mBAA2B,QAAQ,EAAE,CAAC,CAAC;IAC5G,OAAO,CAAC,WAAW,CAAC,gCAAgC,eAAoB,sBAA8B,QAAQ,EAAE,CAAC,CAAC;IAClH,OAAO,CAAC,WAAW,CAAC,6BAA6B,eAAoB,mBAA2B,QAAQ,EAAE,CAAC,CAAC;IAC5G,OAAO,CAAC,WAAW,CAAC,iCAAiC,eAAoB,uBAA+B,QAAQ,EAAE,CAAC,CAAC;IACpH,OAAO,CAAC,WAAW,CAAC,wCAAwC,eAAoB,8BAAsC,QAAQ,EAAE,CAAC,CAAC;IAClI,OAAO,CAAC,WAAW,CAAC,iCAAiC,eAAoB,uBAA+B,QAAQ,EAAE,CAAC,CAAC;IACpH,OAAO,CAAC,WAAW,CAAC,oCAAoC,eAAoB,0BAAkC,QAAQ,EAAE,CAAC,CAAC;IAC1H,OAAO,CAAC,WAAW,CAAC,8BAA8B,eAAoB,oBAA4B,QAAQ,EAAE,CAAC,CAAC;IAC9G,OAAO,CAAC,WAAW,CAAC,8BAA8B,eAAoB,oBAA4B,QAAQ,EAAE,CAAC,CAAC;IAC9G,OAAO,CAAC,WAAW,CAAC,mCAAmC,eAAoB,yBAAiC,QAAQ,EAAE,CAAC,CAAC;IAExH,qHAAqH;IACrH,gGAAgG;IAChG,OAAO,CAAC,kBAAkB,CAAC,wBAAwB,qBAA6B,CAAC;IACjF,OAAO,CAAC,kBAAkB,CAAC,4BAA4B,yBAAiC,CAAC;IACzF,OAAO,CAAC,kBAAkB,CAAC,yBAAyB,sBAA8B,CAAC;IAEnF,sDAAsD;IACtD,MAAM,MAAM,GAAG,MAAM,CAAC,QAAQ,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC;IAClE,MAAM,IAAI,GAAG,MAAM,CAAC,QAAQ,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC,eAAmB,CAAC,cAAmB,CAAC;IAC5F,OAAO,CAAC,WAAW,CAAC,yBAAyB,EAAE,IAAI,EAAE,mBAAwB,QAAQ,EAAE,GAAG,MAAM,CAAC,CAAC;IAClG,OAAO,CAAC,WAAW,CAAC,6BAA6B,EAAE,IAAI,EAAE,uBAA4B,QAAQ,EAAE,GAAG,MAAM,CAAC,CAAC;IAC1G,OAAO,CAAC,WAAW,CAAC,0BAA0B,EAAE,IAAI,EAAE,sBAAyB,QAAQ,EAAE,GAAG,MAAM,CAAC,CAAC;IAEpG,gBAAgB,CAAC,OAAO,CAAC,CAAC;IAC1B,IAAI,MAAM,CAAC,QAAQ,CAAC,YAAY,CAAC,QAAQ,EAAE;QACzC,OAAO,CAAC,WAAW,CAAC,gBAAgB,CAAC,CAAC;QACtC,OAAO,CAAC,SAAS,CAAC,cAAc,gBAAoB,CAAC;KACtD;SAAM;QACL,OAAO,CAAC,WAAW,CAAC,eAAe,CAAC,CAAC;QACrC,OAAO,CAAC,SAAS,CAAC,cAAc,gBAAqB,CAAC;KACvD;AACH,CAAC;AAED,MAAM,gBAAgB,GAAG;;;;CAIxB,CAAC;AACF,MAAM,iBAAiB,GAAG;;;;CAIzB,CAAC;AAEF,MAAM,uBAAuB,GAAG;;;;;;;;;;CAU/B,CAAC;AAEF,yGAAyG;AACzG,MAAM,wBAAwB,GAAG;;;CAGhC,CAAC;AAEF,MAAM,kBAAkB,GAAG,0BAA0B,CAAC;AACtD,MAAM,mBAAmB,GAAG,iCAAiC,CAAC;AAE9D,MAAM,mBAAmB,GAAG,uBAAuB,CAAC;AACpD,MAAM,4BAA4B,GAAG,uBAAuB,GAAG,wBAAwB,CAAC;AAExF,gBAAgB;AAChB,MAAM,CAAC,MAAM,eAAe,GAAG;;;;;;;;;;;CAW9B,CAAC;AAEF,MAAM,aAAa,GAAG;;;;;;CAMrB,CAAC;AAEF,MAAM,qBAAqB,GAAG;;;EAG5B,aAAa,EAAE,CAAC;AAElB,MAAM,oBAAoB,GAAG;;CAE5B,CAAC;AAEF,MAAM,eAAe,GAAG;;;;;;CAMvB,CAAC;AACF,MAAM,uBAAuB,GAAG;;;EAG9B,eAAe,EAAE,CAAC;AACpB,MAAM,eAAe,GAAG;;CAEvB,CAAC;AAEF,+GAA+G;AAC/G,gHAAgH;AAChH,+GAA+G;AAC/G,mHAAmH;AACnH,MAAM,gBAAgB,GAAG;;;;;;;;;;;;;;;;CAgBxB,CAAC;AAEF,MAAM,gBAAgB,GAAG,IAAI,UAAU,gBAAuB,CAAC;AAE/D,gBAAgB;AAChB,MAAM,UAAU,eAAe,CAAC,OAAuB,EAAE,oBAA6B,EAAE,gBAAyB;IAC/G,qBAAqB,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IACpC,qBAAqB,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IAEpC,IAAI,OAAO,GAAG,CAAC,MAAM,CAAC,QAAQ,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC,CAAC,gBAAgB,CAAC,CAAC;IAC7F,IAAI,oBAAoB;QACtB,OAAO,IAAI,GAAG,gBAAgB,CAAC,CAAC,CAAC,4BAA4B,CAAC,CAAC,CAAC,mBAAmB,IAAI,CAAC;IAC1F,OAAO,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC,CAAC,mBAAmB,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC;IAC9F,OAAO,CAAC,0BAA0B,CAAC,gBAAgB,iBAAsB,qBAAqB,EAAE,OAAO,CAAC,CAAC;IAEzG,IAAI,MAAM,CAAC,QAAQ,CAAC,YAAY,CAAC,QAAQ;QACvC,OAAO,CAAC,IAAI,CAAC,cAAc,CAAC,mDAAmD,CAAC,CAAC;;QAEjF,OAAO,CAAC,IAAI,CAAC,cAAc,CAAC,6CAA6C,CAAC,CAAC;IAE7E,OAAO,CAAC,eAAe,CAAC,gBAAgB,mCAA+C,CAAC,IAAI,EAAE,EAAE;QAC9F,IAAI,CAAC,iBAAiB,CAAC,gBAAgB,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YAC3D,MAAM,CAAC,SAAS,KAAK,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;YAChD,MAAM,IAAI,GAAG,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC;YACvC,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,aAAa,EAAE,gBAAgB,CAAC,CAAC;YACjE,OAAO,CAAC,aAAa,CAAC,gBAAgB,CAAC,CAAC;QAC1C,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC;AAED,SAAS,SAAS,CAAC,OAAuB,EAAE,SAAsB,EAAE,QAAoB;IACtF,eAAe,CAAC,OAAO,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC;IAEzC,OAAO,CAAC,IAAI,CAAC,WAAW,CAAC,eAAe,CAAC,CAAC;IAC1C,6BAA6B,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IAC5C,OAAO,CAAC,0BAA0B,CAAC,KAAK,gBAAqB,uBAAuB,EAAE,QAAQ,CAAC,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC;IAExI,sEAAsE;IACtE,iIAAiI;IACjI,MAAM,YAAY,GAAG,KAAK,CAAC;IAC3B,IAAI,YAAY,EAAE;QAChB,OAAO,CAAC,IAAI,CAAC,GAAG,2BAA0C,uDAAuD,CAAC,CAAC;QACnH,OAAO,CAAC,0BAA0B,CAAC,UAAU,gBAAqB,oBAAoB,EAAE;;;;;;KAMvF,CAAC,CAAC;KACJ;AACH,CAAC;AAED,gBAAgB;AAChB,MAAM,UAAU,UAAU,CAAC,OAAuB,EAAE,QAAoB,EAAE,UAAsB,EAAE,YAAY,GAAG,KAAK;IACpH,IAAI,UAAU,EAAE;QACd,OAAO,CAAC,wBAAwB,CAAC,iBAAiB,iBAAsB,uBAAuB,CAAC,OAAO,CAAC,IAAI,CAAC,qBAAqB,EAAE,YAAY,EAAE,IAAI,CAAC,CAAC,CAAC;KAC1J;SAAM;QACL,OAAO,CAAC,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC;QACvC,6BAA6B,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAC5C,OAAO,CAAC,0BAA0B,CAAC,YAAY,gBAAqB,iBAAiB,EAAE,QAAQ,CAAC,CAAC,CAAC,uBAAuB,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC;QAC7I,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,mBAAmB,gBAAqB,CAAC,IAAI,EAAE,EAAE;YACvE,IAAI,CAAC,iBAAiB,CAAC,mBAAmB,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;gBAC9D,MAAM,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC,SAAU,CAAC;gBAC5C,IAAI,QAAQ,CAAC,UAAU,CAAC,MAAM,CAAC,aAAa,CAAC,EAAE;oBAC7C,MAAM,SAAS,GAAG,QAAQ,CAAC,GAAG,CAAC,SAAS,CAAC;oBACzC,IAAI,SAAS,KAAK,SAAS,EAAE;wBAC3B,OAAO,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC;qBAClC;iBACF;YACH,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;QACH,OAAO,CAAC,IAAI,CAAC,WAAW,CAAC,oBAAoB,CAAC,CAAC;KAChD;IAED,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,WAAW,qBAA0B,CAAC,IAAI,EAAE,EAAE;QACpE,IAAI,CAAC,iBAAiB,CAAC,WAAW,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YACtD,MAAM,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC,SAAU,CAAC;YAC5C,IAAI,MAAM,CAAC,QAAQ,CAAC,uBAAuB,IAAI,MAAM,CAAC,MAAM,CAAC,mBAAmB,EAAE,EAAE,wGAAwG;gBAC1L,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,QAAQ,CAAC,WAAW,CAAC,OAAO,EAAE,WAAW,CAAC,cAAc,CAAC,CAAC;aAClF;iBAAM,IAAI,QAAQ,CAAC,UAAU,CAAC,MAAM,CAAC,aAAa,CAAC,EAAE;gBACpD,MAAM,OAAO,GAAG,CAAC,MAAM,CAAC,QAAQ,CAAC,YAAY,IAAI,MAAM,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC,CAAC,CAAE,MAAM,CAAC,MAAM,CAAC,eAA2B,CAAC,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC;gBAChJ,MAAM,CAAC,SAAS,KAAK,OAAO,CAAC,CAAC;gBAC9B,OAAO,CAAC,OAAO,CAAC,WAAW,CAAC,OAAO,EAAE,WAAW,CAAC,cAAc,CAAC,CAAC;aAClE;iBAAM;gBACL,MAAM,CAAC,QAAQ,CAAC,kBAAkB,CAAC,OAAO,EAAE,WAAW,CAAC,cAAc,CAAC,CAAC;aACzE;QACH,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC;AAED,MAAM,CAAC,MAAM,wBAAwB,GAAG;;;;;;;;CAQvC,CAAC;AAEF,4JAA4J;AAC5J,qJAAqJ;AACrJ,+BAA+B;AAC/B,MAAM,uBAAuB,GAAG,0EAA0E,CAAC;AAE3G,gBAAgB;AAChB,MAAM,UAAU,oBAAoB,CAAC,KAAqB;IACxD,MAAM,OAAO,GAAG,YAAY,CAAC,KAAK,CAAC,WAAW,EAAE,KAAK,CAAC,UAAU,EAAE,KAAK,CAAC,YAAY,EAAE,KAAK,CAAC,UAAU,EAAE,KAAK,CAAC,CAAC;IAC/G,cAAc,CAAC,OAAO,CAAC,CAAC;IAExB,MAAM,IAAI,GAAG,KAAK,CAAC,WAAW,CAAC;IAC/B,IAAI,IAAI,GAAG,sBAA0B,IAAI,CAAC,CAAC,kBAAiC,CAAC,aAA6B,CAAC;IAC3G,IAAI,KAAK,CAAC,YAAY,EAAE;QACtB,IAAI,IAAI,eAA8B,CAAC;QACvC,wBAAwB,CAAC,OAAO,EAAE,KAAK,CAAC,aAAa,EAAE,KAAK,CAAC,UAAU,CAAC,CAAC;KAC1E;IAED,IAAI,KAAK,CAAC,UAAU,EAAE;QACpB,kBAAkB,CAAC,OAAO,CAAC,CAAC;KAC7B;IAED,mBAAmB,CAAC,OAAO,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;IACzC,eAAe,CAAC,OAAO,EAAE,sBAA0B,IAAI,EAAE,IAAI,CAAC,CAAC;IAC/D,iBAAiB,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;IAClC,SAAS,CAAC,OAAO,EAAE,KAAK,CAAC,WAAW,EAAE,KAAK,CAAC,UAAU,CAAC,CAAC;IAExD,wMAAwM;IACxM,6BAA6B,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IAC5C,OAAO,CAAC,IAAI,CAAC,GAAG,4BAA4C,oBAAoB,CAAC,CAAC;IAClF,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,WAAW,gBAAqB,CAAC,IAAI,EAAE,EAAE;QAC/D,IAAI,CAAC,iBAAiB,CAAC,WAAW,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YACtD,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAC;QAC1D,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,UAAU,CAAC,OAAO,EAAE,KAAK,CAAC,UAAU,EAAE,KAAK,CAAC,UAAU,CAAC,CAAC;IAExD,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,iBAAiB,mBAAwB,CAAC,IAAI,EAAE,EAAE;QACxE,IAAI,CAAC,iBAAiB,CAAC,iBAAiB,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YAC5D,MAAM,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC,SAAU,CAAC;YAC5C,OAAO,CAAC,YAAY,CAAC,QAAQ,CAAC,UAAU,CAAC,MAAM,CAAC,aAAa,CAAC,IAAI,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC9F,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,sBAAsB;IACtB,QAAQ,CAAC,OAAO,CAAC,CAAC;IAElB,WAAW;IACX,OAAO,CAAC,IAAI,CAAC,WAAW,CAAC,eAAe,CAAC,CAAC;IAC1C,WAAW,CAAC,OAAO,CAAC,CAAC;IACrB,uBAAuB,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IAEtC,IAAI,KAAK,CAAC,aAAa,EAAE;QACvB,eAAe,CAAC,OAAO,CAAC,CAAC;KAC1B;SAAM;QACL,IAAI,iBAAqB,IAAI,EAAE;YAC7B,kCAAkC,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;SAClD;aAAM;YACL,OAAO,CAAC,IAAI,CAAC,GAAG,yBAAyC,uBAAuB,CAAC,CAAC;YAClF,IAAI,CAAC,KAAK,CAAC,YAAY;gBACrB,0BAA0B,CAAC,OAAO,EAAE,KAAK,CAAC,UAAU,CAAC,CAAC;;gBAEtD,0BAA0B,CAAC,OAAO,CAAC,CAAC;YAEtC,OAAO,CAAC,IAAI,CAAC,WAAW,CAAC,cAAc,CAAC,CAAC;YACzC,IAAI,KAAK,CAAC,gBAAgB,IAAI,KAAK,CAAC,YAAY;gBAC9C,oBAAoB,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;;gBAEnC,uBAAuB,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;SACzC;KACF;IAED,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,gBAAgB,eAAoB,CAAC;IAC5D,OAAO,CAAC,IAAI,CAAC,GAAG,2BAA2C,CAAC,KAAK,CAAC,UAAU,eAAkB,CAAC,CAAC,CAAC,CAAC,gBAAgB,CAAC,CAAC,CAAC,2BAA2B,CAAC,CAAC;IAElJ,IAAI,KAAK,CAAC,YAAY;QACpB,oCAAoC,CAAC,OAAO,CAAC,CAAC;IAEhD,oBAAoB,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IACnC,WAAW,CAAC,OAAO,CAAC,CAAC;IAErB,IAAI,KAAK,CAAC,UAAU;QAClB,WAAW,CAAC,OAAO,CAAC,CAAC;IAEvB,OAAO,OAAO,CAAC;AACjB,CAAC;AAED,MAAM,UAAU,oCAAoC,CAAC,OAAuB;IAC1E,2LAA2L;IAC3L,+GAA+G;IAC/G,iMAAiM;IACjM,4GAA4G;IAC5G,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IAC1B,aAAa,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IAE5B,iFAAiF;IACjF,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,yBAAyB,mBAAwB,CAAC,IAAI,EAAE,EAAE;QAChF,IAAI,CAAC,iBAAiB,CAAC,yBAAyB,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YACpE,OAAO,CAAC,YAAY,CAAC,MAAM,CAAC,MAAM,CAAC,sBAAsB,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACrE,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,OAAO,CAAC,IAAI,CAAC,GAAG,yBAAyC,wBAAwB,CAAC,CAAC;AACrF,CAAC","sourcesContent":["/*---------------------------------------------------------------------------------------------\r\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\r\n* See LICENSE.md in the project root for license terms and full copyright notice.\r\n*--------------------------------------------------------------------------------------------*/\r\n/** @packageDocumentation\r\n * @module WebGL\r\n */\r\n\r\nimport { assert } from \"@itwin/core-bentley\";\r\nimport { AttributeMap } from \"../AttributeMap\";\r\nimport { Material } from \"../Material\";\r\nimport { SurfaceBitIndex, SurfaceFlags, TextureUnit } from \"../RenderFlags\";\r\nimport { FragmentShaderComponent, ProgramBuilder, ShaderBuilder, ShaderBuilderFlags, VariableType, VertexShaderComponent } from \"../ShaderBuilder\";\r\nimport { System } from \"../System\";\r\nimport { FeatureMode, IsAnimated, IsClassified, IsInstanced, IsShadowable, IsThematic, TechniqueFlags } from \"../TechniqueFlags\";\r\nimport { TechniqueId } from \"../TechniqueId\";\r\nimport { Texture } from \"../Texture\";\r\nimport { addAnimation } from \"./Animation\";\r\nimport { unpackFloat } from \"./Clipping\";\r\nimport { addColor } from \"./Color\";\r\nimport { addChooseWithBitFlagFunctions, addExtractNthBit, addFrustum, addShaderFlags } from \"./Common\";\r\nimport { addUnpackAndNormalize2Bytes, decodeDepthRgb, unquantize2d } from \"./Decode\";\r\nimport {\r\n addFeatureSymbology, addMaxAlpha, addRenderOrder, addRenderOrderConstants, addSurfaceDiscard, addSurfaceHiliter, FeatureSymbologyOptions,\r\n} from \"./FeatureSymbology\";\r\nimport {\r\n addAltPickBufferOutputs, addFragColorWithPreMultipliedAlpha, addPickBufferOutputs, addWhiteOnWhiteReversal, assignFragColor,\r\n} from \"./Fragment\";\r\nimport { addLighting } from \"./Lighting\";\r\nimport { addSurfaceMonochrome } from \"./Monochrome\";\r\nimport { addColorPlanarClassifier, addFeaturePlanarClassifier, addHilitePlanarClassifier, addOverrideClassifierColor } from \"./PlanarClassification\";\r\nimport { addRenderPass } from \"./RenderPass\";\r\nimport { addSolarShadowMap } from \"./SolarShadowMapping\";\r\nimport { addThematicDisplay, getComputeThematicIndex } from \"./Thematic\";\r\nimport { addTranslucency } from \"./Translucency\";\r\nimport { addFeatureAndMaterialLookup, addModelViewMatrix, addNormalMatrix, addProjectionMatrix } from \"./Vertex\";\r\nimport { wantMaterials } from \"../Mesh\";\r\nimport { addWiremesh } from \"./Wiremesh\";\r\n\r\n// NB: Textures do not contain pre-multiplied alpha.\r\nconst sampleSurfaceTexture = `\r\nvec4 sampleSurfaceTexture() {\r\n return TEXTURE(s_texture, v_texCoord);\r\n}\r\n`;\r\n\r\nconst applyMaterialColor = `\r\n float useMatColor = float(use_material);\r\n vec3 rgb = mix(baseColor.rgb, mat_rgb.rgb, useMatColor * mat_rgb.a);\r\n float a = mix(baseColor.a, mat_alpha.x, useMatColor * mat_alpha.y);\r\n return vec4(rgb, a);\r\n`;\r\n\r\n// if this is a raster glyph, the sampled color has already been modified - do not modify further.\r\n// Mix diffuse color with texel based on texture weight.\r\n// Replace with diffuse RGB if RGB overridden.\r\n// Replace with diffuse alpha if alpha overridden.\r\n// Multiply texel alpha with diffuse alpha if specified.\r\nconst applyTextureWeight = `\r\n bool applyTexture = !u_applyGlyphTex && isSurfaceBitSet(kSurfaceBit_HasTexture);\r\n float textureWeight = applyTexture ? mat_texture_weight : 0.0;\r\n vec3 rgb = mix(baseColor.rgb, g_surfaceTexel.rgb, textureWeight);\r\n rgb = chooseVec3WithBitFlag(rgb, baseColor.rgb, surfaceFlags, kSurfaceBit_OverrideRgb);\r\n\r\n float a = applyTexture ? baseColor.a * g_surfaceTexel.a : baseColor.a;\r\n\r\n return vec4(rgb, a);\r\n`;\r\n\r\nconst decodeFragMaterialParams = `\r\nvoid decodeMaterialParams(vec4 params) {\r\n mat_weights = unpackAndNormalize2Bytes(params.x);\r\n\r\n vec2 texAndSpecR = unpackAndNormalize2Bytes(params.y);\r\n mat_texture_weight = texAndSpecR.x;\r\n\r\n vec2 specGB = unpackAndNormalize2Bytes(params.z);\r\n mat_specular = vec4(texAndSpecR.y, specGB, params.w);\r\n}\r\n`;\r\n\r\nconst decodeMaterialColor = `\r\nvoid decodeMaterialColor(vec4 rgba) {\r\n mat_rgb = vec4(rgba.rgb, float(rgba.r >= 0.0));\r\n mat_alpha = vec2(rgba.a, float(rgba.a >= 0.0));\r\n}\r\n`;\r\n\r\n// defaults: (0x6699, 0xffff, 0xffff, 13.5)\r\nconst computeMaterialParams = `\r\n const vec4 defaults = vec4(26265.0, 65535.0, 65535.0, 13.5);\r\n return use_material ? g_materialParams : defaults;\r\n`;\r\n\r\n// The 8-bit material index is stored with the 24-bit feature index, in the high byte.\r\nconst readMaterialAtlas = `\r\nvoid readMaterialAtlas() {\r\n float materialAtlasStart = u_vertParams.z * u_vertParams.w + u_numColors;\r\n float materialIndex = g_featureAndMaterialIndex.w * 4.0 + materialAtlasStart;\r\n\r\n vec2 tc = computeLUTCoords(materialIndex, u_vertParams.xy, g_vert_center, 1.0);\r\n vec4 rgba = TEXTURE(u_vertLUT, tc);\r\n\r\n tc = computeLUTCoords(materialIndex + 1.0, u_vertParams.xy, g_vert_center, 1.0);\r\n vec4 weightsAndFlags = floor(TEXTURE(u_vertLUT, tc) * 255.0 + 0.5);\r\n\r\n tc = computeLUTCoords(materialIndex + 2.0, u_vertParams.xy, g_vert_center, 1.0);\r\n vec3 specularRgb = floor(TEXTURE(u_vertLUT, tc) * 255.0 + 0.5).rgb;\r\n\r\n tc = computeLUTCoords(materialIndex + 3.0, u_vertParams.xy, g_vert_center, 1.0);\r\n vec4 packedSpecularExponent = TEXTURE(u_vertLUT, tc);\r\n\r\n float flags = weightsAndFlags.w;\r\n mat_rgb = vec4(rgba.rgb, float(flags == 1.0 || flags == 3.0));\r\n mat_alpha = vec2(rgba.a, float(flags == 2.0 || flags == 3.0));\r\n\r\n float specularExponent = unpackFloat(packedSpecularExponent);\r\n g_materialParams.x = weightsAndFlags.y + weightsAndFlags.z * 256.0;\r\n g_materialParams.y = 255.0 + specularRgb.r * 256.0;\r\n g_materialParams.z = specularRgb.g + specularRgb.b * 256.0;\r\n g_materialParams.w = specularExponent;\r\n}\r\n`;\r\n\r\nconst computeMaterial = `\r\n if (u_surfaceFlags[kSurfaceBitIndex_HasMaterialAtlas]) {\r\n readMaterialAtlas();\r\n } else {\r\n decodeMaterialColor(u_materialColor);\r\n g_materialParams = u_materialParams;\r\n }\r\n`;\r\n\r\nfunction addMaterial(builder: ProgramBuilder): void {\r\n const frag = builder.frag;\r\n assert(undefined !== frag.find(\"v_surfaceFlags\"));\r\n\r\n frag.addGlobal(\"mat_texture_weight\", VariableType.Float);\r\n frag.addGlobal(\"mat_weights\", VariableType.Vec2); // diffuse, specular\r\n frag.addGlobal(\"mat_specular\", VariableType.Vec4); // rgb, exponent\r\n\r\n addUnpackAndNormalize2Bytes(frag);\r\n frag.addFunction(decodeFragMaterialParams);\r\n frag.addInitializer(\"decodeMaterialParams(v_materialParams);\");\r\n\r\n addChooseWithBitFlagFunctions(frag);\r\n frag.set(FragmentShaderComponent.ApplyMaterialOverrides, applyTextureWeight);\r\n\r\n const vert = builder.vert;\r\n vert.addGlobal(\"mat_rgb\", VariableType.Vec4); // a = 0 if not overridden, else 1\r\n vert.addGlobal(\"mat_alpha\", VariableType.Vec2); // a = 0 if not overridden, else 1\r\n vert.addGlobal(\"use_material\", VariableType.Boolean);\r\n if (System.instance.capabilities.isWebGL2)\r\n vert.addInitializer(\"use_material = (0u == (surfaceFlags & kSurfaceBit_IgnoreMaterial));\");\r\n else\r\n vert.addInitializer(\"use_material = !nthBitSet(surfaceFlags, kSurfaceBit_IgnoreMaterial);\");\r\n\r\n // Uniform material\r\n vert.addFunction(decodeMaterialColor);\r\n vert.addUniform(\"u_materialColor\", VariableType.Vec4, (prog) => {\r\n prog.addGraphicUniform(\"u_materialColor\", (uniform, params) => {\r\n const info = wantMaterials(params.target.currentViewFlags) ? params.geometry.materialInfo : undefined;\r\n const mat = undefined !== info && !info.isAtlas ? info : Material.default;\r\n uniform.setUniform4fv(mat.rgba);\r\n });\r\n });\r\n\r\n vert.addUniform(\"u_materialParams\", VariableType.Vec4, (prog) => {\r\n prog.addGraphicUniform(\"u_materialParams\", (uniform, params) => {\r\n const info = wantMaterials(params.target.currentViewFlags) ? params.geometry.materialInfo : undefined;\r\n const mat = undefined !== info && !info.isAtlas ? info : Material.default;\r\n uniform.setUniform4fv(mat.fragUniforms);\r\n });\r\n });\r\n\r\n // Material atlas\r\n addFeatureAndMaterialLookup(vert);\r\n vert.addFunction(unpackFloat);\r\n vert.addFunction(readMaterialAtlas);\r\n vert.addUniform(\"u_numColors\", VariableType.Float, (prog) => {\r\n prog.addGraphicUniform(\"u_numColors\", (uniform, params) => {\r\n const info = params.geometry.materialInfo;\r\n const numColors = undefined !== info && info.isAtlas ? info.vertexTableOffset : 0;\r\n uniform.setUniform1f(numColors);\r\n });\r\n });\r\n\r\n vert.addGlobal(\"g_materialParams\", VariableType.Vec4);\r\n vert.set(VertexShaderComponent.ComputeMaterial, computeMaterial);\r\n vert.set(VertexShaderComponent.ApplyMaterialColor, applyMaterialColor);\r\n builder.addFunctionComputedVarying(\"v_materialParams\", VariableType.Vec4, \"computeMaterialParams\", computeMaterialParams);\r\n}\r\n\r\nconst computePositionPrelude = `\r\n vec4 pos = MAT_MV * rawPos;\r\n`;\r\n\r\n// We used to use gl.polygonOffset() for blanking regions, but that doesn't work with logarithmic depth buffer which overwrites the\r\n// computed Z. Instead we must manually offset in vertex shader. We do this even if log depth is not enabled/supported.\r\n// NOTE: If log depth is *not* supported, then the hilite surface vertex shaders previously would still include this logic, but the\r\n// fragment shaders would not use v_eyeSpace. Some Ubuntu 20.04 graphics drivers cleverly and correctly optimized out the varying and the uniform,\r\n// causing an exception when gl.getProgramLocation() failed. So, omit this bit in that case.\r\nconst adjustEyeSpace = `\r\n v_eyeSpace = pos.xyz;\r\n const float blankingRegionOffset = 2.0 / 65536.0;\r\n if (kRenderOrder_BlankingRegion == u_renderOrder)\r\n v_eyeSpace.z -= blankingRegionOffset * (u_frustum.y - u_frustum.x);\r\n`;\r\n\r\nconst computePositionPostlude = `\r\n return u_proj * pos;\r\n`;\r\n\r\nfunction createCommon(instanced: IsInstanced, animated: IsAnimated, shadowable: IsShadowable, isThematic: IsThematic, isHiliter: boolean): ProgramBuilder {\r\n const attrMap = AttributeMap.findAttributeMap(TechniqueId.Surface, IsInstanced.Yes === instanced);\r\n const builder = new ProgramBuilder(attrMap, instanced ? ShaderBuilderFlags.InstancedVertexTable : ShaderBuilderFlags.VertexTable);\r\n const vert = builder.vert;\r\n\r\n if (animated)\r\n addAnimation(vert, true, isThematic);\r\n\r\n if (shadowable)\r\n addSolarShadowMap(builder);\r\n\r\n addProjectionMatrix(vert);\r\n addModelViewMatrix(vert);\r\n\r\n let computePosition;\r\n if (isHiliter && !System.instance.supportsLogZBuffer) {\r\n computePosition = computePositionPrelude + computePositionPostlude;\r\n } else {\r\n addFrustum(builder);\r\n addRenderOrder(builder.vert);\r\n addRenderOrderConstants(builder.vert);\r\n builder.addVarying(\"v_eyeSpace\", VariableType.Vec3);\r\n computePosition = computePositionPrelude + adjustEyeSpace + computePositionPostlude;\r\n }\r\n\r\n vert.set(VertexShaderComponent.ComputePosition, computePosition);\r\n\r\n return builder;\r\n}\r\n\r\n/** @internal */\r\nexport function createSurfaceHiliter(instanced: IsInstanced, classified: IsClassified): ProgramBuilder {\r\n const builder = createCommon(instanced, IsAnimated.No, IsShadowable.No, IsThematic.No, true);\r\n\r\n addSurfaceFlags(builder, true, false);\r\n addTexture(builder, IsAnimated.No, IsThematic.No);\r\n if (classified) {\r\n addHilitePlanarClassifier(builder);\r\n builder.vert.addGlobal(\"feature_ignore_material\", VariableType.Boolean, \"false\");\r\n builder.frag.set(FragmentShaderComponent.AssignFragData, assignFragColor);\r\n } else {\r\n addSurfaceHiliter(builder);\r\n }\r\n\r\n return builder;\r\n}\r\n\r\nconst isSurfaceBitSet = `\r\nbool isSurfaceBitSet(float flag) { return nthBitSet(surfaceFlags, flag); }\r\n`;\r\nconst isSurfaceBitSet2 = `\r\nbool isSurfaceBitSet(uint flag) { return 0u != (surfaceFlags & flag); }\r\n`;\r\n\r\n/** @internal */\r\nfunction addSurfaceFlagsLookup(builder: ShaderBuilder) {\r\n builder.addConstant(\"kSurfaceBitIndex_HasTexture\", VariableType.Int, SurfaceBitIndex.HasTexture.toString());\r\n builder.addConstant(\"kSurfaceBitIndex_ApplyLighting\", VariableType.Int, SurfaceBitIndex.ApplyLighting.toString());\r\n builder.addConstant(\"kSurfaceBitIndex_HasNormals\", VariableType.Int, SurfaceBitIndex.HasNormals.toString());\r\n builder.addConstant(\"kSurfaceBitIndex_IgnoreMaterial\", VariableType.Int, SurfaceBitIndex.IgnoreMaterial.toString());\r\n builder.addConstant(\"kSurfaceBitIndex_TransparencyThreshold\", VariableType.Int, SurfaceBitIndex.TransparencyThreshold.toString());\r\n builder.addConstant(\"kSurfaceBitIndex_BackgroundFill\", VariableType.Int, SurfaceBitIndex.BackgroundFill.toString());\r\n builder.addConstant(\"kSurfaceBitIndex_HasColorAndNormal\", VariableType.Int, SurfaceBitIndex.HasColorAndNormal.toString());\r\n builder.addConstant(\"kSurfaceBitIndex_OverrideRgb\", VariableType.Int, SurfaceBitIndex.OverrideRgb.toString());\r\n builder.addConstant(\"kSurfaceBitIndex_NoFaceFront\", VariableType.Int, SurfaceBitIndex.NoFaceFront.toString());\r\n builder.addConstant(\"kSurfaceBitIndex_HasMaterialAtlas\", VariableType.Int, SurfaceBitIndex.HasMaterialAtlas.toString());\r\n\r\n // Surface flags which get modified in vertex shader are still passed to fragment shader as a single float & are thus\r\n // used differently there & so require different constants. Unused constants are commented out.\r\n builder.addBitFlagConstant(\"kSurfaceBit_HasTexture\", SurfaceBitIndex.HasTexture);\r\n builder.addBitFlagConstant(\"kSurfaceBit_IgnoreMaterial\", SurfaceBitIndex.IgnoreMaterial);\r\n builder.addBitFlagConstant(\"kSurfaceBit_OverrideRgb\", SurfaceBitIndex.OverrideRgb);\r\n\r\n // Only need masks for flags modified in vertex shader\r\n const suffix = System.instance.capabilities.isWebGL2 ? \"u\" : \".0\";\r\n const type = System.instance.capabilities.isWebGL2 ? VariableType.Uint : VariableType.Float;\r\n builder.addConstant(\"kSurfaceMask_HasTexture\", type, SurfaceFlags.HasTexture.toString() + suffix);\r\n builder.addConstant(\"kSurfaceMask_IgnoreMaterial\", type, SurfaceFlags.IgnoreMaterial.toString() + suffix);\r\n builder.addConstant(\"kSurfaceMask_OverrideRgb\", type, SurfaceFlags.OverrideRgb.toString() + suffix);\r\n\r\n addExtractNthBit(builder);\r\n if (System.instance.capabilities.isWebGL2) {\r\n builder.addFunction(isSurfaceBitSet2);\r\n builder.addGlobal(\"surfaceFlags\", VariableType.Uint);\r\n } else {\r\n builder.addFunction(isSurfaceBitSet);\r\n builder.addGlobal(\"surfaceFlags\", VariableType.Float);\r\n }\r\n}\r\n\r\nconst initSurfaceFlags = `\r\n surfaceFlags = u_surfaceFlags[kSurfaceBitIndex_HasTexture] ? kSurfaceMask_HasTexture : 0.0;\r\n surfaceFlags += u_surfaceFlags[kSurfaceBitIndex_IgnoreMaterial] ? kSurfaceMask_IgnoreMaterial : 0.0;\r\n surfaceFlags += u_surfaceFlags[kSurfaceBitIndex_OverrideRgb] ? kSurfaceMask_OverrideRgb : 0.0;\r\n`;\r\nconst initSurfaceFlags2 = `\r\n surfaceFlags = u_surfaceFlags[kSurfaceBitIndex_HasTexture] ? kSurfaceMask_HasTexture : 0u;\r\n surfaceFlags += u_surfaceFlags[kSurfaceBitIndex_IgnoreMaterial] ? kSurfaceMask_IgnoreMaterial : 0u;\r\n surfaceFlags += u_surfaceFlags[kSurfaceBitIndex_OverrideRgb] ? kSurfaceMask_OverrideRgb : 0u;\r\n`;\r\n\r\nconst computeBaseSurfaceFlags = `\r\n bool hasTexture = u_surfaceFlags[kSurfaceBitIndex_HasTexture];\r\n if (feature_ignore_material) {\r\n if (hasTexture) {\r\n hasTexture = false;\r\n surfaceFlags -= kSurfaceMask_HasTexture;\r\n }\r\n\r\n surfaceFlags += kSurfaceMask_IgnoreMaterial;\r\n }\r\n`;\r\n\r\n// Textured surfaces (including raster glyphs) always *multiply* the sampled alpha by the alpha override.\r\nconst computeColorSurfaceFlags = `\r\n if (feature_rgb.r >= 0.0)\r\n surfaceFlags += kSurfaceMask_OverrideRgb;\r\n`;\r\n\r\nconst returnSurfaceFlags = \" return surfaceFlags;\\n\";\r\nconst returnSurfaceFlags2 = \" return float(surfaceFlags);\\n\";\r\n\r\nconst computeSurfaceFlags = computeBaseSurfaceFlags;\r\nconst computeSurfaceFlagsWithColor = computeBaseSurfaceFlags + computeColorSurfaceFlags;\r\n\r\n/** @internal */\r\nexport const octDecodeNormal = `\r\nvec3 octDecodeNormal(vec2 e) {\r\n e = e / 255.0 * 2.0 - 1.0;\r\n vec3 n = vec3(e.x, e.y, 1.0 - abs(e.x) - abs(e.y));\r\n if (n.z < 0.0) {\r\n vec2 signNotZero = vec2(n.x >= 0.0 ? 1.0 : -1.0, n.y >= 0.0 ? 1.0 : -1.0);\r\n n.xy = (1.0 - abs(n.yx)) * signNotZero;\r\n }\r\n\r\n return normalize(n);\r\n}\r\n`;\r\n\r\nconst computeNormal = `\r\n vec2 tc = g_vertexBaseCoords;\r\n tc.x += 3.0 * g_vert_stepX;\r\n vec4 enc = floor(TEXTURE(u_vertLUT, tc) * 255.0 + 0.5);\r\n vec2 normal = u_surfaceFlags[kSurfaceBitIndex_HasColorAndNormal] ? enc.xy : g_vertexData2;\r\n return u_surfaceFlags[kSurfaceBitIndex_HasNormals] ? normalize(MAT_NORM * octDecodeNormal(normal)) : vec3(0.0);\r\n`;\r\n\r\nconst computeAnimatedNormal = `\r\n if (u_animNormalParams.x >= 0.0)\r\n return normalize(MAT_NORM * computeAnimationNormal(u_animNormalParams.x, u_animNormalParams.y, u_animNormalParams.z));\r\n${computeNormal}`;\r\n\r\nconst applyBackgroundColor = `\r\n return u_surfaceFlags[kSurfaceBitIndex_BackgroundFill] ? vec4(u_bgColor.rgb, baseColor.a) : baseColor;\r\n`;\r\n\r\nconst computeTexCoord = `\r\n vec2 tc = g_vertexBaseCoords;\r\n tc.x += 3.0 * g_vert_stepX;\r\n vec4 rgba = floor(TEXTURE(u_vertLUT, tc) * 255.0 + 0.5);\r\n vec2 qcoords = vec2(decodeUInt16(rgba.xy), decodeUInt16(rgba.zw));\r\n return chooseVec2WithBitFlag(vec2(0.0), unquantize2d(qcoords, u_qTexCoordParams), surfaceFlags, kSurfaceBit_HasTexture);\r\n`;\r\nconst computeAnimatedTexCoord = `\r\n if (u_animScalarQParams.x >= 0.0)\r\n return computeAnimationParam(u_animScalarParams.x, u_animScalarParams.y, u_animScalarParams.z, u_animScalarQParams.x, u_animScalarQParams.y);\r\n${computeTexCoord}`;\r\nconst getSurfaceColor = `\r\nvec4 getSurfaceColor() { return v_color; }\r\n`;\r\n\r\n// If we have texture weight < 1.0 we must compute the element/material color first then mix with texture color\r\n// in ApplyMaterialOverrides(). Do the sample once, here, and store in a global variable for possible later use.\r\n// If a glyph texture, must mix getSurfaceColor() with texture color so texture color alpha is applied 100% and\r\n// surface color rgb is scaled by texture color rgb (latter is full white originally but stretched via mipmapping).\r\nconst computeBaseColor = `\r\n g_surfaceTexel = sampleSurfaceTexture();\r\n vec4 surfaceColor = getSurfaceColor();\r\n\r\n if (!u_applyGlyphTex)\r\n return surfaceColor;\r\n\r\n // Compute color for raster glyph.\r\n const vec3 white = vec3(1.0);\r\n const vec3 epsilon = vec3(0.0001);\r\n const vec3 almostWhite = white - epsilon;\r\n\r\n // set to black if almost white and reverse white-on-white is on\r\n bvec3 isAlmostWhite = greaterThan(surfaceColor.rgb, almostWhite);\r\n surfaceColor.rgb = (u_reverseWhiteOnWhite && isAlmostWhite.r && isAlmostWhite.g && isAlmostWhite.b ? vec3(0.0, 0.0, 0.0) : surfaceColor.rgb);\r\n return vec4(surfaceColor.rgb * g_surfaceTexel.rgb, g_surfaceTexel.a);\r\n`;\r\n\r\nconst surfaceFlagArray = new Int32Array(SurfaceBitIndex.Count);\r\n\r\n/** @internal */\r\nexport function addSurfaceFlags(builder: ProgramBuilder, withFeatureOverrides: boolean, withFeatureColor: boolean) {\r\n addSurfaceFlagsLookup(builder.vert);\r\n addSurfaceFlagsLookup(builder.frag);\r\n\r\n let compute = (System.instance.capabilities.isWebGL2 ? initSurfaceFlags2 : initSurfaceFlags);\r\n if (withFeatureOverrides)\r\n compute += `${withFeatureColor ? computeSurfaceFlagsWithColor : computeSurfaceFlags}\\n`;\r\n compute += (System.instance.capabilities.isWebGL2 ? returnSurfaceFlags2 : returnSurfaceFlags);\r\n builder.addFunctionComputedVarying(\"v_surfaceFlags\", VariableType.Float, \"computeSurfaceFlags\", compute);\r\n\r\n if (System.instance.capabilities.isWebGL2)\r\n builder.frag.addInitializer(\"surfaceFlags = uint(floor(v_surfaceFlags + 0.5));\");\r\n else\r\n builder.frag.addInitializer(\"surfaceFlags = floor(v_surfaceFlags + 0.5);\");\r\n\r\n builder.addUniformArray(\"u_surfaceFlags\", VariableType.Boolean, SurfaceBitIndex.Count, (prog) => {\r\n prog.addGraphicUniform(\"u_surfaceFlags\", (uniform, params) => {\r\n assert(undefined !== params.geometry.asSurface);\r\n const mesh = params.geometry.asSurface;\r\n mesh.computeSurfaceFlags(params.programParams, surfaceFlagArray);\r\n uniform.setUniform1iv(surfaceFlagArray);\r\n });\r\n });\r\n}\r\n\r\nfunction addNormal(builder: ProgramBuilder, instanced: IsInstanced, animated: IsAnimated) {\r\n addNormalMatrix(builder.vert, instanced);\r\n\r\n builder.vert.addFunction(octDecodeNormal);\r\n addChooseWithBitFlagFunctions(builder.vert);\r\n builder.addFunctionComputedVarying(\"v_n\", VariableType.Vec3, \"computeLightingNormal\", animated ? computeAnimatedNormal : computeNormal);\r\n\r\n // Set to true to colorize surfaces based on normals (in world space).\r\n // You must also set checkMaxVarying to false in ProgramBuilder.buildProgram to avoid assertions, if using a non-optimized build.\r\n const debugNormals = false;\r\n if (debugNormals) {\r\n builder.frag.set(FragmentShaderComponent.ApplyDebugColor, \"return vec4(vec3(v_normal / 2.0 + 0.5), baseColor.a);\");\r\n builder.addFunctionComputedVarying(\"v_normal\", VariableType.Vec3, \"computeDebugNormal\", `\r\n vec2 tc = g_vertexBaseCoords;\r\n tc.x += 3.0 * g_vert_stepX;\r\n vec4 enc = floor(TEXTURE(u_vertLUT, tc) * 255.0 + 0.5);\r\n vec2 normal = u_surfaceFlags[kSurfaceBitIndex_HasColorAndNormal] ? enc.xy : g_vertexData2;\r\n return u_surfaceFlags[kSurfaceBitIndex_HasNormals] ? normalize(octDecodeNormal(normal)) : vec3(0.0);\r\n `);\r\n }\r\n}\r\n\r\n/** @internal */\r\nexport function addTexture(builder: ProgramBuilder, animated: IsAnimated, isThematic: IsThematic, isPointCloud = false) {\r\n if (isThematic) {\r\n builder.addInlineComputedVarying(\"v_thematicIndex\", VariableType.Float, getComputeThematicIndex(builder.vert.usesInstancedGeometry, isPointCloud, true));\r\n } else {\r\n builder.vert.addFunction(unquantize2d);\r\n addChooseWithBitFlagFunctions(builder.vert);\r\n builder.addFunctionComputedVarying(\"v_texCoord\", VariableType.Vec2, \"computeTexCoord\", animated ? computeAnimatedTexCoord : computeTexCoord);\r\n builder.vert.addUniform(\"u_qTexCoordParams\", VariableType.Vec4, (prog) => {\r\n prog.addGraphicUniform(\"u_qTexCoordParams\", (uniform, params) => {\r\n const surfGeom = params.geometry.asSurface!;\r\n if (surfGeom.useTexture(params.programParams)) {\r\n const uvQParams = surfGeom.lut.uvQParams;\r\n if (undefined !== uvQParams) {\r\n uniform.setUniform4fv(uvQParams);\r\n }\r\n }\r\n });\r\n });\r\n builder.frag.addFunction(sampleSurfaceTexture);\r\n }\r\n\r\n builder.frag.addUniform(\"s_texture\", VariableType.Sampler2D, (prog) => {\r\n prog.addGraphicUniform(\"s_texture\", (uniform, params) => {\r\n const surfGeom = params.geometry.asSurface!;\r\n if (params.geometry.supportsThematicDisplay && params.target.wantThematicDisplay) { // NB: if thematic display is enabled, bind the thematic texture and ignore any applied surface textures\r\n params.target.uniforms.thematic.bindTexture(uniform, TextureUnit.SurfaceTexture);\r\n } else if (surfGeom.useTexture(params.programParams)) {\r\n const texture = (params.geometry.hasAnimation && params.target.analysisTexture) ? (params.target.analysisTexture as Texture) : surfGeom.texture;\r\n assert(undefined !== texture);\r\n texture.texture.bindSampler(uniform, TextureUnit.SurfaceTexture);\r\n } else {\r\n System.instance.ensureSamplerBound(uniform, TextureUnit.SurfaceTexture);\r\n }\r\n });\r\n });\r\n}\r\n\r\nexport const discardClassifiedByAlpha = `\r\n if (u_no_classifier_discard)\r\n return false;\r\n\r\n bool hasAlpha = alpha <= s_maxAlpha;\r\n bool isOpaquePass = (kRenderPass_OpaqueLinear <= u_renderPass && kRenderPass_OpaqueGeneral >= u_renderPass);\r\n bool isTranslucentPass = kRenderPass_Translucent == u_renderPass;\r\n return (isOpaquePass && hasAlpha) || (isTranslucentPass && !hasAlpha);\r\n`;\r\n\r\n// Target.readPixels() renders everything in opaque pass. It turns off textures for normal surfaces but keeps them for things like 3d view attachment tiles.\r\n// We want to discard fully-transparent pixels of those things during readPixels() so that we don't locate the attachment unless the cursor is over a\r\n// non-transparent pixel of it.\r\nconst discardTransparentTexel = `return isSurfaceBitSet(kSurfaceBit_HasTexture) && alpha < (1.0 / 255.0);`;\r\n\r\n/** @internal */\r\nexport function createSurfaceBuilder(flags: TechniqueFlags): ProgramBuilder {\r\n const builder = createCommon(flags.isInstanced, flags.isAnimated, flags.isShadowable, flags.isThematic, false);\r\n addShaderFlags(builder);\r\n\r\n const feat = flags.featureMode;\r\n let opts = FeatureMode.Overrides === feat ? FeatureSymbologyOptions.Surface : FeatureSymbologyOptions.None;\r\n if (flags.isClassified) {\r\n opts &= ~FeatureSymbologyOptions.Alpha;\r\n addColorPlanarClassifier(builder, flags.isTranslucent, flags.isThematic);\r\n }\r\n\r\n if (flags.isThematic) {\r\n addThematicDisplay(builder);\r\n }\r\n\r\n addFeatureSymbology(builder, feat, opts);\r\n addSurfaceFlags(builder, FeatureMode.Overrides === feat, true);\r\n addSurfaceDiscard(builder, flags);\r\n addNormal(builder, flags.isInstanced, flags.isAnimated);\r\n\r\n // In HiddenLine mode, we must compute the base color (plus feature overrides etc) in order to get the alpha, then replace with background color (preserving alpha for the transparency threshold test).\r\n addChooseWithBitFlagFunctions(builder.frag);\r\n builder.frag.set(FragmentShaderComponent.FinalizeBaseColor, applyBackgroundColor);\r\n builder.frag.addUniform(\"u_bgColor\", VariableType.Vec3, (prog) => {\r\n prog.addProgramUniform(\"u_bgColor\", (uniform, params) => {\r\n params.target.uniforms.style.bindBackgroundRgb(uniform);\r\n });\r\n });\r\n\r\n addTexture(builder, flags.isAnimated, flags.isThematic);\r\n\r\n builder.frag.addUniform(\"u_applyGlyphTex\", VariableType.Boolean, (prog) => {\r\n prog.addGraphicUniform(\"u_applyGlyphTex\", (uniform, params) => {\r\n const surfGeom = params.geometry.asSurface!;\r\n uniform.setUniform1i(surfGeom.useTexture(params.programParams) && surfGeom.isGlyph ? 1 : 0);\r\n });\r\n });\r\n\r\n // Fragment and Vertex\r\n addColor(builder);\r\n\r\n // Fragment\r\n builder.frag.addFunction(getSurfaceColor);\r\n addLighting(builder);\r\n addWhiteOnWhiteReversal(builder.frag);\r\n\r\n if (flags.isTranslucent) {\r\n addTranslucency(builder);\r\n } else {\r\n if (FeatureMode.None === feat) {\r\n addFragColorWithPreMultipliedAlpha(builder.frag);\r\n } else {\r\n builder.frag.set(FragmentShaderComponent.DiscardByAlpha, discardTransparentTexel);\r\n if (!flags.isClassified)\r\n addOverrideClassifierColor(builder, flags.isThematic);\r\n else\r\n addFeaturePlanarClassifier(builder);\r\n\r\n builder.frag.addFunction(decodeDepthRgb);\r\n if (flags.isEdgeTestNeeded || flags.isClassified)\r\n addPickBufferOutputs(builder.frag);\r\n else\r\n addAltPickBufferOutputs(builder.frag);\r\n }\r\n }\r\n\r\n builder.frag.addGlobal(\"g_surfaceTexel\", VariableType.Vec4);\r\n builder.frag.set(FragmentShaderComponent.ComputeBaseColor, (flags.isThematic === IsThematic.No) ? computeBaseColor : \"return getSurfaceColor();\");\r\n\r\n if (flags.isClassified)\r\n addClassificationTranslucencyDiscard(builder);\r\n\r\n addSurfaceMonochrome(builder.frag);\r\n addMaterial(builder);\r\n\r\n if (flags.isWiremesh)\r\n addWiremesh(builder);\r\n\r\n return builder;\r\n}\r\n\r\nexport function addClassificationTranslucencyDiscard(builder: ProgramBuilder) {\r\n // For unclassified geometry, we need to render in both the translucent and opaque passes if any feature transparency overrides are applied that would change the default render pass used.\r\n // Those shaders compute the transparency in the vertex shader and discard the vertex in one pass or the other.\r\n // For classified geometry, the transparency comes from the classifier geometry (when using Display.ElementColor), so even if there are no feature overrides, we may need to draw in both passes.\r\n // Since the transparency is not known until the fragment shader, we must perform the discard there instead.\r\n addMaxAlpha(builder.frag);\r\n addRenderPass(builder.frag);\r\n\r\n // Do not discard transparent classified geometry if we're trying to do a pick...\r\n builder.frag.addUniform(\"u_no_classifier_discard\", VariableType.Boolean, (prog) => {\r\n prog.addProgramUniform(\"u_no_classifier_discard\", (uniform, params) => {\r\n uniform.setUniform1i(params.target.isReadPixelsInProgress ? 1 : 0);\r\n });\r\n });\r\n\r\n builder.frag.set(FragmentShaderComponent.DiscardByAlpha, discardClassifiedByAlpha);\r\n}\r\n"]}
|
|
1
|
+
{"version":3,"file":"Surface.js","sourceRoot":"","sources":["../../../../../src/render/webgl/glsl/Surface.ts"],"names":[],"mappings":"AAAA;;;+FAG+F;AAC/F;;GAEG;AAEH,OAAO,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AAC7C,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AACvC,OAAO,EAAiC,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC5E,OAAO,EAA2B,cAAc,EAA0E,MAAM,kBAAkB,CAAC;AACnJ,OAAO,EAAE,MAAM,EAAE,MAAM,WAAW,CAAC;AAInC,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAC3C,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AACzC,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AACnC,OAAO,EAAE,6BAA6B,EAAE,gBAAgB,EAAE,UAAU,EAAE,cAAc,EAAE,MAAM,UAAU,CAAC;AACvG,OAAO,EAAE,2BAA2B,EAAE,cAAc,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AACrF,OAAO,EACL,mBAAmB,EAAE,WAAW,EAAE,cAAc,EAAE,uBAAuB,EAAE,iBAAiB,EAAE,iBAAiB,GAChH,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EACL,uBAAuB,EAAE,kCAAkC,EAAE,oBAAoB,EAAE,uBAAuB,EAAE,eAAe,GAC5H,MAAM,YAAY,CAAC;AACpB,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AACzC,OAAO,EAAE,oBAAoB,EAAE,MAAM,cAAc,CAAC;AACpD,OAAO,EAAE,wBAAwB,EAAE,0BAA0B,EAAE,yBAAyB,EAAE,0BAA0B,EAAE,MAAM,wBAAwB,CAAC;AACrJ,OAAO,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAC7C,OAAO,EAAE,iBAAiB,EAAE,MAAM,sBAAsB,CAAC;AACzD,OAAO,EAAE,kBAAkB,EAAE,uBAAuB,EAAE,MAAM,YAAY,CAAC;AACzE,OAAO,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC;AACjD,OAAO,EAAE,2BAA2B,EAAE,kBAAkB,EAAE,eAAe,EAAE,mBAAmB,EAAE,MAAM,UAAU,CAAC;AACjH,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAEzC,oDAAoD;AACpD,MAAM,oBAAoB,GAAG;;;;CAI5B,CAAC;AAEF,MAAM,kBAAkB,GAAG;;;;;CAK1B,CAAC;AAEF,kGAAkG;AAClG,wDAAwD;AACxD,8CAA8C;AAC9C,kDAAkD;AAClD,wDAAwD;AACxD,MAAM,kBAAkB,GAAG;;;;;;;;;CAS1B,CAAC;AAEF,MAAM,wBAAwB,GAAG;;;;;;;;;;CAUhC,CAAC;AAEF,MAAM,mBAAmB,GAAG;;;;;CAK3B,CAAC;AAEF,2CAA2C;AAC3C,MAAM,qBAAqB,GAAG;;;CAG7B,CAAC;AAEF,sFAAsF;AACtF,MAAM,iBAAiB,GAAG;;;;;;;;;;;;;;;;;;;;;;;;;;;CA2BzB,CAAC;AAEF,MAAM,eAAe,GAAG;;;;;;;CAOvB,CAAC;AAEF,SAAS,WAAW,CAAC,OAAuB;IAC1C,MAAM,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;IAC1B,MAAM,CAAC,SAAS,KAAK,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC;IAElD,IAAI,CAAC,SAAS,CAAC,oBAAoB,gBAAqB,CAAC;IACzD,IAAI,CAAC,SAAS,CAAC,aAAa,eAAoB,CAAC,CAAC,oBAAoB;IACtE,IAAI,CAAC,SAAS,CAAC,cAAc,eAAoB,CAAC,CAAC,gBAAgB;IAEnE,2BAA2B,CAAC,IAAI,CAAC,CAAC;IAClC,IAAI,CAAC,WAAW,CAAC,wBAAwB,CAAC,CAAC;IAC3C,IAAI,CAAC,cAAc,CAAC,yCAAyC,CAAC,CAAC;IAE/D,6BAA6B,CAAC,IAAI,CAAC,CAAC;IACpC,IAAI,CAAC,GAAG,iCAAiD,kBAAkB,CAAC,CAAC;IAE7E,MAAM,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;IAC1B,IAAI,CAAC,SAAS,CAAC,SAAS,eAAoB,CAAC,CAAC,kCAAkC;IAChF,IAAI,CAAC,SAAS,CAAC,WAAW,eAAoB,CAAC,CAAC,kCAAkC;IAClF,IAAI,CAAC,SAAS,CAAC,cAAc,kBAAuB,CAAC;IACrD,IAAI,MAAM,CAAC,QAAQ,CAAC,YAAY,CAAC,QAAQ;QACvC,IAAI,CAAC,cAAc,CAAC,qEAAqE,CAAC,CAAC;;QAE3F,IAAI,CAAC,cAAc,CAAC,sEAAsE,CAAC,CAAC;IAE9F,mBAAmB;IACnB,IAAI,CAAC,WAAW,CAAC,mBAAmB,CAAC,CAAC;IACtC,IAAI,CAAC,UAAU,CAAC,iBAAiB,gBAAqB,CAAC,IAAI,EAAE,EAAE;QAC7D,IAAI,CAAC,iBAAiB,CAAC,iBAAiB,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YAC5D,MAAM,IAAI,GAAG,aAAa,CAAC,MAAM,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,CAAC,SAAS,CAAC;YACtG,MAAM,GAAG,GAAG,SAAS,KAAK,IAAI,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC;YAC1E,OAAO,CAAC,aAAa,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QAClC,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,UAAU,CAAC,kBAAkB,gBAAqB,CAAC,IAAI,EAAE,EAAE;QAC9D,IAAI,CAAC,iBAAiB,CAAC,kBAAkB,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YAC7D,MAAM,IAAI,GAAG,aAAa,CAAC,MAAM,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,CAAC,SAAS,CAAC;YACtG,MAAM,GAAG,GAAG,SAAS,KAAK,IAAI,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC;YAC1E,OAAO,CAAC,aAAa,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;QAC1C,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,iBAAiB;IACjB,2BAA2B,CAAC,IAAI,CAAC,CAAC;IAClC,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC;IAC9B,IAAI,CAAC,WAAW,CAAC,iBAAiB,CAAC,CAAC;IACpC,IAAI,CAAC,UAAU,CAAC,aAAa,iBAAsB,CAAC,IAAI,EAAE,EAAE;QAC1D,IAAI,CAAC,iBAAiB,CAAC,aAAa,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YACxD,MAAM,IAAI,GAAG,MAAM,CAAC,QAAQ,CAAC,YAAY,CAAC;YAC1C,MAAM,SAAS,GAAG,SAAS,KAAK,IAAI,IAAI,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,CAAC,CAAC;YAClF,OAAO,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC;QAClC,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,SAAS,CAAC,kBAAkB,eAAoB,CAAC;IACtD,IAAI,CAAC,GAAG,0BAAwC,eAAe,CAAC,CAAC;IACjE,IAAI,CAAC,GAAG,6BAA2C,kBAAkB,CAAC,CAAC;IACvE,OAAO,CAAC,0BAA0B,CAAC,kBAAkB,gBAAqB,uBAAuB,EAAE,qBAAqB,CAAC,CAAC;AAC5H,CAAC;AAED,MAAM,sBAAsB,GAAG;;CAE9B,CAAC;AAEF,mIAAmI;AACnI,uHAAuH;AACvH,mIAAmI;AACnI,kJAAkJ;AAClJ,4FAA4F;AAC5F,MAAM,cAAc,GAAG;;;;;CAKtB,CAAC;AAEF,MAAM,uBAAuB,GAAG;;CAE/B,CAAC;AAEF,SAAS,YAAY,CAAC,SAAsB,EAAE,QAAoB,EAAE,UAAwB,EAAE,UAAsB,EAAE,SAAkB;IACtI,MAAM,OAAO,GAAG,YAAY,CAAC,gBAAgB,kBAAsB,gBAAoB,SAAS,CAAC,CAAC;IAClG,MAAM,OAAO,GAAG,IAAI,cAAc,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC,8BAAyC,CAAC,oBAA+B,CAAC,CAAC;IAClI,MAAM,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;IAE1B,IAAI,QAAQ;QACV,YAAY,CAAC,IAAI,EAAE,IAAI,EAAE,UAAU,CAAC,CAAC;IAEvC,IAAI,UAAU;QACZ,iBAAiB,CAAC,OAAO,CAAC,CAAC;IAE7B,mBAAmB,CAAC,IAAI,CAAC,CAAC;IAC1B,kBAAkB,CAAC,IAAI,CAAC,CAAC;IAEzB,IAAI,eAAe,CAAC;IACpB,IAAI,SAAS,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,kBAAkB,EAAE;QACpD,eAAe,GAAG,sBAAsB,GAAG,uBAAuB,CAAC;KACpE;SAAM;QACL,UAAU,CAAC,OAAO,CAAC,CAAC;QACpB,cAAc,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAC7B,uBAAuB,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QACtC,OAAO,CAAC,UAAU,CAAC,YAAY,eAAoB,CAAC;QACpD,eAAe,GAAG,sBAAsB,GAAG,cAAc,GAAG,uBAAuB,CAAC;KACrF;IAED,IAAI,CAAC,GAAG,0BAAwC,eAAe,CAAC,CAAC;IAEjE,OAAO,OAAO,CAAC;AACjB,CAAC;AAED,gBAAgB;AAChB,MAAM,UAAU,oBAAoB,CAAC,SAAsB,EAAE,UAAwB;IACnF,MAAM,OAAO,GAAG,YAAY,CAAC,SAAS,sCAAiD,IAAI,CAAC,CAAC;IAE7F,eAAe,CAAC,OAAO,EAAE,IAAI,EAAE,KAAK,CAAC,CAAC;IACtC,UAAU,CAAC,OAAO,yBAA+B,CAAC;IAClD,IAAI,UAAU,EAAE;QACd,yBAAyB,CAAC,OAAO,CAAC,CAAC;QACnC,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,yBAAyB,mBAAwB,OAAO,CAAC,CAAC;QACjF,OAAO,CAAC,IAAI,CAAC,GAAG,0BAAyC,eAAe,CAAC,CAAC;KAC3E;SAAM;QACL,iBAAiB,CAAC,OAAO,CAAC,CAAC;KAC5B;IAED,OAAO,OAAO,CAAC;AACjB,CAAC;AAED,MAAM,eAAe,GAAG;;CAEvB,CAAC;AACF,MAAM,gBAAgB,GAAG;;CAExB,CAAC;AAEF,gBAAgB;AAChB,SAAS,qBAAqB,CAAC,OAAsB;IACnD,OAAO,CAAC,WAAW,CAAC,6BAA6B,eAAoB,mBAA2B,QAAQ,EAAE,CAAC,CAAC;IAC5G,OAAO,CAAC,WAAW,CAAC,gCAAgC,eAAoB,sBAA8B,QAAQ,EAAE,CAAC,CAAC;IAClH,OAAO,CAAC,WAAW,CAAC,6BAA6B,eAAoB,mBAA2B,QAAQ,EAAE,CAAC,CAAC;IAC5G,OAAO,CAAC,WAAW,CAAC,iCAAiC,eAAoB,uBAA+B,QAAQ,EAAE,CAAC,CAAC;IACpH,OAAO,CAAC,WAAW,CAAC,wCAAwC,eAAoB,8BAAsC,QAAQ,EAAE,CAAC,CAAC;IAClI,OAAO,CAAC,WAAW,CAAC,iCAAiC,eAAoB,uBAA+B,QAAQ,EAAE,CAAC,CAAC;IACpH,OAAO,CAAC,WAAW,CAAC,oCAAoC,eAAoB,0BAAkC,QAAQ,EAAE,CAAC,CAAC;IAC1H,OAAO,CAAC,WAAW,CAAC,8BAA8B,eAAoB,oBAA4B,QAAQ,EAAE,CAAC,CAAC;IAC9G,OAAO,CAAC,WAAW,CAAC,8BAA8B,eAAoB,oBAA4B,QAAQ,EAAE,CAAC,CAAC;IAC9G,OAAO,CAAC,WAAW,CAAC,mCAAmC,eAAoB,yBAAiC,QAAQ,EAAE,CAAC,CAAC;IAExH,qHAAqH;IACrH,gGAAgG;IAChG,OAAO,CAAC,kBAAkB,CAAC,wBAAwB,qBAA6B,CAAC;IACjF,OAAO,CAAC,kBAAkB,CAAC,4BAA4B,yBAAiC,CAAC;IACzF,OAAO,CAAC,kBAAkB,CAAC,yBAAyB,sBAA8B,CAAC;IAEnF,sDAAsD;IACtD,MAAM,MAAM,GAAG,MAAM,CAAC,QAAQ,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC;IAClE,MAAM,IAAI,GAAG,MAAM,CAAC,QAAQ,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC,eAAmB,CAAC,cAAmB,CAAC;IAC5F,OAAO,CAAC,WAAW,CAAC,yBAAyB,EAAE,IAAI,EAAE,mBAAwB,QAAQ,EAAE,GAAG,MAAM,CAAC,CAAC;IAClG,OAAO,CAAC,WAAW,CAAC,6BAA6B,EAAE,IAAI,EAAE,uBAA4B,QAAQ,EAAE,GAAG,MAAM,CAAC,CAAC;IAC1G,OAAO,CAAC,WAAW,CAAC,0BAA0B,EAAE,IAAI,EAAE,sBAAyB,QAAQ,EAAE,GAAG,MAAM,CAAC,CAAC;IAEpG,gBAAgB,CAAC,OAAO,CAAC,CAAC;IAC1B,IAAI,MAAM,CAAC,QAAQ,CAAC,YAAY,CAAC,QAAQ,EAAE;QACzC,OAAO,CAAC,WAAW,CAAC,gBAAgB,CAAC,CAAC;QACtC,OAAO,CAAC,SAAS,CAAC,cAAc,gBAAoB,CAAC;KACtD;SAAM;QACL,OAAO,CAAC,WAAW,CAAC,eAAe,CAAC,CAAC;QACrC,OAAO,CAAC,SAAS,CAAC,cAAc,gBAAqB,CAAC;KACvD;AACH,CAAC;AAED,MAAM,gBAAgB,GAAG;;;;CAIxB,CAAC;AACF,MAAM,iBAAiB,GAAG;;;;CAIzB,CAAC;AAEF,MAAM,uBAAuB,GAAG;;;;;;;;;;CAU/B,CAAC;AAEF,yGAAyG;AACzG,MAAM,wBAAwB,GAAG;;;CAGhC,CAAC;AAEF,MAAM,kBAAkB,GAAG,0BAA0B,CAAC;AACtD,MAAM,mBAAmB,GAAG,iCAAiC,CAAC;AAE9D,MAAM,mBAAmB,GAAG,uBAAuB,CAAC;AACpD,MAAM,4BAA4B,GAAG,uBAAuB,GAAG,wBAAwB,CAAC;AAExF,gBAAgB;AAChB,MAAM,CAAC,MAAM,eAAe,GAAG;;;;;;;;;;;CAW9B,CAAC;AAEF,MAAM,aAAa,GAAG;;;;;;CAMrB,CAAC;AAEF,MAAM,qBAAqB,GAAG;;;EAG5B,aAAa,EAAE,CAAC;AAElB,MAAM,oBAAoB,GAAG;;CAE5B,CAAC;AAEF,MAAM,eAAe,GAAG;;;;;;CAMvB,CAAC;AACF,MAAM,uBAAuB,GAAG;;;EAG9B,eAAe,EAAE,CAAC;AACpB,MAAM,eAAe,GAAG;;CAEvB,CAAC;AAEF,+GAA+G;AAC/G,gHAAgH;AAChH,+GAA+G;AAC/G,mHAAmH;AACnH,MAAM,gBAAgB,GAAG;;;;;;;;;;;;;;;;CAgBxB,CAAC;AAEF,MAAM,gBAAgB,GAAG,IAAI,UAAU,gBAAuB,CAAC;AAE/D,gBAAgB;AAChB,MAAM,UAAU,eAAe,CAAC,OAAuB,EAAE,oBAA6B,EAAE,gBAAyB;IAC/G,qBAAqB,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IACpC,qBAAqB,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IAEpC,IAAI,OAAO,GAAG,CAAC,MAAM,CAAC,QAAQ,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC,CAAC,gBAAgB,CAAC,CAAC;IAC7F,IAAI,oBAAoB;QACtB,OAAO,IAAI,GAAG,gBAAgB,CAAC,CAAC,CAAC,4BAA4B,CAAC,CAAC,CAAC,mBAAmB,IAAI,CAAC;IAC1F,OAAO,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC,CAAC,mBAAmB,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC;IAC9F,OAAO,CAAC,0BAA0B,CAAC,gBAAgB,iBAAsB,qBAAqB,EAAE,OAAO,CAAC,CAAC;IAEzG,IAAI,MAAM,CAAC,QAAQ,CAAC,YAAY,CAAC,QAAQ;QACvC,OAAO,CAAC,IAAI,CAAC,cAAc,CAAC,mDAAmD,CAAC,CAAC;;QAEjF,OAAO,CAAC,IAAI,CAAC,cAAc,CAAC,6CAA6C,CAAC,CAAC;IAE7E,OAAO,CAAC,eAAe,CAAC,gBAAgB,mCAA+C,CAAC,IAAI,EAAE,EAAE;QAC9F,IAAI,CAAC,iBAAiB,CAAC,gBAAgB,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YAC3D,MAAM,CAAC,SAAS,KAAK,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;YAChD,MAAM,IAAI,GAAG,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC;YACvC,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,aAAa,EAAE,gBAAgB,CAAC,CAAC;YACjE,OAAO,CAAC,aAAa,CAAC,gBAAgB,CAAC,CAAC;QAC1C,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC;AAED,SAAS,SAAS,CAAC,OAAuB,EAAE,SAAsB,EAAE,QAAoB;IACtF,eAAe,CAAC,OAAO,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC;IAEzC,OAAO,CAAC,IAAI,CAAC,WAAW,CAAC,eAAe,CAAC,CAAC;IAC1C,6BAA6B,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IAC5C,OAAO,CAAC,0BAA0B,CAAC,KAAK,gBAAqB,uBAAuB,EAAE,QAAQ,CAAC,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC;IAExI,sEAAsE;IACtE,iIAAiI;IACjI,MAAM,YAAY,GAAG,KAAK,CAAC;IAC3B,IAAI,YAAY,EAAE;QAChB,OAAO,CAAC,IAAI,CAAC,GAAG,2BAA0C,uDAAuD,CAAC,CAAC;QACnH,OAAO,CAAC,0BAA0B,CAAC,UAAU,gBAAqB,oBAAoB,EAAE;;;;;;KAMvF,CAAC,CAAC;KACJ;AACH,CAAC;AAED,gBAAgB;AAChB,MAAM,UAAU,UAAU,CAAC,OAAuB,EAAE,QAAoB,EAAE,UAAsB,EAAE,YAAY,GAAG,KAAK;IACpH,IAAI,UAAU,EAAE;QACd,OAAO,CAAC,wBAAwB,CAAC,iBAAiB,iBAAsB,uBAAuB,CAAC,OAAO,CAAC,IAAI,CAAC,qBAAqB,EAAE,YAAY,EAAE,IAAI,CAAC,CAAC,CAAC;KAC1J;SAAM;QACL,OAAO,CAAC,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC;QACvC,6BAA6B,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAC5C,OAAO,CAAC,0BAA0B,CAAC,YAAY,gBAAqB,iBAAiB,EAAE,QAAQ,CAAC,CAAC,CAAC,uBAAuB,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC;QAC7I,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,mBAAmB,gBAAqB,CAAC,IAAI,EAAE,EAAE;YACvE,IAAI,CAAC,iBAAiB,CAAC,mBAAmB,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;gBAC9D,MAAM,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC,SAAU,CAAC;gBAC5C,IAAI,QAAQ,CAAC,UAAU,CAAC,MAAM,CAAC,aAAa,CAAC,EAAE;oBAC7C,MAAM,SAAS,GAAG,QAAQ,CAAC,GAAG,CAAC,SAAS,CAAC;oBACzC,IAAI,SAAS,KAAK,SAAS,EAAE;wBAC3B,OAAO,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC;qBAClC;iBACF;YACH,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;QACH,OAAO,CAAC,IAAI,CAAC,WAAW,CAAC,oBAAoB,CAAC,CAAC;KAChD;IAED,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,WAAW,qBAA0B,CAAC,IAAI,EAAE,EAAE;QACpE,IAAI,CAAC,iBAAiB,CAAC,WAAW,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YACtD,MAAM,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC,SAAU,CAAC;YAC5C,IAAI,MAAM,CAAC,QAAQ,CAAC,uBAAuB,IAAI,MAAM,CAAC,MAAM,CAAC,mBAAmB,EAAE,EAAE,wGAAwG;gBAC1L,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,QAAQ,CAAC,WAAW,CAAC,OAAO,EAAE,WAAW,CAAC,cAAc,CAAC,CAAC;aAClF;iBAAM,IAAI,QAAQ,CAAC,UAAU,CAAC,MAAM,CAAC,aAAa,CAAC,EAAE;gBACpD,MAAM,OAAO,GAAG,CAAC,MAAM,CAAC,QAAQ,CAAC,YAAY,IAAI,MAAM,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC,CAAC,CAAE,MAAM,CAAC,MAAM,CAAC,eAA2B,CAAC,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC;gBAChJ,MAAM,CAAC,SAAS,KAAK,OAAO,CAAC,CAAC;gBAC9B,OAAO,CAAC,OAAO,CAAC,WAAW,CAAC,OAAO,EAAE,WAAW,CAAC,cAAc,CAAC,CAAC;aAClE;iBAAM;gBACL,MAAM,CAAC,QAAQ,CAAC,kBAAkB,CAAC,OAAO,EAAE,WAAW,CAAC,cAAc,CAAC,CAAC;aACzE;QACH,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC;AAED,MAAM,CAAC,MAAM,wBAAwB,GAAG;;;;;;;;CAQvC,CAAC;AAEF,4JAA4J;AAC5J,qJAAqJ;AACrJ,+BAA+B;AAC/B,MAAM,uBAAuB,GAAG,0EAA0E,CAAC;AAE3G,gBAAgB;AAChB,MAAM,UAAU,oBAAoB,CAAC,KAAqB;IACxD,MAAM,OAAO,GAAG,YAAY,CAAC,KAAK,CAAC,WAAW,EAAE,KAAK,CAAC,UAAU,EAAE,KAAK,CAAC,YAAY,EAAE,KAAK,CAAC,UAAU,EAAE,KAAK,CAAC,CAAC;IAC/G,cAAc,CAAC,OAAO,CAAC,CAAC;IAExB,MAAM,IAAI,GAAG,KAAK,CAAC,WAAW,CAAC;IAC/B,IAAI,IAAI,GAAG,sBAA0B,IAAI,CAAC,CAAC,kBAAiC,CAAC,aAA6B,CAAC;IAC3G,IAAI,KAAK,CAAC,YAAY,EAAE;QACtB,IAAI,IAAI,eAA8B,CAAC;QACvC,wBAAwB,CAAC,OAAO,EAAE,KAAK,CAAC,aAAa,EAAE,KAAK,CAAC,UAAU,CAAC,CAAC;KAC1E;IAED,IAAI,KAAK,CAAC,UAAU,EAAE;QACpB,kBAAkB,CAAC,OAAO,CAAC,CAAC;KAC7B;IAED,mBAAmB,CAAC,OAAO,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;IACzC,eAAe,CAAC,OAAO,EAAE,sBAA0B,IAAI,EAAE,IAAI,CAAC,CAAC;IAC/D,iBAAiB,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;IAClC,SAAS,CAAC,OAAO,EAAE,KAAK,CAAC,WAAW,EAAE,KAAK,CAAC,UAAU,CAAC,CAAC;IAExD,wMAAwM;IACxM,6BAA6B,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IAC5C,OAAO,CAAC,IAAI,CAAC,GAAG,4BAA4C,oBAAoB,CAAC,CAAC;IAClF,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,WAAW,gBAAqB,CAAC,IAAI,EAAE,EAAE;QAC/D,IAAI,CAAC,iBAAiB,CAAC,WAAW,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YACtD,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAC;QAC1D,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,UAAU,CAAC,OAAO,EAAE,KAAK,CAAC,UAAU,EAAE,KAAK,CAAC,UAAU,CAAC,CAAC;IAExD,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,iBAAiB,mBAAwB,CAAC,IAAI,EAAE,EAAE;QACxE,IAAI,CAAC,iBAAiB,CAAC,iBAAiB,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YAC5D,MAAM,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC,SAAU,CAAC;YAC5C,OAAO,CAAC,YAAY,CAAC,QAAQ,CAAC,UAAU,CAAC,MAAM,CAAC,aAAa,CAAC,IAAI,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC9F,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,sBAAsB;IACtB,QAAQ,CAAC,OAAO,CAAC,CAAC;IAElB,WAAW;IACX,OAAO,CAAC,IAAI,CAAC,WAAW,CAAC,eAAe,CAAC,CAAC;IAC1C,WAAW,CAAC,OAAO,CAAC,CAAC;IACrB,uBAAuB,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IAEtC,IAAI,KAAK,CAAC,aAAa,EAAE;QACvB,eAAe,CAAC,OAAO,CAAC,CAAC;KAC1B;SAAM;QACL,IAAI,iBAAqB,IAAI,EAAE;YAC7B,kCAAkC,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;SAClD;aAAM;YACL,OAAO,CAAC,IAAI,CAAC,GAAG,yBAAyC,uBAAuB,CAAC,CAAC;YAClF,IAAI,CAAC,KAAK,CAAC,YAAY;gBACrB,0BAA0B,CAAC,OAAO,EAAE,KAAK,CAAC,UAAU,CAAC,CAAC;;gBAEtD,0BAA0B,CAAC,OAAO,CAAC,CAAC;YAEtC,OAAO,CAAC,IAAI,CAAC,WAAW,CAAC,cAAc,CAAC,CAAC;YACzC,IAAI,KAAK,CAAC,gBAAgB,IAAI,KAAK,CAAC,YAAY;gBAC9C,oBAAoB,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;;gBAEnC,uBAAuB,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;SACzC;KACF;IAED,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,gBAAgB,eAAoB,CAAC;IAC5D,OAAO,CAAC,IAAI,CAAC,GAAG,2BAA2C,CAAC,KAAK,CAAC,UAAU,eAAkB,CAAC,CAAC,CAAC,CAAC,gBAAgB,CAAC,CAAC,CAAC,2BAA2B,CAAC,CAAC;IAElJ,IAAI,KAAK,CAAC,YAAY;QACpB,oCAAoC,CAAC,OAAO,CAAC,CAAC;IAEhD,oBAAoB,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IACnC,WAAW,CAAC,OAAO,CAAC,CAAC;IAErB,IAAI,KAAK,CAAC,UAAU;QAClB,WAAW,CAAC,OAAO,CAAC,CAAC;IAEvB,OAAO,OAAO,CAAC;AACjB,CAAC;AAED,MAAM,UAAU,oCAAoC,CAAC,OAAuB;IAC1E,2LAA2L;IAC3L,+GAA+G;IAC/G,iMAAiM;IACjM,4GAA4G;IAC5G,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IAC1B,aAAa,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IAE5B,iFAAiF;IACjF,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,yBAAyB,mBAAwB,CAAC,IAAI,EAAE,EAAE;QAChF,IAAI,CAAC,iBAAiB,CAAC,yBAAyB,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YACpE,OAAO,CAAC,YAAY,CAAC,MAAM,CAAC,MAAM,CAAC,sBAAsB,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACrE,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,OAAO,CAAC,IAAI,CAAC,GAAG,yBAAyC,wBAAwB,CAAC,CAAC;AACrF,CAAC","sourcesContent":["/*---------------------------------------------------------------------------------------------\r\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\r\n* See LICENSE.md in the project root for license terms and full copyright notice.\r\n*--------------------------------------------------------------------------------------------*/\r\n/** @packageDocumentation\r\n * @module WebGL\r\n */\r\n\r\nimport { assert } from \"@itwin/core-bentley\";\r\nimport { AttributeMap } from \"../AttributeMap\";\r\nimport { Material } from \"../Material\";\r\nimport { SurfaceBitIndex, SurfaceFlags, TextureUnit } from \"../RenderFlags\";\r\nimport { FragmentShaderComponent, ProgramBuilder, ShaderBuilder, ShaderBuilderFlags, VariableType, VertexShaderComponent } from \"../ShaderBuilder\";\r\nimport { System } from \"../System\";\r\nimport { FeatureMode, IsAnimated, IsClassified, IsInstanced, IsShadowable, IsThematic, TechniqueFlags } from \"../TechniqueFlags\";\r\nimport { TechniqueId } from \"../TechniqueId\";\r\nimport { Texture } from \"../Texture\";\r\nimport { addAnimation } from \"./Animation\";\r\nimport { unpackFloat } from \"./Clipping\";\r\nimport { addColor } from \"./Color\";\r\nimport { addChooseWithBitFlagFunctions, addExtractNthBit, addFrustum, addShaderFlags } from \"./Common\";\r\nimport { addUnpackAndNormalize2Bytes, decodeDepthRgb, unquantize2d } from \"./Decode\";\r\nimport {\r\n addFeatureSymbology, addMaxAlpha, addRenderOrder, addRenderOrderConstants, addSurfaceDiscard, addSurfaceHiliter, FeatureSymbologyOptions,\r\n} from \"./FeatureSymbology\";\r\nimport {\r\n addAltPickBufferOutputs, addFragColorWithPreMultipliedAlpha, addPickBufferOutputs, addWhiteOnWhiteReversal, assignFragColor,\r\n} from \"./Fragment\";\r\nimport { addLighting } from \"./Lighting\";\r\nimport { addSurfaceMonochrome } from \"./Monochrome\";\r\nimport { addColorPlanarClassifier, addFeaturePlanarClassifier, addHilitePlanarClassifier, addOverrideClassifierColor } from \"./PlanarClassification\";\r\nimport { addRenderPass } from \"./RenderPass\";\r\nimport { addSolarShadowMap } from \"./SolarShadowMapping\";\r\nimport { addThematicDisplay, getComputeThematicIndex } from \"./Thematic\";\r\nimport { addTranslucency } from \"./Translucency\";\r\nimport { addFeatureAndMaterialLookup, addModelViewMatrix, addNormalMatrix, addProjectionMatrix } from \"./Vertex\";\r\nimport { wantMaterials } from \"../SurfaceGeometry\";\r\nimport { addWiremesh } from \"./Wiremesh\";\r\n\r\n// NB: Textures do not contain pre-multiplied alpha.\r\nconst sampleSurfaceTexture = `\r\nvec4 sampleSurfaceTexture() {\r\n return TEXTURE(s_texture, v_texCoord);\r\n}\r\n`;\r\n\r\nconst applyMaterialColor = `\r\n float useMatColor = float(use_material);\r\n vec3 rgb = mix(baseColor.rgb, mat_rgb.rgb, useMatColor * mat_rgb.a);\r\n float a = mix(baseColor.a, mat_alpha.x, useMatColor * mat_alpha.y);\r\n return vec4(rgb, a);\r\n`;\r\n\r\n// if this is a raster glyph, the sampled color has already been modified - do not modify further.\r\n// Mix diffuse color with texel based on texture weight.\r\n// Replace with diffuse RGB if RGB overridden.\r\n// Replace with diffuse alpha if alpha overridden.\r\n// Multiply texel alpha with diffuse alpha if specified.\r\nconst applyTextureWeight = `\r\n bool applyTexture = !u_applyGlyphTex && isSurfaceBitSet(kSurfaceBit_HasTexture);\r\n float textureWeight = applyTexture ? mat_texture_weight : 0.0;\r\n vec3 rgb = mix(baseColor.rgb, g_surfaceTexel.rgb, textureWeight);\r\n rgb = chooseVec3WithBitFlag(rgb, baseColor.rgb, surfaceFlags, kSurfaceBit_OverrideRgb);\r\n\r\n float a = applyTexture ? baseColor.a * g_surfaceTexel.a : baseColor.a;\r\n\r\n return vec4(rgb, a);\r\n`;\r\n\r\nconst decodeFragMaterialParams = `\r\nvoid decodeMaterialParams(vec4 params) {\r\n mat_weights = unpackAndNormalize2Bytes(params.x);\r\n\r\n vec2 texAndSpecR = unpackAndNormalize2Bytes(params.y);\r\n mat_texture_weight = texAndSpecR.x;\r\n\r\n vec2 specGB = unpackAndNormalize2Bytes(params.z);\r\n mat_specular = vec4(texAndSpecR.y, specGB, params.w);\r\n}\r\n`;\r\n\r\nconst decodeMaterialColor = `\r\nvoid decodeMaterialColor(vec4 rgba) {\r\n mat_rgb = vec4(rgba.rgb, float(rgba.r >= 0.0));\r\n mat_alpha = vec2(rgba.a, float(rgba.a >= 0.0));\r\n}\r\n`;\r\n\r\n// defaults: (0x6699, 0xffff, 0xffff, 13.5)\r\nconst computeMaterialParams = `\r\n const vec4 defaults = vec4(26265.0, 65535.0, 65535.0, 13.5);\r\n return use_material ? g_materialParams : defaults;\r\n`;\r\n\r\n// The 8-bit material index is stored with the 24-bit feature index, in the high byte.\r\nconst readMaterialAtlas = `\r\nvoid readMaterialAtlas() {\r\n float materialAtlasStart = u_vertParams.z * u_vertParams.w + u_numColors;\r\n float materialIndex = g_featureAndMaterialIndex.w * 4.0 + materialAtlasStart;\r\n\r\n vec2 tc = computeLUTCoords(materialIndex, u_vertParams.xy, g_vert_center, 1.0);\r\n vec4 rgba = TEXTURE(u_vertLUT, tc);\r\n\r\n tc = computeLUTCoords(materialIndex + 1.0, u_vertParams.xy, g_vert_center, 1.0);\r\n vec4 weightsAndFlags = floor(TEXTURE(u_vertLUT, tc) * 255.0 + 0.5);\r\n\r\n tc = computeLUTCoords(materialIndex + 2.0, u_vertParams.xy, g_vert_center, 1.0);\r\n vec3 specularRgb = floor(TEXTURE(u_vertLUT, tc) * 255.0 + 0.5).rgb;\r\n\r\n tc = computeLUTCoords(materialIndex + 3.0, u_vertParams.xy, g_vert_center, 1.0);\r\n vec4 packedSpecularExponent = TEXTURE(u_vertLUT, tc);\r\n\r\n float flags = weightsAndFlags.w;\r\n mat_rgb = vec4(rgba.rgb, float(flags == 1.0 || flags == 3.0));\r\n mat_alpha = vec2(rgba.a, float(flags == 2.0 || flags == 3.0));\r\n\r\n float specularExponent = unpackFloat(packedSpecularExponent);\r\n g_materialParams.x = weightsAndFlags.y + weightsAndFlags.z * 256.0;\r\n g_materialParams.y = 255.0 + specularRgb.r * 256.0;\r\n g_materialParams.z = specularRgb.g + specularRgb.b * 256.0;\r\n g_materialParams.w = specularExponent;\r\n}\r\n`;\r\n\r\nconst computeMaterial = `\r\n if (u_surfaceFlags[kSurfaceBitIndex_HasMaterialAtlas]) {\r\n readMaterialAtlas();\r\n } else {\r\n decodeMaterialColor(u_materialColor);\r\n g_materialParams = u_materialParams;\r\n }\r\n`;\r\n\r\nfunction addMaterial(builder: ProgramBuilder): void {\r\n const frag = builder.frag;\r\n assert(undefined !== frag.find(\"v_surfaceFlags\"));\r\n\r\n frag.addGlobal(\"mat_texture_weight\", VariableType.Float);\r\n frag.addGlobal(\"mat_weights\", VariableType.Vec2); // diffuse, specular\r\n frag.addGlobal(\"mat_specular\", VariableType.Vec4); // rgb, exponent\r\n\r\n addUnpackAndNormalize2Bytes(frag);\r\n frag.addFunction(decodeFragMaterialParams);\r\n frag.addInitializer(\"decodeMaterialParams(v_materialParams);\");\r\n\r\n addChooseWithBitFlagFunctions(frag);\r\n frag.set(FragmentShaderComponent.ApplyMaterialOverrides, applyTextureWeight);\r\n\r\n const vert = builder.vert;\r\n vert.addGlobal(\"mat_rgb\", VariableType.Vec4); // a = 0 if not overridden, else 1\r\n vert.addGlobal(\"mat_alpha\", VariableType.Vec2); // a = 0 if not overridden, else 1\r\n vert.addGlobal(\"use_material\", VariableType.Boolean);\r\n if (System.instance.capabilities.isWebGL2)\r\n vert.addInitializer(\"use_material = (0u == (surfaceFlags & kSurfaceBit_IgnoreMaterial));\");\r\n else\r\n vert.addInitializer(\"use_material = !nthBitSet(surfaceFlags, kSurfaceBit_IgnoreMaterial);\");\r\n\r\n // Uniform material\r\n vert.addFunction(decodeMaterialColor);\r\n vert.addUniform(\"u_materialColor\", VariableType.Vec4, (prog) => {\r\n prog.addGraphicUniform(\"u_materialColor\", (uniform, params) => {\r\n const info = wantMaterials(params.target.currentViewFlags) ? params.geometry.materialInfo : undefined;\r\n const mat = undefined !== info && !info.isAtlas ? info : Material.default;\r\n uniform.setUniform4fv(mat.rgba);\r\n });\r\n });\r\n\r\n vert.addUniform(\"u_materialParams\", VariableType.Vec4, (prog) => {\r\n prog.addGraphicUniform(\"u_materialParams\", (uniform, params) => {\r\n const info = wantMaterials(params.target.currentViewFlags) ? params.geometry.materialInfo : undefined;\r\n const mat = undefined !== info && !info.isAtlas ? info : Material.default;\r\n uniform.setUniform4fv(mat.fragUniforms);\r\n });\r\n });\r\n\r\n // Material atlas\r\n addFeatureAndMaterialLookup(vert);\r\n vert.addFunction(unpackFloat);\r\n vert.addFunction(readMaterialAtlas);\r\n vert.addUniform(\"u_numColors\", VariableType.Float, (prog) => {\r\n prog.addGraphicUniform(\"u_numColors\", (uniform, params) => {\r\n const info = params.geometry.materialInfo;\r\n const numColors = undefined !== info && info.isAtlas ? info.vertexTableOffset : 0;\r\n uniform.setUniform1f(numColors);\r\n });\r\n });\r\n\r\n vert.addGlobal(\"g_materialParams\", VariableType.Vec4);\r\n vert.set(VertexShaderComponent.ComputeMaterial, computeMaterial);\r\n vert.set(VertexShaderComponent.ApplyMaterialColor, applyMaterialColor);\r\n builder.addFunctionComputedVarying(\"v_materialParams\", VariableType.Vec4, \"computeMaterialParams\", computeMaterialParams);\r\n}\r\n\r\nconst computePositionPrelude = `\r\n vec4 pos = MAT_MV * rawPos;\r\n`;\r\n\r\n// We used to use gl.polygonOffset() for blanking regions, but that doesn't work with logarithmic depth buffer which overwrites the\r\n// computed Z. Instead we must manually offset in vertex shader. We do this even if log depth is not enabled/supported.\r\n// NOTE: If log depth is *not* supported, then the hilite surface vertex shaders previously would still include this logic, but the\r\n// fragment shaders would not use v_eyeSpace. Some Ubuntu 20.04 graphics drivers cleverly and correctly optimized out the varying and the uniform,\r\n// causing an exception when gl.getProgramLocation() failed. So, omit this bit in that case.\r\nconst adjustEyeSpace = `\r\n v_eyeSpace = pos.xyz;\r\n const float blankingRegionOffset = 2.0 / 65536.0;\r\n if (kRenderOrder_BlankingRegion == u_renderOrder)\r\n v_eyeSpace.z -= blankingRegionOffset * (u_frustum.y - u_frustum.x);\r\n`;\r\n\r\nconst computePositionPostlude = `\r\n return u_proj * pos;\r\n`;\r\n\r\nfunction createCommon(instanced: IsInstanced, animated: IsAnimated, shadowable: IsShadowable, isThematic: IsThematic, isHiliter: boolean): ProgramBuilder {\r\n const attrMap = AttributeMap.findAttributeMap(TechniqueId.Surface, IsInstanced.Yes === instanced);\r\n const builder = new ProgramBuilder(attrMap, instanced ? ShaderBuilderFlags.InstancedVertexTable : ShaderBuilderFlags.VertexTable);\r\n const vert = builder.vert;\r\n\r\n if (animated)\r\n addAnimation(vert, true, isThematic);\r\n\r\n if (shadowable)\r\n addSolarShadowMap(builder);\r\n\r\n addProjectionMatrix(vert);\r\n addModelViewMatrix(vert);\r\n\r\n let computePosition;\r\n if (isHiliter && !System.instance.supportsLogZBuffer) {\r\n computePosition = computePositionPrelude + computePositionPostlude;\r\n } else {\r\n addFrustum(builder);\r\n addRenderOrder(builder.vert);\r\n addRenderOrderConstants(builder.vert);\r\n builder.addVarying(\"v_eyeSpace\", VariableType.Vec3);\r\n computePosition = computePositionPrelude + adjustEyeSpace + computePositionPostlude;\r\n }\r\n\r\n vert.set(VertexShaderComponent.ComputePosition, computePosition);\r\n\r\n return builder;\r\n}\r\n\r\n/** @internal */\r\nexport function createSurfaceHiliter(instanced: IsInstanced, classified: IsClassified): ProgramBuilder {\r\n const builder = createCommon(instanced, IsAnimated.No, IsShadowable.No, IsThematic.No, true);\r\n\r\n addSurfaceFlags(builder, true, false);\r\n addTexture(builder, IsAnimated.No, IsThematic.No);\r\n if (classified) {\r\n addHilitePlanarClassifier(builder);\r\n builder.vert.addGlobal(\"feature_ignore_material\", VariableType.Boolean, \"false\");\r\n builder.frag.set(FragmentShaderComponent.AssignFragData, assignFragColor);\r\n } else {\r\n addSurfaceHiliter(builder);\r\n }\r\n\r\n return builder;\r\n}\r\n\r\nconst isSurfaceBitSet = `\r\nbool isSurfaceBitSet(float flag) { return nthBitSet(surfaceFlags, flag); }\r\n`;\r\nconst isSurfaceBitSet2 = `\r\nbool isSurfaceBitSet(uint flag) { return 0u != (surfaceFlags & flag); }\r\n`;\r\n\r\n/** @internal */\r\nfunction addSurfaceFlagsLookup(builder: ShaderBuilder) {\r\n builder.addConstant(\"kSurfaceBitIndex_HasTexture\", VariableType.Int, SurfaceBitIndex.HasTexture.toString());\r\n builder.addConstant(\"kSurfaceBitIndex_ApplyLighting\", VariableType.Int, SurfaceBitIndex.ApplyLighting.toString());\r\n builder.addConstant(\"kSurfaceBitIndex_HasNormals\", VariableType.Int, SurfaceBitIndex.HasNormals.toString());\r\n builder.addConstant(\"kSurfaceBitIndex_IgnoreMaterial\", VariableType.Int, SurfaceBitIndex.IgnoreMaterial.toString());\r\n builder.addConstant(\"kSurfaceBitIndex_TransparencyThreshold\", VariableType.Int, SurfaceBitIndex.TransparencyThreshold.toString());\r\n builder.addConstant(\"kSurfaceBitIndex_BackgroundFill\", VariableType.Int, SurfaceBitIndex.BackgroundFill.toString());\r\n builder.addConstant(\"kSurfaceBitIndex_HasColorAndNormal\", VariableType.Int, SurfaceBitIndex.HasColorAndNormal.toString());\r\n builder.addConstant(\"kSurfaceBitIndex_OverrideRgb\", VariableType.Int, SurfaceBitIndex.OverrideRgb.toString());\r\n builder.addConstant(\"kSurfaceBitIndex_NoFaceFront\", VariableType.Int, SurfaceBitIndex.NoFaceFront.toString());\r\n builder.addConstant(\"kSurfaceBitIndex_HasMaterialAtlas\", VariableType.Int, SurfaceBitIndex.HasMaterialAtlas.toString());\r\n\r\n // Surface flags which get modified in vertex shader are still passed to fragment shader as a single float & are thus\r\n // used differently there & so require different constants. Unused constants are commented out.\r\n builder.addBitFlagConstant(\"kSurfaceBit_HasTexture\", SurfaceBitIndex.HasTexture);\r\n builder.addBitFlagConstant(\"kSurfaceBit_IgnoreMaterial\", SurfaceBitIndex.IgnoreMaterial);\r\n builder.addBitFlagConstant(\"kSurfaceBit_OverrideRgb\", SurfaceBitIndex.OverrideRgb);\r\n\r\n // Only need masks for flags modified in vertex shader\r\n const suffix = System.instance.capabilities.isWebGL2 ? \"u\" : \".0\";\r\n const type = System.instance.capabilities.isWebGL2 ? VariableType.Uint : VariableType.Float;\r\n builder.addConstant(\"kSurfaceMask_HasTexture\", type, SurfaceFlags.HasTexture.toString() + suffix);\r\n builder.addConstant(\"kSurfaceMask_IgnoreMaterial\", type, SurfaceFlags.IgnoreMaterial.toString() + suffix);\r\n builder.addConstant(\"kSurfaceMask_OverrideRgb\", type, SurfaceFlags.OverrideRgb.toString() + suffix);\r\n\r\n addExtractNthBit(builder);\r\n if (System.instance.capabilities.isWebGL2) {\r\n builder.addFunction(isSurfaceBitSet2);\r\n builder.addGlobal(\"surfaceFlags\", VariableType.Uint);\r\n } else {\r\n builder.addFunction(isSurfaceBitSet);\r\n builder.addGlobal(\"surfaceFlags\", VariableType.Float);\r\n }\r\n}\r\n\r\nconst initSurfaceFlags = `\r\n surfaceFlags = u_surfaceFlags[kSurfaceBitIndex_HasTexture] ? kSurfaceMask_HasTexture : 0.0;\r\n surfaceFlags += u_surfaceFlags[kSurfaceBitIndex_IgnoreMaterial] ? kSurfaceMask_IgnoreMaterial : 0.0;\r\n surfaceFlags += u_surfaceFlags[kSurfaceBitIndex_OverrideRgb] ? kSurfaceMask_OverrideRgb : 0.0;\r\n`;\r\nconst initSurfaceFlags2 = `\r\n surfaceFlags = u_surfaceFlags[kSurfaceBitIndex_HasTexture] ? kSurfaceMask_HasTexture : 0u;\r\n surfaceFlags += u_surfaceFlags[kSurfaceBitIndex_IgnoreMaterial] ? kSurfaceMask_IgnoreMaterial : 0u;\r\n surfaceFlags += u_surfaceFlags[kSurfaceBitIndex_OverrideRgb] ? kSurfaceMask_OverrideRgb : 0u;\r\n`;\r\n\r\nconst computeBaseSurfaceFlags = `\r\n bool hasTexture = u_surfaceFlags[kSurfaceBitIndex_HasTexture];\r\n if (feature_ignore_material) {\r\n if (hasTexture) {\r\n hasTexture = false;\r\n surfaceFlags -= kSurfaceMask_HasTexture;\r\n }\r\n\r\n surfaceFlags += kSurfaceMask_IgnoreMaterial;\r\n }\r\n`;\r\n\r\n// Textured surfaces (including raster glyphs) always *multiply* the sampled alpha by the alpha override.\r\nconst computeColorSurfaceFlags = `\r\n if (feature_rgb.r >= 0.0)\r\n surfaceFlags += kSurfaceMask_OverrideRgb;\r\n`;\r\n\r\nconst returnSurfaceFlags = \" return surfaceFlags;\\n\";\r\nconst returnSurfaceFlags2 = \" return float(surfaceFlags);\\n\";\r\n\r\nconst computeSurfaceFlags = computeBaseSurfaceFlags;\r\nconst computeSurfaceFlagsWithColor = computeBaseSurfaceFlags + computeColorSurfaceFlags;\r\n\r\n/** @internal */\r\nexport const octDecodeNormal = `\r\nvec3 octDecodeNormal(vec2 e) {\r\n e = e / 255.0 * 2.0 - 1.0;\r\n vec3 n = vec3(e.x, e.y, 1.0 - abs(e.x) - abs(e.y));\r\n if (n.z < 0.0) {\r\n vec2 signNotZero = vec2(n.x >= 0.0 ? 1.0 : -1.0, n.y >= 0.0 ? 1.0 : -1.0);\r\n n.xy = (1.0 - abs(n.yx)) * signNotZero;\r\n }\r\n\r\n return normalize(n);\r\n}\r\n`;\r\n\r\nconst computeNormal = `\r\n vec2 tc = g_vertexBaseCoords;\r\n tc.x += 3.0 * g_vert_stepX;\r\n vec4 enc = floor(TEXTURE(u_vertLUT, tc) * 255.0 + 0.5);\r\n vec2 normal = u_surfaceFlags[kSurfaceBitIndex_HasColorAndNormal] ? enc.xy : g_vertexData2;\r\n return u_surfaceFlags[kSurfaceBitIndex_HasNormals] ? normalize(MAT_NORM * octDecodeNormal(normal)) : vec3(0.0);\r\n`;\r\n\r\nconst computeAnimatedNormal = `\r\n if (u_animNormalParams.x >= 0.0)\r\n return normalize(MAT_NORM * computeAnimationNormal(u_animNormalParams.x, u_animNormalParams.y, u_animNormalParams.z));\r\n${computeNormal}`;\r\n\r\nconst applyBackgroundColor = `\r\n return u_surfaceFlags[kSurfaceBitIndex_BackgroundFill] ? vec4(u_bgColor.rgb, baseColor.a) : baseColor;\r\n`;\r\n\r\nconst computeTexCoord = `\r\n vec2 tc = g_vertexBaseCoords;\r\n tc.x += 3.0 * g_vert_stepX;\r\n vec4 rgba = floor(TEXTURE(u_vertLUT, tc) * 255.0 + 0.5);\r\n vec2 qcoords = vec2(decodeUInt16(rgba.xy), decodeUInt16(rgba.zw));\r\n return chooseVec2WithBitFlag(vec2(0.0), unquantize2d(qcoords, u_qTexCoordParams), surfaceFlags, kSurfaceBit_HasTexture);\r\n`;\r\nconst computeAnimatedTexCoord = `\r\n if (u_animScalarQParams.x >= 0.0)\r\n return computeAnimationParam(u_animScalarParams.x, u_animScalarParams.y, u_animScalarParams.z, u_animScalarQParams.x, u_animScalarQParams.y);\r\n${computeTexCoord}`;\r\nconst getSurfaceColor = `\r\nvec4 getSurfaceColor() { return v_color; }\r\n`;\r\n\r\n// If we have texture weight < 1.0 we must compute the element/material color first then mix with texture color\r\n// in ApplyMaterialOverrides(). Do the sample once, here, and store in a global variable for possible later use.\r\n// If a glyph texture, must mix getSurfaceColor() with texture color so texture color alpha is applied 100% and\r\n// surface color rgb is scaled by texture color rgb (latter is full white originally but stretched via mipmapping).\r\nconst computeBaseColor = `\r\n g_surfaceTexel = sampleSurfaceTexture();\r\n vec4 surfaceColor = getSurfaceColor();\r\n\r\n if (!u_applyGlyphTex)\r\n return surfaceColor;\r\n\r\n // Compute color for raster glyph.\r\n const vec3 white = vec3(1.0);\r\n const vec3 epsilon = vec3(0.0001);\r\n const vec3 almostWhite = white - epsilon;\r\n\r\n // set to black if almost white and reverse white-on-white is on\r\n bvec3 isAlmostWhite = greaterThan(surfaceColor.rgb, almostWhite);\r\n surfaceColor.rgb = (u_reverseWhiteOnWhite && isAlmostWhite.r && isAlmostWhite.g && isAlmostWhite.b ? vec3(0.0, 0.0, 0.0) : surfaceColor.rgb);\r\n return vec4(surfaceColor.rgb * g_surfaceTexel.rgb, g_surfaceTexel.a);\r\n`;\r\n\r\nconst surfaceFlagArray = new Int32Array(SurfaceBitIndex.Count);\r\n\r\n/** @internal */\r\nexport function addSurfaceFlags(builder: ProgramBuilder, withFeatureOverrides: boolean, withFeatureColor: boolean) {\r\n addSurfaceFlagsLookup(builder.vert);\r\n addSurfaceFlagsLookup(builder.frag);\r\n\r\n let compute = (System.instance.capabilities.isWebGL2 ? initSurfaceFlags2 : initSurfaceFlags);\r\n if (withFeatureOverrides)\r\n compute += `${withFeatureColor ? computeSurfaceFlagsWithColor : computeSurfaceFlags}\\n`;\r\n compute += (System.instance.capabilities.isWebGL2 ? returnSurfaceFlags2 : returnSurfaceFlags);\r\n builder.addFunctionComputedVarying(\"v_surfaceFlags\", VariableType.Float, \"computeSurfaceFlags\", compute);\r\n\r\n if (System.instance.capabilities.isWebGL2)\r\n builder.frag.addInitializer(\"surfaceFlags = uint(floor(v_surfaceFlags + 0.5));\");\r\n else\r\n builder.frag.addInitializer(\"surfaceFlags = floor(v_surfaceFlags + 0.5);\");\r\n\r\n builder.addUniformArray(\"u_surfaceFlags\", VariableType.Boolean, SurfaceBitIndex.Count, (prog) => {\r\n prog.addGraphicUniform(\"u_surfaceFlags\", (uniform, params) => {\r\n assert(undefined !== params.geometry.asSurface);\r\n const mesh = params.geometry.asSurface;\r\n mesh.computeSurfaceFlags(params.programParams, surfaceFlagArray);\r\n uniform.setUniform1iv(surfaceFlagArray);\r\n });\r\n });\r\n}\r\n\r\nfunction addNormal(builder: ProgramBuilder, instanced: IsInstanced, animated: IsAnimated) {\r\n addNormalMatrix(builder.vert, instanced);\r\n\r\n builder.vert.addFunction(octDecodeNormal);\r\n addChooseWithBitFlagFunctions(builder.vert);\r\n builder.addFunctionComputedVarying(\"v_n\", VariableType.Vec3, \"computeLightingNormal\", animated ? computeAnimatedNormal : computeNormal);\r\n\r\n // Set to true to colorize surfaces based on normals (in world space).\r\n // You must also set checkMaxVarying to false in ProgramBuilder.buildProgram to avoid assertions, if using a non-optimized build.\r\n const debugNormals = false;\r\n if (debugNormals) {\r\n builder.frag.set(FragmentShaderComponent.ApplyDebugColor, \"return vec4(vec3(v_normal / 2.0 + 0.5), baseColor.a);\");\r\n builder.addFunctionComputedVarying(\"v_normal\", VariableType.Vec3, \"computeDebugNormal\", `\r\n vec2 tc = g_vertexBaseCoords;\r\n tc.x += 3.0 * g_vert_stepX;\r\n vec4 enc = floor(TEXTURE(u_vertLUT, tc) * 255.0 + 0.5);\r\n vec2 normal = u_surfaceFlags[kSurfaceBitIndex_HasColorAndNormal] ? enc.xy : g_vertexData2;\r\n return u_surfaceFlags[kSurfaceBitIndex_HasNormals] ? normalize(octDecodeNormal(normal)) : vec3(0.0);\r\n `);\r\n }\r\n}\r\n\r\n/** @internal */\r\nexport function addTexture(builder: ProgramBuilder, animated: IsAnimated, isThematic: IsThematic, isPointCloud = false) {\r\n if (isThematic) {\r\n builder.addInlineComputedVarying(\"v_thematicIndex\", VariableType.Float, getComputeThematicIndex(builder.vert.usesInstancedGeometry, isPointCloud, true));\r\n } else {\r\n builder.vert.addFunction(unquantize2d);\r\n addChooseWithBitFlagFunctions(builder.vert);\r\n builder.addFunctionComputedVarying(\"v_texCoord\", VariableType.Vec2, \"computeTexCoord\", animated ? computeAnimatedTexCoord : computeTexCoord);\r\n builder.vert.addUniform(\"u_qTexCoordParams\", VariableType.Vec4, (prog) => {\r\n prog.addGraphicUniform(\"u_qTexCoordParams\", (uniform, params) => {\r\n const surfGeom = params.geometry.asSurface!;\r\n if (surfGeom.useTexture(params.programParams)) {\r\n const uvQParams = surfGeom.lut.uvQParams;\r\n if (undefined !== uvQParams) {\r\n uniform.setUniform4fv(uvQParams);\r\n }\r\n }\r\n });\r\n });\r\n builder.frag.addFunction(sampleSurfaceTexture);\r\n }\r\n\r\n builder.frag.addUniform(\"s_texture\", VariableType.Sampler2D, (prog) => {\r\n prog.addGraphicUniform(\"s_texture\", (uniform, params) => {\r\n const surfGeom = params.geometry.asSurface!;\r\n if (params.geometry.supportsThematicDisplay && params.target.wantThematicDisplay) { // NB: if thematic display is enabled, bind the thematic texture and ignore any applied surface textures\r\n params.target.uniforms.thematic.bindTexture(uniform, TextureUnit.SurfaceTexture);\r\n } else if (surfGeom.useTexture(params.programParams)) {\r\n const texture = (params.geometry.hasAnimation && params.target.analysisTexture) ? (params.target.analysisTexture as Texture) : surfGeom.texture;\r\n assert(undefined !== texture);\r\n texture.texture.bindSampler(uniform, TextureUnit.SurfaceTexture);\r\n } else {\r\n System.instance.ensureSamplerBound(uniform, TextureUnit.SurfaceTexture);\r\n }\r\n });\r\n });\r\n}\r\n\r\nexport const discardClassifiedByAlpha = `\r\n if (u_no_classifier_discard)\r\n return false;\r\n\r\n bool hasAlpha = alpha <= s_maxAlpha;\r\n bool isOpaquePass = (kRenderPass_OpaqueLinear <= u_renderPass && kRenderPass_OpaqueGeneral >= u_renderPass);\r\n bool isTranslucentPass = kRenderPass_Translucent == u_renderPass;\r\n return (isOpaquePass && hasAlpha) || (isTranslucentPass && !hasAlpha);\r\n`;\r\n\r\n// Target.readPixels() renders everything in opaque pass. It turns off textures for normal surfaces but keeps them for things like 3d view attachment tiles.\r\n// We want to discard fully-transparent pixels of those things during readPixels() so that we don't locate the attachment unless the cursor is over a\r\n// non-transparent pixel of it.\r\nconst discardTransparentTexel = `return isSurfaceBitSet(kSurfaceBit_HasTexture) && alpha < (1.0 / 255.0);`;\r\n\r\n/** @internal */\r\nexport function createSurfaceBuilder(flags: TechniqueFlags): ProgramBuilder {\r\n const builder = createCommon(flags.isInstanced, flags.isAnimated, flags.isShadowable, flags.isThematic, false);\r\n addShaderFlags(builder);\r\n\r\n const feat = flags.featureMode;\r\n let opts = FeatureMode.Overrides === feat ? FeatureSymbologyOptions.Surface : FeatureSymbologyOptions.None;\r\n if (flags.isClassified) {\r\n opts &= ~FeatureSymbologyOptions.Alpha;\r\n addColorPlanarClassifier(builder, flags.isTranslucent, flags.isThematic);\r\n }\r\n\r\n if (flags.isThematic) {\r\n addThematicDisplay(builder);\r\n }\r\n\r\n addFeatureSymbology(builder, feat, opts);\r\n addSurfaceFlags(builder, FeatureMode.Overrides === feat, true);\r\n addSurfaceDiscard(builder, flags);\r\n addNormal(builder, flags.isInstanced, flags.isAnimated);\r\n\r\n // In HiddenLine mode, we must compute the base color (plus feature overrides etc) in order to get the alpha, then replace with background color (preserving alpha for the transparency threshold test).\r\n addChooseWithBitFlagFunctions(builder.frag);\r\n builder.frag.set(FragmentShaderComponent.FinalizeBaseColor, applyBackgroundColor);\r\n builder.frag.addUniform(\"u_bgColor\", VariableType.Vec3, (prog) => {\r\n prog.addProgramUniform(\"u_bgColor\", (uniform, params) => {\r\n params.target.uniforms.style.bindBackgroundRgb(uniform);\r\n });\r\n });\r\n\r\n addTexture(builder, flags.isAnimated, flags.isThematic);\r\n\r\n builder.frag.addUniform(\"u_applyGlyphTex\", VariableType.Boolean, (prog) => {\r\n prog.addGraphicUniform(\"u_applyGlyphTex\", (uniform, params) => {\r\n const surfGeom = params.geometry.asSurface!;\r\n uniform.setUniform1i(surfGeom.useTexture(params.programParams) && surfGeom.isGlyph ? 1 : 0);\r\n });\r\n });\r\n\r\n // Fragment and Vertex\r\n addColor(builder);\r\n\r\n // Fragment\r\n builder.frag.addFunction(getSurfaceColor);\r\n addLighting(builder);\r\n addWhiteOnWhiteReversal(builder.frag);\r\n\r\n if (flags.isTranslucent) {\r\n addTranslucency(builder);\r\n } else {\r\n if (FeatureMode.None === feat) {\r\n addFragColorWithPreMultipliedAlpha(builder.frag);\r\n } else {\r\n builder.frag.set(FragmentShaderComponent.DiscardByAlpha, discardTransparentTexel);\r\n if (!flags.isClassified)\r\n addOverrideClassifierColor(builder, flags.isThematic);\r\n else\r\n addFeaturePlanarClassifier(builder);\r\n\r\n builder.frag.addFunction(decodeDepthRgb);\r\n if (flags.isEdgeTestNeeded || flags.isClassified)\r\n addPickBufferOutputs(builder.frag);\r\n else\r\n addAltPickBufferOutputs(builder.frag);\r\n }\r\n }\r\n\r\n builder.frag.addGlobal(\"g_surfaceTexel\", VariableType.Vec4);\r\n builder.frag.set(FragmentShaderComponent.ComputeBaseColor, (flags.isThematic === IsThematic.No) ? computeBaseColor : \"return getSurfaceColor();\");\r\n\r\n if (flags.isClassified)\r\n addClassificationTranslucencyDiscard(builder);\r\n\r\n addSurfaceMonochrome(builder.frag);\r\n addMaterial(builder);\r\n\r\n if (flags.isWiremesh)\r\n addWiremesh(builder);\r\n\r\n return builder;\r\n}\r\n\r\nexport function addClassificationTranslucencyDiscard(builder: ProgramBuilder) {\r\n // For unclassified geometry, we need to render in both the translucent and opaque passes if any feature transparency overrides are applied that would change the default render pass used.\r\n // Those shaders compute the transparency in the vertex shader and discard the vertex in one pass or the other.\r\n // For classified geometry, the transparency comes from the classifier geometry (when using Display.ElementColor), so even if there are no feature overrides, we may need to draw in both passes.\r\n // Since the transparency is not known until the fragment shader, we must perform the discard there instead.\r\n addMaxAlpha(builder.frag);\r\n addRenderPass(builder.frag);\r\n\r\n // Do not discard transparent classified geometry if we're trying to do a pick...\r\n builder.frag.addUniform(\"u_no_classifier_discard\", VariableType.Boolean, (prog) => {\r\n prog.addProgramUniform(\"u_no_classifier_discard\", (uniform, params) => {\r\n uniform.setUniform1i(params.target.isReadPixelsInProgress ? 1 : 0);\r\n });\r\n });\r\n\r\n builder.frag.set(FragmentShaderComponent.DiscardByAlpha, discardClassifiedByAlpha);\r\n}\r\n"]}
|
|
@@ -7,10 +7,14 @@ export * from "./render/primitives/mesh/MeshBuilderMap";
|
|
|
7
7
|
export * from "./render/primitives/mesh/MeshPrimitives";
|
|
8
8
|
export * from "./render/primitives/ColorMap";
|
|
9
9
|
export * from "./render/primitives/DisplayParams";
|
|
10
|
+
export * from "./render/primitives/EdgeParams";
|
|
10
11
|
export * from "./render/primitives/PointCloudPrimitive";
|
|
12
|
+
export * from "./render/primitives/PointStringParams";
|
|
13
|
+
export * from "./render/primitives/Polyface";
|
|
14
|
+
export * from "./render/primitives/PolylineParams";
|
|
11
15
|
export * from "./render/primitives/Primitives";
|
|
12
16
|
export * from "./render/primitives/Strokes";
|
|
13
|
-
export * from "./render/primitives/
|
|
17
|
+
export * from "./render/primitives/SurfaceParams";
|
|
14
18
|
export * from "./render/primitives/VertexKey";
|
|
15
19
|
export * from "./render/primitives/VertexTable";
|
|
16
20
|
//# sourceMappingURL=render-primitives.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"render-primitives.d.ts","sourceRoot":"","sources":["../../src/render-primitives.ts"],"names":[],"mappings":"AAIA,cAAc,iDAAiD,CAAC;AAChE,cAAc,2CAA2C,CAAC;AAC1D,cAAc,kDAAkD,CAAC;AACjE,cAAc,kDAAkD,CAAC;AAEjE,cAAc,sCAAsC,CAAC;AACrD,cAAc,yCAAyC,CAAC;AACxD,cAAc,yCAAyC,CAAC;AAExD,cAAc,8BAA8B,CAAC;AAC7C,cAAc,mCAAmC,CAAC;AAClD,cAAc,yCAAyC,CAAC;AACxD,cAAc,gCAAgC,CAAC;AAC/C,cAAc,6BAA6B,CAAC;AAC5C,cAAc,
|
|
1
|
+
{"version":3,"file":"render-primitives.d.ts","sourceRoot":"","sources":["../../src/render-primitives.ts"],"names":[],"mappings":"AAIA,cAAc,iDAAiD,CAAC;AAChE,cAAc,2CAA2C,CAAC;AAC1D,cAAc,kDAAkD,CAAC;AACjE,cAAc,kDAAkD,CAAC;AAEjE,cAAc,sCAAsC,CAAC;AACrD,cAAc,yCAAyC,CAAC;AACxD,cAAc,yCAAyC,CAAC;AAExD,cAAc,8BAA8B,CAAC;AAC7C,cAAc,mCAAmC,CAAC;AAClD,cAAc,gCAAgC,CAAC;AAC/C,cAAc,yCAAyC,CAAC;AACxD,cAAc,uCAAuC,CAAC;AACtD,cAAc,8BAA8B,CAAC;AAC7C,cAAc,oCAAoC,CAAC;AACnD,cAAc,gCAAgC,CAAC;AAC/C,cAAc,6BAA6B,CAAC;AAC5C,cAAc,mCAAmC,CAAC;AAClD,cAAc,+BAA+B,CAAC;AAC9C,cAAc,iCAAiC,CAAC"}
|