欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

使用raphael.js繪制中國地圖

系統 1996 0

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

使用raphael.js繪制中國地圖

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

?

準備工作

我們需要準備一張矢量地圖,可以從網上找一張矢量地圖,或者使用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 = { 
        //格式同上 
    }; 
} 
    

?

以上是我們將準備好的地圖路徑信息封裝到()函數中,并保存文件名為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中,并設置區域為600x500px大小。 
    paintMap(R); 
} 
    

?

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

      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); 
   } 
} 
    

?

這樣一個基本的地圖效果就完成了,接下來我們要介紹結合jquery,PHP+MySQL讀取數據到地圖中來,并實現基本的動態加載數據和交互功能,敬請關注helloweba.com下期文章介紹。

?

來源于 helloweba.com 使用raphael.js繪制中國地圖

?

使用raphael.js繪制中國地圖


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 欧美综合社区 | 亚洲一区二区三区免费视频 | 少妇特黄A片一区二区三区免费看 | 大香萑75久久精品免费 | 日韩在线国产精品 | 久久久久久久免费视频 | 日韩免费一级片 | 91麻豆国产极品在线观看洋子 | 青青草免费观看完整版高清 | 精品国产AV色一区二区深夜久久 | 色香蕉视频 | 99re6热视频精品免费观看 | 色www精品视频在线观看 | 欧美精品久久久久久久久久 | 午夜看片网| 久久亚洲天堂 | 精品国产乱码久久久久久88av | 九九精品在线 | 久久国产成人 | 深爱五月综合网 | 青青热久久国产久精品秒播 | 久久久久无码国产精品一区 | 最新高清无码专区 | 特黄做愛又硬又大A片视频 小视频在线看 | 欧美日韩免费观看视频 | 亚洲在成人网在线看 | 在线一级片 | 国产精品成人在线观看 | 国产无线乱码一区二三区 | 免费视频爱爱太爽了 | 午夜亚洲国产成人不卡在线 | 亚洲精品国产网红在线 | 欧美爱爱一区二区 | 成人久久久 | asian gaysex| 精品av| 亚洲国产天堂久久综合9999 | 免费看h网站 | 国产精品久久久99 | 国产成人精品一区二区三区电影 | 亚洲一区二区在线播放 |