Geolib 项目技术文档
2024-12-24 11:13:15作者:范靓好Udolf
1. 安装指南
使用 npm 安装
npm install geolib
使用 yarn 安装
yarn add geolib
2. 项目的使用说明
概述
Geolib 是一个用于基本地理空间操作的库,例如距离计算、十进制坐标与六十进制坐标的转换等。该库目前是 2D 的,意味着它不支持海拔/高度的计算。
使用方式
Geolib 提供了 UMD 和 ES Module 两种构建方式。你可以根据项目需求选择合适的方式进行使用。
在 Node.js 中使用
const geolib = require('geolib');
在浏览器中使用
<script src="lib/geolib.js"></script>
在浏览器中加载后,可以通过 window.geolib 访问所有函数。
使用 ES Module
如果你使用的是支持 ES Module 的环境(如 Webpack 或 Parcel),可以直接导入需要的函数:
import { getDistance } from 'geolib';
或者导入整个库:
import * as geolib from 'geolib';
为了更好地利用 treeshaking,推荐直接导入单个函数:
import getDistance from 'geolib/es/getDistance';
3. 项目API使用文档
常用函数
getDistance(start, end, accuracy = 1)
计算两个地理坐标之间的距离。
start和end:必须是有效的GeolibInputCoordinates,例如{latitude: 52.518611, longitude: 13.408056}。accuracy:精度(单位:米),默认值为 1 米。
getDistance(
{ latitude: 51.5103, longitude: 7.49347 },
{ latitude: "51° 31' N", longitude: "7° 28' E" }
);
返回值为以米为单位的距离。
getPreciseDistance(start, end, accuracy = 1)
计算两个地理坐标之间的精确距离,使用 Vincenty 反算公式,适用于长距离计算。
geolib.getPreciseDistance(
{ latitude: 51.5103, longitude: 7.49347 },
{ latitude: "51° 31' N", longitude: "7° 28' E" }
);
getCenter(coords)
计算一组地理坐标的中心点。
geolib.getCenter([
{ latitude: 52.516272, longitude: 13.377722 },
{ latitude: 51.515, longitude: 7.453619 },
{ latitude: 51.503333, longitude: -0.119722 },
]);
返回值为包含 latitude 和 longitude 的对象。
getCenterOfBounds(coords)
计算一组地理坐标的边界中心点。
geolib.getCenterOfBounds([
{ latitude: 51.513357512, longitude: 7.45574331 },
{ latitude: 51.515400598, longitude: 7.45518541 },
{ latitude: 51.516241842, longitude: 7.456494328 },
{ latitude: 51.516722545, longitude: 7.459863183 },
{ latitude: 51.517443592, longitude: 7.463232037 },
]);
返回值为包含 latitude 和 longitude 的对象。
getBounds(points)
计算一组地理坐标的边界。
geolib.getBounds([
{ latitude: 52.516272, longitude: 13.377722 },
{ latitude: 51.515, longitude: 7.453619 },
{ latitude: 51.503333, longitude: -0.119722 },
]);
返回值为包含 minLat、maxLat、minLng 和 maxLng 的对象。
isPointInPolygon(point, polygon)
检查一个点是否在多边形内。
geolib.isPointInPolygon({ latitude: 51.5125, longitude: 7.485 }, [
{ latitude: 51.5, longitude: 7.4 },
{ latitude: 51.555, longitude: 7.4 },
{ latitude: 51.555, longitude: 7.625 },
{ latitude: 51.5125, longitude: 7.625 },
]);
返回值为 true 或 false。
isPointWithinRadius(point, centerPoint, radius)
检查一个点是否在圆内。
geolib.isPointWithinRadius(
{ latitude: 51.525, longitude: 7.4575 },
{ latitude: 51.5175, longitude: 7.4678 },
5000
);
返回值为 true 或 false。
4. 项目安装方式
通过 npm 安装
npm install geolib
通过 yarn 安装
yarn add geolib
以上是 Geolib 项目的详细技术文档,涵盖了安装、使用说明、API 文档以及安装方式。希望这份文档能帮助你更好地理解和使用 Geolib 项目。
登录后查看全文
热门项目推荐
相关项目推荐
Kimi-K2.5Kimi K2.5 是一款开源的原生多模态智能体模型,它在 Kimi-K2-Base 的基础上,通过对约 15 万亿混合视觉和文本 tokens 进行持续预训练构建而成。该模型将视觉与语言理解、高级智能体能力、即时模式与思考模式,以及对话式与智能体范式无缝融合。Python00
GLM-4.7-FlashGLM-4.7-Flash 是一款 30B-A3B MoE 模型。作为 30B 级别中的佼佼者,GLM-4.7-Flash 为追求性能与效率平衡的轻量化部署提供了全新选择。Jinja00
VLOOKVLOOK™ 是优雅好用的 Typora/Markdown 主题包和增强插件。 VLOOK™ is an elegant and practical THEME PACKAGE × ENHANCEMENT PLUGIN for Typora/Markdown.Less00
PaddleOCR-VL-1.5PaddleOCR-VL-1.5 是 PaddleOCR-VL 的新一代进阶模型,在 OmniDocBench v1.5 上实现了 94.5% 的全新 state-of-the-art 准确率。 为了严格评估模型在真实物理畸变下的鲁棒性——包括扫描伪影、倾斜、扭曲、屏幕拍摄和光照变化——我们提出了 Real5-OmniDocBench 基准测试集。实验结果表明,该增强模型在新构建的基准测试集上达到了 SOTA 性能。此外,我们通过整合印章识别和文本检测识别(text spotting)任务扩展了模型的能力,同时保持 0.9B 的超紧凑 VLM 规模,具备高效率特性。Python00
KuiklyUI基于KMP技术的高性能、全平台开发框架,具备统一代码库、极致易用性和动态灵活性。 Provide a high-performance, full-platform development framework with unified codebase, ultimate ease of use, and dynamic flexibility. 注意:本仓库为Github仓库镜像,PR或Issue请移步至Github发起,感谢支持!Kotlin07
compass-metrics-modelMetrics model project for the OSS CompassPython00
项目优选
收起
deepin linux kernel
C
27
11
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
523
3.72 K
Ascend Extension for PyTorch
Python
328
387
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
876
576
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
335
161
暂无简介
Dart
762
187
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.33 K
745
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
12
1
React Native鸿蒙化仓库
JavaScript
302
349
华为昇腾面向大规模分布式训练的多模态大模型套件,支撑多模态生成、多模态理解。
Python
112
136