@vcmap/core 6.0.0-rc.4 → 6.0.0-rc.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (209) hide show
  1. package/dist/cesium.d.ts +11 -0
  2. package/dist/index.d.ts +23 -16
  3. package/dist/index.js +21 -14
  4. package/dist/index.js.map +1 -1
  5. package/dist/ol.d.ts +15 -2
  6. package/dist/src/layer/cesium/clusterContext.d.ts +8 -14
  7. package/dist/src/layer/cesium/clusterContext.js +62 -41
  8. package/dist/src/layer/cesium/clusterContext.js.map +1 -1
  9. package/dist/src/layer/cesium/vectorCesiumImpl.d.ts +2 -3
  10. package/dist/src/layer/cesium/vectorCesiumImpl.js +16 -10
  11. package/dist/src/layer/cesium/vectorCesiumImpl.js.map +1 -1
  12. package/dist/src/layer/cesium/vectorContext.d.ts +10 -53
  13. package/dist/src/layer/cesium/vectorContext.js +88 -172
  14. package/dist/src/layer/cesium/vectorContext.js.map +1 -1
  15. package/dist/src/layer/geojsonHelpers.d.ts +1 -1
  16. package/dist/src/layer/geojsonHelpers.js +5 -10
  17. package/dist/src/layer/geojsonHelpers.js.map +1 -1
  18. package/dist/src/layer/oblique/obliqueHelpers.js +6 -6
  19. package/dist/src/layer/oblique/obliqueHelpers.js.map +1 -1
  20. package/dist/src/layer/vectorLayer.d.ts +0 -37
  21. package/dist/src/layer/vectorLayer.js.map +1 -1
  22. package/dist/src/layer/vectorProperties.d.ts +8 -3
  23. package/dist/src/layer/vectorProperties.js +30 -5
  24. package/dist/src/layer/vectorProperties.js.map +1 -1
  25. package/dist/src/map/baseOLMap.js +1 -1
  26. package/dist/src/map/baseOLMap.js.map +1 -1
  27. package/dist/src/map/obliqueMap.d.ts +3 -0
  28. package/dist/src/map/obliqueMap.js +27 -6
  29. package/dist/src/map/obliqueMap.js.map +1 -1
  30. package/dist/src/map/vcsMap.d.ts +8 -0
  31. package/dist/src/map/vcsMap.js +11 -0
  32. package/dist/src/map/vcsMap.js.map +1 -1
  33. package/dist/src/oblique/helpers.js +5 -5
  34. package/dist/src/oblique/helpers.js.map +1 -1
  35. package/dist/src/oblique/obliqueDataSet.js +4 -4
  36. package/dist/src/oblique/obliqueDataSet.js.map +1 -1
  37. package/dist/src/ol/geom/geometryCollection.js +19 -2
  38. package/dist/src/ol/geom/geometryCollection.js.map +1 -1
  39. package/dist/src/style/arcStyle.js +1 -0
  40. package/dist/src/style/arcStyle.js.map +1 -1
  41. package/dist/src/util/editor/createFeatureSession.d.ts +5 -1
  42. package/dist/src/util/editor/createFeatureSession.js +48 -4
  43. package/dist/src/util/editor/createFeatureSession.js.map +1 -1
  44. package/dist/src/util/editor/editFeaturesSession.d.ts +10 -4
  45. package/dist/src/util/editor/editFeaturesSession.js +74 -37
  46. package/dist/src/util/editor/editFeaturesSession.js.map +1 -1
  47. package/dist/src/util/editor/editGeometrySession.d.ts +5 -1
  48. package/dist/src/util/editor/editGeometrySession.js +77 -55
  49. package/dist/src/util/editor/editGeometrySession.js.map +1 -1
  50. package/dist/src/util/editor/editorHelpers.d.ts +12 -6
  51. package/dist/src/util/editor/editorHelpers.js +47 -20
  52. package/dist/src/util/editor/editorHelpers.js.map +1 -1
  53. package/dist/src/util/editor/editorSessionHelpers.d.ts +5 -0
  54. package/dist/src/util/editor/editorSessionHelpers.js +1 -0
  55. package/dist/src/util/editor/editorSessionHelpers.js.map +1 -1
  56. package/dist/src/util/editor/editorSymbols.d.ts +1 -1
  57. package/dist/src/util/editor/editorSymbols.js +1 -1
  58. package/dist/src/util/editor/editorSymbols.js.map +1 -1
  59. package/dist/src/util/editor/interactions/createBBoxInteraction.d.ts +1 -0
  60. package/dist/src/util/editor/interactions/createBBoxInteraction.js +20 -16
  61. package/dist/src/util/editor/interactions/createBBoxInteraction.js.map +1 -1
  62. package/dist/src/util/editor/interactions/createCircleInteraction.js +1 -1
  63. package/dist/src/util/editor/interactions/createCircleInteraction.js.map +1 -1
  64. package/dist/src/util/editor/interactions/createLineStringInteraction.js +3 -3
  65. package/dist/src/util/editor/interactions/createLineStringInteraction.js.map +1 -1
  66. package/dist/src/util/editor/interactions/createPointInteraction.js +1 -1
  67. package/dist/src/util/editor/interactions/createPointInteraction.js.map +1 -1
  68. package/dist/src/util/editor/interactions/createPolygonInteraction.d.ts +4 -0
  69. package/dist/src/util/editor/interactions/createPolygonInteraction.js +9 -3
  70. package/dist/src/util/editor/interactions/createPolygonInteraction.js.map +1 -1
  71. package/dist/src/util/editor/interactions/creationSnapping.d.ts +26 -0
  72. package/dist/src/util/editor/interactions/creationSnapping.js +139 -0
  73. package/dist/src/util/editor/interactions/creationSnapping.js.map +1 -0
  74. package/dist/src/util/editor/interactions/editGeometryMouseOverInteraction.js +3 -2
  75. package/dist/src/util/editor/interactions/editGeometryMouseOverInteraction.js.map +1 -1
  76. package/dist/src/util/editor/interactions/insertVertexInteraction.d.ts +3 -1
  77. package/dist/src/util/editor/interactions/insertVertexInteraction.js +14 -6
  78. package/dist/src/util/editor/interactions/insertVertexInteraction.js.map +1 -1
  79. package/dist/src/util/editor/interactions/layerSnapping.d.ts +19 -0
  80. package/dist/src/util/editor/interactions/layerSnapping.js +87 -0
  81. package/dist/src/util/editor/interactions/layerSnapping.js.map +1 -0
  82. package/dist/src/util/editor/interactions/translateVertexInteraction.js +2 -2
  83. package/dist/src/util/editor/interactions/translateVertexInteraction.js.map +1 -1
  84. package/dist/src/util/editor/interactions/translationSnapping.d.ts +25 -0
  85. package/dist/src/util/editor/interactions/translationSnapping.js +179 -0
  86. package/dist/src/util/editor/interactions/translationSnapping.js.map +1 -0
  87. package/dist/src/util/editor/snappingHelpers.d.ts +44 -0
  88. package/dist/src/util/editor/snappingHelpers.js +329 -0
  89. package/dist/src/util/editor/snappingHelpers.js.map +1 -0
  90. package/dist/src/util/editor/transformation/create2DHandlers.js +26 -26
  91. package/dist/src/util/editor/transformation/create2DHandlers.js.map +1 -1
  92. package/dist/src/util/editor/transformation/create3DHandlers.js +65 -14
  93. package/dist/src/util/editor/transformation/create3DHandlers.js.map +1 -1
  94. package/dist/src/util/editor/transformation/scaleInteraction.js +27 -5
  95. package/dist/src/util/editor/transformation/scaleInteraction.js.map +1 -1
  96. package/dist/src/util/editor/transformation/transformationHandler.js +56 -38
  97. package/dist/src/util/editor/transformation/transformationHandler.js.map +1 -1
  98. package/dist/src/util/editor/transformation/transformationTypes.d.ts +2 -0
  99. package/dist/src/util/editor/transformation/transformationTypes.js +4 -0
  100. package/dist/src/util/editor/transformation/transformationTypes.js.map +1 -1
  101. package/dist/src/util/featureconverter/arcToCesium.d.ts +5 -19
  102. package/dist/src/util/featureconverter/arcToCesium.js +15 -42
  103. package/dist/src/util/featureconverter/arcToCesium.js.map +1 -1
  104. package/dist/src/util/featureconverter/circleToCesium.d.ts +2 -27
  105. package/dist/src/util/featureconverter/circleToCesium.js +84 -63
  106. package/dist/src/util/featureconverter/circleToCesium.js.map +1 -1
  107. package/dist/src/util/featureconverter/clampedPrimitive.d.ts +2 -0
  108. package/dist/src/util/featureconverter/clampedPrimitive.js +29 -0
  109. package/dist/src/util/featureconverter/clampedPrimitive.js.map +1 -0
  110. package/dist/src/util/featureconverter/convert.d.ts +26 -7
  111. package/dist/src/util/featureconverter/convert.js +221 -44
  112. package/dist/src/util/featureconverter/convert.js.map +1 -1
  113. package/dist/src/util/featureconverter/extent3D.d.ts +4 -3
  114. package/dist/src/util/featureconverter/extent3D.js +4 -3
  115. package/dist/src/util/featureconverter/extent3D.js.map +1 -1
  116. package/dist/src/util/featureconverter/lineStringToCesium.d.ts +12 -27
  117. package/dist/src/util/featureconverter/lineStringToCesium.js +85 -107
  118. package/dist/src/util/featureconverter/lineStringToCesium.js.map +1 -1
  119. package/dist/src/util/featureconverter/pointHelpers.d.ts +8 -11
  120. package/dist/src/util/featureconverter/pointHelpers.js +134 -120
  121. package/dist/src/util/featureconverter/pointHelpers.js.map +1 -1
  122. package/dist/src/util/featureconverter/pointToCesium.d.ts +14 -17
  123. package/dist/src/util/featureconverter/pointToCesium.js +47 -96
  124. package/dist/src/util/featureconverter/pointToCesium.js.map +1 -1
  125. package/dist/src/util/featureconverter/polygonToCesium.d.ts +2 -26
  126. package/dist/src/util/featureconverter/polygonToCesium.js +62 -72
  127. package/dist/src/util/featureconverter/polygonToCesium.js.map +1 -1
  128. package/dist/src/util/featureconverter/storeyHelpers.d.ts +17 -0
  129. package/dist/src/util/featureconverter/storeyHelpers.js +78 -0
  130. package/dist/src/util/featureconverter/storeyHelpers.js.map +1 -0
  131. package/dist/src/util/featureconverter/vectorGeometryFactory.d.ts +54 -0
  132. package/dist/src/util/featureconverter/vectorGeometryFactory.js +278 -0
  133. package/dist/src/util/featureconverter/vectorGeometryFactory.js.map +1 -0
  134. package/dist/src/util/featureconverter/vectorHeightInfo.d.ts +86 -0
  135. package/dist/src/util/featureconverter/vectorHeightInfo.js +242 -0
  136. package/dist/src/util/featureconverter/vectorHeightInfo.js.map +1 -0
  137. package/dist/src/util/geometryHelpers.d.ts +22 -1
  138. package/dist/src/util/geometryHelpers.js +65 -2
  139. package/dist/src/util/geometryHelpers.js.map +1 -1
  140. package/dist/src/util/mapCollection.js +8 -0
  141. package/dist/src/util/mapCollection.js.map +1 -1
  142. package/dist/src/util/math.d.ts +6 -2
  143. package/dist/src/util/math.js +34 -12
  144. package/dist/src/util/math.js.map +1 -1
  145. package/dist/tests/unit/helpers/cesiumHelpers.js +3 -1
  146. package/dist/tests/unit/helpers/cesiumHelpers.js.map +1 -1
  147. package/dist/tests/unit/helpers/helpers.d.ts +2 -9
  148. package/dist/tests/unit/helpers/helpers.js +2 -8
  149. package/dist/tests/unit/helpers/helpers.js.map +1 -1
  150. package/index.ts +74 -35
  151. package/package.json +3 -3
  152. package/src/cesium/cesium.d.ts +11 -0
  153. package/src/layer/cesium/clusterContext.ts +82 -91
  154. package/src/layer/cesium/vectorCesiumImpl.ts +17 -11
  155. package/src/layer/cesium/vectorContext.ts +120 -348
  156. package/src/layer/geojsonHelpers.ts +9 -12
  157. package/src/layer/oblique/obliqueHelpers.ts +6 -6
  158. package/src/layer/vectorLayer.ts +0 -71
  159. package/src/layer/vectorProperties.ts +46 -9
  160. package/src/map/baseOLMap.ts +1 -1
  161. package/src/map/obliqueMap.ts +46 -6
  162. package/src/map/vcsMap.ts +20 -2
  163. package/src/oblique/helpers.ts +11 -5
  164. package/src/oblique/obliqueDataSet.ts +4 -4
  165. package/src/ol/geom/geometryCollection.js +21 -2
  166. package/src/ol/ol.d.ts +15 -2
  167. package/src/style/arcStyle.ts +1 -0
  168. package/src/util/editor/createFeatureSession.ts +64 -6
  169. package/src/util/editor/editFeaturesSession.ts +105 -39
  170. package/src/util/editor/editGeometrySession.ts +118 -75
  171. package/src/util/editor/editorHelpers.ts +78 -30
  172. package/src/util/editor/editorSessionHelpers.ts +7 -0
  173. package/src/util/editor/editorSymbols.ts +1 -1
  174. package/src/util/editor/interactions/createBBoxInteraction.ts +25 -16
  175. package/src/util/editor/interactions/createCircleInteraction.ts +1 -1
  176. package/src/util/editor/interactions/createLineStringInteraction.ts +9 -3
  177. package/src/util/editor/interactions/createPointInteraction.ts +1 -1
  178. package/src/util/editor/interactions/createPolygonInteraction.ts +16 -3
  179. package/src/util/editor/interactions/creationSnapping.ts +226 -0
  180. package/src/util/editor/interactions/editGeometryMouseOverInteraction.ts +3 -2
  181. package/src/util/editor/interactions/insertVertexInteraction.ts +27 -7
  182. package/src/util/editor/interactions/layerSnapping.ts +136 -0
  183. package/src/util/editor/interactions/translateVertexInteraction.ts +8 -2
  184. package/src/util/editor/interactions/translationSnapping.ts +302 -0
  185. package/src/util/editor/snappingHelpers.ts +490 -0
  186. package/src/util/editor/transformation/create2DHandlers.ts +38 -26
  187. package/src/util/editor/transformation/create3DHandlers.ts +84 -22
  188. package/src/util/editor/transformation/scaleInteraction.ts +28 -5
  189. package/src/util/editor/transformation/transformationHandler.ts +72 -41
  190. package/src/util/editor/transformation/transformationTypes.ts +5 -0
  191. package/src/util/featureconverter/arcToCesium.ts +25 -95
  192. package/src/util/featureconverter/circleToCesium.ts +127 -113
  193. package/src/util/featureconverter/clampedPrimitive.ts +70 -0
  194. package/src/util/featureconverter/convert.ts +446 -114
  195. package/src/util/featureconverter/extent3D.ts +13 -6
  196. package/src/util/featureconverter/lineStringToCesium.ts +132 -179
  197. package/src/util/featureconverter/pointHelpers.ts +271 -214
  198. package/src/util/featureconverter/pointToCesium.ts +111 -175
  199. package/src/util/featureconverter/polygonToCesium.ts +98 -117
  200. package/src/util/featureconverter/storeyHelpers.ts +104 -0
  201. package/src/util/featureconverter/vectorGeometryFactory.ts +601 -0
  202. package/src/util/featureconverter/vectorHeightInfo.ts +393 -0
  203. package/src/util/geometryHelpers.ts +79 -5
  204. package/src/util/mapCollection.ts +8 -0
  205. package/src/util/math.ts +59 -12
  206. package/dist/src/util/featureconverter/featureconverterHelper.d.ts +0 -35
  207. package/dist/src/util/featureconverter/featureconverterHelper.js +0 -404
  208. package/dist/src/util/featureconverter/featureconverterHelper.js.map +0 -1
  209. package/src/util/featureconverter/featureconverterHelper.ts +0 -672
