标题比较长,主要呢是实现以下几点:
1、将shp数据导入到PostGIS中;
2、Geoserver发布WMS服务;
3、Openlayers调用Wms服务
首先,下载安装软件。
为方便大家下载,我将所有软件上传的百度网盘里了,有需要的可以上网盘直接下载,地址为:http://pan.baIDu.com/s/1ntJrf8P,此外,openlayers的下载地址为:http://pan.baIDu.com/s/1kTBTCX5。
软件下载完成以后安装,如何安装在此就不做详述了,不过注意:postgresql-8.4.14-1-windows安装完成之后,Stack Builder直接取消,下载太慢,安装postgis-pg84-setup-2.0.3-1即可。
接着,将shp数据导入到PostGIS中。
将shp数据导入到PostGIS有两种方式:1、通过QGIS的辅助工具;2、通过cmd命令行。
1、通过Qgis辅助工具
打开QGIS——》打开辅助工具import Shapefiles to Postgresql
——》新建PostGIS连接
——》添加shp数据
注意:Schema类型选择public。
2、通过cmd命令行
通过cmd的方式比较简单,首先,进入命令窗口,切换到Postgresql的bin路径:
</pre><pre name="code" >cd C:\Program files (x86)\Postgresql.4\bin>将shp数据转换为SQL语句:
shp2pgsql D:\data\wgs84\mcounty.shp mcounty > D:\data\wgs84\mcounty.sql新建table并将数据导入:
psql -d opengis -f D:\data\wgs84\mcounty.sql postgres比较:
第一种 *** 作比较简单,但是, *** 作步骤比较多,但是第一种 *** 作在导入polyGON的时候会存在MulTIpolyGON或者polyGON的转化的不一致的问题,导致数据导入的不成功。
接着,在Geoserver中发布。
1、新建数据存储
在Geoserver中新建POSTGIS的数据存储
然后发布图层:
图层发布完成之后转到图层预览,以openlayers的方式打开:
当你看到这个图的时候,就说明你的服务已经发布成功了!
接下来就是用Openlayers调用显示,
<HTML xmlns="http://www.w3.org/1999/xhtml"><head><Meta http-equiv="Content-Type" content="text/HTML; charset=utf-8" /><Title>china epsg:4326 image/png</Title><link rel="stylesheet" type="text/CSS" href="http://200.200.200.223/OpenLayers-2.12/theme/default/style.CSS"/><style type="text/CSS"> body { Font-family: sans-serif; Font-weight: bold; Font-size: .8em; } body { border: 0px; margin: 0px; padding: 0px; } #map { wIDth: 100%; height: 100%; border: 0px; padding: 0px; } #nodeList{ position:absolute; right:10px; top:10px; background:#FFF; border:#06F solID 2px; padding:5px; }</style><script type="text/JavaScript" src="http://200.200.200.223/OpenLayers-2.12/OpenLayers.Js"></script><script type="text/JavaScript" src="http://200.200.200.223/OpenLayers-2.12/lib/OpenLayers/Lang/zh-CN.Js"></script><script type="text/JavaScript"> var map,demolayer; OpenLayers.DOTS_PER_INCH = 90.71428571428572; OpenLayers.Util.onImageLoadErrorcolor = 'transparent'; function init(){ var mapOptions = { resolutions: [0.703125,0.3515625,0.17578125,0.087890625,0.0439453125,0.02197265625,0.010986328125,0.0054931640625,0.00274658203125,0.001373291015625,6.866455078125E-4,3.4332275390625E-4,1.71661376953125E-4,8.58306884765625E-5,4.291534423828125E-5,2.1457672119140625E-5,1.0728836059570312E-5,5.364418029785156E-6,2.682209014892578E-6,1.341104507446289E-6,6.705522537231445E-7,3.3527612686157227E-7 ],projection: new OpenLayers.Projection('epsg:4326'),maxExtent: new OpenLayers.Bounds(-180.0,-90.0,180.0,90.0),units: "degrees",controls: [] }; map = new OpenLayers.Map('map',mapOptions ); map.addControl(new OpenLayers.Control.PanZoombar({ position: new OpenLayers.Pixel(2,15) })); map.addControl(new OpenLayers.Control.Navigation()); map.addControl(new OpenLayers.Control.Scale($('scale'))); map.addControl(new OpenLayers.Control.Mouseposition({element: $('location')})); var wms = new OpenLayers.Layer.WMS( "lake","http://200.200.200.223:8888/geoserver/wms",{ LAYERS: "mpro",transparent:true },{ singleTile: false,ratio: 1,isBaseLayer: false,visibility:true,yx : {'epsg:4326' : true} } ); map.addLayer(wms); map.zoomToExtent(new OpenLayers.Bounds(73.45100463600005,18.16324718800007,134.976797647,53.53194315200005) ); map.events.register('click',map,function (e) { console.log(e); }); }</script></head><body onLoad="init()"> <div ID="map"></div></body></HTML>
如有疑问,请联系:
QQ:1004740957
Email:niujp08@qq.com
总结以上是内存溢出为你收集整理的PostGIS+QGIS+GeoServer+OpenLayers实现数据的存储、服务的发布以及地图的显示全部内容,希望文章能够帮你解决PostGIS+QGIS+GeoServer+OpenLayers实现数据的存储、服务的发布以及地图的显示所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)