⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 sicklms200.hh

📁 机器人人3D仿真工具,可以加入到Simbad仿真环境下应用。
💻 HH
字号:
/* *  Gazebo - Outdoor Multi-Robot Simulator *  Copyright (C) 2003   *     Nate Koenig & Andrew Howard * *  This program is free software; you can redistribute it and/or modify *  it under the terms of the GNU General Public License as published by *  the Free Software Foundation; either version 2 of the License, or *  (at your option) any later version. * *  This program is distributed in the hope that it will be useful, *  but WITHOUT ANY WARRANTY; without even the implied warranty of *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the *  GNU General Public License for more details. * *  You should have received a copy of the GNU General Public License *  along with this program; if not, write to the Free Software *  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA * *//* Desc: Model for a Pioneer2AT * Author: Andrew Howard * Date: 8 May 2003 * CVS: $Id: SickLMS200.hh,v 1.22 2005/05/04 02:31:31 natepak Exp $ */#ifndef SICKLMS200_HH#define SICKLMS200_HH#include "Body.hh"#include "Model.hh"// Forward declarationsclass RayProximity;/// @brief Simulate SICKLMS200 scanning laser range finder.class SickLMS200 : public Model{  /// @brief Constructor  public: SickLMS200( World *world );  /// @brief Destructor  public: virtual ~SickLMS200();    /// @brief Load the model  public: virtual int Load( WorldFile *file, WorldFileNode *node );  /// @brief Initialize the model  public: virtual int Init( WorldFile *file, WorldFileNode *node );  /// @brief Finalize the model  public: virtual int Fini();  /// @brief Update the model state  public: virtual void Update( double step );  /// @brief Load ODE stuff  private: int OdeLoad( WorldFile *file, WorldFileNode *node );  /// @brief Load rays  private: int RayLoad( WorldFile *file, WorldFileNode *node );  /// @brief Update the data in the laser interface  private: void PutLaserData();  /// @brief Update the data in the fiducial interface  private: void PutFiducialData();  // Finalize rays  private: int RayFini();    // Initialize the external interface  private: int IfaceInit();  // Finalize the external interface  private: int IfaceFini();  // Update the data in the external interface  private: void IfacePutData();  // Get command from the interface  private: bool IFaceGetCmd();   // ODE objects  private: Body *body;    // Ray sensor  private: RayProximity *sensor;    // External interfaces  private: gz_laser_t *laser_iface;  private: gz_fiducial_t *fiducial_iface;  // Laser settings  private: int rayCount;  private: int rangeCount;  private: double laserMinRange, laserMaxRange;  private: double laserMinAngle, laserMaxAngle;  private: double laserPeriod;  private: double laserTime;};#endif

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -