@itwin/core-common 4.0.0-dev.52 → 4.0.0-dev.55

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 (890) hide show
  1. package/lib/cjs/AmbientOcclusion.d.ts +49 -49
  2. package/lib/cjs/AmbientOcclusion.js +55 -55
  3. package/lib/cjs/AnalysisStyle.d.ts +134 -134
  4. package/lib/cjs/AnalysisStyle.js +165 -165
  5. package/lib/cjs/AnalysisStyle.js.map +1 -1
  6. package/lib/cjs/AuthorizationClient.d.ts +17 -17
  7. package/lib/cjs/AuthorizationClient.js +9 -9
  8. package/lib/cjs/BackendTypes.d.ts +13 -12
  9. package/lib/cjs/BackendTypes.d.ts.map +1 -1
  10. package/lib/cjs/BackendTypes.js +9 -9
  11. package/lib/cjs/BackgroundMapProvider.d.ts +51 -51
  12. package/lib/cjs/BackgroundMapProvider.d.ts.map +1 -1
  13. package/lib/cjs/BackgroundMapProvider.js +67 -67
  14. package/lib/cjs/BackgroundMapSettings.d.ts +136 -136
  15. package/lib/cjs/BackgroundMapSettings.d.ts.map +1 -1
  16. package/lib/cjs/BackgroundMapSettings.js +154 -154
  17. package/lib/cjs/BackgroundMapSettings.js.map +1 -1
  18. package/lib/cjs/Base64EncodedString.d.ts +32 -32
  19. package/lib/cjs/Base64EncodedString.d.ts.map +1 -1
  20. package/lib/cjs/Base64EncodedString.js +66 -66
  21. package/lib/cjs/Base64EncodedString.js.map +1 -1
  22. package/lib/cjs/BlobReader.d.ts +31 -31
  23. package/lib/cjs/BlobReader.js +84 -84
  24. package/lib/cjs/BriefcaseTypes.d.ts +191 -191
  25. package/lib/cjs/BriefcaseTypes.d.ts.map +1 -1
  26. package/lib/cjs/BriefcaseTypes.js +95 -95
  27. package/lib/cjs/Camera.d.ts +42 -42
  28. package/lib/cjs/Camera.js +62 -62
  29. package/lib/cjs/Camera.js.map +1 -1
  30. package/lib/cjs/ChangedElements.d.ts +85 -85
  31. package/lib/cjs/ChangedElements.js +23 -23
  32. package/lib/cjs/ChangedEntities.d.ts +45 -45
  33. package/lib/cjs/ChangedEntities.d.ts.map +1 -1
  34. package/lib/cjs/ChangedEntities.js +9 -9
  35. package/lib/cjs/ChangesetProps.d.ts +98 -98
  36. package/lib/cjs/ChangesetProps.d.ts.map +1 -1
  37. package/lib/cjs/ChangesetProps.js +22 -22
  38. package/lib/cjs/ClipStyle.d.ts +89 -89
  39. package/lib/cjs/ClipStyle.js +121 -121
  40. package/lib/cjs/ClipStyle.js.map +1 -1
  41. package/lib/cjs/CloudStorage.d.ts +62 -62
  42. package/lib/cjs/CloudStorage.js +113 -113
  43. package/lib/cjs/CloudStorage.js.map +1 -1
  44. package/lib/cjs/CloudStorageTileCache.d.ts +27 -27
  45. package/lib/cjs/CloudStorageTileCache.js +65 -65
  46. package/lib/cjs/CloudStorageTileCache.js.map +1 -1
  47. package/lib/cjs/Code.d.ts +277 -277
  48. package/lib/cjs/Code.d.ts.map +1 -1
  49. package/lib/cjs/Code.js +268 -268
  50. package/lib/cjs/Code.js.map +1 -1
  51. package/lib/cjs/ColorByName.d.ts +161 -161
  52. package/lib/cjs/ColorByName.js +169 -169
  53. package/lib/cjs/ColorDef.d.ts +210 -210
  54. package/lib/cjs/ColorDef.d.ts.map +1 -1
  55. package/lib/cjs/ColorDef.js +572 -572
  56. package/lib/cjs/ColorDef.js.map +1 -1
  57. package/lib/cjs/CommonLoggerCategory.d.ts +18 -18
  58. package/lib/cjs/CommonLoggerCategory.js +26 -26
  59. package/lib/cjs/ConcurrentQuery.d.ts +421 -421
  60. package/lib/cjs/ConcurrentQuery.d.ts.map +1 -1
  61. package/lib/cjs/ConcurrentQuery.js +552 -552
  62. package/lib/cjs/ContextRealityModel.d.ts +303 -303
  63. package/lib/cjs/ContextRealityModel.js +371 -371
  64. package/lib/cjs/DisplayStyleSettings.d.ts +588 -588
  65. package/lib/cjs/DisplayStyleSettings.js +981 -981
  66. package/lib/cjs/DisplayStyleSettings.js.map +1 -1
  67. package/lib/cjs/ECSchemaProps.d.ts +39 -39
  68. package/lib/cjs/ECSchemaProps.js +9 -9
  69. package/lib/cjs/ECSqlReader.d.ts +70 -70
  70. package/lib/cjs/ECSqlReader.d.ts.map +1 -1
  71. package/lib/cjs/ECSqlReader.js +280 -280
  72. package/lib/cjs/ECSqlReader.js.map +1 -1
  73. package/lib/cjs/ECSqlTypes.d.ts +128 -128
  74. package/lib/cjs/ECSqlTypes.js +189 -189
  75. package/lib/cjs/ElementMesh.d.ts +39 -39
  76. package/lib/cjs/ElementMesh.js +56 -56
  77. package/lib/cjs/ElementProps.d.ts +483 -483
  78. package/lib/cjs/ElementProps.d.ts.map +1 -1
  79. package/lib/cjs/ElementProps.js +99 -99
  80. package/lib/cjs/ElementProps.js.map +1 -1
  81. package/lib/cjs/EmphasizeElementsProps.d.ts +55 -55
  82. package/lib/cjs/EmphasizeElementsProps.js +25 -25
  83. package/lib/cjs/EntityProps.d.ts +177 -177
  84. package/lib/cjs/EntityProps.d.ts.map +1 -1
  85. package/lib/cjs/EntityProps.js +113 -113
  86. package/lib/cjs/EntityReference.d.ts +51 -51
  87. package/lib/cjs/EntityReference.d.ts.map +1 -1
  88. package/lib/cjs/EntityReference.js +56 -56
  89. package/lib/cjs/Environment.d.ts +61 -61
  90. package/lib/cjs/Environment.d.ts.map +1 -1
  91. package/lib/cjs/Environment.js +70 -70
  92. package/lib/cjs/Environment.js.map +1 -1
  93. package/lib/cjs/FeatureIndex.d.ts +39 -39
  94. package/lib/cjs/FeatureIndex.js +63 -63
  95. package/lib/cjs/FeatureIndex.js.map +1 -1
  96. package/lib/cjs/FeatureSymbology.d.ts +449 -449
  97. package/lib/cjs/FeatureSymbology.d.ts.map +1 -1
  98. package/lib/cjs/FeatureSymbology.js +618 -618
  99. package/lib/cjs/FeatureSymbology.js.map +1 -1
  100. package/lib/cjs/FeatureTable.d.ts +248 -248
  101. package/lib/cjs/FeatureTable.d.ts.map +1 -1
  102. package/lib/cjs/FeatureTable.js +470 -470
  103. package/lib/cjs/FeatureTable.js.map +1 -1
  104. package/lib/cjs/Fonts.d.ts +51 -51
  105. package/lib/cjs/Fonts.d.ts.map +1 -1
  106. package/lib/cjs/Fonts.js +53 -53
  107. package/lib/cjs/Frustum.d.ts +114 -114
  108. package/lib/cjs/Frustum.js +292 -292
  109. package/lib/cjs/GeoCoordinateServices.d.ts +123 -119
  110. package/lib/cjs/GeoCoordinateServices.d.ts.map +1 -1
  111. package/lib/cjs/GeoCoordinateServices.js +81 -80
  112. package/lib/cjs/GeoCoordinateServices.js.map +1 -1
  113. package/lib/cjs/GeometryContainment.d.ts +28 -28
  114. package/lib/cjs/GeometryContainment.js +9 -9
  115. package/lib/cjs/GeometryParams.d.ts +130 -130
  116. package/lib/cjs/GeometryParams.js +174 -174
  117. package/lib/cjs/GeometrySummary.d.ts +45 -45
  118. package/lib/cjs/GeometrySummary.js +23 -23
  119. package/lib/cjs/Gradient.d.ts +139 -139
  120. package/lib/cjs/Gradient.js +453 -453
  121. package/lib/cjs/Gradient.js.map +1 -1
  122. package/lib/cjs/GraphicParams.d.ts +58 -58
  123. package/lib/cjs/GraphicParams.js +85 -85
  124. package/lib/cjs/GroundPlane.d.ts +52 -52
  125. package/lib/cjs/GroundPlane.d.ts.map +1 -1
  126. package/lib/cjs/GroundPlane.js +63 -63
  127. package/lib/cjs/GroundPlane.js.map +1 -1
  128. package/lib/cjs/HSLColor.d.ts +20 -20
  129. package/lib/cjs/HSLColor.js +32 -32
  130. package/lib/cjs/HSVColor.d.ts +30 -30
  131. package/lib/cjs/HSVColor.js +59 -59
  132. package/lib/cjs/HiddenLine.d.ts +97 -97
  133. package/lib/cjs/HiddenLine.js +160 -160
  134. package/lib/cjs/HiddenLine.js.map +1 -1
  135. package/lib/cjs/Hilite.d.ts +50 -50
  136. package/lib/cjs/Hilite.js +64 -64
  137. package/lib/cjs/Hilite.js.map +1 -1
  138. package/lib/cjs/IModel.d.ts +358 -358
  139. package/lib/cjs/IModel.d.ts.map +1 -1
  140. package/lib/cjs/IModel.js +347 -347
  141. package/lib/cjs/IModel.js.map +1 -1
  142. package/lib/cjs/IModelError.d.ts +42 -42
  143. package/lib/cjs/IModelError.d.ts.map +1 -1
  144. package/lib/cjs/IModelError.js +71 -71
  145. package/lib/cjs/IModelVersion.d.ts +68 -68
  146. package/lib/cjs/IModelVersion.d.ts.map +1 -1
  147. package/lib/cjs/IModelVersion.js +79 -79
  148. package/lib/cjs/Image.d.ts +86 -86
  149. package/lib/cjs/Image.js +128 -128
  150. package/lib/cjs/Image.js.map +1 -1
  151. package/lib/cjs/IpcAppProps.d.ts +141 -141
  152. package/lib/cjs/IpcAppProps.js +23 -23
  153. package/lib/cjs/LightSettings.d.ts +224 -224
  154. package/lib/cjs/LightSettings.js +304 -304
  155. package/lib/cjs/LightSettings.js.map +1 -1
  156. package/lib/cjs/LinePixels.d.ts +34 -34
  157. package/lib/cjs/LinePixels.js +42 -42
  158. package/lib/cjs/Localization.d.ts +113 -113
  159. package/lib/cjs/Localization.js +33 -33
  160. package/lib/cjs/MapImagerySettings.d.ts +62 -62
  161. package/lib/cjs/MapImagerySettings.d.ts.map +1 -1
  162. package/lib/cjs/MapImagerySettings.js +80 -80
  163. package/lib/cjs/MapLayerSettings.d.ts +272 -272
  164. package/lib/cjs/MapLayerSettings.d.ts.map +1 -1
  165. package/lib/cjs/MapLayerSettings.js +407 -407
  166. package/lib/cjs/MapLayerSettings.js.map +1 -1
  167. package/lib/cjs/MassProperties.d.ts +64 -64
  168. package/lib/cjs/MassProperties.js +23 -23
  169. package/lib/cjs/MaterialProps.d.ts +153 -153
  170. package/lib/cjs/MaterialProps.d.ts.map +1 -1
  171. package/lib/cjs/MaterialProps.js +35 -35
  172. package/lib/cjs/ModelClipGroup.d.ts +67 -67
  173. package/lib/cjs/ModelClipGroup.js +96 -96
  174. package/lib/cjs/ModelGeometryChanges.d.ts +107 -107
  175. package/lib/cjs/ModelGeometryChanges.d.ts.map +1 -1
  176. package/lib/cjs/ModelGeometryChanges.js +83 -83
  177. package/lib/cjs/ModelProps.d.ts +67 -67
  178. package/lib/cjs/ModelProps.js +9 -9
  179. package/lib/cjs/NativeAppProps.d.ts +122 -122
  180. package/lib/cjs/NativeAppProps.d.ts.map +1 -1
  181. package/lib/cjs/NativeAppProps.js +30 -30
  182. package/lib/cjs/OctEncodedNormal.d.ts +33 -33
  183. package/lib/cjs/OctEncodedNormal.js +98 -98
  184. package/lib/cjs/PlanProjectionSettings.d.ts +47 -47
  185. package/lib/cjs/PlanProjectionSettings.js +63 -63
  186. package/lib/cjs/PlanProjectionSettings.js.map +1 -1
  187. package/lib/cjs/PlanarClipMask.d.ts +177 -177
  188. package/lib/cjs/PlanarClipMask.js +136 -136
  189. package/lib/cjs/PlanarClipMask.js.map +1 -1
  190. package/lib/cjs/QPoint.d.ts +479 -479
  191. package/lib/cjs/QPoint.js +824 -824
  192. package/lib/cjs/QPoint.js.map +1 -1
  193. package/lib/cjs/RealityDataAccessProps.d.ts +41 -41
  194. package/lib/cjs/RealityDataAccessProps.js +19 -19
  195. package/lib/cjs/RealityModelDisplaySettings.d.ts +183 -183
  196. package/lib/cjs/RealityModelDisplaySettings.d.ts.map +1 -1
  197. package/lib/cjs/RealityModelDisplaySettings.js +141 -141
  198. package/lib/cjs/RealityModelDisplaySettings.js.map +1 -1
  199. package/lib/cjs/Render.d.ts +89 -89
  200. package/lib/cjs/Render.js +177 -177
  201. package/lib/cjs/RenderMaterial.d.ts +58 -58
  202. package/lib/cjs/RenderMaterial.js +75 -75
  203. package/lib/cjs/RenderMaterial.js.map +1 -1
  204. package/lib/cjs/RenderSchedule.d.ts +543 -543
  205. package/lib/cjs/RenderSchedule.js +992 -992
  206. package/lib/cjs/RenderSchedule.js.map +1 -1
  207. package/lib/cjs/RenderTexture.d.ts +70 -70
  208. package/lib/cjs/RenderTexture.d.ts.map +1 -1
  209. package/lib/cjs/RenderTexture.js +59 -59
  210. package/lib/cjs/RenderTexture.js.map +1 -1
  211. package/lib/cjs/RgbColor.d.ts +47 -47
  212. package/lib/cjs/RgbColor.js +77 -77
  213. package/lib/cjs/RpcInterface.d.ts +33 -33
  214. package/lib/cjs/RpcInterface.d.ts.map +1 -1
  215. package/lib/cjs/RpcInterface.js +137 -137
  216. package/lib/cjs/RpcInterface.js.map +1 -1
  217. package/lib/cjs/RpcManager.d.ts +40 -40
  218. package/lib/cjs/RpcManager.js +55 -55
  219. package/lib/cjs/SessionProps.d.ts +16 -16
  220. package/lib/cjs/SessionProps.js +9 -9
  221. package/lib/cjs/SkyBox.d.ts +215 -215
  222. package/lib/cjs/SkyBox.d.ts.map +1 -1
  223. package/lib/cjs/SkyBox.js +209 -209
  224. package/lib/cjs/SkyBox.js.map +1 -1
  225. package/lib/cjs/Snapping.d.ts +49 -49
  226. package/lib/cjs/Snapping.js +9 -9
  227. package/lib/cjs/SolarCalculate.d.ts +27 -27
  228. package/lib/cjs/SolarCalculate.js +211 -211
  229. package/lib/cjs/SolarShadows.d.ts +35 -35
  230. package/lib/cjs/SolarShadows.js +61 -61
  231. package/lib/cjs/SolarShadows.js.map +1 -1
  232. package/lib/cjs/SpatialClassification.d.ts +208 -208
  233. package/lib/cjs/SpatialClassification.js +339 -339
  234. package/lib/cjs/SubCategoryAppearance.d.ts +91 -91
  235. package/lib/cjs/SubCategoryAppearance.js +96 -96
  236. package/lib/cjs/SubCategoryAppearance.js.map +1 -1
  237. package/lib/cjs/SubCategoryOverride.d.ts +46 -46
  238. package/lib/cjs/SubCategoryOverride.js +104 -104
  239. package/lib/cjs/SubCategoryOverride.js.map +1 -1
  240. package/lib/cjs/TerrainSettings.d.ts +82 -82
  241. package/lib/cjs/TerrainSettings.d.ts.map +1 -1
  242. package/lib/cjs/TerrainSettings.js +100 -100
  243. package/lib/cjs/TerrainSettings.js.map +1 -1
  244. package/lib/cjs/TextureMapping.d.ts +118 -118
  245. package/lib/cjs/TextureMapping.js +173 -173
  246. package/lib/cjs/TextureProps.d.ts +65 -65
  247. package/lib/cjs/TextureProps.js +28 -28
  248. package/lib/cjs/ThematicDisplay.d.ts +230 -230
  249. package/lib/cjs/ThematicDisplay.js +343 -343
  250. package/lib/cjs/ThematicDisplay.js.map +1 -1
  251. package/lib/cjs/Thumbnail.d.ts +26 -26
  252. package/lib/cjs/Thumbnail.js +9 -9
  253. package/lib/cjs/TileProps.d.ts +82 -82
  254. package/lib/cjs/TileProps.js +29 -29
  255. package/lib/cjs/Tween.d.ts +191 -191
  256. package/lib/cjs/Tween.d.ts.map +1 -1
  257. package/lib/cjs/Tween.js +570 -570
  258. package/lib/cjs/TxnAction.d.ts +21 -21
  259. package/lib/cjs/TxnAction.js +29 -29
  260. package/lib/cjs/ViewDetails.d.ts +125 -125
  261. package/lib/cjs/ViewDetails.js +166 -166
  262. package/lib/cjs/ViewDetails.js.map +1 -1
  263. package/lib/cjs/ViewFlags.d.ts +287 -287
  264. package/lib/cjs/ViewFlags.d.ts.map +1 -1
  265. package/lib/cjs/ViewFlags.js +367 -367
  266. package/lib/cjs/ViewFlags.js.map +1 -1
  267. package/lib/cjs/ViewProps.d.ts +205 -205
  268. package/lib/cjs/ViewProps.js +9 -9
  269. package/lib/cjs/WhiteOnWhiteReversalSettings.d.ts +36 -36
  270. package/lib/cjs/WhiteOnWhiteReversalSettings.js +37 -37
  271. package/lib/cjs/WhiteOnWhiteReversalSettings.js.map +1 -1
  272. package/lib/cjs/core-common.d.ts +245 -245
  273. package/lib/cjs/core-common.js +265 -261
  274. package/lib/cjs/core-common.js.map +1 -1
  275. package/lib/cjs/domains/FunctionalElementProps.d.ts +11 -11
  276. package/lib/cjs/domains/FunctionalElementProps.js +9 -9
  277. package/lib/cjs/domains/GenericElementProps.d.ts +18 -18
  278. package/lib/cjs/domains/GenericElementProps.js +9 -9
  279. package/lib/cjs/geometry/AdditionalTransform.d.ts +84 -84
  280. package/lib/cjs/geometry/AdditionalTransform.js +85 -85
  281. package/lib/cjs/geometry/AreaPattern.d.ts +82 -82
  282. package/lib/cjs/geometry/AreaPattern.js +203 -203
  283. package/lib/cjs/geometry/BoundingSphere.d.ts +27 -27
  284. package/lib/cjs/geometry/BoundingSphere.js +44 -44
  285. package/lib/cjs/geometry/Cartographic.d.ts +137 -137
  286. package/lib/cjs/geometry/Cartographic.js +345 -345
  287. package/lib/cjs/geometry/Cartographic.js.map +1 -1
  288. package/lib/cjs/geometry/CoordinateReferenceSystem.d.ts +269 -269
  289. package/lib/cjs/geometry/CoordinateReferenceSystem.d.ts.map +1 -1
  290. package/lib/cjs/geometry/CoordinateReferenceSystem.js +260 -260
  291. package/lib/cjs/geometry/ElementGeometry.d.ts +402 -402
  292. package/lib/cjs/geometry/ElementGeometry.d.ts.map +1 -1
  293. package/lib/cjs/geometry/ElementGeometry.js +1719 -1719
  294. package/lib/cjs/geometry/ElementGeometryFB.d.ts +2372 -2372
  295. package/lib/cjs/geometry/ElementGeometryFB.js +3814 -3814
  296. package/lib/cjs/geometry/ElementGeometryFB.js.map +1 -1
  297. package/lib/cjs/geometry/FrustumPlanes.d.ts +81 -81
  298. package/lib/cjs/geometry/FrustumPlanes.js +189 -189
  299. package/lib/cjs/geometry/GeodeticDatum.d.ts +409 -409
  300. package/lib/cjs/geometry/GeodeticDatum.d.ts.map +1 -1
  301. package/lib/cjs/geometry/GeodeticDatum.js +400 -400
  302. package/lib/cjs/geometry/GeodeticEllipsoid.d.ts +72 -72
  303. package/lib/cjs/geometry/GeodeticEllipsoid.js +71 -71
  304. package/lib/cjs/geometry/GeometryStream.d.ts +347 -347
  305. package/lib/cjs/geometry/GeometryStream.d.ts.map +1 -1
  306. package/lib/cjs/geometry/GeometryStream.js +468 -468
  307. package/lib/cjs/geometry/ImageGraphic.d.ts +74 -74
  308. package/lib/cjs/geometry/ImageGraphic.d.ts.map +1 -1
  309. package/lib/cjs/geometry/ImageGraphic.js +98 -98
  310. package/lib/cjs/geometry/LineStyle.d.ts +71 -71
  311. package/lib/cjs/geometry/LineStyle.js +129 -129
  312. package/lib/cjs/geometry/Placement.d.ts +95 -95
  313. package/lib/cjs/geometry/Placement.d.ts.map +1 -1
  314. package/lib/cjs/geometry/Placement.js +131 -131
  315. package/lib/cjs/geometry/Projection.d.ts +251 -251
  316. package/lib/cjs/geometry/Projection.d.ts.map +1 -1
  317. package/lib/cjs/geometry/Projection.js +198 -198
  318. package/lib/cjs/geometry/Projection.js.map +1 -1
  319. package/lib/cjs/geometry/TextString.d.ts +55 -55
  320. package/lib/cjs/geometry/TextString.js +65 -65
  321. package/lib/cjs/geometry/TextString.js.map +1 -1
  322. package/lib/cjs/ipc/IpcSession.d.ts +23 -23
  323. package/lib/cjs/ipc/IpcSession.js +27 -27
  324. package/lib/cjs/ipc/IpcSocket.d.ts +96 -96
  325. package/lib/cjs/ipc/IpcSocket.d.ts.map +1 -1
  326. package/lib/cjs/ipc/IpcSocket.js +16 -16
  327. package/lib/cjs/ipc/IpcWebSocket.d.ts +61 -61
  328. package/lib/cjs/ipc/IpcWebSocket.js +150 -150
  329. package/lib/cjs/ipc/IpcWebSocket.js.map +1 -1
  330. package/lib/cjs/ipc/IpcWebSocketTransport.d.ts +15 -15
  331. package/lib/cjs/ipc/IpcWebSocketTransport.js +160 -160
  332. package/lib/cjs/ipc/IpcWebSocketTransport.js.map +1 -1
  333. package/lib/cjs/rpc/DevToolsRpcInterface.d.ts +32 -32
  334. package/lib/cjs/rpc/DevToolsRpcInterface.js +52 -52
  335. package/lib/cjs/rpc/DevToolsRpcInterface.js.map +1 -1
  336. package/lib/cjs/rpc/IModelReadRpcInterface.d.ts +99 -99
  337. package/lib/cjs/rpc/IModelReadRpcInterface.js +122 -122
  338. package/lib/cjs/rpc/IModelReadRpcInterface.js.map +1 -1
  339. package/lib/cjs/rpc/IModelTileRpcInterface.d.ts +61 -61
  340. package/lib/cjs/rpc/IModelTileRpcInterface.js +97 -96
  341. package/lib/cjs/rpc/IModelTileRpcInterface.js.map +1 -1
  342. package/lib/cjs/rpc/SnapshotIModelRpcInterface.d.ts +23 -23
  343. package/lib/cjs/rpc/SnapshotIModelRpcInterface.js +48 -48
  344. package/lib/cjs/rpc/SnapshotIModelRpcInterface.js.map +1 -1
  345. package/lib/cjs/rpc/TestRpcManager.d.ts +20 -20
  346. package/lib/cjs/rpc/TestRpcManager.js +40 -40
  347. package/lib/cjs/rpc/WipRpcInterface.d.ts +29 -29
  348. package/lib/cjs/rpc/WipRpcInterface.js +40 -40
  349. package/lib/cjs/rpc/WipRpcInterface.js.map +1 -1
  350. package/lib/cjs/rpc/core/RpcConfiguration.d.ts +111 -111
  351. package/lib/cjs/rpc/core/RpcConfiguration.d.ts.map +1 -1
  352. package/lib/cjs/rpc/core/RpcConfiguration.js +191 -191
  353. package/lib/cjs/rpc/core/RpcConfiguration.js.map +1 -1
  354. package/lib/cjs/rpc/core/RpcConstants.d.ts +90 -90
  355. package/lib/cjs/rpc/core/RpcConstants.js +109 -109
  356. package/lib/cjs/rpc/core/RpcControl.d.ts +54 -54
  357. package/lib/cjs/rpc/core/RpcControl.js +150 -145
  358. package/lib/cjs/rpc/core/RpcControl.js.map +1 -1
  359. package/lib/cjs/rpc/core/RpcInvocation.d.ts +89 -89
  360. package/lib/cjs/rpc/core/RpcInvocation.d.ts.map +1 -1
  361. package/lib/cjs/rpc/core/RpcInvocation.js +256 -256
  362. package/lib/cjs/rpc/core/RpcInvocation.js.map +1 -1
  363. package/lib/cjs/rpc/core/RpcMarshaling.d.ts +35 -35
  364. package/lib/cjs/rpc/core/RpcMarshaling.js +156 -156
  365. package/lib/cjs/rpc/core/RpcOperation.d.ts +67 -67
  366. package/lib/cjs/rpc/core/RpcOperation.d.ts.map +1 -1
  367. package/lib/cjs/rpc/core/RpcOperation.js +135 -134
  368. package/lib/cjs/rpc/core/RpcOperation.js.map +1 -1
  369. package/lib/cjs/rpc/core/RpcPendingQueue.d.ts +21 -21
  370. package/lib/cjs/rpc/core/RpcPendingQueue.js +94 -94
  371. package/lib/cjs/rpc/core/RpcPendingQueue.js.map +1 -1
  372. package/lib/cjs/rpc/core/RpcProtocol.d.ts +132 -132
  373. package/lib/cjs/rpc/core/RpcProtocol.d.ts.map +1 -1
  374. package/lib/cjs/rpc/core/RpcProtocol.js +127 -127
  375. package/lib/cjs/rpc/core/RpcProtocol.js.map +1 -1
  376. package/lib/cjs/rpc/core/RpcPush.d.ts +68 -68
  377. package/lib/cjs/rpc/core/RpcPush.d.ts.map +1 -1
  378. package/lib/cjs/rpc/core/RpcPush.js +127 -127
  379. package/lib/cjs/rpc/core/RpcPush.js.map +1 -1
  380. package/lib/cjs/rpc/core/RpcRegistry.d.ts +48 -48
  381. package/lib/cjs/rpc/core/RpcRegistry.js +198 -198
  382. package/lib/cjs/rpc/core/RpcRequest.d.ts +186 -186
  383. package/lib/cjs/rpc/core/RpcRequest.d.ts.map +1 -1
  384. package/lib/cjs/rpc/core/RpcRequest.js +478 -478
  385. package/lib/cjs/rpc/core/RpcRequest.js.map +1 -1
  386. package/lib/cjs/rpc/core/RpcRequestContext.d.ts +14 -14
  387. package/lib/cjs/rpc/core/RpcRequestContext.js +2 -2
  388. package/lib/cjs/rpc/core/RpcRoutingToken.d.ts +12 -12
  389. package/lib/cjs/rpc/core/RpcRoutingToken.js +24 -24
  390. package/lib/cjs/rpc/core/RpcRoutingToken.js.map +1 -1
  391. package/lib/cjs/rpc/core/RpcSessionInvocation.d.ts +10 -10
  392. package/lib/cjs/rpc/core/RpcSessionInvocation.js +60 -60
  393. package/lib/cjs/rpc/core/RpcSessionInvocation.js.map +1 -1
  394. package/lib/cjs/rpc/web/BentleyCloudRpcManager.d.ts +46 -46
  395. package/lib/cjs/rpc/web/BentleyCloudRpcManager.js +73 -73
  396. package/lib/cjs/rpc/web/BentleyCloudRpcManager.js.map +1 -1
  397. package/lib/cjs/rpc/web/BentleyCloudRpcProtocol.d.ts +33 -33
  398. package/lib/cjs/rpc/web/BentleyCloudRpcProtocol.js +141 -141
  399. package/lib/cjs/rpc/web/OpenAPI.d.ts +140 -140
  400. package/lib/cjs/rpc/web/OpenAPI.js +60 -60
  401. package/lib/cjs/rpc/web/OpenAPI.js.map +1 -1
  402. package/lib/cjs/rpc/web/RpcMultipart.d.ts +35 -35
  403. package/lib/cjs/rpc/web/RpcMultipart.js +50 -50
  404. package/lib/cjs/rpc/web/RpcMultipart.js.map +1 -1
  405. package/lib/cjs/rpc/web/WebAppRpcLogging.d.ts +28 -28
  406. package/lib/cjs/rpc/web/WebAppRpcLogging.js +140 -140
  407. package/lib/cjs/rpc/web/WebAppRpcProtocol.d.ts +89 -89
  408. package/lib/cjs/rpc/web/WebAppRpcProtocol.js +116 -116
  409. package/lib/cjs/rpc/web/WebAppRpcProtocol.js.map +1 -1
  410. package/lib/cjs/rpc/web/WebAppRpcRequest.d.ts +67 -67
  411. package/lib/cjs/rpc/web/WebAppRpcRequest.d.ts.map +1 -1
  412. package/lib/cjs/rpc/web/WebAppRpcRequest.js +239 -239
  413. package/lib/cjs/rpc/web/WebAppRpcRequest.js.map +1 -1
  414. package/lib/cjs/rpc/web/multipart/RpcMultipartParser.d.ts +32 -32
  415. package/lib/cjs/rpc/web/multipart/RpcMultipartParser.js +373 -373
  416. package/lib/cjs/tile/B3dmTileIO.d.ts +19 -19
  417. package/lib/cjs/tile/B3dmTileIO.js +66 -66
  418. package/lib/cjs/tile/B3dmTileIO.js.map +1 -1
  419. package/lib/cjs/tile/CompositeTileIO.d.ts +15 -15
  420. package/lib/cjs/tile/CompositeTileIO.js +26 -26
  421. package/lib/cjs/tile/CompositeTileIO.js.map +1 -1
  422. package/lib/cjs/tile/ElementGraphics.d.ts +145 -145
  423. package/lib/cjs/tile/ElementGraphics.d.ts.map +1 -1
  424. package/lib/cjs/tile/ElementGraphics.js +9 -9
  425. package/lib/cjs/tile/GltfTileIO.d.ts +45 -45
  426. package/lib/cjs/tile/GltfTileIO.d.ts.map +1 -1
  427. package/lib/cjs/tile/GltfTileIO.js +109 -109
  428. package/lib/cjs/tile/GltfTileIO.js.map +1 -1
  429. package/lib/cjs/tile/I3dmTileIO.d.ts +20 -20
  430. package/lib/cjs/tile/I3dmTileIO.js +40 -40
  431. package/lib/cjs/tile/I3dmTileIO.js.map +1 -1
  432. package/lib/cjs/tile/IModelTileIO.d.ts +77 -77
  433. package/lib/cjs/tile/IModelTileIO.js +97 -97
  434. package/lib/cjs/tile/IModelTileIO.js.map +1 -1
  435. package/lib/cjs/tile/PntsTileIO.d.ts +17 -17
  436. package/lib/cjs/tile/PntsTileIO.js +26 -26
  437. package/lib/cjs/tile/PntsTileIO.js.map +1 -1
  438. package/lib/cjs/tile/TileIO.d.ts +66 -66
  439. package/lib/cjs/tile/TileIO.js +118 -118
  440. package/lib/cjs/tile/TileMetadata.d.ts +228 -228
  441. package/lib/cjs/tile/TileMetadata.d.ts.map +1 -1
  442. package/lib/cjs/tile/TileMetadata.js +675 -675
  443. package/lib/cjs/tile/TileMetadata.js.map +1 -1
  444. package/lib/cjs/tile/Tileset3dSchema.d.ts +96 -96
  445. package/lib/cjs/tile/Tileset3dSchema.js +9 -9
  446. package/lib/esm/AmbientOcclusion.d.ts +49 -49
  447. package/lib/esm/AmbientOcclusion.js +52 -52
  448. package/lib/esm/AnalysisStyle.d.ts +134 -134
  449. package/lib/esm/AnalysisStyle.js +160 -159
  450. package/lib/esm/AnalysisStyle.js.map +1 -1
  451. package/lib/esm/AuthorizationClient.d.ts +17 -17
  452. package/lib/esm/AuthorizationClient.js +8 -8
  453. package/lib/esm/BackendTypes.d.ts +13 -12
  454. package/lib/esm/BackendTypes.d.ts.map +1 -1
  455. package/lib/esm/BackendTypes.js +8 -8
  456. package/lib/esm/BackgroundMapProvider.d.ts +51 -51
  457. package/lib/esm/BackgroundMapProvider.d.ts.map +1 -1
  458. package/lib/esm/BackgroundMapProvider.js +63 -63
  459. package/lib/esm/BackgroundMapSettings.d.ts +136 -136
  460. package/lib/esm/BackgroundMapSettings.d.ts.map +1 -1
  461. package/lib/esm/BackgroundMapSettings.js +150 -150
  462. package/lib/esm/BackgroundMapSettings.js.map +1 -1
  463. package/lib/esm/Base64EncodedString.d.ts +32 -32
  464. package/lib/esm/Base64EncodedString.d.ts.map +1 -1
  465. package/lib/esm/Base64EncodedString.js +63 -63
  466. package/lib/esm/Base64EncodedString.js.map +1 -1
  467. package/lib/esm/BlobReader.d.ts +31 -31
  468. package/lib/esm/BlobReader.js +79 -79
  469. package/lib/esm/BriefcaseTypes.d.ts +191 -191
  470. package/lib/esm/BriefcaseTypes.d.ts.map +1 -1
  471. package/lib/esm/BriefcaseTypes.js +92 -92
  472. package/lib/esm/Camera.d.ts +42 -42
  473. package/lib/esm/Camera.js +58 -58
  474. package/lib/esm/Camera.js.map +1 -1
  475. package/lib/esm/ChangedElements.d.ts +85 -85
  476. package/lib/esm/ChangedElements.js +20 -20
  477. package/lib/esm/ChangedEntities.d.ts +45 -45
  478. package/lib/esm/ChangedEntities.d.ts.map +1 -1
  479. package/lib/esm/ChangedEntities.js +8 -8
  480. package/lib/esm/ChangesetProps.d.ts +98 -98
  481. package/lib/esm/ChangesetProps.d.ts.map +1 -1
  482. package/lib/esm/ChangesetProps.js +19 -19
  483. package/lib/esm/ClipStyle.d.ts +89 -89
  484. package/lib/esm/ClipStyle.js +118 -116
  485. package/lib/esm/ClipStyle.js.map +1 -1
  486. package/lib/esm/CloudStorage.d.ts +62 -62
  487. package/lib/esm/CloudStorage.js +109 -109
  488. package/lib/esm/CloudStorage.js.map +1 -1
  489. package/lib/esm/CloudStorageTileCache.d.ts +27 -27
  490. package/lib/esm/CloudStorageTileCache.js +61 -61
  491. package/lib/esm/CloudStorageTileCache.js.map +1 -1
  492. package/lib/esm/Code.d.ts +277 -277
  493. package/lib/esm/Code.d.ts.map +1 -1
  494. package/lib/esm/Code.js +263 -263
  495. package/lib/esm/Code.js.map +1 -1
  496. package/lib/esm/ColorByName.d.ts +161 -161
  497. package/lib/esm/ColorByName.js +166 -166
  498. package/lib/esm/ColorDef.d.ts +210 -210
  499. package/lib/esm/ColorDef.d.ts.map +1 -1
  500. package/lib/esm/ColorDef.js +569 -568
  501. package/lib/esm/ColorDef.js.map +1 -1
  502. package/lib/esm/CommonLoggerCategory.d.ts +18 -18
  503. package/lib/esm/CommonLoggerCategory.js +23 -23
  504. package/lib/esm/ConcurrentQuery.d.ts +421 -421
  505. package/lib/esm/ConcurrentQuery.d.ts.map +1 -1
  506. package/lib/esm/ConcurrentQuery.js +545 -545
  507. package/lib/esm/ContextRealityModel.d.ts +303 -303
  508. package/lib/esm/ContextRealityModel.js +366 -366
  509. package/lib/esm/DisplayStyleSettings.d.ts +588 -588
  510. package/lib/esm/DisplayStyleSettings.js +976 -976
  511. package/lib/esm/DisplayStyleSettings.js.map +1 -1
  512. package/lib/esm/ECSchemaProps.d.ts +39 -39
  513. package/lib/esm/ECSchemaProps.js +8 -8
  514. package/lib/esm/ECSqlReader.d.ts +70 -70
  515. package/lib/esm/ECSqlReader.d.ts.map +1 -1
  516. package/lib/esm/ECSqlReader.js +276 -275
  517. package/lib/esm/ECSqlReader.js.map +1 -1
  518. package/lib/esm/ECSqlTypes.d.ts +128 -128
  519. package/lib/esm/ECSqlTypes.js +185 -185
  520. package/lib/esm/ElementMesh.d.ts +39 -39
  521. package/lib/esm/ElementMesh.js +52 -52
  522. package/lib/esm/ElementProps.d.ts +483 -483
  523. package/lib/esm/ElementProps.d.ts.map +1 -1
  524. package/lib/esm/ElementProps.js +93 -92
  525. package/lib/esm/ElementProps.js.map +1 -1
  526. package/lib/esm/EmphasizeElementsProps.d.ts +55 -55
  527. package/lib/esm/EmphasizeElementsProps.js +22 -22
  528. package/lib/esm/EntityProps.d.ts +177 -177
  529. package/lib/esm/EntityProps.d.ts.map +1 -1
  530. package/lib/esm/EntityProps.js +108 -108
  531. package/lib/esm/EntityReference.d.ts +51 -51
  532. package/lib/esm/EntityReference.d.ts.map +1 -1
  533. package/lib/esm/EntityReference.js +52 -52
  534. package/lib/esm/Environment.d.ts +61 -61
  535. package/lib/esm/Environment.d.ts.map +1 -1
  536. package/lib/esm/Environment.js +67 -66
  537. package/lib/esm/Environment.js.map +1 -1
  538. package/lib/esm/FeatureIndex.d.ts +39 -39
  539. package/lib/esm/FeatureIndex.js +57 -57
  540. package/lib/esm/FeatureIndex.js.map +1 -1
  541. package/lib/esm/FeatureSymbology.d.ts +449 -449
  542. package/lib/esm/FeatureSymbology.d.ts.map +1 -1
  543. package/lib/esm/FeatureSymbology.js +615 -613
  544. package/lib/esm/FeatureSymbology.js.map +1 -1
  545. package/lib/esm/FeatureTable.d.ts +248 -248
  546. package/lib/esm/FeatureTable.d.ts.map +1 -1
  547. package/lib/esm/FeatureTable.js +462 -462
  548. package/lib/esm/FeatureTable.js.map +1 -1
  549. package/lib/esm/Fonts.d.ts +51 -51
  550. package/lib/esm/Fonts.d.ts.map +1 -1
  551. package/lib/esm/Fonts.js +49 -49
  552. package/lib/esm/Frustum.d.ts +114 -114
  553. package/lib/esm/Frustum.js +288 -288
  554. package/lib/esm/GeoCoordinateServices.d.ts +123 -119
  555. package/lib/esm/GeoCoordinateServices.d.ts.map +1 -1
  556. package/lib/esm/GeoCoordinateServices.js +77 -76
  557. package/lib/esm/GeoCoordinateServices.js.map +1 -1
  558. package/lib/esm/GeometryContainment.d.ts +28 -28
  559. package/lib/esm/GeometryContainment.js +8 -8
  560. package/lib/esm/GeometryParams.d.ts +130 -130
  561. package/lib/esm/GeometryParams.js +170 -170
  562. package/lib/esm/GeometrySummary.d.ts +45 -45
  563. package/lib/esm/GeometrySummary.js +20 -20
  564. package/lib/esm/Gradient.d.ts +139 -139
  565. package/lib/esm/Gradient.js +450 -450
  566. package/lib/esm/Gradient.js.map +1 -1
  567. package/lib/esm/GraphicParams.d.ts +58 -58
  568. package/lib/esm/GraphicParams.js +81 -81
  569. package/lib/esm/GroundPlane.d.ts +52 -52
  570. package/lib/esm/GroundPlane.d.ts.map +1 -1
  571. package/lib/esm/GroundPlane.js +60 -59
  572. package/lib/esm/GroundPlane.js.map +1 -1
  573. package/lib/esm/HSLColor.d.ts +20 -20
  574. package/lib/esm/HSLColor.js +28 -28
  575. package/lib/esm/HSVColor.d.ts +30 -30
  576. package/lib/esm/HSVColor.js +55 -55
  577. package/lib/esm/HiddenLine.d.ts +97 -97
  578. package/lib/esm/HiddenLine.js +157 -157
  579. package/lib/esm/HiddenLine.js.map +1 -1
  580. package/lib/esm/Hilite.d.ts +50 -50
  581. package/lib/esm/Hilite.js +61 -61
  582. package/lib/esm/Hilite.js.map +1 -1
  583. package/lib/esm/IModel.d.ts +358 -358
  584. package/lib/esm/IModel.d.ts.map +1 -1
  585. package/lib/esm/IModel.js +343 -342
  586. package/lib/esm/IModel.js.map +1 -1
  587. package/lib/esm/IModelError.d.ts +42 -42
  588. package/lib/esm/IModelError.d.ts.map +1 -1
  589. package/lib/esm/IModelError.js +56 -56
  590. package/lib/esm/IModelVersion.d.ts +68 -68
  591. package/lib/esm/IModelVersion.d.ts.map +1 -1
  592. package/lib/esm/IModelVersion.js +75 -75
  593. package/lib/esm/Image.d.ts +86 -86
  594. package/lib/esm/Image.js +120 -120
  595. package/lib/esm/Image.js.map +1 -1
  596. package/lib/esm/IpcAppProps.d.ts +141 -141
  597. package/lib/esm/IpcAppProps.js +19 -19
  598. package/lib/esm/LightSettings.d.ts +224 -224
  599. package/lib/esm/LightSettings.js +297 -296
  600. package/lib/esm/LightSettings.js.map +1 -1
  601. package/lib/esm/LinePixels.d.ts +34 -34
  602. package/lib/esm/LinePixels.js +39 -39
  603. package/lib/esm/Localization.d.ts +113 -113
  604. package/lib/esm/Localization.js +29 -29
  605. package/lib/esm/MapImagerySettings.d.ts +62 -62
  606. package/lib/esm/MapImagerySettings.d.ts.map +1 -1
  607. package/lib/esm/MapImagerySettings.js +76 -76
  608. package/lib/esm/MapLayerSettings.d.ts +272 -272
  609. package/lib/esm/MapLayerSettings.d.ts.map +1 -1
  610. package/lib/esm/MapLayerSettings.js +399 -399
  611. package/lib/esm/MapLayerSettings.js.map +1 -1
  612. package/lib/esm/MassProperties.d.ts +64 -64
  613. package/lib/esm/MassProperties.js +20 -20
  614. package/lib/esm/MaterialProps.d.ts +153 -153
  615. package/lib/esm/MaterialProps.d.ts.map +1 -1
  616. package/lib/esm/MaterialProps.js +32 -32
  617. package/lib/esm/ModelClipGroup.d.ts +67 -67
  618. package/lib/esm/ModelClipGroup.js +91 -91
  619. package/lib/esm/ModelGeometryChanges.d.ts +107 -107
  620. package/lib/esm/ModelGeometryChanges.d.ts.map +1 -1
  621. package/lib/esm/ModelGeometryChanges.js +80 -80
  622. package/lib/esm/ModelProps.d.ts +67 -67
  623. package/lib/esm/ModelProps.js +8 -8
  624. package/lib/esm/NativeAppProps.d.ts +122 -122
  625. package/lib/esm/NativeAppProps.d.ts.map +1 -1
  626. package/lib/esm/NativeAppProps.js +27 -27
  627. package/lib/esm/OctEncodedNormal.d.ts +33 -33
  628. package/lib/esm/OctEncodedNormal.js +93 -93
  629. package/lib/esm/PlanProjectionSettings.d.ts +47 -47
  630. package/lib/esm/PlanProjectionSettings.js +59 -59
  631. package/lib/esm/PlanProjectionSettings.js.map +1 -1
  632. package/lib/esm/PlanarClipMask.d.ts +177 -177
  633. package/lib/esm/PlanarClipMask.js +133 -132
  634. package/lib/esm/PlanarClipMask.js.map +1 -1
  635. package/lib/esm/QPoint.d.ts +479 -479
  636. package/lib/esm/QPoint.js +813 -813
  637. package/lib/esm/QPoint.js.map +1 -1
  638. package/lib/esm/RealityDataAccessProps.d.ts +41 -41
  639. package/lib/esm/RealityDataAccessProps.js +16 -16
  640. package/lib/esm/RealityModelDisplaySettings.d.ts +183 -183
  641. package/lib/esm/RealityModelDisplaySettings.d.ts.map +1 -1
  642. package/lib/esm/RealityModelDisplaySettings.js +138 -136
  643. package/lib/esm/RealityModelDisplaySettings.js.map +1 -1
  644. package/lib/esm/Render.d.ts +89 -89
  645. package/lib/esm/Render.js +165 -165
  646. package/lib/esm/RenderMaterial.d.ts +58 -58
  647. package/lib/esm/RenderMaterial.js +71 -71
  648. package/lib/esm/RenderMaterial.js.map +1 -1
  649. package/lib/esm/RenderSchedule.d.ts +543 -543
  650. package/lib/esm/RenderSchedule.js +989 -989
  651. package/lib/esm/RenderSchedule.js.map +1 -1
  652. package/lib/esm/RenderTexture.d.ts +70 -70
  653. package/lib/esm/RenderTexture.d.ts.map +1 -1
  654. package/lib/esm/RenderTexture.js +55 -55
  655. package/lib/esm/RenderTexture.js.map +1 -1
  656. package/lib/esm/RgbColor.d.ts +47 -47
  657. package/lib/esm/RgbColor.js +73 -73
  658. package/lib/esm/RpcInterface.d.ts +33 -33
  659. package/lib/esm/RpcInterface.d.ts.map +1 -1
  660. package/lib/esm/RpcInterface.js +133 -133
  661. package/lib/esm/RpcInterface.js.map +1 -1
  662. package/lib/esm/RpcManager.d.ts +40 -40
  663. package/lib/esm/RpcManager.js +51 -51
  664. package/lib/esm/SessionProps.d.ts +16 -16
  665. package/lib/esm/SessionProps.js +8 -8
  666. package/lib/esm/SkyBox.d.ts +215 -215
  667. package/lib/esm/SkyBox.d.ts.map +1 -1
  668. package/lib/esm/SkyBox.js +204 -202
  669. package/lib/esm/SkyBox.js.map +1 -1
  670. package/lib/esm/Snapping.d.ts +49 -49
  671. package/lib/esm/Snapping.js +8 -8
  672. package/lib/esm/SolarCalculate.d.ts +27 -27
  673. package/lib/esm/SolarCalculate.js +204 -204
  674. package/lib/esm/SolarShadows.d.ts +35 -35
  675. package/lib/esm/SolarShadows.js +58 -57
  676. package/lib/esm/SolarShadows.js.map +1 -1
  677. package/lib/esm/SpatialClassification.d.ts +208 -208
  678. package/lib/esm/SpatialClassification.js +333 -333
  679. package/lib/esm/SubCategoryAppearance.d.ts +91 -91
  680. package/lib/esm/SubCategoryAppearance.js +93 -92
  681. package/lib/esm/SubCategoryAppearance.js.map +1 -1
  682. package/lib/esm/SubCategoryOverride.d.ts +46 -46
  683. package/lib/esm/SubCategoryOverride.js +101 -100
  684. package/lib/esm/SubCategoryOverride.js.map +1 -1
  685. package/lib/esm/TerrainSettings.d.ts +82 -82
  686. package/lib/esm/TerrainSettings.d.ts.map +1 -1
  687. package/lib/esm/TerrainSettings.js +96 -96
  688. package/lib/esm/TerrainSettings.js.map +1 -1
  689. package/lib/esm/TextureMapping.d.ts +118 -118
  690. package/lib/esm/TextureMapping.js +169 -169
  691. package/lib/esm/TextureProps.d.ts +65 -65
  692. package/lib/esm/TextureProps.js +25 -25
  693. package/lib/esm/ThematicDisplay.d.ts +230 -230
  694. package/lib/esm/ThematicDisplay.js +337 -336
  695. package/lib/esm/ThematicDisplay.js.map +1 -1
  696. package/lib/esm/Thumbnail.d.ts +26 -26
  697. package/lib/esm/Thumbnail.js +8 -8
  698. package/lib/esm/TileProps.d.ts +82 -82
  699. package/lib/esm/TileProps.js +25 -25
  700. package/lib/esm/Tween.d.ts +191 -191
  701. package/lib/esm/Tween.d.ts.map +1 -1
  702. package/lib/esm/Tween.js +565 -565
  703. package/lib/esm/TxnAction.d.ts +21 -21
  704. package/lib/esm/TxnAction.js +26 -26
  705. package/lib/esm/ViewDetails.d.ts +125 -125
  706. package/lib/esm/ViewDetails.js +162 -161
  707. package/lib/esm/ViewDetails.js.map +1 -1
  708. package/lib/esm/ViewFlags.d.ts +287 -287
  709. package/lib/esm/ViewFlags.d.ts.map +1 -1
  710. package/lib/esm/ViewFlags.js +364 -363
  711. package/lib/esm/ViewFlags.js.map +1 -1
  712. package/lib/esm/ViewProps.d.ts +205 -205
  713. package/lib/esm/ViewProps.js +8 -8
  714. package/lib/esm/WhiteOnWhiteReversalSettings.d.ts +36 -36
  715. package/lib/esm/WhiteOnWhiteReversalSettings.js +34 -33
  716. package/lib/esm/WhiteOnWhiteReversalSettings.js.map +1 -1
  717. package/lib/esm/core-common.d.ts +245 -245
  718. package/lib/esm/core-common.js +249 -249
  719. package/lib/esm/domains/FunctionalElementProps.d.ts +11 -11
  720. package/lib/esm/domains/FunctionalElementProps.js +8 -8
  721. package/lib/esm/domains/GenericElementProps.d.ts +18 -18
  722. package/lib/esm/domains/GenericElementProps.js +8 -8
  723. package/lib/esm/geometry/AdditionalTransform.d.ts +84 -84
  724. package/lib/esm/geometry/AdditionalTransform.js +80 -80
  725. package/lib/esm/geometry/AreaPattern.d.ts +82 -82
  726. package/lib/esm/geometry/AreaPattern.js +200 -200
  727. package/lib/esm/geometry/BoundingSphere.d.ts +27 -27
  728. package/lib/esm/geometry/BoundingSphere.js +40 -40
  729. package/lib/esm/geometry/Cartographic.d.ts +137 -137
  730. package/lib/esm/geometry/Cartographic.js +341 -340
  731. package/lib/esm/geometry/Cartographic.js.map +1 -1
  732. package/lib/esm/geometry/CoordinateReferenceSystem.d.ts +269 -269
  733. package/lib/esm/geometry/CoordinateReferenceSystem.d.ts.map +1 -1
  734. package/lib/esm/geometry/CoordinateReferenceSystem.js +253 -253
  735. package/lib/esm/geometry/ElementGeometry.d.ts +402 -402
  736. package/lib/esm/geometry/ElementGeometry.d.ts.map +1 -1
  737. package/lib/esm/geometry/ElementGeometry.js +1716 -1716
  738. package/lib/esm/geometry/ElementGeometryFB.d.ts +2372 -2372
  739. package/lib/esm/geometry/ElementGeometryFB.js +3811 -3811
  740. package/lib/esm/geometry/ElementGeometryFB.js.map +1 -1
  741. package/lib/esm/geometry/FrustumPlanes.d.ts +81 -81
  742. package/lib/esm/geometry/FrustumPlanes.js +185 -185
  743. package/lib/esm/geometry/GeodeticDatum.d.ts +409 -409
  744. package/lib/esm/geometry/GeodeticDatum.d.ts.map +1 -1
  745. package/lib/esm/geometry/GeodeticDatum.js +389 -389
  746. package/lib/esm/geometry/GeodeticEllipsoid.d.ts +72 -72
  747. package/lib/esm/geometry/GeodeticEllipsoid.js +67 -67
  748. package/lib/esm/geometry/GeometryStream.d.ts +347 -347
  749. package/lib/esm/geometry/GeometryStream.d.ts.map +1 -1
  750. package/lib/esm/geometry/GeometryStream.js +463 -463
  751. package/lib/esm/geometry/ImageGraphic.d.ts +74 -74
  752. package/lib/esm/geometry/ImageGraphic.d.ts.map +1 -1
  753. package/lib/esm/geometry/ImageGraphic.js +93 -93
  754. package/lib/esm/geometry/LineStyle.d.ts +71 -71
  755. package/lib/esm/geometry/LineStyle.js +126 -126
  756. package/lib/esm/geometry/Placement.d.ts +95 -95
  757. package/lib/esm/geometry/Placement.d.ts.map +1 -1
  758. package/lib/esm/geometry/Placement.js +126 -126
  759. package/lib/esm/geometry/Projection.d.ts +251 -251
  760. package/lib/esm/geometry/Projection.d.ts.map +1 -1
  761. package/lib/esm/geometry/Projection.js +192 -192
  762. package/lib/esm/geometry/Projection.js.map +1 -1
  763. package/lib/esm/geometry/TextString.d.ts +55 -55
  764. package/lib/esm/geometry/TextString.js +61 -61
  765. package/lib/esm/geometry/TextString.js.map +1 -1
  766. package/lib/esm/ipc/IpcSession.d.ts +23 -23
  767. package/lib/esm/ipc/IpcSession.js +23 -23
  768. package/lib/esm/ipc/IpcSocket.d.ts +96 -96
  769. package/lib/esm/ipc/IpcSocket.d.ts.map +1 -1
  770. package/lib/esm/ipc/IpcSocket.js +12 -12
  771. package/lib/esm/ipc/IpcWebSocket.d.ts +61 -61
  772. package/lib/esm/ipc/IpcWebSocket.js +145 -144
  773. package/lib/esm/ipc/IpcWebSocket.js.map +1 -1
  774. package/lib/esm/ipc/IpcWebSocketTransport.d.ts +15 -15
  775. package/lib/esm/ipc/IpcWebSocketTransport.js +156 -156
  776. package/lib/esm/ipc/IpcWebSocketTransport.js.map +1 -1
  777. package/lib/esm/rpc/DevToolsRpcInterface.d.ts +32 -32
  778. package/lib/esm/rpc/DevToolsRpcInterface.js +49 -48
  779. package/lib/esm/rpc/DevToolsRpcInterface.js.map +1 -1
  780. package/lib/esm/rpc/IModelReadRpcInterface.d.ts +99 -99
  781. package/lib/esm/rpc/IModelReadRpcInterface.js +118 -117
  782. package/lib/esm/rpc/IModelReadRpcInterface.js.map +1 -1
  783. package/lib/esm/rpc/IModelTileRpcInterface.d.ts +61 -61
  784. package/lib/esm/rpc/IModelTileRpcInterface.js +94 -92
  785. package/lib/esm/rpc/IModelTileRpcInterface.js.map +1 -1
  786. package/lib/esm/rpc/SnapshotIModelRpcInterface.d.ts +23 -23
  787. package/lib/esm/rpc/SnapshotIModelRpcInterface.js +45 -44
  788. package/lib/esm/rpc/SnapshotIModelRpcInterface.js.map +1 -1
  789. package/lib/esm/rpc/TestRpcManager.d.ts +20 -20
  790. package/lib/esm/rpc/TestRpcManager.js +36 -36
  791. package/lib/esm/rpc/WipRpcInterface.d.ts +29 -29
  792. package/lib/esm/rpc/WipRpcInterface.js +37 -36
  793. package/lib/esm/rpc/WipRpcInterface.js.map +1 -1
  794. package/lib/esm/rpc/core/RpcConfiguration.d.ts +111 -111
  795. package/lib/esm/rpc/core/RpcConfiguration.d.ts.map +1 -1
  796. package/lib/esm/rpc/core/RpcConfiguration.js +185 -184
  797. package/lib/esm/rpc/core/RpcConfiguration.js.map +1 -1
  798. package/lib/esm/rpc/core/RpcConstants.d.ts +90 -90
  799. package/lib/esm/rpc/core/RpcConstants.js +106 -106
  800. package/lib/esm/rpc/core/RpcControl.d.ts +54 -54
  801. package/lib/esm/rpc/core/RpcControl.js +144 -138
  802. package/lib/esm/rpc/core/RpcControl.js.map +1 -1
  803. package/lib/esm/rpc/core/RpcInvocation.d.ts +89 -89
  804. package/lib/esm/rpc/core/RpcInvocation.d.ts.map +1 -1
  805. package/lib/esm/rpc/core/RpcInvocation.js +253 -252
  806. package/lib/esm/rpc/core/RpcInvocation.js.map +1 -1
  807. package/lib/esm/rpc/core/RpcMarshaling.d.ts +35 -35
  808. package/lib/esm/rpc/core/RpcMarshaling.js +152 -152
  809. package/lib/esm/rpc/core/RpcOperation.d.ts +67 -67
  810. package/lib/esm/rpc/core/RpcOperation.d.ts.map +1 -1
  811. package/lib/esm/rpc/core/RpcOperation.js +130 -129
  812. package/lib/esm/rpc/core/RpcOperation.js.map +1 -1
  813. package/lib/esm/rpc/core/RpcPendingQueue.d.ts +21 -21
  814. package/lib/esm/rpc/core/RpcPendingQueue.js +90 -90
  815. package/lib/esm/rpc/core/RpcPendingQueue.js.map +1 -1
  816. package/lib/esm/rpc/core/RpcProtocol.d.ts +132 -132
  817. package/lib/esm/rpc/core/RpcProtocol.d.ts.map +1 -1
  818. package/lib/esm/rpc/core/RpcProtocol.js +124 -123
  819. package/lib/esm/rpc/core/RpcProtocol.js.map +1 -1
  820. package/lib/esm/rpc/core/RpcPush.d.ts +68 -68
  821. package/lib/esm/rpc/core/RpcPush.d.ts.map +1 -1
  822. package/lib/esm/rpc/core/RpcPush.js +121 -119
  823. package/lib/esm/rpc/core/RpcPush.js.map +1 -1
  824. package/lib/esm/rpc/core/RpcRegistry.d.ts +48 -48
  825. package/lib/esm/rpc/core/RpcRegistry.js +194 -194
  826. package/lib/esm/rpc/core/RpcRequest.d.ts +186 -186
  827. package/lib/esm/rpc/core/RpcRequest.d.ts.map +1 -1
  828. package/lib/esm/rpc/core/RpcRequest.js +474 -473
  829. package/lib/esm/rpc/core/RpcRequest.js.map +1 -1
  830. package/lib/esm/rpc/core/RpcRequestContext.d.ts +14 -14
  831. package/lib/esm/rpc/core/RpcRequestContext.js +1 -1
  832. package/lib/esm/rpc/core/RpcRoutingToken.d.ts +12 -12
  833. package/lib/esm/rpc/core/RpcRoutingToken.js +21 -20
  834. package/lib/esm/rpc/core/RpcRoutingToken.js.map +1 -1
  835. package/lib/esm/rpc/core/RpcSessionInvocation.d.ts +10 -10
  836. package/lib/esm/rpc/core/RpcSessionInvocation.js +56 -56
  837. package/lib/esm/rpc/core/RpcSessionInvocation.js.map +1 -1
  838. package/lib/esm/rpc/web/BentleyCloudRpcManager.d.ts +46 -46
  839. package/lib/esm/rpc/web/BentleyCloudRpcManager.js +69 -68
  840. package/lib/esm/rpc/web/BentleyCloudRpcManager.js.map +1 -1
  841. package/lib/esm/rpc/web/BentleyCloudRpcProtocol.d.ts +33 -33
  842. package/lib/esm/rpc/web/BentleyCloudRpcProtocol.js +137 -137
  843. package/lib/esm/rpc/web/OpenAPI.d.ts +140 -140
  844. package/lib/esm/rpc/web/OpenAPI.js +56 -56
  845. package/lib/esm/rpc/web/OpenAPI.js.map +1 -1
  846. package/lib/esm/rpc/web/RpcMultipart.d.ts +35 -35
  847. package/lib/esm/rpc/web/RpcMultipart.js +47 -46
  848. package/lib/esm/rpc/web/RpcMultipart.js.map +1 -1
  849. package/lib/esm/rpc/web/WebAppRpcLogging.d.ts +28 -28
  850. package/lib/esm/rpc/web/WebAppRpcLogging.js +136 -136
  851. package/lib/esm/rpc/web/WebAppRpcProtocol.d.ts +89 -89
  852. package/lib/esm/rpc/web/WebAppRpcProtocol.js +112 -112
  853. package/lib/esm/rpc/web/WebAppRpcProtocol.js.map +1 -1
  854. package/lib/esm/rpc/web/WebAppRpcRequest.d.ts +67 -67
  855. package/lib/esm/rpc/web/WebAppRpcRequest.d.ts.map +1 -1
  856. package/lib/esm/rpc/web/WebAppRpcRequest.js +236 -235
  857. package/lib/esm/rpc/web/WebAppRpcRequest.js.map +1 -1
  858. package/lib/esm/rpc/web/multipart/RpcMultipartParser.d.ts +32 -32
  859. package/lib/esm/rpc/web/multipart/RpcMultipartParser.js +369 -369
  860. package/lib/esm/tile/B3dmTileIO.d.ts +19 -19
  861. package/lib/esm/tile/B3dmTileIO.js +62 -62
  862. package/lib/esm/tile/B3dmTileIO.js.map +1 -1
  863. package/lib/esm/tile/CompositeTileIO.d.ts +15 -15
  864. package/lib/esm/tile/CompositeTileIO.js +22 -22
  865. package/lib/esm/tile/CompositeTileIO.js.map +1 -1
  866. package/lib/esm/tile/ElementGraphics.d.ts +145 -145
  867. package/lib/esm/tile/ElementGraphics.d.ts.map +1 -1
  868. package/lib/esm/tile/ElementGraphics.js +8 -8
  869. package/lib/esm/tile/GltfTileIO.d.ts +45 -45
  870. package/lib/esm/tile/GltfTileIO.d.ts.map +1 -1
  871. package/lib/esm/tile/GltfTileIO.js +105 -105
  872. package/lib/esm/tile/GltfTileIO.js.map +1 -1
  873. package/lib/esm/tile/I3dmTileIO.d.ts +20 -20
  874. package/lib/esm/tile/I3dmTileIO.js +36 -36
  875. package/lib/esm/tile/I3dmTileIO.js.map +1 -1
  876. package/lib/esm/tile/IModelTileIO.d.ts +77 -77
  877. package/lib/esm/tile/IModelTileIO.js +93 -92
  878. package/lib/esm/tile/IModelTileIO.js.map +1 -1
  879. package/lib/esm/tile/PntsTileIO.d.ts +17 -17
  880. package/lib/esm/tile/PntsTileIO.js +22 -22
  881. package/lib/esm/tile/PntsTileIO.js.map +1 -1
  882. package/lib/esm/tile/TileIO.d.ts +66 -66
  883. package/lib/esm/tile/TileIO.js +110 -110
  884. package/lib/esm/tile/TileMetadata.d.ts +228 -228
  885. package/lib/esm/tile/TileMetadata.d.ts.map +1 -1
  886. package/lib/esm/tile/TileMetadata.js +660 -660
  887. package/lib/esm/tile/TileMetadata.js.map +1 -1
  888. package/lib/esm/tile/Tileset3dSchema.d.ts +96 -96
  889. package/lib/esm/tile/Tileset3dSchema.js +8 -8
  890. package/package.json +8 -8
