将GeoPHP getArea()值转换为km2或英亩

时间:2018-11-15 16:06:40

标签: php geojson

我正在使用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吗?

https://geophp.net/api.html

谢谢。

1 个答案:

答案 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的面积。