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

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

?? gps.cpp

?? 一個簡單的Windows Serial通訊的范例 可接收GPS訊號并解析
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
#include "stdafx.h"
#include "Serial.h"

/* Some helpful defines */
#define SPACE     0x20
#define COMMA     0x2C
#define MAXSIZE    100                            /* GPS at most, sends 80 or so chars per message string.  So set maximum to 100 */

FireEvent (GPSCallBack)[MAX_HANDLER];

//GPS dll export data(GPRMC)
SERIAL_API int              GPSlatDegrees;
SERIAL_API float            GPSlatMinutes;
SERIAL_API unsigned char    GPSlatitudeCardinalString[3];
SERIAL_API int              GPSlongDegrees;
SERIAL_API float            GPSlongMinutes;
SERIAL_API unsigned char    GPSlongitudeCardinalString[3];
SERIAL_API unsigned  long   GPSutcHour;
SERIAL_API unsigned  long   GPSutcMinutes;
SERIAL_API unsigned  long   GPSutcSeconds; 
SERIAL_API float            GPSspeed;
SERIAL_API unsigned char    GPSStatusString[3];
//GPS dll export data(GPGGA)
SERIAL_API int              GPSfix;
SERIAL_API int              GPSNumberOfSatelites;
//GPSString
SERIAL_API unsigned char cGPSString[100];

//stored data

//GPS dll export data(GPRMC)
int              oGPSlatDegrees=0;
float            oGPSlatMinutes=0;
unsigned char    oGPSlatitudeCardinalString[3]="z";
int              oGPSlongDegrees=0;
float            oGPSlongMinutes=0;
unsigned char    oGPSlongitudeCardinalString[3]="z";
unsigned  long   oGPSutcHour=0;
unsigned  long   oGPSutcMinutes=0;
unsigned  long   oGPSutcSeconds=0; 
float            oGPSspeed=0;
unsigned char    oGPSStatusString[3]="z";
//GPS dll export data(GPGGA)
int              oGPSfix=0;
int              oGPSNumberOfSatelites=0;

//for .net


