http://blog.csdn.net/gisshixisheng/article/details/46761535

概述:

本文讲述的是Ol3中的control的介绍和应用。

OL2和OL3 control比较:

相比较Ol2的control,OL3显得特别少,下图分别为Ol2和Ol3的control:

Ol2的control

Ol3的control

相比较Ol2,OL3保留了mouseposition,scaleline,zoom,zoomslider,而将很多东西例如draw等转移到了interaction下面,下图为Ol3的interaction:

OL3中control的常用操作:

Ol3中control的常用操作包括获取control集,添加,删除。

获取control集

  1. var controls = map.getControls();

添加

  1. map.addControl(ctrl);

删除

  1. map.removeControl(ctrl);

OL3添加control示例:

下面是一个比较完成的OL3的Control的示例,

  1. <html xmlns="http://www.w3.org/1999/xhtml">
  2. <head>
  3. <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
  4. <title>control</title>
  5. <link rel="stylesheet" type="text/css" href="http://localhost/ol3/css/ol.css"/>
  6. <style type="text/css">
  7. body, #map {
  8. border: 0px;
  9. margin: 0px;
  10. padding: 0px;
  11. width: 100%;
  12. height: 100%;
  13. font-size: 13px;
  14. }
  15. #location{
  16. position: absolute;
  17. bottom: 10px;
  18. left: 45%;
  19. font-weight: bold;
  20. z-index: 99;
  21. }
  22. #switch{
  23. position:absolute;
  24. right:20pt;
  25. top:40pt;
  26. z-index:999;
  27. }
  28. #rotation{
  29. position: absolute;
  30. top: 10px;
  31. left: 45%;
  32. font-weight: bold;
  33. z-index: 99;
  34. }
  35. .ol-zoomslider{
  36. background: #d0e5f5;
  37. width: 20px;
  38. }
  39. .zoom-to-extent{
  40. position: absolute;
  41. top: 5pt;
  42. left: 28pt;
  43. }
  44. .map-rotate{
  45. position: absolute;
  46. top: 5pt;
  47. left: 45%;
  48. }
  49. </style>
  50. <script type="text/javascript" src="http://localhost/ol3/build/ol.js"></script>
  51. <script type="text/javascript" src="http://localhost/jquery/jquery-1.8.3.js"></script>
  52. <script type="text/javascript">
  53. function init(){
  54. var format = 'image/png';
  55. var bounds = [73.4510046356223, 18.1632471876417,
  56. 134.976797646506, 53.5319431522236];
  57. var controls = new Array();
  58. //鼠标位置
  59. var mousePositionControl = new ol.control.MousePosition({
  60. className: 'custom-mouse-position',
  61. target: document.getElementById('location'),
  62. coordinateFormat: ol.coordinate.createStringXY(5),//保留5位小数
  63. undefinedHTML: ' '
  64. });
  65. controls.push(mousePositionControl);
  66. //缩放至范围
  67. var zoomToExtentControl = new ol.control.ZoomToExtent({
  68. extent: bounds,
  69. className: 'zoom-to-extent',
  70. tipLabel:"全图"
  71. });
  72. controls.push(zoomToExtentControl);
  73. //比例尺
  74. var scaleLineControl = new ol.control.ScaleLine({});
  75. controls.push(scaleLineControl);
  76. //全图
  77. var fullScreenControl = new ol.control.FullScreen({});
  78. controls.push(fullScreenControl);
  79. //缩放控件
  80. var zoomSliderControl = new ol.control.ZoomSlider({});
  81. controls.push(zoomSliderControl);
  82. var rotate = new ol.control.Rotate({
  83. //              label:"↑",
  84. tipLabel:"重置",
  85. target:document.getElementById('rotation'),
  86. autoHide:false
  87. });
  88. controls.push(rotate);
  89. var untiled = new ol.layer.Image({
  90. source: new ol.source.ImageWMS({
  91. ratio: 1,
  92. url: 'http://localhost:8081/geoserver/lzugis/wms',
  93. params: {'FORMAT': format,
  94. 'VERSION': '1.1.1',
  95. LAYERS: 'lzugis:province',
  96. STYLES: ''
  97. }
  98. })
  99. });
  100. var projection = new ol.proj.Projection({
  101. code: 'EPSG:4326',
  102. units: 'degrees'
  103. });
  104. var map = new ol.Map({
  105. controls: ol.control.defaults({
  106. attribution: false
  107. }).extend(controls),
  108. interactions: ol.interaction.defaults().extend([
  109. new ol.interaction.DragRotateAndZoom()
  110. ]),
  111. target: 'map',
  112. layers: [
  113. untiled
  114. ],
  115. view: new ol.View({
  116. projection: projection,
  117. rotation:-45
  118. })
  119. });
  120. map.getView().fitExtent(bounds, map.getSize());
  121. $("#setRotate").on("click",function(){
  122. var angle = $("#rotate").val();
  123. map.getView().setRotation(angle);
  124. });
  125. }
  126. </script>
  127. </head>
  128. <body onLoad="init()">
  129. <div class="layer-change-switch" id="switch">
  130. <div id="slider">
  131. <input id="rotate" type="text" value="-45" maxlength="10" style="width: 50px;" /><button id="setRotate">旋转</button>
  132. </div>
  133. </div>
  134. <div id="map">
  135. <div id="rotation"></div>
  136. <div id="location"></div>
  137. </div>
  138. </body>
  139. </html>

