当前位置: 首页 > news >正文

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实现要素坐标转换:平移、缩放、旋转(批量处理)

在二维坐标系统中&#xff0c;常见转换坐标&#xff1a;平移、缩放、旋转。在ArcGIS中可以通过工具实现移动 、旋转 和缩放&#xff0c;具体操作如下&#xff1a; &#xff08;1&#xff09;移动要素&#xff1a;可通过指针或指定值以交互方式操作所选要素。移动要素&#xf…...

Redis: 主从复制原理

主从复制原理剖析 1 &#xff09;配置 通过下面的从节点的配置项可以开启主从之间的复制功能slaveof 192.16.10.101 6379这里的复制包含全量复制和增量复制 2 &#xff09;主节点的主从配置信息解析 查看主从之间的信息&#xff0c;在主节点上 $ info replication 打印出来的…...

PostgreSQL 向量扩展插件pgvector安装和使用

文章目录 PostgreSQL 向量扩展插件pgvector安装和使用安装postgresqlpgvector下载和安装安装错误调试错误调试1尝试解决 AP1 &#xff1a;启动postgresql 错误调试2尝试解决 AP2 : 使用apt-get install postgresql-server 错误调试3尝试解决 AP3 &#xff1a;卸载apt-get 安装 …...

【论文阅读】基于真实数据感知的模型功能窃取攻击

摘要 目的 模型功能窃取攻击是人工智能安全领域的核心问题之一&#xff0c;目的是利用有限的与目标模型有关的信息训练出性能接近的克隆模型&#xff0c;从而实现模型的功能窃取。针对此类问题&#xff0c;一类经典的工作是基于生成模型的方法&#xff0c;这类方法利用生成器…...

线程池:线程池的实现 | 日志

&#x1f308;个人主页&#xff1a; 南桥几晴秋 &#x1f308;C专栏&#xff1a; 南桥谈C &#x1f308;C语言专栏&#xff1a; C语言学习系列 &#x1f308;Linux学习专栏&#xff1a; 南桥谈Linux &#x1f308;数据结构学习专栏&#xff1a; 数据结构杂谈 &#x1f308;数据…...

海信和TCL雷鸟智能电视的体验

买了型号为32E2F(9008)的海信智能的电视有一段时间了&#xff0c;要使用这个智能电视还真能考验你的智商。海信电视有很多优点&#xff0c;它的屏幕比较靓丽&#xff0c;色彩好看&#xff0c;遥控器不用对着屏幕就能操作。但也有不少缺点。 1. 海信智能电视会强迫自动更新操作…...

自动化学习3:日志记录及测试报告的生成--自动化框架搭建

一.日志记录 1.配置文件pytest.ini&#xff1a;将日志写入文件方便日后查询或查看执行信息。 需要将文件处理器&#xff08;文件存放位置/时间/格式等等&#xff09;添加到配置文件中的【日志记录器】 # pytest.ini [pytest] # ---------------日志文件&#xff0c;需要配合…...

【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是一个广泛使用的开源关系型数据库管理系统&#xff08;RDBMS&#xff09;&#xff0c;它基于SQL&#xff08;Structured Query Language&#xff09;进行操作。MySQL是由瑞典MySQL AB公司开发的&#xff0c;后来被Sun Microsystems收购&#xff0c;最终成为…...

在java后端发送HTTPClient请求

简介 HttpClient遵循http协议的客户端编程工具包支持最新的http协议 部分依赖自动传递依赖了HttpClient的jar包 明明项目中没有引入 HttpClient 的Maven坐标&#xff0c;但是却可以直接使用HttpClient原因是&#xff1a;阿里云的sdk依赖中传递依赖了HttpClient的jar包 发送get请…...

【STM32单片机_(HAL库)】4-3-2【定时器TIM】测量按键按下时间1——编程实现捕获功能

测量按键按下时长思路 测量按键按下时间实验目的 使用定时器 2 通道 2 来捕获按键 &#xff08;按键接PA0&#xff09;按下时间&#xff0c;并通过串口打印。 计一个数的时间&#xff1a;1us&#xff0c;PSC71&#xff0c;ARR65535 下降沿捕获、输入通道 2 映射在 TI2 上、不分…...

