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

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

?? nmea.cpp

?? GPS定位系統,可以與GPS相連接,也可以與與電子地圖等相連接.
?? CPP
字號:
#include "stdafx.h"
#include "nmea.h"

#ifdef _DEBUG
#undef THIS_FILE
static char BASED_CODE THIS_FILE[] = __FILE__;
#endif


NMEA_BOOLEAN CNmeaSentence::Boolean(int nField) const
{
  CString sField(Field(nField));

  if (sField == _T("A"))
    return True;
  else if (sField == _T("V"))
    return False;
  else
    return Unknown;
}


int CNmeaSentence::HexDigitToInt(char c)
{
  int rVal = 0;
  if ((c >= 'a') && (c <= 'f'))
    rVal =  c - 'a' + 10;
  else if ((c >= 'A') && (c <= 'F'))
    rVal =  c - 'A' + 10;
  else if ((c >= '0') && (c <= '9'))
    rVal = c - '0';

  return rVal;
}

DWORD CNmeaSentence::HexValue(const CString& sHexString)
{
  int nLen = sHexString.GetLength();
  DWORD rVal = 0;
  int nMultiplier = 1;
  for (int i=nLen-1; i>=0; i--)
  {
    TCHAR c = sHexString.GetAt(i);
    rVal += (HexDigitToInt((char)c) * nMultiplier);
    nMultiplier *= 16;
  }

  return rVal;
}

BYTE CNmeaSentence::ComputeChecksum() const
{
  BYTE checksum = 0;

  int nLength = m_Sentence.GetLength();
  int i = 1; // Skip over the $ at the begining of the CNmeaSentence

  while (i < nLength && 
         m_Sentence[i] != _T('*') && 
         m_Sentence[i] != _T('\r') && 
         m_Sentence[i] != _T('\n') )
  {
    checksum ^= (BYTE) m_Sentence[i];
    i++;
  }

  return checksum;
}

double CNmeaSentence::Double(int nField) const
{
  CString sField(Field(nField));

  double rVal = 0.0;

  #ifdef _UNICODE
    int nLength = sField.GetLength();
    int nSize = (nLength + 1)/sizeof(TCHAR);
    char* pszFieldAscii = new char[nSize];

    WideCharToMultiByte(CP_ACP, 0, sField, -1, pszFieldAscii, nSize, NULL, NULL);
    rVal = ::atof(pszFieldAscii);

    delete [] pszFieldAscii;
  #else
    rVal = ::atof(sField);
  #endif

  return rVal;
}

NMEA_EASTWEST CNmeaSentence::EastOrWest(int nField) const
{
  CString sField(Field(nField));

  if (sField == _T("E"))
    return East;
  else if (sField == _T("W"))
    return West;
  else
    return EW_Unknown;
}

NMEA_LONGITUDE CNmeaSentence::Longitude(int nPositionFieldNumber, int nEastingFieldNumber) const
{
  NMEA_LONGITUDE rVal;
  rVal.Value = Angle(nPositionFieldNumber);
  rVal.Easting = EastOrWest(nEastingFieldNumber);
  return rVal;
}

NMEA_LATITUDE CNmeaSentence::Latitude(int nPositionFieldNumber, int nNorthingFieldNumber) const
{
  NMEA_LATITUDE rVal;
  rVal.Value = Angle(nPositionFieldNumber);
  rVal.Northing = NorthOrSouth(nNorthingFieldNumber);
  return rVal;
}

CString CNmeaSentence::Field(int nDesiredField) const
{
  CString rVal;

  int i = 1;
  int nCurrentField = 0;

  int nLen = m_Sentence.GetLength();

  while (nCurrentField < nDesiredField && i < nLen)
  {
    if (m_Sentence[i] == _T(',') || m_Sentence[i] == _T('*'))
      nCurrentField++;
    i++;
  }

  if (nCurrentField == nDesiredField)
  {
    while (i < nLen &&
           m_Sentence[i] != _T(',') &&
           m_Sentence[i] != _T('*') &&
           m_Sentence[i] != _T('\n') &&
           m_Sentence[i] != _T('\r') &&
           m_Sentence[i] != 0x00 )
    {
      rVal += m_Sentence[i];
      i++;
    }
  }

  return rVal;
}

int CNmeaSentence::Integer(int nField) const
{
  CString sInteger(Field(nField));
  return ::_ttoi(sInteger);
}

