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 项目。
登录后查看全文
热门项目推荐
相关项目推荐
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0235
GLM-5.2智谱开源 GLM-5.2,这是针对长文本任务的最新旗舰模型。相较于前代产品 GLM-5.1,它在长文本任务处理能力上实现了显著飞跃,并且首次在稳定的 100 万 token 上下文中提供这一能力。Jinja00
JoyAI-VL-Interaction-Preview京东开源首个开源、视觉驱动的实时交互模型——它能实时监控视频流,并自主决定何时发言、保持沉默或委托任务。Jinja00
cann-learning-hubCANN 学习中心仓,支持在线互动运行、边学边练,提供教程、示例与优化方案,一站式助力昇腾开发者快速上手。Jupyter Notebook0161
kornia🐍 空间人工智能的几何计算机视觉库Python02
PaddleParallel Distributed Deep Learning: Machine Learning Framework from Industrial Practice (『飞桨』核心框架,深度学习&机器学习高性能单机、分布式训练和跨平台部署)C++02
热门内容推荐
最新内容推荐
项目优选
收起
暂无描述
Dockerfile
782
5.13 K
本项目是CANN提供的transformer类大模型算子库,实现网络在NPU上加速计算。
C++
892
2.06 K
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
471
476
Ascend Extension for PyTorch
Python
763
980
本项目是CANN提供的神经网络类计算算子库,实现网络在NPU上加速计算。
C++
712
1.44 K
deepin linux kernel
C
32
16
CANN 学习中心仓,支持在线互动运行、边学边练,提供教程、示例与优化方案,一站式助力昇腾开发者快速上手。
Jupyter Notebook
446
159
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
1.11 K
1.15 K
JiuwenSwarm 是一款基于openJiuwen开发的智能AI Agent,它能够将大语言模型的强大能力,通过你日常使用的各类通讯应用,直接延伸至你的指尖。
Python
2.42 K
683
本仓库是 Flutter SDK 与 Flutter Engine 的 OpenHarmony 适配版本,由 CPF-Flutter 团队维护。开发者可使用熟悉的 Flutter 技术栈开发 OpenHarmony 应用,3.35.7 及以后的适配版本可基于本仓库源码构建支持 OpenHarmony 的 Flutter Engine。
Dart
1.05 K
273