@@ -1 +1 @@
1
- {"version":3,"file":"LightSettings.js","sourceRoot":"","sources":["../../src/LightSettings.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 DisplayStyles\r\n */\r\n\r\nimport { assert, JsonUtils } from \"@itwin/core-bentley\";\r\nimport { Vector3d, XYZProps } from \"@itwin/core-geometry\";\r\nimport { RgbColor, RgbColorProps } from \"./RgbColor\";\r\n\r\nfunction extractIntensity(value: number | undefined, defaultValue: number) {\r\n const maxIntensity = 5;\r\n return typeof value === \"number\" ? Math.max(0, Math.min(maxIntensity, value)) : defaultValue;\r\n}\r\n\r\n/** Wire format for the solar directional light associated with a [[LightSettingsProps]].\r\n * The light is colored white and oriented in any direction in world coordinates.\r\n * It will cast shadows if it is above the world XY plane and if the shadows view flag is enabled for the view.\r\n * By default, the solar light is only applied when shadows are enabled, but can be set to be applied unconditionally.\r\n * @public\r\n * @extensions\r\n */\r\nexport interface SolarLightProps {\r\n /** Intensity of the light, typically in [0..1] but can range up to 5. Default: 1.0 */\r\n intensity?: number;\r\n /** Direction of the light in world coordinates. Defaults to a vector looking down on the scene at a 45 degree angle mostly along the Y axis. */\r\n direction?: XYZProps;\r\n /** If true, the light will be applied even when shadows are turned off for the view.\r\n * If false, a roughly overhead light of the same intensity oriented in view space will be used instead.\r\n * Default: false.\r\n */\r\n alwaysEnabled?: boolean;\r\n /** If defined, the time in UNIX milliseconds from which [[direction]] was calculated.\r\n * @see [[DisplayStyleSettings.setSunTime]] to compute the solar direction from a point in time.\r\n */\r\n timePoint?: number;\r\n}\r\n\r\nconst defaultSolarDirection = Vector3d.create(0.272166, 0.680414, 0.680414);\r\n\r\n/** Describes the solar directional light associated with a [[LightSettings]].\r\n * @see [[SolarLightProps]].\r\n * @public\r\n */\r\nexport class SolarLight {\r\n /** Direction of the light in world coordinates. Defaults to a vector looking down on the scene at a 45 degree angle mostly along the Y axis. */\r\n public readonly direction: Readonly<Vector3d>;\r\n /** Intensity of the light, typically in [0..1] but can range up to 5. Default: 1.0 */\r\n public readonly intensity: number;\r\n /** If true, the light will be applied even when shadows are turned off for the view.\r\n * If false, a roughly overhead light of the same intensity oriented in view space will be used instead.\r\n * Default: false.\r\n */\r\n public readonly alwaysEnabled: boolean;\r\n /** If defined, the time in UNIX milliseconds from which [[direction]] was calculated.\r\n * @see [[DisplayStyleSettings.setSunTime]] to compute the solar direction from a point in time.\r\n */\r\n public readonly timePoint?: number;\r\n\r\n public constructor(json?: SolarLightProps) {\r\n json = json || {};\r\n this.intensity = extractIntensity(json.intensity, 1);\r\n this.alwaysEnabled = JsonUtils.asBool(json.alwaysEnabled);\r\n\r\n if (json.direction)\r\n this.direction = Vector3d.fromJSON(json.direction);\r\n else\r\n this.direction = defaultSolarDirection.clone();\r\n\r\n if (typeof json.timePoint === \"number\")\r\n this.timePoint = json.timePoint;\r\n }\r\n\r\n public toJSON(): SolarLightProps | undefined {\r\n const direction = this.direction.isAlmostEqual(defaultSolarDirection) ? undefined : this.direction.toJSON();\r\n const intensity = this.intensity !== 1 ? this.intensity : undefined;\r\n const alwaysEnabled = this.alwaysEnabled ? true : undefined;\r\n const timePoint = this.timePoint;\r\n\r\n if (undefined === direction && undefined === intensity && undefined === alwaysEnabled && undefined === timePoint)\r\n return undefined;\r\n\r\n const json: SolarLightProps = {};\r\n if (direction)\r\n json.direction = direction;\r\n\r\n if (undefined !== intensity)\r\n json.intensity = intensity;\r\n\r\n if (undefined !== alwaysEnabled)\r\n json.alwaysEnabled = alwaysEnabled;\r\n\r\n if (undefined !== timePoint)\r\n json.timePoint = timePoint;\r\n\r\n return json;\r\n }\r\n\r\n /** Create a copy of this SolarLight, identical except in any properties explicitly specified by `changedProps`, with a possible exception for [[timePoint]].\r\n * If `this.timePoint` is defined and `changedProps` defines `direction` but **doesn't** define `timePoint`, the time point will only be preserved in the\r\n * copy if `changesProps.direction` is equal to `this.direction`.\r\n */\r\n public clone(changedProps?: SolarLightProps): SolarLight {\r\n if (!changedProps)\r\n return this;\r\n\r\n const props = this.toJSON() ?? {};\r\n if (undefined !== changedProps.direction)\r\n props.direction = changedProps.direction;\r\n\r\n if (undefined !== changedProps.intensity)\r\n props.intensity = changedProps.intensity;\r\n\r\n if (undefined !== changedProps.alwaysEnabled)\r\n props.alwaysEnabled = changedProps.alwaysEnabled;\r\n\r\n if (undefined !== changedProps.timePoint)\r\n props.timePoint = changedProps.timePoint;\r\n\r\n // If our direction was computed from a time point and the caller only supplies a direction, invalidate the time point unless the input direction matches our direction.\r\n // If caller explicitly supplied a timePoint, trust it.\r\n if (undefined !== this.timePoint && undefined === changedProps.timePoint && undefined !== changedProps.direction) {\r\n const newDirection = Vector3d.fromJSON(changedProps.direction);\r\n if (!newDirection.isAlmostEqual(this.direction))\r\n props.timePoint = undefined;\r\n }\r\n\r\n return new SolarLight(props);\r\n }\r\n\r\n public equals(rhs: SolarLight): boolean {\r\n return this.intensity === rhs.intensity && this.alwaysEnabled === rhs.alwaysEnabled && this.direction.isExactEqual(rhs.direction) && this.timePoint === rhs.timePoint;\r\n }\r\n}\r\n\r\n/** Wire format for the ambient light associated with a [[LightSettingsProps]].\r\n * Ambient light applies equally to all surfaces in the scene.\r\n * @public\r\n * @extensions\r\n */\r\nexport interface AmbientLightProps {\r\n /** The color of the light. Black is treated as a special case, indicating that the surface's own diffuse color should be used. */\r\n color?: RgbColorProps;\r\n /** The intensity of the light. Default: 0.2. */\r\n intensity?: number;\r\n}\r\n\r\n/** Describes the ambient light associated with a [[LightSettings]].\r\n * @see [[AmbientLightProps]]\r\n * @public\r\n */\r\nexport class AmbientLight {\r\n public readonly color: RgbColor;\r\n public readonly intensity: number;\r\n\r\n public constructor(json?: AmbientLightProps) {\r\n json = json || {};\r\n this.intensity = extractIntensity(json.intensity, 0.2);\r\n this.color = json.color ? RgbColor.fromJSON(json.color) : new RgbColor(0, 0, 0);\r\n }\r\n\r\n public toJSON(): AmbientLightProps | undefined {\r\n const color = this.color.r !== 0 || this.color.g !== 0 || this.color.b !== 0 ? this.color.toJSON() : undefined;\r\n const intensity = 0.2 !== this.intensity ? this.intensity : undefined;\r\n if (undefined === color && undefined === intensity)\r\n return undefined;\r\n\r\n const json: AmbientLightProps = {};\r\n if (color)\r\n json.color = color;\r\n\r\n if (undefined !== intensity)\r\n json.intensity = intensity;\r\n\r\n return json;\r\n }\r\n\r\n /** Create a copy of this light, identical except for any properties explicitly specified by `changed`. */\r\n public clone(changed?: AmbientLightProps): AmbientLight {\r\n if (!changed)\r\n return this;\r\n\r\n const props = this.toJSON() ?? {};\r\n if (undefined !== changed.intensity)\r\n props.intensity = changed.intensity;\r\n\r\n if (undefined !== changed.color)\r\n props.color = changed.color;\r\n\r\n return new AmbientLight(props);\r\n }\r\n\r\n public equals(rhs: AmbientLight): boolean {\r\n return this.intensity === rhs.intensity && this.color.equals(rhs.color);\r\n }\r\n}\r\n\r\n/** Wire format for a pair of hemisphere lights associated with a [[LightSettingsProps]].\r\n * Hemisphere lights are oriented in opposite directions along the world Z axis. Each has its own color; they share one intensity.\r\n * They are often used to simulate outdoor reflection of light from the ground and sky, so the colors often match the ground and sky colors\r\n * of the [[SkyBox]].\r\n * @public\r\n * @extensions\r\n */\r\nexport interface HemisphereLightsProps {\r\n /** The color of the downward-facing light. Default: (143, 205, 255). */\r\n upperColor?: RgbColorProps;\r\n /** The color of the upward-facing light. Default: (120, 143, 125). */\r\n lowerColor?: RgbColorProps;\r\n /** Intensity of the lights. Default: 0. */\r\n intensity?: number;\r\n}\r\n\r\nconst defaultUpperHemisphereColor = new RgbColor(143, 205, 255);\r\nconst defaultLowerHemisphereColor = new RgbColor(120, 143, 125);\r\n\r\n/** Describes a pair of hemisphere lights associated with a [[LightSettings]].\r\n * @see [[HemisphereLightsProps]]\r\n * @public\r\n */\r\nexport class HemisphereLights {\r\n public readonly upperColor: RgbColor;\r\n public readonly lowerColor: RgbColor;\r\n public readonly intensity: number;\r\n\r\n public constructor(json?: HemisphereLightsProps) {\r\n json = json || {};\r\n this.intensity = extractIntensity(json.intensity, 0);\r\n this.upperColor = json.upperColor ? RgbColor.fromJSON(json.upperColor) : defaultUpperHemisphereColor;\r\n this.lowerColor = json.lowerColor ? RgbColor.fromJSON(json.lowerColor) : defaultLowerHemisphereColor;\r\n }\r\n\r\n public toJSON(): HemisphereLightsProps | undefined {\r\n const upperColor = this.upperColor.equals(defaultUpperHemisphereColor) ? undefined : this.upperColor.toJSON();\r\n const lowerColor = this.lowerColor.equals(defaultLowerHemisphereColor) ? undefined : this.lowerColor.toJSON();\r\n const intensity = 0 === this.intensity ? undefined : this.intensity;\r\n\r\n if (undefined === upperColor && undefined === lowerColor && undefined === intensity)\r\n return undefined;\r\n\r\n const json: HemisphereLightsProps = {};\r\n if (upperColor)\r\n json.upperColor = upperColor;\r\n\r\n if (lowerColor)\r\n json.lowerColor = lowerColor;\r\n\r\n if (undefined !== intensity)\r\n json.intensity = intensity;\r\n\r\n return json;\r\n }\r\n\r\n /** Create a copy of these lights, identical except for any properties explicitly specified by `changed`. */\r\n public clone(changed?: HemisphereLightsProps): HemisphereLights {\r\n if (!changed)\r\n return this;\r\n\r\n const props = this.toJSON() || {};\r\n if (undefined !== changed.upperColor)\r\n props.upperColor = changed.upperColor;\r\n\r\n if (undefined !== changed.lowerColor)\r\n props.lowerColor = changed.lowerColor;\r\n\r\n if (undefined !== changed.intensity)\r\n props.intensity = changed.intensity;\r\n\r\n return new HemisphereLights(props);\r\n }\r\n\r\n public equals(rhs: HemisphereLights): boolean {\r\n return this.intensity === rhs.intensity && this.upperColor.equals(rhs.upperColor) && this.lowerColor.equals(rhs.lowerColor);\r\n }\r\n}\r\n\r\n/** JSON representation of a [[FresnelSettings]].\r\n * @public\r\n * @extensions\r\n */\r\nexport interface FresnelSettingsProps {\r\n /** See [[FresnelSettings.intensity]].\r\n * Default value: 0\r\n */\r\n intensity?: number;\r\n\r\n /** See [[FresnelSettings.invert]].\r\n * Default value: false\r\n */\r\n invert?: boolean;\r\n}\r\n\r\nfunction clampIntensity(intensity = 0): number {\r\n return Math.max(intensity, 0);\r\n}\r\n\r\n/** As part of a [[LightSettings]], describes how to apply a Fresnel effect to the contents of the view.\r\n * The \"Fresnel effect\" is based on the observation that the reflectivity of a surface varies based on the angle between the surface and\r\n * the viewer's line of sight. For example, a flat surface will appear more reflective when viewed at a glancing angle than it will when\r\n * viewed from above; and a sphere will appear more reflective around its edges than at its center.\r\n *\r\n * This principle can be used to improve photorealism, but the implementation provided here is intended to produce non-realistic but\r\n * aesthetically-pleasing results.\r\n * @see [[LightSettings.fresnel]].\r\n * @public\r\n */\r\nexport class FresnelSettings {\r\n /** The strength of the effect in terms of how much brighter the surface becomes. The intensity at a given point on the surface is determined by\r\n * the angle between the viewer's line of sight and the vector from the viewer to that point. Maximum intensity is produced when those vectors are\r\n * perpendicular, and zero intensity is produced when those vectors are parallel (unless [[invert]] is `true`).\r\n *\r\n * A value of zero turns off the effect. Values less than zero are clamped to zero. Typical values range between 0 and 1.\r\n */\r\n public readonly intensity: number;\r\n /** If true, inverts the effect's [[intensity]] such that maximum intensity is produced when the viewer's line of sight is parallel to the vector between\r\n * the viewer and the point on the surface, and zero intensity is produced when the viewer's line of sight is perpendicular to that vector.\r\n */\r\n public readonly invert: boolean;\r\n\r\n private constructor(intensity: number, invert: boolean) {\r\n assert(intensity >= 0);\r\n this.intensity = intensity;\r\n this.invert = invert;\r\n }\r\n\r\n private static readonly _defaults = new FresnelSettings(0, false);\r\n\r\n /** Create from JSON representation, using default values for any unspecified or `undefined` properties. */\r\n public static fromJSON(props?: FresnelSettingsProps): FresnelSettings {\r\n const intensity = clampIntensity(JsonUtils.asDouble(props?.intensity));\r\n const invert = JsonUtils.asBool(props?.invert);\r\n if (0 === intensity && !invert)\r\n return this._defaults;\r\n\r\n return new this(intensity, invert);\r\n }\r\n\r\n /** Create a new FresnelSettings.\r\n * @note Intensity values less than zero will be set to zero.\r\n */\r\n public static create(intensity = 0, invert = false): FresnelSettings {\r\n return this.fromJSON({ intensity, invert });\r\n }\r\n\r\n /** Convert to JSON representation.\r\n * @note If all settings match the default values, `undefined` will be returned.\r\n */\r\n public toJSON(): FresnelSettingsProps | undefined {\r\n if (0 === this.intensity && !this.invert)\r\n return undefined;\r\n\r\n const props: FresnelSettingsProps = {};\r\n if (0 !== this.intensity)\r\n props.intensity = this.intensity;\r\n\r\n if (this.invert)\r\n props.invert = true;\r\n\r\n return props;\r\n }\r\n\r\n /** Create a copy of these settings, modified to match any properties explicitly specified by `changedProps`. */\r\n public clone(changedProps?: FresnelSettingsProps): FresnelSettings {\r\n if ((undefined === changedProps?.intensity || changedProps.intensity === this.intensity)\r\n && (undefined === changedProps?.invert || changedProps.invert === this.invert))\r\n return this;\r\n\r\n const intensity = changedProps?.intensity ?? this.intensity;\r\n const invert = changedProps?.invert ?? this.invert;\r\n return FresnelSettings.fromJSON({ intensity, invert });\r\n }\r\n\r\n /** Return true if these settings are equivalent to `rhs`. */\r\n public equals(rhs: FresnelSettings): boolean {\r\n return this === rhs || (this.intensity === rhs.intensity && this.invert === rhs.invert);\r\n }\r\n}\r\n\r\n/** Wire format for a [[LightSettings]] describing lighting for a 3d scene.\r\n * 3d lighting provides the following lights, all of which are optional:\r\n * - A \"portrait\" light affixed to the camera and pointing directly forward into the scene. Color: white.\r\n * - A second directional light. Color: white.\r\n * - This can be a solar shadow-casting light, or (when shadows are disabled) a roughly overhead light oriented in view space.\r\n * - A pair of hemisphere lights pointing in opposite directions along the world Z axis. Each has its own customizable color.\r\n * - An ambient light of any color applied equally to all surfaces.\r\n * Specular intensity of all lights is controlled separately.\r\n * Light intensities are typically expressed in [0..1] but can be as large as 5.\r\n * @see [[DisplayStyle3dSettingsProps]]\r\n * @public\r\n * @extensions\r\n */\r\nexport interface LightSettingsProps {\r\n /** A white portrait light affixed to the camera and pointing directly forward into the scene. */\r\n portrait?: {\r\n /** Intensity, typically in [0..1], maximum 5. Default: 0.3. */\r\n intensity?: number;\r\n };\r\n /** Solar light settings. */\r\n solar?: SolarLightProps;\r\n /** Hemisphere light settings. */\r\n hemisphere?: HemisphereLightsProps;\r\n /** Ambient light settings. */\r\n ambient?: AmbientLightProps;\r\n /** Specular intensity applied to all lights. */\r\n specularIntensity?: number;\r\n /** Applies a [cel-shaded](https://en.wikipedia.org/wiki/Cel_shading) effect. If greater than zero, specifies the number of cels. Continuous lighting intensities\r\n * are computed, then quantized to the specified number of cels. Values greater than 254 have no visible effect.\r\n * Typically a value of 2 is appropriate if specular intensity is close to zero; 3 if specular intensity is larger.\r\n * Cel-shading is often combined with thick, dark visible edges for a cartoon or comic book effect.\r\n * Default: 0\r\n */\r\n numCels?: number;\r\n\r\n /** Fresnel settings.\r\n * @see [[FresnelSettings]].\r\n */\r\n fresnel?: FresnelSettingsProps;\r\n}\r\n\r\n/** Describes the lighting for a 3d scene, associated with a [[DisplayStyle3dSettings]] in turn associated with a [DisplayStyle3d]($backend) or [DisplayStyle3dState]($frontend).\r\n * @see [[LightSettingsProps]]\r\n * @public\r\n */\r\nexport class LightSettings {\r\n public readonly solar: SolarLight;\r\n public readonly ambient: AmbientLight;\r\n public readonly hemisphere: HemisphereLights;\r\n /** See [[LightSettingsProps.portrait]]. */\r\n public readonly portraitIntensity: number;\r\n public readonly specularIntensity: number;\r\n /** See [[LightSettingsProps.numCels]]. */\r\n public readonly numCels: number;\r\n public readonly fresnel: FresnelSettings;\r\n\r\n private constructor(solar: SolarLight, ambient: AmbientLight, hemisphere: HemisphereLights, portraitIntensity: number, specularIntensity: number, numCels: number,\r\n fresnel: FresnelSettings) {\r\n this.solar = solar;\r\n this.ambient = ambient;\r\n this.hemisphere = hemisphere;\r\n this.portraitIntensity = portraitIntensity;\r\n this.specularIntensity = specularIntensity;\r\n this.numCels = numCels;\r\n this.fresnel = fresnel;\r\n }\r\n\r\n public static fromJSON(props?: LightSettingsProps): LightSettings {\r\n const solar = new SolarLight(props?.solar);\r\n const ambient = new AmbientLight(props?.ambient);\r\n const hemisphere = new HemisphereLights(props?.hemisphere);\r\n const portraitIntensity = extractIntensity(props?.portrait?.intensity, 0.3);\r\n const specularIntensity = extractIntensity(props?.specularIntensity, 1.0);\r\n const numCels = JsonUtils.asInt(props?.numCels, 0);\r\n const fresnel = FresnelSettings.fromJSON(props?.fresnel);\r\n\r\n return new LightSettings(solar, ambient, hemisphere, portraitIntensity, specularIntensity, numCels, fresnel);\r\n }\r\n\r\n public toJSON(): LightSettingsProps | undefined {\r\n const solar = this.solar.toJSON();\r\n const ambient = this.ambient.toJSON();\r\n const hemisphere = this.hemisphere.toJSON();\r\n const portrait = 0.3 !== this.portraitIntensity ? { intensity: this.portraitIntensity } : undefined;\r\n const specularIntensity = 1 !== this.specularIntensity ? this.specularIntensity : undefined;\r\n const numCels = 0 !== this.numCels ? this.numCels : undefined;\r\n const fresnel = this.fresnel.toJSON();\r\n\r\n if (!solar && !ambient && !hemisphere && !portrait && undefined === specularIntensity && undefined === numCels && undefined === fresnel)\r\n return undefined;\r\n\r\n const json: LightSettingsProps = {};\r\n if (solar)\r\n json.solar = solar;\r\n\r\n if (ambient)\r\n json.ambient = ambient;\r\n\r\n if (hemisphere)\r\n json.hemisphere = hemisphere;\r\n\r\n if (portrait)\r\n json.portrait = portrait;\r\n\r\n if (undefined !== specularIntensity)\r\n json.specularIntensity = specularIntensity;\r\n\r\n if (undefined !== numCels)\r\n json.numCels = numCels;\r\n\r\n if (fresnel)\r\n json.fresnel = fresnel;\r\n\r\n return json;\r\n }\r\n\r\n /** Create a copy of these light settings, identical except for any properties explicitly specified by `changed`.\r\n * Note that the solar, ambient, and hemisphere lights will also be cloned using their own `clone` methods - so for example, the following:\r\n * ` clone({ ambient: { intensity: 0.5 } })`\r\n * will overwrite the ambient light's intensity but preserve its current color, rather than replacing the color with the default color.\r\n */\r\n public clone(changed?: LightSettingsProps): LightSettings {\r\n if (!changed)\r\n return this;\r\n\r\n const solar = this.solar.clone(changed.solar);\r\n const ambient = this.ambient.clone(changed.ambient);\r\n const hemisphere = this.hemisphere.clone(changed.hemisphere);\r\n const portrait = changed.portrait?.intensity ?? this.portraitIntensity;\r\n const specular = changed.specularIntensity ?? this.specularIntensity;\r\n const numCels = changed.numCels ?? this.numCels;\r\n const fresnel = this.fresnel.clone(changed.fresnel);\r\n\r\n return new LightSettings(solar, ambient, hemisphere, portrait, specular, numCels, fresnel);\r\n }\r\n\r\n public equals(rhs: LightSettings): boolean {\r\n if (this === rhs)\r\n return true;\r\n\r\n return this.portraitIntensity === rhs.portraitIntensity && this.specularIntensity === rhs.specularIntensity && this.numCels === rhs.numCels\r\n && this.ambient.equals(rhs.ambient) && this.solar.equals(rhs.solar) && this.hemisphere.equals(rhs.hemisphere) && this.fresnel.equals(rhs.fresnel);\r\n }\r\n}\r\n"]}
1
+ {"version":3,"file":"LightSettings.js","sourceRoot":"","sources":["../../src/LightSettings.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 DisplayStyles\r\n */\r\n\r\nimport { assert, JsonUtils } from \"@itwin/core-bentley\";\r\nimport { Vector3d, XYZProps } from \"@itwin/core-geometry\";\r\nimport { RgbColor, RgbColorProps } from \"./RgbColor\";\r\n\r\nfunction extractIntensity(value: number | undefined, defaultValue: number) {\r\n const maxIntensity = 5;\r\n return typeof value === \"number\" ? Math.max(0, Math.min(maxIntensity, value)) : defaultValue;\r\n}\r\n\r\n/** Wire format for the solar directional light associated with a [[LightSettingsProps]].\r\n * The light is colored white and oriented in any direction in world coordinates.\r\n * It will cast shadows if it is above the world XY plane and if the shadows view flag is enabled for the view.\r\n * By default, the solar light is only applied when shadows are enabled, but can be set to be applied unconditionally.\r\n * @public\r\n * @extensions\r\n */\r\nexport interface SolarLightProps {\r\n /** Intensity of the light, typically in [0..1] but can range up to 5. Default: 1.0 */\r\n intensity?: number;\r\n /** Direction of the light in world coordinates. Defaults to a vector looking down on the scene at a 45 degree angle mostly along the Y axis. */\r\n direction?: XYZProps;\r\n /** If true, the light will be applied even when shadows are turned off for the view.\r\n * If false, a roughly overhead light of the same intensity oriented in view space will be used instead.\r\n * Default: false.\r\n */\r\n alwaysEnabled?: boolean;\r\n /** If defined, the time in UNIX milliseconds from which [[direction]] was calculated.\r\n * @see [[DisplayStyleSettings.setSunTime]] to compute the solar direction from a point in time.\r\n */\r\n timePoint?: number;\r\n}\r\n\r\nconst defaultSolarDirection = Vector3d.create(0.272166, 0.680414, 0.680414);\r\n\r\n/** Describes the solar directional light associated with a [[LightSettings]].\r\n * @see [[SolarLightProps]].\r\n * @public\r\n */\r\nexport class SolarLight {\r\n /** Direction of the light in world coordinates. Defaults to a vector looking down on the scene at a 45 degree angle mostly along the Y axis. */\r\n public readonly direction: Readonly<Vector3d>;\r\n /** Intensity of the light, typically in [0..1] but can range up to 5. Default: 1.0 */\r\n public readonly intensity: number;\r\n /** If true, the light will be applied even when shadows are turned off for the view.\r\n * If false, a roughly overhead light of the same intensity oriented in view space will be used instead.\r\n * Default: false.\r\n */\r\n public readonly alwaysEnabled: boolean;\r\n /** If defined, the time in UNIX milliseconds from which [[direction]] was calculated.\r\n * @see [[DisplayStyleSettings.setSunTime]] to compute the solar direction from a point in time.\r\n */\r\n public readonly timePoint?: number;\r\n\r\n public constructor(json?: SolarLightProps) {\r\n json = json || {};\r\n this.intensity = extractIntensity(json.intensity, 1);\r\n this.alwaysEnabled = JsonUtils.asBool(json.alwaysEnabled);\r\n\r\n if (json.direction)\r\n this.direction = Vector3d.fromJSON(json.direction);\r\n else\r\n this.direction = defaultSolarDirection.clone();\r\n\r\n if (typeof json.timePoint === \"number\")\r\n this.timePoint = json.timePoint;\r\n }\r\n\r\n public toJSON(): SolarLightProps | undefined {\r\n const direction = this.direction.isAlmostEqual(defaultSolarDirection) ? undefined : this.direction.toJSON();\r\n const intensity = this.intensity !== 1 ? this.intensity : undefined;\r\n const alwaysEnabled = this.alwaysEnabled ? true : undefined;\r\n const timePoint = this.timePoint;\r\n\r\n if (undefined === direction && undefined === intensity && undefined === alwaysEnabled && undefined === timePoint)\r\n return undefined;\r\n\r\n const json: SolarLightProps = {};\r\n if (direction)\r\n json.direction = direction;\r\n\r\n if (undefined !== intensity)\r\n json.intensity = intensity;\r\n\r\n if (undefined !== alwaysEnabled)\r\n json.alwaysEnabled = alwaysEnabled;\r\n\r\n if (undefined !== timePoint)\r\n json.timePoint = timePoint;\r\n\r\n return json;\r\n }\r\n\r\n /** Create a copy of this SolarLight, identical except in any properties explicitly specified by `changedProps`, with a possible exception for [[timePoint]].\r\n * If `this.timePoint` is defined and `changedProps` defines `direction` but **doesn't** define `timePoint`, the time point will only be preserved in the\r\n * copy if `changesProps.direction` is equal to `this.direction`.\r\n */\r\n public clone(changedProps?: SolarLightProps): SolarLight {\r\n if (!changedProps)\r\n return this;\r\n\r\n const props = this.toJSON() ?? {};\r\n if (undefined !== changedProps.direction)\r\n props.direction = changedProps.direction;\r\n\r\n if (undefined !== changedProps.intensity)\r\n props.intensity = changedProps.intensity;\r\n\r\n if (undefined !== changedProps.alwaysEnabled)\r\n props.alwaysEnabled = changedProps.alwaysEnabled;\r\n\r\n if (undefined !== changedProps.timePoint)\r\n props.timePoint = changedProps.timePoint;\r\n\r\n // If our direction was computed from a time point and the caller only supplies a direction, invalidate the time point unless the input direction matches our direction.\r\n // If caller explicitly supplied a timePoint, trust it.\r\n if (undefined !== this.timePoint && undefined === changedProps.timePoint && undefined !== changedProps.direction) {\r\n const newDirection = Vector3d.fromJSON(changedProps.direction);\r\n if (!newDirection.isAlmostEqual(this.direction))\r\n props.timePoint = undefined;\r\n }\r\n\r\n return new SolarLight(props);\r\n }\r\n\r\n public equals(rhs: SolarLight): boolean {\r\n return this.intensity === rhs.intensity && this.alwaysEnabled === rhs.alwaysEnabled && this.direction.isExactEqual(rhs.direction) && this.timePoint === rhs.timePoint;\r\n }\r\n}\r\n\r\n/** Wire format for the ambient light associated with a [[LightSettingsProps]].\r\n * Ambient light applies equally to all surfaces in the scene.\r\n * @public\r\n * @extensions\r\n */\r\nexport interface AmbientLightProps {\r\n /** The color of the light. Black is treated as a special case, indicating that the surface's own diffuse color should be used. */\r\n color?: RgbColorProps;\r\n /** The intensity of the light. Default: 0.2. */\r\n intensity?: number;\r\n}\r\n\r\n/** Describes the ambient light associated with a [[LightSettings]].\r\n * @see [[AmbientLightProps]]\r\n * @public\r\n */\r\nexport class AmbientLight {\r\n public readonly color: RgbColor;\r\n public readonly intensity: number;\r\n\r\n public constructor(json?: AmbientLightProps) {\r\n json = json || {};\r\n this.intensity = extractIntensity(json.intensity, 0.2);\r\n this.color = json.color ? RgbColor.fromJSON(json.color) : new RgbColor(0, 0, 0);\r\n }\r\n\r\n public toJSON(): AmbientLightProps | undefined {\r\n const color = this.color.r !== 0 || this.color.g !== 0 || this.color.b !== 0 ? this.color.toJSON() : undefined;\r\n const intensity = 0.2 !== this.intensity ? this.intensity : undefined;\r\n if (undefined === color && undefined === intensity)\r\n return undefined;\r\n\r\n const json: AmbientLightProps = {};\r\n if (color)\r\n json.color = color;\r\n\r\n if (undefined !== intensity)\r\n json.intensity = intensity;\r\n\r\n return json;\r\n }\r\n\r\n /** Create a copy of this light, identical except for any properties explicitly specified by `changed`. */\r\n public clone(changed?: AmbientLightProps): AmbientLight {\r\n if (!changed)\r\n return this;\r\n\r\n const props = this.toJSON() ?? {};\r\n if (undefined !== changed.intensity)\r\n props.intensity = changed.intensity;\r\n\r\n if (undefined !== changed.color)\r\n props.color = changed.color;\r\n\r\n return new AmbientLight(props);\r\n }\r\n\r\n public equals(rhs: AmbientLight): boolean {\r\n return this.intensity === rhs.intensity && this.color.equals(rhs.color);\r\n }\r\n}\r\n\r\n/** Wire format for a pair of hemisphere lights associated with a [[LightSettingsProps]].\r\n * Hemisphere lights are oriented in opposite directions along the world Z axis. Each has its own color; they share one intensity.\r\n * They are often used to simulate outdoor reflection of light from the ground and sky, so the colors often match the ground and sky colors\r\n * of the [[SkyBox]].\r\n * @public\r\n * @extensions\r\n */\r\nexport interface HemisphereLightsProps {\r\n /** The color of the downward-facing light. Default: (143, 205, 255). */\r\n upperColor?: RgbColorProps;\r\n /** The color of the upward-facing light. Default: (120, 143, 125). */\r\n lowerColor?: RgbColorProps;\r\n /** Intensity of the lights. Default: 0. */\r\n intensity?: number;\r\n}\r\n\r\nconst defaultUpperHemisphereColor = new RgbColor(143, 205, 255);\r\nconst defaultLowerHemisphereColor = new RgbColor(120, 143, 125);\r\n\r\n/** Describes a pair of hemisphere lights associated with a [[LightSettings]].\r\n * @see [[HemisphereLightsProps]]\r\n * @public\r\n */\r\nexport class HemisphereLights {\r\n public readonly upperColor: RgbColor;\r\n public readonly lowerColor: RgbColor;\r\n public readonly intensity: number;\r\n\r\n public constructor(json?: HemisphereLightsProps) {\r\n json = json || {};\r\n this.intensity = extractIntensity(json.intensity, 0);\r\n this.upperColor = json.upperColor ? RgbColor.fromJSON(json.upperColor) : defaultUpperHemisphereColor;\r\n this.lowerColor = json.lowerColor ? RgbColor.fromJSON(json.lowerColor) : defaultLowerHemisphereColor;\r\n }\r\n\r\n public toJSON(): HemisphereLightsProps | undefined {\r\n const upperColor = this.upperColor.equals(defaultUpperHemisphereColor) ? undefined : this.upperColor.toJSON();\r\n const lowerColor = this.lowerColor.equals(defaultLowerHemisphereColor) ? undefined : this.lowerColor.toJSON();\r\n const intensity = 0 === this.intensity ? undefined : this.intensity;\r\n\r\n if (undefined === upperColor && undefined === lowerColor && undefined === intensity)\r\n return undefined;\r\n\r\n const json: HemisphereLightsProps = {};\r\n if (upperColor)\r\n json.upperColor = upperColor;\r\n\r\n if (lowerColor)\r\n json.lowerColor = lowerColor;\r\n\r\n if (undefined !== intensity)\r\n json.intensity = intensity;\r\n\r\n return json;\r\n }\r\n\r\n /** Create a copy of these lights, identical except for any properties explicitly specified by `changed`. */\r\n public clone(changed?: HemisphereLightsProps): HemisphereLights {\r\n if (!changed)\r\n return this;\r\n\r\n const props = this.toJSON() || {};\r\n if (undefined !== changed.upperColor)\r\n props.upperColor = changed.upperColor;\r\n\r\n if (undefined !== changed.lowerColor)\r\n props.lowerColor = changed.lowerColor;\r\n\r\n if (undefined !== changed.intensity)\r\n props.intensity = changed.intensity;\r\n\r\n return new HemisphereLights(props);\r\n }\r\n\r\n public equals(rhs: HemisphereLights): boolean {\r\n return this.intensity === rhs.intensity && this.upperColor.equals(rhs.upperColor) && this.lowerColor.equals(rhs.lowerColor);\r\n }\r\n}\r\n\r\n/** JSON representation of a [[FresnelSettings]].\r\n * @public\r\n * @extensions\r\n */\r\nexport interface FresnelSettingsProps {\r\n /** See [[FresnelSettings.intensity]].\r\n * Default value: 0\r\n */\r\n intensity?: number;\r\n\r\n /** See [[FresnelSettings.invert]].\r\n * Default value: false\r\n */\r\n invert?: boolean;\r\n}\r\n\r\nfunction clampIntensity(intensity = 0): number {\r\n return Math.max(intensity, 0);\r\n}\r\n\r\n/** As part of a [[LightSettings]], describes how to apply a Fresnel effect to the contents of the view.\r\n * The \"Fresnel effect\" is based on the observation that the reflectivity of a surface varies based on the angle between the surface and\r\n * the viewer's line of sight. For example, a flat surface will appear more reflective when viewed at a glancing angle than it will when\r\n * viewed from above; and a sphere will appear more reflective around its edges than at its center.\r\n *\r\n * This principle can be used to improve photorealism, but the implementation provided here is intended to produce non-realistic but\r\n * aesthetically-pleasing results.\r\n * @see [[LightSettings.fresnel]].\r\n * @public\r\n */\r\nexport class FresnelSettings {\r\n /** The strength of the effect in terms of how much brighter the surface becomes. The intensity at a given point on the surface is determined by\r\n * the angle between the viewer's line of sight and the vector from the viewer to that point. Maximum intensity is produced when those vectors are\r\n * perpendicular, and zero intensity is produced when those vectors are parallel (unless [[invert]] is `true`).\r\n *\r\n * A value of zero turns off the effect. Values less than zero are clamped to zero. Typical values range between 0 and 1.\r\n */\r\n public readonly intensity: number;\r\n /** If true, inverts the effect's [[intensity]] such that maximum intensity is produced when the viewer's line of sight is parallel to the vector between\r\n * the viewer and the point on the surface, and zero intensity is produced when the viewer's line of sight is perpendicular to that vector.\r\n */\r\n public readonly invert: boolean;\r\n\r\n private constructor(intensity: number, invert: boolean) {\r\n assert(intensity >= 0);\r\n this.intensity = intensity;\r\n this.invert = invert;\r\n }\r\n\r\n private static readonly _defaults = new FresnelSettings(0, false);\r\n\r\n /** Create from JSON representation, using default values for any unspecified or `undefined` properties. */\r\n public static fromJSON(props?: FresnelSettingsProps): FresnelSettings {\r\n const intensity = clampIntensity(JsonUtils.asDouble(props?.intensity));\r\n const invert = JsonUtils.asBool(props?.invert);\r\n if (0 === intensity && !invert)\r\n return this._defaults;\r\n\r\n return new this(intensity, invert);\r\n }\r\n\r\n /** Create a new FresnelSettings.\r\n * @note Intensity values less than zero will be set to zero.\r\n */\r\n public static create(intensity = 0, invert = false): FresnelSettings {\r\n return this.fromJSON({ intensity, invert });\r\n }\r\n\r\n /** Convert to JSON representation.\r\n * @note If all settings match the default values, `undefined` will be returned.\r\n */\r\n public toJSON(): FresnelSettingsProps | undefined {\r\n if (0 === this.intensity && !this.invert)\r\n return undefined;\r\n\r\n const props: FresnelSettingsProps = {};\r\n if (0 !== this.intensity)\r\n props.intensity = this.intensity;\r\n\r\n if (this.invert)\r\n props.invert = true;\r\n\r\n return props;\r\n }\r\n\r\n /** Create a copy of these settings, modified to match any properties explicitly specified by `changedProps`. */\r\n public clone(changedProps?: FresnelSettingsProps): FresnelSettings {\r\n if ((undefined === changedProps?.intensity || changedProps.intensity === this.intensity)\r\n && (undefined === changedProps?.invert || changedProps.invert === this.invert))\r\n return this;\r\n\r\n const intensity = changedProps?.intensity ?? this.intensity;\r\n const invert = changedProps?.invert ?? this.invert;\r\n return FresnelSettings.fromJSON({ intensity, invert });\r\n }\r\n\r\n /** Return true if these settings are equivalent to `rhs`. */\r\n public equals(rhs: FresnelSettings): boolean {\r\n return this === rhs || (this.intensity === rhs.intensity && this.invert === rhs.invert);\r\n }\r\n}\r\n\r\n/** Wire format for a [[LightSettings]] describing lighting for a 3d scene.\r\n * 3d lighting provides the following lights, all of which are optional:\r\n * - A \"portrait\" light affixed to the camera and pointing directly forward into the scene. Color: white.\r\n * - A second directional light. Color: white.\r\n * - This can be a solar shadow-casting light, or (when shadows are disabled) a roughly overhead light oriented in view space.\r\n * - A pair of hemisphere lights pointing in opposite directions along the world Z axis. Each has its own customizable color.\r\n * - An ambient light of any color applied equally to all surfaces.\r\n * Specular intensity of all lights is controlled separately.\r\n * Light intensities are typically expressed in [0..1] but can be as large as 5.\r\n * @see [[DisplayStyle3dSettingsProps]]\r\n * @public\r\n * @extensions\r\n */\r\nexport interface LightSettingsProps {\r\n /** A white portrait light affixed to the camera and pointing directly forward into the scene. */\r\n portrait?: {\r\n /** Intensity, typically in [0..1], maximum 5. Default: 0.3. */\r\n intensity?: number;\r\n };\r\n /** Solar light settings. */\r\n solar?: SolarLightProps;\r\n /** Hemisphere light settings. */\r\n hemisphere?: HemisphereLightsProps;\r\n /** Ambient light settings. */\r\n ambient?: AmbientLightProps;\r\n /** Specular intensity applied to all lights. */\r\n specularIntensity?: number;\r\n /** Applies a [cel-shaded](https://en.wikipedia.org/wiki/Cel_shading) effect. If greater than zero, specifies the number of cels. Continuous lighting intensities\r\n * are computed, then quantized to the specified number of cels. Values greater than 254 have no visible effect.\r\n * Typically a value of 2 is appropriate if specular intensity is close to zero; 3 if specular intensity is larger.\r\n * Cel-shading is often combined with thick, dark visible edges for a cartoon or comic book effect.\r\n * Default: 0\r\n */\r\n numCels?: number;\r\n\r\n /** Fresnel settings.\r\n * @see [[FresnelSettings]].\r\n */\r\n fresnel?: FresnelSettingsProps;\r\n}\r\n\r\n/** Describes the lighting for a 3d scene, associated with a [[DisplayStyle3dSettings]] in turn associated with a [DisplayStyle3d]($backend) or [DisplayStyle3dState]($frontend).\r\n * @see [[LightSettingsProps]]\r\n * @public\r\n */\r\nexport class LightSettings {\r\n public readonly solar: SolarLight;\r\n public readonly ambient: AmbientLight;\r\n public readonly hemisphere: HemisphereLights;\r\n /** See [[LightSettingsProps.portrait]]. */\r\n public readonly portraitIntensity: number;\r\n public readonly specularIntensity: number;\r\n /** See [[LightSettingsProps.numCels]]. */\r\n public readonly numCels: number;\r\n public readonly fresnel: FresnelSettings;\r\n\r\n private constructor(solar: SolarLight, ambient: AmbientLight, hemisphere: HemisphereLights, portraitIntensity: number, specularIntensity: number, numCels: number,\r\n fresnel: FresnelSettings) {\r\n this.solar = solar;\r\n this.ambient = ambient;\r\n this.hemisphere = hemisphere;\r\n this.portraitIntensity = portraitIntensity;\r\n this.specularIntensity = specularIntensity;\r\n this.numCels = numCels;\r\n this.fresnel = fresnel;\r\n }\r\n\r\n public static fromJSON(props?: LightSettingsProps): LightSettings {\r\n const solar = new SolarLight(props?.solar);\r\n const ambient = new AmbientLight(props?.ambient);\r\n const hemisphere = new HemisphereLights(props?.hemisphere);\r\n const portraitIntensity = extractIntensity(props?.portrait?.intensity, 0.3);\r\n const specularIntensity = extractIntensity(props?.specularIntensity, 1.0);\r\n const numCels = JsonUtils.asInt(props?.numCels, 0);\r\n const fresnel = FresnelSettings.fromJSON(props?.fresnel);\r\n\r\n return new LightSettings(solar, ambient, hemisphere, portraitIntensity, specularIntensity, numCels, fresnel);\r\n }\r\n\r\n public toJSON(): LightSettingsProps | undefined {\r\n const solar = this.solar.toJSON();\r\n const ambient = this.ambient.toJSON();\r\n const hemisphere = this.hemisphere.toJSON();\r\n const portrait = 0.3 !== this.portraitIntensity ? { intensity: this.portraitIntensity } : undefined;\r\n const specularIntensity = 1 !== this.specularIntensity ? this.specularIntensity : undefined;\r\n const numCels = 0 !== this.numCels ? this.numCels : undefined;\r\n const fresnel = this.fresnel.toJSON();\r\n\r\n if (!solar && !ambient && !hemisphere && !portrait && undefined === specularIntensity && undefined === numCels && undefined === fresnel)\r\n return undefined;\r\n\r\n const json: LightSettingsProps = {};\r\n if (solar)\r\n json.solar = solar;\r\n\r\n if (ambient)\r\n json.ambient = ambient;\r\n\r\n if (hemisphere)\r\n json.hemisphere = hemisphere;\r\n\r\n if (portrait)\r\n json.portrait = portrait;\r\n\r\n if (undefined !== specularIntensity)\r\n json.specularIntensity = specularIntensity;\r\n\r\n if (undefined !== numCels)\r\n json.numCels = numCels;\r\n\r\n if (fresnel)\r\n json.fresnel = fresnel;\r\n\r\n return json;\r\n }\r\n\r\n /** Create a copy of these light settings, identical except for any properties explicitly specified by `changed`.\r\n * Note that the solar, ambient, and hemisphere lights will also be cloned using their own `clone` methods - so for example, the following:\r\n * ` clone({ ambient: { intensity: 0.5 } })`\r\n * will overwrite the ambient light's intensity but preserve its current color, rather than replacing the color with the default color.\r\n */\r\n public clone(changed?: LightSettingsProps): LightSettings {\r\n if (!changed)\r\n return this;\r\n\r\n const solar = this.solar.clone(changed.solar);\r\n const ambient = this.ambient.clone(changed.ambient);\r\n const hemisphere = this.hemisphere.clone(changed.hemisphere);\r\n const portrait = changed.portrait?.intensity ?? this.portraitIntensity;\r\n const specular = changed.specularIntensity ?? this.specularIntensity;\r\n const numCels = changed.numCels ?? this.numCels;\r\n const fresnel = this.fresnel.clone(changed.fresnel);\r\n\r\n return new LightSettings(solar, ambient, hemisphere, portrait, specular, numCels, fresnel);\r\n }\r\n\r\n public equals(rhs: LightSettings): boolean {\r\n if (this === rhs)\r\n return true;\r\n\r\n return this.portraitIntensity === rhs.portraitIntensity && this.specularIntensity === rhs.specularIntensity && this.numCels === rhs.numCels\r\n && this.ambient.equals(rhs.ambient) && this.solar.equals(rhs.solar) && this.hemisphere.equals(rhs.hemisphere) && this.fresnel.equals(rhs.fresnel);\r\n }\r\n}\r\n"]}
@@ -1,35 +1,35 @@
1
- /** @packageDocumentation
2
- * @module Symbology
3
- */
4
- /** Enumerates the available patterns for drawing patterned lines.
5
- * Each is a 32-bit pattern in which each bit specifies the on- or off-state of a pixel along the line. The pattern repeats along the length of the entire line.
6
- * @public
7
- * @extensions
8
- */
9
- export declare enum LinePixels {
10
- /** A solid line. */
11
- Solid = 0,
12
- /** A solid line. */
13
- Code0 = 0,
14
- /** 1 lit pixel followed by 7 unlit pixels: =&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;=&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;= */
15
- Code1 = 2155905152,
16
- /** 5 lit pixels followed by 3 unlit pixels: =====&nbsp;&nbsp;&nbsp;=====&nbsp;&nbsp;&nbsp;===== */
17
- Code2 = 4177066232,
18
- /** 11 lit pixels followed by 5 unlit pixels: ===========&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;=========== */
19
- Code3 = 4292935648,
20
- /** 7 lit pixels followed by 4 unlit pixels followed by 1 lit pixel followed by 1 lit pixel: =======&nbsp;&nbsp;&nbsp;&nbsp;=&nbsp;&nbsp;&nbsp;&nbsp;=======&nbsp;&nbsp;&nbsp;&nbsp;= */
21
- Code4 = 4262526480,
22
- /** 3 lit pixels followed by 5 unlit pixels: ===&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;===&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;=== */
23
- Code5 = 3772834016,
24
- /** 5 lit pixels followed by 3 unlit followed by 1 lit followed by 3 unlit followed by 1 lit followed by 3 unlit: =====&nbsp;&nbsp;&nbsp;=&nbsp;&nbsp;&nbsp;=&nbsp;&nbsp;&nbsp;===== */
25
- Code6 = 4169726088,
26
- /** 8 lit pixels followed by 3 unlit followed by 2 lit followed by 3 unlit: ========&nbsp;&nbsp;&nbsp;==&nbsp;&nbsp;&nbsp;======== */
27
- Code7 = 4279828248,
28
- /** 2 lit pixels followed by 2 unlit pixels - default style for drawing hidden edges: ==&nbsp;&nbsp;==&nbsp;&nbsp;==&nbsp;&nbsp;== */
29
- HiddenLine = 3435973836,
30
- /** Barely visible - 1 lit pixel followed by 31 unlit pixels. */
31
- Invisible = 1,
32
- /** Indicates no valid line style or none specified, depending on context. */
33
- Invalid = -1
34
- }
1
+ /** @packageDocumentation
2
+ * @module Symbology
3
+ */
4
+ /** Enumerates the available patterns for drawing patterned lines.
5
+ * Each is a 32-bit pattern in which each bit specifies the on- or off-state of a pixel along the line. The pattern repeats along the length of the entire line.
6
+ * @public
7
+ * @extensions
8
+ */
9
+ export declare enum LinePixels {
10
+ /** A solid line. */
11
+ Solid = 0,
12
+ /** A solid line. */
13
+ Code0 = 0,
14
+ /** 1 lit pixel followed by 7 unlit pixels: =&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;=&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;= */
15
+ Code1 = 2155905152,
16
+ /** 5 lit pixels followed by 3 unlit pixels: =====&nbsp;&nbsp;&nbsp;=====&nbsp;&nbsp;&nbsp;===== */
17
+ Code2 = 4177066232,
18
+ /** 11 lit pixels followed by 5 unlit pixels: ===========&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;=========== */
19
+ Code3 = 4292935648,
20
+ /** 7 lit pixels followed by 4 unlit pixels followed by 1 lit pixel followed by 1 lit pixel: =======&nbsp;&nbsp;&nbsp;&nbsp;=&nbsp;&nbsp;&nbsp;&nbsp;=======&nbsp;&nbsp;&nbsp;&nbsp;= */
21
+ Code4 = 4262526480,
22
+ /** 3 lit pixels followed by 5 unlit pixels: ===&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;===&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;=== */
23
+ Code5 = 3772834016,
24
+ /** 5 lit pixels followed by 3 unlit followed by 1 lit followed by 3 unlit followed by 1 lit followed by 3 unlit: =====&nbsp;&nbsp;&nbsp;=&nbsp;&nbsp;&nbsp;=&nbsp;&nbsp;&nbsp;===== */
25
+ Code6 = 4169726088,
26
+ /** 8 lit pixels followed by 3 unlit followed by 2 lit followed by 3 unlit: ========&nbsp;&nbsp;&nbsp;==&nbsp;&nbsp;&nbsp;======== */
27
+ Code7 = 4279828248,
28
+ /** 2 lit pixels followed by 2 unlit pixels - default style for drawing hidden edges: ==&nbsp;&nbsp;==&nbsp;&nbsp;==&nbsp;&nbsp;== */
29
+ HiddenLine = 3435973836,
30
+ /** Barely visible - 1 lit pixel followed by 31 unlit pixels. */
31
+ Invisible = 1,
32
+ /** Indicates no valid line style or none specified, depending on context. */
33
+ Invalid = -1
34
+ }
35
35
  //# sourceMappingURL=LinePixels.d.ts.map
