Converting Degree, Minutes, Seconds (DMS) para decimal em PHP

Atualmente, estou aprendendo a usar a API do Google Maps. Pelo que leio, a API exige a latitude e a longitude no Grau Decimal (DD).

No meu database, os dados são armazenados como DMS.

Exemplo 110 ° 29 ‘01.1 ”

Gostaria de perguntar se vocês têm algum DMS para DD em php. E, o conversor deve aceitar de uma única seqüência de caracteres como o exemplo acima.

Saudações

Você pode tentar se isso está funcionando para você.

$deg,"min"=>$min,"sec"=>$sec); } ?> 

Resolvido.

   Input is ".$input." 
"; for ($i=0; $i < strlen($input); $i++) { $tempD = $input[$i]; //print "
TempD [$i] is : $tempD"; if ($tempD == iconv("UTF-8", "ISO-8859-1//TRANSLIT", '°') ) { $newI = $i + 1 ; //print "
newI is : $newI"; $inputM = substr($input, $newI, -1) ; break; }//close if degree $deg .= $tempD ; }//close for degree //print "InputM is ".$inputM."
"; for ($j=0; $j < strlen($inputM); $j++) { $tempM = $inputM[$j]; //print "
TempM [$j] is : $tempM"; if ($tempM == "'") { $newI = $j + 1 ; //print "
newI is : $newI"; $sec = substr($inputM, $newI, -1) ; break; }//close if minute $min .= $tempM ; }//close for min $result = $deg+( (( $min*60)+($sec) ) /3600 ); print "
Degree is ". $deg*1 ; print "
Minutes is ". $min ; print "
Seconds is ". $sec ; print "
Result is ". $result ; return $deg + ($min / 60) + ($sec / 3600); } ?>

Aqui é onde você passa a latitude, longitude em valores DMS e retorna a seqüência DMS convertida. Fácil e simnple

 function DECtoDMS($latitude, $longitude) { $latitudeDirection = $latitude < 0 ? 'S': 'N'; $longitudeDirection = $longitude < 0 ? 'W': 'E'; $latitudeNotation = $latitude < 0 ? '-': ''; $longitudeNotation = $longitude < 0 ? '-': ''; $latitudeInDegrees = floor(abs($latitude)); $longitudeInDegrees = floor(abs($longitude)); $latitudeDecimal = abs($latitude)-$latitudeInDegrees; $longitudeDecimal = abs($longitude)-$longitudeInDegrees; $_precision = 3; $latitudeMinutes = round($latitudeDecimal*60,$_precision); $longitudeMinutes = round($longitudeDecimal*60,$_precision); return sprintf('%s%s° %s %s %s%s° %s %s', $latitudeNotation, $latitudeInDegrees, $latitudeMinutes, $latitudeDirection, $longitudeNotation, $longitudeInDegrees, $longitudeMinutes, $longitudeDirection ); } 

Eu escrevi uma function PHP que faz o que a pergunta faz: converte uma string em graus / minutos / segundos em graus decimais. Ele aceita vários formatos diferentes para a string e direção de honras (NSEW).

Aqui está o código:

  1) { $temp = preg_replace('/\./', ' ', $latlng, $num_periods - 1); // replace all but last period with delimiter $temp = trim(preg_replace('/[a-zA-Z]/','',$temp)); // when counting chunks we only want numbers $chunk_count = count(explode(" ",$temp)); if ($chunk_count > 2) { $latlng = $temp; // remove last period } else { $latlng = str_replace("."," ",$latlng); // remove all periods, not enough chunks left by keeping last one } } // Remove unneeded characters $latlng = trim($latlng); $latlng = str_replace("º","",$latlng); $latlng = str_replace("'","",$latlng); $latlng = str_replace("\"","",$latlng); $latlng = substr($latlng,0,1) . str_replace('-', ' ', substr($latlng,1)); // remove all but first dash if ($latlng != "") { // DMS with the direction at the start of the string if (preg_match("/^([nsewNSEW]?)\s*(\d{1,3})\s+(\d{1,3})\s+(\d+\.?\d*)$/",$latlng,$matches)) { $valid = true; $degrees = intval($matches[2]); $minutes = intval($matches[3]); $seconds = floatval($matches[4]); if (strtoupper($matches[1]) == "S" || strtoupper($matches[1]) == "W") $direction = -1; } // DMS with the direction at the end of the string if (preg_match("/^(-?\d{1,3})\s+(\d{1,3})\s+(\d+(?:\.\d+)?)\s*([nsewNSEW]?)$/",$latlng,$matches)) { $valid = true; $degrees = intval($matches[1]); $minutes = intval($matches[2]); $seconds = floatval($matches[3]); if (strtoupper($matches[4]) == "S" || strtoupper($matches[4]) == "W" || $degrees < 0) { $direction = -1; $degrees = abs($degrees); } } if ($valid) { // A match was found, do the calculation $decimal_degrees = ($degrees + ($minutes / 60) + ($seconds / 3600)) * $direction; } else { // Decimal degrees with a direction at the start of the string if (preg_match("/^(-?\d+(?:\.\d+)?)\s*([nsewNSEW]?)$/",$latlng,$matches)) { $valid = true; if (strtoupper($matches[2]) == "S" || strtoupper($matches[2]) == "W" || $degrees < 0) { $direction = -1; $degrees = abs($degrees); } $decimal_degrees = $matches[1] * $direction; } // Decimal degrees with a direction at the end of the string if (preg_match("/^([nsewNSEW]?)\s*(\d+(?:\.\d+)?)$/",$latlng,$matches)) { $valid = true; if (strtoupper($matches[1]) == "S" || strtoupper($matches[1]) == "W") $direction = -1; $decimal_degrees = $matches[2] * $direction; } } } if ($valid) { return $decimal_degrees; } else { return false; } } ?> 

Aqui está no Github com casos de teste: https://github.com/prairiewest/PHPconvertDMSToDecimal

Isso funciona muito bem:

  $deg° $min' $sec″ "; ?> 

onde graus, min e seg são as coordenadas angulares.