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

2015-01-24信息快讯网

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


php和jquery实现地图区域数据统计展示数据示例_信息快讯网

HTML

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

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

jQuery

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

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

CodeIgniter中使用cookie的三种方式详解
CodeIgniter采用config控制的多语言实现根据浏览器语言自动转换功能
简单实用的网站PHP缓存类实例
ThinkPHP表单自动提交验证实例教程
ThinkPHP采用<volist>实现三级循环代码实例
ThinkPHP字符串函数及常用函数汇总
ThinkPHP关于session的操作方法汇总
ThinkPHP跳转页success及error模板实例教程
PHP采用XML-RPC构造Web Service实例教程
CodeIgniter模板引擎使用实例
destoon数据库表说明汇总
PHP+Mysql树型结构(无限分类)数据库设计的2种方式实例
PHP大批量插入数据库的3种方法和速度对比
php操作redis中的hash和zset类型数据的方法和代码例子
PHP实现对文本数据库的常用操作方法实例演示
百度地图API应用之获取用户的具体位置
PHP添加Xdebug扩展的方法
php中的路径问题与set_include_path使用介绍
php 不使用js实现页面跳转
简单的php中文转拼音的实现代码
PHP字符串的递增和递减示例介绍
thinkphp3查询mssql数据库乱码解决方法分享
codeigniter教程之多文件上传使用示例
采用header定义为文件然后readfile下载(隐藏下载地址)
分享一个超好用的php header下载函数
基于preg_match_all采集后数据处理的一点心得笔记(编码转换和正则匹配)
php缓冲 output_buffering和ob_start使用介绍
PHP $_FILES中error返回值详解
php读取纯真ip数据库使用示例
使用PHP备份MYSQL数据的多种方法
php中filter函数验证、过滤用户输入的数据
php网站地图生成类示例
百度站点地图(百度sitemap)生成方法分享
CodeIgniter生成网站sitemap地图的方法
PHP生成sitemap.xml地图函数
Android ProgressBar进度条和ProgressDialog进度框的展示DEMO
表格展示无限级分类(PHP版)
©2014-2024 dbsqp.com