2015-05-28 23:05:24 +00:00
|
|
|
|
|
|
|
#include "PhysicsServer.h"
|
|
|
|
|
|
|
|
#include "PosixSharedMemory.h"
|
2015-06-04 22:37:18 +00:00
|
|
|
#include "Win32SharedMemory.h"
|
|
|
|
|
2015-05-29 00:49:55 +00:00
|
|
|
#include "../Importers/ImportURDFDemo/MyURDFImporter.h"
|
|
|
|
#include "../Importers/ImportURDFDemo/MyMultiBodyCreator.h"
|
|
|
|
#include "../Importers/ImportURDFDemo/URDF2Bullet.h"
|
|
|
|
|
2015-05-29 22:04:05 +00:00
|
|
|
#include "SharedMemoryCommon.h"
|
2015-05-28 23:05:24 +00:00
|
|
|
|
|
|
|
|
2015-05-29 22:04:05 +00:00
|
|
|
class PhysicsServer : public SharedMemoryCommon
|
2015-05-28 23:05:24 +00:00
|
|
|
{
|
|
|
|
SharedMemoryInterface* m_sharedMemory;
|
|
|
|
SharedMemoryExampleData* m_testBlock1;
|
2015-05-29 22:04:05 +00:00
|
|
|
bool m_wantsShutdown;
|
|
|
|
|
2015-05-28 23:05:24 +00:00
|
|
|
public:
|
|
|
|
|
|
|
|
PhysicsServer(GUIHelperInterface* helper);
|
|
|
|
|
|
|
|
virtual ~PhysicsServer();
|
|
|
|
|
|
|
|
virtual void initPhysics();
|
|
|
|
|
|
|
|
virtual void stepSimulation(float deltaTime);
|
|
|
|
|
2015-05-29 22:04:05 +00:00
|
|
|
void releaseSharedMemory();
|
|
|
|
|
2015-05-29 00:49:55 +00:00
|
|
|
bool loadUrdf(const char* fileName, const btVector3& pos, const btQuaternion& orn,
|
|
|
|
bool useMultiBody, bool useFixedBase);
|
|
|
|
|
2015-05-28 23:05:24 +00:00
|
|
|
virtual void resetCamera()
|
|
|
|
{
|
|
|
|
float dist = 1;
|
|
|
|
float pitch = 50;
|
|
|
|
float yaw = 35;
|
|
|
|
float targetPos[3]={-3,2.8,-2.5};
|
|
|
|
m_guiHelper->resetCamera(dist,pitch,yaw,targetPos[0],targetPos[1],targetPos[2]);
|
|
|
|
}
|
|
|
|
|
2015-05-29 22:04:05 +00:00
|
|
|
virtual bool wantsTermination();
|
2015-05-28 23:05:24 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
PhysicsServer::PhysicsServer(GUIHelperInterface* helper)
|
2015-05-29 22:04:05 +00:00
|
|
|
:SharedMemoryCommon(helper),
|
|
|
|
m_testBlock1(0),
|
|
|
|
m_wantsShutdown(false)
|
2015-05-28 23:05:24 +00:00
|
|
|
{
|
|
|
|
b3Printf("Started PhysicsServer\n");
|
2015-06-04 22:37:18 +00:00
|
|
|
bool useServer = true;
|
|
|
|
#ifdef _WIN32
|
|
|
|
m_sharedMemory = new Win32SharedMemoryServer();
|
|
|
|
#else
|
2015-05-28 23:05:24 +00:00
|
|
|
m_sharedMemory = new PosixSharedMemory();
|
2015-06-04 22:37:18 +00:00
|
|
|
#endif
|
2015-05-28 23:05:24 +00:00
|
|
|
}
|
|
|
|
|
2015-05-29 22:04:05 +00:00
|
|
|
void PhysicsServer::releaseSharedMemory()
|
2015-05-28 23:05:24 +00:00
|
|
|
{
|
|
|
|
if (m_testBlock1)
|
|
|
|
{
|
|
|
|
m_testBlock1->m_magicId = 0;
|
|
|
|
b3Printf("magic id = %d\n",m_testBlock1->m_magicId);
|
2015-05-29 22:04:05 +00:00
|
|
|
btAssert(m_sharedMemory);
|
|
|
|
m_sharedMemory->releaseSharedMemory(SHARED_MEMORY_KEY, SHARED_MEMORY_SIZE);
|
|
|
|
}
|
|
|
|
if (m_sharedMemory)
|
|
|
|
{
|
|
|
|
|
|
|
|
delete m_sharedMemory;
|
|
|
|
m_sharedMemory = 0;
|
|
|
|
m_testBlock1 = 0;
|
2015-05-28 23:05:24 +00:00
|
|
|
}
|
2015-05-29 22:04:05 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
PhysicsServer::~PhysicsServer()
|
|
|
|
{
|
|
|
|
releaseSharedMemory();
|
2015-05-28 23:05:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void PhysicsServer::initPhysics()
|
|
|
|
{
|
2015-05-29 00:49:55 +00:00
|
|
|
createEmptyDynamicsWorld();
|
|
|
|
|
2015-05-28 23:05:24 +00:00
|
|
|
m_testBlock1 = (SharedMemoryExampleData*) m_sharedMemory->allocateSharedMemory(SHARED_MEMORY_KEY, SHARED_MEMORY_SIZE);
|
|
|
|
|
|
|
|
// btAssert(m_testBlock1);
|
|
|
|
if (m_testBlock1)
|
|
|
|
{
|
|
|
|
// btAssert(m_testBlock1->m_magicId != SHARED_MEMORY_MAGIC_NUMBER);
|
|
|
|
if (m_testBlock1->m_magicId == SHARED_MEMORY_MAGIC_NUMBER)
|
|
|
|
{
|
|
|
|
b3Printf("Warning: shared memory is already initialized, did you already spawn a server?\n");
|
|
|
|
}
|
|
|
|
|
|
|
|
m_testBlock1->m_numClientCommands = 0;
|
|
|
|
m_testBlock1->m_numServerCommands = 0;
|
|
|
|
m_testBlock1->m_numProcessedClientCommands=0;
|
|
|
|
m_testBlock1->m_numProcessedServerCommands=0;
|
|
|
|
|
|
|
|
m_testBlock1->m_magicId = SHARED_MEMORY_MAGIC_NUMBER;
|
|
|
|
b3Printf("Shared memory succesfully allocated\n");
|
|
|
|
} else
|
|
|
|
{
|
|
|
|
b3Error("Couldn't allocated shared memory, is it implemented on your operating system?\n");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-05-29 22:04:05 +00:00
|
|
|
|
|
|
|
bool PhysicsServer::wantsTermination()
|
|
|
|
{
|
|
|
|
return m_wantsShutdown;
|
|
|
|
}
|
|
|
|
|
2015-05-29 00:49:55 +00:00
|
|
|
bool PhysicsServer::loadUrdf(const char* fileName, const btVector3& pos, const btQuaternion& orn,
|
|
|
|
bool useMultiBody, bool useFixedBase)
|
|
|
|
{
|
|
|
|
|
|
|
|
MyURDFImporter u2b(m_guiHelper);
|
|
|
|
bool loadOk = u2b.loadURDF(fileName);
|
|
|
|
if (loadOk)
|
|
|
|
{
|
|
|
|
b3Printf("loaded %s OK!", fileName);
|
|
|
|
|
|
|
|
btTransform tr;
|
|
|
|
tr.setIdentity();
|
|
|
|
tr.setOrigin(pos);
|
|
|
|
tr.setRotation(orn);
|
|
|
|
int rootLinkIndex = u2b.getRootLinkIndex();
|
|
|
|
// printf("urdf root link index = %d\n",rootLinkIndex);
|
|
|
|
MyMultiBodyCreator creation(m_guiHelper);
|
2015-05-29 22:04:05 +00:00
|
|
|
|
2015-05-29 00:49:55 +00:00
|
|
|
ConvertURDF2Bullet(u2b,creation, tr,m_dynamicsWorld,useMultiBody,u2b.getPathPrefix());
|
|
|
|
btMultiBody* mb = creation.getBulletMultiBody();
|
|
|
|
|
2015-05-29 22:04:05 +00:00
|
|
|
return true;
|
2015-05-29 00:49:55 +00:00
|
|
|
}
|
2015-05-29 22:04:05 +00:00
|
|
|
|
|
|
|
return false;
|
2015-05-29 00:49:55 +00:00
|
|
|
}
|
|
|
|
|
2015-05-28 23:05:24 +00:00
|
|
|
void PhysicsServer::stepSimulation(float deltaTime)
|
|
|
|
{
|
2015-05-29 00:49:55 +00:00
|
|
|
|
2015-05-29 22:04:05 +00:00
|
|
|
bool wantsShutdown = false;
|
|
|
|
|
2015-05-28 23:05:24 +00:00
|
|
|
if (m_testBlock1)
|
|
|
|
{
|
|
|
|
///we ignore overflow of integer for now
|
|
|
|
if (m_testBlock1->m_numClientCommands> m_testBlock1->m_numProcessedClientCommands)
|
|
|
|
{
|
|
|
|
|
|
|
|
//until we implement a proper ring buffer, we assume always maximum of 1 outstanding commands
|
|
|
|
btAssert(m_testBlock1->m_numClientCommands==m_testBlock1->m_numProcessedClientCommands+1);
|
|
|
|
|
2015-05-29 00:49:55 +00:00
|
|
|
const SharedMemoryCommand& clientCmd =m_testBlock1->m_clientCommands[0];
|
2015-05-29 22:04:05 +00:00
|
|
|
m_testBlock1->m_numProcessedClientCommands++;
|
2015-05-29 00:49:55 +00:00
|
|
|
|
2015-05-28 23:05:24 +00:00
|
|
|
//consume the command
|
2015-05-29 00:49:55 +00:00
|
|
|
switch (clientCmd.m_type)
|
2015-05-28 23:05:24 +00:00
|
|
|
{
|
|
|
|
case CMD_LOAD_URDF:
|
|
|
|
{
|
2015-05-29 00:49:55 +00:00
|
|
|
b3Printf("Processed CMD_LOAD_URDF:%s",clientCmd.m_urdfArguments.m_urdfFileName);
|
2015-05-28 23:05:24 +00:00
|
|
|
|
|
|
|
//load the actual URDF and send a report: completed or failed
|
|
|
|
|
|
|
|
|
2015-05-29 00:49:55 +00:00
|
|
|
bool completedOk = loadUrdf(clientCmd.m_urdfArguments.m_urdfFileName,
|
|
|
|
btVector3(0,0,0), btQuaternion(0,0,0,1),true,true );
|
|
|
|
SharedMemoryCommand& serverCmd =m_testBlock1->m_serverCommands[0];
|
|
|
|
|
|
|
|
if (completedOk)
|
|
|
|
{
|
|
|
|
serverCmd.m_type =CMD_URDF_LOADING_COMPLETED;
|
|
|
|
} else
|
|
|
|
{
|
|
|
|
serverCmd.m_type =CMD_URDF_LOADING_FAILED;
|
|
|
|
|
|
|
|
}
|
|
|
|
m_testBlock1->m_numServerCommands++;
|
2015-05-29 22:04:05 +00:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
case CMD_STEP_FORWARD_SIMULATION:
|
|
|
|
{
|
|
|
|
|
|
|
|
b3Printf("Step simulation request");
|
|
|
|
double timeStep = clientCmd.m_stepSimulationArguments.m_deltaTimeInSeconds;
|
|
|
|
m_dynamicsWorld->stepSimulation(timeStep);
|
|
|
|
|
|
|
|
SharedMemoryCommand& serverCmd =m_testBlock1->m_serverCommands[0];
|
|
|
|
|
|
|
|
serverCmd.m_type =CMD_STEP_FORWARD_SIMULATION_COMPLETED;
|
|
|
|
m_testBlock1->m_numServerCommands++;
|
|
|
|
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case CMD_SHUTDOWN:
|
|
|
|
{
|
|
|
|
wantsShutdown = true;
|
|
|
|
break;
|
2015-05-28 23:05:24 +00:00
|
|
|
}
|
|
|
|
default:
|
|
|
|
{
|
2015-05-29 22:04:05 +00:00
|
|
|
b3Error("Unsupported command encountered");
|
|
|
|
btAssert(0);
|
2015-05-28 23:05:24 +00:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2015-05-29 22:04:05 +00:00
|
|
|
|
2015-05-28 23:05:24 +00:00
|
|
|
|
|
|
|
//process the command right now
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
2015-05-29 22:04:05 +00:00
|
|
|
if (wantsShutdown)
|
|
|
|
{
|
|
|
|
m_wantsShutdown = true;
|
|
|
|
releaseSharedMemory();
|
|
|
|
}
|
2015-05-28 23:05:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
class CommonExampleInterface* PhysicsServerCreateFunc(struct CommonExampleOptions& options)
|
|
|
|
{
|
|
|
|
return new PhysicsServer(options.m_guiHelper);
|
|
|
|
}
|
|
|
|
|
|
|
|
|