@itwin/core-frontend 3.0.0-dev.152 → 3.0.0-dev.153

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.
Files changed (253) hide show
  1. package/lib/cjs/Marker.d.ts +9 -2
  2. package/lib/cjs/Marker.d.ts.map +1 -1
  3. package/lib/cjs/Marker.js +33 -5
  4. package/lib/cjs/Marker.js.map +1 -1
  5. package/lib/cjs/RealityDataSource.js +1 -12
  6. package/lib/cjs/RealityDataSource.js.map +1 -1
  7. package/lib/cjs/render/RenderMemory.d.ts +21 -15
  8. package/lib/cjs/render/RenderMemory.d.ts.map +1 -1
  9. package/lib/cjs/render/RenderMemory.js +21 -15
  10. package/lib/cjs/render/RenderMemory.js.map +1 -1
  11. package/lib/cjs/render/RenderSystem.d.ts +2 -0
  12. package/lib/cjs/render/RenderSystem.d.ts.map +1 -1
  13. package/lib/cjs/render/RenderSystem.js +2 -0
  14. package/lib/cjs/render/RenderSystem.js.map +1 -1
  15. package/lib/cjs/render/primitives/EdgeParams.d.ts +35 -1
  16. package/lib/cjs/render/primitives/EdgeParams.d.ts.map +1 -1
  17. package/lib/cjs/render/primitives/EdgeParams.js +114 -10
  18. package/lib/cjs/render/primitives/EdgeParams.js.map +1 -1
  19. package/lib/cjs/render/primitives/VertexTable.d.ts +1 -0
  20. package/lib/cjs/render/primitives/VertexTable.d.ts.map +1 -1
  21. package/lib/cjs/render/primitives/VertexTable.js +6 -1
  22. package/lib/cjs/render/primitives/VertexTable.js.map +1 -1
  23. package/lib/cjs/render/webgl/AttributeMap.js +5 -5
  24. package/lib/cjs/render/webgl/CachedGeometry.d.ts +2 -0
  25. package/lib/cjs/render/webgl/CachedGeometry.d.ts.map +1 -1
  26. package/lib/cjs/render/webgl/CachedGeometry.js +14 -13
  27. package/lib/cjs/render/webgl/CachedGeometry.js.map +1 -1
  28. package/lib/cjs/render/webgl/DrawCommand.js +2 -2
  29. package/lib/cjs/render/webgl/IndexedEdgeGeometry.d.ts +51 -0
  30. package/lib/cjs/render/webgl/IndexedEdgeGeometry.d.ts.map +1 -0
  31. package/lib/cjs/render/webgl/IndexedEdgeGeometry.js +90 -0
  32. package/lib/cjs/render/webgl/IndexedEdgeGeometry.js.map +1 -0
  33. package/lib/cjs/render/webgl/InstancedGeometry.d.ts +1 -0
  34. package/lib/cjs/render/webgl/InstancedGeometry.d.ts.map +1 -1
  35. package/lib/cjs/render/webgl/InstancedGeometry.js +1 -0
  36. package/lib/cjs/render/webgl/InstancedGeometry.js.map +1 -1
  37. package/lib/cjs/render/webgl/Mesh.d.ts +2 -0
  38. package/lib/cjs/render/webgl/Mesh.d.ts.map +1 -1
  39. package/lib/cjs/render/webgl/Mesh.js +7 -1
  40. package/lib/cjs/render/webgl/Mesh.js.map +1 -1
  41. package/lib/cjs/render/webgl/PlanarClassifier.js +1 -1
  42. package/lib/cjs/render/webgl/PlanarGrid.js +2 -2
  43. package/lib/cjs/render/webgl/RealityMesh.js +5 -5
  44. package/lib/cjs/render/webgl/RealityMesh.js.map +1 -1
  45. package/lib/cjs/render/webgl/RenderFlags.d.ts +4 -1
  46. package/lib/cjs/render/webgl/RenderFlags.d.ts.map +1 -1
  47. package/lib/cjs/render/webgl/RenderFlags.js +6 -1
  48. package/lib/cjs/render/webgl/RenderFlags.js.map +1 -1
  49. package/lib/cjs/render/webgl/SceneCompositor.js +6 -6
  50. package/lib/cjs/render/webgl/ScreenSpaceEffect.js +1 -1
  51. package/lib/cjs/render/webgl/ShaderBuilder.d.ts +16 -14
  52. package/lib/cjs/render/webgl/ShaderBuilder.d.ts.map +1 -1
  53. package/lib/cjs/render/webgl/ShaderBuilder.js +19 -15
  54. package/lib/cjs/render/webgl/ShaderBuilder.js.map +1 -1
  55. package/lib/cjs/render/webgl/System.d.ts +2 -0
  56. package/lib/cjs/render/webgl/System.d.ts.map +1 -1
  57. package/lib/cjs/render/webgl/System.js +2 -0
  58. package/lib/cjs/render/webgl/System.js.map +1 -1
  59. package/lib/cjs/render/webgl/Target.js +1 -1
  60. package/lib/cjs/render/webgl/Technique.d.ts.map +1 -1
  61. package/lib/cjs/render/webgl/Technique.js +72 -57
  62. package/lib/cjs/render/webgl/Technique.js.map +1 -1
  63. package/lib/cjs/render/webgl/TechniqueId.d.ts +29 -28
  64. package/lib/cjs/render/webgl/TechniqueId.d.ts.map +1 -1
  65. package/lib/cjs/render/webgl/TechniqueId.js +7 -7
  66. package/lib/cjs/render/webgl/TechniqueId.js.map +1 -1
  67. package/lib/cjs/render/webgl/glsl/Animation.js +1 -1
  68. package/lib/cjs/render/webgl/glsl/Color.js +1 -1
  69. package/lib/cjs/render/webgl/glsl/CopyStencil.d.ts.map +1 -1
  70. package/lib/cjs/render/webgl/glsl/CopyStencil.js +4 -7
  71. package/lib/cjs/render/webgl/glsl/CopyStencil.js.map +1 -1
  72. package/lib/cjs/render/webgl/glsl/EVSMFromDepth.js +1 -1
  73. package/lib/cjs/render/webgl/glsl/EVSMFromDepth.js.map +1 -1
  74. package/lib/cjs/render/webgl/glsl/Edge.d.ts +2 -1
  75. package/lib/cjs/render/webgl/glsl/Edge.d.ts.map +1 -1
  76. package/lib/cjs/render/webgl/glsl/Edge.js +132 -14
  77. package/lib/cjs/render/webgl/glsl/Edge.js.map +1 -1
  78. package/lib/cjs/render/webgl/glsl/FeatureSymbology.d.ts.map +1 -1
  79. package/lib/cjs/render/webgl/glsl/FeatureSymbology.js +13 -10
  80. package/lib/cjs/render/webgl/glsl/FeatureSymbology.js.map +1 -1
  81. package/lib/cjs/render/webgl/glsl/Fragment.d.ts.map +1 -1
  82. package/lib/cjs/render/webgl/glsl/Fragment.js +9 -1
  83. package/lib/cjs/render/webgl/glsl/Fragment.js.map +1 -1
  84. package/lib/cjs/render/webgl/glsl/LookupTable.d.ts +4 -2
  85. package/lib/cjs/render/webgl/glsl/LookupTable.d.ts.map +1 -1
  86. package/lib/cjs/render/webgl/glsl/LookupTable.js +7 -3
  87. package/lib/cjs/render/webgl/glsl/LookupTable.js.map +1 -1
  88. package/lib/cjs/render/webgl/glsl/PlanarGrid.js +2 -2
  89. package/lib/cjs/render/webgl/glsl/PlanarGrid.js.map +1 -1
  90. package/lib/cjs/render/webgl/glsl/PointCloud.js +2 -2
  91. package/lib/cjs/render/webgl/glsl/PointCloud.js.map +1 -1
  92. package/lib/cjs/render/webgl/glsl/PointString.js +1 -1
  93. package/lib/cjs/render/webgl/glsl/PointString.js.map +1 -1
  94. package/lib/cjs/render/webgl/glsl/Polyline.js +1 -1
  95. package/lib/cjs/render/webgl/glsl/Polyline.js.map +1 -1
  96. package/lib/cjs/render/webgl/glsl/RealityMesh.js +4 -4
  97. package/lib/cjs/render/webgl/glsl/RealityMesh.js.map +1 -1
  98. package/lib/cjs/render/webgl/glsl/ScreenSpaceEffect.js +1 -1
  99. package/lib/cjs/render/webgl/glsl/ScreenSpaceEffect.js.map +1 -1
  100. package/lib/cjs/render/webgl/glsl/SkyBox.js +1 -1
  101. package/lib/cjs/render/webgl/glsl/SkyBox.js.map +1 -1
  102. package/lib/cjs/render/webgl/glsl/SkySphere.js +1 -1
  103. package/lib/cjs/render/webgl/glsl/Surface.js +3 -3
  104. package/lib/cjs/render/webgl/glsl/Surface.js.map +1 -1
  105. package/lib/cjs/render/webgl/glsl/Vertex.js +1 -1
  106. package/lib/cjs/render/webgl/glsl/Vertex.js.map +1 -1
  107. package/lib/cjs/render/webgl/glsl/ViewportQuad.js +1 -1
  108. package/lib/cjs/render/webgl/glsl/ViewportQuad.js.map +1 -1
  109. package/lib/cjs/tile/IModelTile.d.ts.map +1 -1
  110. package/lib/cjs/tile/IModelTile.js +1 -0
  111. package/lib/cjs/tile/IModelTile.js.map +1 -1
  112. package/lib/cjs/tile/ImdlReader.d.ts +1 -0
  113. package/lib/cjs/tile/ImdlReader.d.ts.map +1 -1
  114. package/lib/cjs/tile/ImdlReader.js +21 -1
  115. package/lib/cjs/tile/ImdlReader.js.map +1 -1
  116. package/lib/cjs/tile/PrimaryTileTree.d.ts.map +1 -1
  117. package/lib/cjs/tile/PrimaryTileTree.js +4 -3
  118. package/lib/cjs/tile/PrimaryTileTree.js.map +1 -1
  119. package/lib/cjs/tile/TileAdmin.d.ts +9 -0
  120. package/lib/cjs/tile/TileAdmin.d.ts.map +1 -1
  121. package/lib/cjs/tile/TileAdmin.js +18 -13
  122. package/lib/cjs/tile/TileAdmin.js.map +1 -1
  123. package/lib/cjs/webgl.d.ts +1 -0
  124. package/lib/cjs/webgl.d.ts.map +1 -1
  125. package/lib/cjs/webgl.js +1 -0
  126. package/lib/cjs/webgl.js.map +1 -1
  127. package/lib/esm/Marker.d.ts +9 -2
  128. package/lib/esm/Marker.d.ts.map +1 -1
  129. package/lib/esm/Marker.js +34 -6
  130. package/lib/esm/Marker.js.map +1 -1
  131. package/lib/esm/RealityDataSource.js +2 -13
  132. package/lib/esm/RealityDataSource.js.map +1 -1
  133. package/lib/esm/render/RenderMemory.d.ts +21 -15
  134. package/lib/esm/render/RenderMemory.d.ts.map +1 -1
  135. package/lib/esm/render/RenderMemory.js +21 -15
  136. package/lib/esm/render/RenderMemory.js.map +1 -1
  137. package/lib/esm/render/RenderSystem.d.ts +2 -0
  138. package/lib/esm/render/RenderSystem.d.ts.map +1 -1
  139. package/lib/esm/render/RenderSystem.js +2 -0
  140. package/lib/esm/render/RenderSystem.js.map +1 -1
  141. package/lib/esm/render/primitives/EdgeParams.d.ts +35 -1
  142. package/lib/esm/render/primitives/EdgeParams.d.ts.map +1 -1
  143. package/lib/esm/render/primitives/EdgeParams.js +114 -10
  144. package/lib/esm/render/primitives/EdgeParams.js.map +1 -1
  145. package/lib/esm/render/primitives/VertexTable.d.ts +1 -0
  146. package/lib/esm/render/primitives/VertexTable.d.ts.map +1 -1
  147. package/lib/esm/render/primitives/VertexTable.js +6 -1
  148. package/lib/esm/render/primitives/VertexTable.js.map +1 -1
  149. package/lib/esm/render/webgl/AttributeMap.js +5 -5
  150. package/lib/esm/render/webgl/CachedGeometry.d.ts +2 -0
  151. package/lib/esm/render/webgl/CachedGeometry.d.ts.map +1 -1
  152. package/lib/esm/render/webgl/CachedGeometry.js +14 -13
  153. package/lib/esm/render/webgl/CachedGeometry.js.map +1 -1
  154. package/lib/esm/render/webgl/DrawCommand.js +2 -2
  155. package/lib/esm/render/webgl/IndexedEdgeGeometry.d.ts +51 -0
  156. package/lib/esm/render/webgl/IndexedEdgeGeometry.d.ts.map +1 -0
  157. package/lib/esm/render/webgl/IndexedEdgeGeometry.js +85 -0
  158. package/lib/esm/render/webgl/IndexedEdgeGeometry.js.map +1 -0
  159. package/lib/esm/render/webgl/InstancedGeometry.d.ts +1 -0
  160. package/lib/esm/render/webgl/InstancedGeometry.d.ts.map +1 -1
  161. package/lib/esm/render/webgl/InstancedGeometry.js +1 -0
  162. package/lib/esm/render/webgl/InstancedGeometry.js.map +1 -1
  163. package/lib/esm/render/webgl/Mesh.d.ts +2 -0
  164. package/lib/esm/render/webgl/Mesh.d.ts.map +1 -1
  165. package/lib/esm/render/webgl/Mesh.js +7 -1
  166. package/lib/esm/render/webgl/Mesh.js.map +1 -1
  167. package/lib/esm/render/webgl/PlanarClassifier.js +1 -1
  168. package/lib/esm/render/webgl/PlanarGrid.js +2 -2
  169. package/lib/esm/render/webgl/RealityMesh.js +5 -5
  170. package/lib/esm/render/webgl/RealityMesh.js.map +1 -1
  171. package/lib/esm/render/webgl/RenderFlags.d.ts +4 -1
  172. package/lib/esm/render/webgl/RenderFlags.d.ts.map +1 -1
  173. package/lib/esm/render/webgl/RenderFlags.js +6 -1
  174. package/lib/esm/render/webgl/RenderFlags.js.map +1 -1
  175. package/lib/esm/render/webgl/SceneCompositor.js +6 -6
  176. package/lib/esm/render/webgl/ScreenSpaceEffect.js +1 -1
  177. package/lib/esm/render/webgl/ShaderBuilder.d.ts +16 -14
  178. package/lib/esm/render/webgl/ShaderBuilder.d.ts.map +1 -1
  179. package/lib/esm/render/webgl/ShaderBuilder.js +19 -15
  180. package/lib/esm/render/webgl/ShaderBuilder.js.map +1 -1
  181. package/lib/esm/render/webgl/System.d.ts +2 -0
  182. package/lib/esm/render/webgl/System.d.ts.map +1 -1
  183. package/lib/esm/render/webgl/System.js +2 -0
  184. package/lib/esm/render/webgl/System.js.map +1 -1
  185. package/lib/esm/render/webgl/Target.js +1 -1
  186. package/lib/esm/render/webgl/Technique.d.ts.map +1 -1
  187. package/lib/esm/render/webgl/Technique.js +72 -57
  188. package/lib/esm/render/webgl/Technique.js.map +1 -1
  189. package/lib/esm/render/webgl/TechniqueId.d.ts +29 -28
  190. package/lib/esm/render/webgl/TechniqueId.d.ts.map +1 -1
  191. package/lib/esm/render/webgl/TechniqueId.js +7 -7
  192. package/lib/esm/render/webgl/TechniqueId.js.map +1 -1
  193. package/lib/esm/render/webgl/glsl/Animation.js +1 -1
  194. package/lib/esm/render/webgl/glsl/Color.js +1 -1
  195. package/lib/esm/render/webgl/glsl/CopyStencil.d.ts.map +1 -1
  196. package/lib/esm/render/webgl/glsl/CopyStencil.js +4 -7
  197. package/lib/esm/render/webgl/glsl/CopyStencil.js.map +1 -1
  198. package/lib/esm/render/webgl/glsl/EVSMFromDepth.js +1 -1
  199. package/lib/esm/render/webgl/glsl/EVSMFromDepth.js.map +1 -1
  200. package/lib/esm/render/webgl/glsl/Edge.d.ts +2 -1
  201. package/lib/esm/render/webgl/glsl/Edge.d.ts.map +1 -1
  202. package/lib/esm/render/webgl/glsl/Edge.js +132 -14
  203. package/lib/esm/render/webgl/glsl/Edge.js.map +1 -1
  204. package/lib/esm/render/webgl/glsl/FeatureSymbology.d.ts.map +1 -1
  205. package/lib/esm/render/webgl/glsl/FeatureSymbology.js +13 -10
  206. package/lib/esm/render/webgl/glsl/FeatureSymbology.js.map +1 -1
  207. package/lib/esm/render/webgl/glsl/Fragment.d.ts.map +1 -1
  208. package/lib/esm/render/webgl/glsl/Fragment.js +9 -1
  209. package/lib/esm/render/webgl/glsl/Fragment.js.map +1 -1
  210. package/lib/esm/render/webgl/glsl/LookupTable.d.ts +4 -2
  211. package/lib/esm/render/webgl/glsl/LookupTable.d.ts.map +1 -1
  212. package/lib/esm/render/webgl/glsl/LookupTable.js +7 -3
  213. package/lib/esm/render/webgl/glsl/LookupTable.js.map +1 -1
  214. package/lib/esm/render/webgl/glsl/PlanarGrid.js +2 -2
  215. package/lib/esm/render/webgl/glsl/PlanarGrid.js.map +1 -1
  216. package/lib/esm/render/webgl/glsl/PointCloud.js +2 -2
  217. package/lib/esm/render/webgl/glsl/PointCloud.js.map +1 -1
  218. package/lib/esm/render/webgl/glsl/PointString.js +1 -1
  219. package/lib/esm/render/webgl/glsl/PointString.js.map +1 -1
  220. package/lib/esm/render/webgl/glsl/Polyline.js +1 -1
  221. package/lib/esm/render/webgl/glsl/Polyline.js.map +1 -1
  222. package/lib/esm/render/webgl/glsl/RealityMesh.js +4 -4
  223. package/lib/esm/render/webgl/glsl/RealityMesh.js.map +1 -1
  224. package/lib/esm/render/webgl/glsl/ScreenSpaceEffect.js +1 -1
  225. package/lib/esm/render/webgl/glsl/ScreenSpaceEffect.js.map +1 -1
  226. package/lib/esm/render/webgl/glsl/SkyBox.js +1 -1
  227. package/lib/esm/render/webgl/glsl/SkyBox.js.map +1 -1
  228. package/lib/esm/render/webgl/glsl/SkySphere.js +1 -1
  229. package/lib/esm/render/webgl/glsl/Surface.js +3 -3
  230. package/lib/esm/render/webgl/glsl/Surface.js.map +1 -1
  231. package/lib/esm/render/webgl/glsl/Vertex.js +1 -1
  232. package/lib/esm/render/webgl/glsl/Vertex.js.map +1 -1
  233. package/lib/esm/render/webgl/glsl/ViewportQuad.js +1 -1
  234. package/lib/esm/render/webgl/glsl/ViewportQuad.js.map +1 -1
  235. package/lib/esm/tile/IModelTile.d.ts.map +1 -1
  236. package/lib/esm/tile/IModelTile.js +1 -0
  237. package/lib/esm/tile/IModelTile.js.map +1 -1
  238. package/lib/esm/tile/ImdlReader.d.ts +1 -0
  239. package/lib/esm/tile/ImdlReader.d.ts.map +1 -1
  240. package/lib/esm/tile/ImdlReader.js +21 -1
  241. package/lib/esm/tile/ImdlReader.js.map +1 -1
  242. package/lib/esm/tile/PrimaryTileTree.d.ts.map +1 -1
  243. package/lib/esm/tile/PrimaryTileTree.js +5 -4
  244. package/lib/esm/tile/PrimaryTileTree.js.map +1 -1
  245. package/lib/esm/tile/TileAdmin.d.ts +9 -0
  246. package/lib/esm/tile/TileAdmin.d.ts.map +1 -1
  247. package/lib/esm/tile/TileAdmin.js +19 -14
  248. package/lib/esm/tile/TileAdmin.js.map +1 -1
  249. package/lib/esm/webgl.d.ts +1 -0
  250. package/lib/esm/webgl.d.ts.map +1 -1
  251. package/lib/esm/webgl.js +1 -0
  252. package/lib/esm/webgl.js.map +1 -1
  253. package/package.json +22 -22
