mapbox加载turf.js创建的格网

这篇博客介绍了如何利用turf.js和MapboxGLJS结合,实现地图上的实时格网(渔网)生成。通过turf.js的squareGrid方法,可以根据指定的坐标和大小生成GeoJSON格式的格网,然后MapboxGLJS将其加载为图层显示。点击地图后,会动态加载格网图层,展示效果良好,优于使用ECharts的实现。完整代码示例展示了点击地图触发格网加载的过程。

turf.js是mapbox官方推荐的进行空间分析的包,其优点在于强大且全面的空间分析功能,且支持geojson格式的输入,因此与Mapbox GL JS集成效果很好。

我们此处介绍Mapbox GL JS加载turf.js实时创建格网(渔网)的方法。

其效果如下:

turf.js能够指定格网大小、坐标等信息实时生成,其效率非常高,也可以在前端根据用户需求实时的生成格网了。生成结果为GeoJson格式,Mapbox根据其生成的结果直接加载。步骤如下:

1、turf.js生成格网(渔网)

turf.js使用turf.squareGrid(bbox, cellSide, options); 方法生成格网,返回格式为Geojson的featureCollection

    var bbox = [112, 22, 114, 23];  //格网坐标 minX,minY,maxX,maxY. modify here.
    var cellSide = 5;  //格网长度 
    var options = {units:'kilometers'};  //长度单位
    var squareGrid = turf.squareGrid(bbox, cellSide, options);  //生成格网

 2、MapBox加载格网

使用常规的addSource及addLayer即可加载,指定source的类型为geojson即可。

    map.addSource('gridsource', {
        type: 'geojson',
        data:squareGr
要在 React.jsMapbox 地图上实现测距功能,可以使用 Mapbox GL JS 库结合 Turf.js 库来实现。 首先,确保你已经在 React 项目中安装了 mapbox-gl 和 turf 库: ```shell npm install mapbox-gl turf ``` 然后,在你的 React 组件中引入所需的库: ```javascript import React, { useRef, useEffect } from 'react'; import mapboxgl from 'mapbox-gl'; import * as turf from '@turf/turf'; ``` 接下来,在你的组件函数中创建地图容器和引用: ```javascript const MapComponent = () => { const mapContainerRef = useRef(null); useEffect(() => { // 初始化地图 mapboxgl.accessToken = 'YOUR_MAPBOX_ACCESS_TOKEN'; const map = new mapboxgl.Map({ container: mapContainerRef.current, style: 'mapbox://styles/mapbox/streets-v11', center: [lng, lat], // 设置地图初始中心点经纬度 zoom: 10, // 设置初始缩放级别 }); // 添加地图控件 map.addControl(new mapboxgl.NavigationControl()); // 添加测距功能 let lineString = turf.lineString([]); let distance = 0; let measureStartPoint = null; map.on('click', (e) => { if (!measureStartPoint) { measureStartPoint = e.lngLat; } else { const endPoint = e.lngLat; distance += turf.distance(measureStartPoint, endPoint); lineString.geometry.coordinates.push([ measureStartPoint.lng, measureStartPoint.lat, ]); lineString.geometry.coordinates.push([endPoint.lng, endPoint.lat]); map.getSource('measure-line').setData(lineString); measureStartPoint = null; } }); map.on('load', () => { // 添加测距线 map.addSource('measure-line', { type: 'geojson', data: { type: 'Feature', geometry: lineString.geometry, }, }); map.addLayer({ id: 'measure-line', type: 'line', source: 'measure-line', paint: { 'line-color': '#0080ff', 'line-width': 2, }, }); }); return () => map.remove(); // 清除地图实例 }, []); return <div ref={mapContainerRef} style={{ width: '100%', height: '400px' }} />; }; ``` 请注意,上述代码中需要替换 `YOUR_MAPBOX_ACCESS_TOKEN` 为你自己的 Mapbox 访问令牌。 以上代码创建了一个地图容器和引用,并在组件加载时初始化地图。通过点击地图,你可以在不同位置之间绘制线段并计算总距离。测距线的样式可以根据需要进行自定义。 希望这可以帮助你在 React.jsMapbox 地图上实现测距功能!
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值