zoukankan      html  css  js  c++  java
  • PHP+Mysql+jQuery实现地图区域数据统计-展示数据

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

    PHP+Mysql+jQuery实现地图区域数据统计-展示数据

    本文紧接本站上一篇文章:PHP+Mysql+jQuery实现地图区域数据统计-载入数据,在原文实例基础上新加提示框展示数据功能,如果您对地图绘制和数据载入不太了解,建议先阅读本站上篇文章的介绍。

    HTML

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

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

    jQuery

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

      

     
    声明:本文为原创文章,helloweba.com和作者拥有版权,如需转载,请注明来源于helloweba.com并保留原文链接:http://www.helloweba.com/view-blog-244.html
  • 相关阅读:
    Oracle第一课
    Web前端试题
    E
    Kingdom of Black and White
    D. Let's Go Hiking
    2021牛客寒假 第一场
    Codeforces Round #691 (Div. 2)
    CF1461D
    CF1461B
    浙财16th校赛 F因子
  • 原文地址:https://www.cnblogs.com/tdalcn/p/6208099.html
Copyright © 2011-2022 走看看