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


Posted in PHP onFebruary 12, 2014

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}
PHP 相关文章推荐
配置PHP使之能同时支持GIF和JPEG
Oct 09 PHP
Blitz templates 最快的PHP模板引擎
Apr 06 PHP
php array的学习笔记
May 10 PHP
php常用Output和ptions/Info函数集介绍
Jun 19 PHP
php递归获取目录内文件(包含子目录)封装类分享
Dec 25 PHP
ThinkPHP 表单自动验证运用示例
Oct 13 PHP
php调整服务器时间的方法
Apr 03 PHP
PHP+shell脚本操作Memcached和Apache Status的实例分享
Mar 11 PHP
PHP入门教程之自定义函数用法详解(创建,调用,变量,参数,返回值等)
Sep 11 PHP
如何通过View::first使用Laravel Blade的动态模板详解
Sep 21 PHP
laravel 5.4 + vue + vux + element的环境搭配过程介绍
Apr 26 PHP
php 输出缓冲 Output Control用法实例详解
Mar 03 PHP
php中的路径问题与set_include_path使用介绍
Feb 11 #PHP
php 不使用js实现页面跳转
Feb 11 #PHP
简单的php中文转拼音的实现代码
Feb 11 #PHP
PHP字符串的递增和递减示例介绍
Feb 11 #PHP
thinkphp3查询mssql数据库乱码解决方法分享
Feb 11 #PHP
php发送post请求的三种方法
Feb 11 #PHP
codeigniter教程之多文件上传使用示例
Feb 11 #PHP
You might like
php zip文件解压类代码
2009/12/02 PHP
php配合jquery实现增删操作具体实例
2013/12/12 PHP
5种PHP创建数组的实例代码分享
2014/01/17 PHP
百度地图经纬度转换到腾讯地图/Google 对应的经纬度
2015/08/28 PHP
利用php的ob缓存机制实现页面静态化方法
2017/07/09 PHP
php nginx 实时输出的简单实现方法
2018/01/21 PHP
精解window.setTimeout()&amp;window.setInterval()使用方式与参数传递问题!
2007/11/23 Javascript
Jquery实现仿新浪微博获取文本框能输入的字数代码
2013/02/22 Javascript
通过length属性判断jquery对象是否存在
2013/10/18 Javascript
js实现的折叠导航示例
2013/11/29 Javascript
基于jQuery实现简单的折叠菜单效果
2015/11/23 Javascript
JavaScript实现瀑布流布局
2020/06/28 Javascript
js实现手机web图片左右滑动效果
2017/12/29 Javascript
NodeJS 实现多语言的示例代码
2018/09/11 NodeJs
AJAX XMLHttpRequest对象创建使用详解
2020/08/20 Javascript
python抓取京东商城手机列表url实例代码
2013/12/18 Python
简单介绍Ruby中的CGI编程
2015/04/10 Python
python实现线程池的方法
2015/06/30 Python
Python二叉树的定义及常用遍历算法分析
2017/11/24 Python
Python实现的质因式分解算法示例
2018/05/03 Python
python实现自动发送报警监控邮件
2018/06/21 Python
Python在for循环中更改list值的方法【推荐】
2018/08/17 Python
Python实现堡垒机模式下远程命令执行操作示例
2019/05/09 Python
python图形开发GUI库pyqt5的详细使用方法及各控件的属性与方法
2020/02/14 Python
基于Python fminunc 的替代方法
2020/02/29 Python
Python如何绘制日历图和热力图
2020/08/07 Python
Python爬虫实例之2021猫眼票房字体加密反爬策略(粗略版)
2021/02/22 Python
Speedo速比涛德国官方网站:世界领先的泳装品牌
2019/08/26 全球购物
美体小铺波兰官方网站:The Body Shop波兰
2019/09/03 全球购物
Feelunique澳大利亚:欧洲的化妆品零售电商
2019/12/18 全球购物
三方合作协议书范本
2014/04/18 职场文书
家长写给孩子的评语
2014/04/18 职场文书
推荐信怎么写
2014/05/09 职场文书
售后服务承诺书模板
2014/05/21 职场文书
法语专业求职信
2014/07/20 职场文书
python实现学员管理系统(面向对象版)
2022/06/05 Python