利用d3、geojson繪制canvas地圖

“第一次用簡(jiǎn)書,嘗試著簡(jiǎn)單記錄一下課程大作業(yè)的實(shí)現(xiàn)過程” ——許三多兒

關(guān)鍵詞:d3.js / canvas/ geojson

實(shí)現(xiàn)過程

加載數(shù)據(jù)

d3.queue().defer().await(){}可以理解成為d3異步加載多個(gè)csv文件,而d3.csv則是一次只能加載一個(gè)。

d3.queue()
    .defer(d3.json, 'geo_shanghai_full.json')
    .defer(d3.csv, 'site.csv')
    .defer(d3.csv, 'spot.csv')
    .defer(d3.csv, 'shop.csv')
    .defer(d3.csv, 'schedulePenalty.csv')
    .await(function(error, shanghaiMapData, siteData, spotData, shopData, scheduleData) {}

定義投影坐標(biāo)系

var projection = d3.geoMercator()
    .center([121.5, 31.1]) //最終要換成上海的中心坐標(biāo)
    .scale(40000)
    .translate([canvasWidth / 2, canvasHeight / 2]) //渲染容器的中心點(diǎn)

初始化路徑

使用d3.geoPath(),將之前定義好的projection賦給path
d3.geoPath:給定GeoJSON幾何或要素對(duì)象,它會(huì)生成SVG路徑數(shù)據(jù)字符串或?qū)⒙窂匠尸F(xiàn)到Canvas。 建議使用Canvas進(jìn)行動(dòng)態(tài)或交互式投影以提高性能。 路徑可以與投影或變換一起使用,也可以用于將平面幾何直接渲染到畫布或SVG。

 var path = d3.geoPath()
       .projection(projection)
       .context(context)

繪圖

mapData.features.forEach(d => {
         context.beginPath()
         path(d)
         context.strokeStyle = 'rgba(255, 255, 255, 0.2)'
         context.lineWidth = 1
         context.stroke()
 })

完整代碼如下:

<html>
    <head>
        <meta charset=utf-8 />
        <title>drawcanvasmap</title>
        <meta name='viewport' content='initial-scale=1,maximum-scale=1,user-scalable=no' />

    </head>
    <style>
        body,
        html {
            margin: 0;
            padding: 0;
            width: 100%;
        }
        
        body {
            background-color: black;
        }
    </style>

    <body>
        <canvas id="shanghaiMap"></canvas>
        <!-- Example data. -->
        <script src="d3.js"></script>
        <script src="http://d3js.org/d3.v4.0.0-alpha.44.min.js"></script>
        <script>
            var canvasWidth = window.innerWidth
            var canvasHeight = window.innerHeight

            var projection = d3.geoMercator()
                .center([121.5, 31.1]) //最終要換成上海的中心坐標(biāo)
                .scale(40000)
                .translate([canvasWidth / 2, canvasHeight / 2]) //渲染容器的中心點(diǎn)

            d3.queue()

                .defer(d3.json, 'geo_shanghai_full.json')
                .defer(d3.csv, 'site.csv')
                .defer(d3.csv, 'spot.csv')
                .defer(d3.csv, 'shop.csv')
                .defer(d3.csv, 'schedulePenalty.csv')
                .await(function(error, shanghaiMapData, siteData, spotData, shopData, scheduleData) {
                    console.log(shanghaiMapData, siteData);
                    drawCanvasMap(shanghaiMapData, projection)

                })

            function drawCanvasMap(mapData, projection) {
                var canvas = document.getElementById('shanghaiMap')
                var context = canvas.getContext('2d')
                context.globalCompositeOperation = 'lighter'

                canvas.width = window.innerWidth
                canvas.height = window.innerHeight

                var path = d3.geoPath()
                    .projection(projection)
                    .context(context)

                // console.log(mapData.features)

                mapData.features.forEach(d => {
                    context.beginPath()
                    path(d)
                    context.strokeStyle = 'rgba(255, 255, 255, 0.2)'
                    context.lineWidth = 1
                    context.stroke()
                })


            }
        </script>
    </body>
</html>
image.png
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 1 Canvas接口元素定義 1.1 getContext()方法 為了在canvas上繪制,你必須先得到一個(gè)畫布...
    Kevin_Junbaozi閱讀 1,449評(píng)論 1 2
  • 一:canvas簡(jiǎn)介 1.1什么是canvas? ①:canvas是HTML5提供的一種新標(biāo)簽 ②:HTML5 ...
    GreenHand1閱讀 4,882評(píng)論 2 32
  • 總原則: 在移動(dòng)APP中,因?yàn)槭謾C(jī)硬件性能有限,其實(shí)不宜做太多特效,應(yīng)該往簡(jiǎn)潔突出重點(diǎn)的方向考慮。 1 性能建議 ...
    Kevin_Junbaozi閱讀 3,153評(píng)論 0 6
  • "use strict";function _classCallCheck(e,t){if(!(e instanc...
    久些閱讀 2,142評(píng)論 0 2
  • 2017年已經(jīng)過去67天。今天是婦女節(jié) 這句話你一定聽過“絕大多數(shù)人 25 歲以后就不再進(jìn)步了”。畢業(yè)后的很多人就...
    夏歐閱讀 639評(píng)論 0 51

友情鏈接更多精彩內(nèi)容