NMEA_BOOLEAN CNmeaSentence::IsChecksumBad(int nField) const
{
  // Checksums are optional, return TRUE if an existing checksum is known to be bad
  CString sChecksum(Field(nField));

  if (sChecksum.IsEmpty())
    return Unknown;

  BYTE CalculatedCheckSum = ComputeChecksum();
  DWORD ReceivedCheckSum = HexValue(sChecksum);

  if (CalculatedCheckSum != ReceivedCheckSum)
    return True;
  else
    return False;
}

NMEA_NORTHSOUTH CNmeaSentence::NorthOrSouth(int nField) const
{
  CString sField(Field(nField));

  if (sField == _T("N"))
    return North;
  else if (sField == _T("S"))
    return South;
  else
    return NS_Unknown;
}

NMEA_TIME CNmeaSentence::Time(int nField) const
{
  NMEA_TIME rVal;
  ZeroMemory(&rVal, sizeof(NMEA_TIME));
  CString sTemp(Field(nField));
  if (sTemp.GetLength() >= 6)
  {
    TCHAR sNumber[3];

    sNumber[0] = sTemp[0];
    sNumber[1] = sTemp[1];
    sNumber[2] = 0x00;
    rVal.wHour = (WORD) ::_ttoi(sNumber);

    sNumber[0] = sTemp[2];
    sNumber[1] = sTemp[3];
    rVal.wMinute = (WORD) ::_ttoi(sNumber);

    sNumber[0] = sTemp[4];
    sNumber[1] = sTemp[5];
    rVal.wSecond = (WORD) ::_ttoi(sNumber);
  }

  return rVal;
}

NMEA_DATE CNmeaSentence::Date(int nField) const
{
  NMEA_DATE rVal;
  ZeroMemory(&rVal, sizeof(NMEA_DATE));
  CString sTemp(Field(nField));
  if (sTemp.GetLength() >= 6)
  {
    TCHAR sNumber[3];

    sNumber[0] = sTemp[0];
    sNumber[1] = sTemp[1];
    sNumber[2] = 0x00;
    rVal.wDay = (WORD) ::_ttoi(sNumber);

    sNumber[0] = sTemp[2];
    sNumber[1] = sTemp[3];
    rVal.wMonth = (WORD) ::_ttoi(sNumber);

    sNumber[0] = sTemp[4];
    sNumber[1] = sTemp[5];
    rVal.wYear = (WORD) ::_ttoi(sNumber);

    //intelligently adjust the year
    if (rVal.wYear < 80)
      rVal.wYear += 2000;
    else if (rVal.wYear >= 75)
      rVal.wYear += 1900;
  }

  return rVal;
}

NMEA_ANGLE CNmeaSentence::Angle(int nField) const
{
  NMEA_ANGLE rVal;
  ZeroMemory(&rVal, sizeof(NMEA_ANGLE));

  CString sTemp(Field(nField));

  int nPointIndex = sTemp.Find(_T('.'));
  if (nPointIndex != -1)
  {
    CString sUnits(sTemp.Left(nPointIndex));
    int nValue = ::_ttoi(sUnits);
    rVal.Degrees = (WORD) (nValue/100);
    rVal.Minutes = (WORD) (nValue - rVal.Degrees*100);

    CString sFraction(sTemp.Right(sTemp.GetLength() - nPointIndex));
    double fValue = 0.0;
    #ifdef _UNICODE
      int nLength = sFraction.GetLength();
      int nSize = (nLength + 1)/sizeof(TCHAR);
      char* pszFieldAscii = new char[nSize];

      WideCharToMultiByte(CP_ACP, 0, sFraction, -1, pszFieldAscii, nSize, NULL, NULL);
      fValue = ::atof(pszFieldAscii);

      delete [] pszFieldAscii;
    #else
      fValue = ::atof(sFraction);
    #endif

    rVal.Seconds = (WORD) (fValue*60);
    rVal.CentiSeconds = (WORD) ((fValue*60 - rVal.Seconds)*100.0);
  }

  return rVal;
}

DWORD CNmeaSentence::NmeaAngleToHundrethsOfSeconds(const NMEA_ANGLE& angle)
{
  DWORD rVal = angle.Degrees*360000 + 
               angle.Minutes*6000 +
               angle.Seconds*100 +
               angle.CentiSeconds;
  return rVal;
}

DWORD CNmeaSentence::NmeaBearingToHundrethsOfDegrees(const double& value)
{
  int nDigits = (int) value;
  int nHundreths = (int) ((value - nDigits)*100);
  return nDigits*100 + nHundreths;
}


