ArcEngine实现要素坐标转换:平移、缩放、旋转(批量处理)
在二维坐标系统中,常见转换坐标:平移、缩放、旋转。在ArcGIS中可以通过工具实现移动 、旋转 和缩放,具体操作如下:
(1)移动要素:可通过指针或指定值以交互方式操作所选要素。移动要素:要移动要素,请使用指针选择并对其进行拖动。选择多个要素后,您可以单击鼠标右键并对齐或分配要素。
(2)旋转要素:要使用指针旋转要素,请对其进行选择并拖动。主选择锚点可指定旋转中心。辅助锚点可将旋转角度捕捉到其他要素。
(3)旋转要素:要使用指针旋转要素,请对其进行选择并拖动。主选择锚点可指定旋转中心。辅助锚点可将旋转角度捕捉到其他要素。
对于实际工作中,会遇到各种复杂的数据,基于不同基点(原点),平移、缩放、旋转的量都不同,要根据具体情况具体分析。本文想实现坐标转换的通用方法,基于基点信息,对图层所有要素进行平移、缩放、旋转。
实现主体函数执行流程如下:
for (int i = 0; i < BasePoints.Rows.Count; i++)
{TransformCoordinate MoveCoor = new TransformCoordinate(); DataRow BaseBow = BasePoints.Rows[i];//1.获取基点信息MoveCoor.getBaseInfo(BaseBow); string shpName = MoveCoor.shpFileName; string output = outputPath + @"\" + shpName;if (inputTargetNameList.Exists(t => t.Equals(shpName)))//判断List是否含某个属性{//2.将所有同名(shpName)文件,从源路径复制至输出路径下,不区分文件后缀名FileCopy.CopyOneShpFile(inputTargetFile, outputPath, shpName,true);//复制文件//3.判断图层中有无图形元素,同时初始化图层即给in_FeatureClass赋值if (MoveCoor.isExistFeatures(output) == false){remind2 += shpName + " ";//图层缺少要素}//4.转换坐标 MoveCoor.ExecutePan();//平移MoveCoor.ExecuteRotate();//旋转MoveCoor.ExecuteTelescopic();//缩放MoveCoor.updateExtend();//更新图层extent}else{remind += shpName + " ";//缺少图层continue;}
}
我这里的基点(PointA和PointB)的坐标信息、旋转角度,缩放比例等坐标转换信息都保存在Excel文件中,如下图所示坐标转换参数表,可以根据不同的项目修改坐标转换的参数,实现通用的坐标转换功能。
坐标转换类:
/// <summary>/// 根据已知基点信息,批量实现图层要素的平移、缩放、旋转。/// 处理Shapefile文件/// </summary>public class TransformCoordinate{//基点信息public string shpFileName;private IPoint PointA;//基点A是图层坐标转换前的基点private IPoint PointB;//基点B是图层坐标转换后的基点private double scale;//缩放比例private double angle;//旋转角度,读取的是角度(°),旋转时用的是弧度,需要角度转为弧度private IFeatureClass in_FeatureClass;public TransformCoordinate(){//基点PointA = new Point();PointB = new Point();}//判断图层中有无图形元素,同时初始化图层public bool isExistFeatures(string in_filePath){IWorkspaceFactory pWorkspaceFactory = new ShapefileWorkspaceFactory();IWorkspaceFactoryLockControl pWorkspaceFactoryLockControl = pWorkspaceFactory as IWorkspaceFactoryLockControl;if (pWorkspaceFactoryLockControl.SchemaLockingEnabled){pWorkspaceFactoryLockControl.DisableSchemaLocking();}IWorkspace pWorkspace = pWorkspaceFactory.OpenFromFile(System.IO.Path.GetDirectoryName(in_filePath), 0);IFeatureWorkspace pFeatureWorkspace = pWorkspace as IFeatureWorkspace;in_FeatureClass = pFeatureWorkspace.OpenFeatureClass(System.IO.Path.GetFileName(in_filePath));if (in_FeatureClass.FeatureCount(null) > 0){ return true; }else{ return false; }}//获取基点信息public void getBaseInfo(DataRow rows){shpFileName = rows[0].ToString().Trim() + ".shp"; PointA.X = Convert.ToDouble(rows[1].ToString());PointA.Y = Convert.ToDouble(rows[2].ToString()); PointB.X = Convert.ToDouble(rows[3].ToString());PointB.Y = Convert.ToDouble(rows[4].ToString());scale = Convert.ToDouble(rows[5].ToString());angle = Math.PI / 180 * Convert.ToDouble(rows[6].ToString());//角度(°)转为弧度}//平移public bool ExecutePan(){ // 获取游标IFeatureCursor in_FeatureCursor = in_FeatureClass.Update(null, true);IFeature in_Feature = in_FeatureCursor.NextFeature();if (in_Feature == null){// 释放游标System.Runtime.InteropServices.Marshal.ReleaseComObject(in_FeatureCursor);return false;}while (in_Feature != null){IGeometry pGeometry = in_Feature.Shape;in_Feature.Shape = Pan(pGeometry, PointB.X - PointA.X, PointB.Y - PointA.Y);in_FeatureCursor.UpdateFeature(in_Feature);in_Feature = in_FeatureCursor.NextFeature();}// 释放游标System.Runtime.InteropServices.Marshal.ReleaseComObject(in_FeatureCursor);return true;}//旋转public bool ExecuteRotate(){ // 获取游标IFeatureCursor in_FeatureCursor = in_FeatureClass.Update(null, true);IFeature in_Feature = in_FeatureCursor.NextFeature();if (in_Feature == null){return false;}while (in_Feature != null){IGeometry pGeometry = in_Feature.Shape;in_Feature.Shape = Rotate(pGeometry, PointB, angle);in_FeatureCursor.UpdateFeature(in_Feature); in_Feature = in_FeatureCursor.NextFeature();}// 释放游标System.Runtime.InteropServices.Marshal.ReleaseComObject(in_FeatureCursor);return true;}//缩放public bool ExecuteTelescopic(){// 获取游标IFeatureCursor in_FeatureCursor = in_FeatureClass.Update(null, true);IFeature in_Feature = in_FeatureCursor.NextFeature();if (in_Feature == null){return false;}while (in_Feature != null){IGeometry pGeometry = in_Feature.Shape;in_Feature.Shape = Telescopic(pGeometry, PointB, scale);in_FeatureCursor.UpdateFeature(in_Feature);in_Feature = in_FeatureCursor.NextFeature();}// 释放游标System.Runtime.InteropServices.Marshal.ReleaseComObject(in_FeatureCursor);return true;}// 平移变换private IGeometry Pan(IGeometry pGeometry, double dx, double dy){ITransform2D pTransform2D = pGeometry as ITransform2D;pTransform2D.Move(dx, dy);return pTransform2D as IGeometry;}/// <summary>/// 伸缩变换/// </summary>/// <param name="pGeometry"></param>/// <param name="originPoint">原点或基点</param>/// <param name="scale"></param>/// <returns></returns>private IGeometry Telescopic(IGeometry pGeometry, IPoint originPoint, double scale){ITransform2D pTransform2D = pGeometry as ITransform2D;pTransform2D.Scale(originPoint, scale, scale);return pTransform2D as IGeometry; }// 旋转变换private IGeometry Rotate(IGeometry pGeometry, IPoint originPoint, double angle){IPointCollection pPointCollection = pGeometry as IPointCollection;ITransform2D pTransform2D = pGeometry as ITransform2D;pTransform2D.Rotate(originPoint, angle);return pTransform2D as IGeometry;}//extent更新public void updateExtend(){((IFeatureClassManage)in_FeatureClass).UpdateExtent();}}
相关文章:
ArcEngine实现要素坐标转换:平移、缩放、旋转(批量处理)
在二维坐标系统中,常见转换坐标:平移、缩放、旋转。在ArcGIS中可以通过工具实现移动 、旋转 和缩放,具体操作如下: (1)移动要素:可通过指针或指定值以交互方式操作所选要素。移动要素…...
Redis: 主从复制原理
主从复制原理剖析 1 )配置 通过下面的从节点的配置项可以开启主从之间的复制功能slaveof 192.16.10.101 6379这里的复制包含全量复制和增量复制 2 )主节点的主从配置信息解析 查看主从之间的信息,在主节点上 $ info replication 打印出来的…...
PostgreSQL 向量扩展插件pgvector安装和使用
文章目录 PostgreSQL 向量扩展插件pgvector安装和使用安装postgresqlpgvector下载和安装安装错误调试错误调试1尝试解决 AP1 :启动postgresql 错误调试2尝试解决 AP2 : 使用apt-get install postgresql-server 错误调试3尝试解决 AP3 :卸载apt-get 安装 …...
【论文阅读】基于真实数据感知的模型功能窃取攻击
摘要 目的 模型功能窃取攻击是人工智能安全领域的核心问题之一,目的是利用有限的与目标模型有关的信息训练出性能接近的克隆模型,从而实现模型的功能窃取。针对此类问题,一类经典的工作是基于生成模型的方法,这类方法利用生成器…...
线程池:线程池的实现 | 日志
🌈个人主页: 南桥几晴秋 🌈C专栏: 南桥谈C 🌈C语言专栏: C语言学习系列 🌈Linux学习专栏: 南桥谈Linux 🌈数据结构学习专栏: 数据结构杂谈 🌈数据…...
海信和TCL雷鸟智能电视的体验
买了型号为32E2F(9008)的海信智能的电视有一段时间了,要使用这个智能电视还真能考验你的智商。海信电视有很多优点,它的屏幕比较靓丽,色彩好看,遥控器不用对着屏幕就能操作。但也有不少缺点。 1. 海信智能电视会强迫自动更新操作…...
自动化学习3:日志记录及测试报告的生成--自动化框架搭建
一.日志记录 1.配置文件pytest.ini:将日志写入文件方便日后查询或查看执行信息。 需要将文件处理器(文件存放位置/时间/格式等等)添加到配置文件中的【日志记录器】 # pytest.ini [pytest] # ---------------日志文件,需要配合…...
【STM32单片机_(HAL库)】4-1【定时器TIM】定时器中断点灯实验
1.硬件 STM32单片机最小系统LED灯模块 2.软件 timer驱动文件添加定时器HAL驱动层文件添加GPIO常用函数定时器中断配置流程main.c程序 #include "sys.h" #include "delay.h" #include "led.h" #include "timer.h"int main(void) {H…...
Linux编译安装Mysql笔记
1.Mysql介绍 MySQL是一个广泛使用的开源关系型数据库管理系统(RDBMS),它基于SQL(Structured Query Language)进行操作。MySQL是由瑞典MySQL AB公司开发的,后来被Sun Microsystems收购,最终成为…...
在java后端发送HTTPClient请求
简介 HttpClient遵循http协议的客户端编程工具包支持最新的http协议 部分依赖自动传递依赖了HttpClient的jar包 明明项目中没有引入 HttpClient 的Maven坐标,但是却可以直接使用HttpClient原因是:阿里云的sdk依赖中传递依赖了HttpClient的jar包 发送get请…...
【STM32单片机_(HAL库)】4-3-2【定时器TIM】测量按键按下时间1——编程实现捕获功能
测量按键按下时长思路 测量按键按下时间实验目的 使用定时器 2 通道 2 来捕获按键 (按键接PA0)按下时间,并通过串口打印。 计一个数的时间:1us,PSC71,ARR65535 下降沿捕获、输入通道 2 映射在 TI2 上、不分…...
MySQL:2059 - Authentication plugin ‘caching_sha2_password‘ cannot be loaded
关于MySQL 客户端在尝试连接到 MySQL 服务器时报错:“2059 - Authentication plugin caching_sha2_password cannot be loaded”,具体是由于 MySQL 服务器默认使用的 caching_sha2_password 认证插件无法加载或不被当前客户端支持。 错误原因 MySQL 8.0…...
【JavaSE】反射、枚举、lambda表达式
目录 反射反射相关类获取类中属性相关方法常用获得类相关的方法示例常用获得类中属性相关的方法示例获得类中注解相关的方法 反射优缺点 枚举常用方法优缺点 枚举与反射lambda表达式语法函数式接口简化规则使用示例变量捕获集合中的应用优缺点 反射 Java的反射(refl…...
P3227 [HNOI2013] 切糕
题意: n ∗ m n*m n∗m的矩阵,每个点可以选择一个值 a i , j k a_{i,j}k ai,jk,然后你能获得 w ( i , j , k ) w(i,j,k) w(i,j,k)的得分,但是相邻两点之间的差值有限制,让你求最大得分。 考虑最小割。 每个点 ( i , j ) (i,j) (i,j)弄出一条长为 R…...
超分服务的分量保存
分量说明 分量的概念主要是对于显卡解码,编码和网络传输而言,显卡可以同时进行几个线程,多个显卡可以分布式计算,对分量进行AI识别,比如我们有cuda的显卡,cuda的核心量可以分给不同的分片视频,第…...
Windows11系统下SkyWalking环境搭建教程
目录 前言SkyWalking简介SkyWalking下载Agent监控实现启动配置SkyWalking启动Java应用程序启动Elasticsearch安装总结 前言 本文为博主在项目环境搭建时记录的SkyWalking安装流程,希望对大家能够有所帮助,不足之处欢迎批评指正🤝ᾑ…...
前端BOM常用操作
BOM操作常用命令详解及代码案例 BOM(Browser Object Model)是浏览器对象模型,是浏览器提供的JavaScript操作浏览器的API。BOM提供了与网页无关的浏览器的功能对象,虽然没有正式的标准,但现代浏览器已经几乎实现了Java…...
【Go】-viper库的使用
目录 viper简介 viper使用 通过viper.Set设置值 读取配置文件说明 读取配置文件 读取多个配置文件 读取配置项的值 读取命令行的值 io.Reader中读取值 写配置文件 WriteConfig() 和 SafeWriteConfig() 区别: viper简介 配置管理解析库,是由大神 Steve Fr…...
JavaWeb酒店管理系统(详细版)
✅作者简介:2022年博客新星 第八。热爱国学的Java后端开发者,修心和技术同步精进。 🍎个人主页:Java Fans的博客 🍊个人信条:不迁怒,不贰过。小知识,大智慧。 💞当前专栏…...
C++ | 定长内存池 | 对象池
文章目录 C | 定长内存池 | 对象池一、内存池的引入二、代码中的内存池实现 - ObjectPool类(一)整体结构(二)内存分配 - New函数(三)内存回收 - Delete函数 三、内存池在TreeNode示例中的性能测试演示四、脱…...
python画图|自制渐变柱状图
在前述学习过程中,我们已经通过官网学习了如何绘制渐变的柱状图及其背景。 掌握一门技能的最佳检验方式就是通过实战,因此,本文尝试做一些渐变设计。 前述学习记录可查看链接: Python画图|渐变背景-CSDN博客 【1】柱状图渐变 …...
基于RPA+BERT的文档辅助“悦读”系统 | OPENAIGC开发者大赛高校组AI创作力奖
在第二届拯救者杯OPENAIGC开发者大赛中,涌现出一批技术突出、创意卓越的作品。为了让这些优秀项目被更多人看到,我们特意开设了优秀作品报道专栏,旨在展示其独特之处和开发者的精彩故事。 无论您是技术专家还是爱好者,希望能带给…...
K8S部署流程
一、war打包镜像(survey,analytics,trac系统) 代码打包成war准备tomcat的server.xml文件,修改connector中8080端口为项目的端口 修改前: <Connector port"8080" protocol"HTTP/1.1"connectionTimeout"20000"redirect…...
DevExpress WinForms中文教程:Data Grid - 如何添加或删除行?
本教程介绍DevExpress WinForm的Data Grid控件UI元素和API,它们使您和最终用户能够添加或删除数据行。您将首选学习如何启用内置的数据导航器,然后学习如何使用Microsoft Outlook启发的New Item行添加新记录。最后教程将向您展示基本的API,它…...
u盘格式化后数据能恢复吗?2024年Top4恢复神器来帮忙
在这个电脑和手机满天飞的时代,U盘是我们用来存东西和传文件的得力助手,特别重要。但是,有时候U盘可能会不小心被格式化了,里面的重要文件就不见了。那么,U盘格式化后的数据还能恢复吗?当然可以。今天会告诉…...
深度学习·Argparse
Argparse 命令行选项、参数和子命令解析器 ArgumentParser 命令行传参数->解析参数->获得对应参数 初始化:parser argparse.ArgumentParser(descriptionxxx)添加命令行参数: parser.add_argument("--training_filepath", typestr, he…...
制造企业为何需要PLM系统?PLM系统解决方案对制造业重要性分析
制造企业为何需要PLM系统?PLM系统解决方案对制造业重要性分析 新华社9月23日消息,据全国组织机构统一社会信用代码数据服务中心统计,我国制造业企业总量突破600万家。数据显示,2024年1至8月,我国制造业企业数量呈现稳…...
http协议中的header详细讲解
http协议中的header详细讲解 HTTP 协议和 TCP/IP 协议族内的其他众多的协议相同,用于客户端和服务器之间的通信。 请求访问文本或图像等资源的一端称为客户端,而提供资源响应的一端称为服务器端。 HTTP 协议规定,请求从客户端发出…...
探索后量子安全:基于格加密技术的未来密码学展望
在信息技术日新月异的今天,量子计算作为下一代计算技术的代表,正逐步从理论走向实践。量子计算的出现对现有的加密体系构成了严重威胁,尤其是基于大数分解和离散对数难题的传统密码学(如RSA和Diffie-Hellman协议)。为了…...
WPF之UI进阶--完整了解wpf的控件和布局容器及应用
前面三篇有关WPF的基础介绍,分别介绍了wpf与winform的异同,wpf的事件生成和使用以及数据绑定。但我们还缺乏一副好的“皮囊”,所以从这篇开始我们来开始学习wpf的UI相关的内容,首当其冲的就是布局容器。 其实我们知道,…...
做设计的靠谱兼职网站有哪些/项目外包平台
python 3 的安装: 背景:之前都是在Pychram上写,我的windows下的python版本是3.5,今天要把一个小脚本上到生产环境上。无奈我服务器上的python版本是2.6.6。所以这里记录一下我安装python3 的过程。 版本下载:https://www.python.o…...
手机营销型网站建设/手游代理加盟哪个平台最强大
我正在为数据库实现一个漂亮的基本搜索引擎,用户可能会在其中包含不同类型的信息。搜索本身由几个联合组成,选择结果总是合并到3列中。然而,返回的数据正在从不同的表中获取。每个查询使用$ term进行匹配,我将其绑定到“ÿ…...
代理登录网站/uc信息流广告投放
利用matlab将位图转为SVG矢量图0 前言1 算法思路1.1 读取图片1.2 中值滤波1.3 中值滤波1.4 去除孤立的像素1.5 提取单独的颜色1.6 找出二值图像中所有的连接体1.7 将提取出来的每个多边形膨胀1.8 输出为SVG格式2 最终结果展示3 完整的Matlab代码惯例声明:本人没有相…...
江西移动网站/广告公司职位
tidb在插入一个新数据的时候报错: Table has no partition for value xxx 表明表中没有这个分区,需要新增 查一下新增语句 ALTER TABLE fans_medal ADD PARTITION (PARTITION p20200828 VALUES LESS THAN (20200829));然后再插入我需要的数据 解决&…...
资料网站怎么做/代推广app下载
2019独角兽企业重金招聘Python工程师标准>>> 伟大的作家XXX曾经说过:1000个人便有1000个HDFS。 转载于:https://my.oschina.net/qiangzigege/blog/360239...
医疗美容网站模板/企业网站怎么注册官网
svg复用元素的方式主要有 <g>, <defs>, <symbol>, <use> 1. <g> group, 分组,定义一组元素,初始不可见 <g id"group" fill"red"><rect x"10" y"10" width"100&quo…...