zoukankan      html  css  js  c++  java
  • 用 Raphaël 绘制中国地图 + 显示数据

    目录

    1. 前言
    2. 效果图
    3. 文件说明
    4. 修改内容
    5. 代码下载

    前言

    其实这个地图的脚本是我在网上找到,找了好多,发现这个用 Raphaël 绘制的地图功能最强,最好看,关键是兼容性也是最好的,支持所有浏览器,包括IE6

    Raphaël 官网:http://raphaeljs.com/ 相当不错的画图插件,有兴趣的可以看看,支持IE6

    地图演示地址:http://www.5imvc.com/Rep/Map

    效果图

    先来看看原版的显示效果

    好看是好看,但是觉得怪怪的。。。就是没有省份的文字,这东西要是给别人用估计会被骂的,考我们地理知识呢?

    说实话,我地理稀烂,上面除了湖北,上海,北京几个大城市,其他都不知道,哈哈,别喷我,还有就是,地图中的澳门,北京,上海太小了,很难点击

    再来看看我修改后的效果图

    文件说明

    raphael.js --raphael的库,画图就靠这个了

    chinamapPath.js -- 中国地图绘制

    chinamap.js   --对绘制的地图增加事件和上色,绑定数据等操作

    修改内容

    我只是对 chinamap.js 文件做了一点修改

    首先,获取每个区域的中心坐标

    //***获取当前图形的中心坐标
    var xx = st.getBBox().x + (st.getBBox().width / 2);
    var yy = st.getBBox().y + (st.getBBox().height / 2);

    然后通过raphael中 Paper.text(x, y, text) 方法将文字增加到每个区域中间

    //***写入地名,并加点击事件,部分区域太小,增加对文字的点击事件
    china[state]['text'] = R.text(xx, yy, china[state]['name']).attr(textAttr).click(function () {
        clickMap();
    }).hover(function () {
        var $sl = $("#topList").find("[title='" + china[state]['name'] + "']:not([select])");
        $sl.css("font-size", "20px");
    }, function () {
        var $sl = $("#topList").find("[title='" + china[state]['name'] + "']:not([select])");
        $sl.css("font-size", "");
    });

    有几个省份中心坐标不在内部,所以文字会跑出去,所以还得最部分坐标进行校正

    //***修改部分地图文字偏移坐标
                switch (china[state]['name']) {
                    case "江苏":
                        xx += 5;
                        yy -= 10;
                        break;
                    case "河北":
                        xx -= 10;
                        yy += 20;
                        break;
                    case "天津":
                        xx += 20;
                        yy += 10;
                        break;
                    case "上海":
                        xx += 20;
                        break;
                    case "广东":
                        yy -= 10;
                        break;
                    case "澳门":
                        yy += 10;
                        break;
                    case "香港":
                        xx += 20;
                        yy += 5;
                        break;
                    case "甘肃":
                        xx -= 40;
                        yy -= 30;
                        break;
                    case "陕西":
                        xx += 5;
                        yy += 20;
                        break;
                    case "内蒙古":
                        xx -= 15;
                        yy += 65;
                        break;
                    default:
                }
    View Code

    最后把数据传到前台让有数据的省区变色,用 china['湖北']['path'] 可以访问到当前raphael 的对象,使用变色方法显示就OK了

     周末一下发两篇文章,好累,休息去咯,喜欢的话求推荐哦,有问题欢迎讨论

    代码下载

    http://download.csdn.net/detail/linfei721/5502961

  • 相关阅读:
    抽象类与接口的区别
    模板模式(Template Pattern)
    KVM虚拟化
    find文本处理(locate)实例学习记录
    AWK-文本处理测试实例记录
    Linux系统中如何查找大文件
    吞吐量和Iops、测试工具FIO使用
    linux了解
    了解docker
    语言资源国际化
  • 原文地址:https://www.cnblogs.com/linfei721/p/3114174.html
Copyright © 2011-2022 走看看