@@ -1,40 +1,40 @@
1
- /*---------------------------------------------------------------------------------------------
2
- * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
3
- * See LICENSE.md in the project root for license terms and full copyright notice.
4
- *--------------------------------------------------------------------------------------------*/
5
- /** @packageDocumentation
6
- * @module Symbology
7
- */
8
- /** Enumerates the available patterns for drawing patterned lines.
9
- * Each is a 32-bit pattern in which each bit specifies the on- or off-state of a pixel along the line. The pattern repeats along the length of the entire line.
10
- * @public
11
- * @extensions
12
- */
13
- export var LinePixels;
14
- (function (LinePixels) {
15
- /** A solid line. */
16
- LinePixels[LinePixels["Solid"] = 0] = "Solid";
17
- /** A solid line. */
18
- LinePixels[LinePixels["Code0"] = 0] = "Code0";
19
- /** 1 lit pixel followed by 7 unlit pixels: =&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;=&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;= */
20
- LinePixels[LinePixels["Code1"] = 2155905152] = "Code1";
21
- /** 5 lit pixels followed by 3 unlit pixels: =====&nbsp;&nbsp;&nbsp;=====&nbsp;&nbsp;&nbsp;===== */
22
- LinePixels[LinePixels["Code2"] = 4177066232] = "Code2";
23
- /** 11 lit pixels followed by 5 unlit pixels: ===========&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;=========== */
24
- LinePixels[LinePixels["Code3"] = 4292935648] = "Code3";
25
- /** 7 lit pixels followed by 4 unlit pixels followed by 1 lit pixel followed by 1 lit pixel: =======&nbsp;&nbsp;&nbsp;&nbsp;=&nbsp;&nbsp;&nbsp;&nbsp;=======&nbsp;&nbsp;&nbsp;&nbsp;= */
26
- LinePixels[LinePixels["Code4"] = 4262526480] = "Code4";
27
- /** 3 lit pixels followed by 5 unlit pixels: ===&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;===&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;=== */
28
- LinePixels[LinePixels["Code5"] = 3772834016] = "Code5";
29
- /** 5 lit pixels followed by 3 unlit followed by 1 lit followed by 3 unlit followed by 1 lit followed by 3 unlit: =====&nbsp;&nbsp;&nbsp;=&nbsp;&nbsp;&nbsp;=&nbsp;&nbsp;&nbsp;===== */
30
- LinePixels[LinePixels["Code6"] = 4169726088] = "Code6";
31
- /** 8 lit pixels followed by 3 unlit followed by 2 lit followed by 3 unlit: ========&nbsp;&nbsp;&nbsp;==&nbsp;&nbsp;&nbsp;======== */
32
- LinePixels[LinePixels["Code7"] = 4279828248] = "Code7";
33
- /** 2 lit pixels followed by 2 unlit pixels - default style for drawing hidden edges: ==&nbsp;&nbsp;==&nbsp;&nbsp;==&nbsp;&nbsp;== */
34
- LinePixels[LinePixels["HiddenLine"] = 3435973836] = "HiddenLine";
35
- /** Barely visible - 1 lit pixel followed by 31 unlit pixels. */
36
- LinePixels[LinePixels["Invisible"] = 1] = "Invisible";
37
- /** Indicates no valid line style or none specified, depending on context. */
38
- LinePixels[LinePixels["Invalid"] = -1] = "Invalid";
39
- })(LinePixels || (LinePixels = {}));
1
+ /*---------------------------------------------------------------------------------------------
2
+ * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
3
+ * See LICENSE.md in the project root for license terms and full copyright notice.
4
+ *--------------------------------------------------------------------------------------------*/
5
+ /** @packageDocumentation
6
+ * @module Symbology
7
+ */
8
+ /** Enumerates the available patterns for drawing patterned lines.
9
+ * Each is a 32-bit pattern in which each bit specifies the on- or off-state of a pixel along the line. The pattern repeats along the length of the entire line.
10
+ * @public
11
+ * @extensions
12
+ */
13
+ export var LinePixels;
14
+ (function (LinePixels) {
15
+ /** A solid line. */
16
+ LinePixels[LinePixels["Solid"] = 0] = "Solid";
17
+ /** A solid line. */
18
+ LinePixels[LinePixels["Code0"] = 0] = "Code0";
19
+ /** 1 lit pixel followed by 7 unlit pixels: =&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;=&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;= */
20
+ LinePixels[LinePixels["Code1"] = 2155905152] = "Code1";
21
+ /** 5 lit pixels followed by 3 unlit pixels: =====&nbsp;&nbsp;&nbsp;=====&nbsp;&nbsp;&nbsp;===== */
22
+ LinePixels[LinePixels["Code2"] = 4177066232] = "Code2";
23
+ /** 11 lit pixels followed by 5 unlit pixels: ===========&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;=========== */
24
+ LinePixels[LinePixels["Code3"] = 4292935648] = "Code3";
25
+ /** 7 lit pixels followed by 4 unlit pixels followed by 1 lit pixel followed by 1 lit pixel: =======&nbsp;&nbsp;&nbsp;&nbsp;=&nbsp;&nbsp;&nbsp;&nbsp;=======&nbsp;&nbsp;&nbsp;&nbsp;= */
26
+ LinePixels[LinePixels["Code4"] = 4262526480] = "Code4";
27
+ /** 3 lit pixels followed by 5 unlit pixels: ===&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;===&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;=== */
28
+ LinePixels[LinePixels["Code5"] = 3772834016] = "Code5";
29
+ /** 5 lit pixels followed by 3 unlit followed by 1 lit followed by 3 unlit followed by 1 lit followed by 3 unlit: =====&nbsp;&nbsp;&nbsp;=&nbsp;&nbsp;&nbsp;=&nbsp;&nbsp;&nbsp;===== */
30
+ LinePixels[LinePixels["Code6"] = 4169726088] = "Code6";
31
+ /** 8 lit pixels followed by 3 unlit followed by 2 lit followed by 3 unlit: ========&nbsp;&nbsp;&nbsp;==&nbsp;&nbsp;&nbsp;======== */
32
+ LinePixels[LinePixels["Code7"] = 4279828248] = "Code7";
33
+ /** 2 lit pixels followed by 2 unlit pixels - default style for drawing hidden edges: ==&nbsp;&nbsp;==&nbsp;&nbsp;==&nbsp;&nbsp;== */
34
+ LinePixels[LinePixels["HiddenLine"] = 3435973836] = "HiddenLine";
35
+ /** Barely visible - 1 lit pixel followed by 31 unlit pixels. */
36
+ LinePixels[LinePixels["Invisible"] = 1] = "Invisible";
37
+ /** Indicates no valid line style or none specified, depending on context. */
38
+ LinePixels[LinePixels["Invalid"] = -1] = "Invalid";
39
+ })(LinePixels || (LinePixels = {}));
40
40
  //# sourceMappingURL=LinePixels.js.map
