我正在使用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;
}
这是假设从多边形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
我不明白的是,这些面积是使用GeoPHP计算出来的。那里的文件根本没有单元吗?
当我转换为英亩时,round($acre, 2)
的值为零。这些多边形面积应在5到15英亩之间。
有人知道如何将面积转换为英亩或km2吗?
谢谢。
答案 0 :(得分:1)
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();
注意:该库不支持MultiPolygon类型,因此您必须循环几何图形并分别获取每个Polygon的面积。