AE+VS+c#开发颜色符号系统之依比例符号化(六)

2024-01-17 02:18

本文主要是介绍AE+VS+c#开发颜色符号系统之依比例符号化(六),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

首先总结一下之前写的几篇符号化文章,列表如下:

AE+VS开发颜色符号系统之单一值符号(一)

AE+VS开发颜色符号系统之唯一值符号(二)

AE+VS开发颜色符号系统之分类符号(三)

AE+VS开发颜色符号系统之分级符号符号化(四)

AE+VS+c#开发颜色符号系统之分级色彩符号化(五)

和之前的操作一样,直接贴几段代码:

ProportionalSymbolsCmd.cs代码

using System;
using System.Drawing;
using System.Runtime.InteropServices;
using ESRI.ArcGIS.ADF.BaseClasses;
using ESRI.ArcGIS.ADF.CATIDs;
using ESRI.ArcGIS.Controls;namespace Visualization
{/// <summary>/// Command that works in ArcMap/Map/PageLayout/// </summary>[Guid("480b7562-e1ed-4e05-a119-9a7d9b5e2863")][ClassInterface(ClassInterfaceType.None)][ProgId("Visualization.ProportionalSymbolsCmd")]public sealed class ProportionalSymbolsCmd : BaseCommand{#region COM Registration Function(s)[ComRegisterFunction()][ComVisible(false)]static void RegisterFunction(Type registerType){// Required for ArcGIS Component Category Registrar supportArcGISCategoryRegistration(registerType);//// TODO: Add any COM registration code here//}[ComUnregisterFunction()][ComVisible(false)]static void UnregisterFunction(Type registerType){// Required for ArcGIS Component Category Registrar supportArcGISCategoryUnregistration(registerType);//// TODO: Add any COM unregistration code here//}#region ArcGIS Component Category Registrar generated code/// <summary>/// Required method for ArcGIS Component Category registration -/// Do not modify the contents of this method with the code editor./// </summary>private static void ArcGISCategoryRegistration(Type registerType){string regKey = string.Format("HKEY_CLASSES_ROOT\\CLSID\\{{{0}}}", registerType.GUID);MxCommands.Register(regKey);ControlsCommands.Register(regKey);}/// <summary>/// Required method for ArcGIS Component Category unregistration -/// Do not modify the contents of this method with the code editor./// </summary>private static void ArcGISCategoryUnregistration(Type registerType){string regKey = string.Format("HKEY_CLASSES_ROOT\\CLSID\\{{{0}}}", registerType.GUID);MxCommands.Unregister(regKey);ControlsCommands.Unregister(regKey);}#endregion#endregionprivate IHookHelper m_hookHelper = null;public ProportionalSymbolsCmd(){base.m_category = "Visualization";base.m_caption = "依比例符号符号化";base.m_message = "依比例符号符号化";base.m_toolTip = "依比例符号符号化";base.m_name = "ProportionalSymbolsCmd";   try{//// TODO: change bitmap name if necessary//string bitmapResourceName = GetType().Name + ".bmp";base.m_bitmap = new Bitmap(GetType(), bitmapResourceName);}catch (Exception ex){System.Diagnostics.Trace.WriteLine(ex.Message, "Invalid Bitmap");}}#region Overridden Class Methods/// <summary>/// Occurs when this command is created/// </summary>/// <param name="hook">Instance of the application</param>public override void OnCreate(object hook){if (hook == null)return;try{m_hookHelper = new HookHelperClass();m_hookHelper.Hook = hook;if (m_hookHelper.ActiveView == null)m_hookHelper = null;}catch{m_hookHelper = null;}if (m_hookHelper == null)base.m_enabled = false;elsebase.m_enabled = true;// TODO:  Add other initialization code}/// <summary>/// Occurs when this command is clicked/// </summary>public override void OnClick(){if (m_hookHelper == null) return;if (m_hookHelper.FocusMap.LayerCount > 0){ProportionalSymbols symbol = new ProportionalSymbols(m_hookHelper);symbol.Show(m_hookHelper as System.Windows.Forms.IWin32Window);}}#endregion}
}

