找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 1497|回复: 0
打印 上一主题 下一主题

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

[复制链接]

2487

主题

2487

帖子

7391

积分

论坛元老

Rank: 8Rank: 8

积分
7391
跳转到指定楼层
楼主
发表于 2018-2-14 06:00:36 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

            

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


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;
            var fillcolor = colors[arr];
            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代码如下:
[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}
            
            
您可能感兴趣的文章:
  • 也谈php网站在线人数统计
  • 发款php蜘蛛统计插件只要有mysql就可用
  • php统计文件大小,以GB、MB、KB、B输出
  • php实现用户在线时间统计详解
  • php中3种方法统计字符串中每种字符的个数并排序
  • 通过php快速统计某个数据库中每张表的数据量
  • php流量统计功能的实现代码
  • php+memcache实现的网站在线人数统计代码
  • PHP+Mysql+jQuery中国地图区域数据统计实例讲解
  • php版微信数据统计接口用法示例
  • PHP实现的统计数据功能详解
            
  • 分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    用户反馈
    客户端