ElementsTopic.html 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
  5. <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0"/>
  6. <meta name="apple-mobile-web-app-capable" content="yes"/>
  7. <title>扩展图专题</title>
  8. <link href='./css/bootstrap.min.css' rel='stylesheet'/>
  9. <link href='./css/bootstrap-responsive.min.css' rel='stylesheet'/>
  10. <link href='./css/sm-extend.css' rel='stylesheet'/>
  11. <link href='./css/sm-doc.css' rel='stylesheet'/>
  12. <style type="text/css">
  13. .table{
  14. display: inline-block;
  15. float: left;
  16. vertical-align: top;
  17. width:450px;
  18. margin: 2px;
  19. }
  20. </style>
  21. </head>
  22. <body data-spy="scroll" data-target=".subnav" data-offset="50">
  23. <!--导航条-->
  24. <div class="navbar navbar-fixed-top" id="navbar"></div>
  25. <script src="js/navbar.js"></script>
  26. <script src="./js/GoTop.js" id="js_gotop"></script>
  27. <div id='container' class='container'>
  28. <div class='page-header'>
  29. <h1>扩展图专题</h1>
  30. <hr/>
  31. <h2>一、简介</h2>
  32. <p>SuperMap iClient for JavaScript 提供了Elements图层,其自身是一个div,用户可以在该图层上添加任意dom对象,并且支持第三方扩展应用。</p>
  33. <p>调用Elements图层的 getDiv方法获得该图层的div后,将dom对象添加到该div中,便可拓展应用。</p>
  34. <h2>二、使用说明</h2>
  35. <br>
  36. <p>下面我们来详细介绍一下如何使用Elements图层扩展应用</p>
  37. <h4> 1.首先创建一个Elements图层,将其添加到地图中,并获取该图层的div。 </h4>
  38. <p>
  39. <pre>
  40. //创建Elements的实例,获得其div
  41. var elementsLayer = new SuperMap.Layer.Elements("elementsLayer");
  42. map.addLayers([elementsLayer]);
  43. var elementsDiv = elementsLayer.getDiv()
  44. </pre>
  45. </p>
  46. <br>
  47. <h5> 可设置Elements图层的div的大小,如下代码片段中,设置该div的大小为地图大小</h5>
  48. <p>
  49. <pre>
  50. //设置Elements实例的div为地图大小
  51. var size = map.getSize
  52. elementsDiv.style.width = size.w;
  53. elementsDiv.style.height = size.h;
  54. </pre>
  55. </p>
  56. <br>
  57. <h4> 2.获取了该图层的div后,用户可以在该图层上添加任意dom对象,无论是用户自己的Dom对象,还是第三方扩展中的Dom对象。 </h4>
  58. <br>
  59. <p> 例如:添加简单DOM对象 </p>
  60. <p>
  61. <pre>
  62. //创建一个图片对象并添加到Elements的实例中
  63. myDom = document.createElement("img");
  64. myDom.src = "images/china.png";
  65. elementsDiv.appendChild(myDom);
  66. </pre>
  67. </p>
  68. <p>以上代码片段中,调用document.createElement()方法创建一个dom对象,并调用Dom函数的appendChild方法将其添加到Elements图层的div上。</p>
  69. <br>
  70. <h4> 3.其次,用户可调用getLayerPxFromLonLat方法,将Dom对象关联到地图中。 </h4>
  71. <p> 该方法把地理坐标转换为Elements图层的像素坐标。</p>
  72. <p>
  73. <pre>
  74. function setDom(){
  75. var bounds = new SuperMap.Bounds(73.620048522949, 3.8537260781999, 134.76846313477, 53.553741455078);
  76. var lonlatLeftTop = new SuperMap.LonLat(bounds.left, bounds.top);
  77. var lonlatRightBottom = new SuperMap.LonLat(bounds.right, bounds.bottom);
  78. //然后分别将左上右下点转换为像素点
  79. var pxLeftTop = elementsLayer.getLayerPxFromLonLat(lonlatLeftTop);
  80. var pxRightBottom = elementsLayer.getLayerPxFromLonLat(lonlatRightBottom);
  81. //设置图片的大小
  82. myDom.style.width = pxRightBottom.x - pxLeftTop.x +"px";
  83. myDom.style.height = pxRightBottom.y - pxLeftTop.y + "px";
  84. //设置图片的位置
  85. myDom.style.position = "absolute";
  86. myDom.style.left = pxLeftTop.x + "px";
  87. myDom.style.top = pxLeftTop.y + "px";
  88. }
  89. </pre>
  90. </p>
  91. <p>以上代码片段中,将图片DOM的范围设置为一地理范围转换的像素范围中,并且将图片DOM的中心位置也设置为某一地理位置转换的像素位置中,从而将DOM对象关联到地图中,且可使其随着地图缩放和平移。</p>
  92. <br>
  93. <h4>4.然后,用户可通过监听map的事件,来实现Dom对象随着地图缩放、移动及其他行为。</h4>
  94. <br>
  95. <p>例如:监听map的moveend事件</p>
  96. <p>
  97. <pre>
  98. //监听地图的moveend事件
  99. map.events.on({moveend: function (evt) {
  100. //判断是否缩放
  101. if(evt.zoomChanged){
  102. //可在此实现Dom对象随着地图缩放的其他行为
  103. }
  104. //重置图片的大小和位置,让图片可以随地图缩放和平移(具体代码如3中所示)
  105. setDom();
  106. }});
  107. </pre>
  108. </p>
  109. <p>
  110. 以上代码片段,可实现Dom对象随着地图缩放、移动及其他行为。
  111. </p>
  112. <br>
  113. <div class="pageImage"><img src="./images/elements.png" /></div>
  114. <br>
  115. <p>此完整范例请见 示范程序->可视化->可视化图层->Elements Layer 扩展。</p>
  116. <br>
  117. <P style="color:red"> 用户可以在Elements图层上添加任意dom对象,以上范例说明是其一简单示范。</p>
  118. <br>
  119. <h2>三、其他拓展示例</h2>
  120. <br>
  121. <div style="width: 100%;height: 380px" >
  122. <div class="table">
  123. <h4>&nbsp&nbsp1、风向图</h4>
  124. <div> <img class="img" src="./images/elementsTopic_winmap.png"/></div>
  125. <br>
  126. <p>
  127. 基于d3js制作风向图图层,将风向图图层绘制在Elements图层的div上,从而将风向图图层与地图关联,在地图上演示风向动态。
  128. </p>
  129. </div>
  130. <div class="table">
  131. <h4>&nbsp&nbsp2、文字云图</h4>
  132. <div> <img class="img" class="img" src="./images/elementsTopic1.png"/> </div>
  133. <br>
  134. <p>
  135. 基于d3js制作文字云图层,将文字云图层绘制在Elements图层的div上,从而将文字云图层与地图关联,通过文字(首都名称)快速定位其所指定的国家。
  136. </p>
  137. </div>
  138. </div>
  139. <div style="width: 100%;height: 350px">
  140. <h4 align="center">3、Twaver拓展</h4>
  141. <div class="table">
  142. <div> <img class="img" class="img" src="./images/elementsTopic_Twaver1.png"/> </div>
  143. <br>
  144. <p>
  145. 将Twaver提供的Chart组件中的饼图DOM对象,绑定到Elements图层的div中,从而将饼图与地图关联,实现高效交互,动态展示数据。
  146. </p>
  147. </div>
  148. <div class="table">
  149. <div> <img class="img" class="img" src="./images/elementsTopic.png"/> </div>
  150. <br>
  151. <p>
  152. 将Twaver提供的network组件的DOM对象,绑定到Elements图层的div中,从而将Network与地图关联,实现高效交互,动态展示数据。
  153. </p>
  154. </div>
  155. </div>
  156. </div>
  157. <div class='footer'>
  158. <p>版权所有&nbsp;&copy; 2000-2016 &nbsp;北京超图软件股份有限公司</p>
  159. </div>
  160. </div>
  161. <script src='./js/jquery.js'></script>
  162. <script src='./js/bootstrap.js'></script>
  163. <script src="./js/navbar.js"></script>
  164. </body>
  165. </html>