亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
欧洲视频一区二区| 欧美日本在线播放| 日韩高清不卡在线| 国产精品女同一区二区三区| 在线综合视频播放| 色拍拍在线精品视频8848| 久99久精品视频免费观看| 亚洲国产精品麻豆| 国产精品美女久久久久av爽李琼| 3d动漫精品啪啪一区二区竹菊| 成人国产精品视频| 久久国产尿小便嘘嘘| 亚洲尤物在线视频观看| 国产视频在线观看一区二区三区 | 亚洲一级二级三级在线免费观看| 26uuu国产日韩综合| 911精品国产一区二区在线| av不卡一区二区三区| 国产精华液一区二区三区| 奇米一区二区三区| 亚洲国产sm捆绑调教视频 | 亚洲最大的成人av| 欧美激情一区二区三区在线| 日韩免费观看高清完整版| 欧美日韩国产在线播放网站| 99精品热视频| 91美女蜜桃在线| 成人免费看片app下载| 国产精品一卡二卡在线观看| 久久电影国产免费久久电影| 日韩中文字幕91| 五月激情综合婷婷| 日韩精品乱码av一区二区| 婷婷综合另类小说色区| 首页综合国产亚洲丝袜| 亚洲va欧美va人人爽| 水蜜桃久久夜色精品一区的特点| 亚洲综合男人的天堂| 日韩精品免费视频人成| 首页欧美精品中文字幕| 亚洲成人先锋电影| 日韩高清在线不卡| 美女视频一区二区三区| 久久精品国产亚洲aⅴ| 日本aⅴ亚洲精品中文乱码| 麻豆精品国产91久久久久久| 精品夜夜嗨av一区二区三区| 国产成人在线视频网址| 成人在线视频一区二区| kk眼镜猥琐国模调教系列一区二区 | 国内精品第一页| 国产精品99久久久久久久女警| 国产精品77777竹菊影视小说| 国产乱一区二区| 国产成人av电影在线| 不卡的av电影| 欧美日韩一区二区三区高清| 91精品综合久久久久久| 欧美mv日韩mv亚洲| 国产无遮挡一区二区三区毛片日本| 国产精品五月天| 亚洲午夜久久久久久久久久久| 日韩精品国产欧美| 国产乱码精品1区2区3区| a美女胸又www黄视频久久| 欧美揉bbbbb揉bbbbb| 日韩一二三区不卡| 国产欧美1区2区3区| 亚洲色图清纯唯美| 丝袜美腿亚洲色图| 粉嫩蜜臀av国产精品网站| 在线中文字幕一区| 日韩一区二区在线观看| 国产欧美一区二区精品秋霞影院| 国产精品久久一卡二卡| 五月综合激情网| 国产一区二区久久| 91麻豆视频网站| 欧美一区二区三区人| 久久精品夜色噜噜亚洲aⅴ| 亚洲欧美成aⅴ人在线观看| 青青国产91久久久久久| 99精品欧美一区二区三区综合在线| 欧美日韩三级一区二区| 国产日韩三级在线| 亚洲第一综合色| 成人黄页在线观看| 7777精品伊人久久久大香线蕉| 久久精品人人做人人爽97| 性欧美大战久久久久久久久| 国产白丝精品91爽爽久久| 欧美日韩黄色一区二区| 日本一区二区免费在线| 日本不卡视频一二三区| 一本色道亚洲精品aⅴ| 久久久久久电影| 天天综合天天综合色| 成人免费毛片高清视频| 欧美一区二区人人喊爽| 亚洲免费在线播放| 高清日韩电视剧大全免费| 欧美一区二区三区人| 亚洲永久精品大片| 国产sm精品调教视频网站| 日韩一区二区视频| 亚洲影视资源网| 91在线视频18| 国产日韩成人精品| 美国十次综合导航| 精品视频资源站| 最新国产成人在线观看| 成人一级视频在线观看| 日韩精品一区二区三区四区视频| 亚洲国产日产av| 99精品视频在线免费观看| 国产清纯白嫩初高生在线观看91| 日韩1区2区日韩1区2区| 欧美精品v日韩精品v韩国精品v| 综合分类小说区另类春色亚洲小说欧美| 久久99精品国产麻豆婷婷| 在线综合亚洲欧美在线视频| 一区av在线播放| 色哦色哦哦色天天综合| 亚洲天堂网中文字| 波多野结衣中文字幕一区| 国产亚洲污的网站| 国产成人av电影在线观看| 久久久久久久久一| 国产精品一级片| 国产色婷婷亚洲99精品小说| 国产sm精品调教视频网站| 国产欧美日韩三级| 欧美亚洲综合一区| 一区二区三国产精华液| 欧美性色黄大片| 亚洲成av人影院在线观看网| 欧美视频精品在线观看| 亚洲国产一区二区三区青草影视| 欧美伊人久久久久久午夜久久久久| 夜夜嗨av一区二区三区网页| 在线观看欧美日本| 午夜日韩在线电影| 欧美一级免费大片| 久久er99热精品一区二区| 精品少妇一区二区三区视频免付费 | 国产精品对白交换视频| 91婷婷韩国欧美一区二区| 亚洲乱码国产乱码精品精小说 | 国产69精品久久777的优势| 国产午夜亚洲精品不卡| 国v精品久久久网| 亚洲视频图片小说| 日本电影亚洲天堂一区| 丝袜美腿成人在线| 久久综合色天天久久综合图片| 粉嫩aⅴ一区二区三区四区五区| 国产精品美女久久久久久久久久久| 色综合色综合色综合色综合色综合| 一区二区三区在线视频播放| 91麻豆精品国产自产在线观看一区 | 狠狠色综合日日| 国产欧美在线观看一区| 日本精品免费观看高清观看| 日日欢夜夜爽一区| 久久亚洲影视婷婷| 91丨九色porny丨蝌蚪| 亚洲va国产va欧美va观看| 久久综合色综合88| 91福利区一区二区三区| 日韩在线a电影| 国产精品情趣视频| 欧美日本不卡视频| 国产乱子伦视频一区二区三区 | 欧美日韩1区2区| 激情小说欧美图片| 亚洲人吸女人奶水| 日韩视频在线观看一区二区| 99热这里都是精品| 天堂久久久久va久久久久| 欧美极品另类videosde| 精品视频1区2区| 成人少妇影院yyyy| 五月婷婷激情综合| 国产精品天天看| 91精品国产综合久久精品性色| 国产精品一区免费视频| 亚洲一区在线观看视频| 久久精品综合网| 欧美一区二区黄色| 91免费国产在线观看| 紧缚奴在线一区二区三区| 尤物在线观看一区| 中文字幕精品—区二区四季| 91麻豆精品国产91久久久资源速度 | 日本一区二区在线不卡| 51精品秘密在线观看| 91黄色免费观看| 国产精品1024久久| 久久er精品视频| 亚洲国产视频在线|