CRMCResponse::CRMCResponse()
{
  Empty();
}

CRMCResponse::~CRMCResponse()
{
  Empty();
}

void CRMCResponse::Empty()
{
  ZeroMemory(&m_Time, sizeof(NMEA_TIME));
  ZeroMemory(&m_Date, sizeof(NMEA_DATE));
  m_IsDataValid              = Unknown;
  ZeroMemory(&m_Latitude, sizeof(NMEA_LATITUDE));
  ZeroMemory(&m_Longitude, sizeof(NMEA_LONGITUDE));
  m_SpeedOverGroundKnots       = 0.0;
}

BOOL CRMCResponse::Parse(const CNmeaSentence& sentence)
{
  // First we check the checksum
  NMEA_BOOLEAN check = sentence.IsChecksumBad(12);
  if (check == True)
  {
    TRACE(_T("CRMCResponse::Parse detected an Invalid checksum\n"));
    return FALSE;
  }
  else if (check == Unknown)
  {
    TRACE(_T("CRMCResponse::Parse detected a missing checksum\n"));
    return FALSE;
  } 

  //then the data
  m_Time                 = sentence.Time(1);
  m_Date                 = sentence.Date(9);
  m_IsDataValid          = sentence.Boolean(2);
  m_Latitude             = sentence.Latitude(3, 4);
  m_Longitude            = sentence.Longitude(5, 6);
  m_SpeedOverGroundKnots = sentence.Double(7);
  m_Bearing              = sentence.Double(8);

  return TRUE;
}




CGGAResponse::CGGAResponse()
{
  Empty();
}

CGGAResponse::~CGGAResponse()
{
  Empty();
}

void CGGAResponse::Empty()
{
  m_GPSQuality            = 0;
  m_nSatellites           = 0;
  m_AntennaAltitudeMeters = 0.0;
}