MySQL:2059 - Authentication plugin ‘caching_sha2_password‘ cannot be loaded

关于MySQL 客户端在尝试连接到 MySQL 服务器时报错&#xff1a;“2059 - Authentication plugin caching_sha2_password cannot be loaded”&#xff0c;具体是由于 MySQL 服务器默认使用的 caching_sha2_password 认证插件无法加载或不被当前客户端支持。 错误原因 MySQL 8.0…...

【JavaSE】反射、枚举、lambda表达式

目录 反射反射相关类获取类中属性相关方法常用获得类相关的方法示例常用获得类中属性相关的方法示例获得类中注解相关的方法 反射优缺点 枚举常用方法优缺点 枚举与反射lambda表达式语法函数式接口简化规则使用示例变量捕获集合中的应用优缺点 反射 Java的反射&#xff08;refl…...

P3227 [HNOI2013] 切糕

题意: n ∗ m n*m n∗m的矩阵,每个点可以选择一个值 a i , j k a_{i,j}k ai,j​k,然后你能获得 w ( i , j , k ) w(i,j,k) w(i,j,k)的得分&#xff0c;但是相邻两点之间的差值有限制&#xff0c;让你求最大得分。 考虑最小割。 每个点 ( i , j ) (i,j) (i,j)弄出一条长为 R…...

超分服务的分量保存

分量说明 分量的概念主要是对于显卡解码&#xff0c;编码和网络传输而言&#xff0c;显卡可以同时进行几个线程&#xff0c;多个显卡可以分布式计算&#xff0c;对分量进行AI识别&#xff0c;比如我们有cuda的显卡&#xff0c;cuda的核心量可以分给不同的分片视频&#xff0c;第…...

Windows11系统下SkyWalking环境搭建教程

目录 前言SkyWalking简介SkyWalking下载Agent监控实现启动配置SkyWalking启动Java应用程序启动Elasticsearch安装总结 前言 本文为博主在项目环境搭建时记录的SkyWalking安装流程&#xff0c;希望对大家能够有所帮助&#xff0c;不足之处欢迎批评指正&#x1f91d;&#x1f91…...

前端BOM常用操作

BOM操作常用命令详解及代码案例 BOM&#xff08;Browser Object Model&#xff09;是浏览器对象模型&#xff0c;是浏览器提供的JavaScript操作浏览器的API。BOM提供了与网页无关的浏览器的功能对象&#xff0c;虽然没有正式的标准&#xff0c;但现代浏览器已经几乎实现了Java…...

【Go】-viper库的使用

目录 viper简介 viper使用 通过viper.Set设置值 读取配置文件说明 读取配置文件 读取多个配置文件 读取配置项的值 读取命令行的值 io.Reader中读取值 写配置文件 WriteConfig() 和 SafeWriteConfig() 区别: viper简介 配置管理解析库&#xff0c;是由大神 Steve Fr…...

JavaWeb酒店管理系统(详细版)

✅作者简介&#xff1a;2022年博客新星 第八。热爱国学的Java后端开发者&#xff0c;修心和技术同步精进。 &#x1f34e;个人主页&#xff1a;Java Fans的博客 &#x1f34a;个人信条&#xff1a;不迁怒&#xff0c;不贰过。小知识&#xff0c;大智慧。 &#x1f49e;当前专栏…...

C++ | 定长内存池 | 对象池

文章目录 C | 定长内存池 | 对象池一、内存池的引入二、代码中的内存池实现 - ObjectPool类&#xff08;一&#xff09;整体结构&#xff08;二&#xff09;内存分配 - New函数&#xff08;三&#xff09;内存回收 - Delete函数 三、内存池在TreeNode示例中的性能测试演示四、脱…...

Linux 文件类型,目录与路径,文件与目录管理

