[Mapbox GL]添加GeoJSON多边形

        使用fill类型的layer添加多边形


<!DOCTYPE html>
<html>
<head>
    <meta charset='utf-8' />
    <title></title>
    <meta name='viewport' content='initial-scale=1,maximum-scale=1,user-scalable=no' />
    <script src='https://api.tiles.mapbox.com/mapbox-gl-js/v0.28.0/mapbox-gl.js'></script>
    <link href='https://api.tiles.mapbox.com/mapbox-gl-js/v0.28.0/mapbox-gl.css' rel='stylesheet' />
    <style>
        body { margin:0; padding:0; }
        #map { position:absolute; top:0; bottom:0; width:100%; }
    </style>
</head>
<body>

<div id='map'></div>
<script>
mapboxgl.accessToken = '<your access token here>';
var map = new mapboxgl.Map({
    container: 'map',
    style: 'mapbox://styles/mapbox/streets-v9',
    center: [-68.13734351262877, 45.137451890638886],
    zoom: 5
});

map.on('load', function () {
    map.addSource('maine', {       /* 添加Source,类型是geojson */
        'type': 'geojson',
        'data': {                  /* geojson数据 */
            'type': 'Feature',
            'geometry': {
                'type': 'Polygon',
                'coordinates': [[[-67.13734351262877, 45.137451890638886],   /* 坐标存在重合的点,形成多边形 */
                    [-66.96466, 44.8097],
                    [-68.03252, 44.3252],
                    [-69.06, 43.98],
                    [-70.11617, 43.68405],
                    [-70.64573401557249, 43.090083319667144],
                    [-70.75102474636725, 43.08003225358635],
                    [-70.79761105007827, 43.21973948828747],
                    [-70.98176001655037, 43.36789581966826],
                    [-70.94416541205806, 43.46633942318431],
                    [-71.08482, 45.3052400000002],
                    [-70.6600225491012, 45.46022288673396],
                    [-70.30495378282376, 45.914794623389355],
                    [-70.00014034695016, 46.69317088478567],
                    [-69.23708614772835, 47.44777598732787],
                    [-68.90478084987546, 47.184794623394396],
                    [-68.23430497910454, 47.35462921812177],
                    [-67.79035274928509, 47.066248887716995],
                    [-67.79141211614706, 45.702585354182816],
                    [-67.13734351262877, 45.137451890638886]]]
            }
        }
    });

    map.addLayer({
        'id': 'maine',
        'type': 'fill',            /* fill类型layer */
        'source': 'maine',         
        'layout': {},
        'paint': {
            'fill-color': '#088',  /* fill颜色 */
            'fill-opacity': 0.8    /* fill透明度 */
        }
    });
});
</script>

</body>
</html>


MapboxGL是一个用于在Web上创建交互式地图的强大库,它可以方便地渲染GeoJSON数据。当您尝试使用`addLayer()`方法添加GeoJSON到地图中时遇到`TypeError: Cannot read properties of undefined (reading 'addLayer')`这样的错误,通常表示在操作某个不存在的对象或变量时出现了问题。 这个错误可能是由于以下几个原因: 1. **初始化问题**:确保在调用`addLayer`之前,Mapbox GL已经被正确地初始化了。例如,可能忘了设置access token或者没有创建map实例。 ```javascript mapboxgl.accessToken = 'YOUR_ACCESS_TOKEN'; const map = new mapboxgl.Map({ container: 'map', // 容器ID style: 'mapbox://styles/mapbox/streets-v11', // 或者自定义样式 }); ``` 2. **GeoJSON数据无效**:提供的GeoJSON数据可能是空的、格式错误,或者还没有加载完成。检查GeoJSON是否已成功解析和包含地理信息。 3. **对象引用错误**:确认`addLayer`方法所属的对象是否已经正确获取。例如,如果你从多个源动态加载GeoJSON,确保正确处理每个数据集的回调函数。 4. **版本兼容性问题**:确认使用的Mapbox GL JS版本和你的代码兼容。某些API可能在旧版和新版中有改变。 为了解决这个问题,您可以按照以下步骤排查: 1. 检查初始化代码。 2. 在添加`addLayer`前打印地图实例,确认其存在。 3. 打印或调试GeoJSON数据,确保内容正确。 4. 使用`try-catch`块捕获并处理可能的错误。 如果问题仍然存在,请提供具体的代码片段以便于更准确地定位问题。相关问题如下:
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值