@itwin/core-frontend 4.4.0-dev.2 → 4.4.0-dev.21
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/CHANGELOG.md +23 -1
- package/lib/cjs/extension/ExtensionRuntime.js +1 -0
- package/lib/cjs/extension/ExtensionRuntime.js.map +1 -1
- package/lib/cjs/render/ParticleCollectionBuilder.d.ts +4 -1
- package/lib/cjs/render/ParticleCollectionBuilder.d.ts.map +1 -1
- package/lib/cjs/render/ParticleCollectionBuilder.js +4 -1
- package/lib/cjs/render/ParticleCollectionBuilder.js.map +1 -1
- package/lib/cjs/render/webgl/InstancedGeometry.d.ts +1 -0
- package/lib/cjs/render/webgl/InstancedGeometry.d.ts.map +1 -1
- package/lib/cjs/render/webgl/InstancedGeometry.js +1 -0
- package/lib/cjs/render/webgl/InstancedGeometry.js.map +1 -1
- package/lib/cjs/tile/ThreeDTileFormatInterpreter.d.ts.map +1 -1
- package/lib/cjs/tile/ThreeDTileFormatInterpreter.js +8 -6
- package/lib/cjs/tile/ThreeDTileFormatInterpreter.js.map +1 -1
- package/lib/cjs/tile/map/ArcGISTileMap.d.ts +6 -2
- package/lib/cjs/tile/map/ArcGISTileMap.d.ts.map +1 -1
- package/lib/cjs/tile/map/ArcGISTileMap.js +127 -69
- package/lib/cjs/tile/map/ArcGISTileMap.js.map +1 -1
- package/lib/cjs/tile/map/ImageryProviders/ArcGISMapLayerImageryProvider.js +1 -1
- package/lib/cjs/tile/map/ImageryProviders/ArcGISMapLayerImageryProvider.js.map +1 -1
- package/lib/cjs/tools/SelectTool.d.ts +1 -0
- package/lib/cjs/tools/SelectTool.d.ts.map +1 -1
- package/lib/cjs/tools/SelectTool.js +19 -13
- package/lib/cjs/tools/SelectTool.js.map +1 -1
- package/lib/esm/extension/ExtensionRuntime.js +2 -1
- package/lib/esm/extension/ExtensionRuntime.js.map +1 -1
- package/lib/esm/render/ParticleCollectionBuilder.d.ts +4 -1
- package/lib/esm/render/ParticleCollectionBuilder.d.ts.map +1 -1
- package/lib/esm/render/ParticleCollectionBuilder.js +4 -1
- package/lib/esm/render/ParticleCollectionBuilder.js.map +1 -1
- package/lib/esm/render/webgl/InstancedGeometry.d.ts +1 -0
- package/lib/esm/render/webgl/InstancedGeometry.d.ts.map +1 -1
- package/lib/esm/render/webgl/InstancedGeometry.js +1 -0
- package/lib/esm/render/webgl/InstancedGeometry.js.map +1 -1
- package/lib/esm/tile/ThreeDTileFormatInterpreter.d.ts.map +1 -1
- package/lib/esm/tile/ThreeDTileFormatInterpreter.js +9 -7
- package/lib/esm/tile/ThreeDTileFormatInterpreter.js.map +1 -1
- package/lib/esm/tile/map/ArcGISTileMap.d.ts +6 -2
- package/lib/esm/tile/map/ArcGISTileMap.d.ts.map +1 -1
- package/lib/esm/tile/map/ArcGISTileMap.js +130 -71
- package/lib/esm/tile/map/ArcGISTileMap.js.map +1 -1
- package/lib/esm/tile/map/ImageryProviders/ArcGISMapLayerImageryProvider.js +1 -1
- package/lib/esm/tile/map/ImageryProviders/ArcGISMapLayerImageryProvider.js.map +1 -1
- package/lib/esm/tools/SelectTool.d.ts +1 -0
- package/lib/esm/tools/SelectTool.d.ts.map +1 -1
- package/lib/esm/tools/SelectTool.js +19 -13
- package/lib/esm/tools/SelectTool.js.map +1 -1
- package/lib/public/scripts/parse-imdl-worker.js +1 -1
- package/lib/workers/webpack/parse-imdl-worker.js +1 -1
- package/package.json +24 -24
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ArcGISMapLayerImageryProvider.js","sourceRoot":"","sources":["../../../../../src/tile/map/ImageryProviders/ArcGISMapLayerImageryProvider.ts"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\r\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\r\n* See LICENSE.md in the project root for license terms and full copyright notice.\r\n*--------------------------------------------------------------------------------------------*/\r\n/** @packageDocumentation\r\n * @module Tiles\r\n */\r\nimport { Cartographic, ImageMapLayerSettings, ImageSource, IModelStatus, ServerError } from \"@itwin/core-common\";\r\nimport { IModelApp } from \"../../../IModelApp\";\r\nimport {\r\n ArcGisErrorCode, ArcGisGeometryReaderJSON, ArcGisGraphicsRenderer, ArcGISImageryProvider, ArcGISTileMap,\r\n ArcGisUtilities, ImageryMapTileTree, MapCartoRectangle, MapFeatureInfoOptions, MapLayerFeature,\r\n MapLayerFeatureInfo, MapLayerImageryProviderStatus, MapSubLayerFeatureInfo, QuadId,\r\n} from \"../../internal\";\r\nimport { PropertyValueFormat, StandardTypeNames } from \"@itwin/appui-abstract\";\r\nimport { Point2d, Range2d, Range2dProps, XYProps } from \"@itwin/core-geometry\";\r\nimport { Logger } from \"@itwin/core-bentley\";\r\nimport { HitDetail } from \"../../../HitDetail\";\r\n\r\nconst loggerCategory = \"MapLayerImageryProvider.ArcGISMapLayerImageryProvider\";\r\n\r\n/** @internal */\r\nexport interface ArcGISIdentifyImageDisplayProps {\r\n width: number;\r\n height: number;\r\n dpi: number;\r\n}\r\n\r\n/** @internal */\r\nexport interface ArcGISIdentifyLayersProps {\r\n prefix: \"top\"|\"visible\"|\"all\";\r\n layerIds?: string[];\r\n}\r\n\r\n/** @internal */\r\nexport interface ArcGISIdentifyRequestUrlProps {\r\n /** The geometry to identify on. Point only support */\r\n geometry: XYProps;\r\n\r\n /** The type of geometry specified by the geometry parameter. Point only support */\r\n geometryType: \"esriGeometryPoint\";\r\n\r\n /** The well-known ID of the spatial reference of the input and output geometries as well as the mapExtent. */\r\n sr?: number;\r\n\r\n /** The layers to perform the identify operation on. The default value is top.\r\n * Format: [top | visible | all]:layerId1,layerId2\r\n */\r\n layers?: ArcGISIdentifyLayersProps;\r\n\r\n /** The distance in screen pixels from the specified geometry within which the identify operation should be performed.\r\n * The value for the tolerance is an integer.\r\n */\r\n tolerance: number;\r\n\r\n /** The extent or bounding box of the map currently being viewed.\r\n * Format: <xmin>, <ymin>, <xmax>, <ymax>\r\n */\r\n mapExtent: Range2dProps;\r\n\r\n /** The screen image display parameters (width, height, and DPI) of the map being currently viewed. T\r\n * Format: <width>,<height>,<dpi>\r\n */\r\n imageDisplay: ArcGISIdentifyImageDisplayProps;\r\n\r\n /** If true, the result set will include the geometries associated with each result. The default is true.\r\n */\r\n returnGeometry?: boolean;\r\n\r\n /** This option can be used to specify the maximum allowable offset to be used for generalizing geometries returned by the identify operation.\r\n * The maxAllowableOffset is in the units of the sr.\r\n */\r\n maxAllowableOffset?: number;\r\n\r\n /** The response format. The default response format is html.\r\n */\r\n f?: \"json\"|\"html\";\r\n\r\n}\r\n\r\n/** @internal */\r\nexport class ArcGISIdentifyRequestUrl {\r\n public static fromJSON(baseUrl: URL|string, json: ArcGISIdentifyRequestUrlProps, srFractionDigits?: number): URL {\r\n\r\n const newUrl = new URL(baseUrl);\r\n newUrl.pathname = `${newUrl.pathname}/identify`;\r\n\r\n if (json.f) {\r\n newUrl.searchParams.append(\"f\", json.f);\r\n }\r\n\r\n const geomPt = Point2d.fromJSON(json.geometry);\r\n newUrl.searchParams.append(\"geometry\", `${this.toFixed(geomPt.x, srFractionDigits)},${this.toFixed(geomPt.y, srFractionDigits)}`);\r\n newUrl.searchParams.append(\"geometryType\", json.geometryType);\r\n\r\n if (json.sr) {\r\n newUrl.searchParams.append(\"sr\", `${json.sr}`);\r\n }\r\n\r\n if (json.layers) {\r\n newUrl.searchParams.append(\"layers\", `${json.layers.prefix}${json.layers.layerIds?.length ? `: ${json.layers.layerIds.join(\",\")}` : \"\"}`);\r\n }\r\n\r\n newUrl.searchParams.append(\"tolerance\", `${json.tolerance}`);\r\n\r\n newUrl.searchParams.append(\"mapExtent\", ArcGISIdentifyRequestUrl.getExtentString(json.mapExtent, srFractionDigits));\r\n\r\n newUrl.searchParams.append(\"imageDisplay\", `${json.imageDisplay.width},${json.imageDisplay.height},${json.imageDisplay.dpi}`);\r\n\r\n if (json.returnGeometry !== undefined) {\r\n newUrl.searchParams.append(\"returnGeometry\", json.returnGeometry ? \"true\" : \"false\");\r\n }\r\n\r\n if (json.maxAllowableOffset !== undefined) {\r\n newUrl.searchParams.append(\"maxAllowableOffset\", `${this.toFixed(json.maxAllowableOffset, srFractionDigits)}`);\r\n }\r\n\r\n return newUrl;\r\n }\r\n\r\n public static toFixed(value: number, srFractionDigits?: number) {\r\n return srFractionDigits === undefined ? value.toString() : value.toFixed(srFractionDigits);\r\n }\r\n\r\n public static getExtentString(range: Range2dProps, srFractionDigits?: number) {\r\n const extent = Range2d.fromJSON(range);\r\n const extentStringArray: string[] = [];\r\n extent.toFloat64Array().forEach((value) => extentStringArray.push(this.toFixed(value, srFractionDigits)));\r\n return extentStringArray.join(\",\");\r\n }\r\n}\r\n\r\n/** @internal */\r\nexport class ArcGISMapLayerImageryProvider extends ArcGISImageryProvider {\r\n private _maxDepthFromLod = 0;\r\n private _minDepthFromLod = 0;\r\n private _copyrightText = \"Copyright\";\r\n private _tileMapSupported = false;\r\n private _mapSupported = false;\r\n private _tilesOnly = false;\r\n private _tileMap: ArcGISTileMap|undefined;\r\n\r\n public serviceJson: any;\r\n constructor(settings: ImageMapLayerSettings) {\r\n super(settings, false);\r\n this._accessClient = IModelApp.mapLayerFormatRegistry.getAccessClient(settings.formatId);\r\n }\r\n\r\n protected override get _filterByCartoRange() { return false; } // Can't trust footprint ranges (USGS Hydro)\r\n\r\n public override get minimumZoomLevel() { return Math.max(super.minimumZoomLevel, this._minDepthFromLod); }\r\n public override get maximumZoomLevel() { return this._maxDepthFromLod > 0 ? this._maxDepthFromLod : super.maximumZoomLevel; }\r\n\r\n public uintToString(uintArray: any) {\r\n return Buffer.from(uintArray).toJSON();\r\n\r\n }\r\n\r\n private async fetchTile(row: number, column: number, zoomLevel: number) {\r\n const tileUrl: string = await this.constructUrl(row, column, zoomLevel);\r\n if (tileUrl.length === 0)\r\n return undefined;\r\n return this.fetch(new URL(tileUrl), { method: \"GET\" });\r\n }\r\n\r\n public override async loadTile(row: number, column: number, zoomLevel: number): Promise<ImageSource | undefined> {\r\n if ((this.status === MapLayerImageryProviderStatus.RequireAuth)) {\r\n return undefined;\r\n }\r\n\r\n try {\r\n const tileResponse = await this.fetchTile(row, column, zoomLevel);\r\n if (tileResponse === undefined)\r\n return undefined;\r\n\r\n if (!this._hasSuccessfullyFetchedTile) {\r\n this._hasSuccessfullyFetchedTile = true;\r\n }\r\n return await this.getImageFromTileResponse(tileResponse, zoomLevel);\r\n } catch (error) {\r\n Logger.logError(loggerCategory, `Error occurred when loading tile(${row},${column},${zoomLevel}) : ${error}`);\r\n return undefined;\r\n }\r\n }\r\n\r\n protected override _generateChildIds(quadId: QuadId, resolveChildren: (childIds: QuadId[]) => void) {\r\n const childIds = this.getPotentialChildIds(quadId);\r\n if (quadId.level < Math.max(1, this.minimumZoomLevel-1)) {\r\n resolveChildren(childIds);\r\n return;\r\n }\r\n\r\n if (this._tileMap) {\r\n // eslint-disable-next-line @typescript-eslint/no-floating-promises\r\n this._tileMap.getChildrenAvailability(childIds).then((availability) => {\r\n const availableChildIds = new Array<QuadId>();\r\n for (let i = 0; i < availability.length; i++)\r\n if (availability[i])\r\n availableChildIds.push(childIds[i]);\r\n\r\n resolveChildren (availableChildIds);\r\n });\r\n } else if (this._usesCachedTiles && this.cartoRange) {\r\n // Filter children by range\r\n const availableChildIds = new Array<QuadId>();\r\n // eslint-disable-next-line @typescript-eslint/prefer-for-of\r\n for (let i = 0; i < childIds.length; i++) {\r\n const childExtent = this.getEPSG4326Extent(childIds[i].row, childIds[i].column, childIds[i].level);\r\n\r\n const childRange = MapCartoRectangle.fromDegrees(childExtent.longitudeLeft, childExtent.latitudeBottom, childExtent.longitudeRight, childExtent.latitudeTop);\r\n if (childRange.intersectsRange(this.cartoRange)) {\r\n availableChildIds.push(childIds[i]);\r\n }\r\n }\r\n resolveChildren (availableChildIds);\r\n } else {\r\n resolveChildren (childIds); // Resolve all children\r\n }\r\n }\r\n\r\n public override async initialize(): Promise<void> {\r\n\r\n const metadata = await this.getServiceJson();\r\n\r\n if (metadata?.content === undefined)\r\n throw new ServerError(IModelStatus.ValidationFailed, \"\");\r\n\r\n const json = metadata.content;\r\n if (json?.error?.code === ArcGisErrorCode.TokenRequired || json?.error?.code === ArcGisErrorCode.InvalidToken) {\r\n // Check again layer status, it might have change during await.\r\n if (this.status === MapLayerImageryProviderStatus.Valid) {\r\n this.setStatus(MapLayerImageryProviderStatus.RequireAuth);\r\n return; // By returning (i.e not throwing), we ensure the tileTree get created and current provider is preserved to report status.\r\n }\r\n }\r\n\r\n this.serviceJson = json;\r\n\r\n if (json.capabilities) {\r\n const capabilities = json.capabilities.split(\",\");\r\n\r\n this._querySupported = capabilities.includes(\"Query\");\r\n this._tileMapSupported = capabilities.includes(\"Tilemap\");\r\n this._mapSupported = capabilities.includes(\"Map\");\r\n this._tilesOnly = capabilities.includes(\"TilesOnly\");\r\n }\r\n\r\n if (json.copyrightText)\r\n this._copyrightText = json.copyrightText;\r\n\r\n this._usesCachedTiles = !!json.tileInfo;\r\n\r\n if (this._usesCachedTiles) {\r\n // Only EPSG:3857 is supported with pre-rendered tiles. Fall back to 'Export' queries if possible otherwise throw.\r\n if (!ArcGisUtilities.isEpsg3857Compatible(json.tileInfo)) {\r\n if (this._mapSupported && !this._tilesOnly) {\r\n this._usesCachedTiles = false;\r\n } else {\r\n throw new ServerError(IModelStatus.ValidationFailed, \"Invalid coordinate system\");\r\n }\r\n }\r\n }\r\n\r\n if (this._usesCachedTiles) {\r\n // Read max LOD\r\n if (json.maxScale !== undefined && json.maxScale !== 0 && Array.isArray(json.tileInfo.lods)) {\r\n for (; this._maxDepthFromLod < json.tileInfo.lods.length && json.tileInfo.lods[this._maxDepthFromLod].scale > json.maxScale; this._maxDepthFromLod++)\r\n ;\r\n }\r\n\r\n // Create tile map object only if we are going to request tiles from this server and it support tilemap requests.\r\n if (this._tileMapSupported) {\r\n const fetch = async (url: URL, options?: RequestInit): Promise<Response> => {\r\n return this.fetch(url, options);\r\n };\r\n this._tileMap = new ArcGISTileMap(this._settings.url, this._settings, fetch, json.tileInfo?.lods?.length);\r\n }\r\n }\r\n\r\n // Read range using fullextent from service metadata\r\n if (json.fullExtent) {\r\n if (json.fullExtent.spatialReference.latestWkid === 3857 || json.fullExtent.spatialReference.wkid === 102100) {\r\n const range3857 = Range2d.createFrom({\r\n low: {x: json.fullExtent.xmin, y: json.fullExtent.ymin},\r\n high: {x: json.fullExtent.xmax, y: json.fullExtent.ymax} });\r\n\r\n const west = this.getEPSG4326Lon(range3857.xLow);\r\n const south = this.getEPSG4326Lat(range3857.yLow);\r\n const east = this.getEPSG4326Lon(range3857.xHigh);\r\n const north = this.getEPSG4326Lat(range3857.yHigh);\r\n this.cartoRange = MapCartoRectangle.fromDegrees(west, south, east, north);\r\n }\r\n }\r\n\r\n // Read minLOD if available\r\n if (json.minLOD !== undefined) {\r\n const minLod = parseInt(json.minLOD, 10);\r\n if (!Number.isNaN(minLod)) {\r\n this._minDepthFromLod = minLod;\r\n }\r\n } else if (json.minScale) {\r\n // Read min LOD using minScale\r\n const minScale = json.minScale;\r\n if (json.tileInfo?.lods !== undefined && Array.isArray(json.tileInfo.lods)) {\r\n for (const lod of json.tileInfo.lods) {\r\n if (lod.scale < minScale) {\r\n this._minDepthFromLod = lod.level;\r\n break;\r\n }\r\n }\r\n }\r\n }\r\n\r\n }\r\n\r\n public override addLogoCards(cards: HTMLTableElement): void {\r\n if (!cards.dataset.arcGisLogoCard) {\r\n cards.dataset.arcGisLogoCard = \"true\";\r\n cards.appendChild(IModelApp.makeLogoCard({ heading: \"ArcGIS\", notice: this._copyrightText }));\r\n }\r\n }\r\n\r\n // Translates the provided Cartographic into a EPSG:3857 point, and retrieve information.\r\n // tolerance is in pixels\r\n private async getIdentifyData(quadId: QuadId, carto: Cartographic, tolerance: number, returnGeometry?: boolean, maxAllowableOffset?: number): Promise<any> {\r\n\r\n const bbox = this.getEPSG3857Extent(quadId.row, quadId.column, quadId.level);\r\n const layerIds = new Array<string>();\r\n this._settings.subLayers.forEach((subLayer) => {\r\n if (this._settings.isSubLayerVisible(subLayer))\r\n layerIds.push(subLayer.idString);\r\n });\r\n const urlObj = ArcGISIdentifyRequestUrl.fromJSON(this._settings.url, {\r\n f: \"json\",\r\n geometry: {x: this.getEPSG3857X(carto.longitudeDegrees), y: this.getEPSG3857Y(carto.latitudeDegrees)},\r\n geometryType: \"esriGeometryPoint\",\r\n tolerance,\r\n mapExtent: {low: {x: bbox.left, y: bbox.bottom}, high: {x: bbox.right, y: bbox.top}},\r\n sr: 3857,\r\n imageDisplay: {width: this.tileSize, height: this.tileSize, dpi: 96},\r\n layers: {prefix: \"top\", layerIds},\r\n returnGeometry,\r\n maxAllowableOffset}, 3 /* 1mm accuracy*/);\r\n\r\n const response = await this.fetch(urlObj, { method: \"GET\" } );\r\n return response.json();\r\n }\r\n\r\n // Makes an identify request to ESRI MapService server, and return it as a list of formatted strings\r\n public override async getToolTip(strings: string[], quadId: QuadId, carto: Cartographic, tree: ImageryMapTileTree): Promise<void> {\r\n await super.getToolTip(strings, quadId, carto, tree);\r\n\r\n if (!this._querySupported)\r\n return;\r\n\r\n const stringSet = new Set<string>();\r\n const json = await this.getIdentifyData(quadId, carto, 1);\r\n\r\n if (json && Array.isArray(json.results)) {\r\n for (const result of json.results) {\r\n if (result.attributes !== undefined && result.attributes[result.displayFieldName] !== undefined) {\r\n const thisString = `${result.displayFieldName}: ${result.attributes[result.displayFieldName]}`;\r\n if (!stringSet.has(thisString)) {\r\n strings.push(thisString);\r\n stringSet.add(thisString);\r\n }\r\n }\r\n }\r\n }\r\n }\r\n\r\n // Makes an identify request to ESRI MapService , and return it as a list MapLayerFeatureInfo object\r\n public override async getFeatureInfo(featureInfos: MapLayerFeatureInfo[], quadId: QuadId, carto: Cartographic, _tree: ImageryMapTileTree, hit: HitDetail, options?: MapFeatureInfoOptions): Promise<void> {\r\n if (!this._querySupported)\r\n return;\r\n\r\n const tileExtent = this.getEPSG3857Extent(quadId.row, quadId.column, quadId.level);\r\n const toleranceWorld = (tileExtent.top - tileExtent.bottom) / this.tileSize;\r\n const maxAllowableOffsetFactor = 2;\r\n const maxAllowableOffset = maxAllowableOffsetFactor*toleranceWorld;\r\n\r\n const tolerancePixel = options?.tolerance ?? 7;\r\n const json = await this.getIdentifyData(quadId, carto, tolerancePixel, true, maxAllowableOffset);\r\n if (json && Array.isArray(json.results)) {\r\n const renderer = new ArcGisGraphicsRenderer({viewport: hit.viewport});\r\n\r\n const layerInfo: MapLayerFeatureInfo = { layerName: this._settings.name, subLayerInfos: [] };\r\n\r\n // The 'identify' service returns us a flat/unordered list of records..\r\n // results may represent features for the a common subLayer.\r\n // For simplicity, we group together features for a given sub-layer.\r\n const subLayers = new Map<string, MapSubLayerFeatureInfo> ();\r\n\r\n for (const result of json.results) {\r\n\r\n let subLayerInfo = subLayers.get(result.layerName);\r\n if (!subLayerInfo) {\r\n subLayerInfo = {\r\n subLayerName: result.layerName ?? \"\",\r\n displayFieldName: result.displayFieldName,\r\n features: [],\r\n };\r\n subLayers.set(result.layerName, subLayerInfo);\r\n }\r\n const feature: MapLayerFeature = {geometries: [], attributes: []};\r\n\r\n // Read all feature attributes\r\n for (const [key, value] of Object.entries(result.attributes)) {\r\n // Convert everything to string for now\r\n const strValue = String(value);\r\n feature.attributes.push({\r\n value: { valueFormat: PropertyValueFormat.Primitive, value: strValue, displayValue: strValue },\r\n property: { name: key, displayLabel: key, typename: StandardTypeNames.String },\r\n });\r\n }\r\n\r\n // Read feature geometries\r\n const geomReader = new ArcGisGeometryReaderJSON(result.geometryType, renderer);\r\n await geomReader.readGeometry(result.geometry);\r\n const graphics = renderer.moveGraphics();\r\n feature.geometries = graphics.map((graphic) => {\r\n return {graphic};\r\n });\r\n subLayerInfo.features.push(feature);\r\n\r\n }\r\n\r\n for ( const value of subLayers.values()) {\r\n layerInfo.subLayerInfos!.push(value);\r\n }\r\n\r\n featureInfos.push(layerInfo);\r\n }\r\n }\r\n\r\n protected getLayerString(prefix = \"show\"): string {\r\n const layers = new Array<string>();\r\n this._settings.subLayers.forEach((subLayer) => {\r\n if (this._settings.isSubLayerVisible(subLayer))\r\n layers.push(subLayer.idString);\r\n });\r\n\r\n return `${prefix}: ${layers.join(\",\")} `;\r\n }\r\n\r\n // construct the Url from the desired Tile\r\n public async constructUrl(row: number, column: number, zoomLevel: number): Promise<string> {\r\n let tmpUrl;\r\n if (this._usesCachedTiles) {\r\n tmpUrl = `${this._settings.url}/tile/${zoomLevel}/${row}/${column} `;\r\n } else {\r\n const bboxString = `${this.getEPSG3857ExtentString(row, column, zoomLevel)}&bboxSR=3857`;\r\n tmpUrl = `${this._settings.url}/export?bbox=${bboxString}&size=${this.tileSize},${this.tileSize}&layers=${this.getLayerString()}&format=png&transparent=${this.transparentBackgroundString}&f=image&sr=3857&imagesr=3857`;\r\n }\r\n return tmpUrl;\r\n }\r\n}\r\n"]}
|
|
1
|
+
{"version":3,"file":"ArcGISMapLayerImageryProvider.js","sourceRoot":"","sources":["../../../../../src/tile/map/ImageryProviders/ArcGISMapLayerImageryProvider.ts"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\r\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\r\n* See LICENSE.md in the project root for license terms and full copyright notice.\r\n*--------------------------------------------------------------------------------------------*/\r\n/** @packageDocumentation\r\n * @module Tiles\r\n */\r\nimport { Cartographic, ImageMapLayerSettings, ImageSource, IModelStatus, ServerError } from \"@itwin/core-common\";\r\nimport { IModelApp } from \"../../../IModelApp\";\r\nimport {\r\n ArcGisErrorCode, ArcGisGeometryReaderJSON, ArcGisGraphicsRenderer, ArcGISImageryProvider, ArcGISTileMap,\r\n ArcGisUtilities, ImageryMapTileTree, MapCartoRectangle, MapFeatureInfoOptions, MapLayerFeature,\r\n MapLayerFeatureInfo, MapLayerImageryProviderStatus, MapSubLayerFeatureInfo, QuadId,\r\n} from \"../../internal\";\r\nimport { PropertyValueFormat, StandardTypeNames } from \"@itwin/appui-abstract\";\r\nimport { Point2d, Range2d, Range2dProps, XYProps } from \"@itwin/core-geometry\";\r\nimport { Logger } from \"@itwin/core-bentley\";\r\nimport { HitDetail } from \"../../../HitDetail\";\r\n\r\nconst loggerCategory = \"MapLayerImageryProvider.ArcGISMapLayerImageryProvider\";\r\n\r\n/** @internal */\r\nexport interface ArcGISIdentifyImageDisplayProps {\r\n width: number;\r\n height: number;\r\n dpi: number;\r\n}\r\n\r\n/** @internal */\r\nexport interface ArcGISIdentifyLayersProps {\r\n prefix: \"top\"|\"visible\"|\"all\";\r\n layerIds?: string[];\r\n}\r\n\r\n/** @internal */\r\nexport interface ArcGISIdentifyRequestUrlProps {\r\n /** The geometry to identify on. Point only support */\r\n geometry: XYProps;\r\n\r\n /** The type of geometry specified by the geometry parameter. Point only support */\r\n geometryType: \"esriGeometryPoint\";\r\n\r\n /** The well-known ID of the spatial reference of the input and output geometries as well as the mapExtent. */\r\n sr?: number;\r\n\r\n /** The layers to perform the identify operation on. The default value is top.\r\n * Format: [top | visible | all]:layerId1,layerId2\r\n */\r\n layers?: ArcGISIdentifyLayersProps;\r\n\r\n /** The distance in screen pixels from the specified geometry within which the identify operation should be performed.\r\n * The value for the tolerance is an integer.\r\n */\r\n tolerance: number;\r\n\r\n /** The extent or bounding box of the map currently being viewed.\r\n * Format: <xmin>, <ymin>, <xmax>, <ymax>\r\n */\r\n mapExtent: Range2dProps;\r\n\r\n /** The screen image display parameters (width, height, and DPI) of the map being currently viewed. T\r\n * Format: <width>,<height>,<dpi>\r\n */\r\n imageDisplay: ArcGISIdentifyImageDisplayProps;\r\n\r\n /** If true, the result set will include the geometries associated with each result. The default is true.\r\n */\r\n returnGeometry?: boolean;\r\n\r\n /** This option can be used to specify the maximum allowable offset to be used for generalizing geometries returned by the identify operation.\r\n * The maxAllowableOffset is in the units of the sr.\r\n */\r\n maxAllowableOffset?: number;\r\n\r\n /** The response format. The default response format is html.\r\n */\r\n f?: \"json\"|\"html\";\r\n\r\n}\r\n\r\n/** @internal */\r\nexport class ArcGISIdentifyRequestUrl {\r\n public static fromJSON(baseUrl: URL|string, json: ArcGISIdentifyRequestUrlProps, srFractionDigits?: number): URL {\r\n\r\n const newUrl = new URL(baseUrl);\r\n newUrl.pathname = `${newUrl.pathname}/identify`;\r\n\r\n if (json.f) {\r\n newUrl.searchParams.append(\"f\", json.f);\r\n }\r\n\r\n const geomPt = Point2d.fromJSON(json.geometry);\r\n newUrl.searchParams.append(\"geometry\", `${this.toFixed(geomPt.x, srFractionDigits)},${this.toFixed(geomPt.y, srFractionDigits)}`);\r\n newUrl.searchParams.append(\"geometryType\", json.geometryType);\r\n\r\n if (json.sr) {\r\n newUrl.searchParams.append(\"sr\", `${json.sr}`);\r\n }\r\n\r\n if (json.layers) {\r\n newUrl.searchParams.append(\"layers\", `${json.layers.prefix}${json.layers.layerIds?.length ? `: ${json.layers.layerIds.join(\",\")}` : \"\"}`);\r\n }\r\n\r\n newUrl.searchParams.append(\"tolerance\", `${json.tolerance}`);\r\n\r\n newUrl.searchParams.append(\"mapExtent\", ArcGISIdentifyRequestUrl.getExtentString(json.mapExtent, srFractionDigits));\r\n\r\n newUrl.searchParams.append(\"imageDisplay\", `${json.imageDisplay.width},${json.imageDisplay.height},${json.imageDisplay.dpi}`);\r\n\r\n if (json.returnGeometry !== undefined) {\r\n newUrl.searchParams.append(\"returnGeometry\", json.returnGeometry ? \"true\" : \"false\");\r\n }\r\n\r\n if (json.maxAllowableOffset !== undefined) {\r\n newUrl.searchParams.append(\"maxAllowableOffset\", `${this.toFixed(json.maxAllowableOffset, srFractionDigits)}`);\r\n }\r\n\r\n return newUrl;\r\n }\r\n\r\n public static toFixed(value: number, srFractionDigits?: number) {\r\n return srFractionDigits === undefined ? value.toString() : value.toFixed(srFractionDigits);\r\n }\r\n\r\n public static getExtentString(range: Range2dProps, srFractionDigits?: number) {\r\n const extent = Range2d.fromJSON(range);\r\n const extentStringArray: string[] = [];\r\n extent.toFloat64Array().forEach((value) => extentStringArray.push(this.toFixed(value, srFractionDigits)));\r\n return extentStringArray.join(\",\");\r\n }\r\n}\r\n\r\n/** @internal */\r\nexport class ArcGISMapLayerImageryProvider extends ArcGISImageryProvider {\r\n private _maxDepthFromLod = 0;\r\n private _minDepthFromLod = 0;\r\n private _copyrightText = \"Copyright\";\r\n private _tileMapSupported = false;\r\n private _mapSupported = false;\r\n private _tilesOnly = false;\r\n private _tileMap: ArcGISTileMap|undefined;\r\n\r\n public serviceJson: any;\r\n constructor(settings: ImageMapLayerSettings) {\r\n super(settings, false);\r\n this._accessClient = IModelApp.mapLayerFormatRegistry.getAccessClient(settings.formatId);\r\n }\r\n\r\n protected override get _filterByCartoRange() { return false; } // Can't trust footprint ranges (USGS Hydro)\r\n\r\n public override get minimumZoomLevel() { return Math.max(super.minimumZoomLevel, this._minDepthFromLod); }\r\n public override get maximumZoomLevel() { return this._maxDepthFromLod > 0 ? this._maxDepthFromLod : super.maximumZoomLevel; }\r\n\r\n public uintToString(uintArray: any) {\r\n return Buffer.from(uintArray).toJSON();\r\n\r\n }\r\n\r\n private async fetchTile(row: number, column: number, zoomLevel: number) {\r\n const tileUrl: string = await this.constructUrl(row, column, zoomLevel);\r\n if (tileUrl.length === 0)\r\n return undefined;\r\n return this.fetch(new URL(tileUrl), { method: \"GET\" });\r\n }\r\n\r\n public override async loadTile(row: number, column: number, zoomLevel: number): Promise<ImageSource | undefined> {\r\n if ((this.status === MapLayerImageryProviderStatus.RequireAuth)) {\r\n return undefined;\r\n }\r\n\r\n try {\r\n const tileResponse = await this.fetchTile(row, column, zoomLevel);\r\n if (tileResponse === undefined)\r\n return undefined;\r\n\r\n if (!this._hasSuccessfullyFetchedTile) {\r\n this._hasSuccessfullyFetchedTile = true;\r\n }\r\n return await this.getImageFromTileResponse(tileResponse, zoomLevel);\r\n } catch (error) {\r\n Logger.logError(loggerCategory, `Error occurred when loading tile(${row},${column},${zoomLevel}) : ${error}`);\r\n return undefined;\r\n }\r\n }\r\n\r\n protected override _generateChildIds(quadId: QuadId, resolveChildren: (childIds: QuadId[]) => void) {\r\n const childIds = this.getPotentialChildIds(quadId);\r\n if (quadId.level < Math.max(1, this.minimumZoomLevel-1)) {\r\n resolveChildren(childIds);\r\n return;\r\n }\r\n\r\n if (this._tileMap) {\r\n // eslint-disable-next-line @typescript-eslint/no-floating-promises\r\n this._tileMap.getChildrenAvailability(childIds).then((availability) => {\r\n const availableChildIds = new Array<QuadId>();\r\n for (let i = 0; i < availability.length; i++)\r\n if (availability[i])\r\n availableChildIds.push(childIds[i]);\r\n\r\n resolveChildren (availableChildIds);\r\n });\r\n } else if (this._usesCachedTiles && this.cartoRange) {\r\n // Filter children by range\r\n const availableChildIds = new Array<QuadId>();\r\n // eslint-disable-next-line @typescript-eslint/prefer-for-of\r\n for (let i = 0; i < childIds.length; i++) {\r\n const childExtent = this.getEPSG4326Extent(childIds[i].row, childIds[i].column, childIds[i].level);\r\n\r\n const childRange = MapCartoRectangle.fromDegrees(childExtent.longitudeLeft, childExtent.latitudeBottom, childExtent.longitudeRight, childExtent.latitudeTop);\r\n if (childRange.intersectsRange(this.cartoRange)) {\r\n availableChildIds.push(childIds[i]);\r\n }\r\n }\r\n resolveChildren (availableChildIds);\r\n } else {\r\n resolveChildren (childIds); // Resolve all children\r\n }\r\n }\r\n\r\n public override async initialize(): Promise<void> {\r\n\r\n const metadata = await this.getServiceJson();\r\n\r\n if (metadata?.content === undefined)\r\n throw new ServerError(IModelStatus.ValidationFailed, \"\");\r\n\r\n const json = metadata.content;\r\n if (json?.error?.code === ArcGisErrorCode.TokenRequired || json?.error?.code === ArcGisErrorCode.InvalidToken) {\r\n // Check again layer status, it might have change during await.\r\n if (this.status === MapLayerImageryProviderStatus.Valid) {\r\n this.setStatus(MapLayerImageryProviderStatus.RequireAuth);\r\n return; // By returning (i.e not throwing), we ensure the tileTree get created and current provider is preserved to report status.\r\n }\r\n }\r\n\r\n this.serviceJson = json;\r\n\r\n if (json.capabilities) {\r\n const capabilities = json.capabilities.split(\",\");\r\n\r\n this._querySupported = capabilities.includes(\"Query\");\r\n this._tileMapSupported = capabilities.includes(\"Tilemap\");\r\n this._mapSupported = capabilities.includes(\"Map\");\r\n this._tilesOnly = capabilities.includes(\"TilesOnly\");\r\n }\r\n\r\n if (json.copyrightText)\r\n this._copyrightText = json.copyrightText;\r\n\r\n this._usesCachedTiles = !!json.tileInfo;\r\n\r\n if (this._usesCachedTiles) {\r\n // Only EPSG:3857 is supported with pre-rendered tiles. Fall back to 'Export' queries if possible otherwise throw.\r\n if (!ArcGisUtilities.isEpsg3857Compatible(json.tileInfo)) {\r\n if (this._mapSupported && !this._tilesOnly) {\r\n this._usesCachedTiles = false;\r\n } else {\r\n throw new ServerError(IModelStatus.ValidationFailed, \"Invalid coordinate system\");\r\n }\r\n }\r\n }\r\n\r\n if (this._usesCachedTiles) {\r\n // Read max LOD\r\n if (json.maxScale !== undefined && json.maxScale !== 0 && Array.isArray(json.tileInfo.lods)) {\r\n for (; this._maxDepthFromLod < json.tileInfo.lods.length && json.tileInfo.lods[this._maxDepthFromLod].scale > json.maxScale; this._maxDepthFromLod++)\r\n ;\r\n }\r\n\r\n // Create tile map object only if we are going to request tiles from this server and it support tilemap requests.\r\n if (this._tileMapSupported) {\r\n const fetch = async (url: URL, options?: RequestInit): Promise<Response> => {\r\n return this.fetch(url, options);\r\n };\r\n this._tileMap = new ArcGISTileMap(this._settings.url, this._settings, fetch);\r\n }\r\n }\r\n\r\n // Read range using fullextent from service metadata\r\n if (json.fullExtent) {\r\n if (json.fullExtent.spatialReference.latestWkid === 3857 || json.fullExtent.spatialReference.wkid === 102100) {\r\n const range3857 = Range2d.createFrom({\r\n low: {x: json.fullExtent.xmin, y: json.fullExtent.ymin},\r\n high: {x: json.fullExtent.xmax, y: json.fullExtent.ymax} });\r\n\r\n const west = this.getEPSG4326Lon(range3857.xLow);\r\n const south = this.getEPSG4326Lat(range3857.yLow);\r\n const east = this.getEPSG4326Lon(range3857.xHigh);\r\n const north = this.getEPSG4326Lat(range3857.yHigh);\r\n this.cartoRange = MapCartoRectangle.fromDegrees(west, south, east, north);\r\n }\r\n }\r\n\r\n // Read minLOD if available\r\n if (json.minLOD !== undefined) {\r\n const minLod = parseInt(json.minLOD, 10);\r\n if (!Number.isNaN(minLod)) {\r\n this._minDepthFromLod = minLod;\r\n }\r\n } else if (json.minScale) {\r\n // Read min LOD using minScale\r\n const minScale = json.minScale;\r\n if (json.tileInfo?.lods !== undefined && Array.isArray(json.tileInfo.lods)) {\r\n for (const lod of json.tileInfo.lods) {\r\n if (lod.scale < minScale) {\r\n this._minDepthFromLod = lod.level;\r\n break;\r\n }\r\n }\r\n }\r\n }\r\n\r\n }\r\n\r\n public override addLogoCards(cards: HTMLTableElement): void {\r\n if (!cards.dataset.arcGisLogoCard) {\r\n cards.dataset.arcGisLogoCard = \"true\";\r\n cards.appendChild(IModelApp.makeLogoCard({ heading: \"ArcGIS\", notice: this._copyrightText }));\r\n }\r\n }\r\n\r\n // Translates the provided Cartographic into a EPSG:3857 point, and retrieve information.\r\n // tolerance is in pixels\r\n private async getIdentifyData(quadId: QuadId, carto: Cartographic, tolerance: number, returnGeometry?: boolean, maxAllowableOffset?: number): Promise<any> {\r\n\r\n const bbox = this.getEPSG3857Extent(quadId.row, quadId.column, quadId.level);\r\n const layerIds = new Array<string>();\r\n this._settings.subLayers.forEach((subLayer) => {\r\n if (this._settings.isSubLayerVisible(subLayer))\r\n layerIds.push(subLayer.idString);\r\n });\r\n const urlObj = ArcGISIdentifyRequestUrl.fromJSON(this._settings.url, {\r\n f: \"json\",\r\n geometry: {x: this.getEPSG3857X(carto.longitudeDegrees), y: this.getEPSG3857Y(carto.latitudeDegrees)},\r\n geometryType: \"esriGeometryPoint\",\r\n tolerance,\r\n mapExtent: {low: {x: bbox.left, y: bbox.bottom}, high: {x: bbox.right, y: bbox.top}},\r\n sr: 3857,\r\n imageDisplay: {width: this.tileSize, height: this.tileSize, dpi: 96},\r\n layers: {prefix: \"top\", layerIds},\r\n returnGeometry,\r\n maxAllowableOffset}, 3 /* 1mm accuracy*/);\r\n\r\n const response = await this.fetch(urlObj, { method: \"GET\" } );\r\n return response.json();\r\n }\r\n\r\n // Makes an identify request to ESRI MapService server, and return it as a list of formatted strings\r\n public override async getToolTip(strings: string[], quadId: QuadId, carto: Cartographic, tree: ImageryMapTileTree): Promise<void> {\r\n await super.getToolTip(strings, quadId, carto, tree);\r\n\r\n if (!this._querySupported)\r\n return;\r\n\r\n const stringSet = new Set<string>();\r\n const json = await this.getIdentifyData(quadId, carto, 1);\r\n\r\n if (json && Array.isArray(json.results)) {\r\n for (const result of json.results) {\r\n if (result.attributes !== undefined && result.attributes[result.displayFieldName] !== undefined) {\r\n const thisString = `${result.displayFieldName}: ${result.attributes[result.displayFieldName]}`;\r\n if (!stringSet.has(thisString)) {\r\n strings.push(thisString);\r\n stringSet.add(thisString);\r\n }\r\n }\r\n }\r\n }\r\n }\r\n\r\n // Makes an identify request to ESRI MapService , and return it as a list MapLayerFeatureInfo object\r\n public override async getFeatureInfo(featureInfos: MapLayerFeatureInfo[], quadId: QuadId, carto: Cartographic, _tree: ImageryMapTileTree, hit: HitDetail, options?: MapFeatureInfoOptions): Promise<void> {\r\n if (!this._querySupported)\r\n return;\r\n\r\n const tileExtent = this.getEPSG3857Extent(quadId.row, quadId.column, quadId.level);\r\n const toleranceWorld = (tileExtent.top - tileExtent.bottom) / this.tileSize;\r\n const maxAllowableOffsetFactor = 2;\r\n const maxAllowableOffset = maxAllowableOffsetFactor*toleranceWorld;\r\n\r\n const tolerancePixel = options?.tolerance ?? 7;\r\n const json = await this.getIdentifyData(quadId, carto, tolerancePixel, true, maxAllowableOffset);\r\n if (json && Array.isArray(json.results)) {\r\n const renderer = new ArcGisGraphicsRenderer({viewport: hit.viewport});\r\n\r\n const layerInfo: MapLayerFeatureInfo = { layerName: this._settings.name, subLayerInfos: [] };\r\n\r\n // The 'identify' service returns us a flat/unordered list of records..\r\n // results may represent features for the a common subLayer.\r\n // For simplicity, we group together features for a given sub-layer.\r\n const subLayers = new Map<string, MapSubLayerFeatureInfo> ();\r\n\r\n for (const result of json.results) {\r\n\r\n let subLayerInfo = subLayers.get(result.layerName);\r\n if (!subLayerInfo) {\r\n subLayerInfo = {\r\n subLayerName: result.layerName ?? \"\",\r\n displayFieldName: result.displayFieldName,\r\n features: [],\r\n };\r\n subLayers.set(result.layerName, subLayerInfo);\r\n }\r\n const feature: MapLayerFeature = {geometries: [], attributes: []};\r\n\r\n // Read all feature attributes\r\n for (const [key, value] of Object.entries(result.attributes)) {\r\n // Convert everything to string for now\r\n const strValue = String(value);\r\n feature.attributes.push({\r\n value: { valueFormat: PropertyValueFormat.Primitive, value: strValue, displayValue: strValue },\r\n property: { name: key, displayLabel: key, typename: StandardTypeNames.String },\r\n });\r\n }\r\n\r\n // Read feature geometries\r\n const geomReader = new ArcGisGeometryReaderJSON(result.geometryType, renderer);\r\n await geomReader.readGeometry(result.geometry);\r\n const graphics = renderer.moveGraphics();\r\n feature.geometries = graphics.map((graphic) => {\r\n return {graphic};\r\n });\r\n subLayerInfo.features.push(feature);\r\n\r\n }\r\n\r\n for ( const value of subLayers.values()) {\r\n layerInfo.subLayerInfos!.push(value);\r\n }\r\n\r\n featureInfos.push(layerInfo);\r\n }\r\n }\r\n\r\n protected getLayerString(prefix = \"show\"): string {\r\n const layers = new Array<string>();\r\n this._settings.subLayers.forEach((subLayer) => {\r\n if (this._settings.isSubLayerVisible(subLayer))\r\n layers.push(subLayer.idString);\r\n });\r\n\r\n return `${prefix}: ${layers.join(\",\")} `;\r\n }\r\n\r\n // construct the Url from the desired Tile\r\n public async constructUrl(row: number, column: number, zoomLevel: number): Promise<string> {\r\n let tmpUrl;\r\n if (this._usesCachedTiles) {\r\n tmpUrl = `${this._settings.url}/tile/${zoomLevel}/${row}/${column} `;\r\n } else {\r\n const bboxString = `${this.getEPSG3857ExtentString(row, column, zoomLevel)}&bboxSR=3857`;\r\n tmpUrl = `${this._settings.url}/export?bbox=${bboxString}&size=${this.tileSize},${this.tileSize}&layers=${this.getLayerString()}&format=png&transparent=${this.transparentBackgroundString}&f=image&sr=3857&imagesr=3857`;\r\n }\r\n return tmpUrl;\r\n }\r\n}\r\n"]}
|
|
@@ -87,6 +87,7 @@ export declare class SelectionTool extends PrimitiveTool {
|
|
|
87
87
|
protected selectByPointsEnd(ev: BeButtonEvent): boolean;
|
|
88
88
|
onMouseMotion(ev: BeButtonEvent): Promise<void>;
|
|
89
89
|
selectDecoration(ev: BeButtonEvent, currHit?: HitDetail): Promise<EventHandled>;
|
|
90
|
+
processHit(ev: BeButtonEvent, hit: HitDetail): Promise<EventHandled>;
|
|
90
91
|
onMouseStartDrag(ev: BeButtonEvent): Promise<EventHandled>;
|
|
91
92
|
onMouseEndDrag(ev: BeButtonEvent): Promise<EventHandled>;
|
|
92
93
|
onDataButtonUp(ev: BeButtonEvent): Promise<EventHandled>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SelectTool.d.ts","sourceRoot":"","sources":["../../../src/tools/SelectTool.ts"],"names":[],"mappings":"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
|
|
1
|
+
{"version":3,"file":"SelectTool.d.ts","sourceRoot":"","sources":["../../../src/tools/SelectTool.ts"],"names":[],"mappings":"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"}
|
|
@@ -425,6 +425,22 @@ class SelectionTool extends PrimitiveTool {
|
|
|
425
425
|
return (currHit.isElementHit ? IModelApp.viewManager.overrideElementButtonEvent(currHit, ev) : IModelApp.viewManager.onDecorationButtonEvent(currHit, ev));
|
|
426
426
|
return EventHandled.No;
|
|
427
427
|
}
|
|
428
|
+
async processHit(ev, hit) {
|
|
429
|
+
if (hit.isModelHit || hit.isMapHit)
|
|
430
|
+
return EventHandled.No; // model hit = terrain, reality models, background maps, etc - not selectable
|
|
431
|
+
switch (this.selectionMode) {
|
|
432
|
+
case SelectionMode.Replace:
|
|
433
|
+
await this.processSelection(hit.sourceId, ev.isControlKey ? SelectionProcessing.InvertElementInSelection : SelectionProcessing.ReplaceSelectionWithElement);
|
|
434
|
+
break;
|
|
435
|
+
case SelectionMode.Add:
|
|
436
|
+
await this.processSelection(hit.sourceId, SelectionProcessing.AddElementToSelection);
|
|
437
|
+
break;
|
|
438
|
+
case SelectionMode.Remove:
|
|
439
|
+
await this.processSelection(hit.sourceId, SelectionProcessing.RemoveElementFromSelection);
|
|
440
|
+
break;
|
|
441
|
+
}
|
|
442
|
+
return EventHandled.Yes;
|
|
443
|
+
}
|
|
428
444
|
async onMouseStartDrag(ev) {
|
|
429
445
|
IModelApp.accuSnap.clear(); // Need to test hit at start drag location, not current AccuSnap...
|
|
430
446
|
if (EventHandled.Yes === await this.selectDecoration(ev))
|
|
@@ -449,21 +465,11 @@ class SelectionTool extends PrimitiveTool {
|
|
|
449
465
|
return EventHandled.Yes;
|
|
450
466
|
}
|
|
451
467
|
const hit = await IModelApp.locateManager.doLocate(new LocateResponse(), true, ev.point, ev.viewport, ev.inputSource);
|
|
452
|
-
if (hit !== undefined
|
|
468
|
+
if (hit !== undefined) {
|
|
453
469
|
if (EventHandled.Yes === await this.selectDecoration(ev, hit))
|
|
454
470
|
return EventHandled.Yes;
|
|
455
|
-
|
|
456
|
-
|
|
457
|
-
await this.processSelection(hit.sourceId, ev.isControlKey ? SelectionProcessing.InvertElementInSelection : SelectionProcessing.ReplaceSelectionWithElement);
|
|
458
|
-
break;
|
|
459
|
-
case SelectionMode.Add:
|
|
460
|
-
await this.processSelection(hit.sourceId, SelectionProcessing.AddElementToSelection);
|
|
461
|
-
break;
|
|
462
|
-
case SelectionMode.Remove:
|
|
463
|
-
await this.processSelection(hit.sourceId, SelectionProcessing.RemoveElementFromSelection);
|
|
464
|
-
break;
|
|
465
|
-
}
|
|
466
|
-
return EventHandled.Yes;
|
|
471
|
+
if (EventHandled.Yes === await this.processHit(ev, hit))
|
|
472
|
+
return EventHandled.Yes;
|
|
467
473
|
}
|
|
468
474
|
if (!ev.isControlKey && this.wantSelectionClearOnMiss(ev) && this.processMiss(ev))
|
|
469
475
|
this.syncSelectionMode();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SelectTool.js","sourceRoot":"","sources":["../../../src/tools/SelectTool.ts"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\r\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\r\n* See LICENSE.md in the project root for license terms and full copyright notice.\r\n*--------------------------------------------------------------------------------------------*/\r\n/** @packageDocumentation\r\n * @module SelectionSet\r\n */\r\n\r\nimport { Id64, Id64Arg } from \"@itwin/core-bentley\";\r\nimport { Point2d, Point3d, Range2d } from \"@itwin/core-geometry\";\r\nimport { ColorDef } from \"@itwin/core-common\";\r\nimport {\r\n ButtonGroupEditorParams, DialogItem, DialogItemValue, DialogPropertySyncItem, PropertyDescription, PropertyEditorParamTypes,\r\n SuppressLabelEditorParams,\r\n} from \"@itwin/appui-abstract\";\r\nimport { LocateFilterStatus, LocateResponse } from \"../ElementLocateManager\";\r\nimport { HitDetail } from \"../HitDetail\";\r\nimport { IModelApp } from \"../IModelApp\";\r\nimport { Pixel } from \"../render/Pixel\";\r\nimport { DecorateContext } from \"../ViewContext\";\r\nimport { ViewRect } from \"../common/ViewRect\";\r\nimport { PrimitiveTool } from \"./PrimitiveTool\";\r\nimport { BeButton, BeButtonEvent, BeModifierKeys, BeTouchEvent, CoordinateLockOverrides, CoreTools, EventHandled, InputSource } from \"./Tool\";\r\nimport { ManipulatorToolEvent } from \"./ToolAdmin\";\r\nimport { ToolAssistance, ToolAssistanceImage, ToolAssistanceInputMethod, ToolAssistanceInstruction, ToolAssistanceSection } from \"./ToolAssistance\";\r\n\r\n// cSpell:ignore buttongroup\r\n\r\n/** The method for choosing elements with the [[SelectionTool]]\r\n * @public\r\n * @extensions\r\n */\r\nexport enum SelectionMethod {\r\n /** Identify element(s) by picking for drag selection (inside/overlap for drag box selection determined by point direction and shift key) */\r\n Pick,\r\n /** Identify elements by overlap with crossing line */\r\n Line,\r\n /** Identify elements by box selection (inside/overlap for box selection determined by point direction and shift key) */\r\n Box,\r\n}\r\n\r\n/** The mode for choosing elements with the [[SelectionTool]]\r\n * @public\r\n * @extensions\r\n */\r\nexport enum SelectionMode {\r\n /** Identified elements replace the current selection set (use control key to add or remove) */\r\n Replace,\r\n /** Identified elements are added to the current selection set */\r\n Add,\r\n /** Identified elements are removed from the current selection set */\r\n Remove,\r\n}\r\n\r\n/** The processing method to use to update the current selection.\r\n * @public\r\n * @extensions\r\n */\r\nexport enum SelectionProcessing {\r\n /** Add element to selection. */\r\n AddElementToSelection,\r\n /** Remove element from selection. */\r\n RemoveElementFromSelection,\r\n /** If element is in selection remove it, else add it. */\r\n InvertElementInSelection,\r\n /** Replace current selection with element. */\r\n ReplaceSelectionWithElement,\r\n}\r\n\r\n/** Tool for picking a set of elements of interest, selected by the user.\r\n * @public\r\n */\r\nexport class SelectionTool extends PrimitiveTool {\r\n public static override hidden = false;\r\n public static override toolId = \"Select\";\r\n public static override iconSpec = \"icon-cursor\";\r\n protected _isSelectByPoints = false;\r\n protected _isSuspended = false;\r\n protected readonly _points: Point3d[] = [];\r\n private _selectionMethodValue: DialogItemValue = { value: SelectionMethod.Pick };\r\n private _selectionModeValue: DialogItemValue = { value: SelectionMode.Replace };\r\n\r\n public override requireWriteableTarget(): boolean { return false; }\r\n public override autoLockTarget(): void { } // NOTE: For selecting elements we only care about iModel, so don't lock target model automatically.\r\n\r\n protected wantSelectionClearOnMiss(_ev: BeButtonEvent): boolean { return SelectionMode.Replace === this.selectionMode; }\r\n protected wantEditManipulators(): boolean { return SelectionMethod.Pick === this.selectionMethod; }\r\n protected wantPickableDecorations(): boolean { return this.wantEditManipulators(); } // Allow pickable decorations selection to be independent of manipulators...\r\n protected wantToolSettings(): boolean { return true; }\r\n\r\n public get selectionMethod(): SelectionMethod { return this._selectionMethodValue.value as SelectionMethod; }\r\n public set selectionMethod(method: SelectionMethod) { this._selectionMethodValue.value = method; }\r\n public get selectionMode(): SelectionMode { return this._selectionModeValue.value as SelectionMode; }\r\n public set selectionMode(mode: SelectionMode) { this._selectionModeValue.value = mode; }\r\n\r\n private static methodsMessage(str: string) { return CoreTools.translate(`ElementSet.SelectionMethods.${str}`); }\r\n private static _methodsName = \"selectionMethods\";\r\n /* The property descriptions used to generate ToolSettings UI. */\r\n private static _getMethodsDescription(): PropertyDescription {\r\n return {\r\n name: SelectionTool._methodsName,\r\n displayLabel: \"\",\r\n typename: \"enum\",\r\n editor: {\r\n name: \"enum-buttongroup\",\r\n params: [{\r\n type: PropertyEditorParamTypes.ButtonGroupData,\r\n buttons: [\r\n { iconSpec: \"icon-select-single\" },\r\n { iconSpec: \"icon-select-line\" },\r\n { iconSpec: \"icon-select-box\" },\r\n ],\r\n } as ButtonGroupEditorParams, {\r\n type: PropertyEditorParamTypes.SuppressEditorLabel,\r\n suppressLabelPlaceholder: true,\r\n } as SuppressLabelEditorParams,\r\n ],\r\n },\r\n enum: {\r\n choices: [\r\n { label: SelectionTool.methodsMessage(\"Pick\"), value: SelectionMethod.Pick },\r\n { label: SelectionTool.methodsMessage(\"Line\"), value: SelectionMethod.Line },\r\n { label: SelectionTool.methodsMessage(\"Box\"), value: SelectionMethod.Box },\r\n ],\r\n },\r\n };\r\n }\r\n\r\n private static modesMessage(str: string) { return CoreTools.translate(`ElementSet.SelectionModes.${str}`); }\r\n private static _modesName = \"selectionModes\";\r\n /* The property descriptions used to generate ToolSettings UI. */\r\n private static _getModesDescription(): PropertyDescription {\r\n return {\r\n name: SelectionTool._modesName,\r\n displayLabel: \"\",\r\n typename: \"enum\",\r\n editor: {\r\n name: \"enum-buttongroup\",\r\n params: [{\r\n type: PropertyEditorParamTypes.ButtonGroupData,\r\n buttons: [\r\n { iconSpec: \"icon-replace\" },\r\n { iconSpec: \"icon-select-plus\" },\r\n {\r\n iconSpec: \"icon-select-minus\",\r\n isEnabledFunction: () => {\r\n const tool = IModelApp.toolAdmin.activeTool;\r\n return tool instanceof PrimitiveTool ? tool.iModel.selectionSet.isActive : false;\r\n },\r\n },\r\n ],\r\n } as ButtonGroupEditorParams, {\r\n type: PropertyEditorParamTypes.SuppressEditorLabel,\r\n suppressLabelPlaceholder: true,\r\n } as SuppressLabelEditorParams,\r\n ],\r\n },\r\n enum: {\r\n choices: [\r\n { label: SelectionTool.modesMessage(\"Replace\"), value: SelectionMode.Replace },\r\n { label: SelectionTool.modesMessage(\"Add\"), value: SelectionMode.Add },\r\n { label: SelectionTool.modesMessage(\"Remove\"), value: SelectionMode.Remove },\r\n ],\r\n },\r\n };\r\n }\r\n\r\n protected showPrompt(mode: SelectionMode, method: SelectionMethod): void {\r\n let mainMsg = \"ElementSet.Prompts.\";\r\n switch (method) {\r\n case SelectionMethod.Pick:\r\n mainMsg += \"IdentifyElement\";\r\n break;\r\n case SelectionMethod.Line:\r\n mainMsg += (0 === this._points.length ? \"StartPoint\" : \"EndPoint\");\r\n break;\r\n case SelectionMethod.Box:\r\n mainMsg += (0 === this._points.length ? \"StartCorner\" : \"OppositeCorner\");\r\n break;\r\n }\r\n\r\n const mainInstruction = ToolAssistance.createInstruction(this.iconSpec, CoreTools.translate(mainMsg));\r\n const sections: ToolAssistanceSection[] = [];\r\n\r\n switch (method) {\r\n case SelectionMethod.Pick:\r\n const mousePickInstructions: ToolAssistanceInstruction[] = [];\r\n mousePickInstructions.push(ToolAssistance.createInstruction(ToolAssistanceImage.LeftClick, CoreTools.translate(\"ElementSet.Inputs.AcceptElement\"), false, ToolAssistanceInputMethod.Mouse));\r\n mousePickInstructions.push(ToolAssistance.createInstruction(ToolAssistanceImage.LeftClickDrag, CoreTools.translate(\"ElementSet.Inputs.BoxCorners\"), false, ToolAssistanceInputMethod.Mouse));\r\n mousePickInstructions.push(ToolAssistance.createInstruction(ToolAssistanceImage.RightClickDrag, CoreTools.translate(\"ElementSet.Inputs.CrossingLine\"), false, ToolAssistanceInputMethod.Mouse));\r\n mousePickInstructions.push(ToolAssistance.createModifierKeyInstruction(ToolAssistance.shiftKey, ToolAssistanceImage.LeftClickDrag, CoreTools.translate(\"ElementSet.Inputs.OverlapSelection\"), false, ToolAssistanceInputMethod.Mouse));\r\n if (SelectionMode.Replace === mode) {\r\n mousePickInstructions.push(ToolAssistance.createKeyboardInstruction(ToolAssistance.ctrlKeyboardInfo, CoreTools.translate(\"ElementSet.Inputs.InvertSelection\"), false, ToolAssistanceInputMethod.Mouse));\r\n mousePickInstructions.push(ToolAssistance.createInstruction(ToolAssistanceImage.CursorClick, CoreTools.translate(\"ElementSet.Inputs.ClearSelection\"), false, ToolAssistanceInputMethod.Mouse));\r\n }\r\n sections.push(ToolAssistance.createSection(mousePickInstructions, ToolAssistance.inputsLabel));\r\n\r\n const touchPickInstructions: ToolAssistanceInstruction[] = [];\r\n if (!ToolAssistance.createTouchCursorInstructions(touchPickInstructions))\r\n touchPickInstructions.push(ToolAssistance.createInstruction(ToolAssistanceImage.OneTouchTap, CoreTools.translate(\"ElementSet.Inputs.AcceptElement\"), false, ToolAssistanceInputMethod.Touch));\r\n sections.push(ToolAssistance.createSection(touchPickInstructions, ToolAssistance.inputsLabel));\r\n break;\r\n case SelectionMethod.Line:\r\n const mouseLineInstructions: ToolAssistanceInstruction[] = [];\r\n mouseLineInstructions.push(ToolAssistance.createInstruction(ToolAssistanceImage.LeftClick, CoreTools.translate(\"ElementSet.Inputs.AcceptPoint\"), false, ToolAssistanceInputMethod.Mouse));\r\n if (SelectionMode.Replace === mode)\r\n mouseLineInstructions.push(ToolAssistance.createModifierKeyInstruction(ToolAssistance.ctrlKey, ToolAssistanceImage.LeftClick, CoreTools.translate(\"ElementSet.Inputs.InvertSelection\"), false, ToolAssistanceInputMethod.Mouse));\r\n sections.push(ToolAssistance.createSection(mouseLineInstructions, ToolAssistance.inputsLabel));\r\n\r\n const touchLineInstructions: ToolAssistanceInstruction[] = [];\r\n touchLineInstructions.push(ToolAssistance.createInstruction(ToolAssistanceImage.OneTouchDrag, CoreTools.translate(\"ElementSet.Inputs.AcceptPoint\"), false, ToolAssistanceInputMethod.Touch));\r\n sections.push(ToolAssistance.createSection(touchLineInstructions, ToolAssistance.inputsLabel));\r\n break;\r\n case SelectionMethod.Box:\r\n const mouseBoxInstructions: ToolAssistanceInstruction[] = [];\r\n mouseBoxInstructions.push(ToolAssistance.createInstruction(ToolAssistanceImage.LeftClick, CoreTools.translate(\"ElementSet.Inputs.AcceptPoint\"), false, ToolAssistanceInputMethod.Mouse));\r\n mouseBoxInstructions.push(ToolAssistance.createModifierKeyInstruction(ToolAssistance.shiftKey, ToolAssistanceImage.LeftClick, CoreTools.translate(\"ElementSet.Inputs.OverlapSelection\"), false, ToolAssistanceInputMethod.Mouse));\r\n if (SelectionMode.Replace === mode)\r\n mouseBoxInstructions.push(ToolAssistance.createModifierKeyInstruction(ToolAssistance.ctrlKey, ToolAssistanceImage.LeftClick, CoreTools.translate(\"ElementSet.Inputs.InvertSelection\"), false, ToolAssistanceInputMethod.Mouse));\r\n sections.push(ToolAssistance.createSection(mouseBoxInstructions, ToolAssistance.inputsLabel));\r\n\r\n const touchBoxInstructions: ToolAssistanceInstruction[] = [];\r\n touchBoxInstructions.push(ToolAssistance.createInstruction(ToolAssistanceImage.OneTouchDrag, CoreTools.translate(\"ElementSet.Inputs.AcceptPoint\"), false, ToolAssistanceInputMethod.Touch));\r\n sections.push(ToolAssistance.createSection(touchBoxInstructions, ToolAssistance.inputsLabel));\r\n break;\r\n }\r\n\r\n const instructions = ToolAssistance.createInstructions(mainInstruction, sections);\r\n IModelApp.notifications.setToolAssistance(instructions);\r\n }\r\n\r\n protected initSelectTool(): void {\r\n const method = this.selectionMethod;\r\n const mode = this.selectionMode;\r\n const enableLocate = SelectionMethod.Pick === method;\r\n\r\n this._isSelectByPoints = false;\r\n this._points.length = 0;\r\n\r\n this.initLocateElements(enableLocate, false, enableLocate ? \"default\" : IModelApp.viewManager.crossHairCursor, CoordinateLockOverrides.All);\r\n IModelApp.locateManager.options.allowDecorations = true; // Always locate to display tool tip even if we reject for adding to selection set...\r\n this.showPrompt(mode, method);\r\n }\r\n\r\n protected processMiss(_ev: BeButtonEvent): boolean {\r\n if (!this.iModel.selectionSet.isActive)\r\n return false;\r\n this.iModel.selectionSet.emptyAll();\r\n return true;\r\n }\r\n\r\n public updateSelection(elementId: Id64Arg, process: SelectionProcessing): boolean {\r\n let returnValue = false;\r\n switch (process) {\r\n case SelectionProcessing.AddElementToSelection:\r\n returnValue = this.iModel.selectionSet.add(elementId);\r\n break;\r\n case SelectionProcessing.RemoveElementFromSelection:\r\n returnValue = this.iModel.selectionSet.remove(elementId);\r\n break;\r\n case SelectionProcessing.InvertElementInSelection: // (if element is in selection remove it else add it.)\r\n returnValue = this.iModel.selectionSet.invert(elementId);\r\n break;\r\n case SelectionProcessing.ReplaceSelectionWithElement:\r\n this.iModel.selectionSet.replace(elementId);\r\n returnValue = true;\r\n break;\r\n default:\r\n return false;\r\n }\r\n // always force UI to sync display of options since the select option of Remove should only be enabled if the selection set has elements.\r\n if (returnValue)\r\n this.syncSelectionMode();\r\n return returnValue;\r\n }\r\n\r\n public async processSelection(elementId: Id64Arg, process: SelectionProcessing): Promise<boolean> { return this.updateSelection(elementId, process); }\r\n\r\n protected useOverlapSelection(ev: BeButtonEvent): boolean {\r\n if (undefined === ev.viewport)\r\n return false;\r\n const pt1 = ev.viewport.worldToView(this._points[0]);\r\n const pt2 = ev.viewport.worldToView(ev.point);\r\n const overlapMode = (pt1.x > pt2.x);\r\n return (ev.isShiftKey ? !overlapMode : overlapMode); // Shift inverts inside/overlap selection...\r\n }\r\n\r\n private selectByPointsDecorate(context: DecorateContext): void {\r\n if (!this._isSelectByPoints)\r\n return;\r\n\r\n const ev = new BeButtonEvent();\r\n IModelApp.toolAdmin.fillEventFromCursorLocation(ev);\r\n if (undefined === ev.viewport)\r\n return;\r\n\r\n const vp = context.viewport;\r\n const bestContrastIsBlack = (ColorDef.black === vp.getContrastToBackgroundColor());\r\n const crossingLine = (SelectionMethod.Line === this.selectionMethod || (SelectionMethod.Pick === this.selectionMethod && BeButton.Reset === ev.button));\r\n const overlapSelection = (crossingLine || this.useOverlapSelection(ev));\r\n\r\n const position = vp.worldToView(this._points[0]);\r\n position.x = Math.floor(position.x) + 0.5;\r\n position.y = Math.floor(position.y) + 0.5;\r\n const position2 = vp.worldToView(ev.point);\r\n position2.x = Math.floor(position2.x) + 0.5;\r\n position2.y = Math.floor(position2.y) + 0.5;\r\n const offset = position2.minus(position);\r\n\r\n const drawDecoration = (ctx: CanvasRenderingContext2D) => {\r\n ctx.strokeStyle = bestContrastIsBlack ? \"black\" : \"white\";\r\n ctx.lineWidth = 1;\r\n if (overlapSelection)\r\n ctx.setLineDash([5, 5]);\r\n\r\n if (crossingLine) {\r\n ctx.beginPath();\r\n ctx.moveTo(0, 0);\r\n ctx.lineTo(offset.x, offset.y);\r\n ctx.stroke();\r\n } else {\r\n ctx.strokeRect(0, 0, offset.x, offset.y);\r\n ctx.fillStyle = bestContrastIsBlack ? \"rgba(0,0,0,.06)\" : \"rgba(255,255,255,.06)\";\r\n ctx.fillRect(0, 0, offset.x, offset.y);\r\n }\r\n };\r\n context.addCanvasDecoration({ position, drawDecoration });\r\n }\r\n\r\n protected selectByPointsProcess(origin: Point3d, corner: Point3d, ev: BeButtonEvent, method: SelectionMethod, overlap: boolean) {\r\n const vp = ev.viewport;\r\n if (!vp)\r\n return;\r\n\r\n const pts: Point2d[] = [];\r\n pts[0] = new Point2d(Math.floor(origin.x + 0.5), Math.floor(origin.y + 0.5));\r\n pts[1] = new Point2d(Math.floor(corner.x + 0.5), Math.floor(corner.y + 0.5));\r\n const range = Range2d.createArray(pts);\r\n\r\n const rect = new ViewRect();\r\n rect.initFromRange(range);\r\n const allowTransients = this.wantPickableDecorations();\r\n\r\n vp.readPixels(rect, Pixel.Selector.Feature, (pixels) => {\r\n if (undefined === pixels)\r\n return;\r\n\r\n const sRange = Range2d.createNull();\r\n sRange.extendPoint(Point2d.create(vp.cssPixelsToDevicePixels(range.low.x), vp.cssPixelsToDevicePixels(range.low.y)));\r\n sRange.extendPoint(Point2d.create(vp.cssPixelsToDevicePixels(range.high.x), vp.cssPixelsToDevicePixels(range.high.y)));\r\n\r\n pts[0].x = vp.cssPixelsToDevicePixels(pts[0].x);\r\n pts[0].y = vp.cssPixelsToDevicePixels(pts[0].y);\r\n\r\n pts[1].x = vp.cssPixelsToDevicePixels(pts[1].x);\r\n pts[1].y = vp.cssPixelsToDevicePixels(pts[1].y);\r\n\r\n let contents = new Set<string>();\r\n const testPoint = Point2d.createZero();\r\n\r\n const getPixelElementId = (pixel: Pixel.Data) => {\r\n if (undefined === pixel.elementId || Id64.isInvalid(pixel.elementId))\r\n return undefined; // no geometry at this location...\r\n\r\n if (!allowTransients && Id64.isTransient(pixel.elementId))\r\n return undefined; // tool didn't request pickable decorations...\r\n\r\n if (!vp.isPixelSelectable(pixel))\r\n return undefined; // reality model, terrain, etc - not selectable\r\n\r\n return pixel.elementId;\r\n };\r\n\r\n if (SelectionMethod.Box === method) {\r\n const outline = overlap ? undefined : new Set<string>();\r\n const offset = sRange.clone();\r\n offset.expandInPlace(-2);\r\n for (testPoint.x = sRange.low.x; testPoint.x <= sRange.high.x; ++testPoint.x) {\r\n for (testPoint.y = sRange.low.y; testPoint.y <= sRange.high.y; ++testPoint.y) {\r\n const pixel = pixels.getPixel(testPoint.x, testPoint.y);\r\n const elementId = getPixelElementId(pixel);\r\n if (undefined === elementId)\r\n continue;\r\n\r\n if (undefined !== outline && !offset.containsPoint(testPoint))\r\n outline.add(elementId.toString());\r\n else\r\n contents.add(elementId.toString());\r\n }\r\n }\r\n if (undefined !== outline && 0 !== outline.size) {\r\n const inside = new Set<string>();\r\n contents.forEach((id) => {\r\n if (!outline.has(id))\r\n inside.add(id);\r\n });\r\n\r\n contents = inside;\r\n }\r\n } else {\r\n const closePoint = Point2d.createZero();\r\n for (testPoint.x = sRange.low.x; testPoint.x <= sRange.high.x; ++testPoint.x) {\r\n for (testPoint.y = sRange.low.y; testPoint.y <= sRange.high.y; ++testPoint.y) {\r\n const pixel = pixels.getPixel(testPoint.x, testPoint.y);\r\n const elementId = getPixelElementId(pixel);\r\n if (undefined === elementId)\r\n continue;\r\n\r\n const fraction = testPoint.fractionOfProjectionToLine(pts[0], pts[1], 0.0);\r\n pts[0].interpolate(fraction, pts[1], closePoint);\r\n if (closePoint.distance(testPoint) < 1.5)\r\n contents.add(elementId.toString());\r\n }\r\n }\r\n }\r\n\r\n if (0 === contents.size) {\r\n if (!ev.isControlKey && this.wantSelectionClearOnMiss(ev) && this.processMiss(ev))\r\n this.syncSelectionMode();\r\n return;\r\n }\r\n\r\n switch (this.selectionMode) {\r\n case SelectionMode.Replace:\r\n if (!ev.isControlKey)\r\n this.processSelection(contents, SelectionProcessing.ReplaceSelectionWithElement); // eslint-disable-line @typescript-eslint/no-floating-promises\r\n else\r\n this.processSelection(contents, SelectionProcessing.InvertElementInSelection); // eslint-disable-line @typescript-eslint/no-floating-promises\r\n break;\r\n case SelectionMode.Add:\r\n this.processSelection(contents, SelectionProcessing.AddElementToSelection); // eslint-disable-line @typescript-eslint/no-floating-promises\r\n break;\r\n case SelectionMode.Remove:\r\n this.processSelection(contents, SelectionProcessing.RemoveElementFromSelection); // eslint-disable-line @typescript-eslint/no-floating-promises\r\n break;\r\n }\r\n }, true);\r\n }\r\n\r\n protected selectByPointsStart(ev: BeButtonEvent): boolean {\r\n if (BeButton.Data !== ev.button && BeButton.Reset !== ev.button)\r\n return false;\r\n this._points.length = 0;\r\n this._points.push(ev.point.clone());\r\n this._isSelectByPoints = true;\r\n IModelApp.accuSnap.enableLocate(false);\r\n IModelApp.toolAdmin.setLocateCircleOn(false);\r\n this.showPrompt(this.selectionMode, this.selectionMethod);\r\n return true;\r\n }\r\n\r\n protected selectByPointsEnd(ev: BeButtonEvent): boolean {\r\n if (!this._isSelectByPoints)\r\n return false;\r\n\r\n const vp = ev.viewport;\r\n if (vp === undefined) {\r\n this.initSelectTool();\r\n return false;\r\n }\r\n\r\n const origin = vp.worldToView(this._points[0]);\r\n const corner = vp.worldToView(ev.point);\r\n if (SelectionMethod.Line === this.selectionMethod || (SelectionMethod.Pick === this.selectionMethod && BeButton.Reset === ev.button))\r\n this.selectByPointsProcess(origin, corner, ev, SelectionMethod.Line, true);\r\n else\r\n this.selectByPointsProcess(origin, corner, ev, SelectionMethod.Box, this.useOverlapSelection(ev));\r\n\r\n this.initSelectTool();\r\n vp.invalidateDecorations();\r\n return true;\r\n }\r\n\r\n public override async onMouseMotion(ev: BeButtonEvent): Promise<void> {\r\n if (undefined !== ev.viewport && this._isSelectByPoints)\r\n ev.viewport.invalidateDecorations();\r\n }\r\n\r\n public async selectDecoration(ev: BeButtonEvent, currHit?: HitDetail): Promise<EventHandled> {\r\n if (undefined === currHit)\r\n currHit = await IModelApp.locateManager.doLocate(new LocateResponse(), true, ev.point, ev.viewport, ev.inputSource);\r\n\r\n if (undefined !== currHit)\r\n return (currHit.isElementHit ? IModelApp.viewManager.overrideElementButtonEvent(currHit, ev) : IModelApp.viewManager.onDecorationButtonEvent(currHit, ev));\r\n\r\n return EventHandled.No;\r\n }\r\n\r\n public override async onMouseStartDrag(ev: BeButtonEvent): Promise<EventHandled> {\r\n IModelApp.accuSnap.clear(); // Need to test hit at start drag location, not current AccuSnap...\r\n if (EventHandled.Yes === await this.selectDecoration(ev))\r\n return EventHandled.Yes;\r\n if (InputSource.Touch === ev.inputSource && SelectionMethod.Pick === this.selectionMethod)\r\n return EventHandled.No; // Require method change for line/box selection...allow IdleTool to handle touch move...\r\n return this.selectByPointsStart(ev) ? EventHandled.Yes : EventHandled.No;\r\n }\r\n\r\n public override async onMouseEndDrag(ev: BeButtonEvent): Promise<EventHandled> {\r\n return this.selectByPointsEnd(ev) ? EventHandled.Yes : EventHandled.No;\r\n }\r\n\r\n public override async onDataButtonUp(ev: BeButtonEvent): Promise<EventHandled> {\r\n if (undefined === ev.viewport)\r\n return EventHandled.No;\r\n\r\n if (this.selectByPointsEnd(ev))\r\n return EventHandled.Yes;\r\n\r\n if (SelectionMethod.Pick !== this.selectionMethod) {\r\n if (!ev.isControlKey && this.wantSelectionClearOnMiss(ev) && this.processMiss(ev))\r\n this.syncSelectionMode();\r\n if (InputSource.Touch !== ev.inputSource)\r\n this.selectByPointsStart(ev); // Require touch move and not tap to start crossing line/box selection...\r\n return EventHandled.Yes;\r\n }\r\n\r\n const hit = await IModelApp.locateManager.doLocate(new LocateResponse(), true, ev.point, ev.viewport, ev.inputSource);\r\n if (hit !== undefined && !hit.isModelHit && !hit.isMapHit) { // model hit = terrain, reality models, background maps, etc - not selectable\r\n if (EventHandled.Yes === await this.selectDecoration(ev, hit))\r\n return EventHandled.Yes;\r\n\r\n switch (this.selectionMode) {\r\n case SelectionMode.Replace:\r\n await this.processSelection(hit.sourceId, ev.isControlKey ? SelectionProcessing.InvertElementInSelection : SelectionProcessing.ReplaceSelectionWithElement);\r\n break;\r\n\r\n case SelectionMode.Add:\r\n await this.processSelection(hit.sourceId, SelectionProcessing.AddElementToSelection);\r\n break;\r\n\r\n case SelectionMode.Remove:\r\n await this.processSelection(hit.sourceId, SelectionProcessing.RemoveElementFromSelection);\r\n break;\r\n }\r\n return EventHandled.Yes;\r\n }\r\n\r\n if (!ev.isControlKey && this.wantSelectionClearOnMiss(ev) && this.processMiss(ev))\r\n this.syncSelectionMode();\r\n\r\n return EventHandled.Yes;\r\n }\r\n\r\n public override async onResetButtonUp(ev: BeButtonEvent): Promise<EventHandled> {\r\n if (this._isSelectByPoints) {\r\n if (undefined !== ev.viewport)\r\n ev.viewport.invalidateDecorations();\r\n this.initSelectTool();\r\n return EventHandled.Yes;\r\n }\r\n\r\n // Check for overlapping hits...\r\n const lastHit = SelectionMode.Remove === this.selectionMode ? undefined : IModelApp.locateManager.currHit;\r\n if (lastHit && this.iModel.selectionSet.has(lastHit.sourceId)) {\r\n const autoHit = IModelApp.accuSnap.currHit;\r\n\r\n // Play nice w/auto-locate, only remove previous hit if not currently auto-locating or over previous hit\r\n if (undefined === autoHit || autoHit.isSameHit(lastHit)) {\r\n const response = new LocateResponse();\r\n let nextHit;\r\n do {\r\n nextHit = await IModelApp.locateManager.doLocate(response, false, ev.point, ev.viewport, ev.inputSource);\r\n } while (undefined !== nextHit && (nextHit.isModelHit || nextHit.isMapHit)); // Ignore reality models, terrain, maps, etc.\r\n\r\n // remove element(s) previously selected if in replace mode, or if we have a next element in add mode\r\n if (SelectionMode.Replace === this.selectionMode || undefined !== nextHit)\r\n await this.processSelection(lastHit.sourceId, SelectionProcessing.RemoveElementFromSelection);\r\n\r\n // add element(s) located via reset button\r\n if (undefined !== nextHit)\r\n await this.processSelection(nextHit.sourceId, SelectionProcessing.AddElementToSelection);\r\n\r\n return EventHandled.Yes;\r\n }\r\n }\r\n\r\n if (EventHandled.Yes === await this.selectDecoration(ev, IModelApp.accuSnap.currHit))\r\n return EventHandled.Yes;\r\n\r\n await IModelApp.accuSnap.resetButton();\r\n return EventHandled.Yes;\r\n }\r\n\r\n public override async onSuspend() {\r\n this._isSuspended = true;\r\n if (this.wantEditManipulators())\r\n IModelApp.toolAdmin.manipulatorToolEvent.raiseEvent(this, ManipulatorToolEvent.Suspend);\r\n }\r\n\r\n public override async onUnsuspend() {\r\n this._isSuspended = false;\r\n if (this.wantEditManipulators())\r\n IModelApp.toolAdmin.manipulatorToolEvent.raiseEvent(this, ManipulatorToolEvent.Unsuspend);\r\n\r\n this.showPrompt(this.selectionMode, this.selectionMethod);\r\n }\r\n\r\n public override async onTouchMoveStart(ev: BeTouchEvent, startEv: BeTouchEvent): Promise<EventHandled> {\r\n if (startEv.isSingleTouch && !this._isSelectByPoints)\r\n await IModelApp.toolAdmin.convertTouchMoveStartToButtonDownAndMotion(startEv, ev);\r\n return (this._isSuspended || this._isSelectByPoints) ? EventHandled.Yes : EventHandled.No;\r\n }\r\n\r\n public override async onTouchMove(ev: BeTouchEvent): Promise<void> {\r\n if (this._isSelectByPoints)\r\n return IModelApp.toolAdmin.convertTouchMoveToMotion(ev);\r\n }\r\n\r\n public override async onTouchComplete(ev: BeTouchEvent): Promise<void> {\r\n if (this._isSelectByPoints)\r\n return IModelApp.toolAdmin.convertTouchEndToButtonUp(ev);\r\n }\r\n\r\n public override async onTouchCancel(ev: BeTouchEvent): Promise<void> {\r\n if (this._isSelectByPoints)\r\n return IModelApp.toolAdmin.convertTouchEndToButtonUp(ev, BeButton.Reset);\r\n }\r\n\r\n public override decorate(context: DecorateContext): void { this.selectByPointsDecorate(context); }\r\n\r\n public override async onModifierKeyTransition(_wentDown: boolean, modifier: BeModifierKeys, _event: KeyboardEvent): Promise<EventHandled> {\r\n return (modifier === BeModifierKeys.Shift && this._isSelectByPoints) ? EventHandled.Yes : EventHandled.No;\r\n }\r\n\r\n public override async filterHit(hit: HitDetail, out?: LocateResponse): Promise<LocateFilterStatus> {\r\n if (!this.wantPickableDecorations() && !hit.isElementHit)\r\n return LocateFilterStatus.Reject;\r\n\r\n const mode = this.selectionMode;\r\n if (SelectionMode.Replace === mode)\r\n return LocateFilterStatus.Accept;\r\n\r\n const isSelected = this.iModel.selectionSet.has(hit.sourceId);\r\n const status = ((SelectionMode.Add === mode ? !isSelected : isSelected) ? LocateFilterStatus.Accept : LocateFilterStatus.Reject);\r\n if (out && LocateFilterStatus.Reject === status)\r\n out.explanation = CoreTools.translate(`ElementSet.Error.${isSelected ? \"AlreadySelected\" : \"NotSelected\"}`);\r\n return status;\r\n }\r\n\r\n public async onRestartTool(): Promise<void> { return this.exitTool(); }\r\n\r\n public override async onCleanup() {\r\n if (this.wantEditManipulators())\r\n IModelApp.toolAdmin.manipulatorToolEvent.raiseEvent(this, ManipulatorToolEvent.Stop);\r\n }\r\n\r\n public override async onPostInstall() {\r\n await super.onPostInstall();\r\n if (!this.targetView)\r\n return;\r\n if (this.wantEditManipulators())\r\n IModelApp.toolAdmin.manipulatorToolEvent.raiseEvent(this, ManipulatorToolEvent.Start);\r\n this.initSelectTool();\r\n }\r\n\r\n public static async startTool(): Promise<boolean> { return new SelectionTool().run(); }\r\n\r\n private syncSelectionMode(): void {\r\n if (SelectionMode.Remove === this.selectionMode && !this.iModel.selectionSet.isActive) {\r\n // No selection active resetting selection mode since there is nothing to Remove\r\n this.selectionMode = SelectionMode.Replace;\r\n this.initSelectTool();\r\n }\r\n if (this.wantToolSettings()) {\r\n const syncMode: DialogPropertySyncItem = { value: this._selectionModeValue, propertyName: SelectionTool._modesName };\r\n IModelApp.toolAdmin.toolSettingsState.saveToolSettingProperty(this.toolId, syncMode);\r\n this.syncToolSettingsProperties([syncMode]);\r\n }\r\n }\r\n\r\n /** Used to supply DefaultToolSettingProvider with a list of properties to use to generate ToolSettings. If undefined then no ToolSettings will be displayed\r\n * @beta\r\n */\r\n public override supplyToolSettingsProperties(): DialogItem[] | undefined {\r\n if (!this.wantToolSettings())\r\n return undefined;\r\n\r\n // load latest values from session\r\n IModelApp.toolAdmin.toolSettingsState.getInitialToolSettingValues(this.toolId, [SelectionTool._modesName])?.forEach((value) => {\r\n if (value.propertyName === SelectionTool._modesName)\r\n this._selectionModeValue = value.value;\r\n });\r\n\r\n // Make sure a mode of SelectionMode.Remove is valid\r\n if (SelectionMode.Remove === this.selectionMode && !this.iModel.selectionSet.isActive) {\r\n this.selectionMode = SelectionMode.Replace;\r\n IModelApp.toolAdmin.toolSettingsState.saveToolSettingProperty(this.toolId, { propertyName: SelectionTool._modesName, value: this._selectionModeValue });\r\n }\r\n\r\n const toolSettings = new Array<DialogItem>();\r\n // generate 3 columns - label will be placed in column 0 and button group editors in columns 1 and 2.\r\n toolSettings.push({ value: this._selectionMethodValue, property: SelectionTool._getMethodsDescription(), editorPosition: { rowPriority: 0, columnIndex: 1 } });\r\n toolSettings.push({ value: this._selectionModeValue, property: SelectionTool._getModesDescription(), editorPosition: { rowPriority: 0, columnIndex: 2 } });\r\n return toolSettings;\r\n }\r\n\r\n /** Used to send changes from UI back to Tool\r\n * @beta\r\n */\r\n public override async applyToolSettingPropertyChange(updatedValue: DialogPropertySyncItem): Promise<boolean> {\r\n let changed = false;\r\n if (updatedValue.propertyName === SelectionTool._methodsName) {\r\n const saveWantManipulators = this.wantEditManipulators();\r\n this._selectionMethodValue = updatedValue.value;\r\n if (this._selectionMethodValue) {\r\n const currWantManipulators = this.wantEditManipulators();\r\n if (saveWantManipulators !== currWantManipulators)\r\n IModelApp.toolAdmin.manipulatorToolEvent.raiseEvent(this, currWantManipulators ? ManipulatorToolEvent.Start : ManipulatorToolEvent.Stop);\r\n changed = true;\r\n }\r\n }\r\n if (updatedValue.propertyName === SelectionTool._modesName) {\r\n this._selectionModeValue = updatedValue.value;\r\n if (this._selectionModeValue) {\r\n if (this.wantToolSettings())\r\n IModelApp.toolAdmin.toolSettingsState.saveToolSettingProperty(this.toolId, { propertyName: SelectionTool._modesName, value: this._selectionModeValue });\r\n changed = true;\r\n }\r\n }\r\n if (changed)\r\n this.initSelectTool();\r\n return true; // return true if change is valid\r\n }\r\n}\r\n"]}
|
|
1
|
+
{"version":3,"file":"SelectTool.js","sourceRoot":"","sources":["../../../src/tools/SelectTool.ts"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\r\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\r\n* See LICENSE.md in the project root for license terms and full copyright notice.\r\n*--------------------------------------------------------------------------------------------*/\r\n/** @packageDocumentation\r\n * @module SelectionSet\r\n */\r\n\r\nimport { Id64, Id64Arg } from \"@itwin/core-bentley\";\r\nimport { Point2d, Point3d, Range2d } from \"@itwin/core-geometry\";\r\nimport { ColorDef } from \"@itwin/core-common\";\r\nimport {\r\n ButtonGroupEditorParams, DialogItem, DialogItemValue, DialogPropertySyncItem, PropertyDescription, PropertyEditorParamTypes,\r\n SuppressLabelEditorParams,\r\n} from \"@itwin/appui-abstract\";\r\nimport { LocateFilterStatus, LocateResponse } from \"../ElementLocateManager\";\r\nimport { HitDetail } from \"../HitDetail\";\r\nimport { IModelApp } from \"../IModelApp\";\r\nimport { Pixel } from \"../render/Pixel\";\r\nimport { DecorateContext } from \"../ViewContext\";\r\nimport { ViewRect } from \"../common/ViewRect\";\r\nimport { PrimitiveTool } from \"./PrimitiveTool\";\r\nimport { BeButton, BeButtonEvent, BeModifierKeys, BeTouchEvent, CoordinateLockOverrides, CoreTools, EventHandled, InputSource } from \"./Tool\";\r\nimport { ManipulatorToolEvent } from \"./ToolAdmin\";\r\nimport { ToolAssistance, ToolAssistanceImage, ToolAssistanceInputMethod, ToolAssistanceInstruction, ToolAssistanceSection } from \"./ToolAssistance\";\r\n\r\n// cSpell:ignore buttongroup\r\n\r\n/** The method for choosing elements with the [[SelectionTool]]\r\n * @public\r\n * @extensions\r\n */\r\nexport enum SelectionMethod {\r\n /** Identify element(s) by picking for drag selection (inside/overlap for drag box selection determined by point direction and shift key) */\r\n Pick,\r\n /** Identify elements by overlap with crossing line */\r\n Line,\r\n /** Identify elements by box selection (inside/overlap for box selection determined by point direction and shift key) */\r\n Box,\r\n}\r\n\r\n/** The mode for choosing elements with the [[SelectionTool]]\r\n * @public\r\n * @extensions\r\n */\r\nexport enum SelectionMode {\r\n /** Identified elements replace the current selection set (use control key to add or remove) */\r\n Replace,\r\n /** Identified elements are added to the current selection set */\r\n Add,\r\n /** Identified elements are removed from the current selection set */\r\n Remove,\r\n}\r\n\r\n/** The processing method to use to update the current selection.\r\n * @public\r\n * @extensions\r\n */\r\nexport enum SelectionProcessing {\r\n /** Add element to selection. */\r\n AddElementToSelection,\r\n /** Remove element from selection. */\r\n RemoveElementFromSelection,\r\n /** If element is in selection remove it, else add it. */\r\n InvertElementInSelection,\r\n /** Replace current selection with element. */\r\n ReplaceSelectionWithElement,\r\n}\r\n\r\n/** Tool for picking a set of elements of interest, selected by the user.\r\n * @public\r\n */\r\nexport class SelectionTool extends PrimitiveTool {\r\n public static override hidden = false;\r\n public static override toolId = \"Select\";\r\n public static override iconSpec = \"icon-cursor\";\r\n protected _isSelectByPoints = false;\r\n protected _isSuspended = false;\r\n protected readonly _points: Point3d[] = [];\r\n private _selectionMethodValue: DialogItemValue = { value: SelectionMethod.Pick };\r\n private _selectionModeValue: DialogItemValue = { value: SelectionMode.Replace };\r\n\r\n public override requireWriteableTarget(): boolean { return false; }\r\n public override autoLockTarget(): void { } // NOTE: For selecting elements we only care about iModel, so don't lock target model automatically.\r\n\r\n protected wantSelectionClearOnMiss(_ev: BeButtonEvent): boolean { return SelectionMode.Replace === this.selectionMode; }\r\n protected wantEditManipulators(): boolean { return SelectionMethod.Pick === this.selectionMethod; }\r\n protected wantPickableDecorations(): boolean { return this.wantEditManipulators(); } // Allow pickable decorations selection to be independent of manipulators...\r\n protected wantToolSettings(): boolean { return true; }\r\n\r\n public get selectionMethod(): SelectionMethod { return this._selectionMethodValue.value as SelectionMethod; }\r\n public set selectionMethod(method: SelectionMethod) { this._selectionMethodValue.value = method; }\r\n public get selectionMode(): SelectionMode { return this._selectionModeValue.value as SelectionMode; }\r\n public set selectionMode(mode: SelectionMode) { this._selectionModeValue.value = mode; }\r\n\r\n private static methodsMessage(str: string) { return CoreTools.translate(`ElementSet.SelectionMethods.${str}`); }\r\n private static _methodsName = \"selectionMethods\";\r\n /* The property descriptions used to generate ToolSettings UI. */\r\n private static _getMethodsDescription(): PropertyDescription {\r\n return {\r\n name: SelectionTool._methodsName,\r\n displayLabel: \"\",\r\n typename: \"enum\",\r\n editor: {\r\n name: \"enum-buttongroup\",\r\n params: [{\r\n type: PropertyEditorParamTypes.ButtonGroupData,\r\n buttons: [\r\n { iconSpec: \"icon-select-single\" },\r\n { iconSpec: \"icon-select-line\" },\r\n { iconSpec: \"icon-select-box\" },\r\n ],\r\n } as ButtonGroupEditorParams, {\r\n type: PropertyEditorParamTypes.SuppressEditorLabel,\r\n suppressLabelPlaceholder: true,\r\n } as SuppressLabelEditorParams,\r\n ],\r\n },\r\n enum: {\r\n choices: [\r\n { label: SelectionTool.methodsMessage(\"Pick\"), value: SelectionMethod.Pick },\r\n { label: SelectionTool.methodsMessage(\"Line\"), value: SelectionMethod.Line },\r\n { label: SelectionTool.methodsMessage(\"Box\"), value: SelectionMethod.Box },\r\n ],\r\n },\r\n };\r\n }\r\n\r\n private static modesMessage(str: string) { return CoreTools.translate(`ElementSet.SelectionModes.${str}`); }\r\n private static _modesName = \"selectionModes\";\r\n /* The property descriptions used to generate ToolSettings UI. */\r\n private static _getModesDescription(): PropertyDescription {\r\n return {\r\n name: SelectionTool._modesName,\r\n displayLabel: \"\",\r\n typename: \"enum\",\r\n editor: {\r\n name: \"enum-buttongroup\",\r\n params: [{\r\n type: PropertyEditorParamTypes.ButtonGroupData,\r\n buttons: [\r\n { iconSpec: \"icon-replace\" },\r\n { iconSpec: \"icon-select-plus\" },\r\n {\r\n iconSpec: \"icon-select-minus\",\r\n isEnabledFunction: () => {\r\n const tool = IModelApp.toolAdmin.activeTool;\r\n return tool instanceof PrimitiveTool ? tool.iModel.selectionSet.isActive : false;\r\n },\r\n },\r\n ],\r\n } as ButtonGroupEditorParams, {\r\n type: PropertyEditorParamTypes.SuppressEditorLabel,\r\n suppressLabelPlaceholder: true,\r\n } as SuppressLabelEditorParams,\r\n ],\r\n },\r\n enum: {\r\n choices: [\r\n { label: SelectionTool.modesMessage(\"Replace\"), value: SelectionMode.Replace },\r\n { label: SelectionTool.modesMessage(\"Add\"), value: SelectionMode.Add },\r\n { label: SelectionTool.modesMessage(\"Remove\"), value: SelectionMode.Remove },\r\n ],\r\n },\r\n };\r\n }\r\n\r\n protected showPrompt(mode: SelectionMode, method: SelectionMethod): void {\r\n let mainMsg = \"ElementSet.Prompts.\";\r\n switch (method) {\r\n case SelectionMethod.Pick:\r\n mainMsg += \"IdentifyElement\";\r\n break;\r\n case SelectionMethod.Line:\r\n mainMsg += (0 === this._points.length ? \"StartPoint\" : \"EndPoint\");\r\n break;\r\n case SelectionMethod.Box:\r\n mainMsg += (0 === this._points.length ? \"StartCorner\" : \"OppositeCorner\");\r\n break;\r\n }\r\n\r\n const mainInstruction = ToolAssistance.createInstruction(this.iconSpec, CoreTools.translate(mainMsg));\r\n const sections: ToolAssistanceSection[] = [];\r\n\r\n switch (method) {\r\n case SelectionMethod.Pick:\r\n const mousePickInstructions: ToolAssistanceInstruction[] = [];\r\n mousePickInstructions.push(ToolAssistance.createInstruction(ToolAssistanceImage.LeftClick, CoreTools.translate(\"ElementSet.Inputs.AcceptElement\"), false, ToolAssistanceInputMethod.Mouse));\r\n mousePickInstructions.push(ToolAssistance.createInstruction(ToolAssistanceImage.LeftClickDrag, CoreTools.translate(\"ElementSet.Inputs.BoxCorners\"), false, ToolAssistanceInputMethod.Mouse));\r\n mousePickInstructions.push(ToolAssistance.createInstruction(ToolAssistanceImage.RightClickDrag, CoreTools.translate(\"ElementSet.Inputs.CrossingLine\"), false, ToolAssistanceInputMethod.Mouse));\r\n mousePickInstructions.push(ToolAssistance.createModifierKeyInstruction(ToolAssistance.shiftKey, ToolAssistanceImage.LeftClickDrag, CoreTools.translate(\"ElementSet.Inputs.OverlapSelection\"), false, ToolAssistanceInputMethod.Mouse));\r\n if (SelectionMode.Replace === mode) {\r\n mousePickInstructions.push(ToolAssistance.createKeyboardInstruction(ToolAssistance.ctrlKeyboardInfo, CoreTools.translate(\"ElementSet.Inputs.InvertSelection\"), false, ToolAssistanceInputMethod.Mouse));\r\n mousePickInstructions.push(ToolAssistance.createInstruction(ToolAssistanceImage.CursorClick, CoreTools.translate(\"ElementSet.Inputs.ClearSelection\"), false, ToolAssistanceInputMethod.Mouse));\r\n }\r\n sections.push(ToolAssistance.createSection(mousePickInstructions, ToolAssistance.inputsLabel));\r\n\r\n const touchPickInstructions: ToolAssistanceInstruction[] = [];\r\n if (!ToolAssistance.createTouchCursorInstructions(touchPickInstructions))\r\n touchPickInstructions.push(ToolAssistance.createInstruction(ToolAssistanceImage.OneTouchTap, CoreTools.translate(\"ElementSet.Inputs.AcceptElement\"), false, ToolAssistanceInputMethod.Touch));\r\n sections.push(ToolAssistance.createSection(touchPickInstructions, ToolAssistance.inputsLabel));\r\n break;\r\n case SelectionMethod.Line:\r\n const mouseLineInstructions: ToolAssistanceInstruction[] = [];\r\n mouseLineInstructions.push(ToolAssistance.createInstruction(ToolAssistanceImage.LeftClick, CoreTools.translate(\"ElementSet.Inputs.AcceptPoint\"), false, ToolAssistanceInputMethod.Mouse));\r\n if (SelectionMode.Replace === mode)\r\n mouseLineInstructions.push(ToolAssistance.createModifierKeyInstruction(ToolAssistance.ctrlKey, ToolAssistanceImage.LeftClick, CoreTools.translate(\"ElementSet.Inputs.InvertSelection\"), false, ToolAssistanceInputMethod.Mouse));\r\n sections.push(ToolAssistance.createSection(mouseLineInstructions, ToolAssistance.inputsLabel));\r\n\r\n const touchLineInstructions: ToolAssistanceInstruction[] = [];\r\n touchLineInstructions.push(ToolAssistance.createInstruction(ToolAssistanceImage.OneTouchDrag, CoreTools.translate(\"ElementSet.Inputs.AcceptPoint\"), false, ToolAssistanceInputMethod.Touch));\r\n sections.push(ToolAssistance.createSection(touchLineInstructions, ToolAssistance.inputsLabel));\r\n break;\r\n case SelectionMethod.Box:\r\n const mouseBoxInstructions: ToolAssistanceInstruction[] = [];\r\n mouseBoxInstructions.push(ToolAssistance.createInstruction(ToolAssistanceImage.LeftClick, CoreTools.translate(\"ElementSet.Inputs.AcceptPoint\"), false, ToolAssistanceInputMethod.Mouse));\r\n mouseBoxInstructions.push(ToolAssistance.createModifierKeyInstruction(ToolAssistance.shiftKey, ToolAssistanceImage.LeftClick, CoreTools.translate(\"ElementSet.Inputs.OverlapSelection\"), false, ToolAssistanceInputMethod.Mouse));\r\n if (SelectionMode.Replace === mode)\r\n mouseBoxInstructions.push(ToolAssistance.createModifierKeyInstruction(ToolAssistance.ctrlKey, ToolAssistanceImage.LeftClick, CoreTools.translate(\"ElementSet.Inputs.InvertSelection\"), false, ToolAssistanceInputMethod.Mouse));\r\n sections.push(ToolAssistance.createSection(mouseBoxInstructions, ToolAssistance.inputsLabel));\r\n\r\n const touchBoxInstructions: ToolAssistanceInstruction[] = [];\r\n touchBoxInstructions.push(ToolAssistance.createInstruction(ToolAssistanceImage.OneTouchDrag, CoreTools.translate(\"ElementSet.Inputs.AcceptPoint\"), false, ToolAssistanceInputMethod.Touch));\r\n sections.push(ToolAssistance.createSection(touchBoxInstructions, ToolAssistance.inputsLabel));\r\n break;\r\n }\r\n\r\n const instructions = ToolAssistance.createInstructions(mainInstruction, sections);\r\n IModelApp.notifications.setToolAssistance(instructions);\r\n }\r\n\r\n protected initSelectTool(): void {\r\n const method = this.selectionMethod;\r\n const mode = this.selectionMode;\r\n const enableLocate = SelectionMethod.Pick === method;\r\n\r\n this._isSelectByPoints = false;\r\n this._points.length = 0;\r\n\r\n this.initLocateElements(enableLocate, false, enableLocate ? \"default\" : IModelApp.viewManager.crossHairCursor, CoordinateLockOverrides.All);\r\n IModelApp.locateManager.options.allowDecorations = true; // Always locate to display tool tip even if we reject for adding to selection set...\r\n this.showPrompt(mode, method);\r\n }\r\n\r\n protected processMiss(_ev: BeButtonEvent): boolean {\r\n if (!this.iModel.selectionSet.isActive)\r\n return false;\r\n this.iModel.selectionSet.emptyAll();\r\n return true;\r\n }\r\n\r\n public updateSelection(elementId: Id64Arg, process: SelectionProcessing): boolean {\r\n let returnValue = false;\r\n switch (process) {\r\n case SelectionProcessing.AddElementToSelection:\r\n returnValue = this.iModel.selectionSet.add(elementId);\r\n break;\r\n case SelectionProcessing.RemoveElementFromSelection:\r\n returnValue = this.iModel.selectionSet.remove(elementId);\r\n break;\r\n case SelectionProcessing.InvertElementInSelection: // (if element is in selection remove it else add it.)\r\n returnValue = this.iModel.selectionSet.invert(elementId);\r\n break;\r\n case SelectionProcessing.ReplaceSelectionWithElement:\r\n this.iModel.selectionSet.replace(elementId);\r\n returnValue = true;\r\n break;\r\n default:\r\n return false;\r\n }\r\n // always force UI to sync display of options since the select option of Remove should only be enabled if the selection set has elements.\r\n if (returnValue)\r\n this.syncSelectionMode();\r\n return returnValue;\r\n }\r\n\r\n public async processSelection(elementId: Id64Arg, process: SelectionProcessing): Promise<boolean> { return this.updateSelection(elementId, process); }\r\n\r\n protected useOverlapSelection(ev: BeButtonEvent): boolean {\r\n if (undefined === ev.viewport)\r\n return false;\r\n const pt1 = ev.viewport.worldToView(this._points[0]);\r\n const pt2 = ev.viewport.worldToView(ev.point);\r\n const overlapMode = (pt1.x > pt2.x);\r\n return (ev.isShiftKey ? !overlapMode : overlapMode); // Shift inverts inside/overlap selection...\r\n }\r\n\r\n private selectByPointsDecorate(context: DecorateContext): void {\r\n if (!this._isSelectByPoints)\r\n return;\r\n\r\n const ev = new BeButtonEvent();\r\n IModelApp.toolAdmin.fillEventFromCursorLocation(ev);\r\n if (undefined === ev.viewport)\r\n return;\r\n\r\n const vp = context.viewport;\r\n const bestContrastIsBlack = (ColorDef.black === vp.getContrastToBackgroundColor());\r\n const crossingLine = (SelectionMethod.Line === this.selectionMethod || (SelectionMethod.Pick === this.selectionMethod && BeButton.Reset === ev.button));\r\n const overlapSelection = (crossingLine || this.useOverlapSelection(ev));\r\n\r\n const position = vp.worldToView(this._points[0]);\r\n position.x = Math.floor(position.x) + 0.5;\r\n position.y = Math.floor(position.y) + 0.5;\r\n const position2 = vp.worldToView(ev.point);\r\n position2.x = Math.floor(position2.x) + 0.5;\r\n position2.y = Math.floor(position2.y) + 0.5;\r\n const offset = position2.minus(position);\r\n\r\n const drawDecoration = (ctx: CanvasRenderingContext2D) => {\r\n ctx.strokeStyle = bestContrastIsBlack ? \"black\" : \"white\";\r\n ctx.lineWidth = 1;\r\n if (overlapSelection)\r\n ctx.setLineDash([5, 5]);\r\n\r\n if (crossingLine) {\r\n ctx.beginPath();\r\n ctx.moveTo(0, 0);\r\n ctx.lineTo(offset.x, offset.y);\r\n ctx.stroke();\r\n } else {\r\n ctx.strokeRect(0, 0, offset.x, offset.y);\r\n ctx.fillStyle = bestContrastIsBlack ? \"rgba(0,0,0,.06)\" : \"rgba(255,255,255,.06)\";\r\n ctx.fillRect(0, 0, offset.x, offset.y);\r\n }\r\n };\r\n context.addCanvasDecoration({ position, drawDecoration });\r\n }\r\n\r\n protected selectByPointsProcess(origin: Point3d, corner: Point3d, ev: BeButtonEvent, method: SelectionMethod, overlap: boolean) {\r\n const vp = ev.viewport;\r\n if (!vp)\r\n return;\r\n\r\n const pts: Point2d[] = [];\r\n pts[0] = new Point2d(Math.floor(origin.x + 0.5), Math.floor(origin.y + 0.5));\r\n pts[1] = new Point2d(Math.floor(corner.x + 0.5), Math.floor(corner.y + 0.5));\r\n const range = Range2d.createArray(pts);\r\n\r\n const rect = new ViewRect();\r\n rect.initFromRange(range);\r\n const allowTransients = this.wantPickableDecorations();\r\n\r\n vp.readPixels(rect, Pixel.Selector.Feature, (pixels) => {\r\n if (undefined === pixels)\r\n return;\r\n\r\n const sRange = Range2d.createNull();\r\n sRange.extendPoint(Point2d.create(vp.cssPixelsToDevicePixels(range.low.x), vp.cssPixelsToDevicePixels(range.low.y)));\r\n sRange.extendPoint(Point2d.create(vp.cssPixelsToDevicePixels(range.high.x), vp.cssPixelsToDevicePixels(range.high.y)));\r\n\r\n pts[0].x = vp.cssPixelsToDevicePixels(pts[0].x);\r\n pts[0].y = vp.cssPixelsToDevicePixels(pts[0].y);\r\n\r\n pts[1].x = vp.cssPixelsToDevicePixels(pts[1].x);\r\n pts[1].y = vp.cssPixelsToDevicePixels(pts[1].y);\r\n\r\n let contents = new Set<string>();\r\n const testPoint = Point2d.createZero();\r\n\r\n const getPixelElementId = (pixel: Pixel.Data) => {\r\n if (undefined === pixel.elementId || Id64.isInvalid(pixel.elementId))\r\n return undefined; // no geometry at this location...\r\n\r\n if (!allowTransients && Id64.isTransient(pixel.elementId))\r\n return undefined; // tool didn't request pickable decorations...\r\n\r\n if (!vp.isPixelSelectable(pixel))\r\n return undefined; // reality model, terrain, etc - not selectable\r\n\r\n return pixel.elementId;\r\n };\r\n\r\n if (SelectionMethod.Box === method) {\r\n const outline = overlap ? undefined : new Set<string>();\r\n const offset = sRange.clone();\r\n offset.expandInPlace(-2);\r\n for (testPoint.x = sRange.low.x; testPoint.x <= sRange.high.x; ++testPoint.x) {\r\n for (testPoint.y = sRange.low.y; testPoint.y <= sRange.high.y; ++testPoint.y) {\r\n const pixel = pixels.getPixel(testPoint.x, testPoint.y);\r\n const elementId = getPixelElementId(pixel);\r\n if (undefined === elementId)\r\n continue;\r\n\r\n if (undefined !== outline && !offset.containsPoint(testPoint))\r\n outline.add(elementId.toString());\r\n else\r\n contents.add(elementId.toString());\r\n }\r\n }\r\n if (undefined !== outline && 0 !== outline.size) {\r\n const inside = new Set<string>();\r\n contents.forEach((id) => {\r\n if (!outline.has(id))\r\n inside.add(id);\r\n });\r\n\r\n contents = inside;\r\n }\r\n } else {\r\n const closePoint = Point2d.createZero();\r\n for (testPoint.x = sRange.low.x; testPoint.x <= sRange.high.x; ++testPoint.x) {\r\n for (testPoint.y = sRange.low.y; testPoint.y <= sRange.high.y; ++testPoint.y) {\r\n const pixel = pixels.getPixel(testPoint.x, testPoint.y);\r\n const elementId = getPixelElementId(pixel);\r\n if (undefined === elementId)\r\n continue;\r\n\r\n const fraction = testPoint.fractionOfProjectionToLine(pts[0], pts[1], 0.0);\r\n pts[0].interpolate(fraction, pts[1], closePoint);\r\n if (closePoint.distance(testPoint) < 1.5)\r\n contents.add(elementId.toString());\r\n }\r\n }\r\n }\r\n\r\n if (0 === contents.size) {\r\n if (!ev.isControlKey && this.wantSelectionClearOnMiss(ev) && this.processMiss(ev))\r\n this.syncSelectionMode();\r\n return;\r\n }\r\n\r\n switch (this.selectionMode) {\r\n case SelectionMode.Replace:\r\n if (!ev.isControlKey)\r\n this.processSelection(contents, SelectionProcessing.ReplaceSelectionWithElement); // eslint-disable-line @typescript-eslint/no-floating-promises\r\n else\r\n this.processSelection(contents, SelectionProcessing.InvertElementInSelection); // eslint-disable-line @typescript-eslint/no-floating-promises\r\n break;\r\n case SelectionMode.Add:\r\n this.processSelection(contents, SelectionProcessing.AddElementToSelection); // eslint-disable-line @typescript-eslint/no-floating-promises\r\n break;\r\n case SelectionMode.Remove:\r\n this.processSelection(contents, SelectionProcessing.RemoveElementFromSelection); // eslint-disable-line @typescript-eslint/no-floating-promises\r\n break;\r\n }\r\n }, true);\r\n }\r\n\r\n protected selectByPointsStart(ev: BeButtonEvent): boolean {\r\n if (BeButton.Data !== ev.button && BeButton.Reset !== ev.button)\r\n return false;\r\n this._points.length = 0;\r\n this._points.push(ev.point.clone());\r\n this._isSelectByPoints = true;\r\n IModelApp.accuSnap.enableLocate(false);\r\n IModelApp.toolAdmin.setLocateCircleOn(false);\r\n this.showPrompt(this.selectionMode, this.selectionMethod);\r\n return true;\r\n }\r\n\r\n protected selectByPointsEnd(ev: BeButtonEvent): boolean {\r\n if (!this._isSelectByPoints)\r\n return false;\r\n\r\n const vp = ev.viewport;\r\n if (vp === undefined) {\r\n this.initSelectTool();\r\n return false;\r\n }\r\n\r\n const origin = vp.worldToView(this._points[0]);\r\n const corner = vp.worldToView(ev.point);\r\n if (SelectionMethod.Line === this.selectionMethod || (SelectionMethod.Pick === this.selectionMethod && BeButton.Reset === ev.button))\r\n this.selectByPointsProcess(origin, corner, ev, SelectionMethod.Line, true);\r\n else\r\n this.selectByPointsProcess(origin, corner, ev, SelectionMethod.Box, this.useOverlapSelection(ev));\r\n\r\n this.initSelectTool();\r\n vp.invalidateDecorations();\r\n return true;\r\n }\r\n\r\n public override async onMouseMotion(ev: BeButtonEvent): Promise<void> {\r\n if (undefined !== ev.viewport && this._isSelectByPoints)\r\n ev.viewport.invalidateDecorations();\r\n }\r\n\r\n public async selectDecoration(ev: BeButtonEvent, currHit?: HitDetail): Promise<EventHandled> {\r\n if (undefined === currHit)\r\n currHit = await IModelApp.locateManager.doLocate(new LocateResponse(), true, ev.point, ev.viewport, ev.inputSource);\r\n\r\n if (undefined !== currHit)\r\n return (currHit.isElementHit ? IModelApp.viewManager.overrideElementButtonEvent(currHit, ev) : IModelApp.viewManager.onDecorationButtonEvent(currHit, ev));\r\n\r\n return EventHandled.No;\r\n }\r\n\r\n public async processHit(ev: BeButtonEvent, hit: HitDetail): Promise<EventHandled> {\r\n if (hit.isModelHit || hit.isMapHit)\r\n return EventHandled.No; // model hit = terrain, reality models, background maps, etc - not selectable\r\n\r\n switch (this.selectionMode) {\r\n case SelectionMode.Replace:\r\n await this.processSelection(hit.sourceId, ev.isControlKey ? SelectionProcessing.InvertElementInSelection : SelectionProcessing.ReplaceSelectionWithElement);\r\n break;\r\n\r\n case SelectionMode.Add:\r\n await this.processSelection(hit.sourceId, SelectionProcessing.AddElementToSelection);\r\n break;\r\n\r\n case SelectionMode.Remove:\r\n await this.processSelection(hit.sourceId, SelectionProcessing.RemoveElementFromSelection);\r\n break;\r\n }\r\n return EventHandled.Yes;\r\n }\r\n\r\n public override async onMouseStartDrag(ev: BeButtonEvent): Promise<EventHandled> {\r\n IModelApp.accuSnap.clear(); // Need to test hit at start drag location, not current AccuSnap...\r\n if (EventHandled.Yes === await this.selectDecoration(ev))\r\n return EventHandled.Yes;\r\n if (InputSource.Touch === ev.inputSource && SelectionMethod.Pick === this.selectionMethod)\r\n return EventHandled.No; // Require method change for line/box selection...allow IdleTool to handle touch move...\r\n return this.selectByPointsStart(ev) ? EventHandled.Yes : EventHandled.No;\r\n }\r\n\r\n public override async onMouseEndDrag(ev: BeButtonEvent): Promise<EventHandled> {\r\n return this.selectByPointsEnd(ev) ? EventHandled.Yes : EventHandled.No;\r\n }\r\n\r\n public override async onDataButtonUp(ev: BeButtonEvent): Promise<EventHandled> {\r\n if (undefined === ev.viewport)\r\n return EventHandled.No;\r\n\r\n if (this.selectByPointsEnd(ev))\r\n return EventHandled.Yes;\r\n\r\n if (SelectionMethod.Pick !== this.selectionMethod) {\r\n if (!ev.isControlKey && this.wantSelectionClearOnMiss(ev) && this.processMiss(ev))\r\n this.syncSelectionMode();\r\n if (InputSource.Touch !== ev.inputSource)\r\n this.selectByPointsStart(ev); // Require touch move and not tap to start crossing line/box selection...\r\n return EventHandled.Yes;\r\n }\r\n\r\n const hit = await IModelApp.locateManager.doLocate(new LocateResponse(), true, ev.point, ev.viewport, ev.inputSource);\r\n if (hit !== undefined) {\r\n if (EventHandled.Yes === await this.selectDecoration(ev, hit))\r\n return EventHandled.Yes;\r\n\r\n if (EventHandled.Yes === await this.processHit(ev, hit))\r\n return EventHandled.Yes;\r\n }\r\n\r\n if (!ev.isControlKey && this.wantSelectionClearOnMiss(ev) && this.processMiss(ev))\r\n this.syncSelectionMode();\r\n\r\n return EventHandled.Yes;\r\n }\r\n\r\n public override async onResetButtonUp(ev: BeButtonEvent): Promise<EventHandled> {\r\n if (this._isSelectByPoints) {\r\n if (undefined !== ev.viewport)\r\n ev.viewport.invalidateDecorations();\r\n this.initSelectTool();\r\n return EventHandled.Yes;\r\n }\r\n\r\n // Check for overlapping hits...\r\n const lastHit = SelectionMode.Remove === this.selectionMode ? undefined : IModelApp.locateManager.currHit;\r\n if (lastHit && this.iModel.selectionSet.has(lastHit.sourceId)) {\r\n const autoHit = IModelApp.accuSnap.currHit;\r\n\r\n // Play nice w/auto-locate, only remove previous hit if not currently auto-locating or over previous hit\r\n if (undefined === autoHit || autoHit.isSameHit(lastHit)) {\r\n const response = new LocateResponse();\r\n let nextHit;\r\n do {\r\n nextHit = await IModelApp.locateManager.doLocate(response, false, ev.point, ev.viewport, ev.inputSource);\r\n } while (undefined !== nextHit && (nextHit.isModelHit || nextHit.isMapHit)); // Ignore reality models, terrain, maps, etc.\r\n\r\n // remove element(s) previously selected if in replace mode, or if we have a next element in add mode\r\n if (SelectionMode.Replace === this.selectionMode || undefined !== nextHit)\r\n await this.processSelection(lastHit.sourceId, SelectionProcessing.RemoveElementFromSelection);\r\n\r\n // add element(s) located via reset button\r\n if (undefined !== nextHit)\r\n await this.processSelection(nextHit.sourceId, SelectionProcessing.AddElementToSelection);\r\n\r\n return EventHandled.Yes;\r\n }\r\n }\r\n\r\n if (EventHandled.Yes === await this.selectDecoration(ev, IModelApp.accuSnap.currHit))\r\n return EventHandled.Yes;\r\n\r\n await IModelApp.accuSnap.resetButton();\r\n return EventHandled.Yes;\r\n }\r\n\r\n public override async onSuspend() {\r\n this._isSuspended = true;\r\n if (this.wantEditManipulators())\r\n IModelApp.toolAdmin.manipulatorToolEvent.raiseEvent(this, ManipulatorToolEvent.Suspend);\r\n }\r\n\r\n public override async onUnsuspend() {\r\n this._isSuspended = false;\r\n if (this.wantEditManipulators())\r\n IModelApp.toolAdmin.manipulatorToolEvent.raiseEvent(this, ManipulatorToolEvent.Unsuspend);\r\n\r\n this.showPrompt(this.selectionMode, this.selectionMethod);\r\n }\r\n\r\n public override async onTouchMoveStart(ev: BeTouchEvent, startEv: BeTouchEvent): Promise<EventHandled> {\r\n if (startEv.isSingleTouch && !this._isSelectByPoints)\r\n await IModelApp.toolAdmin.convertTouchMoveStartToButtonDownAndMotion(startEv, ev);\r\n return (this._isSuspended || this._isSelectByPoints) ? EventHandled.Yes : EventHandled.No;\r\n }\r\n\r\n public override async onTouchMove(ev: BeTouchEvent): Promise<void> {\r\n if (this._isSelectByPoints)\r\n return IModelApp.toolAdmin.convertTouchMoveToMotion(ev);\r\n }\r\n\r\n public override async onTouchComplete(ev: BeTouchEvent): Promise<void> {\r\n if (this._isSelectByPoints)\r\n return IModelApp.toolAdmin.convertTouchEndToButtonUp(ev);\r\n }\r\n\r\n public override async onTouchCancel(ev: BeTouchEvent): Promise<void> {\r\n if (this._isSelectByPoints)\r\n return IModelApp.toolAdmin.convertTouchEndToButtonUp(ev, BeButton.Reset);\r\n }\r\n\r\n public override decorate(context: DecorateContext): void { this.selectByPointsDecorate(context); }\r\n\r\n public override async onModifierKeyTransition(_wentDown: boolean, modifier: BeModifierKeys, _event: KeyboardEvent): Promise<EventHandled> {\r\n return (modifier === BeModifierKeys.Shift && this._isSelectByPoints) ? EventHandled.Yes : EventHandled.No;\r\n }\r\n\r\n public override async filterHit(hit: HitDetail, out?: LocateResponse): Promise<LocateFilterStatus> {\r\n if (!this.wantPickableDecorations() && !hit.isElementHit)\r\n return LocateFilterStatus.Reject;\r\n\r\n const mode = this.selectionMode;\r\n if (SelectionMode.Replace === mode)\r\n return LocateFilterStatus.Accept;\r\n\r\n const isSelected = this.iModel.selectionSet.has(hit.sourceId);\r\n const status = ((SelectionMode.Add === mode ? !isSelected : isSelected) ? LocateFilterStatus.Accept : LocateFilterStatus.Reject);\r\n if (out && LocateFilterStatus.Reject === status)\r\n out.explanation = CoreTools.translate(`ElementSet.Error.${isSelected ? \"AlreadySelected\" : \"NotSelected\"}`);\r\n return status;\r\n }\r\n\r\n public async onRestartTool(): Promise<void> { return this.exitTool(); }\r\n\r\n public override async onCleanup() {\r\n if (this.wantEditManipulators())\r\n IModelApp.toolAdmin.manipulatorToolEvent.raiseEvent(this, ManipulatorToolEvent.Stop);\r\n }\r\n\r\n public override async onPostInstall() {\r\n await super.onPostInstall();\r\n if (!this.targetView)\r\n return;\r\n if (this.wantEditManipulators())\r\n IModelApp.toolAdmin.manipulatorToolEvent.raiseEvent(this, ManipulatorToolEvent.Start);\r\n this.initSelectTool();\r\n }\r\n\r\n public static async startTool(): Promise<boolean> { return new SelectionTool().run(); }\r\n\r\n private syncSelectionMode(): void {\r\n if (SelectionMode.Remove === this.selectionMode && !this.iModel.selectionSet.isActive) {\r\n // No selection active resetting selection mode since there is nothing to Remove\r\n this.selectionMode = SelectionMode.Replace;\r\n this.initSelectTool();\r\n }\r\n if (this.wantToolSettings()) {\r\n const syncMode: DialogPropertySyncItem = { value: this._selectionModeValue, propertyName: SelectionTool._modesName };\r\n IModelApp.toolAdmin.toolSettingsState.saveToolSettingProperty(this.toolId, syncMode);\r\n this.syncToolSettingsProperties([syncMode]);\r\n }\r\n }\r\n\r\n /** Used to supply DefaultToolSettingProvider with a list of properties to use to generate ToolSettings. If undefined then no ToolSettings will be displayed\r\n * @beta\r\n */\r\n public override supplyToolSettingsProperties(): DialogItem[] | undefined {\r\n if (!this.wantToolSettings())\r\n return undefined;\r\n\r\n // load latest values from session\r\n IModelApp.toolAdmin.toolSettingsState.getInitialToolSettingValues(this.toolId, [SelectionTool._modesName])?.forEach((value) => {\r\n if (value.propertyName === SelectionTool._modesName)\r\n this._selectionModeValue = value.value;\r\n });\r\n\r\n // Make sure a mode of SelectionMode.Remove is valid\r\n if (SelectionMode.Remove === this.selectionMode && !this.iModel.selectionSet.isActive) {\r\n this.selectionMode = SelectionMode.Replace;\r\n IModelApp.toolAdmin.toolSettingsState.saveToolSettingProperty(this.toolId, { propertyName: SelectionTool._modesName, value: this._selectionModeValue });\r\n }\r\n\r\n const toolSettings = new Array<DialogItem>();\r\n // generate 3 columns - label will be placed in column 0 and button group editors in columns 1 and 2.\r\n toolSettings.push({ value: this._selectionMethodValue, property: SelectionTool._getMethodsDescription(), editorPosition: { rowPriority: 0, columnIndex: 1 } });\r\n toolSettings.push({ value: this._selectionModeValue, property: SelectionTool._getModesDescription(), editorPosition: { rowPriority: 0, columnIndex: 2 } });\r\n return toolSettings;\r\n }\r\n\r\n /** Used to send changes from UI back to Tool\r\n * @beta\r\n */\r\n public override async applyToolSettingPropertyChange(updatedValue: DialogPropertySyncItem): Promise<boolean> {\r\n let changed = false;\r\n if (updatedValue.propertyName === SelectionTool._methodsName) {\r\n const saveWantManipulators = this.wantEditManipulators();\r\n this._selectionMethodValue = updatedValue.value;\r\n if (this._selectionMethodValue) {\r\n const currWantManipulators = this.wantEditManipulators();\r\n if (saveWantManipulators !== currWantManipulators)\r\n IModelApp.toolAdmin.manipulatorToolEvent.raiseEvent(this, currWantManipulators ? ManipulatorToolEvent.Start : ManipulatorToolEvent.Stop);\r\n changed = true;\r\n }\r\n }\r\n if (updatedValue.propertyName === SelectionTool._modesName) {\r\n this._selectionModeValue = updatedValue.value;\r\n if (this._selectionModeValue) {\r\n if (this.wantToolSettings())\r\n IModelApp.toolAdmin.toolSettingsState.saveToolSettingProperty(this.toolId, { propertyName: SelectionTool._modesName, value: this._selectionModeValue });\r\n changed = true;\r\n }\r\n }\r\n if (changed)\r\n this.initSelectTool();\r\n return true; // return true if change is valid\r\n }\r\n}\r\n"]}
|