您的位置:首页 > 编程语言 > C#

C#打造一个开源webgis(四)地图客户端(上)

2013-10-16 22:38 453 查看

地图客户端

地图客户端是用来显示地图和实现交互的,采用的技术和实现的方式多种多样,有Flash,Silverlight,Javascript等等,此外,别忘了桌面客户端也属于其范畴。

而具体基于这些技术的第三方插件有很多,开源的有如DeepEarth、SharpMap、Gmap.net、Greatmap、OpenLayer,如果细心的话,会发现提及的大多基于.net技术的,没错,个人偏向所致吧,对比过基于Deepzoom实现及Javascript实现的地图效果后,我倾向于Deepzoom(Silverlight版地图基本采用),当然,如果说考虑到用户体验(要安装浏览器插件),用Javascript或许会是更好的选择。若了解原理,展现方式不同,内在其实也大同小异的。简单描述下,仅作为参考:SharpMap对于桌面应用更有名些,我对它最后一次了解也是很久之前了,现在不知道变成怎样了,它集成了很多开源项目,包括GDAL、.net版的JTS(NJTS)等,但是个人对其渲染效果和性能不怎么满意。DeepEarth是比较有名的webClient,渲染效果不错,但功能不足,需要自己开发定制很多GIS常用功能。Gmap.net貌似比较强大,就是参考资料太少。OpenLayers是基于Javascript的……有兴趣的可以了解一下……最后来个笔锋一转,会不会觉得很坑?——我用的是arccgis
api for silverlight,原因很简单,功能强大,足够我使用……

搭建DEMO

先来看看搭建Demo的效果图:



silverlight实现



wpf实现

怎么实现的呢,步骤如下:
1、免费注册arcgis开发者,下载Arcgis api for silverlight的SDK(我顺便下载了Arcgis api for WPF的SDK),其实所谓的SDK,只要得到几个DLL就行了,只要别人有了,直接拷贝过来引用就可以了。注:若不喜欢,完全可以用DeepEarth来代替



2、建一个silverlight的项目,把DLL引用进去,然后创建一个类GoogleMapLayer.cs,内容如下,代码比较好理解,也不写注释了。特别留意一下GetTileUrl方法,采用的url是网上google瓦片服务地址,注释掉的第一行url是本地缓存离线瓦片地图,第二行url是第三节提到过的geoserver提供的wms服务,也就是说可以根据需求定制自己的地图层。

public class GoogleRoadLayer : TiledMapServiceLayer
{
SpatialReference _spatialReference = new SpatialReference(102113);
public override void Initialize()
{
this.FullExtent = new Envelope(-20037508.342787, -20037508.342787, 20037508.342787, 20037508.342787)
{
SpatialReference = _spatialReference
};
this.SpatialReference = _spatialReference;
this.TileInfo = new TileInfo()
{
Height = 256,
Width = 256,
Origin = new MapPoint(-20037508.342787, 20037508.342787)//Origin = new ESRI.ArcGIS.Geometry.MapPoint(-180, 90)
{
SpatialReference = _spatialReference
},
Lods = new Lod[20]
};

double resolution = 156543.033928;
for (int i = 0; i < TileInfo.Lods.Length; i++)
{
TileInfo.Lods[i] = new Lod() { Resolution = resolution };
resolution /= 2;
}
base.Initialize();
}

public override string GetTileUrl(int level, int row, int col)
{
//设置默认值
string url = string.Format("http://mt{0}.google.cn/vt/lyrs=m@163000000&hl=zh-CN&gl=cn&x={1}&s=&y={2}&z={3}&s=", row % 4, col, row, level);
//string url = string.Format("http://192.168.4.164:8083/{2}/{0}_{1}.png", col, row, level);
//string url = string.Format("http://localhost:10100/geoserver/cq/wms?service=WMS&version=1.1.0&request=GetMap&layers=cq:landview&styles=&bbox={0},{1},{2},{3}&width=512&height=473&srs=EPSG:4326&format=image/png";
return url;
}
}


3、在MainPage.xaml(可以新建一个页面)的Grid标签,加入以下内容,至此一个拥有放大缩小、平移、滚轮支持的基本地图浏览程序就完成了

<esri:Map x:Name="map" Background="White"  WrapAround="true" IsLogoVisible="False" >
<esri:Map.Layers>
<esri:LayerCollection>
<local:GoogleRoadLayer ID="TileLayer"/>
</esri:LayerCollection>
</esri:Map.Layers>
</esri:Map>
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