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

地图客户端

地图客户端是用来显示地图和实现交互的,采用的技术和实现的方式多种多样,有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的效果图:
C#打造一个开源webgis(四)地图客户端(上)_第1张图片
silverlight实现

C#打造一个开源webgis(四)地图客户端(上)_第2张图片
wpf实现

怎么实现的呢,步骤如下:
1、免费注册arcgis开发者,下载Arcgis api for silverlight的SDK(我顺便下载了Arcgis api for WPF的SDK),其实所谓的SDK,只要得到几个DLL就行了,只要别人有了,直接拷贝过来引用就可以了。 注:若不喜欢,完全可以用DeepEarth来代替
C#打造一个开源webgis(四)地图客户端(上)_第3张图片
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>



你可能感兴趣的:(C#打造一个开源webgis(四)地图客户端(上))