zoukankan      html  css  js  c++  java
  • ArcGIS Pro二次开发-识别工具

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Text;
    using System.Threading.Tasks;
    using ArcGIS.Core.CIM;
    using ArcGIS.Core.Data;
    using ArcGIS.Core.Geometry;
    using ArcGIS.Desktop.Catalog;
    using ArcGIS.Desktop.Core;
    using ArcGIS.Desktop.Editing;
    using ArcGIS.Desktop.Extensions;
    using ArcGIS.Desktop.Framework;
    using ArcGIS.Desktop.Framework.Contracts;
    using ArcGIS.Desktop.Framework.Dialogs;
    using ArcGIS.Desktop.Framework.Threading.Tasks;
    using ArcGIS.Desktop.Mapping;
    
    
    
    using System.Windows.Input;
    
    
    
    
    
    namespace ProAppModule1
    {
        internal class MapToolSelect : MapTool
        {
            public MapToolSelect()
    
            {
    
                IsSketchTool = true;
    
                SketchType = SketchGeometryType.Circle;
    
                SketchOutputMode = SketchOutputMode.Screen;
    
            }
    
    
    
            protected override Task OnToolActivateAsync(bool active)
    
            {
    
                return base.OnToolActivateAsync(active);
    
            }
    
    
    
            protected override async Task<bool> OnSketchCompleteAsync(Geometry geometry)
    
            {
                var mv = MapView.Active;
    
                var identifyResult = await QueuedTask.Run(() =>
    
                {
    
                    var sb = new StringBuilder();
    
    
    
                    // Get the features that intersect the sketch geometry. 
    
                    var features = mv.GetFeatures(geometry);
    
    
    
                    // Get all layer definitions
    
                    var lyrs = mv.Map.GetLayersAsFlattenedList().OfType<FeatureLayer>();
    
                    foreach (var lyr in lyrs)
    
                    {
    
                        var fCnt = features.ContainsKey(lyr) ? features[lyr].Count : 0;
    
                        sb.AppendLine($@"{fCnt} {(fCnt == 1 ? "record" : "records")} for {lyr.Name}");
    
                    }
    
                    return sb.ToString();
    
                });
    
                MessageBox.Show(identifyResult);
    
                return true;
    
            }
    
        }
    
    
    }
  • 相关阅读:
    读写csv文件
    安卓跳转
    求时间精确到秒的数
    航空公司客户价值分析
    利用LM神经网络和决策树去分类
    拉格朗日插值法
    ID3
    K最近邻
    贝叶斯分类
    FilterDispatcher已被标注为过时解决办法
  • 原文地址:https://www.cnblogs.com/gisoracle/p/12462762.html
Copyright © 2011-2022 走看看