赞
踩
1.官网:http://openlayers.org/
在官网首页上,即可看到相关的介绍,文档,API,以及Examples链接
2.好的中文网站
http://anzhihun.coding.me/ol3-primer/ch01/index.html
3.简介
OpenLayers 3简称ol3,它是一个开源的Web GIS引擎,使用了JavaScript、最新的HTML5技术及CSS技术,支持dom
,canvas
和webgl
三种渲染方式。除了支持网页端,还支持移动端(目前移动端还不成熟,有待进一步完善)。在地图数据源方面,支持各种类型的瓦片地图,既支持在线的,也支持离线的。比如OSM, Bing, MapBox, Stamen, MapQuest等等;还支持各种矢量地图,比如GeoJSON,TopoJSON,KML,GML等等。随着OpenLayers 3的进一步发展,将支持更多的地图类型。
不兼容ol2,采用全新的架构,使用方式及API都不一样,只是在功能上完全实现OpenLayers 2已有的功能,
4.加载地图练习
加载简单地图
- <!Doctype html>
- <html xmlns=http://www.w3.org/1999/xhtml>
- <head>
- <meta http-equiv=Content-Type content="text/html;charset=utf-8">
- <meta http-equiv=X-UA-Compatible content="IE=edge,chrome=1">
- <meta content=always name=referrer>
- <title>OpenLayers 3地图示例</title>
- <link href="../ol3.13.1/ol.css" rel="stylesheet" type="text/css" />
- <script type="text/javascript" src="../src/ol3.13.1/ol.js" charset="utf-8"></script>
- </head>
-
- <body>
- <div id="map" style="width: 100%"></div>
- <script>
- // 创建地图
- new ol.Map({
- // 设置地图图层
- layers: [
- // 创建一个使用Open Street Map地图源的瓦片图层
- source: new ol.source.OSM({
- wrapX : false //使地图横向只出现一个
- })
- ],
- // 设置显示地图的视图
- view: new ol.View({
- center: [0, 0], // 定义地图显示中心于经度0度,纬度0度处
- zoom: 2 // 并且定义地图显示层级为2
- }),
- // 让id为map的div作为地图的容器
- target: 'map'
- });
- </script>
- </body>
-
- </html>
wrapX : false //使地图横向只出现一个
})
],
// 设置显示地图的视图
view: new ol.View({
center: [0, 0], // 定义地图显示中心于经度0度,纬度0度处
zoom: 2 // 并且定义地图显示层级为2
}),
// 让id为map的div作为地图的容器
target: 'map'
});
</script>
</body>
</html>
要想使用OpenLayers 3开发地图,首先你需要引入了OpenLayers 3的js库文件ol3.js及样式文件ol3.css,参见代码中html头部
加载百度地图
- <!DOCTYPE html>
- <html>
- <head>
- <title>Image ArcGIS MapServer</title>
- <link rel="stylesheet" href="https://openlayers.org/en/v4.6.4/css/ol.css" type="text/css">
- <!-- The line below is only needed for old environments like Internet Explorer and Android 4.x -->
- <script src="https://cdn.polyfill.io/v2/polyfill.min.js?features=requestAnimationFrame,Element.prototype.classList,URL"></script>
- <script src="https://openlayers.org/en/v4.6.4/build/ol.js"></script>
- </head>
- <body>
- <div id="baiduMap2" style="width: 100%"></div>
- <script>
-
- // 自定义分辨率和瓦片坐标系
- var resolutions = [];
- var maxZoom = 18;
-
- // 计算百度使用的分辨率
- for(var i=0; i<=maxZoom; i++){
- resolutions[i] = Math.pow(2, maxZoom-i);
- }
- var tilegrid = new ol.tilegrid.TileGrid({
- origin: [0,0], // 设置原点坐标
- resolutions: resolutions // 设置分辨率
- });
-
- // 创建百度地图的数据源
- var baiduSource = new ol.source.TileImage({
- projection: 'EPSG:3857',
- tileGrid: tilegrid,
- tileUrlFunction: function(tileCoord, pixelRatio, proj){
- var z = tileCoord[0];
- var x = tileCoord[1];
- var y = tileCoord[2];
-
- // 百度瓦片服务url将负数使用M前缀来标识
- if(x<0){
- x = 'M' + (-x);
- }
- if(y<0){
- y = 'M' + (-y);
- }
-
- return "http://online0.map.bdimg.com/onlinelabel/?qt=tile&x="+x+"&y="+y+"&z="+z+"&styles=pl&udt=20160426&scaler=1&p=0";
- }
- });
-
- // 百度地图层
- var baiduMapLayer2 = new ol.layer.Tile({
- source: baiduSource
- });
-
- // 创建地图
- new ol.Map({
- layers: [
- baiduMapLayer2
- ],
- view: new ol.View({
- // 设置成都为地图中心
- center: ol.proj.transform([104.06, 30.67], 'EPSG:4326', 'EPSG:3857'),
- zoom: 10
- }),
- target: 'baiduMap2'
- });
- </script>
- </body>
- </html>
将不定期更新资源,欢迎持续关注
想获得更多的学习知识请关注微信公众号:西北码农或扫下方二维码
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。