mirror of
https://github.com/VitaAetaerna/Robotino.git
synced 2024-11-10 04:11:36 +01:00
Create LineFollow
This commit is contained in:
parent
8e435a14b1
commit
7febd48419
197
LineFollow
Normal file
197
LineFollow
Normal file
@ -0,0 +1,197 @@
|
||||
#include <iostream>
|
||||
#include <stdlib.h>
|
||||
#include "rec/robotino/api2/all.h"
|
||||
#include <iostream>
|
||||
|
||||
using namespace rec::robotino::api2;
|
||||
using namespace std;
|
||||
bool _run = true;
|
||||
|
||||
class MyCom : public Com
|
||||
{
|
||||
public:
|
||||
MyCom()
|
||||
: Com( "LineFollow" )
|
||||
{
|
||||
}
|
||||
|
||||
void errorEvent( const char* errorString )
|
||||
{
|
||||
std::cerr << "Error: " << errorString << std::endl;
|
||||
}
|
||||
|
||||
void connectedEvent()
|
||||
{
|
||||
std::cout << "Connected." << std::endl;
|
||||
}
|
||||
|
||||
void connectionClosedEvent()
|
||||
{
|
||||
std::cout << "Connection closed." << std::endl;
|
||||
}
|
||||
|
||||
void logEvent( const char* message, int level )
|
||||
{
|
||||
std::cout << message << std::endl;
|
||||
}
|
||||
};
|
||||
|
||||
class MyBumper : public Bumper
|
||||
{
|
||||
public:
|
||||
MyBumper()
|
||||
: bumped( false )
|
||||
{
|
||||
}
|
||||
|
||||
void bumperEvent( bool hasContact )
|
||||
{
|
||||
bumped |= hasContact;
|
||||
if (true == bumped){
|
||||
std::cout << "Bumper has " << ( hasContact ? "contact" : "no contact") << std::endl;
|
||||
}
|
||||
}
|
||||
|
||||
bool bumped;
|
||||
};
|
||||
|
||||
double x_distance = 0;
|
||||
double y_distance = 0;
|
||||
double phi_absolute = 0;
|
||||
unsigned int sequence = 0;
|
||||
|
||||
|
||||
int digital_inputs[8] = {0,0,0,0,0,0,0,0};
|
||||
|
||||
class MyOdometry: public Odometry{
|
||||
void readingsEvent(double x,double y, double phi, float vx, float vy, float omega, unsigned int seq ){
|
||||
// cout << "X: " << x << " Y: " << y << " Richtung: " << phi << " Sequenz: " << seq << endl;
|
||||
x_distance = x;
|
||||
y_distance = y;
|
||||
phi_absolute = phi;
|
||||
sequence = seq;
|
||||
}
|
||||
};
|
||||
|
||||
|
||||
|
||||
|
||||
class MyDigitalInputArray: public DigitalInputArray{
|
||||
|
||||
void valuesChangedEvent(const int *value, unsigned int size){
|
||||
|
||||
for (int i=0; i<size; i++){
|
||||
digital_inputs[i] = value[i];
|
||||
}
|
||||
cout << *value;
|
||||
}
|
||||
};
|
||||
|
||||
|
||||
MyCom com;
|
||||
MyBumper bumper;
|
||||
OmniDrive omniDrive;
|
||||
MyOdometry odo;
|
||||
MyDigitalInputArray mydia;
|
||||
|
||||
void init( const std::string& hostname )
|
||||
{
|
||||
|
||||
// Connect
|
||||
std::cout << "Connecting...";
|
||||
com.setAddress( hostname.c_str() );
|
||||
|
||||
com.connectToServer( true );
|
||||
|
||||
if( false == com.isConnected() )
|
||||
{
|
||||
std::cout << std::endl << "Could not connect to " << com.address() << std::endl;
|
||||
rec::robotino::api2::shutdown();
|
||||
exit( 1 );
|
||||
}
|
||||
else
|
||||
{
|
||||
std::cout << "success" << std::endl;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
void drive()
|
||||
{
|
||||
odo.set(0,0,0,-1);
|
||||
|
||||
|
||||
while( com.isConnected() && false == bumper.value() && _run )
|
||||
{
|
||||
|
||||
rec::robotino::api2::msleep(100);
|
||||
|
||||
|
||||
DigitalInput();
|
||||
|
||||
if (0 == digital_inputs[0]){
|
||||
omniDrive.setVelocity(0.2,0,0);
|
||||
}
|
||||
if (1 == digital_inputs[0]){
|
||||
omniDrive.setVelocity(0,0,0);
|
||||
}
|
||||
|
||||
|
||||
com.processEvents();
|
||||
rec::robotino::api2::msleep(100);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
void destroy()
|
||||
{
|
||||
com.disconnectFromServer();
|
||||
}
|
||||
|
||||
int main( int argc, char **argv )
|
||||
{
|
||||
std::string hostname = "192.168.100.174";
|
||||
if( argc > 1 )
|
||||
{
|
||||
hostname = argv[1];
|
||||
}
|
||||
|
||||
|
||||
|
||||
//main program routine starts in here
|
||||
try
|
||||
{
|
||||
//connect to your robotino (or try at least)
|
||||
init( hostname );
|
||||
//drive (this contains a while loop)
|
||||
drive();
|
||||
//exit
|
||||
destroy();
|
||||
}
|
||||
catch( const rec::robotino::api2::RobotinoException& e )
|
||||
{
|
||||
std::cerr << "Com Error: " << e.what() << std::endl;
|
||||
}
|
||||
catch( const std::exception& e )
|
||||
{
|
||||
std::cerr << "Error: " << e.what() << std::endl;
|
||||
}
|
||||
catch( ... )
|
||||
{
|
||||
std::cerr << "Unknow Error" << std::endl;
|
||||
}
|
||||
|
||||
rec::robotino::api2::shutdown();
|
||||
|
||||
#ifdef WIN32
|
||||
std::cout << "Press any key to exit..." << std::endl;
|
||||
rec::robotino::api2::waitForKey();
|
||||
#endif
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user