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

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

?? gps.c

?? gps源碼! 轉自網絡
?? C
?? 第 1 頁 / 共 3 頁
字號:
#include <windows.h>
#include "stdio.h"
#include "time.h"
#include "string.h"
#include "assert.h"
#include "gps.h"
#include "math.h"

DCB				dcb;
COMMTIMEOUTS	timeouts;
COMSTAT			ComStat;
HANDLE			idComDev;

unsigned int testCycle = 0;

volatile char gpsMessage[1030][2] = {0};
volatile int buffHead = 0;
volatile int buffEnd = 0;

DWORD WINAPI receiveGPSProc(LPVOID);                //receive gps data
DWORD WINAPI analyseGPSProc(LPVOID);               //analyse gps data


/*******************************************************************************
**           Function: Get GPS Communication Port from GPSPort.ini            **
**               In: char buffer                                              **
**               Out: set the char buffer                                     **
**               Date: 2007-8-1     Author: Owen.Lu                           **  
*******************************************************************************/
void getGPSPort(char backstr[])
{
	FILE *fp = 0;
	char one;
	int ii;
	int state = 0;
	fp = fopen("gpsport.ini", "r");
	assert(fp);
	ii = 3;
	one = fgetc(fp);
	while(!feof(fp))
	{	
		if(one == '\n')
		{
			break;
		}
		backstr[ii] = one;
		ii++;
		one = fgetc(fp);
	}
	backstr[ii] = '\0';
}

/*******************************************************************************
**           Function: Show a MessageBox                                      **
**               In: char buffer                                              **
**               Out: NULL                                                    **
**               Date: 2007-8-1     Author: Owen.Lu                           **  
*******************************************************************************/
void showMessage(char message[])
{
	MessageBox(NULL, message, "GPS V1.00", MB_OK);
}

/*******************************************************************************
**           Function: GPS test Program                                       **
**              sense the GPS Port, Get the GPS Data                          **
**               In:  NULL                                                    **
**               Out: NULL                                                    **
**               Date: 2007-8-1     Author: Owen.Lu                           **  
*******************************************************************************/
void setCOMPortPrj(void)
{
	SetCommTimeouts(idComDev, &timeouts);
	SetupComm(idComDev, 1024, 512);
	dcb.DCBlength = sizeof(DCB);
	GetCommState(idComDev, &dcb);
	dcb.BaudRate = CBR_4800;
	dcb.Parity = 0;
	dcb.fParity = TRUE;
	dcb.ByteSize = 8;
	dcb.fBinary = TRUE;
	dcb.StopBits = ONESTOPBIT;
	SetCommMask(idComDev, EV_ERR|EV_RXCHAR);
	SetCommState(idComDev, &dcb);
}

/*******************************************************************************
**           Function: GPS Send Data                                          **
**               In:  message string                                          **
**               Out: NULL                                                    **
**               Date: 2007-8-1     Author: Owen.Lu                           **  
*******************************************************************************/
int sendComData(char message[])
{
	char sendData[100] = {0};
	
	DWORD sendLength = 0;
	DWORD realSend = 0;
	
	int ii = 0;
	int jj = 0;

	BOOL sendState = FALSE;

	PurgeComm(idComDev, PURGE_RXCLEAR|PURGE_TXCLEAR|PURGE_TXABORT|PURGE_RXABORT);
	strcpy(sendData, message);
	sendLength = strlen(sendData);
		
	for(ii = 0; ii < (int)sendLength; ii++)
	{
		sendState = WriteFile( idComDev, (LPCVOID)sendData, 1, &realSend, NULL);
		if(!realSend)
		{
			return 1;
		}
		for(jj = 0; jj < (int)strlen(sendData); jj++)
		{
			sendData[jj] = sendData[jj + 1];
		}
	}
	return 0;
}

/*******************************************************************************
**           Function: GPS Send Data                                          **
**               In:  message string                                          **
**               Out: message string                                          **
**               Date: 2007-8-1     Author: Owen.Lu                           **  
*******************************************************************************/
int getComData(char message[])
{
	DWORD	dwErrorFlags = 0;
	DWORD	dwBytesRead = 0;

	char	getData[100] = {0};

	PurgeComm(idComDev, PURGE_TXCLEAR);
	ClearCommError(idComDev, &dwErrorFlags, &ComStat);
		
	dwBytesRead = 0;
	dwBytesRead = min(8,ComStat.cbInQue);
	
	if(!dwBytesRead)
	{
		return 0;
	}

	ReadFile(idComDev, getData, dwBytesRead, &dwBytesRead, NULL);
	
	getData[dwBytesRead] = 0;
	strcpy(message, getData);
	return (int)dwBytesRead;
}

