@itwin/core-frontend 4.10.0-dev.3 → 4.10.0-dev.6

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 (293) hide show
  1. package/lib/cjs/DisplayStyleState.d.ts.map +1 -1
  2. package/lib/cjs/DisplayStyleState.js +5 -1
  3. package/lib/cjs/DisplayStyleState.js.map +1 -1
  4. package/lib/cjs/ElementLocateManager.d.ts +7 -1
  5. package/lib/cjs/ElementLocateManager.d.ts.map +1 -1
  6. package/lib/cjs/ElementLocateManager.js +34 -10
  7. package/lib/cjs/ElementLocateManager.js.map +1 -1
  8. package/lib/cjs/NoRenderApp.d.ts +1 -0
  9. package/lib/cjs/NoRenderApp.d.ts.map +1 -1
  10. package/lib/cjs/NoRenderApp.js +1 -0
  11. package/lib/cjs/NoRenderApp.js.map +1 -1
  12. package/lib/cjs/Viewport.d.ts +25 -1
  13. package/lib/cjs/Viewport.d.ts.map +1 -1
  14. package/lib/cjs/Viewport.js +20 -12
  15. package/lib/cjs/Viewport.js.map +1 -1
  16. package/lib/cjs/common/imdl/ImdlModel.d.ts +3 -8
  17. package/lib/cjs/common/imdl/ImdlModel.d.ts.map +1 -1
  18. package/lib/cjs/common/imdl/ImdlModel.js.map +1 -1
  19. package/lib/cjs/common/internal/Symbols.d.ts +7 -0
  20. package/lib/cjs/common/internal/Symbols.d.ts.map +1 -1
  21. package/lib/cjs/common/internal/Symbols.js +8 -1
  22. package/lib/cjs/common/internal/Symbols.js.map +1 -1
  23. package/lib/cjs/common/internal/render/InstancedGraphicPropsBuilder.d.ts +15 -0
  24. package/lib/cjs/common/internal/render/InstancedGraphicPropsBuilder.d.ts.map +1 -0
  25. package/lib/cjs/common/internal/render/InstancedGraphicPropsBuilder.js +95 -0
  26. package/lib/cjs/common/internal/render/InstancedGraphicPropsBuilder.js.map +1 -0
  27. package/lib/cjs/common/internal/render/LineCode.d.ts +9 -0
  28. package/lib/cjs/common/internal/render/LineCode.d.ts.map +1 -0
  29. package/lib/cjs/common/internal/render/LineCode.js +31 -0
  30. package/lib/cjs/common/internal/render/LineCode.js.map +1 -0
  31. package/lib/cjs/common/internal/render/OvrFlags.d.ts +25 -0
  32. package/lib/cjs/common/internal/render/OvrFlags.d.ts.map +1 -0
  33. package/lib/cjs/common/internal/render/OvrFlags.js +10 -0
  34. package/lib/cjs/common/internal/render/OvrFlags.js.map +1 -0
  35. package/lib/cjs/common/render/InstancedGraphicParams.d.ts +25 -1
  36. package/lib/cjs/common/render/InstancedGraphicParams.d.ts.map +1 -1
  37. package/lib/cjs/common/render/InstancedGraphicParams.js +59 -0
  38. package/lib/cjs/common/render/InstancedGraphicParams.js.map +1 -1
  39. package/lib/cjs/common/render/RenderInstancesParams.d.ts +76 -0
  40. package/lib/cjs/common/render/RenderInstancesParams.d.ts.map +1 -0
  41. package/lib/cjs/common/render/RenderInstancesParams.js +33 -0
  42. package/lib/cjs/common/render/RenderInstancesParams.js.map +1 -0
  43. package/lib/cjs/common.d.ts +1 -0
  44. package/lib/cjs/common.d.ts.map +1 -1
  45. package/lib/cjs/common.js +1 -0
  46. package/lib/cjs/common.js.map +1 -1
  47. package/lib/cjs/core-frontend.d.ts +1 -0
  48. package/lib/cjs/core-frontend.d.ts.map +1 -1
  49. package/lib/cjs/core-frontend.js +1 -0
  50. package/lib/cjs/core-frontend.js.map +1 -1
  51. package/lib/cjs/internal/render/PrimitiveBuilder.d.ts +4 -1
  52. package/lib/cjs/internal/render/PrimitiveBuilder.d.ts.map +1 -1
  53. package/lib/cjs/internal/render/PrimitiveBuilder.js +82 -35
  54. package/lib/cjs/internal/render/PrimitiveBuilder.js.map +1 -1
  55. package/lib/cjs/internal/render/RenderGeometry.d.ts +20 -0
  56. package/lib/cjs/internal/render/RenderGeometry.d.ts.map +1 -0
  57. package/lib/cjs/internal/render/RenderGeometry.js +10 -0
  58. package/lib/cjs/internal/render/RenderGeometry.js.map +1 -0
  59. package/lib/cjs/internal/render/RenderInstancesParamsImpl.d.ts +24 -0
  60. package/lib/cjs/internal/render/RenderInstancesParamsImpl.d.ts.map +1 -0
  61. package/lib/cjs/internal/render/RenderInstancesParamsImpl.js +69 -0
  62. package/lib/cjs/internal/render/RenderInstancesParamsImpl.js.map +1 -0
  63. package/lib/cjs/render/GraphicBuilder.d.ts +17 -3
  64. package/lib/cjs/render/GraphicBuilder.d.ts.map +1 -1
  65. package/lib/cjs/render/GraphicBuilder.js +7 -1
  66. package/lib/cjs/render/GraphicBuilder.js.map +1 -1
  67. package/lib/cjs/render/GraphicTemplate.d.ts +76 -0
  68. package/lib/cjs/render/GraphicTemplate.d.ts.map +1 -0
  69. package/lib/cjs/render/GraphicTemplate.js +41 -0
  70. package/lib/cjs/render/GraphicTemplate.js.map +1 -0
  71. package/lib/cjs/render/MockRender.d.ts +12 -2
  72. package/lib/cjs/render/MockRender.d.ts.map +1 -1
  73. package/lib/cjs/render/MockRender.js +19 -5
  74. package/lib/cjs/render/MockRender.js.map +1 -1
  75. package/lib/cjs/render/RenderSystem.d.ts +58 -10
  76. package/lib/cjs/render/RenderSystem.d.ts.map +1 -1
  77. package/lib/cjs/render/RenderSystem.js +42 -4
  78. package/lib/cjs/render/RenderSystem.js.map +1 -1
  79. package/lib/cjs/render/RenderTarget.d.ts +1 -1
  80. package/lib/cjs/render/RenderTarget.d.ts.map +1 -1
  81. package/lib/cjs/render/RenderTarget.js.map +1 -1
  82. package/lib/cjs/render/webgl/BatchUniforms.js.map +1 -1
  83. package/lib/cjs/render/webgl/EdgeSettings.d.ts +2 -1
  84. package/lib/cjs/render/webgl/EdgeSettings.d.ts.map +1 -1
  85. package/lib/cjs/render/webgl/EdgeSettings.js.map +1 -1
  86. package/lib/cjs/render/webgl/FeatureOverrides.d.ts +1 -0
  87. package/lib/cjs/render/webgl/FeatureOverrides.d.ts.map +1 -1
  88. package/lib/cjs/render/webgl/FeatureOverrides.js +37 -20
  89. package/lib/cjs/render/webgl/FeatureOverrides.js.map +1 -1
  90. package/lib/cjs/render/webgl/InstancedGeometry.d.ts +40 -10
  91. package/lib/cjs/render/webgl/InstancedGeometry.d.ts.map +1 -1
  92. package/lib/cjs/render/webgl/InstancedGeometry.js +99 -31
  93. package/lib/cjs/render/webgl/InstancedGeometry.js.map +1 -1
  94. package/lib/cjs/render/webgl/LineCode.d.ts.map +1 -1
  95. package/lib/cjs/render/webgl/LineCode.js +2 -14
  96. package/lib/cjs/render/webgl/LineCode.js.map +1 -1
  97. package/lib/cjs/render/webgl/Mesh.d.ts +9 -4
  98. package/lib/cjs/render/webgl/Mesh.d.ts.map +1 -1
  99. package/lib/cjs/render/webgl/Mesh.js +18 -16
  100. package/lib/cjs/render/webgl/Mesh.js.map +1 -1
  101. package/lib/cjs/render/webgl/PointCloud.d.ts +5 -1
  102. package/lib/cjs/render/webgl/PointCloud.d.ts.map +1 -1
  103. package/lib/cjs/render/webgl/PointCloud.js +7 -2
  104. package/lib/cjs/render/webgl/PointCloud.js.map +1 -1
  105. package/lib/cjs/render/webgl/PointString.d.ts +5 -1
  106. package/lib/cjs/render/webgl/PointString.d.ts.map +1 -1
  107. package/lib/cjs/render/webgl/PointString.js +8 -3
  108. package/lib/cjs/render/webgl/PointString.js.map +1 -1
  109. package/lib/cjs/render/webgl/Polyline.d.ts +5 -1
  110. package/lib/cjs/render/webgl/Polyline.d.ts.map +1 -1
  111. package/lib/cjs/render/webgl/Polyline.js +7 -2
  112. package/lib/cjs/render/webgl/Polyline.js.map +1 -1
  113. package/lib/cjs/render/webgl/Primitive.d.ts +1 -3
  114. package/lib/cjs/render/webgl/Primitive.d.ts.map +1 -1
  115. package/lib/cjs/render/webgl/Primitive.js +1 -6
  116. package/lib/cjs/render/webgl/Primitive.js.map +1 -1
  117. package/lib/cjs/render/webgl/RealityMesh.d.ts +5 -1
  118. package/lib/cjs/render/webgl/RealityMesh.d.ts.map +1 -1
  119. package/lib/cjs/render/webgl/RealityMesh.js +6 -0
  120. package/lib/cjs/render/webgl/RealityMesh.js.map +1 -1
  121. package/lib/cjs/render/webgl/RenderFlags.d.ts +0 -18
  122. package/lib/cjs/render/webgl/RenderFlags.d.ts.map +1 -1
  123. package/lib/cjs/render/webgl/RenderFlags.js.map +1 -1
  124. package/lib/cjs/render/webgl/System.d.ts +11 -5
  125. package/lib/cjs/render/webgl/System.d.ts.map +1 -1
  126. package/lib/cjs/render/webgl/System.js +81 -13
  127. package/lib/cjs/render/webgl/System.js.map +1 -1
  128. package/lib/cjs/render/webgl/Target.d.ts +6 -2
  129. package/lib/cjs/render/webgl/Target.d.ts.map +1 -1
  130. package/lib/cjs/render/webgl/Target.js +23 -1
  131. package/lib/cjs/render/webgl/Target.js.map +1 -1
  132. package/lib/cjs/render/webgl/Texture.d.ts +2 -1
  133. package/lib/cjs/render/webgl/Texture.d.ts.map +1 -1
  134. package/lib/cjs/render/webgl/Texture.js.map +1 -1
  135. package/lib/cjs/render/webgl/glsl/FeatureSymbology.d.ts.map +1 -1
  136. package/lib/cjs/render/webgl/glsl/FeatureSymbology.js +6 -0
  137. package/lib/cjs/render/webgl/glsl/FeatureSymbology.js.map +1 -1
  138. package/lib/cjs/tile/GltfReader.d.ts +27 -7
  139. package/lib/cjs/tile/GltfReader.d.ts.map +1 -1
  140. package/lib/cjs/tile/GltfReader.js +84 -68
  141. package/lib/cjs/tile/GltfReader.js.map +1 -1
  142. package/lib/cjs/tile/ImdlGraphicsCreator.d.ts +4 -1
  143. package/lib/cjs/tile/ImdlGraphicsCreator.d.ts.map +1 -1
  144. package/lib/cjs/tile/ImdlGraphicsCreator.js +32 -22
  145. package/lib/cjs/tile/ImdlGraphicsCreator.js.map +1 -1
  146. package/lib/esm/DisplayStyleState.d.ts.map +1 -1
  147. package/lib/esm/DisplayStyleState.js +5 -1
  148. package/lib/esm/DisplayStyleState.js.map +1 -1
  149. package/lib/esm/ElementLocateManager.d.ts +7 -1
  150. package/lib/esm/ElementLocateManager.d.ts.map +1 -1
  151. package/lib/esm/ElementLocateManager.js +34 -10
  152. package/lib/esm/ElementLocateManager.js.map +1 -1
  153. package/lib/esm/NoRenderApp.d.ts +1 -0
  154. package/lib/esm/NoRenderApp.d.ts.map +1 -1
  155. package/lib/esm/NoRenderApp.js +1 -0
  156. package/lib/esm/NoRenderApp.js.map +1 -1
  157. package/lib/esm/Viewport.d.ts +25 -1
  158. package/lib/esm/Viewport.d.ts.map +1 -1
  159. package/lib/esm/Viewport.js +20 -12
  160. package/lib/esm/Viewport.js.map +1 -1
  161. package/lib/esm/common/imdl/ImdlModel.d.ts +3 -8
  162. package/lib/esm/common/imdl/ImdlModel.d.ts.map +1 -1
  163. package/lib/esm/common/imdl/ImdlModel.js.map +1 -1
  164. package/lib/esm/common/internal/Symbols.d.ts +7 -0
  165. package/lib/esm/common/internal/Symbols.d.ts.map +1 -1
  166. package/lib/esm/common/internal/Symbols.js +7 -0
  167. package/lib/esm/common/internal/Symbols.js.map +1 -1
  168. package/lib/esm/common/internal/render/InstancedGraphicPropsBuilder.d.ts +15 -0
  169. package/lib/esm/common/internal/render/InstancedGraphicPropsBuilder.d.ts.map +1 -0
  170. package/lib/esm/common/internal/render/InstancedGraphicPropsBuilder.js +91 -0
  171. package/lib/esm/common/internal/render/InstancedGraphicPropsBuilder.js.map +1 -0
  172. package/lib/esm/common/internal/render/LineCode.d.ts +9 -0
  173. package/lib/esm/common/internal/render/LineCode.d.ts.map +1 -0
  174. package/lib/esm/common/internal/render/LineCode.js +27 -0
  175. package/lib/esm/common/internal/render/LineCode.js.map +1 -0
  176. package/lib/esm/common/internal/render/OvrFlags.d.ts +25 -0
  177. package/lib/esm/common/internal/render/OvrFlags.d.ts.map +1 -0
  178. package/lib/esm/common/internal/render/OvrFlags.js +9 -0
  179. package/lib/esm/common/internal/render/OvrFlags.js.map +1 -0
  180. package/lib/esm/common/render/InstancedGraphicParams.d.ts +25 -1
  181. package/lib/esm/common/render/InstancedGraphicParams.d.ts.map +1 -1
  182. package/lib/esm/common/render/InstancedGraphicParams.js +58 -1
  183. package/lib/esm/common/render/InstancedGraphicParams.js.map +1 -1
  184. package/lib/esm/common/render/RenderInstancesParams.d.ts +76 -0
  185. package/lib/esm/common/render/RenderInstancesParams.d.ts.map +1 -0
  186. package/lib/esm/common/render/RenderInstancesParams.js +30 -0
  187. package/lib/esm/common/render/RenderInstancesParams.js.map +1 -0
  188. package/lib/esm/common.d.ts +1 -0
  189. package/lib/esm/common.d.ts.map +1 -1
  190. package/lib/esm/common.js +1 -0
  191. package/lib/esm/common.js.map +1 -1
  192. package/lib/esm/core-frontend.d.ts +1 -0
  193. package/lib/esm/core-frontend.d.ts.map +1 -1
  194. package/lib/esm/core-frontend.js +1 -0
  195. package/lib/esm/core-frontend.js.map +1 -1
  196. package/lib/esm/internal/render/PrimitiveBuilder.d.ts +4 -1
  197. package/lib/esm/internal/render/PrimitiveBuilder.d.ts.map +1 -1
  198. package/lib/esm/internal/render/PrimitiveBuilder.js +82 -35
  199. package/lib/esm/internal/render/PrimitiveBuilder.js.map +1 -1
  200. package/lib/esm/internal/render/RenderGeometry.d.ts +20 -0
  201. package/lib/esm/internal/render/RenderGeometry.d.ts.map +1 -0
  202. package/lib/esm/internal/render/RenderGeometry.js +9 -0
  203. package/lib/esm/internal/render/RenderGeometry.js.map +1 -0
  204. package/lib/esm/internal/render/RenderInstancesParamsImpl.d.ts +24 -0
  205. package/lib/esm/internal/render/RenderInstancesParamsImpl.d.ts.map +1 -0
  206. package/lib/esm/internal/render/RenderInstancesParamsImpl.js +64 -0
  207. package/lib/esm/internal/render/RenderInstancesParamsImpl.js.map +1 -0
  208. package/lib/esm/render/GraphicBuilder.d.ts +17 -3
  209. package/lib/esm/render/GraphicBuilder.d.ts.map +1 -1
  210. package/lib/esm/render/GraphicBuilder.js +7 -1
  211. package/lib/esm/render/GraphicBuilder.js.map +1 -1
  212. package/lib/esm/render/GraphicTemplate.d.ts +76 -0
  213. package/lib/esm/render/GraphicTemplate.d.ts.map +1 -0
  214. package/lib/esm/render/GraphicTemplate.js +37 -0
  215. package/lib/esm/render/GraphicTemplate.js.map +1 -0
  216. package/lib/esm/render/MockRender.d.ts +12 -2
  217. package/lib/esm/render/MockRender.d.ts.map +1 -1
  218. package/lib/esm/render/MockRender.js +19 -5
  219. package/lib/esm/render/MockRender.js.map +1 -1
  220. package/lib/esm/render/RenderSystem.d.ts +58 -10
  221. package/lib/esm/render/RenderSystem.d.ts.map +1 -1
  222. package/lib/esm/render/RenderSystem.js +44 -6
  223. package/lib/esm/render/RenderSystem.js.map +1 -1
  224. package/lib/esm/render/RenderTarget.d.ts +1 -1
  225. package/lib/esm/render/RenderTarget.d.ts.map +1 -1
  226. package/lib/esm/render/RenderTarget.js.map +1 -1
  227. package/lib/esm/render/webgl/BatchUniforms.js.map +1 -1
  228. package/lib/esm/render/webgl/EdgeSettings.d.ts +2 -1
  229. package/lib/esm/render/webgl/EdgeSettings.d.ts.map +1 -1
  230. package/lib/esm/render/webgl/EdgeSettings.js.map +1 -1
  231. package/lib/esm/render/webgl/FeatureOverrides.d.ts +1 -0
  232. package/lib/esm/render/webgl/FeatureOverrides.d.ts.map +1 -1
  233. package/lib/esm/render/webgl/FeatureOverrides.js +37 -20
  234. package/lib/esm/render/webgl/FeatureOverrides.js.map +1 -1
  235. package/lib/esm/render/webgl/InstancedGeometry.d.ts +40 -10
  236. package/lib/esm/render/webgl/InstancedGeometry.d.ts.map +1 -1
  237. package/lib/esm/render/webgl/InstancedGeometry.js +97 -30
  238. package/lib/esm/render/webgl/InstancedGeometry.js.map +1 -1
  239. package/lib/esm/render/webgl/LineCode.d.ts.map +1 -1
  240. package/lib/esm/render/webgl/LineCode.js +2 -14
  241. package/lib/esm/render/webgl/LineCode.js.map +1 -1
  242. package/lib/esm/render/webgl/Mesh.d.ts +9 -4
  243. package/lib/esm/render/webgl/Mesh.d.ts.map +1 -1
  244. package/lib/esm/render/webgl/Mesh.js +19 -17
  245. package/lib/esm/render/webgl/Mesh.js.map +1 -1
  246. package/lib/esm/render/webgl/PointCloud.d.ts +5 -1
  247. package/lib/esm/render/webgl/PointCloud.d.ts.map +1 -1
  248. package/lib/esm/render/webgl/PointCloud.js +7 -2
  249. package/lib/esm/render/webgl/PointCloud.js.map +1 -1
  250. package/lib/esm/render/webgl/PointString.d.ts +5 -1
  251. package/lib/esm/render/webgl/PointString.d.ts.map +1 -1
  252. package/lib/esm/render/webgl/PointString.js +8 -3
  253. package/lib/esm/render/webgl/PointString.js.map +1 -1
  254. package/lib/esm/render/webgl/Polyline.d.ts +5 -1
  255. package/lib/esm/render/webgl/Polyline.d.ts.map +1 -1
  256. package/lib/esm/render/webgl/Polyline.js +7 -2
  257. package/lib/esm/render/webgl/Polyline.js.map +1 -1
  258. package/lib/esm/render/webgl/Primitive.d.ts +1 -3
  259. package/lib/esm/render/webgl/Primitive.d.ts.map +1 -1
  260. package/lib/esm/render/webgl/Primitive.js +2 -7
  261. package/lib/esm/render/webgl/Primitive.js.map +1 -1
  262. package/lib/esm/render/webgl/RealityMesh.d.ts +5 -1
  263. package/lib/esm/render/webgl/RealityMesh.d.ts.map +1 -1
  264. package/lib/esm/render/webgl/RealityMesh.js +6 -0
  265. package/lib/esm/render/webgl/RealityMesh.js.map +1 -1
  266. package/lib/esm/render/webgl/RenderFlags.d.ts +0 -18
  267. package/lib/esm/render/webgl/RenderFlags.d.ts.map +1 -1
  268. package/lib/esm/render/webgl/RenderFlags.js.map +1 -1
  269. package/lib/esm/render/webgl/System.d.ts +11 -5
  270. package/lib/esm/render/webgl/System.d.ts.map +1 -1
  271. package/lib/esm/render/webgl/System.js +82 -14
  272. package/lib/esm/render/webgl/System.js.map +1 -1
  273. package/lib/esm/render/webgl/Target.d.ts +6 -2
  274. package/lib/esm/render/webgl/Target.d.ts.map +1 -1
  275. package/lib/esm/render/webgl/Target.js +23 -1
  276. package/lib/esm/render/webgl/Target.js.map +1 -1
  277. package/lib/esm/render/webgl/Texture.d.ts +2 -1
  278. package/lib/esm/render/webgl/Texture.d.ts.map +1 -1
  279. package/lib/esm/render/webgl/Texture.js.map +1 -1
  280. package/lib/esm/render/webgl/glsl/FeatureSymbology.d.ts.map +1 -1
  281. package/lib/esm/render/webgl/glsl/FeatureSymbology.js +6 -0
  282. package/lib/esm/render/webgl/glsl/FeatureSymbology.js.map +1 -1
  283. package/lib/esm/tile/GltfReader.d.ts +27 -7
  284. package/lib/esm/tile/GltfReader.d.ts.map +1 -1
  285. package/lib/esm/tile/GltfReader.js +82 -67
  286. package/lib/esm/tile/GltfReader.js.map +1 -1
  287. package/lib/esm/tile/ImdlGraphicsCreator.d.ts +4 -1
  288. package/lib/esm/tile/ImdlGraphicsCreator.d.ts.map +1 -1
  289. package/lib/esm/tile/ImdlGraphicsCreator.js +31 -22
  290. package/lib/esm/tile/ImdlGraphicsCreator.js.map +1 -1
  291. package/lib/public/scripts/parse-imdl-worker.js +1 -1
  292. package/lib/workers/webpack/parse-imdl-worker.js +1 -1
  293. package/package.json +18 -18