@@ -1,114 +1,114 @@
1
- /** @packageDocumentation
2
- * @module Localization
3
- */
4
- /** Options for Localization
5
- * @public
6
- */
7
- export interface TranslationOptions {
8
- /** for interpolation values */
9
- [key: string]: any;
10
- /**
11
- * defaultValue to return if a translation was not found
12
- */
13
- defaultValue?: any;
14
- /**
15
- * count value used for plurals
16
- */
17
- count?: number;
18
- /**
19
- * used for contexts (eg. male\female)
20
- */
21
- context?: any;
22
- /**
23
- * override languages to use
24
- */
25
- lngs?: string[];
26
- /**
27
- * override language to lookup key if not found see fallbacks for details
28
- */
29
- fallbackLng?: string;
30
- }
31
- /** The interface defining the localization requirements of [IModelApp]($frontend).
32
- * @public
33
- * @extensions
34
- */
35
- export interface Localization {
36
- /** This method must be called and awaited before using an instance of Localization.
37
- * @param namespaces an array of namespaces to load. There must be at least one namespace, and it
38
- * becomes the default namespace.
39
- * @note IModelApp.startup calls this internally, so you should not call this method directly
40
- * except for Localization instances outside of IModelApp (e.g., for tests.)
41
- */
42
- initialize(namespaces: string[]): Promise<void>;
43
- /** Return the translated value of a key.
44
- * @param key - the key that matches a property in the JSON localization file.
45
- * @note The key includes the namespace, which identifies the particular localization file that contains the property,
46
- * followed by a colon, followed by the property in the JSON file.
47
- * For example:
48
- * ``` ts
49
- * const dataString: string = IModelApp.localization.getLocalizedString("iModelJs:BackgroundMap.BingDataAttribution");
50
- * ```
51
- * assigns to dataString the string with property BackgroundMap.BingDataAttribution from the iModelJs.json localization file.
52
- * @returns The string corresponding to the first key that resolves.
53
- * @throws Error if no keys resolve to a string.
54
- */
55
- getLocalizedString(key: string | string[], options?: TranslationOptions): string;
56
- /** Similar to `getLocalizedString` but the namespace is a separate param and the key does not include the namespace.
57
- * @param namespace - the namespace that identifies the particular localization file that contains the property.
58
- * @param key - the key that matches a property in the JSON localization file.
59
- * @returns The string corresponding to the first key that resolves.
60
- * @throws Error if no keys resolve to a string.
61
- * @deprecated in 3.x. Use `getLocalizedString` instead; providing either a key with a namespace `<namespace>:<key>` or
62
- * including `{ ns: <namespace> }` in the options.
63
- */
64
- getLocalizedStringWithNamespace(namespace: string, key: string | string[], options?: TranslationOptions): string;
65
- /** get the English string for a key. */
66
- getEnglishString(namespace: string, key: string | string[], options?: TranslationOptions): string;
67
- /** Replace all instances of `%{key}` within a string with the translations of those keys.
68
- * For example:
69
- * ``` ts
70
- * "MyKeys": {
71
- * "Key1": "First value",
72
- * "Key2": "Second value"
73
- * }
74
- * ```
75
- *
76
- * ``` ts
77
- * getLocalizedKeys("string with %{MyKeys.Key1} followed by %{MyKeys.Key2}!"") // returns "string with First Value followed by Second Value!"
78
- * ```
79
- */
80
- getLocalizedKeys(inputString: string): string;
81
- /** Register a new Namespace and return a Promise that is fulfilled when the content is loaded.
82
- * If the namespace is already registered, its Promise will be returned.
83
- * @param name - the name of the namespace.
84
- * @note - The registerNamespace method starts fetching the appropriate version of the JSON localization file from the server,
85
- * based on the current locale. To make sure that fetch is complete before performing translations from this namespace, await
86
- * fulfillment of returned Promise.
87
- * @see [Localization in iTwin.js]($docs/learning/frontend/Localization.md)
88
- */
89
- registerNamespace(namespace: string): Promise<void>;
90
- /** @internal */
91
- unregisterNamespace(namespace: string): void;
92
- /** @internal */
93
- getNamespacePromise(name: string): Promise<void> | undefined;
94
- /** Get the list of available languages for translations */
95
- getLanguageList(): readonly string[];
96
- /** Change the language for translations. This overrides the language from the browser, for tests. */
97
- changeLanguage(language: string): Promise<void>;
98
- }
99
- /** An empty [[Localization]] used if one is not provided to [IModelApp]($frontend). Does not perform localizations (merely returns the key.)
100
- * @public
101
- */
102
- export declare class EmptyLocalization implements Localization {
103
- initialize(): Promise<void>;
104
- getLocalizedString(key: string | string[]): string;
105
- getLocalizedStringWithNamespace(_namespace: string, key: string | string[]): string;
106
- getEnglishString(_namespace: string, key: string | string[]): string;
107
- getLocalizedKeys(inputString: string): string;
108
- registerNamespace(): Promise<void>;
109
- unregisterNamespace(): void;
110
- getNamespacePromise(): Promise<void> | undefined;
111
- getLanguageList(): readonly string[];
112
- changeLanguage(): Promise<void>;
113
- }
1
+ /** @packageDocumentation
2
+ * @module Localization
3
+ */
4
+ /** Options for Localization
5
+ * @public
6
+ */
7
+ export interface TranslationOptions {
8
+ /** for interpolation values */
9
+ [key: string]: any;
10
+ /**
11
+ * defaultValue to return if a translation was not found
12
+ */
13
+ defaultValue?: any;
14
+ /**
15
+ * count value used for plurals
16
+ */
17
+ count?: number;
18
+ /**
19
+ * used for contexts (eg. male\female)
20
+ */
21
+ context?: any;
22
+ /**
23
+ * override languages to use
24
+ */
25
+ lngs?: string[];
26
+ /**
27
+ * override language to lookup key if not found see fallbacks for details
28
+ */
29
+ fallbackLng?: string;
30
+ }
31
+ /** The interface defining the localization requirements of [IModelApp]($frontend).
32
+ * @public
33
+ * @extensions
34
+ */
35
+ export interface Localization {
36
+ /** This method must be called and awaited before using an instance of Localization.
37
+ * @param namespaces an array of namespaces to load. There must be at least one namespace, and it
38
+ * becomes the default namespace.
39
+ * @note IModelApp.startup calls this internally, so you should not call this method directly
40
+ * except for Localization instances outside of IModelApp (e.g., for tests.)
41
+ */
42
+ initialize(namespaces: string[]): Promise<void>;
43
+ /** Return the translated value of a key.
44
+ * @param key - the key that matches a property in the JSON localization file.
45
+ * @note The key includes the namespace, which identifies the particular localization file that contains the property,
46
+ * followed by a colon, followed by the property in the JSON file.
47
+ * For example:
48
+ * ``` ts
49
+ * const dataString: string = IModelApp.localization.getLocalizedString("iModelJs:BackgroundMap.BingDataAttribution");
50
+ * ```
51
+ * assigns to dataString the string with property BackgroundMap.BingDataAttribution from the iModelJs.json localization file.
52
+ * @returns The string corresponding to the first key that resolves.
53
+ * @throws Error if no keys resolve to a string.
54
+ */
55
+ getLocalizedString(key: string | string[], options?: TranslationOptions): string;
56
+ /** Similar to `getLocalizedString` but the namespace is a separate param and the key does not include the namespace.
57
+ * @param namespace - the namespace that identifies the particular localization file that contains the property.
58
+ * @param key - the key that matches a property in the JSON localization file.
59
+ * @returns The string corresponding to the first key that resolves.
60
+ * @throws Error if no keys resolve to a string.
61
+ * @deprecated in 3.x. Use `getLocalizedString` instead; providing either a key with a namespace `<namespace>:<key>` or
62
+ * including `{ ns: <namespace> }` in the options.
63
+ */
64
+ getLocalizedStringWithNamespace(namespace: string, key: string | string[], options?: TranslationOptions): string;
65
+ /** get the English string for a key. */
66
+ getEnglishString(namespace: string, key: string | string[], options?: TranslationOptions): string;
67
+ /** Replace all instances of `%{key}` within a string with the translations of those keys.
68
+ * For example:
69
+ * ``` ts
70
+ * "MyKeys": {
71
+ * "Key1": "First value",
72
+ * "Key2": "Second value"
73
+ * }
74
+ * ```
75
+ *
76
+ * ``` ts
77
+ * getLocalizedKeys("string with %{MyKeys.Key1} followed by %{MyKeys.Key2}!"") // returns "string with First Value followed by Second Value!"
78
+ * ```
79
+ */
80
+ getLocalizedKeys(inputString: string): string;
81
+ /** Register a new Namespace and return a Promise that is fulfilled when the content is loaded.
82
+ * If the namespace is already registered, its Promise will be returned.
83
+ * @param name - the name of the namespace.
84
+ * @note - The registerNamespace method starts fetching the appropriate version of the JSON localization file from the server,
85
+ * based on the current locale. To make sure that fetch is complete before performing translations from this namespace, await
86
+ * fulfillment of returned Promise.
87
+ * @see [Localization in iTwin.js]($docs/learning/frontend/Localization.md)
88
+ */
89
+ registerNamespace(namespace: string): Promise<void>;
90
+ /** @internal */
91
+ unregisterNamespace(namespace: string): void;
92
+ /** @internal */
93
+ getNamespacePromise(name: string): Promise<void> | undefined;
94
+ /** Get the list of available languages for translations */
95
+ getLanguageList(): readonly string[];
96
+ /** Change the language for translations. This overrides the language from the browser, for tests. */
97
+ changeLanguage(language: string): Promise<void>;
98
+ }
99
+ /** An empty [[Localization]] used if one is not provided to [IModelApp]($frontend). Does not perform localizations (merely returns the key.)
100
+ * @public
101
+ */
102
+ export declare class EmptyLocalization implements Localization {
103
+ initialize(): Promise<void>;
104
+ getLocalizedString(key: string | string[]): string;
105
+ getLocalizedStringWithNamespace(_namespace: string, key: string | string[]): string;
106
+ getEnglishString(_namespace: string, key: string | string[]): string;
107
+ getLocalizedKeys(inputString: string): string;
108
+ registerNamespace(): Promise<void>;
109
+ unregisterNamespace(): void;
110
+ getNamespacePromise(): Promise<void> | undefined;
111
+ getLanguageList(): readonly string[];
112
+ changeLanguage(): Promise<void>;
113
+ }
114
114
  //# sourceMappingURL=Localization.d.ts.map