上述代码效果如下:

(转) OpenLayers3基础教程——OL3 介绍control的更多相关文章

  1. OpenLayers3基础教程——OL3 介绍control

    概述: 本文讲述的是Ol3中的control的介绍和应用. OL2和OL3 control比較: 相比較Ol2的control,OL3显得特别少,下图分别为Ol2和Ol3的control: Ol2的c ...

  2. (转)OpenLayers3基础教程——OL3 介绍interaction

    http://blog.csdn.net/gisshixisheng/article/details/46808647 概述: 本节主要讲述OL3的交互操作interaction,重点介绍draw,s ...

  3. OpenLayers3基础教程——OL3之Popup

    概述: 本节重点讲述OpenLayers3中Popup的调用时实现,OL3改用Overlay取代OL2的Popup功能. 接口简单介绍: overlay跟ol.control.Control一样,是一 ...

  4. (转)OpenLayers3基础教程——OL3基本概念

    http://blog.csdn.net/gisshixisheng/article/details/46756275 OpenLayers3基础教程——OL3基本概念 从本节开始,我会陆陆续续的更新 ...

  5. OpenLayers3基础教程——OL3基本概念

    从本节開始,我会陆陆续续的更新有关OL3的相关文章--OpenLayers3基础教程,欢迎大家关注我的博客,同一时候也希望我的博客可以给大家带来一点帮助. 概述: OpenLayers 3对OpenL ...

  6. (转)OpenLayers3基础教程——OL3之Popup

    http://blog.csdn.net/gisshixisheng/article/details/46794813 概述: 本节重点讲述OpenLayers3中Popup的调用时实现,OL3改用O ...

  7. ActiveMQ基础教程----简单介绍与基础使用

    概述 ActiveMQ是由Apache出品的,一款最流行的,能力强劲的开源消息总线.ActiveMQ是一个完全支持JMS1.1和J2EE 1.4规范的 JMS Provider实现,它非常快速,支持多 ...

  8. Embedded Linux Primer----嵌入式Linux基础教程--章节介绍

    章节介绍 第一章,“导引”,简要介绍了Linux被迅速应用在嵌入式环境的驱动因素,介绍了与嵌入式Linux相关的几个重要的标准和组织. 第二章,“第一个嵌入式经历”,介绍了与后几章所构建的嵌入式Lin ...

  9. (转) OpenLayers3基础教程——加载资源

    概述: 本节讲述如何在Ol3中加载wms图层并显示到地图中. Ol3下载: 你可以在OL官网去下载,下载地址为http://openlayers.org/download/,也可以去我的百度云盘下载, ...

随机推荐

  1. 【[Offer收割]编程练习赛12 B】一面砖墙

    [题目链接]:http://hihocoder.com/problemset/problem/1494 [题意] [题解] 显然只要记住每一行的各个砖头的间隔处的坐标有多少个就好了: ->也就对 ...

  2. Mysql学习总结(40)——MySql之Select用法汇总

    一.条件筛选 1.数字筛选:sql = "Select * from [sheet1$] Where 销售单价 > 100" 2.字符条件:sql = "Selec ...

  3. Win8.1 Hyper-V 共享本机IP上网

    公司的Win8.1自带了Hyper v,可是死活连接不到网络. 原因是公司只给每人分配一个局域网IP,而默认情况下Hyper-V的虚拟机会动态分配了一个没有经过MIS人员许可的IP…… 百度了N久解决 ...

  4. NGINX Web Server Nginx web server

    原文地址:http://nginx.com/resources/admin-guide/web-server/ NGINX Web Server Nginx web server This secti ...

  5. gradle配置国内的镜像

    gradle配置国内的镜像 学习了:http://blog.csdn.net/stdupanda/article/details/72724181 http://blog.csdn.net/lj402 ...

  6. hdu 4850 字符串构造---欧拉回路构造序列 递归+非递归实现

    http://acm.hdu.edu.cn/showproblem.php? pid=4850 题意:构造长度为n的字符序列.使得>=4的子串仅仅出现一次 事实上最长仅仅能构造出来26^4+4- ...

  7. Java基础:String不可变性和final修饰

    转载请注明出处: jiq•钦's technical Blog - 季义钦 String的不可变性 Java规定String是不可变的(immutable).事实上这个不可变具备两层含义: 1 内容不 ...

  8. Android之自己定义(上方标题随ViewPager手势慢慢滑动)

    近期非常蛋疼,项目要模仿网易新闻的样式去做.上次把仿网易新闻client的下拉刷新写出来了.这次是ViewPager的滑动,同一时候ViewPager的上面标题下划线尾随者移动.本来通过ViewPag ...

  9. 5200 fqy的难题----2的疯狂幂

    5200 fqy的难题----2的疯狂幂  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 钻石 Diamond 题解  查看运行结果     题目描述 Description ...

  10. 在Win7中修改 系统盘中 “系统” - “用户” 的环境变量映射关系

    1.在此列表中,选中对应登录帐号 HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVersion\ProfileList 2.将Prof ...