国产久_亚欧精品一区_久久亚洲美女_99精品在线观看_日韩成人三级_久久精品久久久久

BIGEMPA Js API示例中心

3D柱狀圖數據展示源代碼展示

代碼編輯區 運行 下載 還原
                                    <!DOCTYPE html>
<html lang="en">

<style>
    body {
        background-image: url('./xk.jpg');
        background-repeat: no-repeat;
    }

    .tip {
        height: 100px;
        width: 200px;
        position: absolute;
        z-index: 00;
        top: 10px;
        left: 20px;
        color: wheat;
    }
</style>

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <!--
                以下CSS地址請在安裝軟件了替換成本地的地址
                CSS地址請使用:
                http://localhost:9000/bigemap.js/v2.1.0/bigemap.css
                軟件下載地址 http://www.bt68f.cn/reader/download/detail201802017.html
            -->
    <link href='http://www.bt68f.cn:9000/bigemap.js/v2.1.0/bigemap.css' rel='stylesheet' />
    <!--
                JS地址請使用:
                http://localhost:9000/bigemap.js/v2.1.0/bigemap.js
            -->
    <script src='http://www.bt68f.cn:9000/bigemap.js/v2.1.0/bigemap.js'></script>
    <script src="http://www.bt68f.cn/Public/common/js/jquery.min.js"></script>
    <script src="http://www.bt68f.cn/Public/js/d3.min.js"></script>

</head>

<body>
    <div class="d3"></div>
    <div class="tip">成都市XXXXXXX數據展示 如需其他城市 請前往Bigemap下載器下載地圖</div>
</body>
<script>
    //軟件配置信息地址,軟件安裝完成之后使用本地地址,如:http://localhost:9000
    BM.Config.HTTP_URL = 'http://www.bt68f.cn:9000';
    // 在ID為map的元素中實例化一個地圖,并設置地圖的ID號為 bigemap.zhongkexingtu,ID號程序自動生成,無需手動配置,并設置地圖的投影為百度地圖 ,中心點,默認的級別和顯示級別控件
    // var map = BM.map('map', 'bigemap.zhongkexingtu', { center: [33, 80], zoom: 4, zoomControl: true, attributionControl: false });

    // 基礎數據初始化

    var width = 800
    var height = 750

    d3.json('/Public/d3json/sichuanxiaji.geojson').then((data) => {
        console.log(data);
        var mapColor = d3.scaleOrdinal(d3.schemeCategory10)
        var mapLineColor = '#0d67c7';
        // 繪制
        var svg = d3.select('.d3').append('svg')
            .attr('width', width).attr('height', height);
        // 定義地圖的投影
        var projection = d3.geoMercator()
            .center([103.991184, 31])
            .scale(20000);
        // 定義地理路徑生成器
        var path = d3.geoPath()
            .projection(projection);

        var darkmap = svg.append('g').attr('class', 'darkmap');

        var mapGroups = svg.append('g')
            .attr('class', 'mapGroups');


        //制作數據
        var mapdata = []
        BM.geoJson(data, {
            onEachFeature: function (feature, layer) {

                var latlngs = layer.getBounds().getCenter()
                mapdata.push([
                    {
                        'name': feature.properties.name,
                        'log': latlngs.lng,
                        'lat': latlngs.lat,
                        'num': Math.random() * 10,
                        'unit': '%'
                    },
                ])
            }
        })
        console.log(mapdata);
        //繪制陰影
        darkmap.selectAll('path')
            .data(data.features)
            .enter()
            .append('path')
            .attr('class', 'map-path')
            .style('fill', '#2f2727')
            .attr('stroke', 'white')
            .attr('d', path)
            .attr('transform', 'translate(20,10)');
        // 地圖路徑繪制
        console.log(data.features);
        mapGroups.selectAll('path')
            .data(data.features)
            .enter()
            .append('path')
            .attr('class', 'map-path')
            .style('fill', (d, i) => {
                return mapColor(i)
            })
            .attr('stroke', 'white')
            .attr('d', path);

        // // text地理名稱
        mapGroups.selectAll('text')
            .data(mapdata)
            .enter()
            .append('text')
            .text((d) => d[0].name)
            .attr('font-size', '10')
            .attr('transform', (d) => {
                var coor = projection([d[0].log, d[0].lat]);
                return 'translate(' + coor[0] + ',' + coor[1] + ')';
            });;

        //繪制矩形
        var rectWidth = 13;
        var rectHeight = 60;   // 應根據計算得出,先默認柱體高度為60
        var rectColor = '#14a8f394';
        var rectLineColor = '#12ddda';

        var rect3dGroups = svg.append('g')
            .attr('class', 'rect3dGroups');
        var rect3d = rect3dGroups.selectAll('rect3d')
            .data(mapdata)
            .enter()
            .append('g')
            .attr('class', 'rect3d')
            .style('transform', (d, i) => {
                if (i === 15) {    // 都江堰市
                    return `translate(${0}px, ${-4 + 25}px)`;
                }
                if (i === 18) {    // 崇州市
                    return `translate(${0}px, ${-4 + -10}px)`;
                }
                if (i === 8) {    // 溫江市
                    return `translate(${0}px, ${-4 + 30}px)`;
                }
                return 'translate(-20   px, -4px)';
            });
        // 定義柱體高度比例尺
        var maxData = d3.max(mapdata.map((item) => item[0].num));  // 最大增長率對應高度為60
        var rectHScale = d3.scaleLinear()   // 設置線性比例尺
            .domain([0, maxData])
            .range([0, 60]);
        // 繪制頂面
        rect3d.append('path')
            .transition()
            .duration(2000)
            .delay((d, i) => {
                return i * 200
            })
            .attr('d', (d) => {
                let rectHeight = 0;
                for (let i = 0; i < mapdata.length; i += 1) {
                    if (d[0].name.indexOf(mapdata[i][0].name.slice(0, -1)) !== -1) {
                        rectHeight = rectHScale(mapdata[i][0].num);
                    }
                }
                var coor = projection([d[0].log, d[0].lat]);
                return `M${coor[0]} ${coor[1] - rectHeight}l${rectWidth} ${-rectWidth}l${-rectWidth} ${-rectWidth}l${-rectWidth} ${rectWidth}z`
            })
            .attr('fill', rectColor)
            .attr('stroke', rectLineColor)
            .attr('stroke-width', 1)
            .attr('shape-rendering', 'crispedges')

        // 繪制側面
        rect3d.append('path')
            .transition()
            .duration(1000)
            .delay((d, i) => {
                return i * 200
            })
            .attr('d', (d) => {
                let rectHeight = 0;
                for (let i = 0; i < mapdata.length; i += 1) {
                    if (d[0].name.indexOf(mapdata[i][0].name.slice(0, -1)) !== -1) {
                        rectHeight = rectHScale(mapdata[i][0].num);
                    }
                }
                var coor = projection([d[0].log, d[0].lat]);
                return `M${coor[0]} ${coor[1]} l0 ${-rectHeight} l${rectWidth} ${-rectWidth} l0 ${rectHeight} l${-rectWidth} ${rectWidth} l${-rectWidth} ${-rectWidth} l0 ${-rectHeight} l${rectWidth} ${rectWidth} z`
            })
            .attr('fill', rectColor)
            .attr('stroke', rectLineColor)
            .attr('stroke-width', 1)
            .attr('shape-rendering', 'crispedges')

        //定義豬蹄數據
        // // text地理名稱
        mapGroups.selectAll('.zhutext')
            .data(mapdata)
            .enter()
            .append('text')
            .attr('class', 'zhutext')
            .text((d) => {
                var num = d[0].num
                return num.toFixed(1) + '%'
            })
            .attr('font-size', '15')
            .attr('transform', (d) => {
                var coor = projection([d[0].log, d[0].lat]);
                return 'translate(' + (coor[0] + 20) + ',' + (coor[1] - 20) + ')';
            })
            .attr('fill', 'blue');
    })