ProportionalSymbols窗体及代码

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using ESRI.ArcGIS.Controls;
using ESRI.ArcGIS.Carto;
using ESRI.ArcGIS.Display;
using ESRI.ArcGIS.Framework;
using ESRI.ArcGIS.esriSystem;
using ESRI.ArcGIS.DisplayUI;
using ESRI.ArcGIS.Geodatabase;
using ESRI.ArcGIS.Geometry;namespace Visualization
{public partial class ProportionalSymbols : Form{IHookHelper m_hookHelper = null;IActiveView m_activeView = null;IMap m_map = null;IFeatureLayer layer2Symbolize = null;string strRendererField = string.Empty;string strNormalizeField = string.Empty;//    IStyleGallery pStyleGlry = new StyleGallery();IMarkerSymbol markerSymbol = null;IFillSymbol fillSymbol = null;//   IColor gColor = null;double minSize = 12;int legendCount = 5;public ProportionalSymbols(IHookHelper hookHelper){InitializeComponent();m_hookHelper = hookHelper;m_activeView = m_hookHelper.ActiveView;m_map = m_hookHelper.FocusMap;}private void ProportionalSymbols_Load(object sender, EventArgs e){CbxLayersAddItems();}private void cbxLayers2Symbolize_SelectedIndexChanged(object sender, EventArgs e){if (cbxLayers2Symbolize.SelectedItem != null){string strLayer2Symbolize = cbxLayers2Symbolize.SelectedItem.ToString();layer2Symbolize = GetFeatureLayer(strLayer2Symbolize);CbxFieldAdditems(layer2Symbolize);strRendererField = cbxFields.Items[0].ToString();}}private void CbxFieldAdditems(IFeatureLayer featureLayer){IFields fields = featureLayer.FeatureClass.Fields;cbxFields.Items.Clear();cbxNormalization.Items.Clear();cbxNormalization.Items.Add("None");for (int i = 0; i < fields.FieldCount; i++){if ((fields.get_Field(i).Type == esriFieldType.esriFieldTypeDouble) ||(fields.get_Field(i).Type == esriFieldType.esriFieldTypeInteger) ||(fields.get_Field(i).Type == esriFieldType.esriFieldTypeSingle) ||(fields.get_Field(i).Type == esriFieldType.esriFieldTypeSmallInteger)){cbxFields.Items.Add(fields.get_Field(i).Name);cbxNormalization.Items.Add(fields.get_Field(i).Name);}}cbxFields.SelectedIndex = 0;cbxNormalization.SelectedIndex = 0;}private void CbxLayersAddItems(){if (GetLayers() == null) return;IEnumLayer layers = GetLayers();layers.Reset();ILayer layer = layers.Next();while (layer != null){if (layer is IFeatureLayer){cbxLayers2Symbolize.Items.Add(layer.Name);}layer = layers.Next();}}private void btnSymbolize_Click(object sender, EventArgs e){if (layer2Symbolize == null) return;Renderer();}private IProportionalSymbolRenderer CreateRenderer(){IGeoFeatureLayer pGeoFeatureLayer = (IGeoFeatureLayer)layer2Symbolize;ITable pTable = (ITable)pGeoFeatureLayer;ICursor pCursor = pTable.Search(null, false);//Use the statistics objects to calculate the max value and the min valueIDataStatistics pDataStatistics = new DataStatisticsClass();pDataStatistics.Cursor = pCursor;//Set statistical fieldpDataStatistics.Field = strRendererField;//Get the result of statisticsIStatisticsResults pStatisticsResult = pDataStatistics.Statistics;if (pStatisticsResult == null) return null;if (markerSymbol == null){MessageBox.Show("请先选择点符号...", "信息提示", MessageBoxButtons.OK, MessageBoxIcon.Warning);return null;}if (fillSymbol == null){MessageBox.Show("请先选择背景...", "信息提示", MessageBoxButtons.OK, MessageBoxIcon.Warning);return null;}markerSymbol.Size = minSize;// Create a new proportional symbol renderer to draw pop1990IProportionalSymbolRenderer pProportionalSymbolR = new ProportionalSymbolRendererClass();   pProportionalSymbolR.Field = strRendererField;if (strNormalizeField.ToLower() != "none")pProportionalSymbolR.NormField = strNormalizeField;pProportionalSymbolR.MinDataValue = pStatisticsResult.Minimum;pProportionalSymbolR.MaxDataValue = pStatisticsResult.Maximum;pProportionalSymbolR.BackgroundSymbol = fillSymbol;pProportionalSymbolR.MinSymbol = (ISymbol)markerSymbol;pProportionalSymbolR.LegendSymbolCount = legendCount;pProportionalSymbolR.CreateLegendSymbols();return pProportionalSymbolR;}private void Renderer(){IGeoFeatureLayer pGeoFeatureL = (IGeoFeatureLayer)layer2Symbolize;IFeatureClass featureClass = pGeoFeatureL.FeatureClass;//找出rendererField在字段中的编号int lfieldNumber = featureClass.FindField(strRendererField);if (lfieldNumber == -1){MessageBox.Show("Can't find field called " + strRendererField);return;}IProportionalSymbolRenderer renderer = CreateRenderer();if (renderer == null) return;pGeoFeatureL.Renderer = (IFeatureRenderer)renderer;m_activeView.PartialRefresh(esriViewDrawPhase.esriViewGeography, null, m_activeView.Extent);}private void btnClose_Click(object sender, EventArgs e){this.Close();}#region "GetLayers"private IEnumLayer GetLayers(){UID uid = new UIDClass();uid.Value = "{40A9E885-5533-11d0-98BE-00805F7CED21}";// IFeatureLayer//uid.Value = "{E156D7E5-22AF-11D3-9F99-00C04F6BC78E}";  // IGeoFeatureLayer//uid.Value = "{6CA416B1-E160-11D2-9F4E-00C04F6BC78E}";  // IDataLayerif (m_map.LayerCount != 0){IEnumLayer layers = m_map.get_Layers(uid, true);return layers;}return null;}#endregion#region "GetFeatureLayer"private IFeatureLayer GetFeatureLayer(string layerName){//get the layers from the mapsif (GetLayers() == null) return null;IEnumLayer layers = GetLayers();layers.Reset();ILayer layer = null;while ((layer = layers.Next()) != null){if (layer.Name == layerName)return layer as IFeatureLayer;}return null;}#endregionprivate void cbxFields_SelectedIndexChanged(object sender, EventArgs e){if (cbxFields.SelectedItem != null){strRendererField = cbxFields.SelectedItem.ToString();}}private void cbxNormalization_SelectedIndexChanged(object sender, EventArgs e){if (cbxNormalization.SelectedItem != null){strNormalizeField = cbxNormalization.SelectedItem.ToString();}}private void btnSelectBackColor_Click(object sender, EventArgs e){GetSymbolByControl fillSymbolForm = new GetSymbolByControl(esriSymbologyStyleClass.esriStyleClassFillSymbols);fillSymbolForm.ShowDialog();if (fillSymbolForm.m_styleGalleryItem == null) return;fillSymbol = fillSymbolForm.m_styleGalleryItem.Item as IFillSymbol;fillSymbolForm.Dispose();}private void btnSelectSymbol_Click(object sender, EventArgs e){GetSymbolByControl markerSymbolForm = new GetSymbolByControl(esriSymbologyStyleClass.esriStyleClassMarkerSymbols);markerSymbolForm.ShowDialog();if (markerSymbolForm.m_styleGalleryItem == null) return;markerSymbol = markerSymbolForm.m_styleGalleryItem.Item as IMarkerSymbol;markerSymbolForm.Dispose();}private ISymbol GetSymbolBySymbolSelector(esriGeometryType geometryType){try{ISymbolSelector pSymbolSelector = new SymbolSelectorClass();ISymbol symbol = null;switch (geometryType){case ESRI.ArcGIS.Geometry.esriGeometryType.esriGeometryPoint:symbol = new SimpleMarkerSymbolClass();break;case ESRI.ArcGIS.Geometry.esriGeometryType.esriGeometryPolyline:symbol = new SimpleLineSymbolClass();break;case ESRI.ArcGIS.Geometry.esriGeometryType.esriGeometryPolygon:symbol = new SimpleFillSymbolClass();break;default:break;}pSymbolSelector.AddSymbol(symbol);bool response = pSymbolSelector.SelectSymbol(0);if (response){symbol = pSymbolSelector.GetSymbolAt(0);return symbol;}return null;}catch (Exception ex){MessageBox.Show(ex.Message);ISymbol symbol = null;switch (geometryType){case ESRI.ArcGIS.Geometry.esriGeometryType.esriGeometryPoint:symbol = new SimpleMarkerSymbolClass();break;case ESRI.ArcGIS.Geometry.esriGeometryType.esriGeometryPolyline:symbol = new SimpleLineSymbolClass();break;case ESRI.ArcGIS.Geometry.esriGeometryType.esriGeometryPolygon:symbol = new SimpleFillSymbolClass(); break;default:break;}return symbol;}}private void nudLegendCount_ValueChanged(object sender, EventArgs e){legendCount = Convert.ToInt32(nudLegendCount.Value);}private void nudMinsize_ValueChanged(object sender, EventArgs e){minSize = Convert.ToDouble(nudMinsize.Value);}           }
}

关于前面提到的TOC控件爱你不能刷新的问题找到了,需要在axMapControl1_OnViewRefreshed事件里面添加一下代码:

axTOCControl1.Update();即可解决这个问题。不过可能会出现异常:

解决办法见c#+AE开发中,System.Windows.Forms.AxHost.InvalidActiveXStateException 在 ESRI.ArcGIS.AxControls.dll 中发生(问题代码行前添加三行代码初始化控件,修改对应控件名,可以用,启动后使用中暂时未发现异常)

这篇关于AE+VS+c#开发颜色符号系统之依比例符号化(六)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/614634

相关文章

C#中lock关键字的使用小结

《C#中lock关键字的使用小结》在C#中,lock关键字用于确保当一个线程位于给定实例的代码块中时,其他线程无法访问同一实例的该代码块,下面就来介绍一下lock关键字的使用... 目录使用方式工作原理注意事项示例代码为什么不能lock值类型在C#中,lock关键字用于确保当一个线程位于给定实例的代码块中时

PyQt5 GUI 开发的基础知识

《PyQt5GUI开发的基础知识》Qt是一个跨平台的C++图形用户界面开发框架,支持GUI和非GUI程序开发,本文介绍了使用PyQt5进行界面开发的基础知识,包括创建简单窗口、常用控件、窗口属性设... 目录简介第一个PyQt程序最常用的三个功能模块控件QPushButton(按钮)控件QLable(纯文本

C# $字符串插值的使用

《C#$字符串插值的使用》本文介绍了C#中的字符串插值功能,详细介绍了使用$符号的实现方式,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧... 目录$ 字符使用方式创建内插字符串包含不同的数据类型控制内插表达式的格式控制内插表达式的对齐方式内插表达式中使用转义序列内插表达式中使用

C#中的Converter的具体应用

《C#中的Converter的具体应用》C#中的Converter提供了一种灵活的类型转换机制,本文详细介绍了Converter的基本概念、使用场景,具有一定的参考价值,感兴趣的可以了解一下... 目录Converter的基本概念1. Converter委托2. 使用场景布尔型转换示例示例1:简单的字符串到

Linux系统中查询JDK安装目录的几种常用方法

《Linux系统中查询JDK安装目录的几种常用方法》:本文主要介绍Linux系统中查询JDK安装目录的几种常用方法,方法分别是通过update-alternatives、Java命令、环境变量及目... 目录方法 1:通过update-alternatives查询(推荐)方法 2:检查所有已安装的 JDK方

Linux系统之lvcreate命令使用解读

《Linux系统之lvcreate命令使用解读》lvcreate是LVM中创建逻辑卷的核心命令,支持线性、条带化、RAID、镜像、快照、瘦池和缓存池等多种类型,实现灵活存储资源管理,需注意空间分配、R... 目录lvcreate命令详解一、命令概述二、语法格式三、核心功能四、选项详解五、使用示例1. 创建逻

C#监听txt文档获取新数据方式

《C#监听txt文档获取新数据方式》文章介绍通过监听txt文件获取最新数据,并实现开机自启动、禁用窗口关闭按钮、阻止Ctrl+C中断及防止程序退出等功能,代码整合于主函数中,供参考学习... 目录前言一、监听txt文档增加数据二、其他功能1. 设置开机自启动2. 禁止控制台窗口关闭按钮3. 阻止Ctrl +

C#解析JSON数据全攻略指南

《C#解析JSON数据全攻略指南》这篇文章主要为大家详细介绍了使用C#解析JSON数据全攻略指南,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、为什么jsON是C#开发必修课?二、四步搞定网络JSON数据1. 获取数据 - HttpClient最佳实践2. 动态解析 - 快速

基于Python开发一个图像水印批量添加工具

《基于Python开发一个图像水印批量添加工具》在当今数字化内容爆炸式增长的时代,图像版权保护已成为创作者和企业的核心需求,本方案将详细介绍一个基于PythonPIL库的工业级图像水印解决方案,有需要... 目录一、系统架构设计1.1 整体处理流程1.2 类结构设计(扩展版本)二、核心算法深入解析2.1 自

使用Python构建一个高效的日志处理系统

《使用Python构建一个高效的日志处理系统》这篇文章主要为大家详细讲解了如何使用Python开发一个专业的日志分析工具,能够自动化处理、分析和可视化各类日志文件,大幅提升运维效率,需要的可以了解下... 目录环境准备工具功能概述完整代码实现代码深度解析1. 类设计与初始化2. 日志解析核心逻辑3. 文件处