echarts 地圖顯示餅圖

地圖+餅圖

代碼下載地址:map_pie: 地圖上標(biāo)注餅圖

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <script src="jquery-1.11.0.min.js"></script>
    <script src="echarts.min.js"></script>
    <script src="china.js"></script>
</head>
<body>
    <div class="wrap" style="position: relative;">
        <div id="map" style="width: 100%; height: 900px;"></div>
    </div>
    <script>
    var myChart = echarts.init(document.getElementById('map'));
    // 失去坐標(biāo)
    var geoCoordMap = {
        "北京": [116.41667,39.91667],
        "上海": [121.43333,34.50000],
        "廣州": [113.23333,23.16667],
        "杭州": [120.20000,30.26667],
        "重慶": [106.45000, 29.56667],
        "青島": [120.33333,36.06667],
        "廈門": [118.10000,24.46667],
        "福州": [119.30000,26.08333],
        "蘭州": [103.73333,36.03333],
        "長沙": [113.00000,28.21667],
        "南京": [118.78333,32.05000],
        "海外": [130.41667,36.91667],
    };
    //市區(qū)數(shù)據(jù)
    var rawData = [
        ["北京",5,20,30],
        ["上海",10,10,30],
        ["廣州",10,50,30],
        ["杭州",10,20,3],
        ["重慶",10,20,8],
        ["青島",10,20,10],
        ["廈門",10,20,4],
        ["福州",10,10,30],
        ["蘭州",10,15,30],
        ["長沙",10,25,30],
        ["南京",10,20,5],
        ["海外",10,5,10]
    ];


    function makeMapData(rawData) {
        var mapData = [];
        for (var i = 0; i < rawData.length; i++) {
            var geoCoord = geoCoordMap[rawData[i][0]];//某個(gè)市區(qū)得經(jīng)緯度
            if (geoCoord) {
                mapData.push({
                    name: rawData[i][0],//某個(gè)市區(qū)的名稱
                    value: geoCoord.concat(rawData[i].slice(1))
                });
            }
        }
        console.log(mapData);
        return mapData;
    };

    option = {
        animation: false,
        // 地圖背景顏色
        backgroundColor: new echarts.graphic.RadialGradient(0.5, 0.5, 0.4, [{
            offset: 0,
            color: '#fff'
        }, {
            offset: 1,
            color: '#fff'
        }]),
        tooltip: {
            trigger: 'axis'
        },
        geo: {
            map: 'china',
            // silent: true,
            roam: true,
            zoom: 0.9, // 地圖初始大小
            center: [116.366794, 40.400309], // 初始中心位置
            label: {
                normal:{
                    show:false
                },
                emphasis: {
                    show: false,
                    areaColor: '#eee'
                }
            },
            // 地區(qū)塊兒顏色
            itemStyle: {
                normal: {
                    areaColor: '#f3e5a1',
                    borderColor: '#877167'
                },
                emphasis: {
                    areaColor: '#21AEF8'
                }
            }
        },
        series: []
    };

    function renderEachCity() {
        var option = {
            title:[],
            grid: [],
            legend: {
                x : '64%',
                y : '30%',
                orient:'vertical',
                data:['乘用車','客車','專用車']
            },
            series: []
        };

        echarts.util.each(rawData, function(dataItem, idx) {
            var geoCoord = geoCoordMap[dataItem[0]];
            var coord = myChart.convertToPixel('geo', geoCoord);
            idx += '';
            inflationData = [
                { name: '乘用車', value: dataItem[1] },
                { name: '客車', value: dataItem[2] },
                { name: '專用車', value: dataItem[3] },
            ]
            var total =  dataItem[1]+dataItem[2]+dataItem[3];
            var title ={
                text: dataItem[0],
                textStyle:{
                    fontSize:10,
                    fontWeight:'bold',
                },
                x: coord[0]-15,
                y: coord[1]+15
            };
            option.title.push(title);
            option.grid.push({
                id: idx,
                gridId:idx,
                width: 30,
                height: 40,
                left: coord[0] - 15,
                top: coord[1] - 15,
                z: 100
            });
            option.series.push({
                id: idx,
                type: 'pie',
                label: {
                    normal: {
                        show: false
                    },
                    emphasis: {
                        show: true
                    }
                },
                lableLine: {
                    normal: {
                        show: false
                    },
                    emphasis: {
                        show: true
                    }
                },
                radius:total>50 ? '4%' :( total > 40 ? '3%' :(total>30 ? '2%':'1%')) ,
                center:coord,
                data: inflationData,
                z: 100,
                itemStyle: {
                    normal: {
                        color: function(params){
                            // 柱狀圖每根柱子顏色
                            var colorList = ['#fcae91','#fb6a4a','#cb181d'];
                            return colorList[params.dataIndex];
                        }
                    }
                }
            });
        });
        myChart.setOption(option);
    }

    setTimeout(renderEachCity, 0);
    // 縮放和拖拽
    function throttle(fn, delay, debounce) {

        var currCall;
        var lastCall = 0;
        var lastExec = 0;
        var timer = null;
        var diff;
        var scope;
        var args;

        delay = delay || 0;

        function exec() {
            lastExec = (new Date()).getTime();
            timer = null;
            fn.apply(scope, args || []);
        }

        var cb = function() {
            currCall = (new Date()).getTime();
            scope = this;
            args = arguments;
            diff = currCall - (debounce ? lastCall : lastExec) - delay;

            clearTimeout(timer);

            if (debounce) {
                timer = setTimeout(exec, delay);
            } else {
                if (diff >= 0) {
                    exec();
                } else {
                    timer = setTimeout(exec, -diff);
                }
            }

            lastCall = currCall;
        };

        return cb;
    }

    var throttledRenderEachCity = throttle(renderEachCity, 0);
    myChart.on('geoRoam', throttledRenderEachCity);
    myChart.setOption(option);


    </script>
