php发布地图数据,php和jquery实现地图区域数据统计展示数据示例_PHP教程

该博客介绍了如何结合jQuery和Raphael.js库来绘制中国地图,并在鼠标交互时动态显示提示框以展示省份的活跃用户数。通过在body中添加p#tip元素作为提示框,在鼠标滑过省份区块时,利用hover和mousemove事件调整提示框的位置,显示对应的省份名称和数据,提升用户体验。同时,文章提供了提示框的基础CSS样式以供定制。
摘要由CSDN通过智能技术生成

cf96842719effa76abe2400799cba64d.jpg

HTML

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

复制代码 代码如下:

jQuery

通过调用raphael绘制出中国地图,然后载入统计数据,由于地图区块小,我们不在地图载入的时候就将数据显示在地图区块上了,我们通过鼠标交互实现将数据信息更好的展示给用户。当鼠标滑向省份区块时,通过e.pageX和e.pageY定位鼠标坐标,然后通过jquery的css()方法定位提示框p#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(“

“+china[state][‘name’]+”

活跃用户数:”+prodata+”

“);

},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}

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值