亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? gps.cpp

?? 一個簡單的Windows Serial通訊的范例 可接收GPS訊號并解析
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
        while(*(pChar+j) != COMMA)
        {
            qualityString[k] = *(pChar+j);
            j++;
            k++;
			if (k>=2) break;
        }
        lastCommaPosition = j;
        qualityString[k] = '\0';
		sscanf((char *)qualityString, "%d", &fix);
		//printf(" Fix:%d\n", fix);
		GPSfix=fix;

		/* Get number of satelites  */
        pChar = stringRead;
        j = lastCommaPosition + 1;
        k = 0;
        while(*(pChar+j) != COMMA)
        {
            SatelitesString[k] = *(pChar+j);
            j++;
            k++;
			if (k>=9) break;
        }
        lastCommaPosition = j;
        SatelitesString[k] = '\0';
        sscanf((char *)SatelitesString, "%d", &NumberOfSatelites);
		//printf("Number of Satelites:%d\n",NumberOfSatelites);

		GPSNumberOfSatelites=NumberOfSatelites;
        CompareValueAndCallBack();
    }
}


void GPRMC(unsigned char *RMCString)
{
    unsigned char  *pChar;
    unsigned char  *stringRead;
    unsigned int   j, k;                          /* dummy variable */
    //unsigned int     i;                           /* Number of chars read per GPS message string */
    unsigned char  timeString[12];
    unsigned char  latitudeString[11];
//    unsigned char  latitudeCardinalString[3];
    unsigned char  longitudeString[12];
//    unsigned char  longitudeCardinalString[3];
//    unsigned char  StatusString[3];
    unsigned char  SpeedString[10];

    unsigned  long utcTime;              /* Coordinated Universal Time and Eastern Standard Time */
    unsigned  long utcHour, estHour;
    unsigned  long utcMinutes, estMinutes;
    unsigned  long utcSeconds, estSeconds;
    unsigned  char lastCommaPosition;

    float        latitude;
    int          latDegrees;
    float        latMinutes;

    float        longitude;
    int          longDegrees;
    float        longMinutes;

    float speed;

    stringRead=RMCString;
	/* Check if string we collected is the $GPGGA message */
    if(RMCString[3] == 'R' && RMCString[4] == 'M' && RMCString[5] == 'C')
    {

	/*
	 ** RMC - Recommended Minimum Navigation Information
	 **                                                            12
	 **        1         2 3       4 5        6 7   8   9    10  11|
	 **        |         | |       | |        | |   |   |    |   | |
	 ** $--RMC,hhmmss.ss,A,llll.ll,a,yyyyy.yy,a,x.x,x.x,xxxx,x.x,a*hh<CR><LF>
	 **
	 ** Field Number:
	 **  1) UTC Time
	 **  2) Status, V = Navigation receiver warning
	 **  3) Latitude
	 **  4) N or S
	 **  5) Longitude
	 **  6) E or W
	 **  7) Speed over ground, knots
	 **  8) Track made good, degrees true
	 **  9) Date, ddmmyy
	 ** 10) Magnetic Variation, degrees
	 ** 11) E or W
	 ** 12) Checksum
	 */

        pChar = stringRead;

		/* Get UTC time */
        j = 7;                                    /* start of time field */
        k = 0;
        while(*(pChar+j) != COMMA)
        {
            timeString[k] = *(pChar+j);
            j++;
            k++;
			if (k>=11) break;
        }
        lastCommaPosition = j;
        timeString[k] = '\0';
        sscanf((char *)timeString, "%ld", &utcTime);
        utcHour = (utcTime/10000);                /* extract Hours from long */
                                                  /* extract minutes from long */
        utcMinutes = (utcTime - (utcHour*10000))/100;
                                                  /* extract seconds from long */
        utcSeconds = utcTime - (utcHour*10000) - (utcMinutes*100);

        if(utcHour >= 4 && utcHour <= 23) estHour = utcHour - 4;
        else estHour = utcHour + 20;
        estMinutes = utcMinutes;
        estSeconds = utcSeconds;

		/* NB: %02ld formats long to print 2 chars wide, padding with 0 if necessary */
        //printf("%02ld:%02ld:%02ld UTC = %02ld:%02ld:%02ld EST\n", utcHour, utcMinutes, utcSeconds, estHour, estMinutes, estSeconds);		
		GPSutcHour=utcHour; //setup GLOBAL GPS DATA
		GPSutcMinutes=utcMinutes;
		GPSutcSeconds=utcSeconds;

		/* 2)Get STATUS: V or A */
        pChar = stringRead;
        j = lastCommaPosition + 1;
        k = 0;
        while(*(pChar+j) != COMMA)
        {
            GPSStatusString[k] = *(pChar+j);
            k++;
            j++;
			if (k>=2) break;
        }
        lastCommaPosition = j;
        GPSStatusString[k] = '\0';
        //printf("Status:%s\n",StatusString);
		
		/* Get lattitude: ddmm.mmmm */
        pChar = stringRead;
        j = lastCommaPosition + 1;
        k = 0;
        while(*(pChar+j) != COMMA)
        {
            latitudeString[k] = *(pChar+j);
            j++;
            k++;
			if (k>=10) break;
        }
        lastCommaPosition = j;
        latitudeString[k] = '\0';

        sscanf((char *)latitudeString, "%f", &latitude);
        latDegrees = (int)(latitude/100);
        latMinutes = (float)(latitude - latDegrees*100);
        //printf("\t%02d DEG\t%2.4f MIN", latDegrees, latMinutes);
		
		GPSlatDegrees=latDegrees;//setup global data
		GPSlatMinutes=latMinutes;
		/* Get lattitude Cardinal direction */
        pChar = stringRead;
        j = lastCommaPosition + 1;
        k = 0;
        while(*(pChar+j) != COMMA)
        {
            GPSlatitudeCardinalString[k] = *(pChar+j);
            j++;
            k++;
			if (k>=2) break;
        }
        lastCommaPosition = j;
        GPSlatitudeCardinalString[k] = '\0';
        //printf(" %s\n", latitudeCardinalString);

		/* Get longitude: dddmm.mmmm */
        pChar = stringRead;
        j = lastCommaPosition + 1;
        k = 0;
        while(*(pChar+j) != COMMA)
        {
            longitudeString[k] = *(pChar+j);
            j++;
            k++;
			if (k>=11) break;
        }
        lastCommaPosition = j;
        longitudeString[k] = '\0';

        sscanf((char *)longitudeString, "%f", &longitude);
        longDegrees = (int)(longitude/100);
        longMinutes = (float)(longitude - longDegrees*100);
        //printf("\t%03d DEG\t%2.4f MIN", longDegrees, longMinutes);
		
		GPSlongDegrees=longDegrees;
		GPSlongMinutes=longMinutes;
		/* Get longtitude Cardinal direction */
        pChar = stringRead;
        j = lastCommaPosition + 1;
        k = 0;
        while(*(pChar+j) != COMMA)
        {
            GPSlongitudeCardinalString[k] = *(pChar+j);
            j++;
            k++;
			if (k>=2) break;
        }
        lastCommaPosition = j;
        GPSlongitudeCardinalString[k] = '\0';
        //printf(" %s\n", longitudeCardinalString);

		/* Get speed: x.x */
        pChar = stringRead;
        j = lastCommaPosition + 1;
        k = 0;
        while(*(pChar+j) != COMMA)
        {
            SpeedString[k] = *(pChar+j);
            j++;
            k++;
			if (k>=9) break;
        }
        lastCommaPosition = j;
        SpeedString[k] = '\0';

        sscanf((char *)SpeedString, "%f", &speed);
        GPSspeed=speed;
		//printf("\t%2.4f ", speed);

        CompareValueAndCallBack();
    }
}

