[ARDrone] Fix GPS orientation

Add condition South and East for négative latitude/longitude.
This commit is contained in:
Florian Taillard 2011-05-03 13:55:57 +02:00
parent 3b2823fef9
commit 46292cfe8c
1 changed files with 153 additions and 170 deletions

View File

@ -64,8 +64,10 @@ uint8_t *packet = NULL ; // Packet to send
uint_fast16_t packet_size ; // Packet size
// Shared variables for OwlSIG (Geo Information System)
float share_x, share_y, share_z;
double share_x, share_y, share_z;
double share_lat, share_lon, share_alt=0;
double share_lat_cons=-999.0, share_lon_cons=-999.00, share_alt_cons=-999.0;
double share_x_cons=-999.0, share_y_cons=-999.00, share_z_cons=-999.0, share_t_cons=-999.0;
int main(int argc, char *argv[])
{
@ -106,30 +108,37 @@ void parse_command_line(int argc, char **argv)
#endif // DEBUG
}
void traficGPS(int gps) {
void traficGPS(int gps)
{
int offset=0, c=1, i=0, l;
char buffer[4096], chtime[1024];
char *utc, *latitude, *longitude, *chv, *cmd, *ch;
float vitesse;
do {
do
{
c=read(gps, buffer, 4096);
printf("lecture intiale %d\n",c);
} while (c>99);
do {
}
while (c>99);
do
{
c=read(gps, buffer+offset, 1);
offset=offset+c;
} while (buffer[offset-c]!='$');
}
while (buffer[offset-c]!='$');
//buffer[offset]='\0';
//printf("phrase x%sx\n",buffer);
// Debut de phrase GPS sans le dollar
while (1) {
i=0;
offset=0;
do {
do
{
c=read(gps, buffer+offset, 1);
offset=offset+c;
} while (buffer[offset-c]!='$');
}
while (buffer[offset-c]!='$');
//buffer[offset]='\0';
//printf("phrase s x%sx\n",buffer);
if (strncmp(buffer+i,"GPRMC",5)==0)
@ -188,9 +197,12 @@ void traficGPS(int gps) {
datagps.date = atoi(data[9]);
datagps.decmag = atof(data[10]);
if (datagps.orilat=='S') datagps.latitude=-datagps.latitude;
if (datagps.orilon=='W') datagps.longitude=-datagps.longitude;
share_lat=datagps.latitude;
share_lon=datagps.longitude;
printf("Time : %f | State : %c | Latitude : %f%c | Longitude %f%c | Speed : %f km/h | Cap : %f° | Date : %d | DecMagn : %f \n",datagps.time, datagps.state, datagps.latitude, datagps.orilat, datagps.longitude, datagps.orilon, datagps.speed, datagps.cap, datagps.date, datagps.decmag);
printf("lat %s lon %s\n",data[3], data[5]);
printf("Time : %f | State : %c | Latitude : %.10f%c | Longitude %.10f%c | Speed : %f km/h | Cap : %f° | Date : %d | DecMagn : %f maps %.10f %.10f\n",datagps.time, datagps.state, datagps.latitude, datagps.orilat, datagps.longitude, datagps.orilon, datagps.speed, datagps.cap, datagps.date, datagps.decmag, share_lat, share_lon);
/* printf("Taille : %d | Message : %s\n",strlen(buffer+i),buffer+i);
@ -230,6 +242,7 @@ void* thread_send(void* data)
{
make_packet() ;
send_request() ;
sleep(1) ;
}
return NULL;
}
@ -237,45 +250,6 @@ void* thread_send(void* data)
// TCP Server OwlSIG
void* thread_control(void* data)
{
<<<<<<< HEAD
int sockfd, newsockfd, portno=8080;
socklen_t clilen;
char request[1024], response[1204];
struct sockaddr_in serv_addr, cli_addr;
int n;
sockfd = socket(AF_INET, SOCK_STREAM, 0);
if (sockfd < 0)
error("ERROR opening socket TCP");
bzero((char *) &serv_addr, sizeof(serv_addr));
serv_addr.sin_family = AF_INET;
serv_addr.sin_addr.s_addr = INADDR_ANY;
serv_addr.sin_port = htons(portno);
if (bind(sockfd, (struct sockaddr *) &serv_addr, sizeof(serv_addr)) < 0)
error("ERROR on binding");
listen(sockfd,1);
clilen = sizeof(cli_addr);
while (1)
{
newsockfd = accept(sockfd, (struct sockaddr *) &cli_addr, &clilen);
if (newsockfd < 0)
error("ERROR on accept");
bzero(request,1024);
while ( strcmp(request,"end")!=0) {
n = read(newsockfd,request,1024);
if (n < 0) perror("ERROR reading from socket");
printf("%s", request);
// Add command processing
sprintf(response,"Position;OK;1.2;3.4;0.0");
//sprintf(response,"Position;OK;%f;%f;%f",share_x, share_y, share_z);
n = write(newsockfd,response,strlen(response));
if (n < 0) perror("ERROR writing to socket");
}
close(newsockfd);
close(sockfd);
}
return NULL;
=======
int sockfd, newsockfd, portno=8080;
socklen_t clilen;
char request[2048], response[2048], *c;
@ -324,10 +298,20 @@ strcpy(response,"HTTP/1.1 200 OK\nDate: Mon, 18 Apr 2011 19:51:52 GMT\nServer: A
sprintf(response,"%sPosition;OK;%d.0;5.0;6.1\n",response,i++);
else if (strcmp(cmd, "ReadGeoPosition")==0)
sprintf(response,"%sGeoPosition;OK;%f;%f;%f\n",response,share_lat,share_lon,share_alt);
else if (strcmp(cmd, "SendGeoSetpoint")==0)
sprintf(response,"%sGeoSetpoint;OK;%d.0;5.0;6.1;0.0\n",response,i++);
else if (strcmp(cmd, "SendSetpoint")==0)
sprintf(response,"%sSetpoint;OK;%s;%s;%s;%s\n",response,sx,sy,sz,st);
else if (strcmp(cmd, "SendGeoSetpoint")==0) {
share_lat_cons=atof(sx);
share_lon_cons=atof(sy);
share_alt_cons=atof(sz);
share_t_cons=atof(st);
sprintf(response,"%sGeoSetpoint;OK;%.15f;%.15f;%f;%f\n",response,share_lat_cons,share_lon_cons,share_alt_cons,share_t_cons);
}
else if (strcmp(cmd, "SendSetpoint")==0) {
share_x_cons=atof(sx);
share_y_cons=atof(sy);
share_z_cons=atof(sz);
share_t_cons=atof(st);
sprintf(response,"%sSetpoint;OK;%f;%f;%f;%f\n",response,share_x_cons,share_y_cons,share_z_cons,share_t_cons);
}
else
strcat(response,"Not understand\n");
n = write(newsockfd,response,strlen(response));
@ -339,7 +323,6 @@ strcpy(response,"HTTP/1.1 200 OK\nDate: Mon, 18 Apr 2011 19:51:52 GMT\nServer: A
}
close(sockfd);
return NULL;
>>>>>>> ea33a1a... [ARDrone] Add support GPS NMEA
}
void parse_main_options(int argc, char **argv)