@@ -1,30 +1,30 @@
1
- /*---------------------------------------------------------------------------------------------
2
- * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
3
- * See LICENSE.md in the project root for license terms and full copyright notice.
4
- *--------------------------------------------------------------------------------------------*/
5
- /** @packageDocumentation
6
- * @module Localization
7
- */
8
- /** An empty [[Localization]] used if one is not provided to [IModelApp]($frontend). Does not perform localizations (merely returns the key.)
9
- * @public
10
- */
11
- export class EmptyLocalization {
12
- async initialize() { }
13
- getLocalizedString(key) {
14
- if (typeof (key) !== "string") {
15
- key = key[0];
16
- }
17
- // Simulate correct and simple usage of i18next's translation function
18
- // Namely, remove the leading namespace substring if there is one
19
- return key.split(":", 2).pop();
20
- }
21
- getLocalizedStringWithNamespace(_namespace, key) { return this.getLocalizedString(key); }
22
- getEnglishString(_namespace, key) { return this.getLocalizedString(key); }
23
- getLocalizedKeys(inputString) { return inputString; }
24
- async registerNamespace() { }
25
- unregisterNamespace() { }
26
- getNamespacePromise() { return undefined; }
27
- getLanguageList() { return []; }
28
- async changeLanguage() { }
29
- }
1
+ /*---------------------------------------------------------------------------------------------
2
+ * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
3
+ * See LICENSE.md in the project root for license terms and full copyright notice.
4
+ *--------------------------------------------------------------------------------------------*/
5
+ /** @packageDocumentation
6
+ * @module Localization
7
+ */
8
+ /** An empty [[Localization]] used if one is not provided to [IModelApp]($frontend). Does not perform localizations (merely returns the key.)
9
+ * @public
10
+ */
11
+ export class EmptyLocalization {
12
+ async initialize() { }
13
+ getLocalizedString(key) {
14
+ if (typeof (key) !== "string") {
15
+ key = key[0];
16
+ }
17
+ // Simulate correct and simple usage of i18next's translation function
18
+ // Namely, remove the leading namespace substring if there is one
19
+ return key.split(":", 2).pop();
20
+ }
21
+ getLocalizedStringWithNamespace(_namespace, key) { return this.getLocalizedString(key); }
22
+ getEnglishString(_namespace, key) { return this.getLocalizedString(key); }
23
+ getLocalizedKeys(inputString) { return inputString; }
24
+ async registerNamespace() { }
25
+ unregisterNamespace() { }
26
+ getNamespacePromise() { return undefined; }
27
+ getLanguageList() { return []; }
28
+ async changeLanguage() { }
29
+ }
30
30
  //# sourceMappingURL=Localization.js.map