(转) GIS 中地理坐标和屏幕坐标的标准转换方法

简介:

在GIS中,当你拿到一个图层的地理坐标后,如果需要绘制到屏幕上,那么不可避免的需要在地理坐标和屏幕坐标之间进行转换,转换的方法相信每一个做GIS的都会有自己的实现方法,本文描述的是和ArcGIS、WMS、OpenLayers完全一致的坐标转换方法,当然这三个工具、标准、脚本也是采用的相同的方法;

因为采用完全一致的坐标转换方法,因此在我自己实现的WMS服务程序中提供的含透明通道的图,可以完全和ArcGIS提供的图在WEB客户端进行精确的匹配;

现在来介绍坐标转换的原理,其实该原理很简单,就是将视图的中心点和视野的中心点进行配对,然后给定一个地理坐标根据该坐标和视野中心点的偏移和比例尺来进行计算就可以获得屏幕坐标,反之亦然;

下面就是将窗口坐标转换为地理坐标的代码:

1
2
ptGeo.x = geo_center_.x + ( ptWnd.x - see_center_.x ) * resolution_ ;
ptGeo.y = geo_center_.y - ( ptWnd.y - see_center_.y ) * resolution_ ;

下面是将地理坐标转化为窗口坐标的代码:

1
2
ptWnd.x = see_center_.x + ( long )( ( ptGeo.x - geo_center_.x ) / resolution_ + 0.5 );
ptWnd.y = see_center_.y - ( long )( ( ptGeo.y - geo_center_.y ) / resolution_ + 0.5 );

在上面的代码中,see_center_ 是屏幕坐标的窗口中心、geo_center_ 是地理坐标的视野中心,而 resolution_ 就是当前的比例尺;

然而最关键的是,当传入的视野和窗口的比例不一致时,如何进行处理,标准的做法就是分别计算水平和垂直的比例尺,然后取其中较大的那个值作为比例尺,也就是说比例尺的调整向着地理视野更小的方向进行调整,参考如下的代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
void Coord_Transform::Reset_Resolution( GeoRect & extent , DevRect & client )
{
// calc geo_center_ Member
geo_center_.x = ( extent.left + extent.right ) / 2.0 ;
geo_center_.y = ( extent.top + extent.bottom ) / 2.0 ;
// calc see_center_ Member
see_center_.x = ( client.left + client.right ) / 2 ;
see_center_.y = ( client.top + client.bottom ) / 2 ;
// calc resolution_ Member
double RoH = extent.Height( ) / client.Height( ); // Resolution of Height
double RoW = extent.Width( ) / client.Width( ); // Resolution of Width
this ->resolution_ = RoH > RoW ? RoH : RoW ;
this ->geo_change_ = true ;
}

在 WMS 协议中,如果请求的图片大小和视野的宽高比不成比例时也是要求将图片较小的一边增加,让地理视野和图片的比例一致,然后进行绘制,最后一步将生成的图片进行不等比放缩到原始请求的图片大小,这是为了保证客户端采用非矩形点阵的显示设备时能够正常显示地理图;




本文转自94cool博客园博客,原文链接:http://www.cnblogs.com/94cool/p/3922441.html,如需转载请自行联系原作者

相关文章
|
9月前
|
定位技术
百度地图拾取经纬度转为标准GEOJSON格式的函数解决方案
百度地图拾取经纬度转为标准GEOJSON格式的函数解决方案
159 0
|
8月前
|
JavaScript 前端开发 关系型数据库
GIS开发:GeoJSON坐标和WKT的转换
GIS开发:GeoJSON坐标和WKT的转换
485 0
|
定位技术
Threejs实现绘制地球,地理位置标注、经纬度转换世界坐标threejs坐标
Threejs实现绘制地球,地理位置标注、经纬度转换世界坐标threejs坐标
1070 0
Threejs实现绘制地球,地理位置标注、经纬度转换世界坐标threejs坐标
|
2月前
|
图形学 计算机视觉
GEE错误——如何将原有矢量将维度转化为地理坐标系,重投影坐标坐标无法实现?
GEE错误——如何将原有矢量将维度转化为地理坐标系,重投影坐标坐标无法实现?
29 0
|
4月前
ArcGIS中ArcMap求取点要素在栅格图像中的行列号的方法
ArcGIS中ArcMap求取点要素在栅格图像中的行列号的方法
|
4月前
|
定位技术
ArcGIS批量计算图层中矢量要素面积——ArcMap
ArcGIS批量计算图层中矢量要素面积——ArcMap
|
4月前
|
Serverless 定位技术 Windows
ArcGIS中ArcMap快速自动计算单一波段或多波段栅格遥感影像NDVI的方法
ArcGIS中ArcMap快速自动计算单一波段或多波段栅格遥感影像NDVI的方法
|
9月前
|
存储
ArcGIS:模型构建器内变量的数据类型中栅格图层和栅格数据集的区别
ArcGIS:模型构建器内变量的数据类型中栅格图层和栅格数据集的区别
61 0
|
9月前
|
定位技术
ArcGIS:如何对栅格图像进行地理配准和定义投影?
ArcGIS:如何对栅格图像进行地理配准和定义投影?
755 0
qgis 将县区的数据转成市区的边界数据
在第一步的基础上,有了21个面,那么咱们可以对当前的面进行融合操作,生成一个面,也就是咱们需要的市区边界数据。
qgis 将县区的数据转成市区的边界数据