当前位置: 首页>>代码示例>>C++>>正文


C++ Sentence::send方法代码示例

本文整理汇总了C++中Sentence::send方法的典型用法代码示例。如果您正苦于以下问题:C++ Sentence::send方法的具体用法?C++ Sentence::send怎么用?C++ Sentence::send使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在Sentence的用法示例。


在下文中一共展示了Sentence::send方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: startPlaying


//.........这里部分代码省略.........
                                                                     12
                1         2 3       4 5        6 7   8   9     10  11 | 13
                |         | |       | |        | |   |   |      |   | | |
         $--RMC,hhmmss.ss,A,llll.ll,a,yyyyy.yy,a,x.x,x.x,ddmmyy,x.x,a,a*hh<CR><LF>

         $GPRMC,132217.00,A,5228.19856,N,01408.32249,E,47.100,267.38,300710,,,A*58

         Field Number:
          1) UTC Time
          2) Status, A = valid position, V = Navigation receiver warning
          3) Latitude ddmm.mmm
          4) Latitude hemisphere, N or S
          5) Longitude dddmm.mm
          6) Longitude hemisphere, E or W
          7) Speed over ground, knots 0.0 ... 999.9
          8) Course over ground, degrees true
          9) UTC date of position fix, ddmmyy format
         10) Magnetic Variation, degrees
         11) Magnetic Variation direction, E or W
         12) Signal integrity, A=Autonomous mode
         13) Checksum, hh
      */

      // Prepare RMC sentence
      QString rmc = "$GPRMC," + time1 + "," + status1 + "," +
	            latDeg1 + "," + latHem1 + "," +
	            lonDeg1 + "," + lonHem1 + "," +
	            QString("%1").arg( speed.getKnots(), 0, 'f', 1 ) + "," +
	            QString("%1").arg( bearing, 0, 'f', 0 ) + "," +
	            date + ",,," + "A";

      Sentence sentence;

      sentence.send( rmc, m_fifo );

      /**
        GLL - Geographic Position - Latitude/Longitude

               1       2 3        4 5         6 7
               |       | |        | |         | |
        $--GLL,llll.ll,a,yyyyy.yy,a,hhmmss.ss,A*hh<CR><LF>

         Field Number:
          1) Latitude
          2) N or S (North or South)
          3) Longitude
          4) E or W (East or West)
          5) Universal Time Coordinated (UTC)
          6) Status A - Data Valid, V - Data Invalid
          7) Checksum

          $GPGLL,4916.45,N,12311.12,W,225444,A
      */

#if 0
      // Not necessary to send this.
      QString ggl = "$GPGLL," +
	            latDeg1 + "," + latHem1 + "," +
	  	    lonDeg1 + "," + lonHem1 + "," +
	  	    time1 + "," +
	  	    status1;

      sentence.send( ggl, m_fifo );
#endif

      /**
开发者ID:Exadios,项目名称:Cumulus,代码行数:67,代码来源:IgcPlay.cpp

示例2: main

////////////////////////////////////////////////////////////////////////////////
// M A I N
////////////////////////////////////////////////////////////////////////////////
int main(int argc, char **argv)
{
  QString mode;
  QStringList Argv;

  for (int i = 1; i <= argc; i++)
    {
      Argv << argv[i];
    }

  if( argc < 2 )
    {
      char *prog = basename(argv[0]);

      cout << "NMEA GPS Simulator 1.6.0 for Cumulus, 2003-2008 E. Voellm, 2009-2014 A. Pauli (GPL)" << endl << endl
           << "Usage: " << prog << " str|cir|pos|gpos|nplay|iplay [params]" << endl << endl
           << "Parameters: str:  Straight Flight "<< endl
           << "            cir:  Circling "<< endl
           << "            pos:  Fixed Position e.g. standstill in a wave (climb works)"<< endl
           << "            gpos: Fixed Position on ground "<< endl
           << "            nplay: Plays a recorded NMEA file. GPRMC is required to be contained!" << endl
           << "            iplay: Plays a recorded IGC file." << endl
           << "            params:"<< endl
           << "              lat=dd:mm:ss[N|S]  or lat=dd.mmmm  Initial Latitude" << endl
           << "              lon=ddd:mm:ss[E|W] or lon=dd.mmmm  Initial Longitude" << endl
           << "              speed=[km/h] head=[deg]: Glider speed and heading" << endl
           << "              wind=[km/h]  winddir=[deg]: Wind force and direction" << endl
           << "              radius=[m]:  needed for circling" << endl
           << "              dir=[right|left]: Direction of Circle" << endl
           << "              alt=[m]: Altitude of Glider" << endl
           << "              climb=[m/s]: Climbrate" << endl
           << "              sentence0...9='NMEA sentence without checksum': $ and * can be omitted" << endl
           << "              time=[s]: duration of operation" << endl
           << "              pause=[ms]: pause between to send periods" << endl
           << "              device=[path to named pipe]: write into this pipe, default is /tmp/nmeasim" << endl
           << "              device=[ttySx,<speed>]: write to device ttySx with the given speed" << endl
           << "              file=[path to file]: to be played" << endl
           << "              skip=[number]: lines to be skipped in the play file" << endl
           << "              start=[HHMMSS]: goto B-Record start time in the IGC play file" << endl
           << "              factor=[number]: time factor used by IGC file play, default is 1" << endl
           << "            Note: all values can also be specified as float, like 110.5 " << endl << endl
           << "Example: " << prog << " str lat=48:31:48N lon=009:24:00E speed=125 winddir=270" << endl << endl
           << "NMEA output is written into named pipe '" << device.toLatin1().data() << "'." << endl
           << "Cumulus should use the same device name to get these data." << endl;

        exit (0);
    }

  mode = Argv[0];

  qDebug() << "mode=" << mode;

  // @AP: Reset the locale that is used for number formatting to "C" locale.
  setlocale( LC_ALL, "" );
  setlocale( LC_NUMERIC, "C" );
  setenv( "LC_NUMERIC", "C", 1 );
  setenv( "LANG", "C", 1 );

  // First of all read command configuration from file.
  // Determine configuration file position. It is normally stored in the home
  // directory of the user.
  const char *home = getenv("HOME");

  if( home )
    {
      confFile = QString(home) + "/nmea.cfg";
    }
  else
    {
      confFile = "./nmea.cfg";
    }

  readConfig();

  // Override by things given at command line
  cout << "\nParameters from command line:" << endl;

  for (int i = 1; i < argc; i++)
    {
      cout <<  Argv[i].toLatin1().data() << endl;
      scanConfig( Argv[i] );
    }

  // calculate Wind as it was given
  cout << "Parameters for operation:" << endl;

  float winddirTrue = winddir+180;

  if ( winddirTrue > 360.0 )
    winddirTrue -= 360.0;

  if( mode == "str" )
    cout << "Mode:      Straight Flight  " << endl;
  if( mode == "cir" )
    cout << "Mode:      Circling  " << endl;
  if( mode == "gpos" )
    {
//.........这里部分代码省略.........
开发者ID:Exadios,项目名称:Cumulus,代码行数:101,代码来源:main.cpp


注:本文中的Sentence::send方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。