SERIAL_API void RegGPSCallBack(int HookNumber,FireEvent regfunc)
{
	GPSCallBack[HookNumber]=regfunc;
}
void CompareValueAndCallBack()
{
	

	if (oGPSlatDegrees!=GPSlatDegrees ||
		oGPSlatMinutes!=GPSlatMinutes ||
		strcmp((char *)oGPSlatitudeCardinalString,(char *)GPSlatitudeCardinalString)!=0 ||
		oGPSlongDegrees!=GPSlongDegrees ||
		oGPSlongMinutes!=GPSlongMinutes ||
		strcmp((char *)oGPSlongitudeCardinalString,(char *)GPSlongitudeCardinalString)!=0 ||
		oGPSutcHour!=GPSutcHour ||
		oGPSutcMinutes!=GPSutcMinutes ||
		oGPSutcSeconds!=GPSutcSeconds ||
		oGPSspeed!=GPSspeed ||
		strcmp((char *)oGPSStatusString,(char *)GPSStatusString)!=0 ||
		oGPSfix!=GPSfix ||
		oGPSNumberOfSatelites!=GPSNumberOfSatelites)
	{
		oGPSlatDegrees=GPSlatDegrees;
		oGPSlatMinutes=GPSlatMinutes;
		strncpy((char *)oGPSlatitudeCardinalString,(char *)GPSlatitudeCardinalString,3);
		oGPSlongDegrees=GPSlongDegrees;
		oGPSlongMinutes=GPSlongMinutes;
		strncpy((char *)oGPSlongitudeCardinalString,(char *)GPSlongitudeCardinalString,3);
		oGPSutcHour=GPSutcHour;
		oGPSutcMinutes=GPSutcMinutes;
		oGPSutcSeconds=GPSutcSeconds;
		oGPSspeed=GPSspeed;
		strncpy((char *)oGPSStatusString,(char *)GPSStatusString,3);
		oGPSfix=GPSfix;
		oGPSNumberOfSatelites=GPSNumberOfSatelites;
				
		if (GPSCallBack[GPSDataChange]!=NULL)
			GPSCallBack[GPSDataChange]();
		
	}
}
void GPGGA(unsigned char *GGAString)
{
    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  qualityString[3];
	unsigned char  SatelitesString[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;

	int          fix;
	int          NumberOfSatelites;

    stringRead=GGAString;
	/* Check if string we collected is the $GPGGA message */
    if(GGAString[3] == 'G' && GGAString[4] == 'G' && GGAString[5] == 'A')
    {
	/*
	Found GPGGA string.  It has 14 commas total.  Its NMEA sentence structure is:

	$GPGAA,hhmmss.ss,ddmm.mmmm,n,dddmm.mmmm,e,q,ss,y.y,a.a,z,g.g,z,t.t,iii*CC<CR><LF>
	|    |    |    |    |    |    |    |    |    |    |    |    |    |    |
	0   	   1         2         3         4         5         6         7
	0123456789012345678901234567890123456789012345678901234567890123456789012

	where:

	GPGAA		: GPS fixed data identifier
	hhmmss.ss	: Coordinated Universal Time (UTC), also known as GMT
	ddmm.mmmm,n	: Latitude in degrees, minutes and cardinal sign
	dddmm.mmmm,e	: Longitude in degrees, minutes and cardinal sign
	q		: Quality of fix.  1 = there is a fix
	ss		: Number of satellites being used
	y.y		: Horizontal dilution of precision
	a.a,M		: GPS antenna altitude in meters
	g.g,M		: geoidal separation in meters
	t.t		: Age of the defferential correction data
	iiii		: Deferential station's ID
	*CC		: checksum for the sentence
	*/

        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);
		

		/* 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);

		/* Get lattitude Cardinal direction */
        pChar = stringRead;
        j = lastCommaPosition + 1;
        k = 0;
        while(*(pChar+j) != COMMA)
        {
            latitudeCardinalString[k] = *(pChar+j);
            j++;
            k++;
			if (k>=2) break;
        }
        lastCommaPosition = j;
        latitudeCardinalString[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);

		/* Get longtitude Cardinal direction */
        pChar = stringRead;
        j = lastCommaPosition + 1;
        k = 0;
        while(*(pChar+j) != COMMA)
        {
            longitudeCardinalString[k] = *(pChar+j);
            j++;
            k++;
			if (k>=2) break;
        }
        lastCommaPosition = j;
        longitudeCardinalString[k] = '\0';
        //printf(" %s\n", longitudeCardinalString);
		
		/* Get quality */
        pChar = stringRead;
        j = lastCommaPosition + 1;
        k = 0;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
粉嫩av一区二区三区| 亚洲免费观看视频| 国产激情视频一区二区在线观看 | 久久精品水蜜桃av综合天堂| 国产在线麻豆精品观看| 久久精品人人做人人综合 | 无码av免费一区二区三区试看| 欧美日韩一区小说| 奇米色一区二区三区四区| 日韩一级视频免费观看在线| 久久er精品视频| 欧美国产丝袜视频| 欧美亚洲高清一区| 美国十次了思思久久精品导航| 免费看黄色91| 欧美激情自拍偷拍| 欧洲精品一区二区| 看片的网站亚洲| 欧美韩国日本综合| 欧美视频在线不卡| 国产九色sp调教91| 夜夜嗨av一区二区三区四季av| 91精品国产综合久久久久久漫画| 国产乱码一区二区三区| 亚洲免费视频成人| 欧美大胆一级视频| 97se亚洲国产综合自在线观| 日韩 欧美一区二区三区| 国产精品网曝门| 欧美日本在线看| av电影一区二区| 麻豆精品视频在线观看| 亚洲欧美一区二区三区极速播放| 7777精品伊人久久久大香线蕉 | 成人18视频日本| 天堂一区二区在线免费观看| 2023国产精华国产精品| 在线精品观看国产| 国产成都精品91一区二区三| 日韩中文字幕av电影| 国产精品对白交换视频| 91精品国产综合久久久久久久久久| 99久久精品国产麻豆演员表| 久久不见久久见免费视频1| 亚洲综合免费观看高清在线观看 | 国产情人综合久久777777| 欧美精品久久99| 日本韩国视频一区二区| 国产精品正在播放| 男人操女人的视频在线观看欧美| 日韩理论在线观看| 国产欧美一区二区精品久导航 | 国产麻豆精品视频| 日韩精品一卡二卡三卡四卡无卡| 亚洲色图.com| 亚洲欧美一区二区久久| 国产精品天美传媒| 精品国精品国产尤物美女| 欧美色手机在线观看| 色综合久久六月婷婷中文字幕| 高清视频一区二区| 国产激情视频一区二区三区欧美| 久久91精品久久久久久秒播| 日av在线不卡| 日韩成人一区二区| 日韩高清国产一区在线| 午夜在线成人av| 亚洲一区在线看| 一区二区三区日韩欧美| 一区二区在线免费观看| 国产精品毛片a∨一区二区三区| 国产日韩精品一区二区三区在线| 日韩一区二区电影在线| 3d动漫精品啪啪一区二区竹菊| 欧美日韩综合在线| 欧美喷潮久久久xxxxx| 欧美日本精品一区二区三区| 欧美色网站导航| 91超碰这里只有精品国产| 51精品国自产在线| 精品国产免费人成在线观看| 国产亚洲欧美日韩俺去了| 中文av字幕一区| 亚洲精品免费视频| 亚洲成人免费视| 免费在线欧美视频| 韩国在线一区二区| 成人动漫av在线| 在线免费观看成人短视频| 欧美日韩中文字幕精品| 日韩精品在线网站| 国产欧美1区2区3区| 1区2区3区精品视频| 一区二区三区影院| 免费在线成人网| 春色校园综合激情亚洲| 91一区二区三区在线播放| 欧美性猛片xxxx免费看久爱| 欧美一区永久视频免费观看| 精品理论电影在线观看| 国产精品视频在线看| 亚洲美女视频在线| 日本伊人色综合网| 国产成人av福利| 欧美亚洲日本国产| 欧美va在线播放| 国产精品传媒入口麻豆| 亚洲一区二区视频在线观看| 蜜臀99久久精品久久久久久软件| 高清不卡在线观看| 欧美日韩精品久久久| 久久综合九色综合欧美就去吻 | 亚洲a一区二区| 国产一区二区三区四区五区美女 | 成人性视频网站| 欧美丝袜自拍制服另类| 国产亚洲欧美日韩俺去了| 亚洲国产一二三| 国产成都精品91一区二区三| 欧美日韩精品一区视频| 国产精品久久久久久户外露出| 午夜国产精品影院在线观看| 成人午夜私人影院| 欧美一区二区三区四区高清| 成人免费在线播放视频| 国产一区亚洲一区| 欧美久久一区二区| 中文字幕在线一区免费| 久久激五月天综合精品| 欧美视频一区二区| 中文字幕在线播放不卡一区| 精品亚洲国内自在自线福利| 欧美色涩在线第一页| 亚洲国产成人在线| 激情综合色丁香一区二区| 欧美性三三影院| 亚洲欧美日韩国产综合在线 | 麻豆精品新av中文字幕| 在线观看欧美黄色| 一色屋精品亚洲香蕉网站| 国产一级精品在线| 日韩欧美在线不卡| 午夜欧美在线一二页| 色美美综合视频| 国产精品视频一区二区三区不卡| 国模冰冰炮一区二区| 欧美一区二区三区在线电影| 亚洲国产美女搞黄色| 91麻豆国产自产在线观看| 欧美高清在线一区| 国产激情视频一区二区在线观看| 精品国产自在久精品国产| 日韩精品久久久久久| 欧美日韩在线直播| 一区二区三区在线看| 色综合久久精品| 亚洲欧美偷拍卡通变态| 99久久国产免费看| 亚洲天堂网中文字| 91热门视频在线观看| 一区在线观看免费| 色婷婷激情综合| 亚洲视频免费在线| 色天天综合色天天久久| 亚洲欧美成人一区二区三区| 色综合一区二区| 亚洲日本在线a| 成人免费高清视频在线观看| 国产午夜精品一区二区| 国产一区二区三区| 欧美国产97人人爽人人喊| 成人av在线一区二区三区| 亚洲欧美在线视频| 色综合网色综合| 亚洲大片精品永久免费| 91精品国产麻豆国产自产在线| 免费精品视频在线| 久久一区二区三区四区| 成人av电影免费在线播放| 国产精品久久久久永久免费观看| 不卡的av网站| 一二三区精品福利视频| 3atv一区二区三区| 久久国内精品视频| 国产精品视频免费看| 色综合激情久久| 男人的天堂久久精品| 国产午夜亚洲精品羞羞网站| 91小视频免费看| 亚洲v日本v欧美v久久精品| 日韩精品中文字幕在线不卡尤物 | 久久久一区二区三区| 波多野结衣亚洲一区| 亚洲主播在线播放| 精品日韩一区二区三区免费视频| 成人三级伦理片| 亚洲一区二区三区四区不卡| 欧美成人综合网站| 色综合久久中文综合久久97| 麻豆精品国产91久久久久久|