国产久_亚欧精品一区_久久亚洲美女_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>
  • 99国产在线视频| 清纯唯美一区二区三区| 亚洲视频导航| 蜜桃麻豆91| 96成人在线视频| 亚洲欧洲一区二区天堂久久| 性欧美大战久久久久久久免费观看 | 91九色蝌蚪嫩草| 亚洲视频导航| 黄色日韩精品| 欧美日韩在线一二三| 日本午夜一区二区三区| 精品国产综合| 精品免费国产| 久久久精品动漫| 国产日韩二区| 久久久久久久久久久久久久久久av| 欧美综合二区| 久久三级福利| julia一区二区中文久久94| 亚洲欧美日韩国产| 欧美一级久久| 快she精品国产999| 99国产盗摄| 国产精品播放| 欧美国产一二三区| 日韩欧美一区二区三区四区| 欧美日产一区二区三区在线观看| 久久精精品视频| 欧美精品久久久| 亚洲欧洲一区二区| 欧美日本三区| 99伊人成综合| 久久美女性网| 麻豆精品蜜桃一区二区三区| 日韩不卡av| 久久久777| 亚洲美洲欧洲综合国产一区| 精品国产一区二区三区麻豆免费观看完整版| 一区精品视频| 午夜精品久久| 欧美日韩亚洲一区在线观看| 欧美国产免费| 亚洲经典视频在线观看| 亚洲精品社区| 久久久福利视频| 日韩亚洲一区在线播放| 国产精品99免费看| 亚洲精品久久久久久一区二区| 亚洲激情啪啪| 国内视频一区二区| 97免费资源站| 亚洲一区二区三区午夜| 99热免费精品| 国产精品一区视频| 日韩久久精品一区二区三区| 国产综合自拍| 国产激情一区二区三区在线观看| 青娱乐国产91| 国产欧美综合一区二区三区| 精品人伦一区二区三区| 欧美1区免费| 岛国视频一区| 欧美深夜福利| 精品欧美一区二区久久久伦| 欧美日韩国产一区精品一区| av一本久道久久波多野结衣| 欧美 日韩 国产一区二区在线视频 | 精品91视频| 动漫精品视频| 国产精品国产三级欧美二区| 成人片在线免费看| 好吊色欧美一区二区三区四区 | 亚洲麻豆一区| 欧美精品一区二区三区在线看午夜| 精品91在线| 欧美一区激情视频在线观看| 国产一区二区三区久久| 日韩欧美一区二区三区四区五区| 性欧美长视频| 国产精品国码视频| 欧美日产一区二区三区在线观看| 99亚洲精品| 欧美成人久久| 久久国产一区| 老司机精品视频网站| 激情综合视频| 亚洲欧洲另类精品久久综合| 国产精品国模大尺度私拍| 日韩午夜一区| 午夜免费电影一区在线观看| 久久99精品久久久久久三级| 国产亚洲欧美另类一区二区三区| 一个色的综合| 青青成人在线| 九9re精品视频在线观看re6| 亚洲欧美日本日韩| 亚洲福利一区| 欧美 日韩 国产精品免费观看| 欧美精彩一区二区三区| 成人三级视频在线观看一区二区| 一本色道久久综合亚洲精品高清 | 日日夜夜精品网站| 久久久久一区二区| 国产精品亚洲一区| 99国产在线观看| 久久国产精品亚洲va麻豆| 一区二区精品在线| 亚洲国产精品一区二区第四页av| 亚洲精品欧洲精品| 日韩精品一区二区三区色偷偷 | 久久久噜噜噜| 美女亚洲精品| 久久久福利视频| 鲁大师成人一区二区三区| 国产精品久久久久毛片大屁完整版| 国产一区二区三区自拍| 欧美成人首页| 欧美体内she精视频在线观看| 欧美国内亚洲| 影音先锋久久久| 亚洲黄色免费| 亚洲欧美日韩国产综合精品二区| 99re6热在线精品视频播放速度| 亚洲国内精品| 亚洲一区二区三区高清不卡| 麻豆成人在线播放| 国产精品v欧美精品∨日韩| 国产成人精品免费视频大全最热 | 久久精品日产第一区二区| 噜噜噜噜噜久久久久久91| 91成人在线看| 久久99精品国产一区二区三区| 国产区日韩欧美| 午夜午夜精品一区二区三区文| 在线视频91| 国产精品久久久免费| 97久久精品午夜一区二区| 国产精品毛片一区视频| 精品伦理一区二区三区| 视频一区视频二区视频三区视频四区国产| 日韩中文不卡| 在线不卡欧美| 91精品国产91久久久久青草| 久久久久成人精品免费播放动漫| 亚洲不卡1区| 一区在线电影| 国产日韩一区二区三区| 亚洲黄色成人久久久| 一区二区三区我不卡| 97超级碰碰| 视频一区视频二区视频三区视频四区国产| 自拍偷拍99| 亚洲一区二区三区色| 久久久久久欧美精品色一二三四| 伊人久久大香线蕉av一区| 在线综合欧美| 精品在线不卡| 亚洲国产精品www| 国产精品一区二区三区观看| 亚洲国产欧美一区二区三区不卡| 亚洲精品国产精品国自产观看| 不卡一卡2卡3卡4卡精品在| 一本一道久久久a久久久精品91| 99国产精品私拍| 欧美日韩亚洲一区二区三区在线观看| 欧美视频观看一区| 丁香五月网久久综合| 欧美日韩国产免费观看| 国产精品播放| 亚洲欧洲精品一区二区| 精品午夜一区二区| 亚洲国产婷婷| 水蜜桃一区二区三区| 久久精品系列| 欧美日韩一区二| 免费av在线一区二区| 亚洲一区网站| 欧美尤物一区| 久久久久成人精品免费播放动漫| 亚洲九九精品| 欧美一区久久| 久久成人资源| 欧美大片专区| 亚洲国产精品一区二区第四页av| 久久精品观看| 激情婷婷亚洲| 日韩av免费电影| 91成人理论电影| 国产一区二区三区的电影| 欧美一区二区三区在线播放| 国产在线精品一区二区三区》| 在线天堂一区av电影| 欧美日韩一区二区三区在线观看免 | 在线观看日韩羞羞视频| 精品国产aⅴ麻豆| 蜜桃久久av| 亚洲欧美高清| 国产精品毛片在线| 国产精品videosex极品|