Scripts

wgs84 cords to decimaal

Het omvormen van wgs84 tot decimaal VB:N53° 34.127 E006° 44.986 Breedtegraad (decimaal): 53.568783333333 Lengtegraad (decimaal): 6.7497666666667

dmstodecimal.php
<?php
function DMSToDecimal($dms) {
	
    //preg_match('/([NS])(\d+)° (\d+\.\d+)/', $dms, $latMatches);
    //preg_match('/([EW])(\d+)° (\d+\.\d+)/', $dms, $lonMatches);
	preg_match('/([NS])(\d+)[^0-9]+(\d+\.\d+)/', $dms, $latMatches);
    preg_match('/([EW])(\d+)[^0-9]+(\d+\.\d+)/', $dms, $lonMatches);

    if (!empty($latMatches)) {
        $latDirection = $latMatches[1];
        $latDegrees = (float)$latMatches[2];
        $latMinutes = (float)$latMatches[3];

        $latitude = ($latDirection === 'N') ? ($latDegrees + ($latMinutes / 60)) : -($latDegrees + ($latMinutes / 60));
    } else {
        return false; // Invalid latitude format
    }

    if (!empty($lonMatches)) {
        $lonDirection = $lonMatches[1];
        $lonDegrees = (float)$lonMatches[2];
        $lonMinutes = (float)$lonMatches[3];

        $longitude = ($lonDirection === 'E') ? ($lonDegrees + ($lonMinutes / 60)) : -($lonDegrees + ($lonMinutes / 60));
    } else {
        return false; // Invalid longitude format
    }

    return ['latitude' => $latitude, 'longitude' => $longitude];
}

$dmsLatitude = "N53° 34.127";
$dmsLongitude = "E006° 44.986";

$coordinates = DMSToDecimal($dmsLatitude . " " . $dmsLongitude);

if ($coordinates) {
    $latitude = $coordinates['latitude'];
    $longitude = $coordinates['longitude'];
    
    echo "Breedtegraad (decimaal): $latitude<br>";
    echo "Lengtegraad (decimaal): $longitude<br>";
} else {
    echo "Ongeldige DMS-coördinaten.";
}
?>
 

Reacties

0
Nog geen reacties.