您当前的位置: 首页 > 网站编程 > PHP教程 > php和jquery实现地图区域数据统计展示数据示例

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

作者:不详 来源:网络 发布时间: 2014-08-08 16:15 点击:
我们要在地图上有限的区块内展示更多的信息,更好的办法是通过地图交互来实现。本文将给大家讲解通过鼠标滑动到地图指定省份区域,在弹出的提示框中显示对应省份的数据信息。适用于数据统计和地图区块展示等场景 HTML 首先在head部分载入raphael.js库文件和chinamapPat

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

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

  


  HTML

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

  代码如下:

  <div id="map"></div>

  <div id="tip"></div>

  jQuery

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

  代码如下:

  $(function(){

  $.get("json.php",function(json){

  ......//这里省略代码若干

  var i=0;

  for (var state in china) {

  china[state]['path'].color = Raphael.getColor(0.9);

  (function (st, state) {

  var prodata = data[i];

  var fillcolor = colors[arr[i]];

  st.attr({fill:fillcolor});//填充背景色

  xOffset = 70;

  yOffset = 180;

  st.hover(function(e){//鼠标滑向

  st.animate({fill: "#fdd", stroke: "#eee"}, 500);

  R.safari();  

  $("#tip").css({"top":(e.pageY-xOffset)+"px","left":(e.pageX-yOffset)+"px"}).fadeIn("fast")

  .html("<h4>"+china[state]['name']+"</h4><p>活跃用户数:"+prodata+"</p>");

  },function(){//鼠标离开

  st.animate({fill: fillcolor, stroke: "#eee"}, 500);

  R.safari();

  $("#tip").hide();

  });

  st.mousemove(function(e){//鼠标移动

  $("#tip").css({"top":(e.pageY-xOffset)+"px","left":(e.pageX-yOffset)+"px"});

  R.safari();

  });

  })(china[state]['path'], state);

  i++;

  }

  });

  });

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

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

  代码如下:

  #tip{position:absolute; width:180px; border:1px solid #d3d3d3; background:#fff;display:none;

  -moz-border-radius:5px; -webkit-border-radius:5px; overflow:hidden; border-radius:5px;

  -moz-box-shadow:1px 1px 2px rgba(0,0,0,.2); -webkit-box-shadow:1px 1px 2px rgba(0,0,0,.2);

  box-shadow:1px 1px 2px rgba(0,0,0,.2);}

  #tip h4{height:28px; line-height:28px; padding-left:6px; background:#f0f0f0}

  #tip p{line-height:24px; padding:2px 4px}
分享到:
本文"php和jquery实现地图区域数据统计展示数据示例"由远航站长收集整理而来,仅供大家学习与参考使用。更多网站制作教程尽在远航站长站。
顶一下
(0)
0%
踩一下
(0)
0%
[点击 次] [返回上一页] [打印]
发表评论
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
评价:
表情:
用户名: 密码: 验证码:
关于本站 - 联系我们 - 网站声明 - 友情连接- 网站地图 - 站点地图 - 返回顶部
Copyright © 2007-2013 www.yhzhan.com(远航站长). All Rights Reserved .
远航站长:为中小站长提供最佳的学习与交流平台,提供网页制作与网站编程等各类网站制作教程.
官方QQ:445490277 网站群:26680406 网站备案号:豫ICP备07500620号-4