void GPSParse(unsigned char *GPSString)
{
	
	memset(cGPSString,'0',100);
	strcpy((char *)cGPSString,(char *)GPSString);
	if (GPSCallBack[GPSStringComplete]!=NULL)//GPS string callback
		GPSCallBack[GPSStringComplete]();

	if(GPSString[3] == 'R' && GPSString[4] == 'M' && GPSString[5] == 'C')
    {
		GPRMC(GPSString);
	}
	else if(GPSString[3] == 'G' && GPSString[4] == 'G' && GPSString[5] == 'A')
	{
		GPGGA(GPSString);
	}
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产福利一区在线| 国内久久婷婷综合| 综合色中文字幕| 国产丝袜美腿一区二区三区| 国产亚洲一二三区| 欧美高清在线视频| 亚洲视频中文字幕| 亚洲精品免费电影| 亚瑟在线精品视频| 日本不卡视频在线| 国产麻豆视频精品| 成人国产精品免费网站| 91视频.com| 678五月天丁香亚洲综合网| 制服视频三区第一页精品| 日韩亚洲电影在线| 久久亚洲综合色一区二区三区| 精品国产伦一区二区三区免费| 久久综合成人精品亚洲另类欧美| 国产精品欧美久久久久无广告| 日韩一区欧美小说| 五月天精品一区二区三区| 毛片基地黄久久久久久天堂| 国产麻豆午夜三级精品| 日本韩国欧美在线| 日韩欧美一级二级| 日韩一区中文字幕| 日韩va欧美va亚洲va久久| 国产精选一区二区三区| 色屁屁一区二区| 日韩欧美资源站| 亚洲欧洲精品一区二区三区不卡| 亚洲福利电影网| 国产精品69毛片高清亚洲| 91激情在线视频| 精品久久久久久综合日本欧美| 国产欧美日韩在线视频| 午夜欧美视频在线观看 | 精品粉嫩超白一线天av| 亚洲欧洲日产国码二区| 久久99国产精品麻豆| 91丨九色丨蝌蚪富婆spa| 日韩西西人体444www| 亚洲情趣在线观看| 国产自产2019最新不卡| 91久久精品一区二区三区| 久久综合九色欧美综合狠狠| 五月天丁香久久| 色综合天天天天做夜夜夜夜做| 欧美成人艳星乳罩| 午夜精品福利久久久| 91一区在线观看| 久久精品人人做人人综合| 天堂蜜桃91精品| 色婷婷亚洲一区二区三区| 久久久.com| 国产麻豆视频精品| 日韩精品一区在线| 天天av天天翘天天综合网色鬼国产 | 国产99久久久久久免费看农村| 69久久99精品久久久久婷婷| 亚洲一区二区三区不卡国产欧美| 国产成人精品一区二| 欧美精品一区二区三区高清aⅴ | 亚洲日本欧美天堂| 国产精品69毛片高清亚洲| 精品电影一区二区三区| 美女视频黄久久| 日韩欧美国产1| 美腿丝袜在线亚洲一区| 欧美一区午夜精品| 日韩av网站在线观看| 欧美日韩国产综合久久| 亚洲一区免费在线观看| 欧美在线不卡一区| 亚洲高清免费在线| 欧美日韩国产美| 日韩成人精品在线| 日韩欧美亚洲一区二区| 韩国精品主播一区二区在线观看| 欧美日韩不卡视频| 麻豆免费看一区二区三区| 日韩免费视频线观看| 经典三级一区二区| 中文字幕欧美日本乱码一线二线| 粉嫩一区二区三区性色av| 国产精品久久久久一区二区三区共 | 日韩高清电影一区| 91精品国产高清一区二区三区蜜臀 | 国产呦萝稀缺另类资源| 久久久欧美精品sm网站| 成人午夜精品一区二区三区| 国产精品久久久久精k8| 91黄色免费版| 久久99精品国产| 久久久99精品久久| 日本久久一区二区三区| 日本成人超碰在线观看| 国产欧美视频一区二区| 欧美性一二三区| 韩国视频一区二区| 亚洲三级在线免费| 欧美一区二区三区白人| 成人一区二区三区| 亚洲午夜一区二区| 精品国产一区二区国模嫣然| 成人av在线资源网| 免费久久精品视频| 亚洲欧美二区三区| 精品少妇一区二区三区免费观看| 成人综合在线网站| 日韩av成人高清| 亚洲天堂2016| 精品动漫一区二区三区在线观看| 91小视频免费观看| 极品少妇一区二区三区精品视频| 日韩理论片一区二区| 欧美成人一区二区三区| 在线免费观看日本一区| 国产老女人精品毛片久久| 亚洲福利一区二区| 国产精品国产三级国产aⅴ原创| 欧美肥胖老妇做爰| 日本丶国产丶欧美色综合| 国产一区二区影院| 日韩不卡免费视频| 亚洲国产日产av| 中文字幕一区日韩精品欧美| 精品国一区二区三区| 欧美精品免费视频| 日本乱人伦aⅴ精品| 不卡一区二区中文字幕| 国产精品综合在线视频| 毛片av中文字幕一区二区| 亚洲国产日韩av| 一区二区三区四区在线播放| 欧美高清在线一区二区| 国产欧美日韩激情| 精品国产乱码久久久久久图片| 欧美日韩在线精品一区二区三区激情| 成人免费视频国产在线观看| 激情成人综合网| 麻豆精品一区二区| 蜜桃免费网站一区二区三区| 日韩精品电影在线| 免费人成在线不卡| 午夜精品久久久久久久久久久| 一区二区三区鲁丝不卡| 亚洲综合图片区| 一区二区三区在线免费播放| 亚洲精品欧美二区三区中文字幕| 中文字幕亚洲电影| 国产精品久久久久久久久免费丝袜| 久久精品一区蜜桃臀影院| 久久久久免费观看| 日本一区二区在线不卡| 中文在线免费一区三区高中清不卡| 久久亚洲捆绑美女| 国产日韩精品一区二区三区| 久久久久亚洲综合| 国产精品每日更新在线播放网址| 久久久精品综合| 国产精品久久久久久亚洲伦| 亚洲欧美区自拍先锋| 亚洲午夜在线观看视频在线| 日本不卡一区二区三区| 国内成人精品2018免费看| 国产传媒欧美日韩成人| 99久久精品99国产精品| 欧美性猛交一区二区三区精品| 欧美在线播放高清精品| 日韩欧美一区二区久久婷婷| 久久久不卡网国产精品一区| 1区2区3区国产精品| 亚洲狠狠爱一区二区三区| 美女任你摸久久| 成人av网站在线观看| 欧美日韩视频在线一区二区| 欧美电影免费观看高清完整版在| 国产日韩在线不卡| 亚洲一区二区欧美| 激情五月婷婷综合网| youjizz久久| 欧美日本视频在线| 久久一区二区三区四区| 一区二区三区四区亚洲| 看电影不卡的网站| 91美女在线看| 亚洲精品在线电影| 亚洲一区二区在线免费观看视频| 久久99精品久久久久久国产越南 | 国产福利91精品一区| 在线精品视频免费播放| 欧美成人福利视频| 亚洲精品乱码久久久久久黑人 | 国产精品一卡二卡在线观看| 91国偷自产一区二区三区成为亚洲经典 | 一区二区三区四区国产精品| 久久精品久久精品| 欧美最猛性xxxxx直播|