ECharts地圖繪制和鉆取簡(jiǎn)易接口詳解
1.地圖繪制過程原理
給定范圍邊界經(jīng)緯度數(shù)據(jù),再給它個(gè)名字就構(gòu)成了繪制地圖的基礎(chǔ)。也就是說,你可以繪制任意形狀的地圖版塊。
2.地圖數(shù)據(jù)生成
中國(guó)以及省市縣等地圖的基礎(chǔ)數(shù)據(jù)可以從這里生成與下載。
http://datav.aliyun.com/tools/atlas
有了地圖范圍數(shù)據(jù),在 echarts 中通過 registerMap 給這塊注冊(cè)個(gè)名字,即可為后續(xù)繪制使用,以下代碼以最簡(jiǎn)形式繪制一幅中國(guó)地圖。
$.getJSON('https://geo.datav.aliyun.com/areas/bound/100000_full.json', function (data) {
var name = "中國(guó)地圖";
// 注冊(cè)一個(gè)地圖名稱
echarts.registerMap(name, data);
var myChart = echarts.init(document.getElementById('map'));
var mapOption = {
series: [
{
type: 'map', // 指明地圖類型
map: name, // 指明取的名稱
label: {show:true},
roam: true // 可縮放
} ]
};
myChart.setOption(mapOption, true);
});

3.封裝形成簡(jiǎn)易接口
3.1接口定義
從使用方式與期望結(jié)果出發(fā)來定義接口。期望給定區(qū)域名稱,指定繪制位置(DOM元素)即可完成工作。同時(shí)希望能控制是否支持鉆取,這就形成了最基礎(chǔ)的接口定義。
/** 根據(jù)名稱加載地圖
* @param elementId : DOM 元素ID
* @param name : 地圖名稱(僅已定義的地區(qū)名稱)
* @param drill : 是否支持鉆取
*/
ChinaMap.loadMap = function(elementId, name, drill) {...}
3.2接口實(shí)現(xiàn)
(1)支持多地圖圖表繪制,定義 ChartList 來記錄每個(gè)DOM元素對(duì)應(yīng)的圖表對(duì)象。
(2)支持鉆取,建立省市名稱的層級(jí)關(guān)系,市編碼前兩位為省編碼。
ChinaMap.provinceCodes={'13':'河北','14':'山西',...}
ChinaMap.cityCodes={"石家莊市":"130100","唐山市":"130200",...}
(3)動(dòng)態(tài)加載相應(yīng)名稱的數(shù)據(jù)繪制地圖,形如第2節(jié)中的示例。
(4)擴(kuò)展方法:取地圖層級(jí)路徑。如得到“中國(guó)-湖南-長(zhǎng)沙市”的路徑,且相應(yīng)的名稱可點(diǎn)擊跳轉(zhuǎn)。
詳細(xì)實(shí)現(xiàn)代碼請(qǐng)?jiān)L問:https://github.com/triplestudio/helloworld/tree/master/china_map
4.達(dá)成應(yīng)用效果
4.1可鉆取的中國(guó)地圖
使用以下代碼即可在指定的元素中繪制一幅可鉆取的中國(guó)地圖。
ChinaMap.loadMap('map', 'china', true);
方法 ChinaMap.loadMap 后會(huì)返回 echarts 圖表對(duì)象,可以進(jìn)一步進(jìn)行操作。這里,使用以下代碼在鉆取時(shí)得到層級(jí)路徑,以便達(dá)到可向上跳轉(zhuǎn)的效果。
ChinaMap.loadMap('map', 'china', true).on('click', function(param){
$("#path").html(ChinaMap.formatPath('map', param.name));
});

4.2各省地圖
由于只需要指定名稱和顯示元素ID,那么遍歷各省名稱即可快速完成各省地圖的繪制。
for(var prov in ChinaMap.provinces){
$("#main").append("<div id='" + ChinaMap.provinces[prov] + "' class='box'></div>");
ChinaMap.loadMap(ChinaMap.provinces[prov], prov);
}

相關(guān)代碼與數(shù)據(jù)可在此下載:https://github.com/triplestudio/helloworld/releases
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。
相關(guān)文章
JS實(shí)現(xiàn)簡(jiǎn)單打磚塊彈球小游戲
這篇文章主要為大家詳細(xì)介紹了JS實(shí)現(xiàn)簡(jiǎn)單打磚塊彈球小游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-05-05
JavaScript實(shí)現(xiàn)select添加option
這篇文章主要介紹了JavaScript為select添加option的方法和示例,十分的簡(jiǎn)單實(shí)用,有需要的小伙伴可以參考下。2015-07-07
Bootstrap 填充Json數(shù)據(jù)的實(shí)例代碼
本篇文章主要介紹了Bootstrap 填充Json數(shù)據(jù)的實(shí)例代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-01-01
JS實(shí)現(xiàn)點(diǎn)擊按鈕后框架內(nèi)載入不同網(wǎng)頁(yè)的方法
這篇文章主要介紹了JS實(shí)現(xiàn)點(diǎn)擊按鈕后框架內(nèi)載入不同網(wǎng)頁(yè)的方法,涉及javascript點(diǎn)擊按鈕載入頁(yè)面的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-05-05
html+css+js實(shí)現(xiàn)簡(jiǎn)易版ChatGPT聊天機(jī)器人
OpenAI的一款聊天機(jī)器人模型ChatGPT爆火,本篇文章用一百行html+css+js代碼給大家制作一款簡(jiǎn)易的聊天機(jī)器人。2023-02-02
js編寫trim()函數(shù)及正則表達(dá)式的運(yùn)用
js中本身是沒有trim函數(shù)的,不過你可以自己寫一個(gè),下面的實(shí)現(xiàn)方法是用到了正則表達(dá)式,效率不錯(cuò),并把這三個(gè)方法加入String對(duì)象的內(nèi)置方法中去2013-10-10
JavaScript是否可實(shí)現(xiàn)多線程 深入理解JavaScript定時(shí)機(jī)制
JavaScript的setTimeout與setInterval是兩個(gè)很容易欺騙別人感情的方法,因?yàn)槲覀冮_始常常以為調(diào)用了就會(huì)按既定的方式執(zhí)行, 我想不少人都深有同感,2009-12-12

