OpenLayers访问本地瓦片地图

WMS无非就是通过http请求参数来获取瓦片,因此将常规的WMS请求改为对php页面的请求即可实现对本地图片的访问, 例如原来的WMS层代码这样写

layer = new OpenLayers.Layer.WMS( "OpenLayers WMS","http://vmap0.tiles.osgeo.org/wms/vmap0", {layers: 'basic'} );

现在将请求地址变更为php文件地址 

layer = new OpenLayers.Layer.WMS( "卫星本地","picwms.php", {layers: 's'} );

 picwms.php文件用来解析OpenLayers通过wms接口发送的http请求串,返回对应编号的瓦片即可。

例如一个瓦片的WMS请求串为

http://www.daogle.com/map/picwms.php?LAYERS=s&SERVICE=WMS&VERSION=1.1.1&REQUEST=GetMap&STYLES=&EXCEPTIONS=application%2Fvnd.ogc.se_inimage&FORMAT=image%2Fjpeg&SRS=EPSG%3A4326&BBOX=90,90,180,180&WIDTH=256&HEIGHT=256

 经过picwms.php通过对其url参数的解析后,反馈对应的瓦片如下:

http://www.daogle.com/map/data/s/2/s_2_3_1.jpg

5、php脚本说明

picwms.php的代码则非常明确和简单,通过解析url参数中的经纬度,地图类型等,反馈对应的瓦片文件地址即可,具体内容在此不再详叙。

后来不少朋友问我这个解析的代码,我将此代码帖在这里,图源是我用的“稻歌Google Map截获器”工具截取的。

复制代码
// 获取参数
$qstr =  $_SERVER["QUERY_STRING"];
$arr1 =  explode("&", $qstr);
$item1 =  explode("=", $arr1[0]); // LAYERS
$item2 =  explode("=", $arr1[8]); // xy范围

$mapStyle =  $item1[1];

$item3 =  explode(",", $item2[1]);

$xMin = ( float) $item3[0];
$yMin = ( float) $item3[1];
$xMax = ( float) $item3[2];
$yMax = ( float) $item3[3];

// 获取级别
$zoom = (int)(  Log( 360/( $xMax -  $xMin) ) /  Log(2));

// 获得编号
$xBian = ( string)((int)(( $xMin + 180) / ( $xMax -  $xMin)));
$yBian = ( string)((int)((270 -  $yMax) / ( $xMax -  $xMin)));


$picName =  "data/" .  $mapStyle . "/" .  $zoom . "/" .  $mapStyle . "_" . ( string) $zoom . "_" .  $xBian . "_" .  $yBian;
if( $mapStyle == "s")
{
     $picName =  $picName . ".jpg";
}
else  if( $mapStyle == "m")
{
     $picName =  $picName . ".png";
}

// 如果瓦片不存在,反馈错误提示瓦片
if( is_file( $picName) ==  false)
{
     $picName = "data/error.jpg";
}

// 重定向瓦片文件 , $picName即为反馈的瓦片文件url地址
Header("Location: $picName"); 
?>
复制代码

 

6、坐标与投影的说明:

Openlayers默认的坐标系为经纬网,所以大部分采用Openlayers的webgis都采用的是地理经纬网坐标地图切的瓦片,天地图也是如此,这么做的好处是可以在客户端直接算出地图上任意一点的经纬度坐标,但是其形变太大,尤其是角度变形失真严重,所以天地图相比Google Map,尤其是在显示街道地图时失真有些严重,街道方向不准,而Google Map所采用的EPSG:3785投影(或称EPSG:900913)则没有角度变形。

在我的地图案例中,则鼠标显示的是Google Map投影坐标系下的坐标,当然这个是采用变通的办法实现的。Google Map的地图范围是一个正方形,而OpenLayers经纬网默认的地图范围是一个x:y为2:1的矩形,因此为了显示Google Map瓦片,我先将OpenLayers的地图范围改为:

map.maxExtent = new OpenLayers.Bounds(-180, -90, 180, 270);

这样就刚好是一个正方形了,同时,其瓦片数目、显示级别也与Google Map对应了起来。然后picwms.php解析wms请求时,通过经纬度范围算出瓦片编号,再映射瓦片文件命名,然后返回图片即可。

另外,实时显示地图上鼠标的坐标也是一个映射关系:

//获取Map上鼠标位置的经纬度(非真实坐标)
var lonlat = map.getLonLatFromViewPortPx(e.xy);
var x0 = lonlat.lon;//经度
var y0 = lonlat.lat;//纬度
//转换成Google投影坐标,单位为m
//从范围-180, -90, 180, 270转换到Google投影坐标系 //Google投影上边界20037508.343 m //x坐标,单位m var x1 = 20037508.343 * 2 * ( x0 + 180 ) / 360 - 20037508.343; //y坐标,单位m var y1 = 20037508.343 * 2 * ( y0 + 90 ) / 360 - 20037508.343; //地图像素分辨率,单位m/像素 var pixelResolution = 156543.033929687/ Math.pow(2,map.getZoom());

你可能感兴趣的:(GIS)