源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

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

  • 时间:2021-10-30 04:45 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:php和jquery实现地图区域数据统计展示数据示例
[img]http://files.jb51.net/file_images/article/201402/20140212094619.jpg?201411294816[/img] HTML 首先在head部分载入raphael.js库文件和chinamapPath.js路径信息文件,本文不重复写下,唯一不同的地方是需要在body中加一个div#tip,用来展示地图信息的提示框。
[u]复制代码[/u] 代码如下:
<div id="map"></div> <div id="tip"></div>
jQuery 通过调用raphael绘制出中国地图,然后载入统计数据,由于地图区块小,我们不在地图载入的时候就将数据显示在地图区块上了,我们通过鼠标交互实现将数据信息更好的展示给用户。当鼠标滑向省份区块时,通过e.pageX和e.pageY定位鼠标坐标,然后通过jquery的css()方法定位提示框div#tip,并且将对应省份的的名称和活跃用户数加到提示框里并展现出来,请看代码:
[u]复制代码[/u] 代码如下:
$(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代码如下:
[u]复制代码[/u] 代码如下:
#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}
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部