@itwin/map-layers-formats 4.6.0-dev.27 → 4.6.0-dev.28
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/cjs/Tools/GeometryTerrainDraper.d.ts +20 -0
- package/lib/cjs/Tools/GeometryTerrainDraper.d.ts.map +1 -0
- package/lib/cjs/Tools/GeometryTerrainDraper.js +153 -0
- package/lib/cjs/Tools/GeometryTerrainDraper.js.map +1 -0
- package/lib/cjs/Tools/MapFeatureInfoDecorator.d.ts +15 -10
- package/lib/cjs/Tools/MapFeatureInfoDecorator.d.ts.map +1 -1
- package/lib/cjs/Tools/MapFeatureInfoDecorator.js +191 -150
- package/lib/cjs/Tools/MapFeatureInfoDecorator.js.map +1 -1
- package/lib/cjs/Tools/MapFeatureInfoTool.d.ts.map +1 -1
- package/lib/cjs/Tools/MapFeatureInfoTool.js +6 -3
- package/lib/cjs/Tools/MapFeatureInfoTool.js.map +1 -1
- package/lib/esm/Tools/GeometryTerrainDraper.d.ts +20 -0
- package/lib/esm/Tools/GeometryTerrainDraper.d.ts.map +1 -0
- package/lib/esm/Tools/GeometryTerrainDraper.js +149 -0
- package/lib/esm/Tools/GeometryTerrainDraper.js.map +1 -0
- package/lib/esm/Tools/MapFeatureInfoDecorator.d.ts +15 -10
- package/lib/esm/Tools/MapFeatureInfoDecorator.d.ts.map +1 -1
- package/lib/esm/Tools/MapFeatureInfoDecorator.js +193 -152
- package/lib/esm/Tools/MapFeatureInfoDecorator.js.map +1 -1
- package/lib/esm/Tools/MapFeatureInfoTool.d.ts.map +1 -1
- package/lib/esm/Tools/MapFeatureInfoTool.js +6 -3
- package/lib/esm/Tools/MapFeatureInfoTool.js.map +1 -1
- package/package.json +13 -13
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MapFeatureInfoTool.js","sourceRoot":"","sources":["../../../src/Tools/MapFeatureInfoTool.ts"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\n* See LICENSE.md in the project root for license terms and full copyright notice.\n*--------------------------------------------------------------------------------------------*/\n/** @packageDocumentation\n * @module MapLayersFormats\n */\n\nimport {\n BeButtonEvent,\n EventHandled,\n HitDetail,\n IModelApp,\n LocateFilterStatus,\n LocateResponse,\n MapFeatureInfo,\n MapLayerInfoFromTileTree,\n MapLayerScaleRangeVisibility,\n MapTileTreeScaleRangeVisibility,\n PrimitiveTool,\n ToolAssistance,\n ToolAssistanceImage,\n ToolAssistanceInputMethod,\n ToolAssistanceInstruction,\n ToolAssistanceSection,\n Viewport,\n} from \"@itwin/core-frontend\";\nimport { BeEvent } from \"@itwin/core-bentley\";\nimport { ImageMapLayerSettings, MapImageryProps, MapImagerySettings, MapLayerProps } from \"@itwin/core-common\";\nimport { MapFeatureInfoDecorator } from \"./MapFeatureInfoDecorator\";\nimport { mapInfoIcon } from \"../Icons/MapInfoIcon\";\n\n/**\n * Data provided every time [[MapFeatureInfoTool]] retrieves feature information.\n * @see [[MapFeatureInfoToolData]]\n * @beta\n */\nexport interface MapFeatureInfoToolData {\n hit: HitDetail;\n mapInfo?: MapFeatureInfo;\n}\n\nclass ActiveMapLayerState {\n private _activeMapLayers: MapLayerInfoFromTileTree[]|undefined;\n public get activeMapLayers() {return this._activeMapLayers;}\n public set activeMapLayers(active: MapLayerInfoFromTileTree[]|undefined) {\n this._activeMapLayers = active;\n this.isVisible = true;\n this.isInRange = true;\n this.existsInDisplayStyle = true;\n\n }\n public isVisible: boolean = true;\n public isInRange: boolean = true;\n public existsInDisplayStyle: boolean = true;\n\n public get hasMapLayers() { return (this.activeMapLayers && this.activeMapLayers.length > 0);}\n\n public updateWithImagerySettings(imagery: MapImageryProps) {\n const result = {exists: false, hidden: false};\n this.existsInDisplayStyle = false;\n this.isVisible = false;\n if (this.hasMapLayers) {\n const oldMls = this._activeMapLayers![0]; // consider only first layer for now\n\n let newMls: MapLayerProps|undefined;\n if (oldMls.isBaseLayer) {\n if (typeof (imagery.backgroundBase) !== \"number\") {\n newMls = imagery.backgroundBase;\n }\n } else if (oldMls.index?.isOverlay && imagery.overlayLayers && imagery.overlayLayers.length > oldMls.index.index) {\n newMls = imagery.overlayLayers[oldMls.index.index];\n\n } else if ((oldMls.index !== undefined) && imagery.backgroundLayers && imagery.backgroundLayers.length > oldMls.index.index) {\n newMls = imagery.backgroundLayers[oldMls.index.index];\n }\n\n // We want to make sure that newMls and OldMls are the same (but ignoring the 'visible' flag).\n // by using the serialized JSON object\n let tmpNewMls = newMls;\n if (newMls && newMls.visible !== oldMls.settings.visible) {\n tmpNewMls = {...newMls, visible: oldMls.settings.visible};\n }\n const newJson = tmpNewMls ? JSON.stringify(tmpNewMls) : \"\";\n const oldJson = JSON.stringify(oldMls.settings.toJSON());\n\n if (newJson === oldJson ) {\n // We consider newMls and OldMls to be the same mapLayer instance.\n this.existsInDisplayStyle = true;\n this.isVisible = newMls!.visible ? true : false;\n }\n\n }\n return result;\n }\n\n public updateWithScaleRangeVisibility(layerIndexes: MapLayerScaleRangeVisibility[]) {\n if (this.hasMapLayers) {\n const currentMls = this.activeMapLayers![0]; // consider only first layer for now\n for (const scaleRangeVisibility of layerIndexes) {\n if (currentMls.index?.index === scaleRangeVisibility.index) {\n this.isInRange = scaleRangeVisibility.visibility === MapTileTreeScaleRangeVisibility.Visible || scaleRangeVisibility.visibility === MapTileTreeScaleRangeVisibility.Partial;\n }\n }\n }\n\n }\n}\n\n/** Tools that allow extracting feature information from map-layers.\n * Simulate feature highlight by drawing overlay decorations. It also\n * fire an event that provide further feature information meant to be displayed in a UI / Widget.\n * @see [[MapFeatureInfoToolData]]\n * @beta\n */\nexport class MapFeatureInfoTool extends PrimitiveTool {\n public readonly onInfoReady = new BeEvent<(data: MapFeatureInfoToolData) => void>();\n public readonly onInfoCleared = new BeEvent();\n\n public static override toolId = \"MapFeatureInfoTool\";\n public static override iconSpec = mapInfoIcon.dataUri;\n\n private _decorator: MapFeatureInfoDecorator = new MapFeatureInfoDecorator();\n private _layerSettingsCache = new Map<string, MapLayerInfoFromTileTree[]>();\n\n private _state: ActiveMapLayerState = new ActiveMapLayerState();\n private readonly _detachListeners: VoidFunction[] = [];\n private _detachOnMapImageryChanged: VoidFunction|undefined;\n\n public override requireWriteableTarget(): boolean {\n return false;\n }\n\n /** @internal */\n protected setupAndPromptForNextAction(): void {\n this.showPrompt();\n }\n\n private updateDecorator(vp: Viewport) {\n if (this._state.existsInDisplayStyle) {\n if (this._state.isInRange) {\n this._decorator.hidden = !this._state.isVisible;\n }\n } else {\n // Flush existing decorations until a new selection is made\n this.onInfoCleared.raiseEvent();\n this._decorator.clearState();\n }\n vp.invalidateDecorations();\n }\n\n public override async onPostInstall() {\n await super.onPostInstall();\n\n this.setupAndPromptForNextAction();\n\n this.initLocateElements();\n IModelApp.locateManager.options.allowDecorations = true;\n\n this._layerSettingsCache.clear();\n\n // Listen of display style configuration changes, that way we don't have to restart the tool to be up to date.\n const vp = this.targetView;\n if (vp) {\n const mapImageryChangeHandler = (newImagery: Readonly<MapImagerySettings>) => {\n if (this._state.hasMapLayers) {\n this._state.updateWithImagerySettings(newImagery.toJSON());\n this.updateDecorator(vp);\n }\n this._layerSettingsCache.clear();\n };\n\n this._detachListeners.push(vp.onChangeView.addListener((viewport, _previousViewState) => {\n\n // When a saved view is loaded, 'onMapImageryChanged' events are no longer handled, we have to re-attach.\n if (this._detachOnMapImageryChanged) {\n this._detachOnMapImageryChanged();\n }\n this._detachOnMapImageryChanged = viewport.displayStyle.settings.onMapImageryChanged.addListener(mapImageryChangeHandler);\n\n if (this._state.hasMapLayers) {\n this._state.updateWithImagerySettings({\n backgroundBase: viewport.displayStyle.backgroundMapBase.toJSON(),\n backgroundLayers: viewport.displayStyle.getMapLayers(false).map((value) => value.toJSON()),\n overlayLayers: viewport.displayStyle.getMapLayers(true).map((value) => value.toJSON()),\n });\n this.updateDecorator(vp);\n }\n this._layerSettingsCache.clear();\n }));\n\n this._detachOnMapImageryChanged = vp.displayStyle.settings.onMapImageryChanged.addListener(mapImageryChangeHandler);\n\n // Every time a layer goes out of range it, its associated decoration should be hidden (and restore if enter again the range)\n this._detachListeners.push(vp.onMapLayerScaleRangeVisibilityChanged.addListener(((layerIndexes: MapLayerScaleRangeVisibility[]) => {\n if (this._state.hasMapLayers) {\n this._state.updateWithScaleRangeVisibility(layerIndexes);\n if (this._state.existsInDisplayStyle && this._state.isVisible) {\n this._decorator.hidden = !this._state.isInRange;\n vp.invalidateDecorations();\n }\n }\n this._layerSettingsCache.clear();\n })));\n\n }\n\n IModelApp.viewManager.addDecorator(this._decorator);\n\n }\n\n public override async onCleanup() {\n this._detachListeners.forEach((f) => f());\n this._detachListeners.length = 0;\n if (this._detachOnMapImageryChanged) {\n this._detachOnMapImageryChanged();\n }\n\n IModelApp.viewManager.dropDecorator(this._decorator);\n }\n\n /**\n * Get map layer information from a hit.\n * @param hit The hit to get info from.\n * @returns Returns a list of [[MapLayerInfoFromTileTree]]s.\n * @internal\n */\n private getMapLayerInfoFromHit(hit: HitDetail) {\n let mapLayerFromHit: MapLayerInfoFromTileTree[] = [];\n const fromCache = this._layerSettingsCache.get(hit.sourceId);\n if (fromCache) {\n mapLayerFromHit = fromCache;\n } else if (this.targetView) {\n mapLayerFromHit = this.targetView?.mapLayerFromHit(hit).filter(((info) => info.settings instanceof ImageMapLayerSettings && info.provider?.supportsMapFeatureInfo));\n this._layerSettingsCache.set(hit.sourceId, mapLayerFromHit);\n }\n\n return mapLayerFromHit;\n }\n\n public override async getToolTip(hit: HitDetail): Promise<HTMLElement | string> {\n const infos = this.getMapLayerInfoFromHit(hit);\n if (infos.length > 0) {\n const names = infos.map((info) => info.settings.name);\n return `Layer${names.length > 1 ? \"s\" : \"\"}: ${names.join(\", \")}`;\n }\n return \"\";\n }\n\n public override async filterHit(hit: HitDetail, _out?: LocateResponse): Promise<LocateFilterStatus> {\n return this.getMapLayerInfoFromHit(hit).length > 0 ? LocateFilterStatus.Accept : LocateFilterStatus.Reject;\n }\n\n public override async onDataButtonDown(\n ev: BeButtonEvent,\n ): Promise<EventHandled> {\n const hit = await IModelApp.locateManager.doLocate(\n new LocateResponse(),\n true,\n ev.point,\n ev.viewport,\n ev.inputSource,\n );\n if (hit !== undefined) {\n let mapInfo: MapFeatureInfo | undefined;\n\n const mapLayersHit = this.getMapLayerInfoFromHit(hit);\n if (mapLayersHit.length > 0) {\n this._state.activeMapLayers = mapLayersHit;\n IModelApp.toolAdmin.setCursor(\"wait\");\n try {\n const aperture = (hit.viewport.pixelsFromInches(IModelApp.locateManager.apertureInches) / 2.0) + 1.5;\n const pixelRadius = Math.floor(aperture + 0.5);\n mapInfo = await hit.viewport.getMapFeatureInfo(hit, {tolerance: pixelRadius});\n if (mapInfo) {\n this._decorator.setState({ hit, mapInfo });\n }\n } finally {\n IModelApp.toolAdmin.setCursor(undefined);\n }\n }\n\n this.onInfoReady.raiseEvent({ hit, mapInfo });\n return EventHandled.Yes;\n }\n return EventHandled.No;\n }\n\n public override async onResetButtonUp(\n _ev: BeButtonEvent,\n ): Promise<EventHandled> {\n this._state.activeMapLayers = undefined;\n /* Common reset behavior for primitive tools is calling onReinitialize to restart or exitTool to terminate. */\n await this.onReinitialize();\n return EventHandled.No;\n }\n\n public override async onRestartTool() {\n const tool = new MapFeatureInfoTool();\n if (!(await tool.run()))\n return this.exitTool();\n }\n\n /** @internal */\n protected showPrompt(): void {\n\n const promptEnterPoint = IModelApp.localization.getLocalizedString(\"mapLayersFormats:tools.MapFeatureInfoTool.Prompts.EnterPoint\");\n const promptClickIdentify= IModelApp.localization.getLocalizedString(\"mapLayersFormats:tools.MapFeatureInfoTool.Prompts.clickToIdentify\");\n const promptClickClear = IModelApp.localization.getLocalizedString(\"mapLayersFormats:tools.MapFeatureInfoTool.Prompts.clickToClear\");\n\n // Mouse Instructions\n const mouseInstructions: ToolAssistanceInstruction[] = [];\n mouseInstructions.push(ToolAssistance.createInstruction(ToolAssistanceImage.LeftClick, promptClickIdentify, false, ToolAssistanceInputMethod.Mouse));\n mouseInstructions.push(ToolAssistance.createInstruction(ToolAssistanceImage.RightClick, promptClickClear, false, ToolAssistanceInputMethod.Mouse));\n const sections: ToolAssistanceSection[] = [];\n sections.push(ToolAssistance.createSection(mouseInstructions, ToolAssistance.inputsLabel));\n\n // Main Instruction\n const mainInstruction = ToolAssistance.createInstruction(this.iconSpec, promptEnterPoint);\n const instructions = ToolAssistance.createInstructions(mainInstruction, sections);\n\n IModelApp.notifications.setToolAssistance(instructions);\n }\n}\n"]}
|
|
1
|
+
{"version":3,"file":"MapFeatureInfoTool.js","sourceRoot":"","sources":["../../../src/Tools/MapFeatureInfoTool.ts"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\n* See LICENSE.md in the project root for license terms and full copyright notice.\n*--------------------------------------------------------------------------------------------*/\n/** @packageDocumentation\n * @module MapLayersFormats\n */\n\nimport {\n BeButtonEvent,\n EventHandled,\n HitDetail,\n IModelApp,\n LocateFilterStatus,\n LocateResponse,\n MapFeatureInfo,\n MapLayerInfoFromTileTree,\n MapLayerScaleRangeVisibility,\n MapTileTreeScaleRangeVisibility,\n PrimitiveTool,\n ToolAssistance,\n ToolAssistanceImage,\n ToolAssistanceInputMethod,\n ToolAssistanceInstruction,\n ToolAssistanceSection,\n Viewport,\n} from \"@itwin/core-frontend\";\nimport { BeEvent } from \"@itwin/core-bentley\";\nimport { ImageMapLayerSettings, MapImageryProps, MapImagerySettings, MapLayerProps } from \"@itwin/core-common\";\nimport { MapFeatureInfoDecorator } from \"./MapFeatureInfoDecorator\";\nimport { mapInfoIcon } from \"../Icons/MapInfoIcon\";\n\n/**\n * Data provided every time [[MapFeatureInfoTool]] retrieves feature information.\n * @see [[MapFeatureInfoToolData]]\n * @beta\n */\nexport interface MapFeatureInfoToolData {\n hit: HitDetail;\n mapInfo?: MapFeatureInfo;\n}\n\nclass ActiveMapLayerState {\n private _activeMapLayers: MapLayerInfoFromTileTree[]|undefined;\n public get activeMapLayers() {return this._activeMapLayers;}\n public set activeMapLayers(active: MapLayerInfoFromTileTree[]|undefined) {\n this._activeMapLayers = active;\n this.isVisible = true;\n this.isInRange = true;\n this.existsInDisplayStyle = true;\n\n }\n public isVisible: boolean = true;\n public isInRange: boolean = true;\n public existsInDisplayStyle: boolean = true;\n\n public get hasMapLayers() { return (this.activeMapLayers && this.activeMapLayers.length > 0);}\n\n public updateWithImagerySettings(imagery: MapImageryProps) {\n const result = {exists: false, hidden: false};\n this.existsInDisplayStyle = false;\n this.isVisible = false;\n if (this.hasMapLayers) {\n const oldMls = this._activeMapLayers![0]; // consider only first layer for now\n\n let newMls: MapLayerProps|undefined;\n if (oldMls.isBaseLayer) {\n if (typeof (imagery.backgroundBase) !== \"number\") {\n newMls = imagery.backgroundBase;\n }\n } else if (oldMls.index?.isOverlay && imagery.overlayLayers && imagery.overlayLayers.length > oldMls.index.index) {\n newMls = imagery.overlayLayers[oldMls.index.index];\n\n } else if ((oldMls.index !== undefined) && imagery.backgroundLayers && imagery.backgroundLayers.length > oldMls.index.index) {\n newMls = imagery.backgroundLayers[oldMls.index.index];\n }\n\n // We want to make sure that newMls and OldMls are the same (but ignoring the 'visible' flag).\n // by using the serialized JSON object\n let tmpNewMls = newMls;\n if (newMls && newMls.visible !== oldMls.settings.visible) {\n tmpNewMls = {...newMls, visible: oldMls.settings.visible};\n }\n const newJson = tmpNewMls ? JSON.stringify(tmpNewMls) : \"\";\n const oldJson = JSON.stringify(oldMls.settings.toJSON());\n\n if (newJson === oldJson ) {\n // We consider newMls and OldMls to be the same mapLayer instance.\n this.existsInDisplayStyle = true;\n this.isVisible = newMls!.visible ? true : false;\n }\n\n }\n return result;\n }\n\n public updateWithScaleRangeVisibility(layerIndexes: MapLayerScaleRangeVisibility[]) {\n if (this.hasMapLayers) {\n const currentMls = this.activeMapLayers![0]; // consider only first layer for now\n for (const scaleRangeVisibility of layerIndexes) {\n if (currentMls.index?.index === scaleRangeVisibility.index) {\n this.isInRange = scaleRangeVisibility.visibility === MapTileTreeScaleRangeVisibility.Visible || scaleRangeVisibility.visibility === MapTileTreeScaleRangeVisibility.Partial;\n }\n }\n }\n\n }\n}\n\n/** Tools that allow extracting feature information from map-layers.\n * Simulate feature highlight by drawing overlay decorations. It also\n * fire an event that provide further feature information meant to be displayed in a UI / Widget.\n * @see [[MapFeatureInfoToolData]]\n * @beta\n */\nexport class MapFeatureInfoTool extends PrimitiveTool {\n public readonly onInfoReady = new BeEvent<(data: MapFeatureInfoToolData) => void>();\n public readonly onInfoCleared = new BeEvent();\n\n public static override toolId = \"MapFeatureInfoTool\";\n public static override iconSpec = mapInfoIcon.dataUri;\n\n private _decorator: MapFeatureInfoDecorator = new MapFeatureInfoDecorator();\n private _layerSettingsCache = new Map<string, MapLayerInfoFromTileTree[]>();\n\n private _state: ActiveMapLayerState = new ActiveMapLayerState();\n private readonly _detachListeners: VoidFunction[] = [];\n private _detachOnMapImageryChanged: VoidFunction|undefined;\n\n public override requireWriteableTarget(): boolean {\n return false;\n }\n\n /** @internal */\n protected setupAndPromptForNextAction(): void {\n this.showPrompt();\n }\n\n private updateDecorator(vp: Viewport) {\n if (this._state.existsInDisplayStyle) {\n if (this._state.isInRange) {\n this._decorator.hidden = !this._state.isVisible;\n }\n } else {\n // Flush existing decorations until a new selection is made\n this.onInfoCleared.raiseEvent();\n this._decorator.clearData();\n }\n vp.invalidateDecorations();\n }\n\n public override async onPostInstall() {\n await super.onPostInstall();\n\n this.setupAndPromptForNextAction();\n\n this.initLocateElements();\n IModelApp.locateManager.options.allowDecorations = true;\n\n this._layerSettingsCache.clear();\n\n // Listen of display style configuration changes, that way we don't have to restart the tool to be up to date.\n const vp = this.targetView;\n if (vp) {\n const mapImageryChangeHandler = (newImagery: Readonly<MapImagerySettings>) => {\n if (this._state.hasMapLayers) {\n this._state.updateWithImagerySettings(newImagery.toJSON());\n this.updateDecorator(vp);\n }\n this._layerSettingsCache.clear();\n };\n\n this._detachListeners.push(vp.onChangeView.addListener((viewport, _previousViewState) => {\n\n // When a saved view is loaded, 'onMapImageryChanged' events are no longer handled, we have to re-attach.\n if (this._detachOnMapImageryChanged) {\n this._detachOnMapImageryChanged();\n }\n this._detachOnMapImageryChanged = viewport.displayStyle.settings.onMapImageryChanged.addListener(mapImageryChangeHandler);\n\n if (this._state.hasMapLayers) {\n this._state.updateWithImagerySettings({\n backgroundBase: viewport.displayStyle.backgroundMapBase.toJSON(),\n backgroundLayers: viewport.displayStyle.getMapLayers(false).map((value) => value.toJSON()),\n overlayLayers: viewport.displayStyle.getMapLayers(true).map((value) => value.toJSON()),\n });\n this.updateDecorator(vp);\n }\n this._layerSettingsCache.clear();\n }));\n\n this._detachOnMapImageryChanged = vp.displayStyle.settings.onMapImageryChanged.addListener(mapImageryChangeHandler);\n\n // Every time a layer goes out of range it, its associated decoration should be hidden (and restore if enter again the range)\n this._detachListeners.push(vp.onMapLayerScaleRangeVisibilityChanged.addListener(((layerIndexes: MapLayerScaleRangeVisibility[]) => {\n if (this._state.hasMapLayers) {\n this._state.updateWithScaleRangeVisibility(layerIndexes);\n if (this._state.existsInDisplayStyle && this._state.isVisible) {\n this._decorator.hidden = !this._state.isInRange;\n vp.invalidateDecorations();\n }\n }\n this._layerSettingsCache.clear();\n })));\n\n }\n\n IModelApp.viewManager.addDecorator(this._decorator);\n\n }\n\n public override async onCleanup() {\n this._detachListeners.forEach((f) => f());\n this._detachListeners.length = 0;\n if (this._detachOnMapImageryChanged) {\n this._detachOnMapImageryChanged();\n }\n\n IModelApp.viewManager.dropDecorator(this._decorator);\n }\n\n /**\n * Get map layer information from a hit.\n * @param hit The hit to get info from.\n * @returns Returns a list of [[MapLayerInfoFromTileTree]]s.\n * @internal\n */\n private getMapLayerInfoFromHit(hit: HitDetail) {\n let mapLayerFromHit: MapLayerInfoFromTileTree[] = [];\n const fromCache = this._layerSettingsCache.get(hit.sourceId);\n if (fromCache) {\n mapLayerFromHit = fromCache;\n } else if (this.targetView) {\n mapLayerFromHit = this.targetView?.mapLayerFromHit(hit).filter(((info) => info.settings instanceof ImageMapLayerSettings && info.provider?.supportsMapFeatureInfo));\n this._layerSettingsCache.set(hit.sourceId, mapLayerFromHit);\n }\n\n return mapLayerFromHit;\n }\n\n public override async getToolTip(hit: HitDetail): Promise<HTMLElement | string> {\n const infos = this.getMapLayerInfoFromHit(hit);\n if (infos.length > 0) {\n const names = infos.map((info) => info.settings.name);\n return `Layer${names.length > 1 ? \"s\" : \"\"}: ${names.join(\", \")}`;\n }\n return \"\";\n }\n\n public override async filterHit(hit: HitDetail, _out?: LocateResponse): Promise<LocateFilterStatus> {\n return this.getMapLayerInfoFromHit(hit).length > 0 ? LocateFilterStatus.Accept : LocateFilterStatus.Reject;\n }\n\n public override async onDataButtonDown(\n ev: BeButtonEvent,\n ): Promise<EventHandled> {\n const hit = await IModelApp.locateManager.doLocate(\n new LocateResponse(),\n true,\n ev.point,\n ev.viewport,\n ev.inputSource,\n );\n if (hit !== undefined) {\n let mapInfo: MapFeatureInfo | undefined;\n\n const mapLayersHit = this.getMapLayerInfoFromHit(hit);\n if (mapLayersHit.length > 0) {\n this._state.activeMapLayers = mapLayersHit;\n IModelApp.toolAdmin.setCursor(\"wait\");\n try {\n const aperture = (hit.viewport.pixelsFromInches(IModelApp.locateManager.apertureInches) / 2.0) + 1.5;\n const pixelRadius = Math.floor(aperture + 0.5);\n mapInfo = await hit.viewport.getMapFeatureInfo(hit, {tolerance: pixelRadius});\n if (mapInfo) {\n this._decorator.setData({ hit, mapInfo });\n } else {\n IModelApp.toolAdmin.setCursor(undefined);\n }\n } catch {\n IModelApp.toolAdmin.setCursor(undefined);\n }\n }\n\n this.onInfoReady.raiseEvent({ hit, mapInfo });\n return EventHandled.Yes;\n }\n return EventHandled.No;\n }\n\n public override async onResetButtonUp(\n _ev: BeButtonEvent,\n ): Promise<EventHandled> {\n this._state.activeMapLayers = undefined;\n /* Common reset behavior for primitive tools is calling onReinitialize to restart or exitTool to terminate. */\n await this.onReinitialize();\n return EventHandled.No;\n }\n\n public override async onRestartTool() {\n const tool = new MapFeatureInfoTool();\n if (!(await tool.run()))\n return this.exitTool();\n }\n\n /** @internal */\n protected showPrompt(): void {\n\n const promptEnterPoint = IModelApp.localization.getLocalizedString(\"mapLayersFormats:tools.MapFeatureInfoTool.Prompts.EnterPoint\");\n const promptClickIdentify= IModelApp.localization.getLocalizedString(\"mapLayersFormats:tools.MapFeatureInfoTool.Prompts.clickToIdentify\");\n const promptClickClear = IModelApp.localization.getLocalizedString(\"mapLayersFormats:tools.MapFeatureInfoTool.Prompts.clickToClear\");\n\n // Mouse Instructions\n const mouseInstructions: ToolAssistanceInstruction[] = [];\n mouseInstructions.push(ToolAssistance.createInstruction(ToolAssistanceImage.LeftClick, promptClickIdentify, false, ToolAssistanceInputMethod.Mouse));\n mouseInstructions.push(ToolAssistance.createInstruction(ToolAssistanceImage.RightClick, promptClickClear, false, ToolAssistanceInputMethod.Mouse));\n const sections: ToolAssistanceSection[] = [];\n sections.push(ToolAssistance.createSection(mouseInstructions, ToolAssistance.inputsLabel));\n\n // Main Instruction\n const mainInstruction = ToolAssistance.createInstruction(this.iconSpec, promptEnterPoint);\n const instructions = ToolAssistance.createInstructions(mainInstruction, sections);\n\n IModelApp.notifications.setToolAssistance(instructions);\n }\n}\n"]}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { DisclosedTileTreeSet, GeometryTileTreeReference, TileUser, Viewport } from "@itwin/core-frontend";
|
|
2
|
+
import { Angle, CurvePrimitive, GrowableXYZArray, IndexedPolyface, IndexedPolyfaceSubsetVisitor, Loop, Point3d, Polyface, Range3d } from "@itwin/core-geometry";
|
|
3
|
+
/** @internal */
|
|
4
|
+
export declare class GeometryTerrainDraper implements TileUser {
|
|
5
|
+
readonly viewport: Viewport;
|
|
6
|
+
readonly treeRef: GeometryTileTreeReference;
|
|
7
|
+
readonly sideAngle: Angle;
|
|
8
|
+
readonly maxDistanceZ = 100000;
|
|
9
|
+
readonly tileUserId: number;
|
|
10
|
+
constructor(viewport: Viewport, treeRef: GeometryTileTreeReference);
|
|
11
|
+
dispose(): void;
|
|
12
|
+
get iModel(): import("@itwin/core-frontend").IModelConnection;
|
|
13
|
+
onRequestStateChanged(): void;
|
|
14
|
+
discloseTileTrees(trees: DisclosedTileTreeSet): void;
|
|
15
|
+
getMeshTopFacets(mesh: IndexedPolyface): IndexedPolyfaceSubsetVisitor;
|
|
16
|
+
drapeLineString(outStrings: CurvePrimitive[], inPoints: GrowableXYZArray, tolerance: number, range: Range3d): "loading" | "complete";
|
|
17
|
+
drapeLoop(outMeshes: Polyface[], loop: Loop, tolerance: number, range: Range3d): "loading" | "complete";
|
|
18
|
+
drapePoint(outPoint: Point3d, point: Point3d, chordTolerance: number, range: Range3d): "loading" | "complete";
|
|
19
|
+
}
|
|
20
|
+
//# sourceMappingURL=GeometryTerrainDraper.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"GeometryTerrainDraper.d.ts","sourceRoot":"","sources":["../../../src/Tools/GeometryTerrainDraper.ts"],"names":[],"mappings":"AAIA,OAAO,EACc,oBAAoB,EACvC,yBAAyB,EACI,QAAQ,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAChF,OAAO,EAAE,KAAK,EAAsB,cAAc,EAAE,gBAAgB,EAAE,eAAe,EAAE,4BAA4B,EAAE,IAAI,EAAE,OAAO,EAAE,QAAQ,EAA2C,OAAO,EAA8D,MAAM,sBAAsB,CAAC;AA6CzR,gBAAgB;AAChB,qBAAa,qBAAsB,YAAW,QAAQ;aASjB,QAAQ,EAAE,QAAQ;aAAkB,OAAO,EAAE,yBAAyB;IALzG,SAAgB,SAAS,QAA6B;IAEtD,SAAgB,YAAY,UAAS;IACrC,SAAgB,UAAU,EAAE,MAAM,CAAC;gBAEA,QAAQ,EAAE,QAAQ,EAAkB,OAAO,EAAE,yBAAyB;IAKlG,OAAO,IAAI,IAAI;IAItB,IAAW,MAAM,oDAAmC;IAE7C,qBAAqB;IAIrB,iBAAiB,CAAC,KAAK,EAAE,oBAAoB;IAM7C,gBAAgB,CAAC,IAAI,EAAE,eAAe;IAqBtC,eAAe,CAAC,UAAU,EAAE,cAAc,EAAE,EAAE,QAAQ,EAAE,gBAAgB,EAAE,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,OAAO,GAAG,SAAS,GAAG,UAAU;IA8BpI,SAAS,CAAC,SAAS,EAAE,QAAQ,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,OAAO,GAAG,SAAS,GAAG,UAAU;IA4BvG,UAAU,CAAC,QAAQ,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,cAAc,EAAE,MAAM,EAAE,KAAK,EAAE,OAAO,GAAG,SAAS,GAAG,UAAU;CAyBrH"}
|
|
@@ -0,0 +1,149 @@
|
|
|
1
|
+
/*---------------------------------------------------------------------------------------------
|
|
2
|
+
* Copyright (c) Bentley Systems, Incorporated. All rights reserved.
|
|
3
|
+
* See LICENSE.md in the project root for license terms and full copyright notice.
|
|
4
|
+
*--------------------------------------------------------------------------------------------*/
|
|
5
|
+
import { IModelApp, TileGeometryCollector, TileUser } from "@itwin/core-frontend";
|
|
6
|
+
import { Angle, ConvexClipPlaneSet, IndexedPolyfaceSubsetVisitor, PolyfaceClip, PolyfaceQuery, PolygonOps, Range3d, Ray3d, SweepLineStringToFacetsOptions, Vector3d } from "@itwin/core-geometry";
|
|
7
|
+
import { Logger } from "@itwin/core-bentley";
|
|
8
|
+
const loggerCategory = "MapLayersFormats.GeometryTerrainDraper";
|
|
9
|
+
/** A TileGeometryCollector that restricts collection to tiles that overlap a line string.
|
|
10
|
+
/* @internal
|
|
11
|
+
*/
|
|
12
|
+
class LineSegmentCollector extends TileGeometryCollector {
|
|
13
|
+
constructor(user, chordTolerance, range, transform, points) {
|
|
14
|
+
super({ user, chordTolerance, range, transform });
|
|
15
|
+
this._points = points;
|
|
16
|
+
}
|
|
17
|
+
addMissingTile(tile) {
|
|
18
|
+
Logger.logTrace(loggerCategory, `CollectorAdd missing tile: ${tile.contentId}`);
|
|
19
|
+
super.addMissingTile(tile);
|
|
20
|
+
}
|
|
21
|
+
collectTile(tile) {
|
|
22
|
+
let status = super.collectTile(tile);
|
|
23
|
+
if ("reject" !== status && !this.rangeOverlapsLineString(tile.range)) {
|
|
24
|
+
status = "reject";
|
|
25
|
+
}
|
|
26
|
+
Logger.logTrace(loggerCategory, `collectTile - tile: ${tile.contentId} status: ${status} isReady: ${tile.isReady} status:${tile.loadStatus}`);
|
|
27
|
+
return status;
|
|
28
|
+
}
|
|
29
|
+
rangeOverlapsLineString(range) {
|
|
30
|
+
let inside = false;
|
|
31
|
+
const clipper = ConvexClipPlaneSet.createRange3dPlanes(range, true, true, true, true, false, false);
|
|
32
|
+
if (this._options.transform)
|
|
33
|
+
clipper.transformInPlace(this._options.transform);
|
|
34
|
+
for (let i = 0; i < this._points.length - 1 && !inside; i++)
|
|
35
|
+
inside = clipper.announceClippedSegmentIntervals(0, 1, this._points.getPoint3dAtUncheckedPointIndex(i), this._points.getPoint3dAtUncheckedPointIndex(i + 1));
|
|
36
|
+
return inside;
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
/** @internal */
|
|
40
|
+
export class GeometryTerrainDraper {
|
|
41
|
+
constructor(viewport, treeRef) {
|
|
42
|
+
this.viewport = viewport;
|
|
43
|
+
this.treeRef = treeRef;
|
|
44
|
+
// The side angle measures how close the sweep vector is from being parallel to a side face.
|
|
45
|
+
// The larger the angle, the more nearly vertical facets are ignored.
|
|
46
|
+
// This is an "empirical" value that was determined by looking at "problematic" polyfaces
|
|
47
|
+
this.sideAngle = Angle.createDegrees(0.06);
|
|
48
|
+
this.maxDistanceZ = 1.0E5; // Expand the Z Range, but not so much that we get opposite side of globe.
|
|
49
|
+
this.tileUserId = TileUser.generateId();
|
|
50
|
+
IModelApp.tileAdmin.registerUser(this);
|
|
51
|
+
}
|
|
52
|
+
dispose() {
|
|
53
|
+
IModelApp.tileAdmin.forgetUser(this);
|
|
54
|
+
}
|
|
55
|
+
get iModel() { return this.viewport.iModel; }
|
|
56
|
+
onRequestStateChanged() {
|
|
57
|
+
this.viewport.invalidateDecorations();
|
|
58
|
+
}
|
|
59
|
+
discloseTileTrees(trees) {
|
|
60
|
+
trees.disclose(this.treeRef);
|
|
61
|
+
}
|
|
62
|
+
// Filter out non-top facets:
|
|
63
|
+
// For unknown reasons, there are "perpendicular" facets appearing in the terrain meshes.
|
|
64
|
+
getMeshTopFacets(mesh) {
|
|
65
|
+
// constant inputs
|
|
66
|
+
const sweepVector = Vector3d.unitZ();
|
|
67
|
+
// i.e., region is horizontal
|
|
68
|
+
// create subset visitor from the top facets
|
|
69
|
+
const topFacets = [];
|
|
70
|
+
const facetNormal = Vector3d.createZero();
|
|
71
|
+
for (const visitor = mesh.createVisitor(0); visitor.moveToNextFacet();) {
|
|
72
|
+
if (PolygonOps.unitNormal(visitor.point, facetNormal)) {
|
|
73
|
+
const theta = facetNormal.angleFromPerpendicular(sweepVector);
|
|
74
|
+
if (!theta.isMagnitudeLessThanOrEqual(this.sideAngle)) { // skip side facet
|
|
75
|
+
if (facetNormal.dotProduct(sweepVector) > 0) // this is a top facet
|
|
76
|
+
topFacets.push(visitor.currentReadIndex());
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
return IndexedPolyfaceSubsetVisitor.createSubsetVisitor(mesh, topFacets, 0);
|
|
81
|
+
}
|
|
82
|
+
drapeLineString(outStrings, inPoints, tolerance, range) {
|
|
83
|
+
const tree = this.treeRef.treeOwner.load();
|
|
84
|
+
if (!tree)
|
|
85
|
+
return "loading";
|
|
86
|
+
const expandedRange = Range3d.createFrom(range);
|
|
87
|
+
expandedRange.extendZOnly(-this.maxDistanceZ);
|
|
88
|
+
expandedRange.extendZOnly(this.maxDistanceZ);
|
|
89
|
+
const collector = new LineSegmentCollector(this, tolerance, expandedRange, tree.iModelTransform, inPoints);
|
|
90
|
+
this.treeRef.collectTileGeometry(collector);
|
|
91
|
+
collector.requestMissingTiles();
|
|
92
|
+
if (collector.isAllGeometryLoaded && collector.polyfaces.length > 0) {
|
|
93
|
+
for (const polyface of collector.polyfaces) {
|
|
94
|
+
// Use this to serialize (problematic) polyface
|
|
95
|
+
// console.log (`const polyface = ${JSON.stringify(IModelJson.Writer.toIModelJson(polyface))}`);
|
|
96
|
+
outStrings.push(...PolyfaceQuery.sweepLineStringToFacets(inPoints, polyface, SweepLineStringToFacetsOptions.create(Vector3d.unitZ(), this.sideAngle, true, true, false, false)));
|
|
97
|
+
}
|
|
98
|
+
return "complete";
|
|
99
|
+
}
|
|
100
|
+
return "loading";
|
|
101
|
+
}
|
|
102
|
+
drapeLoop(outMeshes, loop, tolerance, range) {
|
|
103
|
+
const tree = this.treeRef.treeOwner.load();
|
|
104
|
+
if (!tree)
|
|
105
|
+
return "loading";
|
|
106
|
+
const expandedRange = Range3d.createFrom(range);
|
|
107
|
+
expandedRange.extendZOnly(-this.maxDistanceZ);
|
|
108
|
+
expandedRange.extendZOnly(this.maxDistanceZ);
|
|
109
|
+
const strokes = loop.getPackedStrokes();
|
|
110
|
+
if (!strokes)
|
|
111
|
+
return "complete";
|
|
112
|
+
const collector = new LineSegmentCollector(this, tolerance, expandedRange, tree.iModelTransform, strokes);
|
|
113
|
+
this.treeRef.collectTileGeometry(collector);
|
|
114
|
+
collector.requestMissingTiles();
|
|
115
|
+
if (collector.isAllGeometryLoaded && collector.polyfaces.length > 0) {
|
|
116
|
+
for (const polyface of collector.polyfaces) {
|
|
117
|
+
const topFacets = this.getMeshTopFacets(polyface);
|
|
118
|
+
const mesh = PolyfaceClip.drapeRegion(topFacets, loop);
|
|
119
|
+
if (mesh)
|
|
120
|
+
outMeshes.push(mesh);
|
|
121
|
+
}
|
|
122
|
+
return "complete";
|
|
123
|
+
}
|
|
124
|
+
return "loading";
|
|
125
|
+
}
|
|
126
|
+
drapePoint(outPoint, point, chordTolerance, range) {
|
|
127
|
+
const tree = this.treeRef.treeOwner.load();
|
|
128
|
+
if (!tree)
|
|
129
|
+
return "loading";
|
|
130
|
+
const expandedRange = Range3d.createFrom(range);
|
|
131
|
+
expandedRange.extendZOnly(-this.maxDistanceZ);
|
|
132
|
+
expandedRange.extendZOnly(this.maxDistanceZ);
|
|
133
|
+
const collector = new TileGeometryCollector({ chordTolerance, range: expandedRange, user: this });
|
|
134
|
+
this.treeRef.collectTileGeometry(collector);
|
|
135
|
+
collector.requestMissingTiles();
|
|
136
|
+
if (collector.isAllGeometryLoaded && collector.polyfaces.length > 0) {
|
|
137
|
+
for (const polyface of collector.polyfaces) {
|
|
138
|
+
// Im assuming a single polyface here since we are draping a single point
|
|
139
|
+
const facetLocation = PolyfaceQuery.intersectRay3d(polyface, Ray3d.create(point, Vector3d.unitZ()));
|
|
140
|
+
if (!facetLocation)
|
|
141
|
+
continue;
|
|
142
|
+
outPoint.setFromPoint3d(facetLocation.point);
|
|
143
|
+
}
|
|
144
|
+
return "complete";
|
|
145
|
+
}
|
|
146
|
+
return "loading";
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
//# sourceMappingURL=GeometryTerrainDraper.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"GeometryTerrainDraper.js","sourceRoot":"","sources":["../../../src/Tools/GeometryTerrainDraper.ts"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\n* See LICENSE.md in the project root for license terms and full copyright notice.\n*--------------------------------------------------------------------------------------------*/\nimport {\n CollectTileStatus, DisclosedTileTreeSet,\n GeometryTileTreeReference, IModelApp,\n Tile, TileGeometryCollector, TileUser, Viewport } from \"@itwin/core-frontend\";\nimport { Angle, ConvexClipPlaneSet, CurvePrimitive, GrowableXYZArray, IndexedPolyface, IndexedPolyfaceSubsetVisitor, Loop, Point3d, Polyface, PolyfaceClip, PolyfaceQuery, PolygonOps, Range3d, Ray3d, SweepLineStringToFacetsOptions, Transform, Vector3d } from \"@itwin/core-geometry\";\nimport { Logger } from \"@itwin/core-bentley\";\n\nconst loggerCategory = \"MapLayersFormats.GeometryTerrainDraper\";\n\n/** A TileGeometryCollector that restricts collection to tiles that overlap a line string.\n/* @internal\n*/\nclass LineSegmentCollector extends TileGeometryCollector {\n private _points: GrowableXYZArray;\n\n constructor(user: TileUser, chordTolerance: number, range: Range3d, transform: Transform, points: GrowableXYZArray) {\n super({ user, chordTolerance, range, transform });\n this._points = points;\n }\n\n public override addMissingTile(tile: Tile): void {\n Logger.logTrace(loggerCategory, `CollectorAdd missing tile: ${tile.contentId}`);\n super.addMissingTile(tile);\n }\n\n public override collectTile(tile: Tile): CollectTileStatus {\n let status = super.collectTile(tile);\n\n if (\"reject\" !== status && !this.rangeOverlapsLineString(tile.range)) {\n status = \"reject\";\n }\n\n Logger.logTrace(loggerCategory, `collectTile - tile: ${tile.contentId} status: ${status } isReady: ${tile.isReady} status:${tile.loadStatus}`);\n return status;\n }\n\n private rangeOverlapsLineString(range: Range3d) {\n let inside = false;\n const clipper = ConvexClipPlaneSet.createRange3dPlanes(range, true, true, true, true, false, false);\n if (this._options.transform)\n clipper.transformInPlace(this._options.transform);\n\n for (let i = 0; i < this._points.length - 1 && !inside; i++)\n inside = clipper.announceClippedSegmentIntervals(0, 1, this._points.getPoint3dAtUncheckedPointIndex(i), this._points.getPoint3dAtUncheckedPointIndex(i + 1));\n\n return inside;\n }\n}\n\n/** @internal */\nexport class GeometryTerrainDraper implements TileUser {\n // The side angle measures how close the sweep vector is from being parallel to a side face.\n // The larger the angle, the more nearly vertical facets are ignored.\n // This is an \"empirical\" value that was determined by looking at \"problematic\" polyfaces\n public readonly sideAngle = Angle.createDegrees(0.06);\n\n public readonly maxDistanceZ = 1.0E5; // Expand the Z Range, but not so much that we get opposite side of globe.\n public readonly tileUserId: number;\n\n public constructor(public readonly viewport: Viewport, public readonly treeRef: GeometryTileTreeReference) {\n this.tileUserId = TileUser.generateId();\n IModelApp.tileAdmin.registerUser(this);\n }\n\n public dispose(): void {\n IModelApp.tileAdmin.forgetUser(this);\n }\n\n public get iModel() { return this.viewport.iModel; }\n\n public onRequestStateChanged() {\n this.viewport.invalidateDecorations();\n }\n\n public discloseTileTrees(trees: DisclosedTileTreeSet) {\n trees.disclose(this.treeRef);\n }\n\n // Filter out non-top facets:\n // For unknown reasons, there are \"perpendicular\" facets appearing in the terrain meshes.\n public getMeshTopFacets(mesh: IndexedPolyface) {\n // constant inputs\n const sweepVector = Vector3d.unitZ();\n // i.e., region is horizontal\n // create subset visitor from the top facets\n const topFacets: number[] = [];\n const facetNormal = Vector3d.createZero();\n\n for (const visitor = mesh.createVisitor(0); visitor.moveToNextFacet(); ) {\n if (PolygonOps.unitNormal(visitor.point, facetNormal)) {\n const theta = facetNormal.angleFromPerpendicular(sweepVector);\n if (!theta.isMagnitudeLessThanOrEqual(this.sideAngle)) { // skip side facet\n if (facetNormal.dotProduct(sweepVector) > 0) // this is a top facet\n topFacets.push(visitor.currentReadIndex());\n }\n }\n }\n\n return IndexedPolyfaceSubsetVisitor.createSubsetVisitor(mesh, topFacets, 0);\n }\n\n public drapeLineString(outStrings: CurvePrimitive[], inPoints: GrowableXYZArray, tolerance: number, range: Range3d): \"loading\" | \"complete\" {\n const tree = this.treeRef.treeOwner.load();\n if (!tree)\n return \"loading\";\n\n const expandedRange = Range3d.createFrom(range);\n expandedRange.extendZOnly(-this.maxDistanceZ);\n expandedRange.extendZOnly(this.maxDistanceZ);\n\n const collector = new LineSegmentCollector(this, tolerance, expandedRange, tree.iModelTransform, inPoints);\n this.treeRef.collectTileGeometry(collector);\n collector.requestMissingTiles();\n\n if (collector.isAllGeometryLoaded && collector.polyfaces.length > 0) {\n\n for (const polyface of collector.polyfaces) {\n // Use this to serialize (problematic) polyface\n // console.log (`const polyface = ${JSON.stringify(IModelJson.Writer.toIModelJson(polyface))}`);\n outStrings.push(...PolyfaceQuery.sweepLineStringToFacets(\n inPoints,\n polyface,\n SweepLineStringToFacetsOptions.create(Vector3d.unitZ(), this.sideAngle, true, true, false, false)));\n }\n\n return \"complete\";\n }\n\n return \"loading\";\n }\n\n public drapeLoop(outMeshes: Polyface[], loop: Loop, tolerance: number, range: Range3d): \"loading\" | \"complete\" {\n const tree = this.treeRef.treeOwner.load();\n if (!tree)\n return \"loading\";\n\n const expandedRange = Range3d.createFrom(range);\n expandedRange.extendZOnly(-this.maxDistanceZ);\n expandedRange.extendZOnly(this.maxDistanceZ);\n\n const strokes = loop.getPackedStrokes();\n if (!strokes)\n return \"complete\";\n\n const collector = new LineSegmentCollector(this, tolerance, expandedRange, tree.iModelTransform, strokes);\n this.treeRef.collectTileGeometry(collector);\n collector.requestMissingTiles();\n\n if (collector.isAllGeometryLoaded && collector.polyfaces.length > 0) {\n for (const polyface of collector.polyfaces) {\n const topFacets = this.getMeshTopFacets(polyface);\n const mesh = PolyfaceClip.drapeRegion(topFacets, loop);\n if (mesh)\n outMeshes.push(mesh);\n }\n return \"complete\";\n }\n return \"loading\";\n }\n public drapePoint(outPoint: Point3d, point: Point3d, chordTolerance: number, range: Range3d): \"loading\" | \"complete\" {\n const tree = this.treeRef.treeOwner.load();\n if (!tree)\n return \"loading\";\n\n const expandedRange = Range3d.createFrom(range);\n expandedRange.extendZOnly(-this.maxDistanceZ);\n expandedRange.extendZOnly(this.maxDistanceZ);\n\n const collector = new TileGeometryCollector({chordTolerance, range: expandedRange, user: this });\n this.treeRef.collectTileGeometry(collector);\n collector.requestMissingTiles();\n\n if (collector.isAllGeometryLoaded && collector.polyfaces.length > 0) {\n for (const polyface of collector.polyfaces) {\n // Im assuming a single polyface here since we are draping a single point\n const facetLocation = PolyfaceQuery.intersectRay3d(polyface, Ray3d.create(point, Vector3d.unitZ() ));\n if (!facetLocation)\n continue;\n outPoint.setFromPoint3d(facetLocation.point);\n }\n return \"complete\";\n }\n return \"loading\";\n }\n}\n"]}
|
|
@@ -1,37 +1,42 @@
|
|
|
1
1
|
import { ColorDef } from "@itwin/core-common";
|
|
2
2
|
import { DecorateContext, Decorator } from "@itwin/core-frontend";
|
|
3
|
-
import {
|
|
3
|
+
import { Point2d, Point3d } from "@itwin/core-geometry";
|
|
4
4
|
import { MapFeatureInfoToolData } from "./MapFeatureInfoTool";
|
|
5
5
|
/** @internal */
|
|
6
6
|
export declare class MapFeatureInfoDecorator implements Decorator {
|
|
7
7
|
hidden: boolean;
|
|
8
8
|
readonly useCachedDecorations = true;
|
|
9
|
-
readonly disableTerrainDraper =
|
|
9
|
+
readonly disableTerrainDraper = false;
|
|
10
10
|
markerSize: Point2d;
|
|
11
11
|
lineWidth: number;
|
|
12
|
+
maxDrapeSizePixels: number;
|
|
13
|
+
chordTolerancePixels: number;
|
|
12
14
|
private _highlightColor;
|
|
13
15
|
get highlightColor(): ColorDef;
|
|
14
16
|
set highlightColor(color: ColorDef);
|
|
15
17
|
get defaultMarkerIconSvgXml(): string;
|
|
16
|
-
private _drapePoints;
|
|
17
18
|
private _scratchPoints;
|
|
18
|
-
private
|
|
19
|
-
private
|
|
19
|
+
private _drapeGraphicsStates;
|
|
20
|
+
private _drapedPrimitives;
|
|
20
21
|
private _allGeomDraped;
|
|
21
22
|
private _draper?;
|
|
22
23
|
private _markerImage;
|
|
23
24
|
private _markerSet;
|
|
24
25
|
extraMarkers: Point3d[] | undefined;
|
|
25
|
-
private
|
|
26
|
+
private _data;
|
|
26
27
|
private readonly _graphicType;
|
|
27
28
|
constructor();
|
|
28
29
|
private updateMarkerImage;
|
|
29
|
-
private
|
|
30
|
-
|
|
31
|
-
|
|
30
|
+
private computePixelSize;
|
|
31
|
+
private computeChordTolerance;
|
|
32
|
+
clearData: () => void;
|
|
33
|
+
setData: (data: MapFeatureInfoToolData) => void;
|
|
32
34
|
private getGeometryTreeRef;
|
|
33
35
|
protected renderGraphics(context: DecorateContext): import("@itwin/core-frontend").RenderGraphic | undefined;
|
|
34
|
-
|
|
36
|
+
private initializeDrapeState;
|
|
37
|
+
private drapeGeometries;
|
|
38
|
+
private appendDrapedGeometries;
|
|
39
|
+
private appendGeometries;
|
|
35
40
|
decorate(context: DecorateContext): void;
|
|
36
41
|
}
|
|
37
42
|
//# sourceMappingURL=MapFeatureInfoDecorator.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MapFeatureInfoDecorator.d.ts","sourceRoot":"","sources":["../../../src/Tools/MapFeatureInfoDecorator.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"MapFeatureInfoDecorator.d.ts","sourceRoot":"","sources":["../../../src/Tools/MapFeatureInfoDecorator.ts"],"names":[],"mappings":"AAIA,OAAO,EAAuB,QAAQ,EAAE,MAAM,oBAAoB,CAAC;AACnE,OAAO,EACmB,eAAe,EAAE,SAAS,EAGrB,MAAM,sBAAsB,CAAC;AAC5D,OAAO,EAAkC,OAAO,EAAE,OAAO,EAA+C,MAAM,sBAAsB,CAAC;AACrI,OAAO,EAAE,sBAAsB,EAAE,MAAM,sBAAsB,CAAC;AAkG9D,gBAAgB;AAChB,qBAAa,uBAAwB,YAAW,SAAS;IAChD,MAAM,UAAS;IACtB,SAAgB,oBAAoB,QAAQ;IAC5C,SAAgB,oBAAoB,SAAS;IACtC,UAAU,UAAuB;IACjC,SAAS,SAAM;IAIf,kBAAkB,SAAS;IAI3B,oBAAoB,SAAM;IAEjC,OAAO,CAAC,eAAe,CAAmC;IAC1D,IAAW,cAAc,IACQ,QAAQ,CADkB;IAC3D,IAAW,cAAc,CAAC,KAAK,EAAE,QAAQ,EAGxC;IAED,IAAW,uBAAuB,WAAwtB;IAE1vB,OAAO,CAAC,cAAc,CAA0B;IAEhD,OAAO,CAAC,oBAAoB,CAA2B;IACvD,OAAO,CAAC,iBAAiB,CAA0B;IACnD,OAAO,CAAC,cAAc,CAAS;IAC/B,OAAO,CAAC,OAAO,CAAC,CAAwB;IACxC,OAAO,CAAC,YAAY,CAAmB;IACvC,OAAO,CAAC,UAAU,CAAsB;IAGjC,YAAY,EAAE,OAAO,EAAE,GAAC,SAAS,CAAC;IAEzC,OAAO,CAAC,KAAK,CAAqC;IAElD,OAAO,CAAC,QAAQ,CAAC,YAAY,CAA4B;;IAOzD,OAAO,CAAC,iBAAiB;IAKzB,OAAO,CAAC,gBAAgB;IAaxB,OAAO,CAAC,qBAAqB;IAWtB,SAAS,aAEd;IAEK,OAAO,SAAU,sBAAsB,UA2B5C;IAEF,OAAO,CAAC,kBAAkB;IAa1B,SAAS,CAAC,cAAc,CAAC,OAAO,EAAE,eAAe;IAyCjD,OAAO,CAAC,oBAAoB;IAiC5B,OAAO,CAAC,eAAe;IA+CvB,OAAO,CAAC,sBAAsB;IAkB9B,OAAO,CAAC,gBAAgB;IA4BjB,QAAQ,CAAC,OAAO,EAAE,eAAe,GAAG,IAAI;CAUhD"}
|