@@ -39,6 +39,7 @@ export class CachedGeometry {
39
39
  get asSurface() { return undefined; }
40
40
  get asMesh() { return undefined; }
41
41
  get asEdge() { return undefined; }
42
+ get asIndexedEdge() { return undefined; }
42
43
  get asRealityMesh() { return undefined; }
43
44
  get asSilhouette() { return undefined; }
44
45
  get asInstanced() { return undefined; }
@@ -293,7 +294,7 @@ export class SkyBoxQuadsGeometry extends CachedGeometry {
293
294
  constructor(ndxGeomParams, texture) {
294
295
  super();
295
296
  this.cube = texture;
296
- this._techniqueId = 22 /* SkyBox */;
297
+ this._techniqueId = 23 /* SkyBox */;
297
298
  this._params = ndxGeomParams;
298
299
  }
299
300
  static create(texture) {
@@ -466,7 +467,7 @@ export class SkySphereViewportQuadGeometry extends ViewportQuadGeometry {
466
467
  this._isWorldPosSet = true;
467
468
  this._setPointsFromFrustum(target);
468
469
  this._worldPosBuff.bindData(this.worldPos, GL.Buffer.Usage.StreamDraw);
469
- const attrWorldPos = AttributeMap.findAttribute("a_worldPos", 23 /* SkySphereGradient */, false);
470
+ const attrWorldPos = AttributeMap.findAttribute("a_worldPos", 24 /* SkySphereGradient */, false);
470
471
  assert(attrWorldPos !== undefined);
471
472
  this._params.buffers.addBuffer(this._worldPosBuff, [BufferParameters.create(attrWorldPos.location, 3, GL.DataType.Float, false, 0, 0, false)]);
472
473
  }
@@ -554,7 +555,7 @@ export class SkySphereViewportQuadGeometry extends ViewportQuadGeometry {
554
555
  const params = ViewportQuad.getInstance().createParams();
555
556
  if (undefined === params)
556
557
  return undefined;
557
- const technique = "sphere" === skybox.type ? 24 /* SkySphereTexture */ : 23 /* SkySphereGradient */;
558
+ const technique = "sphere" === skybox.type ? 25 /* SkySphereTexture */ : 24 /* SkySphereGradient */;
558
559
  return new SkySphereViewportQuadGeometry(params, skybox, technique);
559
560
  }
560
561
  get isDisposed() { return super.isDisposed && this._worldPosBuff.isDisposed; }
@@ -578,13 +579,13 @@ export class AmbientOcclusionGeometry extends TexturedViewportQuadGeometry {
578
579
  get depthAndOrder() { return this._textures[0]; }
579
580
  get noise() { return System.instance.noiseTexture.getHandle(); }
580
581
  constructor(params, textures) {
581
- super(params, 25 /* AmbientOcclusion */, textures);
582
+ super(params, 26 /* AmbientOcclusion */, textures);
582
583
  }
583
584
  }
584
585
  /** @internal */
585
586
  export class BlurGeometry extends TexturedViewportQuadGeometry {
586
587
  constructor(params, textures, blurDir) {
587
- super(params, 26 /* Blur */, textures);
588
+ super(params, 27 /* Blur */, textures);
588
589
  this.blurDir = blurDir;
589
590
  }
590
591
  static createGeometry(texToBlur, depthAndOrder, blurDir) {
@@ -600,7 +601,7 @@ export class BlurGeometry extends TexturedViewportQuadGeometry {
600
601
  /** @internal */
601
602
  export class EVSMGeometry extends TexturedViewportQuadGeometry {
602
603
  constructor(params, textures, width, height) {
603
- super(params, 21 /* EVSMFromDepth */, textures);
604
+ super(params, 22 /* EVSMFromDepth */, textures);
604
605
  this.stepSize = new Float32Array(2);
605
606
  this.stepSize[0] = 1.0 / width;
606
607
  this.stepSize[1] = 1.0 / height;
@@ -644,7 +645,7 @@ export class CompositeGeometry extends TexturedViewportQuadGeometry {
644
645
  return computeCompositeTechniqueId(flags);
645
646
  }
646
647
  constructor(params, textures) {
647
- super(params, 8 /* CompositeHilite */, textures);
648
+ super(params, 9 /* CompositeHilite */, textures);
648
649
  assert(4 <= this._textures.length);
649
650
  }
650
651
  }
@@ -664,7 +665,7 @@ export class CopyPickBufferGeometry extends TexturedViewportQuadGeometry {
664
665
  get featureId() { return this._textures[0]; }
665
666
  get depthAndOrder() { return this._textures[1]; }
666
667
  constructor(params, textures) {
667
- super(params, 16 /* CopyPickBuffers */, textures);
668
+ super(params, 17 /* CopyPickBuffers */, textures);
668
669
  }
669
670
  }
670
671
  export class CombineTexturesGeometry extends TexturedViewportQuadGeometry {
@@ -680,7 +681,7 @@ export class CombineTexturesGeometry extends TexturedViewportQuadGeometry {
680
681
  get texture0() { return this._textures[0]; }
681
682
  get texture1() { return this._textures[1]; }
682
683
  constructor(params, textures) {
683
- super(params, 27 /* CombineTextures */, textures);
684
+ super(params, 28 /* CombineTextures */, textures);
684
685
  }
685
686
  }
686
687
  export class Combine3TexturesGeometry extends TexturedViewportQuadGeometry {
@@ -697,7 +698,7 @@ export class Combine3TexturesGeometry extends TexturedViewportQuadGeometry {
697
698
  get texture1() { return this._textures[1]; }
698
699
  get texture2() { return this._textures[2]; }
699
700
  constructor(params, textures) {
700
- super(params, 28 /* Combine3Textures */, textures);
701
+ super(params, 29 /* Combine3Textures */, textures);
701
702
  }
702
703
  }
703
704
  /** @internal */
@@ -725,7 +726,7 @@ export var BoundaryType;
725
726
  /** @internal */
726
727
  export class VolumeClassifierGeometry extends SingleTexturedViewportQuadGeometry {
727
728
  constructor(params, texture) {
728
- super(params, texture, 30 /* VolClassSetBlend */);
729
+ super(params, texture, 31 /* VolClassSetBlend */);
729
730
  this.boundaryType = BoundaryType.Inside;
730
731
  }
731
732
  static createVCGeometry(texture) {
@@ -753,7 +754,7 @@ export class ScreenPointsGeometry extends CachedGeometry {
753
754
  this._scale[1] = this._positions.params[3];
754
755
  this._scale[2] = this._positions.params[3]; // just copy the scale from y
755
756
  this.buffers = BuffersContainer.create();
756
- const attrPos = AttributeMap.findAttribute("a_pos", 29 /* VolClassCopyZ */, false);
757
+ const attrPos = AttributeMap.findAttribute("a_pos", 30 /* VolClassCopyZ */, false);
757
758
  assert(attrPos !== undefined);
758
759
  this.buffers.addBuffer(this._positions, [BufferParameters.create(attrPos.location, 2, GL.DataType.UnsignedShort, false, 0, 0, false)]);
759
760
  }
@@ -788,7 +789,7 @@ export class ScreenPointsGeometry extends CachedGeometry {
788
789
  stats.addBuffer(RenderMemory.BufferType.PointStrings, this._positions.bytesUsed);
789
790
  }
790
791
  _wantWoWReversal(_target) { return false; }
791
- get techniqueId() { return 29 /* VolClassCopyZ */; }
792
+ get techniqueId() { return 30 /* VolClassCopyZ */; }
792
793
  getRenderPass(_target) { return 5 /* Classification */; }
793
794
  get renderOrder() { return 0 /* None */; }
794
795
  get qOrigin() { return this._origin; }
@@ -1 +1 @@
1
- {"version":3,"file":"CachedGeometry.js","sourceRoot":"","sources":["../../../../src/render/webgl/CachedGeometry.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, dispose } from \"@itwin/core-bentley\";\r\nimport { Angle, Point2d, Point3d, Range3d, Vector2d, Vector3d } from \"@itwin/core-geometry\";\r\nimport { Npc, QParams2d, QParams3d, QPoint2dList, QPoint3dList, RenderMode, RenderTexture } from \"@itwin/core-common\";\r\nimport { RenderSkyGradientParams, RenderSkySphereParams } from \"../RenderSystem\";\r\nimport { FlashMode } from \"../../FlashSettings\";\r\nimport { TesselatedPolyline } from \"../primitives/PolylineParams\";\r\nimport { RenderMemory } from \"../RenderMemory\";\r\nimport { AttributeMap } from \"./AttributeMap\";\r\nimport { ColorInfo } from \"./ColorInfo\";\r\nimport { WebGLDisposable } from \"./Disposable\";\r\nimport { DrawParams, ShaderProgramParams } from \"./DrawCommand\";\r\nimport { LineCode } from \"./LineCode\";\r\nimport { fromSumOf, FrustumUniformType } from \"./FrustumUniforms\";\r\nimport { GL } from \"./GL\";\r\nimport { BufferHandle, BufferParameters, BuffersContainer, QBufferHandle2d, QBufferHandle3d } from \"./AttributeBuffers\";\r\nimport { InstancedGeometry } from \"./InstancedGeometry\";\r\nimport { MaterialInfo } from \"./Material\";\r\nimport { MeshGeometry } from \"./MeshGeometry\";\r\nimport { EdgeGeometry, SilhouetteEdgeGeometry } from \"./EdgeGeometry\";\r\nimport { SurfaceGeometry } from \"./SurfaceGeometry\";\r\nimport { PointCloudGeometry } from \"./PointCloud\";\r\nimport { CompositeFlags, RenderOrder, RenderPass } from \"./RenderFlags\";\r\nimport { System } from \"./System\";\r\nimport { Target } from \"./Target\";\r\nimport { computeCompositeTechniqueId, TechniqueId } from \"./TechniqueId\";\r\nimport { RealityMeshGeometry } from \"./RealityMesh\";\r\nimport { TextureHandle } from \"./Texture\";\r\nimport { VertexLUT } from \"./VertexLUT\";\r\nimport { PlanarGridGeometry } from \"./PlanarGrid\";\r\n\r\nconst scratchVec3a = new Vector3d();\r\nconst scratchVec3b = new Vector3d();\r\nconst scratchVec3c = new Vector3d();\r\nconst scratchPoint3a = new Point3d();\r\nconst scratchPoint3b = new Point3d();\r\nconst scratchPoint3c = new Point3d();\r\nconst scratchPoint3d = new Point3d();\r\n\r\n/** Represents a geometric primitive ready to be submitted to the GPU for rendering.\r\n * @internal\r\n */\r\nexport abstract class CachedGeometry implements WebGLDisposable, RenderMemory.Consumer {\r\n protected _range?: Range3d;\r\n /**\r\n * Functions for obtaining a subclass of CachedGeometry.\r\n * IMPORTANT: Do NOT use code like `const surface = cachedGeom as SurfaceGeometry`.\r\n * Instanced geometry holds a reference to the shared geometry rendered for each instance - such casts will fail,\r\n * while the casting `functions` will forward to the shared geometry.\r\n */\r\n public get asLUT(): LUTGeometry | undefined { return undefined; }\r\n public get asSurface(): SurfaceGeometry | undefined { return undefined; }\r\n public get asMesh(): MeshGeometry | undefined { return undefined; }\r\n public get asEdge(): EdgeGeometry | undefined { return undefined; }\r\n public get asRealityMesh(): RealityMeshGeometry | undefined { return undefined; }\r\n public get asSilhouette(): SilhouetteEdgeGeometry | undefined { return undefined; }\r\n public get asInstanced(): InstancedGeometry | undefined { return undefined; }\r\n public get isInstanced() { return undefined !== this.asInstanced; }\r\n public get asPointCloud(): PointCloudGeometry | undefined { return undefined; }\r\n public get asPlanarGrid(): PlanarGridGeometry | undefined { return undefined; }\r\n public get alwaysRenderTranslucent(): boolean { return false; }\r\n public get allowColorOverride(): boolean { return true; }\r\n\r\n // Returns true if white portions of this geometry should render as black on white background\r\n protected abstract _wantWoWReversal(_target: Target): boolean;\r\n // Returns the edge/line weight used to render this geometry\r\n protected _getLineWeight(_params: ShaderProgramParams): number { return 0; }\r\n // Returns the edge/line pattern used to render this geometry\r\n protected _getLineCode(_params: ShaderProgramParams): number { return LineCode.solid; }\r\n\r\n public abstract get isDisposed(): boolean;\r\n // Returns the Id of the Technique used to render this geometry\r\n public abstract get techniqueId(): TechniqueId;\r\n // Returns the pass in which to render this geometry. RenderPass.None indicates it should not be rendered.\r\n public abstract getRenderPass(target: Target): RenderPass;\r\n // Returns the 'order' of this geometry, which determines how z-fighting is resolved.\r\n public abstract get renderOrder(): RenderOrder;\r\n // Returns true if this is a lit surface\r\n public get isLitSurface(): boolean { return false; }\r\n // Returns true if this is an unlit surface with baked-in lighting (e.g. 3mx, scalable mesh reality models)\r\n public get hasBakedLighting(): boolean { return false; }\r\n // Returns true if this primitive contains auxillary animation data.\r\n public get hasAnimation(): boolean { return false; }\r\n\r\n /** Returns the origin of this geometry's quantization parameters. */\r\n public abstract get qOrigin(): Float32Array;\r\n /** Returns the scale of this geometry's quantization parameters. */\r\n public abstract get qScale(): Float32Array;\r\n // Draws this geometry\r\n public abstract draw(): void;\r\n\r\n public abstract dispose(): void;\r\n\r\n // Intended to be overridden by specific subclasses\r\n public get materialInfo(): MaterialInfo | undefined { return undefined; }\r\n public get hasMaterialAtlas(): boolean {\r\n const mat = this.materialInfo;\r\n return undefined !== mat && mat.isAtlas;\r\n }\r\n\r\n public get polylineBuffers(): PolylineBuffers | undefined { return undefined; }\r\n public get hasFeatures(): boolean { return false; }\r\n public get viewIndependentOrigin(): Point3d | undefined { return undefined; }\r\n public get isViewIndependent(): boolean { return undefined !== this.viewIndependentOrigin; }\r\n\r\n public get supportsThematicDisplay() { return false; }\r\n\r\n public get isEdge(): boolean {\r\n switch (this.renderOrder) {\r\n case RenderOrder.Edge:\r\n case RenderOrder.Silhouette:\r\n case RenderOrder.PlanarEdge:\r\n case RenderOrder.PlanarSilhouette:\r\n return true;\r\n default:\r\n return false;\r\n }\r\n }\r\n public wantWoWReversal(params: ShaderProgramParams): boolean {\r\n return params.target.currentViewFlags.whiteOnWhiteReversal && this._wantWoWReversal(params.target);\r\n }\r\n public getLineCode(params: ShaderProgramParams): number {\r\n return params.target.currentViewFlags.styles ? this._getLineCode(params) : LineCode.solid;\r\n }\r\n public getLineWeight(params: ShaderProgramParams): number {\r\n if (!params.target.currentViewFlags.weights) {\r\n return 1.0;\r\n }\r\n\r\n const minWeight = 1;\r\n let weight = this._getLineWeight(params);\r\n weight = Math.max(weight, minWeight);\r\n weight = Math.min(weight, 31.0);\r\n return weight;\r\n }\r\n\r\n public getFlashMode(params: DrawParams): FlashMode {\r\n // By default only surfaces rendered with lighting get brightened. Overridden for reality meshes since they have lighting baked-in.\r\n // NB: If the reality model is classified, the classifiers are drawn without lighting, therefore we mix the hilite color.\r\n if (this.hasBakedLighting)\r\n return FlashMode.Hilite;\r\n\r\n const vf = params.target.currentViewFlags;\r\n if (!this.isLitSurface || RenderMode.SmoothShade !== vf.renderMode)\r\n return FlashMode.Hilite;\r\n\r\n return vf.lighting ? params.target.plan.flashSettings.litMode : FlashMode.Hilite;\r\n }\r\n\r\n public wantMixMonochromeColor(_target: Target): boolean { return false; }\r\n public wantMonochrome(_target: Target): boolean { return true; }\r\n\r\n public abstract collectStatistics(stats: RenderMemory.Statistics): void;\r\n\r\n public computeRange(output?: Range3d): Range3d {\r\n if (undefined === this._range) {\r\n const lowX = this.qOrigin[0];\r\n const lowY = this.qOrigin[1];\r\n const lowZ = this.qOrigin[2];\r\n\r\n const hiX = 0xffff * this.qScale[0] + lowX;\r\n const hiY = 0xffff * this.qScale[1] + lowY;\r\n const hiZ = 0xffff * this.qScale[2] + lowZ;\r\n\r\n this._range = Range3d.createXYZXYZ(lowX, lowY, lowZ, hiX, hiY, hiZ);\r\n }\r\n\r\n return this._range.clone(output);\r\n }\r\n}\r\n\r\n/** Geometry which is drawn using indices into a look-up texture of vertex data, via gl.drawArrays()\r\n * @internal\r\n */\r\nexport abstract class LUTGeometry extends CachedGeometry {\r\n private readonly _viewIndependentOrigin?: Point3d;\r\n\r\n public abstract get lutBuffers(): BuffersContainer;\r\n\r\n // The texture containing the vertex data.\r\n public abstract get lut(): VertexLUT;\r\n public override get asLUT() { return this; }\r\n public override get viewIndependentOrigin() { return this._viewIndependentOrigin; }\r\n\r\n protected abstract _draw(_numInstances: number, _instanceBuffersContainer?: BuffersContainer): void;\r\n public draw(): void { this._draw(0); }\r\n public drawInstanced(numInstances: number, instanceBuffersContainer: BuffersContainer): void { this._draw(numInstances, instanceBuffersContainer); }\r\n\r\n // Override this if your color varies based on the target\r\n public getColor(_target: Target): ColorInfo { return this.lut.colorInfo; }\r\n\r\n public get qOrigin(): Float32Array { return this.lut.qOrigin; }\r\n public get qScale(): Float32Array { return this.lut.qScale; }\r\n public override get hasAnimation() { return this.lut.hasAnimation; }\r\n\r\n protected constructor(viewIndependentOrigin?: Point3d) {\r\n super();\r\n this._viewIndependentOrigin = viewIndependentOrigin;\r\n }\r\n}\r\n\r\n/** Parameters used to construct an IndexedGeometry\r\n * @internal\r\n */\r\nexport class IndexedGeometryParams implements WebGLDisposable {\r\n public readonly buffers: BuffersContainer;\r\n public readonly positions: QBufferHandle3d;\r\n public readonly indices: BufferHandle;\r\n public readonly numIndices: number;\r\n\r\n protected constructor(positions: QBufferHandle3d, indices: BufferHandle, numIndices: number) {\r\n this.buffers = BuffersContainer.create();\r\n const attrPos = AttributeMap.findAttribute(\"a_pos\", undefined, false);\r\n assert(attrPos !== undefined);\r\n this.buffers.addBuffer(positions, [BufferParameters.create(attrPos.location, 3, GL.DataType.UnsignedShort, false, 0, 0, false)]);\r\n this.buffers.addBuffer(indices, []);\r\n this.positions = positions;\r\n this.indices = indices;\r\n this.numIndices = numIndices;\r\n }\r\n\r\n public static create(positions: Uint16Array, qParams: QParams3d, indices: Uint32Array) {\r\n const posBuf = QBufferHandle3d.create(qParams, positions);\r\n const indBuf = BufferHandle.createBuffer(GL.Buffer.Target.ElementArrayBuffer, indices);\r\n if (undefined === posBuf || undefined === indBuf)\r\n return undefined;\r\n\r\n return new IndexedGeometryParams(posBuf, indBuf, indices.length);\r\n }\r\n public static createFromList(positions: QPoint3dList, indices: Uint32Array) {\r\n return IndexedGeometryParams.create(positions.toTypedArray(), positions.params, indices);\r\n }\r\n\r\n public get isDisposed(): boolean {\r\n return this.buffers.isDisposed\r\n && this.positions.isDisposed\r\n && this.indices.isDisposed;\r\n }\r\n\r\n public dispose() {\r\n dispose(this.buffers);\r\n dispose(this.positions);\r\n dispose(this.indices);\r\n }\r\n}\r\n\r\n/** A geometric primitive which is rendered using gl.drawElements() with one or more vertex buffers indexed by an index buffer.\r\n * @internal\r\n */\r\nexport abstract class IndexedGeometry extends CachedGeometry {\r\n protected readonly _params: IndexedGeometryParams;\r\n protected _wantWoWReversal(_target: Target): boolean { return false; }\r\n protected constructor(params: IndexedGeometryParams) {\r\n super();\r\n this._params = params;\r\n }\r\n\r\n public get isDisposed(): boolean { return this._params.isDisposed; }\r\n\r\n public dispose() {\r\n dispose(this._params);\r\n }\r\n\r\n public draw(): void {\r\n this._params.buffers.bind();\r\n System.instance.context.drawElements(GL.PrimitiveType.Triangles, this._params.numIndices, GL.DataType.UnsignedInt, 0);\r\n this._params.buffers.unbind();\r\n }\r\n\r\n public get qOrigin() { return this._params.positions.origin; }\r\n public get qScale() { return this._params.positions.scale; }\r\n}\r\n\r\n/** a cube of quads in normalized device coordinates for skybox rendering techniques\r\n * @internal\r\n */\r\nclass SkyBoxQuads {\r\n public readonly vertices: Uint16Array;\r\n public readonly vertexParams: QParams3d;\r\n\r\n public constructor() {\r\n const skyBoxSz = 1.0;\r\n\r\n const qVerts = new QPoint3dList(QParams3d.fromNormalizedRange());\r\n\r\n // NB: After applying the rotation matrix in the shader, Back becomes (Bottom), etc.\r\n // See the notes in the parens below.\r\n\r\n // ###TODO: Make this indexed. Currently not indexed because of previous six-sided texture system.\r\n\r\n // Back (Bottom after rotation)\r\n qVerts.add(new Point3d(-skyBoxSz, skyBoxSz, skyBoxSz)); // back upper left - 0\r\n qVerts.add(new Point3d(skyBoxSz, skyBoxSz, skyBoxSz)); // back upper right - 1\r\n qVerts.add(new Point3d(-skyBoxSz, -skyBoxSz, skyBoxSz)); // back lower left - 2\r\n qVerts.add(new Point3d(skyBoxSz, skyBoxSz, skyBoxSz)); // back upper right - 1\r\n qVerts.add(new Point3d(skyBoxSz, -skyBoxSz, skyBoxSz)); // back lower right - 3\r\n qVerts.add(new Point3d(-skyBoxSz, -skyBoxSz, skyBoxSz)); // back lower left - 2\r\n\r\n // Front (Top after rotation)\r\n qVerts.add(new Point3d(-skyBoxSz, skyBoxSz, -skyBoxSz)); // front upper left - 4\r\n qVerts.add(new Point3d(skyBoxSz, skyBoxSz, -skyBoxSz)); // front upper right - 5\r\n qVerts.add(new Point3d(-skyBoxSz, -skyBoxSz, -skyBoxSz)); // front lower left - 6\r\n qVerts.add(new Point3d(skyBoxSz, skyBoxSz, -skyBoxSz)); // front upper right - 5\r\n qVerts.add(new Point3d(skyBoxSz, -skyBoxSz, -skyBoxSz)); // front lower right - 7\r\n qVerts.add(new Point3d(-skyBoxSz, -skyBoxSz, -skyBoxSz)); // front lower left - 6\r\n\r\n // Top (Front after rotation)\r\n qVerts.add(new Point3d(-skyBoxSz, skyBoxSz, -skyBoxSz)); // front upper left - 4\r\n qVerts.add(new Point3d(skyBoxSz, skyBoxSz, -skyBoxSz)); // front upper right - 5\r\n qVerts.add(new Point3d(skyBoxSz, skyBoxSz, skyBoxSz)); // back upper right - 1\r\n qVerts.add(new Point3d(-skyBoxSz, skyBoxSz, -skyBoxSz)); // front upper left - 4\r\n qVerts.add(new Point3d(-skyBoxSz, skyBoxSz, skyBoxSz)); // back upper left - 0\r\n qVerts.add(new Point3d(skyBoxSz, skyBoxSz, skyBoxSz)); // back upper right - 1\r\n\r\n // Bottom (Back after rotation)\r\n qVerts.add(new Point3d(-skyBoxSz, -skyBoxSz, skyBoxSz)); // back lower left - 2\r\n qVerts.add(new Point3d(skyBoxSz, -skyBoxSz, skyBoxSz)); // back lower right - 3\r\n qVerts.add(new Point3d(-skyBoxSz, -skyBoxSz, -skyBoxSz)); // front lower left - 6\r\n qVerts.add(new Point3d(skyBoxSz, -skyBoxSz, skyBoxSz)); // back lower right - 3\r\n qVerts.add(new Point3d(skyBoxSz, -skyBoxSz, -skyBoxSz)); // front lower right - 7\r\n qVerts.add(new Point3d(-skyBoxSz, -skyBoxSz, -skyBoxSz)); // front lower left - 6\r\n\r\n // Left (Right after rotation)\r\n qVerts.add(new Point3d(-skyBoxSz, skyBoxSz, skyBoxSz)); // back upper left - 0\r\n qVerts.add(new Point3d(-skyBoxSz, skyBoxSz, -skyBoxSz)); // front upper left - 4\r\n qVerts.add(new Point3d(-skyBoxSz, -skyBoxSz, skyBoxSz)); // back lower left - 2\r\n qVerts.add(new Point3d(-skyBoxSz, skyBoxSz, -skyBoxSz)); // front upper left - 4\r\n qVerts.add(new Point3d(-skyBoxSz, -skyBoxSz, -skyBoxSz)); // front lower left - 6\r\n qVerts.add(new Point3d(-skyBoxSz, -skyBoxSz, skyBoxSz)); // back lower left - 2\r\n\r\n // Right (Left after rotation)\r\n qVerts.add(new Point3d(skyBoxSz, skyBoxSz, skyBoxSz)); // back upper right - 1\r\n qVerts.add(new Point3d(skyBoxSz, skyBoxSz, -skyBoxSz)); // front upper right - 5\r\n qVerts.add(new Point3d(skyBoxSz, -skyBoxSz, skyBoxSz)); // back lower right - 3\r\n qVerts.add(new Point3d(skyBoxSz, skyBoxSz, -skyBoxSz)); // front upper right - 5\r\n qVerts.add(new Point3d(skyBoxSz, -skyBoxSz, -skyBoxSz)); // front lower right - 7\r\n qVerts.add(new Point3d(skyBoxSz, -skyBoxSz, skyBoxSz)); // back lower right - 3\r\n\r\n this.vertices = qVerts.toTypedArray();\r\n this.vertexParams = qVerts.params;\r\n }\r\n\r\n public createParams() {\r\n return SkyBoxGeometryParams.create(this.vertices, this.vertexParams);\r\n }\r\n}\r\n\r\n/** Parameters used to construct an SkyBox\r\n * @internal\r\n */\r\nexport class SkyBoxGeometryParams implements WebGLDisposable {\r\n public readonly buffers: BuffersContainer;\r\n public readonly positions: QBufferHandle3d;\r\n\r\n protected constructor(positions: QBufferHandle3d) {\r\n this.buffers = BuffersContainer.create();\r\n const attrPos = AttributeMap.findAttribute(\"a_pos\", undefined, false);\r\n assert(attrPos !== undefined);\r\n this.buffers.addBuffer(positions, [BufferParameters.create(attrPos.location, 3, GL.DataType.UnsignedShort, false, 0, 0, false)]);\r\n this.positions = positions;\r\n }\r\n\r\n public static create(positions: Uint16Array, qparams: QParams3d) {\r\n const posBuf = QBufferHandle3d.create(qparams, positions);\r\n if (undefined === posBuf)\r\n return undefined;\r\n\r\n return new SkyBoxGeometryParams(posBuf);\r\n }\r\n\r\n public get isDisposed(): boolean { return this.buffers.isDisposed && this.positions.isDisposed; }\r\n\r\n public dispose() {\r\n dispose(this.buffers);\r\n dispose(this.positions);\r\n }\r\n}\r\n\r\n/** @internal */\r\nnamespace SkyBoxQuads { // eslint-disable-line no-redeclare\r\n let skyBoxQuads: SkyBoxQuads | undefined;\r\n\r\n export function getInstance(): SkyBoxQuads {\r\n if (undefined === skyBoxQuads)\r\n skyBoxQuads = new SkyBoxQuads();\r\n\r\n return skyBoxQuads;\r\n }\r\n}\r\n\r\n/** Geometry used for view-space rendering techniques.\r\n * @internal\r\n */\r\nexport class SkyBoxQuadsGeometry extends CachedGeometry {\r\n protected _techniqueId: TechniqueId;\r\n public readonly cube: RenderTexture;\r\n protected readonly _params: SkyBoxGeometryParams;\r\n\r\n protected constructor(ndxGeomParams: SkyBoxGeometryParams, texture: RenderTexture) {\r\n super();\r\n this.cube = texture;\r\n this._techniqueId = TechniqueId.SkyBox;\r\n this._params = ndxGeomParams;\r\n }\r\n\r\n public static create(texture: RenderTexture): SkyBoxQuadsGeometry | undefined {\r\n const sbxGeomParams = SkyBoxQuads.getInstance().createParams();\r\n return undefined !== sbxGeomParams ? new SkyBoxQuadsGeometry(sbxGeomParams, texture) : undefined;\r\n }\r\n\r\n public collectStatistics(_stats: RenderMemory.Statistics): void {\r\n // Not interested in tracking this.\r\n }\r\n\r\n public get techniqueId(): TechniqueId { return this._techniqueId; }\r\n public getRenderPass(_target: Target) { return RenderPass.SkyBox; }\r\n public get renderOrder() { return RenderOrder.UnlitSurface; }\r\n\r\n public draw(): void {\r\n this._params.buffers.bind();\r\n System.instance.context.drawArrays(GL.PrimitiveType.Triangles, 0, 36);\r\n this._params.buffers.unbind();\r\n }\r\n\r\n public get qOrigin() { return this._params.positions.origin; }\r\n public get qScale() { return this._params.positions.scale; }\r\n\r\n public get isDisposed(): boolean { return this._params.isDisposed; }\r\n\r\n public dispose() {\r\n dispose(this._params);\r\n }\r\n\r\n protected _wantWoWReversal(_target: Target): boolean { return false; }\r\n}\r\n\r\n/** A quad with its corners mapped to the dimensions as the viewport, used for special rendering techniques.\r\n * @internal\r\n */\r\nclass ViewportQuad {\r\n public readonly vertices: Uint16Array;\r\n public readonly vertexParams: QParams3d;\r\n public readonly indices = new Uint32Array(6);\r\n\r\n public constructor() {\r\n const pt = new Point3d(-1, -1, 0);\r\n const vertices = new QPoint3dList(QParams3d.fromNormalizedRange());\r\n vertices.add(pt);\r\n pt.x = 1;\r\n vertices.add(pt);\r\n pt.y = 1;\r\n vertices.add(pt);\r\n pt.x = -1;\r\n vertices.add(pt);\r\n\r\n this.vertices = vertices.toTypedArray();\r\n this.vertexParams = vertices.params;\r\n\r\n this.indices[0] = 0;\r\n this.indices[1] = 1;\r\n this.indices[2] = 2;\r\n this.indices[3] = 0;\r\n this.indices[4] = 2;\r\n this.indices[5] = 3;\r\n }\r\n\r\n public createParams() {\r\n return IndexedGeometryParams.create(this.vertices, this.vertexParams, this.indices);\r\n }\r\n}\r\n\r\n/** @internal */\r\nnamespace ViewportQuad { // eslint-disable-line no-redeclare\r\n let viewportQuad: ViewportQuad | undefined;\r\n\r\n export function getInstance(): ViewportQuad {\r\n if (undefined === viewportQuad)\r\n viewportQuad = new ViewportQuad();\r\n\r\n return viewportQuad;\r\n }\r\n}\r\n\r\n/** Geometry used for view-space rendering techniques.\r\n * @internal\r\n */\r\nexport class ViewportQuadGeometry extends IndexedGeometry {\r\n protected _techniqueId: TechniqueId;\r\n\r\n protected constructor(params: IndexedGeometryParams, techniqueId: TechniqueId) {\r\n super(params);\r\n this._techniqueId = techniqueId;\r\n }\r\n public static create(techniqueId: TechniqueId) {\r\n const params = ViewportQuad.getInstance().createParams();\r\n return undefined !== params ? new this(params, techniqueId) : undefined;\r\n }\r\n\r\n public get techniqueId(): TechniqueId { return this._techniqueId; }\r\n public getRenderPass(_target: Target) { return RenderPass.OpaqueGeneral; }\r\n public get renderOrder() { return RenderOrder.UnlitSurface; }\r\n\r\n public collectStatistics(_stats: RenderMemory.Statistics): void {\r\n // NB: These don't really count...\r\n }\r\n}\r\n\r\n/** Geometry used for view-space rendering techniques which involve sampling one or more textures.\r\n * @internal\r\n */\r\nexport class TexturedViewportQuadGeometry extends ViewportQuadGeometry {\r\n protected readonly _textures: WebGLTexture[];\r\n\r\n protected constructor(params: IndexedGeometryParams, techniqueId: TechniqueId, textures: WebGLTexture[]) {\r\n super(params, techniqueId);\r\n this._textures = textures;\r\n\r\n // TypeScript compiler will happily accept TextureHandle (or any other type) in place of WebGLTexture.\r\n // There is no such 'type' as WebGLTexture at run-time.\r\n assert(this._textures.every((tx) => !(tx instanceof TextureHandle)));\r\n }\r\n\r\n public static createTexturedViewportQuadGeometry(techniqueId: TechniqueId, textures: WebGLTexture[]): TexturedViewportQuadGeometry | undefined {\r\n const params = ViewportQuad.getInstance().createParams();\r\n if (undefined === params)\r\n return undefined;\r\n\r\n return new this(params, techniqueId, textures);\r\n }\r\n}\r\n\r\n/** Geometry used for rendering default gradient-style or single texture spherical skybox.\r\n * @internal\r\n */\r\nexport class SkySphereViewportQuadGeometry extends ViewportQuadGeometry {\r\n public worldPos: Float32Array; // LeftBottom, RightBottom, RightTop, LeftTop worl pos of frustum at mid depth.\r\n public readonly typeAndExponents: Float32Array; // [0] -1.0 for 2-color gradient, 1.0 for 4-color gradient, 0.0 for texture; [1] sky exponent (4-color only) [2] ground exponent (4-color only)\r\n public readonly zOffset: number;\r\n public readonly rotation: number;\r\n public readonly zenithColor: Float32Array;\r\n public readonly skyColor: Float32Array;\r\n public readonly groundColor: Float32Array;\r\n public readonly nadirColor: Float32Array;\r\n public readonly skyTexture?: RenderTexture;\r\n protected readonly _worldPosBuff: BufferHandle;\r\n private _isWorldPosSet: boolean = false;\r\n\r\n public initWorldPos(target: Target): void {\r\n if (this._isWorldPosSet)\r\n return;\r\n\r\n this._isWorldPosSet = true;\r\n this._setPointsFromFrustum(target);\r\n this._worldPosBuff.bindData(this.worldPos, GL.Buffer.Usage.StreamDraw);\r\n const attrWorldPos = AttributeMap.findAttribute(\"a_worldPos\", TechniqueId.SkySphereGradient, false);\r\n assert(attrWorldPos !== undefined);\r\n this._params.buffers.addBuffer(this._worldPosBuff, [BufferParameters.create(attrWorldPos.location, 3, GL.DataType.Float, false, 0, 0, false)]);\r\n }\r\n\r\n private _setPointsFromFrustum(target: Target) {\r\n const frustum = target.planFrustum;\r\n const wp = this.worldPos;\r\n\r\n const lb = frustum.getCorner(Npc.LeftBottomRear).interpolate(0.5, frustum.getCorner(Npc.LeftBottomFront), scratchPoint3a);\r\n const rb = frustum.getCorner(Npc.RightBottomRear).interpolate(0.5, frustum.getCorner(Npc.RightBottomFront), scratchPoint3b);\r\n const rt = frustum.getCorner(Npc.RightTopRear).interpolate(0.5, frustum.getCorner(Npc.RightTopFront), scratchPoint3c);\r\n if (!target.plan.backgroundMapOn || !target.plan.isGlobeMode3D) {\r\n wp[0] = lb.x;\r\n wp[1] = lb.y;\r\n wp[2] = lb.z;\r\n wp[3] = rb.x;\r\n wp[4] = rb.y;\r\n wp[5] = rb.z;\r\n wp[6] = rt.x;\r\n wp[7] = rt.y;\r\n wp[8] = rt.z;\r\n const lt = frustum.getCorner(Npc.LeftTopRear).interpolate(0.5, frustum.getCorner(Npc.LeftTopFront), scratchPoint3d);\r\n wp[9] = lt.x;\r\n wp[10] = lt.y;\r\n wp[11] = lt.z;\r\n } else {\r\n // Need to fake a different frustum to orient the 4 corners properly.\r\n // First find true frustum center & size.\r\n const fCenter = lb.interpolate(0.5, rt, scratchPoint3d);\r\n const upScreen = Vector3d.createStartEnd(rb, rt, scratchVec3a);\r\n let rightScreen = Vector3d.createStartEnd(lb, rb, scratchVec3b);\r\n const halfWidth = upScreen.magnitude() * 0.5;\r\n const halfHeight = rightScreen.magnitude() * 0.5;\r\n // Find the projection of the globe up onto the frustum plane.\r\n upScreen.normalizeInPlace();\r\n rightScreen.normalizeInPlace();\r\n const projUp = target.plan.upVector.dotProduct(upScreen);\r\n const projRt = target.plan.upVector.dotProduct(rightScreen);\r\n // Find camera position (create one for ortho).\r\n let camPos: Point3d;\r\n if (FrustumUniformType.Perspective === target.uniforms.frustum.type) {\r\n const farLowerLeft = frustum.getCorner(Npc.LeftBottomRear);\r\n const nearLowerLeft = frustum.getCorner(Npc.LeftBottomFront);\r\n const scale = 1.0 / (1.0 - target.planFraction);\r\n const zVec = Vector3d.createStartEnd(farLowerLeft, nearLowerLeft, scratchVec3c);\r\n camPos = fromSumOf(farLowerLeft, zVec, scale, scratchPoint3a);\r\n } else {\r\n const delta = Vector3d.createStartEnd(frustum.getCorner(Npc.LeftBottomRear), frustum.getCorner(Npc.LeftBottomFront), scratchVec3c);\r\n const pseudoCameraHalfAngle = 22.5;\r\n const diagonal = frustum.getCorner(Npc.LeftBottomRear).distance(frustum.getCorner(Npc.RightTopRear));\r\n const focalLength = diagonal / (2 * Math.atan(pseudoCameraHalfAngle * Angle.radiansPerDegree));\r\n let zScale = focalLength / delta.magnitude();\r\n if (zScale < 1.000001)\r\n zScale = 1.000001; // prevent worldEye front being on or inside the frustum front plane\r\n camPos = Point3d.createAdd3Scaled(frustum.getCorner(Npc.LeftBottomRear), .5, frustum.getCorner(Npc.RightTopRear), .5, delta, zScale, scratchPoint3a);\r\n }\r\n // Compute the distance from the camera to the frustum center.\r\n const camDist = camPos.distance(fCenter);\r\n // Now use a fixed camera direction and compute a new frustum center.\r\n const camDir = Vector3d.create(0.0, 1.0, 0.0, scratchVec3c);\r\n fCenter.setFromPoint3d(camPos);\r\n fCenter.addScaledInPlace(camDir, camDist);\r\n // Create an up vector that mimics the projection of the globl up onto the real frustum.\r\n upScreen.set(projRt, 0.0, projUp);\r\n upScreen.normalizeInPlace();\r\n // Compute a new right vector and then compute the 4 points for the sky.\r\n rightScreen = upScreen.crossProduct(camDir, scratchVec3b);\r\n upScreen.scaleInPlace(halfHeight);\r\n rightScreen.scaleInPlace(halfWidth);\r\n wp[0] = fCenter.x - rightScreen.x - upScreen.x; // left bottom\r\n wp[1] = fCenter.y - rightScreen.y - upScreen.y;\r\n wp[2] = fCenter.z - rightScreen.z - upScreen.z;\r\n wp[3] = fCenter.x + rightScreen.x - upScreen.x; // right bottom\r\n wp[4] = fCenter.y + rightScreen.y - upScreen.y;\r\n wp[5] = fCenter.z + rightScreen.z - upScreen.z;\r\n wp[6] = fCenter.x + rightScreen.x + upScreen.x; // right top\r\n wp[7] = fCenter.y + rightScreen.y + upScreen.y;\r\n wp[8] = fCenter.z + rightScreen.z + upScreen.z;\r\n wp[9] = fCenter.x - rightScreen.x + upScreen.x; // left top\r\n wp[10] = fCenter.y - rightScreen.y + upScreen.y;\r\n wp[11] = fCenter.z - rightScreen.z + upScreen.z;\r\n }\r\n }\r\n\r\n protected constructor(params: IndexedGeometryParams, skybox: RenderSkySphereParams | RenderSkyGradientParams, techniqueId: TechniqueId) {\r\n super(params, techniqueId);\r\n\r\n this.worldPos = new Float32Array(4 * 3);\r\n this._worldPosBuff = new BufferHandle(GL.Buffer.Target.ArrayBuffer);\r\n this.typeAndExponents = new Float32Array(3);\r\n this.zenithColor = new Float32Array(3);\r\n this.skyColor = new Float32Array(3);\r\n this.groundColor = new Float32Array(3);\r\n this.nadirColor = new Float32Array(3);\r\n this.zOffset = skybox.zOffset;\r\n\r\n this.rotation = \"sphere\" === skybox.type ? skybox.rotation : 0;\r\n if (skybox.type === \"sphere\") {\r\n this.skyTexture = skybox.texture;\r\n this.typeAndExponents[0] = 0.0;\r\n this.typeAndExponents[1] = 1.0;\r\n this.typeAndExponents[2] = 1.0;\r\n this.zenithColor[0] = 0.0;\r\n this.zenithColor[1] = 0.0;\r\n this.zenithColor[2] = 0.0;\r\n this.nadirColor[0] = 0.0;\r\n this.nadirColor[1] = 0.0;\r\n this.nadirColor[2] = 0.0;\r\n this.skyColor[0] = 0.0;\r\n this.skyColor[1] = 0.0;\r\n this.skyColor[2] = 0.0;\r\n this.groundColor[0] = 0.0;\r\n this.groundColor[1] = 0.0;\r\n this.groundColor[2] = 0.0;\r\n } else {\r\n const gradient = skybox.gradient;\r\n\r\n this.zenithColor[0] = gradient.zenithColor.colors.r / 255.0;\r\n this.zenithColor[1] = gradient.zenithColor.colors.g / 255.0;\r\n this.zenithColor[2] = gradient.zenithColor.colors.b / 255.0;\r\n this.nadirColor[0] = gradient.nadirColor.colors.r / 255.0;\r\n this.nadirColor[1] = gradient.nadirColor.colors.g / 255.0;\r\n this.nadirColor[2] = gradient.nadirColor.colors.b / 255.0;\r\n\r\n if (gradient.twoColor) {\r\n this.typeAndExponents[0] = -1.0;\r\n this.typeAndExponents[1] = 4.0;\r\n this.typeAndExponents[2] = 4.0;\r\n this.skyColor[0] = 0.0;\r\n this.skyColor[1] = 0.0;\r\n this.skyColor[2] = 0.0;\r\n this.groundColor[0] = 0.0;\r\n this.groundColor[1] = 0.0;\r\n this.groundColor[2] = 0.0;\r\n } else {\r\n this.typeAndExponents[0] = 1.0;\r\n this.typeAndExponents[1] = gradient.skyExponent;\r\n this.typeAndExponents[2] = gradient.groundExponent;\r\n this.skyColor[0] = gradient.skyColor.colors.r / 255.0;\r\n this.skyColor[1] = gradient.skyColor.colors.g / 255.0;\r\n this.skyColor[2] = gradient.skyColor.colors.b / 255.0;\r\n this.groundColor[0] = gradient.groundColor.colors.r / 255.0;\r\n this.groundColor[1] = gradient.groundColor.colors.g / 255.0;\r\n this.groundColor[2] = gradient.groundColor.colors.b / 255.0;\r\n }\r\n }\r\n }\r\n\r\n public static createGeometry(skybox: RenderSkySphereParams | RenderSkyGradientParams) {\r\n const params = ViewportQuad.getInstance().createParams();\r\n if (undefined === params)\r\n return undefined;\r\n\r\n const technique = \"sphere\" === skybox.type ? TechniqueId.SkySphereTexture : TechniqueId.SkySphereGradient;\r\n return new SkySphereViewportQuadGeometry(params, skybox, technique);\r\n }\r\n\r\n public override get isDisposed(): boolean { return super.isDisposed && this._worldPosBuff.isDisposed; }\r\n\r\n public override dispose() {\r\n super.dispose();\r\n dispose(this._worldPosBuff);\r\n }\r\n}\r\n\r\n/** Geometry used when rendering ambient occlusion information to an output texture\r\n * @internal\r\n */\r\nexport class AmbientOcclusionGeometry extends TexturedViewportQuadGeometry {\r\n public static createGeometry(depthAndOrder: WebGLTexture) {\r\n const params = ViewportQuad.getInstance().createParams();\r\n if (undefined === params) {\r\n return undefined;\r\n }\r\n\r\n // Will derive positions and normals from depthAndOrder.\r\n return new AmbientOcclusionGeometry(params, [depthAndOrder]);\r\n }\r\n\r\n public get depthAndOrder() { return this._textures[0]; }\r\n public get noise() { return System.instance.noiseTexture!.getHandle()!; }\r\n\r\n private constructor(params: IndexedGeometryParams, textures: WebGLTexture[]) {\r\n super(params, TechniqueId.AmbientOcclusion, textures);\r\n }\r\n}\r\n\r\n/** @internal */\r\nexport class BlurGeometry extends TexturedViewportQuadGeometry {\r\n public readonly blurDir: Vector2d;\r\n\r\n public static createGeometry(texToBlur: WebGLTexture, depthAndOrder: WebGLTexture, blurDir: Vector2d) {\r\n const params = ViewportQuad.getInstance().createParams();\r\n if (undefined === params) {\r\n return undefined;\r\n }\r\n return new BlurGeometry(params, [texToBlur, depthAndOrder], blurDir);\r\n }\r\n\r\n public get textureToBlur() { return this._textures[0]; }\r\n public get depthAndOrder() { return this._textures[1]; }\r\n\r\n private constructor(params: IndexedGeometryParams, textures: WebGLTexture[], blurDir: Vector2d) {\r\n super(params, TechniqueId.Blur, textures);\r\n this.blurDir = blurDir;\r\n }\r\n}\r\n\r\n/** @internal */\r\nexport class EVSMGeometry extends TexturedViewportQuadGeometry {\r\n public readonly stepSize = new Float32Array(2);\r\n\r\n public static createGeometry(depthBuffer: WebGLTexture, width: number, height: number) {\r\n const params = ViewportQuad.getInstance().createParams();\r\n if (undefined === params)\r\n return undefined;\r\n\r\n return new EVSMGeometry(params, [depthBuffer], width, height);\r\n }\r\n\r\n public get depthTexture() { return this._textures[0]; }\r\n\r\n private constructor(params: IndexedGeometryParams, textures: WebGLTexture[], width: number, height: number) {\r\n super(params, TechniqueId.EVSMFromDepth, textures);\r\n this.stepSize[0] = 1.0 / width;\r\n this.stepSize[1] = 1.0 / height;\r\n }\r\n}\r\n\r\n/** Geometry used during the 'composite' pass to apply transparency and/or hilite effects.\r\n * @internal\r\n */\r\nexport class CompositeGeometry extends TexturedViewportQuadGeometry {\r\n public static createGeometry(opaque: WebGLTexture, accum: WebGLTexture, reveal: WebGLTexture, hilite: WebGLTexture) {\r\n const params = ViewportQuad.getInstance().createParams();\r\n if (undefined === params)\r\n return undefined;\r\n\r\n const textures = [opaque, accum, reveal, hilite];\r\n return new CompositeGeometry(params, textures);\r\n }\r\n\r\n public get opaque() { return this._textures[0]; }\r\n public get accum() { return this._textures[1]; }\r\n public get reveal() { return this._textures[2]; }\r\n public get hilite() { return this._textures[3]; }\r\n public get occlusion(): WebGLTexture | undefined {\r\n return this._textures.length > 4 ? this._textures[4] : undefined;\r\n }\r\n public set occlusion(occlusion: WebGLTexture | undefined) {\r\n assert((undefined === occlusion) === (undefined !== this.occlusion));\r\n if (undefined !== occlusion)\r\n this._textures[4] = occlusion;\r\n else\r\n this._textures.length = 4;\r\n }\r\n\r\n // Invoked each frame to determine the appropriate Technique to use.\r\n public update(flags: CompositeFlags): void { this._techniqueId = this.determineTechnique(flags); }\r\n\r\n private determineTechnique(flags: CompositeFlags): TechniqueId {\r\n return computeCompositeTechniqueId(flags);\r\n }\r\n\r\n private constructor(params: IndexedGeometryParams, textures: WebGLTexture[]) {\r\n super(params, TechniqueId.CompositeHilite, textures);\r\n assert(4 <= this._textures.length);\r\n }\r\n}\r\n\r\n/** Geometry used to ping-pong the pick buffer data in between opaque passes.\r\n * @internal\r\n */\r\nexport class CopyPickBufferGeometry extends TexturedViewportQuadGeometry {\r\n public static createGeometry(featureId: WebGLTexture, depthAndOrder: WebGLTexture) {\r\n const params = ViewportQuad.getInstance().createParams();\r\n if (undefined !== params) {\r\n return new CopyPickBufferGeometry(params, [featureId, depthAndOrder]);\r\n } else {\r\n return undefined;\r\n }\r\n }\r\n\r\n public get featureId() { return this._textures[0]; }\r\n public get depthAndOrder() { return this._textures[1]; }\r\n\r\n private constructor(params: IndexedGeometryParams, textures: WebGLTexture[]) {\r\n super(params, TechniqueId.CopyPickBuffers, textures);\r\n }\r\n}\r\nexport class CombineTexturesGeometry extends TexturedViewportQuadGeometry {\r\n public static createGeometry(texture0: WebGLTexture, texture1: WebGLTexture) {\r\n const params = ViewportQuad.getInstance().createParams();\r\n if (undefined !== params) {\r\n return new CombineTexturesGeometry(params, [texture0, texture1]);\r\n } else {\r\n return undefined;\r\n }\r\n }\r\n\r\n public get texture0() { return this._textures[0]; }\r\n public get texture1() { return this._textures[1]; }\r\n\r\n private constructor(params: IndexedGeometryParams, textures: WebGLTexture[]) {\r\n super(params, TechniqueId.CombineTextures, textures);\r\n }\r\n}\r\n\r\nexport class Combine3TexturesGeometry extends TexturedViewportQuadGeometry {\r\n public static createGeometry(texture0: WebGLTexture, texture1: WebGLTexture, texture2: WebGLTexture) {\r\n const params = ViewportQuad.getInstance().createParams();\r\n if (undefined !== params) {\r\n return new Combine3TexturesGeometry(params, [texture0, texture1, texture2]);\r\n } else {\r\n return undefined;\r\n }\r\n }\r\n\r\n public get texture0() { return this._textures[0]; }\r\n public get texture1() { return this._textures[1]; }\r\n public get texture2() { return this._textures[2]; }\r\n\r\n private constructor(params: IndexedGeometryParams, textures: WebGLTexture[]) {\r\n super(params, TechniqueId.Combine3Textures, textures);\r\n }\r\n}\r\n\r\n/** @internal */\r\nexport class SingleTexturedViewportQuadGeometry extends TexturedViewportQuadGeometry {\r\n public static createGeometry(texture: WebGLTexture, techId: TechniqueId) {\r\n const params = ViewportQuad.getInstance().createParams();\r\n if (undefined === params) {\r\n return undefined;\r\n }\r\n\r\n return new SingleTexturedViewportQuadGeometry(params, texture, techId);\r\n }\r\n\r\n public get texture(): WebGLTexture { return this._textures[0]; }\r\n public set texture(texture: WebGLTexture) { this._textures[0] = texture; }\r\n\r\n protected constructor(params: IndexedGeometryParams, texture: WebGLTexture, techId: TechniqueId) {\r\n super(params, techId, [texture]);\r\n }\r\n}\r\n\r\n/** @internal */\r\nexport enum BoundaryType {\r\n Outside = 0,\r\n Inside = 1,\r\n Selected = 2,\r\n}\r\n\r\n/** @internal */\r\nexport class VolumeClassifierGeometry extends SingleTexturedViewportQuadGeometry {\r\n public boundaryType: BoundaryType = BoundaryType.Inside;\r\n\r\n public static createVCGeometry(texture: WebGLTexture) {\r\n const params = ViewportQuad.getInstance().createParams();\r\n if (undefined === params)\r\n return undefined;\r\n return new VolumeClassifierGeometry(params, texture);\r\n }\r\n\r\n private constructor(params: IndexedGeometryParams, texture: WebGLTexture) {\r\n super(params, texture, TechniqueId.VolClassSetBlend);\r\n }\r\n}\r\n\r\n/** A geometric primitive which renders gl points using gl.drawArrays() with one vertex buffer.\r\n * @internal\r\n */\r\nexport class ScreenPointsGeometry extends CachedGeometry {\r\n protected _numPoints: number;\r\n protected _origin: Float32Array;\r\n protected _scale: Float32Array;\r\n protected _positions: QBufferHandle2d;\r\n public readonly buffers: BuffersContainer;\r\n public readonly zTexture: WebGLTexture;\r\n\r\n protected constructor(vertices: QPoint2dList, zTexture: WebGLTexture) {\r\n super();\r\n\r\n this.zTexture = zTexture;\r\n\r\n this._numPoints = vertices.length;\r\n\r\n this._positions = QBufferHandle2d.create(vertices.params, vertices.toTypedArray())!;\r\n\r\n this._origin = new Float32Array(3);\r\n this._origin[0] = this._positions.params[0];\r\n this._origin[1] = this._positions.params[1];\r\n this._origin[2] = 0.0;\r\n this._scale = new Float32Array(3);\r\n this._scale[0] = this._positions.params[2];\r\n this._scale[1] = this._positions.params[3];\r\n this._scale[2] = this._positions.params[3]; // just copy the scale from y\r\n\r\n this.buffers = BuffersContainer.create();\r\n const attrPos = AttributeMap.findAttribute(\"a_pos\", TechniqueId.VolClassCopyZ, false);\r\n assert(attrPos !== undefined);\r\n this.buffers.addBuffer(this._positions, [BufferParameters.create(attrPos.location, 2, GL.DataType.UnsignedShort, false, 0, 0, false)]);\r\n }\r\n\r\n public static createGeometry(width: number, height: number, depth: WebGLTexture): ScreenPointsGeometry {\r\n const pixWidth = 2.0 / width;\r\n const pixHeight = 2.0 / height;\r\n\r\n const startX = pixWidth * 0.5 - 1.0;\r\n const startY = pixHeight * 0.5 - 1.0;\r\n\r\n const pt = new Point2d(startX, startY);\r\n const vertices = new QPoint2dList(QParams2d.fromNormalizedRange());\r\n\r\n for (let y = 0; y < height; ++y) {\r\n pt.x = startX;\r\n for (let x = 0; x < width; ++x) {\r\n vertices.add(pt);\r\n pt.x += pixWidth;\r\n }\r\n pt.y += pixHeight;\r\n }\r\n return new ScreenPointsGeometry(vertices, depth);\r\n }\r\n\r\n public draw(): void {\r\n this.buffers.bind();\r\n System.instance.context.drawArrays(GL.PrimitiveType.Points, 0, this._numPoints);\r\n this.buffers.unbind();\r\n }\r\n\r\n public get isDisposed(): boolean { return this.buffers.isDisposed && this._positions.isDisposed; }\r\n\r\n public dispose() {\r\n dispose(this.buffers);\r\n dispose(this._positions);\r\n }\r\n\r\n public collectStatistics(stats: RenderMemory.Statistics): void {\r\n stats.addBuffer(RenderMemory.BufferType.PointStrings, this._positions.bytesUsed);\r\n }\r\n\r\n protected _wantWoWReversal(_target: Target): boolean { return false; }\r\n public get techniqueId(): TechniqueId { return TechniqueId.VolClassCopyZ; }\r\n public getRenderPass(_target: Target) { return RenderPass.Classification; }\r\n public get renderOrder() { return RenderOrder.None; }\r\n public get qOrigin() { return this._origin; }\r\n public get qScale() { return this._scale; }\r\n}\r\n\r\n/** @internal */\r\nexport class PolylineBuffers implements WebGLDisposable {\r\n public buffers: BuffersContainer;\r\n public indices: BufferHandle;\r\n public prevIndices: BufferHandle;\r\n public nextIndicesAndParams: BufferHandle;\r\n private constructor(indices: BufferHandle, prevIndices: BufferHandle, nextIndicesAndParams: BufferHandle) {\r\n this.buffers = BuffersContainer.create();\r\n\r\n const attrPos = AttributeMap.findAttribute(\"a_pos\", TechniqueId.Polyline, false);\r\n const attrPrevIndex = AttributeMap.findAttribute(\"a_prevIndex\", TechniqueId.Polyline, false);\r\n const attrNextIndex = AttributeMap.findAttribute(\"a_nextIndex\", TechniqueId.Polyline, false);\r\n const attrParam = AttributeMap.findAttribute(\"a_param\", TechniqueId.Polyline, false);\r\n assert(attrPos !== undefined);\r\n assert(attrPrevIndex !== undefined);\r\n assert(attrNextIndex !== undefined);\r\n assert(attrParam !== undefined);\r\n\r\n this.buffers.addBuffer(indices, [BufferParameters.create(attrPos.location, 3, GL.DataType.UnsignedByte, false, 0, 0, false)]);\r\n this.buffers.addBuffer(prevIndices, [BufferParameters.create(attrPrevIndex.location, 3, GL.DataType.UnsignedByte, false, 0, 0, false)]);\r\n this.buffers.addBuffer(nextIndicesAndParams, [\r\n BufferParameters.create(attrNextIndex.location, 3, GL.DataType.UnsignedByte, false, 4, 0, false),\r\n BufferParameters.create(attrParam.location, 1, GL.DataType.UnsignedByte, false, 4, 3, false),\r\n ]);\r\n\r\n this.indices = indices;\r\n this.prevIndices = prevIndices;\r\n this.nextIndicesAndParams = nextIndicesAndParams;\r\n }\r\n\r\n public static create(polyline: TesselatedPolyline): PolylineBuffers | undefined {\r\n const indices = BufferHandle.createArrayBuffer(polyline.indices.data);\r\n const prev = BufferHandle.createArrayBuffer(polyline.prevIndices.data);\r\n const next = BufferHandle.createArrayBuffer(polyline.nextIndicesAndParams);\r\n return undefined !== indices && undefined !== prev && undefined !== next ? new PolylineBuffers(indices, prev, next) : undefined;\r\n }\r\n\r\n public collectStatistics(stats: RenderMemory.Statistics, type: RenderMemory.BufferType): void {\r\n stats.addBuffer(type, this.indices.bytesUsed + this.prevIndices.bytesUsed + this.nextIndicesAndParams.bytesUsed);\r\n }\r\n\r\n public get isDisposed(): boolean {\r\n return this.buffers.isDisposed\r\n && this.indices.isDisposed\r\n && this.prevIndices.isDisposed\r\n && this.nextIndicesAndParams.isDisposed;\r\n }\r\n\r\n public dispose() {\r\n dispose(this.buffers);\r\n dispose(this.indices);\r\n dispose(this.prevIndices);\r\n dispose(this.nextIndicesAndParams);\r\n }\r\n}\r\n"]}
1
+ {"version":3,"file":"CachedGeometry.js","sourceRoot":"","sources":["../../../../src/render/webgl/CachedGeometry.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, dispose } from \"@itwin/core-bentley\";\r\nimport { Angle, Point2d, Point3d, Range3d, Vector2d, Vector3d } from \"@itwin/core-geometry\";\r\nimport { Npc, QParams2d, QParams3d, QPoint2dList, QPoint3dList, RenderMode, RenderTexture } from \"@itwin/core-common\";\r\nimport { RenderSkyGradientParams, RenderSkySphereParams } from \"../RenderSystem\";\r\nimport { FlashMode } from \"../../FlashSettings\";\r\nimport { TesselatedPolyline } from \"../primitives/PolylineParams\";\r\nimport { RenderMemory } from \"../RenderMemory\";\r\nimport { AttributeMap } from \"./AttributeMap\";\r\nimport { ColorInfo } from \"./ColorInfo\";\r\nimport { WebGLDisposable } from \"./Disposable\";\r\nimport { DrawParams, ShaderProgramParams } from \"./DrawCommand\";\r\nimport { LineCode } from \"./LineCode\";\r\nimport { fromSumOf, FrustumUniformType } from \"./FrustumUniforms\";\r\nimport { GL } from \"./GL\";\r\nimport { BufferHandle, BufferParameters, BuffersContainer, QBufferHandle2d, QBufferHandle3d } from \"./AttributeBuffers\";\r\nimport { InstancedGeometry } from \"./InstancedGeometry\";\r\nimport { MaterialInfo } from \"./Material\";\r\nimport { MeshGeometry } from \"./MeshGeometry\";\r\nimport { EdgeGeometry, SilhouetteEdgeGeometry } from \"./EdgeGeometry\";\r\nimport { IndexedEdgeGeometry } from \"./IndexedEdgeGeometry\";\r\nimport { SurfaceGeometry } from \"./SurfaceGeometry\";\r\nimport { PointCloudGeometry } from \"./PointCloud\";\r\nimport { CompositeFlags, RenderOrder, RenderPass } from \"./RenderFlags\";\r\nimport { System } from \"./System\";\r\nimport { Target } from \"./Target\";\r\nimport { computeCompositeTechniqueId, TechniqueId } from \"./TechniqueId\";\r\nimport { RealityMeshGeometry } from \"./RealityMesh\";\r\nimport { TextureHandle } from \"./Texture\";\r\nimport { VertexLUT } from \"./VertexLUT\";\r\nimport { PlanarGridGeometry } from \"./PlanarGrid\";\r\n\r\nconst scratchVec3a = new Vector3d();\r\nconst scratchVec3b = new Vector3d();\r\nconst scratchVec3c = new Vector3d();\r\nconst scratchPoint3a = new Point3d();\r\nconst scratchPoint3b = new Point3d();\r\nconst scratchPoint3c = new Point3d();\r\nconst scratchPoint3d = new Point3d();\r\n\r\n/** Represents a geometric primitive ready to be submitted to the GPU for rendering.\r\n * @internal\r\n */\r\nexport abstract class CachedGeometry implements WebGLDisposable, RenderMemory.Consumer {\r\n protected _range?: Range3d;\r\n /**\r\n * Functions for obtaining a subclass of CachedGeometry.\r\n * IMPORTANT: Do NOT use code like `const surface = cachedGeom as SurfaceGeometry`.\r\n * Instanced geometry holds a reference to the shared geometry rendered for each instance - such casts will fail,\r\n * while the casting `functions` will forward to the shared geometry.\r\n */\r\n public get asLUT(): LUTGeometry | undefined { return undefined; }\r\n public get asSurface(): SurfaceGeometry | undefined { return undefined; }\r\n public get asMesh(): MeshGeometry | undefined { return undefined; }\r\n public get asEdge(): EdgeGeometry | undefined { return undefined; }\r\n public get asIndexedEdge(): IndexedEdgeGeometry | undefined { return undefined; }\r\n public get asRealityMesh(): RealityMeshGeometry | undefined { return undefined; }\r\n public get asSilhouette(): SilhouetteEdgeGeometry | undefined { return undefined; }\r\n public get asInstanced(): InstancedGeometry | undefined { return undefined; }\r\n public get isInstanced() { return undefined !== this.asInstanced; }\r\n public get asPointCloud(): PointCloudGeometry | undefined { return undefined; }\r\n public get asPlanarGrid(): PlanarGridGeometry | undefined { return undefined; }\r\n public get alwaysRenderTranslucent(): boolean { return false; }\r\n public get allowColorOverride(): boolean { return true; }\r\n\r\n // Returns true if white portions of this geometry should render as black on white background\r\n protected abstract _wantWoWReversal(_target: Target): boolean;\r\n // Returns the edge/line weight used to render this geometry\r\n protected _getLineWeight(_params: ShaderProgramParams): number { return 0; }\r\n // Returns the edge/line pattern used to render this geometry\r\n protected _getLineCode(_params: ShaderProgramParams): number { return LineCode.solid; }\r\n\r\n public abstract get isDisposed(): boolean;\r\n // Returns the Id of the Technique used to render this geometry\r\n public abstract get techniqueId(): TechniqueId;\r\n // Returns the pass in which to render this geometry. RenderPass.None indicates it should not be rendered.\r\n public abstract getRenderPass(target: Target): RenderPass;\r\n // Returns the 'order' of this geometry, which determines how z-fighting is resolved.\r\n public abstract get renderOrder(): RenderOrder;\r\n // Returns true if this is a lit surface\r\n public get isLitSurface(): boolean { return false; }\r\n // Returns true if this is an unlit surface with baked-in lighting (e.g. 3mx, scalable mesh reality models)\r\n public get hasBakedLighting(): boolean { return false; }\r\n // Returns true if this primitive contains auxillary animation data.\r\n public get hasAnimation(): boolean { return false; }\r\n\r\n /** Returns the origin of this geometry's quantization parameters. */\r\n public abstract get qOrigin(): Float32Array;\r\n /** Returns the scale of this geometry's quantization parameters. */\r\n public abstract get qScale(): Float32Array;\r\n // Draws this geometry\r\n public abstract draw(): void;\r\n\r\n public abstract dispose(): void;\r\n\r\n // Intended to be overridden by specific subclasses\r\n public get materialInfo(): MaterialInfo | undefined { return undefined; }\r\n public get hasMaterialAtlas(): boolean {\r\n const mat = this.materialInfo;\r\n return undefined !== mat && mat.isAtlas;\r\n }\r\n\r\n public get polylineBuffers(): PolylineBuffers | undefined { return undefined; }\r\n public get hasFeatures(): boolean { return false; }\r\n public get viewIndependentOrigin(): Point3d | undefined { return undefined; }\r\n public get isViewIndependent(): boolean { return undefined !== this.viewIndependentOrigin; }\r\n\r\n public get supportsThematicDisplay() { return false; }\r\n\r\n public get isEdge(): boolean {\r\n switch (this.renderOrder) {\r\n case RenderOrder.Edge:\r\n case RenderOrder.Silhouette:\r\n case RenderOrder.PlanarEdge:\r\n case RenderOrder.PlanarSilhouette:\r\n return true;\r\n default:\r\n return false;\r\n }\r\n }\r\n public wantWoWReversal(params: ShaderProgramParams): boolean {\r\n return params.target.currentViewFlags.whiteOnWhiteReversal && this._wantWoWReversal(params.target);\r\n }\r\n public getLineCode(params: ShaderProgramParams): number {\r\n return params.target.currentViewFlags.styles ? this._getLineCode(params) : LineCode.solid;\r\n }\r\n public getLineWeight(params: ShaderProgramParams): number {\r\n if (!params.target.currentViewFlags.weights) {\r\n return 1.0;\r\n }\r\n\r\n const minWeight = 1;\r\n let weight = this._getLineWeight(params);\r\n weight = Math.max(weight, minWeight);\r\n weight = Math.min(weight, 31.0);\r\n return weight;\r\n }\r\n\r\n public getFlashMode(params: DrawParams): FlashMode {\r\n // By default only surfaces rendered with lighting get brightened. Overridden for reality meshes since they have lighting baked-in.\r\n // NB: If the reality model is classified, the classifiers are drawn without lighting, therefore we mix the hilite color.\r\n if (this.hasBakedLighting)\r\n return FlashMode.Hilite;\r\n\r\n const vf = params.target.currentViewFlags;\r\n if (!this.isLitSurface || RenderMode.SmoothShade !== vf.renderMode)\r\n return FlashMode.Hilite;\r\n\r\n return vf.lighting ? params.target.plan.flashSettings.litMode : FlashMode.Hilite;\r\n }\r\n\r\n public wantMixMonochromeColor(_target: Target): boolean { return false; }\r\n public wantMonochrome(_target: Target): boolean { return true; }\r\n\r\n public abstract collectStatistics(stats: RenderMemory.Statistics): void;\r\n\r\n public computeRange(output?: Range3d): Range3d {\r\n if (undefined === this._range) {\r\n const lowX = this.qOrigin[0];\r\n const lowY = this.qOrigin[1];\r\n const lowZ = this.qOrigin[2];\r\n\r\n const hiX = 0xffff * this.qScale[0] + lowX;\r\n const hiY = 0xffff * this.qScale[1] + lowY;\r\n const hiZ = 0xffff * this.qScale[2] + lowZ;\r\n\r\n this._range = Range3d.createXYZXYZ(lowX, lowY, lowZ, hiX, hiY, hiZ);\r\n }\r\n\r\n return this._range.clone(output);\r\n }\r\n}\r\n\r\n/** Geometry which is drawn using indices into a look-up texture of vertex data, via gl.drawArrays()\r\n * @internal\r\n */\r\nexport abstract class LUTGeometry extends CachedGeometry {\r\n private readonly _viewIndependentOrigin?: Point3d;\r\n\r\n public abstract get lutBuffers(): BuffersContainer;\r\n\r\n // The texture containing the vertex data.\r\n public abstract get lut(): VertexLUT;\r\n public override get asLUT() { return this; }\r\n public override get viewIndependentOrigin() { return this._viewIndependentOrigin; }\r\n\r\n protected abstract _draw(_numInstances: number, _instanceBuffersContainer?: BuffersContainer): void;\r\n public draw(): void { this._draw(0); }\r\n public drawInstanced(numInstances: number, instanceBuffersContainer: BuffersContainer): void { this._draw(numInstances, instanceBuffersContainer); }\r\n\r\n // Override this if your color varies based on the target\r\n public getColor(_target: Target): ColorInfo { return this.lut.colorInfo; }\r\n\r\n public get qOrigin(): Float32Array { return this.lut.qOrigin; }\r\n public get qScale(): Float32Array { return this.lut.qScale; }\r\n public override get hasAnimation() { return this.lut.hasAnimation; }\r\n\r\n protected constructor(viewIndependentOrigin?: Point3d) {\r\n super();\r\n this._viewIndependentOrigin = viewIndependentOrigin;\r\n }\r\n}\r\n\r\n/** Parameters used to construct an IndexedGeometry\r\n * @internal\r\n */\r\nexport class IndexedGeometryParams implements WebGLDisposable {\r\n public readonly buffers: BuffersContainer;\r\n public readonly positions: QBufferHandle3d;\r\n public readonly indices: BufferHandle;\r\n public readonly numIndices: number;\r\n\r\n protected constructor(positions: QBufferHandle3d, indices: BufferHandle, numIndices: number) {\r\n this.buffers = BuffersContainer.create();\r\n const attrPos = AttributeMap.findAttribute(\"a_pos\", undefined, false);\r\n assert(attrPos !== undefined);\r\n this.buffers.addBuffer(positions, [BufferParameters.create(attrPos.location, 3, GL.DataType.UnsignedShort, false, 0, 0, false)]);\r\n this.buffers.addBuffer(indices, []);\r\n this.positions = positions;\r\n this.indices = indices;\r\n this.numIndices = numIndices;\r\n }\r\n\r\n public static create(positions: Uint16Array, qParams: QParams3d, indices: Uint32Array) {\r\n const posBuf = QBufferHandle3d.create(qParams, positions);\r\n const indBuf = BufferHandle.createBuffer(GL.Buffer.Target.ElementArrayBuffer, indices);\r\n if (undefined === posBuf || undefined === indBuf)\r\n return undefined;\r\n\r\n return new IndexedGeometryParams(posBuf, indBuf, indices.length);\r\n }\r\n public static createFromList(positions: QPoint3dList, indices: Uint32Array) {\r\n return IndexedGeometryParams.create(positions.toTypedArray(), positions.params, indices);\r\n }\r\n\r\n public get isDisposed(): boolean {\r\n return this.buffers.isDisposed\r\n && this.positions.isDisposed\r\n && this.indices.isDisposed;\r\n }\r\n\r\n public dispose() {\r\n dispose(this.buffers);\r\n dispose(this.positions);\r\n dispose(this.indices);\r\n }\r\n}\r\n\r\n/** A geometric primitive which is rendered using gl.drawElements() with one or more vertex buffers indexed by an index buffer.\r\n * @internal\r\n */\r\nexport abstract class IndexedGeometry extends CachedGeometry {\r\n protected readonly _params: IndexedGeometryParams;\r\n protected _wantWoWReversal(_target: Target): boolean { return false; }\r\n protected constructor(params: IndexedGeometryParams) {\r\n super();\r\n this._params = params;\r\n }\r\n\r\n public get isDisposed(): boolean { return this._params.isDisposed; }\r\n\r\n public dispose() {\r\n dispose(this._params);\r\n }\r\n\r\n public draw(): void {\r\n this._params.buffers.bind();\r\n System.instance.context.drawElements(GL.PrimitiveType.Triangles, this._params.numIndices, GL.DataType.UnsignedInt, 0);\r\n this._params.buffers.unbind();\r\n }\r\n\r\n public get qOrigin() { return this._params.positions.origin; }\r\n public get qScale() { return this._params.positions.scale; }\r\n}\r\n\r\n/** a cube of quads in normalized device coordinates for skybox rendering techniques\r\n * @internal\r\n */\r\nclass SkyBoxQuads {\r\n public readonly vertices: Uint16Array;\r\n public readonly vertexParams: QParams3d;\r\n\r\n public constructor() {\r\n const skyBoxSz = 1.0;\r\n\r\n const qVerts = new QPoint3dList(QParams3d.fromNormalizedRange());\r\n\r\n // NB: After applying the rotation matrix in the shader, Back becomes (Bottom), etc.\r\n // See the notes in the parens below.\r\n\r\n // ###TODO: Make this indexed. Currently not indexed because of previous six-sided texture system.\r\n\r\n // Back (Bottom after rotation)\r\n qVerts.add(new Point3d(-skyBoxSz, skyBoxSz, skyBoxSz)); // back upper left - 0\r\n qVerts.add(new Point3d(skyBoxSz, skyBoxSz, skyBoxSz)); // back upper right - 1\r\n qVerts.add(new Point3d(-skyBoxSz, -skyBoxSz, skyBoxSz)); // back lower left - 2\r\n qVerts.add(new Point3d(skyBoxSz, skyBoxSz, skyBoxSz)); // back upper right - 1\r\n qVerts.add(new Point3d(skyBoxSz, -skyBoxSz, skyBoxSz)); // back lower right - 3\r\n qVerts.add(new Point3d(-skyBoxSz, -skyBoxSz, skyBoxSz)); // back lower left - 2\r\n\r\n // Front (Top after rotation)\r\n qVerts.add(new Point3d(-skyBoxSz, skyBoxSz, -skyBoxSz)); // front upper left - 4\r\n qVerts.add(new Point3d(skyBoxSz, skyBoxSz, -skyBoxSz)); // front upper right - 5\r\n qVerts.add(new Point3d(-skyBoxSz, -skyBoxSz, -skyBoxSz)); // front lower left - 6\r\n qVerts.add(new Point3d(skyBoxSz, skyBoxSz, -skyBoxSz)); // front upper right - 5\r\n qVerts.add(new Point3d(skyBoxSz, -skyBoxSz, -skyBoxSz)); // front lower right - 7\r\n qVerts.add(new Point3d(-skyBoxSz, -skyBoxSz, -skyBoxSz)); // front lower left - 6\r\n\r\n // Top (Front after rotation)\r\n qVerts.add(new Point3d(-skyBoxSz, skyBoxSz, -skyBoxSz)); // front upper left - 4\r\n qVerts.add(new Point3d(skyBoxSz, skyBoxSz, -skyBoxSz)); // front upper right - 5\r\n qVerts.add(new Point3d(skyBoxSz, skyBoxSz, skyBoxSz)); // back upper right - 1\r\n qVerts.add(new Point3d(-skyBoxSz, skyBoxSz, -skyBoxSz)); // front upper left - 4\r\n qVerts.add(new Point3d(-skyBoxSz, skyBoxSz, skyBoxSz)); // back upper left - 0\r\n qVerts.add(new Point3d(skyBoxSz, skyBoxSz, skyBoxSz)); // back upper right - 1\r\n\r\n // Bottom (Back after rotation)\r\n qVerts.add(new Point3d(-skyBoxSz, -skyBoxSz, skyBoxSz)); // back lower left - 2\r\n qVerts.add(new Point3d(skyBoxSz, -skyBoxSz, skyBoxSz)); // back lower right - 3\r\n qVerts.add(new Point3d(-skyBoxSz, -skyBoxSz, -skyBoxSz)); // front lower left - 6\r\n qVerts.add(new Point3d(skyBoxSz, -skyBoxSz, skyBoxSz)); // back lower right - 3\r\n qVerts.add(new Point3d(skyBoxSz, -skyBoxSz, -skyBoxSz)); // front lower right - 7\r\n qVerts.add(new Point3d(-skyBoxSz, -skyBoxSz, -skyBoxSz)); // front lower left - 6\r\n\r\n // Left (Right after rotation)\r\n qVerts.add(new Point3d(-skyBoxSz, skyBoxSz, skyBoxSz)); // back upper left - 0\r\n qVerts.add(new Point3d(-skyBoxSz, skyBoxSz, -skyBoxSz)); // front upper left - 4\r\n qVerts.add(new Point3d(-skyBoxSz, -skyBoxSz, skyBoxSz)); // back lower left - 2\r\n qVerts.add(new Point3d(-skyBoxSz, skyBoxSz, -skyBoxSz)); // front upper left - 4\r\n qVerts.add(new Point3d(-skyBoxSz, -skyBoxSz, -skyBoxSz)); // front lower left - 6\r\n qVerts.add(new Point3d(-skyBoxSz, -skyBoxSz, skyBoxSz)); // back lower left - 2\r\n\r\n // Right (Left after rotation)\r\n qVerts.add(new Point3d(skyBoxSz, skyBoxSz, skyBoxSz)); // back upper right - 1\r\n qVerts.add(new Point3d(skyBoxSz, skyBoxSz, -skyBoxSz)); // front upper right - 5\r\n qVerts.add(new Point3d(skyBoxSz, -skyBoxSz, skyBoxSz)); // back lower right - 3\r\n qVerts.add(new Point3d(skyBoxSz, skyBoxSz, -skyBoxSz)); // front upper right - 5\r\n qVerts.add(new Point3d(skyBoxSz, -skyBoxSz, -skyBoxSz)); // front lower right - 7\r\n qVerts.add(new Point3d(skyBoxSz, -skyBoxSz, skyBoxSz)); // back lower right - 3\r\n\r\n this.vertices = qVerts.toTypedArray();\r\n this.vertexParams = qVerts.params;\r\n }\r\n\r\n public createParams() {\r\n return SkyBoxGeometryParams.create(this.vertices, this.vertexParams);\r\n }\r\n}\r\n\r\n/** Parameters used to construct an SkyBox\r\n * @internal\r\n */\r\nexport class SkyBoxGeometryParams implements WebGLDisposable {\r\n public readonly buffers: BuffersContainer;\r\n public readonly positions: QBufferHandle3d;\r\n\r\n protected constructor(positions: QBufferHandle3d) {\r\n this.buffers = BuffersContainer.create();\r\n const attrPos = AttributeMap.findAttribute(\"a_pos\", undefined, false);\r\n assert(attrPos !== undefined);\r\n this.buffers.addBuffer(positions, [BufferParameters.create(attrPos.location, 3, GL.DataType.UnsignedShort, false, 0, 0, false)]);\r\n this.positions = positions;\r\n }\r\n\r\n public static create(positions: Uint16Array, qparams: QParams3d) {\r\n const posBuf = QBufferHandle3d.create(qparams, positions);\r\n if (undefined === posBuf)\r\n return undefined;\r\n\r\n return new SkyBoxGeometryParams(posBuf);\r\n }\r\n\r\n public get isDisposed(): boolean { return this.buffers.isDisposed && this.positions.isDisposed; }\r\n\r\n public dispose() {\r\n dispose(this.buffers);\r\n dispose(this.positions);\r\n }\r\n}\r\n\r\n/** @internal */\r\nnamespace SkyBoxQuads { // eslint-disable-line no-redeclare\r\n let skyBoxQuads: SkyBoxQuads | undefined;\r\n\r\n export function getInstance(): SkyBoxQuads {\r\n if (undefined === skyBoxQuads)\r\n skyBoxQuads = new SkyBoxQuads();\r\n\r\n return skyBoxQuads;\r\n }\r\n}\r\n\r\n/** Geometry used for view-space rendering techniques.\r\n * @internal\r\n */\r\nexport class SkyBoxQuadsGeometry extends CachedGeometry {\r\n protected _techniqueId: TechniqueId;\r\n public readonly cube: RenderTexture;\r\n protected readonly _params: SkyBoxGeometryParams;\r\n\r\n protected constructor(ndxGeomParams: SkyBoxGeometryParams, texture: RenderTexture) {\r\n super();\r\n this.cube = texture;\r\n this._techniqueId = TechniqueId.SkyBox;\r\n this._params = ndxGeomParams;\r\n }\r\n\r\n public static create(texture: RenderTexture): SkyBoxQuadsGeometry | undefined {\r\n const sbxGeomParams = SkyBoxQuads.getInstance().createParams();\r\n return undefined !== sbxGeomParams ? new SkyBoxQuadsGeometry(sbxGeomParams, texture) : undefined;\r\n }\r\n\r\n public collectStatistics(_stats: RenderMemory.Statistics): void {\r\n // Not interested in tracking this.\r\n }\r\n\r\n public get techniqueId(): TechniqueId { return this._techniqueId; }\r\n public getRenderPass(_target: Target) { return RenderPass.SkyBox; }\r\n public get renderOrder() { return RenderOrder.UnlitSurface; }\r\n\r\n public draw(): void {\r\n this._params.buffers.bind();\r\n System.instance.context.drawArrays(GL.PrimitiveType.Triangles, 0, 36);\r\n this._params.buffers.unbind();\r\n }\r\n\r\n public get qOrigin() { return this._params.positions.origin; }\r\n public get qScale() { return this._params.positions.scale; }\r\n\r\n public get isDisposed(): boolean { return this._params.isDisposed; }\r\n\r\n public dispose() {\r\n dispose(this._params);\r\n }\r\n\r\n protected _wantWoWReversal(_target: Target): boolean { return false; }\r\n}\r\n\r\n/** A quad with its corners mapped to the dimensions as the viewport, used for special rendering techniques.\r\n * @internal\r\n */\r\nclass ViewportQuad {\r\n public readonly vertices: Uint16Array;\r\n public readonly vertexParams: QParams3d;\r\n public readonly indices = new Uint32Array(6);\r\n\r\n public constructor() {\r\n const pt = new Point3d(-1, -1, 0);\r\n const vertices = new QPoint3dList(QParams3d.fromNormalizedRange());\r\n vertices.add(pt);\r\n pt.x = 1;\r\n vertices.add(pt);\r\n pt.y = 1;\r\n vertices.add(pt);\r\n pt.x = -1;\r\n vertices.add(pt);\r\n\r\n this.vertices = vertices.toTypedArray();\r\n this.vertexParams = vertices.params;\r\n\r\n this.indices[0] = 0;\r\n this.indices[1] = 1;\r\n this.indices[2] = 2;\r\n this.indices[3] = 0;\r\n this.indices[4] = 2;\r\n this.indices[5] = 3;\r\n }\r\n\r\n public createParams() {\r\n return IndexedGeometryParams.create(this.vertices, this.vertexParams, this.indices);\r\n }\r\n}\r\n\r\n/** @internal */\r\nnamespace ViewportQuad { // eslint-disable-line no-redeclare\r\n let viewportQuad: ViewportQuad | undefined;\r\n\r\n export function getInstance(): ViewportQuad {\r\n if (undefined === viewportQuad)\r\n viewportQuad = new ViewportQuad();\r\n\r\n return viewportQuad;\r\n }\r\n}\r\n\r\n/** Geometry used for view-space rendering techniques.\r\n * @internal\r\n */\r\nexport class ViewportQuadGeometry extends IndexedGeometry {\r\n protected _techniqueId: TechniqueId;\r\n\r\n protected constructor(params: IndexedGeometryParams, techniqueId: TechniqueId) {\r\n super(params);\r\n this._techniqueId = techniqueId;\r\n }\r\n public static create(techniqueId: TechniqueId) {\r\n const params = ViewportQuad.getInstance().createParams();\r\n return undefined !== params ? new this(params, techniqueId) : undefined;\r\n }\r\n\r\n public get techniqueId(): TechniqueId { return this._techniqueId; }\r\n public getRenderPass(_target: Target) { return RenderPass.OpaqueGeneral; }\r\n public get renderOrder() { return RenderOrder.UnlitSurface; }\r\n\r\n public collectStatistics(_stats: RenderMemory.Statistics): void {\r\n // NB: These don't really count...\r\n }\r\n}\r\n\r\n/** Geometry used for view-space rendering techniques which involve sampling one or more textures.\r\n * @internal\r\n */\r\nexport class TexturedViewportQuadGeometry extends ViewportQuadGeometry {\r\n protected readonly _textures: WebGLTexture[];\r\n\r\n protected constructor(params: IndexedGeometryParams, techniqueId: TechniqueId, textures: WebGLTexture[]) {\r\n super(params, techniqueId);\r\n this._textures = textures;\r\n\r\n // TypeScript compiler will happily accept TextureHandle (or any other type) in place of WebGLTexture.\r\n // There is no such 'type' as WebGLTexture at run-time.\r\n assert(this._textures.every((tx) => !(tx instanceof TextureHandle)));\r\n }\r\n\r\n public static createTexturedViewportQuadGeometry(techniqueId: TechniqueId, textures: WebGLTexture[]): TexturedViewportQuadGeometry | undefined {\r\n const params = ViewportQuad.getInstance().createParams();\r\n if (undefined === params)\r\n return undefined;\r\n\r\n return new this(params, techniqueId, textures);\r\n }\r\n}\r\n\r\n/** Geometry used for rendering default gradient-style or single texture spherical skybox.\r\n * @internal\r\n */\r\nexport class SkySphereViewportQuadGeometry extends ViewportQuadGeometry {\r\n public worldPos: Float32Array; // LeftBottom, RightBottom, RightTop, LeftTop worl pos of frustum at mid depth.\r\n public readonly typeAndExponents: Float32Array; // [0] -1.0 for 2-color gradient, 1.0 for 4-color gradient, 0.0 for texture; [1] sky exponent (4-color only) [2] ground exponent (4-color only)\r\n public readonly zOffset: number;\r\n public readonly rotation: number;\r\n public readonly zenithColor: Float32Array;\r\n public readonly skyColor: Float32Array;\r\n public readonly groundColor: Float32Array;\r\n public readonly nadirColor: Float32Array;\r\n public readonly skyTexture?: RenderTexture;\r\n protected readonly _worldPosBuff: BufferHandle;\r\n private _isWorldPosSet: boolean = false;\r\n\r\n public initWorldPos(target: Target): void {\r\n if (this._isWorldPosSet)\r\n return;\r\n\r\n this._isWorldPosSet = true;\r\n this._setPointsFromFrustum(target);\r\n this._worldPosBuff.bindData(this.worldPos, GL.Buffer.Usage.StreamDraw);\r\n const attrWorldPos = AttributeMap.findAttribute(\"a_worldPos\", TechniqueId.SkySphereGradient, false);\r\n assert(attrWorldPos !== undefined);\r\n this._params.buffers.addBuffer(this._worldPosBuff, [BufferParameters.create(attrWorldPos.location, 3, GL.DataType.Float, false, 0, 0, false)]);\r\n }\r\n\r\n private _setPointsFromFrustum(target: Target) {\r\n const frustum = target.planFrustum;\r\n const wp = this.worldPos;\r\n\r\n const lb = frustum.getCorner(Npc.LeftBottomRear).interpolate(0.5, frustum.getCorner(Npc.LeftBottomFront), scratchPoint3a);\r\n const rb = frustum.getCorner(Npc.RightBottomRear).interpolate(0.5, frustum.getCorner(Npc.RightBottomFront), scratchPoint3b);\r\n const rt = frustum.getCorner(Npc.RightTopRear).interpolate(0.5, frustum.getCorner(Npc.RightTopFront), scratchPoint3c);\r\n if (!target.plan.backgroundMapOn || !target.plan.isGlobeMode3D) {\r\n wp[0] = lb.x;\r\n wp[1] = lb.y;\r\n wp[2] = lb.z;\r\n wp[3] = rb.x;\r\n wp[4] = rb.y;\r\n wp[5] = rb.z;\r\n wp[6] = rt.x;\r\n wp[7] = rt.y;\r\n wp[8] = rt.z;\r\n const lt = frustum.getCorner(Npc.LeftTopRear).interpolate(0.5, frustum.getCorner(Npc.LeftTopFront), scratchPoint3d);\r\n wp[9] = lt.x;\r\n wp[10] = lt.y;\r\n wp[11] = lt.z;\r\n } else {\r\n // Need to fake a different frustum to orient the 4 corners properly.\r\n // First find true frustum center & size.\r\n const fCenter = lb.interpolate(0.5, rt, scratchPoint3d);\r\n const upScreen = Vector3d.createStartEnd(rb, rt, scratchVec3a);\r\n let rightScreen = Vector3d.createStartEnd(lb, rb, scratchVec3b);\r\n const halfWidth = upScreen.magnitude() * 0.5;\r\n const halfHeight = rightScreen.magnitude() * 0.5;\r\n // Find the projection of the globe up onto the frustum plane.\r\n upScreen.normalizeInPlace();\r\n rightScreen.normalizeInPlace();\r\n const projUp = target.plan.upVector.dotProduct(upScreen);\r\n const projRt = target.plan.upVector.dotProduct(rightScreen);\r\n // Find camera position (create one for ortho).\r\n let camPos: Point3d;\r\n if (FrustumUniformType.Perspective === target.uniforms.frustum.type) {\r\n const farLowerLeft = frustum.getCorner(Npc.LeftBottomRear);\r\n const nearLowerLeft = frustum.getCorner(Npc.LeftBottomFront);\r\n const scale = 1.0 / (1.0 - target.planFraction);\r\n const zVec = Vector3d.createStartEnd(farLowerLeft, nearLowerLeft, scratchVec3c);\r\n camPos = fromSumOf(farLowerLeft, zVec, scale, scratchPoint3a);\r\n } else {\r\n const delta = Vector3d.createStartEnd(frustum.getCorner(Npc.LeftBottomRear), frustum.getCorner(Npc.LeftBottomFront), scratchVec3c);\r\n const pseudoCameraHalfAngle = 22.5;\r\n const diagonal = frustum.getCorner(Npc.LeftBottomRear).distance(frustum.getCorner(Npc.RightTopRear));\r\n const focalLength = diagonal / (2 * Math.atan(pseudoCameraHalfAngle * Angle.radiansPerDegree));\r\n let zScale = focalLength / delta.magnitude();\r\n if (zScale < 1.000001)\r\n zScale = 1.000001; // prevent worldEye front being on or inside the frustum front plane\r\n camPos = Point3d.createAdd3Scaled(frustum.getCorner(Npc.LeftBottomRear), .5, frustum.getCorner(Npc.RightTopRear), .5, delta, zScale, scratchPoint3a);\r\n }\r\n // Compute the distance from the camera to the frustum center.\r\n const camDist = camPos.distance(fCenter);\r\n // Now use a fixed camera direction and compute a new frustum center.\r\n const camDir = Vector3d.create(0.0, 1.0, 0.0, scratchVec3c);\r\n fCenter.setFromPoint3d(camPos);\r\n fCenter.addScaledInPlace(camDir, camDist);\r\n // Create an up vector that mimics the projection of the globl up onto the real frustum.\r\n upScreen.set(projRt, 0.0, projUp);\r\n upScreen.normalizeInPlace();\r\n // Compute a new right vector and then compute the 4 points for the sky.\r\n rightScreen = upScreen.crossProduct(camDir, scratchVec3b);\r\n upScreen.scaleInPlace(halfHeight);\r\n rightScreen.scaleInPlace(halfWidth);\r\n wp[0] = fCenter.x - rightScreen.x - upScreen.x; // left bottom\r\n wp[1] = fCenter.y - rightScreen.y - upScreen.y;\r\n wp[2] = fCenter.z - rightScreen.z - upScreen.z;\r\n wp[3] = fCenter.x + rightScreen.x - upScreen.x; // right bottom\r\n wp[4] = fCenter.y + rightScreen.y - upScreen.y;\r\n wp[5] = fCenter.z + rightScreen.z - upScreen.z;\r\n wp[6] = fCenter.x + rightScreen.x + upScreen.x; // right top\r\n wp[7] = fCenter.y + rightScreen.y + upScreen.y;\r\n wp[8] = fCenter.z + rightScreen.z + upScreen.z;\r\n wp[9] = fCenter.x - rightScreen.x + upScreen.x; // left top\r\n wp[10] = fCenter.y - rightScreen.y + upScreen.y;\r\n wp[11] = fCenter.z - rightScreen.z + upScreen.z;\r\n }\r\n }\r\n\r\n protected constructor(params: IndexedGeometryParams, skybox: RenderSkySphereParams | RenderSkyGradientParams, techniqueId: TechniqueId) {\r\n super(params, techniqueId);\r\n\r\n this.worldPos = new Float32Array(4 * 3);\r\n this._worldPosBuff = new BufferHandle(GL.Buffer.Target.ArrayBuffer);\r\n this.typeAndExponents = new Float32Array(3);\r\n this.zenithColor = new Float32Array(3);\r\n this.skyColor = new Float32Array(3);\r\n this.groundColor = new Float32Array(3);\r\n this.nadirColor = new Float32Array(3);\r\n this.zOffset = skybox.zOffset;\r\n\r\n this.rotation = \"sphere\" === skybox.type ? skybox.rotation : 0;\r\n if (skybox.type === \"sphere\") {\r\n this.skyTexture = skybox.texture;\r\n this.typeAndExponents[0] = 0.0;\r\n this.typeAndExponents[1] = 1.0;\r\n this.typeAndExponents[2] = 1.0;\r\n this.zenithColor[0] = 0.0;\r\n this.zenithColor[1] = 0.0;\r\n this.zenithColor[2] = 0.0;\r\n this.nadirColor[0] = 0.0;\r\n this.nadirColor[1] = 0.0;\r\n this.nadirColor[2] = 0.0;\r\n this.skyColor[0] = 0.0;\r\n this.skyColor[1] = 0.0;\r\n this.skyColor[2] = 0.0;\r\n this.groundColor[0] = 0.0;\r\n this.groundColor[1] = 0.0;\r\n this.groundColor[2] = 0.0;\r\n } else {\r\n const gradient = skybox.gradient;\r\n\r\n this.zenithColor[0] = gradient.zenithColor.colors.r / 255.0;\r\n this.zenithColor[1] = gradient.zenithColor.colors.g / 255.0;\r\n this.zenithColor[2] = gradient.zenithColor.colors.b / 255.0;\r\n this.nadirColor[0] = gradient.nadirColor.colors.r / 255.0;\r\n this.nadirColor[1] = gradient.nadirColor.colors.g / 255.0;\r\n this.nadirColor[2] = gradient.nadirColor.colors.b / 255.0;\r\n\r\n if (gradient.twoColor) {\r\n this.typeAndExponents[0] = -1.0;\r\n this.typeAndExponents[1] = 4.0;\r\n this.typeAndExponents[2] = 4.0;\r\n this.skyColor[0] = 0.0;\r\n this.skyColor[1] = 0.0;\r\n this.skyColor[2] = 0.0;\r\n this.groundColor[0] = 0.0;\r\n this.groundColor[1] = 0.0;\r\n this.groundColor[2] = 0.0;\r\n } else {\r\n this.typeAndExponents[0] = 1.0;\r\n this.typeAndExponents[1] = gradient.skyExponent;\r\n this.typeAndExponents[2] = gradient.groundExponent;\r\n this.skyColor[0] = gradient.skyColor.colors.r / 255.0;\r\n this.skyColor[1] = gradient.skyColor.colors.g / 255.0;\r\n this.skyColor[2] = gradient.skyColor.colors.b / 255.0;\r\n this.groundColor[0] = gradient.groundColor.colors.r / 255.0;\r\n this.groundColor[1] = gradient.groundColor.colors.g / 255.0;\r\n this.groundColor[2] = gradient.groundColor.colors.b / 255.0;\r\n }\r\n }\r\n }\r\n\r\n public static createGeometry(skybox: RenderSkySphereParams | RenderSkyGradientParams) {\r\n const params = ViewportQuad.getInstance().createParams();\r\n if (undefined === params)\r\n return undefined;\r\n\r\n const technique = \"sphere\" === skybox.type ? TechniqueId.SkySphereTexture : TechniqueId.SkySphereGradient;\r\n return new SkySphereViewportQuadGeometry(params, skybox, technique);\r\n }\r\n\r\n public override get isDisposed(): boolean { return super.isDisposed && this._worldPosBuff.isDisposed; }\r\n\r\n public override dispose() {\r\n super.dispose();\r\n dispose(this._worldPosBuff);\r\n }\r\n}\r\n\r\n/** Geometry used when rendering ambient occlusion information to an output texture\r\n * @internal\r\n */\r\nexport class AmbientOcclusionGeometry extends TexturedViewportQuadGeometry {\r\n public static createGeometry(depthAndOrder: WebGLTexture) {\r\n const params = ViewportQuad.getInstance().createParams();\r\n if (undefined === params) {\r\n return undefined;\r\n }\r\n\r\n // Will derive positions and normals from depthAndOrder.\r\n return new AmbientOcclusionGeometry(params, [depthAndOrder]);\r\n }\r\n\r\n public get depthAndOrder() { return this._textures[0]; }\r\n public get noise() { return System.instance.noiseTexture!.getHandle()!; }\r\n\r\n private constructor(params: IndexedGeometryParams, textures: WebGLTexture[]) {\r\n super(params, TechniqueId.AmbientOcclusion, textures);\r\n }\r\n}\r\n\r\n/** @internal */\r\nexport class BlurGeometry extends TexturedViewportQuadGeometry {\r\n public readonly blurDir: Vector2d;\r\n\r\n public static createGeometry(texToBlur: WebGLTexture, depthAndOrder: WebGLTexture, blurDir: Vector2d) {\r\n const params = ViewportQuad.getInstance().createParams();\r\n if (undefined === params) {\r\n return undefined;\r\n }\r\n return new BlurGeometry(params, [texToBlur, depthAndOrder], blurDir);\r\n }\r\n\r\n public get textureToBlur() { return this._textures[0]; }\r\n public get depthAndOrder() { return this._textures[1]; }\r\n\r\n private constructor(params: IndexedGeometryParams, textures: WebGLTexture[], blurDir: Vector2d) {\r\n super(params, TechniqueId.Blur, textures);\r\n this.blurDir = blurDir;\r\n }\r\n}\r\n\r\n/** @internal */\r\nexport class EVSMGeometry extends TexturedViewportQuadGeometry {\r\n public readonly stepSize = new Float32Array(2);\r\n\r\n public static createGeometry(depthBuffer: WebGLTexture, width: number, height: number) {\r\n const params = ViewportQuad.getInstance().createParams();\r\n if (undefined === params)\r\n return undefined;\r\n\r\n return new EVSMGeometry(params, [depthBuffer], width, height);\r\n }\r\n\r\n public get depthTexture() { return this._textures[0]; }\r\n\r\n private constructor(params: IndexedGeometryParams, textures: WebGLTexture[], width: number, height: number) {\r\n super(params, TechniqueId.EVSMFromDepth, textures);\r\n this.stepSize[0] = 1.0 / width;\r\n this.stepSize[1] = 1.0 / height;\r\n }\r\n}\r\n\r\n/** Geometry used during the 'composite' pass to apply transparency and/or hilite effects.\r\n * @internal\r\n */\r\nexport class CompositeGeometry extends TexturedViewportQuadGeometry {\r\n public static createGeometry(opaque: WebGLTexture, accum: WebGLTexture, reveal: WebGLTexture, hilite: WebGLTexture) {\r\n const params = ViewportQuad.getInstance().createParams();\r\n if (undefined === params)\r\n return undefined;\r\n\r\n const textures = [opaque, accum, reveal, hilite];\r\n return new CompositeGeometry(params, textures);\r\n }\r\n\r\n public get opaque() { return this._textures[0]; }\r\n public get accum() { return this._textures[1]; }\r\n public get reveal() { return this._textures[2]; }\r\n public get hilite() { return this._textures[3]; }\r\n public get occlusion(): WebGLTexture | undefined {\r\n return this._textures.length > 4 ? this._textures[4] : undefined;\r\n }\r\n public set occlusion(occlusion: WebGLTexture | undefined) {\r\n assert((undefined === occlusion) === (undefined !== this.occlusion));\r\n if (undefined !== occlusion)\r\n this._textures[4] = occlusion;\r\n else\r\n this._textures.length = 4;\r\n }\r\n\r\n // Invoked each frame to determine the appropriate Technique to use.\r\n public update(flags: CompositeFlags): void { this._techniqueId = this.determineTechnique(flags); }\r\n\r\n private determineTechnique(flags: CompositeFlags): TechniqueId {\r\n return computeCompositeTechniqueId(flags);\r\n }\r\n\r\n private constructor(params: IndexedGeometryParams, textures: WebGLTexture[]) {\r\n super(params, TechniqueId.CompositeHilite, textures);\r\n assert(4 <= this._textures.length);\r\n }\r\n}\r\n\r\n/** Geometry used to ping-pong the pick buffer data in between opaque passes.\r\n * @internal\r\n */\r\nexport class CopyPickBufferGeometry extends TexturedViewportQuadGeometry {\r\n public static createGeometry(featureId: WebGLTexture, depthAndOrder: WebGLTexture) {\r\n const params = ViewportQuad.getInstance().createParams();\r\n if (undefined !== params) {\r\n return new CopyPickBufferGeometry(params, [featureId, depthAndOrder]);\r\n } else {\r\n return undefined;\r\n }\r\n }\r\n\r\n public get featureId() { return this._textures[0]; }\r\n public get depthAndOrder() { return this._textures[1]; }\r\n\r\n private constructor(params: IndexedGeometryParams, textures: WebGLTexture[]) {\r\n super(params, TechniqueId.CopyPickBuffers, textures);\r\n }\r\n}\r\nexport class CombineTexturesGeometry extends TexturedViewportQuadGeometry {\r\n public static createGeometry(texture0: WebGLTexture, texture1: WebGLTexture) {\r\n const params = ViewportQuad.getInstance().createParams();\r\n if (undefined !== params) {\r\n return new CombineTexturesGeometry(params, [texture0, texture1]);\r\n } else {\r\n return undefined;\r\n }\r\n }\r\n\r\n public get texture0() { return this._textures[0]; }\r\n public get texture1() { return this._textures[1]; }\r\n\r\n private constructor(params: IndexedGeometryParams, textures: WebGLTexture[]) {\r\n super(params, TechniqueId.CombineTextures, textures);\r\n }\r\n}\r\n\r\nexport class Combine3TexturesGeometry extends TexturedViewportQuadGeometry {\r\n public static createGeometry(texture0: WebGLTexture, texture1: WebGLTexture, texture2: WebGLTexture) {\r\n const params = ViewportQuad.getInstance().createParams();\r\n if (undefined !== params) {\r\n return new Combine3TexturesGeometry(params, [texture0, texture1, texture2]);\r\n } else {\r\n return undefined;\r\n }\r\n }\r\n\r\n public get texture0() { return this._textures[0]; }\r\n public get texture1() { return this._textures[1]; }\r\n public get texture2() { return this._textures[2]; }\r\n\r\n private constructor(params: IndexedGeometryParams, textures: WebGLTexture[]) {\r\n super(params, TechniqueId.Combine3Textures, textures);\r\n }\r\n}\r\n\r\n/** @internal */\r\nexport class SingleTexturedViewportQuadGeometry extends TexturedViewportQuadGeometry {\r\n public static createGeometry(texture: WebGLTexture, techId: TechniqueId) {\r\n const params = ViewportQuad.getInstance().createParams();\r\n if (undefined === params) {\r\n return undefined;\r\n }\r\n\r\n return new SingleTexturedViewportQuadGeometry(params, texture, techId);\r\n }\r\n\r\n public get texture(): WebGLTexture { return this._textures[0]; }\r\n public set texture(texture: WebGLTexture) { this._textures[0] = texture; }\r\n\r\n protected constructor(params: IndexedGeometryParams, texture: WebGLTexture, techId: TechniqueId) {\r\n super(params, techId, [texture]);\r\n }\r\n}\r\n\r\n/** @internal */\r\nexport enum BoundaryType {\r\n Outside = 0,\r\n Inside = 1,\r\n Selected = 2,\r\n}\r\n\r\n/** @internal */\r\nexport class VolumeClassifierGeometry extends SingleTexturedViewportQuadGeometry {\r\n public boundaryType: BoundaryType = BoundaryType.Inside;\r\n\r\n public static createVCGeometry(texture: WebGLTexture) {\r\n const params = ViewportQuad.getInstance().createParams();\r\n if (undefined === params)\r\n return undefined;\r\n return new VolumeClassifierGeometry(params, texture);\r\n }\r\n\r\n private constructor(params: IndexedGeometryParams, texture: WebGLTexture) {\r\n super(params, texture, TechniqueId.VolClassSetBlend);\r\n }\r\n}\r\n\r\n/** A geometric primitive which renders gl points using gl.drawArrays() with one vertex buffer.\r\n * @internal\r\n */\r\nexport class ScreenPointsGeometry extends CachedGeometry {\r\n protected _numPoints: number;\r\n protected _origin: Float32Array;\r\n protected _scale: Float32Array;\r\n protected _positions: QBufferHandle2d;\r\n public readonly buffers: BuffersContainer;\r\n public readonly zTexture: WebGLTexture;\r\n\r\n protected constructor(vertices: QPoint2dList, zTexture: WebGLTexture) {\r\n super();\r\n\r\n this.zTexture = zTexture;\r\n\r\n this._numPoints = vertices.length;\r\n\r\n this._positions = QBufferHandle2d.create(vertices.params, vertices.toTypedArray())!;\r\n\r\n this._origin = new Float32Array(3);\r\n this._origin[0] = this._positions.params[0];\r\n this._origin[1] = this._positions.params[1];\r\n this._origin[2] = 0.0;\r\n this._scale = new Float32Array(3);\r\n this._scale[0] = this._positions.params[2];\r\n this._scale[1] = this._positions.params[3];\r\n this._scale[2] = this._positions.params[3]; // just copy the scale from y\r\n\r\n this.buffers = BuffersContainer.create();\r\n const attrPos = AttributeMap.findAttribute(\"a_pos\", TechniqueId.VolClassCopyZ, false);\r\n assert(attrPos !== undefined);\r\n this.buffers.addBuffer(this._positions, [BufferParameters.create(attrPos.location, 2, GL.DataType.UnsignedShort, false, 0, 0, false)]);\r\n }\r\n\r\n public static createGeometry(width: number, height: number, depth: WebGLTexture): ScreenPointsGeometry {\r\n const pixWidth = 2.0 / width;\r\n const pixHeight = 2.0 / height;\r\n\r\n const startX = pixWidth * 0.5 - 1.0;\r\n const startY = pixHeight * 0.5 - 1.0;\r\n\r\n const pt = new Point2d(startX, startY);\r\n const vertices = new QPoint2dList(QParams2d.fromNormalizedRange());\r\n\r\n for (let y = 0; y < height; ++y) {\r\n pt.x = startX;\r\n for (let x = 0; x < width; ++x) {\r\n vertices.add(pt);\r\n pt.x += pixWidth;\r\n }\r\n pt.y += pixHeight;\r\n }\r\n return new ScreenPointsGeometry(vertices, depth);\r\n }\r\n\r\n public draw(): void {\r\n this.buffers.bind();\r\n System.instance.context.drawArrays(GL.PrimitiveType.Points, 0, this._numPoints);\r\n this.buffers.unbind();\r\n }\r\n\r\n public get isDisposed(): boolean { return this.buffers.isDisposed && this._positions.isDisposed; }\r\n\r\n public dispose() {\r\n dispose(this.buffers);\r\n dispose(this._positions);\r\n }\r\n\r\n public collectStatistics(stats: RenderMemory.Statistics): void {\r\n stats.addBuffer(RenderMemory.BufferType.PointStrings, this._positions.bytesUsed);\r\n }\r\n\r\n protected _wantWoWReversal(_target: Target): boolean { return false; }\r\n public get techniqueId(): TechniqueId { return TechniqueId.VolClassCopyZ; }\r\n public getRenderPass(_target: Target) { return RenderPass.Classification; }\r\n public get renderOrder() { return RenderOrder.None; }\r\n public get qOrigin() { return this._origin; }\r\n public get qScale() { return this._scale; }\r\n}\r\n\r\n/** @internal */\r\nexport class PolylineBuffers implements WebGLDisposable {\r\n public buffers: BuffersContainer;\r\n public indices: BufferHandle;\r\n public prevIndices: BufferHandle;\r\n public nextIndicesAndParams: BufferHandle;\r\n private constructor(indices: BufferHandle, prevIndices: BufferHandle, nextIndicesAndParams: BufferHandle) {\r\n this.buffers = BuffersContainer.create();\r\n\r\n const attrPos = AttributeMap.findAttribute(\"a_pos\", TechniqueId.Polyline, false);\r\n const attrPrevIndex = AttributeMap.findAttribute(\"a_prevIndex\", TechniqueId.Polyline, false);\r\n const attrNextIndex = AttributeMap.findAttribute(\"a_nextIndex\", TechniqueId.Polyline, false);\r\n const attrParam = AttributeMap.findAttribute(\"a_param\", TechniqueId.Polyline, false);\r\n assert(attrPos !== undefined);\r\n assert(attrPrevIndex !== undefined);\r\n assert(attrNextIndex !== undefined);\r\n assert(attrParam !== undefined);\r\n\r\n this.buffers.addBuffer(indices, [BufferParameters.create(attrPos.location, 3, GL.DataType.UnsignedByte, false, 0, 0, false)]);\r\n this.buffers.addBuffer(prevIndices, [BufferParameters.create(attrPrevIndex.location, 3, GL.DataType.UnsignedByte, false, 0, 0, false)]);\r\n this.buffers.addBuffer(nextIndicesAndParams, [\r\n BufferParameters.create(attrNextIndex.location, 3, GL.DataType.UnsignedByte, false, 4, 0, false),\r\n BufferParameters.create(attrParam.location, 1, GL.DataType.UnsignedByte, false, 4, 3, false),\r\n ]);\r\n\r\n this.indices = indices;\r\n this.prevIndices = prevIndices;\r\n this.nextIndicesAndParams = nextIndicesAndParams;\r\n }\r\n\r\n public static create(polyline: TesselatedPolyline): PolylineBuffers | undefined {\r\n const indices = BufferHandle.createArrayBuffer(polyline.indices.data);\r\n const prev = BufferHandle.createArrayBuffer(polyline.prevIndices.data);\r\n const next = BufferHandle.createArrayBuffer(polyline.nextIndicesAndParams);\r\n return undefined !== indices && undefined !== prev && undefined !== next ? new PolylineBuffers(indices, prev, next) : undefined;\r\n }\r\n\r\n public collectStatistics(stats: RenderMemory.Statistics, type: RenderMemory.BufferType): void {\r\n stats.addBuffer(type, this.indices.bytesUsed + this.prevIndices.bytesUsed + this.nextIndicesAndParams.bytesUsed);\r\n }\r\n\r\n public get isDisposed(): boolean {\r\n return this.buffers.isDisposed\r\n && this.indices.isDisposed\r\n && this.prevIndices.isDisposed\r\n && this.nextIndicesAndParams.isDisposed;\r\n }\r\n\r\n public dispose() {\r\n dispose(this.buffers);\r\n dispose(this.indices);\r\n dispose(this.prevIndices);\r\n dispose(this.nextIndicesAndParams);\r\n }\r\n}\r\n"]}
@@ -142,7 +142,7 @@ export class PrimitiveCommand {
142
142
  return;
143
143
  const target = exec.target;
144
144
  const thematic = this.primitive.cachedGeometry.supportsThematicDisplay && target.wantThematicDisplay;
145
- const shadowable = (techniqueId === 0 /* Surface */ || techniqueId === 6 /* RealityMesh */) && target.solarShadowMap.isReady && target.currentViewFlags.shadows && !thematic;
145
+ const shadowable = (techniqueId === 0 /* Surface */ || techniqueId === 7 /* RealityMesh */) && target.solarShadowMap.isReady && target.currentViewFlags.shadows && !thematic;
146
146
  const isShadowable = shadowable ? 1 /* Yes */ : 0 /* No */;
147
147
  let isThematic = thematic ? 1 /* Yes */ : 0 /* No */;
148
148
  const isClassified = (undefined !== target.currentPlanarClassifierOrDrape || undefined !== target.activeVolumeClassifierTexture) ? 1 /* Yes */ : 0 /* No */;
@@ -151,7 +151,7 @@ export class PrimitiveCommand {
151
151
  // Point clouds do not support hillshade or slope mode for thematic display.
152
152
  if (isThematic && (undefined !== this.primitive.cachedGeometry.asPointCloud) && (target.uniforms.thematic.wantSlopeMode || target.uniforms.thematic.wantHillShadeMode))
153
153
  isThematic = 0 /* No */;
154
- const wiremesh = target.currentViewFlags.wiremesh && System.instance.isWebGL2 && (techniqueId === 0 /* Surface */ || techniqueId === 6 /* RealityMesh */);
154
+ const wiremesh = target.currentViewFlags.wiremesh && System.instance.isWebGL2 && (techniqueId === 0 /* Surface */ || techniqueId === 7 /* RealityMesh */);
155
155
  const isWiremesh = wiremesh ? 1 /* Yes */ : 0 /* No */;
156
156
  const flags = PrimitiveCommand._scratchTechniqueFlags;
157
157
  flags.init(target, exec.renderPass, isInstanced, isAnimated, isClassified, isShadowable, isThematic, isWiremesh);
@@ -0,0 +1,51 @@
1
+ /** @packageDocumentation
2
+ * @module WebGL
3
+ */
4
+ import { EdgeTable, IndexedEdgeParams } from "../primitives/EdgeParams";
5
+ import { RenderMemory } from "../RenderMemory";
6
+ import { TextureHandle } from "./Texture";
7
+ import { BuffersContainer } from "./AttributeBuffers";
8
+ import { WebGLDisposable } from "./Disposable";
9
+ import { MeshData } from "./MeshData";
10
+ import { MeshGeometry } from "./MeshGeometry";
11
+ import { TechniqueId } from "./TechniqueId";
12
+ import { Target } from "./Target";
13
+ import { ShaderProgramParams } from "./DrawCommand";
14
+ import { RenderOrder } from "./RenderFlags";
15
+ /** @see [[EdgeTable]]
16
+ * @internal
17
+ */
18
+ export declare class EdgeLUT implements WebGLDisposable {
19
+ readonly texture: TextureHandle;
20
+ readonly numSegments: number;
21
+ readonly silhouettePadding: number;
22
+ private constructor();
23
+ dispose(): void;
24
+ static create(table: EdgeTable): EdgeLUT | undefined;
25
+ get bytesUsed(): number;
26
+ get isDisposed(): boolean;
27
+ }
28
+ /** @see [[IndexedEdgeParams]]
29
+ * @internal
30
+ */
31
+ export declare class IndexedEdgeGeometry extends MeshGeometry {
32
+ private readonly _buffers;
33
+ private readonly _indices;
34
+ readonly edgeLut: EdgeLUT;
35
+ get lutBuffers(): BuffersContainer;
36
+ get asIndexedEdge(): this;
37
+ private constructor();
38
+ dispose(): void;
39
+ get isDisposed(): boolean;
40
+ static create(mesh: MeshData, params: IndexedEdgeParams): IndexedEdgeGeometry | undefined;
41
+ collectStatistics(stats: RenderMemory.Statistics): void;
42
+ protected _draw(numInstances: number, instances?: BuffersContainer): void;
43
+ protected _wantWoWReversal(): boolean;
44
+ protected _getLineCode(params: ShaderProgramParams): number;
45
+ get techniqueId(): TechniqueId;
46
+ getRenderPass(target: Target): import("./RenderFlags").RenderPass;
47
+ get renderOrder(): RenderOrder;
48
+ getColor(target: Target): import("./ColorInfo").ColorInfo;
49
+ wantMonochrome(target: Target): boolean;
50
+ }
51
+ //# sourceMappingURL=IndexedEdgeGeometry.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"IndexedEdgeGeometry.d.ts","sourceRoot":"","sources":["../../../../src/render/webgl/IndexedEdgeGeometry.ts"],"names":[],"mappings":"AAIA;;GAEG;AAIH,OAAO,EAAE,SAAS,EAAE,iBAAiB,EAAE,MAAM,0BAA0B,CAAC;AACxE,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,aAAa,EAAE,MAAM,WAAW,CAAC;AAC1C,OAAO,EAAkC,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AACtF,OAAO,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAC/C,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AACtC,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAE9C,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAG5C,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAClC,OAAO,EAAE,mBAAmB,EAAE,MAAM,eAAe,CAAC;AACpD,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAE5C;;GAEG;AACH,qBAAa,OAAQ,YAAW,eAAe;IAC7C,SAAgB,OAAO,EAAE,aAAa,CAAC;IACvC,SAAgB,WAAW,EAAE,MAAM,CAAC;IACpC,SAAgB,iBAAiB,EAAE,MAAM,CAAC;IAE1C,OAAO;IAMA,OAAO,IAAI,IAAI;WAIR,MAAM,CAAC,KAAK,EAAE,SAAS,GAAG,OAAO,GAAG,SAAS;IAK3D,IAAW,SAAS,IAAI,MAAM,CAE7B;IAED,IAAW,UAAU,IAAI,OAAO,CAE/B;CACF;AAED;;GAEG;AACH,qBAAa,mBAAoB,SAAQ,YAAY;IACnD,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAmB;IAC5C,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAe;IACxC,SAAgB,OAAO,EAAE,OAAO,CAAC;IAEjC,IAAW,UAAU,qBAA4B;IACjD,IAAoB,aAAa,SAAmB;IAEpD,OAAO;IAUA,OAAO,IAAI,IAAI;IAMtB,IAAW,UAAU,IAAI,OAAO,CAE/B;WAEa,MAAM,CAAC,IAAI,EAAE,QAAQ,EAAE,MAAM,EAAE,iBAAiB,GAAG,mBAAmB,GAAG,SAAS;IAMzF,iBAAiB,CAAC,KAAK,EAAE,YAAY,CAAC,UAAU,GAAG,IAAI;IAK9D,SAAS,CAAC,KAAK,CAAC,YAAY,EAAE,MAAM,EAAE,SAAS,CAAC,EAAE,gBAAgB,GAAG,IAAI;IAOzE,SAAS,CAAC,gBAAgB,IAAI,OAAO;cAClB,YAAY,CAAC,MAAM,EAAE,mBAAmB,GAAG,MAAM;IAEpE,IAAW,WAAW,gBAAsC;IACrD,aAAa,CAAC,MAAM,EAAE,MAAM;IACnC,IAAW,WAAW,gBAAwE;IAC9E,QAAQ,CAAC,MAAM,EAAE,MAAM;IACvB,cAAc,CAAC,MAAM,EAAE,MAAM;CAC9C"}