2017-02-24 23:34:11 +00:00
|
|
|
|
2018-02-03 02:33:29 +00:00
|
|
|
#ifdef B3_USE_ROBOTSIM_GUI
|
2018-09-23 21:17:31 +00:00
|
|
|
#include "b3RobotSimulatorClientAPI.h"
|
2018-02-03 02:33:29 +00:00
|
|
|
#else
|
2018-09-23 21:17:31 +00:00
|
|
|
#include "b3RobotSimulatorClientAPI_NoGUI.h"
|
2018-02-03 02:33:29 +00:00
|
|
|
#endif
|
|
|
|
|
2017-02-24 23:34:11 +00:00
|
|
|
#include "../Utils/b3Clock.h"
|
|
|
|
|
|
|
|
#include <string.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <assert.h>
|
2018-09-23 21:17:31 +00:00
|
|
|
#define ASSERT_EQ(a, b) assert((a) == (b));
|
2017-02-24 23:34:11 +00:00
|
|
|
#include "MinitaurSetup.h"
|
2018-02-03 02:33:29 +00:00
|
|
|
|
2017-02-24 23:34:11 +00:00
|
|
|
int main(int argc, char* argv[])
|
|
|
|
{
|
2018-02-03 02:33:29 +00:00
|
|
|
#ifdef B3_USE_ROBOTSIM_GUI
|
2017-02-24 23:34:11 +00:00
|
|
|
b3RobotSimulatorClientAPI* sim = new b3RobotSimulatorClientAPI();
|
2018-02-03 02:33:29 +00:00
|
|
|
bool isConnected = sim->connect(eCONNECT_GUI);
|
|
|
|
#else
|
|
|
|
b3RobotSimulatorClientAPI_NoGUI* sim = new b3RobotSimulatorClientAPI_NoGUI();
|
|
|
|
bool isConnected = sim->connect(eCONNECT_DIRECT);
|
|
|
|
#endif
|
|
|
|
if (!isConnected)
|
|
|
|
{
|
|
|
|
printf("Cannot connect\n");
|
|
|
|
return -1;
|
|
|
|
}
|
2017-02-24 23:34:11 +00:00
|
|
|
//Can also use eCONNECT_DIRECT,eCONNECT_SHARED_MEMORY,eCONNECT_UDP,eCONNECT_TCP, for example:
|
|
|
|
//sim->connect(eCONNECT_UDP, "localhost", 1234);
|
2018-09-23 21:17:31 +00:00
|
|
|
sim->configureDebugVisualizer(COV_ENABLE_GUI, 0);
|
|
|
|
// sim->configureDebugVisualizer( COV_ENABLE_SHADOWS, 0);//COV_ENABLE_WIREFRAME
|
2017-05-02 05:35:33 +00:00
|
|
|
sim->setTimeOut(10);
|
2017-02-24 23:34:11 +00:00
|
|
|
//syncBodies is only needed when connecting to an existing physics server that has already some bodies
|
|
|
|
sim->syncBodies();
|
2018-09-23 21:17:31 +00:00
|
|
|
btScalar fixedTimeStep = 1. / 240.;
|
2017-03-16 00:09:17 +00:00
|
|
|
|
|
|
|
sim->setTimeStep(fixedTimeStep);
|
|
|
|
|
2018-09-23 21:17:31 +00:00
|
|
|
btQuaternion q = sim->getQuaternionFromEuler(btVector3(0.1, 0.2, 0.3));
|
2018-05-27 00:42:33 +00:00
|
|
|
btVector3 rpy;
|
2017-03-16 00:09:17 +00:00
|
|
|
rpy = sim->getEulerFromQuaternion(q);
|
2017-02-24 23:34:11 +00:00
|
|
|
|
2018-09-23 21:17:31 +00:00
|
|
|
sim->setGravity(btVector3(0, 0, -9.8));
|
2017-02-24 23:34:11 +00:00
|
|
|
|
2017-03-16 00:09:17 +00:00
|
|
|
//int blockId = sim->loadURDF("cube.urdf");
|
|
|
|
//b3BodyInfo bodyInfo;
|
|
|
|
//sim->getBodyInfo(blockId,&bodyInfo);
|
2017-03-03 19:33:20 +00:00
|
|
|
|
2017-05-02 05:35:33 +00:00
|
|
|
sim->loadURDF("plane.urdf");
|
2017-02-24 23:34:11 +00:00
|
|
|
|
2017-05-02 05:35:33 +00:00
|
|
|
MinitaurSetup minitaur;
|
2018-09-23 21:17:31 +00:00
|
|
|
int minitaurUid = minitaur.setupMinitaur(sim, btVector3(0, 0, .3));
|
2017-02-24 23:34:11 +00:00
|
|
|
|
2017-05-02 05:35:33 +00:00
|
|
|
//b3RobotSimulatorLoadUrdfFileArgs args;
|
|
|
|
//args.m_startPosition.setValue(2,0,1);
|
2017-03-16 00:09:17 +00:00
|
|
|
//int r2d2 = sim->loadURDF("r2d2.urdf",args);
|
2017-02-24 23:34:11 +00:00
|
|
|
|
2017-03-16 00:09:17 +00:00
|
|
|
//b3RobotSimulatorLoadFileResults sdfResults;
|
|
|
|
//if (!sim->loadSDF("two_cubes.sdf",sdfResults))
|
|
|
|
//{
|
2018-09-23 21:17:31 +00:00
|
|
|
// b3Warning("Can't load SDF!\n");
|
2017-03-16 00:09:17 +00:00
|
|
|
//}
|
2017-02-24 23:34:11 +00:00
|
|
|
|
|
|
|
b3Clock clock;
|
|
|
|
double startTime = clock.getTimeInSeconds();
|
|
|
|
double simWallClockSeconds = 20.;
|
2017-02-25 05:40:43 +00:00
|
|
|
#if 0
|
2017-02-24 23:34:11 +00:00
|
|
|
while (clock.getTimeInSeconds()-startTime < simWallClockSeconds)
|
|
|
|
{
|
|
|
|
sim->stepSimulation();
|
|
|
|
}
|
2017-02-25 05:40:43 +00:00
|
|
|
#endif
|
2017-03-02 20:33:22 +00:00
|
|
|
sim->setRealTimeSimulation(false);
|
2017-03-16 16:13:33 +00:00
|
|
|
int vidLogId = -1;
|
|
|
|
int minitaurLogId = -1;
|
2017-03-20 17:58:07 +00:00
|
|
|
int rotateCamera = 0;
|
2017-03-16 16:13:33 +00:00
|
|
|
|
2017-03-02 20:33:22 +00:00
|
|
|
while (sim->canSubmitCommand())
|
2017-02-24 23:34:11 +00:00
|
|
|
{
|
2017-03-02 20:33:22 +00:00
|
|
|
b3KeyboardEventsData keyEvents;
|
|
|
|
sim->getKeyboardEvents(&keyEvents);
|
|
|
|
if (keyEvents.m_numKeyboardEvents)
|
|
|
|
{
|
2017-03-16 16:13:33 +00:00
|
|
|
//printf("num key events = %d]\n", keyEvents.m_numKeyboardEvents);
|
2017-03-02 20:33:22 +00:00
|
|
|
//m_keyState is a flag combination of eButtonIsDown,eButtonTriggered, eButtonReleased
|
2018-09-23 21:17:31 +00:00
|
|
|
for (int i = 0; i < keyEvents.m_numKeyboardEvents; i++)
|
2017-03-02 20:33:22 +00:00
|
|
|
{
|
2017-03-20 17:58:07 +00:00
|
|
|
b3KeyboardEvent& e = keyEvents.m_keyboardEvents[i];
|
|
|
|
|
2018-09-23 21:17:31 +00:00
|
|
|
if (e.m_keyCode == '0')
|
2017-03-16 16:13:33 +00:00
|
|
|
{
|
2018-09-23 21:17:31 +00:00
|
|
|
if (e.m_keyState & eButtonTriggered)
|
2017-03-16 16:13:33 +00:00
|
|
|
{
|
|
|
|
if (vidLogId < 0)
|
|
|
|
{
|
2018-09-23 21:17:31 +00:00
|
|
|
vidLogId = sim->startStateLogging(STATE_LOGGING_VIDEO_MP4, "video.mp4");
|
|
|
|
}
|
2017-03-16 16:13:33 +00:00
|
|
|
else
|
|
|
|
{
|
|
|
|
sim->stopStateLogging(vidLogId);
|
2018-09-23 21:17:31 +00:00
|
|
|
vidLogId = -1;
|
2017-03-16 16:13:33 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-09-23 21:17:31 +00:00
|
|
|
if (e.m_keyCode == 'm')
|
2017-03-16 16:13:33 +00:00
|
|
|
{
|
2018-09-23 21:17:31 +00:00
|
|
|
if (minitaurLogId < 0 && e.m_keyState & eButtonTriggered)
|
2017-03-16 16:13:33 +00:00
|
|
|
{
|
2018-09-23 21:17:31 +00:00
|
|
|
minitaurLogId = sim->startStateLogging(STATE_LOGGING_MINITAUR, "simlog.bin");
|
2017-03-16 16:13:33 +00:00
|
|
|
}
|
2018-09-23 21:17:31 +00:00
|
|
|
if (minitaurLogId >= 0 && e.m_keyState & eButtonReleased)
|
2017-03-16 16:13:33 +00:00
|
|
|
{
|
|
|
|
sim->stopStateLogging(minitaurLogId);
|
2018-09-23 21:17:31 +00:00
|
|
|
minitaurLogId = -1;
|
2017-03-16 16:13:33 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-09-23 21:17:31 +00:00
|
|
|
if (e.m_keyCode == 'r' && e.m_keyState & eButtonTriggered)
|
2017-03-20 17:58:07 +00:00
|
|
|
{
|
2018-09-23 21:17:31 +00:00
|
|
|
rotateCamera = 1 - rotateCamera;
|
2017-03-20 17:58:07 +00:00
|
|
|
}
|
|
|
|
|
2017-03-16 16:13:33 +00:00
|
|
|
//printf("keyEvent[%d].m_keyCode = %d, state = %d\n", i,keyEvents.m_keyboardEvents[i].m_keyCode,keyEvents.m_keyboardEvents[i].m_keyState);
|
2017-03-02 20:33:22 +00:00
|
|
|
}
|
|
|
|
}
|
2017-03-16 00:09:17 +00:00
|
|
|
sim->stepSimulation();
|
2017-03-20 17:58:07 +00:00
|
|
|
|
|
|
|
if (rotateCamera)
|
|
|
|
{
|
2018-09-23 21:17:31 +00:00
|
|
|
static double yaw = 0;
|
2017-03-20 17:58:07 +00:00
|
|
|
double distance = 1;
|
2018-09-23 21:17:31 +00:00
|
|
|
yaw += 0.1;
|
2018-05-27 00:42:33 +00:00
|
|
|
btVector3 basePos;
|
|
|
|
btQuaternion baseOrn;
|
2018-09-23 21:17:31 +00:00
|
|
|
sim->getBasePositionAndOrientation(minitaurUid, basePos, baseOrn);
|
|
|
|
sim->resetDebugVisualizerCamera(distance, -20, yaw, basePos);
|
2017-03-20 17:58:07 +00:00
|
|
|
}
|
2018-09-23 21:17:31 +00:00
|
|
|
b3Clock::usleep(1000. * 1000. * fixedTimeStep);
|
2017-02-24 23:34:11 +00:00
|
|
|
}
|
|
|
|
|
2017-03-02 20:33:22 +00:00
|
|
|
printf("sim->disconnect\n");
|
|
|
|
|
2017-02-24 23:34:11 +00:00
|
|
|
sim->disconnect();
|
2018-09-23 21:17:31 +00:00
|
|
|
|
2017-03-02 20:33:22 +00:00
|
|
|
printf("delete sim\n");
|
2017-02-24 23:34:11 +00:00
|
|
|
delete sim;
|
|
|
|
|
2017-03-02 20:33:22 +00:00
|
|
|
printf("exit\n");
|
2017-02-24 23:34:11 +00:00
|
|
|
}
|