BOOL CGGAResponse::Parse(const CNmeaSentence& sentence)
{
  // First we check the checksum...
  if (sentence.IsChecksumBad(15) == True)
  {
    TRACE(_T("CGGAResponse::Parse detected an Invalid Checksum"));
    return FALSE;
  } 

  m_GPSQuality            = sentence.Integer(6);
  m_nSatellites           = sentence.Integer(7);
  m_AntennaAltitudeMeters = sentence.Double(9);

  return TRUE;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一区二区福利视频| 暴力调教一区二区三区| 欧美电影影音先锋| 五月婷婷综合在线| 91精品久久久久久蜜臀| 丝袜脚交一区二区| 精品少妇一区二区三区在线播放| 秋霞电影网一区二区| 欧美mv日韩mv| 成人免费看黄yyy456| 日韩久久一区二区| 欧美亚男人的天堂| 日本aⅴ亚洲精品中文乱码| 日韩免费观看高清完整版在线观看| 国产乱码精品一品二品| 中文字幕一区二区三区蜜月| 欧美视频在线一区二区三区| 久草这里只有精品视频| 国产精品午夜免费| 国产精品无圣光一区二区| 色综合久久88色综合天天免费| 亚洲午夜激情网页| 精品久久久久久综合日本欧美| caoporm超碰国产精品| 香蕉影视欧美成人| 国产精品视频一二| 欧美日韩极品在线观看一区| 国产白丝精品91爽爽久久| 一区二区三区美女| 337p日本欧洲亚洲大胆色噜噜| 91美女片黄在线| 免费国产亚洲视频| 日韩理论电影院| 26uuu国产电影一区二区| 日本韩国欧美在线| 国内精品久久久久影院一蜜桃| 亚洲精品免费在线观看| 精品国产一区二区三区四区四| 色综合久久久久综合99| 国产一区91精品张津瑜| 视频一区二区三区在线| 亚洲另类在线一区| 国产情人综合久久777777| 欧美日韩免费观看一区三区| 国产成人精品三级| 蜜臀久久99精品久久久画质超高清| 国产精品免费看片| 精品免费视频.| 欧美日韩专区在线| va亚洲va日韩不卡在线观看| 狠狠色丁香久久婷婷综合_中| 亚洲午夜在线电影| 中文字幕亚洲成人| 国产欧美一区二区精品性色超碰 | 亚洲大片精品永久免费| 亚洲欧洲精品一区二区精品久久久| 日韩欧美不卡一区| 欧美伦理电影网| 欧美三级资源在线| 91小视频免费观看| fc2成人免费人成在线观看播放| 国产精品综合视频| 国产精品99久久久久| 韩国午夜理伦三级不卡影院| 久色婷婷小香蕉久久| 日韩精品亚洲专区| 日本视频免费一区| 日韩经典中文字幕一区| 亚洲6080在线| 午夜精品福利在线| 秋霞电影一区二区| 久久国产乱子精品免费女| 日韩av中文字幕一区二区三区| 亚洲一二三专区| 亚洲国产综合色| 亚洲成av人片www| 天天爽夜夜爽夜夜爽精品视频| 视频在线观看91| 欧美三级中文字| 欧美网站一区二区| 欧美久久久久免费| 91精品国产欧美日韩| 欧美一级精品在线| 精品国产一区二区三区久久影院| 精品免费99久久| 国产精品污网站| 一区二区三区欧美视频| 亚洲www啪成人一区二区麻豆| 亚洲第一电影网| 六月丁香综合在线视频| 国产九色精品成人porny | 91在线视频播放| 欧洲精品中文字幕| 8v天堂国产在线一区二区| 日韩久久免费av| 欧美韩国一区二区| 亚洲综合区在线| 美日韩黄色大片| 国产成人av一区二区三区在线观看| 成人精品一区二区三区中文字幕| 99精品偷自拍| 91麻豆精品国产91久久久更新时间 | 久久久久久电影| 亚洲欧洲日本在线| 天天综合色天天综合色h| 久久超碰97中文字幕| 国产99久久久久久免费看农村| 91麻豆swag| 欧美一区二区二区| 最新国产精品久久精品| 日韩精品三区四区| 成人91在线观看| 欧美精品少妇一区二区三区| 久久久久久久精| 亚洲国产精品天堂| 国产成人免费9x9x人网站视频| 色综合网色综合| 欧美大黄免费观看| 一区二区三区四区精品在线视频| 天堂一区二区在线| 不卡在线观看av| 日韩亚洲欧美在线观看| 亚洲色图视频网| 精品在线观看视频| 色婷婷久久99综合精品jk白丝 | 欧美亚洲动漫精品| 国产日韩成人精品| 日韩电影一区二区三区四区| 国产精品18久久久| 欧美精品777| 亚洲美女区一区| 国产精品一区2区| 日韩欧美第一区| 亚洲一区视频在线观看视频| 风流少妇一区二区| 日韩一区二区三区在线| 一区二区三区在线观看网站| 国产成人av影院| 欧美xxxx老人做受| 丝袜亚洲另类欧美| 久久影院午夜片一区| 亚洲午夜电影在线观看| 成人av片在线观看| 26uuu精品一区二区| 蜜桃av噜噜一区| 欧美男男青年gay1069videost | 欧美一区二区视频免费观看| 亚洲男人的天堂在线aⅴ视频| 国产一区二区精品久久| 91精品国产综合久久香蕉的特点| 亚洲天堂免费看| 成人99免费视频| 中国色在线观看另类| 国产大陆精品国产| 国产日韩欧美精品综合| 狠狠色丁香久久婷婷综合_中| 欧美成人三级在线| 蜜桃视频在线观看一区| 91精品国产综合久久蜜臀 | 一区二区在线观看不卡| 不卡av在线免费观看| 国产亚洲欧美一级| 国产精品一区二区久久不卡| 久久亚洲精品国产精品紫薇| 国模少妇一区二区三区| 精品久久久久香蕉网| 久99久精品视频免费观看| 日韩精品一区二区三区中文精品 | 国产一区二区三区不卡在线观看 | 精品国产sm最大网站免费看| 美女久久久精品| 日韩欧美一区中文| 免费观看30秒视频久久| 欧美成人精品福利| 韩国成人在线视频| 国产日韩av一区二区| 成人一区二区在线观看| 亚洲人一二三区| 欧美性生活大片视频| 午夜精品福利久久久| 欧美成人a∨高清免费观看| 精品一区二区三区免费| 国产午夜久久久久| 色哟哟国产精品| 香蕉成人啪国产精品视频综合网 | 国产一区二区三区在线观看精品 | 3d动漫精品啪啪一区二区竹菊| 奇米精品一区二区三区在线观看| 日韩欧美美女一区二区三区| 国产精品一区二区三区网站| 国产精品美女久久久久久久网站| 91在线视频观看| 人妖欧美一区二区| 国产亚洲一二三区| 色欧美乱欧美15图片| 日韩国产一区二| 国产欧美日韩视频一区二区| 91色porny在线视频| 青娱乐精品视频| 国产精品热久久久久夜色精品三区 |