@@ -1,404 +0,0 @@
1
- import { getBottomLeft } from 'ol/extent.js';
2
- import { Cartesian3, HeightReference, ColorGeometryInstanceAttribute, GeometryInstance, Material, SceneTransforms, MaterialAppearance, ClassificationType, PerInstanceColorAppearance, GroundPrimitive, GroundPolylinePrimitive, ClassificationPrimitive, ShadowMode, Primitive, Color, PolylineMaterialAppearance, } from '@vcmap-cesium/engine';
3
- import { getCesiumColor } from '../../style/styleHelpers.js';
4
- import { createSync } from '../../layer/vectorSymbols.js';
5
- export function getMaterialAppearance(scene, fill, feature) {
6
- const options = {
7
- flat: true,
8
- renderState: {
9
- depthTest: {
10
- enabled: true,
11
- },
12
- },
13
- };
14
- const fillColor = fill.getColor();
15
- if (fillColor instanceof CanvasPattern) {
16
- const canvas = document.createElement('canvas');
17
- const ctx = canvas.getContext('2d');
18
- ctx.fillStyle = fillColor;
19
- ctx.fillRect(0, 0, 300, 300);
20
- options.material = Material.fromType('Wallpaper', {
21
- image: canvas,
22
- anchor: SceneTransforms.wgs84ToDrawingBufferCoordinates(scene, Cartesian3.fromDegreesArray(getBottomLeft(feature.getGeometry().getExtent()))[0]),
23
- });
24
- }
25
- else {
26
- const color = getCesiumColor(fillColor, [0, 0, 0, 1]);
27
- options.material = Material.fromType('Color', {
28
- color,
29
- });
30
- options.translucent = color.alpha !== 1;
31
- }
32
- return new MaterialAppearance(options);
33
- }
34
- export function createClassificationPrimitive(options, geometries, color, classificationType) {
35
- const instances = geometries.map((geometry) => new GeometryInstance({
36
- geometry,
37
- attributes: {
38
- color: ColorGeometryInstanceAttribute.fromColor(color),
39
- },
40
- }));
41
- const appearance = new PerInstanceColorAppearance({
42
- flat: false,
43
- renderState: {
44
- depthTest: {
45
- enabled: true,
46
- },
47
- lineWidth: 1,
48
- },
49
- translucent: color.alpha !== 1,
50
- });
51
- const classificationPrimitiveOptions = {
52
- ...options,
53
- geometryInstances: instances,
54
- appearance,
55
- shadows: ShadowMode.ENABLED,
56
- classificationType,
57
- };
58
- return new ClassificationPrimitive(classificationPrimitiveOptions);
59
- }
60
- export function createPrimitive(scene, vectorProperties, allowPicking, feature, geometries, style, groundPrimitive) {
61
- const classificationType = vectorProperties.getClassificationType(feature);
62
- const options = {
63
- shadows: ShadowMode.ENABLED,
64
- allowPicking,
65
- asynchronous: !feature[createSync],
66
- };
67
- let primitive;
68
- if (classificationType !== undefined && !groundPrimitive) {
69
- if (!ClassificationPrimitive.isSupported(scene)) {
70
- return null;
71
- }
72
- const color = getCesiumColor(style.getFill().getColor(), // XXX PatternDescriptor
73
- [0, 0, 0, 1]);
74
- primitive = createClassificationPrimitive(options, geometries, color, classificationType);
75
- }
76
- else {
77
- const instances = geometries.map((geometry) => new GeometryInstance({
78
- geometry,
79
- }));
80
- options.geometryInstances = instances;
81
- const appearance = getMaterialAppearance(scene, style.getFill(), feature);
82
- options.appearance = appearance;
83
- if (groundPrimitive) {
84
- if (!GroundPrimitive.isSupported(scene)) {
85
- return null;
86
- }
87
- options.classificationType =
88
- classificationType || ClassificationType.TERRAIN;
89
- primitive = new GroundPrimitive(options);
90
- }
91
- else {
92
- primitive = new Primitive(options);
93
- }
94
- }
95
- return primitive;
96
- }
97
- export function createOutlinePrimitive(_scene, _vectorProperties, allowPicking, feature, geometries, style) {
98
- const color = getCesiumColor(style.getStroke().getColor(), [0, 0, 0, 1]);
99
- const instances = geometries.map((geometry) => new GeometryInstance({
100
- geometry,
101
- attributes: {
102
- color: ColorGeometryInstanceAttribute.fromColor(color),
103
- },
104
- }));
105
- const appearance = new PerInstanceColorAppearance({
106
- flat: true,
107
- renderState: {
108
- depthTest: {
109
- enabled: true,
110
- },
111
- lineWidth: 1,
112
- },
113
- translucent: color.alpha !== 1,
114
- });
115
- const options = {
116
- geometryInstances: instances,
117
- appearance,
118
- shadows: ShadowMode.ENABLED,
119
- allowPicking,
120
- asynchronous: !feature[createSync],
121
- };
122
- const primitive = new Primitive(options);
123
- return primitive;
124
- }
125
- export function createLinePrimitive(scene, vectorProperties, allowPicking, feature, geometries, style, groundPrimitive) {
126
- const classificationType = vectorProperties.getClassificationType(feature);
127
- const instances = geometries.map((geometry) => new GeometryInstance({
128
- geometry,
129
- }));
130
- const color = getCesiumColor(style.getStroke().getColor(), [0, 0, 0, 1]);
131
- let material;
132
- if (style.getStroke()?.getLineDash()) {
133
- material = Material.fromType('Stripe', {
134
- horizontal: false,
135
- repeat: 500,
136
- evenColor: color,
137
- oddColor: new Color(0, 0, 0, 0), // transparent
138
- });
139
- }
140
- else {
141
- material = Material.fromType('Color', { color });
142
- }
143
- const appearance = new PolylineMaterialAppearance({
144
- renderState: {
145
- depthTest: {
146
- enabled: true,
147
- },
148
- lineWidth: 1,
149
- },
150
- translucent: color.alpha !== 1,
151
- material,
152
- });
153
- const options = {
154
- geometryInstances: instances,
155
- appearance,
156
- shadows: ShadowMode.ENABLED,
157
- allowPicking,
158
- asynchronous: !feature[createSync],
159
- };
160
- let primitive;
161
- if (groundPrimitive) {
162
- if (!GroundPolylinePrimitive.isSupported(scene)) {
163
- return null;
164
- }
165
- options.classificationType =
166
- classificationType || ClassificationType.TERRAIN;
167
- primitive = new GroundPolylinePrimitive(options);
168
- }
169
- else {
170
- primitive = new Primitive(options);
171
- }
172
- return primitive;
173
- }
174
- /**
175
- * returns groundlevel or extracts the minimum height from the coordinates, returns 0 if no z coordinates are set
176
- * @param groundLevel
177
- * @param coordinates
178
- */
179
- export function getMinHeightOrGroundLevel(groundLevel, coordinates) {
180
- if (groundLevel != null && Number.isFinite(Number(groundLevel))) {
181
- return groundLevel;
182
- }
183
- if (coordinates) {
184
- let minimumHeight = Infinity;
185
- for (let i = 0; i < coordinates.length; i++) {
186
- minimumHeight =
187
- coordinates[i][2] < minimumHeight ? coordinates[i][2] : minimumHeight;
188
- }
189
- if (Number.isFinite(minimumHeight)) {
190
- return minimumHeight;
191
- }
192
- }
193
- return 0;
194
- }
195
- /**
196
- * @param extrudedHeight should be a number > 0
197
- * @param storeyHeights
198
- * @param storeyNumber
199
- */
200
- export function getStoreyHeights(extrudedHeight, storeyHeights, storeyNumber) {
201
- const positiveExtrudedHeight = Math.abs(extrudedHeight);
202
- const fittedStoreyHeights = [];
203
- if (storeyHeights.length) {
204
- let height = 0;
205
- for (let i = 0; i < storeyHeights.length; i++) {
206
- height += storeyHeights[i];
207
- if (height < positiveExtrudedHeight) {
208
- fittedStoreyHeights.push(storeyHeights[i]);
209
- }
210
- else {
211
- fittedStoreyHeights.push(storeyHeights[i] - (height - positiveExtrudedHeight));
212
- return fittedStoreyHeights;
213
- }
214
- }
215
- const lastStoreyHeight = storeyHeights[storeyHeights.length - 1];
216
- while (height < positiveExtrudedHeight) {
217
- height += lastStoreyHeight;
218
- if (height < positiveExtrudedHeight) {
219
- fittedStoreyHeights.push(lastStoreyHeight);
220
- }
221
- else {
222
- fittedStoreyHeights.push(lastStoreyHeight - (height - positiveExtrudedHeight));
223
- return fittedStoreyHeights;
224
- }
225
- }
226
- }
227
- else if (storeyNumber) {
228
- return new Array(storeyNumber).fill(positiveExtrudedHeight / storeyNumber);
229
- }
230
- // case no predefined storeyHeights
231
- return [positiveExtrudedHeight];
232
- }
233
- export function validateStoreys(storeys, storeyHeights) {
234
- if (storeys && storeyHeights.length) {
235
- const missingStoreyHeights = storeys - storeyHeights.length;
236
- if (missingStoreyHeights > 0) {
237
- storeyHeights.push(...new Array(missingStoreyHeights).fill(storeyHeights[storeyHeights.length - 1]));
238
- }
239
- else if (missingStoreyHeights < 0) {
240
- storeyHeights.splice(storeyHeights.length + missingStoreyHeights);
241
- }
242
- if (storeys > 100) {
243
- storeyHeights.splice(100);
244
- }
245
- }
246
- else {
247
- storeyHeights.splice(0);
248
- }
249
- }
250
- export function getHeightAboveGround(feature, heightReference, vectorProperties) {
251
- if (heightReference === HeightReference.RELATIVE_TO_GROUND) {
252
- return vectorProperties.getHeightAboveGround(feature);
253
- }
254
- return 0;
255
- }
256
- export function getHeightInfo(feature, vectorProperties, coordinates) {
257
- const extrudedHeight = vectorProperties.getExtrudedHeight(feature);
258
- let storeysAboveGround = vectorProperties.getStoreysAboveGround(feature);
259
- let storeysBelowGround = vectorProperties.getStoreysBelowGround(feature);
260
- let storeyHeightsAboveGround = vectorProperties.getStoreyHeightsAboveGround(feature);
261
- let storeyHeightsBelowGround = vectorProperties.getStoreyHeightsBelowGround(feature);
262
- if (extrudedHeight) {
263
- // current Case only extrudedHeight
264
- if (extrudedHeight > 0) {
265
- storeyHeightsAboveGround = getStoreyHeights(extrudedHeight, storeyHeightsAboveGround, storeysAboveGround);
266
- storeysAboveGround = storeyHeightsAboveGround.length;
267
- storeyHeightsBelowGround = [];
268
- storeysBelowGround = 0;
269
- }
270
- else if (extrudedHeight < 0) {
271
- storeyHeightsBelowGround = getStoreyHeights(extrudedHeight, storeyHeightsBelowGround, storeysBelowGround);
272
- storeysBelowGround = storeyHeightsBelowGround.length;
273
- storeyHeightsAboveGround = [];
274
- storeysAboveGround = 0;
275
- }
276
- }
277
- validateStoreys(storeysAboveGround, storeyHeightsAboveGround);
278
- validateStoreys(storeysBelowGround, storeyHeightsBelowGround);
279
- const skirt = vectorProperties.getSkirt(feature);
280
- const olcsGroundLevel = vectorProperties.getGroundLevel(feature);
281
- const heightReference = vectorProperties.getAltitudeMode(feature);
282
- const heightAboveGroundAdjustment = getHeightAboveGround(feature, heightReference, vectorProperties);
283
- const groundLevel = getMinHeightOrGroundLevel(olcsGroundLevel, coordinates) +
284
- heightAboveGroundAdjustment;
285
- const hasZCoordinate = !!coordinates.find((value) => value[2]);
286
- const extruded = !!(storeyHeightsAboveGround.length ||
287
- storeyHeightsBelowGround.length ||
288
- skirt);
289
- const perPositionHeight = hasZCoordinate &&
290
- olcsGroundLevel == null &&
291
- (!extruded ||
292
- (extruded &&
293
- storeyHeightsAboveGround.length + storeyHeightsBelowGround.length ===
294
- 1));
295
- return {
296
- extruded,
297
- storeyHeightsAboveGround,
298
- storeyHeightsBelowGround,
299
- skirt,
300
- groundLevel,
301
- perPositionHeight,
302
- heightReference,
303
- heightAboveGroundAdjustment,
304
- };
305
- }
306
- export function getStoreyOptions(storeyHeights, initialHeight, down, result) {
307
- const direction = down ? -1 : 1;
308
- let currentHeight = initialHeight;
309
- const storeys = storeyHeights.length;
310
- const options = new Array(storeys);
311
- for (let i = 0; i < storeys; i++) {
312
- const extrudedHeight = currentHeight + direction * storeyHeights[i];
313
- options[i] = {
314
- currentHeight,
315
- extrudedHeight,
316
- };
317
- currentHeight = extrudedHeight;
318
- }
319
- if (result) {
320
- result.push(...options);
321
- return result;
322
- }
323
- return options;
324
- }
325
- export function addPrimitivesToContext(feature, style, geometries, vectorProperties, scene, geometryFactory, context) {
326
- // no geometries, so early escape
327
- if (!geometries.length) {
328
- return;
329
- }
330
- const fillGeometries = [];
331
- const outlineGeometries = [];
332
- const lineGeometries = [];
333
- const heightInfo = getHeightInfo(feature, vectorProperties, geometryFactory.getCoordinates(geometries));
334
- const hasFill = !!style.getFill();
335
- const hasStroke = !!style.getStroke();
336
- let groundPrimitive = false;
337
- geometries.forEach((geometry) => {
338
- const geometryOptions = geometryFactory.getGeometryOptions(geometry, heightInfo.heightAboveGroundAdjustment, heightInfo.perPositionHeight, heightInfo.groundLevel);
339
- const storeyOptions = getStoreyOptions(heightInfo.storeyHeightsAboveGround, heightInfo.groundLevel);
340
- getStoreyOptions(heightInfo.storeyHeightsBelowGround, heightInfo.groundLevel, true, storeyOptions);
341
- if (hasFill) {
342
- storeyOptions.forEach((options) => {
343
- fillGeometries.push(...geometryFactory.createSolidGeometries(geometryOptions, options.currentHeight, heightInfo.perPositionHeight, options.extrudedHeight));
344
- });
345
- }
346
- if (hasStroke) {
347
- storeyOptions.forEach((options) => {
348
- outlineGeometries.push(...geometryFactory.createOutlineGeometries(geometryOptions, options.currentHeight, heightInfo.perPositionHeight, options.extrudedHeight));
349
- });
350
- }
351
- if (heightInfo.skirt) {
352
- const currentHeight = heightInfo.groundLevel -
353
- heightInfo.storeyHeightsBelowGround.reduce((a, b) => a + b, 0);
354
- const extrudedHeight = currentHeight - heightInfo.skirt;
355
- const skirtPositionHeight = heightInfo.storeyHeightsBelowGround.length
356
- ? false
357
- : heightInfo.perPositionHeight;
358
- if (hasFill) {
359
- fillGeometries.push(...geometryFactory.createSolidGeometries(geometryOptions, currentHeight, skirtPositionHeight, extrudedHeight));
360
- }
361
- if (hasStroke) {
362
- outlineGeometries.push(...geometryFactory.createOutlineGeometries(geometryOptions, currentHeight, skirtPositionHeight, extrudedHeight));
363
- }
364
- }
365
- if (!heightInfo.extruded) {
366
- if (heightInfo.heightReference === HeightReference.CLAMP_TO_GROUND) {
367
- groundPrimitive = true;
368
- }
369
- if (hasFill) {
370
- fillGeometries.push(...geometryFactory.createFillGeometries(geometryOptions, heightInfo.groundLevel, heightInfo.perPositionHeight));
371
- }
372
- if (hasStroke) {
373
- if (heightInfo.heightReference === HeightReference.CLAMP_TO_GROUND) {
374
- lineGeometries.push(...geometryFactory.createGroundLineGeometries(geometryOptions, style));
375
- }
376
- else {
377
- lineGeometries.push(...geometryFactory.createLineGeometries(geometryOptions, style));
378
- }
379
- }
380
- }
381
- });
382
- const allowPicking = vectorProperties.getAllowPicking(feature);
383
- const primitives = [];
384
- if (lineGeometries.length) {
385
- const linePrimitive = createLinePrimitive(scene, vectorProperties, allowPicking, feature, lineGeometries, style, groundPrimitive);
386
- if (linePrimitive) {
387
- primitives.push(linePrimitive);
388
- }
389
- }
390
- if (fillGeometries.length) {
391
- const fillPrimitive = createPrimitive(scene, vectorProperties, allowPicking, feature, fillGeometries, style, groundPrimitive);
392
- if (fillPrimitive) {
393
- primitives.push(fillPrimitive);
394
- }
395
- }
396
- if (outlineGeometries.length) {
397
- const outlinePrimitive = createOutlinePrimitive(scene, vectorProperties, allowPicking, feature, outlineGeometries, style);
398
- if (outlinePrimitive) {
399
- primitives.push(outlinePrimitive);
400
- }
401
- }
402
- context.addPrimitives(primitives, feature, allowPicking);
403
- }
404
- //# sourceMappingURL=featureconverterHelper.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"featureconverterHelper.js","sourceRoot":"","sources":["../../../../src/util/featureconverter/featureconverterHelper.ts"],"names":[],"mappings":"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"}