/************************************************************************************ * File Name: GpsData.c * Function Describe:´¦ÀíGPSÄ£¿é·¢»ØµÄÊý¾Ý£¬ÌáÈ¡µ½sutGpsInfo * Relate Module: * Explain: * Writer: ShiLiangWen * Date: 2015.5.26 $GPGGA,235957.003,,,,,0,0,,,M,,M,,*44 $GPGSA,A,1,,,,,,,,,,,,,,,*1E $GPGSV,1,1,00*79 $GPRMC,235957.003,V,,,,,0.00,0.00,050180,,,N*4D *************************************************************************************/ #define THIS_FILE_ID 10 //-------------------------------------------------------------------------------------------- #include "includes.h" GPS_DATA_TYPE GPS_Data_Type; SUT_GPS_INF sutGpsInfo; /************************************************************************************* * **************************************************************************************/ int HEX_2_INT32(int hex_val) { char tmp_buf[13] = {0}; int val; snprintf(tmp_buf, sizeof(tmp_buf), "%x", hex_val); val = atoi (tmp_buf); return val; } /************************************************************************************* * **************************************************************************************/ static unsigned char translate_digitAscii_to_bcd(char *ascii_number, unsigned char len, char *bcd_number) { int i, j; char temp[10] = ""; /* extra + and NULL */ unsigned char bcd_index = 0; /* Index into output bcd_number */ int num_len = len; /* Translate or skip over invalid characters */ for (i = 0, j = 0; i < num_len; i++) { temp[j++] = ascii_number[i] & 0x0F; } ascii_number[len] = 0; /* Now that temp has the bcd codes in natural order... Squish them together * and reverse the order per bcd coding. */ for (i = 0; i < j; i+=2) bcd_number[bcd_index++] = ((char)(temp[i] << 4)) | temp[i+1]; bcd_number[len] = 0; return 0; } /*===================================== UTC time:hms status latitue north? longitue east? ËÙ¶È(½Ú) ·½Î»½Ç UTC time ´ÅÆ«½Ç ·½Ïò ģʽ checksum $GPRMC hhmmss.sss A/V ddmm.mmmm N/S dddmm.mmmm E/W speed aspect ddmmyy 000-180 E/W A/D/E/N *hh For example: $GPRMC,024813.640,A,3158.4608,N,11848.3737,E,10.05,324.27,150706,,,A*50 */ #define GPRMC_UTC1_TOKEN_INDEX 0 #define GPRMC_STATUS_TOKEN_INDEX 1 #define GPRMC_LATITUE_TOKEN_INDEX 2 #define GPRMC_NORTH_TOKEN_INDEX 3 #define GPRMC_longitue_TOKEN_INDEX 4 #define GPRMC_EAST_TOKEN_INDEX 5 #define GPRMC_SPEED_TOKEN_INDEX 6 #define GPRMC_ASPECT_TOKEN_INDEX 7 #define GPRMC_UTC2_TOKEN_INDEX 8 #define GPRMC_HIGHT_TOKEN_INDEX 8 #define GPRMC_STARTNUM_TOKEN_INDEX 6 /************************************************************************************* * **************************************************************************************/ void process_gps_data(char *buf,uint32_t size) //ÕâÀïµÄbuf¾ÍÊÇ´ÓGPRMC,ºó¿ªÊ¼ { char tmp_char[16] = {0}; char bcd_tmp[8] = {0}; char *token[16] = {NULL}; char size_each_token[16] = {0}; unsigned char hh,hl; unsigned char token_index = 0; unsigned char j=0; int i = 0; int index = 0; int dig_bit_num = 0; int ptr_each = 0; unsigned short speed; unsigned short aspect; // char* g_cGetlongitude=NULL; // char* g_cGetlatitude=NULL; double speed_jie = 0.0; token[token_index] = buf; RunMake(THIS_FILE_ID); while(index < size ) { if(buf[index] == ',') { size_each_token[token_index] = ptr_each; if(ptr_each == 0) token[token_index] = NULL; //*(token[token_index] + ptr_each) = 0; // ptr_each = 0; token_index++; token[token_index] = buf+index+1; //skip this ',' if(*(token[token_index]+1) == '*') { size_each_token[token_index] = 1; //cut of *hh\r\n } } else { ptr_each++; } index++; } RunMake(THIS_FILE_ID); if(GPS_Data_Type==GNRMC) { //UTC time:hms if(token[GPRMC_UTC1_TOKEN_INDEX]) { memset(tmp_char , 0 ,sizeof(tmp_char)); memset(bcd_tmp , 0 ,sizeof(bcd_tmp)); strncpy((char*)tmp_char,(char*)token[0],size_each_token[0]); #if 1 for(i = 6; i < 9;i++) tmp_char[i] = tmp_char[i+1]; tmp_char[i]=0; sutGpsInfo.SendTime=atoi(tmp_char); //311410000 #else translate_digitAscii_to_bcd(tmp_char,6,bcd_tmp); //È¥µô.xx //СʱÐèÒª¼Ó8 ÒòΪ±±¾©ÊǶ«8Çø hl=bcd_tmp[0]&0x0f; hh=bcd_tmp[0]&0xf0; hl+=8; if(hl>=10){ hl-=10; hh+=0x10; //if(hh>0x20)hh=0; ´¦ÀíGPSʱ¼äÎÊÌâ V520_P1 } sutGpsInfo.hour=(hh | hl); sutGpsInfo.minu = bcd_tmp[1]; sutGpsInfo.sec = bcd_tmp[2]; #endif } RunMake(THIS_FILE_ID); //Fix status if(token[GPRMC_STATUS_TOKEN_INDEX]) { memset(tmp_char , 0 ,sizeof(tmp_char)); strncpy((char*)tmp_char,(char*)token[1],size_each_token[1]); //if(*tmp_char == 'A'){ if(*tmp_char == 'A'){ sutGpsInfo.isGpsValid = 1; //SlwTrace(INF,"sutGpsInfo.isGpsValid1!",1); }else{ sutGpsInfo.isGpsValid = 0; //SlwTrace(INF,"sutGpsInfo.isGpsNOtValid1!------------------",1); } } RunMake(THIS_FILE_ID); if(sutGpsInfo.isGpsValid == 0)return; //latitude γ¶È /*===================================== UTC time:hms status latitue north? longitue east? ËÙ¶È(½Ú) ·½Î»½Ç UTC time ´ÅÆ«½Ç ·½Ïò ģʽ checksum $GPRMC hhmmss.ss A/V ddmm.mmmm N/S dddmm.mmmm E/W speed aspect ddmmyy 000-180 E/W A/D/E/N *hh For example: $GPRMC,024813.640,A,3158.4608,N,11848.3737,E,010.5,324.7,150706,,,A*50 */ if(token[GPRMC_LATITUE_TOKEN_INDEX]) { RunMake(THIS_FILE_ID); memset(tmp_char , 0 ,sizeof(tmp_char)); memset(bcd_tmp , 0 ,sizeof(bcd_tmp)); strncpy((char*)(tmp_char+1),(char*)token[2],size_each_token[2]); tmp_char[0] = '0'; RunMake(THIS_FILE_ID); for(i = 5; i < 8;i++) tmp_char[i] = tmp_char[i+1]; tmp_char[8] = 0; //СÊýµãºóÃæÈ¥µô×îºó1λ translate_digitAscii_to_bcd(tmp_char,8,bcd_tmp); //È¥µô.xx //North or south memset(tmp_char , 0 ,sizeof(tmp_char)); if(token[GPRMC_NORTH_TOKEN_INDEX]) { strncpy((char*)tmp_char,(char*)token[3],size_each_token[3]); // if(*tmp_char == 'S') // bcd_tmp[0] |= 0x80; sutGpsInfo.NSFlag=*tmp_char; sutGpsInfo.latitue = (bcd_tmp[3] | (bcd_tmp[2] << 8) |(bcd_tmp[1] << 16) |(bcd_tmp[0] << 24)); } RunMake(THIS_FILE_ID); } //longitude ¾­¶È if(token[GPRMC_longitue_TOKEN_INDEX]) { memset(tmp_char , 0 ,sizeof(tmp_char)); memset(bcd_tmp , 0 ,sizeof(bcd_tmp)); RunMake(THIS_FILE_ID); strncpy((char*)tmp_char,(char*)token[4],size_each_token[4]); for(i = 5; i < 8;i++) tmp_char[i] = tmp_char[i+1]; tmp_char[8] = 0; translate_digitAscii_to_bcd(tmp_char,8,bcd_tmp); //È¥µô.xx RunMake(THIS_FILE_ID); //east or west if(token[GPRMC_EAST_TOKEN_INDEX]) { memset(tmp_char , 0 ,sizeof(tmp_char)); strncpy((char*)tmp_char,(char*)token[5],size_each_token[5]); // if(*tmp_char == 'W') // bcd_tmp[0] |= 0x80; sutGpsInfo.EWFlag=*tmp_char; sutGpsInfo.longitue = (bcd_tmp[3] | (bcd_tmp[2] << 8) |(bcd_tmp[1] << 16) |(bcd_tmp[0] << 24)); } } //Speed if(token[GPRMC_SPEED_TOKEN_INDEX]) { RunMake(THIS_FILE_ID); memset(tmp_char , 0 ,sizeof(tmp_char)); strncpy((char*)tmp_char,(char*)token[GPRMC_SPEED_TOKEN_INDEX],size_each_token[GPRMC_SPEED_TOKEN_INDEX]); index = 0; while(index < size_each_token[GPRMC_SPEED_TOKEN_INDEX]) { if(tmp_char[index] == '.') break; index++; } dig_bit_num = size_each_token[GPRMC_SPEED_TOKEN_INDEX]-index-1; //ÕâÀindex´ú±íСÊýµãÇ°ÓжàÉÙλ,dig_bit_num´ú±íСÊýµãºóÃæÓжàÉÙλ RunMake(THIS_FILE_ID); //ol_debug("dig_bit_num:%d,all len:%d",dig_bit_num,size_each_token[GPRMC_SPEED_TOKEN_INDEX]); #if 0 if(index == 3) { speed_jie = (tmp_char[0]-0x30)*100 + (tmp_char[1]-0x30)*10 + (tmp_char[2]-0x30); } else if(index == 2) { speed_jie = (tmp_char[0]-0x30)*10 + (tmp_char[1]-0x30); } else speed_jie = (tmp_char[0]-0x30); if(dig_bit_num > 0) speed_jie += (tmp_char[index+1]-0x30)*0.1; #else speed_jie = atoi(tmp_char); if(dig_bit_num>0) speed_jie += (tmp_char[index+1]-0x30)*0.1; #endif speed = (unsigned short)(speed_jie*1.852); sutGpsInfo.speed = ( ((speed/100)<<8) | (((speed /10)%10)<<4) | (speed %10) ); //ol_debug("speed_jie to speed:%d,xinan speed:%d",speed,sutGpsInfo.speed); } RunMake(THIS_FILE_ID); //Aspect ·½Ïò if(token[GPRMC_ASPECT_TOKEN_INDEX]) { memset(tmp_char , 0 ,sizeof(tmp_char)); strncpy((char*)tmp_char,(char*)token[GPRMC_ASPECT_TOKEN_INDEX],size_each_token[GPRMC_ASPECT_TOKEN_INDEX]); // #if 0 // aspect = (unsigned short)((tmp_char[0]-0x30)*100 // + (tmp_char[1]-0x30)*10 // + (tmp_char[2]-0x30)); // //aspect = 150; // sutGpsInfo.aspect= ( ((aspect/100) << 8) | (((aspect /10)%10)<<4) | (aspect %10) ); // // #else // aspect=atoi(tmp_char); // aspect %=360; // sutGpsInfo.aspect= ( ((aspect/100) << 8) | (((aspect /10)%10)<<4) | (aspect %10) ); // #endif i=0; j=0; while(tmp_char[i]){ if(*tmp_char=='.'){ //bcd_tmp i++; bcd_tmp[j]=tmp_char[i]; break; } bcd_tmp[j]=tmp_char[i]; j++; i++; } sutGpsInfo.aspect=atoi(bcd_tmp); //printf("get GPS aspect--------------------------%d-----------\r\n",sutGpsInfo.aspect); } RunMake(THIS_FILE_ID); //UTC2 if(token[GPRMC_UTC2_TOKEN_INDEX]) { memset(tmp_char , 0 ,sizeof(tmp_char)); memset(bcd_tmp , 0 ,sizeof(bcd_tmp)); strncpy((char*)tmp_char,(char*)token[GPRMC_UTC2_TOKEN_INDEX],size_each_token[GPRMC_UTC2_TOKEN_INDEX]); translate_digitAscii_to_bcd(tmp_char,6,bcd_tmp); sutGpsInfo.day = bcd_tmp[0]; sutGpsInfo.month= bcd_tmp[1]; sutGpsInfo.year = bcd_tmp[2]; } } if(GPS_Data_Type==GNGGA){ //printf("get GPS GNGGA-------------------------------------\r\n"); if(token[GPRMC_STARTNUM_TOKEN_INDEX]) { strncpy((char*)tmp_char,(char*)token[GPRMC_STARTNUM_TOKEN_INDEX],size_each_token[GPRMC_STARTNUM_TOKEN_INDEX]); // bcd_tmp[0]=tmp_char[0]; // bcd_tmp[1]=tmp_char[1]; // bcd_tmp[2]=0; sutGpsInfo.startnum=atoi(tmp_char); //printf("get GPS startnum--------------------------%d-----------\r\n",sutGpsInfo.startnum); } if(token[GPRMC_HIGHT_TOKEN_INDEX]) { memset(tmp_char , 0 ,sizeof(tmp_char)); strncpy((char*)tmp_char,(char*)token[GPRMC_HIGHT_TOKEN_INDEX],size_each_token[GPRMC_HIGHT_TOKEN_INDEX]); // bcd_tmp for(i=0,j=0;i2){ sucCt=0; } len=strlen(&nema[7]); if(len>(UART3_RX_BUFFER_SIZE-10)){ SlwTrace(INF,"UART2RECV OVER!",1); } //printf("buffer3==%s\r\n",nema); process_gps_data(&nema[7],len); sutGpsInfo.isGpsWork=1; sutGpsInfo.GpsOpened=1; sutGpsInfo.GpsInactiveCt=0; }