麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > JavaScript > 正文

raphael.js繪制中國地圖 地圖繪制方法

2019-11-20 21:07:34
字體:
來源:轉載
供稿:網(wǎng)友

最近的數(shù)據(jù)統(tǒng)計項目中要用到中國地圖,也就是在地圖上動態(tài)的顯示某個時間段某個省份地區(qū)的統(tǒng)計數(shù)據(jù),我們不需要flash,僅僅依靠raphael.js以及SVG圖像就可以完成地圖的交互操作。在本文中,我給大家分享如何使用js來完成地圖交互。

先簡單介紹下raphael.js,raphael.js是一個很小的javascript庫,它可以在網(wǎng)頁中實現(xiàn)繪制各種矢量圖、各類圖表、以及圖像裁剪、旋轉、運動動畫等等功能。此外raphael.js還跨瀏覽器兼容,而且還兼容老掉牙的IE6啊。raphael.js的官網(wǎng)地址: http://raphaeljs.com/

準備工作

我們需要準備一張矢量地圖,可以從網(wǎng)上找一張矢量地圖,或者使用illustrator繪制一份矢量地圖,然后導出為SVG格式的文件,這個文件可以在瀏覽器上打開,然后提取里面的path路徑信息(M開頭的坐標)。并將path路徑信息,按照chinamapPath.js的格式準備好地圖路徑信息。

復制代碼 代碼如下:

var china = [];

function paintMap(R) {
    var attr = {
        "fill": "#97d6f5",
        "stroke": "#eee",
        "stroke-width": 1,
        "stroke-linejoin": "round"
    };

    china.aomen = {
        name: "澳門",
        path: R.path("M413.032,.........省略若干......... ,414.183z").attr(attr)
    }
    china.hk = {
        //格式同上
    };
}

以上是我們將準備好的地圖路徑信息封裝到()函數(shù)中,并保存文件名為chinamapPath.js,供后面調用。

HTML

首先在head部分載入raphael.js庫文件和chinamapPath.js路徑信息文件。

 

復制代碼 代碼如下:

<script type="text/javascript" src="raphael.js"></script>
<script type="text/javascript" src="chinamapPath.js"></script>

然后在body中需要放置地圖的位置放置div#map。
 

復制代碼 代碼如下:

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

JAVASCRIPT

首先我們在頁面中調用地圖,方法如下:

復制代碼 代碼如下:

window.onload = function () {
    //繪制地圖
    var R = Raphael("map", 600, 500);//將地圖載入到id為map的div中,并設置區(qū)域為600x500px大小。
    paintMap(R);
}

這個時候我們用瀏覽器打開會顯示載入后的地圖。接下來我們要給地圖中的對應的省份區(qū)域加上省份名稱,以及鼠標滑向每個省份區(qū)塊時的變色動畫效果。

復制代碼 代碼如下:

window.onload = function () {
    var R = Raphael("map", 600, 500);
    //調用繪制地圖方法
    paintMap(R);

    var textAttr = {
        "fill": "#000",
        "font-size": "12px",
        "cursor": "pointer"
    };

           
    for (var state in china) {
        china[state]['path'].color = Raphael.getColor(0.9);

        (function (st, state) {

            //獲取當前圖形的中心坐標
            var xx = st.getBBox().x + (st.getBBox().width / 2);
            var yy = st.getBBox().y + (st.getBBox().height / 2);

            //寫入文字
            china[state]['text'] = R.text(xx, yy, china[state]['name']).attr(textAttr);

            st[0].onmouseover = function () {//鼠標滑向
                st.animate({fill: st.color, stroke: "#eee"}, 500);
                china[state]['text'].toFront();
                R.safari();
            };
            st[0].onmouseout = function () {//鼠標離開
                st.animate({fill: "#97d6f5", stroke: "#eee"}, 500);
                china[state]['text'].toFront();
                R.safari();
            };

         })(china[state]['path'], state);
    }
}

以上代碼中運用了raphael提供的方法有:getColor,getBBox,animate,toFront等等,這些可以在raphael文檔中找到使用說明,本文不在講述。
此外由于地圖尺寸原因,有些省份名稱在地圖中的顯示位置不恰當,需要修正偏移量,這樣看起來舒服點。

復制代碼 代碼如下:

window.onload = function () {
    var R = Raphael("map", 600, 500);
    ...
    for (var state in china) {
        ...
        (function (st, state) {
            ....
            switch (china[state]['name']) {
                case "江蘇":
                    xx += 5;
                    yy -= 10;
                    break;
                case "河北":
                    xx -= 10;
                    yy += 20;
                    break;
                case "天津":
                    xx += 10;
                    yy += 10;
                    break;
                case "上海":
                    xx += 10;
                    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 += 10;
                    break;
                case "內蒙古":
                    xx -= 15;
                    yy += 65;
                    break;
                default:
            }
            ...
      })(china[state]['path'], state);
   }
}

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 久久99综合久久爱伊人 | 黄色试看视频 | 97se亚洲综合在线韩国专区福利 | 亚洲第一男人天堂 | 久久久av亚洲男天堂 | 宅男噜噜噜66国产在线观看 | 国产精品成人久久 | 国产精品久久久久久久久久免 | 久久久av亚洲男天堂 | 国产免费黄色 | 欧美日韩免费一区 | 日韩黄网站 | 欧美一级免费在线观看 | av老司机久久 | 欧美一级特黄a | 久久视频精品 | 精品国产一区二区三区蜜殿 | 在线观看免费污视频 | 日韩在线欧美在线 | 免费午夜视频 | 国内毛片视频 | 精品久久久久久久久久久下田 | 中文字幕在线观看视频一区 | 日韩激情| 女18一级大黄毛片免费女人 | 国产视频精品在线 | 国产精品久久av | 49vvv| 亚洲欧美国产精品va在线观看 | 日本aaaa片毛片免费观蜜桃 | 国产无遮挡一区二区三区毛片日本 | 三人弄娇妻高潮3p视频 | 日日草视频 | 污黄视频在线观看 | 久久经典视频 | 视频一区二区三区在线播放 | 最近免费观看高清韩国日本大全 | 国产一级中文字幕 | lutube成人福利在线观看污 | 亚洲成人精品在线 | 亚洲国产视频在线 |