PHP+Mysql+jQuery实现地图区域数据统计-展示数据
2016-12-21 16:14
597 查看
我们要在地图上有限的区块内展示更多的信息,更好的办法是通过地图交互来实现。本文将给大家讲解通过鼠标滑动到地图指定省份区域,在弹出的提示框中显示对应省份的数据信息。适用于数据统计和地图区块展示等场景。
查看演示下载源码
本文紧接本站上一篇文章:PHP+Mysql+jQuery实现地图区域数据统计-载入数据,在原文实例基础上新加提示框展示数据功能,如果您对地图绘制和数据载入不太了解,建议先阅读本站上篇文章的介绍。
<divid="map"></div>
<divid="tip"></div>
$(function(){
$.get("json.php",function(json){
......//这里省略代码若干
vari=0;
for(varstateinchina){
china[state]['path'].color=Raphael.getColor(0.9);
(function(st,state){
varprodata=data[i];
varfillcolor=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.clientY-xOffset)+"px","left":(e.clientX-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.clientY-xOffset)+"px","left":(e.clientX-yOffset)+"px"});
R.safari();
});
})(china[state]['path'],state);
i++;
}
});
});
以上代码可以看出,通过jQuery的hover()鼠标滑向省份区块时,调用弹出提示框,并将数据载入显示在提示框中,而值得关注的是,我们还需要加一个效果,就是鼠标在省份区块上移动mousemove()的时候,也应该调用提示框跟随鼠标一起移动,否则的话当鼠标在一个省份区块内滑动的话提示框位置不会变化,这样会影响体验效果,小小的改动可以提升用户体验。
最后,如果您需要定制提示框的效果的话,可以设置提示框的CSS样式,本例简单的CSS代码如下:
#tip{position:absolute;width:180px;border:1pxsolid#d3d3d3;background:#fff;display:none;
-moz-border-radius:5px;-webkit-border-radius:5px;overflow:hidden;border-radius:5px;
-moz-box-shadow:1px1px2pxrgba(0,0,0,.2);-webkit-box-shadow:1px1px2pxrgba(0,0,0,.2);
box-shadow:1px1px2pxrgba(0,0,0,.2);}
#tiph4{height:28px;line-height:28px;padding-left:6px;background:#f0f0f0}
#tipp{line-height:24px;padding:2px4px}
声明:本文为原创文章,helloweba.com和作者拥有版权,如需转载,请注明来源于helloweba.com并保留原文链接:http://www.helloweba.com/view-blog-244.html
本文紧接本站上一篇文章:
HTML
首先在head部分载入raphael.js库文件和chinamapPath.js路径信息文件,本文不重复写下,唯一不同的地方是需要在body中加一个div#tip,用来展示地图信息的提示框。jQuery
通过调用raphael绘制出中国地图,然后载入统计数据,由于地图区块小,我们不在地图载入的时候就将数据显示在地图区块上了,我们通过鼠标交互实现将数据信息更好的展示给用户。当鼠标滑向省份区块时,通过e.clientX和e.clientY定位鼠标坐标,然后通过jquery的css()方法定位提示框div#tip,并且将对应省份的的名称和活跃用户数加到提示框里并展现出来,请看代码:$.get("json.php",function(json){
......//这里省略代码若干
vari=0;
for(varstateinchina){
china[state]['path'].color=Raphael.getColor(0.9);
(function(st,state){
varprodata=data[i];
varfillcolor=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.clientY-xOffset)+"px","left":(e.clientX-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.clientY-xOffset)+"px","left":(e.clientX-yOffset)+"px"});
R.safari();
});
})(china[state]['path'],state);
i++;
}
});
});
以上代码可以看出,通过jQuery的hover()鼠标滑向省份区块时,调用弹出提示框,并将数据载入显示在提示框中,而值得关注的是,我们还需要加一个效果,就是鼠标在省份区块上移动mousemove()的时候,也应该调用提示框跟随鼠标一起移动,否则的话当鼠标在一个省份区块内滑动的话提示框位置不会变化,这样会影响体验效果,小小的改动可以提升用户体验。
最后,如果您需要定制提示框的效果的话,可以设置提示框的CSS样式,本例简单的CSS代码如下:
-moz-border-radius:5px;-webkit-border-radius:5px;overflow:hidden;border-radius:5px;
-moz-box-shadow:1px1px2pxrgba(0,0,0,.2);-webkit-box-shadow:1px1px2pxrgba(0,0,0,.2);
box-shadow:1px1px2pxrgba(0,0,0,.2);}
#tiph4{height:28px;line-height:28px;padding-left:6px;background:#f0f0f0}
#tipp{line-height:24px;padding:2px4px}
声明:本文为原创文章,helloweba.com和作者拥有版权,如需转载,请注明来源于
相关文章推荐
- PHP+Mysql+jQuery实现地图区域数据统计-展示数据
- PHP+Mysql+jQuery实现地图区域数据统计-展示数据
- php和jquery实现地图区域数据统计展示数据示例
- PHP+Mysql+jQuery实现中国地图区域数据统计
- PHP+Mysql+jQuery实现地图区域数据统计-载入数据
- php和jquery实现地图区域数据统计展示数据示例
- PHP+Mysql+jQuery实现中国地图区域数据统计(raphael.js)
- PHP+Mysql+jQuery中国地图区域数据统计实例讲解
- PHP+Mysql+jQuery中国地图区域数据统计实例讲解
- 如何使用PHP+jQuery+MySQL实现异步加载ECharts地图数据(附源码下载)
- 如何使用PHP+jQuery+MySQL实现异步加载ECharts地图数据(附源码下载)
- jQuery+Ajax+PHP+Mysql实现分页显示数据
- C#+JQuery+.Ashx+百度Echarts 实现全国省市地图和饼状图动态数据图形报表的统计
- jQuery+Ajax+PHP+Mysql实现分页显示数据
- jQuery+Ajax+PHP+Mysql实现分页显示数据
- jQuery+Ajax+PHP+Mysql实现分页显示数据
- 项目开发实战 jQuery+php+mysql实现数据上传功能(补充!!!)
- jQuery+Ajax+PHP+Mysql实现分页显示数据
- jQuery+Ajax+PHP+Mysql实现分页显示数据
- jQuery+Ajax+PHP+Mysql实现分页显示数据