@vcmap/core 5.3.3 → 6.0.0-rc.10

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 (400) hide show
  1. package/dist/cesium.d.ts +12 -0
  2. package/dist/index.d.ts +27 -19
  3. package/dist/index.js +22 -14
  4. package/dist/index.js.map +1 -1
  5. package/dist/ol.d.ts +15 -2
  6. package/dist/src/category/category.d.ts +5 -4
  7. package/dist/src/category/category.js +2 -1
  8. package/dist/src/category/category.js.map +1 -1
  9. package/dist/src/category/categoryCollection.js.map +1 -1
  10. package/dist/src/cesium/cesiumVcsCameraPrimitive.d.ts +1 -0
  11. package/dist/src/cesium/cesiumVcsCameraPrimitive.js +4 -0
  12. package/dist/src/cesium/cesiumVcsCameraPrimitive.js.map +1 -1
  13. package/dist/src/classRegistry.d.ts +4 -3
  14. package/dist/src/classRegistry.js +2 -0
  15. package/dist/src/classRegistry.js.map +1 -1
  16. package/dist/src/featureProvider/abstractFeatureProvider.js.map +1 -1
  17. package/dist/src/featureProvider/wmsFeatureProvider.js.map +1 -1
  18. package/dist/src/interaction/abstractInteraction.js.map +1 -1
  19. package/dist/src/interaction/coordinateAtPixel.js.map +1 -1
  20. package/dist/src/interaction/eventHandler.js.map +1 -1
  21. package/dist/src/interaction/featureAtPixelInteraction.d.ts +4 -12
  22. package/dist/src/interaction/featureAtPixelInteraction.js +5 -21
  23. package/dist/src/interaction/featureAtPixelInteraction.js.map +1 -1
  24. package/dist/src/interaction/featureProviderInteraction.js.map +1 -1
  25. package/dist/src/interaction/interactionChain.js.map +1 -1
  26. package/dist/src/interaction/interactionType.js +4 -4
  27. package/dist/src/interaction/interactionType.js.map +1 -1
  28. package/dist/src/layer/cesium/cesiumTilesetCesiumImpl.js.map +1 -1
  29. package/dist/src/layer/cesium/clusterContext.d.ts +12 -16
  30. package/dist/src/layer/cesium/clusterContext.js +75 -43
  31. package/dist/src/layer/cesium/clusterContext.js.map +1 -1
  32. package/dist/src/layer/cesium/dataSourceCesiumImpl.js.map +1 -1
  33. package/dist/src/layer/cesium/rasterLayerCesiumImpl.js.map +1 -1
  34. package/dist/src/layer/cesium/resourceHelper.js.map +1 -1
  35. package/dist/src/layer/cesium/singleImageCesiumImpl.js.map +1 -1
  36. package/dist/src/layer/cesium/terrainCesiumImpl.js.map +1 -1
  37. package/dist/src/layer/cesium/tmsCesiumImpl.js.map +1 -1
  38. package/dist/src/layer/cesium/vectorCesiumImpl.d.ts +2 -3
  39. package/dist/src/layer/cesium/vectorCesiumImpl.js +16 -10
  40. package/dist/src/layer/cesium/vectorCesiumImpl.js.map +1 -1
  41. package/dist/src/layer/cesium/vectorContext.d.ts +11 -54
  42. package/dist/src/layer/cesium/vectorContext.js +154 -171
  43. package/dist/src/layer/cesium/vectorContext.js.map +1 -1
  44. package/dist/src/layer/cesium/vectorRasterTileCesiumImpl.js.map +1 -1
  45. package/dist/src/layer/cesium/vectorTileImageryProvider.js.map +1 -1
  46. package/dist/src/layer/cesium/wmsCesiumImpl.js.map +1 -1
  47. package/dist/src/layer/cesiumTilesetLayer.js.map +1 -1
  48. package/dist/src/layer/czmlLayer.js.map +1 -1
  49. package/dist/src/layer/dataSourceLayer.js.map +1 -1
  50. package/dist/src/layer/featureLayer.js.map +1 -1
  51. package/dist/src/layer/featureStoreFeatureVisibility.js.map +1 -1
  52. package/dist/src/layer/featureStoreLayer.js.map +1 -1
  53. package/dist/src/layer/featureStoreLayerChanges.js.map +1 -1
  54. package/dist/src/layer/featureVisibility.js +4 -5
  55. package/dist/src/layer/featureVisibility.js.map +1 -1
  56. package/dist/src/layer/geojsonHelpers.d.ts +1 -1
  57. package/dist/src/layer/geojsonHelpers.js +5 -10
  58. package/dist/src/layer/geojsonHelpers.js.map +1 -1
  59. package/dist/src/layer/geojsonLayer.js.map +1 -1
  60. package/dist/src/layer/globalHider.js.map +1 -1
  61. package/dist/src/layer/layer.js.map +1 -1
  62. package/dist/src/layer/layerImplementation.js.map +1 -1
  63. package/dist/src/layer/oblique/layerObliqueImpl.js.map +1 -1
  64. package/dist/src/layer/oblique/obliqueHelpers.js +9 -9
  65. package/dist/src/layer/oblique/obliqueHelpers.js.map +1 -1
  66. package/dist/src/layer/oblique/vectorObliqueImpl.d.ts +3 -3
  67. package/dist/src/layer/oblique/vectorObliqueImpl.js.map +1 -1
  68. package/dist/src/layer/openStreetMapLayer.js.map +1 -1
  69. package/dist/src/layer/openlayers/layerOpenlayersImpl.js.map +1 -1
  70. package/dist/src/layer/openlayers/rasterLayerOpenlayersImpl.js.map +1 -1
  71. package/dist/src/layer/openlayers/singleImageOpenlayersImpl.js.map +1 -1
  72. package/dist/src/layer/openlayers/tmsOpenlayersImpl.js.map +1 -1
  73. package/dist/src/layer/openlayers/vectorOpenlayersImpl.d.ts +2 -2
  74. package/dist/src/layer/openlayers/vectorOpenlayersImpl.js.map +1 -1
  75. package/dist/src/layer/openlayers/vectorTileOpenlayersImpl.d.ts +1 -7
  76. package/dist/src/layer/openlayers/vectorTileOpenlayersImpl.js +18 -47
  77. package/dist/src/layer/openlayers/vectorTileOpenlayersImpl.js.map +1 -1
  78. package/dist/src/layer/openlayers/wmsOpenlayersImpl.js.map +1 -1
  79. package/dist/src/layer/openlayers/wmtsOpenlayersImpl.js.map +1 -1
  80. package/dist/src/layer/pointCloudLayer.js.map +1 -1
  81. package/dist/src/layer/rasterLayer.js +1 -1
  82. package/dist/src/layer/rasterLayer.js.map +1 -1
  83. package/dist/src/layer/singleImageLayer.js.map +1 -1
  84. package/dist/src/layer/terrainHelpers.js.map +1 -1
  85. package/dist/src/layer/terrainLayer.js.map +1 -1
  86. package/dist/src/layer/tileLoadedHelper.js.map +1 -1
  87. package/dist/src/layer/tileProvider/mvtTileProvider.js.map +1 -1
  88. package/dist/src/layer/tileProvider/staticGeojsonTileProvider.js.map +1 -1
  89. package/dist/src/layer/tileProvider/tileProvider.js.map +1 -1
  90. package/dist/src/layer/tileProvider/urlTemplateTileProvider.js.map +1 -1
  91. package/dist/src/layer/tmsLayer.js.map +1 -1
  92. package/dist/src/layer/vectorHelpers.js.map +1 -1
  93. package/dist/src/layer/vectorLayer.d.ts +0 -37
  94. package/dist/src/layer/vectorLayer.js +1 -3
  95. package/dist/src/layer/vectorLayer.js.map +1 -1
  96. package/dist/src/layer/vectorProperties.d.ts +10 -5
  97. package/dist/src/layer/vectorProperties.js +59 -10
  98. package/dist/src/layer/vectorProperties.js.map +1 -1
  99. package/dist/src/layer/vectorTileLayer.js.map +1 -1
  100. package/dist/src/layer/wfsLayer.js.map +1 -1
  101. package/dist/src/layer/wmsHelpers.js.map +1 -1
  102. package/dist/src/layer/wmsLayer.js.map +1 -1
  103. package/dist/src/layer/wmtsLayer.js.map +1 -1
  104. package/dist/src/map/baseOLMap.js +1 -1
  105. package/dist/src/map/baseOLMap.js.map +1 -1
  106. package/dist/src/map/cameraLimiter.js +1 -1
  107. package/dist/src/map/cameraLimiter.js.map +1 -1
  108. package/dist/src/map/cesiumMap.js.map +1 -1
  109. package/dist/src/map/obliqueMap.js.map +1 -1
  110. package/dist/src/map/openlayersMap.js +1 -1
  111. package/dist/src/map/openlayersMap.js.map +1 -1
  112. package/dist/src/map/vcsMap.js.map +1 -1
  113. package/dist/src/oblique/helpers.js +5 -5
  114. package/dist/src/oblique/helpers.js.map +1 -1
  115. package/dist/src/oblique/obliqueCollection.js.map +1 -1
  116. package/dist/src/oblique/obliqueDataSet.js +5 -5
  117. package/dist/src/oblique/obliqueDataSet.js.map +1 -1
  118. package/dist/src/oblique/obliqueImage.js.map +1 -1
  119. package/dist/src/oblique/obliqueImageMeta.js.map +1 -1
  120. package/dist/src/oblique/obliqueProvider.js.map +1 -1
  121. package/dist/src/oblique/obliqueView.js.map +1 -1
  122. package/dist/src/oblique/obliqueViewDirection.js +1 -1
  123. package/dist/src/oblique/obliqueViewDirection.js.map +1 -1
  124. package/dist/src/oblique/parseImageJson.js.map +1 -1
  125. package/dist/src/ol/feature.js.map +1 -1
  126. package/dist/src/ol/geom/geometryCollection.js +80 -6
  127. package/dist/src/ol/geom/geometryCollection.js.map +1 -1
  128. package/dist/src/ol/render/canvas/canvasTileRenderer.js.map +1 -1
  129. package/dist/src/ol/source/ClusterEnhancedVectorSource.js.map +1 -1
  130. package/dist/src/ol/source/VcsCluster.js.map +1 -1
  131. package/dist/src/overrideClassRegistry.d.ts +2 -2
  132. package/dist/src/overrideClassRegistry.js +5 -3
  133. package/dist/src/overrideClassRegistry.js.map +1 -1
  134. package/dist/src/style/arcStyle.js +1 -0
  135. package/dist/src/style/arcStyle.js.map +1 -1
  136. package/dist/src/style/arrowStyle.js +6 -6
  137. package/dist/src/style/arrowStyle.js.map +1 -1
  138. package/dist/src/style/declarativeStyleItem.js.map +1 -1
  139. package/dist/src/style/shapesCategory.js.map +1 -1
  140. package/dist/src/style/styleFactory.js.map +1 -1
  141. package/dist/src/style/styleHelpers.js +4 -2
  142. package/dist/src/style/styleHelpers.js.map +1 -1
  143. package/dist/src/style/styleItem.js.map +1 -1
  144. package/dist/src/style/vectorStyleItem.js +9 -9
  145. package/dist/src/style/vectorStyleItem.js.map +1 -1
  146. package/dist/src/style/writeStyle.js.map +1 -1
  147. package/dist/src/util/clipping/clippingObject.js.map +1 -1
  148. package/dist/src/util/clipping/clippingObjectManager.js.map +1 -1
  149. package/dist/src/util/clipping/clippingPlaneHelper.js +2 -2
  150. package/dist/src/util/clipping/clippingPlaneHelper.js.map +1 -1
  151. package/dist/src/util/collection.js.map +1 -1
  152. package/dist/src/util/displayQuality/displayQuality.d.ts +1 -0
  153. package/dist/src/util/displayQuality/displayQuality.js +13 -2
  154. package/dist/src/util/displayQuality/displayQuality.js.map +1 -1
  155. package/dist/src/util/editor/createFeatureSession.d.ts +10 -2
  156. package/dist/src/util/editor/createFeatureSession.js +75 -9
  157. package/dist/src/util/editor/createFeatureSession.js.map +1 -1
  158. package/dist/src/util/editor/editFeaturesSession.d.ts +10 -4
  159. package/dist/src/util/editor/editFeaturesSession.js +74 -37
  160. package/dist/src/util/editor/editFeaturesSession.js.map +1 -1
  161. package/dist/src/util/editor/editGeometrySession.d.ts +7 -2
  162. package/dist/src/util/editor/editGeometrySession.js +109 -66
  163. package/dist/src/util/editor/editGeometrySession.js.map +1 -1
  164. package/dist/src/util/editor/editorHelpers.d.ts +13 -6
  165. package/dist/src/util/editor/editorHelpers.js +53 -23
  166. package/dist/src/util/editor/editorHelpers.js.map +1 -1
  167. package/dist/src/util/editor/editorSessionHelpers.d.ts +6 -6
  168. package/dist/src/util/editor/editorSessionHelpers.js +8 -18
  169. package/dist/src/util/editor/editorSessionHelpers.js.map +1 -1
  170. package/dist/src/util/editor/editorSymbols.d.ts +1 -1
  171. package/dist/src/util/editor/editorSymbols.js +1 -1
  172. package/dist/src/util/editor/editorSymbols.js.map +1 -1
  173. package/dist/src/util/editor/interactions/createBBoxInteraction.d.ts +1 -0
  174. package/dist/src/util/editor/interactions/createBBoxInteraction.js +20 -16
  175. package/dist/src/util/editor/interactions/createBBoxInteraction.js.map +1 -1
  176. package/dist/src/util/editor/interactions/createCircleInteraction.js +1 -1
  177. package/dist/src/util/editor/interactions/createCircleInteraction.js.map +1 -1
  178. package/dist/src/util/editor/interactions/createLineStringInteraction.js +3 -3
  179. package/dist/src/util/editor/interactions/createLineStringInteraction.js.map +1 -1
  180. package/dist/src/util/editor/interactions/createPointInteraction.js +1 -1
  181. package/dist/src/util/editor/interactions/createPointInteraction.js.map +1 -1
  182. package/dist/src/util/editor/interactions/createPolygonInteraction.d.ts +4 -0
  183. package/dist/src/util/editor/interactions/createPolygonInteraction.js +9 -3
  184. package/dist/src/util/editor/interactions/createPolygonInteraction.js.map +1 -1
  185. package/dist/src/util/editor/interactions/creationSnapping.d.ts +26 -0
  186. package/dist/src/util/editor/interactions/creationSnapping.js +139 -0
  187. package/dist/src/util/editor/interactions/creationSnapping.js.map +1 -0
  188. package/dist/src/util/editor/interactions/editFeaturesMouseOverInteraction.js.map +1 -1
  189. package/dist/src/util/editor/interactions/editGeometryMouseOverInteraction.js +11 -9
  190. package/dist/src/util/editor/interactions/editGeometryMouseOverInteraction.js.map +1 -1
  191. package/dist/src/util/editor/interactions/ensureHandlerSelectionInteraction.js.map +1 -1
  192. package/dist/src/util/editor/interactions/insertVertexInteraction.d.ts +3 -1
  193. package/dist/src/util/editor/interactions/insertVertexInteraction.js +14 -6
  194. package/dist/src/util/editor/interactions/insertVertexInteraction.js.map +1 -1
  195. package/dist/src/util/editor/interactions/layerSnapping.d.ts +19 -0
  196. package/dist/src/util/editor/interactions/layerSnapping.js +87 -0
  197. package/dist/src/util/editor/interactions/layerSnapping.js.map +1 -0
  198. package/dist/src/util/editor/interactions/mapInteractionController.js.map +1 -1
  199. package/dist/src/util/editor/interactions/removeVertexInteraction.d.ts +1 -1
  200. package/dist/src/util/editor/interactions/removeVertexInteraction.js +2 -2
  201. package/dist/src/util/editor/interactions/removeVertexInteraction.js.map +1 -1
  202. package/dist/src/util/editor/interactions/segmentLengthInteraction.d.ts +16 -0
  203. package/dist/src/util/editor/interactions/segmentLengthInteraction.js +167 -0
  204. package/dist/src/util/editor/interactions/segmentLengthInteraction.js.map +1 -0
  205. package/dist/src/util/editor/interactions/selectFeatureMouseOverInteraction.js +1 -1
  206. package/dist/src/util/editor/interactions/selectFeatureMouseOverInteraction.js.map +1 -1
  207. package/dist/src/util/editor/interactions/selectMultiFeatureInteraction.d.ts +1 -1
  208. package/dist/src/util/editor/interactions/selectMultiFeatureInteraction.js.map +1 -1
  209. package/dist/src/util/editor/interactions/selectSingleFeatureInteraction.d.ts +1 -1
  210. package/dist/src/util/editor/interactions/selectSingleFeatureInteraction.js.map +1 -1
  211. package/dist/src/util/editor/interactions/translateVertexInteraction.js +4 -8
  212. package/dist/src/util/editor/interactions/translateVertexInteraction.js.map +1 -1
  213. package/dist/src/util/editor/interactions/translationSnapping.d.ts +25 -0
  214. package/dist/src/util/editor/interactions/translationSnapping.js +180 -0
  215. package/dist/src/util/editor/interactions/translationSnapping.js.map +1 -0
  216. package/dist/src/util/editor/selectFeaturesSession.js.map +1 -1
  217. package/dist/src/util/editor/snappingHelpers.d.ts +44 -0
  218. package/dist/src/util/editor/snappingHelpers.js +329 -0
  219. package/dist/src/util/editor/snappingHelpers.js.map +1 -0
  220. package/dist/src/util/editor/transformation/create2DHandlers.js +26 -26
  221. package/dist/src/util/editor/transformation/create2DHandlers.js.map +1 -1
  222. package/dist/src/util/editor/transformation/create3DHandlers.js +65 -14
  223. package/dist/src/util/editor/transformation/create3DHandlers.js.map +1 -1
  224. package/dist/src/util/editor/transformation/extrudeInteraction.js.map +1 -1
  225. package/dist/src/util/editor/transformation/rotateInteraction.js.map +1 -1
  226. package/dist/src/util/editor/transformation/scaleInteraction.js +27 -5
  227. package/dist/src/util/editor/transformation/scaleInteraction.js.map +1 -1
  228. package/dist/src/util/editor/transformation/transformationHandler.js +56 -38
  229. package/dist/src/util/editor/transformation/transformationHandler.js.map +1 -1
  230. package/dist/src/util/editor/transformation/transformationTypes.d.ts +2 -0
  231. package/dist/src/util/editor/transformation/transformationTypes.js +6 -2
  232. package/dist/src/util/editor/transformation/transformationTypes.js.map +1 -1
  233. package/dist/src/util/editor/transformation/translateInteraction.js.map +1 -1
  234. package/dist/src/util/editor/validateGeoemetry.js.map +1 -1
  235. package/dist/src/util/exclusiveManager.js.map +1 -1
  236. package/dist/src/util/extent.js.map +1 -1
  237. package/dist/src/util/featureconverter/arcToCesium.d.ts +5 -19
  238. package/dist/src/util/featureconverter/arcToCesium.js +15 -42
  239. package/dist/src/util/featureconverter/arcToCesium.js.map +1 -1
  240. package/dist/src/util/featureconverter/circleToCesium.d.ts +2 -27
  241. package/dist/src/util/featureconverter/circleToCesium.js +85 -64
  242. package/dist/src/util/featureconverter/circleToCesium.js.map +1 -1
  243. package/dist/src/util/featureconverter/clampedPrimitive.d.ts +2 -0
  244. package/dist/src/util/featureconverter/clampedPrimitive.js +29 -0
  245. package/dist/src/util/featureconverter/clampedPrimitive.js.map +1 -0
  246. package/dist/src/util/featureconverter/convert.d.ts +30 -7
  247. package/dist/src/util/featureconverter/convert.js +221 -44
  248. package/dist/src/util/featureconverter/convert.js.map +1 -1
  249. package/dist/src/util/featureconverter/extent3D.d.ts +4 -3
  250. package/dist/src/util/featureconverter/extent3D.js +4 -3
  251. package/dist/src/util/featureconverter/extent3D.js.map +1 -1
  252. package/dist/src/util/featureconverter/lineStringToCesium.d.ts +12 -27
  253. package/dist/src/util/featureconverter/lineStringToCesium.js +85 -107
  254. package/dist/src/util/featureconverter/lineStringToCesium.js.map +1 -1
  255. package/dist/src/util/featureconverter/pointHelpers.d.ts +8 -11
  256. package/dist/src/util/featureconverter/pointHelpers.js +141 -121
  257. package/dist/src/util/featureconverter/pointHelpers.js.map +1 -1
  258. package/dist/src/util/featureconverter/pointToCesium.d.ts +14 -17
  259. package/dist/src/util/featureconverter/pointToCesium.js +50 -98
  260. package/dist/src/util/featureconverter/pointToCesium.js.map +1 -1
  261. package/dist/src/util/featureconverter/polygonToCesium.d.ts +2 -26
  262. package/dist/src/util/featureconverter/polygonToCesium.js +63 -73
  263. package/dist/src/util/featureconverter/polygonToCesium.js.map +1 -1
  264. package/dist/src/util/featureconverter/storeyHelpers.d.ts +17 -0
  265. package/dist/src/util/featureconverter/storeyHelpers.js +78 -0
  266. package/dist/src/util/featureconverter/storeyHelpers.js.map +1 -0
  267. package/dist/src/util/featureconverter/vectorGeometryFactory.d.ts +54 -0
  268. package/dist/src/util/featureconverter/vectorGeometryFactory.js +278 -0
  269. package/dist/src/util/featureconverter/vectorGeometryFactory.js.map +1 -0
  270. package/dist/src/util/featureconverter/vectorHeightInfo.d.ts +86 -0
  271. package/dist/src/util/featureconverter/vectorHeightInfo.js +240 -0
  272. package/dist/src/util/featureconverter/vectorHeightInfo.js.map +1 -0
  273. package/dist/src/util/fetch.js.map +1 -1
  274. package/dist/src/util/flight/flightAnchor.js.map +1 -1
  275. package/dist/src/util/flight/flightCollection.js.map +1 -1
  276. package/dist/src/util/flight/flightHelpers.js.map +1 -1
  277. package/dist/src/util/flight/flightInstance.js.map +1 -1
  278. package/dist/src/util/flight/flightPlayer.d.ts +11 -6
  279. package/dist/src/util/flight/flightPlayer.js +52 -16
  280. package/dist/src/util/flight/flightPlayer.js.map +1 -1
  281. package/dist/src/util/flight/flightVisualizer.js.map +1 -1
  282. package/dist/src/util/geometryHelpers.d.ts +34 -2
  283. package/dist/src/util/geometryHelpers.js +172 -4
  284. package/dist/src/util/geometryHelpers.js.map +1 -1
  285. package/dist/src/util/hiddenObjects.js.map +1 -1
  286. package/dist/src/util/indexedCollection.js.map +1 -1
  287. package/dist/src/util/layerCollection.js.map +1 -1
  288. package/dist/src/util/locale.js.map +1 -1
  289. package/dist/src/util/mapCollection.js.map +1 -1
  290. package/dist/src/util/math.d.ts +18 -2
  291. package/dist/src/util/math.js +55 -12
  292. package/dist/src/util/math.js.map +1 -1
  293. package/dist/src/util/overrideCollection.d.ts +7 -7
  294. package/dist/src/util/overrideCollection.js +10 -7
  295. package/dist/src/util/overrideCollection.js.map +1 -1
  296. package/dist/src/util/projection.js.map +1 -1
  297. package/dist/src/util/urlHelpers.js.map +1 -1
  298. package/dist/src/util/viewpoint.js.map +1 -1
  299. package/dist/src/vcsApp.d.ts +3 -3
  300. package/dist/src/vcsApp.js +1 -0
  301. package/dist/src/vcsApp.js.map +1 -1
  302. package/dist/src/vcsEvent.js.map +1 -1
  303. package/dist/src/vcsModule.js.map +1 -1
  304. package/dist/src/vcsModuleHelpers.d.ts +1 -0
  305. package/dist/src/vcsModuleHelpers.js +16 -2
  306. package/dist/src/vcsModuleHelpers.js.map +1 -1
  307. package/dist/src/vcsObject.js.map +1 -1
  308. package/dist/tests/unit/helpers/cesiumHelpers.d.ts +11 -11
  309. package/dist/tests/unit/helpers/cesiumHelpers.js +6 -1
  310. package/dist/tests/unit/helpers/cesiumHelpers.js.map +1 -1
  311. package/dist/tests/unit/helpers/helpers.d.ts +2 -9
  312. package/dist/tests/unit/helpers/helpers.js +4 -10
  313. package/dist/tests/unit/helpers/helpers.js.map +1 -1
  314. package/dist/tests/unit/helpers/importJSON.js.map +1 -1
  315. package/dist/tests/unit/helpers/obliqueHelpers.js.map +1 -1
  316. package/index.ts +84 -36
  317. package/package.json +21 -21
  318. package/src/category/category.ts +11 -9
  319. package/src/category/categoryCollection.ts +1 -1
  320. package/src/cesium/cesium.d.ts +12 -0
  321. package/src/cesium/cesiumVcsCameraPrimitive.ts +5 -0
  322. package/src/classRegistry.ts +7 -4
  323. package/src/featureProvider/wmsFeatureProvider.ts +1 -1
  324. package/src/global.d.ts +6 -1
  325. package/src/interaction/featureAtPixelInteraction.ts +7 -26
  326. package/src/layer/cesium/clusterContext.ts +97 -93
  327. package/src/layer/cesium/vectorCesiumImpl.ts +17 -11
  328. package/src/layer/cesium/vectorContext.ts +229 -348
  329. package/src/layer/featureVisibility.ts +3 -6
  330. package/src/layer/geojsonHelpers.ts +9 -12
  331. package/src/layer/oblique/obliqueHelpers.ts +9 -9
  332. package/src/layer/oblique/vectorObliqueImpl.ts +2 -2
  333. package/src/layer/openlayers/vectorOpenlayersImpl.ts +2 -2
  334. package/src/layer/openlayers/vectorTileOpenlayersImpl.ts +23 -53
  335. package/src/layer/tileLoadedHelper.ts +1 -3
  336. package/src/layer/tileProvider/mvtTileProvider.ts +2 -2
  337. package/src/layer/vectorLayer.ts +1 -74
  338. package/src/layer/vectorProperties.ts +80 -16
  339. package/src/map/baseOLMap.ts +1 -1
  340. package/src/oblique/helpers.ts +11 -5
  341. package/src/oblique/obliqueDataSet.ts +4 -4
  342. package/src/ol/geom/geometryCollection.js +96 -6
  343. package/src/ol/ol.d.ts +15 -2
  344. package/src/overrideClassRegistry.ts +13 -7
  345. package/src/style/arcStyle.ts +1 -0
  346. package/src/style/arrowStyle.ts +7 -7
  347. package/src/style/declarativeStyleItem.ts +2 -2
  348. package/src/style/styleHelpers.ts +15 -13
  349. package/src/style/vectorStyleItem.ts +14 -14
  350. package/src/util/clipping/clippingObject.ts +1 -3
  351. package/src/util/clipping/clippingPlaneHelper.ts +3 -4
  352. package/src/util/displayQuality/displayQuality.ts +13 -1
  353. package/src/util/editor/createFeatureSession.ts +107 -13
  354. package/src/util/editor/editFeaturesSession.ts +105 -39
  355. package/src/util/editor/editGeometrySession.ts +157 -83
  356. package/src/util/editor/editorHelpers.ts +85 -33
  357. package/src/util/editor/editorSessionHelpers.ts +13 -20
  358. package/src/util/editor/editorSymbols.ts +1 -1
  359. package/src/util/editor/interactions/createBBoxInteraction.ts +25 -16
  360. package/src/util/editor/interactions/createCircleInteraction.ts +1 -1
  361. package/src/util/editor/interactions/createLineStringInteraction.ts +9 -3
  362. package/src/util/editor/interactions/createPointInteraction.ts +1 -1
  363. package/src/util/editor/interactions/createPolygonInteraction.ts +16 -3
  364. package/src/util/editor/interactions/creationSnapping.ts +226 -0
  365. package/src/util/editor/interactions/editGeometryMouseOverInteraction.ts +7 -6
  366. package/src/util/editor/interactions/insertVertexInteraction.ts +27 -7
  367. package/src/util/editor/interactions/layerSnapping.ts +136 -0
  368. package/src/util/editor/interactions/removeVertexInteraction.ts +3 -4
  369. package/src/util/editor/interactions/segmentLengthInteraction.ts +227 -0
  370. package/src/util/editor/interactions/translateVertexInteraction.ts +11 -12
  371. package/src/util/editor/interactions/translationSnapping.ts +302 -0
  372. package/src/util/editor/snappingHelpers.ts +490 -0
  373. package/src/util/editor/transformation/create2DHandlers.ts +38 -26
  374. package/src/util/editor/transformation/create3DHandlers.ts +84 -22
  375. package/src/util/editor/transformation/scaleInteraction.ts +28 -5
  376. package/src/util/editor/transformation/transformationHandler.ts +72 -41
  377. package/src/util/editor/transformation/transformationTypes.ts +5 -0
  378. package/src/util/featureconverter/arcToCesium.ts +25 -95
  379. package/src/util/featureconverter/circleToCesium.ts +128 -114
  380. package/src/util/featureconverter/clampedPrimitive.ts +70 -0
  381. package/src/util/featureconverter/convert.ts +447 -113
  382. package/src/util/featureconverter/extent3D.ts +13 -6
  383. package/src/util/featureconverter/lineStringToCesium.ts +134 -181
  384. package/src/util/featureconverter/pointHelpers.ts +285 -219
  385. package/src/util/featureconverter/pointToCesium.ts +117 -177
  386. package/src/util/featureconverter/polygonToCesium.ts +99 -118
  387. package/src/util/featureconverter/storeyHelpers.ts +104 -0
  388. package/src/util/featureconverter/vectorGeometryFactory.ts +601 -0
  389. package/src/util/featureconverter/vectorHeightInfo.ts +392 -0
  390. package/src/util/flight/flightPlayer.ts +64 -22
  391. package/src/util/geometryHelpers.ts +239 -9
  392. package/src/util/hiddenObjects.ts +4 -4
  393. package/src/util/math.ts +87 -12
  394. package/src/util/overrideCollection.ts +33 -21
  395. package/src/vcsApp.ts +11 -4
  396. package/src/vcsModuleHelpers.ts +25 -2
  397. package/dist/src/util/featureconverter/featureconverterHelper.d.ts +0 -35
  398. package/dist/src/util/featureconverter/featureconverterHelper.js +0 -403
  399. package/dist/src/util/featureconverter/featureconverterHelper.js.map +0 -1
  400. package/src/util/featureconverter/featureconverterHelper.ts +0 -668
