Calculo - Sistema de Rastreamento

Olá amigos.

Tenho um cliente que comprou um software de rastreamento em PHP, a questão e que o cliente deseja um relatorio que informe a kilometragem que o veiculo rodou.

Peguei uma função:

<?php function distancia($lat1, $lon1, $lat2, $lon2, $unit) { $theta = $lon1 - $lon2; $dist = sin(deg2rad($lat1)) * sin(deg2rad($lat2)) + cos(deg2rad($lat1)) * cos(deg2rad($lat2)) * cos(deg2rad($theta)); $dist = acos($dist); $dist = rad2deg($dist); $miles = $dist * 60 * 1.1515; $unit = strtoupper($unit); if ($unit == "K") { return ($miles * 1.609344); } else if ($unit == "N") { return ($miles * 0.8684); } else { return $miles; } } ?>

Essa função pega os parametros longitude e lagitude e calcula a distancia em km.

Informei parametros fixo e a função esta funcionando correto.

Segue linha da tabela com os valores para vocês entenderem

id	date	                                imei	                                     	latitudes	Hemis	longitude	    Hemis	

899952 2014-11-17 01:16:32 359710045107894 A 0852.7093 S 03627.5916 W
899953 2014-11-17 01:16:34 359710045107894 A 0852.7093 S 03627.5916 W
899954 2014-11-17 01:16:36 359710045097251 A 0922.2971 S 04029.2716 W
899955 2014-11-17 01:16:38 359710044325562 A 0852.7154 S 03627.5417 W
899956 2014-11-17 01:16:46 359710045107894 A 0852.7093 S 03627.5916 W
899957 2014-11-17 01:16:49 359710044325562 A 0852.7154 S 03627.5417 W
899958 2014-11-17 01:16:50 359710045097251 A 0922.2971 S 04029.2716 W
899959 2014-11-17 01:16:53 359710044318401 A 0852.7145 S 03627.5656 W

Imaginei de fazer o seguinte:
O campo que identifica o veiculo e o IMEI a questão e que o sistema fica informando a cada 1 minuto a posição do veiculo.
Como isso não estou sabendo como pegar a ultima longitude e latitude para pode calcular a distancia.
Pensei em pegar fazendo um filtro por data e hora, tipo
no dia 02/12/2014 Hora 06:00:00 (pegar latitude e longitude)====> parametro 1
no dia 02/12/2014 Hora 07:00:00 (pegar latitude e longitude)====> parametro 2
Ou seja calcular de hora em hora
A questão e que estou sem saber exatamente como fazer esses select, pra filtrar por data e depois por hora.

Espero que tenham entendido, pois ate pra explicar e complicado.

Mas agradeço a ajuda de todos.

Paulo
Click Informatica

Ninguem tem um dica

Já existe esta função para acumular a distância no sistema de rastreamento adquirido pelo seu cliente, você vai ter que entrar em contato
para o pessoal te passar como pegar valor da km rodada.

Exemplo deste tipo de sistema:
http://www.ti5.com.br/phptrack

Eu pegaria a latitude e longitude origem e destino e usaria uma das apis do google para calcular a kilometragem da rota, depois e só ter o valor por km

Quilometragem Linear ou Trajetória.

trajeto

Eu quis dizer que com api do google você consegue as duas formas.