/*******************************************************************************
**           Function: Get GPS Signal Information                             **
**       ................................................                     **
**  Each frament start with $, there are different frament such as            **
**   $GPGGA, $GPGSA , $GPGSV , $GPRMC and so on                               **
**       ................................................                     **
**      $GPRMC,<1>,<2>,<3>,<4>,<5>,<6>,<7>,<8>,<9>,<10>,<11>*hh               **
**       <01>:  [Time]: hhmmss                                                **
**       <02>:  [State]: A is efficiency , V is inefficiency                  **
**       <03>:  [Latitude]: ddmm.mmmm                                         **
**       <04>:  [South or North earth]: N is north, S is south                **
**       <05>:  [Longitude]: ddmm.mmmm                                        **
**       <06>:  [East or West earth]: E is east, W is west                    **
**       <07>:  [High ]:  range from 0.0 to 999.9                             **
**       <08>:  [direction]: range from 000.0 to 359.9                        **
**       <09>:  [date]:  ddmmyy                                               **
**       <10>:  [Magnetic Change]: range from 000.0 to 180.0                  **
**       <11>:  [Magnetic director change]: E or W                            **
**               In: NULL                                                     **
**               Out: NULL                                                    **
**               Date: 2007-8-1     Author: Owen.Lu                           **  
*******************************************************************************/
DWORD WINAPI receiveGPSProc(LPVOID lpparam)
{
	char message[10] = {0};
	int  receiveLength = 0;
	int  ii = 0;
	FILE *fp;
	fp = fopen("gps.dat", "w");
	while(1)
	{
		memset(message, 0, sizeof(message));
	    receiveLength = getComData(message);
		if(receiveLength == 0)
		{
			continue;
		}
		for(ii = 0; ii < receiveLength; ii++)
		{
			gpsMessage[buffHead][0] = message[ii];
			gpsMessage[buffHead][1] = 1;
			buffHead = (buffHead + 1 ) % 1024;
		}
		fprintf(fp, "%s", message);
		fflush(fp);
	}
	
}

/*******************************************************************************
**           Function: Analyse GPS Signal Information                         **
**      $GPRMC,<1>,<2>,<3>,<4>,<5>,<6>,<7>,<8>,<9>,<10>,<11>*hh               **
**       <01>:  [Time]: hhmmss                                                **
**       <02>:  [State]: A is efficiency , V is inefficiency                  **
**       <03>:  [Latitude]: ddmm.mmmm                                         **
**       <04>:  [South or North earth]: N is north, S is south                **
**       <05>:  [Longitude]: ddmm.mmmm                                        **
**       <06>:  [East or West earth]: E is east, W is west                    **
**       <07>:  [High ]:  range from 0.0 to 999.9                             **
**       <08>:  [direction]: range from 000.0 to 359.9                        **
**       <09>:  [date]:  ddmmyy                                               **
**       <10>:  [Magnetic Change]: range from 000.0 to 180.0                  **
**       <11>:  [Magnetic director change]: E or W                            **
**               In:  NULL                                                    **
**               Out: NULL                                                    **
**               Date: 2007-8-1     Author: Owen.Lu                           **  
*******************************************************************************/
DWORD WINAPI analyseGPSProc(LPVOID lpparam)
{
	char singleType[10] = {'\0'};
	int  knowSignle = 0;
	while(1)
	{
		getString(singleType);
		if(strcmp(singleType, "$gpalm") == 0)
		{
			knowSignle = 1;
			gpsGPALM();
		}
		if(strcmp(singleType, "$pgrmi") == 0)
		{
			knowSignle = 1;
			gpsPGRMI();
		}
		if(strcmp(singleType, "$pgrmo") == 0)
		{
			knowSignle = 1;
			gpsPGRMO();
		}		
		if(strcmp(singleType, "$gpgga") == 0)
		{
			knowSignle = 1;
			gpsGPGGA();
		}		
		if(strcmp(singleType, "$gpgsa") == 0)
		{
			knowSignle = 1;
			gpsGPGSA();
		}
		if(strcmp(singleType, "$gpgsv") == 0)
		{
			knowSignle = 1;
			gpsGPGSV();
		}		
		if(strcmp(singleType, "$gprmc") == 0)
		{
			knowSignle = 1;
			gpsGPRMC();
		}
		if(strcmp(singleType, "$gpvtg") == 0)
		{
			knowSignle = 1;
			gpsGPVTG();
		}
		if(strcmp(singleType, "$lcgll") == 0)
		{
			knowSignle = 1;
			gpsLCGLL();
		}
		if(strcmp(singleType, "$lcvtg") == 0)
		{
			knowSignle = 1;
			gpsLCVTG();
		}
		if(strcmp(singleType, "$pgrme") == 0)
		{
			knowSignle = 1;
			gpsPGRME();
		}
		if(strcmp(singleType, "$pgrmt") == 0)
		{
			knowSignle = 1;
			gpsPGRMT();
		}
		if(knowSignle == 0)
		{
			printf("%s.............\n", singleType);
		}
		knowSignle = 0;
	}
	return 0;
}

