Openlayers中的比例尺(scale)和分辨率(resolution)

转自:http://blog.csdn.net/dazhi_1314/archive/2010/08/05/5790506.aspx

 

今天研究了一下Openlayers中的比例尺(scale)和分辨率(resolution),弄懂了一些以前不太懂的东西。


一、首先阐明几个概念:
1、Scale:比例尺,图上距离和实地距离之比。
2、Resolution:分辨率,每个象元代表的实地距离(map units per pixels)。
3、Extent:地图的范围(地图四至)。
4、zoomlevel:缩放的级别(0~15)。
注:因为这几个变量均为对”地图显示“的量化描述,因此均有最大和最小值。
5、map,baselayer:map即地图,其size也是决定显示的因素。baselayer相当于一个地图中的底图,许多尺度变换函数均在baselayer类中实现,所以map中必须添加baselayer。
在Openlayers中如要正确显示一副地图,则上面的变量必须要正确设置,但不一定全部设置,全部设置,计算不正确的话可能导致冲突。可选择设置部分,其余由Openlayers自动计算。
二、scale 和 Resolution 的相互转化。
按照Openlayers中的概念,分比率是比较好计算的,比如直接取地图实际宽度(或高度)和地图div(以像素为单位)大小之比,就得到了该缩放级别下的分辨率。假设:地图单位是米,在某个缩放级别L下的分辨率为R,如何得到该缩放级别L的比例尺?
Scale是图上距离和实地距离之比,现在我们有的是地图的 屏幕距离(以像素为单位),实地距离和分辨率 ,很显然,我们只要得到 图上距离 即可。问题转化为如何由 屏幕距离+分辨率,求图上距离 。 解决问题的关键是dpi, dots per inches,or pixels per inches。Openlayers假定其接受的地图图片均为72dpi,即72的像素点有一英寸的长度,即屏幕上的地图图片中,72个像素点就是一英寸 的长度。现在问题基本上有头绪了,就屏幕距离(像素为单位)通过72dpi这个值,转换为图上距离。假设屏幕距离为P,分辨率为R,则比例尺S为:

实地距离: R * P
图上距离: (P / 72) / 39.3701 = P / (72*39.3701)    
比例尺: S =  P / (72*39.3701)  / R*P   = 1 /  R*72*32.3701
39.3701是inches和米的对应关系 。Openlayers专有对象定义了这样的对应关系,为的就是能对于不同投影,不同单位的地图得到一个大概的比例尺。
OpenLayers.INCHES_PER_UNIT =
 { 
 'inches': 1.0, 
 'ft': 12.0,
 'mi': 63360.0, 
  'm': 39.3701, 
 'km': 39370.1, 
 'dd': 4374754,
 'yd': 36 };
Openlayers中也有这个一个定义:OpenLayers.DOTS_PER_INCH = 72;即前文中提到的dpi。
当然由Scale反算Resolution也很简单,关键是要知道单位,Units。
讲的不太明白,可能我也只是弄懂了Scale和Resolution,对于Zoom,zoomlevel,exten,scale,Resolution之间的关系,我也还有一点模糊,准备再学习一下。如果有人想了解一下,可以看 这里 ,也可以直接研究Openlayers的源码,那样会更有收获些。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
OpenLayers比例尺是通过计算视图心点的分辨率来得到的。在构造ol.control.ScaleLine对象时,会动态创建一个包含比例尺信息的div元素。比例尺的具体显示内容和样式可以通过设置相应的CSS来控制。在OpenLayers地图添加比例尺控件时,需要在HTML页面创建一个用于作为比例尺容器的div标签,并将其与地图容器一同放置在body。通过合理设置比例尺容器的样式,可以使比例尺在地图上显示为期望的位置和样式。根据地图视图的设置和当前地图缩放级别,OpenLayers会自动计算并更新比例尺的显示值和样式。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [openlayers比例尺的计算原理](https://blog.csdn.net/u013240519/article/details/84136793)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [Openlayers学习之地图比例尺控件](https://download.csdn.net/download/weixin_38660051/14663633)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值