GeokitPHP 地理工具包

联合创作 · 2023-09-28 00:23

Geokit 是一个 PHP 工具包,用于解决与地理相关的任务,例如:

  • 距离计算。
  • 航向、中点和终点计算。
  • 矩形边界框计算。

安装

使用 Composer 安装最新版本

composer require geokit/geokit

检查 Packagist 页面以获取所有可用版本。

参考

距离

距离实例允许方便地表示距离测量单位。

use Geokit\Distance;

$distance = new Distance(1000); // Defaults to meters
// or
$distance = new Distance(1, Distance::UNIT_KILOMETERS);

$meters = $distance->meters();
$kilometers = $distance->kilometers();
$miles = $distance->miles();
$yards = $distance->yards();
$feet = $distance->feet();
$inches = $distance->inches();
$nauticalMiles = $distance->nautical();
 

距离也可以从带有可选单位的字符串中创建。

use Geokit\Distance;

$distance = Distance::fromString('1000'); // Defaults to meters
$distance = Distance::fromString('1000m');
$distance = Distance::fromString('1km');
$distance = Distance::fromString('100 miles');
$distance = Distance::fromString('100 yards');
$distance = Distance::fromString('1 foot');
$distance = Distance::fromString('1 inch');
$distance = Distance::fromString('234nm');

位置

APosition是在x(或longitude)和y(或latitude)坐标中表示地理位置的基本结构 。

  • 经度范围在 -180 度和 180 度之间,包括端值。高于 180 或低于 -180 的经度被归一化。例如,480、840 和 1200 都将归一化为 120 度。
  • 纬度范围在 -90 度和 90 度之间(含)。高于 90 或低于 -90 的纬度被归一化。例如,100 将归一化为 80 度。
use Geokit\Position;

$position = Position::fromXY(181, 91);

$x = $position->x(); // Returns -179.0, normalized
$y = $position->y(); // Returns 89.0, normalized

边界框

BoundingBox 实例表示地理坐标中的一个矩形,包括一个跨越 180 度纵向子午线的矩形。

它由左下(西南)和右上(东北)角点构成。

use Geokit\BoundingBox;
use Geokit\Position;

$southWest = Position::fromXY(2, 1);
$northEast = Position::fromXY(2, 1);

$boundingBox = BoundingBox::fromCornerPositions($southWest, $northEast);

$southWestPosition = $boundingBox->southWest();
$northEastPosition = $boundingBox->northEast();

$center = $boundingBox->center();

$span = $boundingBox->span();

$boolean = $boundingBox->contains($position);

$newBoundingBox = $boundingBox->extend($position);
$newBoundingBox = $boundingBox->union($otherBoundingBox);

使用expand()shrink()方法,可以按一定距离扩展或缩小 BoundingBox 实例。

use Geokit\Distance;

$expandedBoundingBox = $boundingBox->expand(
    Distance::fromString('10km')
);

$shrinkedBoundingBox = $boundingBox->shrink(
    Distance::fromString('10km')
);

 

 

浏览 7
点赞
评论
收藏
分享

手机扫一扫分享

编辑 分享
举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

编辑 分享
举报