</body>
</html>

我的這部分代碼也是從一個(gè)博客上修改后的杉允,具體原博客的地址我找不到了,他的是顯示柱狀圖我給改成了餅圖

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末恬吕,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子须床,更是在濱河造成了極大的恐慌铐料,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,290評論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件豺旬,死亡現(xiàn)場離奇詭異钠惩,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)族阅,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,107評論 2 385
  • 文/潘曉璐 我一進(jìn)店門篓跛,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人坦刀,你說我怎么就攤上這事愧沟。” “怎么了鲤遥?”我有些...
    開封第一講書人閱讀 156,872評論 0 347
  • 文/不壞的土叔 我叫張陵沐寺,是天一觀的道長。 經(jīng)常有香客問我盖奈,道長混坞,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,415評論 1 283
  • 正文 為了忘掉前任钢坦,我火速辦了婚禮究孕,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘爹凹。我一直安慰自己蚊俺,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,453評論 6 385
  • 文/花漫 我一把揭開白布逛万。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪宇植。 梳的紋絲不亂的頭發(fā)上得封,一...
    開封第一講書人閱讀 49,784評論 1 290
  • 那天,我揣著相機(jī)與錄音指郁,去河邊找鬼忙上。 笑死,一個(gè)胖子當(dāng)著我的面吹牛闲坎,可吹牛的內(nèi)容都是我干的疫粥。 我是一名探鬼主播,決...
    沈念sama閱讀 38,927評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼腰懂,長吁一口氣:“原來是場噩夢啊……” “哼梗逮!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起绣溜,我...
    開封第一講書人閱讀 37,691評論 0 266
  • 序言:老撾萬榮一對情侶失蹤慷彤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后怖喻,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體底哗,經(jīng)...
    沈念sama閱讀 44,137評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,472評論 2 326
  • 正文 我和宋清朗相戀三年锚沸,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了跋选。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,622評論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡哗蜈,死狀恐怖前标,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情恬叹,我是刑警寧澤候生,帶...
    沈念sama閱讀 34,289評論 4 329
  • 正文 年R本政府宣布,位于F島的核電站绽昼,受9級特大地震影響唯鸭,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜硅确,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,887評論 3 312
  • 文/蒙蒙 一目溉、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧菱农,春花似錦缭付、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,741評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春绣檬,著一層夾襖步出監(jiān)牢的瞬間足陨,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,977評論 1 265
  • 我被黑心中介騙來泰國打工娇未, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留墨缘,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,316評論 2 360
  • 正文 我出身青樓零抬,卻偏偏與公主長得像镊讼,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子平夜,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,490評論 2 348

推薦閱讀更多精彩內(nèi)容

  • 發(fā)現(xiàn) 關(guān)注 消息 iOS 第三方庫蝶棋、插件、知名博客總結(jié) 作者大灰狼的小綿羊哥哥關(guān)注 2017.06.26 09:4...
    肇東周閱讀 12,059評論 4 62
  • 定義: 由一個(gè)工廠對象決定創(chuàng)建出哪一種產(chǎn)品類的實(shí)例. 類型: 創(chuàng)建型(creational), 但不屬于GOF23...
    a_salt_fish閱讀 247評論 0 4
  • 不工作讓陷入了焦慮不安的狀態(tài)褥芒,滿身的疲憊無法宣泄嚼松,無處訴說。告訴自己不要惶恐锰扶,可還是滿心糾結(jié)献酗。既希望離開家去外面工...
    歐陽紫凌閱讀 134評論 0 0
  • 《如水赤子夢》 我們都有過——爛漫天真的童年,朝氣蓬勃的少年坷牛,因年少無知而輕狂妄為的青春…… 更亦有過罕偎, 想用一生...
    5ce43e45b388閱讀 333評論 0 0