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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? nmea.cpp

?? 本系統(tǒng)為公交車輛調(diào)度系統(tǒng)
?? 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一区二区三区免费野_久草精品视频
国产女主播视频一区二区| 在线看国产日韩| 国产丝袜在线精品| 成人av在线播放网站| 国产精品久久久久久亚洲毛片 | 久久99精品久久久久久久久久久久| 884aa四虎影成人精品一区| 免费的国产精品| 久久人人97超碰com| 成人美女视频在线观看18| 中文字幕在线不卡一区| 欧美亚洲国产一区二区三区| 日韩av电影免费观看高清完整版| 久久综合九色综合欧美98| 丁香啪啪综合成人亚洲小说| 中文字幕视频一区二区三区久| 欧美主播一区二区三区| 日韩av成人高清| 国产精品免费久久| 欧美主播一区二区三区| 激情六月婷婷综合| 亚洲卡通动漫在线| 欧美一区二区三区公司| 国产成人综合在线| 午夜欧美在线一二页| 国产网站一区二区| 在线一区二区视频| 精品亚洲成av人在线观看| 国产精品久久久久久久久免费桃花| 欧洲人成人精品| 国产精品一品二品| 亚洲一区二区视频在线观看| 精品国产一区二区三区不卡 | 色老头久久综合| 久久成人18免费观看| 国产精品久久久久国产精品日日 | 成人短视频下载| 视频一区二区三区中文字幕| 国产精品丝袜黑色高跟| 日韩一区二区精品在线观看| 成人三级在线视频| 免费在线观看成人| 亚洲狠狠丁香婷婷综合久久久| 日韩亚洲欧美在线观看| 色综合视频在线观看| 国产精品综合视频| 日韩影院精彩在线| 一区在线中文字幕| 久久亚洲二区三区| 69堂成人精品免费视频| 99久久99久久免费精品蜜臀| 激情综合亚洲精品| 五月婷婷激情综合| 亚洲免费观看高清在线观看| 久久免费午夜影院| 日韩久久久久久| 欧美挠脚心视频网站| 91麻豆国产福利精品| 国产999精品久久| 国内精品视频一区二区三区八戒| 亚洲电影中文字幕在线观看| 中文字幕在线不卡国产视频| 久久女同精品一区二区| 亚洲四区在线观看| 久久亚洲影视婷婷| 久久综合精品国产一区二区三区| 88在线观看91蜜桃国自产| 在线观看视频一区二区| 91麻豆国产自产在线观看| 丁香婷婷综合网| 国产激情一区二区三区| 韩国欧美国产1区| 精品在线视频一区| 久久不见久久见免费视频1| 日韩av一区二区三区四区| 亚洲高清在线精品| 日韩精品一卡二卡三卡四卡无卡| 亚洲一区二区三区中文字幕| 亚洲丝袜美腿综合| 亚洲欧美日韩系列| 亚洲一区二区三区四区五区黄 | 国产欧美一区二区精品性色| 2024国产精品| 国产视频视频一区| 国产免费成人在线视频| 国产精品天干天干在线综合| 国产精品天干天干在观线| 国产精品国产三级国产aⅴ中文| 国产精品久久久久久福利一牛影视| 欧美激情在线免费观看| 亚洲国产精品成人综合色在线婷婷| 国产日韩欧美一区二区三区综合| 精品国产乱码91久久久久久网站| 日韩精品中文字幕一区| 精品国产一区二区国模嫣然| 国产欧美一区二区精品婷婷| 中文字幕在线不卡一区| 亚洲欧美另类久久久精品| 亚洲精品免费在线播放| 丝袜亚洲另类欧美| 激情文学综合丁香| 成人av先锋影音| 欧美日韩在线三级| 亚洲精品在线电影| 中文字幕制服丝袜一区二区三区 | 亚洲国产成人在线| 亚洲视频一二区| 舔着乳尖日韩一区| 国产高清无密码一区二区三区| 成年人午夜久久久| 717成人午夜免费福利电影| 久久女同互慰一区二区三区| ...中文天堂在线一区| 午夜免费久久看| 福利一区二区在线| 欧洲视频一区二区| 久久久久国产精品厨房| 亚洲精品成人悠悠色影视| 久久精品av麻豆的观看方式| 懂色av一区二区三区蜜臀| 欧美日韩激情一区| 久久久www免费人成精品| 一区二区在线观看视频| 国内成人自拍视频| 色婷婷久久综合| 国产三级精品在线| 日精品一区二区三区| 成人av在线电影| 日韩美一区二区三区| 亚洲黄色性网站| 丰满白嫩尤物一区二区| 欧美人动与zoxxxx乱| 国产精品久久毛片av大全日韩| 蜜桃av一区二区| 欧美性xxxxx极品少妇| 中文字幕精品一区二区精品绿巨人| 亚洲va国产天堂va久久en| 高清成人免费视频| 日韩欧美一区二区在线视频| 亚洲欧美精品午睡沙发| 丁香另类激情小说| 日韩欧美一级特黄在线播放| 亚洲综合一区二区三区| 99re这里都是精品| 国产欧美日韩一区二区三区在线观看 | 成人av电影在线观看| 日韩一区二区视频| 亚洲福利一二三区| 色八戒一区二区三区| 国产精品视频看| 国产成人av电影在线| 精品免费视频.| 日本aⅴ免费视频一区二区三区| 欧美亚洲免费在线一区| 亚洲日本免费电影| aaa欧美日韩| 国产精品短视频| 成人精品视频一区| 久久九九99视频| 国产又粗又猛又爽又黄91精品| 日韩欧美123| 婷婷久久综合九色综合伊人色| 在线精品视频一区二区| 亚洲精品成人精品456| 91看片淫黄大片一级在线观看| 日韩一区中文字幕| 色综合夜色一区| 亚洲美女电影在线| 欧美性色aⅴ视频一区日韩精品| 亚洲欧美日韩电影| 91麻豆精品在线观看| 一区二区三区四区蜜桃| 日本电影欧美片| 亚洲成av人片一区二区梦乃| 欧美日韩国产综合一区二区 | 久久机这里只有精品| 精品国产成人系列| 国产一区二区三区在线观看精品 | 99久久久无码国产精品| 国产精品久久777777| 92精品国产成人观看免费| 亚洲欧洲国产日韩| 欧美色综合久久| 丝瓜av网站精品一区二区| 欧美一区二区在线观看| 激情五月激情综合网| 国产精品视频一二| 欧美午夜一区二区| 奇米影视在线99精品| 久久久国产午夜精品| 91色porny在线视频| 亚洲高清免费视频| 精品动漫一区二区三区在线观看| 国产精品18久久久久| 亚洲裸体在线观看| 欧美日韩国产精选| 国产成人日日夜夜| 亚洲一区二区三区爽爽爽爽爽 | 久久婷婷成人综合色| 99久久婷婷国产综合精品|