MapboxGL添加三维柱状图效果

本文介绍如何使用MapboxGL在地图上叠加三维柱状图效果,包括准备页面、添加图层、点数据转换为矩形面数据、加载三维柱形图层及加入交互事件。

效果

三维地图效果

准备

我们这里只以html+jQuery+css纯demo写法展示如何叠加三维柱状图图层效果!
我们需要mapboxGL的js、css和jQuery.js

    <script type="text/javascript" src="jquery.min.js"></script>
    <script type="text/javascript" src="mapbox-gl.min.js"></script>
    <link type="text/css" rel="stylesheet" href="mapbox-gl.min.css">

还有自己定义的js文件

	 <script type="text/javascript" src="decklayer.js"></script>
	 <script type="text/javascript">
	     styleLoad();
	 </script>

页面添加图层

定义好map容器后在js里将地图添加到容器中

    <div id="map"></div>
 	var url = "https://iserver.supermap.io/iserver/services/map-china400/rest/maps/China_4326";
    var map, popup;
    var attribution = "3Dbar-demo";

    map = new mapboxgl.Map({
   
   
        container: 'map',
        style: {
   
   
            "version": 8,
            "sources": {
   
   
                "raster-tiles": {
   
   
                    "attribution": attribution,
                    "type": "raster",
                    "tiles": [url + '/zxyTileImage.png?z={z}&x={x}&y={y}'],
                    "tileSize": 256,
                },
            },
            "layers": [{
   
   
                "id": "simple-tiles",
                "type": "raster",
                "source": "raster-tiles",
                "minzoom": 0,
                "maxzoom": 22
            }]
        },
        center: [104.038567,30.650149],
        zoom: 13,
        pitch: 40,
        bearing: 0
    });
    map.addControl(new mapboxgl.NavigationControl(), 'top-left');

点数据转换矩形面数据

我的数据集是geojson点数据集格式

  	/**
     * 初始化数据
     */
    var geometry = {
   
   
        "features":[
            {
   
   
                "geometry":{
   
   
                    "coordinates":[
                        []
                    ],
                    "type":
评论 2
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

sun_falls

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值