我正在使用GeoPHP来获取 GeoJson 多边形的面积。
下面是我的功能。
/**
* gets the areas in acres for field geojson polygons
* @return string
*/
public function polygon_area($json)
{
// get the geoPHP library
require_once(__DIR__ . '/vendor/GeoPHP/geoPHP.inc');
// create the json array as string
$geoJson = '{"type":"Polygon","coordinates":['.$json.']}';
// create the polygon geoPHP object
$polygon = geoPHP::load($geoJson,'json');
// the area of the polygon
$area = $polygon->getArea();
// convert area into acres
$acre = $area * 247.105;
// return the geophp area
return $area;
}
Run Code Online (Sandbox Code Playgroud)
假设从多边形 json 返回的面积为平方公里。但我不这么认为。
请参阅下面使用上述代码中的GeoPHP 函数返回的值。$polygon->getArea()
Area: 1.21816181142E-5
Area: 4.06926334051E-6
Area: 5.59853614135E-6
Area: 3.74998247921E-6
Area: 5.91964048269E-6
Area: 2.50475049057E-6
Area: 5.84341879772E-7
Area: 7.7207101441E-6
Area: 4.27298301986E-6
Area: 2.99669066806E-6
Area: 1.76724087666E-5
Run Code Online (Sandbox Code Playgroud)
我无法理解的是,使用GeoPHP计算这些区域的测量单位是什么。有没有任何单位的文档?
当我转换为英亩时,round($acre, 2)该值为零。这些多边形区域的面积应为 5 至 15 英亩。
有谁知道如何将面积转换为英亩或平方公里?
提前致谢。
GeoPHP 在面积计算中返回平方度。看看https://github.com/spinen/laravel-geometry。它基于phayes/geoPHP构建,并添加了 getSquareMeters() 和 getAcres() 方法。
在您的情况下,面积可以计算为:
// create the json array as string
$geoJson = '{"type":"Polygon","coordinates":['.$json.']}';
// create the polygon geoPHP object
$polygon = geoPHP::load($geoJson,'json');
// get the area in square meters
$areaSquareM = $polygon->getSquareMeters();
// convert to square kilometers
$areaSquareKm = $areaSquareM / 1000000;
// area in acres
$areaAcres = $polygon->getAcres();
Run Code Online (Sandbox Code Playgroud)
注意:该库不支持多多边形类型,因此您必须循环几何图形并单独获取每个多边形的面积。