`
holoblog
  • 浏览: 1270454 次
博客专栏
E0fcf0b7-6756-3051-9a54-90b4324c9940
SQL Server 20...
浏览量:19636
文章分类
社区版块
存档分类
最新评论

GeoServer地图开发解决方案(五):基于Silverlight技术的地图客户端实现

 
阅读更多

  GeoServer 是 OpenGIS Web 服务器规范的 J2EE 实现的社区开源项目,利用 GeoServer 可以方便的发布地图数据,允许用户对特征数据进行更新、删除、插入操作,通过 GeoServer 可以比较容易的在用户之间迅速共享空间地理信息。本系列博文提供全面、完善的GeoServer部署解决方案,包括GeoServer环境搭建、地图数据处理、部署地图数据、发布地图服务等功能的详细介绍。文中内容来自本人工作中通过网络学习后总结而成,如有类同纯属巧合,同时欢迎广大网友前来交流。  

          

        

  系列目录导航:

  GeoServer地图开发解决方案(一):环境搭建篇

  GeoServer地图开发解决方案(二):地图数据处理篇

  GeoServer地图开发解决方案(三):部署地图数据篇

  GeoServer地图开发解决方案(四):发布Web地图服务(WMS)篇

  GeoServer地图开发解决方案(五):基于Silverlight技术的地图客户端实现

  我曾经写作过一篇关于微软Bing Maps的客户端实现的博文:《基于DeepZoom技术的Bing Maps客户端实现研究》,详细介绍了如何使用Silverlight中的DeepZoom技术实现Bing Maps的客户端。本篇介绍的内容则为基于Web地图服务(Web Map Service,简称:WMS)的Silverlight地图客户端实现。

一、DeepZoom简介

  DeepZoom技术以MultiScaleImage控件为核心,其内部有一个MultiScaleTileSource类型的源属性,主要用于设置MultiScaleImage控件所要呈现的数据源。基于Silverlight的Web GIS客户端实现也是通MultiScaleImage控件来实现,核心就在于通过MultiScaleTileSource属性针对不同的Web GIS地图瓦片数据(Image Tiles)提供商为MultiScaleImage控件实现一个数据源。因此本篇所需要做的工作就是针对WMS服务为MultiScaleImage控件实现一套加载数据源的算法。

二、WMS服务加载实现

  实现WMS服务加载的算法其实非常简单,只需要了解WMS发布的方式、WMS地址的参数组成结构以及地图瓦片的投影原理就可以了,首先需要定义一个盒子对象作为访问WMS的边界参数对象。

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />-->publicclassBBox
{
publicintX{get;set;}
publicintY{get;set;}
publicintWidth{get;set;}
publicintHeight{get;set;}

publicBBox(intx,inty,intw,inth)
{
this.X=x;
this.Y=y;
this.Width=w;
this.Height=h;
}
}

  关于WMS服务加载的详细算法需要一些GIS理论基础才能够知道具体的实现原理,这里我就不逐一介绍,直接贴代码:

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />-->publicclassWMSTileSource:MultiScaleTileSource
{
publicWMSTileSource()
:
base(int.MaxValue,int.MaxValue,0x100,0x100,0)
{}

publicconstintTILE_SIZE=256;
///<summary>
///地球半径
///</summary>
publicconstdoubleEARTH_RADIUS=6378137;
///<summary>
///地球周长
///</summary>
publicconstdoubleEARTH_CIRCUMFERENCE=EARTH_RADIUS*2*Math.PI;
publicconstdoubleHALF_EARTH_CIRCUMFERENCE=EARTH_CIRCUMFERENCE/2;

///<summary>
///WMS服务地址
///</summary>
privateconststringTilePath=@"http://localhost:8080/geoserver/wms?service=WMS&version=1.1.0&request=GetMap&layers=cq:CQ_County_region,cq:CQ_County_region_level&styles=&bbox={0},{1},{2},{3}&width=512&height=421&srs=EPSG:4326&&Format=image/png";

publicstringGetQuadKey(stringurl)
{
varregex
=newRegex(".*tiles/(.+)[.].*");
Matchmatch
=regex.Match(url);

returnmatch.Groups[1].ToString();
}

publicBBoxQuadKeyToBBox(stringquadKey,intx,inty,intzoomLevel)
{
charc=quadKey[0];

inttileSize=2<<(18-zoomLevel-1);

if(c=='0')
{
y
=y-tileSize;
}

elseif(c=='1')
{
y
=y-tileSize;
x
=x+tileSize;
}

elseif(c=='3')
{
x
=x+tileSize;
}

if(quadKey.Length>1)
{
returnQuadKeyToBBox(quadKey.Substring(1),x,y,zoomLevel+1);
}
returnnewBBox(x,y,tileSize,tileSize);
}

publicBBoxQuadKeyToBBox(stringquadKey)
{
constintx=0;
constinty=262144;
returnQuadKeyToBBox(quadKey,x,y,1);
}

publicdoubleXToLongitudeAtZoom(intx,intzoom)
{
doublearc=EARTH_CIRCUMFERENCE/((1<<zoom)*TILE_SIZE);
doublemetersX=(x*arc)-HALF_EARTH_CIRCUMFERENCE;
doubleresult=RadToDeg(metersX/EARTH_RADIUS);
returnresult;
}

publicdoubleYToLatitudeAtZoom(inty,intzoom)
{
doublearc=EARTH_CIRCUMFERENCE/((1<<zoom)*TILE_SIZE);
doublemetersY=HALF_EARTH_CIRCUMFERENCE-(y*arc);
doublea=Math.Exp(metersY*2/EARTH_RADIUS);
doubleresult=RadToDeg(Math.Asin((a-1)/(a+1)));
returnresult;
}

publicdoubleRadToDeg(doubled)
{
returnd/Math.PI*180.0;
}

privatestaticstringTileXYToQuadKey(inttileX,inttileY,intlevelOfDetail)
{
varquadKey
=newStringBuilder();
for(inti=levelOfDetail;i>0;i--)
{
chardigit='0';
intmask=1<<(i-1);
if((tileX&mask)!=0)
{
digit
++;
}
if((tileY&mask)!=0)
{
digit
++;
digit
++;
}
quadKey.Append(digit);
}
returnquadKey.ToString();
}

protectedoverridevoidGetTileLayers(inttileLevel,inttilePositionX,inttilePositionY,System.Collections.Generic.IList<object>tileImageLayerSources)
{
intzoom=tileLevel-8;
if(zoom>0)
{
stringquadKey=TileXYToQuadKey(tilePositionX,tilePositionY,zoom);
BBoxboundingBox
=QuadKeyToBBox(quadKey);

doublelon=XToLongitudeAtZoom(boundingBox.X*TILE_SIZE,18);
doublelat=YToLatitudeAtZoom(boundingBox.Y*TILE_SIZE,18);

doublelon2=XToLongitudeAtZoom((boundingBox.X+boundingBox.Width)*TILE_SIZE,18);
doublelat2=YToLatitudeAtZoom((boundingBox.Y-boundingBox.Height)*TILE_SIZE,18);

stringwmsUrl=string.Format(TilePath,lon,lat,lon2,lat2,TILE_SIZE);

varveUri
=newUri(wmsUrl);
tileImageLayerSources.Add(veUri);
}
}
}

  前端通过一个按钮事件驱动触发加载WMS服务,按钮的XAML代码如下:

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--><ButtonContent="WMS图层"Height="30"Width="80"Name="btnWms"Click="btnWms_Click"/>

  示例我就直接基于《基于DeepZoom技术的Bing Maps客户端实现研究》一文中的示例扩展,对应的后台代码为如下代码块:

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />-->privatevoidbtnWms_Click(objectsender,RoutedEventArgse)
{
msi.Source
=newWMSTileSource();
}

        

    

分享到:
评论

相关推荐

    GeoServer地图开发解决方案

    ### GeoServer地图开发解决方案 #### 一、GeoServer概述与环境搭建 GeoServer是一个开源的地理信息系统(GIS)服务器,遵循Open Geospatial Consortium (OGC)标准,提供了丰富的地图服务,包括WMS(Web Map Service...

    GeoServer地图开发解决方案.doc

    总的来说,GeoServer地图开发解决方案涉及了从环境搭建、地图数据处理到服务发布的全过程,旨在创建一个高效、可扩展的空间信息共享平台。通过这个解决方案,开发者和GIS专业人员可以轻松地将各种地理数据转换为可...

    Geoserver跨域问题解决方案

    在IT行业中,尤其是在Web开发领域,跨域问题是一个常见的挑战,尤其当涉及到GIS(地理信息系统)服务时,如Geoserver。Geoserver是一个开源的、基于Java的服务器,用于发布和管理地理空间数据。当从一个源(如浏览器...

    GeoServer 和GeoWebCache

    GeoServer地图开发解决方案.doc geoserver地图配置文档.docx geoserver显示中文.doc Geoserver中Postgis的应用入门.pdf geowebcache+wms配置.doc GeoWebCache配置.docx Oracle_Spatial_与geoserver,_Google_Earth_集

    地图服务器基于geoserver改造

    总结起来,"地图服务器基于geoserver改造"是一个将开源GeoServer与Tomcat结合的项目,旨在提供一个易于部署和使用的GIS服务。改造的核心在于利用Tomcat的便利性和GeoServer的强大功能,为用户提供一个高效、稳定的...

    geoserver 地图专题图

    【标题】"geoserver 地图专题图" 涉及的是使用Geoserver结合OpenLayers创建地图专题图的技术。地图专题图是地理信息系统(GIS)中的一个重要概念,它允许用户根据特定主题或变量来可视化地理数据。在这种情况下,...

    基于GeoServer的WebGIS开发.pdf

    标题:“基于GeoServer的WebGIS开发.pdf” 描述:“基于GeoServer的WebGIS开发.pdf” 标签:技术 知识点: 1. GeoServer简介 GeoServer是一个开源的服务器,它允许用户在互联网上发布和共享地理信息数据。它广泛...

    geoserver教程,很详细的一步步的教程

    1. 学习Silverlight基础:Silverlight是一种用于构建富互联网应用程序(RIA)的技术,它可以用来展示GeoServer发布的地图服务。 2. 创建Silverlight项目:使用Visual Studio等IDE创建一个新的Silverlight应用程序。 ...

    geoserver中文开发手册.zip_GeoServer 地图服务_geoserver_geoserver手册

    GeoServer 是 OpenGIS Web 服务器规范的 J2EE 实现,利用 GeoServer 可以方便的发布地图数据,允许用户对特征数据进行更新、删除、插入操作,通过 GeoServer 可以比较容易的在用户之间迅速共享空间地理信息。

    geoserver地图配置文档

    4. 下载 Geoserver:Geoserver 是一个基于开源的地图服务器,需要下载并安装 Geoserver。 5. 下载 PostgreSQL:PostgreSQL 是一个关系数据库管理系统,需要下载并安装 PostgreSQL。 6. 下载 PostGIS:PostGIS 是一个...

    GeoServer3D开发环境配置

    GeoServer3D 开发环境配置知识点 一、GeoServer3D 开发环境配置概述 GeoServer 是一个基于 Java 语言的开源地理空间数据服务器,提供了强大的地理空间数据管理和服务功能。为了进行 GeoServer 的二次开发,需要...

    GeoServer地图配置服务器客户端搭建

    GeoServer是一种开源的Java应用程序,专门用于发布地理空间数据,并且是Geospatial Server的一种实现,遵循开放地理空间联盟(OGC)的标准。本篇文章将深入探讨如何详细配置GeoServer并建立客户端,以便有效地管理和...

    GeoServer+OpenLayers发布下载的Google卫星影像

    GeoServer+OpenLayers 发布下载的 Google 卫星影像 GeoServer 是一个基于 Java 的开源地理信息系统(GIS),它可以提供...通过这篇文章,读者可以了解如何使用 GeoServer 和 OpenLayers 实现空间数据的发布和可视化。

    leaflet结合geoserver实现地图空间查询.zip

    GeoServer是一款基于Java开发的开源GIS服务器,遵循开放地理空间联盟(OGC)的标准,如WMS(Web Map Service)和WFS(Web Feature Service)。GeoServer能够发布和操作地理空间数据,使得用户可以通过网络进行查询、...

Global site tag (gtag.js) - Google Analytics