Parameters
- mapPoint
- The point in map coordinates
Return Value
A point in page coordinates
Exception | Description |
---|---|
System.InvalidOperationException | Mapframe must contain a 2D map |
System.ArgumentNullException | mapPoint |
ArcGIS.Core.CalledOnWrongThreadException | This method or property must be called within the lambda passed to QueuedTask.Run. |
internal class GetMapCoordinates : MapTool { protected override void OnToolMouseDown(MapViewMouseButtonEventArgs e) { if (e.ChangedButton == System.Windows.Input.MouseButton.Left) e.Handled = true; //Handle the event args to get the call to the corresponding async method } protected override Task HandleMouseDownAsync(MapViewMouseButtonEventArgs e) { return QueuedTask.Run(() => { var pointSymbol = SymbolFactory.Instance.ConstructPointSymbol(ColorFactory.Instance.BlackRGB, 8); var layout = Project.Current.GetItems<LayoutProjectItem>().FirstOrDefault().GetLayout(); //Convert the clicked point in client coordinates to the corresponding map coordinates. var mapPoint = MapView.Active.ClientToMap(e.ClientPoint); ArcGIS.Desktop.Framework.Dialogs.MessageBox.Show(string.Format("X: {0} Y: {1} Z: {2}", mapPoint.X, mapPoint.Y, mapPoint.Z), "Map Coordinates"); //Get the corresponding layout point var mapFrame = layout.FindElement("New Map Frame") as MapFrame; var pointOnLayoutFrame = mapFrame.MapToPage(mapPoint); //Create a point graphic on the Layout. var cimGraphicElement = new CIMPointGraphic { Location = pointOnLayoutFrame, Symbol = pointSymbol.MakeSymbolReference() }; //Or use GraphicFactory var cimGraphicElement2 = GraphicFactory.Instance.CreateSimpleGraphic( pointOnLayoutFrame, pointSymbol); //At 2.x - LayoutElementFactory.Instance.CreateGraphicElement(layout, cimGraphicElement); ElementFactory.Instance.CreateGraphicElement(layout, cimGraphicElement); ElementFactory.Instance.CreateGraphicElement(layout, cimGraphicElement2); }); } }
Target Platforms: Windows 11, Windows 10, Windows 8.1