文件类型 后面的字符表示文件类型标志 普通文件&#xff1a;-&#xff08;纯文本文件&#xff0c;二进制文件&#xff0c;数据格式文件&#xff09; 如文本文件、图片、程序文件等。 目录文件&#xff1a;d&#xff08;directory&#xff09; 用来存放其他文件或子目录。 设备…...

Unity3D中Gfx.WaitForPresent优化方案

前言 在Unity中&#xff0c;Gfx.WaitForPresent占用CPU过高通常表示主线程在等待GPU完成渲染&#xff08;即CPU被阻塞&#xff09;&#xff0c;这表明存在GPU瓶颈或垂直同步/帧率设置问题。以下是系统的优化方案&#xff1a; 对惹&#xff0c;这里有一个游戏开发交流小组&…...

前端倒计时误差!

提示:记录工作中遇到的需求及解决办法 文章目录 前言一、误差从何而来?二、五大解决方案1. 动态校准法(基础版)2. Web Worker 计时3. 服务器时间同步4. Performance API 高精度计时5. 页面可见性API优化三、生产环境最佳实践四、终极解决方案架构前言 前几天听说公司某个项…...

线程同步:确保多线程程序的安全与高效!

全文目录&#xff1a; 开篇语前序前言第一部分&#xff1a;线程同步的概念与问题1.1 线程同步的概念1.2 线程同步的问题1.3 线程同步的解决方案 第二部分&#xff1a;synchronized关键字的使用2.1 使用 synchronized修饰方法2.2 使用 synchronized修饰代码块 第三部分&#xff…...

【网络安全产品大调研系列】2. 体验漏洞扫描

前言 2023 年漏洞扫描服务市场规模预计为 3.06&#xff08;十亿美元&#xff09;。漏洞扫描服务市场行业预计将从 2024 年的 3.48&#xff08;十亿美元&#xff09;增长到 2032 年的 9.54&#xff08;十亿美元&#xff09;。预测期内漏洞扫描服务市场 CAGR&#xff08;增长率&…...

基于数字孪生的水厂可视化平台建设:架构与实践

分享大纲&#xff1a; 1、数字孪生水厂可视化平台建设背景 2、数字孪生水厂可视化平台建设架构 3、数字孪生水厂可视化平台建设成效 近几年&#xff0c;数字孪生水厂的建设开展的如火如荼。作为提升水厂管理效率、优化资源的调度手段&#xff0c;基于数字孪生的水厂可视化平台的…...

Keil 中设置 STM32 Flash 和 RAM 地址详解

文章目录 Keil 中设置 STM32 Flash 和 RAM 地址详解一、Flash 和 RAM 配置界面(Target 选项卡)1. IROM1(用于配置 Flash)2. IRAM1(用于配置 RAM)二、链接器设置界面(Linker 选项卡)1. 勾选“Use Memory Layout from Target Dialog”2. 查看链接器参数(如果没有勾选上面…...

拉力测试cuda pytorch 把 4070显卡拉满

import torch import timedef stress_test_gpu(matrix_size16384, duration300):"""对GPU进行压力测试&#xff0c;通过持续的矩阵乘法来最大化GPU利用率参数:matrix_size: 矩阵维度大小&#xff0c;增大可提高计算复杂度duration: 测试持续时间&#xff08;秒&…...

Mysql中select查询语句的执行过程

目录 1、介绍 1.1、组件介绍 1.2、Sql执行顺序 2、执行流程 2.1. 连接与认证 2.2. 查询缓存 2.3. 语法解析&#xff08;Parser&#xff09; 2.4、执行sql 1. 预处理&#xff08;Preprocessor&#xff09; 2. 查询优化器&#xff08;Optimizer&#xff09; 3. 执行器…...

Chromium 136 编译指南 Windows篇:depot_tools 配置与源码获取(二)

引言 工欲善其事&#xff0c;必先利其器。在完成了 Visual Studio 2022 和 Windows SDK 的安装后&#xff0c;我们即将接触到 Chromium 开发生态中最核心的工具——depot_tools。这个由 Google 精心打造的工具集&#xff0c;就像是连接开发者与 Chromium 庞大代码库的智能桥梁…...