www.adminn.cn
站长正能量分享网!

php和jquery实现地图区域数据统计展示数据示例

AD:阿里云服务器企业会员更优惠 腾讯云香港,韩国免备案服务器1.8折优惠

我们要在地图上有限的区块内展示更多的信息,更好的办法是通过地图交互来实现。本文将给大家讲解通过鼠标滑动到地图指定省份区域,在弹出的提示框中显示对应省份的数据信息。适用于数据统计和地图区块展示等场景。

HTML

首先在head部分载入raphael.js库文件和chinamapPath.js路径信息文件,本文不重复写下,唯一不同的地方是需要在body中加一个p#tip,用来展示地图信息的提示框。代码如下:

  1. <p id="map"></p>  
  2. <p id="tip"></p> 

jQuery

通过调用raphael绘制出中国地图,然后载入统计数据,由于地图区块小,我们不在地图载入的时候就将数据显示在地图区块上了,我们通过鼠标交互实现将数据信息更好的展示给用户。当鼠标滑向省份区块时,通过e.pageX和e.pageY定位鼠标坐标,然后通过jquery的css()方法定位提示框p#tip,并且将对应省份的的名称和活跃用户数加到提示框里并展现出来,请看代码:

  1. $(function(){  
  2.     $.get("json.php",function(json){  
  3.  
  4.     ……//这里省略代码若干  
  5.  
  6.     var i=0;  
  7.     for (var state in china) {  
  8.         china[state]['path'].color = Raphael.getColor(0.9);  
  9.         (function (st, state) {  
  10.             var prodata = data[i];  
  11.             var fillcolor = colors[arr[i]];  
  12.             st.attr({fill:fillcolor});//填充背景色  
  13.             xOffset = 70;  
  14.             yOffset = 180;  
  15.             st.hover(function(e){//鼠标滑向  
  16.                 st.animate({fill: "#fdd", stroke: "#eee"}, 500);  
  17.                 R.safari();                  
  18.                 $("#tip").css({"top":(e.pageY-xOffset)+"px","left":(e.pageX-yOffset)+"px"}).fadeIn("fast")  
  19.                 .html("<h4>"+china[state]['name']+"</h4><p>活跃用户数:"+prodata+"</p>");  
  20.             },function(){//鼠标离开  
  21.                 st.animate({fill: fillcolor, stroke: "#eee"}, 500);  
  22.                 R.safari();  
  23.                 $("#tip").hide();  
  24.             });  
  25.  
  26.             st.mousemove(function(e){//鼠标移动  
  27.                 $("#tip").css({"top":(e.pageY-xOffset)+"px","left":(e.pageX-yOffset)+"px"});  
  28.                 R.safari();  
  29.             });  
  30.  
  31.          })(china[state]['path'], state);  
  32.          i++;  
  33.     }  
  34.     });  
  35. });  

以上代码可以看出,通过jQuery的hover()鼠标滑向省份区块时,调用弹出提示框,并将数据载入显示在提示框中,而值得关注的是,我们还需要加一个效果,就是鼠标在省份区块上移动mousemove()的时候,也应该调用提示框跟随鼠标一起移动,否则的话当鼠标在一个省份区块内滑动的话提示框位置不会变化,这样会影响体验效果,小小的改动可以提升用户体验。

最后,如果您需要定制提示框的效果的话,可以设置提示框的CSS样式,本例简单的CSS代码如下:

  1. #tip{position:absolute; width:180px; border:1px solid #d3d3d3; background:#fff;display:none;  
  2. -moz-border-radius:5px; -webkit-border-radius:5px; overflow:hidden; border-radius:5px;  
  3. -moz-box-shadow:1px 1px 2px rgba(0,0,0,.2); -webkit-box-shadow:1px 1px 2px rgba(0,0,0,.2);   
  4. box-shadow:1px 1px 2px rgba(0,0,0,.2);}  
  5. #tip h4{height:28px; line-height:28px; padding-left:6px; background:#f0f0f0}  
  6. #tip p{line-height:24px; padding:2px 4px} 

模板优惠价: (点击购买)
版权声明:本文采用知识共享 署名4.0国际许可协议 [BY-NC-SA] 进行授权
文章名称:《php和jquery实现地图区域数据统计展示数据示例》
文章链接:https://www.adminn.cn/news/8545.html
本站资源模板仅供个人学习交流,请于下载后24小时内删除,不允许用于商业用途,否则法律问题自行承担。2021.5月起,网站调整,暂不再分享免费模板。谢谢理解

扫码支付后请联系右侧QQ发送下载地址!!

源码请勿用于任何涉灰站点!净化网络,站长更有责!

支付宝扫一扫打赏