/*******************************************************************************
**           Function: Get string from string by char                         **
**               In:                                                          **
**               Out:                                                         **
**               Date: 2007-8-1     Author: Owen.Lu                           **  
*******************************************************************************/
void getBetweenChar(char input[], char backstr[], char stopcn)
{
	int ii = 0;
	while(input[ii] != stopcn)
	{
		backstr[ii] = input[ii];
		ii++;
	}
	backstr[ii] = '\0';
}

/*******************************************************************************
**           Function: Get system time and date                               **
**               In:                                                          **
**               Out:                                                         **
**               Date: 2007-8-1     Author: Owen.Lu                           **  

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品理论片在线观看| 日韩av电影天堂| 一区二区三区精品在线观看| 欧美激情一区二区三区四区| 日韩高清在线一区| 色欧美乱欧美15图片| 亚洲男同性恋视频| 欧美日韩成人综合天天影院| 免费高清不卡av| 欧美国产一区在线| 99国产精品久久久| 五月婷婷另类国产| 色欧美片视频在线观看| 欧美日韩日日摸| 亚洲日本在线视频观看| 国产一区二区视频在线| 国产精品久久久久精k8| 欧美性生活影院| 精一区二区三区| 亚洲啪啪综合av一区二区三区| 欧美系列亚洲系列| 久久不见久久见免费视频7| 国产精品少妇自拍| 欧美日韩不卡视频| 国产成人三级在线观看| 有坂深雪av一区二区精品| 日韩一区二区在线观看视频播放| 成人免费看视频| 丝袜美腿一区二区三区| 国产目拍亚洲精品99久久精品| 色素色在线综合| 久久aⅴ国产欧美74aaa| 亚洲一区二区在线播放相泽| 久久综合狠狠综合| 色综合久久久久久久久| 极品少妇xxxx精品少妇偷拍| 亚洲你懂的在线视频| 欧美精品一区二区三区视频| 中文字幕永久在线不卡| 国产激情偷乱视频一区二区三区| 国产欧美一区二区三区在线看蜜臀| 亚洲一线二线三线视频| 99久久精品免费看国产| 中文字幕精品在线不卡| 国产乱码精品一区二区三区五月婷| 在线精品亚洲一区二区不卡| 国产精品丝袜久久久久久app| 久久99九九99精品| 91麻豆.com| 激情综合一区二区三区| 一区二区三区欧美日韩| 国产亚洲制服色| 日韩精品一区二区三区老鸭窝 | 国产精品影视天天线| 欧美mv和日韩mv国产网站| 奇米色一区二区三区四区| 91视频xxxx| 亚洲激情一二三区| 欧美日韩五月天| 亚洲chinese男男1069| 91精品国产福利| 国产99一区视频免费| 国产目拍亚洲精品99久久精品| 成人污视频在线观看| 一区二区在线电影| 日韩一区二区麻豆国产| 精品综合免费视频观看| 丝袜美腿亚洲综合| 国产女人aaa级久久久级| 91精品婷婷国产综合久久竹菊| 国产一区二区三区四区五区美女| 99视频在线精品| 欧美大胆一级视频| 国产乱码精品一区二区三区av | 91精品福利在线一区二区三区 | 91精品国产综合久久小美女| 欧美性做爰猛烈叫床潮| 一本一道波多野结衣一区二区| 经典一区二区三区| 天天做天天摸天天爽国产一区| 91精品国产高清一区二区三区| 久久精品亚洲一区二区三区浴池| 久久电影国产免费久久电影 | 精品久久久久久久人人人人传媒| 国产自产视频一区二区三区| 一区二区国产盗摄色噜噜| 国产视频一区二区在线| 亚洲一区二区视频在线| 欧美日韩一级二级| av电影在线观看一区| 成人av先锋影音| 欧美亚洲综合网| 日韩一区二区在线播放| 国产亚洲福利社区一区| 国产精品久久久久三级| 亚洲国产成人va在线观看天堂| 五月天丁香久久| 精品一区二区三区久久| 国产v日产∨综合v精品视频| 91免费国产视频网站| 欧美日韩中文字幕一区| 日韩免费高清视频| 一区二区三区精密机械公司| 一区二区三区欧美| 美国三级日本三级久久99 | 国产精品久久久久9999吃药| 综合欧美一区二区三区| 日韩专区中文字幕一区二区| 精彩视频一区二区| 91久久人澡人人添人人爽欧美| 欧美日韩成人高清| 日本一区二区高清| 亚洲国产精品久久久久婷婷884| 久久av中文字幕片| 色94色欧美sute亚洲线路一久| 欧美videos中文字幕| 最新国产精品久久精品| 日韩精品电影一区亚洲| 成人自拍视频在线| 欧美精选午夜久久久乱码6080| 久久免费偷拍视频| 亚洲高清不卡在线| 懂色av噜噜一区二区三区av| 精品视频1区2区3区| 国产精品国产三级国产a| 日本视频在线一区| 色噜噜狠狠色综合中国| 26uuu久久综合| 亚洲午夜影视影院在线观看| 国产成人一级电影| 欧美一区二区在线不卡| 亚洲黄色av一区| 懂色一区二区三区免费观看| 91麻豆精品91久久久久久清纯 | 国产乱子伦一区二区三区国色天香| 一本到三区不卡视频| 国产亚洲欧美日韩俺去了| 日本午夜精品一区二区三区电影 | 欧美日韩一区三区| |精品福利一区二区三区| 国产米奇在线777精品观看| 欧美日韩激情一区二区三区| 亚洲素人一区二区| 成人一区二区三区| 精品久久久久99| 国产精品18久久久久久vr| 欧洲亚洲精品在线| 亚洲色欲色欲www| 岛国一区二区在线观看| 久久亚洲精精品中文字幕早川悠里| 午夜免费久久看| 欧美日韩国产经典色站一区二区三区| 国产精品乱码人人做人人爱| 国产精品影视在线观看| 欧美精品一区二区三区四区 | 欧美少妇xxx| 亚洲综合久久av| 在线一区二区三区四区五区 | 久久精品一区四区| 久久97超碰色| 久久综合五月天婷婷伊人| 免费在线观看视频一区| 91精品综合久久久久久| 免费视频最近日韩| 日韩美女一区二区三区| 麻豆高清免费国产一区| 欧美xxxxx牲另类人与| 美女视频黄频大全不卡视频在线播放| 91麻豆精品国产91久久久使用方法| 三级久久三级久久久| 欧美日韩国产精选| 美女mm1313爽爽久久久蜜臀| 日韩精品一区二区三区四区| 捆绑变态av一区二区三区| 亚洲精品一区在线观看| 狠狠色2019综合网| 国产欧美日本一区视频| 成人国产电影网| 一区二区三区欧美| 91精品国产欧美一区二区| 久久国产精品72免费观看| 精品电影一区二区| jizz一区二区| 亚洲综合在线观看视频| 欧美一区二区三区视频在线| 国产乱子伦一区二区三区国色天香| 欧美国产综合一区二区| 在线观看www91| 麻豆91在线观看| 国产精品情趣视频| 欧美在线观看一区二区| 国产成人综合亚洲91猫咪| 中文字幕一区二区三区不卡| 欧美图区在线视频| 另类人妖一区二区av| 国产欧美日韩亚州综合| 欧洲精品在线观看| 久久精品国产亚洲高清剧情介绍| 中文字幕av一区二区三区| 欧美午夜精品久久久|