</script>

</html>                                                                                                                        
国产久_亚欧精品一区_久久亚洲美女_99精品在线观看_日韩成人三级_久久精品久久久久
<code id="kseui"><acronym id="kseui"></acronym></code>
  • <abbr id="kseui"><tbody id="kseui"></tbody></abbr>
  • <button id="kseui"></button>
  • 精品69视频一区二区三区Q| 国产日韩欧美综合精品| 日产精品高清视频免费| 91视频免费进入| 99综合视频| 亚洲高清视频一区二区| 中文字幕一区二区三区最新| 精品视频在线观看| 国产精品日韩高清| av成人观看| 久久激情网站| 久久精品中文| 3d精品h动漫啪啪一区二区| 国产区二精品视| 国产日韩一区欧美| 一区二区精品国产| 国产精品区一区| 国产亚洲毛片在线| 亚洲欧美日韩国产一区二区| 亚洲黄页一区| 国产欧美大片| 久久精品99| 成人91视频| 国模精品一区二区三区| 国产在线精品日韩| 欧美极品色图| 日韩av一级大片| 永久免费精品视频网站| 欧美喷水视频| 亚洲二区免费| 麻豆亚洲精品| 不卡视频一区二区| 久久久福利视频| 亚洲一区二区不卡视频| 欧美全黄视频| 亚洲欧美日韩国产一区二区| 久久婷婷丁香| 欧日韩一区二区三区| 亚洲欧美日韩在线综合| 精品成人在线| 老司机免费视频久久| 国产成人免费观看| 水蜜桃亚洲精品| 在线国产日韩| 99在线视频播放| 色999日韩自偷自拍美女| 欧美黄色一区| 久久久久高清| 日本一区二区三区视频在线播放 | 欧美大香线蕉线伊人久久国产精品 | 亚洲一区二区三区涩| 国产偷国产偷亚洲高清97cao| 久久久7777| 在线精品一区| 国产一区二区精品在线| 最新精品视频| 成人18视频| 最新欧美日韩亚洲| 91嫩草国产在线观看| 亚洲一区bb| 玖玖视频精品| 中文字幕中文字幕在线中心一区| 国语自产精品视频在线看8查询8| 国产三级精品在线不卡| 免费毛片一区二区三区久久久| 欧美区国产区| 成人免费91在线看| 午夜精品免费| 国内精品视频在线播放| 在线观看欧美亚洲| 蜜桃在线一区二区三区精品| 亚洲精品九九| 日韩国产高清一区| 久久一日本道色综合久久| 亚洲精品影院| yellow视频在线观看一区二区| 亚洲欧美综合国产精品一区| 99九九视频| 亚洲日本国产| 一本色道婷婷久久欧美| 国产伦精品一区二区三区视频免费| 欧美日韩精品免费观看视一区二区| 999热视频在线观看| 亚洲激情午夜| 亚洲国产精品123| 国产精品久久国产三级国电话系列 | 精品日韩电影| 免费亚洲视频| 在线精品亚洲| 中文字幕一区二区三区精彩视频 | 好看的日韩精品视频在线| 一区二区三区福利| 欧美激情偷拍| 一本久道久久综合狠狠爱亚洲精品 | 亚洲一区二区三区午夜| 午夜久久久久| 亚洲v国产v| 久久精品aaaaaa毛片| 久久综合导航| 午夜在线一区二区| 亚洲欧洲精品一区| 国产精品观看| 欧美日韩另类丝袜其他| 欧美一区激情视频在线观看| 国产欧美一区二区视频| 91福利入口| 免费在线播放第一区高清av| 亚洲国产一区二区三区a毛片| 伊人久久大香线蕉午夜av| 欧美成熟毛茸茸复古| 欧美精品123| 欧美日韩成人一区二区三区| 国内成+人亚洲| 久久99欧美| 欧美精品一区二区三区久久| 国产精品制服诱惑| 久久精品丝袜高跟鞋| 久久99精品久久久久子伦| 国产精品一区二区三区免费| 国产成人女人毛片视频在线| 国产91亚洲精品一区二区三区| 91亚色免费| 国产一级二级三级精品| 久久av一区二区| 日韩电影免费观看高清完整| 欧洲亚洲一区| 女生裸体视频一区二区三区| 欧美激情一区二区三区在线视频| 欧美激情精品久久久六区热门| 欧美三级视频| 国产伦精品一区| 99久热re在线精品996热视频| 国产美女99p| 老牛影视免费一区二区| 欧美日韩亚洲综合一区二区三区激情在线| 欧美aaaaa喷水| 亚洲资源视频| 日韩午夜免费视频| 久久亚洲二区| 欧洲精品亚洲精品| 欧美 亚欧 日韩视频在线| 激情婷婷欧美| 91在线在线观看| 奇米影视首页 狠狠色丁香婷婷久久综合| 日韩视频在线播放| 亚洲精品女人| 国产精品久久精品国产| 色综合久久久久久久久五月| 一区二区精品国产| 亚洲欧美精品| 久久人人97超碰人人澡爱香蕉| 综合视频在线观看| 麻豆亚洲精品| 亚洲欧洲一区二区| 国产三区二区一区久久| 精品一区二区不卡| 影院欧美亚洲| 久草热久草热线频97精品| 中文字幕免费在线不卡| 亚洲资源av| 亚洲欧洲三级| 99精品国产高清一区二区| 亚洲国产另类久久久精品极度| 在线亚洲一区| 日韩欧美亚洲在线| 一区二区高清视频| 色99中文字幕| 老司机精品视频网站| 欧美在线三区| 国产视频一区二区不卡| 亚洲一二三区精品| 久久久精彩视频| 国产乱人伦精品一区二区 | 日本一区二区三区四区在线观看| 国产精品yjizz| 免费观看成人高| 国产精品综合| 午夜国产一区| 久久久一本精品99久久精品| 99在线精品视频在线观看| 人禽交欧美网站免费| 亚洲欧美成人| 好吊视频一区二区三区四区| 精品一区日韩成人| 亚洲一区在线免费| 欧美性色综合| 午夜精品美女久久久久av福利| 裸体一区二区| 99av国产精品欲麻豆| 日本婷婷久久久久久久久一区二区| 久久精品二区| 一区二区三区国产盗摄| 亚洲视频精品一区| 欧美aaaaa喷水| 国产精品久久国产三级国电话系列 | 性欧美.com| 麻豆av一区| 国产一级特黄a大片99| 蜜桃av噜噜一区二区三区| 99热免费精品在线观看|