【免费分享】GIS开发面试题(流程+自我介绍+基础篇+Openlayer&mapbox)

本篇文章针对GIS应届生就业方向及面试困惑问题进行了收集整理,并列出了关于GIS开发面试中常见的问题(含答案)。

图片

包括以下内容

前言

简介

面试之前

面试流程

自我介绍-AI

基础篇

1、GIS八股文基础篇

2、Openlayers图形绘制

3、倾斜摄影

主流地图的坐标系

常用的坐标转换软件

6、地图上要素很多,加载慢,遇到过崩掉的情况么,前端是如何缓解的

7、二维和三维的区别

8、mapbox和Cesium的区别

9、天地图的地理坐标系,投影坐标系和地理坐标系区别

10、openlayer加载栅格服务需要那些信息

11、geojson

12、空间分析的常见方法

13、经纬度坐标和投影坐标的区别14、地心坐标系和参心坐标系的区别

15、GIS中投影坐标系有哪些

16、常见的空间数据库

17、地理坐标系如何测量距离

Openlayer&mapbox

1、0penlayer如何查询要素

2、Openlayers加载geojson

3、使用了openlayer哪些地图的功能

4、openlayer添加图层到指定位置

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在 React.js 和 Mapbox 地图上实现测距功能,可以使用 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.js 和 Mapbox 地图上实现测距功能!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值