@@ -0,0 +1,490 @@
1
+ import { Coordinate } from 'ol/coordinate.js';
2
+ import { Fill, Icon, Stroke, Style } from 'ol/style.js';
3
+ import { Feature } from 'ol';
4
+ import { Geometry, Point } from 'ol/geom.js';
5
+ import RegularShape from 'ol/style/RegularShape.js';
6
+ import { Cartesian2, Matrix2, Math as CesiumMath } from '@vcmap-cesium/engine';
7
+ import {
8
+ cartesian2DDistanceSquared,
9
+ cartesian2Intersection,
10
+ getCartesianBearing,
11
+ getMidPoint,
12
+ } from '../math.js';
13
+ import { getClosestPointOn2DLine } from './editorHelpers.js';
14
+ import VectorLayer from '../../layer/vectorLayer.js';
15
+ import {
16
+ alreadyTransformedToImage,
17
+ alreadyTransformedToMercator,
18
+ doNotTransform,
19
+ } from '../../layer/vectorSymbols.js';
20
+ import { blackColor } from '../../style/styleHelpers.js';
21
+ import { PrimitiveOptionsType } from '../../layer/vectorProperties.js';
22
+ import { isRelativeHeightReference } from '../featureconverter/vectorHeightInfo.js';
23
+
24
+ export const snapTypes = ['orthogonal', 'parallel', 'vertex', 'edge'] as const;
25
+
26
+ export type SnapType = (typeof snapTypes)[number];
27
+
28
+ export type SnapResult<T extends SnapType = SnapType> = T extends 'orthogonal'
29
+ ? {
30
+ type: T;
31
+ snapped: Coordinate;
32
+ otherVertexIndex: number;
33
+ }
34
+ : T extends 'parallel'
35
+ ? {
36
+ type: T;
37
+ parallelIndex: number;
38
+ snapped: Coordinate;
39
+ otherVertexIndex: number;
40
+ }
41
+ : T extends 'vertex'
42
+ ? {
43
+ type: T;
44
+ snapped: Coordinate;
45
+ }
46
+ : T extends 'edge'
47
+ ? {
48
+ type: T;
49
+ snapped: Coordinate;
50
+ }
51
+ : never;
52
+
53
+ let scratchCartesian21 = new Cartesian2();
54
+ let scratchCartesian22 = new Cartesian2();
55
+
56
+ const orothogonalSrc =
57
+ 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABkCAYAAAA2VDb+AAACmElEQVR4Xu2a3zHFQBjFz60AFeDNGypABcaTVzqgAlSADuiACuiADtCBDpgzk525Yyb5cpNNzibOvt652f1+3/n+bbIA8IP6tWj4bRY/0UADsAIcArUEnANmkemCGHcSdBJ0EnQSrCPgKuAqMHMCngU8DHka9DjsVtitsFtht8JuhWsIeBaYeScMt8Juhd0KuxV2K+xWuJ7ANoDPOZfCqAzSdgJ4AvAK4HluMNoA+GszYdxXQCbPowuAZDRBXE49RPoASCAeANxMFUQOAAnEXaWISYVFTgA0nInyBMD3VCjkBpCqBiG8TwHCEACS3ecAmB+KXhGAfQCHAM4A7HawhOXyosP/RvtLBGD5RoggrgEcrHi6opWwCoBkdxcQxULoAiCBoLRvW6qBVeGoxMTYBwBtpxrYEa61AFEkhL4AaPdWBaFNkuRgxQmzmJUDAI1Zr5qgNhDYNjOZFrFyAVgFAkOB5bWIe4acAFI4sAOMcgLzBrtF+coNgAbtVeEQQWBV4OwgXUMAoEGM8avAsiIS4lAAaDsN3AwgMBdIh6YhAbBHeAkAyGeFIQHQdia74wYI8jAYGgAT4lugAlYDgpKsoQG0yQWP1bg9WwBRRWBjtCGxHhjl+wDOCh+BgQQguUccIwRoO0td05wga4rGAhBVA75g4bX66GssAFEekPUDEQCOrjnWDoDThgd9qW6QIwA5jC/6GQYQfCVWtPdyHM4KsAKavxPMobKin8EQKOaGVkFq+d2fYn/5ngYgd4H4AFaA2AHy7a0AuQvEB7ACxA6Qb28FyF0gPoAVIHaAfHsrQO4C8QGsALED5NtbAXIXiA9gBYgdIN/eCpC7QHwAK0DsAPn2VoDcBeIDWAFiB8i3twLkLhAf4N8r4Bch+4Nf5+N6mQAAAABJRU5ErkJggg==';
58
+
59
+ let orthogonalStyle: Style | undefined;
60
+ function getOrthogonalStyle(): Style {
61
+ if (!orthogonalStyle) {
62
+ orthogonalStyle = new Style({
63
+ image: new Icon({
64
+ src: orothogonalSrc,
65
+ scale: 0.25,
66
+ anchor: [0.5, 1],
67
+ }),
68
+ });
69
+ }
70
+ return orthogonalStyle;
71
+ }
72
+
73
+ const parallelSrc =
74
+ 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAMgAAADICAYAAACtWK6eAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEwAACxMBAJqcGAAAAd1JREFUeJzt00EKwkAQRcFEPGyOpKfVE/iyiDIzWLVv+DS8bQMAAAAAAAAAAAAAAAAAAAAAAAAAAID/so8esIDj4v3jKys+m33f0gRy7nXx/tc/nn3f0m6jB8DMBAJBIBAEAkEgEAQCQSAQBAJBIBAEAkEgEAQCQSAQBAJBIBAEAkEgEAQCQSAQBAJBIBAEAkEgEAQCQSAQBAJBIBAEAkEgEAQCQSAQBAJBIBAEAkEgEAQCQSAQBAJBIBAEAkEgEAQCQSAQBAJBIBAEAkEgEAQCQSAQBAJBIBAEAkEgEAQCQSAQBAJBIBAEAkEgEAQCQSAQBAJBIBAEAkEgEAQCQSAQBAJBIBAEAkEgEAQCQSAQBAJBIBAEAkEgEAQCQSAQBAJBIBAEAkEgEAQCQSAQBAJBIBAEAkEgEAQCQSAQBAJBIBAEAkEgEAQCQSAQBAJBIBAEAkEgEAQCQSAQBAJBIBAEAkEgEAQCQSAQBAJBIBAEAkEgEAQCQSAQBAJBIBAEAkEgEAQCQSAQBAJBIBAEAkEgEAQCQSAQBAJBIBAEAkEgEAQCQSAQBAJBIBAEAkEgEAQCQSAQBAJBIBDuowcs4Dl6wInZ9wEAAAAAAAAAAAAAAAAAAAAAAAAAAAALeQNcNQZTV+qErgAAAABJRU5ErkJggg==';
75
+
76
+ let parallelStyle: Style | undefined;
77
+ function getParallelStyle(): Style {
78
+ if (!parallelStyle) {
79
+ parallelStyle = new Style({
80
+ image: new Icon({
81
+ src: parallelSrc,
82
+ scale: 0.1,
83
+ anchor: [0.5, 1],
84
+ }),
85
+ });
86
+ }
87
+ return parallelStyle;
88
+ }
89
+
90
+ let vertexStyle: Style | undefined;
91
+ function getVertexStyle(): Style {
92
+ if (!vertexStyle) {
93
+ vertexStyle = new Style({
94
+ image: new RegularShape({
95
+ radius: 6,
96
+ points: 4,
97
+ fill: new Fill({
98
+ color: [255, 255, 255, 0.4],
99
+ }),
100
+ stroke: new Stroke({
101
+ color: blackColor,
102
+ width: 1,
103
+ }),
104
+ }),
105
+ });
106
+ }
107
+ return vertexStyle;
108
+ }
109
+
110
+ const FIVE_DEGREES = CesiumMath.toRadians(5);
111
+
112
+ function getClosestOrthogonal(
113
+ start: Coordinate,
114
+ end: Coordinate,
115
+ point: Coordinate,
116
+ ): Coordinate {
117
+ scratchCartesian21 = Cartesian2.fromElements(
118
+ end[0] - start[0],
119
+ end[1] - start[1],
120
+ scratchCartesian21,
121
+ ); // segment;
122
+ const matrix = Matrix2.fromArray([0, 1, -1, 0]);
123
+ scratchCartesian22 = Matrix2.multiplyByVector(
124
+ matrix,
125
+ scratchCartesian21,
126
+ scratchCartesian22,
127
+ );
128
+ scratchCartesian22 = Cartesian2.normalize(
129
+ scratchCartesian22,
130
+ scratchCartesian22,
131
+ );
132
+ scratchCartesian22 = Cartesian2.multiplyByScalar(
133
+ scratchCartesian22,
134
+ 0.0001,
135
+ scratchCartesian22,
136
+ );
137
+
138
+ const newSegment = [
139
+ scratchCartesian22.x + end[0],
140
+ scratchCartesian22.y + end[1],
141
+ point[2],
142
+ ];
143
+ return getClosestPointOn2DLine(end, newSegment, point);
144
+ }
145
+
146
+ function findClosestOrthogonalOrLinear(
147
+ start: Coordinate,
148
+ end: Coordinate,
149
+ point: Coordinate,
150
+ ): Coordinate {
151
+ const c1 = getClosestPointOn2DLine(start, end, point);
152
+ const c2 = getClosestOrthogonal(start, end, point);
153
+ const d1 = cartesian2DDistanceSquared(c1, point);
154
+ const d2 = cartesian2DDistanceSquared(c2, point);
155
+ if (d1 > d2) {
156
+ return c2;
157
+ }
158
+ return c1;
159
+ }
160
+
161
+ /**
162
+ * projects the point onto the imaginary line from origin in direction theta
163
+ * @param origin
164
+ * @param point
165
+ * @param theta - direction from north in radians
166
+ * @returns
167
+ */
168
+ function getClosestInDirection(
169
+ origin: Coordinate,
170
+ point: Coordinate,
171
+ theta: number,
172
+ ): Coordinate {
173
+ let alpha = theta + CesiumMath.PI_OVER_TWO;
174
+ alpha = alpha > CesiumMath.TWO_PI ? alpha - CesiumMath.TWO_PI : alpha;
175
+ const unityP1 = [
176
+ origin[0] + 100 * Math.cos(alpha),
177
+ origin[1] - 100 * Math.sin(alpha),
178
+ origin[2],
179
+ ];
180
+
181
+ return getClosestPointOn2DLine(origin, unityP1, point);
182
+ }
183
+
184
+ function getOrthogonalSnapResult(
185
+ coordinate: Coordinate,
186
+ p1: Coordinate,
187
+ p2: Coordinate,
188
+ otherVertexIndex: number,
189
+ ): SnapResult<'orthogonal'> | undefined {
190
+ const currentBearing = getCartesianBearing(p1, coordinate);
191
+ const previousBearing = getCartesianBearing(p2, p1);
192
+ const previousBearingDiff = Math.abs(previousBearing - currentBearing);
193
+ if (
194
+ previousBearingDiff < FIVE_DEGREES || // 5
195
+ (previousBearingDiff > CesiumMath.PI_OVER_TWO - FIVE_DEGREES &&
196
+ previousBearingDiff < CesiumMath.PI_OVER_TWO + FIVE_DEGREES) || // 90 +/- 5
197
+ (previousBearingDiff > CesiumMath.PI - FIVE_DEGREES &&
198
+ previousBearingDiff < CesiumMath.PI + FIVE_DEGREES) || // 180 +/- 5
199
+ (previousBearingDiff > CesiumMath.THREE_PI_OVER_TWO - FIVE_DEGREES &&
200
+ previousBearingDiff < CesiumMath.THREE_PI_OVER_TWO + FIVE_DEGREES) || // 280 +/- 5
201
+ previousBearingDiff > CesiumMath.TWO_PI - FIVE_DEGREES // 360 - 5
202
+ ) {
203
+ const snapped = findClosestOrthogonalOrLinear(p2, p1, coordinate);
204
+
205
+ return {
206
+ type: 'orthogonal',
207
+ snapped,
208
+ otherVertexIndex,
209
+ };
210
+ }
211
+
212
+ return undefined;
213
+ }
214
+
215
+ function getParallelSnapResult(
216
+ coordinate: Coordinate,
217
+ p1: Coordinate,
218
+ geometryBearings: number[],
219
+ otherVertexIndex: number,
220
+ ): SnapResult<'parallel'> | undefined {
221
+ const currentBearing = getCartesianBearing(p1, coordinate);
222
+ const bearingsLength = geometryBearings.length;
223
+ for (let parallelIndex = 0; parallelIndex < bearingsLength; parallelIndex++) {
224
+ const bearing = geometryBearings[parallelIndex];
225
+ if (bearing >= 0) {
226
+ const bearingDiff = Math.abs(bearing - currentBearing);
227
+ if (
228
+ bearingDiff < FIVE_DEGREES || // 5
229
+ (bearingDiff > CesiumMath.PI - FIVE_DEGREES &&
230
+ bearingDiff < CesiumMath.PI + FIVE_DEGREES) || // 180 +/- 5
231
+ bearingDiff > CesiumMath.TWO_PI - FIVE_DEGREES // 360 - 5
232
+ ) {
233
+ const snapped = getClosestInDirection(p1, coordinate, bearing);
234
+ return {
235
+ type: 'parallel',
236
+ snapped,
237
+ otherVertexIndex,
238
+ parallelIndex,
239
+ };
240
+ }
241
+ }
242
+ }
243
+
244
+ return undefined;
245
+ }
246
+
247
+ /**
248
+ * Try to create an orthogonal for p2 - p1 - coordinate. otherwise snaps p1 - coordinate to any of the given geometry bearings
249
+ * @param coordinate
250
+ * @param p1
251
+ * @param p2
252
+ * @param geometryBearings
253
+ * @param otherVertexIndex
254
+ * @param maxDistanceSquared
255
+ * @param snapOrthogonal
256
+ * @param snapParallel
257
+ */
258
+ export function getAngleSnapResult(
259
+ coordinate: Coordinate,
260
+ p1: Coordinate,
261
+ p2: Coordinate,
262
+ geometryBearings: number[],
263
+ otherVertexIndex: number,
264
+ maxDistanceSquared: number,
265
+ snapOrthogonal = true,
266
+ snapParallel = true,
267
+ ): SnapResult<'orthogonal' | 'parallel'> | undefined {
268
+ let snapResult: SnapResult<'orthogonal' | 'parallel'> | undefined =
269
+ snapOrthogonal
270
+ ? getOrthogonalSnapResult(coordinate, p1, p2, otherVertexIndex)
271
+ : undefined;
272
+
273
+ if (!snapResult && snapParallel) {
274
+ snapResult = getParallelSnapResult(
275
+ coordinate,
276
+ p1,
277
+ geometryBearings,
278
+ otherVertexIndex,
279
+ );
280
+ }
281
+
282
+ if (
283
+ snapResult?.snapped &&
284
+ cartesian2DDistanceSquared(snapResult.snapped, coordinate) <=
285
+ maxDistanceSquared
286
+ ) {
287
+ return snapResult;
288
+ }
289
+ return undefined;
290
+ }
291
+
292
+ /**
293
+ * Snaps to the vertices of the provided geometries, otherwise tries to snap to the edges.
294
+ * @param geometries
295
+ * @param coordinate
296
+ * @param maxDistanceSquared
297
+ * @param snapToVertex
298
+ * @param snapToEdge
299
+ */
300
+ export function getGeometrySnapResult(
301
+ geometries: Geometry[],
302
+ coordinate: Coordinate,
303
+ maxDistanceSquared: number,
304
+ snapToVertex = true,
305
+ snapToEdge = true,
306
+ ): SnapResult<'edge' | 'vertex'> | undefined {
307
+ let distanceSquared = Infinity;
308
+ let result: SnapResult<'vertex' | 'edge'> | undefined;
309
+
310
+ if (snapToVertex) {
311
+ geometries.forEach((geometry) => {
312
+ const coordinates = geometry.getFlatCoordinates();
313
+ const stride = geometry.getStride();
314
+
315
+ const { length } = coordinates;
316
+ for (let i = 0; i < length; i += stride) {
317
+ const vertex = [coordinates[i], coordinates[i + 1]];
318
+ if (stride > 2) {
319
+ vertex[2] = coordinates[i + 2];
320
+ }
321
+ const currentDistanceSquared = cartesian2DDistanceSquared(
322
+ vertex,
323
+ coordinate,
324
+ );
325
+
326
+ if (
327
+ currentDistanceSquared < distanceSquared &&
328
+ currentDistanceSquared <= maxDistanceSquared
329
+ ) {
330
+ distanceSquared = currentDistanceSquared;
331
+ if (!result) {
332
+ result = {
333
+ type: 'vertex',
334
+ snapped: vertex,
335
+ };
336
+ } else {
337
+ result.type = 'vertex';
338
+ result.snapped = vertex;
339
+ }
340
+ }
341
+ }
342
+ });
343
+ }
344
+
345
+ if (!result && snapToEdge) {
346
+ distanceSquared = Infinity;
347
+ geometries.forEach((geometry) => {
348
+ const closestPoint = geometry.getClosestPoint(coordinate);
349
+ const currentDistanceSquared = cartesian2DDistanceSquared(
350
+ closestPoint,
351
+ coordinate,
352
+ );
353
+
354
+ if (
355
+ currentDistanceSquared < distanceSquared &&
356
+ currentDistanceSquared <= maxDistanceSquared
357
+ ) {
358
+ distanceSquared = currentDistanceSquared;
359
+ if (!result) {
360
+ result = {
361
+ type: 'edge',
362
+ snapped: closestPoint,
363
+ };
364
+ } else {
365
+ result.type = 'edge';
366
+ result.snapped = closestPoint;
367
+ }
368
+ }
369
+ });
370
+ }
371
+
372
+ return result;
373
+ }
374
+
375
+ export function setSnappingFeatures(
376
+ results: (SnapResult | undefined)[],
377
+ coordinates: Coordinate[],
378
+ layer: VectorLayer,
379
+ ): () => void {
380
+ const features = results
381
+ .map((result) => {
382
+ let feature: Feature | undefined;
383
+ if (result?.type === 'orthogonal' && result.otherVertexIndex > -1) {
384
+ feature = new Feature({
385
+ geometry: new Point(coordinates[result.otherVertexIndex]),
386
+ });
387
+ feature.setStyle(getOrthogonalStyle);
388
+ } else if (result?.type === 'parallel' && result.parallelIndex > -1) {
389
+ const { parallelIndex } = result;
390
+ const other =
391
+ parallelIndex !== coordinates.length - 1 ? parallelIndex + 1 : 0;
392
+ const midPoint = getMidPoint(
393
+ coordinates[parallelIndex],
394
+ coordinates[other],
395
+ );
396
+ feature = new Feature({
397
+ geometry: new Point(midPoint),
398
+ });
399
+ feature.setStyle(getParallelStyle());
400
+ } else if (result?.type === 'vertex') {
401
+ feature = new Feature({
402
+ geometry: new Point(result.snapped),
403
+ olcs_allowPicking: false,
404
+ olcs_primitiveOptions: {
405
+ type: PrimitiveOptionsType.BOX,
406
+ geometryOptions: {
407
+ minimum: [-3, -3, -3],
408
+ maximum: [3, 3, 3],
409
+ },
410
+ depthFailColor: 'rgba(150,147,147,0.47)',
411
+ },
412
+ olcs_modelAutoScale: true,
413
+ });
414
+ feature.setStyle(getVertexStyle());
415
+ } else if (result?.type === 'edge') {
416
+ feature = new Feature({
417
+ geometry: new Point(result.snapped),
418
+ olcs_allowPicking: false,
419
+ olcs_primitiveOptions: {
420
+ type: PrimitiveOptionsType.SPHERE,
421
+ geometryOptions: {
422
+ radius: 3,
423
+ },
424
+ depthFailColor: 'rgba(150,147,147,0.47)',
425
+ },
426
+ olcs_modelAutoScale: true,
427
+ });
428
+ }
429
+
430
+ if (feature) {
431
+ const geometry = feature.getGeometry()!;
432
+ geometry[alreadyTransformedToImage] = true;
433
+ geometry[alreadyTransformedToMercator] = true;
434
+ feature[doNotTransform] = true;
435
+ }
436
+ return feature;
437
+ })
438
+ .filter((f): f is Feature => !!f);
439
+
440
+ if (isRelativeHeightReference(layer.vectorProperties.altitudeMode)) {
441
+ features.forEach((feature) => {
442
+ feature.set('olcs_altitudeMode', 'absolute');
443
+ });
444
+ }
445
+ layer.addFeatures(features);
446
+ return () => {
447
+ layer.removeFeaturesById(features.map((f) => f.getId()!));
448
+ };
449
+ }
450
+
451
+ export function getSnappedCoordinateForResults(
452
+ results: (SnapResult | undefined)[],
453
+ coordinates: Coordinate[],
454
+ maxDistanceSquared: number,
455
+ ): Coordinate | undefined {
456
+ const snapped0 = results[0]?.snapped;
457
+ const snapped1 = results[1]?.snapped;
458
+
459
+ if (
460
+ snapped0 &&
461
+ snapped1 &&
462
+ (results[0]!.type === 'orthogonal' || results[0]!.type === 'parallel') &&
463
+ (results[1]!.type === 'orthogonal' || results[1]!.type === 'parallel')
464
+ ) {
465
+ const other0 = coordinates[results[0]!.otherVertexIndex];
466
+ const other1 = coordinates[results[1]!.otherVertexIndex];
467
+ if (other0 && other1) {
468
+ const intersection = cartesian2Intersection(
469
+ [snapped0, other0],
470
+ [snapped1, other1],
471
+ );
472
+ if (
473
+ intersection &&
474
+ cartesian2DDistanceSquared(intersection, snapped0) <= maxDistanceSquared
475
+ ) {
476
+ return [intersection[0], intersection[1], snapped0[2]];
477
+ }
478
+ }
479
+ }
480
+
481
+ if (snapped1) {
482
+ return snapped1;
483
+ }
484
+
485
+ if (snapped0) {
486
+ return snapped0;
487
+ }
488
+
489
+ return undefined;
490
+ }
@@ -30,16 +30,16 @@ function createAxisPositions(
30
30
  ): Coordinate[] {
31
31
  if (axis === AxisAndPlanes.X) {
32
32
  return [
33
- [extent[0], center[1], center[2]],
34
- [center[0], center[1], center[2]],
35
- [extent[2], center[1], center[2]],
33
+ [extent[0], center[1]],
34
+ [center[0], center[1]],
35
+ [extent[2], center[1]],
36
36
  ];
37
37
  }
38
38
 
39
39
  return [
40
- [center[0], extent[1], center[2]],
41
- [center[0], center[1], center[2]],
42
- [center[0], extent[3], center[2]],
40
+ [center[0], extent[1]],
41
+ [center[0], center[1]],
42
+ [center[0], extent[3]],
43
43
  ];
44
44
  }