@@ -80,7 +80,7 @@ export class FeatureOverrides {
80
80
  assert(undefined !== this._lut.dataBytes);
81
81
  return this._lut.dataBytes;
82
82
  }
83
- _initialize(map, ovrs, hilite, flashed) {
83
+ _initialize(map, ovrs, pickExcludes, hilite, flashed) {
84
84
  const nFeatures = map.numFeatures;
85
85
  const dims = computeWidthAndHeight(nFeatures, 2);
86
86
  const width = dims.width;
@@ -90,21 +90,21 @@ export class FeatureOverrides {
90
90
  this._lutParams[1] = height;
91
91
  const data = new Uint8Array(width * height * 4);
92
92
  const creator = new Texture2DDataUpdater(data);
93
- this.buildLookupTable(creator, map, ovrs, flashed, hilite);
93
+ this.buildLookupTable(creator, map, ovrs, pickExcludes, flashed, hilite);
94
94
  return TextureHandle.createForData(width, height, data, true, GL.Texture.WrapMode.ClampToEdge);
95
95
  }
96
- _update(map, lut, flashed, hilites, ovrs) {
96
+ _update(map, lut, pickExcludes, flashed, hilites, ovrs) {
97
97
  const updater = new Texture2DDataUpdater(lut.dataBytes);
98
98
  if (undefined === ovrs) {
99
- this.updateFlashedAndHilited(updater, map, flashed, hilites);
99
+ this.updateFlashedAndHilited(updater, map, pickExcludes, flashed, hilites);
100
100
  }
101
101
  else {
102
102
  assert(undefined !== hilites);
103
- this.buildLookupTable(updater, map, ovrs, flashed, hilites);
103
+ this.buildLookupTable(updater, map, ovrs, pickExcludes, flashed, hilites);
104
104
  }
105
105
  lut.update(updater);
106
106
  }
107
- buildLookupTable(data, map, ovr, flashedIdParts, hilites) {
107
+ buildLookupTable(data, map, ovr, pickExclude, flashedIdParts, hilites) {
108
108
  const allowHilite = true !== this._options.noHilite;
109
109
  const allowFlash = true !== this._options.noFlash;
110
110
  const allowEmphasis = true !== this._options.noEmphasis;
@@ -192,6 +192,10 @@ export class FeatureOverrides {
192
192
  flags |= 8 /* OvrFlags.IgnoreMaterial */;
193
193
  if (allowFlash && undefined !== flashedIdParts && feature.elementId.lower === flashedIdParts.lower && feature.elementId.upper === flashedIdParts.upper)
194
194
  flags |= 16 /* OvrFlags.Flashed */;
195
+ if (pickExclude?.hasPair(feature.elementId)) {
196
+ flags |= 2048 /* OvrFlags.InvisibleDuringPick */;
197
+ ++nHidden;
198
+ }
195
199
  data.setOvrFlagsAtIndex(dataIndex, flags);
196
200
  if (0 /* OvrFlags.None */ !== flags)
197
201
  nOverridden++;
@@ -201,9 +205,9 @@ export class FeatureOverrides {
201
205
  this.updateUniformSymbologyFlags();
202
206
  }
203
207
  // NB: If hilites is undefined, it means that the hilited set has not changed.
204
- updateFlashedAndHilited(data, map, flashed, hilites) {
208
+ updateFlashedAndHilited(data, map, pickExcludes, flashed, hilites) {
205
209
  if (!hilites || true === this._options.noHilite) {
206
- this.updateFlashed(data, map, flashed);
210
+ this.updateFlashed(data, map, pickExcludes, flashed);
207
211
  return;
208
212
  }
209
213
  const allowFlash = true !== this._options.noFlash;
@@ -229,6 +233,9 @@ export class FeatureOverrides {
229
233
  isFlashed = feature.elementId.lower === flashed.lower && feature.elementId.upper === flashed.upper;
230
234
  let newFlags = isFlashed ? (oldFlags | 16 /* OvrFlags.Flashed */) : (oldFlags & ~16 /* OvrFlags.Flashed */);
231
235
  newFlags = isHilited ? (newFlags | 256 /* OvrFlags.Hilited */) : (newFlags & ~256 /* OvrFlags.Hilited */);
236
+ if (pickExcludes) {
237
+ newFlags = pickExcludes.hasPair(feature.elementId) ? (newFlags | 2048 /* OvrFlags.InvisibleDuringPick */) : (newFlags & ~2048 /* OvrFlags.InvisibleDuringPick */);
238
+ }
232
239
  data.setOvrFlagsAtIndex(dataIndex, newFlags);
233
240
  if (0 /* OvrFlags.None */ !== newFlags) {
234
241
  this._anyOverridden = true;
@@ -237,8 +244,8 @@ export class FeatureOverrides {
237
244
  }
238
245
  this.updateUniformSymbologyFlags();
239
246
  }
240
- updateFlashed(data, map, flashed) {
241
- if (true === this._options.noFlash)
247
+ updateFlashed(data, map, pickExcludes, flashed) {
248
+ if (true === this._options.noFlash && !pickExcludes)
242
249
  return;
243
250
  this._anyOverridden = false;
244
251
  const elemId = { lower: 0, upper: 0 };
@@ -251,11 +258,18 @@ export class FeatureOverrides {
251
258
  continue;
252
259
  }
253
260
  let isFlashed = false;
254
- if (flashed) {
255
- map.getElementIdPair(i, elemId);
256
- isFlashed = elemId.lower === flashed.lower && elemId.upper === flashed.upper;
261
+ let thisElemId;
262
+ if (flashed && !this._options.noFlash) {
263
+ thisElemId = map.getElementIdPair(i, elemId);
264
+ isFlashed = thisElemId.lower === flashed.lower && thisElemId.upper === flashed.upper;
265
+ }
266
+ let newFlags = isFlashed ? (oldFlags | 16 /* OvrFlags.Flashed */) : (oldFlags & ~16 /* OvrFlags.Flashed */);
267
+ if (pickExcludes) {
268
+ if (!thisElemId) {
269
+ thisElemId = map.getElementIdPair(i, elemId);
270
+ }
271
+ newFlags = pickExcludes.hasPair(thisElemId) ? (newFlags | 2048 /* OvrFlags.InvisibleDuringPick */) : (newFlags & ~2048 /* OvrFlags.InvisibleDuringPick */);
257
272
  }
258
- const newFlags = isFlashed ? (oldFlags | 16 /* OvrFlags.Flashed */) : (oldFlags & ~16 /* OvrFlags.Flashed */);
259
273
  data.setOvrFlagsAtIndex(dataIndex, newFlags);
260
274
  if (0 /* OvrFlags.None */ !== newFlags)
261
275
  this._anyOverridden = true;
@@ -265,6 +279,7 @@ export class FeatureOverrides {
265
279
  constructor(target, options, cleanup) {
266
280
  this._lastFlashId = Id64.invalid;
267
281
  this._hiliteSyncObserver = {};
282
+ this._pickExclusionsSyncObserver = {};
268
283
  this._anyOverridden = true;
269
284
  this._allHidden = true;
270
285
  this._anyTranslucent = true;
@@ -295,9 +310,10 @@ export class FeatureOverrides {
295
310
  const ovrs = this.target.currentFeatureSymbologyOverrides;
296
311
  this._mostRecentSymbologyOverrides = ovrs;
297
312
  const hilite = this.target.hilites;
298
- this._lut = this._initialize(map, ovrs, hilite, this.target.flashed);
313
+ this._lut = this._initialize(map, ovrs, this.target.pickExclusions, hilite, this.target.flashed);
299
314
  this._lastFlashId = Id64.invalid;
300
315
  this._hiliteSyncObserver = {};
316
+ this._pickExclusionsSyncObserver = {};
301
317
  }
302
318
  update(features) {
303
319
  let ovrs = this.target.currentFeatureSymbologyOverrides;
@@ -307,13 +323,14 @@ export class FeatureOverrides {
307
323
  else
308
324
  ovrs = undefined;
309
325
  const flashedId = this.target.flashedId;
310
- const hiliteSyncTarget = this.target.hiliteSyncTarget;
311
- const hiliteUpdated = !sync(hiliteSyncTarget, this._hiliteSyncObserver);
312
326
  const hilite = this.target.hilites;
313
- if (ovrsUpdated || hiliteUpdated || flashedId !== this._lastFlashId) {
327
+ const hiliteUpdated = !sync(this.target.hiliteSyncTarget, this._hiliteSyncObserver);
328
+ const pickExcludesUpdated = !sync(this.target.pickExclusionsSyncTarget, this._pickExclusionsSyncObserver);
329
+ if (ovrsUpdated || hiliteUpdated || flashedId !== this._lastFlashId || pickExcludesUpdated) {
314
330
  // _lut can be undefined if context was lost, (gl.createTexture returns null)
315
- if (this._lut)
316
- this._update(features, this._lut, this.target.flashed, undefined !== ovrs || hiliteUpdated ? hilite : undefined, ovrs);
331
+ if (this._lut) {
332
+ this._update(features, this._lut, undefined !== ovrs || pickExcludesUpdated ? this.target.pickExclusions : undefined, this.target.flashed, undefined !== ovrs || hiliteUpdated ? hilite : undefined, ovrs);
333
+ }
317
334
  this._lastFlashId = flashedId;
318
335
  }
319
336
  }
@@ -1 +1 @@
1
- {"version":3,"file":"FeatureOverrides.js","sourceRoot":"","sources":["../../../../src/render/webgl/FeatureOverrides.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, Id64 } from \"@itwin/core-bentley\";\r\nimport { PackedFeature, RenderFeatureTable } from \"@itwin/core-common\";\r\nimport { FeatureSymbology } from \"../FeatureSymbology\";\r\nimport { WebGLDisposable } from \"./Disposable\";\r\nimport { LineCode } from \"./LineCode\";\r\nimport { GL } from \"./GL\";\r\nimport { UniformHandle } from \"./UniformHandle\";\r\nimport { EmphasisFlags, OvrFlags, TextureUnit } from \"./RenderFlags\";\r\nimport { sync, SyncObserver } from \"./Sync\";\r\nimport { System } from \"./System\";\r\nimport { Hilites, Target } from \"./Target\";\r\nimport { Texture2DDataUpdater, Texture2DHandle, TextureHandle } from \"./Texture\";\r\nimport { BatchOptions } from \"../../common/render/BatchOptions\";\r\nimport { DisplayParams } from \"../../common/internal/render/DisplayParams\";\r\n\r\nfunction computeWidthAndHeight(nEntries: number, nRgbaPerEntry: number, nExtraRgba: number = 0, nTables: number = 1): { width: number, height: number } {\r\n const maxSize = System.instance.maxTextureSize;\r\n const nRgba = nEntries * nRgbaPerEntry * nTables + nExtraRgba;\r\n\r\n if (nRgba < maxSize)\r\n return { width: nRgba, height: 1 };\r\n\r\n // Make roughly square to reduce unused space in last row\r\n let width = Math.ceil(Math.sqrt(nRgba));\r\n\r\n // Ensure a given entry's RGBA values all fit on the same row.\r\n const remainder = width % nRgbaPerEntry;\r\n if (0 !== remainder) {\r\n width += nRgbaPerEntry - remainder;\r\n }\r\n\r\n // Compute height\r\n const height = Math.ceil(nRgba / width);\r\n\r\n assert(height <= maxSize);\r\n assert(width <= maxSize);\r\n assert(width * height >= nRgba);\r\n assert(Math.floor(height) === height);\r\n assert(Math.floor(width) === width);\r\n\r\n // Row padding should never be necessary...\r\n assert(0 === width % nRgbaPerEntry);\r\n\r\n return { width, height };\r\n}\r\n\r\nexport function isFeatureHilited(feature: PackedFeature, hilites: Hilites, isModelHilited: boolean): boolean {\r\n if (hilites.isEmpty)\r\n return false;\r\n\r\n if (\"union\" === hilites.modelSubCategoryMode)\r\n return isModelHilited || hilites.elements.hasPair(feature.elementId) || hilites.subcategories.hasPair(feature.subCategoryId);\r\n\r\n return hilites.elements.hasPair(feature.elementId) || (isModelHilited && hilites.subcategories.hasPair(feature.subCategoryId));\r\n}\r\n\r\n/** @internal */\r\nexport type FeatureOverridesCleanup = () => void;\r\n\r\nconst scratchPackedFeature = PackedFeature.createWithIndex();\r\n\r\n/** @internal */\r\nexport class FeatureOverrides implements WebGLDisposable {\r\n public readonly target: Target;\r\n private readonly _options: BatchOptions;\r\n private _lut?: Texture2DHandle;\r\n private _mostRecentSymbologyOverrides?: FeatureSymbology.Overrides;\r\n private _lastFlashId = Id64.invalid;\r\n private _hiliteSyncObserver: SyncObserver = {};\r\n private _anyOverridden = true;\r\n private _allHidden = true;\r\n private _anyTranslucent = true;\r\n private _anyViewIndependentTranslucent = true;\r\n private _anyOpaque = true;\r\n private _anyHilited = true;\r\n private _lutParams = new Float32Array(2);\r\n private _uniformSymbologyFlags: EmphasisFlags = EmphasisFlags.None;\r\n private _cleanup?: FeatureOverridesCleanup;\r\n\r\n public get anyOverridden() { return this._anyOverridden; }\r\n public get allHidden() { return this._allHidden; }\r\n public get anyTranslucent() { return this._anyTranslucent; }\r\n public get anyViewIndependentTranslucent() { return this._anyViewIndependentTranslucent; }\r\n public get anyOpaque() { return this._anyOpaque; }\r\n public get anyHilited() { return this._anyHilited; }\r\n\r\n /** For tests. */\r\n public get lutData(): Uint8Array | undefined { return this._lut?.dataBytes; }\r\n public get byteLength(): number { return undefined !== this._lut ? this._lut.bytesUsed : 0; }\r\n public get isUniform() { return 2 === this._lutParams[0] && 1 === this._lutParams[1]; }\r\n\r\n private updateUniformSymbologyFlags(): void {\r\n this._uniformSymbologyFlags = EmphasisFlags.None;\r\n if (!this.isUniform || !this._lut)\r\n return;\r\n\r\n let flags = this._lut.dataBytes![0];\r\n if (0 !== (flags & OvrFlags.Flashed))\r\n this._uniformSymbologyFlags |= EmphasisFlags.Flashed;\r\n\r\n if (0 !== (flags & OvrFlags.NonLocatable))\r\n this._uniformSymbologyFlags |= EmphasisFlags.NonLocatable;\r\n\r\n if (!this._anyHilited)\r\n return;\r\n\r\n flags = this._lut.dataBytes![1] << 8;\r\n if (0 !== (flags & OvrFlags.Hilited))\r\n this._uniformSymbologyFlags |= EmphasisFlags.Hilite;\r\n\r\n if (0 !== (flags & OvrFlags.Emphasized))\r\n this._uniformSymbologyFlags |= EmphasisFlags.Emphasized;\r\n }\r\n\r\n public getUniformOverrides(): Uint8Array {\r\n assert(this.isUniform);\r\n assert(undefined !== this._lut);\r\n assert(undefined !== this._lut.dataBytes);\r\n return this._lut.dataBytes;\r\n }\r\n\r\n private _initialize(map: RenderFeatureTable, ovrs: FeatureSymbology.Overrides, hilite: Hilites, flashed?: Id64.Uint32Pair): Texture2DHandle | undefined {\r\n const nFeatures = map.numFeatures;\r\n const dims = computeWidthAndHeight(nFeatures, 2);\r\n const width = dims.width;\r\n const height = dims.height;\r\n assert(width * height >= nFeatures);\r\n\r\n this._lutParams[0] = width;\r\n this._lutParams[1] = height;\r\n\r\n const data = new Uint8Array(width * height * 4);\r\n const creator = new Texture2DDataUpdater(data);\r\n this.buildLookupTable(creator, map, ovrs, flashed, hilite);\r\n\r\n return TextureHandle.createForData(width, height, data, true, GL.Texture.WrapMode.ClampToEdge);\r\n }\r\n\r\n private _update(map: RenderFeatureTable, lut: Texture2DHandle, flashed?: Id64.Uint32Pair, hilites?: Hilites, ovrs?: FeatureSymbology.Overrides) {\r\n const updater = new Texture2DDataUpdater(lut.dataBytes!);\r\n\r\n if (undefined === ovrs) {\r\n this.updateFlashedAndHilited(updater, map, flashed, hilites);\r\n } else {\r\n assert(undefined !== hilites);\r\n this.buildLookupTable(updater, map, ovrs, flashed, hilites);\r\n }\r\n\r\n lut.update(updater);\r\n }\r\n\r\n private buildLookupTable(data: Texture2DDataUpdater, map: RenderFeatureTable, ovr: FeatureSymbology.Overrides, flashedIdParts: Id64.Uint32Pair | undefined, hilites: Hilites) {\r\n const allowHilite = true !== this._options.noHilite;\r\n const allowFlash = true !== this._options.noFlash;\r\n const allowEmphasis = true !== this._options.noEmphasis;\r\n\r\n let isModelHilited = false;\r\n const prevModelId = { lower: -1, upper: -1 };\r\n\r\n this._anyOpaque = this._anyTranslucent = this._anyViewIndependentTranslucent = this._anyHilited = false;\r\n\r\n let nHidden = 0;\r\n let nOverridden = 0;\r\n\r\n // NB: We currently use 2 RGBA values per feature as follows:\r\n // [0]\r\n // RG = override flags (see OvrFlags enum)\r\n // B = line code\r\n // A = line weight (if we need an extra byte in future, could combine code+weight into a single byte).\r\n // [1]\r\n // RGB = rgb\r\n // A = alpha\r\n for (const feature of map.iterable(scratchPackedFeature)) {\r\n const i = feature.index;\r\n const dataIndex = i * 4 * 2;\r\n\r\n if (prevModelId.lower !== feature.modelId.lower || prevModelId.upper !== feature.modelId.upper) {\r\n prevModelId.lower = feature.modelId.lower;\r\n prevModelId.upper = feature.modelId.upper;\r\n isModelHilited = allowHilite && hilites.models.hasPair(feature.modelId);\r\n }\r\n\r\n const app = this.target.currentBranch.getFeatureAppearance(\r\n ovr,\r\n feature.elementId.lower, feature.elementId.upper,\r\n feature.subCategoryId.lower, feature.subCategoryId.upper,\r\n feature.geometryClass,\r\n feature.modelId.lower, feature.modelId.upper,\r\n map.type, feature.animationNodeId);\r\n\r\n // NB: If the appearance is fully transparent, then:\r\n // - For normal (\"primary\") models, getAppearance() returns undefined.\r\n // - For classifier models, getAppearance() returns the appearance, and classification shader will discard fully-transparent classified pixels.\r\n // (The latter is how we clip the classified model using the classifiers).\r\n if (undefined === app) {\r\n // The feature is not visible. We don't care about any of the other overrides, because we're not going to render it.\r\n data.setOvrFlagsAtIndex(dataIndex, OvrFlags.Visibility);\r\n nHidden++;\r\n nOverridden++;\r\n continue;\r\n }\r\n\r\n let flags = app.nonLocatable ? OvrFlags.NonLocatable : OvrFlags.None;\r\n if (allowHilite && isFeatureHilited(feature, hilites, isModelHilited)) {\r\n flags |= OvrFlags.Hilited;\r\n this._anyHilited = true;\r\n }\r\n\r\n if (allowEmphasis && app.emphasized) {\r\n flags |= OvrFlags.Emphasized;\r\n this._anyHilited = true;\r\n }\r\n\r\n if (app.overridesRgb && app.rgb) {\r\n flags |= OvrFlags.Rgb;\r\n const rgb = app.rgb;\r\n data.setByteAtIndex(dataIndex + 4, rgb.r);\r\n data.setByteAtIndex(dataIndex + 5, rgb.g);\r\n data.setByteAtIndex(dataIndex + 6, rgb.b);\r\n }\r\n\r\n if (undefined !== app.transparency) {\r\n // transparency in range [0, 1]...convert to byte and invert so 0=transparent...\r\n flags |= OvrFlags.Alpha;\r\n let alpha = 1.0 - app.transparency;\r\n alpha = Math.floor(0xff * alpha + 0.5);\r\n if ((0xff - alpha) < DisplayParams.minTransparency)\r\n alpha = 0xff;\r\n\r\n data.setByteAtIndex(dataIndex + 7, alpha);\r\n if (0xff === alpha) {\r\n this._anyOpaque = true;\r\n } else {\r\n this._anyTranslucent = true;\r\n if (!app.viewDependentTransparency) {\r\n flags |= OvrFlags.ViewIndependentTransparency;\r\n this._anyViewIndependentTranslucent = true;\r\n }\r\n }\r\n }\r\n\r\n if (app.overridesWeight && app.weight) {\r\n flags |= OvrFlags.Weight;\r\n let weight = app.weight;\r\n weight = Math.min(31, weight);\r\n weight = Math.max(1, weight);\r\n data.setByteAtIndex(dataIndex + 3, weight);\r\n }\r\n\r\n if (app.overridesLinePixels && app.linePixels) {\r\n flags |= OvrFlags.LineCode;\r\n const lineCode = LineCode.valueFromLinePixels(app.linePixels);\r\n data.setByteAtIndex(dataIndex + 2, lineCode);\r\n }\r\n\r\n if (app.ignoresMaterial)\r\n flags |= OvrFlags.IgnoreMaterial;\r\n\r\n if (allowFlash && undefined !== flashedIdParts && feature.elementId.lower === flashedIdParts.lower && feature.elementId.upper === flashedIdParts.upper)\r\n flags |= OvrFlags.Flashed;\r\n\r\n data.setOvrFlagsAtIndex(dataIndex, flags);\r\n if (OvrFlags.None !== flags)\r\n nOverridden++;\r\n }\r\n\r\n this._allHidden = (nHidden === map.numFeatures);\r\n this._anyOverridden = (nOverridden > 0);\r\n\r\n this.updateUniformSymbologyFlags();\r\n }\r\n\r\n // NB: If hilites is undefined, it means that the hilited set has not changed.\r\n private updateFlashedAndHilited(data: Texture2DDataUpdater, map: RenderFeatureTable, flashed?: Id64.Uint32Pair, hilites?: Hilites) {\r\n if (!hilites || true === this._options.noHilite) {\r\n this.updateFlashed(data, map, flashed);\r\n return;\r\n }\r\n\r\n const allowFlash = true !== this._options.noFlash;\r\n const intersect = \"intersection\" === hilites.modelSubCategoryMode;\r\n\r\n this._anyOverridden = this._anyHilited = false;\r\n for (const feature of map.iterable(scratchPackedFeature)) {\r\n const dataIndex = feature.index * 4 * 2;\r\n const oldFlags = data.getOvrFlagsAtIndex(dataIndex);\r\n if (OvrFlags.None !== (oldFlags & OvrFlags.Visibility)) {\r\n // If it's invisible, none of the other flags matter. We can't flash it and don't want to hilite it.\r\n this._anyOverridden = true;\r\n continue;\r\n }\r\n\r\n const isModelHilited = hilites.models.hasPair(feature.modelId);\r\n let isHilited = isModelHilited && !intersect;\r\n if (!isHilited)\r\n isHilited = hilites.elements.hasPair(feature.elementId);\r\n\r\n if (!isHilited)\r\n if (isModelHilited || !intersect)\r\n isHilited = hilites.subcategories.hasPair(feature.subCategoryId);\r\n\r\n let isFlashed = false;\r\n if (flashed && allowFlash)\r\n isFlashed = feature.elementId.lower === flashed.lower && feature.elementId.upper === flashed.upper;\r\n\r\n let newFlags = isFlashed ? (oldFlags | OvrFlags.Flashed) : (oldFlags & ~OvrFlags.Flashed);\r\n newFlags = isHilited ? (newFlags | OvrFlags.Hilited) : (newFlags & ~OvrFlags.Hilited);\r\n\r\n data.setOvrFlagsAtIndex(dataIndex, newFlags);\r\n if (OvrFlags.None !== newFlags) {\r\n this._anyOverridden = true;\r\n this._anyHilited = this._anyHilited || isHilited || OvrFlags.None !== (newFlags & OvrFlags.Emphasized);\r\n }\r\n }\r\n\r\n this.updateUniformSymbologyFlags();\r\n }\r\n\r\n private updateFlashed(data: Texture2DDataUpdater, map: RenderFeatureTable, flashed?: Id64.Uint32Pair): void {\r\n if (true === this._options.noFlash)\r\n return;\r\n\r\n this._anyOverridden = false;\r\n const elemId = { lower: 0, upper: 0 };\r\n for (let i = 0; i < map.numFeatures; i++) {\r\n const dataIndex = i * 4 * 2;\r\n const oldFlags = data.getOvrFlagsAtIndex(dataIndex);\r\n if (OvrFlags.None !== (oldFlags & OvrFlags.Visibility)) {\r\n // If it's invisible, none of the other flags matter and we can't flash it.\r\n this._anyOverridden = true;\r\n continue;\r\n }\r\n\r\n let isFlashed = false;\r\n if (flashed) {\r\n map.getElementIdPair(i, elemId);\r\n isFlashed = elemId.lower === flashed.lower && elemId.upper === flashed.upper;\r\n }\r\n\r\n const newFlags = isFlashed ? (oldFlags | OvrFlags.Flashed) : (oldFlags & ~OvrFlags.Flashed);\r\n data.setOvrFlagsAtIndex(dataIndex, newFlags);\r\n if (OvrFlags.None !== newFlags)\r\n this._anyOverridden = true;\r\n }\r\n\r\n this.updateUniformSymbologyFlags();\r\n }\r\n\r\n private constructor(target: Target, options: BatchOptions, cleanup: FeatureOverridesCleanup | undefined) {\r\n this.target = target;\r\n this._options = options;\r\n this._cleanup = cleanup;\r\n }\r\n\r\n public static createFromTarget(target: Target, options: BatchOptions, cleanup: FeatureOverridesCleanup | undefined) {\r\n return new FeatureOverrides(target, options, cleanup);\r\n }\r\n\r\n public get isDisposed(): boolean { return undefined === this._lut; }\r\n\r\n public dispose() {\r\n this._lut = dispose(this._lut);\r\n if (this._cleanup) {\r\n this._cleanup();\r\n this._cleanup = undefined;\r\n }\r\n }\r\n\r\n public initFromMap(map: RenderFeatureTable) {\r\n const nFeatures = map.numFeatures;\r\n assert(0 < nFeatures);\r\n\r\n this._lut = dispose(this._lut);\r\n\r\n const ovrs: FeatureSymbology.Overrides = this.target.currentFeatureSymbologyOverrides;\r\n this._mostRecentSymbologyOverrides = ovrs;\r\n const hilite = this.target.hilites;\r\n this._lut = this._initialize(map, ovrs, hilite, this.target.flashed);\r\n this._lastFlashId = Id64.invalid;\r\n this._hiliteSyncObserver = {};\r\n }\r\n\r\n public update(features: RenderFeatureTable) {\r\n let ovrs: FeatureSymbology.Overrides | undefined = this.target.currentFeatureSymbologyOverrides;\r\n const ovrsUpdated = ovrs !== this._mostRecentSymbologyOverrides;\r\n if (ovrsUpdated)\r\n this._mostRecentSymbologyOverrides = ovrs;\r\n else\r\n ovrs = undefined;\r\n\r\n const flashedId = this.target.flashedId;\r\n\r\n const hiliteSyncTarget = this.target.hiliteSyncTarget;\r\n const hiliteUpdated = !sync(hiliteSyncTarget, this._hiliteSyncObserver);\r\n\r\n const hilite = this.target.hilites;\r\n if (ovrsUpdated || hiliteUpdated || flashedId !== this._lastFlashId) {\r\n // _lut can be undefined if context was lost, (gl.createTexture returns null)\r\n if (this._lut)\r\n this._update(features, this._lut, this.target.flashed, undefined !== ovrs || hiliteUpdated ? hilite : undefined, ovrs);\r\n\r\n this._lastFlashId = flashedId;\r\n }\r\n }\r\n\r\n public bindLUTParams(uniform: UniformHandle): void {\r\n uniform.setUniform2fv(this._lutParams);\r\n }\r\n\r\n public bindLUT(uniform: UniformHandle): void {\r\n if (this._lut)\r\n this._lut.bindSampler(uniform, TextureUnit.FeatureSymbology);\r\n }\r\n\r\n public bindUniformSymbologyFlags(uniform: UniformHandle): void {\r\n uniform.setUniform1f(this._uniformSymbologyFlags);\r\n }\r\n}\r\n"]}
1
+ {"version":3,"file":"FeatureOverrides.js","sourceRoot":"","sources":["../../../../src/render/webgl/FeatureOverrides.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, Id64 } from \"@itwin/core-bentley\";\r\nimport { PackedFeature, RenderFeatureTable } from \"@itwin/core-common\";\r\nimport { FeatureSymbology } from \"../FeatureSymbology\";\r\nimport { WebGLDisposable } from \"./Disposable\";\r\nimport { LineCode } from \"./LineCode\";\r\nimport { GL } from \"./GL\";\r\nimport { UniformHandle } from \"./UniformHandle\";\r\nimport { EmphasisFlags, TextureUnit } from \"./RenderFlags\";\r\nimport { sync, SyncObserver } from \"./Sync\";\r\nimport { System } from \"./System\";\r\nimport { Hilites, Target } from \"./Target\";\r\nimport { Texture2DDataUpdater, Texture2DHandle, TextureHandle } from \"./Texture\";\r\nimport { BatchOptions } from \"../../common/render/BatchOptions\";\r\nimport { DisplayParams } from \"../../common/internal/render/DisplayParams\";\r\nimport { OvrFlags } from \"../../common/internal/render/OvrFlags\";\r\n\r\nfunction computeWidthAndHeight(nEntries: number, nRgbaPerEntry: number, nExtraRgba: number = 0, nTables: number = 1): { width: number, height: number } {\r\n const maxSize = System.instance.maxTextureSize;\r\n const nRgba = nEntries * nRgbaPerEntry * nTables + nExtraRgba;\r\n\r\n if (nRgba < maxSize)\r\n return { width: nRgba, height: 1 };\r\n\r\n // Make roughly square to reduce unused space in last row\r\n let width = Math.ceil(Math.sqrt(nRgba));\r\n\r\n // Ensure a given entry's RGBA values all fit on the same row.\r\n const remainder = width % nRgbaPerEntry;\r\n if (0 !== remainder) {\r\n width += nRgbaPerEntry - remainder;\r\n }\r\n\r\n // Compute height\r\n const height = Math.ceil(nRgba / width);\r\n\r\n assert(height <= maxSize);\r\n assert(width <= maxSize);\r\n assert(width * height >= nRgba);\r\n assert(Math.floor(height) === height);\r\n assert(Math.floor(width) === width);\r\n\r\n // Row padding should never be necessary...\r\n assert(0 === width % nRgbaPerEntry);\r\n\r\n return { width, height };\r\n}\r\n\r\nexport function isFeatureHilited(feature: PackedFeature, hilites: Hilites, isModelHilited: boolean): boolean {\r\n if (hilites.isEmpty)\r\n return false;\r\n\r\n if (\"union\" === hilites.modelSubCategoryMode)\r\n return isModelHilited || hilites.elements.hasPair(feature.elementId) || hilites.subcategories.hasPair(feature.subCategoryId);\r\n\r\n return hilites.elements.hasPair(feature.elementId) || (isModelHilited && hilites.subcategories.hasPair(feature.subCategoryId));\r\n}\r\n\r\n/** @internal */\r\nexport type FeatureOverridesCleanup = () => void;\r\n\r\nconst scratchPackedFeature = PackedFeature.createWithIndex();\r\n\r\n/** @internal */\r\nexport class FeatureOverrides implements WebGLDisposable {\r\n public readonly target: Target;\r\n private readonly _options: BatchOptions;\r\n private _lut?: Texture2DHandle;\r\n private _mostRecentSymbologyOverrides?: FeatureSymbology.Overrides;\r\n private _lastFlashId = Id64.invalid;\r\n private _hiliteSyncObserver: SyncObserver = {};\r\n private _pickExclusionsSyncObserver: SyncObserver = {};\r\n private _anyOverridden = true;\r\n private _allHidden = true;\r\n private _anyTranslucent = true;\r\n private _anyViewIndependentTranslucent = true;\r\n private _anyOpaque = true;\r\n private _anyHilited = true;\r\n private _lutParams = new Float32Array(2);\r\n private _uniformSymbologyFlags: EmphasisFlags = EmphasisFlags.None;\r\n private _cleanup?: FeatureOverridesCleanup;\r\n\r\n public get anyOverridden() { return this._anyOverridden; }\r\n public get allHidden() { return this._allHidden; }\r\n public get anyTranslucent() { return this._anyTranslucent; }\r\n public get anyViewIndependentTranslucent() { return this._anyViewIndependentTranslucent; }\r\n public get anyOpaque() { return this._anyOpaque; }\r\n public get anyHilited() { return this._anyHilited; }\r\n\r\n /** For tests. */\r\n public get lutData(): Uint8Array | undefined { return this._lut?.dataBytes; }\r\n public get byteLength(): number { return undefined !== this._lut ? this._lut.bytesUsed : 0; }\r\n public get isUniform() { return 2 === this._lutParams[0] && 1 === this._lutParams[1]; }\r\n\r\n private updateUniformSymbologyFlags(): void {\r\n this._uniformSymbologyFlags = EmphasisFlags.None;\r\n if (!this.isUniform || !this._lut)\r\n return;\r\n\r\n let flags = this._lut.dataBytes![0];\r\n if (0 !== (flags & OvrFlags.Flashed))\r\n this._uniformSymbologyFlags |= EmphasisFlags.Flashed;\r\n\r\n if (0 !== (flags & OvrFlags.NonLocatable))\r\n this._uniformSymbologyFlags |= EmphasisFlags.NonLocatable;\r\n\r\n if (!this._anyHilited)\r\n return;\r\n\r\n flags = this._lut.dataBytes![1] << 8;\r\n if (0 !== (flags & OvrFlags.Hilited))\r\n this._uniformSymbologyFlags |= EmphasisFlags.Hilite;\r\n\r\n if (0 !== (flags & OvrFlags.Emphasized))\r\n this._uniformSymbologyFlags |= EmphasisFlags.Emphasized;\r\n }\r\n\r\n public getUniformOverrides(): Uint8Array {\r\n assert(this.isUniform);\r\n assert(undefined !== this._lut);\r\n assert(undefined !== this._lut.dataBytes);\r\n return this._lut.dataBytes;\r\n }\r\n\r\n private _initialize(map: RenderFeatureTable, ovrs: FeatureSymbology.Overrides, pickExcludes: Id64.Uint32Set, hilite: Hilites, flashed?: Id64.Uint32Pair): Texture2DHandle | undefined {\r\n const nFeatures = map.numFeatures;\r\n const dims = computeWidthAndHeight(nFeatures, 2);\r\n const width = dims.width;\r\n const height = dims.height;\r\n assert(width * height >= nFeatures);\r\n\r\n this._lutParams[0] = width;\r\n this._lutParams[1] = height;\r\n\r\n const data = new Uint8Array(width * height * 4);\r\n const creator = new Texture2DDataUpdater(data);\r\n this.buildLookupTable(creator, map, ovrs, pickExcludes, flashed, hilite);\r\n\r\n return TextureHandle.createForData(width, height, data, true, GL.Texture.WrapMode.ClampToEdge);\r\n }\r\n\r\n private _update(map: RenderFeatureTable, lut: Texture2DHandle, pickExcludes: Id64.Uint32Set | undefined, flashed?: Id64.Uint32Pair, hilites?: Hilites, ovrs?: FeatureSymbology.Overrides) {\r\n const updater = new Texture2DDataUpdater(lut.dataBytes!);\r\n\r\n if (undefined === ovrs) {\r\n this.updateFlashedAndHilited(updater, map, pickExcludes, flashed, hilites);\r\n } else {\r\n assert(undefined !== hilites);\r\n this.buildLookupTable(updater, map, ovrs, pickExcludes, flashed, hilites);\r\n }\r\n\r\n lut.update(updater);\r\n }\r\n\r\n private buildLookupTable(data: Texture2DDataUpdater, map: RenderFeatureTable, ovr: FeatureSymbology.Overrides, pickExclude: Id64.Uint32Set | undefined, flashedIdParts: Id64.Uint32Pair | undefined, hilites: Hilites) {\r\n const allowHilite = true !== this._options.noHilite;\r\n const allowFlash = true !== this._options.noFlash;\r\n const allowEmphasis = true !== this._options.noEmphasis;\r\n\r\n let isModelHilited = false;\r\n const prevModelId = { lower: -1, upper: -1 };\r\n\r\n this._anyOpaque = this._anyTranslucent = this._anyViewIndependentTranslucent = this._anyHilited = false;\r\n\r\n let nHidden = 0;\r\n let nOverridden = 0;\r\n\r\n // NB: We currently use 2 RGBA values per feature as follows:\r\n // [0]\r\n // RG = override flags (see OvrFlags enum)\r\n // B = line code\r\n // A = line weight (if we need an extra byte in future, could combine code+weight into a single byte).\r\n // [1]\r\n // RGB = rgb\r\n // A = alpha\r\n for (const feature of map.iterable(scratchPackedFeature)) {\r\n const i = feature.index;\r\n const dataIndex = i * 4 * 2;\r\n\r\n if (prevModelId.lower !== feature.modelId.lower || prevModelId.upper !== feature.modelId.upper) {\r\n prevModelId.lower = feature.modelId.lower;\r\n prevModelId.upper = feature.modelId.upper;\r\n isModelHilited = allowHilite && hilites.models.hasPair(feature.modelId);\r\n }\r\n\r\n const app = this.target.currentBranch.getFeatureAppearance(\r\n ovr,\r\n feature.elementId.lower, feature.elementId.upper,\r\n feature.subCategoryId.lower, feature.subCategoryId.upper,\r\n feature.geometryClass,\r\n feature.modelId.lower, feature.modelId.upper,\r\n map.type, feature.animationNodeId);\r\n\r\n // NB: If the appearance is fully transparent, then:\r\n // - For normal (\"primary\") models, getAppearance() returns undefined.\r\n // - For classifier models, getAppearance() returns the appearance, and classification shader will discard fully-transparent classified pixels.\r\n // (The latter is how we clip the classified model using the classifiers).\r\n if (undefined === app) {\r\n // The feature is not visible. We don't care about any of the other overrides, because we're not going to render it.\r\n data.setOvrFlagsAtIndex(dataIndex, OvrFlags.Visibility);\r\n nHidden++;\r\n nOverridden++;\r\n continue;\r\n }\r\n\r\n let flags = app.nonLocatable ? OvrFlags.NonLocatable : OvrFlags.None;\r\n if (allowHilite && isFeatureHilited(feature, hilites, isModelHilited)) {\r\n flags |= OvrFlags.Hilited;\r\n this._anyHilited = true;\r\n }\r\n\r\n if (allowEmphasis && app.emphasized) {\r\n flags |= OvrFlags.Emphasized;\r\n this._anyHilited = true;\r\n }\r\n\r\n if (app.overridesRgb && app.rgb) {\r\n flags |= OvrFlags.Rgb;\r\n const rgb = app.rgb;\r\n data.setByteAtIndex(dataIndex + 4, rgb.r);\r\n data.setByteAtIndex(dataIndex + 5, rgb.g);\r\n data.setByteAtIndex(dataIndex + 6, rgb.b);\r\n }\r\n\r\n if (undefined !== app.transparency) {\r\n // transparency in range [0, 1]...convert to byte and invert so 0=transparent...\r\n flags |= OvrFlags.Alpha;\r\n let alpha = 1.0 - app.transparency;\r\n alpha = Math.floor(0xff * alpha + 0.5);\r\n if ((0xff - alpha) < DisplayParams.minTransparency)\r\n alpha = 0xff;\r\n\r\n data.setByteAtIndex(dataIndex + 7, alpha);\r\n if (0xff === alpha) {\r\n this._anyOpaque = true;\r\n } else {\r\n this._anyTranslucent = true;\r\n if (!app.viewDependentTransparency) {\r\n flags |= OvrFlags.ViewIndependentTransparency;\r\n this._anyViewIndependentTranslucent = true;\r\n }\r\n }\r\n }\r\n\r\n if (app.overridesWeight && app.weight) {\r\n flags |= OvrFlags.Weight;\r\n let weight = app.weight;\r\n weight = Math.min(31, weight);\r\n weight = Math.max(1, weight);\r\n data.setByteAtIndex(dataIndex + 3, weight);\r\n }\r\n\r\n if (app.overridesLinePixels && app.linePixels) {\r\n flags |= OvrFlags.LineCode;\r\n const lineCode = LineCode.valueFromLinePixels(app.linePixels);\r\n data.setByteAtIndex(dataIndex + 2, lineCode);\r\n }\r\n\r\n if (app.ignoresMaterial)\r\n flags |= OvrFlags.IgnoreMaterial;\r\n\r\n if (allowFlash && undefined !== flashedIdParts && feature.elementId.lower === flashedIdParts.lower && feature.elementId.upper === flashedIdParts.upper)\r\n flags |= OvrFlags.Flashed;\r\n\r\n if (pickExclude?.hasPair(feature.elementId)) {\r\n flags |= OvrFlags.InvisibleDuringPick;\r\n ++nHidden;\r\n }\r\n\r\n data.setOvrFlagsAtIndex(dataIndex, flags);\r\n if (OvrFlags.None !== flags)\r\n nOverridden++;\r\n }\r\n\r\n this._allHidden = (nHidden === map.numFeatures);\r\n this._anyOverridden = (nOverridden > 0);\r\n\r\n this.updateUniformSymbologyFlags();\r\n }\r\n\r\n // NB: If hilites is undefined, it means that the hilited set has not changed.\r\n private updateFlashedAndHilited(data: Texture2DDataUpdater, map: RenderFeatureTable, pickExcludes: Id64.Uint32Set | undefined, flashed?: Id64.Uint32Pair, hilites?: Hilites) {\r\n if (!hilites || true === this._options.noHilite) {\r\n this.updateFlashed(data, map, pickExcludes, flashed);\r\n return;\r\n }\r\n\r\n const allowFlash = true !== this._options.noFlash;\r\n const intersect = \"intersection\" === hilites.modelSubCategoryMode;\r\n\r\n this._anyOverridden = this._anyHilited = false;\r\n for (const feature of map.iterable(scratchPackedFeature)) {\r\n const dataIndex = feature.index * 4 * 2;\r\n const oldFlags = data.getOvrFlagsAtIndex(dataIndex);\r\n if (OvrFlags.None !== (oldFlags & OvrFlags.Visibility)) {\r\n // If it's invisible, none of the other flags matter. We can't flash it and don't want to hilite it.\r\n this._anyOverridden = true;\r\n continue;\r\n }\r\n\r\n const isModelHilited = hilites.models.hasPair(feature.modelId);\r\n let isHilited = isModelHilited && !intersect;\r\n if (!isHilited)\r\n isHilited = hilites.elements.hasPair(feature.elementId);\r\n\r\n if (!isHilited)\r\n if (isModelHilited || !intersect)\r\n isHilited = hilites.subcategories.hasPair(feature.subCategoryId);\r\n\r\n let isFlashed = false;\r\n if (flashed && allowFlash)\r\n isFlashed = feature.elementId.lower === flashed.lower && feature.elementId.upper === flashed.upper;\r\n\r\n let newFlags = isFlashed ? (oldFlags | OvrFlags.Flashed) : (oldFlags & ~OvrFlags.Flashed);\r\n newFlags = isHilited ? (newFlags | OvrFlags.Hilited) : (newFlags & ~OvrFlags.Hilited);\r\n if (pickExcludes) {\r\n newFlags = pickExcludes.hasPair(feature.elementId) ? (newFlags | OvrFlags.InvisibleDuringPick) : (newFlags & ~OvrFlags.InvisibleDuringPick);\r\n }\r\n\r\n data.setOvrFlagsAtIndex(dataIndex, newFlags);\r\n if (OvrFlags.None !== newFlags) {\r\n this._anyOverridden = true;\r\n this._anyHilited = this._anyHilited || isHilited || OvrFlags.None !== (newFlags & OvrFlags.Emphasized);\r\n }\r\n }\r\n\r\n this.updateUniformSymbologyFlags();\r\n }\r\n\r\n private updateFlashed(data: Texture2DDataUpdater, map: RenderFeatureTable, pickExcludes: Id64.Uint32Set | undefined, flashed?: Id64.Uint32Pair): void {\r\n if (true === this._options.noFlash && !pickExcludes)\r\n return;\r\n\r\n this._anyOverridden = false;\r\n const elemId = { lower: 0, upper: 0 };\r\n for (let i = 0; i < map.numFeatures; i++) {\r\n const dataIndex = i * 4 * 2;\r\n const oldFlags = data.getOvrFlagsAtIndex(dataIndex);\r\n if (OvrFlags.None !== (oldFlags & OvrFlags.Visibility)) {\r\n // If it's invisible, none of the other flags matter and we can't flash it.\r\n this._anyOverridden = true;\r\n continue;\r\n }\r\n\r\n let isFlashed = false;\r\n let thisElemId: Id64.Uint32Pair | undefined;\r\n if (flashed && !this._options.noFlash) {\r\n thisElemId = map.getElementIdPair(i, elemId);\r\n isFlashed = thisElemId.lower === flashed.lower && thisElemId.upper === flashed.upper;\r\n }\r\n\r\n let newFlags = isFlashed ? (oldFlags | OvrFlags.Flashed) : (oldFlags & ~OvrFlags.Flashed);\r\n if (pickExcludes) {\r\n if (!thisElemId) {\r\n thisElemId = map.getElementIdPair(i, elemId);\r\n }\r\n\r\n newFlags = pickExcludes.hasPair(thisElemId) ? (newFlags | OvrFlags.InvisibleDuringPick) : (newFlags & ~OvrFlags.InvisibleDuringPick);\r\n }\r\n\r\n data.setOvrFlagsAtIndex(dataIndex, newFlags);\r\n if (OvrFlags.None !== newFlags)\r\n this._anyOverridden = true;\r\n }\r\n\r\n this.updateUniformSymbologyFlags();\r\n }\r\n\r\n private constructor(target: Target, options: BatchOptions, cleanup: FeatureOverridesCleanup | undefined) {\r\n this.target = target;\r\n this._options = options;\r\n this._cleanup = cleanup;\r\n }\r\n\r\n public static createFromTarget(target: Target, options: BatchOptions, cleanup: FeatureOverridesCleanup | undefined) {\r\n return new FeatureOverrides(target, options, cleanup);\r\n }\r\n\r\n public get isDisposed(): boolean { return undefined === this._lut; }\r\n\r\n public dispose() {\r\n this._lut = dispose(this._lut);\r\n if (this._cleanup) {\r\n this._cleanup();\r\n this._cleanup = undefined;\r\n }\r\n }\r\n\r\n public initFromMap(map: RenderFeatureTable) {\r\n const nFeatures = map.numFeatures;\r\n assert(0 < nFeatures);\r\n\r\n this._lut = dispose(this._lut);\r\n\r\n const ovrs: FeatureSymbology.Overrides = this.target.currentFeatureSymbologyOverrides;\r\n this._mostRecentSymbologyOverrides = ovrs;\r\n const hilite = this.target.hilites;\r\n this._lut = this._initialize(map, ovrs, this.target.pickExclusions, hilite, this.target.flashed);\r\n this._lastFlashId = Id64.invalid;\r\n this._hiliteSyncObserver = {};\r\n this._pickExclusionsSyncObserver = {};\r\n }\r\n\r\n public update(features: RenderFeatureTable) {\r\n let ovrs: FeatureSymbology.Overrides | undefined = this.target.currentFeatureSymbologyOverrides;\r\n const ovrsUpdated = ovrs !== this._mostRecentSymbologyOverrides;\r\n if (ovrsUpdated)\r\n this._mostRecentSymbologyOverrides = ovrs;\r\n else\r\n ovrs = undefined;\r\n\r\n const flashedId = this.target.flashedId;\r\n\r\n const hilite = this.target.hilites;\r\n const hiliteUpdated = !sync(this.target.hiliteSyncTarget, this._hiliteSyncObserver);\r\n const pickExcludesUpdated = !sync(this.target.pickExclusionsSyncTarget, this._pickExclusionsSyncObserver);\r\n\r\n if (ovrsUpdated || hiliteUpdated || flashedId !== this._lastFlashId || pickExcludesUpdated) {\r\n // _lut can be undefined if context was lost, (gl.createTexture returns null)\r\n if (this._lut) {\r\n this._update(\r\n features,\r\n this._lut,\r\n undefined !== ovrs || pickExcludesUpdated ? this.target.pickExclusions : undefined,\r\n this.target.flashed,\r\n undefined !== ovrs || hiliteUpdated ? hilite : undefined, ovrs,\r\n );\r\n }\r\n\r\n this._lastFlashId = flashedId;\r\n }\r\n }\r\n\r\n public bindLUTParams(uniform: UniformHandle): void {\r\n uniform.setUniform2fv(this._lutParams);\r\n }\r\n\r\n public bindLUT(uniform: UniformHandle): void {\r\n if (this._lut)\r\n this._lut.bindSampler(uniform, TextureUnit.FeatureSymbology);\r\n }\r\n\r\n public bindUniformSymbologyFlags(uniform: UniformHandle): void {\r\n uniform.setUniform1f(this._uniformSymbologyFlags);\r\n }\r\n}\r\n"]}
@@ -1,8 +1,8 @@
1
1
  /** @packageDocumentation
2
2
  * @module WebGL
3
3
  */
4
- import { Point3d, Range3d, Transform } from "@itwin/core-geometry";
5
- import { InstancedGraphicParams, PatternGraphicParams } from "../../common/render/InstancedGraphicParams";
4
+ import { Point3d, Range3d, Transform, XYAndZ } from "@itwin/core-geometry";
5
+ import { InstancedGraphicParams, InstancedGraphicProps, PatternGraphicParams } from "../../common/render/InstancedGraphicParams";
6
6
  import { RenderMemory } from "../RenderMemory";
7
7
  import { CachedGeometry, LUTGeometry } from "./CachedGeometry";
8
8
  import { ShaderProgramParams } from "./DrawCommand";
@@ -10,15 +10,17 @@ import { BufferHandle, BufferParameters } from "./AttributeBuffers";
10
10
  import { Target } from "./Target";
11
11
  import { TechniqueId } from "./TechniqueId";
12
12
  import { Matrix4 } from "./Matrix";
13
+ import { RenderInstances } from "../RenderSystem";
14
+ import { _implementationProhibited } from "../../common/internal/Symbols";
15
+ import { RenderInstancesParamsImpl } from "../../internal/render/RenderInstancesParamsImpl";
13
16
  /** @internal */
14
17
  export declare function isInstancedGraphicParams(params: any): params is InstancedGraphicParams;
15
18
  declare class InstanceData {
16
19
  readonly numInstances: number;
17
- readonly range: Range3d;
18
20
  private readonly _rtcOnlyTransform;
19
21
  private readonly _rtcModelTransform;
20
22
  private readonly _modelMatrix;
21
- protected constructor(numInstances: number, rtcCenter: Point3d, range: Range3d);
23
+ protected constructor(numInstances: number, rtcCenter: Point3d);
22
24
  getRtcModelTransform(modelMatrix: Transform): Transform;
23
25
  getRtcOnlyTransform(): Transform;
24
26
  private static readonly _noFeatureId;
@@ -32,26 +34,53 @@ export interface PatternTransforms {
32
34
  readonly origin: Float32Array;
33
35
  }
34
36
  /** @internal */
35
- export declare class InstanceBuffers extends InstanceData {
36
- private static readonly _patternParams;
37
+ export declare class InstanceBuffersData extends InstanceData {
37
38
  readonly transforms: BufferHandle;
38
39
  readonly featureIds?: BufferHandle;
39
- readonly hasFeatures: boolean;
40
40
  readonly symbology?: BufferHandle;
41
+ private _noDispose;
42
+ private constructor();
43
+ static create(params: InstancedGraphicParams | InstancedGraphicProps, disableDisposal?: boolean): InstanceBuffersData | undefined;
44
+ dispose(): void;
45
+ get isDisposed(): boolean;
46
+ }
47
+ /** @internal */
48
+ export interface RenderInstancesImpl extends RenderInstances {
49
+ readonly buffers: InstanceBuffersData;
50
+ }
51
+ /** @internal */
52
+ export declare namespace RenderInstancesImpl {
53
+ function create(params: RenderInstancesParamsImpl): RenderInstancesImpl | undefined;
54
+ }
55
+ /** @internal */
56
+ export declare class InstanceBuffers {
57
+ private static readonly _patternParams;
58
+ private readonly _data;
41
59
  readonly patternParams: Float32Array;
42
60
  readonly patternTransforms: undefined;
43
61
  readonly viewIndependentOrigin: undefined;
62
+ readonly range: Range3d;
63
+ get numInstances(): number;
64
+ get transforms(): BufferHandle;
65
+ get featureIds(): BufferHandle | undefined;
66
+ get symbology(): BufferHandle | undefined;
67
+ get hasFeatures(): boolean;
68
+ get patternFeatureId(): Float32Array;
69
+ getRtcModelTransform(modelMatrix: Transform): Transform;
70
+ getRtcOnlyTransform(): Transform;
44
71
  private constructor();
45
72
  static createTransformBufferParameters(techniqueId: TechniqueId): BufferParameters[];
46
- static create(params: InstancedGraphicParams, range: Range3d): InstanceBuffers | undefined;
47
- get isDisposed(): boolean;
73
+ static fromParams(params: InstancedGraphicParams, computeReprRange: () => Range3d): InstanceBuffers | undefined;
74
+ static fromRenderInstances(arg: RenderInstances, reprRange: Range3d): InstanceBuffers;
48
75
  dispose(): void;
76
+ get isDisposed(): boolean;
49
77
  collectStatistics(stats: RenderMemory.Statistics): void;
50
78
  private static extendTransformedRange;
51
- static computeRange(reprRange: Range3d, tfs: Float32Array, rtcCenter: Point3d, out?: Range3d): Range3d;
79
+ static computeRange(reprRange: Range3d, tfs: Float32Array, rtcCenter: XYAndZ, out?: Range3d): Range3d;
52
80
  }
53
81
  /** @internal */
54
82
  export declare class PatternBuffers extends InstanceData {
83
+ readonly range: Range3d;
55
84
  readonly patternParams: Float32Array;
56
85
  readonly origin: Float32Array;
57
86
  readonly orgTransform: Matrix4;
@@ -60,6 +89,7 @@ export declare class PatternBuffers extends InstanceData {
60
89
  readonly offsets: BufferHandle;
61
90
  readonly viewIndependentOrigin: Point3d | undefined;
62
91
  private readonly _featureId?;
92
+ readonly [_implementationProhibited] = "renderAreaPattern";
63
93
  private constructor();
64
94
  static create(params: PatternGraphicParams): PatternBuffers | undefined;
65
95
  readonly patternTransforms: PatternTransforms;
@@ -1 +1 @@
1
- {"version":3,"file":"InstancedGeometry.d.ts","sourceRoot":"","sources":["../../../../src/render/webgl/InstancedGeometry.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"InstancedGeometry.d.ts","sourceRoot":"","sources":["../../../../src/render/webgl/InstancedGeometry.ts"],"names":[],"mappings":"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"}
@@ -5,6 +5,7 @@
5
5
  /** @packageDocumentation
6
6
  * @module WebGL
7
7
  */
8
+ var _a;
8
9
  import { assert, dispose } from "@itwin/core-bentley";
9
10
  import { Point3d, Range3d, Transform } from "@itwin/core-geometry";
10
11
  import { AttributeMap } from "./AttributeMap";
@@ -12,16 +13,17 @@ import { CachedGeometry } from "./CachedGeometry";
12
13
  import { GL } from "./GL";
13
14
  import { BufferHandle, BufferParameters, BuffersContainer } from "./AttributeBuffers";
14
15
  import { Matrix4 } from "./Matrix";
16
+ import { _featureTable, _implementationProhibited, _transformCenter, _transforms } from "../../common/internal/Symbols";
17
+ import { BatchType, PackedFeatureTable } from "@itwin/core-common";
15
18
  /** @internal */
16
19
  export function isInstancedGraphicParams(params) {
17
20
  return typeof params === "object" && typeof params.count === "number" && params.transforms instanceof Float32Array && params.transformCenter instanceof Point3d;
18
21
  }
19
22
  class InstanceData {
20
- constructor(numInstances, rtcCenter, range) {
23
+ constructor(numInstances, rtcCenter) {
21
24
  // The model matrix from which _rtcModelTransform was previously computed. If it changes, _rtcModelTransform must be recomputed.
22
25
  this._modelMatrix = Transform.createIdentity();
23
26
  this.numInstances = numInstances;
24
- this.range = range;
25
27
  this._rtcOnlyTransform = Transform.createTranslation(rtcCenter);
26
28
  this._rtcModelTransform = this._rtcOnlyTransform.clone();
27
29
  }
@@ -41,16 +43,84 @@ class InstanceData {
41
43
  }
42
44
  InstanceData._noFeatureId = new Float32Array([0, 0, 0]);
43
45
  /** @internal */
44
- export class InstanceBuffers extends InstanceData {
45
- constructor(count, transforms, rtcCenter, range, symbology, featureIds) {
46
- super(count, rtcCenter, range);
47
- this.patternParams = InstanceBuffers._patternParams;
48
- this.patternTransforms = undefined;
49
- this.viewIndependentOrigin = undefined;
46
+ export class InstanceBuffersData extends InstanceData {
47
+ constructor(count, transforms, rtcCenter, symbology, featureIds, disableDisposal = false) {
48
+ super(count, rtcCenter);
49
+ this._noDispose = false;
50
50
  this.transforms = transforms;
51
51
  this.featureIds = featureIds;
52
- this.hasFeatures = undefined !== featureIds;
53
52
  this.symbology = symbology;
53
+ this._noDispose = disableDisposal;
54
+ }
55
+ static create(params, disableDisposal = false) {
56
+ const { count, featureIds, symbologyOverrides, transforms } = params;
57
+ assert(count > 0 && Math.floor(count) === count);
58
+ assert(count === transforms.length / 12);
59
+ assert(undefined === featureIds || count === featureIds.length / 3);
60
+ assert(undefined === symbologyOverrides || count * 8 === symbologyOverrides.length);
61
+ let idBuf;
62
+ if (undefined !== featureIds && undefined === (idBuf = BufferHandle.createArrayBuffer(featureIds)))
63
+ return undefined;
64
+ let symBuf;
65
+ if (undefined !== symbologyOverrides && undefined === (symBuf = BufferHandle.createArrayBuffer(symbologyOverrides)))
66
+ return undefined;
67
+ const tfBuf = BufferHandle.createArrayBuffer(transforms);
68
+ const transformCenter = params.transformCenter instanceof Point3d ? params.transformCenter : Point3d.fromJSON(params.transformCenter);
69
+ if (!tfBuf) {
70
+ return undefined;
71
+ }
72
+ return new InstanceBuffersData(count, tfBuf, transformCenter, symBuf, idBuf, disableDisposal);
73
+ }
74
+ dispose() {
75
+ if (!this._noDispose) {
76
+ dispose(this.transforms);
77
+ dispose(this.featureIds);
78
+ dispose(this.symbology);
79
+ }
80
+ }
81
+ get isDisposed() {
82
+ return this.transforms.isDisposed && (!this.featureIds || this.featureIds.isDisposed) && (!this.symbology || this.symbology.isDisposed);
83
+ }
84
+ }
85
+ /** @internal */
86
+ export var RenderInstancesImpl;
87
+ (function (RenderInstancesImpl) {
88
+ function create(params) {
89
+ const buffers = InstanceBuffersData.create(params.instances, true);
90
+ if (!buffers) {
91
+ return undefined;
92
+ }
93
+ let featureTable;
94
+ if (params.features) {
95
+ // ###TODO permit user to specify batch type and other batch options...
96
+ featureTable = new PackedFeatureTable(params.features.data, params.features.modelId, params.features.count, BatchType.Primary);
97
+ }
98
+ return {
99
+ [_implementationProhibited]: "renderInstances",
100
+ buffers,
101
+ [_transforms]: params.instances.transforms,
102
+ [_transformCenter]: params.instances.transformCenter,
103
+ [_featureTable]: featureTable,
104
+ };
105
+ }
106
+ RenderInstancesImpl.create = create;
107
+ })(RenderInstancesImpl || (RenderInstancesImpl = {}));
108
+ /** @internal */
109
+ export class InstanceBuffers {
110
+ get numInstances() { return this._data.numInstances; }
111
+ get transforms() { return this._data.transforms; }
112
+ get featureIds() { return this._data.featureIds; }
113
+ get symbology() { return this._data.symbology; }
114
+ get hasFeatures() { return undefined !== this.featureIds; }
115
+ get patternFeatureId() { return this._data.patternFeatureId; }
116
+ getRtcModelTransform(modelMatrix) { return this._data.getRtcModelTransform(modelMatrix); }
117
+ getRtcOnlyTransform() { return this._data.getRtcOnlyTransform(); }
118
+ constructor(data, range) {
119
+ this.patternParams = InstanceBuffers._patternParams;
120
+ this.patternTransforms = undefined;
121
+ this.viewIndependentOrigin = undefined;
122
+ this._data = data;
123
+ this.range = range;
54
124
  }
55
125
  static createTransformBufferParameters(techniqueId) {
56
126
  const params = [];
@@ -79,30 +149,24 @@ export class InstanceBuffers extends InstanceData {
79
149
  }
80
150
  return params;
81
151
  }
82
- static create(params, range) {
83
- const { count, featureIds, symbologyOverrides, transforms } = params;
84
- assert(count > 0 && Math.floor(count) === count);
85
- assert(count === transforms.length / 12);
86
- assert(undefined === featureIds || count === featureIds.length / 3);
87
- assert(undefined === symbologyOverrides || count * 8 === symbologyOverrides.length);
88
- let idBuf;
89
- if (undefined !== featureIds && undefined === (idBuf = BufferHandle.createArrayBuffer(featureIds)))
90
- return undefined;
91
- let symBuf;
92
- if (undefined !== symbologyOverrides && undefined === (symBuf = BufferHandle.createArrayBuffer(symbologyOverrides)))
152
+ static fromParams(params, computeReprRange) {
153
+ const data = InstanceBuffersData.create(params);
154
+ if (!data) {
93
155
  return undefined;
94
- const tfBuf = BufferHandle.createArrayBuffer(transforms);
95
- return undefined !== tfBuf ? new InstanceBuffers(count, tfBuf, params.transformCenter, range, symBuf, idBuf) : undefined;
156
+ }
157
+ const range = params.range ?? this.computeRange(computeReprRange(), params.transforms, params.transformCenter);
158
+ return new InstanceBuffers(data, range);
96
159
  }
97
- get isDisposed() {
98
- return this.transforms.isDisposed
99
- && (undefined === this.featureIds || this.featureIds.isDisposed)
100
- && (undefined === this.symbology || this.symbology.isDisposed);
160
+ static fromRenderInstances(arg, reprRange) {
161
+ const instances = arg;
162
+ const range = this.computeRange(reprRange, instances[_transforms], instances[_transformCenter]);
163
+ return new InstanceBuffers(instances.buffers, range);
101
164
  }
102
165
  dispose() {
103
- dispose(this.transforms);
104
- dispose(this.featureIds);
105
- dispose(this.symbology);
166
+ dispose(this._data);
167
+ }
168
+ get isDisposed() {
169
+ return this._data.isDisposed;
106
170
  }
107
171
  collectStatistics(stats) {
108
172
  const featureBytes = undefined !== this.featureIds ? this.featureIds.bytesUsed : 0;
@@ -138,7 +202,8 @@ export class PatternBuffers extends InstanceData {
138
202
  constructor(count, rtcCenter, range, patternParams, // [ isAreaPattern, spacingX, spacingY, scale ]
139
203
  origin, // [ x, y ]
140
204
  orgTransform, localToModel, symbolToLocal, offsets, featureId, viewIndependentOrigin) {
141
- super(count, rtcCenter, range);
205
+ super(count, rtcCenter);
206
+ this.range = range;
142
207
  this.patternParams = patternParams;
143
208
  this.origin = origin;
144
209
  this.orgTransform = orgTransform;
@@ -146,6 +211,7 @@ export class PatternBuffers extends InstanceData {
146
211
  this.symbolToLocal = symbolToLocal;
147
212
  this.offsets = offsets;
148
213
  this.viewIndependentOrigin = viewIndependentOrigin;
214
+ this[_a] = "renderAreaPattern";
149
215
  this.patternTransforms = this;
150
216
  if (undefined !== featureId) {
151
217
  this._featureId = new Float32Array([
@@ -179,6 +245,7 @@ export class PatternBuffers extends InstanceData {
179
245
  stats.addInstances(this.offsets.bytesUsed);
180
246
  }
181
247
  }
248
+ _a = _implementationProhibited;
182
249
  /** @internal */
183
250
  export class InstancedGeometry extends CachedGeometry {
184
251
  getRtcModelTransform(modelMatrix) { return this._buffers.getRtcModelTransform(modelMatrix); }