zoukankan      html  css  js  c++  java
  • ArcGIS Pro二次开发地图MapSeries序列设置

      /*
       
      Copyright 2019 Esri
       
      Licensed under the Apache License, Version 2.0 (the "License");
      you may not use this file except in compliance with the License.
      You may obtain a copy of the License at
       
      http://www.apache.org/licenses/LICENSE-2.0
       
      Unless required by applicable law or agreed to in writing, software
      distributed under the License is distributed on an "AS IS" BASIS,
      WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
       
      See the License for the specific language governing permissions and
      limitations under the License.
       
      */
      using ArcGIS.Core.Data;
      using ArcGIS.Desktop.Framework.Dialogs;
      using System;
      using System.Collections.Generic;
      using System.Collections.ObjectModel;
      using System.Linq;
      using System.Text;
      using System.Threading.Tasks;
       
      namespace LayoutMapSeries.LayoutSettings
      {
      public class MapSeriesDefinition
      {
      public string FeatureClassName { get; set; }
       
      public IList<MapSeriesItem> MapSeriesItems = new List<MapSeriesItem>();
       
      public void LoadFromFeatureClass(string layoutName, FeatureClass featureClass, string fieldList)
      {
      MapSeriesItems.Clear();
      var oidName = featureClass.GetDefinition().GetObjectIDField();
      QueryFilter getQf = new QueryFilter
      {
      SubFields = $@"{oidName},{fieldList}"
      };
      var fields = fieldList.Split(new char []{ ',' });
      if (fields.Length < 2)
      {
      throw new Exception($@"List of fields {fieldList} needs to contain at least ID and Name");
      }
      // For Selecting all matching entries.
      using (var rowCursor = featureClass.Search(getQf))
      {
      var oidIdx = rowCursor.FindField(oidName);
      var idIdx = rowCursor.FindField(fields[0]);
      var nameIdx = rowCursor.FindField(fields[1]);
      while (rowCursor.MoveNext())
      {
      using (var row = rowCursor.Current)
      {
      var oid = Convert.ToInt64(row[oidIdx]);
      var id = Convert.ToInt32(row[idIdx]);
      var name = row[nameIdx].ToString();
      if (string.IsNullOrEmpty(layoutName)) MessageBox.Show("test");
      MapSeriesItems.Add(new MapSeriesItem { Oid = oid, Id = id, Name = name, LayoutName = layoutName });
      }
      }
      }
      }
      }
       
      public class MapSeriesItem
      {
      public long Oid { get; set; }
      public int Id { get; set; }
      public string Name { get; set; }
      public string LayoutName { get; set; }
      }
      }
  • 相关阅读:
    SharePoint Workflow出了问题, 除了ULS log还可以看什么日志?
    Kernel Mode Debugging 初步 一
    一些debug常用的"魔法"数值
    SQL Block的初级排查
    [持续更新]一些有用的PowerShell收集
    关于斜杠(slash)和反斜杠(back slash)的小知识点
    如何安全地解放C盘剩余磁盘空间?
    返璞归真asp.net mvc 1.0(3) Controller/Action【转】
    关于Oxite的教训
    [翻译ASP.NET MVC]Contact Manager开发之旅之迭代2 修改样式,美化应用 【转】
  • 原文地址:https://www.cnblogs.com/gisoracle/p/12504199.html
Copyright © 2011-2022 走看看