@itwin/map-layers-formats 4.6.0-dev.25 → 4.6.0-dev.28
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.
- package/lib/cjs/ArcGisFeature/ArcGisFeatureFormat.js.map +1 -1
- package/lib/cjs/ArcGisFeature/ArcGisFeatureProvider.js.map +1 -1
- package/lib/cjs/ArcGisFeature/ArcGisFeatureQuery.js.map +1 -1
- package/lib/cjs/ArcGisFeature/ArcGisFeatureReader.js.map +1 -1
- package/lib/cjs/ArcGisFeature/ArcGisFeatureResponse.js.map +1 -1
- package/lib/cjs/ArcGisFeature/ArcGisJsonFeatureReader.js.map +1 -1
- package/lib/cjs/ArcGisFeature/ArcGisPbfFeatureReader.js.map +1 -1
- package/lib/cjs/ArcGisFeature/ArcGisSymbologyRenderer.js.map +1 -1
- package/lib/cjs/ArcGisFeature/EsriSymbology.js.map +1 -1
- package/lib/cjs/ArcGisFeature/esriPBuffer.gen.js.map +1 -1
- package/lib/cjs/Feature/DefaultMarkerIcon.js +9 -9
- package/lib/cjs/Feature/DefaultMarkerIcon.js.map +1 -1
- package/lib/cjs/Feature/FeatureCanvasRenderer.js.map +1 -1
- package/lib/cjs/Feature/FeatureInfoReader.js.map +1 -1
- package/lib/cjs/Feature/FeatureSymbology.js.map +1 -1
- package/lib/cjs/Feature/RandomMapColor.js.map +1 -1
- package/lib/cjs/GeoJSON/GeoJSONGeometry.js.map +1 -1
- package/lib/cjs/GeoJSON/GeoJSONGeometryReader.js.map +1 -1
- package/lib/cjs/Icons/MapInfoIcon.js.map +1 -1
- package/lib/cjs/OgcApiFeatures/OgcApiFeaturesFormat.js.map +1 -1
- package/lib/cjs/OgcApiFeatures/OgcApiFeaturesProvider.js.map +1 -1
- package/lib/cjs/OgcApiFeatures/OgcApiFeaturesReader.js.map +1 -1
- package/lib/cjs/Tools/GeometryTerrainDraper.d.ts +20 -0
- package/lib/cjs/Tools/GeometryTerrainDraper.d.ts.map +1 -0
- package/lib/cjs/Tools/GeometryTerrainDraper.js +153 -0
- package/lib/cjs/Tools/GeometryTerrainDraper.js.map +1 -0
- package/lib/cjs/Tools/MapFeatureInfoDecorator.d.ts +15 -10
- package/lib/cjs/Tools/MapFeatureInfoDecorator.d.ts.map +1 -1
- package/lib/cjs/Tools/MapFeatureInfoDecorator.js +191 -150
- package/lib/cjs/Tools/MapFeatureInfoDecorator.js.map +1 -1
- package/lib/cjs/Tools/MapFeatureInfoTool.d.ts.map +1 -1
- package/lib/cjs/Tools/MapFeatureInfoTool.js +6 -3
- package/lib/cjs/Tools/MapFeatureInfoTool.js.map +1 -1
- package/lib/cjs/map-layers-formats.js.map +1 -1
- package/lib/cjs/mapLayersFormats.js.map +1 -1
- package/lib/esm/ArcGisFeature/ArcGisFeatureFormat.js.map +1 -1
- package/lib/esm/ArcGisFeature/ArcGisFeatureProvider.js.map +1 -1
- package/lib/esm/ArcGisFeature/ArcGisFeatureQuery.js.map +1 -1
- package/lib/esm/ArcGisFeature/ArcGisFeatureReader.js.map +1 -1
- package/lib/esm/ArcGisFeature/ArcGisFeatureResponse.js.map +1 -1
- package/lib/esm/ArcGisFeature/ArcGisJsonFeatureReader.js.map +1 -1
- package/lib/esm/ArcGisFeature/ArcGisPbfFeatureReader.js.map +1 -1
- package/lib/esm/ArcGisFeature/ArcGisSymbologyRenderer.js.map +1 -1
- package/lib/esm/ArcGisFeature/EsriSymbology.js.map +1 -1
- package/lib/esm/ArcGisFeature/esriPBuffer.gen.js.map +1 -1
- package/lib/esm/Feature/DefaultMarkerIcon.js +9 -9
- package/lib/esm/Feature/DefaultMarkerIcon.js.map +1 -1
- package/lib/esm/Feature/FeatureCanvasRenderer.js.map +1 -1
- package/lib/esm/Feature/FeatureInfoReader.js.map +1 -1
- package/lib/esm/Feature/FeatureSymbology.js.map +1 -1
- package/lib/esm/Feature/RandomMapColor.js.map +1 -1
- package/lib/esm/GeoJSON/GeoJSONGeometry.js.map +1 -1
- package/lib/esm/GeoJSON/GeoJSONGeometryReader.js.map +1 -1
- package/lib/esm/Icons/MapInfoIcon.js.map +1 -1
- package/lib/esm/OgcApiFeatures/OgcApiFeaturesFormat.js.map +1 -1
- package/lib/esm/OgcApiFeatures/OgcApiFeaturesProvider.js.map +1 -1
- package/lib/esm/OgcApiFeatures/OgcApiFeaturesReader.js.map +1 -1
- package/lib/esm/Tools/GeometryTerrainDraper.d.ts +20 -0
- package/lib/esm/Tools/GeometryTerrainDraper.d.ts.map +1 -0
- package/lib/esm/Tools/GeometryTerrainDraper.js +149 -0
- package/lib/esm/Tools/GeometryTerrainDraper.js.map +1 -0
- package/lib/esm/Tools/MapFeatureInfoDecorator.d.ts +15 -10
- package/lib/esm/Tools/MapFeatureInfoDecorator.d.ts.map +1 -1
- package/lib/esm/Tools/MapFeatureInfoDecorator.js +193 -152
- package/lib/esm/Tools/MapFeatureInfoDecorator.js.map +1 -1
- package/lib/esm/Tools/MapFeatureInfoTool.d.ts.map +1 -1
- package/lib/esm/Tools/MapFeatureInfoTool.js +6 -3
- package/lib/esm/Tools/MapFeatureInfoTool.js.map +1 -1
- package/lib/esm/map-layers-formats.js.map +1 -1
- package/lib/esm/mapLayersFormats.js.map +1 -1
- package/lib/public/locales/en/mapLayersFormats.json +18 -18
- package/package.json +13 -13
|
@@ -2,71 +2,12 @@
|
|
|
2
2
|
* Copyright (c) Bentley Systems, Incorporated. All rights reserved.
|
|
3
3
|
* See LICENSE.md in the project root for license terms and full copyright notice.
|
|
4
4
|
*--------------------------------------------------------------------------------------------*/
|
|
5
|
-
/* eslint-disable no-console */
|
|
6
5
|
import { Base64EncodedString, ColorDef } from "@itwin/core-common";
|
|
7
|
-
import { GraphicType, IModelApp, MapTileTreeReference, Marker, MarkerSet
|
|
8
|
-
import {
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
class DrapeLineStringCollector extends TileGeometryCollector {
|
|
13
|
-
constructor(user, chordTolerance, range, transform, _points) {
|
|
14
|
-
super({ user, chordTolerance, range, transform });
|
|
15
|
-
this._points = _points;
|
|
16
|
-
}
|
|
17
|
-
collectTile(tile) {
|
|
18
|
-
let status = super.collectTile(tile);
|
|
19
|
-
if ("reject" !== status && !this.rangeOverlapsLineString(tile.range))
|
|
20
|
-
status = "reject";
|
|
21
|
-
return status;
|
|
22
|
-
}
|
|
23
|
-
rangeOverlapsLineString(range) {
|
|
24
|
-
let inside = false;
|
|
25
|
-
const clipper = ConvexClipPlaneSet.createRange3dPlanes(range, true, true, true, true, false, false);
|
|
26
|
-
if (this._options.transform)
|
|
27
|
-
clipper.transformInPlace(this._options.transform);
|
|
28
|
-
for (let i = 0; i < this._points.length - 1 && !inside; i++)
|
|
29
|
-
inside = clipper.announceClippedSegmentIntervals(0, 1, this._points.getPoint3dAtUncheckedPointIndex(i), this._points.getPoint3dAtUncheckedPointIndex(i + 1));
|
|
30
|
-
return inside;
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
/** @internal */
|
|
34
|
-
class TerrainDraper {
|
|
35
|
-
constructor(viewport, treeRef) {
|
|
36
|
-
this.viewport = viewport;
|
|
37
|
-
this.treeRef = treeRef;
|
|
38
|
-
this.tileUserId = TileUser.generateId();
|
|
39
|
-
IModelApp.tileAdmin.registerUser(this);
|
|
40
|
-
}
|
|
41
|
-
dispose() {
|
|
42
|
-
IModelApp.tileAdmin.forgetUser(this);
|
|
43
|
-
}
|
|
44
|
-
get iModel() { return this.viewport.iModel; }
|
|
45
|
-
onRequestStateChanged() {
|
|
46
|
-
this.viewport.invalidateDecorations();
|
|
47
|
-
}
|
|
48
|
-
discloseTileTrees(trees) {
|
|
49
|
-
trees.disclose(this.treeRef);
|
|
50
|
-
}
|
|
51
|
-
drapeLineString(outStrings, inPoints, tolerance, maxDistance = 1.0E5) {
|
|
52
|
-
const tree = this.treeRef.treeOwner.load();
|
|
53
|
-
if (!tree)
|
|
54
|
-
return "loading";
|
|
55
|
-
const range = Range3d.createNull();
|
|
56
|
-
range.extendArray(inPoints);
|
|
57
|
-
range.extendZOnly(-maxDistance); // Expand - but not so much that we get opposite side of globe.
|
|
58
|
-
range.extendZOnly(maxDistance);
|
|
59
|
-
const collector = new DrapeLineStringCollector(this, tolerance, range, tree.iModelTransform, inPoints);
|
|
60
|
-
this.treeRef.collectTileGeometry(collector);
|
|
61
|
-
collector.requestMissingTiles();
|
|
62
|
-
if (collector.isAllGeometryLoaded && collector.polyfaces.length > 0) {
|
|
63
|
-
for (const polyface of collector.polyfaces)
|
|
64
|
-
outStrings.push(...PolyfaceQuery.sweepLineStringToFacets(inPoints, polyface, SweepLineStringToFacetsOptions.create(Vector3d.unitZ(), undefined, true, true, false, false)));
|
|
65
|
-
return "complete";
|
|
66
|
-
}
|
|
67
|
-
return "loading";
|
|
68
|
-
}
|
|
69
|
-
}
|
|
6
|
+
import { GraphicType, IModelApp, MapTileTreeReference, Marker, MarkerSet } from "@itwin/core-frontend";
|
|
7
|
+
import { GrowableXYZArray, Point2d, Point3d, Range3d, Transform } from "@itwin/core-geometry";
|
|
8
|
+
import { GeometryTerrainDraper } from "./GeometryTerrainDraper";
|
|
9
|
+
import { Logger } from "@itwin/core-bentley";
|
|
10
|
+
const loggerCategory = "MapLayersFormats.MapFeatureInfoDecorator";
|
|
70
11
|
/** @internal */
|
|
71
12
|
class PinMarker extends Marker {
|
|
72
13
|
constructor(worldLocation, size, image) {
|
|
@@ -107,6 +48,37 @@ class PinMarkerSet extends MarkerSet {
|
|
|
107
48
|
return new PinMarkerCluster(cluster.getClusterLocation(), cluster.markers[0].size, cluster, undefined);
|
|
108
49
|
}
|
|
109
50
|
}
|
|
51
|
+
class DrapedPrimitives {
|
|
52
|
+
constructor() {
|
|
53
|
+
this._points = new GrowableXYZArray();
|
|
54
|
+
}
|
|
55
|
+
get strings() {
|
|
56
|
+
return this._strings;
|
|
57
|
+
}
|
|
58
|
+
get meshes() {
|
|
59
|
+
return this._meshes;
|
|
60
|
+
}
|
|
61
|
+
get points() {
|
|
62
|
+
return this._points;
|
|
63
|
+
}
|
|
64
|
+
clear() {
|
|
65
|
+
this._strings = undefined;
|
|
66
|
+
this._meshes = undefined;
|
|
67
|
+
this._points.clear();
|
|
68
|
+
}
|
|
69
|
+
addStrings(drapedStrings) {
|
|
70
|
+
if (!this._strings) {
|
|
71
|
+
this._strings = [];
|
|
72
|
+
}
|
|
73
|
+
for (const ds of drapedStrings)
|
|
74
|
+
this._strings.push(ds);
|
|
75
|
+
}
|
|
76
|
+
addMeshes(drapedMeshes) {
|
|
77
|
+
if (!this._meshes)
|
|
78
|
+
this._meshes = [];
|
|
79
|
+
drapedMeshes.forEach((ds) => this._meshes.push(ds));
|
|
80
|
+
}
|
|
81
|
+
}
|
|
110
82
|
/** @internal */
|
|
111
83
|
export class MapFeatureInfoDecorator {
|
|
112
84
|
get highlightColor() { return this._highlightColor; }
|
|
@@ -118,32 +90,37 @@ export class MapFeatureInfoDecorator {
|
|
|
118
90
|
constructor() {
|
|
119
91
|
this.hidden = false;
|
|
120
92
|
this.useCachedDecorations = true;
|
|
121
|
-
this.disableTerrainDraper =
|
|
93
|
+
this.disableTerrainDraper = false;
|
|
122
94
|
this.markerSize = new Point2d(32, 32);
|
|
123
95
|
this.lineWidth = 3;
|
|
96
|
+
// This is the maximum allowed size of a geometry, in pixels, to be draped.
|
|
97
|
+
// If the value is too large, we will end up downloading tons of terrain tiles, and possibly hang for too long.
|
|
98
|
+
this.maxDrapeSizePixels = 50000;
|
|
99
|
+
// This value controls the chord tolerance used to collect terrain tiles
|
|
100
|
+
// at the "right" resolution. Higher values, will give coarser terrain tiles.
|
|
101
|
+
this.chordTolerancePixels = 20;
|
|
124
102
|
this._highlightColor = ColorDef.from(0, 255, 255, 127);
|
|
125
|
-
this._drapePoints = new GrowableXYZArray();
|
|
126
103
|
this._scratchPoints = new GrowableXYZArray();
|
|
127
|
-
this.
|
|
104
|
+
this._drapeGraphicsStates = [];
|
|
105
|
+
this._drapedPrimitives = new DrapedPrimitives();
|
|
128
106
|
this._allGeomDraped = false;
|
|
129
107
|
this._markerSet = new PinMarkerSet();
|
|
130
108
|
this._graphicType = GraphicType.WorldOverlay;
|
|
131
|
-
this.
|
|
132
|
-
this.
|
|
109
|
+
this.clearData = () => {
|
|
110
|
+
this._data = undefined;
|
|
133
111
|
};
|
|
134
|
-
this.
|
|
135
|
-
this.
|
|
112
|
+
this.setData = (data) => {
|
|
113
|
+
this._drapedPrimitives.clear();
|
|
136
114
|
this._allGeomDraped = false;
|
|
137
115
|
this.hidden = false;
|
|
138
|
-
this.
|
|
116
|
+
this._data = data;
|
|
139
117
|
IModelApp.viewManager.invalidateCachedDecorationsAllViews(this);
|
|
140
|
-
this.
|
|
141
|
-
this.
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
const drapeTreeRef = this.getGeometryTreeRef(state.hit.viewport);
|
|
118
|
+
this._drapeGraphicsStates = [];
|
|
119
|
+
if (!this.disableTerrainDraper && this._data.mapInfo?.layerInfos && data.hit.viewport.displayStyle.displayTerrain) {
|
|
120
|
+
if (data.hit?.modelId) {
|
|
121
|
+
const drapeTreeRef = this.getGeometryTreeRef(data.hit.viewport);
|
|
145
122
|
if (drapeTreeRef) {
|
|
146
|
-
this._draper = new
|
|
123
|
+
this._draper = new GeometryTerrainDraper(data.hit.viewport, drapeTreeRef);
|
|
147
124
|
return;
|
|
148
125
|
}
|
|
149
126
|
}
|
|
@@ -161,10 +138,10 @@ export class MapFeatureInfoDecorator {
|
|
|
161
138
|
const base64 = Base64EncodedString.encode(this.defaultMarkerIconSvgXml);
|
|
162
139
|
this._markerImage.src = `data:image/svg+xml;base64,${base64}`;
|
|
163
140
|
}
|
|
164
|
-
|
|
141
|
+
computePixelSize(viewport, applyAspectRatioSkew, pointWorld) {
|
|
165
142
|
let pixelSize = 1;
|
|
166
143
|
// Compute the horizontal distance in meters between two adjacent pixels at the center of the geometry.
|
|
167
|
-
pixelSize = viewport.getPixelSizeAtPoint(
|
|
144
|
+
pixelSize = viewport.getPixelSizeAtPoint(pointWorld);
|
|
168
145
|
pixelSize = viewport.target.adjustPixelSizeForLOD(pixelSize);
|
|
169
146
|
// Aspect ratio skew > 1.0 stretches the view in Y. In that case use the smaller vertical pixel distance for our stroke tolerance.
|
|
170
147
|
const skew = applyAspectRatioSkew ? viewport.view.getAspectRatioSkew() : 0;
|
|
@@ -172,6 +149,17 @@ export class MapFeatureInfoDecorator {
|
|
|
172
149
|
pixelSize /= skew;
|
|
173
150
|
return pixelSize * 0.25;
|
|
174
151
|
}
|
|
152
|
+
computeChordTolerance(viewport, drapeRange) {
|
|
153
|
+
const drapeSizeWorld = Math.max(drapeRange.xLength(), drapeRange.yLength());
|
|
154
|
+
const pixelSize = this.computePixelSize(viewport, true, drapeRange.center);
|
|
155
|
+
const maxDrapeRangeSizeRatio = this.maxDrapeSizePixels / (drapeSizeWorld / pixelSize);
|
|
156
|
+
if (maxDrapeRangeSizeRatio < 1) {
|
|
157
|
+
Logger.logWarning(loggerCategory, "Element too large; chord tolerance was adjusted");
|
|
158
|
+
return (pixelSize / maxDrapeRangeSizeRatio) * this.chordTolerancePixels;
|
|
159
|
+
}
|
|
160
|
+
return pixelSize * this.chordTolerancePixels;
|
|
161
|
+
}
|
|
162
|
+
;
|
|
175
163
|
getGeometryTreeRef(vp) {
|
|
176
164
|
let treeRef;
|
|
177
165
|
if (vp.backgroundMapSettings.applyTerrain) {
|
|
@@ -185,7 +173,7 @@ export class MapFeatureInfoDecorator {
|
|
|
185
173
|
}
|
|
186
174
|
renderGraphics(context) {
|
|
187
175
|
this._markerSet.markers.clear();
|
|
188
|
-
if (this.
|
|
176
|
+
if (this._data?.mapInfo?.layerInfos === undefined || this.hidden) {
|
|
189
177
|
return undefined;
|
|
190
178
|
}
|
|
191
179
|
let transform;
|
|
@@ -195,71 +183,137 @@ export class MapFeatureInfoDecorator {
|
|
|
195
183
|
}
|
|
196
184
|
const builder = context.createGraphicBuilder(this._graphicType, transform);
|
|
197
185
|
if (this._draper) {
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
186
|
+
this.initializeDrapeState(context.viewport);
|
|
187
|
+
// We need to call drapeGeometries() until it returns true (i.e. fully complete)
|
|
188
|
+
if (!this._allGeomDraped) {
|
|
189
|
+
if (!this.drapeGeometries(context.viewport))
|
|
190
|
+
return undefined;
|
|
191
|
+
}
|
|
192
|
+
this.appendDrapedGeometries(builder);
|
|
193
|
+
}
|
|
194
|
+
else {
|
|
195
|
+
// Append geometries straight from the state to the builder
|
|
196
|
+
this.appendGeometries(builder);
|
|
197
|
+
}
|
|
198
|
+
// Add extra markers if any specified
|
|
199
|
+
if (this.extraMarkers !== undefined) {
|
|
200
|
+
this.extraMarkers.forEach((markerPoint) => {
|
|
201
|
+
builder.setSymbology(this.highlightColor, this.highlightColor, this.lineWidth);
|
|
202
|
+
this._markerSet.markers.add(new PinMarker(markerPoint, this.markerSize, this._markerImage));
|
|
203
|
+
});
|
|
204
|
+
}
|
|
205
|
+
return builder.finish();
|
|
206
|
+
}
|
|
207
|
+
// Iterates the mapfeatureinfo data and create a draping state for each entry
|
|
208
|
+
initializeDrapeState(viewport) {
|
|
209
|
+
if (this._drapeGraphicsStates.length === 0) {
|
|
210
|
+
const getGraphicRange = (graphic) => {
|
|
211
|
+
if (graphic.type === "linestring")
|
|
212
|
+
return Range3d.createArray(graphic.points);
|
|
213
|
+
else if (graphic.type === "loop")
|
|
214
|
+
return graphic.loop.range();
|
|
215
|
+
else if (graphic.type === "pointstring")
|
|
216
|
+
return Range3d.createArray(graphic.points);
|
|
217
|
+
else
|
|
218
|
+
return Range3d.createNull();
|
|
219
|
+
};
|
|
220
|
+
for (const layerInfo of this._data?.mapInfo?.layerInfos ?? []) {
|
|
221
|
+
for (const subLayerInfo of layerInfo?.subLayerInfos ?? []) {
|
|
222
|
+
for (const feature of subLayerInfo.features) {
|
|
223
|
+
feature.geometries?.forEach(((geom) => {
|
|
224
|
+
const range = getGraphicRange(geom.graphic);
|
|
225
|
+
this._drapeGraphicsStates.push({
|
|
226
|
+
graphic: geom.graphic,
|
|
227
|
+
collectorState: "loading",
|
|
228
|
+
chordTolerance: this.computeChordTolerance(viewport, range),
|
|
229
|
+
range,
|
|
230
|
+
});
|
|
231
|
+
}));
|
|
213
232
|
}
|
|
214
233
|
}
|
|
215
234
|
}
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
235
|
+
}
|
|
236
|
+
}
|
|
237
|
+
// returns true when all geometries are fully draped; otherwise false
|
|
238
|
+
drapeGeometries(_viewport) {
|
|
239
|
+
if (!this._draper)
|
|
240
|
+
return false;
|
|
241
|
+
let hasMissingDrapeGeoms = false;
|
|
242
|
+
for (const state of this._drapeGraphicsStates) {
|
|
243
|
+
if (state.collectorState === "loading") {
|
|
244
|
+
this._scratchPoints.clear();
|
|
245
|
+
if (state.graphic.type === "linestring") {
|
|
246
|
+
this._scratchPoints.pushAll(state.graphic.points);
|
|
247
|
+
const drapedStrings = [];
|
|
248
|
+
if ("loading" === this._draper.drapeLineString(drapedStrings, this._scratchPoints, state.chordTolerance, state.range)) {
|
|
249
|
+
hasMissingDrapeGeoms = true;
|
|
250
|
+
break;
|
|
251
|
+
}
|
|
252
|
+
else {
|
|
253
|
+
this._drapedPrimitives.addStrings(drapedStrings);
|
|
254
|
+
state.collectorState = "complete";
|
|
255
|
+
}
|
|
256
|
+
}
|
|
257
|
+
else if (state.graphic.type === "loop") {
|
|
258
|
+
const loop = state.graphic.loop;
|
|
259
|
+
const outMeshes = [];
|
|
260
|
+
if ("loading" === this._draper.drapeLoop(outMeshes, loop, state.chordTolerance, state.range)) {
|
|
261
|
+
hasMissingDrapeGeoms = true;
|
|
262
|
+
break; // We drape each graphic sequentially, otherwise collector get messed up.
|
|
263
|
+
}
|
|
264
|
+
else {
|
|
265
|
+
this._drapedPrimitives.addMeshes(outMeshes);
|
|
266
|
+
state.collectorState = "complete";
|
|
267
|
+
}
|
|
268
|
+
}
|
|
269
|
+
else if (state.graphic.type === "pointstring") {
|
|
270
|
+
const outPoint = Point3d.createZero();
|
|
271
|
+
for (const point of state.graphic.points) {
|
|
272
|
+
if ("loading" === this._draper.drapePoint(outPoint, point, state.chordTolerance, state.range)) {
|
|
273
|
+
this._allGeomDraped = false;
|
|
274
|
+
return false;
|
|
233
275
|
}
|
|
234
|
-
else {
|
|
235
|
-
this.
|
|
236
|
-
state.collectorState = "complete";
|
|
276
|
+
else if (!outPoint.isZero) {
|
|
277
|
+
this._drapedPrimitives.points.push(outPoint);
|
|
237
278
|
}
|
|
238
279
|
}
|
|
239
|
-
drapePointsOffset += state.count;
|
|
240
280
|
}
|
|
241
|
-
this._allGeomDraped = !hasMissingLineStrings;
|
|
242
|
-
}
|
|
243
|
-
if (this._drapedStrings) {
|
|
244
|
-
builder.setSymbology(this.highlightColor, this.highlightColor, this.lineWidth);
|
|
245
|
-
this._drapedStrings.forEach((line) => builder.addLineString(line.points));
|
|
246
281
|
}
|
|
247
282
|
}
|
|
248
|
-
|
|
283
|
+
this._allGeomDraped = !hasMissingDrapeGeoms;
|
|
284
|
+
return this._allGeomDraped;
|
|
285
|
+
}
|
|
286
|
+
appendDrapedGeometries(builder) {
|
|
287
|
+
if (this._drapedPrimitives.strings) {
|
|
249
288
|
builder.setSymbology(this.highlightColor, this.highlightColor, this.lineWidth);
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
289
|
+
this._drapedPrimitives.strings.forEach((line) => builder.addLineString(line.points));
|
|
290
|
+
}
|
|
291
|
+
if (this._drapedPrimitives.meshes) {
|
|
292
|
+
builder.setSymbology(this.highlightColor, this.highlightColor, this.lineWidth);
|
|
293
|
+
this._drapedPrimitives.meshes.forEach((polyface) => builder.addPolyface(polyface, true));
|
|
294
|
+
}
|
|
295
|
+
if (this._drapedPrimitives.points.length > 0) {
|
|
296
|
+
for (let i = 0; i < this._drapedPrimitives.points.length; i++) {
|
|
297
|
+
this._markerSet.markers.add(new PinMarker(this._drapedPrimitives.points.getPoint3dAtUncheckedPointIndex(i), this.markerSize, this._markerImage));
|
|
298
|
+
}
|
|
299
|
+
}
|
|
300
|
+
}
|
|
301
|
+
appendGeometries(builder) {
|
|
302
|
+
if (!this._data?.mapInfo?.layerInfos)
|
|
303
|
+
return;
|
|
304
|
+
builder.setSymbology(this.highlightColor, this.highlightColor, this.lineWidth);
|
|
305
|
+
for (const layerInfo of this._data.mapInfo.layerInfos) {
|
|
306
|
+
if (layerInfo.subLayerInfos && !(layerInfo.subLayerInfos instanceof HTMLElement)) {
|
|
307
|
+
for (const subLayerInfo of layerInfo.subLayerInfos) {
|
|
308
|
+
for (const feature of subLayerInfo.features) {
|
|
309
|
+
if (feature.geometries) {
|
|
310
|
+
for (const geom of feature.geometries) {
|
|
311
|
+
if (geom.graphic.type === "pointstring") {
|
|
312
|
+
for (const point of geom.graphic.points)
|
|
313
|
+
this._markerSet.markers.add(new PinMarker(point, this.markerSize, this._markerImage));
|
|
314
|
+
}
|
|
315
|
+
else {
|
|
316
|
+
builder.addPrimitive(geom.graphic);
|
|
263
317
|
}
|
|
264
318
|
}
|
|
265
319
|
}
|
|
@@ -267,26 +321,13 @@ export class MapFeatureInfoDecorator {
|
|
|
267
321
|
}
|
|
268
322
|
}
|
|
269
323
|
}
|
|
270
|
-
// Add extra markers if any specified
|
|
271
|
-
if (this.extraMarkers !== undefined) {
|
|
272
|
-
this.extraMarkers.forEach((markerPoint) => {
|
|
273
|
-
builder.setSymbology(this.highlightColor, this.highlightColor, this.lineWidth);
|
|
274
|
-
this._markerSet.markers.add(new PinMarker(markerPoint, this.markerSize, this._markerImage));
|
|
275
|
-
});
|
|
276
|
-
}
|
|
277
|
-
return builder.finish();
|
|
278
|
-
}
|
|
279
|
-
addDrapedStrings(drapedStrings) {
|
|
280
|
-
if (!this._drapedStrings) {
|
|
281
|
-
this._drapedStrings = [];
|
|
282
|
-
}
|
|
283
|
-
for (const ds of drapedStrings)
|
|
284
|
-
this._drapedStrings.push(ds);
|
|
285
324
|
}
|
|
286
325
|
decorate(context) {
|
|
287
326
|
const graphics = this.renderGraphics(context);
|
|
288
|
-
if (graphics)
|
|
327
|
+
if (graphics) {
|
|
289
328
|
context.addDecoration(this._graphicType, graphics);
|
|
329
|
+
IModelApp.toolAdmin.setCursor(undefined);
|
|
330
|
+
}
|
|
290
331
|
this._markerSet.addDecoration(context);
|
|
291
332
|
return;
|
|
292
333
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MapFeatureInfoDecorator.js","sourceRoot":"","sources":["../../../src/Tools/MapFeatureInfoDecorator.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/* eslint-disable no-console */\r\nimport { Base64EncodedString, ColorDef } from \"@itwin/core-common\";\r\nimport {\r\n BeButtonEvent, Cluster, CollectTileStatus, DecorateContext, Decorator, DisclosedTileTreeSet,\r\n GeometryTileTreeReference, GraphicType, IModelApp, MapTileTreeReference, Marker, MarkerImage, MarkerSet,\r\n Tile, TileGeometryCollector, TileTreeReference, TileUser, Viewport } from \"@itwin/core-frontend\";\r\nimport { ConvexClipPlaneSet, CurvePrimitive, GrowableXYZArray, LineString3d, Point2d, Point3d, PolyfaceQuery, Range3d, SweepLineStringToFacetsOptions, Transform, Vector3d, XAndY, XYAndZ } from \"@itwin/core-geometry\";\r\nimport { MapFeatureInfoToolData } from \"./MapFeatureInfoTool\";\r\n\r\n/** A TileGeometryCollector that restricts collection to tiles that overlap a line string.\r\n/* @internal\r\n*/\r\nclass DrapeLineStringCollector extends TileGeometryCollector {\r\n constructor(user: TileUser, chordTolerance: number, range: Range3d, transform: Transform, private _points: GrowableXYZArray) {\r\n super({ user, chordTolerance, range, transform });\r\n }\r\n\r\n public override collectTile(tile: Tile): CollectTileStatus {\r\n let status = super.collectTile(tile);\r\n if (\"reject\" !== status && !this.rangeOverlapsLineString(tile.range))\r\n status = \"reject\";\r\n\r\n return status;\r\n }\r\n\r\n private rangeOverlapsLineString(range: Range3d) {\r\n let inside = false;\r\n const clipper = ConvexClipPlaneSet.createRange3dPlanes(range, true, true, true, true, false, false);\r\n if (this._options.transform)\r\n clipper.transformInPlace(this._options.transform);\r\n\r\n for (let i = 0; i < this._points.length - 1 && !inside; i++)\r\n inside = clipper.announceClippedSegmentIntervals(0, 1, this._points.getPoint3dAtUncheckedPointIndex(i), this._points.getPoint3dAtUncheckedPointIndex(i + 1));\r\n\r\n return inside;\r\n }\r\n}\r\n\r\n/** @internal */\r\nclass TerrainDraper implements TileUser {\r\n public readonly tileUserId: number;\r\n\r\n public constructor(public readonly viewport: Viewport, public readonly treeRef: GeometryTileTreeReference) {\r\n this.tileUserId = TileUser.generateId();\r\n IModelApp.tileAdmin.registerUser(this);\r\n }\r\n\r\n public dispose(): void {\r\n IModelApp.tileAdmin.forgetUser(this);\r\n }\r\n\r\n public get iModel() { return this.viewport.iModel; }\r\n\r\n public onRequestStateChanged() {\r\n this.viewport.invalidateDecorations();\r\n }\r\n\r\n public discloseTileTrees(trees: DisclosedTileTreeSet) {\r\n trees.disclose(this.treeRef);\r\n }\r\n\r\n public drapeLineString(outStrings: CurvePrimitive[], inPoints: GrowableXYZArray, tolerance: number, maxDistance = 1.0E5): \"loading\" | \"complete\" {\r\n const tree = this.treeRef.treeOwner.load();\r\n if (!tree)\r\n return \"loading\";\r\n\r\n const range = Range3d.createNull();\r\n range.extendArray(inPoints);\r\n range.extendZOnly(-maxDistance); // Expand - but not so much that we get opposite side of globe.\r\n range.extendZOnly(maxDistance);\r\n\r\n const collector = new DrapeLineStringCollector(this, tolerance, range, tree.iModelTransform, inPoints);\r\n this.treeRef.collectTileGeometry(collector);\r\n collector.requestMissingTiles();\r\n\r\n if (collector.isAllGeometryLoaded && collector.polyfaces.length > 0) {\r\n for (const polyface of collector.polyfaces)\r\n outStrings.push(...PolyfaceQuery.sweepLineStringToFacets(inPoints, polyface,\r\n SweepLineStringToFacetsOptions.create(Vector3d.unitZ(), undefined, true, true, false, false)));\r\n return \"complete\";\r\n }\r\n\r\n return \"loading\";\r\n }\r\n}\r\n\r\n/** @internal */\r\nclass PinMarker extends Marker {\r\n public constructor(worldLocation: XYAndZ, size: XAndY, image: MarkerImage) {\r\n super(worldLocation, size);\r\n this.image = image;\r\n this.imageOffset = new Point3d(0, Math.floor(size.y * .5));\r\n }\r\n}\r\n\r\n/** @internal */\r\nclass PinMarkerCluster extends Marker {\r\n /** Create a new cluster marker */\r\n constructor(location: XYAndZ, size: XAndY, cluster: Cluster<PinMarker>, image: MarkerImage | Promise<MarkerImage> | undefined) {\r\n super(location, size);\r\n\r\n this.title = IModelApp.localization.getLocalizedString(\"mapLayersFormats:Messages.MapFeatureInfoDecorator.clusterZoomIn\", { nbInstances: cluster.markers.length});\r\n\r\n this.imageOffset = new Point3d(0, size.y * 0.5);\r\n this.label = cluster.markers.length.toLocaleString();\r\n this.labelColor = \"black\";\r\n this.labelFont = \"bold 14px sans-serif\";\r\n\r\n if (image)\r\n this.setImage(image);\r\n }\r\n\r\n /** Show the cluster as a white circle with an outline */\r\n public override drawFunc(ctx: CanvasRenderingContext2D): void {\r\n ctx.beginPath();\r\n ctx.strokeStyle = \"#372528\";\r\n ctx.fillStyle = \"white\";\r\n ctx.lineWidth = 5;\r\n ctx.arc(0, 0, this.size.x * 0.5, 0, Math.PI * 2);\r\n ctx.fill();\r\n ctx.stroke();\r\n }\r\n\r\n public override onMouseButton(_ev: BeButtonEvent): boolean { return true; } // Don't allow clicks to be sent to active tool...\r\n}\r\n\r\n/** @internal */\r\nclass PinMarkerSet extends MarkerSet<PinMarker> {\r\n protected getClusterMarker(cluster: Cluster<PinMarker>): Marker {\r\n // No image passed to the cluster, we prefer to have the circle only\r\n return new PinMarkerCluster(cluster.getClusterLocation(), cluster.markers[0].size, cluster, undefined);\r\n }\r\n}\r\n\r\n/** @internal */\r\ninterface DrapePointState {\r\n count: number;\r\n collectorState: string;\r\n}\r\n\r\n/** @internal */\r\nexport class MapFeatureInfoDecorator implements Decorator {\r\n public hidden = false;\r\n public readonly useCachedDecorations = true;\r\n public readonly disableTerrainDraper = true;\r\n public markerSize = new Point2d(32, 32);\r\n public lineWidth = 3;\r\n private _highlightColor = ColorDef.from(0, 255, 255, 127);\r\n\r\n public get highlightColor() { return this._highlightColor;}\r\n public set highlightColor(color: ColorDef) {\r\n this.updateMarkerImage();\r\n this._highlightColor = color;\r\n }\r\n\r\n public get defaultMarkerIconSvgXml() { return `<svg class=\"indicator\" viewBox=\"0 0 22 22\" width=\"22\" height=\"22\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"m11 0a7.44506 7.44506 0 0 0 -7.5 7.2875c0 1.65 1.132 4.2625 3.25477 8.1125 1.55652 2.75 4.24523 6.6 4.24523 6.6s2.68865-3.9875 4.24528-6.7375c2.12272-3.85 3.25472-6.4625 3.25472-8.1125a7.4215 7.4215 0 0 0 -7.5-7.15z\" fill=\"black\"/><path d=\"m11 1.01715a6.46476 6.46476 0 0 0 -6.48285 6.27033c0 1.72619 1.67181 4.97973 3.12836 7.62139.97564 1.7237 2.42828 3.92176 3.34118 5.27161.91413-1.39148 2.385-3.673 3.37336-5.41907 1.451-2.63171 3.1228-5.88525 3.1228-7.61139a6.39982 6.39982 0 0 0 -6.48285-6.13287zm.00183 8.98285a3 3 0 1 1 3-3 3 3 0 0 1 -3 3z\" fill=\"${this.highlightColor.toRgbString()}\"/></svg>`; }\r\n\r\n private _drapePoints = new GrowableXYZArray();\r\n private _scratchPoints = new GrowableXYZArray();\r\n\r\n private _drapePointsStates: DrapePointState[] = [];\r\n private _drapedStrings?: LineString3d[];\r\n private _allGeomDraped = false;\r\n private _draper?: TerrainDraper;\r\n private _markerImage: HTMLImageElement;\r\n private _markerSet = new PinMarkerSet();\r\n\r\n // Extra markers can be added outside the normal state\r\n public extraMarkers: Point3d[]|undefined;\r\n\r\n private _state: MapFeatureInfoToolData | undefined;\r\n\r\n private readonly _graphicType = GraphicType.WorldOverlay;\r\n\r\n public constructor() {\r\n this._markerImage = new Image();\r\n this.updateMarkerImage();\r\n }\r\n\r\n private updateMarkerImage() {\r\n const base64 = Base64EncodedString.encode(this.defaultMarkerIconSvgXml);\r\n this._markerImage.src = `data:image/svg+xml;base64,${base64}`;\r\n }\r\n\r\n private _computeChordTolerance(viewport: Viewport, applyAspectRatioSkew: boolean, computeRange: () => Range3d) {\r\n let pixelSize = 1;\r\n // Compute the horizontal distance in meters between two adjacent pixels at the center of the geometry.\r\n pixelSize = viewport.getPixelSizeAtPoint(computeRange().center);\r\n pixelSize = viewport.target.adjustPixelSizeForLOD(pixelSize);\r\n\r\n // Aspect ratio skew > 1.0 stretches the view in Y. In that case use the smaller vertical pixel distance for our stroke tolerance.\r\n const skew = applyAspectRatioSkew ? viewport.view.getAspectRatioSkew() : 0;\r\n if (skew > 1)\r\n pixelSize /= skew;\r\n return pixelSize * 0.25;\r\n }\r\n\r\n public clearState = () => {\r\n this._state = undefined;\r\n };\r\n\r\n public setState = (state: MapFeatureInfoToolData) => {\r\n\r\n this._drapedStrings = undefined;\r\n this._allGeomDraped = false;\r\n this.hidden = false;\r\n\r\n this._state = state;\r\n IModelApp.viewManager.invalidateCachedDecorationsAllViews(this);\r\n\r\n this._drapePoints.clear();\r\n this._drapePointsStates = [];\r\n\r\n if (!this.disableTerrainDraper && this._state.mapInfo?.layerInfos && state.hit.viewport.displayStyle.displayTerrain) {\r\n\r\n if (state.hit?.modelId) {\r\n const drapeTreeRef = this.getGeometryTreeRef(state.hit.viewport);\r\n if (drapeTreeRef) {\r\n this._draper = new TerrainDraper(state.hit.viewport, drapeTreeRef);\r\n return;\r\n }\r\n }\r\n }\r\n\r\n if (this._draper) {\r\n // Dispose draper every time?\r\n this._draper.dispose();\r\n this._draper = undefined;\r\n }\r\n };\r\n\r\n private getGeometryTreeRef(vp: Viewport): GeometryTileTreeReference | undefined {\r\n let treeRef: GeometryTileTreeReference | undefined;\r\n if (vp.backgroundMapSettings.applyTerrain) {\r\n vp.forEachMapTreeRef((ref: TileTreeReference) => {\r\n if (!treeRef && ref instanceof MapTileTreeReference) {\r\n treeRef = ref.createGeometryTreeReference();\r\n }\r\n });\r\n }\r\n\r\n return treeRef;\r\n }\r\n\r\n protected renderGraphics(context: DecorateContext) {\r\n this._markerSet.markers.clear();\r\n\r\n if (this._state?.mapInfo?.layerInfos === undefined || this.hidden) {\r\n return undefined;\r\n }\r\n\r\n let transform: Transform|undefined;\r\n const groundBias = context.viewport.displayStyle.backgroundMapSettings.groundBias;\r\n if (groundBias !== 0) {\r\n transform = Transform.createTranslationXYZ(0, 0 , groundBias);\r\n }\r\n const builder = context.createGraphicBuilder(this._graphicType, transform);\r\n\r\n if (this._draper) {\r\n if (this._drapePoints.length === 0 && this._state.mapInfo.layerInfos) {\r\n\r\n for (const layerInfo of this._state.mapInfo.layerInfos) {\r\n if (layerInfo.subLayerInfos) {\r\n for (const subLayerInfo of layerInfo.subLayerInfos) {\r\n for (const feature of subLayerInfo.features) {\r\n if (feature.geometries) {\r\n for (const geom of feature.geometries) {\r\n if (geom.graphic.type === \"linestring\") {\r\n this._drapePointsStates.push({ count: geom.graphic.points.length, collectorState: \"loading\" });\r\n this._drapePoints.pushAll(geom.graphic.points);\r\n }\r\n }\r\n }\r\n }\r\n }\r\n\r\n }\r\n }\r\n }\r\n\r\n if (!this._allGeomDraped) {\r\n\r\n let hasMissingLineStrings = false;\r\n let drapePointsOffset = 0;\r\n for (const state of this._drapePointsStates) {\r\n\r\n if (state.collectorState === \"loading\") {\r\n this._scratchPoints.clear();\r\n this._scratchPoints.resize(state.count);\r\n\r\n let dstIdx = 0;\r\n for (let srcIdx = drapePointsOffset; srcIdx < drapePointsOffset + state.count; srcIdx++) {\r\n this._scratchPoints.transferFromGrowableXYZArray(dstIdx++, this._drapePoints, srcIdx);\r\n }\r\n\r\n const drapeRange = Range3d.createNull();\r\n drapeRange.extendArray(this._scratchPoints);\r\n const drapedStrings: LineString3d[] = [];\r\n const tolerance = this._computeChordTolerance(context.viewport, true, () => drapeRange) * 10; // 10 pixels\r\n if (\"loading\" === this._draper.drapeLineString(drapedStrings, this._scratchPoints, tolerance)) {\r\n hasMissingLineStrings = true;\r\n } else {\r\n this.addDrapedStrings(drapedStrings);\r\n state.collectorState = \"complete\";\r\n }\r\n }\r\n drapePointsOffset += state.count;\r\n }\r\n this._allGeomDraped = !hasMissingLineStrings;\r\n }\r\n\r\n if (this._drapedStrings) {\r\n builder.setSymbology(this.highlightColor, this.highlightColor, this.lineWidth);\r\n this._drapedStrings.forEach((line) => builder.addLineString(line.points));\r\n }\r\n\r\n } else {\r\n builder.setSymbology(this.highlightColor, this.highlightColor, this.lineWidth);\r\n for (const layerInfo of this._state.mapInfo.layerInfos) {\r\n if (layerInfo.subLayerInfos && !(layerInfo.subLayerInfos instanceof HTMLElement)) {\r\n for (const subLayerInfo of layerInfo.subLayerInfos) {\r\n for (const feature of subLayerInfo.features) {\r\n if (feature.geometries) {\r\n for (const geom of feature.geometries) {\r\n if (geom.graphic.type === \"pointstring\") {\r\n for (const point of geom.graphic.points)\r\n this._markerSet.markers.add(new PinMarker(point, this.markerSize, this._markerImage));\r\n } else {\r\n builder.addPrimitive(geom.graphic);\r\n }\r\n\r\n }\r\n }\r\n }\r\n }\r\n\r\n }\r\n\r\n }\r\n }\r\n\r\n // Add extra markers if any specified\r\n if ( this.extraMarkers !== undefined) {\r\n this.extraMarkers.forEach((markerPoint)=> {\r\n builder.setSymbology(this.highlightColor, this.highlightColor, this.lineWidth);\r\n this._markerSet.markers.add(new PinMarker(markerPoint, this.markerSize, this._markerImage));\r\n });\r\n }\r\n\r\n return builder.finish();\r\n }\r\n\r\n public addDrapedStrings(drapedStrings: LineString3d[]) {\r\n if (!this._drapedStrings) {\r\n this._drapedStrings = [];\r\n }\r\n for (const ds of drapedStrings)\r\n this._drapedStrings.push(ds);\r\n }\r\n\r\n public decorate(context: DecorateContext): void {\r\n const graphics = this.renderGraphics(context);\r\n if (graphics)\r\n context.addDecoration(this._graphicType, graphics);\r\n\r\n this._markerSet.addDecoration(context);\r\n return;\r\n }\r\n}\r\n"]}
|
|
1
|
+
{"version":3,"file":"MapFeatureInfoDecorator.js","sourceRoot":"","sources":["../../../src/Tools/MapFeatureInfoDecorator.ts"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\n* See LICENSE.md in the project root for license terms and full copyright notice.\n*--------------------------------------------------------------------------------------------*/\nimport { Base64EncodedString, ColorDef } from \"@itwin/core-common\";\nimport {\n BeButtonEvent, Cluster, DecorateContext, Decorator,\n GeometryTileTreeReference, GraphicBuilder, GraphicPrimitive, GraphicType, IModelApp, MapTileTreeReference, Marker, MarkerImage, MarkerSet,\n ScreenViewport,\n TileTreeReference, Viewport } from \"@itwin/core-frontend\";\nimport { GrowableXYZArray, LineString3d, Point2d, Point3d, Polyface, Range3d, Transform, XAndY, XYAndZ } from \"@itwin/core-geometry\";\nimport { MapFeatureInfoToolData } from \"./MapFeatureInfoTool\";\nimport { GeometryTerrainDraper } from \"./GeometryTerrainDraper\";\nimport { Logger } from \"@itwin/core-bentley\";\nconst loggerCategory = \"MapLayersFormats.MapFeatureInfoDecorator\";\n\n/** @internal */\nclass PinMarker extends Marker {\n public constructor(worldLocation: XYAndZ, size: XAndY, image: MarkerImage) {\n super(worldLocation, size);\n this.image = image;\n this.imageOffset = new Point3d(0, Math.floor(size.y * .5));\n }\n}\n\n/** @internal */\nclass PinMarkerCluster extends Marker {\n /** Create a new cluster marker */\n constructor(location: XYAndZ, size: XAndY, cluster: Cluster<PinMarker>, image: MarkerImage | Promise<MarkerImage> | undefined) {\n super(location, size);\n\n this.title = IModelApp.localization.getLocalizedString(\"mapLayersFormats:Messages.MapFeatureInfoDecorator.clusterZoomIn\", { nbInstances: cluster.markers.length});\n\n this.imageOffset = new Point3d(0, size.y * 0.5);\n this.label = cluster.markers.length.toLocaleString();\n this.labelColor = \"black\";\n this.labelFont = \"bold 14px sans-serif\";\n\n if (image)\n this.setImage(image);\n }\n\n /** Show the cluster as a white circle with an outline */\n public override drawFunc(ctx: CanvasRenderingContext2D): void {\n ctx.beginPath();\n ctx.strokeStyle = \"#372528\";\n ctx.fillStyle = \"white\";\n ctx.lineWidth = 5;\n ctx.arc(0, 0, this.size.x * 0.5, 0, Math.PI * 2);\n ctx.fill();\n ctx.stroke();\n }\n\n public override onMouseButton(_ev: BeButtonEvent): boolean { return true; } // Don't allow clicks to be sent to active tool...\n}\n\n/** @internal */\nclass PinMarkerSet extends MarkerSet<PinMarker> {\n protected getClusterMarker(cluster: Cluster<PinMarker>): Marker {\n // No image passed to the cluster, we prefer to have the circle only\n return new PinMarkerCluster(cluster.getClusterLocation(), cluster.markers[0].size, cluster, undefined);\n }\n}\n\ninterface DrapeGraphicState {\n graphic: GraphicPrimitive;\n collectorState: string;\n chordTolerance: number;\n range: Range3d;\n}\n\nclass DrapedPrimitives {\n private _strings?: LineString3d[];\n private _meshes?: Polyface[];\n private _points = new GrowableXYZArray();\n\n public get strings() {\n return this._strings;\n }\n\n public get meshes() {\n return this._meshes;\n }\n\n public get points() {\n return this._points;\n }\n\n public clear() {\n this._strings = undefined;\n this._meshes = undefined;\n this._points.clear();\n }\n\n public addStrings(drapedStrings: LineString3d[]) {\n if (!this._strings) {\n this._strings = [];\n }\n for (const ds of drapedStrings)\n this._strings.push(ds);\n }\n\n public addMeshes(drapedMeshes: Polyface[]) {\n if (!this._meshes)\n this._meshes = [];\n drapedMeshes.forEach((ds) => this._meshes!.push(ds));\n }\n}\n\n/** @internal */\nexport class MapFeatureInfoDecorator implements Decorator {\n public hidden = false;\n public readonly useCachedDecorations = true;\n public readonly disableTerrainDraper = false;\n public markerSize = new Point2d(32, 32);\n public lineWidth = 3;\n\n // This is the maximum allowed size of a geometry, in pixels, to be draped.\n // If the value is too large, we will end up downloading tons of terrain tiles, and possibly hang for too long.\n public maxDrapeSizePixels = 50000;\n\n // This value controls the chord tolerance used to collect terrain tiles\n // at the \"right\" resolution. Higher values, will give coarser terrain tiles.\n public chordTolerancePixels = 20;\n\n private _highlightColor = ColorDef.from(0, 255, 255, 127);\n public get highlightColor() { return this._highlightColor;}\n public set highlightColor(color: ColorDef) {\n this.updateMarkerImage();\n this._highlightColor = color;\n }\n\n public get defaultMarkerIconSvgXml() { return `<svg class=\"indicator\" viewBox=\"0 0 22 22\" width=\"22\" height=\"22\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"m11 0a7.44506 7.44506 0 0 0 -7.5 7.2875c0 1.65 1.132 4.2625 3.25477 8.1125 1.55652 2.75 4.24523 6.6 4.24523 6.6s2.68865-3.9875 4.24528-6.7375c2.12272-3.85 3.25472-6.4625 3.25472-8.1125a7.4215 7.4215 0 0 0 -7.5-7.15z\" fill=\"black\"/><path d=\"m11 1.01715a6.46476 6.46476 0 0 0 -6.48285 6.27033c0 1.72619 1.67181 4.97973 3.12836 7.62139.97564 1.7237 2.42828 3.92176 3.34118 5.27161.91413-1.39148 2.385-3.673 3.37336-5.41907 1.451-2.63171 3.1228-5.88525 3.1228-7.61139a6.39982 6.39982 0 0 0 -6.48285-6.13287zm.00183 8.98285a3 3 0 1 1 3-3 3 3 0 0 1 -3 3z\" fill=\"${this.highlightColor.toRgbString()}\"/></svg>`; }\n\n private _scratchPoints = new GrowableXYZArray();\n\n private _drapeGraphicsStates: DrapeGraphicState[] = [];\n private _drapedPrimitives = new DrapedPrimitives();\n private _allGeomDraped = false;\n private _draper?: GeometryTerrainDraper;\n private _markerImage: HTMLImageElement;\n private _markerSet = new PinMarkerSet();\n\n // Extra markers can be added outside the normal state\n public extraMarkers: Point3d[]|undefined;\n\n private _data: MapFeatureInfoToolData | undefined;\n\n private readonly _graphicType = GraphicType.WorldOverlay;\n\n public constructor() {\n this._markerImage = new Image();\n this.updateMarkerImage();\n }\n\n private updateMarkerImage() {\n const base64 = Base64EncodedString.encode(this.defaultMarkerIconSvgXml);\n this._markerImage.src = `data:image/svg+xml;base64,${base64}`;\n }\n\n private computePixelSize(viewport: Viewport, applyAspectRatioSkew: boolean, pointWorld: Point3d) {\n let pixelSize = 1;\n // Compute the horizontal distance in meters between two adjacent pixels at the center of the geometry.\n pixelSize = viewport.getPixelSizeAtPoint(pointWorld);\n pixelSize = viewport.target.adjustPixelSizeForLOD(pixelSize);\n\n // Aspect ratio skew > 1.0 stretches the view in Y. In that case use the smaller vertical pixel distance for our stroke tolerance.\n const skew = applyAspectRatioSkew ? viewport.view.getAspectRatioSkew() : 0;\n if (skew > 1)\n pixelSize /= skew;\n return pixelSize * 0.25;\n }\n\n private computeChordTolerance(viewport: Viewport, drapeRange: Range3d) {\n const drapeSizeWorld = Math.max(drapeRange.xLength(), drapeRange.yLength());\n const pixelSize = this.computePixelSize(viewport, true, drapeRange.center);\n const maxDrapeRangeSizeRatio = this.maxDrapeSizePixels / (drapeSizeWorld / pixelSize);\n if (maxDrapeRangeSizeRatio < 1) {\n Logger.logWarning(loggerCategory, \"Element too large; chord tolerance was adjusted\");\n return (pixelSize / maxDrapeRangeSizeRatio)*this.chordTolerancePixels;\n }\n return pixelSize*this.chordTolerancePixels;\n };\n\n public clearData = () => {\n this._data = undefined;\n };\n\n public setData = (data: MapFeatureInfoToolData) => {\n\n this._drapedPrimitives.clear();\n this._allGeomDraped = false;\n this.hidden = false;\n\n this._data = data;\n IModelApp.viewManager.invalidateCachedDecorationsAllViews(this);\n\n this._drapeGraphicsStates = [];\n\n if (!this.disableTerrainDraper && this._data.mapInfo?.layerInfos && data.hit.viewport.displayStyle.displayTerrain) {\n\n if (data.hit?.modelId) {\n const drapeTreeRef = this.getGeometryTreeRef(data.hit.viewport);\n if (drapeTreeRef) {\n this._draper = new GeometryTerrainDraper(data.hit.viewport, drapeTreeRef);\n return;\n }\n }\n }\n\n if (this._draper) {\n // Dispose draper every time?\n this._draper.dispose();\n this._draper = undefined;\n }\n };\n\n private getGeometryTreeRef(vp: Viewport): GeometryTileTreeReference | undefined {\n let treeRef: GeometryTileTreeReference | undefined;\n if (vp.backgroundMapSettings.applyTerrain) {\n vp.forEachMapTreeRef((ref: TileTreeReference) => {\n if (!treeRef && ref instanceof MapTileTreeReference) {\n treeRef = ref.createGeometryTreeReference();\n }\n });\n }\n\n return treeRef;\n }\n\n protected renderGraphics(context: DecorateContext) {\n this._markerSet.markers.clear();\n\n if (this._data?.mapInfo?.layerInfos === undefined || this.hidden) {\n return undefined;\n }\n\n let transform: Transform|undefined;\n const groundBias = context.viewport.displayStyle.backgroundMapSettings.groundBias;\n if (groundBias !== 0) {\n transform = Transform.createTranslationXYZ(0, 0 , groundBias);\n }\n const builder = context.createGraphicBuilder(this._graphicType, transform);\n\n if (this._draper) {\n this.initializeDrapeState(context.viewport);\n\n // We need to call drapeGeometries() until it returns true (i.e. fully complete)\n if (!this._allGeomDraped) {\n if (!this.drapeGeometries(context.viewport))\n return undefined;\n }\n\n this.appendDrapedGeometries(builder);\n } else {\n // Append geometries straight from the state to the builder\n this.appendGeometries(builder);\n }\n\n // Add extra markers if any specified\n if ( this.extraMarkers !== undefined) {\n this.extraMarkers.forEach((markerPoint)=> {\n builder.setSymbology(this.highlightColor, this.highlightColor, this.lineWidth);\n this._markerSet.markers.add(new PinMarker(markerPoint, this.markerSize, this._markerImage));\n });\n }\n\n return builder.finish();\n }\n\n // Iterates the mapfeatureinfo data and create a draping state for each entry\n private initializeDrapeState(viewport: ScreenViewport) {\n if (this._drapeGraphicsStates.length === 0) {\n const getGraphicRange = (graphic: GraphicPrimitive) => {\n if (graphic.type === \"linestring\")\n return Range3d.createArray(graphic.points);\n else if (graphic.type === \"loop\")\n return graphic.loop.range();\n else if (graphic.type === \"pointstring\")\n return Range3d.createArray(graphic.points);\n else\n return Range3d.createNull();\n };\n\n for (const layerInfo of this._data?.mapInfo?.layerInfos??[]) {\n for (const subLayerInfo of layerInfo?.subLayerInfos??[]) {\n for (const feature of subLayerInfo.features) {\n\n feature.geometries?.forEach(((geom)=> {\n const range = getGraphicRange(geom.graphic);\n this._drapeGraphicsStates.push({\n graphic: geom.graphic,\n collectorState: \"loading\",\n chordTolerance: this.computeChordTolerance(viewport, range),\n range,\n });\n } ));\n }\n }\n }\n }\n }\n\n // returns true when all geometries are fully draped; otherwise false\n private drapeGeometries(_viewport: ScreenViewport): boolean {\n if (!this._draper)\n return false;\n\n let hasMissingDrapeGeoms = false;\n for (const state of this._drapeGraphicsStates) {\n if (state.collectorState === \"loading\") {\n this._scratchPoints.clear();\n\n if (state.graphic.type === \"linestring\") {\n this._scratchPoints.pushAll(state.graphic.points);\n const drapedStrings: LineString3d[] = [];\n if (\"loading\" === this._draper.drapeLineString(drapedStrings, this._scratchPoints, state.chordTolerance, state.range)) {\n hasMissingDrapeGeoms = true;\n break;\n } else {\n this._drapedPrimitives.addStrings(drapedStrings);\n state.collectorState = \"complete\";\n }\n } else if (state.graphic.type === \"loop\") {\n const loop = state.graphic.loop;\n const outMeshes: Polyface[] = [];\n if (\"loading\" === this._draper.drapeLoop(outMeshes, loop, state.chordTolerance, state.range)) {\n hasMissingDrapeGeoms = true;\n break; // We drape each graphic sequentially, otherwise collector get messed up.\n } else {\n this._drapedPrimitives.addMeshes(outMeshes);\n state.collectorState = \"complete\";\n }\n } else if (state.graphic.type === \"pointstring\") {\n const outPoint = Point3d.createZero();\n for (const point of state.graphic.points) {\n if (\"loading\" === this._draper.drapePoint(outPoint, point, state.chordTolerance, state.range)) {\n this._allGeomDraped = false;\n return false;\n } else if (!outPoint.isZero) {\n this._drapedPrimitives.points.push(outPoint);\n }\n }\n }\n }\n }\n\n this._allGeomDraped = !hasMissingDrapeGeoms;\n return this._allGeomDraped;\n }\n\n private appendDrapedGeometries(builder: GraphicBuilder) {\n if (this._drapedPrimitives.strings) {\n builder.setSymbology(this.highlightColor, this.highlightColor, this.lineWidth);\n this._drapedPrimitives.strings.forEach((line) => builder.addLineString(line.points));\n }\n\n if (this._drapedPrimitives.meshes) {\n builder.setSymbology(this.highlightColor, this.highlightColor, this.lineWidth);\n this._drapedPrimitives.meshes.forEach((polyface) => builder.addPolyface(polyface, true));\n }\n\n if (this._drapedPrimitives.points.length > 0) {\n for (let i = 0; i < this._drapedPrimitives.points.length; i++) {\n this._markerSet.markers.add(new PinMarker(this._drapedPrimitives.points.getPoint3dAtUncheckedPointIndex(i), this.markerSize, this._markerImage));\n }\n }\n }\n\n private appendGeometries(builder: GraphicBuilder) {\n if (!this._data?.mapInfo?.layerInfos)\n return;\n\n builder.setSymbology(this.highlightColor, this.highlightColor, this.lineWidth);\n for (const layerInfo of this._data.mapInfo.layerInfos) {\n if (layerInfo.subLayerInfos && !(layerInfo.subLayerInfos instanceof HTMLElement)) {\n for (const subLayerInfo of layerInfo.subLayerInfos) {\n for (const feature of subLayerInfo.features) {\n if (feature.geometries) {\n for (const geom of feature.geometries) {\n if (geom.graphic.type === \"pointstring\") {\n for (const point of geom.graphic.points)\n this._markerSet.markers.add(new PinMarker(point, this.markerSize, this._markerImage));\n } else {\n builder.addPrimitive(geom.graphic);\n }\n\n }\n }\n }\n }\n\n }\n\n }\n }\n\n public decorate(context: DecorateContext): void {\n const graphics = this.renderGraphics(context);\n if (graphics) {\n context.addDecoration(this._graphicType, graphics);\n IModelApp.toolAdmin.setCursor(undefined);\n }\n\n this._markerSet.addDecoration(context);\n return;\n }\n}\n"]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MapFeatureInfoTool.d.ts","sourceRoot":"","sources":["../../../src/Tools/MapFeatureInfoTool.ts"],"names":[],"mappings":"AAIA;;GAEG;AAEH,OAAO,EACL,aAAa,EACb,YAAY,EACZ,SAAS,EAET,kBAAkB,EAClB,cAAc,EACd,cAAc,EAId,aAAa,EAOd,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAK9C;;;;GAIG;AACH,MAAM,WAAW,sBAAsB;IACrC,GAAG,EAAE,SAAS,CAAC;IACf,OAAO,CAAC,EAAE,cAAc,CAAC;CAC1B;AAqED;;;;;GAKG;AACH,qBAAa,kBAAmB,SAAQ,aAAa;IACnD,SAAgB,WAAW,iBAAsB,sBAAsB,KAAK,IAAI,EAAI;IACpF,SAAgB,aAAa,kDAAkB;IAE/C,OAAuB,MAAM,SAAwB;IACrD,OAAuB,QAAQ,moCAAuB;IAEtD,OAAO,CAAC,UAAU,CAA0D;IAC5E,OAAO,CAAC,mBAAmB,CAAiD;IAE5E,OAAO,CAAC,MAAM,CAAkD;IAChE,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAsB;IACvD,OAAO,CAAE,0BAA0B,CAAyB;IAE5C,sBAAsB,IAAI,OAAO;IAIjD,gBAAgB;IAChB,SAAS,CAAC,2BAA2B,IAAI,IAAI;IAI7C,OAAO,CAAC,eAAe;IAaD,aAAa;IA4Db,SAAS;IAU/B;;;;;OAKG;IACH,OAAO,CAAC,sBAAsB;IAaR,UAAU,CAAC,GAAG,EAAE,SAAS,GAAG,OAAO,CAAC,WAAW,GAAG,MAAM,CAAC;IASzD,SAAS,CAAC,GAAG,EAAE,SAAS,EAAE,IAAI,CAAC,EAAE,cAAc,GAAG,OAAO,CAAC,kBAAkB,CAAC;IAI7E,gBAAgB,CACpC,EAAE,EAAE,aAAa,GAChB,OAAO,CAAC,YAAY,CAAC;
|
|
1
|
+
{"version":3,"file":"MapFeatureInfoTool.d.ts","sourceRoot":"","sources":["../../../src/Tools/MapFeatureInfoTool.ts"],"names":[],"mappings":"AAIA;;GAEG;AAEH,OAAO,EACL,aAAa,EACb,YAAY,EACZ,SAAS,EAET,kBAAkB,EAClB,cAAc,EACd,cAAc,EAId,aAAa,EAOd,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAK9C;;;;GAIG;AACH,MAAM,WAAW,sBAAsB;IACrC,GAAG,EAAE,SAAS,CAAC;IACf,OAAO,CAAC,EAAE,cAAc,CAAC;CAC1B;AAqED;;;;;GAKG;AACH,qBAAa,kBAAmB,SAAQ,aAAa;IACnD,SAAgB,WAAW,iBAAsB,sBAAsB,KAAK,IAAI,EAAI;IACpF,SAAgB,aAAa,kDAAkB;IAE/C,OAAuB,MAAM,SAAwB;IACrD,OAAuB,QAAQ,moCAAuB;IAEtD,OAAO,CAAC,UAAU,CAA0D;IAC5E,OAAO,CAAC,mBAAmB,CAAiD;IAE5E,OAAO,CAAC,MAAM,CAAkD;IAChE,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAsB;IACvD,OAAO,CAAE,0BAA0B,CAAyB;IAE5C,sBAAsB,IAAI,OAAO;IAIjD,gBAAgB;IAChB,SAAS,CAAC,2BAA2B,IAAI,IAAI;IAI7C,OAAO,CAAC,eAAe;IAaD,aAAa;IA4Db,SAAS;IAU/B;;;;;OAKG;IACH,OAAO,CAAC,sBAAsB;IAaR,UAAU,CAAC,GAAG,EAAE,SAAS,GAAG,OAAO,CAAC,WAAW,GAAG,MAAM,CAAC;IASzD,SAAS,CAAC,GAAG,EAAE,SAAS,EAAE,IAAI,CAAC,EAAE,cAAc,GAAG,OAAO,CAAC,kBAAkB,CAAC;IAI7E,gBAAgB,CACpC,EAAE,EAAE,aAAa,GAChB,OAAO,CAAC,YAAY,CAAC;IAmCF,eAAe,CACnC,GAAG,EAAE,aAAa,GACjB,OAAO,CAAC,YAAY,CAAC;IAOF,aAAa;IAMnC,gBAAgB;IAChB,SAAS,CAAC,UAAU,IAAI,IAAI;CAmB7B"}
|
|
@@ -101,7 +101,7 @@ export class MapFeatureInfoTool extends PrimitiveTool {
|
|
|
101
101
|
else {
|
|
102
102
|
// Flush existing decorations until a new selection is made
|
|
103
103
|
this.onInfoCleared.raiseEvent();
|
|
104
|
-
this._decorator.
|
|
104
|
+
this._decorator.clearData();
|
|
105
105
|
}
|
|
106
106
|
vp.invalidateDecorations();
|
|
107
107
|
}
|
|
@@ -202,10 +202,13 @@ export class MapFeatureInfoTool extends PrimitiveTool {
|
|
|
202
202
|
const pixelRadius = Math.floor(aperture + 0.5);
|
|
203
203
|
mapInfo = await hit.viewport.getMapFeatureInfo(hit, { tolerance: pixelRadius });
|
|
204
204
|
if (mapInfo) {
|
|
205
|
-
this._decorator.
|
|
205
|
+
this._decorator.setData({ hit, mapInfo });
|
|
206
|
+
}
|
|
207
|
+
else {
|
|
208
|
+
IModelApp.toolAdmin.setCursor(undefined);
|
|
206
209
|
}
|
|
207
210
|
}
|
|
208
|
-
|
|
211
|
+
catch {
|
|
209
212
|
IModelApp.toolAdmin.setCursor(undefined);
|
|
210
213
|
}
|
|
211
214
|
}
|