45
45
 
@@ -122,15 +122,15 @@ function createLineAxisFeatures(
122
122
  if (axis === AxisAndPlanes.X) {
123
123
  color = Color.RED.toCssColorString();
124
124
  coordinates = [
125
- [0, 0, 0],
126
- [1, 0, 0],
125
+ [0, 0],
126
+ [1, 0],
127
127
  ];
128
128
  rotation = Math.PI / 2;
129
129
  } else {
130
130
  color = Color.GREEN.toCssColorString();
131
131
  coordinates = [
132
- [0, 0, 0],
133
- [0, 1, 0],
132
+ [0, 0],
133
+ [0, 1],
134
134
  ];
135
135
  }
136
136
  color = colorOverride ?? color;
@@ -176,11 +176,11 @@ function createPlaneFeature(colorOverride?: string): Feature<Polygon> {
176
176
  const feature = new Feature({
177
177
  geometry: new Polygon([
178
178
  [
179
- [0.2, 0.2, 0],
180
- [0.2, 0.4, 0],
181
- [0.4, 0.4, 0],
182
- [0.4, 0.2, 0],
183
- [0.2, 0.2, 0],
179
+ [0.2, 0.2],
180
+ [0.2, 0.4],
181
+ [0.4, 0.4],
182
+ [0.4, 0.2],
183
+ [0.2, 0.2],
184
184
  ],
185
185
  ]),
186
186
  axis: AxisAndPlanes.XY,
@@ -220,12 +220,15 @@ function createShowShadowFeatures(
220
220
  }
221
221
  features.forEach((f) => {
222
222
  f.getGeometry()!.applyTransform(
223
- (input: number[], output: number[] | undefined): number[] => {
223
+ (
224
+ input: number[],
225
+ output: number[] | undefined,
226
+ stride = 2,
227
+ ): number[] => {
224
228
  const inputLength = input.length;
225
- for (let i = 0; i < inputLength; i += 3) {
229
+ for (let i = 0; i < inputLength; i += stride) {
226
230
  output![i] = input[i] * scale + center[0];
227
231
  output![i + 1] = input[i + 1] * scale + center[1];
228
- output![i + 2] = 0;
229
232
  }
230
233
  return output as number[];
231
234
  },
@@ -249,7 +252,7 @@ export default function create2DHandlers(
249
252
  scratchLayer: VectorLayer,
250
253
  mode: TransformationMode,
251
254
  ): Handlers {
252
- let center = [0, 0, 0];
255
+ let center = [0, 0];
253
256
  let scale = 1;
254
257
  let features: Feature[] = [];
255
258
  if (
@@ -283,19 +286,22 @@ export default function create2DHandlers(
283
286
  });
284
287
 
285
288
  const postRenderListenerKey = map.olMap!.on('postrender', () => {
286
- if (!(center[0] === 0 && center[1] === 0 && center[2] === 0)) {
289
+ if (!(center[0] === 0 && center[1] === 0)) {
287
290
  const res = map.getCurrentResolution(center) * 60;
288
291
  const factor = res / scale;
289
292
  if (factor !== 1) {
290
293
  features.forEach((f) => {
291
294
  f.getGeometry()!.applyTransform(
292
- (input: number[], output: number[] | undefined): number[] => {
295
+ (
296
+ input: number[],
297
+ output: number[] | undefined,
298
+ stride = 2,
299
+ ): number[] => {
293
300
  const inputLength = input.length;
294
- for (let i = 0; i < inputLength; i += 3) {
301
+ for (let i = 0; i < inputLength; i += stride) {
295
302
  output![i] = (input[i] - center[0]) * factor + center[0];
296
303
  output![i + 1] =
297
304
  (input[i + 1] - center[1]) * factor + center[1];
298
- output![i + 2] = 0;
299
305
  }
300
306
  return output as number[];
301
307
  },
@@ -343,12 +349,18 @@ export default function create2DHandlers(
343
349
  const dy = newCenter[1] - center[1];
344
350
  features.forEach((f) => {
345
351
  f.getGeometry()!.applyTransform(
346
- (input: number[], output: number[] | undefined): number[] => {
352
+ (
353
+ input: number[],
354
+ output: number[] | undefined,
355
+ stride = 2,
356
+ ): number[] => {
347
357
  const inputLength = input.length;
348
- for (let i = 0; i < inputLength; i += 3) {
358
+ for (let i = 0; i < inputLength; i += stride) {
349
359
  output![i] = input[i] + dx;
350
360
  output![i + 1] = input[i + 1] + dy;
351
- output![i + 2] = input[i + 2];
361
+ if (stride > 2) {
362
+ output![i + 2] = input[i + 2];
363
+ }
352
364
  }
353
365
  return output as number[];
354
366
  },