精品国语人妻色乱码二区,免费乱理伦片在线观看2018,日韩精品视频在线播放,高潮无码又爽又刺激视频在线

<source id="8jepl"><menu id="8jepl"></menu></source>
    <source id="8jepl"><menu id="8jepl"></menu></source>
    <rp id="8jepl"><mark id="8jepl"><label id="8jepl"></label></mark></rp>
          <source id="8jepl"><menu id="8jepl"><label id="8jepl"></label></menu></source>
          <source id="8jepl"></source>
              <source id="8jepl"></source>
                <video id="8jepl"><menu id="8jepl"></menu></video>
                0712-2888027 189-8648-0214
                微信公眾號

                孝感風(fēng)信網(wǎng)絡(luò)科技有限公司微信公眾號

                當(dāng)前位置:主頁 > 技術(shù)支持 > Javascript/JQuery > 利用raphael.js繪制中國地圖結(jié)合項(xiàng)目完成地圖交互

                利用raphael.js繪制中國地圖結(jié)合項(xiàng)目完成地圖交互

                時(shí)間:2016-11-15來源:風(fēng)信官網(wǎng) 點(diǎn)擊: 1009次
                Raphael 是一個(gè)用于在網(wǎng)頁中繪制矢量圖形的 Javascript 庫。它使用 SVG W3C 推薦標(biāo)準(zhǔn)和 VML 作為創(chuàng)建圖形的基礎(chǔ),你可以通過 JavaScript 操作 DOM 來輕松創(chuàng)建出各種復(fù)雜的柱狀圖、餅圖、曲線圖等各種圖表,還可以繪制任意形狀的圖形,可以進(jìn)行圖表或圖像的裁剪和旋轉(zhuǎn)等復(fù)雜操作。
                 
                Raphaël 是跨瀏覽器的矢量圖形庫,目前支持的瀏覽器包括: Firefox 3.0+,Safari 3.0+,Chrome 5.0+,Opera 9.5+ 以及 Internet Explorer 6.0+。
                 
                風(fēng)信建站在實(shí)際開發(fā)項(xiàng)目中的應(yīng)用截圖演示:
                利用raphael.js繪制中國地圖結(jié)合項(xiàng)目完成地圖交互

                準(zhǔn)備工作

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

                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 = { 
                        //格式同上 
                    }} 
                

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

                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

                首先我們在頁面中調(diào)用地圖,方法如下:

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

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

                window.onload = function () { 
                    var R = Raphael("map"600500); 
                    //調(diào)用繪制地圖方法 
                    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) { 
                             
                            //獲取當(dāng)前圖形的中心坐標(biāo) 
                            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 () {//鼠標(biāo)滑向 
                                st.animate({fill: st.color, stroke: "#eee"}500); 
                                china[state]['text'].toFront(); 
                                R.safari(); 
                            }; 
                            st[0].onmouseout = function () {//鼠標(biāo)離開 
                                st.animate({fill: "#97d6f5", stroke: "#eee"}500); 
                                china[state]['text'].toFront(); 
                                R.safari(); 
                            }; 
                                     
                         })(china[state]['path'], state); 
                    } 
                } 
                

                以上代碼中運(yùn)用了raphael提供的方法有:getColor,getBBox,animate,toFront等等,這些可以在raphael文檔中找到使用說明,本文不在講述。

                此外由于地圖尺寸原因,有些省份名稱在地圖中的顯示位置不恰當(dāng),需要修正偏移量,這樣看起來舒服點(diǎn)。

                window.onload = function () { 
                    var R = Raphael("map"600500); 
                    ... 
                    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 "內(nèi)蒙古": 
                                    xx -= 15; 
                                    yy += 65; 
                                    break; 
                                default: 
                            } 
                            ... 
                      })(china[state]['path'], state); 
                   } 
                } 
                

                這樣一個(gè)基本的地圖效果就完成了,接下來我們要介紹結(jié)合jquery,PHP+MySQL讀取數(shù)據(jù)到地圖中來,并實(shí)現(xiàn)基本的動態(tài)加載數(shù)據(jù)和交互功能

                 
                實(shí)用網(wǎng)站:
                 
                raphael.js地圖演示地址:http://www.helloweba.com/demo/chinamap/
                 
                Raphael 官方網(wǎng)站地址:http://raphaeljs.com
                 
                Raphael 英文參考文檔:http://raphaeljs.com/reference.html
                 
                Raphael 中文幫助文檔:http://julying.com/lab/raphael-js/docs/
                熱門關(guān)鍵詞: raphael.js 繪制中國地圖 地圖交互 JQuery
                欄目列表
                推薦內(nèi)容
                熱點(diǎn)內(nèi)容
                展開