00001 /*************************************************************************** 00002 * Copyright (C) 2005 by Robot Group Leipzig * 00003 * martius@informatik.uni-leipzig.de * 00004 * fhesse@informatik.uni-leipzig.de * 00005 * der@informatik.uni-leipzig.de * 00006 * * 00007 * This program is free software; you can redistribute it and/or modify * 00008 * it under the terms of the GNU General Public License as published by * 00009 * the Free Software Foundation; either version 2 of the License, or * 00010 * (at your option) any later version. * 00011 * * 00012 * This program is distributed in the hope that it will be useful, * 00013 * but WITHOUT ANY WARRANTY; without even the implied warranty of * 00014 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * 00015 * GNU General Public License for more details. * 00016 * * 00017 * You should have received a copy of the GNU General Public License * 00018 * along with this program; if not, write to the * 00019 * Free Software Foundation, Inc., * 00020 * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * 00021 * * 00022 * $Log: positionsensor.h,v $ 00023 * Revision 1.1 2005/11/22 10:24:04 martius 00024 * abstract class for position sensor 00025 * 00026 * * 00027 ***************************************************************************/ 00028 #ifndef __POSITIONSENSOR_H 00029 #define __POSITIONSENSOR_H 00030 00031 #include <list> 00032 using namespace std; 00033 #include <ode/common.h> 00034 #include "position.h" 00035 00036 /** Abstract class for Position-sensors. 00037 The sensor value is usually some kind of distance to some fixed object in space 00038 */ 00039 class PositionSensor { 00040 public: 00041 PositionSensor() {} 00042 virtual ~PositionSensor() {} 00043 00044 /** initialises sensor with body of robot 00045 @return number of sensor values returned by get 00046 */ 00047 virtual int init(dBodyID body) = 0; 00048 00049 /** performs sense action 00050 */ 00051 virtual bool sense(const GlobalData& globaldata) = 0; 00052 00053 /** returns a list of sensor values (usually in the range [0,1] ) 00054 */ 00055 virtual list<double> get() = 0; 00056 00057 }; 00058 00059 #endif
1.4.7