Deleting bullet demos: 1) We don't need them. 2) They prolong the compilation process. 3) They produce weird errors on linking with the libs.
This commit is contained in:
parent
e8fe6286a4
commit
2ae938a557
104
extern/bullet/Demos/AllBulletDemos/CMakeLists.txt
vendored
104
extern/bullet/Demos/AllBulletDemos/CMakeLists.txt
vendored
@ -1,104 +0,0 @@
|
|||||||
# This is basically the overall name of the project in Visual Studio this is the name of the Solution File
|
|
||||||
|
|
||||||
|
|
||||||
# For every executable you have with a main method you should have an add_executable line below.
|
|
||||||
# For every add executable line you should list every .cpp and .h file you have associated with that executable.
|
|
||||||
|
|
||||||
|
|
||||||
# You shouldn't have to modify anything below this line
|
|
||||||
########################################################
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
INCLUDE_DIRECTORIES(
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/Extras
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/Extras/GIMPACTUtils
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/Extras/HACD
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/Extras/ConvexDecomposition
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/Extras/LibXML
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/Extras/LibXML/include
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/src
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/Demos/OpenGL
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/Extras/Serialize/BulletFileLoader
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/Extras/Serialize/BulletWorldImporter
|
|
||||||
${VECTOR_MATH_INCLUDE}
|
|
||||||
)
|
|
||||||
|
|
||||||
LINK_LIBRARIES(
|
|
||||||
GLUI GIMPACTUtils HACD ConvexDecomposition OpenGLSupport BulletWorldImporter BulletSoftBody BulletDynamics BulletCollision BulletFileLoader LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY}
|
|
||||||
)
|
|
||||||
|
|
||||||
SET(AllBulletDemos_SRCS
|
|
||||||
Main.cpp
|
|
||||||
DemoEntries.cpp
|
|
||||||
../CcdPhysicsDemo/CcdPhysicsDemo.cpp
|
|
||||||
../BasicDemo/BasicDemo.cpp
|
|
||||||
../BspDemo/BspDemo.cpp
|
|
||||||
../BspDemo/BspConverter.cpp
|
|
||||||
../BspDemo/BspLoader.cpp
|
|
||||||
../DynamicControlDemo/MotorDemo.cpp
|
|
||||||
../ConcaveDemo/ConcavePhysicsDemo.cpp
|
|
||||||
../ConcaveRaycastDemo/ConcaveRaycastDemo.cpp
|
|
||||||
../ConcaveConvexcastDemo/ConcaveConvexcastDemo.cpp
|
|
||||||
../ConvexDecompositionDemo/ConvexDecompositionDemo.cpp
|
|
||||||
../SliderConstraintDemo/SliderConstraintDemo.cpp
|
|
||||||
../RagdollDemo/RagdollDemo.cpp
|
|
||||||
../GimpactTestDemo/GimpactTestDemo.cpp
|
|
||||||
../Raytracer/Raytracer.cpp
|
|
||||||
../GjkConvexCastDemo/LinearConvexCastDemo.cpp
|
|
||||||
../ForkLiftDemo/ForkLiftDemo.cpp
|
|
||||||
../SoftDemo/SoftDemo.cpp
|
|
||||||
../ConstraintDemo/ConstraintDemo.cpp
|
|
||||||
../Benchmarks/BenchmarkDemo.cpp
|
|
||||||
../Box2dDemo/Box2dDemo.cpp
|
|
||||||
|
|
||||||
)
|
|
||||||
|
|
||||||
IF (WIN32)
|
|
||||||
ADD_EXECUTABLE(AppAllBulletDemos
|
|
||||||
${AllBulletDemos_SRCS}
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/build/bullet.rc
|
|
||||||
)
|
|
||||||
ELSE()
|
|
||||||
ADD_EXECUTABLE(AppAllBulletDemos
|
|
||||||
${AllBulletDemos_SRCS}
|
|
||||||
)
|
|
||||||
ENDIF()
|
|
||||||
|
|
||||||
|
|
||||||
IF (WIN32)
|
|
||||||
IF (NOT INTERNAL_CREATE_MSVC_RELATIVE_PATH_PROJECTFILES)
|
|
||||||
IF (CMAKE_CL_64)
|
|
||||||
ADD_CUSTOM_COMMAND(
|
|
||||||
TARGET AppAllBulletDemos
|
|
||||||
POST_BUILD
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/glut64.dll ${CMAKE_CURRENT_BINARY_DIR}
|
|
||||||
)
|
|
||||||
ELSE(CMAKE_CL_64)
|
|
||||||
ADD_CUSTOM_COMMAND(
|
|
||||||
TARGET AppAllBulletDemos
|
|
||||||
POST_BUILD
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/GLUT32.DLL ${CMAKE_CURRENT_BINARY_DIR}
|
|
||||||
)
|
|
||||||
ENDIF(CMAKE_CL_64)
|
|
||||||
ENDIF (NOT INTERNAL_CREATE_MSVC_RELATIVE_PATH_PROJECTFILES)
|
|
||||||
ENDIF(WIN32)
|
|
||||||
|
|
||||||
|
|
||||||
IF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES)
|
|
||||||
ADD_CUSTOM_COMMAND(
|
|
||||||
TARGET AppAllBulletDemos
|
|
||||||
POST_BUILD
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/Demos/SerializeDemo/testFile.bullet ${CMAKE_CURRENT_BINARY_DIR}/testFile.bullet
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/file.obj ${CMAKE_CURRENT_BINARY_DIR}
|
|
||||||
)
|
|
||||||
ENDIF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES)
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES)
|
|
||||||
SET_TARGET_PROPERTIES(AppAllBulletDemos PROPERTIES DEBUG_POSTFIX "_Debug")
|
|
||||||
SET_TARGET_PROPERTIES(AppAllBulletDemos PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel")
|
|
||||||
SET_TARGET_PROPERTIES(AppAllBulletDemos PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo")
|
|
||||||
ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES)
|
|
178
extern/bullet/Demos/AllBulletDemos/DemoEntries.cpp
vendored
178
extern/bullet/Demos/AllBulletDemos/DemoEntries.cpp
vendored
@ -1,178 +0,0 @@
|
|||||||
/*
|
|
||||||
Bullet Continuous Collision Detection and Physics Library
|
|
||||||
Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied warranty.
|
|
||||||
In no event will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it freely,
|
|
||||||
subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
|
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "DemoEntries.h"
|
|
||||||
|
|
||||||
#include "../CcdPhysicsDemo/CcdPhysicsDemo.h"
|
|
||||||
#include "../BspDemo/BspDemo.h"
|
|
||||||
#include "../BasicDemo/BasicDemo.h"
|
|
||||||
#include "../ConcaveDemo/ConcaveDemo.h"
|
|
||||||
#include "../ConcaveRaycastDemo/ConcaveRaycastDemo.h"
|
|
||||||
#include "../ConcaveConvexcastDemo/ConcaveConvexcastDemo.h"
|
|
||||||
#include "../ConvexDecompositionDemo/ConvexDecompositionDemo.h"
|
|
||||||
#include "../DynamicControlDemo/MotorDemo.h"
|
|
||||||
#include "../SliderConstraintDemo/SliderConstraintDemo.h"
|
|
||||||
#include "../RagdollDemo/RagdollDemo.h"
|
|
||||||
#include "../GimpactTestDemo/GimpactTestDemo.h"
|
|
||||||
#include "../Raytracer/Raytracer.h"
|
|
||||||
#include "../GjkConvexCastDemo/LinearConvexCastDemo.h"
|
|
||||||
#include "../ForkLiftDemo/ForkLiftDemo.h"
|
|
||||||
#include "../ConstraintDemo/ConstraintDemo.h"
|
|
||||||
//#include "../Benchmarks/BenchmarkDemo.h"
|
|
||||||
#include "../SoftDemo/SoftDemo.h"
|
|
||||||
//#include "../Box2dDemo/Box2dDemo.h"
|
|
||||||
|
|
||||||
#include "GLDebugFont.h"
|
|
||||||
|
|
||||||
#include "GlutStuff.h"//OpenGL stuff
|
|
||||||
|
|
||||||
|
|
||||||
extern int gNumAlignedAllocs;
|
|
||||||
extern int gNumAlignedFree;
|
|
||||||
extern int gTotalBytesAlignedAllocs;
|
|
||||||
|
|
||||||
class btEmptyDebugDemo : public GlutDemoApplication
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
btEmptyDebugDemo()
|
|
||||||
{
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual void clientMoveAndDisplay()
|
|
||||||
{
|
|
||||||
|
|
||||||
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
|
||||||
|
|
||||||
float xOffset = 10.f;
|
|
||||||
float yStart = 20.f;
|
|
||||||
float yIncr = 20.f;
|
|
||||||
char buf[124];
|
|
||||||
|
|
||||||
|
|
||||||
glColor3f(0, 0, 0);
|
|
||||||
|
|
||||||
setOrthographicProjection();
|
|
||||||
|
|
||||||
glRasterPos3f(xOffset,yStart,0);
|
|
||||||
sprintf(buf,"gNumAlignedAllocs= %d",gNumAlignedAllocs);
|
|
||||||
GLDebugDrawString(xOffset,yStart,buf);
|
|
||||||
yStart += yIncr;
|
|
||||||
|
|
||||||
glRasterPos3f(xOffset,yStart,0);
|
|
||||||
sprintf(buf,"gNumAlignedFree= %d",gNumAlignedFree);
|
|
||||||
GLDebugDrawString(xOffset,yStart,buf);
|
|
||||||
yStart += yIncr;
|
|
||||||
|
|
||||||
glRasterPos3f(xOffset,yStart,0);
|
|
||||||
sprintf(buf,"# alloc-free = %d",gNumAlignedAllocs-gNumAlignedFree);
|
|
||||||
GLDebugDrawString(xOffset,yStart,buf);
|
|
||||||
yStart += yIncr;
|
|
||||||
#ifdef BT_DEBUG_MEMORY_ALLOCATIONS
|
|
||||||
glRasterPos3f(xOffset,yStart,0);
|
|
||||||
sprintf(buf,"gTotalBytesAlignedAllocs = %d",gTotalBytesAlignedAllocs);
|
|
||||||
GLDebugDrawString(xOffset,yStart,buf);
|
|
||||||
yStart += yIncr;
|
|
||||||
#endif //BT_DEBUG_MEMORY_ALLOCATIONS
|
|
||||||
|
|
||||||
glFlush();
|
|
||||||
glutSwapBuffers();
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual void initPhysics() {}
|
|
||||||
|
|
||||||
static DemoApplication* Create()
|
|
||||||
{
|
|
||||||
btEmptyDebugDemo* demo = new btEmptyDebugDemo();
|
|
||||||
demo->myinit();
|
|
||||||
return demo;
|
|
||||||
}
|
|
||||||
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
btDemoEntry g_demoEntries[] =
|
|
||||||
{
|
|
||||||
// {"Box2dDemo",Box2dDemo::Create},
|
|
||||||
{"ForkLift Demo",ForkLiftDemo::Create},
|
|
||||||
{"Dynamic Control Demo",MotorDemo::Create},
|
|
||||||
{"ConstraintDemo",ConstraintDemo::Create},
|
|
||||||
|
|
||||||
{"Ragdoll Demo",RagdollDemo::Create},
|
|
||||||
{"Basic Demo", BasicDemo::Create},
|
|
||||||
{"CcdPhysicsDemo", CcdPhysicsDemo::Create},
|
|
||||||
{"Convex Decomposition",ConvexDecompositionDemo::Create},
|
|
||||||
{"Concave Moving", GimpactConcaveDemo::Create},
|
|
||||||
|
|
||||||
{"ConcaveDemo",ConcaveDemo::Create},
|
|
||||||
{"Concave Convexcast Demo",ConcaveConvexcastDemo::Create},
|
|
||||||
{"SoftBody Cluster Collide1",SoftDemo19::Create},
|
|
||||||
|
|
||||||
{"SoftBody Ropes Attach",SoftDemo4::Create},
|
|
||||||
|
|
||||||
{"SoftBody Cloth Attach",SoftDemo5::Create},
|
|
||||||
|
|
||||||
{"SoftBody Cloth",SoftDemo0::Create},
|
|
||||||
|
|
||||||
// {"SoftBody Volume",SoftDemo2::Create},
|
|
||||||
{"SoftBody Pressure",SoftDemo1::Create},
|
|
||||||
{"SoftBody Cluster Car",SoftDemo24::Create},
|
|
||||||
{"SoftBody Cluster Robot",SoftDemo25::Create},
|
|
||||||
// {"SoftBody Ropes",SoftDemo3::Create},
|
|
||||||
{"SoftBody Sticks",SoftDemo6::Create},
|
|
||||||
{"SoftBody Collide",SoftDemo7::Create},
|
|
||||||
{"SoftBody Collide2",SoftDemo8::Create},
|
|
||||||
// {"SoftBody Collide3",SoftDemo9::Create},
|
|
||||||
// {"SoftBody Impact",SoftDemo10::Create},
|
|
||||||
{"SoftBody Aero",SoftDemo11::Create},
|
|
||||||
{"SoftBody Friction",SoftDemo12::Create},
|
|
||||||
// {"SoftBody Torus",SoftDemo13::Create},
|
|
||||||
// {"SoftBody Torus Match",SoftDemo14::Create},
|
|
||||||
// {"SoftBody Bunny",SoftDemo15::Create},
|
|
||||||
// {"SoftBody Bunny Match",SoftDemo16::Create},
|
|
||||||
{"SoftBody Init Cutting",SoftDemo17::Create},
|
|
||||||
// {"SoftBody Cluster Deform",SoftDemo18::Create},
|
|
||||||
|
|
||||||
// {"SoftBody Cluster Collide2",SoftDemo20::Create},
|
|
||||||
// {"SoftBody Cluster Socket",SoftDemo21::Create},
|
|
||||||
{"SoftBody Cluster Hinge",SoftDemo22::Create},
|
|
||||||
{"SoftBody Cluster Combine",SoftDemo23::Create},
|
|
||||||
// {"SoftBody Cluster Stack Soft",SoftDemo26::Create},
|
|
||||||
{"SoftBody Cluster Stack Mixed",SoftDemo27::Create},
|
|
||||||
|
|
||||||
{"SoftBody TetGen Tetrahedral Cube",SoftDemo28::Create},
|
|
||||||
{"SoftBody TetGen Tetrahedral Bunny",SoftDemo29::Create},
|
|
||||||
|
|
||||||
|
|
||||||
// {"SliderConstraint",SliderConstraintDemo::Create},
|
|
||||||
|
|
||||||
// {"ConcaveRaycastDemo",ConcaveRaycastDemo::Create},
|
|
||||||
//{"BspDemo", BspDemo::Create},
|
|
||||||
// {"Raytracer Test",Raytracer::Create},
|
|
||||||
// {"GjkConvexCast",LinearConvexCastDemo::Create},
|
|
||||||
// {"Benchmark 3000 FALL",BenchmarkDemo1::Create},
|
|
||||||
// {"Benchmark 1000 STACK",BenchmarkDemo2::Create},
|
|
||||||
// {"Benchmark 136 RAGDOLLS",BenchmarkDemo3::Create},
|
|
||||||
// {"Benchmark 1000 CONVEX",BenchmarkDemo4::Create},
|
|
||||||
// {"Benchmark Mesh-Prim",BenchmarkDemo5::Create},
|
|
||||||
// {"Benchmark Mesh-Convex",BenchmarkDemo6::Create},
|
|
||||||
// {"Benchmark Raycast",BenchmarkDemo7::Create},
|
|
||||||
|
|
||||||
{"MemoryLeak Checker",btEmptyDebugDemo::Create},
|
|
||||||
{0, 0}
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
34
extern/bullet/Demos/AllBulletDemos/DemoEntries.h
vendored
34
extern/bullet/Demos/AllBulletDemos/DemoEntries.h
vendored
@ -1,34 +0,0 @@
|
|||||||
/*
|
|
||||||
Bullet Continuous Collision Detection and Physics Library
|
|
||||||
Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied warranty.
|
|
||||||
In no event will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it freely,
|
|
||||||
subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
|
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifndef BT_DEMO_ENTRIES_H
|
|
||||||
#define BT_DEMO_ENTRIES_H
|
|
||||||
|
|
||||||
|
|
||||||
class DemoApplication;
|
|
||||||
|
|
||||||
typedef DemoApplication* DemoCreateFcn();
|
|
||||||
|
|
||||||
struct btDemoEntry
|
|
||||||
{
|
|
||||||
const char *name;
|
|
||||||
DemoCreateFcn *createFcn;
|
|
||||||
};
|
|
||||||
|
|
||||||
extern btDemoEntry g_demoEntries[];
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#endif //BT_DEMO_ENTRIES_H
|
|
574
extern/bullet/Demos/AllBulletDemos/Main.cpp
vendored
574
extern/bullet/Demos/AllBulletDemos/Main.cpp
vendored
@ -1,574 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (c) 2006-2007 Erin Catto http://www.gphysics.com
|
|
||||||
*
|
|
||||||
* This software is provided 'as-is', without any express or implied
|
|
||||||
* warranty. In no event will the authors be held liable for any damages
|
|
||||||
* arising from the use of this software.
|
|
||||||
* Permission is granted to anyone to use this software for any purpose,
|
|
||||||
* including commercial applications, and to alter it and redistribute it
|
|
||||||
* freely, subject to the following restrictions:
|
|
||||||
* 1. The origin of this software must not be misrepresented; you must not
|
|
||||||
* claim that you wrote the original software. If you use this software
|
|
||||||
* in a product, an acknowledgment in the product documentation would be
|
|
||||||
* appreciated but is not required.
|
|
||||||
* 2. Altered source versions must be plainly marked as such, and must not be
|
|
||||||
* misrepresented as being the original software.
|
|
||||||
* 3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include <stdio.h>
|
|
||||||
|
|
||||||
#include "glui/GL/glui.h"
|
|
||||||
#include "LinearMath/btScalar.h"
|
|
||||||
#include "LinearMath/btMinMax.h"
|
|
||||||
#include "BulletDynamics/ConstraintSolver/btSequentialImpulseConstraintSolver.h"
|
|
||||||
#include "DemoApplication.h"
|
|
||||||
#include "DemoEntries.h"
|
|
||||||
#include "BulletDynamics/Dynamics/btDiscreteDynamicsWorld.h"
|
|
||||||
#include "BulletSoftBody/btSoftRigidDynamicsWorld.h"
|
|
||||||
#include "BulletSoftBody/btSoftBodyHelpers.h"
|
|
||||||
|
|
||||||
#include "GLDebugDrawer.h"
|
|
||||||
static GLDebugDrawer dDebugDraw2;
|
|
||||||
|
|
||||||
#include "LinearMath/btQuickprof.h"
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
namespace
|
|
||||||
{
|
|
||||||
int testIndex=1;
|
|
||||||
int testSelection=0;
|
|
||||||
btDemoEntry* entry;
|
|
||||||
DemoApplication* demo;
|
|
||||||
int iterationCount;
|
|
||||||
int width;
|
|
||||||
int height;
|
|
||||||
int framePeriod;//todo: test if this value should be 0
|
|
||||||
int mainWindow;
|
|
||||||
GLUI *glui;
|
|
||||||
//float hz;
|
|
||||||
float viewZoom=20.f;
|
|
||||||
float viewX;
|
|
||||||
float viewY;
|
|
||||||
int tx, ty, tw, th;
|
|
||||||
int gDrawAabb;
|
|
||||||
int gWireFrame;
|
|
||||||
int gDrawNormals;
|
|
||||||
int gHelpText;
|
|
||||||
int gDebugConstraints;
|
|
||||||
int gDebugContacts;
|
|
||||||
int gDrawTextures=1;
|
|
||||||
int gDrawShadows=0;
|
|
||||||
int gDrawClusters=0;
|
|
||||||
int gDebugNoDeactivation;
|
|
||||||
int gUseWarmstarting;
|
|
||||||
int gRandomizeConstraints;
|
|
||||||
int gUseSplitImpulse;
|
|
||||||
float gErp;
|
|
||||||
float gSlop;
|
|
||||||
float gErp2;
|
|
||||||
float gWarmStartingParameter;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void setDefaultSettings()
|
|
||||||
{
|
|
||||||
viewX = 0.0f;
|
|
||||||
viewY = 0.0f;
|
|
||||||
framePeriod = 6;//16;//16;//todo: test if this value should be 0
|
|
||||||
|
|
||||||
width = 1280;
|
|
||||||
height = 768;//480;
|
|
||||||
iterationCount = 10;
|
|
||||||
gDrawAabb=0;
|
|
||||||
gDrawNormals=0;
|
|
||||||
gWireFrame=0;
|
|
||||||
gDebugContacts=0;
|
|
||||||
//enable constraint debug visualization for first demo, only if user hasn't overridden the setting
|
|
||||||
if (testSelection>1)
|
|
||||||
{
|
|
||||||
gDebugConstraints=0;
|
|
||||||
} else
|
|
||||||
{
|
|
||||||
gDebugConstraints=1;
|
|
||||||
}
|
|
||||||
gHelpText = 0;
|
|
||||||
gDrawTextures=1;
|
|
||||||
gDrawShadows=0;
|
|
||||||
gDrawClusters=0;
|
|
||||||
|
|
||||||
gDebugNoDeactivation = 0;
|
|
||||||
gUseSplitImpulse = 1;
|
|
||||||
gUseWarmstarting = 1;
|
|
||||||
gRandomizeConstraints = 0;
|
|
||||||
gErp = 0.2f;
|
|
||||||
gSlop=0.0f;
|
|
||||||
gErp2 = 0.81f;
|
|
||||||
gWarmStartingParameter = 0.85f;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
void setDefaultSettingsAndSync()
|
|
||||||
{
|
|
||||||
setDefaultSettings();
|
|
||||||
glui->sync_live();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void TogglePause()
|
|
||||||
{
|
|
||||||
if (demo)
|
|
||||||
demo->toggleIdle();
|
|
||||||
}
|
|
||||||
|
|
||||||
void ResetScene()
|
|
||||||
{
|
|
||||||
if (demo)
|
|
||||||
demo->clientResetScene();
|
|
||||||
}
|
|
||||||
|
|
||||||
void NextScene()
|
|
||||||
{
|
|
||||||
testSelection++;
|
|
||||||
if (testSelection>1)
|
|
||||||
{
|
|
||||||
gDebugConstraints=0;
|
|
||||||
} else
|
|
||||||
{
|
|
||||||
gDebugConstraints=1;
|
|
||||||
}
|
|
||||||
|
|
||||||
if(testSelection>28)
|
|
||||||
testSelection=0;
|
|
||||||
if (glui)
|
|
||||||
glui->sync_live();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void SingleSimulationStep()
|
|
||||||
{
|
|
||||||
if (demo)
|
|
||||||
demo->clientMoveAndDisplay();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void Resize(int w, int h)
|
|
||||||
{
|
|
||||||
width = w;
|
|
||||||
height = h;
|
|
||||||
|
|
||||||
GLUI_Master.get_viewport_area( &tx, &ty, &tw, &th );
|
|
||||||
glViewport( tx, ty, tw, th );
|
|
||||||
|
|
||||||
glMatrixMode(GL_PROJECTION);
|
|
||||||
glLoadIdentity();
|
|
||||||
if (demo)
|
|
||||||
demo->reshape(tw, th);
|
|
||||||
}
|
|
||||||
|
|
||||||
DemoApplication* CreatDemo(btDemoEntry* entry)
|
|
||||||
{
|
|
||||||
DemoApplication* demo = entry->createFcn();
|
|
||||||
btAssert(demo);
|
|
||||||
if (demo->getDynamicsWorld())
|
|
||||||
{
|
|
||||||
demo->getDynamicsWorld()->setDebugDrawer(&dDebugDraw2);
|
|
||||||
gDrawTextures = demo->getTexturing();
|
|
||||||
gDrawShadows = demo->getShadows();
|
|
||||||
if (glui)
|
|
||||||
glui->sync_live();
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifndef BT_NO_PROFILE
|
|
||||||
CProfileManager::Reset();
|
|
||||||
#endif //BT_NO_PROFILE
|
|
||||||
|
|
||||||
return demo;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/*b2Vec2 ConvertScreenToWorld(int x, int y)
|
|
||||||
{
|
|
||||||
b2Vec2 p;
|
|
||||||
|
|
||||||
float ratio = float(tw) / float(th);
|
|
||||||
float u = x / float(tw);
|
|
||||||
float v = (th - y) / float(th);
|
|
||||||
p.x = viewZoom * (viewX - ratio) * (1.0f - u) + viewZoom * (ratio + viewX) * u;
|
|
||||||
p.y = viewZoom * (viewY - 0.1f) * (1.0f - v) + viewZoom * (viewY + 1.9f) * v;
|
|
||||||
return p;
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
// This is used to control the frame rate (60Hz).
|
|
||||||
void Timer(int)
|
|
||||||
{
|
|
||||||
glutSetWindow(mainWindow);
|
|
||||||
glutPostRedisplay();
|
|
||||||
glutTimerFunc(framePeriod, Timer, 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
void SimulationLoop()
|
|
||||||
{
|
|
||||||
Resize(width, height);
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if (gDrawAabb)
|
|
||||||
{
|
|
||||||
demo->setDebugMode(demo->getDebugMode() |btIDebugDraw::DBG_DrawAabb);
|
|
||||||
} else
|
|
||||||
{
|
|
||||||
demo->setDebugMode(demo->getDebugMode() & (~btIDebugDraw::DBG_DrawAabb));
|
|
||||||
}
|
|
||||||
if (gWireFrame)
|
|
||||||
{
|
|
||||||
demo->setDebugMode(demo->getDebugMode() |btIDebugDraw::DBG_DrawWireframe);
|
|
||||||
} else
|
|
||||||
{
|
|
||||||
demo->setDebugMode(demo->getDebugMode() & (~btIDebugDraw::DBG_DrawWireframe));
|
|
||||||
}
|
|
||||||
if (gDrawNormals)
|
|
||||||
{
|
|
||||||
demo->setDebugMode(demo->getDebugMode() |btIDebugDraw::DBG_DrawNormals);
|
|
||||||
} else
|
|
||||||
{
|
|
||||||
demo->setDebugMode(demo->getDebugMode() & (~btIDebugDraw::DBG_DrawNormals));
|
|
||||||
}
|
|
||||||
if (gHelpText)
|
|
||||||
{
|
|
||||||
demo->setDebugMode(demo->getDebugMode() & (~btIDebugDraw::DBG_NoHelpText));
|
|
||||||
} else
|
|
||||||
{
|
|
||||||
demo->setDebugMode(demo->getDebugMode() |btIDebugDraw::DBG_NoHelpText);
|
|
||||||
}
|
|
||||||
if (gDebugConstraints)
|
|
||||||
{
|
|
||||||
demo->setDebugMode(demo->getDebugMode() |btIDebugDraw::DBG_DrawConstraints+btIDebugDraw::DBG_DrawConstraintLimits);
|
|
||||||
} else
|
|
||||||
{
|
|
||||||
demo->setDebugMode(demo->getDebugMode() & (~btIDebugDraw::DBG_DrawConstraints+btIDebugDraw::DBG_DrawConstraintLimits));
|
|
||||||
}
|
|
||||||
if (gDebugContacts)
|
|
||||||
{
|
|
||||||
demo->setDebugMode(demo->getDebugMode() |btIDebugDraw::DBG_DrawContactPoints);
|
|
||||||
} else
|
|
||||||
{
|
|
||||||
demo->setDebugMode(demo->getDebugMode() & (~btIDebugDraw::DBG_DrawContactPoints));
|
|
||||||
}
|
|
||||||
|
|
||||||
demo->setTexturing(0!=gDrawTextures);
|
|
||||||
demo->setShadows(0!=gDrawShadows);
|
|
||||||
demo->setDrawClusters(0!=gDrawClusters);
|
|
||||||
|
|
||||||
if (gDebugNoDeactivation)
|
|
||||||
{
|
|
||||||
demo->setDebugMode(demo->getDebugMode() |btIDebugDraw::DBG_NoDeactivation);
|
|
||||||
} else
|
|
||||||
{
|
|
||||||
demo->setDebugMode(demo->getDebugMode() & (~btIDebugDraw::DBG_NoDeactivation));
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if (demo->getDynamicsWorld() && demo->getDynamicsWorld()->getWorldType() == BT_DISCRETE_DYNAMICS_WORLD)
|
|
||||||
{
|
|
||||||
btDiscreteDynamicsWorld* discreteWorld = (btDiscreteDynamicsWorld*) demo->getDynamicsWorld();
|
|
||||||
discreteWorld->getSolverInfo().m_numIterations = iterationCount;
|
|
||||||
discreteWorld->getSolverInfo().m_erp = gErp;
|
|
||||||
discreteWorld->getSolverInfo().m_erp2 = gErp2;
|
|
||||||
|
|
||||||
discreteWorld->getSolverInfo().m_linearSlop = gSlop;
|
|
||||||
|
|
||||||
discreteWorld->getSolverInfo().m_warmstartingFactor = gWarmStartingParameter;
|
|
||||||
discreteWorld->getSolverInfo().m_splitImpulse = gUseSplitImpulse;
|
|
||||||
|
|
||||||
// btSequentialImpulseConstraintSolver* solver = ((btSequentialImpulseConstraintSolver*) discreteWorld->getConstraintSolver());
|
|
||||||
|
|
||||||
if (gUseWarmstarting)
|
|
||||||
{
|
|
||||||
discreteWorld->getSolverInfo().m_solverMode |= SOLVER_USE_WARMSTARTING;
|
|
||||||
} else
|
|
||||||
{
|
|
||||||
discreteWorld->getSolverInfo().m_solverMode &= (~SOLVER_USE_WARMSTARTING);
|
|
||||||
}
|
|
||||||
if (gRandomizeConstraints)
|
|
||||||
{
|
|
||||||
discreteWorld->getSolverInfo().m_solverMode |= SOLVER_RANDMIZE_ORDER;
|
|
||||||
} else
|
|
||||||
{
|
|
||||||
discreteWorld->getSolverInfo().m_solverMode &= (~SOLVER_RANDMIZE_ORDER);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!demo->isIdle())
|
|
||||||
{
|
|
||||||
demo->clientMoveAndDisplay();
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
demo->displayCallback();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (demo->getDynamicsWorld() && demo->getDynamicsWorld()->getWorldType()==BT_SOFT_RIGID_DYNAMICS_WORLD)
|
|
||||||
{
|
|
||||||
btSoftRigidDynamicsWorld* softWorld = (btSoftRigidDynamicsWorld*)demo->getDynamicsWorld();
|
|
||||||
for ( int i=0;i<softWorld->getSoftBodyArray().size();i++)
|
|
||||||
{
|
|
||||||
btSoftBody* psb=(btSoftBody*)softWorld->getSoftBodyArray()[i];
|
|
||||||
if (softWorld->getDebugDrawer() && !(softWorld->getDebugDrawer()->getDebugMode() & (btIDebugDraw::DBG_DrawWireframe)))
|
|
||||||
{
|
|
||||||
btSoftBodyHelpers::DrawFrame(psb,softWorld->getDebugDrawer());
|
|
||||||
btSoftBodyHelpers::Draw(psb,softWorld->getDebugDrawer(),softWorld->getDrawFlags());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (testSelection != testIndex)
|
|
||||||
{
|
|
||||||
if (testSelection>1)
|
|
||||||
{
|
|
||||||
gDebugConstraints=0;
|
|
||||||
} else
|
|
||||||
{
|
|
||||||
gDebugConstraints=1;
|
|
||||||
}
|
|
||||||
|
|
||||||
testIndex = testSelection;
|
|
||||||
delete demo;
|
|
||||||
entry = g_demoEntries + testIndex;
|
|
||||||
demo = CreatDemo(entry);
|
|
||||||
viewZoom = 20.0f;
|
|
||||||
viewX = 0.0f;
|
|
||||||
viewY = 0.0f;
|
|
||||||
Resize(width, height);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void RestartScene()
|
|
||||||
{
|
|
||||||
delete demo;
|
|
||||||
entry = g_demoEntries + testIndex;
|
|
||||||
demo = CreatDemo(entry);
|
|
||||||
viewZoom = 20.0f;
|
|
||||||
viewX = 0.0f;
|
|
||||||
viewY = 0.0f;
|
|
||||||
Resize(width, height);
|
|
||||||
}
|
|
||||||
|
|
||||||
void Keyboard(unsigned char key, int x, int y)
|
|
||||||
{
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
switch (key)
|
|
||||||
{
|
|
||||||
case 27:
|
|
||||||
exit(0);
|
|
||||||
break;
|
|
||||||
|
|
||||||
// Press 'r' to reset.
|
|
||||||
case 'r':
|
|
||||||
delete demo;
|
|
||||||
demo = CreatDemo(entry);
|
|
||||||
Resize(width,height);
|
|
||||||
break;
|
|
||||||
|
|
||||||
default:
|
|
||||||
if (demo)
|
|
||||||
{
|
|
||||||
demo->keyboardCallback(key,x,y);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void KeyboardSpecialUp(int key, int x, int y)
|
|
||||||
{
|
|
||||||
if (demo)
|
|
||||||
{
|
|
||||||
demo->specialKeyboardUp(key,x,y);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void GlutIdleFunc()
|
|
||||||
{
|
|
||||||
int current_window, new_window=-1;
|
|
||||||
current_window = glutGetWindow();
|
|
||||||
if (GLUI_Master.gluis.first_child() != NULL )
|
|
||||||
{
|
|
||||||
new_window = ((GLUI_Main*)GLUI_Master.gluis.first_child())->getMainWindowId();
|
|
||||||
}
|
|
||||||
if ( (new_window > 0) && (new_window != current_window ))
|
|
||||||
{
|
|
||||||
//--- Window is changed only if its not already the current window ---
|
|
||||||
glutSetWindow( new_window );
|
|
||||||
}
|
|
||||||
|
|
||||||
if (demo)
|
|
||||||
demo->moveAndDisplay();
|
|
||||||
|
|
||||||
glutSetWindow( current_window );
|
|
||||||
}
|
|
||||||
|
|
||||||
void KeyboardSpecial(int key, int x, int y)
|
|
||||||
{
|
|
||||||
|
|
||||||
if (demo)
|
|
||||||
{
|
|
||||||
demo->specialKeyboard(key,x,y);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void Mouse(int button, int state, int x, int y)
|
|
||||||
{
|
|
||||||
if (demo)
|
|
||||||
demo->mouseFunc(button,state,x,y);
|
|
||||||
}
|
|
||||||
|
|
||||||
void MouseMotion(int x, int y)
|
|
||||||
{
|
|
||||||
demo->mouseMotionFunc(x,y);
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifdef BT_USE_FREEGLUT
|
|
||||||
#include "GL/freeglut_ext.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
int main(int argc, char** argv)
|
|
||||||
{
|
|
||||||
|
|
||||||
//#define CHECK_FPU_EXCEPTIONS 1
|
|
||||||
#ifdef CHECK_FPU_EXCEPTIONS
|
|
||||||
|
|
||||||
int cw = _control87(0, 0);
|
|
||||||
|
|
||||||
// Set the exception masks off, turn exceptions on
|
|
||||||
cw &= ~(EM_ZERODIVIDE | EM_INVALID);
|
|
||||||
|
|
||||||
printf("control87 = %#x\n", cw);
|
|
||||||
|
|
||||||
// Set the control word
|
|
||||||
_control87(cw, MCW_EM);
|
|
||||||
#endif //CHECK_FPU_EXCEPTIONS
|
|
||||||
|
|
||||||
|
|
||||||
setDefaultSettings();
|
|
||||||
|
|
||||||
int bulletVersion = btGetVersion();
|
|
||||||
printf("Bullet version %d\n",bulletVersion);
|
|
||||||
|
|
||||||
glutInit(&argc, argv);
|
|
||||||
glutInitDisplayMode(GLUT_RGBA | GLUT_DOUBLE |GLUT_DEPTH | GLUT_STENCIL);
|
|
||||||
glutInitWindowSize(width, height);
|
|
||||||
mainWindow = glutCreateWindow("http://bulletphysics.com");
|
|
||||||
#ifdef BT_USE_FREEGLUT
|
|
||||||
glutSetOption (GLUT_ACTION_ON_WINDOW_CLOSE, GLUT_ACTION_GLUTMAINLOOP_RETURNS);
|
|
||||||
#endif
|
|
||||||
entry = g_demoEntries + testIndex;
|
|
||||||
demo = CreatDemo(entry);
|
|
||||||
|
|
||||||
glutDisplayFunc(SimulationLoop);
|
|
||||||
GLUI_Master.set_glutReshapeFunc(Resize);
|
|
||||||
GLUI_Master.set_glutKeyboardFunc(Keyboard);
|
|
||||||
GLUI_Master.set_glutSpecialFunc(KeyboardSpecial);
|
|
||||||
GLUI_Master.set_glutIdleFunc(GlutIdleFunc);
|
|
||||||
GLUI_Master.set_glutSpecialUpFunc(KeyboardSpecialUp);
|
|
||||||
GLUI_Master.set_glutMouseFunc(Mouse);
|
|
||||||
glutMotionFunc(MouseMotion);
|
|
||||||
|
|
||||||
|
|
||||||
glui = GLUI_Master.create_glui_subwindow( mainWindow,
|
|
||||||
GLUI_SUBWINDOW_RIGHT );
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
glui->add_statictext("Tests");
|
|
||||||
GLUI_Listbox* testList =
|
|
||||||
glui->add_listbox("", &testSelection);
|
|
||||||
glui->add_button("Next Scene", 0,(GLUI_Update_CB)NextScene);
|
|
||||||
|
|
||||||
glui->add_separator();
|
|
||||||
|
|
||||||
GLUI_Spinner* iterationSpinner =
|
|
||||||
glui->add_spinner("Iterations", GLUI_SPINNER_INT, &iterationCount);
|
|
||||||
iterationSpinner->set_int_limits(1, 250);
|
|
||||||
|
|
||||||
/* GLUI_Spinner* hertzSpinner =
|
|
||||||
glui->add_spinner("Hertz", GLUI_SPINNER_FLOAT, &hz);
|
|
||||||
hertzSpinner->set_float_limits(5.0f, 200.0f);
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
glui->add_checkbox("DisableDeactivation", &gDebugNoDeactivation);
|
|
||||||
glui->add_checkbox("Split Impulse", &gUseSplitImpulse);
|
|
||||||
GLUI_Spinner* spinner = 0;
|
|
||||||
|
|
||||||
spinner = glui->add_spinner("ERP", GLUI_SPINNER_FLOAT, &gErp);
|
|
||||||
// spinner->set_float_limits(0.f,1.f);
|
|
||||||
// spinner = glui->add_spinner("ERP2", GLUI_SPINNER_FLOAT, &gErp2);
|
|
||||||
spinner->set_float_limits(0.f,1.f);
|
|
||||||
spinner = glui->add_spinner("Slop", GLUI_SPINNER_FLOAT, &gSlop);
|
|
||||||
spinner->set_float_limits(0.f,1.f);
|
|
||||||
// spinner = glui->add_spinner("WSP", GLUI_SPINNER_FLOAT,&gWarmStartingParameter);
|
|
||||||
// spinner->set_float_limits (0.f,1.0);
|
|
||||||
glui->add_checkbox("Warmstarting", &gUseWarmstarting);
|
|
||||||
glui->add_checkbox("Randomize Constraints", &gRandomizeConstraints);
|
|
||||||
|
|
||||||
|
|
||||||
glui->add_button("Reset Defaults", 0,(GLUI_Update_CB)setDefaultSettingsAndSync);
|
|
||||||
glui->add_separator();
|
|
||||||
|
|
||||||
GLUI_Panel* drawPanel = glui->add_panel("Debug Draw");
|
|
||||||
|
|
||||||
|
|
||||||
glui->add_checkbox_to_panel(drawPanel, "Help", &gHelpText);
|
|
||||||
glui->add_checkbox_to_panel(drawPanel, "AABBs", &gDrawAabb);
|
|
||||||
glui->add_checkbox_to_panel(drawPanel, "Wireframe", &gWireFrame);
|
|
||||||
glui->add_checkbox_to_panel(drawPanel, "Normals", &gDrawNormals);
|
|
||||||
glui->add_checkbox_to_panel(drawPanel, "Contacts", &gDebugContacts);
|
|
||||||
glui->add_checkbox_to_panel(drawPanel, "Constraints", &gDebugConstraints);
|
|
||||||
|
|
||||||
glui->add_checkbox_to_panel(drawPanel, "Textures", &gDrawTextures);
|
|
||||||
glui->add_checkbox_to_panel(drawPanel, "Shadows", &gDrawShadows);
|
|
||||||
glui->add_checkbox_to_panel(drawPanel, "Clusters", &gDrawClusters);
|
|
||||||
|
|
||||||
int testCount = 0;
|
|
||||||
btDemoEntry* e = g_demoEntries;
|
|
||||||
while (e->createFcn)
|
|
||||||
{
|
|
||||||
testList->add_item(testCount, e->name);
|
|
||||||
++testCount;
|
|
||||||
++e;
|
|
||||||
}
|
|
||||||
|
|
||||||
glui->add_separator();
|
|
||||||
|
|
||||||
glui->add_button("Toggle Pause", 0,(GLUI_Update_CB)TogglePause);
|
|
||||||
|
|
||||||
glui->add_button("Single Step", 0,(GLUI_Update_CB)SingleSimulationStep);
|
|
||||||
glui->add_button("Reset Scene", 0,(GLUI_Update_CB)ResetScene);
|
|
||||||
glui->add_button("Restart Scene", 0,(GLUI_Update_CB)RestartScene);
|
|
||||||
|
|
||||||
glui->add_separator();
|
|
||||||
|
|
||||||
// glui->add_button("Exit", 0,(GLUI_Update_CB)exit);
|
|
||||||
|
|
||||||
glui->set_main_gfx_window( mainWindow );
|
|
||||||
|
|
||||||
// Use a timer to control the frame rate.
|
|
||||||
glutTimerFunc(framePeriod, Timer, 0);
|
|
||||||
|
|
||||||
glutMainLoop();
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
34
extern/bullet/Demos/AllBulletDemos/Makefile.am
vendored
34
extern/bullet/Demos/AllBulletDemos/Makefile.am
vendored
@ -1,34 +0,0 @@
|
|||||||
noinst_PROGRAMS=AllBulletDemo
|
|
||||||
|
|
||||||
AllBulletDemo_SOURCES=\
|
|
||||||
../SoftDemo/SoftDemo.cpp \
|
|
||||||
../ConstraintDemo/ConstraintDemo.cpp \
|
|
||||||
../ForkLiftDemo/ForkLiftDemo.cpp \
|
|
||||||
../RagdollDemo/RagdollDemo.cpp \
|
|
||||||
../BasicDemo/BasicDemo.cpp \
|
|
||||||
../CcdPhysicsDemo/CcdPhysicsDemo.cpp \
|
|
||||||
../SliderConstraintDemo/SliderConstraintDemo.cpp \
|
|
||||||
../ConcaveRaycastDemo/ConcaveRaycastDemo.cpp \
|
|
||||||
../Raytracer/Raytracer.cpp \
|
|
||||||
../BspDemo/BspDemo.cpp \
|
|
||||||
../BspDemo/BspLoader.cpp \
|
|
||||||
../BspDemo/BspConverter.cpp \
|
|
||||||
../ConcaveConvexcastDemo/ConcaveConvexcastDemo.cpp \
|
|
||||||
../ConvexDecompositionDemo/ConvexDecompositionDemo.cpp \
|
|
||||||
../GimpactTestDemo/GimpactTestDemo.cpp \
|
|
||||||
../GjkConvexCastDemo/LinearConvexCastDemo.cpp \
|
|
||||||
../ConcaveDemo/ConcavePhysicsDemo.cpp \
|
|
||||||
../DynamicControlDemo/MotorDemo.cpp \
|
|
||||||
DemoEntries.cpp \
|
|
||||||
DemoEntries.h\
|
|
||||||
Main.cpp
|
|
||||||
AllBulletDemo_CXXFLAGS=\
|
|
||||||
-I@top_builddir@/src \
|
|
||||||
-I@top_builddir@/Extras/GIMPACTUtils \
|
|
||||||
-I@top_builddir@/Extras/ConvexDecomposition \
|
|
||||||
-I@top_builddir@/Extras/HACD \
|
|
||||||
-I@top_builddir@/Extras \
|
|
||||||
-I@top_builddir@/Demos/OpenGL \
|
|
||||||
-I@top_builddir@/Demos/SoftDemo \
|
|
||||||
$(CXXFLAGS)
|
|
||||||
AllBulletDemo_LDADD=-L../OpenGL -lbulletopenglsupport -L../../src -L../../Extras -lgimpactutils -lconvexdecomposition -lHACD -lBulletSoftBody -lBulletDynamics -lBulletCollision -lLinearMath -lglui @opengl_LIBS@
|
|
273
extern/bullet/Demos/BasicDemo/BasicDemo.cpp
vendored
273
extern/bullet/Demos/BasicDemo/BasicDemo.cpp
vendored
@ -1,273 +0,0 @@
|
|||||||
/*
|
|
||||||
Bullet Continuous Collision Detection and Physics Library
|
|
||||||
Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied warranty.
|
|
||||||
In no event will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it freely,
|
|
||||||
subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
|
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
///create 125 (5x5x5) dynamic object
|
|
||||||
#define ARRAY_SIZE_X 5
|
|
||||||
#define ARRAY_SIZE_Y 5
|
|
||||||
#define ARRAY_SIZE_Z 5
|
|
||||||
|
|
||||||
//maximum number of objects (and allow user to shoot additional boxes)
|
|
||||||
#define MAX_PROXIES (ARRAY_SIZE_X*ARRAY_SIZE_Y*ARRAY_SIZE_Z + 1024)
|
|
||||||
|
|
||||||
///scaling of the objects (0.1 = 20 centimeter boxes )
|
|
||||||
#define SCALING 1.
|
|
||||||
#define START_POS_X -5
|
|
||||||
#define START_POS_Y -5
|
|
||||||
#define START_POS_Z -3
|
|
||||||
|
|
||||||
#include "BasicDemo.h"
|
|
||||||
#include "GlutStuff.h"
|
|
||||||
///btBulletDynamicsCommon.h is the main Bullet include file, contains most common include files.
|
|
||||||
#include "btBulletDynamicsCommon.h"
|
|
||||||
|
|
||||||
#include <stdio.h> //printf debugging
|
|
||||||
#include "GLDebugDrawer.h"
|
|
||||||
#include "LinearMath/btAabbUtil2.h"
|
|
||||||
|
|
||||||
static GLDebugDrawer gDebugDraw;
|
|
||||||
|
|
||||||
///The MyOverlapCallback is used to show how to collect object that overlap with a given bounding box defined by aabbMin and aabbMax.
|
|
||||||
///See m_dynamicsWorld->getBroadphase()->aabbTest.
|
|
||||||
struct MyOverlapCallback : public btBroadphaseAabbCallback
|
|
||||||
{
|
|
||||||
btVector3 m_queryAabbMin;
|
|
||||||
btVector3 m_queryAabbMax;
|
|
||||||
|
|
||||||
int m_numOverlap;
|
|
||||||
MyOverlapCallback(const btVector3& aabbMin, const btVector3& aabbMax ) : m_queryAabbMin(aabbMin),m_queryAabbMax(aabbMax),m_numOverlap(0) {}
|
|
||||||
virtual bool process(const btBroadphaseProxy* proxy)
|
|
||||||
{
|
|
||||||
btVector3 proxyAabbMin,proxyAabbMax;
|
|
||||||
btCollisionObject* colObj0 = (btCollisionObject*)proxy->m_clientObject;
|
|
||||||
colObj0->getCollisionShape()->getAabb(colObj0->getWorldTransform(),proxyAabbMin,proxyAabbMax);
|
|
||||||
if (TestAabbAgainstAabb2(proxyAabbMin,proxyAabbMax,m_queryAabbMin,m_queryAabbMax))
|
|
||||||
{
|
|
||||||
m_numOverlap++;
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
void BasicDemo::clientMoveAndDisplay()
|
|
||||||
{
|
|
||||||
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
|
||||||
|
|
||||||
//simple dynamics world doesn't handle fixed-time-stepping
|
|
||||||
float ms = getDeltaTimeMicroseconds();
|
|
||||||
|
|
||||||
///step the simulation
|
|
||||||
if (m_dynamicsWorld)
|
|
||||||
{
|
|
||||||
m_dynamicsWorld->stepSimulation(ms / 1000000.f);
|
|
||||||
//optional but useful: debug drawing
|
|
||||||
m_dynamicsWorld->debugDrawWorld();
|
|
||||||
|
|
||||||
btVector3 aabbMin(1,1,1);
|
|
||||||
btVector3 aabbMax(2,2,2);
|
|
||||||
|
|
||||||
MyOverlapCallback aabbOverlap(aabbMin,aabbMax);
|
|
||||||
m_dynamicsWorld->getBroadphase()->aabbTest(aabbMin,aabbMax,aabbOverlap);
|
|
||||||
|
|
||||||
if (aabbOverlap.m_numOverlap)
|
|
||||||
printf("#aabb overlap = %d\n", aabbOverlap.m_numOverlap);
|
|
||||||
}
|
|
||||||
|
|
||||||
renderme();
|
|
||||||
|
|
||||||
glFlush();
|
|
||||||
|
|
||||||
swapBuffers();
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void BasicDemo::displayCallback(void) {
|
|
||||||
|
|
||||||
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
|
||||||
|
|
||||||
renderme();
|
|
||||||
|
|
||||||
//optional but useful: debug drawing to detect problems
|
|
||||||
if (m_dynamicsWorld)
|
|
||||||
m_dynamicsWorld->debugDrawWorld();
|
|
||||||
|
|
||||||
glFlush();
|
|
||||||
swapBuffers();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void BasicDemo::initPhysics()
|
|
||||||
{
|
|
||||||
setTexturing(true);
|
|
||||||
setShadows(true);
|
|
||||||
|
|
||||||
setCameraDistance(btScalar(SCALING*50.));
|
|
||||||
|
|
||||||
///collision configuration contains default setup for memory, collision setup
|
|
||||||
m_collisionConfiguration = new btDefaultCollisionConfiguration();
|
|
||||||
//m_collisionConfiguration->setConvexConvexMultipointIterations();
|
|
||||||
|
|
||||||
///use the default collision dispatcher. For parallel processing you can use a diffent dispatcher (see Extras/BulletMultiThreaded)
|
|
||||||
m_dispatcher = new btCollisionDispatcher(m_collisionConfiguration);
|
|
||||||
|
|
||||||
m_broadphase = new btDbvtBroadphase();
|
|
||||||
|
|
||||||
///the default constraint solver. For parallel processing you can use a different solver (see Extras/BulletMultiThreaded)
|
|
||||||
btSequentialImpulseConstraintSolver* sol = new btSequentialImpulseConstraintSolver;
|
|
||||||
m_solver = sol;
|
|
||||||
|
|
||||||
m_dynamicsWorld = new btDiscreteDynamicsWorld(m_dispatcher,m_broadphase,m_solver,m_collisionConfiguration);
|
|
||||||
m_dynamicsWorld->setDebugDrawer(&gDebugDraw);
|
|
||||||
|
|
||||||
m_dynamicsWorld->setGravity(btVector3(0,-10,0));
|
|
||||||
|
|
||||||
///create a few basic rigid bodies
|
|
||||||
btBoxShape* groundShape = new btBoxShape(btVector3(btScalar(50.),btScalar(50.),btScalar(50.)));
|
|
||||||
//groundShape->initializePolyhedralFeatures();
|
|
||||||
// btCollisionShape* groundShape = new btStaticPlaneShape(btVector3(0,1,0),50);
|
|
||||||
|
|
||||||
m_collisionShapes.push_back(groundShape);
|
|
||||||
|
|
||||||
btTransform groundTransform;
|
|
||||||
groundTransform.setIdentity();
|
|
||||||
groundTransform.setOrigin(btVector3(0,-50,0));
|
|
||||||
|
|
||||||
//We can also use DemoApplication::localCreateRigidBody, but for clarity it is provided here:
|
|
||||||
{
|
|
||||||
btScalar mass(0.);
|
|
||||||
|
|
||||||
//rigidbody is dynamic if and only if mass is non zero, otherwise static
|
|
||||||
bool isDynamic = (mass != 0.f);
|
|
||||||
|
|
||||||
btVector3 localInertia(0,0,0);
|
|
||||||
if (isDynamic)
|
|
||||||
groundShape->calculateLocalInertia(mass,localInertia);
|
|
||||||
|
|
||||||
//using motionstate is recommended, it provides interpolation capabilities, and only synchronizes 'active' objects
|
|
||||||
btDefaultMotionState* myMotionState = new btDefaultMotionState(groundTransform);
|
|
||||||
btRigidBody::btRigidBodyConstructionInfo rbInfo(mass,myMotionState,groundShape,localInertia);
|
|
||||||
btRigidBody* body = new btRigidBody(rbInfo);
|
|
||||||
|
|
||||||
//add the body to the dynamics world
|
|
||||||
m_dynamicsWorld->addRigidBody(body);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
{
|
|
||||||
//create a few dynamic rigidbodies
|
|
||||||
// Re-using the same collision is better for memory usage and performance
|
|
||||||
|
|
||||||
btBoxShape* colShape = new btBoxShape(btVector3(SCALING*1,SCALING*1,SCALING*1));
|
|
||||||
//btCollisionShape* colShape = new btSphereShape(btScalar(1.));
|
|
||||||
m_collisionShapes.push_back(colShape);
|
|
||||||
|
|
||||||
/// Create Dynamic Objects
|
|
||||||
btTransform startTransform;
|
|
||||||
startTransform.setIdentity();
|
|
||||||
|
|
||||||
btScalar mass(1.f);
|
|
||||||
|
|
||||||
//rigidbody is dynamic if and only if mass is non zero, otherwise static
|
|
||||||
bool isDynamic = (mass != 0.f);
|
|
||||||
|
|
||||||
btVector3 localInertia(0,0,0);
|
|
||||||
if (isDynamic)
|
|
||||||
colShape->calculateLocalInertia(mass,localInertia);
|
|
||||||
|
|
||||||
float start_x = START_POS_X - ARRAY_SIZE_X/2;
|
|
||||||
float start_y = START_POS_Y;
|
|
||||||
float start_z = START_POS_Z - ARRAY_SIZE_Z/2;
|
|
||||||
|
|
||||||
for (int k=0;k<ARRAY_SIZE_Y;k++)
|
|
||||||
{
|
|
||||||
for (int i=0;i<ARRAY_SIZE_X;i++)
|
|
||||||
{
|
|
||||||
for(int j = 0;j<ARRAY_SIZE_Z;j++)
|
|
||||||
{
|
|
||||||
startTransform.setOrigin(SCALING*btVector3(
|
|
||||||
btScalar(2.0*i + start_x),
|
|
||||||
btScalar(20+2.0*k + start_y),
|
|
||||||
btScalar(2.0*j + start_z)));
|
|
||||||
|
|
||||||
|
|
||||||
//using motionstate is recommended, it provides interpolation capabilities, and only synchronizes 'active' objects
|
|
||||||
btDefaultMotionState* myMotionState = new btDefaultMotionState(startTransform);
|
|
||||||
btRigidBody::btRigidBodyConstructionInfo rbInfo(mass,myMotionState,colShape,localInertia);
|
|
||||||
btRigidBody* body = new btRigidBody(rbInfo);
|
|
||||||
|
|
||||||
|
|
||||||
m_dynamicsWorld->addRigidBody(body);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
void BasicDemo::clientResetScene()
|
|
||||||
{
|
|
||||||
exitPhysics();
|
|
||||||
initPhysics();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void BasicDemo::exitPhysics()
|
|
||||||
{
|
|
||||||
|
|
||||||
//cleanup in the reverse order of creation/initialization
|
|
||||||
|
|
||||||
//remove the rigidbodies from the dynamics world and delete them
|
|
||||||
int i;
|
|
||||||
for (i=m_dynamicsWorld->getNumCollisionObjects()-1; i>=0 ;i--)
|
|
||||||
{
|
|
||||||
btCollisionObject* obj = m_dynamicsWorld->getCollisionObjectArray()[i];
|
|
||||||
btRigidBody* body = btRigidBody::upcast(obj);
|
|
||||||
if (body && body->getMotionState())
|
|
||||||
{
|
|
||||||
delete body->getMotionState();
|
|
||||||
}
|
|
||||||
m_dynamicsWorld->removeCollisionObject( obj );
|
|
||||||
delete obj;
|
|
||||||
}
|
|
||||||
|
|
||||||
//delete collision shapes
|
|
||||||
for (int j=0;j<m_collisionShapes.size();j++)
|
|
||||||
{
|
|
||||||
btCollisionShape* shape = m_collisionShapes[j];
|
|
||||||
delete shape;
|
|
||||||
}
|
|
||||||
m_collisionShapes.clear();
|
|
||||||
|
|
||||||
delete m_dynamicsWorld;
|
|
||||||
|
|
||||||
delete m_solver;
|
|
||||||
|
|
||||||
delete m_broadphase;
|
|
||||||
|
|
||||||
delete m_dispatcher;
|
|
||||||
|
|
||||||
delete m_collisionConfiguration;
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
82
extern/bullet/Demos/BasicDemo/BasicDemo.h
vendored
82
extern/bullet/Demos/BasicDemo/BasicDemo.h
vendored
@ -1,82 +0,0 @@
|
|||||||
/*
|
|
||||||
Bullet Continuous Collision Detection and Physics Library
|
|
||||||
Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied warranty.
|
|
||||||
In no event will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it freely,
|
|
||||||
subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
|
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
#ifndef BASIC_DEMO_H
|
|
||||||
#define BASIC_DEMO_H
|
|
||||||
|
|
||||||
#ifdef _WINDOWS
|
|
||||||
#include "Win32DemoApplication.h"
|
|
||||||
#define PlatformDemoApplication Win32DemoApplication
|
|
||||||
#else
|
|
||||||
#include "GlutDemoApplication.h"
|
|
||||||
#define PlatformDemoApplication GlutDemoApplication
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include "LinearMath/btAlignedObjectArray.h"
|
|
||||||
|
|
||||||
class btBroadphaseInterface;
|
|
||||||
class btCollisionShape;
|
|
||||||
class btOverlappingPairCache;
|
|
||||||
class btCollisionDispatcher;
|
|
||||||
class btConstraintSolver;
|
|
||||||
struct btCollisionAlgorithmCreateFunc;
|
|
||||||
class btDefaultCollisionConfiguration;
|
|
||||||
|
|
||||||
///BasicDemo is good starting point for learning the code base and porting.
|
|
||||||
|
|
||||||
class BasicDemo : public PlatformDemoApplication
|
|
||||||
{
|
|
||||||
|
|
||||||
//keep the collision shapes, for deletion/cleanup
|
|
||||||
btAlignedObjectArray<btCollisionShape*> m_collisionShapes;
|
|
||||||
|
|
||||||
btBroadphaseInterface* m_broadphase;
|
|
||||||
|
|
||||||
btCollisionDispatcher* m_dispatcher;
|
|
||||||
|
|
||||||
btConstraintSolver* m_solver;
|
|
||||||
|
|
||||||
btDefaultCollisionConfiguration* m_collisionConfiguration;
|
|
||||||
|
|
||||||
public:
|
|
||||||
|
|
||||||
BasicDemo()
|
|
||||||
{
|
|
||||||
}
|
|
||||||
virtual ~BasicDemo()
|
|
||||||
{
|
|
||||||
exitPhysics();
|
|
||||||
}
|
|
||||||
void initPhysics();
|
|
||||||
|
|
||||||
void exitPhysics();
|
|
||||||
|
|
||||||
virtual void clientMoveAndDisplay();
|
|
||||||
|
|
||||||
virtual void displayCallback();
|
|
||||||
virtual void clientResetScene();
|
|
||||||
|
|
||||||
static DemoApplication* Create()
|
|
||||||
{
|
|
||||||
BasicDemo* demo = new BasicDemo;
|
|
||||||
demo->myinit();
|
|
||||||
demo->initPhysics();
|
|
||||||
return demo;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif //BASIC_DEMO_H
|
|
||||||
|
|
87
extern/bullet/Demos/BasicDemo/CMakeLists.txt
vendored
87
extern/bullet/Demos/BasicDemo/CMakeLists.txt
vendored
@ -1,87 +0,0 @@
|
|||||||
# This is basically the overall name of the project in Visual Studio this is the name of the Solution File
|
|
||||||
|
|
||||||
|
|
||||||
# For every executable you have with a main method you should have an add_executable line below.
|
|
||||||
# For every add executable line you should list every .cpp and .h file you have associated with that executable.
|
|
||||||
|
|
||||||
|
|
||||||
# This is the variable for Windows. I use this to define the root of my directory structure.
|
|
||||||
SET(GLUT_ROOT ${BULLET_PHYSICS_SOURCE_DIR}/Glut)
|
|
||||||
|
|
||||||
# You shouldn't have to modify anything below this line
|
|
||||||
########################################################
|
|
||||||
|
|
||||||
INCLUDE_DIRECTORIES(
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/src ${BULLET_PHYSICS_SOURCE_DIR}/Demos/OpenGL
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
IF (USE_GLUT)
|
|
||||||
LINK_LIBRARIES(
|
|
||||||
OpenGLSupport BulletDynamics BulletCollision LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY}
|
|
||||||
)
|
|
||||||
|
|
||||||
IF (WIN32)
|
|
||||||
ADD_EXECUTABLE(AppBasicDemo
|
|
||||||
main.cpp
|
|
||||||
BasicDemo.cpp
|
|
||||||
BasicDemo.h
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/build/bullet.rc
|
|
||||||
)
|
|
||||||
ELSE()
|
|
||||||
ADD_EXECUTABLE(AppBasicDemo
|
|
||||||
main.cpp
|
|
||||||
BasicDemo.cpp
|
|
||||||
BasicDemo.h
|
|
||||||
)
|
|
||||||
ENDIF()
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
IF (WIN32)
|
|
||||||
IF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES)
|
|
||||||
IF (CMAKE_CL_64)
|
|
||||||
ADD_CUSTOM_COMMAND(
|
|
||||||
TARGET AppBasicDemo
|
|
||||||
POST_BUILD
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/glut64.dll ${CMAKE_CURRENT_BINARY_DIR}
|
|
||||||
)
|
|
||||||
ELSE(CMAKE_CL_64)
|
|
||||||
ADD_CUSTOM_COMMAND(
|
|
||||||
TARGET AppBasicDemo
|
|
||||||
POST_BUILD
|
|
||||||
# COMMAND copy /Y ${BULLET_PHYSICS_SOURCE_DIR}/GLUT32.DLL ${CMAKE_CURRENT_BINARY_DIR}
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/GLUT32.DLL ${CMAKE_CURRENT_BINARY_DIR}
|
|
||||||
)
|
|
||||||
ENDIF(CMAKE_CL_64)
|
|
||||||
ENDIF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES)
|
|
||||||
|
|
||||||
ENDIF(WIN32)
|
|
||||||
ELSE (USE_GLUT)
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
LINK_LIBRARIES(
|
|
||||||
OpenGLSupport BulletDynamics BulletCollision LinearMath ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY}
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
ADD_EXECUTABLE(AppBasicDemo
|
|
||||||
WIN32
|
|
||||||
../OpenGL/Win32AppMain.cpp
|
|
||||||
Win32BasicDemo.cpp
|
|
||||||
BasicDemo.cpp
|
|
||||||
BasicDemo.h
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/build/bullet.rc
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
ENDIF (USE_GLUT)
|
|
||||||
|
|
||||||
IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES)
|
|
||||||
SET_TARGET_PROPERTIES(AppBasicDemo PROPERTIES DEBUG_POSTFIX "_Debug")
|
|
||||||
SET_TARGET_PROPERTIES(AppBasicDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel")
|
|
||||||
SET_TARGET_PROPERTIES(AppBasicDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo")
|
|
||||||
ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES)
|
|
5
extern/bullet/Demos/BasicDemo/Makefile.am
vendored
5
extern/bullet/Demos/BasicDemo/Makefile.am
vendored
@ -1,5 +0,0 @@
|
|||||||
noinst_PROGRAMS=BasicDemo
|
|
||||||
|
|
||||||
BasicDemo_SOURCES=BasicDemo.cpp BasicDemo.h main.cpp
|
|
||||||
BasicDemo_CXXFLAGS=-I@top_builddir@/src -I@top_builddir@/Demos/OpenGL $(CXXFLAGS)
|
|
||||||
BasicDemo_LDADD=-L../OpenGL -lbulletopenglsupport -L../../src -lBulletDynamics -lBulletCollision -lLinearMath @opengl_LIBS@
|
|
25
extern/bullet/Demos/BasicDemo/Win32BasicDemo.cpp
vendored
25
extern/bullet/Demos/BasicDemo/Win32BasicDemo.cpp
vendored
@ -1,25 +0,0 @@
|
|||||||
#ifdef _WINDOWS
|
|
||||||
/*
|
|
||||||
Bullet Continuous Collision Detection and Physics Library
|
|
||||||
Copyright (c) 2003-2009 Erwin Coumans http://bulletphysics.org
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied warranty.
|
|
||||||
In no event will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it freely,
|
|
||||||
subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
|
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "BasicDemo.h"
|
|
||||||
|
|
||||||
///The 'createDemo' function is called from Bullet/Demos/OpenGL/Win32AppMain.cpp to instantiate this particular demo
|
|
||||||
DemoApplication* createDemo()
|
|
||||||
{
|
|
||||||
return new BasicDemo();
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
|
39
extern/bullet/Demos/BasicDemo/main.cpp
vendored
39
extern/bullet/Demos/BasicDemo/main.cpp
vendored
@ -1,39 +0,0 @@
|
|||||||
/*
|
|
||||||
Bullet Continuous Collision Detection and Physics Library
|
|
||||||
Copyright (c) 2003-2007 Erwin Coumans http://continuousphysics.com/Bullet/
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied warranty.
|
|
||||||
In no event will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it freely,
|
|
||||||
subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
|
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "BasicDemo.h"
|
|
||||||
#include "GlutStuff.h"
|
|
||||||
#include "btBulletDynamicsCommon.h"
|
|
||||||
#include "LinearMath/btHashMap.h"
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
int main(int argc,char** argv)
|
|
||||||
{
|
|
||||||
|
|
||||||
BasicDemo ccdDemo;
|
|
||||||
ccdDemo.initPhysics();
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef CHECK_MEMORY_LEAKS
|
|
||||||
ccdDemo.exitPhysics();
|
|
||||||
#else
|
|
||||||
return glutmain(argc, argv,1024,600,"Bullet Physics Demo. http://bulletphysics.org",&ccdDemo);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
//default glut doesn't return from mainloop
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
1329
extern/bullet/Demos/Benchmarks/BenchmarkDemo.cpp
vendored
1329
extern/bullet/Demos/Benchmarks/BenchmarkDemo.cpp
vendored
File diff suppressed because it is too large
Load Diff
265
extern/bullet/Demos/Benchmarks/BenchmarkDemo.h
vendored
265
extern/bullet/Demos/Benchmarks/BenchmarkDemo.h
vendored
@ -1,265 +0,0 @@
|
|||||||
/*
|
|
||||||
Bullet Continuous Collision Detection and Physics Library
|
|
||||||
Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied warranty.
|
|
||||||
In no event will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it freely,
|
|
||||||
subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
|
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
#ifndef BENCHMARK_DEMO_H
|
|
||||||
#define BENCHMARK_DEMO_H
|
|
||||||
|
|
||||||
|
|
||||||
#include "LinearMath/btAlignedObjectArray.h"
|
|
||||||
#include "LinearMath/btTransform.h"
|
|
||||||
|
|
||||||
class btDynamicsWorld;
|
|
||||||
|
|
||||||
#define NUMRAYS 500
|
|
||||||
|
|
||||||
class btRigidBody;
|
|
||||||
class btBroadphaseInterface;
|
|
||||||
class btCollisionShape;
|
|
||||||
class btOverlappingPairCache;
|
|
||||||
class btCollisionDispatcher;
|
|
||||||
class btConstraintSolver;
|
|
||||||
struct btCollisionAlgorithmCreateFunc;
|
|
||||||
class btDefaultCollisionConfiguration;
|
|
||||||
|
|
||||||
|
|
||||||
#ifndef USE_GRAPHICAL_BENCHMARK
|
|
||||||
///empty placeholder
|
|
||||||
class DemoApplication
|
|
||||||
{
|
|
||||||
protected:
|
|
||||||
|
|
||||||
btDynamicsWorld* m_dynamicsWorld;
|
|
||||||
btScalar m_defaultContactProcessingThreshold;
|
|
||||||
|
|
||||||
public:
|
|
||||||
DemoApplication()
|
|
||||||
:m_defaultContactProcessingThreshold(BT_LARGE_FLOAT)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
virtual void myinit() {}
|
|
||||||
virtual btDynamicsWorld* getDynamicsWorld()
|
|
||||||
{
|
|
||||||
return m_dynamicsWorld;
|
|
||||||
}
|
|
||||||
|
|
||||||
btScalar getDeltaTimeMicroseconds()
|
|
||||||
{
|
|
||||||
return 1.f;
|
|
||||||
}
|
|
||||||
|
|
||||||
void renderme() {}
|
|
||||||
void setCameraDistance(btScalar dist){}
|
|
||||||
void clientResetScene(){}
|
|
||||||
btRigidBody* localCreateRigidBody(float mass, const btTransform& startTransform,btCollisionShape* shape);
|
|
||||||
|
|
||||||
};
|
|
||||||
///BenchmarkDemo is provides several performance tests
|
|
||||||
#define PlatformDemoApplication DemoApplication
|
|
||||||
#else //USE_GRAPHICAL_BENCHMARK
|
|
||||||
|
|
||||||
#ifdef _WINDOWS
|
|
||||||
#include "Win32DemoApplication.h"
|
|
||||||
#define PlatformDemoApplication Win32DemoApplication
|
|
||||||
#else
|
|
||||||
#include "GlutDemoApplication.h"
|
|
||||||
#define PlatformDemoApplication GlutDemoApplication
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif //USE_GRAPHICAL_BENCHMARK
|
|
||||||
|
|
||||||
|
|
||||||
class BenchmarkDemo : public PlatformDemoApplication
|
|
||||||
{
|
|
||||||
|
|
||||||
//keep the collision shapes, for deletion/cleanup
|
|
||||||
btAlignedObjectArray<btCollisionShape*> m_collisionShapes;
|
|
||||||
|
|
||||||
btAlignedObjectArray<class RagDoll*> m_ragdolls;
|
|
||||||
|
|
||||||
btBroadphaseInterface* m_overlappingPairCache;
|
|
||||||
|
|
||||||
btCollisionDispatcher* m_dispatcher;
|
|
||||||
|
|
||||||
btConstraintSolver* m_solver;
|
|
||||||
|
|
||||||
btDefaultCollisionConfiguration* m_collisionConfiguration;
|
|
||||||
|
|
||||||
int m_benchmark;
|
|
||||||
|
|
||||||
void createTest1();
|
|
||||||
void createTest2();
|
|
||||||
void createTest3();
|
|
||||||
void createTest4();
|
|
||||||
void createTest5();
|
|
||||||
void createTest6();
|
|
||||||
void createTest7();
|
|
||||||
|
|
||||||
void createWall(const btVector3& offsetPosition,int stackSize,const btVector3& boxSize);
|
|
||||||
void createPyramid(const btVector3& offsetPosition,int stackSize,const btVector3& boxSize);
|
|
||||||
void createTowerCircle(const btVector3& offsetPosition,int stackSize,int rotSize,const btVector3& boxSize);
|
|
||||||
void createLargeMeshBody();
|
|
||||||
|
|
||||||
|
|
||||||
class SpuBatchRaycaster* m_batchRaycaster;
|
|
||||||
class btThreadSupportInterface* m_batchRaycasterThreadSupport;
|
|
||||||
|
|
||||||
void castRays();
|
|
||||||
void initRays();
|
|
||||||
|
|
||||||
public:
|
|
||||||
|
|
||||||
BenchmarkDemo(int benchmark)
|
|
||||||
:m_benchmark(benchmark)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
virtual ~BenchmarkDemo()
|
|
||||||
{
|
|
||||||
exitPhysics();
|
|
||||||
}
|
|
||||||
void initPhysics();
|
|
||||||
|
|
||||||
void exitPhysics();
|
|
||||||
|
|
||||||
virtual void clientMoveAndDisplay();
|
|
||||||
|
|
||||||
virtual void displayCallback();
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
};
|
|
||||||
|
|
||||||
class BenchmarkDemo1 : public BenchmarkDemo
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
BenchmarkDemo1()
|
|
||||||
:BenchmarkDemo(1)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
static DemoApplication* Create()
|
|
||||||
{
|
|
||||||
BenchmarkDemo1* demo = new BenchmarkDemo1;
|
|
||||||
demo->myinit();
|
|
||||||
demo->initPhysics();
|
|
||||||
return demo;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
class BenchmarkDemo2 : public BenchmarkDemo
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
BenchmarkDemo2()
|
|
||||||
:BenchmarkDemo(2)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
static DemoApplication* Create()
|
|
||||||
{
|
|
||||||
BenchmarkDemo2* demo = new BenchmarkDemo2;
|
|
||||||
demo->myinit();
|
|
||||||
demo->initPhysics();
|
|
||||||
return demo;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
class BenchmarkDemo3 : public BenchmarkDemo
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
BenchmarkDemo3()
|
|
||||||
:BenchmarkDemo(3)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
static DemoApplication* Create()
|
|
||||||
{
|
|
||||||
BenchmarkDemo3* demo = new BenchmarkDemo3;
|
|
||||||
demo->myinit();
|
|
||||||
demo->initPhysics();
|
|
||||||
return demo;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
class BenchmarkDemo4 : public BenchmarkDemo
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
BenchmarkDemo4()
|
|
||||||
:BenchmarkDemo(4)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
static DemoApplication* Create()
|
|
||||||
{
|
|
||||||
BenchmarkDemo4* demo = new BenchmarkDemo4;
|
|
||||||
demo->myinit();
|
|
||||||
demo->initPhysics();
|
|
||||||
return demo;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
class BenchmarkDemo5 : public BenchmarkDemo
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
BenchmarkDemo5()
|
|
||||||
:BenchmarkDemo(5)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
static DemoApplication* Create()
|
|
||||||
{
|
|
||||||
BenchmarkDemo5* demo = new BenchmarkDemo5;
|
|
||||||
demo->myinit();
|
|
||||||
demo->initPhysics();
|
|
||||||
return demo;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
class BenchmarkDemo6 : public BenchmarkDemo
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
BenchmarkDemo6()
|
|
||||||
:BenchmarkDemo(6)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
static DemoApplication* Create()
|
|
||||||
{
|
|
||||||
BenchmarkDemo6* demo = new BenchmarkDemo6;
|
|
||||||
demo->myinit();
|
|
||||||
demo->initPhysics();
|
|
||||||
return demo;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
class BenchmarkDemo7 : public BenchmarkDemo
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
BenchmarkDemo7()
|
|
||||||
:BenchmarkDemo(7)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
static DemoApplication* Create()
|
|
||||||
{
|
|
||||||
BenchmarkDemo7* demo = new BenchmarkDemo7;
|
|
||||||
demo->myinit();
|
|
||||||
demo->initPhysics();
|
|
||||||
return demo;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif //BENCHMARK_DEMO_H
|
|
||||||
|
|
107
extern/bullet/Demos/Benchmarks/CMakeLists.txt
vendored
107
extern/bullet/Demos/Benchmarks/CMakeLists.txt
vendored
@ -1,107 +0,0 @@
|
|||||||
# This is basically the overall name of the project in Visual Studio this is the name of the Solution File
|
|
||||||
|
|
||||||
|
|
||||||
# For every executable you have with a main method you should have an add_executable line below.
|
|
||||||
# For every add executable line you should list every .cpp and .h file you have associated with that executable.
|
|
||||||
|
|
||||||
|
|
||||||
# You shouldn't have to modify anything below this line
|
|
||||||
########################################################
|
|
||||||
|
|
||||||
IF (USE_GRAPHICAL_BENCHMARK)
|
|
||||||
IF (USE_GLUT)
|
|
||||||
INCLUDE_DIRECTORIES(
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/src
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/Demos/OpenGL
|
|
||||||
)
|
|
||||||
|
|
||||||
IF (USE_MULTITHREADED_BENCHMARK)
|
|
||||||
INCLUDE_DIRECTORIES( ${VECTOR_MATH_INCLUDE} )
|
|
||||||
LINK_LIBRARIES( OpenGLSupport BulletMultiThreaded BulletDynamics BulletCollision LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY})
|
|
||||||
ELSE()
|
|
||||||
LINK_LIBRARIES( OpenGLSupport BulletDynamics BulletCollision LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY})
|
|
||||||
ENDIF(USE_MULTITHREADED_BENCHMARK)
|
|
||||||
|
|
||||||
IF (WIN32)
|
|
||||||
ADD_EXECUTABLE(AppBenchmarks
|
|
||||||
main.cpp
|
|
||||||
BenchmarkDemo.cpp
|
|
||||||
BenchmarkDemo.h
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/build/bullet.rc
|
|
||||||
)
|
|
||||||
ELSE()
|
|
||||||
ADD_EXECUTABLE(AppBenchmarks
|
|
||||||
main.cpp
|
|
||||||
BenchmarkDemo.cpp
|
|
||||||
BenchmarkDemo.h
|
|
||||||
)
|
|
||||||
ENDIF ()
|
|
||||||
IF (WIN32)
|
|
||||||
IF (NOT INTERNAL_CREATE_MSVC_RELATIVE_PATH_PROJECTFILES)
|
|
||||||
IF (CMAKE_CL_64)
|
|
||||||
ADD_CUSTOM_COMMAND(
|
|
||||||
TARGET AppBenchmarks
|
|
||||||
POST_BUILD
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/glut64.dll ${CMAKE_CURRENT_BINARY_DIR}
|
|
||||||
)
|
|
||||||
ELSE(CMAKE_CL_64)
|
|
||||||
ADD_CUSTOM_COMMAND(
|
|
||||||
TARGET AppBenchmarks
|
|
||||||
POST_BUILD
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/GLUT32.DLL ${CMAKE_CURRENT_BINARY_DIR}
|
|
||||||
)
|
|
||||||
ENDIF(CMAKE_CL_64)
|
|
||||||
ENDIF (NOT INTERNAL_CREATE_MSVC_RELATIVE_PATH_PROJECTFILES)
|
|
||||||
IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES)
|
|
||||||
SET_TARGET_PROPERTIES(AppBenchmarks PROPERTIES DEBUG_POSTFIX "_Debug")
|
|
||||||
SET_TARGET_PROPERTIES(AppBenchmarks PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel")
|
|
||||||
SET_TARGET_PROPERTIES(AppBenchmarks PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo")
|
|
||||||
ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES)
|
|
||||||
|
|
||||||
ENDIF(WIN32)
|
|
||||||
ELSE (USE_GLUT)
|
|
||||||
INCLUDE_DIRECTORIES(
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/src
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/Demos/OpenGL
|
|
||||||
)
|
|
||||||
|
|
||||||
IF (USE_MULTITHREADED_BENCHMARK)
|
|
||||||
INCLUDE_DIRECTORIES( ${VECTOR_MATH_INCLUDE} )
|
|
||||||
LINK_LIBRARIES(
|
|
||||||
OpenGLSupport BulletMultiThreaded BulletDynamics BulletCollision LinearMath ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY}
|
|
||||||
)
|
|
||||||
ELSE()
|
|
||||||
LINK_LIBRARIES(
|
|
||||||
OpenGLSupport BulletDynamics BulletCollision LinearMath ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY}
|
|
||||||
)
|
|
||||||
|
|
||||||
ENDIF()
|
|
||||||
|
|
||||||
ADD_EXECUTABLE(AppBenchmarks
|
|
||||||
WIN32
|
|
||||||
../OpenGL/Win32AppMain.cpp
|
|
||||||
BenchmarkDemo.cpp
|
|
||||||
BenchmarkDemo.h
|
|
||||||
Win32BenchmarkDemo.cpp
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/build/bullet.rc
|
|
||||||
)
|
|
||||||
ENDIF (USE_GLUT)
|
|
||||||
ELSE (USE_GRAPHICAL_BENCHMARK)
|
|
||||||
|
|
||||||
INCLUDE_DIRECTORIES(
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/src
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/Demos/OpenGL
|
|
||||||
)
|
|
||||||
|
|
||||||
IF (USE_MULTITHREADED_BENCHMARK)
|
|
||||||
LINK_LIBRARIES( BulletMultiThreaded BulletDynamics BulletCollision LinearMath )
|
|
||||||
ELSE()
|
|
||||||
LINK_LIBRARIES( BulletDynamics BulletCollision LinearMath )
|
|
||||||
ENDIF()
|
|
||||||
|
|
||||||
|
|
||||||
ADD_EXECUTABLE(AppBenchmarks
|
|
||||||
main.cpp
|
|
||||||
BenchmarkDemo.cpp
|
|
||||||
)
|
|
||||||
ENDIF (USE_GRAPHICAL_BENCHMARK)
|
|
49
extern/bullet/Demos/Benchmarks/Taru.mdl
vendored
49
extern/bullet/Demos/Benchmarks/Taru.mdl
vendored
@ -1,49 +0,0 @@
|
|||||||
#define TaruVtxCount 43
|
|
||||||
#define TaruIdxCount 132
|
|
||||||
|
|
||||||
static float TaruVtx[] = {
|
|
||||||
1.08664f,-1.99237f,0.0f,
|
|
||||||
0.768369f,-1.99237f,-0.768369f,
|
|
||||||
1.28852f,1.34412e-007f,-1.28852f,
|
|
||||||
1.82224f,1.90735e-007f,0.0f,
|
|
||||||
0.0f,-1.99237f,-1.08664f,
|
|
||||||
0.0f,0.0f,-1.82224f,
|
|
||||||
0.0f,-1.99237f,-1.08664f,
|
|
||||||
-0.768369f,-1.99237f,-0.768369f,
|
|
||||||
-1.28852f,1.34412e-007f,-1.28852f,
|
|
||||||
0.0f,0.0f,-1.82224f,
|
|
||||||
-1.08664f,-1.99237f,1.82086e-007f,
|
|
||||||
-1.82224f,1.90735e-007f,1.59305e-007f,
|
|
||||||
-0.768369f,-1.99237f,0.76837f,
|
|
||||||
-1.28852f,2.47058e-007f,1.28852f,
|
|
||||||
1.42495e-007f,-1.99237f,1.08664f,
|
|
||||||
2.38958e-007f,2.70388e-007f,1.82224f,
|
|
||||||
0.768369f,-1.99237f,0.768369f,
|
|
||||||
1.28852f,2.47058e-007f,1.28852f,
|
|
||||||
0.768369f,1.99237f,-0.768369f,
|
|
||||||
1.08664f,1.99237f,0.0f,
|
|
||||||
0.0f,1.99237f,-1.08664f,
|
|
||||||
-0.768369f,1.99237f,-0.768369f,
|
|
||||||
0.0f,1.99237f,-1.08664f,
|
|
||||||
-1.08664f,1.99237f,0.0f,
|
|
||||||
-0.768369f,1.99237f,0.768369f,
|
|
||||||
1.42495e-007f,1.99237f,1.08664f,
|
|
||||||
0.768369f,1.99237f,0.768369f,
|
|
||||||
1.42495e-007f,-1.99237f,1.08664f,
|
|
||||||
-0.768369f,-1.99237f,0.76837f,
|
|
||||||
-1.08664f,-1.99237f,1.82086e-007f,
|
|
||||||
-0.768369f,-1.99237f,-0.768369f,
|
|
||||||
0.0f,-1.99237f,-1.08664f,
|
|
||||||
0.768369f,-1.99237f,-0.768369f,
|
|
||||||
1.08664f,-1.99237f,0.0f,
|
|
||||||
0.768369f,-1.99237f,0.768369f,
|
|
||||||
0.768369f,1.99237f,-0.768369f,
|
|
||||||
0.0f,1.99237f,-1.08664f,
|
|
||||||
-0.768369f,1.99237f,-0.768369f,
|
|
||||||
-1.08664f,1.99237f,0.0f,
|
|
||||||
-0.768369f,1.99237f,0.768369f,
|
|
||||||
1.42495e-007f,1.99237f,1.08664f,
|
|
||||||
0.768369f,1.99237f,0.768369f,
|
|
||||||
1.08664f,1.99237f,0.0f,
|
|
||||||
};
|
|
||||||
|
|
@ -1,25 +0,0 @@
|
|||||||
#ifdef _WINDOWS
|
|
||||||
/*
|
|
||||||
Bullet Continuous Collision Detection and Physics Library
|
|
||||||
Copyright (c) 2003-2009 Erwin Coumans http://bulletphysics.org
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied warranty.
|
|
||||||
In no event will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it freely,
|
|
||||||
subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
|
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "BenchmarkDemo.h"
|
|
||||||
|
|
||||||
///The 'createDemo' function is called from Bullet/Demos/OpenGL/Win32AppMain.cpp to instantiate this particular demo
|
|
||||||
DemoApplication* createDemo()
|
|
||||||
{
|
|
||||||
return new BenchmarkDemo(1);
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
|
84369
extern/bullet/Demos/Benchmarks/landscape.mdl
vendored
84369
extern/bullet/Demos/Benchmarks/landscape.mdl
vendored
File diff suppressed because it is too large
Load Diff
89
extern/bullet/Demos/Benchmarks/main.cpp
vendored
89
extern/bullet/Demos/Benchmarks/main.cpp
vendored
@ -1,89 +0,0 @@
|
|||||||
/*
|
|
||||||
Bullet Continuous Collision Detection and Physics Library
|
|
||||||
Copyright (c) 2003-2007 Erwin Coumans http://continuousphysics.com/Bullet/
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied warranty.
|
|
||||||
In no event will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it freely,
|
|
||||||
subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
|
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "BenchmarkDemo.h"
|
|
||||||
#include "btBulletDynamicsCommon.h"
|
|
||||||
#include "LinearMath/btHashMap.h"
|
|
||||||
#include <stdio.h>
|
|
||||||
|
|
||||||
#ifdef USE_GRAPHICAL_BENCHMARK
|
|
||||||
#include "GlutStuff.h"
|
|
||||||
#include "GLDebugDrawer.h"
|
|
||||||
GLDebugDrawer gDebugDrawer;
|
|
||||||
#define benchmarkDemo benchmarkDemo2
|
|
||||||
#endif //USE_GRAPHICAL_BENCHMARK
|
|
||||||
|
|
||||||
|
|
||||||
#define NUM_DEMOS 7
|
|
||||||
#define NUM_TESTS 200
|
|
||||||
|
|
||||||
extern bool gDisableDeactivation;
|
|
||||||
|
|
||||||
int main(int argc,char** argv)
|
|
||||||
{
|
|
||||||
gDisableDeactivation = true;
|
|
||||||
|
|
||||||
BenchmarkDemo1 benchmarkDemo1;
|
|
||||||
BenchmarkDemo2 benchmarkDemo2;
|
|
||||||
BenchmarkDemo3 benchmarkDemo3;
|
|
||||||
BenchmarkDemo4 benchmarkDemo4;
|
|
||||||
BenchmarkDemo5 benchmarkDemo5;
|
|
||||||
BenchmarkDemo6 benchmarkDemo6;
|
|
||||||
BenchmarkDemo7 benchmarkDemo7;
|
|
||||||
|
|
||||||
BenchmarkDemo* demoArray[NUM_DEMOS] = {&benchmarkDemo1,&benchmarkDemo2,&benchmarkDemo3,&benchmarkDemo4,&benchmarkDemo5,&benchmarkDemo6,&benchmarkDemo7};
|
|
||||||
const char* demoNames[NUM_DEMOS] = {"3000 fall", "1000 stack", "136 ragdolls","1000 convex", "prim-trimesh", "convex-trimesh","raytests"};
|
|
||||||
float totalTime[NUM_DEMOS] = {0.f,0.f,0.f,0.f,0.f,0.f,0.f};
|
|
||||||
|
|
||||||
#ifdef USE_GRAPHICAL_BENCHMARK
|
|
||||||
benchmarkDemo.initPhysics();
|
|
||||||
benchmarkDemo.getDynamicsWorld()->setDebugDrawer(&gDebugDrawer);
|
|
||||||
benchmarkDemo.setDebugMode(benchmarkDemo.getDebugMode() | btIDebugDraw::DBG_NoDeactivation);
|
|
||||||
return glutmain(argc, argv,640,480,"Bullet Physics Demo. http://bulletphysics.com",&benchmarkDemo);
|
|
||||||
|
|
||||||
#else //USE_GRAPHICAL_BENCHMARK
|
|
||||||
int d;
|
|
||||||
|
|
||||||
for (d=0;d<NUM_DEMOS;d++)
|
|
||||||
{
|
|
||||||
demoArray[d]->initPhysics();
|
|
||||||
|
|
||||||
|
|
||||||
for (int i=0;i<NUM_TESTS;i++)
|
|
||||||
{
|
|
||||||
demoArray[d]->clientMoveAndDisplay();
|
|
||||||
float frameTime = CProfileManager::Get_Time_Since_Reset();
|
|
||||||
if ((i % 25)==0)
|
|
||||||
{
|
|
||||||
printf("BenchmarkDemo: %s, Frame %d, Duration (ms): %f\n",demoNames[d],i,frameTime);
|
|
||||||
}
|
|
||||||
totalTime[d] += frameTime;
|
|
||||||
if (i==NUM_TESTS-1)
|
|
||||||
CProfileManager::dumpAll();
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
demoArray[d]->exitPhysics();
|
|
||||||
}
|
|
||||||
|
|
||||||
for (d=0;d<NUM_DEMOS;d++)
|
|
||||||
{
|
|
||||||
printf("\nResults for %s: %f",demoNames[d],totalTime[d]*(1.f/NUM_TESTS));
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif //USE_GRAPHICAL_BENCHMARK
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
22
extern/bullet/Demos/Benchmarks/premake4.lua
vendored
22
extern/bullet/Demos/Benchmarks/premake4.lua
vendored
@ -1,22 +0,0 @@
|
|||||||
|
|
||||||
project "AppBenchmarks"
|
|
||||||
|
|
||||||
if _OPTIONS["ios"] then
|
|
||||||
kind "WindowedApp"
|
|
||||||
else
|
|
||||||
kind "ConsoleApp"
|
|
||||||
end
|
|
||||||
|
|
||||||
includedirs {"../../src"}
|
|
||||||
|
|
||||||
links {
|
|
||||||
"BulletDynamics","BulletCollision", "LinearMath"
|
|
||||||
}
|
|
||||||
|
|
||||||
language "C++"
|
|
||||||
|
|
||||||
files {
|
|
||||||
"**.cpp",
|
|
||||||
"**.h",
|
|
||||||
}
|
|
||||||
|
|
370
extern/bullet/Demos/Box2dDemo/Box2dDemo.cpp
vendored
370
extern/bullet/Demos/Box2dDemo/Box2dDemo.cpp
vendored
@ -1,370 +0,0 @@
|
|||||||
/*
|
|
||||||
Bullet Continuous Collision Detection and Physics Library
|
|
||||||
Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied warranty.
|
|
||||||
In no event will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it freely,
|
|
||||||
subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
|
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "BulletCollision/CollisionShapes/btBox2dShape.h"
|
|
||||||
#include "BulletCollision/CollisionDispatch/btEmptyCollisionAlgorithm.h"
|
|
||||||
#include "BulletCollision/CollisionDispatch/btBox2dBox2dCollisionAlgorithm.h"
|
|
||||||
#include "BulletCollision/CollisionDispatch/btConvex2dConvex2dAlgorithm.h"
|
|
||||||
#include "GL_DialogDynamicsWorld.h"
|
|
||||||
#include "GL_DialogWindow.h"
|
|
||||||
|
|
||||||
|
|
||||||
#include "BulletCollision/CollisionShapes/btBox2dShape.h"
|
|
||||||
#include "BulletCollision/CollisionShapes/btConvex2dShape.h"
|
|
||||||
#include "BulletCollision/NarrowPhaseCollision/btMinkowskiPenetrationDepthSolver.h"
|
|
||||||
|
|
||||||
///create 125 (5x5x5) dynamic object
|
|
||||||
#define ARRAY_SIZE_X 5
|
|
||||||
#define ARRAY_SIZE_Y 5
|
|
||||||
#define ARRAY_SIZE_Z 1
|
|
||||||
|
|
||||||
//maximum number of objects (and allow user to shoot additional boxes)
|
|
||||||
#define MAX_PROXIES (ARRAY_SIZE_X*ARRAY_SIZE_Y*ARRAY_SIZE_Z + 1024)
|
|
||||||
|
|
||||||
///scaling of the objects (0.1 = 20 centimeter boxes )
|
|
||||||
#define SCALING 1
|
|
||||||
#define START_POS_X -5
|
|
||||||
#define START_POS_Y -5
|
|
||||||
#define START_POS_Z -3
|
|
||||||
|
|
||||||
#include "Box2dDemo.h"
|
|
||||||
#include "GlutStuff.h"
|
|
||||||
///btBulletDynamicsCommon.h is the main Bullet include file, contains most common include files.
|
|
||||||
#include "btBulletDynamicsCommon.h"
|
|
||||||
#include <stdio.h> //printf debugging
|
|
||||||
|
|
||||||
|
|
||||||
void Box2dDemo::clientMoveAndDisplay()
|
|
||||||
{
|
|
||||||
|
|
||||||
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
|
||||||
|
|
||||||
//simple dynamics world doesn't handle fixed-time-stepping
|
|
||||||
float ms = getDeltaTimeMicroseconds();
|
|
||||||
|
|
||||||
///step the simulation
|
|
||||||
if (m_dynamicsWorld)
|
|
||||||
{
|
|
||||||
m_dynamicsWorld->stepSimulation(ms / 1000000.f);
|
|
||||||
//optional but useful: debug drawing
|
|
||||||
m_dynamicsWorld->debugDrawWorld();
|
|
||||||
}
|
|
||||||
|
|
||||||
renderme();
|
|
||||||
|
|
||||||
if (m_dialogDynamicsWorld)
|
|
||||||
m_dialogDynamicsWorld->draw(ms / 1000000.f);
|
|
||||||
|
|
||||||
glFlush();
|
|
||||||
|
|
||||||
swapBuffers();
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void Box2dDemo::displayCallback(void) {
|
|
||||||
|
|
||||||
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
|
||||||
|
|
||||||
renderme();
|
|
||||||
|
|
||||||
//optional but useful: debug drawing to detect problems
|
|
||||||
if (m_dynamicsWorld)
|
|
||||||
m_dynamicsWorld->debugDrawWorld();
|
|
||||||
|
|
||||||
if (m_dialogDynamicsWorld)
|
|
||||||
m_dialogDynamicsWorld->draw(0.f);
|
|
||||||
|
|
||||||
glFlush();
|
|
||||||
swapBuffers();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void Box2dDemo::reshape(int w, int h)
|
|
||||||
{
|
|
||||||
if (m_dialogDynamicsWorld)
|
|
||||||
m_dialogDynamicsWorld->setScreenSize(w,h);
|
|
||||||
PlatformDemoApplication::reshape(w,h);
|
|
||||||
}
|
|
||||||
|
|
||||||
void Box2dDemo::initPhysics()
|
|
||||||
{
|
|
||||||
|
|
||||||
m_dialogDynamicsWorld = new GL_DialogDynamicsWorld();
|
|
||||||
|
|
||||||
//m_dialogDynamicsWorld->createDialog(100,110,200,50);
|
|
||||||
//m_dialogDynamicsWorld->createDialog(100,00,100,100);
|
|
||||||
//m_dialogDynamicsWorld->createDialog(0,0,100,100);
|
|
||||||
GL_DialogWindow* settings = m_dialogDynamicsWorld->createDialog(50,0,200,120,"Settings");
|
|
||||||
GL_ToggleControl* toggle = m_dialogDynamicsWorld->createToggle(settings,"Toggle 1");
|
|
||||||
toggle = m_dialogDynamicsWorld->createToggle(settings,"Toggle 2");
|
|
||||||
toggle ->m_active = true;
|
|
||||||
toggle = m_dialogDynamicsWorld->createToggle(settings,"Toggle 3");
|
|
||||||
//GL_SliderControl* slider = m_dialogDynamicsWorld->createSlider(settings,"Slider");
|
|
||||||
|
|
||||||
GL_DialogWindow* dialog = m_dialogDynamicsWorld->createDialog(0,200,420,300,"Help");
|
|
||||||
GL_TextControl* txt = new GL_TextControl;
|
|
||||||
dialog->addControl(txt);
|
|
||||||
txt->m_textLines.push_back("Mouse to move");
|
|
||||||
txt->m_textLines.push_back("Test 2");
|
|
||||||
txt->m_textLines.push_back("mouse to interact");
|
|
||||||
txt->m_textLines.push_back("ALT + mouse to move camera");
|
|
||||||
txt->m_textLines.push_back("space to reset");
|
|
||||||
txt->m_textLines.push_back("cursor keys and z,x to navigate");
|
|
||||||
txt->m_textLines.push_back("i to toggle simulation, s single step");
|
|
||||||
txt->m_textLines.push_back("q to quit");
|
|
||||||
txt->m_textLines.push_back(". to shoot box");
|
|
||||||
txt->m_textLines.push_back("d to toggle deactivation");
|
|
||||||
txt->m_textLines.push_back("g to toggle mesh animation (ConcaveDemo)");
|
|
||||||
txt->m_textLines.push_back("h to toggle help text");
|
|
||||||
txt->m_textLines.push_back("o to toggle orthogonal/perspective view");
|
|
||||||
//txt->m_textLines.push_back("+- shooting speed = %10.2f",m_ShootBoxInitialSpeed);
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
setTexturing(true);
|
|
||||||
setShadows(true);
|
|
||||||
|
|
||||||
setCameraDistance(btScalar(SCALING*50.));
|
|
||||||
m_cameraTargetPosition.setValue(0,0,0);//0, ARRAY_SIZE_Y, 0);
|
|
||||||
|
|
||||||
///collision configuration contains default setup for memory, collision setup
|
|
||||||
m_collisionConfiguration = new btDefaultCollisionConfiguration();
|
|
||||||
//m_collisionConfiguration->setConvexConvexMultipointIterations();
|
|
||||||
|
|
||||||
///use the default collision dispatcher. For parallel processing you can use a diffent dispatcher (see Extras/BulletMultiThreaded)
|
|
||||||
m_dispatcher = new btCollisionDispatcher(m_collisionConfiguration);
|
|
||||||
|
|
||||||
btVoronoiSimplexSolver* simplex = new btVoronoiSimplexSolver();
|
|
||||||
btMinkowskiPenetrationDepthSolver* pdSolver = new btMinkowskiPenetrationDepthSolver();
|
|
||||||
|
|
||||||
|
|
||||||
btConvex2dConvex2dAlgorithm::CreateFunc* convexAlgo2d = new btConvex2dConvex2dAlgorithm::CreateFunc(simplex,pdSolver);
|
|
||||||
|
|
||||||
m_dispatcher->registerCollisionCreateFunc(CONVEX_2D_SHAPE_PROXYTYPE,CONVEX_2D_SHAPE_PROXYTYPE,convexAlgo2d);
|
|
||||||
m_dispatcher->registerCollisionCreateFunc(BOX_2D_SHAPE_PROXYTYPE,CONVEX_2D_SHAPE_PROXYTYPE,convexAlgo2d);
|
|
||||||
m_dispatcher->registerCollisionCreateFunc(CONVEX_2D_SHAPE_PROXYTYPE,BOX_2D_SHAPE_PROXYTYPE,convexAlgo2d);
|
|
||||||
m_dispatcher->registerCollisionCreateFunc(BOX_2D_SHAPE_PROXYTYPE,BOX_2D_SHAPE_PROXYTYPE,new btBox2dBox2dCollisionAlgorithm::CreateFunc());
|
|
||||||
|
|
||||||
m_broadphase = new btDbvtBroadphase();
|
|
||||||
//m_broadphase = new btSimpleBroadphase();
|
|
||||||
|
|
||||||
///the default constraint solver. For parallel processing you can use a different solver (see Extras/BulletMultiThreaded)
|
|
||||||
btSequentialImpulseConstraintSolver* sol = new btSequentialImpulseConstraintSolver;
|
|
||||||
m_solver = sol;
|
|
||||||
|
|
||||||
m_dynamicsWorld = new btDiscreteDynamicsWorld(m_dispatcher,m_broadphase,m_solver,m_collisionConfiguration);
|
|
||||||
//m_dynamicsWorld->getSolverInfo().m_erp = 1.f;
|
|
||||||
//m_dynamicsWorld->getSolverInfo().m_numIterations = 4;
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
m_dynamicsWorld->setGravity(btVector3(0,-10,0));
|
|
||||||
|
|
||||||
///create a few basic rigid bodies
|
|
||||||
btCollisionShape* groundShape = new btBoxShape(btVector3(btScalar(150.),btScalar(50.),btScalar(150.)));
|
|
||||||
// btCollisionShape* groundShape = new btStaticPlaneShape(btVector3(0,1,0),50);
|
|
||||||
|
|
||||||
m_collisionShapes.push_back(groundShape);
|
|
||||||
|
|
||||||
btTransform groundTransform;
|
|
||||||
groundTransform.setIdentity();
|
|
||||||
groundTransform.setOrigin(btVector3(0,-43,0));
|
|
||||||
|
|
||||||
//We can also use DemoApplication::localCreateRigidBody, but for clarity it is provided here:
|
|
||||||
{
|
|
||||||
btScalar mass(0.);
|
|
||||||
|
|
||||||
//rigidbody is dynamic if and only if mass is non zero, otherwise static
|
|
||||||
bool isDynamic = (mass != 0.f);
|
|
||||||
|
|
||||||
btVector3 localInertia(0,0,0);
|
|
||||||
if (isDynamic)
|
|
||||||
groundShape->calculateLocalInertia(mass,localInertia);
|
|
||||||
|
|
||||||
//using motionstate is recommended, it provides interpolation capabilities, and only synchronizes 'active' objects
|
|
||||||
btDefaultMotionState* myMotionState = new btDefaultMotionState(groundTransform);
|
|
||||||
btRigidBody::btRigidBodyConstructionInfo rbInfo(mass,myMotionState,groundShape,localInertia);
|
|
||||||
btRigidBody* body = new btRigidBody(rbInfo);
|
|
||||||
|
|
||||||
//add the body to the dynamics world
|
|
||||||
m_dynamicsWorld->addRigidBody(body);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
{
|
|
||||||
//create a few dynamic rigidbodies
|
|
||||||
// Re-using the same collision is better for memory usage and performance
|
|
||||||
|
|
||||||
btScalar u= btScalar(1*SCALING-0.04);
|
|
||||||
btVector3 points[3] = {btVector3(0,u,0),btVector3(-u,-u,0),btVector3(u,-u,0)};
|
|
||||||
btConvexShape* childShape0 = new btBoxShape(btVector3(btScalar(SCALING*1),btScalar(SCALING*1),btScalar(0.04)));
|
|
||||||
btConvexShape* colShape= new btConvex2dShape(childShape0);
|
|
||||||
//btCollisionShape* colShape = new btBox2dShape(btVector3(SCALING*1,SCALING*1,0.04));
|
|
||||||
btConvexShape* childShape1 = new btConvexHullShape(&points[0].getX(),3);
|
|
||||||
btConvexShape* colShape2= new btConvex2dShape(childShape1);
|
|
||||||
btConvexShape* childShape2 = new btCylinderShapeZ(btVector3(btScalar(SCALING*1),btScalar(SCALING*1),btScalar(0.04)));
|
|
||||||
btConvexShape* colShape3= new btConvex2dShape(childShape2);
|
|
||||||
|
|
||||||
|
|
||||||
m_collisionShapes.push_back(colShape);
|
|
||||||
m_collisionShapes.push_back(colShape2);
|
|
||||||
m_collisionShapes.push_back(colShape3);
|
|
||||||
|
|
||||||
m_collisionShapes.push_back(childShape0);
|
|
||||||
m_collisionShapes.push_back(childShape1);
|
|
||||||
m_collisionShapes.push_back(childShape2);
|
|
||||||
|
|
||||||
|
|
||||||
//btUniformScalingShape* colShape = new btUniformScalingShape(convexColShape,1.f);
|
|
||||||
colShape->setMargin(btScalar(0.03));
|
|
||||||
//btCollisionShape* colShape = new btSphereShape(btScalar(1.));
|
|
||||||
|
|
||||||
/// Create Dynamic Objects
|
|
||||||
btTransform startTransform;
|
|
||||||
startTransform.setIdentity();
|
|
||||||
|
|
||||||
btScalar mass(1.f);
|
|
||||||
|
|
||||||
//rigidbody is dynamic if and only if mass is non zero, otherwise static
|
|
||||||
bool isDynamic = (mass != 0.f);
|
|
||||||
|
|
||||||
btVector3 localInertia(0,0,0);
|
|
||||||
if (isDynamic)
|
|
||||||
colShape->calculateLocalInertia(mass,localInertia);
|
|
||||||
|
|
||||||
// float start_x = START_POS_X - ARRAY_SIZE_X/2;
|
|
||||||
// float start_y = START_POS_Y;
|
|
||||||
// float start_z = START_POS_Z - ARRAY_SIZE_Z/2;
|
|
||||||
|
|
||||||
btVector3 x(-ARRAY_SIZE_X, 8.0f,-20.f);
|
|
||||||
btVector3 y;
|
|
||||||
btVector3 deltaX(SCALING*1, SCALING*2,0.f);
|
|
||||||
btVector3 deltaY(SCALING*2, 0.0f,0.f);
|
|
||||||
|
|
||||||
for (int i = 0; i < ARRAY_SIZE_X; ++i)
|
|
||||||
{
|
|
||||||
y = x;
|
|
||||||
|
|
||||||
for (int j = i; j < ARRAY_SIZE_Y; ++j)
|
|
||||||
{
|
|
||||||
startTransform.setOrigin(y-btVector3(-10,0,0));
|
|
||||||
|
|
||||||
|
|
||||||
//using motionstate is recommended, it provides interpolation capabilities, and only synchronizes 'active' objects
|
|
||||||
btDefaultMotionState* myMotionState = new btDefaultMotionState(startTransform);
|
|
||||||
btRigidBody::btRigidBodyConstructionInfo rbInfo(0,0,0);
|
|
||||||
switch (j%3)
|
|
||||||
{
|
|
||||||
#if 1
|
|
||||||
case 0:
|
|
||||||
rbInfo = btRigidBody::btRigidBodyConstructionInfo(mass,myMotionState,colShape,localInertia);
|
|
||||||
break;
|
|
||||||
case 1:
|
|
||||||
rbInfo = btRigidBody::btRigidBodyConstructionInfo(mass,myMotionState,colShape3,localInertia);
|
|
||||||
break;
|
|
||||||
#endif
|
|
||||||
default:
|
|
||||||
rbInfo = btRigidBody::btRigidBodyConstructionInfo(mass,myMotionState,colShape2,localInertia);
|
|
||||||
}
|
|
||||||
btRigidBody* body = new btRigidBody(rbInfo);
|
|
||||||
//body->setContactProcessingThreshold(colShape->getContactBreakingThreshold());
|
|
||||||
body->setActivationState(ISLAND_SLEEPING);
|
|
||||||
body->setLinearFactor(btVector3(1,1,0));
|
|
||||||
body->setAngularFactor(btVector3(0,0,1));
|
|
||||||
|
|
||||||
m_dynamicsWorld->addRigidBody(body);
|
|
||||||
body->setActivationState(ISLAND_SLEEPING);
|
|
||||||
|
|
||||||
|
|
||||||
// y += -0.8*deltaY;
|
|
||||||
y += deltaY;
|
|
||||||
}
|
|
||||||
|
|
||||||
x += deltaX;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
clientResetScene();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void Box2dDemo::exitPhysics()
|
|
||||||
{
|
|
||||||
delete m_dialogDynamicsWorld;
|
|
||||||
m_dialogDynamicsWorld = 0;
|
|
||||||
|
|
||||||
//cleanup in the reverse order of creation/initialization
|
|
||||||
|
|
||||||
//remove the rigidbodies from the dynamics world and delete them
|
|
||||||
int i;
|
|
||||||
if (m_dynamicsWorld)
|
|
||||||
for (i=m_dynamicsWorld->getNumCollisionObjects()-1; i>=0 ;i--)
|
|
||||||
{
|
|
||||||
btCollisionObject* obj = m_dynamicsWorld->getCollisionObjectArray()[i];
|
|
||||||
btRigidBody* body = btRigidBody::upcast(obj);
|
|
||||||
if (body && body->getMotionState())
|
|
||||||
{
|
|
||||||
delete body->getMotionState();
|
|
||||||
}
|
|
||||||
m_dynamicsWorld->removeCollisionObject( obj );
|
|
||||||
delete obj;
|
|
||||||
}
|
|
||||||
|
|
||||||
//delete collision shapes
|
|
||||||
for (int j=0;j<m_collisionShapes.size();j++)
|
|
||||||
{
|
|
||||||
btCollisionShape* shape = m_collisionShapes[j];
|
|
||||||
delete shape;
|
|
||||||
}
|
|
||||||
m_collisionShapes.clear();
|
|
||||||
|
|
||||||
delete m_dynamicsWorld;
|
|
||||||
|
|
||||||
delete m_solver;
|
|
||||||
|
|
||||||
delete m_broadphase;
|
|
||||||
|
|
||||||
delete m_dispatcher;
|
|
||||||
|
|
||||||
delete m_collisionConfiguration;
|
|
||||||
|
|
||||||
m_dynamicsWorld = 0;
|
|
||||||
m_solver = 0;
|
|
||||||
m_broadphase = 0;
|
|
||||||
m_dispatcher = 0;
|
|
||||||
m_collisionConfiguration = 0;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
void Box2dDemo::mouseFunc(int button, int state, int x, int y)
|
|
||||||
{
|
|
||||||
|
|
||||||
if (!m_dialogDynamicsWorld->mouseFunc(button,state,x,y))
|
|
||||||
{
|
|
||||||
DemoApplication::mouseFunc(button,state,x,y);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void Box2dDemo::mouseMotionFunc(int x,int y)
|
|
||||||
{
|
|
||||||
m_dialogDynamicsWorld->mouseMotionFunc(x,y);
|
|
||||||
DemoApplication::mouseMotionFunc(x,y);
|
|
||||||
}
|
|
||||||
|
|
89
extern/bullet/Demos/Box2dDemo/Box2dDemo.h
vendored
89
extern/bullet/Demos/Box2dDemo/Box2dDemo.h
vendored
@ -1,89 +0,0 @@
|
|||||||
/*
|
|
||||||
Bullet Continuous Collision Detection and Physics Library
|
|
||||||
Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied warranty.
|
|
||||||
In no event will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it freely,
|
|
||||||
subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
|
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
#ifndef BOX2D_DEMO_H
|
|
||||||
#define BOX2D_DEMO_H
|
|
||||||
|
|
||||||
#ifdef _WINDOWS
|
|
||||||
#include "Win32DemoApplication.h"
|
|
||||||
#define PlatformDemoApplication Win32DemoApplication
|
|
||||||
#else
|
|
||||||
#include "GlutDemoApplication.h"
|
|
||||||
#define PlatformDemoApplication GlutDemoApplication
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include "LinearMath/btAlignedObjectArray.h"
|
|
||||||
|
|
||||||
class btBroadphaseInterface;
|
|
||||||
class btCollisionShape;
|
|
||||||
class btOverlappingPairCache;
|
|
||||||
class btCollisionDispatcher;
|
|
||||||
class btConstraintSolver;
|
|
||||||
struct btCollisionAlgorithmCreateFunc;
|
|
||||||
class btDefaultCollisionConfiguration;
|
|
||||||
class GL_DialogDynamicsWorld;
|
|
||||||
|
|
||||||
///Box2dDemo is good starting point for learning the code base and porting.
|
|
||||||
class Box2dDemo : public PlatformDemoApplication
|
|
||||||
{
|
|
||||||
|
|
||||||
//keep the collision shapes, for deletion/cleanup
|
|
||||||
btAlignedObjectArray<btCollisionShape*> m_collisionShapes;
|
|
||||||
|
|
||||||
btBroadphaseInterface* m_broadphase;
|
|
||||||
|
|
||||||
btCollisionDispatcher* m_dispatcher;
|
|
||||||
|
|
||||||
btConstraintSolver* m_solver;
|
|
||||||
|
|
||||||
btDefaultCollisionConfiguration* m_collisionConfiguration;
|
|
||||||
|
|
||||||
GL_DialogDynamicsWorld* m_dialogDynamicsWorld;
|
|
||||||
|
|
||||||
public:
|
|
||||||
|
|
||||||
Box2dDemo() : m_dialogDynamicsWorld(0)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
virtual ~Box2dDemo()
|
|
||||||
{
|
|
||||||
exitPhysics();
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual void reshape(int w, int h);
|
|
||||||
|
|
||||||
void initPhysics();
|
|
||||||
|
|
||||||
void exitPhysics();
|
|
||||||
|
|
||||||
virtual void clientMoveAndDisplay();
|
|
||||||
|
|
||||||
virtual void displayCallback();
|
|
||||||
|
|
||||||
static DemoApplication* Create()
|
|
||||||
{
|
|
||||||
Box2dDemo* demo = new Box2dDemo;
|
|
||||||
demo->myinit();
|
|
||||||
demo->initPhysics();
|
|
||||||
return demo;
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual void mouseFunc(int button, int state, int x, int y);
|
|
||||||
virtual void mouseMotionFunc(int x,int y);
|
|
||||||
|
|
||||||
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif //BOX2D_DEMO_H
|
|
||||||
|
|
75
extern/bullet/Demos/Box2dDemo/CMakeLists.txt
vendored
75
extern/bullet/Demos/Box2dDemo/CMakeLists.txt
vendored
@ -1,75 +0,0 @@
|
|||||||
# This is basically the overall name of the project in Visual Studio this is the name of the Solution File
|
|
||||||
|
|
||||||
|
|
||||||
# For every executable you have with a main method you should have an add_executable line below.
|
|
||||||
# For every add executable line you should list every .cpp and .h file you have associated with that executable.
|
|
||||||
|
|
||||||
|
|
||||||
# This is the variable for Windows. I use this to define the root of my directory structure.
|
|
||||||
SET(GLUT_ROOT ${BULLET_PHYSICS_SOURCE_DIR}/Glut)
|
|
||||||
|
|
||||||
# You shouldn't have to modify anything below this line
|
|
||||||
########################################################
|
|
||||||
|
|
||||||
INCLUDE_DIRECTORIES(
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/src ${BULLET_PHYSICS_SOURCE_DIR}/Demos/OpenGL
|
|
||||||
)
|
|
||||||
|
|
||||||
IF (USE_GLUT)
|
|
||||||
LINK_LIBRARIES(
|
|
||||||
OpenGLSupport BulletDynamics BulletCollision LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY}
|
|
||||||
)
|
|
||||||
|
|
||||||
IF (WIN32)
|
|
||||||
ADD_EXECUTABLE(AppBox2dDemo
|
|
||||||
main.cpp
|
|
||||||
Box2dDemo.cpp
|
|
||||||
Box2dDemo.h
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/build/bullet.rc
|
|
||||||
)
|
|
||||||
ELSE()
|
|
||||||
ADD_EXECUTABLE(AppBox2dDemo
|
|
||||||
main.cpp
|
|
||||||
Box2dDemo.cpp
|
|
||||||
Box2dDemo.h
|
|
||||||
)
|
|
||||||
ENDIF()
|
|
||||||
IF (WIN32)
|
|
||||||
IF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES)
|
|
||||||
IF (CMAKE_CL_64)
|
|
||||||
ADD_CUSTOM_COMMAND(
|
|
||||||
TARGET AppBox2dDemo
|
|
||||||
POST_BUILD
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/glut64.dll ${CMAKE_CURRENT_BINARY_DIR}
|
|
||||||
)
|
|
||||||
ELSE(CMAKE_CL_64)
|
|
||||||
ADD_CUSTOM_COMMAND(
|
|
||||||
TARGET AppBox2dDemo
|
|
||||||
POST_BUILD
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/GLUT32.DLL ${CMAKE_CURRENT_BINARY_DIR}
|
|
||||||
)
|
|
||||||
ENDIF(CMAKE_CL_64)
|
|
||||||
ENDIF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES)
|
|
||||||
|
|
||||||
ENDIF(WIN32)
|
|
||||||
ELSE (USE_GLUT)
|
|
||||||
LINK_LIBRARIES(
|
|
||||||
OpenGLSupport BulletDynamics BulletCollision LinearMath ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY}
|
|
||||||
)
|
|
||||||
|
|
||||||
ADD_EXECUTABLE(AppBox2dDemo
|
|
||||||
WIN32
|
|
||||||
../OpenGL/Win32AppMain.cpp
|
|
||||||
Win32Box2dDemo.cpp
|
|
||||||
Box2dDemo.cpp
|
|
||||||
Box2dDemo.h
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/build/bullet.rc
|
|
||||||
)
|
|
||||||
ENDIF (USE_GLUT)
|
|
||||||
|
|
||||||
IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES)
|
|
||||||
SET_TARGET_PROPERTIES(AppBox2dDemo PROPERTIES DEBUG_POSTFIX "_Debug")
|
|
||||||
SET_TARGET_PROPERTIES(AppBox2dDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel")
|
|
||||||
SET_TARGET_PROPERTIES(AppBox2dDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo")
|
|
||||||
ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES)
|
|
||||||
|
|
25
extern/bullet/Demos/Box2dDemo/Win32Box2dDemo.cpp
vendored
25
extern/bullet/Demos/Box2dDemo/Win32Box2dDemo.cpp
vendored
@ -1,25 +0,0 @@
|
|||||||
#ifdef _WINDOWS
|
|
||||||
/*
|
|
||||||
Bullet Continuous Collision Detection and Physics Library
|
|
||||||
Copyright (c) 2003-2009 Erwin Coumans http://bulletphysics.org
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied warranty.
|
|
||||||
In no event will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it freely,
|
|
||||||
subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
|
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "Box2dDemo.h"
|
|
||||||
|
|
||||||
///The 'createDemo' function is called from Bullet/Demos/OpenGL/Win32AppMain.cpp to instantiate this particular demo
|
|
||||||
DemoApplication* createDemo()
|
|
||||||
{
|
|
||||||
return new Box2dDemo();
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
|
61
extern/bullet/Demos/Box2dDemo/main.cpp
vendored
61
extern/bullet/Demos/Box2dDemo/main.cpp
vendored
@ -1,61 +0,0 @@
|
|||||||
/*
|
|
||||||
Bullet Continuous Collision Detection and Physics Library
|
|
||||||
Copyright (c) 2003-2007 Erwin Coumans http://continuousphysics.com/Bullet/
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied warranty.
|
|
||||||
In no event will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it freely,
|
|
||||||
subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
|
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "Box2dDemo.h"
|
|
||||||
#include "GlutStuff.h"
|
|
||||||
#include "GLDebugDrawer.h"
|
|
||||||
#include "btBulletDynamicsCommon.h"
|
|
||||||
#include "LinearMath/btHashMap.h"
|
|
||||||
|
|
||||||
class OurValue
|
|
||||||
{
|
|
||||||
int m_uid;
|
|
||||||
|
|
||||||
public:
|
|
||||||
OurValue(const btVector3& initialPos)
|
|
||||||
:m_position(initialPos)
|
|
||||||
{
|
|
||||||
static int gUid=0;
|
|
||||||
m_uid=gUid;
|
|
||||||
gUid++;
|
|
||||||
}
|
|
||||||
|
|
||||||
btVector3 m_position;
|
|
||||||
int getUid() const
|
|
||||||
{
|
|
||||||
return m_uid;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
int main(int argc,char** argv)
|
|
||||||
{
|
|
||||||
GLDebugDrawer gDebugDrawer;
|
|
||||||
|
|
||||||
Box2dDemo ccdDemo;
|
|
||||||
ccdDemo.initPhysics();
|
|
||||||
ccdDemo.getDynamicsWorld()->setDebugDrawer(&gDebugDrawer);
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef CHECK_MEMORY_LEAKS
|
|
||||||
ccdDemo.exitPhysics();
|
|
||||||
#else
|
|
||||||
return glutmain(argc, argv,640,480,"Bullet Physics Demo. http://bulletphysics.com",&ccdDemo);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
//default glut doesn't return from mainloop
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
207
extern/bullet/Demos/BspDemo/BspConverter.cpp
vendored
207
extern/bullet/Demos/BspDemo/BspConverter.cpp
vendored
@ -1,207 +0,0 @@
|
|||||||
/*
|
|
||||||
Bullet Continuous Collision Detection and Physics Library
|
|
||||||
Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied warranty.
|
|
||||||
In no event will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it freely,
|
|
||||||
subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
|
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "BspConverter.h"
|
|
||||||
#include "BspLoader.h"
|
|
||||||
#include "LinearMath/btVector3.h"
|
|
||||||
#include "LinearMath/btGeometryUtil.h"
|
|
||||||
#include <stdio.h>
|
|
||||||
#include <string.h>
|
|
||||||
|
|
||||||
|
|
||||||
void BspConverter::convertBsp(BspLoader& bspLoader,float scaling)
|
|
||||||
{
|
|
||||||
{
|
|
||||||
|
|
||||||
float playstartf[3] = {0,0,100};
|
|
||||||
|
|
||||||
if (bspLoader.findVectorByName(&playstartf[0],"info_player_start"))
|
|
||||||
{
|
|
||||||
printf("found playerstart\n");
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
if (bspLoader.findVectorByName(&playstartf[0],"info_player_deathmatch"))
|
|
||||||
{
|
|
||||||
printf("found deatchmatch start\n");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
btVector3 playerStart (playstartf[0],playstartf[1],playstartf[2]);
|
|
||||||
|
|
||||||
|
|
||||||
playerStart[2] += 20.f; //start a bit higher
|
|
||||||
|
|
||||||
playerStart *= scaling;
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//progressBegin("Loading bsp");
|
|
||||||
|
|
||||||
for (int i=0;i<bspLoader.m_numleafs;i++)
|
|
||||||
{
|
|
||||||
printf("Reading bspLeaf %i from total %i (%f procent)\n",i, bspLoader.m_numleafs,(100.f*(float)i/float(bspLoader.m_numleafs)) );
|
|
||||||
|
|
||||||
bool isValidBrush = false;
|
|
||||||
|
|
||||||
BSPLeaf& leaf = bspLoader.m_dleafs[i];
|
|
||||||
|
|
||||||
for (int b=0;b<leaf.numLeafBrushes;b++)
|
|
||||||
{
|
|
||||||
btAlignedObjectArray<btVector3> planeEquations;
|
|
||||||
|
|
||||||
int brushid = bspLoader.m_dleafbrushes[leaf.firstLeafBrush+b];
|
|
||||||
|
|
||||||
BSPBrush& brush = bspLoader.m_dbrushes[brushid];
|
|
||||||
if (brush.shaderNum!=-1)
|
|
||||||
{
|
|
||||||
if (bspLoader.m_dshaders[ brush.shaderNum ].contentFlags & BSPCONTENTS_SOLID)
|
|
||||||
{
|
|
||||||
brush.shaderNum = -1;
|
|
||||||
|
|
||||||
for (int p=0;p<brush.numSides;p++)
|
|
||||||
{
|
|
||||||
int sideid = brush.firstSide+p;
|
|
||||||
BSPBrushSide& brushside = bspLoader.m_dbrushsides[sideid];
|
|
||||||
int planeid = brushside.planeNum;
|
|
||||||
BSPPlane& plane = bspLoader.m_dplanes[planeid];
|
|
||||||
btVector3 planeEq;
|
|
||||||
planeEq.setValue(
|
|
||||||
plane.normal[0],
|
|
||||||
plane.normal[1],
|
|
||||||
plane.normal[2]);
|
|
||||||
planeEq[3] = scaling*-plane.dist;
|
|
||||||
|
|
||||||
planeEquations.push_back(planeEq);
|
|
||||||
isValidBrush=true;
|
|
||||||
}
|
|
||||||
if (isValidBrush)
|
|
||||||
{
|
|
||||||
|
|
||||||
btAlignedObjectArray<btVector3> vertices;
|
|
||||||
btGeometryUtil::getVerticesFromPlaneEquations(planeEquations,vertices);
|
|
||||||
|
|
||||||
bool isEntity = false;
|
|
||||||
btVector3 entityTarget(0.f,0.f,0.f);
|
|
||||||
addConvexVerticesCollider(vertices,isEntity,entityTarget);
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#define USE_ENTITIES
|
|
||||||
#ifdef USE_ENTITIES
|
|
||||||
|
|
||||||
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
for (i=0;i<bspLoader.m_num_entities;i++)
|
|
||||||
{
|
|
||||||
const BSPEntity& entity = bspLoader.m_entities[i];
|
|
||||||
const char* cl = bspLoader.getValueForKey(&entity,"classname");
|
|
||||||
if ( !strcmp( cl, "trigger_push" ) ) {
|
|
||||||
btVector3 targetLocation(0.f,0.f,0.f);
|
|
||||||
|
|
||||||
cl = bspLoader.getValueForKey(&entity,"target");
|
|
||||||
if ( strcmp( cl, "" ) ) {
|
|
||||||
//its not empty so ...
|
|
||||||
|
|
||||||
/*
|
|
||||||
//lookup the target position for the jumppad:
|
|
||||||
const BSPEntity* targetentity = bspLoader.getEntityByValue( "targetname" , cl );
|
|
||||||
if (targetentity)
|
|
||||||
{
|
|
||||||
if (bspLoader.getVectorForKey( targetentity , "origin",&targetLocation[0]))
|
|
||||||
{
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
cl = bspLoader.getValueForKey(&entity,"model");
|
|
||||||
if ( strcmp( cl, "" ) ) {
|
|
||||||
// add the model as a brush
|
|
||||||
if (cl[0] == '*')
|
|
||||||
{
|
|
||||||
int modelnr = atoi(&cl[1]);
|
|
||||||
if ((modelnr >=0) && (modelnr < bspLoader.m_nummodels))
|
|
||||||
{
|
|
||||||
const BSPModel& model = bspLoader.m_dmodels[modelnr];
|
|
||||||
for (int n=0;n<model.numBrushes;n++)
|
|
||||||
{
|
|
||||||
btAlignedObjectArray<btVector3> planeEquations;
|
|
||||||
bool isValidBrush = false;
|
|
||||||
|
|
||||||
//convert brush
|
|
||||||
const BSPBrush& brush = bspLoader.m_dbrushes[model.firstBrush+n];
|
|
||||||
{
|
|
||||||
for (int p=0;p<brush.numSides;p++)
|
|
||||||
{
|
|
||||||
int sideid = brush.firstSide+p;
|
|
||||||
BSPBrushSide& brushside = bspLoader.m_dbrushsides[sideid];
|
|
||||||
int planeid = brushside.planeNum;
|
|
||||||
BSPPlane& plane = bspLoader.m_dplanes[planeid];
|
|
||||||
btVector3 planeEq;
|
|
||||||
planeEq.setValue(
|
|
||||||
plane.normal[0],
|
|
||||||
plane.normal[1],
|
|
||||||
plane.normal[2]);
|
|
||||||
planeEq[3] = scaling*-plane.dist;
|
|
||||||
planeEquations.push_back(planeEq);
|
|
||||||
isValidBrush=true;
|
|
||||||
}
|
|
||||||
if (isValidBrush)
|
|
||||||
{
|
|
||||||
|
|
||||||
btAlignedObjectArray<btVector3> vertices;
|
|
||||||
btGeometryUtil::getVerticesFromPlaneEquations(planeEquations,vertices);
|
|
||||||
|
|
||||||
bool isEntity=true;
|
|
||||||
addConvexVerticesCollider(vertices,isEntity,targetLocation);
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
printf("unsupported trigger_push model, md3 ?\n");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif //USE_ENTITIES
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//progressEnd();
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
39
extern/bullet/Demos/BspDemo/BspConverter.h
vendored
39
extern/bullet/Demos/BspDemo/BspConverter.h
vendored
@ -1,39 +0,0 @@
|
|||||||
/*
|
|
||||||
Bullet Continuous Collision Detection and Physics Library
|
|
||||||
Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied warranty.
|
|
||||||
In no event will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it freely,
|
|
||||||
subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
|
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifndef BSP_CONVERTER_H
|
|
||||||
#define BSP_CONVERTER_H
|
|
||||||
|
|
||||||
class BspLoader;
|
|
||||||
#include "LinearMath/btVector3.h"
|
|
||||||
#include "LinearMath/btAlignedObjectArray.h"
|
|
||||||
|
|
||||||
///BspConverter turns a loaded bsp level into convex parts (vertices)
|
|
||||||
class BspConverter
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
|
|
||||||
void convertBsp(BspLoader& bspLoader,float scaling);
|
|
||||||
virtual ~BspConverter()
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
///this callback is called for each brush that succesfully converted into vertices
|
|
||||||
virtual void addConvexVerticesCollider(btAlignedObjectArray<btVector3>& vertices, bool isEntity, const btVector3& entityTargetLocation) = 0;
|
|
||||||
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif //BSP_CONVERTER_H
|
|
||||||
|
|
321
extern/bullet/Demos/BspDemo/BspDemo.cpp
vendored
321
extern/bullet/Demos/BspDemo/BspDemo.cpp
vendored
@ -1,321 +0,0 @@
|
|||||||
/*
|
|
||||||
Bullet Continuous Collision Detection and Physics Library
|
|
||||||
Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied warranty.
|
|
||||||
In no event will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it freely,
|
|
||||||
subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
|
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "btBulletDynamicsCommon.h"
|
|
||||||
|
|
||||||
#include "LinearMath/btQuickprof.h"
|
|
||||||
#include "LinearMath/btIDebugDraw.h"
|
|
||||||
|
|
||||||
#include "GLDebugDrawer.h"
|
|
||||||
|
|
||||||
|
|
||||||
#define QUAKE_BSP_IMPORTING 1
|
|
||||||
|
|
||||||
#ifdef QUAKE_BSP_IMPORTING
|
|
||||||
#include "BspLoader.h"
|
|
||||||
#include "BspConverter.h"
|
|
||||||
#endif //QUAKE_BSP_IMPORTING
|
|
||||||
|
|
||||||
|
|
||||||
#include <stdio.h> //printf debugging
|
|
||||||
|
|
||||||
|
|
||||||
#include "BspDemo.h"
|
|
||||||
#include "GL_ShapeDrawer.h"
|
|
||||||
#include "GlutStuff.h"
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#define CUBE_HALF_EXTENTS 1
|
|
||||||
#define EXTRA_HEIGHT -20.f
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
///BspToBulletConverter extends the BspConverter to convert to Bullet datastructures
|
|
||||||
class BspToBulletConverter : public BspConverter
|
|
||||||
{
|
|
||||||
BspDemo* m_demoApp;
|
|
||||||
|
|
||||||
public:
|
|
||||||
|
|
||||||
BspToBulletConverter(BspDemo* demoApp)
|
|
||||||
:m_demoApp(demoApp)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual void addConvexVerticesCollider(btAlignedObjectArray<btVector3>& vertices, bool isEntity, const btVector3& entityTargetLocation)
|
|
||||||
{
|
|
||||||
///perhaps we can do something special with entities (isEntity)
|
|
||||||
///like adding a collision Triggering (as example)
|
|
||||||
|
|
||||||
if (vertices.size() > 0)
|
|
||||||
{
|
|
||||||
float mass = 0.f;
|
|
||||||
btTransform startTransform;
|
|
||||||
//can use a shift
|
|
||||||
startTransform.setIdentity();
|
|
||||||
startTransform.setOrigin(btVector3(0,0,-10.f));
|
|
||||||
//this create an internal copy of the vertices
|
|
||||||
|
|
||||||
btCollisionShape* shape = new btConvexHullShape(&(vertices[0].getX()),vertices.size());
|
|
||||||
m_demoApp->m_collisionShapes.push_back(shape);
|
|
||||||
|
|
||||||
//btRigidBody* body = m_demoApp->localCreateRigidBody(mass, startTransform,shape);
|
|
||||||
m_demoApp->localCreateRigidBody(mass, startTransform,shape);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
////////////////////////////////////
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
BspDemo::~BspDemo()
|
|
||||||
{
|
|
||||||
//cleanup in the reverse order of creation/initialization
|
|
||||||
|
|
||||||
//remove the rigidbodies from the dynamics world and delete them
|
|
||||||
int i;
|
|
||||||
for (i=m_dynamicsWorld->getNumCollisionObjects()-1; i>=0 ;i--)
|
|
||||||
{
|
|
||||||
btCollisionObject* obj = m_dynamicsWorld->getCollisionObjectArray()[i];
|
|
||||||
btRigidBody* body = btRigidBody::upcast(obj);
|
|
||||||
if (body && body->getMotionState())
|
|
||||||
{
|
|
||||||
delete body->getMotionState();
|
|
||||||
}
|
|
||||||
m_dynamicsWorld->removeCollisionObject( obj );
|
|
||||||
delete obj;
|
|
||||||
}
|
|
||||||
|
|
||||||
//delete collision shapes
|
|
||||||
for (int j=0;j<m_collisionShapes.size();j++)
|
|
||||||
{
|
|
||||||
btCollisionShape* shape = m_collisionShapes[j];
|
|
||||||
delete shape;
|
|
||||||
}
|
|
||||||
|
|
||||||
//delete dynamics world
|
|
||||||
delete m_dynamicsWorld;
|
|
||||||
|
|
||||||
//delete solver
|
|
||||||
delete m_solver;
|
|
||||||
|
|
||||||
//delete broadphase
|
|
||||||
delete m_broadphase;
|
|
||||||
|
|
||||||
//delete dispatcher
|
|
||||||
delete m_dispatcher;
|
|
||||||
|
|
||||||
delete m_collisionConfiguration;
|
|
||||||
}
|
|
||||||
|
|
||||||
void BspDemo::initPhysics()
|
|
||||||
{
|
|
||||||
const char* bspfilename = "BspDemo.bsp";
|
|
||||||
|
|
||||||
initPhysics(bspfilename);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void BspDemo::initPhysics(const char* bspfilename)
|
|
||||||
{
|
|
||||||
setTexturing(true);
|
|
||||||
setShadows(false);
|
|
||||||
|
|
||||||
m_cameraUp = btVector3(0,0,1);
|
|
||||||
m_forwardAxis = 1;
|
|
||||||
|
|
||||||
setCameraDistance(22.f);
|
|
||||||
|
|
||||||
///Setup a Physics Simulation Environment
|
|
||||||
|
|
||||||
m_collisionConfiguration = new btDefaultCollisionConfiguration();
|
|
||||||
// btCollisionShape* groundShape = new btBoxShape(btVector3(50,3,50));
|
|
||||||
m_dispatcher = new btCollisionDispatcher(m_collisionConfiguration);
|
|
||||||
btVector3 worldMin(-1000,-1000,-1000);
|
|
||||||
btVector3 worldMax(1000,1000,1000);
|
|
||||||
m_broadphase = new btDbvtBroadphase();
|
|
||||||
//m_broadphase = new btAxisSweep3(worldMin,worldMax);
|
|
||||||
//btOverlappingPairCache* broadphase = new btSimpleBroadphase();
|
|
||||||
m_solver = new btSequentialImpulseConstraintSolver();
|
|
||||||
//ConstraintSolver* solver = new OdeConstraintSolver;
|
|
||||||
m_dynamicsWorld = new btDiscreteDynamicsWorld(m_dispatcher,m_broadphase,m_solver,m_collisionConfiguration);
|
|
||||||
|
|
||||||
m_dynamicsWorld->setGravity(-m_cameraUp * 10);
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef QUAKE_BSP_IMPORTING
|
|
||||||
|
|
||||||
void* memoryBuffer = 0;
|
|
||||||
|
|
||||||
FILE* file = fopen(bspfilename,"r");
|
|
||||||
if (!file)
|
|
||||||
{
|
|
||||||
//try again other path,
|
|
||||||
//sight... visual studio leaves the current working directory in the projectfiles folder
|
|
||||||
//instead of executable folder. who wants this default behaviour?!?
|
|
||||||
bspfilename = "../../BspDemo.bsp";
|
|
||||||
file = fopen(bspfilename,"r");
|
|
||||||
}
|
|
||||||
if (!file)
|
|
||||||
{
|
|
||||||
|
|
||||||
//try again other path, cmake needs 4 levels deep back...
|
|
||||||
bspfilename = "../../../../BspDemo.bsp";
|
|
||||||
file = fopen(bspfilename,"r");
|
|
||||||
}
|
|
||||||
if (!file)
|
|
||||||
{
|
|
||||||
//try again other path,
|
|
||||||
//sight... visual studio leaves the current working directory in the projectfiles folder
|
|
||||||
//instead of executable folder. who wants this default behaviour?!?
|
|
||||||
bspfilename = "BspDemo.bsp";
|
|
||||||
file = fopen(bspfilename,"r");
|
|
||||||
}
|
|
||||||
|
|
||||||
if (file)
|
|
||||||
{
|
|
||||||
BspLoader bspLoader;
|
|
||||||
int size=0;
|
|
||||||
if (fseek(file, 0, SEEK_END) || (size = ftell(file)) == EOF || fseek(file, 0, SEEK_SET)) { /* File operations denied? ok, just close and return failure */
|
|
||||||
printf("Error: cannot get filesize from %s\n", bspfilename);
|
|
||||||
} else
|
|
||||||
{
|
|
||||||
//how to detect file size?
|
|
||||||
memoryBuffer = malloc(size+1);
|
|
||||||
fread(memoryBuffer,1,size,file);
|
|
||||||
bspLoader.loadBSPFile( memoryBuffer);
|
|
||||||
|
|
||||||
BspToBulletConverter bsp2bullet(this);
|
|
||||||
float bspScaling = 0.1f;
|
|
||||||
bsp2bullet.convertBsp(bspLoader,bspScaling);
|
|
||||||
|
|
||||||
}
|
|
||||||
fclose(file);
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
clientResetScene();
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void BspDemo::clientMoveAndDisplay()
|
|
||||||
{
|
|
||||||
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
|
||||||
float dt = getDeltaTimeMicroseconds() * 0.000001f;
|
|
||||||
|
|
||||||
m_dynamicsWorld->stepSimulation(dt);
|
|
||||||
|
|
||||||
//optional but useful: debug drawing
|
|
||||||
m_dynamicsWorld->debugDrawWorld();
|
|
||||||
|
|
||||||
renderme();
|
|
||||||
|
|
||||||
glFlush();
|
|
||||||
glutSwapBuffers();
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void BspDemo::displayCallback(void) {
|
|
||||||
|
|
||||||
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
|
||||||
|
|
||||||
|
|
||||||
renderme();
|
|
||||||
|
|
||||||
//optional but useful: debug drawing
|
|
||||||
if (m_dynamicsWorld)
|
|
||||||
m_dynamicsWorld->debugDrawWorld();
|
|
||||||
|
|
||||||
glFlush();
|
|
||||||
glutSwapBuffers();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//some code that de-mangles the windows filename passed in as argument
|
|
||||||
char cleaned_filename[512];
|
|
||||||
char* getLastFileName()
|
|
||||||
{
|
|
||||||
return cleaned_filename;
|
|
||||||
}
|
|
||||||
char* makeExeToBspFilename(const char* lpCmdLine)
|
|
||||||
{
|
|
||||||
|
|
||||||
|
|
||||||
// We might get a windows-style path on the command line, this can mess up the DOM which expects
|
|
||||||
// all paths to be URI's. This block of code does some conversion to try and make the input
|
|
||||||
// compliant without breaking the ability to accept a properly formatted URI. Right now this only
|
|
||||||
// displays the first filename
|
|
||||||
const char *in = lpCmdLine;
|
|
||||||
char* out = cleaned_filename;
|
|
||||||
*out = '\0';
|
|
||||||
// If the first character is a ", skip it (filenames with spaces in them are quoted)
|
|
||||||
if(*in == '\"')
|
|
||||||
{
|
|
||||||
in++;
|
|
||||||
}
|
|
||||||
int i;
|
|
||||||
for(i =0; i<512; i++)
|
|
||||||
{
|
|
||||||
//if we get '.' we stop as well, unless it's the first character. Then we add .bsp as extension
|
|
||||||
// If we hit a null or a quote, stop copying. This will get just the first filename.
|
|
||||||
if(i && (in[0] == '.') && (in[1] == 'e') && (in[2] == 'x') && (in[3] == 'e'))
|
|
||||||
break;
|
|
||||||
|
|
||||||
// If we hit a null or a quote, stop copying. This will get just the first filename.
|
|
||||||
if(*in == '\0' || *in == '\"')
|
|
||||||
break;
|
|
||||||
// Copy while swapping backslashes for forward ones
|
|
||||||
if(*in == '\\')
|
|
||||||
{
|
|
||||||
*out = '/';
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
*out = *in;
|
|
||||||
}
|
|
||||||
in++;
|
|
||||||
out++;
|
|
||||||
}
|
|
||||||
*(out++) = '.';
|
|
||||||
*(out++) = 'b';
|
|
||||||
*(out++) = 's';
|
|
||||||
*(out++) = 'p';
|
|
||||||
*(out++) = 0;
|
|
||||||
|
|
||||||
return cleaned_filename;
|
|
||||||
}
|
|
71
extern/bullet/Demos/BspDemo/BspDemo.h
vendored
71
extern/bullet/Demos/BspDemo/BspDemo.h
vendored
@ -1,71 +0,0 @@
|
|||||||
/*
|
|
||||||
Bullet Continuous Collision Detection and Physics Library
|
|
||||||
Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied warranty.
|
|
||||||
In no event will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it freely,
|
|
||||||
subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
|
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
#ifndef BSP_DEMO_H
|
|
||||||
#define BSP_DEMO_H
|
|
||||||
|
|
||||||
#include "GlutDemoApplication.h"
|
|
||||||
#include "LinearMath/btAlignedObjectArray.h"
|
|
||||||
|
|
||||||
class btBroadphaseInterface;
|
|
||||||
class btCollisionShape;
|
|
||||||
class btOverlappingPairCache;
|
|
||||||
class btCollisionDispatcher;
|
|
||||||
class btConstraintSolver;
|
|
||||||
struct btCollisionAlgorithmCreateFunc;
|
|
||||||
class btDefaultCollisionConfiguration;
|
|
||||||
|
|
||||||
|
|
||||||
///BspDemo shows the convex collision detection, by converting a Quake BSP file into convex objects and allowing interaction with boxes.
|
|
||||||
class BspDemo : public GlutDemoApplication
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
|
|
||||||
//keep the collision shapes, for deletion/cleanup
|
|
||||||
btAlignedObjectArray<btCollisionShape*> m_collisionShapes;
|
|
||||||
|
|
||||||
btBroadphaseInterface* m_broadphase;
|
|
||||||
|
|
||||||
btCollisionDispatcher* m_dispatcher;
|
|
||||||
|
|
||||||
btConstraintSolver* m_solver;
|
|
||||||
|
|
||||||
btDefaultCollisionConfiguration* m_collisionConfiguration;
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
virtual ~BspDemo();
|
|
||||||
|
|
||||||
virtual void initPhysics();
|
|
||||||
|
|
||||||
void initPhysics(const char* bspfilename);
|
|
||||||
|
|
||||||
virtual void clientMoveAndDisplay();
|
|
||||||
|
|
||||||
virtual void displayCallback();
|
|
||||||
|
|
||||||
static DemoApplication* Create()
|
|
||||||
{
|
|
||||||
BspDemo* demo = new BspDemo;
|
|
||||||
demo->myinit();
|
|
||||||
demo->initPhysics("BspDemo.bsp");
|
|
||||||
return demo;
|
|
||||||
}
|
|
||||||
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif //BSP_DEMO_H
|
|
||||||
|
|
||||||
|
|
730
extern/bullet/Demos/BspDemo/BspLoader.cpp
vendored
730
extern/bullet/Demos/BspDemo/BspLoader.cpp
vendored
@ -1,730 +0,0 @@
|
|||||||
/*
|
|
||||||
===========================================================================
|
|
||||||
Copyright (C) 1999-2005 Id Software, Inc.
|
|
||||||
|
|
||||||
This file is part of Quake III Arena source code.
|
|
||||||
|
|
||||||
Quake III Arena source code is free software; you can redistribute it
|
|
||||||
and/or modify it under the terms of the GNU bteral Public License as
|
|
||||||
published by the Free Software Foundation; either version 2 of the License,
|
|
||||||
or (at your option) any later version.
|
|
||||||
|
|
||||||
Quake III Arena source code 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 bteral Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU bteral Public License
|
|
||||||
along with Foobar; if not, write to the Free Software
|
|
||||||
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
===========================================================================
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
#include "BspLoader.h"
|
|
||||||
#include <stdio.h>
|
|
||||||
#include <string.h>
|
|
||||||
|
|
||||||
typedef struct
|
|
||||||
{
|
|
||||||
char filename[1024];
|
|
||||||
char *buffer,*script_p,*end_p;
|
|
||||||
int line;
|
|
||||||
} BSPScript;
|
|
||||||
|
|
||||||
#define MAX_INCLUDES 8
|
|
||||||
BSPScript scriptstack[MAX_INCLUDES];
|
|
||||||
BSPScript *script;
|
|
||||||
int scriptline;
|
|
||||||
|
|
||||||
char token[BSPMAXTOKEN];
|
|
||||||
bool endofscript;
|
|
||||||
bool tokenready; // only true if UnGetToken was just called
|
|
||||||
|
|
||||||
//
|
|
||||||
//loadBSPFile
|
|
||||||
//
|
|
||||||
|
|
||||||
int extrasize = 100;
|
|
||||||
|
|
||||||
BspLoader::BspLoader()
|
|
||||||
:m_num_entities(0)
|
|
||||||
{
|
|
||||||
m_Endianness = getMachineEndianness();
|
|
||||||
if (m_Endianness == BSP_BIG_ENDIAN)
|
|
||||||
{
|
|
||||||
printf("Machine is BIG_ENDIAN\n");
|
|
||||||
} else
|
|
||||||
{
|
|
||||||
printf("Machine is Little Endian\n");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
bool BspLoader::loadBSPFile( void* memoryBuffer) {
|
|
||||||
|
|
||||||
BSPHeader *header = (BSPHeader*) memoryBuffer;
|
|
||||||
|
|
||||||
// load the file header
|
|
||||||
if (header)
|
|
||||||
{
|
|
||||||
// swap the header
|
|
||||||
swapBlock( (int *)header, sizeof(*header) );
|
|
||||||
|
|
||||||
int length = (header->lumps[BSPLUMP_SHADERS].filelen) / sizeof(BSPShader);
|
|
||||||
m_dshaders.resize(length+extrasize);
|
|
||||||
m_numShaders = copyLump( header, BSPLUMP_SHADERS, &m_dshaders[0], sizeof(BSPShader) );
|
|
||||||
|
|
||||||
length = (header->lumps[LUMP_MODELS].filelen) / sizeof(BSPModel);
|
|
||||||
m_dmodels.resize(length+extrasize);
|
|
||||||
m_nummodels = copyLump( header, LUMP_MODELS, &m_dmodels[0], sizeof(BSPModel) );
|
|
||||||
|
|
||||||
length = (header->lumps[BSPLUMP_PLANES].filelen) / sizeof(BSPPlane);
|
|
||||||
m_dplanes.resize(length+extrasize);
|
|
||||||
m_numplanes = copyLump( header, BSPLUMP_PLANES, &m_dplanes[0], sizeof(BSPPlane) );
|
|
||||||
|
|
||||||
length = (header->lumps[BSPLUMP_LEAFS].filelen) / sizeof(BSPLeaf);
|
|
||||||
m_dleafs.resize(length+extrasize);
|
|
||||||
m_numleafs = copyLump( header, BSPLUMP_LEAFS, &m_dleafs[0], sizeof(BSPLeaf) );
|
|
||||||
|
|
||||||
length = (header->lumps[BSPLUMP_NODES].filelen) / sizeof(BSPNode);
|
|
||||||
m_dnodes.resize(length+extrasize);
|
|
||||||
m_numnodes = copyLump( header, BSPLUMP_NODES, &m_dnodes[0], sizeof(BSPNode) );
|
|
||||||
|
|
||||||
length = (header->lumps[BSPLUMP_LEAFSURFACES].filelen) / sizeof(m_dleafsurfaces[0]);
|
|
||||||
m_dleafsurfaces.resize(length+extrasize);
|
|
||||||
m_numleafsurfaces = copyLump( header, BSPLUMP_LEAFSURFACES, &m_dleafsurfaces[0], sizeof(m_dleafsurfaces[0]) );
|
|
||||||
|
|
||||||
length = (header->lumps[BSPLUMP_LEAFBRUSHES].filelen) / sizeof(m_dleafbrushes[0]) ;
|
|
||||||
m_dleafbrushes.resize(length+extrasize);
|
|
||||||
m_numleafbrushes = copyLump( header, BSPLUMP_LEAFBRUSHES, &m_dleafbrushes[0], sizeof(m_dleafbrushes[0]) );
|
|
||||||
|
|
||||||
length = (header->lumps[LUMP_BRUSHES].filelen) / sizeof(BSPBrush);
|
|
||||||
m_dbrushes.resize(length+extrasize);
|
|
||||||
m_numbrushes = copyLump( header, LUMP_BRUSHES, &m_dbrushes[0], sizeof(BSPBrush) );
|
|
||||||
|
|
||||||
|
|
||||||
length = (header->lumps[LUMP_BRUSHSIDES].filelen) / sizeof(BSPBrushSide);
|
|
||||||
m_dbrushsides.resize(length+extrasize);
|
|
||||||
m_numbrushsides = copyLump( header, LUMP_BRUSHSIDES, &m_dbrushsides[0], sizeof(BSPBrushSide) );
|
|
||||||
|
|
||||||
|
|
||||||
length = (header->lumps[LUMP_SURFACES].filelen) / sizeof(BSPSurface);
|
|
||||||
m_drawSurfaces.resize(length+extrasize);
|
|
||||||
m_numDrawSurfaces = copyLump( header, LUMP_SURFACES, &m_drawSurfaces[0], sizeof(BSPSurface) );
|
|
||||||
|
|
||||||
|
|
||||||
length = (header->lumps[LUMP_DRAWINDEXES].filelen) / sizeof(m_drawIndexes[0]);
|
|
||||||
m_drawIndexes.resize(length+extrasize);
|
|
||||||
m_numDrawIndexes = copyLump( header, LUMP_DRAWINDEXES, &m_drawIndexes[0], sizeof(m_drawIndexes[0]) );
|
|
||||||
|
|
||||||
length = (header->lumps[LUMP_VISIBILITY].filelen) / 1;
|
|
||||||
m_visBytes.resize(length+extrasize);
|
|
||||||
m_numVisBytes = copyLump( header, LUMP_VISIBILITY, &m_visBytes[0], 1 );
|
|
||||||
|
|
||||||
length = (header->lumps[LUMP_LIGHTMAPS].filelen) / 1;
|
|
||||||
m_lightBytes.resize(length+extrasize);
|
|
||||||
m_numLightBytes = copyLump( header, LUMP_LIGHTMAPS, &m_lightBytes[0], 1 );
|
|
||||||
|
|
||||||
length = (header->lumps[BSPLUMP_ENTITIES].filelen) / 1;
|
|
||||||
m_dentdata.resize(length+extrasize);
|
|
||||||
m_entdatasize = copyLump( header, BSPLUMP_ENTITIES, &m_dentdata[0], 1);
|
|
||||||
|
|
||||||
length = (header->lumps[LUMP_LIGHTGRID].filelen) / 1;
|
|
||||||
m_gridData.resize(length+extrasize);
|
|
||||||
m_numGridPoints = copyLump( header, LUMP_LIGHTGRID, &m_gridData[0], 8 );
|
|
||||||
|
|
||||||
// swap everything
|
|
||||||
swapBSPFile();
|
|
||||||
|
|
||||||
return true;
|
|
||||||
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
const char* BspLoader::getValueForKey( const BSPEntity* ent, const char* key ) const {
|
|
||||||
|
|
||||||
const BSPKeyValuePair* ep;
|
|
||||||
|
|
||||||
for (ep=ent->epairs ; ep ; ep=ep->next) {
|
|
||||||
if (!strcmp(ep->key, key) ) {
|
|
||||||
return ep->value;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return "";
|
|
||||||
}
|
|
||||||
|
|
||||||
float BspLoader::getFloatForKey( const BSPEntity *ent, const char *key ) {
|
|
||||||
const char *k;
|
|
||||||
|
|
||||||
k = getValueForKey( ent, key );
|
|
||||||
return float(atof(k));
|
|
||||||
}
|
|
||||||
|
|
||||||
bool BspLoader::getVectorForKey( const BSPEntity *ent, const char *key, BSPVector3 vec ) {
|
|
||||||
|
|
||||||
const char *k;
|
|
||||||
k = getValueForKey (ent, key);
|
|
||||||
if (strcmp(k, ""))
|
|
||||||
{
|
|
||||||
sscanf (k, "%f %f %f", &vec[0], &vec[1], &vec[2]);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
==============
|
|
||||||
parseFromMemory
|
|
||||||
==============
|
|
||||||
*/
|
|
||||||
void BspLoader::parseFromMemory (char *buffer, int size)
|
|
||||||
{
|
|
||||||
script = scriptstack;
|
|
||||||
script++;
|
|
||||||
if (script == &scriptstack[MAX_INCLUDES])
|
|
||||||
{
|
|
||||||
//printf("script file exceeded MAX_INCLUDES");
|
|
||||||
}
|
|
||||||
strcpy (script->filename, "memory buffer" );
|
|
||||||
|
|
||||||
script->buffer = buffer;
|
|
||||||
script->line = 1;
|
|
||||||
script->script_p = script->buffer;
|
|
||||||
script->end_p = script->buffer + size;
|
|
||||||
|
|
||||||
endofscript = false;
|
|
||||||
tokenready = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
bool BspLoader::isEndOfScript (bool crossline)
|
|
||||||
{
|
|
||||||
if (!crossline)
|
|
||||||
//printf("Line %i is incomplete\n",scriptline);
|
|
||||||
|
|
||||||
if (!strcmp (script->filename, "memory buffer"))
|
|
||||||
{
|
|
||||||
endofscript = true;
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
//free (script->buffer);
|
|
||||||
if (script == scriptstack+1)
|
|
||||||
{
|
|
||||||
endofscript = true;
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
script--;
|
|
||||||
scriptline = script->line;
|
|
||||||
//printf ("returning to %s\n", script->filename);
|
|
||||||
return getToken (crossline);
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
|
|
||||||
==============
|
|
||||||
getToken
|
|
||||||
==============
|
|
||||||
*/
|
|
||||||
bool BspLoader::getToken (bool crossline)
|
|
||||||
{
|
|
||||||
char *token_p;
|
|
||||||
|
|
||||||
if (tokenready) // is a token allready waiting?
|
|
||||||
{
|
|
||||||
tokenready = false;
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (script->script_p >= script->end_p)
|
|
||||||
return isEndOfScript (crossline);
|
|
||||||
|
|
||||||
//
|
|
||||||
// skip space
|
|
||||||
//
|
|
||||||
skipspace:
|
|
||||||
while (*script->script_p <= 32)
|
|
||||||
{
|
|
||||||
if (script->script_p >= script->end_p)
|
|
||||||
return isEndOfScript (crossline);
|
|
||||||
if (*script->script_p++ == '\n')
|
|
||||||
{
|
|
||||||
if (!crossline)
|
|
||||||
{
|
|
||||||
//printf("Line %i is incomplete\n",scriptline);
|
|
||||||
}
|
|
||||||
scriptline = script->line++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (script->script_p >= script->end_p)
|
|
||||||
return isEndOfScript (crossline);
|
|
||||||
|
|
||||||
// ; # // comments
|
|
||||||
if (*script->script_p == ';' || *script->script_p == '#'
|
|
||||||
|| ( script->script_p[0] == '/' && script->script_p[1] == '/') )
|
|
||||||
{
|
|
||||||
if (!crossline)
|
|
||||||
{
|
|
||||||
//printf("Line %i is incomplete\n",scriptline);
|
|
||||||
}
|
|
||||||
while (*script->script_p++ != '\n')
|
|
||||||
if (script->script_p >= script->end_p)
|
|
||||||
return isEndOfScript (crossline);
|
|
||||||
scriptline = script->line++;
|
|
||||||
goto skipspace;
|
|
||||||
}
|
|
||||||
|
|
||||||
// /* */ comments
|
|
||||||
if (script->script_p[0] == '/' && script->script_p[1] == '*')
|
|
||||||
{
|
|
||||||
if (!crossline)
|
|
||||||
{
|
|
||||||
//printf("Line %i is incomplete\n",scriptline);
|
|
||||||
}
|
|
||||||
script->script_p+=2;
|
|
||||||
while (script->script_p[0] != '*' && script->script_p[1] != '/')
|
|
||||||
{
|
|
||||||
if ( *script->script_p == '\n' ) {
|
|
||||||
scriptline = script->line++;
|
|
||||||
}
|
|
||||||
script->script_p++;
|
|
||||||
if (script->script_p >= script->end_p)
|
|
||||||
return isEndOfScript (crossline);
|
|
||||||
}
|
|
||||||
script->script_p += 2;
|
|
||||||
goto skipspace;
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
// copy token
|
|
||||||
//
|
|
||||||
token_p = token;
|
|
||||||
|
|
||||||
if (*script->script_p == '"')
|
|
||||||
{
|
|
||||||
// quoted token
|
|
||||||
script->script_p++;
|
|
||||||
while (*script->script_p != '"')
|
|
||||||
{
|
|
||||||
*token_p++ = *script->script_p++;
|
|
||||||
if (script->script_p == script->end_p)
|
|
||||||
break;
|
|
||||||
if (token_p == &token[BSPMAXTOKEN])
|
|
||||||
{
|
|
||||||
//printf ("Token too large on line %i\n",scriptline);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
script->script_p++;
|
|
||||||
}
|
|
||||||
else // regular token
|
|
||||||
while ( *script->script_p > 32 && *script->script_p != ';')
|
|
||||||
{
|
|
||||||
*token_p++ = *script->script_p++;
|
|
||||||
if (script->script_p == script->end_p)
|
|
||||||
break;
|
|
||||||
if (token_p == &token[BSPMAXTOKEN])
|
|
||||||
{
|
|
||||||
//printf ("Token too large on line %i\n",scriptline);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
*token_p = 0;
|
|
||||||
|
|
||||||
if (!strcmp (token, "$include"))
|
|
||||||
{
|
|
||||||
//getToken (false);
|
|
||||||
//AddScriptToStack (token);
|
|
||||||
return false;//getToken (crossline);
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
char *BspLoader::copystring(const char *s)
|
|
||||||
{
|
|
||||||
char *b;
|
|
||||||
b = (char*) malloc( strlen(s)+1);
|
|
||||||
strcpy (b, s);
|
|
||||||
return b;
|
|
||||||
}
|
|
||||||
|
|
||||||
void BspLoader::stripTrailing( char *e ) {
|
|
||||||
char *s;
|
|
||||||
|
|
||||||
s = e + strlen(e)-1;
|
|
||||||
while (s >= e && *s <= 32)
|
|
||||||
{
|
|
||||||
*s = 0;
|
|
||||||
s--;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
/*
|
|
||||||
=================
|
|
||||||
parseEpair
|
|
||||||
=================
|
|
||||||
*/
|
|
||||||
BSPKeyValuePair *BspLoader::parseEpair( void ) {
|
|
||||||
BSPKeyValuePair *e;
|
|
||||||
|
|
||||||
e = (struct BSPPair*) malloc( sizeof(BSPKeyValuePair));
|
|
||||||
memset( e, 0, sizeof(BSPKeyValuePair) );
|
|
||||||
|
|
||||||
if ( strlen(token) >= BSPMAX_KEY-1 ) {
|
|
||||||
//printf ("ParseEpar: token too long");
|
|
||||||
}
|
|
||||||
e->key = copystring( token );
|
|
||||||
getToken( false );
|
|
||||||
if ( strlen(token) >= BSPMAX_VALUE-1 ) {
|
|
||||||
|
|
||||||
//printf ("ParseEpar: token too long");
|
|
||||||
}
|
|
||||||
e->value = copystring( token );
|
|
||||||
|
|
||||||
// strip trailing spaces that sometimes get accidentally
|
|
||||||
// added in the editor
|
|
||||||
stripTrailing( e->key );
|
|
||||||
stripTrailing( e->value );
|
|
||||||
|
|
||||||
return e;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
================
|
|
||||||
parseEntity
|
|
||||||
================
|
|
||||||
*/
|
|
||||||
bool BspLoader::parseEntity( void ) {
|
|
||||||
BSPKeyValuePair *e;
|
|
||||||
BSPEntity *mapent;
|
|
||||||
|
|
||||||
if ( !getToken (true) ) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ( strcmp (token, "{") ) {
|
|
||||||
|
|
||||||
//printf ("parseEntity: { not found");
|
|
||||||
}
|
|
||||||
|
|
||||||
BSPEntity bla;
|
|
||||||
bla.brushes = 0;
|
|
||||||
bla.epairs = 0;
|
|
||||||
bla.firstDrawSurf = 0;
|
|
||||||
bla.origin[0] = 0.f;
|
|
||||||
bla.origin[1] = 0.f;
|
|
||||||
bla.origin[2] = 0.f;
|
|
||||||
bla.patches = 0;
|
|
||||||
|
|
||||||
m_entities.push_back(bla);
|
|
||||||
mapent = &m_entities[m_entities.size()-1];
|
|
||||||
m_num_entities++;
|
|
||||||
|
|
||||||
do {
|
|
||||||
if ( !getToken (true) ) {
|
|
||||||
//printf("parseEntity: EOF without closing brace");
|
|
||||||
}
|
|
||||||
if ( !strcmp (token, "}") ) {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
e = (struct BSPPair*)parseEpair ();
|
|
||||||
e->next = mapent->epairs;
|
|
||||||
mapent->epairs = e;
|
|
||||||
} while (1);
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
================
|
|
||||||
parseEntities
|
|
||||||
|
|
||||||
Parses the dentdata string into entities
|
|
||||||
================
|
|
||||||
*/
|
|
||||||
void BspLoader::parseEntities( void ) {
|
|
||||||
m_num_entities = 0;
|
|
||||||
m_entities.clear();
|
|
||||||
|
|
||||||
parseFromMemory( &m_dentdata[0], m_entdatasize );
|
|
||||||
|
|
||||||
while ( parseEntity () ) {
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
int BspLoader::getMachineEndianness()
|
|
||||||
{
|
|
||||||
long int i = 1;
|
|
||||||
const char *p = (const char *) &i;
|
|
||||||
if (p[0] == 1) // Lowest address contains the least significant byte
|
|
||||||
return BSP_LITTLE_ENDIAN;
|
|
||||||
else
|
|
||||||
return BSP_BIG_ENDIAN;
|
|
||||||
}
|
|
||||||
|
|
||||||
short BspLoader::isLittleShort (short l)
|
|
||||||
{
|
|
||||||
if (machineEndianness() == BSP_BIG_ENDIAN)
|
|
||||||
{
|
|
||||||
unsigned char b1,b2;
|
|
||||||
|
|
||||||
b1 = l&255;
|
|
||||||
b2 = (l>>8)&255;
|
|
||||||
|
|
||||||
return (b1<<8) + b2;
|
|
||||||
}
|
|
||||||
//little endian
|
|
||||||
return l;
|
|
||||||
}
|
|
||||||
|
|
||||||
short BspLoader::isBigShort (short l)
|
|
||||||
{
|
|
||||||
if (machineEndianness() == BSP_BIG_ENDIAN)
|
|
||||||
{
|
|
||||||
return l;
|
|
||||||
}
|
|
||||||
|
|
||||||
unsigned char b1,b2;
|
|
||||||
|
|
||||||
b1 = l&255;
|
|
||||||
b2 = (l>>8)&255;
|
|
||||||
|
|
||||||
return (b1<<8) + b2;
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
int BspLoader::isLittleLong (int l)
|
|
||||||
{
|
|
||||||
if (machineEndianness() == BSP_BIG_ENDIAN)
|
|
||||||
{
|
|
||||||
unsigned char b1,b2,b3,b4;
|
|
||||||
|
|
||||||
b1 = l&255;
|
|
||||||
b2 = (l>>8)&255;
|
|
||||||
b3 = (l>>16)&255;
|
|
||||||
b4 = (l>>24)&255;
|
|
||||||
|
|
||||||
return ((int)b1<<24) + ((int)b2<<16) + ((int)b3<<8) + b4;
|
|
||||||
}
|
|
||||||
|
|
||||||
//little endian
|
|
||||||
return l;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
int BspLoader::isBigLong (int l)
|
|
||||||
{
|
|
||||||
if (machineEndianness() == BSP_BIG_ENDIAN)
|
|
||||||
{
|
|
||||||
return l;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
unsigned char b1,b2,b3,b4;
|
|
||||||
|
|
||||||
b1 = l&255;
|
|
||||||
b2 = (l>>8)&255;
|
|
||||||
b3 = (l>>16)&255;
|
|
||||||
b4 = (l>>24)&255;
|
|
||||||
|
|
||||||
return ((int)b1<<24) + ((int)b2<<16) + ((int)b3<<8) + b4;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
float BspLoader::isLittleFloat (float l)
|
|
||||||
{
|
|
||||||
if (machineEndianness() == BSP_BIG_ENDIAN)
|
|
||||||
{
|
|
||||||
union {unsigned char b[4]; float f;} in, out;
|
|
||||||
|
|
||||||
in.f = l;
|
|
||||||
out.b[0] = in.b[3];
|
|
||||||
out.b[1] = in.b[2];
|
|
||||||
out.b[2] = in.b[1];
|
|
||||||
out.b[3] = in.b[0];
|
|
||||||
|
|
||||||
return out.f;
|
|
||||||
}
|
|
||||||
|
|
||||||
//little endian
|
|
||||||
return l;
|
|
||||||
}
|
|
||||||
|
|
||||||
float BspLoader::isBigFloat (float l)
|
|
||||||
{
|
|
||||||
if (machineEndianness() == BSP_BIG_ENDIAN)
|
|
||||||
{
|
|
||||||
return l;
|
|
||||||
}
|
|
||||||
//little endian
|
|
||||||
union {unsigned char b[4]; float f;} in, out;
|
|
||||||
|
|
||||||
in.f = l;
|
|
||||||
out.b[0] = in.b[3];
|
|
||||||
out.b[1] = in.b[2];
|
|
||||||
out.b[2] = in.b[1];
|
|
||||||
out.b[3] = in.b[0];
|
|
||||||
|
|
||||||
return out.f;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//
|
|
||||||
// swapBlock
|
|
||||||
// If all values are 32 bits, this can be used to swap everything
|
|
||||||
//
|
|
||||||
|
|
||||||
void BspLoader::swapBlock( int *block, int sizeOfBlock ) {
|
|
||||||
int i;
|
|
||||||
|
|
||||||
sizeOfBlock >>= 2;
|
|
||||||
for ( i = 0 ; i < sizeOfBlock ; i++ ) {
|
|
||||||
block[i] = isLittleLong( block[i] );
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
// copyLump
|
|
||||||
//
|
|
||||||
|
|
||||||
int BspLoader::copyLump( BSPHeader *header, int lump, void *dest, int size ) {
|
|
||||||
int length, ofs;
|
|
||||||
|
|
||||||
length = header->lumps[lump].filelen;
|
|
||||||
ofs = header->lumps[lump].fileofs;
|
|
||||||
|
|
||||||
//if ( length % size ) {
|
|
||||||
// printf ("loadBSPFile: odd lump size");
|
|
||||||
//}
|
|
||||||
|
|
||||||
memcpy( dest, (unsigned char *)header + ofs, length );
|
|
||||||
|
|
||||||
return length / size;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//
|
|
||||||
// swapBSPFile
|
|
||||||
//
|
|
||||||
|
|
||||||
void BspLoader::swapBSPFile( void ) {
|
|
||||||
int i;
|
|
||||||
|
|
||||||
// models
|
|
||||||
swapBlock( (int *) &m_dmodels[0], m_nummodels * sizeof( m_dmodels[0] ) );
|
|
||||||
|
|
||||||
// shaders (don't swap the name)
|
|
||||||
for ( i = 0 ; i < m_numShaders ; i++ ) {
|
|
||||||
m_dshaders[i].contentFlags = isLittleLong( m_dshaders[i].contentFlags );
|
|
||||||
m_dshaders[i].surfaceFlags = isLittleLong( m_dshaders[i].surfaceFlags );
|
|
||||||
}
|
|
||||||
|
|
||||||
// planes
|
|
||||||
swapBlock( (int *)&m_dplanes[0], m_numplanes * sizeof( m_dplanes[0] ) );
|
|
||||||
|
|
||||||
// nodes
|
|
||||||
swapBlock( (int *)&m_dnodes[0], m_numnodes * sizeof( m_dnodes[0] ) );
|
|
||||||
|
|
||||||
// leafs
|
|
||||||
swapBlock( (int *)&m_dleafs[0], m_numleafs * sizeof( m_dleafs[0] ) );
|
|
||||||
|
|
||||||
// leaffaces
|
|
||||||
swapBlock( (int *)&m_dleafsurfaces[0], m_numleafsurfaces * sizeof( m_dleafsurfaces[0] ) );
|
|
||||||
|
|
||||||
// leafbrushes
|
|
||||||
swapBlock( (int *)&m_dleafbrushes[0], m_numleafbrushes * sizeof( m_dleafbrushes[0] ) );
|
|
||||||
|
|
||||||
// brushes
|
|
||||||
swapBlock( (int *)&m_dbrushes[0], m_numbrushes * sizeof( m_dbrushes[0] ) );
|
|
||||||
|
|
||||||
// brushsides
|
|
||||||
swapBlock( (int *)&m_dbrushsides[0], m_numbrushsides * sizeof( m_dbrushsides[0] ) );
|
|
||||||
|
|
||||||
// vis
|
|
||||||
((int *)&m_visBytes)[0] = isLittleLong( ((int *)&m_visBytes)[0] );
|
|
||||||
((int *)&m_visBytes)[1] = isLittleLong( ((int *)&m_visBytes)[1] );
|
|
||||||
|
|
||||||
|
|
||||||
// drawindexes
|
|
||||||
swapBlock( (int *)&m_drawIndexes[0], m_numDrawIndexes * sizeof( m_drawIndexes[0] ) );
|
|
||||||
|
|
||||||
// drawsurfs
|
|
||||||
swapBlock( (int *)&m_drawSurfaces[0], m_numDrawSurfaces * sizeof( m_drawSurfaces[0] ) );
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
bool BspLoader::findVectorByName(float* outvec,const char* name)
|
|
||||||
{
|
|
||||||
const char *cl;
|
|
||||||
BSPVector3 origin;
|
|
||||||
|
|
||||||
bool found = false;
|
|
||||||
|
|
||||||
parseEntities();
|
|
||||||
|
|
||||||
for ( int i = 1; i < m_num_entities; i++ ) {
|
|
||||||
cl = getValueForKey (&m_entities[i], "classname");
|
|
||||||
if ( !strcmp( cl, "info_player_start" ) ) {
|
|
||||||
getVectorForKey( &m_entities[i], "origin", origin );
|
|
||||||
found = true;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
if ( !strcmp( cl, "info_player_deathmatch" ) ) {
|
|
||||||
getVectorForKey( &m_entities[i], "origin", origin );
|
|
||||||
found = true;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (found)
|
|
||||||
{
|
|
||||||
outvec[0] = origin[0];
|
|
||||||
outvec[1] = origin[1];
|
|
||||||
outvec[2] = origin[2];
|
|
||||||
}
|
|
||||||
return found;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
const BSPEntity * BspLoader::getEntityByValue( const char* name, const char* value)
|
|
||||||
{
|
|
||||||
const BSPEntity* entity = NULL;
|
|
||||||
|
|
||||||
for ( int i = 1; i < m_num_entities; i++ ) {
|
|
||||||
|
|
||||||
const BSPEntity& ent = m_entities[i];
|
|
||||||
|
|
||||||
const char* cl = getValueForKey (&m_entities[i], name);
|
|
||||||
if ( !strcmp( cl, value ) ) {
|
|
||||||
entity = &ent;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return entity;
|
|
||||||
}
|
|
||||||
|
|
295
extern/bullet/Demos/BspDemo/BspLoader.h
vendored
295
extern/bullet/Demos/BspDemo/BspLoader.h
vendored
@ -1,295 +0,0 @@
|
|||||||
/*
|
|
||||||
===========================================================================
|
|
||||||
Copyright (C) 1999-2005 Id Software, Inc.
|
|
||||||
|
|
||||||
This file is part of Quake III Arena source code.
|
|
||||||
|
|
||||||
Quake III Arena source code is free software; you can redistribute it
|
|
||||||
and/or modify it under the terms of the GNU bteral Public License as
|
|
||||||
published by the Free Software Foundation; either version 2 of the License,
|
|
||||||
or (at your option) any later version.
|
|
||||||
|
|
||||||
Quake III Arena source code 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 bteral Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU bteral Public License
|
|
||||||
along with Foobar; if not, write to the Free Software
|
|
||||||
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
===========================================================================
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#ifndef BSP_LOADER_H
|
|
||||||
#define BSP_LOADER_H
|
|
||||||
|
|
||||||
#include "LinearMath/btAlignedObjectArray.h"
|
|
||||||
|
|
||||||
#define BSPMAXTOKEN 1024
|
|
||||||
#define BSPMAX_KEY 32
|
|
||||||
#define BSPMAX_VALUE 1024
|
|
||||||
#define BSPCONTENTS_SOLID 1
|
|
||||||
#define BSPCONTENTS_AREAPORTAL 0x8000
|
|
||||||
#define BSPLUMP_ENTITIES 0
|
|
||||||
#define BSPLUMP_SHADERS 1
|
|
||||||
#define BSPLUMP_PLANES 2
|
|
||||||
#define BSPLUMP_NODES 3
|
|
||||||
#define BSPLUMP_LEAFS 4
|
|
||||||
#define BSPLUMP_LEAFSURFACES 5
|
|
||||||
#define BSPLUMP_LEAFBRUSHES 6
|
|
||||||
#define LUMP_MODELS 7
|
|
||||||
#define LUMP_BRUSHES 8
|
|
||||||
#define LUMP_BRUSHSIDES 9
|
|
||||||
#define LUMP_DRAWVERTS 10
|
|
||||||
#define LUMP_DRAWINDEXES 11
|
|
||||||
#define LUMP_SURFACES 13
|
|
||||||
#define LUMP_LIGHTMAPS 14
|
|
||||||
#define LUMP_LIGHTGRID 15
|
|
||||||
#define LUMP_VISIBILITY 16
|
|
||||||
#define HEADER_LUMPS 17
|
|
||||||
#define MAX_QPATH 64
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
typedef struct {
|
|
||||||
int fileofs, filelen;
|
|
||||||
} BSPLump;
|
|
||||||
|
|
||||||
typedef float BSPVector3[3];
|
|
||||||
|
|
||||||
typedef struct {
|
|
||||||
int ident;
|
|
||||||
int version;
|
|
||||||
|
|
||||||
BSPLump lumps[HEADER_LUMPS];
|
|
||||||
} BSPHeader;
|
|
||||||
|
|
||||||
|
|
||||||
typedef struct {
|
|
||||||
float mins[3], maxs[3];
|
|
||||||
int firstSurface, numSurfaces;
|
|
||||||
int firstBrush, numBrushes;
|
|
||||||
} BSPModel;
|
|
||||||
|
|
||||||
typedef struct {
|
|
||||||
char shader[MAX_QPATH];
|
|
||||||
int surfaceFlags;
|
|
||||||
int contentFlags;
|
|
||||||
} BSPShader;
|
|
||||||
|
|
||||||
typedef struct {
|
|
||||||
float normal[3];
|
|
||||||
float dist;
|
|
||||||
} BSPPlane;
|
|
||||||
|
|
||||||
typedef struct {
|
|
||||||
int planeNum;
|
|
||||||
int children[2];
|
|
||||||
int mins[3];
|
|
||||||
int maxs[3];
|
|
||||||
} BSPNode;
|
|
||||||
|
|
||||||
typedef struct {
|
|
||||||
int cluster;
|
|
||||||
int area;
|
|
||||||
|
|
||||||
int mins[3];
|
|
||||||
int maxs[3];
|
|
||||||
|
|
||||||
int firstLeafSurface;
|
|
||||||
int numLeafSurfaces;
|
|
||||||
|
|
||||||
int firstLeafBrush;
|
|
||||||
int numLeafBrushes;
|
|
||||||
} BSPLeaf;
|
|
||||||
|
|
||||||
typedef struct {
|
|
||||||
int planeNum;
|
|
||||||
int shaderNum;
|
|
||||||
} BSPBrushSide;
|
|
||||||
|
|
||||||
typedef struct {
|
|
||||||
int firstSide;
|
|
||||||
int numSides;
|
|
||||||
int shaderNum;
|
|
||||||
} BSPBrush;
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
typedef struct BSPPair {
|
|
||||||
struct BSPPair *next;
|
|
||||||
char *key;
|
|
||||||
char *value;
|
|
||||||
} BSPKeyValuePair;
|
|
||||||
|
|
||||||
typedef struct {
|
|
||||||
BSPVector3 origin;
|
|
||||||
struct bspbrush_s *brushes;
|
|
||||||
struct parseMesh_s *patches;
|
|
||||||
int firstDrawSurf;
|
|
||||||
BSPKeyValuePair *epairs;
|
|
||||||
} BSPEntity;
|
|
||||||
|
|
||||||
typedef enum {
|
|
||||||
MST_BAD,
|
|
||||||
MST_PLANAR,
|
|
||||||
MST_PATCH,
|
|
||||||
MST_TRIANGLE_SOUP,
|
|
||||||
MST_FLARE
|
|
||||||
} BSPMapSurface;
|
|
||||||
|
|
||||||
typedef struct {
|
|
||||||
int shaderNum;
|
|
||||||
int fogNum;
|
|
||||||
int surfaceType;
|
|
||||||
|
|
||||||
int firstVert;
|
|
||||||
int numVerts;
|
|
||||||
|
|
||||||
int firstIndex;
|
|
||||||
int numIndexes;
|
|
||||||
|
|
||||||
int lightmapNum;
|
|
||||||
int lightmapX, lightmapY;
|
|
||||||
int lightmapWidth, lightmapHeight;
|
|
||||||
|
|
||||||
BSPVector3 lightmapOrigin;
|
|
||||||
BSPVector3 lightmapVecs[3];
|
|
||||||
|
|
||||||
int patchWidth;
|
|
||||||
int patchHeight;
|
|
||||||
} BSPSurface;
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
///GPL code from IdSofware to parse a Quake 3 BSP file
|
|
||||||
///check that your platform define __BIG_ENDIAN__ correctly (in BspLoader.cpp)
|
|
||||||
class BspLoader
|
|
||||||
{
|
|
||||||
int m_Endianness;
|
|
||||||
|
|
||||||
public:
|
|
||||||
|
|
||||||
BspLoader();
|
|
||||||
|
|
||||||
bool loadBSPFile( void* memoryBuffer);
|
|
||||||
|
|
||||||
const char* getValueForKey( const BSPEntity *ent, const char *key ) const;
|
|
||||||
|
|
||||||
bool getVectorForKey( const BSPEntity *ent, const char *key, BSPVector3 vec );
|
|
||||||
|
|
||||||
float getFloatForKey( const BSPEntity *ent, const char *key );
|
|
||||||
|
|
||||||
void parseEntities( void );
|
|
||||||
|
|
||||||
bool findVectorByName(float* outvec,const char* name);
|
|
||||||
|
|
||||||
const BSPEntity * getEntityByValue( const char* name, const char* value);
|
|
||||||
|
|
||||||
|
|
||||||
protected:
|
|
||||||
|
|
||||||
void parseFromMemory (char *buffer, int size);
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
bool isEndOfScript (bool crossline);
|
|
||||||
|
|
||||||
bool getToken (bool crossline);
|
|
||||||
|
|
||||||
char *copystring(const char *s);
|
|
||||||
|
|
||||||
void stripTrailing( char *e );
|
|
||||||
|
|
||||||
BSPKeyValuePair * parseEpair( void );
|
|
||||||
|
|
||||||
bool parseEntity( void );
|
|
||||||
|
|
||||||
short isLittleShort (short l);
|
|
||||||
int isLittleLong (int l);
|
|
||||||
float isLittleFloat (float l);
|
|
||||||
|
|
||||||
int isBigLong (int l);
|
|
||||||
short isBigShort (short l);
|
|
||||||
float isBigFloat (float l);
|
|
||||||
|
|
||||||
void swapBlock( int *block, int sizeOfBlock );
|
|
||||||
|
|
||||||
int copyLump( BSPHeader *header, int lump, void *dest, int size );
|
|
||||||
|
|
||||||
void swapBSPFile( void );
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
public: //easier for conversion
|
|
||||||
int m_num_entities;
|
|
||||||
btAlignedObjectArray<BSPEntity> m_entities;
|
|
||||||
|
|
||||||
int m_nummodels;
|
|
||||||
btAlignedObjectArray<BSPModel> m_dmodels;
|
|
||||||
|
|
||||||
int m_numShaders;
|
|
||||||
btAlignedObjectArray<BSPShader> m_dshaders;
|
|
||||||
|
|
||||||
int m_entdatasize;
|
|
||||||
btAlignedObjectArray<char> m_dentdata;
|
|
||||||
|
|
||||||
int m_numleafs;
|
|
||||||
btAlignedObjectArray<BSPLeaf> m_dleafs;
|
|
||||||
|
|
||||||
int m_numplanes;
|
|
||||||
btAlignedObjectArray<BSPPlane> m_dplanes;
|
|
||||||
|
|
||||||
int m_numnodes;
|
|
||||||
btAlignedObjectArray<BSPNode> m_dnodes;
|
|
||||||
|
|
||||||
int m_numleafsurfaces;
|
|
||||||
btAlignedObjectArray<int> m_dleafsurfaces;
|
|
||||||
|
|
||||||
int m_numleafbrushes;
|
|
||||||
btAlignedObjectArray<int> m_dleafbrushes;
|
|
||||||
|
|
||||||
int m_numbrushes;
|
|
||||||
btAlignedObjectArray<BSPBrush> m_dbrushes;
|
|
||||||
|
|
||||||
int m_numbrushsides;
|
|
||||||
btAlignedObjectArray<BSPBrushSide> m_dbrushsides;
|
|
||||||
|
|
||||||
int m_numLightBytes;
|
|
||||||
btAlignedObjectArray<unsigned char> m_lightBytes;
|
|
||||||
|
|
||||||
int m_numGridPoints;
|
|
||||||
btAlignedObjectArray<unsigned char> m_gridData;
|
|
||||||
|
|
||||||
int m_numVisBytes;
|
|
||||||
btAlignedObjectArray<unsigned char> m_visBytes;
|
|
||||||
|
|
||||||
|
|
||||||
int m_numDrawIndexes;
|
|
||||||
btAlignedObjectArray<int> m_drawIndexes;
|
|
||||||
|
|
||||||
int m_numDrawSurfaces;
|
|
||||||
btAlignedObjectArray<BSPSurface> m_drawSurfaces;
|
|
||||||
|
|
||||||
enum
|
|
||||||
{
|
|
||||||
BSP_LITTLE_ENDIAN = 0,
|
|
||||||
BSP_BIG_ENDIAN = 1
|
|
||||||
};
|
|
||||||
|
|
||||||
//returns machines big endian / little endian
|
|
||||||
//
|
|
||||||
int getMachineEndianness();
|
|
||||||
|
|
||||||
inline int machineEndianness()
|
|
||||||
{
|
|
||||||
return m_Endianness;
|
|
||||||
}
|
|
||||||
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif //BSP_LOADER_H
|
|
60
extern/bullet/Demos/BspDemo/CMakeLists.txt
vendored
60
extern/bullet/Demos/BspDemo/CMakeLists.txt
vendored
@ -1,60 +0,0 @@
|
|||||||
# This is basically the overall name of the project in Visual Studio this is the name of the Solution File
|
|
||||||
|
|
||||||
|
|
||||||
# For every executable you have with a main method you should have an add_executable line below.
|
|
||||||
# For every add executable line you should list every .cpp and .h file you have associated with that executable.
|
|
||||||
|
|
||||||
|
|
||||||
# You shouldn't have to modify anything below this line
|
|
||||||
########################################################
|
|
||||||
|
|
||||||
|
|
||||||
INCLUDE_DIRECTORIES(
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/src ${BULLET_PHYSICS_SOURCE_DIR}/Demos/OpenGL
|
|
||||||
)
|
|
||||||
|
|
||||||
LINK_LIBRARIES(
|
|
||||||
OpenGLSupport BulletDynamics BulletCollision LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY}
|
|
||||||
)
|
|
||||||
|
|
||||||
ADD_EXECUTABLE(AppBspPhysicsDemo
|
|
||||||
main.cpp
|
|
||||||
BspDemo.cpp
|
|
||||||
BspLoader.cpp
|
|
||||||
BspConverter.cpp
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
IF (WIN32)
|
|
||||||
IF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES)
|
|
||||||
IF (CMAKE_CL_64)
|
|
||||||
ADD_CUSTOM_COMMAND(
|
|
||||||
TARGET AppBspPhysicsDemo
|
|
||||||
POST_BUILD
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/glut64.dll ${CMAKE_CURRENT_BINARY_DIR}
|
|
||||||
)
|
|
||||||
ELSE(CMAKE_CL_64)
|
|
||||||
ADD_CUSTOM_COMMAND(
|
|
||||||
TARGET AppBspPhysicsDemo
|
|
||||||
POST_BUILD
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/GLUT32.DLL ${CMAKE_CURRENT_BINARY_DIR}
|
|
||||||
)
|
|
||||||
ENDIF(CMAKE_CL_64)
|
|
||||||
ENDIF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES)
|
|
||||||
ENDIF(WIN32)
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
IF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES)
|
|
||||||
ADD_CUSTOM_COMMAND(
|
|
||||||
TARGET AppBspPhysicsDemo
|
|
||||||
POST_BUILD
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/BspDemo.bsp ${CMAKE_CURRENT_BINARY_DIR}
|
|
||||||
)
|
|
||||||
ENDIF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES)
|
|
||||||
|
|
||||||
IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES)
|
|
||||||
SET_TARGET_PROPERTIES(AppBspPhysicsDemo PROPERTIES DEBUG_POSTFIX "_Debug")
|
|
||||||
SET_TARGET_PROPERTIES(AppBspPhysicsDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel")
|
|
||||||
SET_TARGET_PROPERTIES(AppBspPhysicsDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo")
|
|
||||||
ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES)
|
|
59
extern/bullet/Demos/BspDemo/main.cpp
vendored
59
extern/bullet/Demos/BspDemo/main.cpp
vendored
@ -1,59 +0,0 @@
|
|||||||
/*
|
|
||||||
Bullet Continuous Collision Detection and Physics Library
|
|
||||||
Copyright (c) 2003-2007 Erwin Coumans http://continuousphysics.com/Bullet/
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied warranty.
|
|
||||||
In no event will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it freely,
|
|
||||||
subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
|
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
#include "BspDemo.h"
|
|
||||||
#include "GlutStuff.h"
|
|
||||||
#include "GLDebugDrawer.h"
|
|
||||||
#include "btBulletDynamicsCommon.h"
|
|
||||||
|
|
||||||
char* makeExeToBspFilename(const char* lpCmdLine);
|
|
||||||
char* getLastFileName();
|
|
||||||
|
|
||||||
|
|
||||||
int main(int argc,char** argv)
|
|
||||||
{
|
|
||||||
|
|
||||||
BspDemo* bspDemo = new BspDemo();
|
|
||||||
|
|
||||||
const char* bspfilename = "BspDemo.bsp";
|
|
||||||
|
|
||||||
printf("argc=%i\n",argc);
|
|
||||||
{
|
|
||||||
for (int i=0;i<argc;i++)
|
|
||||||
{
|
|
||||||
printf("argv[%i]=%s\n",i,argv[i]);
|
|
||||||
}
|
|
||||||
|
|
||||||
bspfilename = makeExeToBspFilename(argv[0]);
|
|
||||||
printf("new name=%s\n",bspfilename);
|
|
||||||
}
|
|
||||||
if (argc>1)
|
|
||||||
{
|
|
||||||
bspfilename = argv[1];
|
|
||||||
}
|
|
||||||
|
|
||||||
GLDebugDrawer gDebugDrawer;
|
|
||||||
|
|
||||||
// Enrico: TODO: Should change parameter type of initPhysics() to std::string or at least const char *
|
|
||||||
bspDemo->initPhysics((char*)bspfilename);
|
|
||||||
|
|
||||||
bspDemo->getDynamicsWorld()->setDebugDrawer(&gDebugDrawer);
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
return glutmain(argc, argv,640,480,"Bullet Quake BSP Physics Viewer http://bulletphysics.org",bspDemo);
|
|
||||||
}
|
|
||||||
|
|
996
extern/bullet/Demos/BulletDinoDemo/BulletDino.c
vendored
996
extern/bullet/Demos/BulletDinoDemo/BulletDino.c
vendored
@ -1,996 +0,0 @@
|
|||||||
|
|
||||||
/* This demo has been modified to use the Bullet C-API.
|
|
||||||
The C-API is minimal, and will develop based on developer feedback.
|
|
||||||
The C++ API is recommended, and compatible with the C-API.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* Copyright (c) Mark J. Kilgard, 1994, 1997. */
|
|
||||||
|
|
||||||
/* This program is freely distributable without licensing fees
|
|
||||||
and is provided without guarantee or warrantee expressed or
|
|
||||||
implied. This program is -not- in the public domain. */
|
|
||||||
|
|
||||||
/* Example for PC game developers to show how to *combine* texturing,
|
|
||||||
reflections, and projected shadows all in real-time with OpenGL.
|
|
||||||
Robust reflections use stenciling. Robust projected shadows
|
|
||||||
use both stenciling and polygon offset. PC game programmers
|
|
||||||
should realize that neither stenciling nor polygon offset are
|
|
||||||
supported by Direct3D, so these real-time rendering algorithms
|
|
||||||
are only really viable with OpenGL.
|
|
||||||
|
|
||||||
The program has modes for disabling the stenciling and polygon
|
|
||||||
offset uses. It is worth running this example with these features
|
|
||||||
toggled off so you can see the sort of artifacts that result.
|
|
||||||
|
|
||||||
Notice that the floor texturing, reflections, and shadowing
|
|
||||||
all co-exist properly. */
|
|
||||||
|
|
||||||
/* When you run this program: Left mouse button controls the
|
|
||||||
view. Middle mouse button controls light position (left &
|
|
||||||
right rotates light around dino; up & down moves light
|
|
||||||
position up and down). Right mouse button pops up menu. */
|
|
||||||
|
|
||||||
/* Check out the comments in the "redraw" routine to see how the
|
|
||||||
reflection blending and surface stenciling is done. You can
|
|
||||||
also see in "redraw" how the projected shadows are rendered,
|
|
||||||
including the use of stenciling and polygon offset. */
|
|
||||||
|
|
||||||
/* This program is derived from glutdino.c */
|
|
||||||
|
|
||||||
/* Compile: cc -o dinoshade dinoshade.c -lglut -lGLU -lGL -lXmu -lXext -lX11 -lm */
|
|
||||||
|
|
||||||
#include <stdio.h>
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <string.h>
|
|
||||||
#include <math.h> /* for cos(), sin(), and sqrt() */
|
|
||||||
#ifdef WIN32//for glut.h
|
|
||||||
#include <windows.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef WIN32
|
|
||||||
#ifndef CALLBACK
|
|
||||||
#define CALLBACK
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
//think different
|
|
||||||
#if defined(__APPLE__) && !defined (VMDMESA)
|
|
||||||
#include <OpenGL/gl.h>
|
|
||||||
#include <OpenGL/glu.h>
|
|
||||||
#include <GLUT/glut.h>
|
|
||||||
#define GLVOIDPTR GLvoid(*)()
|
|
||||||
#else
|
|
||||||
#include <GL/glut.h>
|
|
||||||
#include <GL/glext.h>
|
|
||||||
#define GLVOIDPTR void(CALLBACK*)()
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Some <math.h> files do not define M_PI... */
|
|
||||||
#ifndef M_PI
|
|
||||||
#define M_PI 3.14159265
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
//#include "../../include/Bullet-C-Api.h"
|
|
||||||
#include "Bullet-C-Api.h"
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
plPhysicsSdkHandle physicsSdk=0;
|
|
||||||
plDynamicsWorldHandle dynamicsWorld=0;
|
|
||||||
plRigidBodyHandle floorRigidBody;
|
|
||||||
plRigidBodyHandle dinoRigidBody;
|
|
||||||
|
|
||||||
/* Variable controlling various rendering modes. */
|
|
||||||
static int stencilReflection = 1, stencilShadow = 1, offsetShadow = 1;
|
|
||||||
static int renderShadow = 1, renderDinosaur = 1, renderReflection = 1;
|
|
||||||
static int linearFiltering = 0, useMipmaps = 0, useTexture = 1;
|
|
||||||
static int reportSpeed = 0;
|
|
||||||
static int animation = 1;
|
|
||||||
static GLboolean lightSwitch = GL_TRUE;
|
|
||||||
static int directionalLight = 1;
|
|
||||||
static int forceExtension = 0;
|
|
||||||
|
|
||||||
/* Time varying or user-controled variables. */
|
|
||||||
static float jump = 0.0;
|
|
||||||
static float lightAngle = 0.0, lightHeight = 20;
|
|
||||||
GLfloat angle = -150; /* in degrees */
|
|
||||||
GLfloat angle2 = 30; /* in degrees */
|
|
||||||
|
|
||||||
int moving, startx, starty;
|
|
||||||
int lightMoving = 0, lightStartX, lightStartY;
|
|
||||||
|
|
||||||
enum {
|
|
||||||
MISSING, EXTENSION, ONE_DOT_ONE
|
|
||||||
};
|
|
||||||
int polygonOffsetVersion;
|
|
||||||
|
|
||||||
static GLdouble bodyWidth = 3.0;
|
|
||||||
/* *INDENT-OFF* */
|
|
||||||
static GLfloat body[][2] = { {0, 3}, {1, 1}, {5, 1}, {8, 4}, {10, 4}, {11, 5},
|
|
||||||
{11, 11.5}, {13, 12}, {13, 13}, {10, 13.5}, {13, 14}, {13, 15}, {11, 16},
|
|
||||||
{8, 16}, {7, 15}, {7, 13}, {8, 12}, {7, 11}, {6, 6}, {4, 3}, {3, 2},
|
|
||||||
{1, 2} };
|
|
||||||
static GLfloat arm[][2] = { {8, 10}, {9, 9}, {10, 9}, {13, 8}, {14, 9}, {16, 9},
|
|
||||||
{15, 9.5}, {16, 10}, {15, 10}, {15.5, 11}, {14.5, 10}, {14, 11}, {14, 10},
|
|
||||||
{13, 9}, {11, 11}, {9, 11} };
|
|
||||||
static GLfloat leg[][2] = { {8, 6}, {8, 4}, {9, 3}, {9, 2}, {8, 1}, {8, 0.5}, {9, 0},
|
|
||||||
{12, 0}, {10, 1}, {10, 2}, {12, 4}, {11, 6}, {10, 7}, {9, 7} };
|
|
||||||
static GLfloat eye[][2] = { {8.75, 15}, {9, 14.7}, {9.6, 14.7}, {10.1, 15},
|
|
||||||
{9.6, 15.25}, {9, 15.25} };
|
|
||||||
static GLfloat lightPosition[4];
|
|
||||||
static GLfloat lightColor[] = {0.8, 1.0, 0.8, 1.0}; /* green-tinted */
|
|
||||||
static GLfloat skinColor[] = {0.1, 1.0, 0.1, 1.0}, eyeColor[] = {1.0, 0.2, 0.2, 1.0};
|
|
||||||
/* *INDENT-ON* */
|
|
||||||
|
|
||||||
/* Nice floor texture tiling pattern. */
|
|
||||||
static char *circles[] = {
|
|
||||||
"....xxxx........",
|
|
||||||
"..xxxxxxxx......",
|
|
||||||
".xxxxxxxxxx.....",
|
|
||||||
".xxx....xxx.....",
|
|
||||||
"xxx......xxx....",
|
|
||||||
"xxx......xxx....",
|
|
||||||
"xxx......xxx....",
|
|
||||||
"xxx......xxx....",
|
|
||||||
".xxx....xxx.....",
|
|
||||||
".xxxxxxxxxx.....",
|
|
||||||
"..xxxxxxxx......",
|
|
||||||
"....xxxx........",
|
|
||||||
"................",
|
|
||||||
"................",
|
|
||||||
"................",
|
|
||||||
"................",
|
|
||||||
};
|
|
||||||
|
|
||||||
static void
|
|
||||||
makeFloorTexture(void)
|
|
||||||
{
|
|
||||||
GLubyte floorTexture[16][16][3];
|
|
||||||
GLubyte *loc;
|
|
||||||
int s, t;
|
|
||||||
loc=0;
|
|
||||||
|
|
||||||
/* Setup RGB image for the texture. */
|
|
||||||
loc = (GLubyte*) floorTexture;
|
|
||||||
for (t = 0; t < 16; t++) {
|
|
||||||
for (s = 0; s < 16; s++) {
|
|
||||||
if (circles[t][s] == 'x') {
|
|
||||||
/* Nice green. */
|
|
||||||
loc[0] = 0x1f;
|
|
||||||
loc[1] = 0x8f;
|
|
||||||
loc[2] = 0x1f;
|
|
||||||
} else {
|
|
||||||
/* Light gray. */
|
|
||||||
loc[0] = 0xaa;
|
|
||||||
loc[1] = 0xaa;
|
|
||||||
loc[2] = 0xaa;
|
|
||||||
}
|
|
||||||
loc += 3;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
glPixelStorei(GL_UNPACK_ALIGNMENT, 1);
|
|
||||||
|
|
||||||
if (useMipmaps) {
|
|
||||||
glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER,
|
|
||||||
GL_LINEAR_MIPMAP_LINEAR);
|
|
||||||
gluBuild2DMipmaps(GL_TEXTURE_2D, 3, 16, 16,
|
|
||||||
GL_RGB, GL_UNSIGNED_BYTE, floorTexture);
|
|
||||||
} else {
|
|
||||||
if (linearFiltering) {
|
|
||||||
glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR);
|
|
||||||
} else {
|
|
||||||
glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_NEAREST);
|
|
||||||
}
|
|
||||||
glTexImage2D(GL_TEXTURE_2D, 0, 3, 16, 16, 0,
|
|
||||||
GL_RGB, GL_UNSIGNED_BYTE, floorTexture);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
enum {
|
|
||||||
X, Y, Z, W
|
|
||||||
};
|
|
||||||
enum {
|
|
||||||
A, B, C, D
|
|
||||||
};
|
|
||||||
|
|
||||||
/* Create a matrix that will project the desired shadow. */
|
|
||||||
void
|
|
||||||
shadowMatrix(GLfloat shadowMat[4][4],
|
|
||||||
GLfloat groundplane[4],
|
|
||||||
GLfloat lightpos[4])
|
|
||||||
{
|
|
||||||
GLfloat dot;
|
|
||||||
|
|
||||||
/* Find dot product between light position vector and ground plane normal. */
|
|
||||||
dot = groundplane[X] * lightpos[X] +
|
|
||||||
groundplane[Y] * lightpos[Y] +
|
|
||||||
groundplane[Z] * lightpos[Z] +
|
|
||||||
groundplane[W] * lightpos[W];
|
|
||||||
|
|
||||||
shadowMat[0][0] = dot - lightpos[X] * groundplane[X];
|
|
||||||
shadowMat[1][0] = 0.f - lightpos[X] * groundplane[Y];
|
|
||||||
shadowMat[2][0] = 0.f - lightpos[X] * groundplane[Z];
|
|
||||||
shadowMat[3][0] = 0.f - lightpos[X] * groundplane[W];
|
|
||||||
|
|
||||||
shadowMat[X][1] = 0.f - lightpos[Y] * groundplane[X];
|
|
||||||
shadowMat[1][1] = dot - lightpos[Y] * groundplane[Y];
|
|
||||||
shadowMat[2][1] = 0.f - lightpos[Y] * groundplane[Z];
|
|
||||||
shadowMat[3][1] = 0.f - lightpos[Y] * groundplane[W];
|
|
||||||
|
|
||||||
shadowMat[X][2] = 0.f - lightpos[Z] * groundplane[X];
|
|
||||||
shadowMat[1][2] = 0.f - lightpos[Z] * groundplane[Y];
|
|
||||||
shadowMat[2][2] = dot - lightpos[Z] * groundplane[Z];
|
|
||||||
shadowMat[3][2] = 0.f - lightpos[Z] * groundplane[W];
|
|
||||||
|
|
||||||
shadowMat[X][3] = 0.f - lightpos[W] * groundplane[X];
|
|
||||||
shadowMat[1][3] = 0.f - lightpos[W] * groundplane[Y];
|
|
||||||
shadowMat[2][3] = 0.f - lightpos[W] * groundplane[Z];
|
|
||||||
shadowMat[3][3] = dot - lightpos[W] * groundplane[W];
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Find the plane equation given 3 points. */
|
|
||||||
void
|
|
||||||
findPlane(GLfloat plane[4],
|
|
||||||
GLfloat v0[3], GLfloat v1[3], GLfloat v2[3])
|
|
||||||
{
|
|
||||||
GLfloat vec0[3], vec1[3];
|
|
||||||
|
|
||||||
/* Need 2 vectors to find cross product. */
|
|
||||||
vec0[X] = v1[X] - v0[X];
|
|
||||||
vec0[Y] = v1[Y] - v0[Y];
|
|
||||||
vec0[Z] = v1[Z] - v0[Z];
|
|
||||||
|
|
||||||
vec1[X] = v2[X] - v0[X];
|
|
||||||
vec1[Y] = v2[Y] - v0[Y];
|
|
||||||
vec1[Z] = v2[Z] - v0[Z];
|
|
||||||
|
|
||||||
/* find cross product to get A, B, and C of plane equation */
|
|
||||||
plane[A] = vec0[Y] * vec1[Z] - vec0[Z] * vec1[Y];
|
|
||||||
plane[B] = -(vec0[X] * vec1[Z] - vec0[Z] * vec1[X]);
|
|
||||||
plane[C] = vec0[X] * vec1[Y] - vec0[Y] * vec1[X];
|
|
||||||
|
|
||||||
plane[D] = -(plane[A] * v0[X] + plane[B] * v0[Y] + plane[C] * v0[Z]);
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
extrudeSolidFromPolygon(GLfloat data[][2], unsigned int dataSize,
|
|
||||||
GLdouble thickness, GLuint side, GLuint edge, GLuint whole)
|
|
||||||
{
|
|
||||||
static GLUtriangulatorObj *tobj = NULL;
|
|
||||||
GLdouble vertex[3], dx, dy, len;
|
|
||||||
int i;
|
|
||||||
int count = dataSize / (2 * sizeof(GLfloat));
|
|
||||||
|
|
||||||
if (tobj == NULL) {
|
|
||||||
tobj = gluNewTess(); /* create and initialize a GLU
|
|
||||||
polygon * * tesselation object */
|
|
||||||
gluTessCallback(tobj, (GLenum)GLU_BEGIN, (GLVOIDPTR)glBegin);
|
|
||||||
gluTessCallback(tobj, (GLenum)GLU_VERTEX, (GLVOIDPTR)glVertex2fv); /* semi-tricky */
|
|
||||||
gluTessCallback(tobj, (GLenum)GLU_END, (GLVOIDPTR)glEnd);
|
|
||||||
}
|
|
||||||
glNewList(side, GL_COMPILE);
|
|
||||||
glShadeModel(GL_SMOOTH); /* smooth minimizes seeing
|
|
||||||
tessellation */
|
|
||||||
gluBeginPolygon(tobj);
|
|
||||||
for (i = 0; i < count; i++) {
|
|
||||||
vertex[0] = data[i][0];
|
|
||||||
vertex[1] = data[i][1];
|
|
||||||
vertex[2] = 0;
|
|
||||||
gluTessVertex(tobj, vertex, data[i]);
|
|
||||||
}
|
|
||||||
gluEndPolygon(tobj);
|
|
||||||
glEndList();
|
|
||||||
glNewList(edge, GL_COMPILE);
|
|
||||||
glShadeModel(GL_FLAT); /* flat shade keeps angular hands
|
|
||||||
from being "smoothed" */
|
|
||||||
glBegin(GL_QUAD_STRIP);
|
|
||||||
for (i = 0; i <= count; i++) {
|
|
||||||
/* mod function handles closing the edge */
|
|
||||||
glVertex3f(data[i % count][0], data[i % count][1], 0.0);
|
|
||||||
glVertex3f(data[i % count][0], data[i % count][1], thickness);
|
|
||||||
/* Calculate a unit normal by dividing by Euclidean
|
|
||||||
distance. We * could be lazy and use
|
|
||||||
glEnable(GL_NORMALIZE) so we could pass in * arbitrary
|
|
||||||
normals for a very slight performance hit. */
|
|
||||||
dx = data[(i + 1) % count][1] - data[i % count][1];
|
|
||||||
dy = data[i % count][0] - data[(i + 1) % count][0];
|
|
||||||
len = sqrt(dx * dx + dy * dy);
|
|
||||||
glNormal3f(dx / len, dy / len, 0.0);
|
|
||||||
}
|
|
||||||
glEnd();
|
|
||||||
glEndList();
|
|
||||||
glNewList(whole, GL_COMPILE);
|
|
||||||
glFrontFace(GL_CW);
|
|
||||||
glCallList(edge);
|
|
||||||
glNormal3f(0.0, 0.0, -1.0); /* constant normal for side */
|
|
||||||
glCallList(side);
|
|
||||||
glPushMatrix();
|
|
||||||
glTranslatef(0.0, 0.0, thickness);
|
|
||||||
glFrontFace(GL_CCW);
|
|
||||||
glNormal3f(0.0, 0.0, 1.0); /* opposite normal for other side */
|
|
||||||
glCallList(side);
|
|
||||||
glPopMatrix();
|
|
||||||
glEndList();
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Enumerants for refering to display lists. */
|
|
||||||
typedef enum {
|
|
||||||
RESERVED, BODY_SIDE, BODY_EDGE, BODY_WHOLE, ARM_SIDE, ARM_EDGE, ARM_WHOLE,
|
|
||||||
LEG_SIDE, LEG_EDGE, LEG_WHOLE, EYE_SIDE, EYE_EDGE, EYE_WHOLE
|
|
||||||
} displayLists;
|
|
||||||
|
|
||||||
static void
|
|
||||||
makeDinosaur(void)
|
|
||||||
{
|
|
||||||
extrudeSolidFromPolygon(body, sizeof(body), bodyWidth,
|
|
||||||
BODY_SIDE, BODY_EDGE, BODY_WHOLE);
|
|
||||||
extrudeSolidFromPolygon(arm, sizeof(arm), bodyWidth / 4,
|
|
||||||
ARM_SIDE, ARM_EDGE, ARM_WHOLE);
|
|
||||||
extrudeSolidFromPolygon(leg, sizeof(leg), bodyWidth / 2,
|
|
||||||
LEG_SIDE, LEG_EDGE, LEG_WHOLE);
|
|
||||||
extrudeSolidFromPolygon(eye, sizeof(eye), bodyWidth + 0.2,
|
|
||||||
EYE_SIDE, EYE_EDGE, EYE_WHOLE);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
|
||||||
drawDinosaur(void)
|
|
||||||
|
|
||||||
{
|
|
||||||
plReal matrix[16];
|
|
||||||
|
|
||||||
glPushMatrix();
|
|
||||||
/* Translate the dinosaur to be at (0,8,0). */
|
|
||||||
|
|
||||||
plGetOpenGLMatrix(dinoRigidBody,matrix);
|
|
||||||
// plGetPosition(dinoRigidBody,dinoWorldPos);
|
|
||||||
// glTranslatef(-8, 0, -bodyWidth / 2);
|
|
||||||
//glTranslatef(0.0, jump, 0.0);
|
|
||||||
// glTranslatef(dinoWorldPos[0],dinoWorldPos[1],dinoWorldPos[2]);
|
|
||||||
|
|
||||||
#ifdef BT_USE_DOUBLE_PRECISION
|
|
||||||
glMultMatrixd(matrix);
|
|
||||||
#else
|
|
||||||
glMultMatrixf(matrix);
|
|
||||||
#endif
|
|
||||||
// glutSolidCube(15);
|
|
||||||
glTranslatef(-8.5, -8.5, 0);
|
|
||||||
|
|
||||||
glMaterialfv(GL_FRONT, GL_DIFFUSE, skinColor);
|
|
||||||
glCallList(BODY_WHOLE);
|
|
||||||
glTranslatef(0.0, 0.0, bodyWidth);
|
|
||||||
glCallList(ARM_WHOLE);
|
|
||||||
glCallList(LEG_WHOLE);
|
|
||||||
glTranslatef(0.0, 0.0, -bodyWidth - bodyWidth / 4);
|
|
||||||
glCallList(ARM_WHOLE);
|
|
||||||
glTranslatef(0.0, 0.0, -bodyWidth / 4);
|
|
||||||
glCallList(LEG_WHOLE);
|
|
||||||
glTranslatef(0.0, 0.0, bodyWidth / 2 - 0.1);
|
|
||||||
glMaterialfv(GL_FRONT, GL_DIFFUSE, eyeColor);
|
|
||||||
glCallList(EYE_WHOLE);
|
|
||||||
|
|
||||||
|
|
||||||
glPopMatrix();
|
|
||||||
}
|
|
||||||
|
|
||||||
static GLfloat floorVertices[4][3] = {
|
|
||||||
{ -20.0, 0.0, 20.0 },
|
|
||||||
{ 20.0, 0.0, 20.0 },
|
|
||||||
{ 20.0, 0.0, -20.0 },
|
|
||||||
{ -20.0, 0.0, -20.0 },
|
|
||||||
};
|
|
||||||
|
|
||||||
/* Draw a floor (possibly textured). */
|
|
||||||
static void
|
|
||||||
drawFloor(void)
|
|
||||||
{
|
|
||||||
glDisable(GL_LIGHTING);
|
|
||||||
|
|
||||||
if (useTexture) {
|
|
||||||
glEnable(GL_TEXTURE_2D);
|
|
||||||
}
|
|
||||||
|
|
||||||
glBegin(GL_QUADS);
|
|
||||||
glTexCoord2f(0.0, 0.0);
|
|
||||||
glVertex3fv(floorVertices[0]);
|
|
||||||
glTexCoord2f(0.0, 16.0);
|
|
||||||
glVertex3fv(floorVertices[1]);
|
|
||||||
glTexCoord2f(16.0, 16.0);
|
|
||||||
glVertex3fv(floorVertices[2]);
|
|
||||||
glTexCoord2f(16.0, 0.0);
|
|
||||||
glVertex3fv(floorVertices[3]);
|
|
||||||
glEnd();
|
|
||||||
|
|
||||||
if (useTexture) {
|
|
||||||
glDisable(GL_TEXTURE_2D);
|
|
||||||
}
|
|
||||||
|
|
||||||
glEnable(GL_LIGHTING);
|
|
||||||
}
|
|
||||||
|
|
||||||
static GLfloat floorPlane[4];
|
|
||||||
static GLfloat floorShadow[4][4];
|
|
||||||
|
|
||||||
static void
|
|
||||||
redraw(void)
|
|
||||||
{
|
|
||||||
int start = 0, end = 0 ;
|
|
||||||
|
|
||||||
if (reportSpeed) {
|
|
||||||
start = glutGet(GLUT_ELAPSED_TIME);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Clear; default stencil clears to zero. */
|
|
||||||
if ((stencilReflection && renderReflection) || (stencilShadow && renderShadow)) {
|
|
||||||
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT | GL_STENCIL_BUFFER_BIT);
|
|
||||||
} else {
|
|
||||||
/* Avoid clearing stencil when not using it. */
|
|
||||||
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Reposition the light source. */
|
|
||||||
lightPosition[0] = 12*cos(lightAngle);
|
|
||||||
lightPosition[1] = lightHeight;
|
|
||||||
lightPosition[2] = 12*sin(lightAngle);
|
|
||||||
if (directionalLight) {
|
|
||||||
lightPosition[3] = 0.0;
|
|
||||||
} else {
|
|
||||||
lightPosition[3] = 1.0;
|
|
||||||
}
|
|
||||||
|
|
||||||
shadowMatrix(floorShadow, floorPlane, lightPosition);
|
|
||||||
|
|
||||||
glPushMatrix();
|
|
||||||
/* Perform scene rotations based on user mouse input. */
|
|
||||||
glRotatef(angle2, 1.0, 0.0, 0.0);
|
|
||||||
glRotatef(angle, 0.0, 1.0, 0.0);
|
|
||||||
|
|
||||||
/* Tell GL new light source position. */
|
|
||||||
glLightfv(GL_LIGHT0, GL_POSITION, lightPosition);
|
|
||||||
|
|
||||||
if (renderReflection) {
|
|
||||||
if (stencilReflection) {
|
|
||||||
/* We can eliminate the visual "artifact" of seeing the "flipped"
|
|
||||||
dinosaur underneath the floor by using stencil. The idea is
|
|
||||||
draw the floor without color or depth update but so that
|
|
||||||
a stencil value of one is where the floor will be. Later when
|
|
||||||
rendering the dinosaur reflection, we will only update pixels
|
|
||||||
with a stencil value of 1 to make sure the reflection only
|
|
||||||
lives on the floor, not below the floor. */
|
|
||||||
|
|
||||||
/* Don't update color or depth. */
|
|
||||||
glDisable(GL_DEPTH_TEST);
|
|
||||||
glColorMask(GL_FALSE, GL_FALSE, GL_FALSE, GL_FALSE);
|
|
||||||
|
|
||||||
/* Draw 1 into the stencil buffer. */
|
|
||||||
glEnable(GL_STENCIL_TEST);
|
|
||||||
glStencilOp(GL_REPLACE, GL_REPLACE, GL_REPLACE);
|
|
||||||
glStencilFunc(GL_ALWAYS, 1, 0xffffffff);
|
|
||||||
|
|
||||||
/* Now render floor; floor pixels just get their stencil set to 1. */
|
|
||||||
drawFloor();
|
|
||||||
|
|
||||||
/* Re-enable update of color and depth. */
|
|
||||||
glColorMask(GL_TRUE, GL_TRUE, GL_TRUE, GL_TRUE);
|
|
||||||
glEnable(GL_DEPTH_TEST);
|
|
||||||
|
|
||||||
/* Now, only render where stencil is set to 1. */
|
|
||||||
glStencilFunc(GL_EQUAL, 1, 0xffffffff); /* draw if ==1 */
|
|
||||||
glStencilOp(GL_KEEP, GL_KEEP, GL_KEEP);
|
|
||||||
}
|
|
||||||
|
|
||||||
glPushMatrix();
|
|
||||||
|
|
||||||
/* The critical reflection step: Reflect dinosaur through the floor
|
|
||||||
(the Y=0 plane) to make a relection. */
|
|
||||||
glScalef(1.0, -1.0, 1.0);
|
|
||||||
|
|
||||||
/* Reflect the light position. */
|
|
||||||
glLightfv(GL_LIGHT0, GL_POSITION, lightPosition);
|
|
||||||
|
|
||||||
/* To avoid our normals getting reversed and hence botched lighting
|
|
||||||
on the reflection, turn on normalize. */
|
|
||||||
glEnable(GL_NORMALIZE);
|
|
||||||
glCullFace(GL_FRONT);
|
|
||||||
|
|
||||||
/* Draw the reflected dinosaur. */
|
|
||||||
drawDinosaur();
|
|
||||||
|
|
||||||
/* Disable noramlize again and re-enable back face culling. */
|
|
||||||
glDisable(GL_NORMALIZE);
|
|
||||||
glCullFace(GL_BACK);
|
|
||||||
|
|
||||||
glPopMatrix();
|
|
||||||
|
|
||||||
/* Switch back to the unreflected light position. */
|
|
||||||
glLightfv(GL_LIGHT0, GL_POSITION, lightPosition);
|
|
||||||
|
|
||||||
if (stencilReflection) {
|
|
||||||
glDisable(GL_STENCIL_TEST);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Back face culling will get used to only draw either the top or the
|
|
||||||
bottom floor. This let's us get a floor with two distinct
|
|
||||||
appearances. The top floor surface is reflective and kind of red.
|
|
||||||
The bottom floor surface is not reflective and blue. */
|
|
||||||
|
|
||||||
/* Draw "bottom" of floor in blue. */
|
|
||||||
glFrontFace(GL_CW); /* Switch face orientation. */
|
|
||||||
glColor4f(0.1, 0.1, 0.7, 1.0);
|
|
||||||
drawFloor();
|
|
||||||
glFrontFace(GL_CCW);
|
|
||||||
|
|
||||||
if (renderShadow) {
|
|
||||||
if (stencilShadow) {
|
|
||||||
/* Draw the floor with stencil value 3. This helps us only
|
|
||||||
draw the shadow once per floor pixel (and only on the
|
|
||||||
floor pixels). */
|
|
||||||
glEnable(GL_STENCIL_TEST);
|
|
||||||
glStencilFunc(GL_ALWAYS, 3, 0xffffffff);
|
|
||||||
glStencilOp(GL_KEEP, GL_KEEP, GL_REPLACE);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Draw "top" of floor. Use blending to blend in reflection. */
|
|
||||||
glEnable(GL_BLEND);
|
|
||||||
glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);
|
|
||||||
glColor4f(0.7, 0.0, 0.0, 0.3);
|
|
||||||
glColor4f(1.0, 1.0, 1.0, 0.3);
|
|
||||||
drawFloor();
|
|
||||||
glDisable(GL_BLEND);
|
|
||||||
|
|
||||||
if (renderDinosaur) {
|
|
||||||
/* Draw "actual" dinosaur, not its reflection. */
|
|
||||||
drawDinosaur();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (renderShadow) {
|
|
||||||
|
|
||||||
/* Render the projected shadow. */
|
|
||||||
|
|
||||||
if (stencilShadow) {
|
|
||||||
|
|
||||||
/* Now, only render where stencil is set above 2 (ie, 3 where
|
|
||||||
the top floor is). Update stencil with 2 where the shadow
|
|
||||||
gets drawn so we don't redraw (and accidently reblend) the
|
|
||||||
shadow). */
|
|
||||||
glStencilFunc(GL_LESS, 2, 0xffffffff); /* draw if ==1 */
|
|
||||||
glStencilOp(GL_REPLACE, GL_REPLACE, GL_REPLACE);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* To eliminate depth buffer artifacts, we use polygon offset
|
|
||||||
to raise the depth of the projected shadow slightly so
|
|
||||||
that it does not depth buffer alias with the floor. */
|
|
||||||
if (offsetShadow) {
|
|
||||||
switch (polygonOffsetVersion) {
|
|
||||||
case EXTENSION:
|
|
||||||
#ifdef GL_VERSION_1_1
|
|
||||||
case ONE_DOT_ONE:
|
|
||||||
glEnable(GL_POLYGON_OFFSET_FILL);
|
|
||||||
break;
|
|
||||||
#endif
|
|
||||||
case MISSING:
|
|
||||||
/* Oh well. */
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Render 50% black shadow color on top of whatever the
|
|
||||||
floor appareance is. */
|
|
||||||
glEnable(GL_BLEND);
|
|
||||||
glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);
|
|
||||||
glDisable(GL_LIGHTING); /* Force the 50% black. */
|
|
||||||
glColor4f(0.0, 0.0, 0.0, 0.5);
|
|
||||||
|
|
||||||
glPushMatrix();
|
|
||||||
/* Project the shadow. */
|
|
||||||
glMultMatrixf((GLfloat *) floorShadow);
|
|
||||||
drawDinosaur();
|
|
||||||
glPopMatrix();
|
|
||||||
|
|
||||||
glDisable(GL_BLEND);
|
|
||||||
glEnable(GL_LIGHTING);
|
|
||||||
|
|
||||||
if (offsetShadow) {
|
|
||||||
switch (polygonOffsetVersion) {
|
|
||||||
#ifdef GL_VERSION_1_1
|
|
||||||
case ONE_DOT_ONE:
|
|
||||||
glDisable(GL_POLYGON_OFFSET_FILL);
|
|
||||||
break;
|
|
||||||
#endif
|
|
||||||
case MISSING:
|
|
||||||
/* Oh well. */
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (stencilShadow) {
|
|
||||||
glDisable(GL_STENCIL_TEST);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
glPushMatrix();
|
|
||||||
glDisable(GL_LIGHTING);
|
|
||||||
glColor3f(1.0, 1.0, 0.0);
|
|
||||||
if (directionalLight) {
|
|
||||||
/* Draw an arrowhead. */
|
|
||||||
glDisable(GL_CULL_FACE);
|
|
||||||
glTranslatef(lightPosition[0], lightPosition[1], lightPosition[2]);
|
|
||||||
glRotatef(lightAngle * -180.0 / M_PI, 0, 1, 0);
|
|
||||||
glRotatef(atan(lightHeight/12) * 180.0 / M_PI, 0, 0, 1);
|
|
||||||
glBegin(GL_TRIANGLE_FAN);
|
|
||||||
glVertex3f(0, 0, 0);
|
|
||||||
glVertex3f(2, 1, 1);
|
|
||||||
glVertex3f(2, -1, 1);
|
|
||||||
glVertex3f(2, -1, -1);
|
|
||||||
glVertex3f(2, 1, -1);
|
|
||||||
glVertex3f(2, 1, 1);
|
|
||||||
glEnd();
|
|
||||||
/* Draw a white line from light direction. */
|
|
||||||
glColor3f(1.0, 1.0, 1.0);
|
|
||||||
glBegin(GL_LINES);
|
|
||||||
glVertex3f(0, 0, 0);
|
|
||||||
glVertex3f(5, 0, 0);
|
|
||||||
glEnd();
|
|
||||||
glEnable(GL_CULL_FACE);
|
|
||||||
} else {
|
|
||||||
/* Draw a yellow ball at the light source. */
|
|
||||||
glTranslatef(lightPosition[0], lightPosition[1], lightPosition[2]);
|
|
||||||
glutSolidSphere(1.0, 5, 5);
|
|
||||||
}
|
|
||||||
glEnable(GL_LIGHTING);
|
|
||||||
glPopMatrix();
|
|
||||||
|
|
||||||
glPopMatrix();
|
|
||||||
|
|
||||||
if (reportSpeed) {
|
|
||||||
glFinish();
|
|
||||||
end = glutGet(GLUT_ELAPSED_TIME);
|
|
||||||
printf("Speed %.3g frames/sec (%d ms)\n", 1000.0/(end-start), end-start);
|
|
||||||
}
|
|
||||||
|
|
||||||
glutSwapBuffers();
|
|
||||||
}
|
|
||||||
|
|
||||||
/* ARGSUSED2 */
|
|
||||||
static void
|
|
||||||
mouse(int button, int state, int x, int y)
|
|
||||||
{
|
|
||||||
if (button == GLUT_LEFT_BUTTON) {
|
|
||||||
if (state == GLUT_DOWN) {
|
|
||||||
moving = 1;
|
|
||||||
startx = x;
|
|
||||||
starty = y;
|
|
||||||
}
|
|
||||||
if (state == GLUT_UP) {
|
|
||||||
moving = 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (button == GLUT_MIDDLE_BUTTON) {
|
|
||||||
if (state == GLUT_DOWN) {
|
|
||||||
lightMoving = 1;
|
|
||||||
lightStartX = x;
|
|
||||||
lightStartY = y;
|
|
||||||
}
|
|
||||||
if (state == GLUT_UP) {
|
|
||||||
lightMoving = 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* ARGSUSED1 */
|
|
||||||
static void
|
|
||||||
motion(int x, int y)
|
|
||||||
{
|
|
||||||
if (moving) {
|
|
||||||
angle = angle + (x - startx);
|
|
||||||
angle2 = angle2 + (y - starty);
|
|
||||||
startx = x;
|
|
||||||
starty = y;
|
|
||||||
glutPostRedisplay();
|
|
||||||
}
|
|
||||||
if (0){//lightMoving) {
|
|
||||||
lightAngle += (x - lightStartX)/40.0;
|
|
||||||
lightHeight += (lightStartY - y)/20.0;
|
|
||||||
lightStartX = x;
|
|
||||||
lightStartY = y;
|
|
||||||
glutPostRedisplay();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Advance time varying state when idle callback registered. */
|
|
||||||
static void
|
|
||||||
idle(void)
|
|
||||||
{
|
|
||||||
static float time = 0.0;
|
|
||||||
static float prevtime = 0.0;
|
|
||||||
float dtime;
|
|
||||||
prevtime = time;
|
|
||||||
|
|
||||||
time = glutGet(GLUT_ELAPSED_TIME) / 500.0;
|
|
||||||
dtime = time - prevtime;
|
|
||||||
|
|
||||||
jump = 4.0 * fabs(sin(time)*0.5);
|
|
||||||
if (!lightMoving) {
|
|
||||||
lightAngle = time;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (dynamicsWorld)
|
|
||||||
plStepSimulation(dynamicsWorld,dtime);
|
|
||||||
|
|
||||||
glutPostRedisplay();
|
|
||||||
}
|
|
||||||
|
|
||||||
enum {
|
|
||||||
M_NONE, M_MOTION, M_LIGHT, M_TEXTURE, M_SHADOWS, M_REFLECTION, M_DINOSAUR,
|
|
||||||
M_STENCIL_REFLECTION, M_STENCIL_SHADOW, M_OFFSET_SHADOW,
|
|
||||||
M_POSITIONAL, M_DIRECTIONAL, M_PERFORMANCE
|
|
||||||
};
|
|
||||||
|
|
||||||
static void
|
|
||||||
controlLights(int value)
|
|
||||||
{
|
|
||||||
switch (value) {
|
|
||||||
case M_NONE:
|
|
||||||
return;
|
|
||||||
case M_MOTION:
|
|
||||||
animation = 1 - animation;
|
|
||||||
if (animation) {
|
|
||||||
glutIdleFunc(idle);
|
|
||||||
} else {
|
|
||||||
glutIdleFunc(NULL);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case M_LIGHT:
|
|
||||||
lightSwitch = !lightSwitch;
|
|
||||||
if (lightSwitch) {
|
|
||||||
glEnable(GL_LIGHT0);
|
|
||||||
} else {
|
|
||||||
glDisable(GL_LIGHT0);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case M_TEXTURE:
|
|
||||||
useTexture = !useTexture;
|
|
||||||
break;
|
|
||||||
case M_SHADOWS:
|
|
||||||
renderShadow = 1 - renderShadow;
|
|
||||||
break;
|
|
||||||
case M_REFLECTION:
|
|
||||||
renderReflection = 1 - renderReflection;
|
|
||||||
break;
|
|
||||||
case M_DINOSAUR:
|
|
||||||
renderDinosaur = 1 - renderDinosaur;
|
|
||||||
break;
|
|
||||||
case M_STENCIL_REFLECTION:
|
|
||||||
stencilReflection = 1 - stencilReflection;
|
|
||||||
break;
|
|
||||||
case M_STENCIL_SHADOW:
|
|
||||||
stencilShadow = 1 - stencilShadow;
|
|
||||||
break;
|
|
||||||
case M_OFFSET_SHADOW:
|
|
||||||
offsetShadow = 1 - offsetShadow;
|
|
||||||
break;
|
|
||||||
case M_POSITIONAL:
|
|
||||||
directionalLight = 0;
|
|
||||||
break;
|
|
||||||
case M_DIRECTIONAL:
|
|
||||||
directionalLight = 1;
|
|
||||||
break;
|
|
||||||
case M_PERFORMANCE:
|
|
||||||
reportSpeed = 1 - reportSpeed;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
glutPostRedisplay();
|
|
||||||
}
|
|
||||||
|
|
||||||
/* When not visible, stop animating. Restart when visible again. */
|
|
||||||
static void
|
|
||||||
visible(int vis)
|
|
||||||
{
|
|
||||||
if (vis == GLUT_VISIBLE) {
|
|
||||||
if (animation)
|
|
||||||
glutIdleFunc(idle);
|
|
||||||
} else {
|
|
||||||
if (!animation)
|
|
||||||
glutIdleFunc(NULL);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Press any key to redraw; good when motion stopped and
|
|
||||||
performance reporting on. */
|
|
||||||
/* ARGSUSED */
|
|
||||||
static void
|
|
||||||
key(unsigned char c, int x, int y)
|
|
||||||
{
|
|
||||||
if (c == 27) {
|
|
||||||
exit(0); /* IRIS GLism, Escape quits. */
|
|
||||||
}
|
|
||||||
glutPostRedisplay();
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Press any key to redraw; good when motion stopped and
|
|
||||||
performance reporting on. */
|
|
||||||
/* ARGSUSED */
|
|
||||||
static void
|
|
||||||
special(int k, int x, int y)
|
|
||||||
{
|
|
||||||
glutPostRedisplay();
|
|
||||||
}
|
|
||||||
|
|
||||||
static int
|
|
||||||
supportsOneDotOne(void)
|
|
||||||
{
|
|
||||||
const char *version;
|
|
||||||
int major, minor;
|
|
||||||
|
|
||||||
version = (char *) glGetString(GL_VERSION);
|
|
||||||
if (sscanf(version, "%d.%d", &major, &minor) == 2)
|
|
||||||
return ((major > 1) || (major >= 1 && minor >= 1));
|
|
||||||
return 0; /* OpenGL version string malformed! */
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
int
|
|
||||||
main(int argc, char **argv)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
plCollisionShapeHandle floorShape;
|
|
||||||
plCollisionShapeHandle dinoShape,dinoChildShape;
|
|
||||||
plVector3 floorPos,childPos;
|
|
||||||
plVector3 dinoPos;
|
|
||||||
plQuaternion childOrn,dinoOrient;
|
|
||||||
|
|
||||||
void* user_data=NULL;
|
|
||||||
|
|
||||||
physicsSdk = plNewBulletSdk();
|
|
||||||
dynamicsWorld = plCreateDynamicsWorld(physicsSdk);
|
|
||||||
|
|
||||||
//create ground plane
|
|
||||||
|
|
||||||
floorShape = plNewConvexHullShape();
|
|
||||||
|
|
||||||
for (i=0;i<4;i++)
|
|
||||||
{
|
|
||||||
// floorVertices
|
|
||||||
plAddVertex(floorShape,floorVertices[i][0],floorVertices[i][1],floorVertices[i][2]);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
floorShape = plNewBoxShape(120,0,120);
|
|
||||||
|
|
||||||
floorRigidBody = plCreateRigidBody(user_data,0.f,floorShape);
|
|
||||||
floorPos[0] = 0;
|
|
||||||
floorPos[1] = 0;
|
|
||||||
floorPos[2] = 0;
|
|
||||||
|
|
||||||
plSetPosition(floorRigidBody,floorPos);
|
|
||||||
plAddRigidBody(dynamicsWorld,floorRigidBody);
|
|
||||||
|
|
||||||
//create dino rigidbody
|
|
||||||
dinoChildShape = plNewBoxShape(8.5,8.5,8.5);
|
|
||||||
dinoShape = plNewCompoundShape();
|
|
||||||
childPos[0] = 0;
|
|
||||||
childPos[1] = 0;
|
|
||||||
childPos[2] = 0;
|
|
||||||
childOrn[0] = 0;
|
|
||||||
childOrn[1] = 0;
|
|
||||||
childOrn[2] = 0;
|
|
||||||
childOrn[3] = 1;
|
|
||||||
|
|
||||||
plAddChildShape(dinoShape,dinoChildShape,childPos,childOrn);
|
|
||||||
|
|
||||||
dinoPos[0] = -10; dinoPos[1] = 28; dinoPos[2] = 0;
|
|
||||||
dinoRigidBody = plCreateRigidBody(0,1.0,dinoShape);
|
|
||||||
plSetPosition(dinoRigidBody,dinoPos);
|
|
||||||
plSetEuler(0,0,3.15*0.20,dinoOrient);
|
|
||||||
plSetOrientation(dinoRigidBody,dinoOrient);
|
|
||||||
|
|
||||||
plAddRigidBody(dynamicsWorld,dinoRigidBody);
|
|
||||||
|
|
||||||
printf("BulletDino\n");
|
|
||||||
glutInit(&argc, argv);
|
|
||||||
|
|
||||||
for (i=1; i<argc; i++) {
|
|
||||||
if (!strcmp("-linear", argv[i])) {
|
|
||||||
linearFiltering = 1;
|
|
||||||
} else if (!strcmp("-mipmap", argv[i])) {
|
|
||||||
useMipmaps = 1;
|
|
||||||
} else if (!strcmp("-ext", argv[i])) {
|
|
||||||
forceExtension = 1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
glutInitDisplayMode(GLUT_RGB | GLUT_DOUBLE | GLUT_DEPTH | GLUT_STENCIL | GLUT_MULTISAMPLE);
|
|
||||||
|
|
||||||
#if 0
|
|
||||||
/* In GLUT 4.0, you'll be able to do this an be sure to
|
|
||||||
get 2 bits of stencil if the machine has it for you. */
|
|
||||||
glutInitDisplayString("samples stencil>=2 rgb double depth");
|
|
||||||
#endif
|
|
||||||
|
|
||||||
glutCreateWindow("Shadowy Leapin' Lizards");
|
|
||||||
|
|
||||||
if (glutGet(GLUT_WINDOW_STENCIL_SIZE) <= 1) {
|
|
||||||
printf("dinoshade: Sorry, I need at least 2 bits of stencil.\n");
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Register GLUT callbacks. */
|
|
||||||
glutDisplayFunc(redraw);
|
|
||||||
glutMouseFunc(mouse);
|
|
||||||
glutMotionFunc(motion);
|
|
||||||
glutVisibilityFunc(visible);
|
|
||||||
glutKeyboardFunc(key);
|
|
||||||
glutSpecialFunc(special);
|
|
||||||
|
|
||||||
glutCreateMenu(controlLights);
|
|
||||||
|
|
||||||
glutAddMenuEntry("Toggle motion", M_MOTION);
|
|
||||||
glutAddMenuEntry("-----------------------", M_NONE);
|
|
||||||
glutAddMenuEntry("Toggle light", M_LIGHT);
|
|
||||||
glutAddMenuEntry("Toggle texture", M_TEXTURE);
|
|
||||||
glutAddMenuEntry("Toggle shadows", M_SHADOWS);
|
|
||||||
glutAddMenuEntry("Toggle reflection", M_REFLECTION);
|
|
||||||
glutAddMenuEntry("Toggle dinosaur", M_DINOSAUR);
|
|
||||||
glutAddMenuEntry("-----------------------", M_NONE);
|
|
||||||
glutAddMenuEntry("Toggle reflection stenciling", M_STENCIL_REFLECTION);
|
|
||||||
glutAddMenuEntry("Toggle shadow stenciling", M_STENCIL_SHADOW);
|
|
||||||
glutAddMenuEntry("Toggle shadow offset", M_OFFSET_SHADOW);
|
|
||||||
glutAddMenuEntry("----------------------", M_NONE);
|
|
||||||
glutAddMenuEntry("Positional light", M_POSITIONAL);
|
|
||||||
glutAddMenuEntry("Directional light", M_DIRECTIONAL);
|
|
||||||
glutAddMenuEntry("-----------------------", M_NONE);
|
|
||||||
glutAddMenuEntry("Toggle performance", M_PERFORMANCE);
|
|
||||||
glutAttachMenu(GLUT_RIGHT_BUTTON);
|
|
||||||
makeDinosaur();
|
|
||||||
|
|
||||||
#ifdef GL_VERSION_1_1
|
|
||||||
if (supportsOneDotOne() && !forceExtension) {
|
|
||||||
polygonOffsetVersion = ONE_DOT_ONE;
|
|
||||||
glPolygonOffset(-2.0, -1.0);
|
|
||||||
} else
|
|
||||||
#endif
|
|
||||||
{
|
|
||||||
{
|
|
||||||
polygonOffsetVersion = MISSING;
|
|
||||||
printf("\ndinoshine: Missing polygon offset.\n");
|
|
||||||
printf(" Expect shadow depth aliasing artifacts.\n\n");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
glEnable(GL_CULL_FACE);
|
|
||||||
glEnable(GL_DEPTH_TEST);
|
|
||||||
glEnable(GL_TEXTURE_2D);
|
|
||||||
glLineWidth(3.0);
|
|
||||||
|
|
||||||
glMatrixMode(GL_PROJECTION);
|
|
||||||
gluPerspective( /* field of view in degree */ 40.0,
|
|
||||||
/* aspect ratio */ 1.0,
|
|
||||||
/* Z near */ 20.0, /* Z far */ 100.0);
|
|
||||||
glMatrixMode(GL_MODELVIEW);
|
|
||||||
gluLookAt(0.0, 8.0, 60.0, /* eye is at (0,0,30) */
|
|
||||||
0.0, 8.0, 0.0, /* center is at (0,0,0) */
|
|
||||||
0.0, 1.0, 0.); /* up is in postivie Y direction */
|
|
||||||
|
|
||||||
glLightModeli(GL_LIGHT_MODEL_LOCAL_VIEWER, 1);
|
|
||||||
glLightfv(GL_LIGHT0, GL_DIFFUSE, lightColor);
|
|
||||||
glLightf(GL_LIGHT0, GL_CONSTANT_ATTENUATION, 0.1);
|
|
||||||
glLightf(GL_LIGHT0, GL_LINEAR_ATTENUATION, 0.05);
|
|
||||||
glEnable(GL_LIGHT0);
|
|
||||||
glEnable(GL_LIGHTING);
|
|
||||||
|
|
||||||
makeFloorTexture();
|
|
||||||
|
|
||||||
/* Setup floor plane for projected shadow calculations. */
|
|
||||||
findPlane(floorPlane, floorVertices[1], floorVertices[2], floorVertices[3]);
|
|
||||||
|
|
||||||
glutMainLoop();
|
|
||||||
|
|
||||||
plDeleteDynamicsWorld(dynamicsWorld);
|
|
||||||
plDeletePhysicsSdk(physicsSdk);
|
|
||||||
|
|
||||||
|
|
||||||
return 0; /* ANSI C requires main to return int. */
|
|
||||||
}
|
|
@ -1,61 +0,0 @@
|
|||||||
# This is basically the overall name of the project in Visual Studio this is the name of the Solution File
|
|
||||||
|
|
||||||
|
|
||||||
# For every executable you have with a main method you should have an add_executable line below.
|
|
||||||
# For every add executable line you should list every .cpp and .h file you have associated with that executable.
|
|
||||||
|
|
||||||
|
|
||||||
# This is the variable for Windows. I use this to define the root of my directory structure.
|
|
||||||
SET(GLUT_ROOT ${BULLET_PHYSICS_SOURCE_DIR}/Glut)
|
|
||||||
|
|
||||||
# You shouldn't have to modify anything below this line
|
|
||||||
########################################################
|
|
||||||
|
|
||||||
|
|
||||||
# This is the shortcut to finding GLU, GLUT and OpenGL if they are properly installed on your system
|
|
||||||
# This should be the case.
|
|
||||||
INCLUDE (${CMAKE_ROOT}/Modules/FindGLU.cmake)
|
|
||||||
INCLUDE (${CMAKE_ROOT}/Modules/FindGLUT.cmake)
|
|
||||||
INCLUDE (${CMAKE_ROOT}/Modules/FindOpenGL.cmake)
|
|
||||||
|
|
||||||
|
|
||||||
IF (WIN32)
|
|
||||||
# This is the Windows code for which Opengl, and Glut are not properly installed
|
|
||||||
# since I can't install them I must cheat and copy libraries around
|
|
||||||
INCLUDE_DIRECTORIES(${GLUT_ROOT})
|
|
||||||
# LINK_DIRECTORIES(${GLUT_ROOT}\\lib)
|
|
||||||
IF (${GLUT_glut_LIBRARY} MATCHES "GLUT_glut_LIBRARY-NOTFOUND")
|
|
||||||
SET(GLUT_glut_LIBRARY ${BULLET_PHYSICS_SOURCE_DIR}/Glut/glut32.lib)
|
|
||||||
# LINK_LIBRARIES(${GLUT_ROOT}\\lib\\glut32 ${OPENGL_gl_LIBRARY} ${OPENGL_glU_LIBRARY})
|
|
||||||
# TARGET_LINK_LIBRARIES(table ${GLUT_ROOT}\\lib\\glut32)
|
|
||||||
#
|
|
||||||
# ADD_CUSTOM_COMMAND(TARGET table POST_BUILD COMMAND copy ${GLUT_ROOT}\\lib\\glut32.dll ${GLUT_ROOT}\\bin\\vs2005\\Debug
|
|
||||||
# COMMAND copy ${GLUT_ROOT}\\lib\\glut32.dll ${GLUT_ROOT}\\bin\\vs2003\\Debug
|
|
||||||
# COMMAND copy ${GLUT_ROOT}\\lib\\glut32.dll ${GLUT_ROOT}\\bin\\vs6\\Debug)
|
|
||||||
ELSE (${GLUT_glut_LIBRARY} MATCHES "GLUT_glut_LIBRARY-NOTFOUND")
|
|
||||||
# LINK_LIBRARIES(${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glU_LIBRARY})
|
|
||||||
# TARGET_LINK_LIBRARIES(table ${GLUT_glut_LIBRARY})
|
|
||||||
ENDIF(${GLUT_glut_LIBRARY} MATCHES "GLUT_glut_LIBRARY-NOTFOUND")
|
|
||||||
# TARGET_LINK_LIBRARIES(table ${OPENGL_gl_LIBRARY})
|
|
||||||
# TARGET_LINK_LIBRARIES(table ${OPENGL_glu_LIBRARY})
|
|
||||||
ELSE (WIN32)
|
|
||||||
# This is the lines for linux. This should always work if everything is installed and working fine.
|
|
||||||
# SET(CMAKE_BUILD_TYPE Debug)
|
|
||||||
# SET(CMAKE_CXX_FLAGS_DEBUG "-g")
|
|
||||||
INCLUDE_DIRECTORIES(/usr/include /usr/local/include ${GLUT_INCLUDE_DIR})
|
|
||||||
# TARGET_LINK_LIBRARIES(table ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glU_LIBRARY})
|
|
||||||
# TARGET_LINK_LIBRARIES(checker ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glU_LIBRARY})
|
|
||||||
ENDIF (WIN32)
|
|
||||||
|
|
||||||
INCLUDE_DIRECTORIES(
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/src ${BULLET_PHYSICS_SOURCE_DIR}/Demos/OpenGL
|
|
||||||
)
|
|
||||||
|
|
||||||
LINK_LIBRARIES(
|
|
||||||
OpenGLSupport BulletDynamics BulletCollision LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glU_LIBRARY}
|
|
||||||
)
|
|
||||||
|
|
||||||
ADD_EXECUTABLE(BulletDino
|
|
||||||
BulletDino.c
|
|
||||||
)
|
|
||||||
|
|
@ -1,180 +0,0 @@
|
|||||||
/*
|
|
||||||
Bullet Continuous Collision Detection and Physics Library
|
|
||||||
Copyright (c) 2003-2010 Erwin Coumans http://continuousphysics.com/Bullet/
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied warranty.
|
|
||||||
In no event will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it freely,
|
|
||||||
subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
|
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#include "BulletXmlImportDemo.h"
|
|
||||||
#include "GlutStuff.h"
|
|
||||||
///btBulletDynamicsCommon.h is the main Bullet include file, contains most common include files.
|
|
||||||
#include "btBulletDynamicsCommon.h"
|
|
||||||
#include "LinearMath/btSerializer.h"
|
|
||||||
#include "btBulletFile.h"
|
|
||||||
#include "btBulletWorldImporter.h"
|
|
||||||
#include "btBulletXmlWorldImporter.h"
|
|
||||||
|
|
||||||
#include "BulletCollision/Gimpact/btGImpactCollisionAlgorithm.h"
|
|
||||||
#include <stdio.h> //printf debugging
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#include "GLDebugDrawer.h"
|
|
||||||
GLDebugDrawer gDebugDrawer;
|
|
||||||
|
|
||||||
|
|
||||||
void BulletXmlImportDemo::initPhysics()
|
|
||||||
{
|
|
||||||
setTexturing(true);
|
|
||||||
setShadows(true);
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
setupEmptyDynamicsWorld();
|
|
||||||
|
|
||||||
|
|
||||||
m_dynamicsWorld->setDebugDrawer(&gDebugDrawer);
|
|
||||||
|
|
||||||
|
|
||||||
btBulletXmlWorldImporter* importer = new btBulletXmlWorldImporter(m_dynamicsWorld);
|
|
||||||
importer->loadFile("bullet_basic.xml");
|
|
||||||
// importer->loadFile("bulletser.xml");
|
|
||||||
// importer->loadFile("bullet_constraints.xml");
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
void BulletXmlImportDemo::clientMoveAndDisplay()
|
|
||||||
{
|
|
||||||
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
|
||||||
|
|
||||||
//simple dynamics world doesn't handle fixed-time-stepping
|
|
||||||
float ms = getDeltaTimeMicroseconds();
|
|
||||||
|
|
||||||
///step the simulation
|
|
||||||
if (m_dynamicsWorld)
|
|
||||||
{
|
|
||||||
|
|
||||||
|
|
||||||
m_dynamicsWorld->stepSimulation(ms / 1000000.f);
|
|
||||||
m_dynamicsWorld->debugDrawWorld();
|
|
||||||
}
|
|
||||||
|
|
||||||
renderme();
|
|
||||||
|
|
||||||
glFlush();
|
|
||||||
|
|
||||||
swapBuffers();
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void BulletXmlImportDemo::displayCallback(void) {
|
|
||||||
|
|
||||||
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
|
||||||
|
|
||||||
|
|
||||||
renderme();
|
|
||||||
|
|
||||||
//optional but useful: debug drawing to detect problems
|
|
||||||
if (m_dynamicsWorld)
|
|
||||||
m_dynamicsWorld->debugDrawWorld();
|
|
||||||
|
|
||||||
glFlush();
|
|
||||||
swapBuffers();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void BulletXmlImportDemo::setupEmptyDynamicsWorld()
|
|
||||||
{
|
|
||||||
m_collisionConfiguration = new btDefaultCollisionConfiguration();
|
|
||||||
|
|
||||||
///use the default collision dispatcher. For parallel processing you can use a diffent dispatcher (see Extras/BulletMultiThreaded)
|
|
||||||
m_dispatcher = new btCollisionDispatcher(m_collisionConfiguration);
|
|
||||||
|
|
||||||
btGImpactCollisionAlgorithm::registerAlgorithm(m_dispatcher);
|
|
||||||
|
|
||||||
m_broadphase = new btDbvtBroadphase();
|
|
||||||
|
|
||||||
///the default constraint solver. For parallel processing you can use a different solver (see Extras/BulletMultiThreaded)
|
|
||||||
btSequentialImpulseConstraintSolver* sol = new btSequentialImpulseConstraintSolver;
|
|
||||||
m_solver = sol;
|
|
||||||
m_dynamicsWorld = new btDiscreteDynamicsWorld(m_dispatcher,m_broadphase,m_solver,m_collisionConfiguration);
|
|
||||||
|
|
||||||
//btGImpactCollisionAlgorithm::registerAlgorithm((btCollisionDispatcher*)m_dynamicsWorld->getDispatcher());
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
BulletXmlImportDemo::~BulletXmlImportDemo()
|
|
||||||
{
|
|
||||||
m_fileLoader->deleteAllData();
|
|
||||||
delete m_fileLoader;
|
|
||||||
exitPhysics();
|
|
||||||
}
|
|
||||||
|
|
||||||
void BulletXmlImportDemo::clientResetScene()
|
|
||||||
{
|
|
||||||
exitPhysics();
|
|
||||||
initPhysics();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void BulletXmlImportDemo::exitPhysics()
|
|
||||||
{
|
|
||||||
|
|
||||||
//cleanup in the reverse order of creation/initialization
|
|
||||||
|
|
||||||
//remove the rigidbodies from the dynamics world and delete them
|
|
||||||
int i;
|
|
||||||
for (i=m_dynamicsWorld->getNumCollisionObjects()-1; i>=0 ;i--)
|
|
||||||
{
|
|
||||||
btCollisionObject* obj = m_dynamicsWorld->getCollisionObjectArray()[i];
|
|
||||||
btRigidBody* body = btRigidBody::upcast(obj);
|
|
||||||
if (body && body->getMotionState())
|
|
||||||
{
|
|
||||||
delete body->getMotionState();
|
|
||||||
}
|
|
||||||
m_dynamicsWorld->removeCollisionObject( obj );
|
|
||||||
delete obj;
|
|
||||||
}
|
|
||||||
|
|
||||||
//delete collision shapes
|
|
||||||
for (int j=0;j<m_collisionShapes.size();j++)
|
|
||||||
{
|
|
||||||
btCollisionShape* shape = m_collisionShapes[j];
|
|
||||||
delete shape;
|
|
||||||
}
|
|
||||||
|
|
||||||
m_collisionShapes.clear();
|
|
||||||
|
|
||||||
delete m_dynamicsWorld;
|
|
||||||
|
|
||||||
delete m_solver;
|
|
||||||
|
|
||||||
delete m_broadphase;
|
|
||||||
|
|
||||||
delete m_dispatcher;
|
|
||||||
|
|
||||||
delete m_collisionConfiguration;
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -1,87 +0,0 @@
|
|||||||
|
|
||||||
/*
|
|
||||||
Bullet Continuous Collision Detection and Physics Library
|
|
||||||
Copyright (c) 2003-2010 Erwin Coumans http://continuousphysics.com/Bullet/
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied warranty.
|
|
||||||
In no event will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it freely,
|
|
||||||
subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
|
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
#ifndef SERIALIZE_DEMO_H
|
|
||||||
#define SERIALIZE_DEMO_H
|
|
||||||
|
|
||||||
#ifdef _WINDOWS
|
|
||||||
#include "Win32DemoApplication.h"
|
|
||||||
#define PlatformDemoApplication Win32DemoApplication
|
|
||||||
#else
|
|
||||||
#include "GlutDemoApplication.h"
|
|
||||||
#define PlatformDemoApplication GlutDemoApplication
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include "LinearMath/btAlignedObjectArray.h"
|
|
||||||
|
|
||||||
class btBroadphaseInterface;
|
|
||||||
class btCollisionShape;
|
|
||||||
class btOverlappingPairCache;
|
|
||||||
class btCollisionDispatcher;
|
|
||||||
class btConstraintSolver;
|
|
||||||
struct btCollisionAlgorithmCreateFunc;
|
|
||||||
class btDefaultCollisionConfiguration;
|
|
||||||
|
|
||||||
///BulletXmlImportDemo shows how to use save and load XML Bullet physics files (work-in-progress)
|
|
||||||
class BulletXmlImportDemo : public PlatformDemoApplication
|
|
||||||
{
|
|
||||||
|
|
||||||
//keep the collision shapes, for deletion/cleanup
|
|
||||||
btAlignedObjectArray<btCollisionShape*> m_collisionShapes;
|
|
||||||
|
|
||||||
btBroadphaseInterface* m_broadphase;
|
|
||||||
|
|
||||||
btCollisionDispatcher* m_dispatcher;
|
|
||||||
|
|
||||||
btConstraintSolver* m_solver;
|
|
||||||
|
|
||||||
btDefaultCollisionConfiguration* m_collisionConfiguration;
|
|
||||||
|
|
||||||
class btBulletWorldImporter* m_fileLoader;
|
|
||||||
|
|
||||||
public:
|
|
||||||
|
|
||||||
BulletXmlImportDemo()
|
|
||||||
{
|
|
||||||
//m_idle=true;
|
|
||||||
setCameraDistance(btScalar(30.));
|
|
||||||
}
|
|
||||||
virtual ~BulletXmlImportDemo();
|
|
||||||
|
|
||||||
virtual void clientResetScene();
|
|
||||||
|
|
||||||
void initPhysics();
|
|
||||||
|
|
||||||
void setupEmptyDynamicsWorld();
|
|
||||||
|
|
||||||
void exitPhysics();
|
|
||||||
|
|
||||||
virtual void clientMoveAndDisplay();
|
|
||||||
|
|
||||||
virtual void displayCallback();
|
|
||||||
|
|
||||||
static DemoApplication* Create()
|
|
||||||
{
|
|
||||||
BulletXmlImportDemo* demo = new BulletXmlImportDemo;
|
|
||||||
demo->myinit();
|
|
||||||
demo->initPhysics();
|
|
||||||
return demo;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif //SERIALIZE_DEMO_H
|
|
||||||
|
|
@ -1,94 +0,0 @@
|
|||||||
# This is basically the overall name of the project in Visual Studio this is the name of the Solution File
|
|
||||||
|
|
||||||
|
|
||||||
# For every executable you have with a main method you should have an add_executable line below.
|
|
||||||
# For every add executable line you should list every .cpp and .h file you have associated with that executable.
|
|
||||||
|
|
||||||
|
|
||||||
# This is the variable for Windows. I use this to define the root of my directory structure.
|
|
||||||
SET(GLUT_ROOT ${BULLET_PHYSICS_SOURCE_DIR}/Glut)
|
|
||||||
|
|
||||||
# You shouldn't have to modify anything below this line
|
|
||||||
########################################################
|
|
||||||
|
|
||||||
|
|
||||||
INCLUDE_DIRECTORIES(
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/src
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/Demos/OpenGL
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/Extras/Serialize/BulletFileLoader
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/Extras/Serialize/BulletWorldImporter
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/Extras/Serialize/BulletXmlWorldImporter
|
|
||||||
)
|
|
||||||
|
|
||||||
ADD_DEFINITIONS(-DDESERIALIZE_SOFT_BODIES)
|
|
||||||
|
|
||||||
IF (USE_GLUT)
|
|
||||||
LINK_LIBRARIES(
|
|
||||||
OpenGLSupport BulletXmlWorldImporter BulletWorldImporter BulletSoftBody BulletDynamics BulletCollision BulletFileLoader LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY}
|
|
||||||
)
|
|
||||||
|
|
||||||
IF (WIN32)
|
|
||||||
ADD_EXECUTABLE(AppBulletXmlImportDemo
|
|
||||||
main.cpp
|
|
||||||
BulletXmlImportDemo.cpp
|
|
||||||
BulletXmlImportDemo.h
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/build/bullet.rc
|
|
||||||
)
|
|
||||||
ELSE()
|
|
||||||
ADD_EXECUTABLE(AppBulletXmlImportDemo
|
|
||||||
main.cpp
|
|
||||||
BulletXmlImportDemo.cpp
|
|
||||||
BulletXmlImportDemo.h
|
|
||||||
)
|
|
||||||
ENDIF()
|
|
||||||
IF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES)
|
|
||||||
IF (WIN32)
|
|
||||||
IF (CMAKE_CL_64)
|
|
||||||
ADD_CUSTOM_COMMAND(
|
|
||||||
TARGET AppBulletXmlImportDemo
|
|
||||||
POST_BUILD
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/glut64.dll ${CMAKE_CURRENT_BINARY_DIR}
|
|
||||||
)
|
|
||||||
ELSE(CMAKE_CL_64)
|
|
||||||
ADD_CUSTOM_COMMAND(
|
|
||||||
TARGET AppBulletXmlImportDemo
|
|
||||||
POST_BUILD
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/GLUT32.DLL ${CMAKE_CURRENT_BINARY_DIR}
|
|
||||||
)
|
|
||||||
ENDIF(CMAKE_CL_64)
|
|
||||||
ENDIF(WIN32)
|
|
||||||
ENDIF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES)
|
|
||||||
|
|
||||||
ELSE (USE_GLUT)
|
|
||||||
|
|
||||||
LINK_LIBRARIES(
|
|
||||||
OpenGLSupport BulletXmlWorldImporter BulletWorldImporter BulletSoftBody BulletDynamics BulletCollision BulletFileLoader LinearMath ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY}
|
|
||||||
)
|
|
||||||
|
|
||||||
ADD_EXECUTABLE(AppBulletXmlImportDemo
|
|
||||||
WIN32
|
|
||||||
../OpenGL/Win32AppMain.cpp
|
|
||||||
Win32BulletXmlImportDemo.cpp
|
|
||||||
BulletXmlImportDemo.cpp
|
|
||||||
BulletXmlImportDemo.h
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/build/bullet.rc
|
|
||||||
)
|
|
||||||
ENDIF (USE_GLUT)
|
|
||||||
|
|
||||||
IF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES AND NOT INTERNAL_UPDATE_SERIALIZATION_STRUCTURES)
|
|
||||||
ADD_CUSTOM_COMMAND(
|
|
||||||
TARGET AppBulletXmlImportDemo
|
|
||||||
POST_BUILD
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/Demos/BulletXmlImportDemo/bullet_basic.xml ${CMAKE_CURRENT_BINARY_DIR}/bullet_basic.xml
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/Demos/BulletXmlImportDemo/bullet_basic.xml ${CMAKE_CURRENT_BINARY_DIR}/Debug/bullet_basic.xml
|
|
||||||
)
|
|
||||||
ENDIF ()
|
|
||||||
|
|
||||||
|
|
||||||
IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES)
|
|
||||||
SET_TARGET_PROPERTIES(AppBulletXmlImportDemo PROPERTIES DEBUG_POSTFIX "_Debug")
|
|
||||||
SET_TARGET_PROPERTIES(AppBulletXmlImportDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel")
|
|
||||||
SET_TARGET_PROPERTIES(AppBulletXmlImportDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo")
|
|
||||||
ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES)
|
|
||||||
|
|
||||||
|
|
@ -1,25 +0,0 @@
|
|||||||
#ifdef _WINDOWS
|
|
||||||
/*
|
|
||||||
Bullet Continuous Collision Detection and Physics Library
|
|
||||||
Copyright (c) 2003-2010 Erwin Coumans http://bulletphysics.org
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied warranty.
|
|
||||||
In no event will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it freely,
|
|
||||||
subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
|
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "BulletXmlImportDemo.h"
|
|
||||||
|
|
||||||
///The 'createDemo' function is called from Bullet/Demos/OpenGL/Win32AppMain.cpp to instantiate this particular demo
|
|
||||||
DemoApplication* createDemo()
|
|
||||||
{
|
|
||||||
return new BulletXmlImportDemo();
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
|
@ -1,668 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<bullet_physics version=281 itemcount = 9>
|
|
||||||
<btDynamicsWorldFloatData pointer=2>
|
|
||||||
<m_solverInfo type="btContactSolverInfoFloatData">
|
|
||||||
<m_tau type="float"> 0.600000 </m_tau>
|
|
||||||
<m_damping type="float"> 1.000000 </m_damping>
|
|
||||||
<m_friction type="float"> 0.300000 </m_friction>
|
|
||||||
<m_timeStep type="float"> 0.016667 </m_timeStep>
|
|
||||||
<m_restitution type="float"> 0.000000 </m_restitution>
|
|
||||||
<m_maxErrorReduction type="float"> 20.000000 </m_maxErrorReduction>
|
|
||||||
<m_sor type="float"> 1.000000 </m_sor>
|
|
||||||
<m_erp type="float"> 0.200000 </m_erp>
|
|
||||||
<m_erp2 type="float"> 0.800000 </m_erp2>
|
|
||||||
<m_globalCfm type="float"> 0.000000 </m_globalCfm>
|
|
||||||
<m_splitImpulsePenetrationThreshold type="float"> -0.040000 </m_splitImpulsePenetrationThreshold>
|
|
||||||
<m_splitImpulseTurnErp type="float"> 0.100000 </m_splitImpulseTurnErp>
|
|
||||||
<m_linearSlop type="float"> 0.000000 </m_linearSlop>
|
|
||||||
<m_warmstartingFactor type="float"> 0.850000 </m_warmstartingFactor>
|
|
||||||
<m_maxGyroscopicForce type="float"> 100.000000 </m_maxGyroscopicForce>
|
|
||||||
<m_singleAxisRollingFrictionThreshold type="float"> 1000000015047466200000000000000.000000 </m_singleAxisRollingFrictionThreshold>
|
|
||||||
<m_numIterations type="int"> 10 </m_numIterations>
|
|
||||||
<m_solverMode type="int"> 260 </m_solverMode>
|
|
||||||
<m_restingContactRestitutionThreshold type="int"> 2 </m_restingContactRestitutionThreshold>
|
|
||||||
<m_minimumSolverBatchSize type="int"> 128 </m_minimumSolverBatchSize>
|
|
||||||
<m_splitImpulse type="int"> 1 </m_splitImpulse>
|
|
||||||
<m_padding type="char" count=4> 0 0 0 0 </m_padding>
|
|
||||||
</m_solverInfo>
|
|
||||||
<m_gravity type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 -10.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_gravity>
|
|
||||||
</btDynamicsWorldFloatData>
|
|
||||||
<btRigidBodyFloatData pointer=4>
|
|
||||||
<m_collisionObjectData type="btCollisionObjectFloatData">
|
|
||||||
<m_broadphaseHandle type="pointer"> 0 </m_broadphaseHandle>
|
|
||||||
<m_collisionShape type="pointer"> 3 </m_collisionShape>
|
|
||||||
<m_rootCollisionShape type="pointer"> 0 </m_rootCollisionShape>
|
|
||||||
<m_name type="pointer"> 0 </m_name>
|
|
||||||
<m_worldTransform type="btTransformFloatData">
|
|
||||||
<m_basis type="btMatrix3x3FloatData">
|
|
||||||
<m_el type="btVector3FloatData" count=3>
|
|
||||||
<m_floats type="float" count=4> 1.000000 0.000000 0.000000 0.000000 </m_floats>
|
|
||||||
<m_floats type="float" count=4> 0.000000 1.000000 0.000000 0.000000 </m_floats>
|
|
||||||
<m_floats type="float" count=4> 0.000000 0.000000 1.000000 0.000000 </m_floats>
|
|
||||||
</m_el>
|
|
||||||
</m_basis>
|
|
||||||
<m_origin type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 -50.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_origin>
|
|
||||||
</m_worldTransform>
|
|
||||||
<m_interpolationWorldTransform type="btTransformFloatData">
|
|
||||||
<m_basis type="btMatrix3x3FloatData">
|
|
||||||
<m_el type="btVector3FloatData" count=3>
|
|
||||||
<m_floats type="float" count=4> 1.000000 0.000000 0.000000 0.000000 </m_floats>
|
|
||||||
<m_floats type="float" count=4> 0.000000 1.000000 0.000000 0.000000 </m_floats>
|
|
||||||
<m_floats type="float" count=4> 0.000000 0.000000 1.000000 0.000000 </m_floats>
|
|
||||||
</m_el>
|
|
||||||
</m_basis>
|
|
||||||
<m_origin type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 0.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_origin>
|
|
||||||
</m_interpolationWorldTransform>
|
|
||||||
<m_interpolationLinearVelocity type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 0.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_interpolationLinearVelocity>
|
|
||||||
<m_interpolationAngularVelocity type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 0.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_interpolationAngularVelocity>
|
|
||||||
<m_anisotropicFriction type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 1.000000 1.000000 1.000000 0.000000 </m_floats>
|
|
||||||
</m_anisotropicFriction>
|
|
||||||
<m_contactProcessingThreshold type="float"> 999999984306749440.000000 </m_contactProcessingThreshold>
|
|
||||||
<m_deactivationTime type="float"> 0.000000 </m_deactivationTime>
|
|
||||||
<m_friction type="float"> 0.500000 </m_friction>
|
|
||||||
<m_rollingFriction type="float"> -431602080.000000 </m_rollingFriction>
|
|
||||||
<m_restitution type="float"> 0.000000 </m_restitution>
|
|
||||||
<m_hitFraction type="float"> 1.000000 </m_hitFraction>
|
|
||||||
<m_ccdSweptSphereRadius type="float"> 0.000000 </m_ccdSweptSphereRadius>
|
|
||||||
<m_ccdMotionThreshold type="float"> 0.000000 </m_ccdMotionThreshold>
|
|
||||||
<m_hasAnisotropicFriction type="int"> 0 </m_hasAnisotropicFriction>
|
|
||||||
<m_collisionFlags type="int"> 1 </m_collisionFlags>
|
|
||||||
<m_islandTag1 type="int"> -1 </m_islandTag1>
|
|
||||||
<m_companionId type="int"> -2 </m_companionId>
|
|
||||||
<m_activationState1 type="int"> 2 </m_activationState1>
|
|
||||||
<m_internalType type="int"> 2 </m_internalType>
|
|
||||||
<m_checkCollideWith type="int"> 0 </m_checkCollideWith>
|
|
||||||
<m_padding type="char" count=4> -51 -51 -51 -51 </m_padding>
|
|
||||||
</m_collisionObjectData>
|
|
||||||
<m_invInertiaTensorWorld type="btMatrix3x3FloatData">
|
|
||||||
<m_el type="btVector3FloatData" count=3>
|
|
||||||
<m_floats type="float" count=4> 0.000000 0.000000 0.000000 0.000000 </m_floats>
|
|
||||||
<m_floats type="float" count=4> 0.000000 0.000000 0.000000 0.000000 </m_floats>
|
|
||||||
<m_floats type="float" count=4> 0.000000 0.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_el>
|
|
||||||
</m_invInertiaTensorWorld>
|
|
||||||
<m_linearVelocity type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 0.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_linearVelocity>
|
|
||||||
<m_angularVelocity type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 0.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_angularVelocity>
|
|
||||||
<m_angularFactor type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 1.000000 1.000000 1.000000 0.000000 </m_floats>
|
|
||||||
</m_angularFactor>
|
|
||||||
<m_linearFactor type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 1.000000 1.000000 1.000000 0.000000 </m_floats>
|
|
||||||
</m_linearFactor>
|
|
||||||
<m_gravity type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 0.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_gravity>
|
|
||||||
<m_gravity_acceleration type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 0.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_gravity_acceleration>
|
|
||||||
<m_invInertiaLocal type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 0.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_invInertiaLocal>
|
|
||||||
<m_totalForce type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 0.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_totalForce>
|
|
||||||
<m_totalTorque type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 0.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_totalTorque>
|
|
||||||
<m_inverseMass type="float"> 0.000000 </m_inverseMass>
|
|
||||||
<m_linearDamping type="float"> 0.000000 </m_linearDamping>
|
|
||||||
<m_angularDamping type="float"> 0.000000 </m_angularDamping>
|
|
||||||
<m_additionalDampingFactor type="float"> 0.005000 </m_additionalDampingFactor>
|
|
||||||
<m_additionalLinearDampingThresholdSqr type="float"> 0.010000 </m_additionalLinearDampingThresholdSqr>
|
|
||||||
<m_additionalAngularDampingThresholdSqr type="float"> 0.010000 </m_additionalAngularDampingThresholdSqr>
|
|
||||||
<m_additionalAngularDampingFactor type="float"> 0.010000 </m_additionalAngularDampingFactor>
|
|
||||||
<m_linearSleepingThreshold type="float"> 0.800000 </m_linearSleepingThreshold>
|
|
||||||
<m_angularSleepingThreshold type="float"> 1.000000 </m_angularSleepingThreshold>
|
|
||||||
<m_additionalDamping type="int"> 0 </m_additionalDamping>
|
|
||||||
</btRigidBodyFloatData>
|
|
||||||
<btRigidBodyFloatData pointer=6>
|
|
||||||
<m_collisionObjectData type="btCollisionObjectFloatData">
|
|
||||||
<m_broadphaseHandle type="pointer"> 0 </m_broadphaseHandle>
|
|
||||||
<m_collisionShape type="pointer"> 5 </m_collisionShape>
|
|
||||||
<m_rootCollisionShape type="pointer"> 0 </m_rootCollisionShape>
|
|
||||||
<m_name type="pointer"> 0 </m_name>
|
|
||||||
<m_worldTransform type="btTransformFloatData">
|
|
||||||
<m_basis type="btMatrix3x3FloatData">
|
|
||||||
<m_el type="btVector3FloatData" count=3>
|
|
||||||
<m_floats type="float" count=4> 1.000000 0.000000 0.000000 0.000000 </m_floats>
|
|
||||||
<m_floats type="float" count=4> 0.000000 1.000000 0.000000 0.000000 </m_floats>
|
|
||||||
<m_floats type="float" count=4> 0.000000 0.000000 1.000000 0.000000 </m_floats>
|
|
||||||
</m_el>
|
|
||||||
</m_basis>
|
|
||||||
<m_origin type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> -5.000000 14.166666 -3.000000 0.000000 </m_floats>
|
|
||||||
</m_origin>
|
|
||||||
</m_worldTransform>
|
|
||||||
<m_interpolationWorldTransform type="btTransformFloatData">
|
|
||||||
<m_basis type="btMatrix3x3FloatData">
|
|
||||||
<m_el type="btVector3FloatData" count=3>
|
|
||||||
<m_floats type="float" count=4> 1.000000 0.000000 0.000000 0.000000 </m_floats>
|
|
||||||
<m_floats type="float" count=4> 0.000000 1.000000 0.000000 0.000000 </m_floats>
|
|
||||||
<m_floats type="float" count=4> 0.000000 0.000000 1.000000 0.000000 </m_floats>
|
|
||||||
</m_el>
|
|
||||||
</m_basis>
|
|
||||||
<m_origin type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> -5.000000 14.166666 -3.000000 0.000000 </m_floats>
|
|
||||||
</m_origin>
|
|
||||||
</m_interpolationWorldTransform>
|
|
||||||
<m_interpolationLinearVelocity type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 -4.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_interpolationLinearVelocity>
|
|
||||||
<m_interpolationAngularVelocity type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 0.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_interpolationAngularVelocity>
|
|
||||||
<m_anisotropicFriction type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 1.000000 1.000000 1.000000 0.000000 </m_floats>
|
|
||||||
</m_anisotropicFriction>
|
|
||||||
<m_contactProcessingThreshold type="float"> 999999984306749440.000000 </m_contactProcessingThreshold>
|
|
||||||
<m_deactivationTime type="float"> 0.000000 </m_deactivationTime>
|
|
||||||
<m_friction type="float"> 0.500000 </m_friction>
|
|
||||||
<m_rollingFriction type="float"> -431602080.000000 </m_rollingFriction>
|
|
||||||
<m_restitution type="float"> 0.000000 </m_restitution>
|
|
||||||
<m_hitFraction type="float"> 1.000000 </m_hitFraction>
|
|
||||||
<m_ccdSweptSphereRadius type="float"> 0.000000 </m_ccdSweptSphereRadius>
|
|
||||||
<m_ccdMotionThreshold type="float"> 0.000000 </m_ccdMotionThreshold>
|
|
||||||
<m_hasAnisotropicFriction type="int"> 0 </m_hasAnisotropicFriction>
|
|
||||||
<m_collisionFlags type="int"> 0 </m_collisionFlags>
|
|
||||||
<m_islandTag1 type="int"> 4 </m_islandTag1>
|
|
||||||
<m_companionId type="int"> -1 </m_companionId>
|
|
||||||
<m_activationState1 type="int"> 1 </m_activationState1>
|
|
||||||
<m_internalType type="int"> 2 </m_internalType>
|
|
||||||
<m_checkCollideWith type="int"> 0 </m_checkCollideWith>
|
|
||||||
<m_padding type="char" count=4> -51 -51 -51 -51 </m_padding>
|
|
||||||
</m_collisionObjectData>
|
|
||||||
<m_invInertiaTensorWorld type="btMatrix3x3FloatData">
|
|
||||||
<m_el type="btVector3FloatData" count=3>
|
|
||||||
<m_floats type="float" count=4> 1.500000 0.000000 0.000000 0.000000 </m_floats>
|
|
||||||
<m_floats type="float" count=4> 0.000000 1.500000 0.000000 0.000000 </m_floats>
|
|
||||||
<m_floats type="float" count=4> 0.000000 0.000000 1.500000 0.000000 </m_floats>
|
|
||||||
</m_el>
|
|
||||||
</m_invInertiaTensorWorld>
|
|
||||||
<m_linearVelocity type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 -4.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_linearVelocity>
|
|
||||||
<m_angularVelocity type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 0.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_angularVelocity>
|
|
||||||
<m_angularFactor type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 1.000000 1.000000 1.000000 0.000000 </m_floats>
|
|
||||||
</m_angularFactor>
|
|
||||||
<m_linearFactor type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 1.000000 1.000000 1.000000 0.000000 </m_floats>
|
|
||||||
</m_linearFactor>
|
|
||||||
<m_gravity type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 -10.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_gravity>
|
|
||||||
<m_gravity_acceleration type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 -10.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_gravity_acceleration>
|
|
||||||
<m_invInertiaLocal type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 1.500000 1.500000 1.500000 0.000000 </m_floats>
|
|
||||||
</m_invInertiaLocal>
|
|
||||||
<m_totalForce type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 0.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_totalForce>
|
|
||||||
<m_totalTorque type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 0.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_totalTorque>
|
|
||||||
<m_inverseMass type="float"> 1.000000 </m_inverseMass>
|
|
||||||
<m_linearDamping type="float"> 0.000000 </m_linearDamping>
|
|
||||||
<m_angularDamping type="float"> 0.000000 </m_angularDamping>
|
|
||||||
<m_additionalDampingFactor type="float"> 0.005000 </m_additionalDampingFactor>
|
|
||||||
<m_additionalLinearDampingThresholdSqr type="float"> 0.010000 </m_additionalLinearDampingThresholdSqr>
|
|
||||||
<m_additionalAngularDampingThresholdSqr type="float"> 0.010000 </m_additionalAngularDampingThresholdSqr>
|
|
||||||
<m_additionalAngularDampingFactor type="float"> 0.010000 </m_additionalAngularDampingFactor>
|
|
||||||
<m_linearSleepingThreshold type="float"> 0.800000 </m_linearSleepingThreshold>
|
|
||||||
<m_angularSleepingThreshold type="float"> 1.000000 </m_angularSleepingThreshold>
|
|
||||||
<m_additionalDamping type="int"> 0 </m_additionalDamping>
|
|
||||||
</btRigidBodyFloatData>
|
|
||||||
<btRigidBodyFloatData pointer=7>
|
|
||||||
<m_collisionObjectData type="btCollisionObjectFloatData">
|
|
||||||
<m_broadphaseHandle type="pointer"> 0 </m_broadphaseHandle>
|
|
||||||
<m_collisionShape type="pointer"> 5 </m_collisionShape>
|
|
||||||
<m_rootCollisionShape type="pointer"> 0 </m_rootCollisionShape>
|
|
||||||
<m_name type="pointer"> 0 </m_name>
|
|
||||||
<m_worldTransform type="btTransformFloatData">
|
|
||||||
<m_basis type="btMatrix3x3FloatData">
|
|
||||||
<m_el type="btVector3FloatData" count=3>
|
|
||||||
<m_floats type="float" count=4> 1.000000 0.000000 0.000000 0.000000 </m_floats>
|
|
||||||
<m_floats type="float" count=4> 0.000000 1.000000 0.000000 0.000000 </m_floats>
|
|
||||||
<m_floats type="float" count=4> 0.000000 0.000000 1.000000 0.000000 </m_floats>
|
|
||||||
</m_el>
|
|
||||||
</m_basis>
|
|
||||||
<m_origin type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> -5.000000 16.166668 -3.000000 0.000000 </m_floats>
|
|
||||||
</m_origin>
|
|
||||||
</m_worldTransform>
|
|
||||||
<m_interpolationWorldTransform type="btTransformFloatData">
|
|
||||||
<m_basis type="btMatrix3x3FloatData">
|
|
||||||
<m_el type="btVector3FloatData" count=3>
|
|
||||||
<m_floats type="float" count=4> 1.000000 0.000000 0.000000 0.000000 </m_floats>
|
|
||||||
<m_floats type="float" count=4> 0.000000 1.000000 0.000000 0.000000 </m_floats>
|
|
||||||
<m_floats type="float" count=4> 0.000000 0.000000 1.000000 0.000000 </m_floats>
|
|
||||||
</m_el>
|
|
||||||
</m_basis>
|
|
||||||
<m_origin type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> -5.000000 16.166668 -3.000000 0.000000 </m_floats>
|
|
||||||
</m_origin>
|
|
||||||
</m_interpolationWorldTransform>
|
|
||||||
<m_interpolationLinearVelocity type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 -4.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_interpolationLinearVelocity>
|
|
||||||
<m_interpolationAngularVelocity type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 0.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_interpolationAngularVelocity>
|
|
||||||
<m_anisotropicFriction type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 1.000000 1.000000 1.000000 0.000000 </m_floats>
|
|
||||||
</m_anisotropicFriction>
|
|
||||||
<m_contactProcessingThreshold type="float"> 999999984306749440.000000 </m_contactProcessingThreshold>
|
|
||||||
<m_deactivationTime type="float"> 0.000000 </m_deactivationTime>
|
|
||||||
<m_friction type="float"> 0.500000 </m_friction>
|
|
||||||
<m_rollingFriction type="float"> -431602080.000000 </m_rollingFriction>
|
|
||||||
<m_restitution type="float"> 0.000000 </m_restitution>
|
|
||||||
<m_hitFraction type="float"> 1.000000 </m_hitFraction>
|
|
||||||
<m_ccdSweptSphereRadius type="float"> 0.000000 </m_ccdSweptSphereRadius>
|
|
||||||
<m_ccdMotionThreshold type="float"> 0.000000 </m_ccdMotionThreshold>
|
|
||||||
<m_hasAnisotropicFriction type="int"> 0 </m_hasAnisotropicFriction>
|
|
||||||
<m_collisionFlags type="int"> 0 </m_collisionFlags>
|
|
||||||
<m_islandTag1 type="int"> 4 </m_islandTag1>
|
|
||||||
<m_companionId type="int"> -1 </m_companionId>
|
|
||||||
<m_activationState1 type="int"> 1 </m_activationState1>
|
|
||||||
<m_internalType type="int"> 2 </m_internalType>
|
|
||||||
<m_checkCollideWith type="int"> 0 </m_checkCollideWith>
|
|
||||||
<m_padding type="char" count=4> -51 -51 -51 -51 </m_padding>
|
|
||||||
</m_collisionObjectData>
|
|
||||||
<m_invInertiaTensorWorld type="btMatrix3x3FloatData">
|
|
||||||
<m_el type="btVector3FloatData" count=3>
|
|
||||||
<m_floats type="float" count=4> 1.500000 0.000000 0.000000 0.000000 </m_floats>
|
|
||||||
<m_floats type="float" count=4> 0.000000 1.500000 0.000000 0.000000 </m_floats>
|
|
||||||
<m_floats type="float" count=4> 0.000000 0.000000 1.500000 0.000000 </m_floats>
|
|
||||||
</m_el>
|
|
||||||
</m_invInertiaTensorWorld>
|
|
||||||
<m_linearVelocity type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 -4.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_linearVelocity>
|
|
||||||
<m_angularVelocity type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 0.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_angularVelocity>
|
|
||||||
<m_angularFactor type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 1.000000 1.000000 1.000000 0.000000 </m_floats>
|
|
||||||
</m_angularFactor>
|
|
||||||
<m_linearFactor type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 1.000000 1.000000 1.000000 0.000000 </m_floats>
|
|
||||||
</m_linearFactor>
|
|
||||||
<m_gravity type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 -10.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_gravity>
|
|
||||||
<m_gravity_acceleration type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 -10.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_gravity_acceleration>
|
|
||||||
<m_invInertiaLocal type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 1.500000 1.500000 1.500000 0.000000 </m_floats>
|
|
||||||
</m_invInertiaLocal>
|
|
||||||
<m_totalForce type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 0.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_totalForce>
|
|
||||||
<m_totalTorque type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 0.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_totalTorque>
|
|
||||||
<m_inverseMass type="float"> 1.000000 </m_inverseMass>
|
|
||||||
<m_linearDamping type="float"> 0.000000 </m_linearDamping>
|
|
||||||
<m_angularDamping type="float"> 0.000000 </m_angularDamping>
|
|
||||||
<m_additionalDampingFactor type="float"> 0.005000 </m_additionalDampingFactor>
|
|
||||||
<m_additionalLinearDampingThresholdSqr type="float"> 0.010000 </m_additionalLinearDampingThresholdSqr>
|
|
||||||
<m_additionalAngularDampingThresholdSqr type="float"> 0.010000 </m_additionalAngularDampingThresholdSqr>
|
|
||||||
<m_additionalAngularDampingFactor type="float"> 0.010000 </m_additionalAngularDampingFactor>
|
|
||||||
<m_linearSleepingThreshold type="float"> 0.800000 </m_linearSleepingThreshold>
|
|
||||||
<m_angularSleepingThreshold type="float"> 1.000000 </m_angularSleepingThreshold>
|
|
||||||
<m_additionalDamping type="int"> 0 </m_additionalDamping>
|
|
||||||
</btRigidBodyFloatData>
|
|
||||||
<btRigidBodyFloatData pointer=8>
|
|
||||||
<m_collisionObjectData type="btCollisionObjectFloatData">
|
|
||||||
<m_broadphaseHandle type="pointer"> 0 </m_broadphaseHandle>
|
|
||||||
<m_collisionShape type="pointer"> 5 </m_collisionShape>
|
|
||||||
<m_rootCollisionShape type="pointer"> 0 </m_rootCollisionShape>
|
|
||||||
<m_name type="pointer"> 0 </m_name>
|
|
||||||
<m_worldTransform type="btTransformFloatData">
|
|
||||||
<m_basis type="btMatrix3x3FloatData">
|
|
||||||
<m_el type="btVector3FloatData" count=3>
|
|
||||||
<m_floats type="float" count=4> 1.000000 0.000000 0.000000 0.000000 </m_floats>
|
|
||||||
<m_floats type="float" count=4> 0.000000 1.000000 0.000000 0.000000 </m_floats>
|
|
||||||
<m_floats type="float" count=4> 0.000000 0.000000 1.000000 0.000000 </m_floats>
|
|
||||||
</m_el>
|
|
||||||
</m_basis>
|
|
||||||
<m_origin type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> -5.000000 18.166668 -3.000000 0.000000 </m_floats>
|
|
||||||
</m_origin>
|
|
||||||
</m_worldTransform>
|
|
||||||
<m_interpolationWorldTransform type="btTransformFloatData">
|
|
||||||
<m_basis type="btMatrix3x3FloatData">
|
|
||||||
<m_el type="btVector3FloatData" count=3>
|
|
||||||
<m_floats type="float" count=4> 1.000000 0.000000 0.000000 0.000000 </m_floats>
|
|
||||||
<m_floats type="float" count=4> 0.000000 1.000000 0.000000 0.000000 </m_floats>
|
|
||||||
<m_floats type="float" count=4> 0.000000 0.000000 1.000000 0.000000 </m_floats>
|
|
||||||
</m_el>
|
|
||||||
</m_basis>
|
|
||||||
<m_origin type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> -5.000000 18.166668 -3.000000 0.000000 </m_floats>
|
|
||||||
</m_origin>
|
|
||||||
</m_interpolationWorldTransform>
|
|
||||||
<m_interpolationLinearVelocity type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 -4.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_interpolationLinearVelocity>
|
|
||||||
<m_interpolationAngularVelocity type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 0.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_interpolationAngularVelocity>
|
|
||||||
<m_anisotropicFriction type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 1.000000 1.000000 1.000000 0.000000 </m_floats>
|
|
||||||
</m_anisotropicFriction>
|
|
||||||
<m_contactProcessingThreshold type="float"> 999999984306749440.000000 </m_contactProcessingThreshold>
|
|
||||||
<m_deactivationTime type="float"> 0.000000 </m_deactivationTime>
|
|
||||||
<m_friction type="float"> 0.500000 </m_friction>
|
|
||||||
<m_rollingFriction type="float"> -431602080.000000 </m_rollingFriction>
|
|
||||||
<m_restitution type="float"> 0.000000 </m_restitution>
|
|
||||||
<m_hitFraction type="float"> 1.000000 </m_hitFraction>
|
|
||||||
<m_ccdSweptSphereRadius type="float"> 0.000000 </m_ccdSweptSphereRadius>
|
|
||||||
<m_ccdMotionThreshold type="float"> 0.000000 </m_ccdMotionThreshold>
|
|
||||||
<m_hasAnisotropicFriction type="int"> 0 </m_hasAnisotropicFriction>
|
|
||||||
<m_collisionFlags type="int"> 0 </m_collisionFlags>
|
|
||||||
<m_islandTag1 type="int"> 4 </m_islandTag1>
|
|
||||||
<m_companionId type="int"> -1 </m_companionId>
|
|
||||||
<m_activationState1 type="int"> 1 </m_activationState1>
|
|
||||||
<m_internalType type="int"> 2 </m_internalType>
|
|
||||||
<m_checkCollideWith type="int"> 0 </m_checkCollideWith>
|
|
||||||
<m_padding type="char" count=4> -51 -51 -51 -51 </m_padding>
|
|
||||||
</m_collisionObjectData>
|
|
||||||
<m_invInertiaTensorWorld type="btMatrix3x3FloatData">
|
|
||||||
<m_el type="btVector3FloatData" count=3>
|
|
||||||
<m_floats type="float" count=4> 1.500000 0.000000 0.000000 0.000000 </m_floats>
|
|
||||||
<m_floats type="float" count=4> 0.000000 1.500000 0.000000 0.000000 </m_floats>
|
|
||||||
<m_floats type="float" count=4> 0.000000 0.000000 1.500000 0.000000 </m_floats>
|
|
||||||
</m_el>
|
|
||||||
</m_invInertiaTensorWorld>
|
|
||||||
<m_linearVelocity type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 -4.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_linearVelocity>
|
|
||||||
<m_angularVelocity type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 0.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_angularVelocity>
|
|
||||||
<m_angularFactor type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 1.000000 1.000000 1.000000 0.000000 </m_floats>
|
|
||||||
</m_angularFactor>
|
|
||||||
<m_linearFactor type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 1.000000 1.000000 1.000000 0.000000 </m_floats>
|
|
||||||
</m_linearFactor>
|
|
||||||
<m_gravity type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 -10.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_gravity>
|
|
||||||
<m_gravity_acceleration type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 -10.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_gravity_acceleration>
|
|
||||||
<m_invInertiaLocal type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 1.500000 1.500000 1.500000 0.000000 </m_floats>
|
|
||||||
</m_invInertiaLocal>
|
|
||||||
<m_totalForce type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 0.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_totalForce>
|
|
||||||
<m_totalTorque type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 0.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_totalTorque>
|
|
||||||
<m_inverseMass type="float"> 1.000000 </m_inverseMass>
|
|
||||||
<m_linearDamping type="float"> 0.000000 </m_linearDamping>
|
|
||||||
<m_angularDamping type="float"> 0.000000 </m_angularDamping>
|
|
||||||
<m_additionalDampingFactor type="float"> 0.005000 </m_additionalDampingFactor>
|
|
||||||
<m_additionalLinearDampingThresholdSqr type="float"> 0.010000 </m_additionalLinearDampingThresholdSqr>
|
|
||||||
<m_additionalAngularDampingThresholdSqr type="float"> 0.010000 </m_additionalAngularDampingThresholdSqr>
|
|
||||||
<m_additionalAngularDampingFactor type="float"> 0.010000 </m_additionalAngularDampingFactor>
|
|
||||||
<m_linearSleepingThreshold type="float"> 0.800000 </m_linearSleepingThreshold>
|
|
||||||
<m_angularSleepingThreshold type="float"> 1.000000 </m_angularSleepingThreshold>
|
|
||||||
<m_additionalDamping type="int"> 0 </m_additionalDamping>
|
|
||||||
</btRigidBodyFloatData>
|
|
||||||
<btRigidBodyFloatData pointer=9>
|
|
||||||
<m_collisionObjectData type="btCollisionObjectFloatData">
|
|
||||||
<m_broadphaseHandle type="pointer"> 0 </m_broadphaseHandle>
|
|
||||||
<m_collisionShape type="pointer"> 5 </m_collisionShape>
|
|
||||||
<m_rootCollisionShape type="pointer"> 0 </m_rootCollisionShape>
|
|
||||||
<m_name type="pointer"> 0 </m_name>
|
|
||||||
<m_worldTransform type="btTransformFloatData">
|
|
||||||
<m_basis type="btMatrix3x3FloatData">
|
|
||||||
<m_el type="btVector3FloatData" count=3>
|
|
||||||
<m_floats type="float" count=4> 1.000000 0.000000 0.000000 0.000000 </m_floats>
|
|
||||||
<m_floats type="float" count=4> 0.000000 1.000000 0.000000 0.000000 </m_floats>
|
|
||||||
<m_floats type="float" count=4> 0.000000 0.000000 1.000000 0.000000 </m_floats>
|
|
||||||
</m_el>
|
|
||||||
</m_basis>
|
|
||||||
<m_origin type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> -5.000000 20.166668 -3.000000 0.000000 </m_floats>
|
|
||||||
</m_origin>
|
|
||||||
</m_worldTransform>
|
|
||||||
<m_interpolationWorldTransform type="btTransformFloatData">
|
|
||||||
<m_basis type="btMatrix3x3FloatData">
|
|
||||||
<m_el type="btVector3FloatData" count=3>
|
|
||||||
<m_floats type="float" count=4> 1.000000 0.000000 0.000000 0.000000 </m_floats>
|
|
||||||
<m_floats type="float" count=4> 0.000000 1.000000 0.000000 0.000000 </m_floats>
|
|
||||||
<m_floats type="float" count=4> 0.000000 0.000000 1.000000 0.000000 </m_floats>
|
|
||||||
</m_el>
|
|
||||||
</m_basis>
|
|
||||||
<m_origin type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> -5.000000 20.166668 -3.000000 0.000000 </m_floats>
|
|
||||||
</m_origin>
|
|
||||||
</m_interpolationWorldTransform>
|
|
||||||
<m_interpolationLinearVelocity type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 -4.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_interpolationLinearVelocity>
|
|
||||||
<m_interpolationAngularVelocity type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 0.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_interpolationAngularVelocity>
|
|
||||||
<m_anisotropicFriction type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 1.000000 1.000000 1.000000 0.000000 </m_floats>
|
|
||||||
</m_anisotropicFriction>
|
|
||||||
<m_contactProcessingThreshold type="float"> 999999984306749440.000000 </m_contactProcessingThreshold>
|
|
||||||
<m_deactivationTime type="float"> 0.000000 </m_deactivationTime>
|
|
||||||
<m_friction type="float"> 0.500000 </m_friction>
|
|
||||||
<m_rollingFriction type="float"> -431602080.000000 </m_rollingFriction>
|
|
||||||
<m_restitution type="float"> 0.000000 </m_restitution>
|
|
||||||
<m_hitFraction type="float"> 1.000000 </m_hitFraction>
|
|
||||||
<m_ccdSweptSphereRadius type="float"> 0.000000 </m_ccdSweptSphereRadius>
|
|
||||||
<m_ccdMotionThreshold type="float"> 0.000000 </m_ccdMotionThreshold>
|
|
||||||
<m_hasAnisotropicFriction type="int"> 0 </m_hasAnisotropicFriction>
|
|
||||||
<m_collisionFlags type="int"> 0 </m_collisionFlags>
|
|
||||||
<m_islandTag1 type="int"> 4 </m_islandTag1>
|
|
||||||
<m_companionId type="int"> -1 </m_companionId>
|
|
||||||
<m_activationState1 type="int"> 1 </m_activationState1>
|
|
||||||
<m_internalType type="int"> 2 </m_internalType>
|
|
||||||
<m_checkCollideWith type="int"> 0 </m_checkCollideWith>
|
|
||||||
<m_padding type="char" count=4> -51 -51 -51 -51 </m_padding>
|
|
||||||
</m_collisionObjectData>
|
|
||||||
<m_invInertiaTensorWorld type="btMatrix3x3FloatData">
|
|
||||||
<m_el type="btVector3FloatData" count=3>
|
|
||||||
<m_floats type="float" count=4> 1.500000 0.000000 0.000000 0.000000 </m_floats>
|
|
||||||
<m_floats type="float" count=4> 0.000000 1.500000 0.000000 0.000000 </m_floats>
|
|
||||||
<m_floats type="float" count=4> 0.000000 0.000000 1.500000 0.000000 </m_floats>
|
|
||||||
</m_el>
|
|
||||||
</m_invInertiaTensorWorld>
|
|
||||||
<m_linearVelocity type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 -4.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_linearVelocity>
|
|
||||||
<m_angularVelocity type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 0.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_angularVelocity>
|
|
||||||
<m_angularFactor type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 1.000000 1.000000 1.000000 0.000000 </m_floats>
|
|
||||||
</m_angularFactor>
|
|
||||||
<m_linearFactor type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 1.000000 1.000000 1.000000 0.000000 </m_floats>
|
|
||||||
</m_linearFactor>
|
|
||||||
<m_gravity type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 -10.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_gravity>
|
|
||||||
<m_gravity_acceleration type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 -10.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_gravity_acceleration>
|
|
||||||
<m_invInertiaLocal type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 1.500000 1.500000 1.500000 0.000000 </m_floats>
|
|
||||||
</m_invInertiaLocal>
|
|
||||||
<m_totalForce type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 0.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_totalForce>
|
|
||||||
<m_totalTorque type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 0.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_totalTorque>
|
|
||||||
<m_inverseMass type="float"> 1.000000 </m_inverseMass>
|
|
||||||
<m_linearDamping type="float"> 0.000000 </m_linearDamping>
|
|
||||||
<m_angularDamping type="float"> 0.000000 </m_angularDamping>
|
|
||||||
<m_additionalDampingFactor type="float"> 0.005000 </m_additionalDampingFactor>
|
|
||||||
<m_additionalLinearDampingThresholdSqr type="float"> 0.010000 </m_additionalLinearDampingThresholdSqr>
|
|
||||||
<m_additionalAngularDampingThresholdSqr type="float"> 0.010000 </m_additionalAngularDampingThresholdSqr>
|
|
||||||
<m_additionalAngularDampingFactor type="float"> 0.010000 </m_additionalAngularDampingFactor>
|
|
||||||
<m_linearSleepingThreshold type="float"> 0.800000 </m_linearSleepingThreshold>
|
|
||||||
<m_angularSleepingThreshold type="float"> 1.000000 </m_angularSleepingThreshold>
|
|
||||||
<m_additionalDamping type="int"> 0 </m_additionalDamping>
|
|
||||||
</btRigidBodyFloatData>
|
|
||||||
<btRigidBodyFloatData pointer=10>
|
|
||||||
<m_collisionObjectData type="btCollisionObjectFloatData">
|
|
||||||
<m_broadphaseHandle type="pointer"> 0 </m_broadphaseHandle>
|
|
||||||
<m_collisionShape type="pointer"> 5 </m_collisionShape>
|
|
||||||
<m_rootCollisionShape type="pointer"> 0 </m_rootCollisionShape>
|
|
||||||
<m_name type="pointer"> 0 </m_name>
|
|
||||||
<m_worldTransform type="btTransformFloatData">
|
|
||||||
<m_basis type="btMatrix3x3FloatData">
|
|
||||||
<m_el type="btVector3FloatData" count=3>
|
|
||||||
<m_floats type="float" count=4> 1.000000 0.000000 0.000000 0.000000 </m_floats>
|
|
||||||
<m_floats type="float" count=4> 0.000000 1.000000 0.000000 0.000000 </m_floats>
|
|
||||||
<m_floats type="float" count=4> 0.000000 0.000000 1.000000 0.000000 </m_floats>
|
|
||||||
</m_el>
|
|
||||||
</m_basis>
|
|
||||||
<m_origin type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> -5.000000 22.166668 -3.000000 0.000000 </m_floats>
|
|
||||||
</m_origin>
|
|
||||||
</m_worldTransform>
|
|
||||||
<m_interpolationWorldTransform type="btTransformFloatData">
|
|
||||||
<m_basis type="btMatrix3x3FloatData">
|
|
||||||
<m_el type="btVector3FloatData" count=3>
|
|
||||||
<m_floats type="float" count=4> 1.000000 0.000000 0.000000 0.000000 </m_floats>
|
|
||||||
<m_floats type="float" count=4> 0.000000 1.000000 0.000000 0.000000 </m_floats>
|
|
||||||
<m_floats type="float" count=4> 0.000000 0.000000 1.000000 0.000000 </m_floats>
|
|
||||||
</m_el>
|
|
||||||
</m_basis>
|
|
||||||
<m_origin type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> -5.000000 22.166668 -3.000000 0.000000 </m_floats>
|
|
||||||
</m_origin>
|
|
||||||
</m_interpolationWorldTransform>
|
|
||||||
<m_interpolationLinearVelocity type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 -4.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_interpolationLinearVelocity>
|
|
||||||
<m_interpolationAngularVelocity type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 0.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_interpolationAngularVelocity>
|
|
||||||
<m_anisotropicFriction type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 1.000000 1.000000 1.000000 0.000000 </m_floats>
|
|
||||||
</m_anisotropicFriction>
|
|
||||||
<m_contactProcessingThreshold type="float"> 999999984306749440.000000 </m_contactProcessingThreshold>
|
|
||||||
<m_deactivationTime type="float"> 0.000000 </m_deactivationTime>
|
|
||||||
<m_friction type="float"> 0.500000 </m_friction>
|
|
||||||
<m_rollingFriction type="float"> -431602080.000000 </m_rollingFriction>
|
|
||||||
<m_restitution type="float"> 0.000000 </m_restitution>
|
|
||||||
<m_hitFraction type="float"> 1.000000 </m_hitFraction>
|
|
||||||
<m_ccdSweptSphereRadius type="float"> 0.000000 </m_ccdSweptSphereRadius>
|
|
||||||
<m_ccdMotionThreshold type="float"> 0.000000 </m_ccdMotionThreshold>
|
|
||||||
<m_hasAnisotropicFriction type="int"> 0 </m_hasAnisotropicFriction>
|
|
||||||
<m_collisionFlags type="int"> 0 </m_collisionFlags>
|
|
||||||
<m_islandTag1 type="int"> 4 </m_islandTag1>
|
|
||||||
<m_companionId type="int"> -1 </m_companionId>
|
|
||||||
<m_activationState1 type="int"> 1 </m_activationState1>
|
|
||||||
<m_internalType type="int"> 2 </m_internalType>
|
|
||||||
<m_checkCollideWith type="int"> 0 </m_checkCollideWith>
|
|
||||||
<m_padding type="char" count=4> -51 -51 -51 -51 </m_padding>
|
|
||||||
</m_collisionObjectData>
|
|
||||||
<m_invInertiaTensorWorld type="btMatrix3x3FloatData">
|
|
||||||
<m_el type="btVector3FloatData" count=3>
|
|
||||||
<m_floats type="float" count=4> 1.500000 0.000000 0.000000 0.000000 </m_floats>
|
|
||||||
<m_floats type="float" count=4> 0.000000 1.500000 0.000000 0.000000 </m_floats>
|
|
||||||
<m_floats type="float" count=4> 0.000000 0.000000 1.500000 0.000000 </m_floats>
|
|
||||||
</m_el>
|
|
||||||
</m_invInertiaTensorWorld>
|
|
||||||
<m_linearVelocity type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 -4.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_linearVelocity>
|
|
||||||
<m_angularVelocity type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 0.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_angularVelocity>
|
|
||||||
<m_angularFactor type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 1.000000 1.000000 1.000000 0.000000 </m_floats>
|
|
||||||
</m_angularFactor>
|
|
||||||
<m_linearFactor type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 1.000000 1.000000 1.000000 0.000000 </m_floats>
|
|
||||||
</m_linearFactor>
|
|
||||||
<m_gravity type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 -10.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_gravity>
|
|
||||||
<m_gravity_acceleration type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 -10.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_gravity_acceleration>
|
|
||||||
<m_invInertiaLocal type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 1.500000 1.500000 1.500000 0.000000 </m_floats>
|
|
||||||
</m_invInertiaLocal>
|
|
||||||
<m_totalForce type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 0.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_totalForce>
|
|
||||||
<m_totalTorque type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.000000 0.000000 0.000000 0.000000 </m_floats>
|
|
||||||
</m_totalTorque>
|
|
||||||
<m_inverseMass type="float"> 1.000000 </m_inverseMass>
|
|
||||||
<m_linearDamping type="float"> 0.000000 </m_linearDamping>
|
|
||||||
<m_angularDamping type="float"> 0.000000 </m_angularDamping>
|
|
||||||
<m_additionalDampingFactor type="float"> 0.005000 </m_additionalDampingFactor>
|
|
||||||
<m_additionalLinearDampingThresholdSqr type="float"> 0.010000 </m_additionalLinearDampingThresholdSqr>
|
|
||||||
<m_additionalAngularDampingThresholdSqr type="float"> 0.010000 </m_additionalAngularDampingThresholdSqr>
|
|
||||||
<m_additionalAngularDampingFactor type="float"> 0.010000 </m_additionalAngularDampingFactor>
|
|
||||||
<m_linearSleepingThreshold type="float"> 0.800000 </m_linearSleepingThreshold>
|
|
||||||
<m_angularSleepingThreshold type="float"> 1.000000 </m_angularSleepingThreshold>
|
|
||||||
<m_additionalDamping type="int"> 0 </m_additionalDamping>
|
|
||||||
</btRigidBodyFloatData>
|
|
||||||
<btConvexInternalShapeData pointer=3>
|
|
||||||
<m_collisionShapeData type="btCollisionShapeData">
|
|
||||||
<m_name type="pointer"> 0 </m_name>
|
|
||||||
<m_shapeType type="int"> 0 </m_shapeType>
|
|
||||||
<m_padding type="char" count=4> -51 -51 -51 -51 </m_padding>
|
|
||||||
</m_collisionShapeData>
|
|
||||||
<m_localScaling type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 1.000000 1.000000 1.000000 0.000000 </m_floats>
|
|
||||||
</m_localScaling>
|
|
||||||
<m_implicitShapeDimensions type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 49.959999 49.959999 49.959999 0.000000 </m_floats>
|
|
||||||
</m_implicitShapeDimensions>
|
|
||||||
<m_collisionMargin type="float"> 0.040000 </m_collisionMargin>
|
|
||||||
<m_padding type="int"> -842150451 </m_padding>
|
|
||||||
</btConvexInternalShapeData>
|
|
||||||
<btConvexInternalShapeData pointer=5>
|
|
||||||
<m_collisionShapeData type="btCollisionShapeData">
|
|
||||||
<m_name type="pointer"> 0 </m_name>
|
|
||||||
<m_shapeType type="int"> 0 </m_shapeType>
|
|
||||||
<m_padding type="char" count=4> -51 -51 -51 -51 </m_padding>
|
|
||||||
</m_collisionShapeData>
|
|
||||||
<m_localScaling type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 1.000000 1.000000 1.000000 0.000000 </m_floats>
|
|
||||||
</m_localScaling>
|
|
||||||
<m_implicitShapeDimensions type="btVector3FloatData">
|
|
||||||
<m_floats type="float" count=4> 0.960000 0.960000 0.960000 0.000000 </m_floats>
|
|
||||||
</m_implicitShapeDimensions>
|
|
||||||
<m_collisionMargin type="float"> 0.040000 </m_collisionMargin>
|
|
||||||
<m_padding type="int"> -842150451 </m_padding>
|
|
||||||
</btConvexInternalShapeData>
|
|
||||||
</bullet_physics>
|
|
24344
extern/bullet/Demos/BulletXmlImportDemo/bulletser.xml
vendored
24344
extern/bullet/Demos/BulletXmlImportDemo/bulletser.xml
vendored
File diff suppressed because it is too large
Load Diff
107
extern/bullet/Demos/BulletXmlImportDemo/main.cpp
vendored
107
extern/bullet/Demos/BulletXmlImportDemo/main.cpp
vendored
@ -1,107 +0,0 @@
|
|||||||
/*
|
|
||||||
Bullet Continuous Collision Detection and Physics Library
|
|
||||||
Copyright (c) 2003-2007 Erwin Coumans http://continuousphysics.com/Bullet/
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied warranty.
|
|
||||||
In no event will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it freely,
|
|
||||||
subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
|
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "BulletXmlImportDemo.h"
|
|
||||||
#include "GlutStuff.h"
|
|
||||||
|
|
||||||
#include "btBulletDynamicsCommon.h"
|
|
||||||
#include "LinearMath/btHashMap.h"
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef USE_AMD_OPENCL
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#include "btOpenCLUtils.h"
|
|
||||||
|
|
||||||
#include <LinearMath/btScalar.h>
|
|
||||||
|
|
||||||
cl_context g_cxMainContext;
|
|
||||||
cl_device_id g_cdDevice;
|
|
||||||
cl_command_queue g_cqCommandQue;
|
|
||||||
|
|
||||||
|
|
||||||
// Returns true if OpenCL is initialized properly, false otherwise.
|
|
||||||
bool initCL( void* glCtx, void* glDC )
|
|
||||||
{
|
|
||||||
const char* vendorSDK = btOpenCLUtils::getSdkVendorName();
|
|
||||||
printf("This program was compiled using the %s OpenCL SDK\n",vendorSDK);
|
|
||||||
|
|
||||||
int ciErrNum = 0;
|
|
||||||
|
|
||||||
#ifdef BT_USE_CLEW
|
|
||||||
ciErrNum = clewInit( "OpenCL.dll" );
|
|
||||||
if ( ciErrNum != CLEW_SUCCESS ) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(CL_PLATFORM_MINI_CL)
|
|
||||||
cl_device_type deviceType = CL_DEVICE_TYPE_CPU;
|
|
||||||
#elif defined(CL_PLATFORM_AMD)
|
|
||||||
cl_device_type deviceType = CL_DEVICE_TYPE_GPU;
|
|
||||||
#elif defined(CL_PLATFORM_NVIDIA)
|
|
||||||
cl_device_type deviceType = CL_DEVICE_TYPE_GPU;
|
|
||||||
#else
|
|
||||||
cl_device_type deviceType = CL_DEVICE_TYPE_CPU;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
g_cxMainContext = btOpenCLUtils::createContextFromType(deviceType, &ciErrNum, glCtx, glDC);
|
|
||||||
oclCHECKERROR(ciErrNum, CL_SUCCESS);
|
|
||||||
|
|
||||||
int numDev = btOpenCLUtils::getNumDevices(g_cxMainContext);
|
|
||||||
if (!numDev)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
g_cdDevice = btOpenCLUtils::getDevice(g_cxMainContext,0);
|
|
||||||
|
|
||||||
btOpenCLDeviceInfo clInfo;
|
|
||||||
btOpenCLUtils::getDeviceInfo(g_cdDevice,clInfo);
|
|
||||||
btOpenCLUtils::printDeviceInfo(g_cdDevice);
|
|
||||||
|
|
||||||
// create a command-queue
|
|
||||||
g_cqCommandQue = clCreateCommandQueue(g_cxMainContext, g_cdDevice, 0, &ciErrNum);
|
|
||||||
oclCHECKERROR(ciErrNum, CL_SUCCESS);
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif //#ifdef USE_AMD_OPENCL
|
|
||||||
|
|
||||||
|
|
||||||
int main(int argc,char** argv)
|
|
||||||
{
|
|
||||||
|
|
||||||
#ifdef USE_AMD_OPENCL
|
|
||||||
|
|
||||||
bool initialized = initCL(0,0);
|
|
||||||
btAssert(initialized);
|
|
||||||
#endif //USE_AMD_OPENCL
|
|
||||||
|
|
||||||
|
|
||||||
BulletXmlImportDemo serializeDemo;
|
|
||||||
serializeDemo.initPhysics();
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef CHECK_MEMORY_LEAKS
|
|
||||||
serializeDemo.exitPhysics();
|
|
||||||
#else
|
|
||||||
return glutmain(argc, argv,640,480,"Bullet Physics Demo. http://bulletphysics.org",&serializeDemo);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
//default glut doesn't return from mainloop
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
68
extern/bullet/Demos/CMakeLists.txt
vendored
68
extern/bullet/Demos/CMakeLists.txt
vendored
@ -1,68 +0,0 @@
|
|||||||
|
|
||||||
IF (USE_DX11 AND BUILD_MULTITHREADING)
|
|
||||||
SUBDIRS(DX11ClothDemo)
|
|
||||||
ENDIF()
|
|
||||||
|
|
||||||
SUBDIRS( HelloWorld )
|
|
||||||
|
|
||||||
|
|
||||||
IF (USE_GLUT)
|
|
||||||
IF (GLUT_FOUND)
|
|
||||||
IF(BUILD_CPU_DEMOS)
|
|
||||||
SET(SharedDemoSubdirs
|
|
||||||
OpenGL AllBulletDemos ConvexDecompositionDemo
|
|
||||||
CcdPhysicsDemo BulletXmlImportDemo ConstraintDemo SliderConstraintDemo GenericJointDemo Raytracer
|
|
||||||
RagdollDemo ForkLiftDemo BasicDemo FeatherstoneMultiBodyDemo RollingFrictionDemo RaytestDemo VoronoiFractureDemo
|
|
||||||
GyroscopicDemo FractureDemo Box2dDemo BspDemo MovingConcaveDemo VehicleDemo
|
|
||||||
UserCollisionAlgorithm CharacterDemo SoftDemo
|
|
||||||
CollisionInterfaceDemo ConcaveConvexcastDemo SimplexDemo DynamicControlDemo
|
|
||||||
ConvexHullDistance
|
|
||||||
DoublePrecisionDemo ConcaveDemo CollisionDemo
|
|
||||||
ContinuousConvexCollision ConcaveRaycastDemo GjkConvexCastDemo
|
|
||||||
MultiMaterialDemo SerializeDemo InternalEdgeDemo
|
|
||||||
)
|
|
||||||
ELSE()
|
|
||||||
SET(SharedDemoSubdirs OpenGL )
|
|
||||||
ENDIF(BUILD_CPU_DEMOS)
|
|
||||||
|
|
||||||
IF(BUILD_MULTITHREADING)
|
|
||||||
SUBDIRS( MultiThreadedDemo OpenCLClothDemo )
|
|
||||||
ENDIF(BUILD_MULTITHREADING)
|
|
||||||
|
|
||||||
SUBDIRS(
|
|
||||||
${SharedDemoSubdirs}
|
|
||||||
Benchmarks
|
|
||||||
)
|
|
||||||
|
|
||||||
IF(BUILD_MULTITHREADING)
|
|
||||||
SUBDIRS( ThreadingDemo VectorAdd_OpenCL )
|
|
||||||
ENDIF()
|
|
||||||
|
|
||||||
ENDIF(GLUT_FOUND)
|
|
||||||
ELSE (USE_GLUT)
|
|
||||||
IF (WIN32)
|
|
||||||
SUBDIRS(
|
|
||||||
OpenGL
|
|
||||||
BasicDemo
|
|
||||||
RaytestDemo
|
|
||||||
FractureDemo
|
|
||||||
Benchmarks
|
|
||||||
Box2dDemo
|
|
||||||
CollisionInterfaceDemo
|
|
||||||
ConcaveDemo
|
|
||||||
ConstraintDemo
|
|
||||||
RollingFrictionDemo
|
|
||||||
ConvexDecompositionDemo
|
|
||||||
InternalEdgeDemo
|
|
||||||
GimpactTestDemo
|
|
||||||
GyroscopicDemo
|
|
||||||
FeatherstoneMultiBodyDemo
|
|
||||||
GenericJointDemo
|
|
||||||
SerializeDemo
|
|
||||||
SoftDemo
|
|
||||||
VectorAdd_OpenCL
|
|
||||||
VoronoiFractureDemo
|
|
||||||
)
|
|
||||||
ENDIF(WIN32)
|
|
||||||
ENDIF (USE_GLUT)
|
|
||||||
|
|
@ -1,59 +0,0 @@
|
|||||||
# This is basically the overall name of the project in Visual Studio this is the name of the Solution File
|
|
||||||
|
|
||||||
|
|
||||||
# For every executable you have with a main method you should have an add_executable line below.
|
|
||||||
# For every add executable line you should list every .cpp and .h file you have associated with that executable.
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# You shouldn't have to modify anything below this line
|
|
||||||
########################################################
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
INCLUDE_DIRECTORIES(
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/src ${BULLET_PHYSICS_SOURCE_DIR}/Demos/OpenGL
|
|
||||||
)
|
|
||||||
|
|
||||||
LINK_LIBRARIES(
|
|
||||||
OpenGLSupport BulletDynamics BulletCollision LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY}
|
|
||||||
)
|
|
||||||
|
|
||||||
IF (WIN32)
|
|
||||||
ADD_EXECUTABLE(AppCcdPhysicsDemo
|
|
||||||
main.cpp
|
|
||||||
CcdPhysicsDemo.cpp
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/build/bullet.rc
|
|
||||||
)
|
|
||||||
ELSE()
|
|
||||||
ADD_EXECUTABLE(AppCcdPhysicsDemo
|
|
||||||
main.cpp
|
|
||||||
CcdPhysicsDemo.cpp
|
|
||||||
)
|
|
||||||
ENDIF()
|
|
||||||
|
|
||||||
IF (WIN32)
|
|
||||||
IF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES)
|
|
||||||
IF (CMAKE_CL_64)
|
|
||||||
ADD_CUSTOM_COMMAND(
|
|
||||||
TARGET AppCcdPhysicsDemo
|
|
||||||
POST_BUILD
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/glut64.dll ${CMAKE_CURRENT_BINARY_DIR}
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/glut64.dll ${CMAKE_CURRENT_BINARY_DIR}/Debug
|
|
||||||
)
|
|
||||||
ELSE(CMAKE_CL_64)
|
|
||||||
ADD_CUSTOM_COMMAND(
|
|
||||||
TARGET AppCcdPhysicsDemo
|
|
||||||
POST_BUILD
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/GLUT32.DLL ${CMAKE_CURRENT_BINARY_DIR}
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/GLUT32.DLL ${CMAKE_CURRENT_BINARY_DIR}/Debug
|
|
||||||
)
|
|
||||||
ENDIF(CMAKE_CL_64)
|
|
||||||
ENDIF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES)
|
|
||||||
ENDIF(WIN32)
|
|
||||||
|
|
||||||
IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES)
|
|
||||||
SET_TARGET_PROPERTIES(AppCcdPhysicsDemo PROPERTIES DEBUG_POSTFIX "_Debug")
|
|
||||||
SET_TARGET_PROPERTIES(AppCcdPhysicsDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel")
|
|
||||||
SET_TARGET_PROPERTIES(AppCcdPhysicsDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo")
|
|
||||||
ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES)
|
|
@ -1,424 +0,0 @@
|
|||||||
/*
|
|
||||||
Bullet Continuous Collision Detection and Physics Library
|
|
||||||
Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied warranty.
|
|
||||||
In no event will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it freely,
|
|
||||||
subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
|
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#define CUBE_HALF_EXTENTS 1
|
|
||||||
|
|
||||||
#define EXTRA_HEIGHT 1.f
|
|
||||||
|
|
||||||
#include "CcdPhysicsDemo.h"
|
|
||||||
#include "GlutStuff.h"
|
|
||||||
#include "GLDebugFont.h"
|
|
||||||
|
|
||||||
///btBulletDynamicsCommon.h is the main Bullet include file, contains most common include files.
|
|
||||||
#include "btBulletDynamicsCommon.h"
|
|
||||||
|
|
||||||
#include <stdio.h> //printf debugging
|
|
||||||
#include "GLDebugDrawer.h"
|
|
||||||
|
|
||||||
#if 0
|
|
||||||
extern btAlignedObjectArray<btVector3> debugContacts;
|
|
||||||
extern btAlignedObjectArray<btVector3> debugNormals;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
static GLDebugDrawer sDebugDrawer;
|
|
||||||
|
|
||||||
|
|
||||||
CcdPhysicsDemo::CcdPhysicsDemo()
|
|
||||||
:m_ccdMode(USE_CCD)
|
|
||||||
{
|
|
||||||
setDebugMode(btIDebugDraw::DBG_DrawText+btIDebugDraw::DBG_NoHelpText);
|
|
||||||
setCameraDistance(btScalar(40.));
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void CcdPhysicsDemo::clientMoveAndDisplay()
|
|
||||||
{
|
|
||||||
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
|
||||||
|
|
||||||
//simple dynamics world doesn't handle fixed-time-stepping
|
|
||||||
//float ms = getDeltaTimeMicroseconds();
|
|
||||||
|
|
||||||
///step the simulation
|
|
||||||
if (m_dynamicsWorld)
|
|
||||||
{
|
|
||||||
m_dynamicsWorld->stepSimulation(1./60.,0);//ms / 1000000.f);
|
|
||||||
//optional but useful: debug drawing
|
|
||||||
m_dynamicsWorld->debugDrawWorld();
|
|
||||||
}
|
|
||||||
|
|
||||||
renderme();
|
|
||||||
|
|
||||||
displayText();
|
|
||||||
#if 0
|
|
||||||
for (int i=0;i<debugContacts.size();i++)
|
|
||||||
{
|
|
||||||
getDynamicsWorld()->getDebugDrawer()->drawContactPoint(debugContacts[i],debugNormals[i],0,0,btVector3(1,0,0));
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
glFlush();
|
|
||||||
|
|
||||||
swapBuffers();
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void CcdPhysicsDemo::displayText()
|
|
||||||
{
|
|
||||||
int lineWidth=440;
|
|
||||||
int xStart = m_glutScreenWidth - lineWidth;
|
|
||||||
int yStart = 20;
|
|
||||||
|
|
||||||
if((getDebugMode() & btIDebugDraw::DBG_DrawText)!=0)
|
|
||||||
{
|
|
||||||
setOrthographicProjection();
|
|
||||||
glDisable(GL_LIGHTING);
|
|
||||||
glColor3f(0, 0, 0);
|
|
||||||
char buf[124];
|
|
||||||
|
|
||||||
glRasterPos3f(xStart, yStart, 0);
|
|
||||||
switch (m_ccdMode)
|
|
||||||
{
|
|
||||||
case USE_CCD:
|
|
||||||
{
|
|
||||||
sprintf(buf,"Predictive contacts and motion clamping");
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case USE_NO_CCD:
|
|
||||||
{
|
|
||||||
sprintf(buf,"CCD handling disabled");
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
default:
|
|
||||||
{
|
|
||||||
sprintf(buf,"unknown CCD setting");
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
GLDebugDrawString(xStart,20,buf);
|
|
||||||
glRasterPos3f(xStart, yStart, 0);
|
|
||||||
sprintf(buf,"Press 'p' to change CCD mode");
|
|
||||||
yStart+=20;
|
|
||||||
GLDebugDrawString(xStart,yStart,buf);
|
|
||||||
glRasterPos3f(xStart, yStart, 0);
|
|
||||||
sprintf(buf,"Press '.' or right mouse to shoot bullets");
|
|
||||||
yStart+=20;
|
|
||||||
GLDebugDrawString(xStart,yStart,buf);
|
|
||||||
glRasterPos3f(xStart, yStart, 0);
|
|
||||||
sprintf(buf,"space to restart, h(elp), t(ext), w(ire)");
|
|
||||||
yStart+=20;
|
|
||||||
GLDebugDrawString(xStart,yStart,buf);
|
|
||||||
|
|
||||||
resetPerspectiveProjection();
|
|
||||||
glEnable(GL_LIGHTING);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void CcdPhysicsDemo::displayCallback(void) {
|
|
||||||
|
|
||||||
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
|
||||||
|
|
||||||
renderme();
|
|
||||||
|
|
||||||
displayText();
|
|
||||||
|
|
||||||
//optional but useful: debug drawing to detect problems
|
|
||||||
if (m_dynamicsWorld)
|
|
||||||
{
|
|
||||||
m_dynamicsWorld->debugDrawWorld();
|
|
||||||
}
|
|
||||||
#if 0
|
|
||||||
for (int i=0;i<debugContacts.size();i++)
|
|
||||||
{
|
|
||||||
getDynamicsWorld()->getDebugDrawer()->drawContactPoint(debugContacts[i],debugNormals[i],0,0,btVector3(1,0,0));
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
glFlush();
|
|
||||||
swapBuffers();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void CcdPhysicsDemo::initPhysics()
|
|
||||||
{
|
|
||||||
setTexturing(true);
|
|
||||||
setShadows(true);
|
|
||||||
|
|
||||||
m_ShootBoxInitialSpeed = 4000.f;
|
|
||||||
|
|
||||||
m_defaultContactProcessingThreshold = 0.f;
|
|
||||||
|
|
||||||
///collision configuration contains default setup for memory, collision setup
|
|
||||||
m_collisionConfiguration = new btDefaultCollisionConfiguration();
|
|
||||||
// m_collisionConfiguration->setConvexConvexMultipointIterations();
|
|
||||||
|
|
||||||
///use the default collision dispatcher. For parallel processing you can use a diffent dispatcher (see Extras/BulletMultiThreaded)
|
|
||||||
m_dispatcher = new btCollisionDispatcher(m_collisionConfiguration);
|
|
||||||
//m_dispatcher->registerCollisionCreateFunc(BOX_SHAPE_PROXYTYPE,BOX_SHAPE_PROXYTYPE,m_collisionConfiguration->getCollisionAlgorithmCreateFunc(CONVEX_SHAPE_PROXYTYPE,CONVEX_SHAPE_PROXYTYPE));
|
|
||||||
|
|
||||||
m_broadphase = new btDbvtBroadphase();
|
|
||||||
|
|
||||||
///the default constraint solver. For parallel processing you can use a different solver (see Extras/BulletMultiThreaded)
|
|
||||||
btSequentialImpulseConstraintSolver* sol = new btSequentialImpulseConstraintSolver;
|
|
||||||
m_solver = sol;
|
|
||||||
|
|
||||||
m_dynamicsWorld = new btDiscreteDynamicsWorld(m_dispatcher,m_broadphase,m_solver,m_collisionConfiguration);
|
|
||||||
m_dynamicsWorld->getSolverInfo().m_solverMode |=SOLVER_USE_2_FRICTION_DIRECTIONS|SOLVER_RANDMIZE_ORDER;
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
m_dynamicsWorld ->setDebugDrawer(&sDebugDrawer);
|
|
||||||
|
|
||||||
//m_dynamicsWorld->getSolverInfo().m_splitImpulse=false;
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if (m_ccdMode==USE_CCD)
|
|
||||||
{
|
|
||||||
m_dynamicsWorld->getDispatchInfo().m_useContinuous=true;
|
|
||||||
} else
|
|
||||||
{
|
|
||||||
m_dynamicsWorld->getDispatchInfo().m_useContinuous=false;
|
|
||||||
}
|
|
||||||
|
|
||||||
m_dynamicsWorld->setGravity(btVector3(0,-10,0));
|
|
||||||
|
|
||||||
///create a few basic rigid bodies
|
|
||||||
btBoxShape* box = new btBoxShape(btVector3(btScalar(110.),btScalar(1.),btScalar(110.)));
|
|
||||||
// box->initializePolyhedralFeatures();
|
|
||||||
btCollisionShape* groundShape = box;
|
|
||||||
|
|
||||||
// btCollisionShape* groundShape = new btStaticPlaneShape(btVector3(0,1,0),50);
|
|
||||||
|
|
||||||
m_collisionShapes.push_back(groundShape);
|
|
||||||
//m_collisionShapes.push_back(new btCylinderShape (btVector3(CUBE_HALF_EXTENTS,CUBE_HALF_EXTENTS,CUBE_HALF_EXTENTS)));
|
|
||||||
m_collisionShapes.push_back(new btBoxShape (btVector3(CUBE_HALF_EXTENTS,CUBE_HALF_EXTENTS,CUBE_HALF_EXTENTS)));
|
|
||||||
|
|
||||||
btTransform groundTransform;
|
|
||||||
groundTransform.setIdentity();
|
|
||||||
//groundTransform.setOrigin(btVector3(5,5,5));
|
|
||||||
|
|
||||||
//We can also use DemoApplication::localCreateRigidBody, but for clarity it is provided here:
|
|
||||||
{
|
|
||||||
btScalar mass(0.);
|
|
||||||
|
|
||||||
//rigidbody is dynamic if and only if mass is non zero, otherwise static
|
|
||||||
bool isDynamic = (mass != 0.f);
|
|
||||||
|
|
||||||
btVector3 localInertia(0,0,0);
|
|
||||||
if (isDynamic)
|
|
||||||
groundShape->calculateLocalInertia(mass,localInertia);
|
|
||||||
|
|
||||||
//using motionstate is recommended, it provides interpolation capabilities, and only synchronizes 'active' objects
|
|
||||||
btDefaultMotionState* myMotionState = new btDefaultMotionState(groundTransform);
|
|
||||||
btRigidBody::btRigidBodyConstructionInfo rbInfo(mass,myMotionState,groundShape,localInertia);
|
|
||||||
btRigidBody* body = new btRigidBody(rbInfo);
|
|
||||||
body->setFriction(0.5);
|
|
||||||
//body->setRollingFriction(0.3);
|
|
||||||
//add the body to the dynamics world
|
|
||||||
m_dynamicsWorld->addRigidBody(body);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
{
|
|
||||||
//create a few dynamic rigidbodies
|
|
||||||
// Re-using the same collision is better for memory usage and performance
|
|
||||||
|
|
||||||
btCollisionShape* colShape = new btBoxShape(btVector3(1,1,1));
|
|
||||||
|
|
||||||
//btCollisionShape* colShape = new btSphereShape(btScalar(1.));
|
|
||||||
m_collisionShapes.push_back(colShape);
|
|
||||||
|
|
||||||
/// Create Dynamic Objects
|
|
||||||
btTransform startTransform;
|
|
||||||
startTransform.setIdentity();
|
|
||||||
|
|
||||||
btScalar mass(1.f);
|
|
||||||
|
|
||||||
//rigidbody is dynamic if and only if mass is non zero, otherwise static
|
|
||||||
bool isDynamic = (mass != 0.f);
|
|
||||||
|
|
||||||
btVector3 localInertia(0,0,0);
|
|
||||||
if (isDynamic)
|
|
||||||
colShape->calculateLocalInertia(mass,localInertia);
|
|
||||||
|
|
||||||
int gNumObjects = 120;//120;
|
|
||||||
int i;
|
|
||||||
for (i=0;i<gNumObjects;i++)
|
|
||||||
{
|
|
||||||
btCollisionShape* shape = m_collisionShapes[1];
|
|
||||||
|
|
||||||
btTransform trans;
|
|
||||||
trans.setIdentity();
|
|
||||||
|
|
||||||
//stack them
|
|
||||||
int colsize = 10;
|
|
||||||
int row = (i*CUBE_HALF_EXTENTS*2)/(colsize*2*CUBE_HALF_EXTENTS);
|
|
||||||
int row2 = row;
|
|
||||||
int col = (i)%(colsize)-colsize/2;
|
|
||||||
|
|
||||||
|
|
||||||
if (col>3)
|
|
||||||
{
|
|
||||||
col=11;
|
|
||||||
row2 |=1;
|
|
||||||
}
|
|
||||||
|
|
||||||
btVector3 pos(col*2*CUBE_HALF_EXTENTS + (row2%2)*CUBE_HALF_EXTENTS,
|
|
||||||
row*2*CUBE_HALF_EXTENTS+CUBE_HALF_EXTENTS+EXTRA_HEIGHT,0);
|
|
||||||
|
|
||||||
trans.setOrigin(pos);
|
|
||||||
|
|
||||||
float mass = 1.f;
|
|
||||||
|
|
||||||
btRigidBody* body = localCreateRigidBody(mass,trans,shape);
|
|
||||||
body->setAnisotropicFriction(shape->getAnisotropicRollingFrictionDirection(),btCollisionObject::CF_ANISOTROPIC_ROLLING_FRICTION);
|
|
||||||
body->setFriction(0.5);
|
|
||||||
|
|
||||||
//body->setRollingFriction(.3);
|
|
||||||
///when using m_ccdMode
|
|
||||||
if (m_ccdMode==USE_CCD)
|
|
||||||
{
|
|
||||||
body->setCcdMotionThreshold(CUBE_HALF_EXTENTS);
|
|
||||||
body->setCcdSweptSphereRadius(0.9*CUBE_HALF_EXTENTS);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
void CcdPhysicsDemo::clientResetScene()
|
|
||||||
{
|
|
||||||
exitPhysics();
|
|
||||||
initPhysics();
|
|
||||||
}
|
|
||||||
|
|
||||||
void CcdPhysicsDemo::keyboardCallback(unsigned char key, int x, int y)
|
|
||||||
{
|
|
||||||
if (key=='p')
|
|
||||||
{
|
|
||||||
switch (m_ccdMode)
|
|
||||||
{
|
|
||||||
case USE_CCD:
|
|
||||||
{
|
|
||||||
m_ccdMode = USE_NO_CCD;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case USE_NO_CCD:
|
|
||||||
default:
|
|
||||||
{
|
|
||||||
m_ccdMode = USE_CCD;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
clientResetScene();
|
|
||||||
} else
|
|
||||||
{
|
|
||||||
DemoApplication::keyboardCallback(key,x,y);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void CcdPhysicsDemo::shootBox(const btVector3& destination)
|
|
||||||
{
|
|
||||||
|
|
||||||
if (m_dynamicsWorld)
|
|
||||||
{
|
|
||||||
float mass = 1.f;
|
|
||||||
btTransform startTransform;
|
|
||||||
startTransform.setIdentity();
|
|
||||||
btVector3 camPos = getCameraPosition();
|
|
||||||
startTransform.setOrigin(camPos);
|
|
||||||
|
|
||||||
setShootBoxShape ();
|
|
||||||
|
|
||||||
|
|
||||||
btRigidBody* body = this->localCreateRigidBody(mass, startTransform,m_shootBoxShape);
|
|
||||||
body->setLinearFactor(btVector3(1,1,1));
|
|
||||||
//body->setRestitution(1);
|
|
||||||
|
|
||||||
btVector3 linVel(destination[0]-camPos[0],destination[1]-camPos[1],destination[2]-camPos[2]);
|
|
||||||
linVel.normalize();
|
|
||||||
linVel*=m_ShootBoxInitialSpeed;
|
|
||||||
|
|
||||||
body->getWorldTransform().setOrigin(camPos);
|
|
||||||
body->getWorldTransform().setRotation(btQuaternion(0,0,0,1));
|
|
||||||
body->setLinearVelocity(linVel);
|
|
||||||
body->setAngularVelocity(btVector3(0,0,0));
|
|
||||||
body->setContactProcessingThreshold(1e30);
|
|
||||||
|
|
||||||
///when using m_ccdMode, disable regular CCD
|
|
||||||
if (m_ccdMode==USE_CCD)
|
|
||||||
{
|
|
||||||
body->setCcdMotionThreshold(CUBE_HALF_EXTENTS);
|
|
||||||
body->setCcdSweptSphereRadius(0.4f);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void CcdPhysicsDemo::exitPhysics()
|
|
||||||
{
|
|
||||||
|
|
||||||
//cleanup in the reverse order of creation/initialization
|
|
||||||
|
|
||||||
//remove the rigidbodies from the dynamics world and delete them
|
|
||||||
int i;
|
|
||||||
for (i=m_dynamicsWorld->getNumCollisionObjects()-1; i>=0 ;i--)
|
|
||||||
{
|
|
||||||
btCollisionObject* obj = m_dynamicsWorld->getCollisionObjectArray()[i];
|
|
||||||
btRigidBody* body = btRigidBody::upcast(obj);
|
|
||||||
if (body && body->getMotionState())
|
|
||||||
{
|
|
||||||
delete body->getMotionState();
|
|
||||||
}
|
|
||||||
m_dynamicsWorld->removeCollisionObject( obj );
|
|
||||||
delete obj;
|
|
||||||
}
|
|
||||||
|
|
||||||
//delete collision shapes
|
|
||||||
for (int j=0;j<m_collisionShapes.size();j++)
|
|
||||||
{
|
|
||||||
btCollisionShape* shape = m_collisionShapes[j];
|
|
||||||
delete shape;
|
|
||||||
}
|
|
||||||
m_collisionShapes.clear();
|
|
||||||
|
|
||||||
delete m_dynamicsWorld;
|
|
||||||
|
|
||||||
delete m_solver;
|
|
||||||
|
|
||||||
delete m_broadphase;
|
|
||||||
|
|
||||||
delete m_dispatcher;
|
|
||||||
|
|
||||||
delete m_collisionConfiguration;
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -1,94 +0,0 @@
|
|||||||
/*
|
|
||||||
Bullet Continuous Collision Detection and Physics Library
|
|
||||||
Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied warranty.
|
|
||||||
In no event will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it freely,
|
|
||||||
subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
|
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
#ifndef BT_CCD_PHYSICS_DEMO_H
|
|
||||||
#define BT_CCD_PHYSICS_DEMO_H
|
|
||||||
|
|
||||||
#ifdef _WINDOWS
|
|
||||||
#include "Win32DemoApplication.h"
|
|
||||||
#define PlatformDemoApplication Win32DemoApplication
|
|
||||||
#else
|
|
||||||
#include "GlutDemoApplication.h"
|
|
||||||
#define PlatformDemoApplication GlutDemoApplication
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include "LinearMath/btAlignedObjectArray.h"
|
|
||||||
|
|
||||||
class btBroadphaseInterface;
|
|
||||||
class btCollisionShape;
|
|
||||||
class btOverlappingPairCache;
|
|
||||||
class btCollisionDispatcher;
|
|
||||||
class btConstraintSolver;
|
|
||||||
struct btCollisionAlgorithmCreateFunc;
|
|
||||||
class btDefaultCollisionConfiguration;
|
|
||||||
|
|
||||||
///CcdPhysicsDemo is good starting point for learning the code base and porting.
|
|
||||||
|
|
||||||
class CcdPhysicsDemo : public PlatformDemoApplication
|
|
||||||
{
|
|
||||||
|
|
||||||
//keep the collision shapes, for deletion/cleanup
|
|
||||||
btAlignedObjectArray<btCollisionShape*> m_collisionShapes;
|
|
||||||
|
|
||||||
btBroadphaseInterface* m_broadphase;
|
|
||||||
|
|
||||||
btCollisionDispatcher* m_dispatcher;
|
|
||||||
|
|
||||||
btConstraintSolver* m_solver;
|
|
||||||
|
|
||||||
enum
|
|
||||||
{
|
|
||||||
USE_CCD=1,
|
|
||||||
USE_NO_CCD
|
|
||||||
};
|
|
||||||
int m_ccdMode;
|
|
||||||
|
|
||||||
btDefaultCollisionConfiguration* m_collisionConfiguration;
|
|
||||||
|
|
||||||
public:
|
|
||||||
|
|
||||||
CcdPhysicsDemo();
|
|
||||||
|
|
||||||
virtual ~CcdPhysicsDemo()
|
|
||||||
{
|
|
||||||
exitPhysics();
|
|
||||||
}
|
|
||||||
void initPhysics();
|
|
||||||
|
|
||||||
void exitPhysics();
|
|
||||||
|
|
||||||
virtual void clientMoveAndDisplay();
|
|
||||||
|
|
||||||
void displayText();
|
|
||||||
|
|
||||||
virtual void keyboardCallback(unsigned char key, int x, int y);
|
|
||||||
|
|
||||||
virtual void displayCallback();
|
|
||||||
virtual void shootBox(const btVector3& destination);
|
|
||||||
virtual void clientResetScene();
|
|
||||||
|
|
||||||
|
|
||||||
static DemoApplication* Create()
|
|
||||||
{
|
|
||||||
CcdPhysicsDemo* demo = new CcdPhysicsDemo;
|
|
||||||
demo->myinit();
|
|
||||||
demo->initPhysics();
|
|
||||||
return demo;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif //BT_CCD_PHYSICS_DEMO_H
|
|
||||||
|
|
@ -1,5 +0,0 @@
|
|||||||
noinst_PROGRAMS=CcdPhysicsDemo
|
|
||||||
|
|
||||||
CcdPhysicsDemo_SOURCES=CcdPhysicsDemo.cpp CcdPhysicsDemo.h main.cpp
|
|
||||||
CcdPhysicsDemo_CXXFLAGS=-I@top_builddir@/src -I@top_builddir@/Demos/OpenGL $(CXXFLAGS)
|
|
||||||
CcdPhysicsDemo_LDADD=-L../OpenGL -lbulletopenglsupport -L../../src -lBulletDynamics -lBulletCollision -lLinearMath @opengl_LIBS@
|
|
49
extern/bullet/Demos/CcdPhysicsDemo/main.cpp
vendored
49
extern/bullet/Demos/CcdPhysicsDemo/main.cpp
vendored
@ -1,49 +0,0 @@
|
|||||||
/*
|
|
||||||
Bullet Continuous Collision Detection and Physics Library
|
|
||||||
Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied warranty.
|
|
||||||
In no event will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it freely,
|
|
||||||
subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
|
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "CcdPhysicsDemo.h"
|
|
||||||
#include "GlutStuff.h"
|
|
||||||
#include "GLDebugDrawer.h"
|
|
||||||
#include "btBulletDynamicsCommon.h"
|
|
||||||
#ifdef __DEBUG_FPU_ISSUES
|
|
||||||
#define _GNU_SOURCE
|
|
||||||
#include <fenv.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
GLDebugDrawer gDebugDrawer;
|
|
||||||
|
|
||||||
int main(int argc,char** argv)
|
|
||||||
{
|
|
||||||
|
|
||||||
CcdPhysicsDemo* ccdDemo = new CcdPhysicsDemo();
|
|
||||||
|
|
||||||
#ifdef __DEBUG_FPU_ISSUES
|
|
||||||
// feenableexcept (FE_DIVBYZERO);
|
|
||||||
// feenableexcept (FE_INEXACT);
|
|
||||||
// feenableexcept (FE_INVALID);
|
|
||||||
// feenableexcept (FE_OVERFLOW|FE_DIVBYZERO|FE_UNDERFLOW);
|
|
||||||
// feenableexcept (FE_UNDERFLOW);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
ccdDemo->initPhysics();
|
|
||||||
ccdDemo->getDynamicsWorld()->setDebugDrawer(&gDebugDrawer);
|
|
||||||
|
|
||||||
|
|
||||||
glutmain(argc, argv,640,480,"Bullet Physics Demo. http://bulletphysics.com",ccdDemo);
|
|
||||||
|
|
||||||
delete ccdDemo;
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
}
|
|
277
extern/bullet/Demos/CellSpuDemo/BasicDemo2.cpp
vendored
277
extern/bullet/Demos/CellSpuDemo/BasicDemo2.cpp
vendored
@ -1,277 +0,0 @@
|
|||||||
/*
|
|
||||||
Bullet Continuous Collision Detection and Physics Library
|
|
||||||
Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied warranty.
|
|
||||||
In no event will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it freely,
|
|
||||||
subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
|
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
//#define USE_GROUND_BOX 1
|
|
||||||
#define PRINT_CONTACT_STATISTICS 1
|
|
||||||
#define USE_PARALLEL_DISPATCHER 1
|
|
||||||
|
|
||||||
|
|
||||||
//#define USE_SIMPLE_DYNAMICS_WORLD 1
|
|
||||||
|
|
||||||
int gNumObjects = 5;
|
|
||||||
#define HALF_EXTENTS btScalar(1.)
|
|
||||||
#include "btBulletDynamicsCommon.h"
|
|
||||||
#include "BulletCollision/BroadphaseCollision/btMultiSapBroadphase.h"
|
|
||||||
#include "LinearMath/btIDebugDraw.h"
|
|
||||||
#include <stdio.h> //printf debugging
|
|
||||||
btScalar deltaTime = btScalar(1./60.);
|
|
||||||
btScalar gCollisionMargin = btScalar(0.05);
|
|
||||||
#include "BasicDemo2.h"
|
|
||||||
|
|
||||||
#ifdef USE_PARALLEL_DISPATCHER
|
|
||||||
#include "BulletMultiThreaded/SpuGatheringCollisionDispatcher.h"
|
|
||||||
#include "BulletMultiThreaded/Win32ThreadSupport.h"
|
|
||||||
#include "BulletMultiThreaded/SpuLibspe2Support.h"
|
|
||||||
#include "BulletMultiThreaded/SpuNarrowPhaseCollisionTask/SpuGatheringCollisionTask.h"
|
|
||||||
#endif//USE_PARALLEL_DISPATCHER
|
|
||||||
|
|
||||||
|
|
||||||
#include <LinearMath/btAlignedObjectArray.h>
|
|
||||||
|
|
||||||
////////////////////////////////////
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
int main(int argc,char** argv)
|
|
||||||
{
|
|
||||||
|
|
||||||
BasicDemo ccdDemo;
|
|
||||||
ccdDemo.initPhysics();
|
|
||||||
|
|
||||||
int i;
|
|
||||||
for (i=0;i<5;i++)
|
|
||||||
ccdDemo.clientMoveAndDisplay();
|
|
||||||
ccdDemo.exitPhysics();
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
extern int gNumManifold;
|
|
||||||
|
|
||||||
void BasicDemo::clientMoveAndDisplay()
|
|
||||||
{
|
|
||||||
|
|
||||||
//simple dynamics world doesn't handle fixed-time-stepping
|
|
||||||
float ms = m_clock.getTimeMicroseconds();
|
|
||||||
m_clock.reset();
|
|
||||||
float minFPS = 1000000.f/60.f;
|
|
||||||
if (ms > minFPS)
|
|
||||||
ms = minFPS;
|
|
||||||
|
|
||||||
if (m_dynamicsWorld)
|
|
||||||
m_dynamicsWorld->stepSimulation(ms / 1000000.f);
|
|
||||||
|
|
||||||
//some additional debugging info
|
|
||||||
#ifdef PRINT_CONTACT_STATISTICS
|
|
||||||
printf("num contact manifolds: %i\n",gNumManifold);
|
|
||||||
int numManifolds = m_dynamicsWorld->getDispatcher()->getNumManifolds();
|
|
||||||
for (int i=0;i<numManifolds;i++)
|
|
||||||
{
|
|
||||||
btPersistentManifold* contactManifold = m_dynamicsWorld->getDispatcher()->getManifoldByIndexInternal(i);
|
|
||||||
btCollisionObject* obA = static_cast<btCollisionObject*>(contactManifold->getBody0());
|
|
||||||
btCollisionObject* obB = static_cast<btCollisionObject*>(contactManifold->getBody1());
|
|
||||||
|
|
||||||
int numContacts = contactManifold->getNumContacts();
|
|
||||||
for (int j=0;j<numContacts;j++)
|
|
||||||
{
|
|
||||||
btManifoldPoint& pt = contactManifold->getContactPoint(j);
|
|
||||||
btVector3 ptA = pt.getPositionWorldOnA();
|
|
||||||
btVector3 ptB = pt.getPositionWorldOnB();
|
|
||||||
printf("contact manifold[%d],pointA[%d]=(%f,%f,%f)\n",i,j,ptA[0],ptA[1],ptA[2]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif //PRINT_CONTACT_STATISTICS
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void BasicDemo::initPhysics()
|
|
||||||
{
|
|
||||||
|
|
||||||
btDefaultCollisionConfiguration* collisionConfiguration = new btDefaultCollisionConfiguration();
|
|
||||||
|
|
||||||
#ifdef USE_PARALLEL_DISPATCHER
|
|
||||||
|
|
||||||
int maxNumOutstandingTasks = 1;//number of maximum outstanding tasks
|
|
||||||
#ifdef USE_WIN32_THREADING
|
|
||||||
|
|
||||||
Win32ThreadSupport* threadSupport = new Win32ThreadSupport(Win32ThreadSupport::Win32ThreadConstructionInfo(
|
|
||||||
"collision",
|
|
||||||
processCollisionTask,
|
|
||||||
createCollisionLocalStoreMemory,
|
|
||||||
maxNumOutstandingTasks));
|
|
||||||
#else
|
|
||||||
|
|
||||||
spe_program_handle_t * program_handle;
|
|
||||||
#ifndef USE_CESOF
|
|
||||||
char* spuFileName = "../../../src/BulletMultiThreaded/out/spuCollision.elf";
|
|
||||||
|
|
||||||
program_handle = spe_image_open (spuFileName);
|
|
||||||
if (program_handle == NULL)
|
|
||||||
{
|
|
||||||
printf( "SPU OPEN IMAGE ERROR:%s\n",spuFileName);
|
|
||||||
exit(0);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
printf( "IMAGE OPENED:%s\n",spuFileName);
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
extern spe_program_handle_t spu_program;
|
|
||||||
program_handle = &spu_program;
|
|
||||||
#endif
|
|
||||||
SpuLibspe2Support* threadSupport = new SpuLibspe2Support( program_handle, maxNumOutstandingTasks);
|
|
||||||
|
|
||||||
#endif // WIN32
|
|
||||||
|
|
||||||
|
|
||||||
m_dispatcher = new SpuGatheringCollisionDispatcher(threadSupport,maxNumOutstandingTasks,collisionConfiguration);
|
|
||||||
#else
|
|
||||||
m_dispatcher = new btCollisionDispatcher(collisionConfiguration);
|
|
||||||
#endif //USE_PARALLEL_DISPATCHER
|
|
||||||
m_collisionConfiguration = new btDefaultCollisionConfiguration();
|
|
||||||
|
|
||||||
|
|
||||||
#define USE_SWEEP_AND_PRUNE 1
|
|
||||||
#ifdef USE_SWEEP_AND_PRUNE
|
|
||||||
#define maxProxies 8192
|
|
||||||
btVector3 worldAabbMin(-10000,-10000,-10000);
|
|
||||||
btVector3 worldAabbMax(10000,10000,10000);
|
|
||||||
m_overlappingPairCache = new btAxisSweep3(worldAabbMin,worldAabbMax,maxProxies);
|
|
||||||
//m_overlappingPairCache = new btMultiSapBroadphase();
|
|
||||||
|
|
||||||
|
|
||||||
#else
|
|
||||||
m_overlappingPairCache = new btSimpleBroadphase;
|
|
||||||
#endif //USE_SWEEP_AND_PRUNE
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
btSequentialImpulseConstraintSolver* sol = new btSequentialImpulseConstraintSolver;
|
|
||||||
m_solver = sol;
|
|
||||||
|
|
||||||
|
|
||||||
m_dynamicsWorld = new btDiscreteDynamicsWorld(m_dispatcher,m_overlappingPairCache,m_solver,m_collisionConfiguration);
|
|
||||||
m_dynamicsWorld->getDispatchInfo().m_enableSPU = true;
|
|
||||||
|
|
||||||
m_dynamicsWorld->setGravity(btVector3(0,-10,0));
|
|
||||||
|
|
||||||
|
|
||||||
///create a few basic rigid bodies
|
|
||||||
|
|
||||||
|
|
||||||
//static ground
|
|
||||||
#ifdef USE_GROUND_BOX
|
|
||||||
btCollisionShape* groundShape = new btBoxShape(btVector3(btScalar(50.),btScalar(50.),btScalar(50.)));
|
|
||||||
#else
|
|
||||||
btCollisionShape* groundShape = new btSphereShape(btScalar(50.));
|
|
||||||
#endif//USE_GROUND_BOX
|
|
||||||
|
|
||||||
m_collisionShapes.push_back(groundShape);
|
|
||||||
|
|
||||||
btTransform groundTransform;
|
|
||||||
groundTransform.setIdentity();
|
|
||||||
groundTransform.setOrigin(btVector3(0,-50,0));
|
|
||||||
localCreateRigidBody(btScalar(0.),groundTransform,groundShape);
|
|
||||||
|
|
||||||
//create a few dynamic sphere rigidbodies (re-using the same sphere shape)
|
|
||||||
//btCollisionShape* sphereShape = new btBoxShape(btVector3(1,1,1));
|
|
||||||
btCollisionShape* sphereShape = new btSphereShape(btScalar(1.));
|
|
||||||
m_collisionShapes.push_back(sphereShape);
|
|
||||||
|
|
||||||
int i;
|
|
||||||
for (i=0;i<gNumObjects;i++)
|
|
||||||
{
|
|
||||||
|
|
||||||
sphereShape->setMargin(gCollisionMargin);
|
|
||||||
btTransform trans;
|
|
||||||
trans.setIdentity();
|
|
||||||
//stack them
|
|
||||||
int colsize = 2;
|
|
||||||
int row = (int)((i*HALF_EXTENTS*2)/(colsize*2*HALF_EXTENTS));
|
|
||||||
int row2 = row;
|
|
||||||
int col = (i)%(colsize)-colsize/2;
|
|
||||||
btVector3 pos(col*2*HALF_EXTENTS + (row2%2)*HALF_EXTENTS,
|
|
||||||
row*2*HALF_EXTENTS+HALF_EXTENTS,0);
|
|
||||||
|
|
||||||
trans.setOrigin(pos);
|
|
||||||
//btRigidBody* body = localCreateRigidBody(btScalar(1.),trans,sphereShape);
|
|
||||||
localCreateRigidBody(btScalar(1.),trans,sphereShape);
|
|
||||||
}
|
|
||||||
|
|
||||||
//clientResetScene();
|
|
||||||
}
|
|
||||||
|
|
||||||
btRigidBody* BasicDemo::localCreateRigidBody(btScalar mass,const btTransform& startTrans,btCollisionShape* colShape)
|
|
||||||
{
|
|
||||||
btVector3 inertia(0,0,0);
|
|
||||||
if (mass)
|
|
||||||
colShape->calculateLocalInertia(mass,inertia);
|
|
||||||
btRigidBody::btRigidBodyConstructionInfo rbci(mass,0,colShape,inertia);
|
|
||||||
rbci.m_startWorldTransform = startTrans;
|
|
||||||
|
|
||||||
btRigidBody* body = new btRigidBody(rbci);
|
|
||||||
m_dynamicsWorld->addRigidBody(body);
|
|
||||||
return body;
|
|
||||||
|
|
||||||
}
|
|
||||||
void BasicDemo::exitPhysics()
|
|
||||||
{
|
|
||||||
|
|
||||||
|
|
||||||
//cleanup in the reverse order of creation/initialization
|
|
||||||
|
|
||||||
//remove the rigidbodies from the dynamics world and delete them
|
|
||||||
int i;
|
|
||||||
for (i=m_dynamicsWorld->getNumCollisionObjects()-1; i>=0 ;i--)
|
|
||||||
{
|
|
||||||
btCollisionObject* obj = m_dynamicsWorld->getCollisionObjectArray()[i];
|
|
||||||
m_dynamicsWorld->removeCollisionObject( obj );
|
|
||||||
delete obj;
|
|
||||||
}
|
|
||||||
|
|
||||||
//delete collision shapes
|
|
||||||
for (int j=0;j<m_collisionShapes.size();j++)
|
|
||||||
{
|
|
||||||
btCollisionShape* shape = m_collisionShapes[j];
|
|
||||||
delete shape;
|
|
||||||
}
|
|
||||||
|
|
||||||
//delete dynamics world
|
|
||||||
delete m_dynamicsWorld;
|
|
||||||
|
|
||||||
//delete solver
|
|
||||||
delete m_solver;
|
|
||||||
|
|
||||||
//delete broadphase
|
|
||||||
delete m_overlappingPairCache;
|
|
||||||
|
|
||||||
//delete dispatcher
|
|
||||||
delete m_dispatcher;
|
|
||||||
|
|
||||||
delete m_collisionConfiguration;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
62
extern/bullet/Demos/CellSpuDemo/BasicDemo2.h
vendored
62
extern/bullet/Demos/CellSpuDemo/BasicDemo2.h
vendored
@ -1,62 +0,0 @@
|
|||||||
/*
|
|
||||||
Bullet Continuous Collision Detection and Physics Library
|
|
||||||
Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied warranty.
|
|
||||||
In no event will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it freely,
|
|
||||||
subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
|
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
#ifndef BASIC_DEMO_H
|
|
||||||
#define BASIC_DEMO_H
|
|
||||||
|
|
||||||
#include "LinearMath/btQuickprof.h"
|
|
||||||
|
|
||||||
class btDiscreteDynamicsworld;
|
|
||||||
class btCollisionShape;
|
|
||||||
class btOverlappingPairCache;
|
|
||||||
class btCollisionDispatcher;
|
|
||||||
class btConstraintSolver;
|
|
||||||
struct btCollisionAlgorithmCreateFunc;
|
|
||||||
|
|
||||||
///BasicDemo is good starting point for learning the code base and porting.
|
|
||||||
class BasicDemo
|
|
||||||
{
|
|
||||||
btClock m_clock;
|
|
||||||
|
|
||||||
//keep the collision shapes, for deletion/cleanup
|
|
||||||
btAlignedObjectArray<btCollisionShape*> m_collisionShapes;
|
|
||||||
|
|
||||||
btBroadphaseInterface* m_overlappingPairCache;
|
|
||||||
|
|
||||||
btCollisionDispatcher* m_dispatcher;
|
|
||||||
btDefaultCollisionConfiguration* m_collisionConfiguration;
|
|
||||||
btConstraintSolver* m_solver;
|
|
||||||
btDiscreteDynamicsWorld* m_dynamicsWorld;
|
|
||||||
|
|
||||||
btCollisionAlgorithmCreateFunc* m_sphereSphereCF;
|
|
||||||
btCollisionAlgorithmCreateFunc* m_sphereBoxCF;
|
|
||||||
btCollisionAlgorithmCreateFunc* m_boxSphereCF;
|
|
||||||
|
|
||||||
btRigidBody* localCreateRigidBody(btScalar mass,const btTransform& startTrans,btCollisionShape* colShape);
|
|
||||||
|
|
||||||
|
|
||||||
public:
|
|
||||||
|
|
||||||
void initPhysics();
|
|
||||||
|
|
||||||
void exitPhysics();
|
|
||||||
|
|
||||||
virtual void clientMoveAndDisplay();
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif //BASIC_DEMO_H
|
|
||||||
|
|
75
extern/bullet/Demos/CharacterDemo/CMakeLists.txt
vendored
75
extern/bullet/Demos/CharacterDemo/CMakeLists.txt
vendored
@ -1,75 +0,0 @@
|
|||||||
# This is basically the overall name of the project in Visual Studio this is the name of the Solution File
|
|
||||||
|
|
||||||
|
|
||||||
# For every executable you have with a main method you should have an add_executable line below.
|
|
||||||
# For every add executable line you should list every .cpp and .h file you have associated with that executable.
|
|
||||||
|
|
||||||
|
|
||||||
# You shouldn't have to modify anything below this line
|
|
||||||
########################################################
|
|
||||||
|
|
||||||
|
|
||||||
INCLUDE_DIRECTORIES(
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/src ${BULLET_PHYSICS_SOURCE_DIR}/Demos/OpenGL
|
|
||||||
)
|
|
||||||
|
|
||||||
LINK_LIBRARIES(
|
|
||||||
OpenGLSupport BulletDynamics BulletCollision LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY}
|
|
||||||
)
|
|
||||||
SET(CharacterDemo_SRCS
|
|
||||||
|
|
||||||
DynamicCharacterController.cpp
|
|
||||||
DynamicCharacterController.h
|
|
||||||
CharacterDemo.cpp
|
|
||||||
CharacterDemo.h
|
|
||||||
../BspDemo/BspConverter.cpp
|
|
||||||
../BspDemo/BspConverter.h
|
|
||||||
../BspDemo/BspLoader.cpp
|
|
||||||
../BspDemo/BspLoader.h
|
|
||||||
main.cpp
|
|
||||||
)
|
|
||||||
|
|
||||||
IF (WIN32)
|
|
||||||
ADD_EXECUTABLE(AppCharacterDemo
|
|
||||||
${CharacterDemo_SRCS}
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/build/bullet.rc
|
|
||||||
)
|
|
||||||
ELSE()
|
|
||||||
ADD_EXECUTABLE(AppCharacterDemo
|
|
||||||
${CharacterDemo_SRCS}
|
|
||||||
)
|
|
||||||
ENDIF()
|
|
||||||
|
|
||||||
IF (WIN32)
|
|
||||||
IF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES)
|
|
||||||
IF (CMAKE_CL_64)
|
|
||||||
ADD_CUSTOM_COMMAND(
|
|
||||||
TARGET AppCharacterDemo
|
|
||||||
POST_BUILD
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/glut64.dll ${CMAKE_CURRENT_BINARY_DIR}
|
|
||||||
)
|
|
||||||
ELSE(CMAKE_CL_64)
|
|
||||||
ADD_CUSTOM_COMMAND(
|
|
||||||
TARGET AppCharacterDemo
|
|
||||||
POST_BUILD
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/GLUT32.DLL ${CMAKE_CURRENT_BINARY_DIR}
|
|
||||||
)
|
|
||||||
ENDIF(CMAKE_CL_64)
|
|
||||||
ENDIF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES)
|
|
||||||
ENDIF(WIN32)
|
|
||||||
|
|
||||||
IF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES)
|
|
||||||
ADD_CUSTOM_COMMAND(
|
|
||||||
TARGET AppCharacterDemo
|
|
||||||
POST_BUILD
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/BspDemo.bsp ${CMAKE_CURRENT_BINARY_DIR}
|
|
||||||
)
|
|
||||||
ENDIF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES)
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES)
|
|
||||||
SET_TARGET_PROPERTIES(AppCharacterDemo PROPERTIES DEBUG_POSTFIX "_Debug")
|
|
||||||
SET_TARGET_PROPERTIES(AppCharacterDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel")
|
|
||||||
SET_TARGET_PROPERTIES(AppCharacterDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo")
|
|
||||||
ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES)
|
|
531
extern/bullet/Demos/CharacterDemo/CharacterDemo.cpp
vendored
531
extern/bullet/Demos/CharacterDemo/CharacterDemo.cpp
vendored
@ -1,531 +0,0 @@
|
|||||||
/*
|
|
||||||
Bullet Continuous Collision Detection and Physics Library
|
|
||||||
Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied warranty.
|
|
||||||
In no event will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it freely,
|
|
||||||
subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
|
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "btBulletDynamicsCommon.h"
|
|
||||||
#include "BulletCollision/CollisionShapes/btHeightfieldTerrainShape.h"
|
|
||||||
#include "BulletCollision/CollisionDispatch/btGhostObject.h"
|
|
||||||
|
|
||||||
#include "GLDebugDrawer.h"
|
|
||||||
#include <stdio.h> //printf debugging
|
|
||||||
|
|
||||||
#include "GL_ShapeDrawer.h"
|
|
||||||
|
|
||||||
#include "GlutStuff.h"
|
|
||||||
#include "CharacterDemo.h"
|
|
||||||
#ifdef DYNAMIC_CHARACTER_CONTROLLER
|
|
||||||
#include "DynamicCharacterController.h"
|
|
||||||
#else
|
|
||||||
#include "BulletDynamics/Character/btKinematicCharacterController.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
const int maxProxies = 32766;
|
|
||||||
const int maxOverlap = 65535;
|
|
||||||
|
|
||||||
static int gForward = 0;
|
|
||||||
static int gBackward = 0;
|
|
||||||
static int gLeft = 0;
|
|
||||||
static int gRight = 0;
|
|
||||||
static int gJump = 0;
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
CharacterDemo::CharacterDemo()
|
|
||||||
:
|
|
||||||
m_indexVertexArrays(0),
|
|
||||||
m_vertices(0),
|
|
||||||
m_cameraHeight(4.f),
|
|
||||||
m_minCameraDistance(3.f),
|
|
||||||
m_maxCameraDistance(10.f)
|
|
||||||
{
|
|
||||||
m_character = 0;
|
|
||||||
m_cameraPosition = btVector3(30,30,30);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void CharacterDemo::initPhysics()
|
|
||||||
{
|
|
||||||
btCollisionShape* groundShape = new btBoxShape(btVector3(50,3,50));
|
|
||||||
m_collisionShapes.push_back(groundShape);
|
|
||||||
m_collisionConfiguration = new btDefaultCollisionConfiguration();
|
|
||||||
m_dispatcher = new btCollisionDispatcher(m_collisionConfiguration);
|
|
||||||
btVector3 worldMin(-1000,-1000,-1000);
|
|
||||||
btVector3 worldMax(1000,1000,1000);
|
|
||||||
btAxisSweep3* sweepBP = new btAxisSweep3(worldMin,worldMax);
|
|
||||||
m_overlappingPairCache = sweepBP;
|
|
||||||
|
|
||||||
m_constraintSolver = new btSequentialImpulseConstraintSolver();
|
|
||||||
m_dynamicsWorld = new btDiscreteDynamicsWorld(m_dispatcher,m_overlappingPairCache,m_constraintSolver,m_collisionConfiguration);
|
|
||||||
m_dynamicsWorld->getDispatchInfo().m_allowedCcdPenetration=0.0001f;
|
|
||||||
|
|
||||||
#ifdef DYNAMIC_CHARACTER_CONTROLLER
|
|
||||||
m_character = new DynamicCharacterController ();
|
|
||||||
#else
|
|
||||||
|
|
||||||
btTransform startTransform;
|
|
||||||
startTransform.setIdentity ();
|
|
||||||
//startTransform.setOrigin (btVector3(0.0, 4.0, 0.0));
|
|
||||||
startTransform.setOrigin (btVector3(10.210098,-1.6433364,16.453260));
|
|
||||||
|
|
||||||
|
|
||||||
m_ghostObject = new btPairCachingGhostObject();
|
|
||||||
m_ghostObject->setWorldTransform(startTransform);
|
|
||||||
sweepBP->getOverlappingPairCache()->setInternalGhostPairCallback(new btGhostPairCallback());
|
|
||||||
btScalar characterHeight=1.75;
|
|
||||||
btScalar characterWidth =1.75;
|
|
||||||
btConvexShape* capsule = new btCapsuleShape(characterWidth,characterHeight);
|
|
||||||
m_ghostObject->setCollisionShape (capsule);
|
|
||||||
m_ghostObject->setCollisionFlags (btCollisionObject::CF_CHARACTER_OBJECT);
|
|
||||||
|
|
||||||
btScalar stepHeight = btScalar(0.35);
|
|
||||||
m_character = new btKinematicCharacterController (m_ghostObject,capsule,stepHeight);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
////////////////
|
|
||||||
|
|
||||||
/// Create some basic environment from a Quake level
|
|
||||||
|
|
||||||
//m_dynamicsWorld->setGravity(btVector3(0,0,0));
|
|
||||||
btTransform tr;
|
|
||||||
tr.setIdentity();
|
|
||||||
|
|
||||||
const char* bspfilename = "BspDemo.bsp";
|
|
||||||
void* memoryBuffer = 0;
|
|
||||||
|
|
||||||
FILE* file = fopen(bspfilename,"r");
|
|
||||||
if (!file)
|
|
||||||
{
|
|
||||||
//cmake generated visual studio projects need 4 levels back
|
|
||||||
bspfilename = "../../../../BspDemo.bsp";
|
|
||||||
file = fopen(bspfilename,"r");
|
|
||||||
}
|
|
||||||
if (!file)
|
|
||||||
{
|
|
||||||
//visual studio leaves the current working directory in the projectfiles folder
|
|
||||||
bspfilename = "../../BspDemo.bsp";
|
|
||||||
file = fopen(bspfilename,"r");
|
|
||||||
}
|
|
||||||
if (!file)
|
|
||||||
{
|
|
||||||
//visual studio leaves the current working directory in the projectfiles folder
|
|
||||||
bspfilename = "BspDemo.bsp";
|
|
||||||
file = fopen(bspfilename,"r");
|
|
||||||
}
|
|
||||||
|
|
||||||
if (file)
|
|
||||||
{
|
|
||||||
BspLoader bspLoader;
|
|
||||||
int size=0;
|
|
||||||
if (fseek(file, 0, SEEK_END) || (size = ftell(file)) == EOF || fseek(file, 0, SEEK_SET)) { /* File operations denied? ok, just close and return failure */
|
|
||||||
printf("Error: cannot get filesize from %s\n", bspfilename);
|
|
||||||
} else
|
|
||||||
{
|
|
||||||
//how to detect file size?
|
|
||||||
memoryBuffer = malloc(size+1);
|
|
||||||
fread(memoryBuffer,1,size,file);
|
|
||||||
bspLoader.loadBSPFile( memoryBuffer);
|
|
||||||
|
|
||||||
BspToBulletConverter bsp2bullet(this);
|
|
||||||
float bspScaling = 0.1f;
|
|
||||||
bsp2bullet.convertBsp(bspLoader,bspScaling);
|
|
||||||
|
|
||||||
}
|
|
||||||
fclose(file);
|
|
||||||
}
|
|
||||||
|
|
||||||
///only collide with static for now (no interaction with dynamic objects)
|
|
||||||
m_dynamicsWorld->addCollisionObject(m_ghostObject,btBroadphaseProxy::CharacterFilter, btBroadphaseProxy::StaticFilter|btBroadphaseProxy::DefaultFilter);
|
|
||||||
|
|
||||||
m_dynamicsWorld->addAction(m_character);
|
|
||||||
|
|
||||||
|
|
||||||
///////////////
|
|
||||||
|
|
||||||
clientResetScene();
|
|
||||||
|
|
||||||
setCameraDistance(56.f);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
//to be implemented by the demo
|
|
||||||
void CharacterDemo::renderme()
|
|
||||||
{
|
|
||||||
updateCamera();
|
|
||||||
|
|
||||||
DemoApplication::renderme();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void CharacterDemo::debugDrawContacts()
|
|
||||||
{
|
|
||||||
// printf("numPairs = %d\n",m_customPairCallback->getOverlappingPairArray().size());
|
|
||||||
{
|
|
||||||
btManifoldArray manifoldArray;
|
|
||||||
btBroadphasePairArray& pairArray = m_ghostObject->getOverlappingPairCache()->getOverlappingPairArray();
|
|
||||||
int numPairs = pairArray.size();
|
|
||||||
|
|
||||||
for (int i=0;i<numPairs;i++)
|
|
||||||
{
|
|
||||||
manifoldArray.clear();
|
|
||||||
|
|
||||||
const btBroadphasePair& pair = pairArray[i];
|
|
||||||
|
|
||||||
btBroadphasePair* collisionPair = m_overlappingPairCache->getOverlappingPairCache()->findPair(pair.m_pProxy0,pair.m_pProxy1);
|
|
||||||
if (!collisionPair)
|
|
||||||
continue;
|
|
||||||
|
|
||||||
if (collisionPair->m_algorithm)
|
|
||||||
collisionPair->m_algorithm->getAllContactManifolds(manifoldArray);
|
|
||||||
|
|
||||||
for (int j=0;j<manifoldArray.size();j++)
|
|
||||||
{
|
|
||||||
btPersistentManifold* manifold = manifoldArray[j];
|
|
||||||
for (int p=0;p<manifold->getNumContacts();p++)
|
|
||||||
{
|
|
||||||
const btManifoldPoint&pt = manifold->getContactPoint(p);
|
|
||||||
|
|
||||||
btVector3 color(255,255,255);
|
|
||||||
m_dynamicsWorld->getDebugDrawer()->drawContactPoint(pt.getPositionWorldOnB(),pt.m_normalWorldOnB,pt.getDistance(),pt.getLifeTime(),color);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
void CharacterDemo::clientMoveAndDisplay()
|
|
||||||
{
|
|
||||||
|
|
||||||
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
|
||||||
|
|
||||||
float dt = getDeltaTimeMicroseconds() * 0.000001f;
|
|
||||||
|
|
||||||
/* Character stuff &*/
|
|
||||||
if (m_character)
|
|
||||||
{
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
debugDrawContacts();
|
|
||||||
|
|
||||||
|
|
||||||
if (m_dynamicsWorld)
|
|
||||||
{
|
|
||||||
//during idle mode, just run 1 simulation step maximum
|
|
||||||
int maxSimSubSteps = m_idle ? 1 : 2;
|
|
||||||
if (m_idle)
|
|
||||||
dt = 1.0/420.f;
|
|
||||||
|
|
||||||
///set walkDirection for our character
|
|
||||||
btTransform xform;
|
|
||||||
xform = m_ghostObject->getWorldTransform ();
|
|
||||||
|
|
||||||
btVector3 forwardDir = xform.getBasis()[2];
|
|
||||||
// printf("forwardDir=%f,%f,%f\n",forwardDir[0],forwardDir[1],forwardDir[2]);
|
|
||||||
btVector3 upDir = xform.getBasis()[1];
|
|
||||||
btVector3 strafeDir = xform.getBasis()[0];
|
|
||||||
forwardDir.normalize ();
|
|
||||||
upDir.normalize ();
|
|
||||||
strafeDir.normalize ();
|
|
||||||
|
|
||||||
btVector3 walkDirection = btVector3(0.0, 0.0, 0.0);
|
|
||||||
btScalar walkVelocity = btScalar(1.1) * 4.0; // 4 km/h -> 1.1 m/s
|
|
||||||
btScalar walkSpeed = walkVelocity * dt;
|
|
||||||
|
|
||||||
//rotate view
|
|
||||||
if (gLeft)
|
|
||||||
{
|
|
||||||
btMatrix3x3 orn = m_ghostObject->getWorldTransform().getBasis();
|
|
||||||
orn *= btMatrix3x3(btQuaternion(btVector3(0,1,0),0.01));
|
|
||||||
m_ghostObject->getWorldTransform ().setBasis(orn);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (gRight)
|
|
||||||
{
|
|
||||||
btMatrix3x3 orn = m_ghostObject->getWorldTransform().getBasis();
|
|
||||||
orn *= btMatrix3x3(btQuaternion(btVector3(0,1,0),-0.01));
|
|
||||||
m_ghostObject->getWorldTransform ().setBasis(orn);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (gForward)
|
|
||||||
walkDirection += forwardDir;
|
|
||||||
|
|
||||||
if (gBackward)
|
|
||||||
walkDirection -= forwardDir;
|
|
||||||
|
|
||||||
|
|
||||||
m_character->setWalkDirection(walkDirection*walkSpeed);
|
|
||||||
|
|
||||||
|
|
||||||
int numSimSteps = m_dynamicsWorld->stepSimulation(dt,maxSimSubSteps);
|
|
||||||
|
|
||||||
//optional but useful: debug drawing
|
|
||||||
if (m_dynamicsWorld)
|
|
||||||
m_dynamicsWorld->debugDrawWorld();
|
|
||||||
|
|
||||||
//#define VERBOSE_FEEDBACK
|
|
||||||
#ifdef VERBOSE_FEEDBACK
|
|
||||||
if (!numSimSteps)
|
|
||||||
printf("Interpolated transforms\n");
|
|
||||||
else
|
|
||||||
{
|
|
||||||
if (numSimSteps > maxSimSubSteps)
|
|
||||||
{
|
|
||||||
//detect dropping frames
|
|
||||||
printf("Dropped (%i) simulation steps out of %i\n",numSimSteps - maxSimSubSteps,numSimSteps);
|
|
||||||
} else
|
|
||||||
{
|
|
||||||
printf("Simulated (%i) steps\n",numSimSteps);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif //VERBOSE_FEEDBACK
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef USE_QUICKPROF
|
|
||||||
btProfiler::beginBlock("render");
|
|
||||||
#endif //USE_QUICKPROF
|
|
||||||
|
|
||||||
|
|
||||||
renderme();
|
|
||||||
|
|
||||||
#ifdef USE_QUICKPROF
|
|
||||||
btProfiler::endBlock("render");
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
glFlush();
|
|
||||||
glutSwapBuffers();
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void CharacterDemo::displayCallback(void)
|
|
||||||
{
|
|
||||||
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
|
||||||
|
|
||||||
renderme();
|
|
||||||
|
|
||||||
//optional but useful: debug drawing
|
|
||||||
if (m_dynamicsWorld)
|
|
||||||
m_dynamicsWorld->debugDrawWorld();
|
|
||||||
|
|
||||||
debugDrawContacts();
|
|
||||||
|
|
||||||
glFlush();
|
|
||||||
glutSwapBuffers();
|
|
||||||
}
|
|
||||||
|
|
||||||
void CharacterDemo::clientResetScene()
|
|
||||||
{
|
|
||||||
m_dynamicsWorld->getBroadphase()->getOverlappingPairCache()->cleanProxyFromPairs(m_ghostObject->getBroadphaseHandle(),getDynamicsWorld()->getDispatcher());
|
|
||||||
|
|
||||||
m_character->reset (m_dynamicsWorld);
|
|
||||||
///WTF
|
|
||||||
m_character->warp (btVector3(10.210001,-2.0306311,16.576973));
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
void CharacterDemo::specialKeyboardUp(int key, int x, int y)
|
|
||||||
{
|
|
||||||
switch (key)
|
|
||||||
{
|
|
||||||
case GLUT_KEY_UP:
|
|
||||||
{
|
|
||||||
gForward = 0;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case GLUT_KEY_DOWN:
|
|
||||||
{
|
|
||||||
gBackward = 0;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case GLUT_KEY_LEFT:
|
|
||||||
{
|
|
||||||
gLeft = 0;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case GLUT_KEY_RIGHT:
|
|
||||||
{
|
|
||||||
gRight = 0;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
DemoApplication::specialKeyboardUp(key,x,y);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void CharacterDemo::specialKeyboard(int key, int x, int y)
|
|
||||||
{
|
|
||||||
|
|
||||||
// printf("key = %i x=%i y=%i\n",key,x,y);
|
|
||||||
|
|
||||||
switch (key)
|
|
||||||
{
|
|
||||||
case GLUT_KEY_UP:
|
|
||||||
{
|
|
||||||
gForward = 1;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case GLUT_KEY_DOWN:
|
|
||||||
{
|
|
||||||
gBackward = 1;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case GLUT_KEY_LEFT:
|
|
||||||
{
|
|
||||||
gLeft = 1;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case GLUT_KEY_RIGHT:
|
|
||||||
{
|
|
||||||
gRight = 1;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case GLUT_KEY_F1:
|
|
||||||
{
|
|
||||||
if (m_character && m_character->canJump())
|
|
||||||
gJump = 1;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
DemoApplication::specialKeyboard(key,x,y);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
// glutPostRedisplay();
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
void CharacterDemo::updateCamera()
|
|
||||||
{
|
|
||||||
|
|
||||||
//#define DISABLE_CAMERA 1
|
|
||||||
#ifdef DISABLE_CAMERA
|
|
||||||
DemoApplication::updateCamera();
|
|
||||||
return;
|
|
||||||
#endif //DISABLE_CAMERA
|
|
||||||
|
|
||||||
glMatrixMode(GL_PROJECTION);
|
|
||||||
glLoadIdentity();
|
|
||||||
|
|
||||||
btTransform characterWorldTrans;
|
|
||||||
|
|
||||||
//look at the vehicle
|
|
||||||
characterWorldTrans = m_ghostObject->getWorldTransform();
|
|
||||||
btVector3 up = characterWorldTrans.getBasis()[1];
|
|
||||||
btVector3 backward = -characterWorldTrans.getBasis()[2];
|
|
||||||
up.normalize ();
|
|
||||||
backward.normalize ();
|
|
||||||
|
|
||||||
m_cameraTargetPosition = characterWorldTrans.getOrigin();
|
|
||||||
m_cameraPosition = m_cameraTargetPosition + up * 10.0 + backward * 12.0;
|
|
||||||
|
|
||||||
//use the convex sweep test to find a safe position for the camera (not blocked by static geometry)
|
|
||||||
btSphereShape cameraSphere(0.2f);
|
|
||||||
btTransform cameraFrom,cameraTo;
|
|
||||||
cameraFrom.setIdentity();
|
|
||||||
cameraFrom.setOrigin(characterWorldTrans.getOrigin());
|
|
||||||
cameraTo.setIdentity();
|
|
||||||
cameraTo.setOrigin(m_cameraPosition);
|
|
||||||
|
|
||||||
btCollisionWorld::ClosestConvexResultCallback cb( characterWorldTrans.getOrigin(), cameraTo.getOrigin() );
|
|
||||||
cb.m_collisionFilterMask = btBroadphaseProxy::StaticFilter;
|
|
||||||
|
|
||||||
m_dynamicsWorld->convexSweepTest(&cameraSphere,cameraFrom,cameraTo,cb);
|
|
||||||
if (cb.hasHit())
|
|
||||||
{
|
|
||||||
|
|
||||||
btScalar minFraction = cb.m_closestHitFraction;//btMax(btScalar(0.3),cb.m_closestHitFraction);
|
|
||||||
m_cameraPosition.setInterpolate3(cameraFrom.getOrigin(),cameraTo.getOrigin(),minFraction);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//update OpenGL camera settings
|
|
||||||
glFrustum(-1.0, 1.0, -1.0, 1.0, 1.0, 10000.0);
|
|
||||||
|
|
||||||
glMatrixMode(GL_MODELVIEW);
|
|
||||||
glLoadIdentity();
|
|
||||||
|
|
||||||
gluLookAt(m_cameraPosition[0],m_cameraPosition[1],m_cameraPosition[2],
|
|
||||||
m_cameraTargetPosition[0],m_cameraTargetPosition[1], m_cameraTargetPosition[2],
|
|
||||||
m_cameraUp.getX(),m_cameraUp.getY(),m_cameraUp.getZ());
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
CharacterDemo::~CharacterDemo()
|
|
||||||
{
|
|
||||||
//cleanup in the reverse order of creation/initialization
|
|
||||||
if (m_character)
|
|
||||||
{
|
|
||||||
m_dynamicsWorld->removeCollisionObject(m_ghostObject);
|
|
||||||
}
|
|
||||||
//remove the rigidbodies from the dynamics world and delete them
|
|
||||||
int i;
|
|
||||||
for (i=m_dynamicsWorld->getNumCollisionObjects()-1; i>=0 ;i--)
|
|
||||||
{
|
|
||||||
btCollisionObject* obj = m_dynamicsWorld->getCollisionObjectArray()[i];
|
|
||||||
btRigidBody* body = btRigidBody::upcast(obj);
|
|
||||||
if (body && body->getMotionState())
|
|
||||||
{
|
|
||||||
delete body->getMotionState();
|
|
||||||
}
|
|
||||||
m_dynamicsWorld->removeCollisionObject( obj );
|
|
||||||
delete obj;
|
|
||||||
}
|
|
||||||
|
|
||||||
//delete collision shapes
|
|
||||||
for (int j=0;j<m_collisionShapes.size();j++)
|
|
||||||
{
|
|
||||||
btCollisionShape* shape = m_collisionShapes[j];
|
|
||||||
delete shape;
|
|
||||||
}
|
|
||||||
|
|
||||||
delete m_indexVertexArrays;
|
|
||||||
delete m_vertices;
|
|
||||||
|
|
||||||
//delete dynamics world
|
|
||||||
delete m_dynamicsWorld;
|
|
||||||
|
|
||||||
//delete solver
|
|
||||||
delete m_constraintSolver;
|
|
||||||
|
|
||||||
//delete broadphase
|
|
||||||
delete m_overlappingPairCache;
|
|
||||||
|
|
||||||
//delete dispatcher
|
|
||||||
delete m_dispatcher;
|
|
||||||
|
|
||||||
delete m_collisionConfiguration;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
153
extern/bullet/Demos/CharacterDemo/CharacterDemo.h
vendored
153
extern/bullet/Demos/CharacterDemo/CharacterDemo.h
vendored
@ -1,153 +0,0 @@
|
|||||||
/*
|
|
||||||
Bullet Continuous Collision Detection and Physics Library
|
|
||||||
Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied warranty.
|
|
||||||
In no event will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it freely,
|
|
||||||
subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
|
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
#ifndef CHARACTER_DEMO_H
|
|
||||||
#define CHARACTER_DEMO_H
|
|
||||||
|
|
||||||
|
|
||||||
///DYNAMIC_CHARACTER_CONTROLLER is not fully implemented yet at the moment
|
|
||||||
//#define DYNAMIC_CHARACTER_CONTROLLER 1
|
|
||||||
|
|
||||||
#include "BulletCollision/CollisionShapes/btConvexHullShape.h"
|
|
||||||
|
|
||||||
class btCharacterControllerInterface;
|
|
||||||
class btDynamicCharacterController;
|
|
||||||
class btKinematicCharacterController;
|
|
||||||
|
|
||||||
class btCollisionShape;
|
|
||||||
|
|
||||||
|
|
||||||
#include "GlutDemoApplication.h"
|
|
||||||
|
|
||||||
///CharacterDemo shows how to setup and use the built-in raycast vehicle
|
|
||||||
class CharacterDemo : public GlutDemoApplication
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
|
|
||||||
#ifdef DYNAMIC_CHARACTER_CONTROLLER
|
|
||||||
btCharacterControllerInterface* m_character;
|
|
||||||
#else
|
|
||||||
btKinematicCharacterController* m_character;
|
|
||||||
class btPairCachingGhostObject* m_ghostObject;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
btAlignedObjectArray<btCollisionShape*> m_collisionShapes;
|
|
||||||
|
|
||||||
class btBroadphaseInterface* m_overlappingPairCache;
|
|
||||||
|
|
||||||
class btCollisionDispatcher* m_dispatcher;
|
|
||||||
|
|
||||||
class btConstraintSolver* m_constraintSolver;
|
|
||||||
|
|
||||||
class btDefaultCollisionConfiguration* m_collisionConfiguration;
|
|
||||||
|
|
||||||
class btTriangleIndexVertexArray* m_indexVertexArrays;
|
|
||||||
|
|
||||||
btVector3* m_vertices;
|
|
||||||
|
|
||||||
void debugDrawContacts();
|
|
||||||
|
|
||||||
float m_cameraHeight;
|
|
||||||
|
|
||||||
float m_minCameraDistance;
|
|
||||||
float m_maxCameraDistance;
|
|
||||||
|
|
||||||
|
|
||||||
CharacterDemo();
|
|
||||||
|
|
||||||
virtual ~CharacterDemo();
|
|
||||||
|
|
||||||
virtual void clientMoveAndDisplay();
|
|
||||||
|
|
||||||
virtual void clientResetScene();
|
|
||||||
|
|
||||||
virtual void displayCallback();
|
|
||||||
|
|
||||||
///a very basic camera following the character
|
|
||||||
virtual void updateCamera();
|
|
||||||
|
|
||||||
virtual void specialKeyboard(int key, int x, int y);
|
|
||||||
|
|
||||||
virtual void specialKeyboardUp(int key, int x, int y);
|
|
||||||
|
|
||||||
void renderme();
|
|
||||||
|
|
||||||
void initPhysics();
|
|
||||||
|
|
||||||
static DemoApplication* Create()
|
|
||||||
{
|
|
||||||
CharacterDemo* demo = new CharacterDemo();
|
|
||||||
demo->myinit();
|
|
||||||
demo->initPhysics();
|
|
||||||
return demo;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#define QUAKE_BSP_IMPORTING 1
|
|
||||||
#ifdef QUAKE_BSP_IMPORTING
|
|
||||||
#include "../BspDemo/BspLoader.h"
|
|
||||||
#include "../BspDemo/BspConverter.h"
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
class BspToBulletConverter : public BspConverter
|
|
||||||
{
|
|
||||||
CharacterDemo* m_demoApp;
|
|
||||||
|
|
||||||
public:
|
|
||||||
|
|
||||||
BspToBulletConverter(CharacterDemo* demoApp)
|
|
||||||
:m_demoApp(demoApp)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual void addConvexVerticesCollider(btAlignedObjectArray<btVector3>& vertices, bool isEntity, const btVector3& entityTargetLocation)
|
|
||||||
{
|
|
||||||
///perhaps we can do something special with entities (isEntity)
|
|
||||||
///like adding a collision Triggering (as example)
|
|
||||||
|
|
||||||
if (vertices.size() > 0)
|
|
||||||
{
|
|
||||||
float mass = 0.f;
|
|
||||||
btTransform startTransform;
|
|
||||||
//can use a shift
|
|
||||||
startTransform.setIdentity();
|
|
||||||
startTransform.setOrigin(btVector3(0,-10.0f,0.0f));
|
|
||||||
//this create an internal copy of the vertices
|
|
||||||
for (int i = 0; i < vertices.size(); i++)
|
|
||||||
{
|
|
||||||
vertices[i] *= btScalar(0.5);
|
|
||||||
float t = vertices[i].getZ() * btScalar(0.75);
|
|
||||||
vertices[i].setZ(-vertices[i].getY());
|
|
||||||
vertices[i].setY(t);
|
|
||||||
}
|
|
||||||
|
|
||||||
btCollisionShape* shape = new btConvexHullShape(&(vertices[0].getX()),vertices.size());
|
|
||||||
m_demoApp->m_collisionShapes.push_back(shape);
|
|
||||||
|
|
||||||
//btRigidBody* body = m_demoApp->localCreateRigidBody(mass, startTransform,shape);
|
|
||||||
m_demoApp->localCreateRigidBody(mass, startTransform,shape);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
#endif //QUAKE_BSP_IMPORTING
|
|
||||||
|
|
||||||
|
|
||||||
#endif //CHARACTER_DEMO_H
|
|
||||||
|
|
||||||
|
|
@ -1,204 +0,0 @@
|
|||||||
#include "BulletCollision/CollisionShapes/btMultiSphereShape.h"
|
|
||||||
#include "BulletDynamics/Dynamics/btRigidBody.h"
|
|
||||||
#include "BulletCollision/CollisionDispatch/btCollisionWorld.h"
|
|
||||||
#include "LinearMath/btDefaultMotionState.h"
|
|
||||||
#include "DynamicCharacterController.h"
|
|
||||||
|
|
||||||
DynamicCharacterController::DynamicCharacterController ()
|
|
||||||
{
|
|
||||||
m_rayLambda[0] = 1.0;
|
|
||||||
m_rayLambda[1] = 1.0;
|
|
||||||
m_halfHeight = 1.0;
|
|
||||||
m_turnAngle = 0.0;
|
|
||||||
m_maxLinearVelocity = 10.0;
|
|
||||||
m_walkVelocity = 8.0; // meters/sec
|
|
||||||
m_turnVelocity = 1.0; // radians/sec
|
|
||||||
m_shape = NULL;
|
|
||||||
m_rigidBody = NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
DynamicCharacterController::~DynamicCharacterController ()
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
void DynamicCharacterController::setup (btScalar height, btScalar width, btScalar stepHeight)
|
|
||||||
{
|
|
||||||
btVector3 spherePositions[2];
|
|
||||||
btScalar sphereRadii[2];
|
|
||||||
|
|
||||||
sphereRadii[0] = width;
|
|
||||||
sphereRadii[1] = width;
|
|
||||||
spherePositions[0] = btVector3 (0.0, (height/btScalar(2.0) - width), 0.0);
|
|
||||||
spherePositions[1] = btVector3 (0.0, (-height/btScalar(2.0) + width), 0.0);
|
|
||||||
|
|
||||||
m_halfHeight = height/btScalar(2.0);
|
|
||||||
|
|
||||||
m_shape = new btMultiSphereShape (&spherePositions[0], &sphereRadii[0], 2);
|
|
||||||
|
|
||||||
btTransform startTransform;
|
|
||||||
startTransform.setIdentity ();
|
|
||||||
startTransform.setOrigin (btVector3(0.0, 2.0, 0.0));
|
|
||||||
btDefaultMotionState* myMotionState = new btDefaultMotionState(startTransform);
|
|
||||||
btRigidBody::btRigidBodyConstructionInfo cInfo(1.0, myMotionState, m_shape);
|
|
||||||
m_rigidBody = new btRigidBody(cInfo);
|
|
||||||
// kinematic vs. static doesn't work
|
|
||||||
//m_rigidBody->setCollisionFlags( m_rigidBody->getCollisionFlags() | btCollisionObject::CF_KINEMATIC_OBJECT);
|
|
||||||
m_rigidBody->setSleepingThresholds (0.0, 0.0);
|
|
||||||
m_rigidBody->setAngularFactor (0.0);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
void DynamicCharacterController::destroy ()
|
|
||||||
{
|
|
||||||
if (m_shape)
|
|
||||||
{
|
|
||||||
delete m_shape;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (m_rigidBody)
|
|
||||||
{
|
|
||||||
delete m_rigidBody;
|
|
||||||
m_rigidBody = 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
btCollisionObject* DynamicCharacterController::getCollisionObject ()
|
|
||||||
{
|
|
||||||
return m_rigidBody;
|
|
||||||
}
|
|
||||||
|
|
||||||
void DynamicCharacterController::preStep (const btCollisionWorld* collisionWorld)
|
|
||||||
{
|
|
||||||
btTransform xform;
|
|
||||||
m_rigidBody->getMotionState()->getWorldTransform (xform);
|
|
||||||
btVector3 down = -xform.getBasis()[1];
|
|
||||||
btVector3 forward = xform.getBasis()[2];
|
|
||||||
down.normalize ();
|
|
||||||
forward.normalize();
|
|
||||||
|
|
||||||
m_raySource[0] = xform.getOrigin();
|
|
||||||
m_raySource[1] = xform.getOrigin();
|
|
||||||
|
|
||||||
m_rayTarget[0] = m_raySource[0] + down * m_halfHeight * btScalar(1.1);
|
|
||||||
m_rayTarget[1] = m_raySource[1] + forward * m_halfHeight * btScalar(1.1);
|
|
||||||
|
|
||||||
class ClosestNotMe : public btCollisionWorld::ClosestRayResultCallback
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
ClosestNotMe (btRigidBody* me) : btCollisionWorld::ClosestRayResultCallback(btVector3(0.0, 0.0, 0.0), btVector3(0.0, 0.0, 0.0))
|
|
||||||
{
|
|
||||||
m_me = me;
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual btScalar addSingleResult(btCollisionWorld::LocalRayResult& rayResult,bool normalInWorldSpace)
|
|
||||||
{
|
|
||||||
if (rayResult.m_collisionObject == m_me)
|
|
||||||
return 1.0;
|
|
||||||
|
|
||||||
return ClosestRayResultCallback::addSingleResult (rayResult, normalInWorldSpace
|
|
||||||
);
|
|
||||||
}
|
|
||||||
protected:
|
|
||||||
btRigidBody* m_me;
|
|
||||||
};
|
|
||||||
|
|
||||||
ClosestNotMe rayCallback(m_rigidBody);
|
|
||||||
|
|
||||||
int i = 0;
|
|
||||||
for (i = 0; i < 2; i++)
|
|
||||||
{
|
|
||||||
rayCallback.m_closestHitFraction = 1.0;
|
|
||||||
collisionWorld->rayTest (m_raySource[i], m_rayTarget[i], rayCallback);
|
|
||||||
if (rayCallback.hasHit())
|
|
||||||
{
|
|
||||||
m_rayLambda[i] = rayCallback.m_closestHitFraction;
|
|
||||||
} else {
|
|
||||||
m_rayLambda[i] = 1.0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void DynamicCharacterController::playerStep (const btCollisionWorld* dynaWorld,btScalar dt,
|
|
||||||
int forward,
|
|
||||||
int backward,
|
|
||||||
int left,
|
|
||||||
int right,
|
|
||||||
int jump)
|
|
||||||
{
|
|
||||||
btTransform xform;
|
|
||||||
m_rigidBody->getMotionState()->getWorldTransform (xform);
|
|
||||||
|
|
||||||
/* Handle turning */
|
|
||||||
if (left)
|
|
||||||
m_turnAngle -= dt * m_turnVelocity;
|
|
||||||
if (right)
|
|
||||||
m_turnAngle += dt * m_turnVelocity;
|
|
||||||
|
|
||||||
xform.setRotation (btQuaternion (btVector3(0.0, 1.0, 0.0), m_turnAngle));
|
|
||||||
|
|
||||||
btVector3 linearVelocity = m_rigidBody->getLinearVelocity();
|
|
||||||
btScalar speed = m_rigidBody->getLinearVelocity().length();
|
|
||||||
|
|
||||||
btVector3 forwardDir = xform.getBasis()[2];
|
|
||||||
forwardDir.normalize ();
|
|
||||||
btVector3 walkDirection = btVector3(0.0, 0.0, 0.0);
|
|
||||||
btScalar walkSpeed = m_walkVelocity * dt;
|
|
||||||
|
|
||||||
if (forward)
|
|
||||||
walkDirection += forwardDir;
|
|
||||||
if (backward)
|
|
||||||
walkDirection -= forwardDir;
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if (!forward && !backward && onGround())
|
|
||||||
{
|
|
||||||
/* Dampen when on the ground and not being moved by the player */
|
|
||||||
linearVelocity *= btScalar(0.2);
|
|
||||||
m_rigidBody->setLinearVelocity (linearVelocity);
|
|
||||||
} else {
|
|
||||||
if (speed < m_maxLinearVelocity)
|
|
||||||
{
|
|
||||||
btVector3 velocity = linearVelocity + walkDirection * walkSpeed;
|
|
||||||
m_rigidBody->setLinearVelocity (velocity);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
m_rigidBody->getMotionState()->setWorldTransform (xform);
|
|
||||||
m_rigidBody->setCenterOfMassTransform (xform);
|
|
||||||
}
|
|
||||||
|
|
||||||
bool DynamicCharacterController::canJump () const
|
|
||||||
{
|
|
||||||
return onGround();
|
|
||||||
}
|
|
||||||
|
|
||||||
void DynamicCharacterController::jump ()
|
|
||||||
{
|
|
||||||
if (!canJump())
|
|
||||||
return;
|
|
||||||
|
|
||||||
btTransform xform;
|
|
||||||
m_rigidBody->getMotionState()->getWorldTransform (xform);
|
|
||||||
btVector3 up = xform.getBasis()[1];
|
|
||||||
up.normalize ();
|
|
||||||
btScalar magnitude = (btScalar(1.0)/m_rigidBody->getInvMass()) * btScalar(8.0);
|
|
||||||
m_rigidBody->applyCentralImpulse (up * magnitude);
|
|
||||||
}
|
|
||||||
|
|
||||||
bool DynamicCharacterController::onGround () const
|
|
||||||
{
|
|
||||||
return m_rayLambda[0] < btScalar(1.0);
|
|
||||||
}
|
|
||||||
|
|
||||||
void DynamicCharacterController::reset ()
|
|
||||||
{
|
|
||||||
}
|
|
||||||
void DynamicCharacterController::warp (const btVector3& origin)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
void DynamicCharacterController::registerPairCacheAndDispatcher (btOverlappingPairCache* pairCache, btCollisionDispatcher* dispatcher)
|
|
||||||
{
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
@ -1,55 +0,0 @@
|
|||||||
#ifndef CHARACTER_CONTROLLER_H
|
|
||||||
#define CHARACTER_CONTROLLER_H
|
|
||||||
|
|
||||||
#include "LinearMath/btVector3.h"
|
|
||||||
|
|
||||||
#include "BulletDynamics/Character/btCharacterControllerInterface.h"
|
|
||||||
|
|
||||||
class btCollisionShape;
|
|
||||||
class btRigidBody;
|
|
||||||
class btCollisionWorld;
|
|
||||||
|
|
||||||
///DynamicCharacterController is obsolete/unsupported at the moment
|
|
||||||
class DynamicCharacterController : public btCharacterControllerInterface
|
|
||||||
{
|
|
||||||
protected:
|
|
||||||
btScalar m_halfHeight;
|
|
||||||
btCollisionShape* m_shape;
|
|
||||||
btRigidBody* m_rigidBody;
|
|
||||||
|
|
||||||
btVector3 m_raySource[2];
|
|
||||||
btVector3 m_rayTarget[2];
|
|
||||||
btScalar m_rayLambda[2];
|
|
||||||
btVector3 m_rayNormal[2];
|
|
||||||
|
|
||||||
btScalar m_turnAngle;
|
|
||||||
|
|
||||||
btScalar m_maxLinearVelocity;
|
|
||||||
btScalar m_walkVelocity;
|
|
||||||
btScalar m_turnVelocity;
|
|
||||||
public:
|
|
||||||
DynamicCharacterController ();
|
|
||||||
~DynamicCharacterController ();
|
|
||||||
void setup (btScalar height = 2.0, btScalar width = 0.25, btScalar stepHeight = 0.25);
|
|
||||||
void destroy ();
|
|
||||||
|
|
||||||
virtual void reset ();
|
|
||||||
virtual void warp (const btVector3& origin);
|
|
||||||
virtual void registerPairCacheAndDispatcher (btOverlappingPairCache* pairCache, btCollisionDispatcher* dispatcher);
|
|
||||||
|
|
||||||
btCollisionObject* getCollisionObject ();
|
|
||||||
|
|
||||||
void preStep (const btCollisionWorld* collisionWorld);
|
|
||||||
void playerStep (const btCollisionWorld* collisionWorld,btScalar dt,
|
|
||||||
int forward,
|
|
||||||
int backward,
|
|
||||||
int left,
|
|
||||||
int right,
|
|
||||||
int jump);
|
|
||||||
bool canJump () const;
|
|
||||||
void jump ();
|
|
||||||
|
|
||||||
bool onGround () const;
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif
|
|
19
extern/bullet/Demos/CharacterDemo/main.cpp
vendored
19
extern/bullet/Demos/CharacterDemo/main.cpp
vendored
@ -1,19 +0,0 @@
|
|||||||
|
|
||||||
#include "CharacterDemo.h"
|
|
||||||
#include "GlutStuff.h"
|
|
||||||
#include "GLDebugDrawer.h"
|
|
||||||
#include "btBulletDynamicsCommon.h"
|
|
||||||
|
|
||||||
GLDebugDrawer gDebugDrawer;
|
|
||||||
|
|
||||||
int main(int argc,char** argv)
|
|
||||||
{
|
|
||||||
|
|
||||||
CharacterDemo* characterDemo = new CharacterDemo;
|
|
||||||
|
|
||||||
characterDemo->initPhysics();
|
|
||||||
characterDemo->getDynamicsWorld()->setDebugDrawer(&gDebugDrawer);
|
|
||||||
|
|
||||||
return glutmain(argc, argv,640,480,"Bullet Character Demo. http://www.continuousphysics.com/Bullet/phpBB2/", characterDemo);
|
|
||||||
}
|
|
||||||
|
|
54
extern/bullet/Demos/CollisionDemo/CMakeLists.txt
vendored
54
extern/bullet/Demos/CollisionDemo/CMakeLists.txt
vendored
@ -1,54 +0,0 @@
|
|||||||
# This is basically the overall name of the project in Visual Studio this is the name of the Solution File
|
|
||||||
|
|
||||||
|
|
||||||
# For every executable you have with a main method you should have an add_executable line below.
|
|
||||||
# For every add executable line you should list every .cpp and .h file you have associated with that executable.
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# You shouldn't have to modify anything below this line
|
|
||||||
########################################################
|
|
||||||
|
|
||||||
|
|
||||||
INCLUDE_DIRECTORIES(
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/src ${BULLET_PHYSICS_SOURCE_DIR}/Demos/OpenGL
|
|
||||||
)
|
|
||||||
|
|
||||||
LINK_LIBRARIES(
|
|
||||||
OpenGLSupport BulletDynamics BulletCollision LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY}
|
|
||||||
)
|
|
||||||
|
|
||||||
IF (WIN32)
|
|
||||||
ADD_EXECUTABLE(AppCollisionDemo
|
|
||||||
CollisionDemo.cpp
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/build/bullet.rc
|
|
||||||
)
|
|
||||||
ELSE()
|
|
||||||
ADD_EXECUTABLE(AppCollisionDemo
|
|
||||||
CollisionDemo.cpp
|
|
||||||
)
|
|
||||||
ENDIF()
|
|
||||||
|
|
||||||
IF (WIN32)
|
|
||||||
IF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES)
|
|
||||||
IF (CMAKE_CL_64)
|
|
||||||
ADD_CUSTOM_COMMAND(
|
|
||||||
TARGET AppCollisionDemo
|
|
||||||
POST_BUILD
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/glut64.dll ${CMAKE_CURRENT_BINARY_DIR}
|
|
||||||
)
|
|
||||||
ELSE(CMAKE_CL_64)
|
|
||||||
ADD_CUSTOM_COMMAND(
|
|
||||||
TARGET AppCollisionDemo
|
|
||||||
POST_BUILD
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/GLUT32.DLL ${CMAKE_CURRENT_BINARY_DIR}
|
|
||||||
)
|
|
||||||
ENDIF(CMAKE_CL_64)
|
|
||||||
ENDIF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES)
|
|
||||||
ENDIF(WIN32)
|
|
||||||
|
|
||||||
IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES)
|
|
||||||
SET_TARGET_PROPERTIES(AppCollisionDemo PROPERTIES DEBUG_POSTFIX "_Debug")
|
|
||||||
SET_TARGET_PROPERTIES(AppCollisionDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel")
|
|
||||||
SET_TARGET_PROPERTIES(AppCollisionDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo")
|
|
||||||
ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES)
|
|
380
extern/bullet/Demos/CollisionDemo/CollisionDemo.cpp
vendored
380
extern/bullet/Demos/CollisionDemo/CollisionDemo.cpp
vendored
@ -1,380 +0,0 @@
|
|||||||
/*
|
|
||||||
Bullet Continuous Collision Detection and Physics Library
|
|
||||||
Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied warranty.
|
|
||||||
In no event will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it freely,
|
|
||||||
subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
|
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
///
|
|
||||||
/// Collision Demo shows a degenerate case, where the Simplex solver has to deal with near-affine dependent cases
|
|
||||||
/// See the define CATCH_DEGENERATE_TETRAHEDRON in Bullet's btVoronoiSimplexSolver.cpp
|
|
||||||
///
|
|
||||||
|
|
||||||
|
|
||||||
//#define CHECK_GENSHER_TRIANGLE_CASE 1
|
|
||||||
|
|
||||||
|
|
||||||
///This low-level internal demo does intentionally NOT use the btBulletCollisionCommon.h header
|
|
||||||
///It needs internal access
|
|
||||||
#include "GL_Simplex1to4.h"
|
|
||||||
#include "LinearMath/btQuaternion.h"
|
|
||||||
#include "LinearMath/btTransform.h"
|
|
||||||
#include "BulletCollision/NarrowPhaseCollision/btVoronoiSimplexSolver.h"
|
|
||||||
#include "BulletCollision/CollisionShapes/btBoxShape.h"
|
|
||||||
#include "BulletCollision/NarrowPhaseCollision/btGjkPairDetector.h"
|
|
||||||
#include "BulletCollision/NarrowPhaseCollision/btPointCollector.h"
|
|
||||||
#include "BulletCollision/NarrowPhaseCollision/btVoronoiSimplexSolver.h"
|
|
||||||
#include "BulletCollision/NarrowPhaseCollision/btConvexPenetrationDepthSolver.h"
|
|
||||||
#include "BulletCollision/NarrowPhaseCollision/btGjkEpaPenetrationDepthSolver.h"
|
|
||||||
#include "LinearMath/btTransformUtil.h"
|
|
||||||
|
|
||||||
#include "CollisionDemo.h"
|
|
||||||
#include "GL_ShapeDrawer.h"
|
|
||||||
#include "GlutStuff.h"
|
|
||||||
#include "LinearMath/btIDebugDraw.h"
|
|
||||||
#include "../OpenGL/GLDebugDrawer.h"
|
|
||||||
GLDebugDrawer debugDrawer;
|
|
||||||
|
|
||||||
|
|
||||||
float yaw=0.f,pitch=0.f,roll=0.f;
|
|
||||||
const int maxNumObjects = 4;
|
|
||||||
const int numObjects = 2;
|
|
||||||
|
|
||||||
GL_Simplex1to4 simplex;
|
|
||||||
|
|
||||||
btPolyhedralConvexShape* shapePtr[maxNumObjects];
|
|
||||||
|
|
||||||
btTransform tr[numObjects];
|
|
||||||
int screenWidth = 640;
|
|
||||||
int screenHeight = 480;
|
|
||||||
|
|
||||||
void DrawRasterizerLine(float const* , float const*, int)
|
|
||||||
{
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
int main(int argc,char** argv)
|
|
||||||
{
|
|
||||||
CollisionDemo* colDemo = new CollisionDemo();
|
|
||||||
|
|
||||||
#ifdef CHECK_GENSHER_TRIANGLE_CASE
|
|
||||||
colDemo->setCameraDistance(8.f);
|
|
||||||
#else
|
|
||||||
colDemo->setCameraDistance(4.f);
|
|
||||||
|
|
||||||
#endif //
|
|
||||||
colDemo->initPhysics();
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
return glutmain(argc, argv,screenWidth,screenHeight,"Collision Demo",colDemo);
|
|
||||||
}
|
|
||||||
|
|
||||||
void CollisionDemo::initPhysics()
|
|
||||||
{
|
|
||||||
setTexturing(false);
|
|
||||||
setShadows(false);
|
|
||||||
|
|
||||||
//m_debugMode |= btIDebugDraw::DBG_DrawWireframe;
|
|
||||||
#ifdef CHECK_GENSHER_TRIANGLE_CASE
|
|
||||||
m_azi = 140.f;
|
|
||||||
#else
|
|
||||||
m_azi = 250.f;
|
|
||||||
#endif
|
|
||||||
m_ele = 25.f;
|
|
||||||
|
|
||||||
m_azi = 0;
|
|
||||||
m_ele = 0;
|
|
||||||
m_cameraTargetPosition.setValue(8.12,0.39,0);
|
|
||||||
|
|
||||||
tr[0].setIdentity();
|
|
||||||
tr[0].setOrigin(btVector3(10,0,0));
|
|
||||||
tr[1].setIdentity();
|
|
||||||
tr[1].setOrigin(btVector3(0,0,0));
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef CHECK_GENSHER_TRIANGLE_CASE
|
|
||||||
tr[0].setIdentity();
|
|
||||||
tr[1].setIdentity();
|
|
||||||
#endif //CHECK_GENSHER_TRIANGLE_CASE
|
|
||||||
|
|
||||||
btVector3 boxHalfExtentsA(1,1,1);//1.0000004768371582f,1.0000004768371582f,1.0000001192092896f);
|
|
||||||
btVector3 boxHalfExtentsB(4,4,4);//3.2836332321166992f,3.2836332321166992f,3.2836320400238037f);
|
|
||||||
|
|
||||||
#ifndef CHECK_GENSHER_TRIANGLE_CASE
|
|
||||||
btBoxShape* boxA = new btBoxShape(boxHalfExtentsA);
|
|
||||||
btBoxShape* boxB = new btBoxShape(boxHalfExtentsB);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef CHECK_GENSHER_TRIANGLE_CASE
|
|
||||||
shapePtr[0] = trishapeA;
|
|
||||||
shapePtr[1] = trishapeB;
|
|
||||||
#else
|
|
||||||
shapePtr[0] = boxA;
|
|
||||||
shapePtr[1] = boxB;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
void CollisionDemo::clientMoveAndDisplay()
|
|
||||||
{
|
|
||||||
|
|
||||||
displayCallback();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
static btVoronoiSimplexSolver sGjkSimplexSolver;
|
|
||||||
btSimplexSolverInterface& gGjkSimplexSolver = sGjkSimplexSolver;
|
|
||||||
|
|
||||||
static btScalar gContactBreakingThreshold=.02f;
|
|
||||||
int myiter = 1;
|
|
||||||
int mystate = 2;
|
|
||||||
|
|
||||||
int checkPerturbation = 1;
|
|
||||||
int numPerturbationIterations = 20;
|
|
||||||
void CollisionDemo::displayCallback(void) {
|
|
||||||
|
|
||||||
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
|
||||||
glDisable(GL_LIGHTING);
|
|
||||||
|
|
||||||
btVoronoiSimplexSolver sGjkSimplexSolver;
|
|
||||||
btGjkEpaPenetrationDepthSolver epaSolver;
|
|
||||||
btPointCollector gjkOutput;
|
|
||||||
btVector3 worldBoundsMin(-1000,-1000,-1000);
|
|
||||||
btVector3 worldBoundsMax(1000,1000,1000);
|
|
||||||
{
|
|
||||||
btGjkPairDetector convexConvex(shapePtr[0],shapePtr[1],&sGjkSimplexSolver,&epaSolver);
|
|
||||||
|
|
||||||
btGjkPairDetector::ClosestPointInput input;
|
|
||||||
input.m_transformA = tr[0];
|
|
||||||
input.m_transformB = tr[1];
|
|
||||||
|
|
||||||
|
|
||||||
convexConvex.getClosestPoints(input, gjkOutput, 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
ATTRIBUTE_ALIGNED16(btScalar) m[16];
|
|
||||||
int i;
|
|
||||||
|
|
||||||
//m_ele = 21.2;
|
|
||||||
//m_azi = -56.6;
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
for (i=0;i<numObjects;i++)
|
|
||||||
{
|
|
||||||
tr[i].getOpenGLMatrix( m );
|
|
||||||
//m_shapeDrawer->drawOpenGL(m,shapePtr[i],btVector3(119./255.,147./255.,60./255.),btIDebugDraw::DBG_FastWireframe,worldBoundsMin,worldBoundsMax);
|
|
||||||
m_shapeDrawer->drawOpenGL(m,shapePtr[i],btVector3(0.6,0.6,0.6),btIDebugDraw::DBG_FastWireframe,worldBoundsMin,worldBoundsMax);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (gjkOutput.m_hasResult)
|
|
||||||
{
|
|
||||||
printf("original distance: %10.4f\n", gjkOutput.m_distance);
|
|
||||||
btVector3 endPt = gjkOutput.m_pointInWorld +
|
|
||||||
gjkOutput.m_normalOnBInWorld*gjkOutput.m_distance;
|
|
||||||
|
|
||||||
debugDrawer.drawLine(gjkOutput.m_pointInWorld,endPt,btVector3(0,0,0));
|
|
||||||
debugDrawer.drawSphere(gjkOutput.m_pointInWorld,0.05,btVector3(0,0,0));
|
|
||||||
debugDrawer.drawSphere(endPt,0.05,btVector3(0,0,0));
|
|
||||||
|
|
||||||
bool perturbeA = false;//true;
|
|
||||||
const btScalar angleLimit = 0.125f * SIMD_PI;
|
|
||||||
btScalar perturbeAngle;
|
|
||||||
btScalar radiusA = shapePtr[0]->getAngularMotionDisc();
|
|
||||||
btScalar radiusB = shapePtr[1]->getAngularMotionDisc();
|
|
||||||
|
|
||||||
if (radiusA < radiusB)
|
|
||||||
{
|
|
||||||
perturbeAngle = gContactBreakingThreshold /radiusA;
|
|
||||||
perturbeA = true;
|
|
||||||
} else
|
|
||||||
{
|
|
||||||
perturbeAngle = gContactBreakingThreshold / radiusB;
|
|
||||||
perturbeA = false;
|
|
||||||
}
|
|
||||||
if ( perturbeAngle > angleLimit )
|
|
||||||
perturbeAngle = angleLimit;
|
|
||||||
|
|
||||||
perturbeAngle*=5;
|
|
||||||
|
|
||||||
btVector3 v0,v1;
|
|
||||||
btPlaneSpace1(gjkOutput.m_normalOnBInWorld,v0,v1);
|
|
||||||
|
|
||||||
glLineWidth(5);
|
|
||||||
int i;
|
|
||||||
i=0;
|
|
||||||
if (myiter>=numPerturbationIterations)
|
|
||||||
myiter=0;
|
|
||||||
if (mystate<2)
|
|
||||||
{
|
|
||||||
i= myiter;
|
|
||||||
}
|
|
||||||
|
|
||||||
for ( ;i<numPerturbationIterations;i++)
|
|
||||||
{
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
btGjkPairDetector::ClosestPointInput input;
|
|
||||||
input.m_transformA = tr[0];
|
|
||||||
input.m_transformB = tr[1];
|
|
||||||
sGjkSimplexSolver.reset();
|
|
||||||
|
|
||||||
btQuaternion perturbeRot(v0,perturbeAngle);
|
|
||||||
btScalar iterationAngle = i*(SIMD_2_PI/btScalar(numPerturbationIterations));
|
|
||||||
btQuaternion rotq(gjkOutput.m_normalOnBInWorld,iterationAngle);
|
|
||||||
if (perturbeA)
|
|
||||||
{
|
|
||||||
input.m_transformA.setBasis( btMatrix3x3(rotq*perturbeRot*rotq.inverse())*tr[0].getBasis());
|
|
||||||
} else
|
|
||||||
{
|
|
||||||
input.m_transformB.setBasis( btMatrix3x3(rotq.inverse()*perturbeRot*rotq)*tr[1].getBasis());
|
|
||||||
}
|
|
||||||
debugDrawer.drawTransform(input.m_transformA,1.0);
|
|
||||||
btGjkPairDetector convexConvex(shapePtr[0],shapePtr[1],&sGjkSimplexSolver,&epaSolver);
|
|
||||||
input.m_maximumDistanceSquared = BT_LARGE_FLOAT;
|
|
||||||
gjkOutput.m_distance = BT_LARGE_FLOAT;
|
|
||||||
convexConvex.getClosestPoints(input, gjkOutput, 0);
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if (mystate!=2 || i==myiter)
|
|
||||||
|
|
||||||
{
|
|
||||||
ATTRIBUTE_ALIGNED16(btScalar) m[16];
|
|
||||||
|
|
||||||
input.m_transformA.getOpenGLMatrix( m );
|
|
||||||
//m_shapeDrawer->drawOpenGL(m,shapePtr[0],btVector3(108./255.,131./255.,158./255),btIDebugDraw::DBG_FastWireframe,worldBoundsMin,worldBoundsMax);
|
|
||||||
m_shapeDrawer->drawOpenGL(m,shapePtr[0],btVector3(0.3,0.3,1),btIDebugDraw::DBG_FastWireframe,worldBoundsMin,worldBoundsMax);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
if (1)//gjkOutput.m_hasResult)
|
|
||||||
{
|
|
||||||
|
|
||||||
printf("perturbed distance: %10.4f\n", gjkOutput.m_distance);
|
|
||||||
btVector3 startPt,endPt;
|
|
||||||
btScalar depth = 0;
|
|
||||||
if (perturbeA)
|
|
||||||
{
|
|
||||||
btVector3 endPtOrg = gjkOutput.m_pointInWorld + gjkOutput.m_normalOnBInWorld*gjkOutput.m_distance;
|
|
||||||
endPt = (tr[0]*input.m_transformA.inverse())(endPtOrg);
|
|
||||||
depth = (endPt - gjkOutput.m_pointInWorld).dot(gjkOutput.m_normalOnBInWorld);
|
|
||||||
startPt = endPt-gjkOutput.m_normalOnBInWorld*depth;
|
|
||||||
} else
|
|
||||||
{
|
|
||||||
endPt = gjkOutput.m_pointInWorld + gjkOutput.m_normalOnBInWorld*gjkOutput.m_distance;
|
|
||||||
startPt = (tr[1]*input.m_transformB.inverse())(gjkOutput.m_pointInWorld);
|
|
||||||
depth = (endPt - startPt).dot(gjkOutput.m_normalOnBInWorld);
|
|
||||||
}
|
|
||||||
|
|
||||||
printf("corrected distance: %10.4f\n", depth);
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
debugDrawer.drawLine(startPt,endPt,btVector3(1,0,0));
|
|
||||||
debugDrawer.drawSphere(startPt,0.05,btVector3(0,1,0));
|
|
||||||
debugDrawer.drawSphere(endPt,0.05,btVector3(0,0,1));
|
|
||||||
}
|
|
||||||
if (mystate<2)
|
|
||||||
break;
|
|
||||||
if (mystate==2 && i>myiter)
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
static int looper = 0;
|
|
||||||
if (looper++>10)
|
|
||||||
{
|
|
||||||
looper =0;
|
|
||||||
checkPerturbation++;
|
|
||||||
if (checkPerturbation>numPerturbationIterations)
|
|
||||||
checkPerturbation=0;
|
|
||||||
}
|
|
||||||
|
|
||||||
GL_ShapeDrawer::drawCoordSystem();
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if (mystate==1 || mystate==2)
|
|
||||||
{
|
|
||||||
static int count = 10;
|
|
||||||
count--;
|
|
||||||
if (count<0)
|
|
||||||
{
|
|
||||||
count=10;
|
|
||||||
myiter++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
btQuaternion orn;
|
|
||||||
orn.setEuler(yaw,pitch,roll);
|
|
||||||
//let it rotate
|
|
||||||
//tr[0].setRotation(orn);
|
|
||||||
|
|
||||||
pitch += 0.005f;
|
|
||||||
yaw += 0.01f;
|
|
||||||
|
|
||||||
glFlush();
|
|
||||||
glutSwapBuffers();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void CollisionDemo::specialKeyboard(int key, int x, int y)
|
|
||||||
{
|
|
||||||
switch (key)
|
|
||||||
{
|
|
||||||
case GLUT_KEY_DOWN:
|
|
||||||
case GLUT_KEY_UP:
|
|
||||||
{
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
default:
|
|
||||||
DemoApplication::specialKeyboard(key,x,y);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
void CollisionDemo::specialKeyboardUp(int key, int x, int y)
|
|
||||||
{
|
|
||||||
switch (key)
|
|
||||||
{
|
|
||||||
case GLUT_KEY_UP :
|
|
||||||
{
|
|
||||||
myiter++;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
case GLUT_KEY_DOWN:
|
|
||||||
{
|
|
||||||
mystate++;
|
|
||||||
if (mystate>1)
|
|
||||||
myiter=0;
|
|
||||||
if (mystate>=4)
|
|
||||||
mystate = 0;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
default:
|
|
||||||
DemoApplication::specialKeyboardUp(key,x,y);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,38 +0,0 @@
|
|||||||
/*
|
|
||||||
Bullet Continuous Collision Detection and Physics Library
|
|
||||||
Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied warranty.
|
|
||||||
In no event will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it freely,
|
|
||||||
subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
|
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
#ifndef COLLISION_DEMO_H
|
|
||||||
#define COLLISION_DEMO_H
|
|
||||||
|
|
||||||
#include "GlutDemoApplication.h"
|
|
||||||
|
|
||||||
///CollisionDemo shows the low-level direct access to GJK
|
|
||||||
class CollisionDemo : public GlutDemoApplication
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
|
|
||||||
void initPhysics();
|
|
||||||
|
|
||||||
virtual void clientMoveAndDisplay();
|
|
||||||
|
|
||||||
virtual void displayCallback();
|
|
||||||
|
|
||||||
virtual void specialKeyboardUp(int key, int x, int y);
|
|
||||||
|
|
||||||
virtual void specialKeyboard(int key, int x, int y);
|
|
||||||
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif //COLLISION_DEMO_H
|
|
||||||
|
|
@ -1,77 +0,0 @@
|
|||||||
# This is basically the overall name of the project in Visual Studio this is the name of the Solution File
|
|
||||||
|
|
||||||
|
|
||||||
# For every executable you have with a main method you should have an add_executable line below.
|
|
||||||
# For every add executable line you should list every .cpp and .h file you have associated with that executable.
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# You shouldn't have to modify anything below this line
|
|
||||||
########################################################
|
|
||||||
|
|
||||||
|
|
||||||
IF (USE_GLUT)
|
|
||||||
INCLUDE_DIRECTORIES(
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/src ${BULLET_PHYSICS_SOURCE_DIR}/Demos/OpenGL
|
|
||||||
)
|
|
||||||
|
|
||||||
LINK_LIBRARIES(
|
|
||||||
OpenGLSupport BulletDynamics BulletCollision LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY}
|
|
||||||
)
|
|
||||||
|
|
||||||
IF (WIN32)
|
|
||||||
ADD_EXECUTABLE(AppCollisionInterfaceDemo
|
|
||||||
CollisionInterfaceDemo.cpp
|
|
||||||
CollisionInterfaceDemo.h
|
|
||||||
main.cpp
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/build/bullet.rc
|
|
||||||
)
|
|
||||||
ELSE()
|
|
||||||
ADD_EXECUTABLE(AppCollisionInterfaceDemo
|
|
||||||
CollisionInterfaceDemo.cpp
|
|
||||||
CollisionInterfaceDemo.h
|
|
||||||
main.cpp
|
|
||||||
)
|
|
||||||
ENDIF()
|
|
||||||
IF (WIN32)
|
|
||||||
IF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES)
|
|
||||||
IF (CMAKE_CL_64)
|
|
||||||
ADD_CUSTOM_COMMAND(
|
|
||||||
TARGET AppCollisionInterfaceDemo
|
|
||||||
POST_BUILD
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/glut64.dll ${CMAKE_CURRENT_BINARY_DIR}
|
|
||||||
)
|
|
||||||
ELSE(CMAKE_CL_64)
|
|
||||||
ADD_CUSTOM_COMMAND(
|
|
||||||
TARGET AppCollisionInterfaceDemo
|
|
||||||
POST_BUILD
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/GLUT32.DLL ${CMAKE_CURRENT_BINARY_DIR}
|
|
||||||
)
|
|
||||||
ENDIF(CMAKE_CL_64)
|
|
||||||
ENDIF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES)
|
|
||||||
ENDIF(WIN32)
|
|
||||||
ELSE (USE_GLUT)
|
|
||||||
INCLUDE_DIRECTORIES(
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/src ${BULLET_PHYSICS_SOURCE_DIR}/Demos/OpenGL
|
|
||||||
)
|
|
||||||
|
|
||||||
LINK_LIBRARIES(
|
|
||||||
OpenGLSupport BulletDynamics BulletCollision LinearMath ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY}
|
|
||||||
)
|
|
||||||
|
|
||||||
ADD_EXECUTABLE(AppCollisionInterfaceDemo
|
|
||||||
WIN32
|
|
||||||
CollisionInterfaceDemo.cpp
|
|
||||||
CollisionInterfaceDemo.h
|
|
||||||
Win32CollisionInterfaceDemo.cpp
|
|
||||||
../OpenGL/Win32AppMain.cpp
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/build/bullet.rc
|
|
||||||
)
|
|
||||||
ENDIF (USE_GLUT)
|
|
||||||
|
|
||||||
|
|
||||||
IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES)
|
|
||||||
SET_TARGET_PROPERTIES(AppCollisionInterfaceDemo PROPERTIES DEBUG_POSTFIX "_Debug")
|
|
||||||
SET_TARGET_PROPERTIES(AppCollisionInterfaceDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel")
|
|
||||||
SET_TARGET_PROPERTIES(AppCollisionInterfaceDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo")
|
|
||||||
ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES)
|
|
@ -1,292 +0,0 @@
|
|||||||
/*
|
|
||||||
Bullet Continuous Collision Detection and Physics Library
|
|
||||||
Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied warranty.
|
|
||||||
In no event will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it freely,
|
|
||||||
subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
|
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
///
|
|
||||||
/// CollisionInterfaceDemo shows high level usage of the Collision Detection.
|
|
||||||
///
|
|
||||||
#define TEST_NOT_ADDING_OBJECTS_TO_WORLD
|
|
||||||
|
|
||||||
#include "GL_Simplex1to4.h"
|
|
||||||
|
|
||||||
//include common Bullet Collision Detection headerfiles
|
|
||||||
#include "btBulletCollisionCommon.h"
|
|
||||||
|
|
||||||
#include "LinearMath/btIDebugDraw.h"
|
|
||||||
#include "GL_ShapeDrawer.h"
|
|
||||||
#include "CollisionInterfaceDemo.h"
|
|
||||||
#include "GlutStuff.h"
|
|
||||||
#include "GLDebugDrawer.h"
|
|
||||||
|
|
||||||
btScalar yaw=0.f,pitch=0.f,roll=0.f;
|
|
||||||
const int maxNumObjects = 4;
|
|
||||||
const int numObjects = 2;
|
|
||||||
|
|
||||||
GL_Simplex1to4 simplex;
|
|
||||||
|
|
||||||
btCollisionObject objects[maxNumObjects];
|
|
||||||
btCollisionWorld* collisionWorld = 0;
|
|
||||||
|
|
||||||
GLDebugDrawer debugDrawer;
|
|
||||||
|
|
||||||
|
|
||||||
void CollisionInterfaceDemo::initPhysics()
|
|
||||||
{
|
|
||||||
|
|
||||||
m_debugMode |= btIDebugDraw::DBG_DrawWireframe;
|
|
||||||
|
|
||||||
btMatrix3x3 basisA;
|
|
||||||
basisA.setIdentity();
|
|
||||||
|
|
||||||
btMatrix3x3 basisB;
|
|
||||||
basisB.setIdentity();
|
|
||||||
|
|
||||||
objects[0].getWorldTransform().setBasis(basisA);
|
|
||||||
objects[1].getWorldTransform().setBasis(basisB);
|
|
||||||
|
|
||||||
btBoxShape* boxA = new btBoxShape(btVector3(1,1,1));
|
|
||||||
boxA->setMargin(0.f);
|
|
||||||
|
|
||||||
btBoxShape* boxB = new btBoxShape(btVector3(0.5,0.5,0.5));
|
|
||||||
boxB->setMargin(0.f);
|
|
||||||
//ConvexHullShape hullA(points0,3);
|
|
||||||
//hullA.setLocalScaling(btVector3(3,3,3));
|
|
||||||
//ConvexHullShape hullB(points1,4);
|
|
||||||
//hullB.setLocalScaling(btVector3(4,4,4));
|
|
||||||
|
|
||||||
objects[0].setCollisionShape(boxA);//&hullA;
|
|
||||||
objects[1].setCollisionShape(boxB);//&hullB;
|
|
||||||
|
|
||||||
btDefaultCollisionConfiguration* collisionConfiguration = new btDefaultCollisionConfiguration();
|
|
||||||
btCollisionDispatcher* dispatcher = new btCollisionDispatcher(collisionConfiguration);
|
|
||||||
btVector3 worldAabbMin(-1000,-1000,-1000);
|
|
||||||
btVector3 worldAabbMax(1000,1000,1000);
|
|
||||||
|
|
||||||
btAxisSweep3* broadphase = new btAxisSweep3(worldAabbMin,worldAabbMax);
|
|
||||||
|
|
||||||
//SimpleBroadphase is a brute force alternative, performing N^2 aabb overlap tests
|
|
||||||
//SimpleBroadphase* broadphase = new btSimpleBroadphase;
|
|
||||||
|
|
||||||
collisionWorld = new btCollisionWorld(dispatcher,broadphase,collisionConfiguration);
|
|
||||||
collisionWorld->setDebugDrawer(&debugDrawer);
|
|
||||||
|
|
||||||
#ifdef TEST_NOT_ADDING_OBJECTS_TO_WORLD
|
|
||||||
// collisionWorld->addCollisionObject(&objects[0]);
|
|
||||||
collisionWorld->addCollisionObject(&objects[1]);
|
|
||||||
#endif //TEST_NOT_ADDING_OBJECTS_TO_WORLD
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
//to be implemented by the demo
|
|
||||||
|
|
||||||
void CollisionInterfaceDemo::clientMoveAndDisplay()
|
|
||||||
{
|
|
||||||
|
|
||||||
displayCallback();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
static btVoronoiSimplexSolver sGjkSimplexSolver;
|
|
||||||
btSimplexSolverInterface& gGjkSimplexSolver = sGjkSimplexSolver;
|
|
||||||
|
|
||||||
struct btDrawingResult : public btCollisionWorld::ContactResultCallback
|
|
||||||
{
|
|
||||||
virtual btScalar addSingleResult(btManifoldPoint& cp, const btCollisionObjectWrapper* colObj0Wrap,int partId0,int index0,const btCollisionObjectWrapper* colObj1Wrap,int partId1,int index1)
|
|
||||||
{
|
|
||||||
|
|
||||||
glBegin(GL_LINES);
|
|
||||||
glColor3f(0, 0, 0);
|
|
||||||
|
|
||||||
btVector3 ptA = cp.getPositionWorldOnA();
|
|
||||||
btVector3 ptB = cp.getPositionWorldOnB();
|
|
||||||
|
|
||||||
glVertex3d(ptA.x(),ptA.y(),ptA.z());
|
|
||||||
glVertex3d(ptB.x(),ptB.y(),ptB.z());
|
|
||||||
glEnd();
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
void CollisionInterfaceDemo::displayCallback(void) {
|
|
||||||
|
|
||||||
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
|
||||||
glDisable(GL_LIGHTING);
|
|
||||||
|
|
||||||
btScalar m[16];
|
|
||||||
|
|
||||||
btVector3 worldBoundsMin,worldBoundsMax;
|
|
||||||
collisionWorld->getBroadphase()->getBroadphaseAabb(worldBoundsMin,worldBoundsMax);
|
|
||||||
|
|
||||||
|
|
||||||
int i;
|
|
||||||
for (i=0;i<numObjects;i++)
|
|
||||||
{
|
|
||||||
|
|
||||||
objects[i].getWorldTransform().getOpenGLMatrix( m );
|
|
||||||
m_shapeDrawer->drawOpenGL(m,objects[i].getCollisionShape(),btVector3(1,1,1),getDebugMode(),worldBoundsMin,worldBoundsMax);
|
|
||||||
}
|
|
||||||
|
|
||||||
collisionWorld->getDispatchInfo().m_debugDraw = &debugDrawer;
|
|
||||||
|
|
||||||
if (collisionWorld)
|
|
||||||
collisionWorld->performDiscreteCollisionDetection();
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#ifndef TEST_NOT_ADDING_OBJECTS_TO_WORLD
|
|
||||||
|
|
||||||
collisionWorld->debugDrawWorld();
|
|
||||||
///one way to draw all the contact points is iterating over contact manifolds in the dispatcher:
|
|
||||||
|
|
||||||
int numManifolds = collisionWorld->getDispatcher()->getNumManifolds();
|
|
||||||
for (i=0;i<numManifolds;i++)
|
|
||||||
{
|
|
||||||
btPersistentManifold* contactManifold = collisionWorld->getDispatcher()->getManifoldByIndexInternal(i);
|
|
||||||
btCollisionObject* obA = static_cast<btCollisionObject*>(contactManifold->getBody0());
|
|
||||||
btCollisionObject* obB = static_cast<btCollisionObject*>(contactManifold->getBody1());
|
|
||||||
|
|
||||||
int numContacts = contactManifold->getNumContacts();
|
|
||||||
for (int j=0;j<numContacts;j++)
|
|
||||||
{
|
|
||||||
btManifoldPoint& pt = contactManifold->getContactPoint(j);
|
|
||||||
|
|
||||||
glBegin(GL_LINES);
|
|
||||||
glColor3f(0, 0, 0);
|
|
||||||
|
|
||||||
btVector3 ptA = pt.getPositionWorldOnA();
|
|
||||||
btVector3 ptB = pt.getPositionWorldOnB();
|
|
||||||
|
|
||||||
glVertex3d(ptA.x(),ptA.y(),ptA.z());
|
|
||||||
glVertex3d(ptB.x(),ptB.y(),ptB.z());
|
|
||||||
glEnd();
|
|
||||||
}
|
|
||||||
|
|
||||||
//you can un-comment out this line, and then all points are removed
|
|
||||||
//contactManifold->clearManifold();
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
|
|
||||||
|
|
||||||
glDisable(GL_TEXTURE_2D);
|
|
||||||
for (i=0;i<numObjects;i++)
|
|
||||||
{
|
|
||||||
collisionWorld->debugDrawObject(objects[i].getWorldTransform(),objects[i].getCollisionShape(), btVector3(1,1,0));
|
|
||||||
}
|
|
||||||
|
|
||||||
btDrawingResult renderCallback;
|
|
||||||
|
|
||||||
//collisionWorld->contactPairTest(&objects[0],&objects[1], renderCallback);
|
|
||||||
collisionWorld->contactTest(&objects[0],renderCallback);
|
|
||||||
|
|
||||||
#if 0
|
|
||||||
|
|
||||||
//another way is to directly query the dispatcher for both objects. The objects don't need to be inserted into the world
|
|
||||||
|
|
||||||
btCollisionAlgorithm* algo = collisionWorld->getDispatcher()->findAlgorithm(&objects[0],&objects[1]);
|
|
||||||
btManifoldResult contactPointResult(&objects[0],&objects[1]);
|
|
||||||
algo->processCollision(&objects[0],&objects[1],collisionWorld->getDispatchInfo(),&contactPointResult);
|
|
||||||
|
|
||||||
btManifoldArray manifoldArray;
|
|
||||||
algo->getAllContactManifolds(manifoldArray);
|
|
||||||
|
|
||||||
int numManifolds = manifoldArray.size();
|
|
||||||
for (i=0;i<numManifolds;i++)
|
|
||||||
{
|
|
||||||
btPersistentManifold* contactManifold = manifoldArray[i];
|
|
||||||
btCollisionObject* obA = static_cast<btCollisionObject*>(contactManifold->getBody0());
|
|
||||||
// btCollisionObject* obB = static_cast<btCollisionObject*>(contactManifold->getBody1());
|
|
||||||
|
|
||||||
glDisable(GL_DEPTH_TEST);
|
|
||||||
int numContacts = contactManifold->getNumContacts();
|
|
||||||
bool swap = obA == &objects[0];
|
|
||||||
|
|
||||||
for (int j=0;j<numContacts;j++)
|
|
||||||
{
|
|
||||||
btManifoldPoint& pt = contactManifold->getContactPoint(j);
|
|
||||||
|
|
||||||
glBegin(GL_LINES);
|
|
||||||
glColor3f(0, 0, 0);
|
|
||||||
|
|
||||||
btVector3 ptA = swap ?pt.getPositionWorldOnA():pt.getPositionWorldOnB();
|
|
||||||
btVector3 ptB = swap ? pt.getPositionWorldOnB():pt.getPositionWorldOnA();
|
|
||||||
|
|
||||||
glVertex3d(ptA.x(),ptA.y(),ptA.z());
|
|
||||||
glVertex3d(ptB.x(),ptB.y(),ptB.z());
|
|
||||||
glEnd();
|
|
||||||
}
|
|
||||||
|
|
||||||
//you can un-comment out this line, and then all points are removed
|
|
||||||
//contactManifold->clearManifold();
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//GL_ShapeDrawer::drawCoordSystem();
|
|
||||||
|
|
||||||
|
|
||||||
// btQuaternion qA = objects[0].getWorldTransform().getRotation();
|
|
||||||
// btQuaternion qB = objects[1].getWorldTransform().getRotation();
|
|
||||||
|
|
||||||
|
|
||||||
if (!m_idle)
|
|
||||||
{
|
|
||||||
|
|
||||||
|
|
||||||
btScalar timeInSeconds = getDeltaTimeMicroseconds()/1000.f;
|
|
||||||
|
|
||||||
btQuaternion orn;
|
|
||||||
|
|
||||||
objects[0].getWorldTransform().getBasis().getEulerYPR(yaw,pitch,roll);
|
|
||||||
pitch += 0.00005f*timeInSeconds;
|
|
||||||
yaw += 0.0001f*timeInSeconds;
|
|
||||||
objects[0].getWorldTransform().getBasis().setEulerYPR(yaw,pitch,roll);
|
|
||||||
|
|
||||||
orn.setEuler(yaw,pitch,roll);
|
|
||||||
objects[1].getWorldTransform().setOrigin(objects[1].getWorldTransform().getOrigin()+btVector3(0,-0.00001*timeInSeconds,0));
|
|
||||||
|
|
||||||
//objects[0].getWorldTransform().setRotation(orn);
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
glFlush();
|
|
||||||
swapBuffers();
|
|
||||||
}
|
|
||||||
|
|
||||||
void CollisionInterfaceDemo::clientResetScene()
|
|
||||||
{
|
|
||||||
objects[0].getWorldTransform().setOrigin(btVector3(0.0f,3.f,0.f));
|
|
||||||
|
|
||||||
btQuaternion rotA(0.739f,-0.204f,0.587f,0.257f);
|
|
||||||
rotA.normalize();
|
|
||||||
|
|
||||||
objects[0].getWorldTransform().setRotation(rotA);
|
|
||||||
|
|
||||||
objects[1].getWorldTransform().setOrigin(btVector3(0.0f,4.248f,0.f));
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
@ -1,42 +0,0 @@
|
|||||||
/*
|
|
||||||
Bullet Continuous Collision Detection and Physics Library
|
|
||||||
Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied warranty.
|
|
||||||
In no event will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it freely,
|
|
||||||
subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
|
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
#ifndef COLLISION_INTERFACE_DEMO_H
|
|
||||||
#define COLLISION_INTERFACE_DEMO_H
|
|
||||||
|
|
||||||
#ifdef _WINDOWS
|
|
||||||
#include "Win32DemoApplication.h"
|
|
||||||
#define PlatformDemoApplication Win32DemoApplication
|
|
||||||
#else
|
|
||||||
#include "GlutDemoApplication.h"
|
|
||||||
#define PlatformDemoApplication GlutDemoApplication
|
|
||||||
#endif
|
|
||||||
|
|
||||||
///CollisionInterfaceDemo shows how to use the collision detection without dynamics (btCollisionWorld/CollisionObject)
|
|
||||||
class CollisionInterfaceDemo : public PlatformDemoApplication
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
|
|
||||||
void initPhysics();
|
|
||||||
|
|
||||||
virtual void clientMoveAndDisplay();
|
|
||||||
|
|
||||||
virtual void displayCallback();
|
|
||||||
|
|
||||||
virtual void clientResetScene();
|
|
||||||
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif //COLLISION_INTERFACE_DEMO_H
|
|
||||||
|
|
@ -1,25 +0,0 @@
|
|||||||
#ifdef _WINDOWS
|
|
||||||
/*
|
|
||||||
Bullet Continuous Collision Detection and Physics Library
|
|
||||||
Copyright (c) 2003-2009 Erwin Coumans http://bulletphysics.org
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied warranty.
|
|
||||||
In no event will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it freely,
|
|
||||||
subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
|
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "CollisionInterfaceDemo.h"
|
|
||||||
|
|
||||||
///The 'createDemo' function is called from Bullet/Demos/OpenGL/Win32AppMain.cpp to instantiate this particular demo
|
|
||||||
DemoApplication* createDemo()
|
|
||||||
{
|
|
||||||
return new CollisionInterfaceDemo();
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
|
@ -1,19 +0,0 @@
|
|||||||
|
|
||||||
#include "CollisionInterfaceDemo.h"
|
|
||||||
#include "GlutStuff.h"
|
|
||||||
#include "btBulletDynamicsCommon.h"
|
|
||||||
|
|
||||||
int screenWidth = 640;
|
|
||||||
int screenHeight = 480;
|
|
||||||
|
|
||||||
|
|
||||||
int main(int argc,char** argv)
|
|
||||||
{
|
|
||||||
CollisionInterfaceDemo* collisionInterfaceDemo = new CollisionInterfaceDemo();
|
|
||||||
|
|
||||||
collisionInterfaceDemo->initPhysics();
|
|
||||||
|
|
||||||
collisionInterfaceDemo->clientResetScene();
|
|
||||||
|
|
||||||
return glutmain(argc, argv,screenWidth,screenHeight,"Collision Interface Demo",collisionInterfaceDemo);
|
|
||||||
}
|
|
@ -1,48 +0,0 @@
|
|||||||
# This is basically the overall name of the project in Visual Studio this is the name of the Solution File
|
|
||||||
|
|
||||||
|
|
||||||
# For every executable you have with a main method you should have an add_executable line below.
|
|
||||||
# For every add executable line you should list every .cpp and .h file you have associated with that executable.
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# You shouldn't have to modify anything below this line
|
|
||||||
########################################################
|
|
||||||
|
|
||||||
|
|
||||||
INCLUDE_DIRECTORIES(
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/src ${BULLET_PHYSICS_SOURCE_DIR}/Demos/OpenGL
|
|
||||||
)
|
|
||||||
|
|
||||||
LINK_LIBRARIES(
|
|
||||||
OpenGLSupport BulletDynamics BulletCollision LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY}
|
|
||||||
)
|
|
||||||
|
|
||||||
ADD_EXECUTABLE(AppConcaveConvexCastDemo
|
|
||||||
ConcaveConvexcastDemo.cpp
|
|
||||||
main.cpp
|
|
||||||
)
|
|
||||||
|
|
||||||
IF (WIN32)
|
|
||||||
IF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES)
|
|
||||||
IF (CMAKE_CL_64)
|
|
||||||
ADD_CUSTOM_COMMAND(
|
|
||||||
TARGET AppConcaveConvexCastDemo
|
|
||||||
POST_BUILD
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/glut64.dll ${CMAKE_CURRENT_BINARY_DIR}
|
|
||||||
)
|
|
||||||
ELSE(CMAKE_CL_64)
|
|
||||||
ADD_CUSTOM_COMMAND(
|
|
||||||
TARGET AppConcaveConvexCastDemo
|
|
||||||
POST_BUILD
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/GLUT32.DLL ${CMAKE_CURRENT_BINARY_DIR}
|
|
||||||
)
|
|
||||||
ENDIF(CMAKE_CL_64)
|
|
||||||
ENDIF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES)
|
|
||||||
ENDIF(WIN32)
|
|
||||||
|
|
||||||
IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES)
|
|
||||||
SET_TARGET_PROPERTIES(AppConcaveConvexCastDemo PROPERTIES DEBUG_POSTFIX "_Debug")
|
|
||||||
SET_TARGET_PROPERTIES(AppConcaveConvexCastDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel")
|
|
||||||
SET_TARGET_PROPERTIES(AppConcaveConvexCastDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo")
|
|
||||||
ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES)
|
|
@ -1,516 +0,0 @@
|
|||||||
/*
|
|
||||||
Bullet Continuous Collision Detection and Physics Library
|
|
||||||
Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied warranty.
|
|
||||||
In no event will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it freely,
|
|
||||||
subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
|
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "btBulletDynamicsCommon.h"
|
|
||||||
#include "LinearMath/btIDebugDraw.h"
|
|
||||||
#include "BulletCollision/CollisionShapes/btBoxShape.h"
|
|
||||||
#include "GLDebugDrawer.h"
|
|
||||||
#include "ConcaveConvexcastDemo.h"
|
|
||||||
#include "GL_ShapeDrawer.h"
|
|
||||||
#include "GlutStuff.h"
|
|
||||||
|
|
||||||
#define NUM_DYNAMIC_BOXES_X 30
|
|
||||||
#define NUM_DYNAMIC_BOXES_Y 30
|
|
||||||
|
|
||||||
static btVector3* gVertices=0;
|
|
||||||
static int* gIndices=0;
|
|
||||||
static btBvhTriangleMeshShape* trimeshShape =0;
|
|
||||||
static btRigidBody* staticBody = 0;
|
|
||||||
static float waveheight = 5.f;
|
|
||||||
|
|
||||||
const float TRIANGLE_SIZE=8.f;
|
|
||||||
|
|
||||||
|
|
||||||
/* Scrolls back and forth over terrain */
|
|
||||||
#define NUMRAYS_IN_BAR 100
|
|
||||||
class btConvexcastBatch
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
btVector3 source[NUMRAYS_IN_BAR];
|
|
||||||
btVector3 dest[NUMRAYS_IN_BAR];
|
|
||||||
btVector3 direction[NUMRAYS_IN_BAR];
|
|
||||||
btVector3 hit_com[NUMRAYS_IN_BAR];
|
|
||||||
btVector3 hit_surface[NUMRAYS_IN_BAR];
|
|
||||||
btScalar hit_fraction[NUMRAYS_IN_BAR];
|
|
||||||
btVector3 normal[NUMRAYS_IN_BAR];
|
|
||||||
|
|
||||||
int frame_counter;
|
|
||||||
int ms;
|
|
||||||
int sum_ms;
|
|
||||||
int sum_ms_samples;
|
|
||||||
int min_ms;
|
|
||||||
int max_ms;
|
|
||||||
|
|
||||||
#ifdef USE_BT_CLOCK
|
|
||||||
btClock frame_timer;
|
|
||||||
#endif //USE_BT_CLOCK
|
|
||||||
|
|
||||||
btScalar dx;
|
|
||||||
btScalar min_x;
|
|
||||||
btScalar max_x;
|
|
||||||
btScalar min_y;
|
|
||||||
btScalar max_y;
|
|
||||||
btScalar sign;
|
|
||||||
|
|
||||||
btVector3 boxShapeHalfExtents;
|
|
||||||
btBoxShape boxShape;
|
|
||||||
|
|
||||||
btConvexcastBatch () : boxShape(btVector3(0.0, 0.0, 0.0))
|
|
||||||
{
|
|
||||||
ms = 0;
|
|
||||||
max_ms = 0;
|
|
||||||
min_ms = 9999.0;
|
|
||||||
sum_ms_samples = 0;
|
|
||||||
sum_ms = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
btConvexcastBatch (bool unused, btScalar ray_length, btScalar min_z, btScalar max_z, btScalar min_y , btScalar max_y ) : boxShape(btVector3(0.0, 0.0, 0.0))
|
|
||||||
{
|
|
||||||
boxShapeHalfExtents = btVector3(1.0, 1.0, 1.0);
|
|
||||||
boxShape = btBoxShape(boxShapeHalfExtents);
|
|
||||||
frame_counter = 0;
|
|
||||||
ms = 0;
|
|
||||||
max_ms = 0;
|
|
||||||
min_ms = 9999.0;
|
|
||||||
sum_ms_samples = 0;
|
|
||||||
sum_ms = 0;
|
|
||||||
dx = 10.0;
|
|
||||||
min_x = -40;
|
|
||||||
max_x = 20;
|
|
||||||
this->min_y = min_y;
|
|
||||||
this->max_y = max_y;
|
|
||||||
sign = 1.0;
|
|
||||||
// btScalar dalpha = 2*SIMD_2_PI/NUMRAYS_IN_BAR;
|
|
||||||
for (int i = 0; i < NUMRAYS_IN_BAR; i++)
|
|
||||||
{
|
|
||||||
btScalar z = (max_z-min_z)/NUMRAYS_IN_BAR * i + min_z;
|
|
||||||
source[i] = btVector3(min_x, max_y, z);
|
|
||||||
dest[i] = btVector3(min_x + ray_length, min_y, z);
|
|
||||||
normal[i] = btVector3(1.0, 0.0, 0.0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
btConvexcastBatch (btScalar ray_length, btScalar z, btScalar min_y = -1000, btScalar max_y = 10) : boxShape(btVector3(0.0, 0.0, 0.0))
|
|
||||||
{
|
|
||||||
boxShapeHalfExtents = btVector3(1.0, 1.0, 1.0);
|
|
||||||
boxShape = btBoxShape(boxShapeHalfExtents);
|
|
||||||
frame_counter = 0;
|
|
||||||
ms = 0;
|
|
||||||
max_ms = 0;
|
|
||||||
min_ms = 9999.0;
|
|
||||||
sum_ms_samples = 0;
|
|
||||||
sum_ms = 0;
|
|
||||||
dx = 10.0;
|
|
||||||
min_x = -40;
|
|
||||||
max_x = 20;
|
|
||||||
this->min_y = min_y;
|
|
||||||
this->max_y = max_y;
|
|
||||||
sign = 1.0;
|
|
||||||
btScalar dalpha = btScalar(2)*SIMD_2_PI/btScalar(NUMRAYS_IN_BAR);
|
|
||||||
for (int i = 0; i < NUMRAYS_IN_BAR; i++)
|
|
||||||
{
|
|
||||||
btScalar alpha = dalpha * btScalar(i);
|
|
||||||
// rotate around by alpha degrees y
|
|
||||||
btTransform tr(btQuaternion(btVector3(0.0, 1.0, 0.0), alpha));
|
|
||||||
direction[i] = btVector3(1.0, 0.0, 0.0);
|
|
||||||
direction[i] = tr * direction[i];
|
|
||||||
source[i] = btVector3(min_x, max_y, z);
|
|
||||||
dest[i] = source[i] + direction[i] * ray_length;
|
|
||||||
dest[i][1] = min_y;
|
|
||||||
normal[i] = btVector3(1.0, 0.0, 0.0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void move (btScalar dt)
|
|
||||||
{
|
|
||||||
if (dt > (1.0/60.0))
|
|
||||||
dt = 1.0/60.0;
|
|
||||||
for (int i = 0; i < NUMRAYS_IN_BAR; i++)
|
|
||||||
{
|
|
||||||
source[i][0] += dx * dt * sign;
|
|
||||||
dest[i][0] += dx * dt * sign;
|
|
||||||
}
|
|
||||||
if (source[0][0] < min_x)
|
|
||||||
sign = 1.0;
|
|
||||||
else if (source[0][0] > max_x)
|
|
||||||
sign = -1.0;
|
|
||||||
}
|
|
||||||
|
|
||||||
void cast (btCollisionWorld* cw)
|
|
||||||
{
|
|
||||||
#ifdef USE_BT_CLOCK
|
|
||||||
frame_timer.reset ();
|
|
||||||
#endif //USE_BT_CLOCK
|
|
||||||
for (int i = 0; i < NUMRAYS_IN_BAR; i++)
|
|
||||||
{
|
|
||||||
btCollisionWorld::ClosestConvexResultCallback cb(source[i], dest[i]);
|
|
||||||
btQuaternion qFrom;
|
|
||||||
btQuaternion qTo;
|
|
||||||
qFrom.setRotation (btVector3(1.0, 0.0, 0.0), 0.0);
|
|
||||||
qTo.setRotation (btVector3(1.0, 0.0, 0.0), 0.7);
|
|
||||||
btTransform from(qFrom, source[i]);
|
|
||||||
btTransform to(qTo, dest[i]);
|
|
||||||
cw->convexSweepTest (&boxShape, from, to, cb);
|
|
||||||
if (cb.hasHit ())
|
|
||||||
{
|
|
||||||
hit_surface[i] = cb.m_hitPointWorld;
|
|
||||||
hit_com[i].setInterpolate3(source[i], dest[i], cb.m_closestHitFraction);
|
|
||||||
hit_fraction[i] = cb.m_closestHitFraction;
|
|
||||||
normal[i] = cb.m_hitNormalWorld;
|
|
||||||
normal[i].normalize ();
|
|
||||||
} else {
|
|
||||||
hit_com[i] = dest[i];
|
|
||||||
hit_surface[i] = dest[i];
|
|
||||||
hit_fraction[i] = 1.0f;
|
|
||||||
normal[i] = btVector3(1.0, 0.0, 0.0);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
#ifdef USE_BT_CLOCK
|
|
||||||
ms += frame_timer.getTimeMilliseconds ();
|
|
||||||
#endif //USE_BT_CLOCK
|
|
||||||
frame_counter++;
|
|
||||||
if (frame_counter > 50)
|
|
||||||
{
|
|
||||||
min_ms = ms < min_ms ? ms : min_ms;
|
|
||||||
max_ms = ms > max_ms ? ms : max_ms;
|
|
||||||
sum_ms += ms;
|
|
||||||
sum_ms_samples++;
|
|
||||||
btScalar mean_ms = (btScalar)sum_ms/(btScalar)sum_ms_samples;
|
|
||||||
printf("%d rays in %d ms %d %d %f\n", NUMRAYS_IN_BAR * frame_counter, ms, min_ms, max_ms, mean_ms);
|
|
||||||
ms = 0;
|
|
||||||
frame_counter = 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void drawCube (const btTransform& T)
|
|
||||||
{
|
|
||||||
ATTRIBUTE_ALIGNED16(btScalar) m[16];
|
|
||||||
T.getOpenGLMatrix (&m[0]);
|
|
||||||
glPushMatrix ();
|
|
||||||
#ifdef BT_USE_DOUBLE_PRECISION
|
|
||||||
glMultMatrixd (&m[0]);
|
|
||||||
glScaled (2.0 * boxShapeHalfExtents[0], 2.0 * boxShapeHalfExtents[1], 2.0 * boxShapeHalfExtents[2]);
|
|
||||||
#else
|
|
||||||
glMultMatrixf (&m[0]);
|
|
||||||
glScalef (2.0 * boxShapeHalfExtents[0], 2.0 * boxShapeHalfExtents[1], 2.0 * boxShapeHalfExtents[2]);
|
|
||||||
#endif //BT_USE_DOUBLE_PRECISION
|
|
||||||
glutSolidCube (1.0);
|
|
||||||
glPopMatrix ();
|
|
||||||
}
|
|
||||||
|
|
||||||
void draw ()
|
|
||||||
{
|
|
||||||
glDisable (GL_LIGHTING);
|
|
||||||
glColor3f (0.0, 1.0, 0.0);
|
|
||||||
glBegin (GL_LINES);
|
|
||||||
int i;
|
|
||||||
for (i = 0; i < NUMRAYS_IN_BAR; i++)
|
|
||||||
{
|
|
||||||
glVertex3f (source[i][0], source[i][1], source[i][2]);
|
|
||||||
glVertex3f (hit_com[i][0], hit_com[i][1], hit_com[i][2]);
|
|
||||||
}
|
|
||||||
glColor3f (1.0, 1.0, 1.0);
|
|
||||||
glBegin (GL_LINES);
|
|
||||||
btScalar normal_scale = 10.0; // easier to see if this is big
|
|
||||||
for (i = 0; i < NUMRAYS_IN_BAR; i++)
|
|
||||||
{
|
|
||||||
glVertex3f (hit_surface[i][0], hit_surface[i][1], hit_surface[i][2]);
|
|
||||||
glVertex3f (hit_surface[i][0] + normal_scale * normal[i][0], hit_surface[i][1] + normal_scale * normal[i][1], hit_surface[i][2] + normal_scale * normal[i][2]);
|
|
||||||
}
|
|
||||||
glEnd ();
|
|
||||||
glColor3f (0.0, 1.0, 1.0);
|
|
||||||
btQuaternion qFrom;
|
|
||||||
btQuaternion qTo;
|
|
||||||
qFrom.setRotation (btVector3(1.0, 0.0, 0.0), 0.0);
|
|
||||||
qTo.setRotation (btVector3(1.0, 0.0, 0.0), 0.7);
|
|
||||||
for ( i = 0; i < NUMRAYS_IN_BAR; i++)
|
|
||||||
{
|
|
||||||
btTransform from(qFrom, source[i]);
|
|
||||||
btTransform to(qTo, dest[i]);
|
|
||||||
btVector3 linVel, angVel;
|
|
||||||
btTransformUtil::calculateVelocity (from, to, 1.0, linVel, angVel);
|
|
||||||
btTransform T;
|
|
||||||
btTransformUtil::integrateTransform (from, linVel, angVel, hit_fraction[i], T);
|
|
||||||
drawCube (T);
|
|
||||||
}
|
|
||||||
glEnable (GL_LIGHTING);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
static btConvexcastBatch convexcastBatch;
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
const int NUM_VERTS_X = 30;
|
|
||||||
const int NUM_VERTS_Y = 30;
|
|
||||||
const int totalVerts = NUM_VERTS_X*NUM_VERTS_Y;
|
|
||||||
|
|
||||||
void ConcaveConvexcastDemo::setVertexPositions(float waveheight, float offset)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
int j;
|
|
||||||
|
|
||||||
for ( i=0;i<NUM_VERTS_X;i++)
|
|
||||||
{
|
|
||||||
for (j=0;j<NUM_VERTS_Y;j++)
|
|
||||||
{
|
|
||||||
gVertices[i+j*NUM_VERTS_X].setValue((i-NUM_VERTS_X*0.5f)*TRIANGLE_SIZE,
|
|
||||||
//0.f,
|
|
||||||
waveheight*sinf((float)i+offset)*cosf((float)j+offset),
|
|
||||||
(j-NUM_VERTS_Y*0.5f)*TRIANGLE_SIZE);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void ConcaveConvexcastDemo::keyboardCallback(unsigned char key, int x, int y)
|
|
||||||
{
|
|
||||||
if (key == 'g')
|
|
||||||
{
|
|
||||||
m_animatedMesh = !m_animatedMesh;
|
|
||||||
if (m_animatedMesh)
|
|
||||||
{
|
|
||||||
staticBody->setCollisionFlags( staticBody->getCollisionFlags() | btCollisionObject::CF_KINEMATIC_OBJECT);
|
|
||||||
staticBody->setActivationState(DISABLE_DEACTIVATION);
|
|
||||||
} else
|
|
||||||
{
|
|
||||||
staticBody->setCollisionFlags( staticBody->getCollisionFlags() & ~btCollisionObject::CF_KINEMATIC_OBJECT);
|
|
||||||
staticBody->forceActivationState(ACTIVE_TAG);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
DemoApplication::keyboardCallback(key,x,y);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
void ConcaveConvexcastDemo::initPhysics()
|
|
||||||
{
|
|
||||||
#define TRISIZE 10.f
|
|
||||||
|
|
||||||
setCameraDistance(100.f);
|
|
||||||
|
|
||||||
|
|
||||||
int vertStride = sizeof(btVector3);
|
|
||||||
int indexStride = 3*sizeof(int);
|
|
||||||
|
|
||||||
|
|
||||||
const int totalTriangles = 2*(NUM_VERTS_X-1)*(NUM_VERTS_Y-1);
|
|
||||||
|
|
||||||
gVertices = new btVector3[totalVerts];
|
|
||||||
gIndices = new int[totalTriangles*3];
|
|
||||||
|
|
||||||
int i;
|
|
||||||
|
|
||||||
|
|
||||||
setVertexPositions(waveheight,0.f);
|
|
||||||
|
|
||||||
int index=0;
|
|
||||||
for ( i=0;i<NUM_VERTS_X-1;i++)
|
|
||||||
{
|
|
||||||
for (int j=0;j<NUM_VERTS_Y-1;j++)
|
|
||||||
{
|
|
||||||
gIndices[index++] = j*NUM_VERTS_X+i;
|
|
||||||
gIndices[index++] = j*NUM_VERTS_X+i+1;
|
|
||||||
gIndices[index++] = (j+1)*NUM_VERTS_X+i+1;
|
|
||||||
|
|
||||||
gIndices[index++] = j*NUM_VERTS_X+i;
|
|
||||||
gIndices[index++] = (j+1)*NUM_VERTS_X+i+1;
|
|
||||||
gIndices[index++] = (j+1)*NUM_VERTS_X+i;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
m_indexVertexArrays = new btTriangleIndexVertexArray(totalTriangles,
|
|
||||||
gIndices,
|
|
||||||
indexStride,
|
|
||||||
totalVerts,(btScalar*) &gVertices[0].x(),vertStride);
|
|
||||||
|
|
||||||
bool useQuantizedAabbCompression = true;
|
|
||||||
|
|
||||||
trimeshShape = new btBvhTriangleMeshShape(m_indexVertexArrays,useQuantizedAabbCompression);
|
|
||||||
|
|
||||||
m_collisionShapes.push_back(trimeshShape);
|
|
||||||
|
|
||||||
btCollisionShape* groundShape = trimeshShape;
|
|
||||||
|
|
||||||
|
|
||||||
m_collisionConfiguration = new btDefaultCollisionConfiguration();
|
|
||||||
|
|
||||||
m_dispatcher = new btCollisionDispatcher(m_collisionConfiguration);
|
|
||||||
|
|
||||||
btVector3 worldMin(-1000,-1000,-1000);
|
|
||||||
btVector3 worldMax(1000,1000,1000);
|
|
||||||
m_broadphase = new btAxisSweep3(worldMin,worldMax);
|
|
||||||
m_solver = new btSequentialImpulseConstraintSolver();
|
|
||||||
m_dynamicsWorld = new btDiscreteDynamicsWorld(m_dispatcher,m_broadphase,m_solver,m_collisionConfiguration);
|
|
||||||
|
|
||||||
float mass = 0.f;
|
|
||||||
btTransform startTransform;
|
|
||||||
startTransform.setIdentity();
|
|
||||||
startTransform.setOrigin(btVector3(0,-2,0));
|
|
||||||
|
|
||||||
btCollisionShape* colShape = new btBoxShape(btVector3(1,1,1));
|
|
||||||
m_collisionShapes.push_back(colShape);
|
|
||||||
|
|
||||||
{
|
|
||||||
for (int j=0;j<NUM_DYNAMIC_BOXES_X;j++)
|
|
||||||
for (int i=0;i<NUM_DYNAMIC_BOXES_Y;i++)
|
|
||||||
{
|
|
||||||
//btCollisionShape* colShape = new btCapsuleShape(0.5,2.0);//boxShape = new btSphereShape(1.f);
|
|
||||||
startTransform.setOrigin(btVector3(5*(i-NUM_DYNAMIC_BOXES_X/2),10,5*(j-NUM_DYNAMIC_BOXES_Y/2)));
|
|
||||||
localCreateRigidBody(1, startTransform,colShape);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
startTransform.setIdentity();
|
|
||||||
//startTransform = btTransform(btQuaternion (btVector3(1,1,1), 1.5));
|
|
||||||
staticBody = localCreateRigidBody(mass, startTransform,groundShape);
|
|
||||||
|
|
||||||
staticBody->setCollisionFlags(staticBody->getCollisionFlags() | btCollisionObject::CF_STATIC_OBJECT);
|
|
||||||
|
|
||||||
//enable custom material callback
|
|
||||||
staticBody->setCollisionFlags(staticBody->getCollisionFlags() | btCollisionObject::CF_CUSTOM_MATERIAL_CALLBACK);
|
|
||||||
|
|
||||||
convexcastBatch = btConvexcastBatch (40.0, 0.0, -10.0,80.0);
|
|
||||||
//convexcastBatch = btConvexcastBatch (true, 40.0, -50.0, 50.0);
|
|
||||||
}
|
|
||||||
|
|
||||||
void ConcaveConvexcastDemo::clientMoveAndDisplay()
|
|
||||||
{
|
|
||||||
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
|
||||||
|
|
||||||
float dt = getDeltaTimeMicroseconds() * 0.000001f;
|
|
||||||
|
|
||||||
if (m_animatedMesh)
|
|
||||||
{
|
|
||||||
static float offset=0.f;
|
|
||||||
offset+=0.01f;
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
int i;
|
|
||||||
int j;
|
|
||||||
btVector3 aabbMin(BT_LARGE_FLOAT,BT_LARGE_FLOAT,BT_LARGE_FLOAT);
|
|
||||||
btVector3 aabbMax(-BT_LARGE_FLOAT,-BT_LARGE_FLOAT,-BT_LARGE_FLOAT);
|
|
||||||
|
|
||||||
for ( i=NUM_VERTS_X/2-3;i<NUM_VERTS_X/2+2;i++)
|
|
||||||
{
|
|
||||||
for (j=NUM_VERTS_X/2-3;j<NUM_VERTS_Y/2+2;j++)
|
|
||||||
{
|
|
||||||
|
|
||||||
aabbMax.setMax(gVertices[i+j*NUM_VERTS_X]);
|
|
||||||
aabbMin.setMin(gVertices[i+j*NUM_VERTS_X]);
|
|
||||||
|
|
||||||
gVertices[i+j*NUM_VERTS_X].setValue((i-NUM_VERTS_X*0.5f)*TRIANGLE_SIZE,
|
|
||||||
//0.f,
|
|
||||||
waveheight*sinf((float)i+offset)*cosf((float)j+offset),
|
|
||||||
(j-NUM_VERTS_Y*0.5f)*TRIANGLE_SIZE);
|
|
||||||
|
|
||||||
aabbMin.setMin(gVertices[i+j*NUM_VERTS_X]);
|
|
||||||
aabbMax.setMax(gVertices[i+j*NUM_VERTS_X]);
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
trimeshShape->partialRefitTree(aabbMin,aabbMax);
|
|
||||||
|
|
||||||
|
|
||||||
//clear all contact points involving mesh proxy. Note: this is a slow/unoptimized operation.
|
|
||||||
m_dynamicsWorld->getBroadphase()->getOverlappingPairCache()->cleanProxyFromPairs(staticBody->getBroadphaseHandle(),getDynamicsWorld()->getDispatcher());
|
|
||||||
}
|
|
||||||
|
|
||||||
m_dynamicsWorld->stepSimulation(dt);
|
|
||||||
|
|
||||||
//optional but useful: debug drawing
|
|
||||||
m_dynamicsWorld->debugDrawWorld();
|
|
||||||
|
|
||||||
convexcastBatch.move (dt);
|
|
||||||
convexcastBatch.cast (m_dynamicsWorld);
|
|
||||||
renderme();
|
|
||||||
convexcastBatch.draw ();
|
|
||||||
glFlush();
|
|
||||||
glutSwapBuffers();
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void ConcaveConvexcastDemo::displayCallback(void) {
|
|
||||||
|
|
||||||
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
|
||||||
|
|
||||||
renderme();
|
|
||||||
convexcastBatch.draw ();
|
|
||||||
glFlush();
|
|
||||||
glutSwapBuffers();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void ConcaveConvexcastDemo::exitPhysics()
|
|
||||||
{
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//cleanup in the reverse order of creation/initialization
|
|
||||||
|
|
||||||
//remove the rigidbodies from the dynamics world and delete them
|
|
||||||
int i;
|
|
||||||
for (i=m_dynamicsWorld->getNumCollisionObjects()-1; i>=0 ;i--)
|
|
||||||
{
|
|
||||||
btCollisionObject* obj = m_dynamicsWorld->getCollisionObjectArray()[i];
|
|
||||||
btRigidBody* body = btRigidBody::upcast(obj);
|
|
||||||
if (body && body->getMotionState())
|
|
||||||
{
|
|
||||||
delete body->getMotionState();
|
|
||||||
}
|
|
||||||
m_dynamicsWorld->removeCollisionObject( obj );
|
|
||||||
delete obj;
|
|
||||||
}
|
|
||||||
|
|
||||||
//delete collision shapes
|
|
||||||
for (int j=0;j<m_collisionShapes.size();j++)
|
|
||||||
{
|
|
||||||
btCollisionShape* shape = m_collisionShapes[j];
|
|
||||||
delete shape;
|
|
||||||
}
|
|
||||||
|
|
||||||
//delete dynamics world
|
|
||||||
delete m_dynamicsWorld;
|
|
||||||
|
|
||||||
if (m_indexVertexArrays)
|
|
||||||
delete m_indexVertexArrays;
|
|
||||||
|
|
||||||
//delete solver
|
|
||||||
delete m_solver;
|
|
||||||
|
|
||||||
//delete broadphase
|
|
||||||
delete m_broadphase;
|
|
||||||
|
|
||||||
//delete dispatcher
|
|
||||||
delete m_dispatcher;
|
|
||||||
|
|
||||||
delete m_collisionConfiguration;
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -1,84 +0,0 @@
|
|||||||
/*
|
|
||||||
Bullet Continuous Collision Detection and Physics Library
|
|
||||||
Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied warranty.
|
|
||||||
In no event will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it freely,
|
|
||||||
subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
|
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
#ifndef CONCAVE_CONVEXCAST_DEMO_H
|
|
||||||
#define CONCAVE_CONVEXCAST_DEMO_H
|
|
||||||
|
|
||||||
#include "GlutDemoApplication.h"
|
|
||||||
#include "LinearMath/btAlignedObjectArray.h"
|
|
||||||
|
|
||||||
class btBroadphaseInterface;
|
|
||||||
class btCollisionShape;
|
|
||||||
class btOverlappingPairCache;
|
|
||||||
class btCollisionDispatcher;
|
|
||||||
class btConstraintSolver;
|
|
||||||
struct btCollisionAlgorithmCreateFunc;
|
|
||||||
class btDefaultCollisionConfiguration;
|
|
||||||
class btTriangleIndexVertexArray;
|
|
||||||
|
|
||||||
///ConcaveRaycaseDemo shows usage of static concave triangle meshes
|
|
||||||
///It also shows per-triangle material (friction/restitution) through CustomMaterialCombinerCallback
|
|
||||||
class ConcaveConvexcastDemo : public GlutDemoApplication
|
|
||||||
{
|
|
||||||
|
|
||||||
//keep the collision shapes, for deletion/cleanup
|
|
||||||
btAlignedObjectArray<btCollisionShape*> m_collisionShapes;
|
|
||||||
|
|
||||||
btTriangleIndexVertexArray* m_indexVertexArrays;
|
|
||||||
|
|
||||||
btBroadphaseInterface* m_broadphase;
|
|
||||||
|
|
||||||
btCollisionDispatcher* m_dispatcher;
|
|
||||||
|
|
||||||
btConstraintSolver* m_solver;
|
|
||||||
|
|
||||||
btDefaultCollisionConfiguration* m_collisionConfiguration;
|
|
||||||
|
|
||||||
bool m_animatedMesh;
|
|
||||||
|
|
||||||
public:
|
|
||||||
|
|
||||||
ConcaveConvexcastDemo() : m_animatedMesh(true)
|
|
||||||
{
|
|
||||||
|
|
||||||
}
|
|
||||||
void initPhysics();
|
|
||||||
|
|
||||||
void exitPhysics();
|
|
||||||
|
|
||||||
virtual ~ConcaveConvexcastDemo()
|
|
||||||
{
|
|
||||||
exitPhysics();
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual void clientMoveAndDisplay();
|
|
||||||
|
|
||||||
virtual void displayCallback();
|
|
||||||
|
|
||||||
//to show refit works
|
|
||||||
void setVertexPositions(float waveheight, float offset);
|
|
||||||
|
|
||||||
virtual void keyboardCallback(unsigned char key, int x, int y);
|
|
||||||
|
|
||||||
static DemoApplication* Create()
|
|
||||||
{
|
|
||||||
ConcaveConvexcastDemo* demo = new ConcaveConvexcastDemo();
|
|
||||||
demo->myinit();
|
|
||||||
demo->initPhysics();
|
|
||||||
return demo;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif //CONCAVE_CONVEXCAST_DEMO_H
|
|
||||||
|
|
@ -1,15 +0,0 @@
|
|||||||
|
|
||||||
#include "ConcaveConvexcastDemo.h"
|
|
||||||
#include "GlutStuff.h"
|
|
||||||
|
|
||||||
|
|
||||||
int main(int argc,char** argv)
|
|
||||||
{
|
|
||||||
|
|
||||||
ConcaveConvexcastDemo* concaveConvexcastDemo = new ConcaveConvexcastDemo();
|
|
||||||
concaveConvexcastDemo->initPhysics();
|
|
||||||
concaveConvexcastDemo->setCameraDistance(30.f);
|
|
||||||
|
|
||||||
return glutmain(argc, argv,640,480,"Concave Convexcast Demo",concaveConvexcastDemo);
|
|
||||||
}
|
|
||||||
|
|
80
extern/bullet/Demos/ConcaveDemo/CMakeLists.txt
vendored
80
extern/bullet/Demos/ConcaveDemo/CMakeLists.txt
vendored
@ -1,80 +0,0 @@
|
|||||||
# This is basically the overall name of the project in Visual Studio this is the name of the Solution File
|
|
||||||
|
|
||||||
|
|
||||||
# For every executable you have with a main method you should have an add_executable line below.
|
|
||||||
# For every add executable line you should list every .cpp and .h file you have associated with that executable.
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# You shouldn't have to modify anything below this line
|
|
||||||
########################################################
|
|
||||||
|
|
||||||
IF (USE_GLUT)
|
|
||||||
INCLUDE_DIRECTORIES(
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/src ${BULLET_PHYSICS_SOURCE_DIR}/Demos/OpenGL
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/Extras/Serialize/BulletFileLoader
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/Extras/Serialize/BulletWorldImporter
|
|
||||||
)
|
|
||||||
|
|
||||||
LINK_LIBRARIES(
|
|
||||||
OpenGLSupport BulletWorldImporter BulletDynamics BulletCollision BulletFileLoader LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY}
|
|
||||||
)
|
|
||||||
|
|
||||||
IF (WIN32)
|
|
||||||
ADD_EXECUTABLE(AppConcaveDemo
|
|
||||||
ConcavePhysicsDemo.cpp
|
|
||||||
main.cpp
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/build/bullet.rc
|
|
||||||
)
|
|
||||||
ELSE()
|
|
||||||
ADD_EXECUTABLE(AppConcaveDemo
|
|
||||||
ConcavePhysicsDemo.cpp
|
|
||||||
main.cpp
|
|
||||||
)
|
|
||||||
ENDIF()
|
|
||||||
IF (WIN32)
|
|
||||||
IF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES)
|
|
||||||
IF (CMAKE_CL_64)
|
|
||||||
ADD_CUSTOM_COMMAND(
|
|
||||||
TARGET AppConcaveDemo
|
|
||||||
POST_BUILD
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/glut64.dll ${CMAKE_CURRENT_BINARY_DIR}
|
|
||||||
)
|
|
||||||
ELSE(CMAKE_CL_64)
|
|
||||||
ADD_CUSTOM_COMMAND(
|
|
||||||
TARGET AppConcaveDemo
|
|
||||||
POST_BUILD
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/GLUT32.DLL ${CMAKE_CURRENT_BINARY_DIR}
|
|
||||||
)
|
|
||||||
ENDIF(CMAKE_CL_64)
|
|
||||||
ENDIF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES)
|
|
||||||
ENDIF(WIN32)
|
|
||||||
ELSE (USE_GLUT)
|
|
||||||
|
|
||||||
INCLUDE_DIRECTORIES(
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/src ${BULLET_PHYSICS_SOURCE_DIR}/Demos/OpenGL
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/Extras/Serialize/BulletFileLoader
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/Extras/Serialize/BulletWorldImporter
|
|
||||||
)
|
|
||||||
|
|
||||||
LINK_LIBRARIES(
|
|
||||||
OpenGLSupport BulletWorldImporter BulletDynamics BulletCollision BulletFileLoader LinearMath ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY}
|
|
||||||
)
|
|
||||||
|
|
||||||
ADD_EXECUTABLE(AppConcaveDemo
|
|
||||||
WIN32
|
|
||||||
../OpenGL/Win32AppMain.cpp
|
|
||||||
ConcavePhysicsDemo.cpp
|
|
||||||
ConcaveDemo.h
|
|
||||||
Win32ConcaveDemo.cpp
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/build/bullet.rc
|
|
||||||
)
|
|
||||||
|
|
||||||
ENDIF (USE_GLUT)
|
|
||||||
|
|
||||||
IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES)
|
|
||||||
SET_TARGET_PROPERTIES(AppConcaveDemo PROPERTIES DEBUG_POSTFIX "_Debug")
|
|
||||||
SET_TARGET_PROPERTIES(AppConcaveDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel")
|
|
||||||
SET_TARGET_PROPERTIES(AppConcaveDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo")
|
|
||||||
ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES)
|
|
91
extern/bullet/Demos/ConcaveDemo/ConcaveDemo.h
vendored
91
extern/bullet/Demos/ConcaveDemo/ConcaveDemo.h
vendored
@ -1,91 +0,0 @@
|
|||||||
/*
|
|
||||||
Bullet Continuous Collision Detection and Physics Library
|
|
||||||
Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied warranty.
|
|
||||||
In no event will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it freely,
|
|
||||||
subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
|
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
#ifndef CONCAVE_DEMO_H
|
|
||||||
#define CONCAVE_DEMO_H
|
|
||||||
|
|
||||||
#ifdef _WINDOWS
|
|
||||||
#include "Win32DemoApplication.h"
|
|
||||||
#define PlatformDemoApplication Win32DemoApplication
|
|
||||||
#else
|
|
||||||
#include "GlutDemoApplication.h"
|
|
||||||
#define PlatformDemoApplication GlutDemoApplication
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include "LinearMath/btAlignedObjectArray.h"
|
|
||||||
|
|
||||||
class btBroadphaseInterface;
|
|
||||||
class btCollisionShape;
|
|
||||||
class btOverlappingPairCache;
|
|
||||||
class btCollisionDispatcher;
|
|
||||||
class btConstraintSolver;
|
|
||||||
struct btCollisionAlgorithmCreateFunc;
|
|
||||||
class btDefaultCollisionConfiguration;
|
|
||||||
class btTriangleIndexVertexArray;
|
|
||||||
|
|
||||||
///ConcaveDemo shows usage of static concave triangle meshes
|
|
||||||
///It also shows per-triangle material (friction/restitution) through CustomMaterialCombinerCallback
|
|
||||||
class ConcaveDemo : public PlatformDemoApplication
|
|
||||||
{
|
|
||||||
|
|
||||||
//keep the collision shapes, for deletion/cleanup
|
|
||||||
btAlignedObjectArray<btCollisionShape*> m_collisionShapes;
|
|
||||||
|
|
||||||
btTriangleIndexVertexArray* m_indexVertexArrays;
|
|
||||||
|
|
||||||
btBroadphaseInterface* m_broadphase;
|
|
||||||
|
|
||||||
btCollisionDispatcher* m_dispatcher;
|
|
||||||
|
|
||||||
btConstraintSolver* m_solver;
|
|
||||||
|
|
||||||
btDefaultCollisionConfiguration* m_collisionConfiguration;
|
|
||||||
|
|
||||||
bool m_animatedMesh;
|
|
||||||
|
|
||||||
public:
|
|
||||||
|
|
||||||
ConcaveDemo() : m_animatedMesh(true)
|
|
||||||
{
|
|
||||||
|
|
||||||
}
|
|
||||||
void initPhysics();
|
|
||||||
|
|
||||||
void exitPhysics();
|
|
||||||
|
|
||||||
virtual ~ConcaveDemo()
|
|
||||||
{
|
|
||||||
exitPhysics();
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual void clientMoveAndDisplay();
|
|
||||||
|
|
||||||
virtual void displayCallback();
|
|
||||||
|
|
||||||
//to show refit works
|
|
||||||
void setVertexPositions(float waveheight, float offset);
|
|
||||||
|
|
||||||
virtual void keyboardCallback(unsigned char key, int x, int y);
|
|
||||||
|
|
||||||
static DemoApplication* Create()
|
|
||||||
{
|
|
||||||
ConcaveDemo* demo = new ConcaveDemo();
|
|
||||||
demo->myinit();
|
|
||||||
demo->initPhysics();
|
|
||||||
return demo;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif //CONCAVE_DEMO_H
|
|
||||||
|
|
@ -1,474 +0,0 @@
|
|||||||
/*
|
|
||||||
Bullet Continuous Collision Detection and Physics Library
|
|
||||||
Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied warranty.
|
|
||||||
In no event will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it freely,
|
|
||||||
subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
|
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "btBulletDynamicsCommon.h"
|
|
||||||
#include "LinearMath/btIDebugDraw.h"
|
|
||||||
#include "GLDebugDrawer.h"
|
|
||||||
#include "ConcaveDemo.h"
|
|
||||||
#include "GL_ShapeDrawer.h"
|
|
||||||
#include "GlutStuff.h"
|
|
||||||
|
|
||||||
#define SERIALIZE_TO_DISK 1
|
|
||||||
|
|
||||||
#ifndef SERIALIZE_TO_DISK
|
|
||||||
#include "btBulletWorldImporter.h"
|
|
||||||
#endif //SERIALIZE_TO_DISK
|
|
||||||
|
|
||||||
//by default, the sample only (de)serializes the BVH to disk.
|
|
||||||
//If you enable the SERIALIZE_SHAPE define then it will serialize the entire collision shape
|
|
||||||
//then the animation will not play, because it is using the deserialized vertices
|
|
||||||
//#define SERIALIZE_SHAPE
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//#define USE_PARALLEL_DISPATCHER 1
|
|
||||||
#ifdef USE_PARALLEL_DISPATCHER
|
|
||||||
#include "../../Extras/BulletMultiThreaded/SpuGatheringCollisionDispatcher.h"
|
|
||||||
#include "../../Extras/BulletMultiThreaded/Win32ThreadSupport.h"
|
|
||||||
#include "../../Extras/BulletMultiThreaded/SpuNarrowPhaseCollisionTask/SpuGatheringCollisionTask.h"
|
|
||||||
#endif//USE_PARALLEL_DISPATCHER
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
static btVector3* gVertices=0;
|
|
||||||
static int* gIndices=0;
|
|
||||||
static btBvhTriangleMeshShape* trimeshShape =0;
|
|
||||||
static btRigidBody* staticBody = 0;
|
|
||||||
static float waveheight = 5.f;
|
|
||||||
|
|
||||||
const float TRIANGLE_SIZE=8.f;
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
///User can override this material combiner by implementing gContactAddedCallback and setting body0->m_collisionFlags |= btCollisionObject::customMaterialCallback;
|
|
||||||
inline btScalar calculateCombinedFriction(float friction0,float friction1)
|
|
||||||
{
|
|
||||||
btScalar friction = friction0 * friction1;
|
|
||||||
|
|
||||||
const btScalar MAX_FRICTION = 10.f;
|
|
||||||
if (friction < -MAX_FRICTION)
|
|
||||||
friction = -MAX_FRICTION;
|
|
||||||
if (friction > MAX_FRICTION)
|
|
||||||
friction = MAX_FRICTION;
|
|
||||||
return friction;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
inline btScalar calculateCombinedRestitution(float restitution0,float restitution1)
|
|
||||||
{
|
|
||||||
return restitution0 * restitution1;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
static bool CustomMaterialCombinerCallback(btManifoldPoint& cp, const btCollisionObjectWrapper* colObj0Wrap,int partId0,int index0,const btCollisionObjectWrapper* colObj1Wrap,int partId1,int index1)
|
|
||||||
{
|
|
||||||
|
|
||||||
float friction0 = colObj0Wrap->getCollisionObject()->getFriction();
|
|
||||||
float friction1 = colObj1Wrap->getCollisionObject()->getFriction();
|
|
||||||
float restitution0 = colObj0Wrap->getCollisionObject()->getRestitution();
|
|
||||||
float restitution1 = colObj1Wrap->getCollisionObject()->getRestitution();
|
|
||||||
|
|
||||||
if (colObj0Wrap->getCollisionObject()->getCollisionFlags() & btCollisionObject::CF_CUSTOM_MATERIAL_CALLBACK)
|
|
||||||
{
|
|
||||||
friction0 = 1.0;//partId0,index0
|
|
||||||
restitution0 = 0.f;
|
|
||||||
}
|
|
||||||
if (colObj1Wrap->getCollisionObject()->getCollisionFlags() & btCollisionObject::CF_CUSTOM_MATERIAL_CALLBACK)
|
|
||||||
{
|
|
||||||
if (index1&1)
|
|
||||||
{
|
|
||||||
friction1 = 1.0f;//partId1,index1
|
|
||||||
} else
|
|
||||||
{
|
|
||||||
friction1 = 0.f;
|
|
||||||
}
|
|
||||||
restitution1 = 0.f;
|
|
||||||
}
|
|
||||||
|
|
||||||
cp.m_combinedFriction = calculateCombinedFriction(friction0,friction1);
|
|
||||||
cp.m_combinedRestitution = calculateCombinedRestitution(restitution0,restitution1);
|
|
||||||
|
|
||||||
//this return value is currently ignored, but to be on the safe side: return false if you don't calculate friction
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
extern ContactAddedCallback gContactAddedCallback;
|
|
||||||
|
|
||||||
const int NUM_VERTS_X = 30;
|
|
||||||
const int NUM_VERTS_Y = 30;
|
|
||||||
const int totalVerts = NUM_VERTS_X*NUM_VERTS_Y;
|
|
||||||
|
|
||||||
void ConcaveDemo::setVertexPositions(float waveheight, float offset)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
int j;
|
|
||||||
|
|
||||||
for ( i=0;i<NUM_VERTS_X;i++)
|
|
||||||
{
|
|
||||||
for (j=0;j<NUM_VERTS_Y;j++)
|
|
||||||
{
|
|
||||||
gVertices[i+j*NUM_VERTS_X].setValue((i-NUM_VERTS_X*0.5f)*TRIANGLE_SIZE,
|
|
||||||
//0.f,
|
|
||||||
waveheight*sinf((float)i+offset)*cosf((float)j+offset),
|
|
||||||
(j-NUM_VERTS_Y*0.5f)*TRIANGLE_SIZE);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void ConcaveDemo::keyboardCallback(unsigned char key, int x, int y)
|
|
||||||
{
|
|
||||||
if (key == 'g')
|
|
||||||
{
|
|
||||||
m_animatedMesh = !m_animatedMesh;
|
|
||||||
if (m_animatedMesh)
|
|
||||||
{
|
|
||||||
staticBody->setCollisionFlags( staticBody->getCollisionFlags() | btCollisionObject::CF_KINEMATIC_OBJECT);
|
|
||||||
staticBody->setActivationState(DISABLE_DEACTIVATION);
|
|
||||||
} else
|
|
||||||
{
|
|
||||||
staticBody->setCollisionFlags( staticBody->getCollisionFlags() & ~btCollisionObject::CF_KINEMATIC_OBJECT);
|
|
||||||
staticBody->forceActivationState(ACTIVE_TAG);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
DemoApplication::keyboardCallback(key,x,y);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
void ConcaveDemo::initPhysics()
|
|
||||||
{
|
|
||||||
|
|
||||||
setTexturing(true);
|
|
||||||
setShadows(false);//true);
|
|
||||||
|
|
||||||
#define TRISIZE 10.f
|
|
||||||
|
|
||||||
gContactAddedCallback = CustomMaterialCombinerCallback;
|
|
||||||
|
|
||||||
#define USE_TRIMESH_SHAPE 1
|
|
||||||
#ifdef USE_TRIMESH_SHAPE
|
|
||||||
|
|
||||||
int vertStride = sizeof(btVector3);
|
|
||||||
int indexStride = 3*sizeof(int);
|
|
||||||
|
|
||||||
|
|
||||||
const int totalTriangles = 2*(NUM_VERTS_X-1)*(NUM_VERTS_Y-1);
|
|
||||||
|
|
||||||
gVertices = new btVector3[totalVerts];
|
|
||||||
gIndices = new int[totalTriangles*3];
|
|
||||||
|
|
||||||
int i;
|
|
||||||
|
|
||||||
|
|
||||||
setVertexPositions(waveheight,0.f);
|
|
||||||
|
|
||||||
int index=0;
|
|
||||||
for ( i=0;i<NUM_VERTS_X-1;i++)
|
|
||||||
{
|
|
||||||
for (int j=0;j<NUM_VERTS_Y-1;j++)
|
|
||||||
{
|
|
||||||
gIndices[index++] = j*NUM_VERTS_X+i;
|
|
||||||
gIndices[index++] = j*NUM_VERTS_X+i+1;
|
|
||||||
gIndices[index++] = (j+1)*NUM_VERTS_X+i+1;
|
|
||||||
|
|
||||||
gIndices[index++] = j*NUM_VERTS_X+i;
|
|
||||||
gIndices[index++] = (j+1)*NUM_VERTS_X+i+1;
|
|
||||||
gIndices[index++] = (j+1)*NUM_VERTS_X+i;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
m_indexVertexArrays = new btTriangleIndexVertexArray(totalTriangles,
|
|
||||||
gIndices,
|
|
||||||
indexStride,
|
|
||||||
totalVerts,(btScalar*) &gVertices[0].x(),vertStride);
|
|
||||||
|
|
||||||
bool useQuantizedAabbCompression = true;
|
|
||||||
|
|
||||||
//comment out the next line to read the BVH from disk (first run the demo once to create the BVH)
|
|
||||||
|
|
||||||
#ifdef SERIALIZE_TO_DISK
|
|
||||||
|
|
||||||
|
|
||||||
btVector3 aabbMin(-1000,-1000,-1000),aabbMax(1000,1000,1000);
|
|
||||||
|
|
||||||
trimeshShape = new btBvhTriangleMeshShape(m_indexVertexArrays,useQuantizedAabbCompression,aabbMin,aabbMax);
|
|
||||||
m_collisionShapes.push_back(trimeshShape);
|
|
||||||
|
|
||||||
int maxSerializeBufferSize = 1024*1024*5;
|
|
||||||
btDefaultSerializer* serializer = new btDefaultSerializer(maxSerializeBufferSize);
|
|
||||||
//serializer->setSerializationFlags(BT_SERIALIZE_NO_BVH);// or BT_SERIALIZE_NO_TRIANGLEINFOMAP
|
|
||||||
serializer->startSerialization();
|
|
||||||
//registering a name is optional, it allows you to retrieve the shape by name
|
|
||||||
//serializer->registerNameForPointer(trimeshShape,"mymesh");
|
|
||||||
#ifdef SERIALIZE_SHAPE
|
|
||||||
trimeshShape->serializeSingleShape(serializer);
|
|
||||||
#else
|
|
||||||
trimeshShape->serializeSingleBvh(serializer);
|
|
||||||
#endif
|
|
||||||
serializer->finishSerialization();
|
|
||||||
FILE* f2 = fopen("myShape.bullet","wb");
|
|
||||||
fwrite(serializer->getBufferPointer(),serializer->getCurrentBufferSize(),1,f2);
|
|
||||||
fclose(f2);
|
|
||||||
|
|
||||||
#else
|
|
||||||
btBulletWorldImporter import(0);//don't store info into the world
|
|
||||||
if (import.loadFile("myShape.bullet"))
|
|
||||||
{
|
|
||||||
int numBvh = import.getNumBvhs();
|
|
||||||
if (numBvh)
|
|
||||||
{
|
|
||||||
btOptimizedBvh* bvh = import.getBvhByIndex(0);
|
|
||||||
btVector3 aabbMin(-1000,-1000,-1000),aabbMax(1000,1000,1000);
|
|
||||||
|
|
||||||
trimeshShape = new btBvhTriangleMeshShape(m_indexVertexArrays,useQuantizedAabbCompression,aabbMin,aabbMax,false);
|
|
||||||
trimeshShape->setOptimizedBvh(bvh);
|
|
||||||
//trimeshShape = new btBvhTriangleMeshShape(m_indexVertexArrays,useQuantizedAabbCompression,aabbMin,aabbMax);
|
|
||||||
//trimeshShape->setOptimizedBvh(bvh);
|
|
||||||
|
|
||||||
}
|
|
||||||
int numShape = import.getNumCollisionShapes();
|
|
||||||
if (numShape)
|
|
||||||
{
|
|
||||||
trimeshShape = (btBvhTriangleMeshShape*)import.getCollisionShapeByIndex(0);
|
|
||||||
|
|
||||||
//if you know the name, you can also try to get the shape by name:
|
|
||||||
const char* meshName = import.getNameForPointer(trimeshShape);
|
|
||||||
if (meshName)
|
|
||||||
trimeshShape = (btBvhTriangleMeshShape*)import.getCollisionShapeByName(meshName);
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
btCollisionShape* groundShape = trimeshShape;
|
|
||||||
|
|
||||||
#else
|
|
||||||
btCollisionShape* groundShape = new btBoxShape(btVector3(50,3,50));
|
|
||||||
m_collisionShapes.push_back(groundShape);
|
|
||||||
|
|
||||||
#endif //USE_TRIMESH_SHAPE
|
|
||||||
|
|
||||||
m_collisionConfiguration = new btDefaultCollisionConfiguration();
|
|
||||||
|
|
||||||
#ifdef USE_PARALLEL_DISPATCHER
|
|
||||||
|
|
||||||
#ifdef USE_WIN32_THREADING
|
|
||||||
|
|
||||||
int maxNumOutstandingTasks = 4;//number of maximum outstanding tasks
|
|
||||||
Win32ThreadSupport* threadSupport = new Win32ThreadSupport(Win32ThreadSupport::Win32ThreadConstructionInfo(
|
|
||||||
"collision",
|
|
||||||
processCollisionTask,
|
|
||||||
createCollisionLocalStoreMemory,
|
|
||||||
maxNumOutstandingTasks));
|
|
||||||
#else
|
|
||||||
///@todo show other platform threading
|
|
||||||
///Playstation 3 SPU (SPURS) version is available through PS3 Devnet
|
|
||||||
///Libspe2 SPU support will be available soon
|
|
||||||
///pthreads version
|
|
||||||
///you can hook it up to your custom task scheduler by deriving from btThreadSupportInterface
|
|
||||||
#endif
|
|
||||||
|
|
||||||
m_dispatcher = new SpuGatheringCollisionDispatcher(threadSupport,maxNumOutstandingTasks,m_collisionConfiguration);
|
|
||||||
#else
|
|
||||||
m_dispatcher = new btCollisionDispatcher(m_collisionConfiguration);
|
|
||||||
#endif//USE_PARALLEL_DISPATCHER
|
|
||||||
|
|
||||||
|
|
||||||
btVector3 worldMin(-1000,-1000,-1000);
|
|
||||||
btVector3 worldMax(1000,1000,1000);
|
|
||||||
m_broadphase = new btAxisSweep3(worldMin,worldMax);
|
|
||||||
m_solver = new btSequentialImpulseConstraintSolver();
|
|
||||||
m_dynamicsWorld = new btDiscreteDynamicsWorld(m_dispatcher,m_broadphase,m_solver,m_collisionConfiguration);
|
|
||||||
#ifdef USE_PARALLEL_DISPATCHER
|
|
||||||
m_dynamicsWorld->getDispatchInfo().m_enableSPU=true;
|
|
||||||
#endif //USE_PARALLEL_DISPATCHER
|
|
||||||
|
|
||||||
float mass = 0.f;
|
|
||||||
btTransform startTransform;
|
|
||||||
startTransform.setIdentity();
|
|
||||||
startTransform.setOrigin(btVector3(0,-2,0));
|
|
||||||
|
|
||||||
#ifdef USE_BOX_SHAPE
|
|
||||||
btCollisionShape* colShape = new btBoxShape(btVector3(1,1,1));
|
|
||||||
#else
|
|
||||||
|
|
||||||
btCompoundShape* colShape = new btCompoundShape;
|
|
||||||
btCollisionShape* cylinderShape = new btCylinderShapeX(btVector3(4,1,1));
|
|
||||||
btCollisionShape* boxShape = new btBoxShape(btVector3(4,1,1));
|
|
||||||
btTransform localTransform;
|
|
||||||
localTransform.setIdentity();
|
|
||||||
colShape->addChildShape(localTransform,boxShape);
|
|
||||||
btQuaternion orn(SIMD_HALF_PI,0,0);
|
|
||||||
localTransform.setRotation(orn);
|
|
||||||
colShape->addChildShape(localTransform,cylinderShape);
|
|
||||||
|
|
||||||
#endif //USE_BOX_SHAPE
|
|
||||||
|
|
||||||
|
|
||||||
m_collisionShapes.push_back(colShape);
|
|
||||||
|
|
||||||
{
|
|
||||||
for (int i=0;i<10;i++)
|
|
||||||
{
|
|
||||||
startTransform.setOrigin(btVector3(2,10+i*2,1));
|
|
||||||
localCreateRigidBody(1, startTransform,colShape);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
startTransform.setIdentity();
|
|
||||||
staticBody = localCreateRigidBody(mass, startTransform,groundShape);
|
|
||||||
|
|
||||||
staticBody->setCollisionFlags(staticBody->getCollisionFlags() | btCollisionObject::CF_KINEMATIC_OBJECT);//STATIC_OBJECT);
|
|
||||||
|
|
||||||
//enable custom material callback
|
|
||||||
staticBody->setCollisionFlags(staticBody->getCollisionFlags() | btCollisionObject::CF_CUSTOM_MATERIAL_CALLBACK);
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
void ConcaveDemo::clientMoveAndDisplay()
|
|
||||||
{
|
|
||||||
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
|
||||||
|
|
||||||
float dt = getDeltaTimeMicroseconds() * 0.000001f;
|
|
||||||
|
|
||||||
if (m_animatedMesh)
|
|
||||||
{
|
|
||||||
static float offset=0.f;
|
|
||||||
offset+=dt;
|
|
||||||
|
|
||||||
// setVertexPositions(waveheight,offset);
|
|
||||||
|
|
||||||
int i;
|
|
||||||
int j;
|
|
||||||
btVector3 aabbMin(BT_LARGE_FLOAT,BT_LARGE_FLOAT,BT_LARGE_FLOAT);
|
|
||||||
btVector3 aabbMax(-BT_LARGE_FLOAT,-BT_LARGE_FLOAT,-BT_LARGE_FLOAT);
|
|
||||||
|
|
||||||
for ( i=NUM_VERTS_X/2-3;i<NUM_VERTS_X/2+2;i++)
|
|
||||||
{
|
|
||||||
for (j=NUM_VERTS_X/2-3;j<NUM_VERTS_Y/2+2;j++)
|
|
||||||
{
|
|
||||||
|
|
||||||
aabbMax.setMax(gVertices[i+j*NUM_VERTS_X]);
|
|
||||||
aabbMin.setMin(gVertices[i+j*NUM_VERTS_X]);
|
|
||||||
|
|
||||||
gVertices[i+j*NUM_VERTS_X].setValue((i-NUM_VERTS_X*0.5f)*TRIANGLE_SIZE,
|
|
||||||
//0.f,
|
|
||||||
waveheight*sinf((float)i+offset)*cosf((float)j+offset),
|
|
||||||
(j-NUM_VERTS_Y*0.5f)*TRIANGLE_SIZE);
|
|
||||||
|
|
||||||
aabbMin.setMin(gVertices[i+j*NUM_VERTS_X]);
|
|
||||||
aabbMax.setMax(gVertices[i+j*NUM_VERTS_X]);
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
trimeshShape->partialRefitTree(aabbMin,aabbMax);
|
|
||||||
|
|
||||||
//clear all contact points involving mesh proxy. Note: this is a slow/unoptimized operation.
|
|
||||||
m_dynamicsWorld->getBroadphase()->getOverlappingPairCache()->cleanProxyFromPairs(staticBody->getBroadphaseHandle(),getDynamicsWorld()->getDispatcher());
|
|
||||||
}
|
|
||||||
|
|
||||||
m_dynamicsWorld->stepSimulation(dt);
|
|
||||||
|
|
||||||
//optional but useful: debug drawing
|
|
||||||
m_dynamicsWorld->debugDrawWorld();
|
|
||||||
|
|
||||||
|
|
||||||
renderme();
|
|
||||||
|
|
||||||
glFlush();
|
|
||||||
swapBuffers();
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void ConcaveDemo::displayCallback(void) {
|
|
||||||
|
|
||||||
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
|
||||||
|
|
||||||
renderme();
|
|
||||||
|
|
||||||
//optional but useful: debug drawing
|
|
||||||
if (m_dynamicsWorld)
|
|
||||||
m_dynamicsWorld->debugDrawWorld();
|
|
||||||
|
|
||||||
|
|
||||||
glFlush();
|
|
||||||
swapBuffers();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void ConcaveDemo::exitPhysics()
|
|
||||||
{
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//cleanup in the reverse order of creation/initialization
|
|
||||||
|
|
||||||
//remove the rigidbodies from the dynamics world and delete them
|
|
||||||
int i;
|
|
||||||
for (i=m_dynamicsWorld->getNumCollisionObjects()-1; i>=0 ;i--)
|
|
||||||
{
|
|
||||||
btCollisionObject* obj = m_dynamicsWorld->getCollisionObjectArray()[i];
|
|
||||||
btRigidBody* body = btRigidBody::upcast(obj);
|
|
||||||
if (body && body->getMotionState())
|
|
||||||
{
|
|
||||||
delete body->getMotionState();
|
|
||||||
}
|
|
||||||
m_dynamicsWorld->removeCollisionObject( obj );
|
|
||||||
delete obj;
|
|
||||||
}
|
|
||||||
|
|
||||||
//delete collision shapes
|
|
||||||
for (int j=0;j<m_collisionShapes.size();j++)
|
|
||||||
{
|
|
||||||
btCollisionShape* shape = m_collisionShapes[j];
|
|
||||||
delete shape;
|
|
||||||
}
|
|
||||||
|
|
||||||
//delete dynamics world
|
|
||||||
delete m_dynamicsWorld;
|
|
||||||
|
|
||||||
if (m_indexVertexArrays)
|
|
||||||
delete m_indexVertexArrays;
|
|
||||||
|
|
||||||
//delete solver
|
|
||||||
delete m_solver;
|
|
||||||
|
|
||||||
//delete broadphase
|
|
||||||
delete m_broadphase;
|
|
||||||
|
|
||||||
//delete dispatcher
|
|
||||||
delete m_dispatcher;
|
|
||||||
|
|
||||||
delete m_collisionConfiguration;
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
3
extern/bullet/Demos/ConcaveDemo/Jamfile
vendored
3
extern/bullet/Demos/ConcaveDemo/Jamfile
vendored
@ -1,3 +0,0 @@
|
|||||||
SubDir TOP Demos ConcaveDemo ;
|
|
||||||
|
|
||||||
BulletDemo ConcaveDemo : [ Wildcard *.h *.cpp ] ;
|
|
@ -1,25 +0,0 @@
|
|||||||
#ifdef _WINDOWS
|
|
||||||
/*
|
|
||||||
Bullet Continuous Collision Detection and Physics Library
|
|
||||||
Copyright (c) 2003-2009 Erwin Coumans http://bulletphysics.org
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied warranty.
|
|
||||||
In no event will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it freely,
|
|
||||||
subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
|
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "ConcaveDemo.h"
|
|
||||||
|
|
||||||
///The 'createDemo' function is called from Bullet/Demos/OpenGL/Win32AppMain.cpp to instantiate this particular demo
|
|
||||||
DemoApplication* createDemo()
|
|
||||||
{
|
|
||||||
return new ConcaveDemo();
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
|
19
extern/bullet/Demos/ConcaveDemo/main.cpp
vendored
19
extern/bullet/Demos/ConcaveDemo/main.cpp
vendored
@ -1,19 +0,0 @@
|
|||||||
|
|
||||||
#include "ConcaveDemo.h"
|
|
||||||
#include "GlutStuff.h"
|
|
||||||
|
|
||||||
#include "GLDebugDrawer.h"
|
|
||||||
#include "btBulletDynamicsCommon.h"
|
|
||||||
|
|
||||||
GLDebugDrawer gDebugDrawer;
|
|
||||||
int main(int argc,char** argv)
|
|
||||||
{
|
|
||||||
|
|
||||||
ConcaveDemo* concaveDemo = new ConcaveDemo();
|
|
||||||
concaveDemo->initPhysics();
|
|
||||||
concaveDemo->setCameraDistance(30.f);
|
|
||||||
concaveDemo->getDynamicsWorld()->setDebugDrawer(&gDebugDrawer);
|
|
||||||
|
|
||||||
return glutmain(argc, argv,640,480,"Static Concave Mesh Demo",concaveDemo);
|
|
||||||
}
|
|
||||||
|
|
@ -1,57 +0,0 @@
|
|||||||
# This is basically the overall name of the project in Visual Studio this is the name of the Solution File
|
|
||||||
|
|
||||||
|
|
||||||
# For every executable you have with a main method you should have an add_executable line below.
|
|
||||||
# For every add executable line you should list every .cpp and .h file you have associated with that executable.
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# You shouldn't have to modify anything below this line
|
|
||||||
########################################################
|
|
||||||
|
|
||||||
|
|
||||||
INCLUDE_DIRECTORIES(
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/src ${BULLET_PHYSICS_SOURCE_DIR}/Demos/OpenGL
|
|
||||||
)
|
|
||||||
|
|
||||||
LINK_LIBRARIES(
|
|
||||||
OpenGLSupport BulletDynamics BulletCollision LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY}
|
|
||||||
)
|
|
||||||
|
|
||||||
IF (WIN32)
|
|
||||||
ADD_EXECUTABLE(AppConcaveRayCastDemo
|
|
||||||
ConcaveRaycastDemo.cpp
|
|
||||||
main.cpp
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/build/bullet.rc
|
|
||||||
)
|
|
||||||
ELSE()
|
|
||||||
ADD_EXECUTABLE(AppConcaveRayCastDemo
|
|
||||||
ConcaveRaycastDemo.cpp
|
|
||||||
main.cpp
|
|
||||||
)
|
|
||||||
ENDIF()
|
|
||||||
|
|
||||||
IF (WIN32)
|
|
||||||
IF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES)
|
|
||||||
IF (CMAKE_CL_64)
|
|
||||||
ADD_CUSTOM_COMMAND(
|
|
||||||
TARGET AppConcaveRayCastDemo
|
|
||||||
POST_BUILD
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/glut64.dll ${CMAKE_CURRENT_BINARY_DIR}
|
|
||||||
)
|
|
||||||
ELSE(CMAKE_CL_64)
|
|
||||||
ADD_CUSTOM_COMMAND(
|
|
||||||
TARGET AppConcaveRayCastDemo
|
|
||||||
POST_BUILD
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/GLUT32.DLL ${CMAKE_CURRENT_BINARY_DIR}
|
|
||||||
)
|
|
||||||
ENDIF(CMAKE_CL_64)
|
|
||||||
ENDIF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES)
|
|
||||||
ENDIF(WIN32)
|
|
||||||
|
|
||||||
|
|
||||||
IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES)
|
|
||||||
SET_TARGET_PROPERTIES(AppConcaveRayCastDemo PROPERTIES DEBUG_POSTFIX "_Debug")
|
|
||||||
SET_TARGET_PROPERTIES(AppConcaveRayCastDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel")
|
|
||||||
SET_TARGET_PROPERTIES(AppConcaveRayCastDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo")
|
|
||||||
ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES)
|
|
@ -1,490 +0,0 @@
|
|||||||
/*
|
|
||||||
Bullet Continuous Collision Detection and Physics Library
|
|
||||||
Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied warranty.
|
|
||||||
In no event will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it freely,
|
|
||||||
subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
|
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "btBulletDynamicsCommon.h"
|
|
||||||
#include "LinearMath/btIDebugDraw.h"
|
|
||||||
#include "GLDebugDrawer.h"
|
|
||||||
#include "ConcaveRaycastDemo.h"
|
|
||||||
#include "GL_ShapeDrawer.h"
|
|
||||||
#include "GlutStuff.h"
|
|
||||||
|
|
||||||
static GLDebugDrawer sDebugDraw;
|
|
||||||
|
|
||||||
static btVector3* gVertices=0;
|
|
||||||
static int* gIndices=0;
|
|
||||||
static btBvhTriangleMeshShape* trimeshShape =0;
|
|
||||||
static btRigidBody* staticBody = 0;
|
|
||||||
static float waveheight = 5.f;
|
|
||||||
|
|
||||||
const float TRIANGLE_SIZE=8.f;
|
|
||||||
|
|
||||||
|
|
||||||
/* Scrolls back and forth over terrain */
|
|
||||||
#define NUMRAYS_IN_BAR 100
|
|
||||||
class btRaycastBar
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
btVector3 source[NUMRAYS_IN_BAR];
|
|
||||||
btVector3 dest[NUMRAYS_IN_BAR];
|
|
||||||
btVector3 direction[NUMRAYS_IN_BAR];
|
|
||||||
btVector3 hit[NUMRAYS_IN_BAR];
|
|
||||||
btVector3 normal[NUMRAYS_IN_BAR];
|
|
||||||
|
|
||||||
int frame_counter;
|
|
||||||
int ms;
|
|
||||||
int sum_ms;
|
|
||||||
int sum_ms_samples;
|
|
||||||
int min_ms;
|
|
||||||
int max_ms;
|
|
||||||
|
|
||||||
#ifdef USE_BT_CLOCK
|
|
||||||
btClock frame_timer;
|
|
||||||
#endif //USE_BT_CLOCK
|
|
||||||
|
|
||||||
btScalar dx;
|
|
||||||
btScalar min_x;
|
|
||||||
btScalar max_x;
|
|
||||||
btScalar min_y;
|
|
||||||
btScalar max_y;
|
|
||||||
btScalar sign;
|
|
||||||
|
|
||||||
btRaycastBar ()
|
|
||||||
{
|
|
||||||
ms = 0;
|
|
||||||
max_ms = 0;
|
|
||||||
min_ms = 9999.0;
|
|
||||||
sum_ms_samples = 0;
|
|
||||||
sum_ms = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
btRaycastBar (bool unused, btScalar ray_length, btScalar min_z, btScalar max_z, btScalar min_y = -10, btScalar max_y = 10)
|
|
||||||
{
|
|
||||||
frame_counter = 0;
|
|
||||||
ms = 0;
|
|
||||||
max_ms = 0;
|
|
||||||
min_ms = 9999.0;
|
|
||||||
sum_ms_samples = 0;
|
|
||||||
sum_ms = 0;
|
|
||||||
dx = 10.0;
|
|
||||||
min_x = -40;
|
|
||||||
max_x = 20;
|
|
||||||
this->min_y = min_y;
|
|
||||||
this->max_y = max_y;
|
|
||||||
sign = 1.0;
|
|
||||||
// btScalar dalpha = 2*SIMD_2_PI/NUMRAYS_IN_BAR;
|
|
||||||
for (int i = 0; i < NUMRAYS_IN_BAR; i++)
|
|
||||||
{
|
|
||||||
btScalar z = (max_z-min_z)/btScalar(NUMRAYS_IN_BAR) * btScalar(i) + min_z;
|
|
||||||
source[i] = btVector3(min_x, max_y, z);
|
|
||||||
dest[i] = btVector3(min_x + ray_length, min_y, z);
|
|
||||||
normal[i] = btVector3(1.0, 0.0, 0.0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
btRaycastBar (btScalar ray_length, btScalar z, btScalar min_y = -1000, btScalar max_y = 10)
|
|
||||||
{
|
|
||||||
frame_counter = 0;
|
|
||||||
ms = 0;
|
|
||||||
max_ms = 0;
|
|
||||||
min_ms = 9999.0;
|
|
||||||
sum_ms_samples = 0;
|
|
||||||
sum_ms = 0;
|
|
||||||
dx = 10.0;
|
|
||||||
min_x = -40;
|
|
||||||
max_x = 20;
|
|
||||||
this->min_y = min_y;
|
|
||||||
this->max_y = max_y;
|
|
||||||
sign = 1.0;
|
|
||||||
btScalar dalpha = 2*SIMD_2_PI/NUMRAYS_IN_BAR;
|
|
||||||
for (int i = 0; i < NUMRAYS_IN_BAR; i++)
|
|
||||||
{
|
|
||||||
btScalar alpha = dalpha * i;
|
|
||||||
// rotate around by alpha degrees y
|
|
||||||
btTransform tr (btQuaternion (btVector3(0.0, 1.0, 0.0), alpha));
|
|
||||||
direction[i] = btVector3(1.0, 0.0, 0.0);
|
|
||||||
direction[i] = tr* direction[i];
|
|
||||||
direction[i] = direction[i] * ray_length;
|
|
||||||
source[i] = btVector3(min_x, max_y, z);
|
|
||||||
dest[i] = source[i] + direction[i];
|
|
||||||
dest[i][1] = min_y;
|
|
||||||
normal[i] = btVector3(1.0, 0.0, 0.0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void move (btScalar dt)
|
|
||||||
{
|
|
||||||
if (dt > (1.0/60.0))
|
|
||||||
dt = 1.0/60.0;
|
|
||||||
for (int i = 0; i < NUMRAYS_IN_BAR; i++)
|
|
||||||
{
|
|
||||||
source[i][0] += dx * dt * sign;
|
|
||||||
dest[i][0] += dx * dt * sign;
|
|
||||||
}
|
|
||||||
if (source[0][0] < min_x)
|
|
||||||
sign = 1.0;
|
|
||||||
else if (source[0][0] > max_x)
|
|
||||||
sign = -1.0;
|
|
||||||
}
|
|
||||||
|
|
||||||
void cast (btCollisionWorld* cw)
|
|
||||||
{
|
|
||||||
#ifdef USE_BT_CLOCK
|
|
||||||
frame_timer.reset ();
|
|
||||||
#endif //USE_BT_CLOCK
|
|
||||||
|
|
||||||
#ifdef BATCH_RAYCASTER
|
|
||||||
if (!gBatchRaycaster)
|
|
||||||
return;
|
|
||||||
|
|
||||||
gBatchRaycaster->clearRays ();
|
|
||||||
for (int i = 0; i < NUMRAYS_IN_BAR; i++)
|
|
||||||
{
|
|
||||||
gBatchRaycaster->addRay (source[i], dest[i]);
|
|
||||||
}
|
|
||||||
gBatchRaycaster->performBatchRaycast ();
|
|
||||||
for (int i = 0; i < gBatchRaycaster->getNumRays (); i++)
|
|
||||||
{
|
|
||||||
const SpuRaycastTaskWorkUnitOut& out = (*gBatchRaycaster)[i];
|
|
||||||
hit[i].setInterpolate3(source[i],dest[i],out.hitFraction);
|
|
||||||
normal[i] = out.hitNormal;
|
|
||||||
normal[i].normalize ();
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
for (int i = 0; i < NUMRAYS_IN_BAR; i++)
|
|
||||||
{
|
|
||||||
btCollisionWorld::ClosestRayResultCallback cb(source[i], dest[i]);
|
|
||||||
|
|
||||||
cw->rayTest (source[i], dest[i], cb);
|
|
||||||
if (cb.hasHit ())
|
|
||||||
{
|
|
||||||
hit[i] = cb.m_hitPointWorld;
|
|
||||||
normal[i] = cb.m_hitNormalWorld;
|
|
||||||
normal[i].normalize ();
|
|
||||||
} else {
|
|
||||||
hit[i] = dest[i];
|
|
||||||
normal[i] = btVector3(1.0, 0.0, 0.0);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
#ifdef USE_BT_CLOCK
|
|
||||||
ms += frame_timer.getTimeMilliseconds ();
|
|
||||||
#endif //USE_BT_CLOCK
|
|
||||||
frame_counter++;
|
|
||||||
if (frame_counter > 50)
|
|
||||||
{
|
|
||||||
min_ms = ms < min_ms ? ms : min_ms;
|
|
||||||
max_ms = ms > max_ms ? ms : max_ms;
|
|
||||||
sum_ms += ms;
|
|
||||||
sum_ms_samples++;
|
|
||||||
btScalar mean_ms = (btScalar)sum_ms/(btScalar)sum_ms_samples;
|
|
||||||
printf("%d rays in %d ms %d %d %f\n", NUMRAYS_IN_BAR * frame_counter, ms, min_ms, max_ms, mean_ms);
|
|
||||||
ms = 0;
|
|
||||||
frame_counter = 0;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
void draw ()
|
|
||||||
{
|
|
||||||
glDisable (GL_LIGHTING);
|
|
||||||
glColor3f (0.0, 1.0, 0.0);
|
|
||||||
glBegin (GL_LINES);
|
|
||||||
int i;
|
|
||||||
|
|
||||||
for (i = 0; i < NUMRAYS_IN_BAR; i++)
|
|
||||||
{
|
|
||||||
glVertex3f (source[i][0], source[i][1], source[i][2]);
|
|
||||||
glVertex3f (hit[i][0], hit[i][1], hit[i][2]);
|
|
||||||
}
|
|
||||||
glEnd ();
|
|
||||||
glColor3f (1.0, 1.0, 1.0);
|
|
||||||
glBegin (GL_LINES);
|
|
||||||
for (i = 0; i < NUMRAYS_IN_BAR; i++)
|
|
||||||
{
|
|
||||||
glVertex3f (hit[i][0], hit[i][1], hit[i][2]);
|
|
||||||
glVertex3f (hit[i][0] + normal[i][0], hit[i][1] + normal[i][1], hit[i][2] + normal[i][2]);
|
|
||||||
}
|
|
||||||
glEnd ();
|
|
||||||
glColor3f (0.0, 1.0, 1.0);
|
|
||||||
glBegin (GL_POINTS);
|
|
||||||
for ( i = 0; i < NUMRAYS_IN_BAR; i++)
|
|
||||||
{
|
|
||||||
glVertex3f (hit[i][0], hit[i][1], hit[i][2]);
|
|
||||||
}
|
|
||||||
glEnd ();
|
|
||||||
glEnable (GL_LIGHTING);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
static btRaycastBar raycastBar;
|
|
||||||
|
|
||||||
|
|
||||||
const int NUM_VERTS_X = 30;
|
|
||||||
const int NUM_VERTS_Y = 30;
|
|
||||||
const int totalVerts = NUM_VERTS_X*NUM_VERTS_Y;
|
|
||||||
|
|
||||||
void ConcaveRaycastDemo::setVertexPositions(float waveheight, float offset)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
int j;
|
|
||||||
|
|
||||||
for ( i=0;i<NUM_VERTS_X;i++)
|
|
||||||
{
|
|
||||||
for (j=0;j<NUM_VERTS_Y;j++)
|
|
||||||
{
|
|
||||||
gVertices[i+j*NUM_VERTS_X].setValue((i-NUM_VERTS_X*0.5f)*TRIANGLE_SIZE,
|
|
||||||
//0.f,
|
|
||||||
waveheight*sinf((float)i+offset)*cosf((float)j+offset),
|
|
||||||
(j-NUM_VERTS_Y*0.5f)*TRIANGLE_SIZE);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void ConcaveRaycastDemo::keyboardCallback(unsigned char key, int x, int y)
|
|
||||||
{
|
|
||||||
if (key == 'g')
|
|
||||||
{
|
|
||||||
m_animatedMesh = !m_animatedMesh;
|
|
||||||
if (m_animatedMesh)
|
|
||||||
{
|
|
||||||
staticBody->setCollisionFlags( staticBody->getCollisionFlags() | btCollisionObject::CF_KINEMATIC_OBJECT);
|
|
||||||
staticBody->setActivationState(DISABLE_DEACTIVATION);
|
|
||||||
} else
|
|
||||||
{
|
|
||||||
staticBody->setCollisionFlags( staticBody->getCollisionFlags() & ~btCollisionObject::CF_KINEMATIC_OBJECT);
|
|
||||||
staticBody->forceActivationState(ACTIVE_TAG);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
DemoApplication::keyboardCallback(key,x,y);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
void ConcaveRaycastDemo::initPhysics()
|
|
||||||
{
|
|
||||||
|
|
||||||
#define TRISIZE 10.f
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
int vertStride = sizeof(btVector3);
|
|
||||||
int indexStride = 3*sizeof(int);
|
|
||||||
|
|
||||||
|
|
||||||
const int totalTriangles = 2*(NUM_VERTS_X-1)*(NUM_VERTS_Y-1);
|
|
||||||
|
|
||||||
gVertices = new btVector3[totalVerts];
|
|
||||||
gIndices = new int[totalTriangles*3];
|
|
||||||
|
|
||||||
int i;
|
|
||||||
|
|
||||||
|
|
||||||
setVertexPositions(waveheight,0.f);
|
|
||||||
|
|
||||||
int index=0;
|
|
||||||
for ( i=0;i<NUM_VERTS_X-1;i++)
|
|
||||||
{
|
|
||||||
for (int j=0;j<NUM_VERTS_Y-1;j++)
|
|
||||||
{
|
|
||||||
gIndices[index++] = j*NUM_VERTS_X+i;
|
|
||||||
gIndices[index++] = j*NUM_VERTS_X+i+1;
|
|
||||||
gIndices[index++] = (j+1)*NUM_VERTS_X+i+1;
|
|
||||||
|
|
||||||
gIndices[index++] = j*NUM_VERTS_X+i;
|
|
||||||
gIndices[index++] = (j+1)*NUM_VERTS_X+i+1;
|
|
||||||
gIndices[index++] = (j+1)*NUM_VERTS_X+i;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
m_indexVertexArrays = new btTriangleIndexVertexArray(totalTriangles,
|
|
||||||
gIndices,
|
|
||||||
indexStride,
|
|
||||||
totalVerts,(btScalar*) &gVertices[0].x(),vertStride);
|
|
||||||
|
|
||||||
bool useQuantizedAabbCompression = true;
|
|
||||||
|
|
||||||
trimeshShape = new btBvhTriangleMeshShape(m_indexVertexArrays,useQuantizedAabbCompression);
|
|
||||||
m_collisionShapes.push_back(trimeshShape);
|
|
||||||
|
|
||||||
btCollisionShape* groundShape = trimeshShape;
|
|
||||||
|
|
||||||
m_collisionConfiguration = new btDefaultCollisionConfiguration();
|
|
||||||
|
|
||||||
|
|
||||||
m_dispatcher = new btCollisionDispatcher(m_collisionConfiguration);
|
|
||||||
|
|
||||||
|
|
||||||
btVector3 worldMin(-1000,-1000,-1000);
|
|
||||||
btVector3 worldMax(1000,1000,1000);
|
|
||||||
m_broadphase = new btAxisSweep3(worldMin,worldMax);
|
|
||||||
m_solver = new btSequentialImpulseConstraintSolver();
|
|
||||||
m_dynamicsWorld = new btDiscreteDynamicsWorld(m_dispatcher,m_broadphase,m_solver,m_collisionConfiguration);
|
|
||||||
m_dynamicsWorld->getSolverInfo().m_splitImpulse=true;
|
|
||||||
m_dynamicsWorld->setDebugDrawer(&sDebugDraw);
|
|
||||||
|
|
||||||
float mass = 0.f;
|
|
||||||
btTransform startTransform;
|
|
||||||
startTransform.setIdentity();
|
|
||||||
startTransform.setOrigin(btVector3(0,-2,0));
|
|
||||||
|
|
||||||
btCollisionShape* colShape = new btBoxShape(btVector3(1,1,1));
|
|
||||||
m_collisionShapes.push_back(colShape);
|
|
||||||
|
|
||||||
{
|
|
||||||
for (int i=0;i<10;i++)
|
|
||||||
{
|
|
||||||
//btCollisionShape* colShape = new btCapsuleShape(0.5,2.0);//boxShape = new btSphereShape(1.f);
|
|
||||||
startTransform.setOrigin(btVector3(2*i,10,1));
|
|
||||||
localCreateRigidBody(1, startTransform,colShape);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
startTransform.setIdentity();
|
|
||||||
staticBody = localCreateRigidBody(mass, startTransform,groundShape);
|
|
||||||
|
|
||||||
staticBody->setCollisionFlags(staticBody->getCollisionFlags() | btCollisionObject::CF_STATIC_OBJECT);
|
|
||||||
|
|
||||||
#ifdef BATCH_RAYCASTER
|
|
||||||
int maxNumOutstandingTasks = 4;
|
|
||||||
|
|
||||||
#ifdef USE_WIN32_THREADING
|
|
||||||
Win32ThreadSupport::Win32ThreadConstructionInfo tci("batch raycast",
|
|
||||||
processRaycastTask,
|
|
||||||
createRaycastLocalStoreMemory,
|
|
||||||
maxNumOutstandingTasks);
|
|
||||||
m_threadSupportRaycast = new Win32ThreadSupport(tci);
|
|
||||||
printf("m_threadSupportRaycast = %p\n", m_threadSupportRaycast);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
gBatchRaycaster = new SpuBatchRaycaster (m_threadSupportRaycast, maxNumOutstandingTasks, m_dynamicsWorld->getCollisionObjectArray(), m_dynamicsWorld->getNumCollisionObjects());
|
|
||||||
#endif
|
|
||||||
|
|
||||||
raycastBar = btRaycastBar (4000.0, 0.0);
|
|
||||||
//raycastBar = btRaycastBar (true, 40.0, -50.0, 50.0);
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
void ConcaveRaycastDemo::clientMoveAndDisplay()
|
|
||||||
{
|
|
||||||
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
|
||||||
|
|
||||||
float dt = getDeltaTimeMicroseconds() * 0.000001f;
|
|
||||||
|
|
||||||
if (m_animatedMesh)
|
|
||||||
{
|
|
||||||
static float offset=0.f;
|
|
||||||
offset+=0.01f;
|
|
||||||
|
|
||||||
setVertexPositions(waveheight,offset);
|
|
||||||
|
|
||||||
btVector3 worldMin(-1000,-1000,-1000);
|
|
||||||
btVector3 worldMax(1000,1000,1000);
|
|
||||||
|
|
||||||
trimeshShape->refitTree(worldMin,worldMax);
|
|
||||||
|
|
||||||
//clear all contact points involving mesh proxy. Note: this is a slow/unoptimized operation.
|
|
||||||
m_dynamicsWorld->getBroadphase()->getOverlappingPairCache()->cleanProxyFromPairs(staticBody->getBroadphaseHandle(),getDynamicsWorld()->getDispatcher());
|
|
||||||
}
|
|
||||||
|
|
||||||
m_dynamicsWorld->stepSimulation(1./60.,0);
|
|
||||||
|
|
||||||
//optional but useful: debug drawing
|
|
||||||
m_dynamicsWorld->debugDrawWorld();
|
|
||||||
|
|
||||||
raycastBar.move (dt);
|
|
||||||
raycastBar.cast (m_dynamicsWorld);
|
|
||||||
renderme();
|
|
||||||
raycastBar.draw ();
|
|
||||||
glFlush();
|
|
||||||
glutSwapBuffers();
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void ConcaveRaycastDemo::displayCallback(void) {
|
|
||||||
|
|
||||||
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
|
||||||
|
|
||||||
//optional but useful: debug drawing
|
|
||||||
if (m_dynamicsWorld)
|
|
||||||
m_dynamicsWorld->debugDrawWorld();
|
|
||||||
|
|
||||||
renderme();
|
|
||||||
raycastBar.draw ();
|
|
||||||
glFlush();
|
|
||||||
glutSwapBuffers();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void ConcaveRaycastDemo::exitPhysics()
|
|
||||||
{
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//cleanup in the reverse order of creation/initialization
|
|
||||||
|
|
||||||
//remove the rigidbodies from the dynamics world and delete them
|
|
||||||
int i;
|
|
||||||
for (i=m_dynamicsWorld->getNumCollisionObjects()-1; i>=0 ;i--)
|
|
||||||
{
|
|
||||||
btCollisionObject* obj = m_dynamicsWorld->getCollisionObjectArray()[i];
|
|
||||||
btRigidBody* body = btRigidBody::upcast(obj);
|
|
||||||
if (body && body->getMotionState())
|
|
||||||
{
|
|
||||||
delete body->getMotionState();
|
|
||||||
}
|
|
||||||
m_dynamicsWorld->removeCollisionObject( obj );
|
|
||||||
delete obj;
|
|
||||||
}
|
|
||||||
|
|
||||||
//delete collision shapes
|
|
||||||
for (int j=0;j<m_collisionShapes.size();j++)
|
|
||||||
{
|
|
||||||
btCollisionShape* shape = m_collisionShapes[j];
|
|
||||||
delete shape;
|
|
||||||
}
|
|
||||||
|
|
||||||
//delete dynamics world
|
|
||||||
delete m_dynamicsWorld;
|
|
||||||
|
|
||||||
if (m_indexVertexArrays)
|
|
||||||
delete m_indexVertexArrays;
|
|
||||||
|
|
||||||
//delete solver
|
|
||||||
delete m_solver;
|
|
||||||
|
|
||||||
//delete broadphase
|
|
||||||
delete m_broadphase;
|
|
||||||
|
|
||||||
//delete dispatcher
|
|
||||||
delete m_dispatcher;
|
|
||||||
|
|
||||||
delete m_collisionConfiguration;
|
|
||||||
|
|
||||||
delete[] gVertices;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -1,85 +0,0 @@
|
|||||||
/*
|
|
||||||
Bullet Continuous Collision Detection and Physics Library
|
|
||||||
Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied warranty.
|
|
||||||
In no event will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it freely,
|
|
||||||
subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
|
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
#ifndef CONCAVE_RAYCAST_DEMO_H
|
|
||||||
#define CONCAVE_RAYCAST_DEMO_H
|
|
||||||
|
|
||||||
#include "GlutDemoApplication.h"
|
|
||||||
#include "LinearMath/btAlignedObjectArray.h"
|
|
||||||
|
|
||||||
class btBroadphaseInterface;
|
|
||||||
class btCollisionShape;
|
|
||||||
class btOverlappingPairCache;
|
|
||||||
class btCollisionDispatcher;
|
|
||||||
class btConstraintSolver;
|
|
||||||
struct btCollisionAlgorithmCreateFunc;
|
|
||||||
class btDefaultCollisionConfiguration;
|
|
||||||
class btTriangleIndexVertexArray;
|
|
||||||
|
|
||||||
///ConcaveRaycastDemo shows usage of static concave triangle meshes
|
|
||||||
class ConcaveRaycastDemo : public GlutDemoApplication
|
|
||||||
{
|
|
||||||
|
|
||||||
//keep the collision shapes, for deletion/cleanup
|
|
||||||
btAlignedObjectArray<btCollisionShape*> m_collisionShapes;
|
|
||||||
|
|
||||||
btTriangleIndexVertexArray* m_indexVertexArrays;
|
|
||||||
|
|
||||||
btBroadphaseInterface* m_broadphase;
|
|
||||||
|
|
||||||
btCollisionDispatcher* m_dispatcher;
|
|
||||||
|
|
||||||
btConstraintSolver* m_solver;
|
|
||||||
|
|
||||||
class btThreadSupportInterface* m_threadSupportRaycast;
|
|
||||||
|
|
||||||
btDefaultCollisionConfiguration* m_collisionConfiguration;
|
|
||||||
|
|
||||||
bool m_animatedMesh;
|
|
||||||
|
|
||||||
public:
|
|
||||||
|
|
||||||
ConcaveRaycastDemo() : m_animatedMesh(false)
|
|
||||||
{
|
|
||||||
|
|
||||||
}
|
|
||||||
void initPhysics();
|
|
||||||
|
|
||||||
void exitPhysics();
|
|
||||||
|
|
||||||
virtual ~ConcaveRaycastDemo()
|
|
||||||
{
|
|
||||||
exitPhysics();
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual void clientMoveAndDisplay();
|
|
||||||
|
|
||||||
virtual void displayCallback();
|
|
||||||
|
|
||||||
//to show refit works
|
|
||||||
void setVertexPositions(float waveheight, float offset);
|
|
||||||
|
|
||||||
virtual void keyboardCallback(unsigned char key, int x, int y);
|
|
||||||
|
|
||||||
static DemoApplication* Create()
|
|
||||||
{
|
|
||||||
ConcaveRaycastDemo* demo = new ConcaveRaycastDemo();
|
|
||||||
demo->myinit();
|
|
||||||
demo->initPhysics();
|
|
||||||
return demo;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif //CONCAVE_RAYCAST_DEMO_H
|
|
||||||
|
|
15
extern/bullet/Demos/ConcaveRaycastDemo/main.cpp
vendored
15
extern/bullet/Demos/ConcaveRaycastDemo/main.cpp
vendored
@ -1,15 +0,0 @@
|
|||||||
|
|
||||||
#include "ConcaveRaycastDemo.h"
|
|
||||||
#include "GlutStuff.h"
|
|
||||||
|
|
||||||
|
|
||||||
int main(int argc,char** argv)
|
|
||||||
{
|
|
||||||
|
|
||||||
ConcaveRaycastDemo* concaveRaycastDemo = new ConcaveRaycastDemo();
|
|
||||||
concaveRaycastDemo->initPhysics();
|
|
||||||
concaveRaycastDemo->setCameraDistance(30.f);
|
|
||||||
|
|
||||||
return glutmain(argc, argv,640,480,"Concave Raycast Demo",concaveRaycastDemo);
|
|
||||||
}
|
|
||||||
|
|
@ -1,71 +0,0 @@
|
|||||||
# This is basically the overall name of the project in Visual Studio this is the name of the Solution File
|
|
||||||
|
|
||||||
|
|
||||||
# For every executable you have with a main method you should have an add_executable line below.
|
|
||||||
# For every add executable line you should list every .cpp and .h file you have associated with that executable.
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# You shouldn't have to modify anything below this line
|
|
||||||
########################################################
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
INCLUDE_DIRECTORIES(
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/src
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/Demos/OpenGL
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/Extras/Serialize/BulletFileLoader
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/Extras/Serialize/BulletWorldImporter
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
IF (USE_GLUT)
|
|
||||||
LINK_LIBRARIES(
|
|
||||||
OpenGLSupport BulletWorldImporter BulletDynamics BulletCollision LinearMath BulletFileLoader ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY}
|
|
||||||
)
|
|
||||||
|
|
||||||
ADD_EXECUTABLE(AppConstraintDemo
|
|
||||||
ConstraintDemo.cpp
|
|
||||||
ConstraintDemo.h
|
|
||||||
main.cpp
|
|
||||||
)
|
|
||||||
IF (WIN32)
|
|
||||||
IF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES)
|
|
||||||
IF (CMAKE_CL_64)
|
|
||||||
ADD_CUSTOM_COMMAND(
|
|
||||||
TARGET AppConstraintDemo
|
|
||||||
POST_BUILD
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/glut64.dll ${CMAKE_CURRENT_BINARY_DIR}
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/glut64.dll ${CMAKE_CURRENT_BINARY_DIR}/Debug
|
|
||||||
)
|
|
||||||
ELSE(CMAKE_CL_64)
|
|
||||||
ADD_CUSTOM_COMMAND(
|
|
||||||
TARGET AppConstraintDemo
|
|
||||||
POST_BUILD
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/GLUT32.DLL ${CMAKE_CURRENT_BINARY_DIR}
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/GLUT32.DLL ${CMAKE_CURRENT_BINARY_DIR}/Debug
|
|
||||||
)
|
|
||||||
ENDIF(CMAKE_CL_64)
|
|
||||||
ENDIF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES)
|
|
||||||
ENDIF(WIN32)
|
|
||||||
ELSE (USE_GLUT)
|
|
||||||
LINK_LIBRARIES(
|
|
||||||
OpenGLSupport BulletWorldImporter BulletDynamics BulletCollision LinearMath BulletFileLoader ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY}
|
|
||||||
)
|
|
||||||
|
|
||||||
ADD_EXECUTABLE(AppConstraintDemo
|
|
||||||
WIN32
|
|
||||||
../OpenGL/Win32AppMain.cpp
|
|
||||||
Win32ConstraintDemo.cpp
|
|
||||||
ConstraintDemo.cpp
|
|
||||||
ConstraintDemo.h
|
|
||||||
)
|
|
||||||
ENDIF (USE_GLUT)
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES)
|
|
||||||
SET_TARGET_PROPERTIES(AppConstraintDemo PROPERTIES DEBUG_POSTFIX "_Debug")
|
|
||||||
SET_TARGET_PROPERTIES(AppConstraintDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel")
|
|
||||||
SET_TARGET_PROPERTIES(AppConstraintDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo")
|
|
||||||
ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES)
|
|
@ -1,863 +0,0 @@
|
|||||||
/*
|
|
||||||
Bullet Continuous Collision Detection and Physics Library
|
|
||||||
Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied warranty.
|
|
||||||
In no event will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it freely,
|
|
||||||
subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
|
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#include "btBulletDynamicsCommon.h"
|
|
||||||
#include "LinearMath/btIDebugDraw.h"
|
|
||||||
|
|
||||||
#include "GLDebugDrawer.h"
|
|
||||||
|
|
||||||
#include "GLDebugFont.h"
|
|
||||||
#include <stdio.h> //printf debugging
|
|
||||||
|
|
||||||
#include "ConstraintDemo.h"
|
|
||||||
#include "GL_ShapeDrawer.h"
|
|
||||||
#include "GlutStuff.h"
|
|
||||||
|
|
||||||
#include "GLDebugDrawer.h"
|
|
||||||
static GLDebugDrawer gDebugDrawer;
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
const int numObjects = 3;
|
|
||||||
|
|
||||||
#define ENABLE_ALL_DEMOS 1
|
|
||||||
|
|
||||||
#define CUBE_HALF_EXTENTS 1.f
|
|
||||||
|
|
||||||
#define SIMD_PI_2 ((SIMD_PI)*0.5f)
|
|
||||||
#define SIMD_PI_4 ((SIMD_PI)*0.25f)
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
btTransform sliderTransform;
|
|
||||||
btVector3 lowerSliderLimit = btVector3(-10,0,0);
|
|
||||||
btVector3 hiSliderLimit = btVector3(10,0,0);
|
|
||||||
|
|
||||||
btRigidBody* d6body0 =0;
|
|
||||||
|
|
||||||
btHingeConstraint* spDoorHinge = NULL;
|
|
||||||
btHingeConstraint* spHingeDynAB = NULL;
|
|
||||||
btGeneric6DofConstraint* spSlider6Dof = NULL;
|
|
||||||
|
|
||||||
static bool s_bTestConeTwistMotor = false;
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void drawLimit()
|
|
||||||
{
|
|
||||||
btVector3 from = sliderTransform*lowerSliderLimit;
|
|
||||||
btVector3 to = sliderTransform*hiSliderLimit;
|
|
||||||
btVector3 color(255,0,0);
|
|
||||||
glBegin(GL_LINES);
|
|
||||||
glColor3f(color.getX(), color.getY(), color.getZ());
|
|
||||||
glVertex3d(from.getX(), from.getY(), from.getZ());
|
|
||||||
glVertex3d(to.getX(), to.getY(), to.getZ());
|
|
||||||
if (d6body0)
|
|
||||||
{
|
|
||||||
from = d6body0->getWorldTransform().getOrigin();
|
|
||||||
to = from + d6body0->getWorldTransform().getBasis() * btVector3(0,0,10);
|
|
||||||
glVertex3d(from.getX(), from.getY(), from.getZ());
|
|
||||||
glVertex3d(to.getX(), to.getY(), to.getZ());
|
|
||||||
}
|
|
||||||
glEnd();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void ConstraintDemo::setupEmptyDynamicsWorld()
|
|
||||||
{
|
|
||||||
m_collisionConfiguration = new btDefaultCollisionConfiguration();
|
|
||||||
m_dispatcher = new btCollisionDispatcher(m_collisionConfiguration);
|
|
||||||
m_overlappingPairCache = new btDbvtBroadphase();
|
|
||||||
m_constraintSolver = new btSequentialImpulseConstraintSolver();
|
|
||||||
m_dynamicsWorld = new btDiscreteDynamicsWorld(m_dispatcher,m_overlappingPairCache,m_constraintSolver,m_collisionConfiguration);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
void ConstraintDemo::clientResetScene()
|
|
||||||
{
|
|
||||||
exitPhysics();
|
|
||||||
initPhysics();
|
|
||||||
}
|
|
||||||
void ConstraintDemo::initPhysics()
|
|
||||||
{
|
|
||||||
setTexturing(true);
|
|
||||||
setShadows(true);
|
|
||||||
|
|
||||||
setCameraDistance(26.f);
|
|
||||||
m_Time = 0;
|
|
||||||
|
|
||||||
setupEmptyDynamicsWorld();
|
|
||||||
|
|
||||||
m_dynamicsWorld->setDebugDrawer(&gDebugDrawer);
|
|
||||||
|
|
||||||
|
|
||||||
//btCollisionShape* groundShape = new btBoxShape(btVector3(btScalar(50.),btScalar(40.),btScalar(50.)));
|
|
||||||
btCollisionShape* groundShape = new btStaticPlaneShape(btVector3(0,1,0),40);
|
|
||||||
|
|
||||||
m_collisionShapes.push_back(groundShape);
|
|
||||||
btTransform groundTransform;
|
|
||||||
groundTransform.setIdentity();
|
|
||||||
groundTransform.setOrigin(btVector3(0,-56,0));
|
|
||||||
btRigidBody* groundBody;
|
|
||||||
groundBody= localCreateRigidBody(0, groundTransform, groundShape);
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
btCollisionShape* shape = new btBoxShape(btVector3(CUBE_HALF_EXTENTS,CUBE_HALF_EXTENTS,CUBE_HALF_EXTENTS));
|
|
||||||
m_collisionShapes.push_back(shape);
|
|
||||||
btTransform trans;
|
|
||||||
trans.setIdentity();
|
|
||||||
trans.setOrigin(btVector3(0,20,0));
|
|
||||||
|
|
||||||
float mass = 1.f;
|
|
||||||
|
|
||||||
#if ENABLE_ALL_DEMOS
|
|
||||||
///gear constraint demo
|
|
||||||
|
|
||||||
#define THETA SIMD_PI/4.f
|
|
||||||
#define L_1 (2 - tan(THETA))
|
|
||||||
#define L_2 (1 / cos(THETA))
|
|
||||||
#define RATIO L_2 / L_1
|
|
||||||
|
|
||||||
btRigidBody* bodyA=0;
|
|
||||||
btRigidBody* bodyB=0;
|
|
||||||
|
|
||||||
{
|
|
||||||
btCollisionShape* cylA = new btCylinderShape(btVector3(0.2,0.25,0.2));
|
|
||||||
btCollisionShape* cylB = new btCylinderShape(btVector3(L_1,0.025,L_1));
|
|
||||||
btCompoundShape* cyl0 = new btCompoundShape();
|
|
||||||
cyl0->addChildShape(btTransform::getIdentity(),cylA);
|
|
||||||
cyl0->addChildShape(btTransform::getIdentity(),cylB);
|
|
||||||
|
|
||||||
btScalar mass = 6.28;
|
|
||||||
btVector3 localInertia;
|
|
||||||
cyl0->calculateLocalInertia(mass,localInertia);
|
|
||||||
btRigidBody::btRigidBodyConstructionInfo ci(mass,0,cyl0,localInertia);
|
|
||||||
ci.m_startWorldTransform.setOrigin(btVector3(-8,1,-8));
|
|
||||||
|
|
||||||
btRigidBody* body = new btRigidBody(ci);//1,0,cyl0,localInertia);
|
|
||||||
m_dynamicsWorld->addRigidBody(body);
|
|
||||||
body->setLinearFactor(btVector3(0,0,0));
|
|
||||||
body->setAngularFactor(btVector3(0,1,0));
|
|
||||||
bodyA = body;
|
|
||||||
}
|
|
||||||
|
|
||||||
{
|
|
||||||
btCollisionShape* cylA = new btCylinderShape(btVector3(0.2,0.26,0.2));
|
|
||||||
btCollisionShape* cylB = new btCylinderShape(btVector3(L_2,0.025,L_2));
|
|
||||||
btCompoundShape* cyl0 = new btCompoundShape();
|
|
||||||
cyl0->addChildShape(btTransform::getIdentity(),cylA);
|
|
||||||
cyl0->addChildShape(btTransform::getIdentity(),cylB);
|
|
||||||
|
|
||||||
btScalar mass = 6.28;
|
|
||||||
btVector3 localInertia;
|
|
||||||
cyl0->calculateLocalInertia(mass,localInertia);
|
|
||||||
btRigidBody::btRigidBodyConstructionInfo ci(mass,0,cyl0,localInertia);
|
|
||||||
ci.m_startWorldTransform.setOrigin(btVector3(-10,2,-8));
|
|
||||||
|
|
||||||
|
|
||||||
btQuaternion orn(btVector3(0,0,1),-THETA);
|
|
||||||
ci.m_startWorldTransform.setRotation(orn);
|
|
||||||
|
|
||||||
btRigidBody* body = new btRigidBody(ci);//1,0,cyl0,localInertia);
|
|
||||||
body->setLinearFactor(btVector3(0,0,0));
|
|
||||||
btHingeConstraint* hinge = new btHingeConstraint(*body,btVector3(0,0,0),btVector3(0,1,0),true);
|
|
||||||
m_dynamicsWorld->addConstraint(hinge);
|
|
||||||
bodyB= body;
|
|
||||||
body->setAngularVelocity(btVector3(0,3,0));
|
|
||||||
|
|
||||||
m_dynamicsWorld->addRigidBody(body);
|
|
||||||
}
|
|
||||||
|
|
||||||
btVector3 axisA(0,1,0);
|
|
||||||
btVector3 axisB(0,1,0);
|
|
||||||
btQuaternion orn(btVector3(0,0,1),-THETA);
|
|
||||||
btMatrix3x3 mat(orn);
|
|
||||||
axisB = mat.getRow(1);
|
|
||||||
|
|
||||||
btGearConstraint* gear = new btGearConstraint(*bodyA,*bodyB, axisA,axisB,RATIO);
|
|
||||||
m_dynamicsWorld->addConstraint(gear,true);
|
|
||||||
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
#if ENABLE_ALL_DEMOS
|
|
||||||
//point to point constraint with a breaking threshold
|
|
||||||
{
|
|
||||||
trans.setIdentity();
|
|
||||||
trans.setOrigin(btVector3(1,30,-5));
|
|
||||||
localCreateRigidBody( mass,trans,shape);
|
|
||||||
trans.setOrigin(btVector3(0,0,-5));
|
|
||||||
|
|
||||||
btRigidBody* body0 = localCreateRigidBody( mass,trans,shape);
|
|
||||||
trans.setOrigin(btVector3(2*CUBE_HALF_EXTENTS,20,0));
|
|
||||||
mass = 1.f;
|
|
||||||
// btRigidBody* body1 = 0;//localCreateRigidBody( mass,trans,shape);
|
|
||||||
btVector3 pivotInA(CUBE_HALF_EXTENTS,CUBE_HALF_EXTENTS,0);
|
|
||||||
btTypedConstraint* p2p = new btPoint2PointConstraint(*body0,pivotInA);
|
|
||||||
m_dynamicsWorld->addConstraint(p2p);
|
|
||||||
p2p ->setBreakingImpulseThreshold(10.2);
|
|
||||||
p2p->setDbgDrawSize(btScalar(5.f));
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#if ENABLE_ALL_DEMOS
|
|
||||||
//point to point constraint (ball socket)
|
|
||||||
{
|
|
||||||
btRigidBody* body0 = localCreateRigidBody( mass,trans,shape);
|
|
||||||
trans.setOrigin(btVector3(2*CUBE_HALF_EXTENTS,20,0));
|
|
||||||
|
|
||||||
mass = 1.f;
|
|
||||||
// btRigidBody* body1 = 0;//localCreateRigidBody( mass,trans,shape);
|
|
||||||
// btRigidBody* body1 = localCreateRigidBody( 0.0,trans,0);
|
|
||||||
//body1->setActivationState(DISABLE_DEACTIVATION);
|
|
||||||
//body1->setDamping(0.3,0.3);
|
|
||||||
|
|
||||||
btVector3 pivotInA(CUBE_HALF_EXTENTS,-CUBE_HALF_EXTENTS,-CUBE_HALF_EXTENTS);
|
|
||||||
btVector3 axisInA(0,0,1);
|
|
||||||
|
|
||||||
// btVector3 pivotInB = body1 ? body1->getCenterOfMassTransform().inverse()(body0->getCenterOfMassTransform()(pivotInA)) : pivotInA;
|
|
||||||
// btVector3 axisInB = body1?
|
|
||||||
// (body1->getCenterOfMassTransform().getBasis().inverse()*(body1->getCenterOfMassTransform().getBasis() * axisInA)) :
|
|
||||||
body0->getCenterOfMassTransform().getBasis() * axisInA;
|
|
||||||
|
|
||||||
#define P2P
|
|
||||||
#ifdef P2P
|
|
||||||
btTypedConstraint* p2p = new btPoint2PointConstraint(*body0,pivotInA);
|
|
||||||
//btTypedConstraint* p2p = new btPoint2PointConstraint(*body0,*body1,pivotInA,pivotInB);
|
|
||||||
//btTypedConstraint* hinge = new btHingeConstraint(*body0,*body1,pivotInA,pivotInB,axisInA,axisInB);
|
|
||||||
m_dynamicsWorld->addConstraint(p2p);
|
|
||||||
p2p->setDbgDrawSize(btScalar(5.f));
|
|
||||||
#else
|
|
||||||
btHingeConstraint* hinge = new btHingeConstraint(*body0,pivotInA,axisInA);
|
|
||||||
|
|
||||||
//use zero targetVelocity and a small maxMotorImpulse to simulate joint friction
|
|
||||||
//float targetVelocity = 0.f;
|
|
||||||
//float maxMotorImpulse = 0.01;
|
|
||||||
float targetVelocity = 1.f;
|
|
||||||
float maxMotorImpulse = 1.0f;
|
|
||||||
hinge->enableAngularMotor(true,targetVelocity,maxMotorImpulse);
|
|
||||||
m_dynamicsWorld->addConstraint(hinge);
|
|
||||||
hinge->setDbgDrawSize(btScalar(5.f));
|
|
||||||
#endif //P2P
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
#if ENABLE_ALL_DEMOS
|
|
||||||
{
|
|
||||||
btTransform trans;
|
|
||||||
trans.setIdentity();
|
|
||||||
btVector3 worldPos(-20,0,30);
|
|
||||||
trans.setOrigin(worldPos);
|
|
||||||
|
|
||||||
btTransform frameInA, frameInB;
|
|
||||||
frameInA = btTransform::getIdentity();
|
|
||||||
frameInB = btTransform::getIdentity();
|
|
||||||
|
|
||||||
btRigidBody* pRbA1 = localCreateRigidBody(mass, trans, shape);
|
|
||||||
// btRigidBody* pRbA1 = localCreateRigidBody(0.f, trans, shape);
|
|
||||||
pRbA1->setActivationState(DISABLE_DEACTIVATION);
|
|
||||||
|
|
||||||
// add dynamic rigid body B1
|
|
||||||
worldPos.setValue(-30,0,30);
|
|
||||||
trans.setOrigin(worldPos);
|
|
||||||
btRigidBody* pRbB1 = localCreateRigidBody(mass, trans, shape);
|
|
||||||
// btRigidBody* pRbB1 = localCreateRigidBody(0.f, trans, shape);
|
|
||||||
pRbB1->setActivationState(DISABLE_DEACTIVATION);
|
|
||||||
|
|
||||||
// create slider constraint between A1 and B1 and add it to world
|
|
||||||
|
|
||||||
btSliderConstraint* spSlider1 = new btSliderConstraint(*pRbA1, *pRbB1, frameInA, frameInB, true);
|
|
||||||
// spSlider1 = new btSliderConstraint(*pRbA1, *pRbB1, frameInA, frameInB, false);
|
|
||||||
spSlider1->setLowerLinLimit(-15.0F);
|
|
||||||
spSlider1->setUpperLinLimit(-5.0F);
|
|
||||||
// spSlider1->setLowerLinLimit(5.0F);
|
|
||||||
// spSlider1->setUpperLinLimit(15.0F);
|
|
||||||
// spSlider1->setLowerLinLimit(-10.0F);
|
|
||||||
// spSlider1->setUpperLinLimit(-10.0F);
|
|
||||||
|
|
||||||
spSlider1->setLowerAngLimit(-SIMD_PI / 3.0F);
|
|
||||||
spSlider1->setUpperAngLimit( SIMD_PI / 3.0F);
|
|
||||||
|
|
||||||
|
|
||||||
m_dynamicsWorld->addConstraint(spSlider1, true);
|
|
||||||
spSlider1->setDbgDrawSize(btScalar(5.f));
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if ENABLE_ALL_DEMOS
|
|
||||||
//create a slider, using the generic D6 constraint
|
|
||||||
{
|
|
||||||
mass = 1.f;
|
|
||||||
btVector3 sliderWorldPos(0,10,0);
|
|
||||||
btVector3 sliderAxis(1,0,0);
|
|
||||||
btScalar angle=0.f;//SIMD_RADS_PER_DEG * 10.f;
|
|
||||||
btMatrix3x3 sliderOrientation(btQuaternion(sliderAxis ,angle));
|
|
||||||
trans.setIdentity();
|
|
||||||
trans.setOrigin(sliderWorldPos);
|
|
||||||
//trans.setBasis(sliderOrientation);
|
|
||||||
sliderTransform = trans;
|
|
||||||
|
|
||||||
d6body0 = localCreateRigidBody( mass,trans,shape);
|
|
||||||
d6body0->setActivationState(DISABLE_DEACTIVATION);
|
|
||||||
btRigidBody* fixedBody1 = localCreateRigidBody(0,trans,0);
|
|
||||||
m_dynamicsWorld->addRigidBody(fixedBody1);
|
|
||||||
|
|
||||||
btTransform frameInA, frameInB;
|
|
||||||
frameInA = btTransform::getIdentity();
|
|
||||||
frameInB = btTransform::getIdentity();
|
|
||||||
frameInA.setOrigin(btVector3(0., 5., 0.));
|
|
||||||
frameInB.setOrigin(btVector3(0., 5., 0.));
|
|
||||||
|
|
||||||
// bool useLinearReferenceFrameA = false;//use fixed frame B for linear llimits
|
|
||||||
bool useLinearReferenceFrameA = true;//use fixed frame A for linear llimits
|
|
||||||
spSlider6Dof = new btGeneric6DofConstraint(*fixedBody1, *d6body0,frameInA,frameInB,useLinearReferenceFrameA);
|
|
||||||
spSlider6Dof->setLinearLowerLimit(lowerSliderLimit);
|
|
||||||
spSlider6Dof->setLinearUpperLimit(hiSliderLimit);
|
|
||||||
|
|
||||||
//range should be small, otherwise singularities will 'explode' the constraint
|
|
||||||
// spSlider6Dof->setAngularLowerLimit(btVector3(-1.5,0,0));
|
|
||||||
// spSlider6Dof->setAngularUpperLimit(btVector3(1.5,0,0));
|
|
||||||
// spSlider6Dof->setAngularLowerLimit(btVector3(0,0,0));
|
|
||||||
// spSlider6Dof->setAngularUpperLimit(btVector3(0,0,0));
|
|
||||||
spSlider6Dof->setAngularLowerLimit(btVector3(-SIMD_PI,0,0));
|
|
||||||
spSlider6Dof->setAngularUpperLimit(btVector3(1.5,0,0));
|
|
||||||
|
|
||||||
spSlider6Dof->getTranslationalLimitMotor()->m_enableMotor[0] = true;
|
|
||||||
spSlider6Dof->getTranslationalLimitMotor()->m_targetVelocity[0] = -5.0f;
|
|
||||||
spSlider6Dof->getTranslationalLimitMotor()->m_maxMotorForce[0] = 0.1f;
|
|
||||||
|
|
||||||
|
|
||||||
m_dynamicsWorld->addConstraint(spSlider6Dof);
|
|
||||||
spSlider6Dof->setDbgDrawSize(btScalar(5.f));
|
|
||||||
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
#if ENABLE_ALL_DEMOS
|
|
||||||
{ // create a door using hinge constraint attached to the world
|
|
||||||
btCollisionShape* pDoorShape = new btBoxShape(btVector3(2.0f, 5.0f, 0.2f));
|
|
||||||
m_collisionShapes.push_back(pDoorShape);
|
|
||||||
btTransform doorTrans;
|
|
||||||
doorTrans.setIdentity();
|
|
||||||
doorTrans.setOrigin(btVector3(-5.0f, -2.0f, 0.0f));
|
|
||||||
btRigidBody* pDoorBody = localCreateRigidBody( 1.0, doorTrans, pDoorShape);
|
|
||||||
pDoorBody->setActivationState(DISABLE_DEACTIVATION);
|
|
||||||
const btVector3 btPivotA(10.f + 2.1f, -2.0f, 0.0f ); // right next to the door slightly outside
|
|
||||||
btVector3 btAxisA( 0.0f, 1.0f, 0.0f ); // pointing upwards, aka Y-axis
|
|
||||||
|
|
||||||
spDoorHinge = new btHingeConstraint( *pDoorBody, btPivotA, btAxisA );
|
|
||||||
|
|
||||||
// spDoorHinge->setLimit( 0.0f, SIMD_PI_2 );
|
|
||||||
// test problem values
|
|
||||||
// spDoorHinge->setLimit( -SIMD_PI, SIMD_PI*0.8f);
|
|
||||||
|
|
||||||
// spDoorHinge->setLimit( 1.f, -1.f);
|
|
||||||
// spDoorHinge->setLimit( -SIMD_PI*0.8f, SIMD_PI);
|
|
||||||
// spDoorHinge->setLimit( -SIMD_PI*0.8f, SIMD_PI, 0.9f, 0.3f, 0.0f);
|
|
||||||
// spDoorHinge->setLimit( -SIMD_PI*0.8f, SIMD_PI, 0.9f, 0.01f, 0.0f); // "sticky limits"
|
|
||||||
spDoorHinge->setLimit( -SIMD_PI * 0.25f, SIMD_PI * 0.25f );
|
|
||||||
// spDoorHinge->setLimit( 0.0f, 0.0f );
|
|
||||||
m_dynamicsWorld->addConstraint(spDoorHinge);
|
|
||||||
spDoorHinge->setDbgDrawSize(btScalar(5.f));
|
|
||||||
|
|
||||||
//doorTrans.setOrigin(btVector3(-5.0f, 2.0f, 0.0f));
|
|
||||||
//btRigidBody* pDropBody = localCreateRigidBody( 10.0, doorTrans, shape);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
#if ENABLE_ALL_DEMOS
|
|
||||||
{ // create a generic 6DOF constraint
|
|
||||||
|
|
||||||
btTransform tr;
|
|
||||||
tr.setIdentity();
|
|
||||||
tr.setOrigin(btVector3(btScalar(10.), btScalar(6.), btScalar(0.)));
|
|
||||||
tr.getBasis().setEulerZYX(0,0,0);
|
|
||||||
// btRigidBody* pBodyA = localCreateRigidBody( mass, tr, shape);
|
|
||||||
btRigidBody* pBodyA = localCreateRigidBody( 0.0, tr, shape);
|
|
||||||
// btRigidBody* pBodyA = localCreateRigidBody( 0.0, tr, 0);
|
|
||||||
pBodyA->setActivationState(DISABLE_DEACTIVATION);
|
|
||||||
|
|
||||||
tr.setIdentity();
|
|
||||||
tr.setOrigin(btVector3(btScalar(0.), btScalar(6.), btScalar(0.)));
|
|
||||||
tr.getBasis().setEulerZYX(0,0,0);
|
|
||||||
btRigidBody* pBodyB = localCreateRigidBody(mass, tr, shape);
|
|
||||||
// btRigidBody* pBodyB = localCreateRigidBody(0.f, tr, shape);
|
|
||||||
pBodyB->setActivationState(DISABLE_DEACTIVATION);
|
|
||||||
|
|
||||||
btTransform frameInA, frameInB;
|
|
||||||
frameInA = btTransform::getIdentity();
|
|
||||||
frameInA.setOrigin(btVector3(btScalar(-5.), btScalar(0.), btScalar(0.)));
|
|
||||||
frameInB = btTransform::getIdentity();
|
|
||||||
frameInB.setOrigin(btVector3(btScalar(5.), btScalar(0.), btScalar(0.)));
|
|
||||||
|
|
||||||
btGeneric6DofConstraint* pGen6DOF = new btGeneric6DofConstraint(*pBodyA, *pBodyB, frameInA, frameInB, true);
|
|
||||||
// btGeneric6DofConstraint* pGen6DOF = new btGeneric6DofConstraint(*pBodyA, *pBodyB, frameInA, frameInB, false);
|
|
||||||
pGen6DOF->setLinearLowerLimit(btVector3(-10., -2., -1.));
|
|
||||||
pGen6DOF->setLinearUpperLimit(btVector3(10., 2., 1.));
|
|
||||||
// pGen6DOF->setLinearLowerLimit(btVector3(-10., 0., 0.));
|
|
||||||
// pGen6DOF->setLinearUpperLimit(btVector3(10., 0., 0.));
|
|
||||||
// pGen6DOF->setLinearLowerLimit(btVector3(0., 0., 0.));
|
|
||||||
// pGen6DOF->setLinearUpperLimit(btVector3(0., 0., 0.));
|
|
||||||
|
|
||||||
// pGen6DOF->getTranslationalLimitMotor()->m_enableMotor[0] = true;
|
|
||||||
// pGen6DOF->getTranslationalLimitMotor()->m_targetVelocity[0] = 5.0f;
|
|
||||||
// pGen6DOF->getTranslationalLimitMotor()->m_maxMotorForce[0] = 0.1f;
|
|
||||||
|
|
||||||
|
|
||||||
// pGen6DOF->setAngularLowerLimit(btVector3(0., SIMD_HALF_PI*0.9, 0.));
|
|
||||||
// pGen6DOF->setAngularUpperLimit(btVector3(0., -SIMD_HALF_PI*0.9, 0.));
|
|
||||||
// pGen6DOF->setAngularLowerLimit(btVector3(0., 0., -SIMD_HALF_PI));
|
|
||||||
// pGen6DOF->setAngularUpperLimit(btVector3(0., 0., SIMD_HALF_PI));
|
|
||||||
|
|
||||||
pGen6DOF->setAngularLowerLimit(btVector3(-SIMD_HALF_PI * 0.5f, -0.75, -SIMD_HALF_PI * 0.8f));
|
|
||||||
pGen6DOF->setAngularUpperLimit(btVector3(SIMD_HALF_PI * 0.5f, 0.75, SIMD_HALF_PI * 0.8f));
|
|
||||||
// pGen6DOF->setAngularLowerLimit(btVector3(0.f, -0.75, SIMD_HALF_PI * 0.8f));
|
|
||||||
// pGen6DOF->setAngularUpperLimit(btVector3(0.f, 0.75, -SIMD_HALF_PI * 0.8f));
|
|
||||||
// pGen6DOF->setAngularLowerLimit(btVector3(0.f, -SIMD_HALF_PI * 0.8f, SIMD_HALF_PI * 1.98f));
|
|
||||||
// pGen6DOF->setAngularUpperLimit(btVector3(0.f, SIMD_HALF_PI * 0.8f, -SIMD_HALF_PI * 1.98f));
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// pGen6DOF->setAngularLowerLimit(btVector3(-0.75,-0.5, -0.5));
|
|
||||||
// pGen6DOF->setAngularUpperLimit(btVector3(0.75,0.5, 0.5));
|
|
||||||
// pGen6DOF->setAngularLowerLimit(btVector3(-0.75,0., 0.));
|
|
||||||
// pGen6DOF->setAngularUpperLimit(btVector3(0.75,0., 0.));
|
|
||||||
// pGen6DOF->setAngularLowerLimit(btVector3(0., -0.7,0.));
|
|
||||||
// pGen6DOF->setAngularUpperLimit(btVector3(0., 0.7, 0.));
|
|
||||||
// pGen6DOF->setAngularLowerLimit(btVector3(-1., 0.,0.));
|
|
||||||
// pGen6DOF->setAngularUpperLimit(btVector3(1., 0., 0.));
|
|
||||||
|
|
||||||
m_dynamicsWorld->addConstraint(pGen6DOF, true);
|
|
||||||
pGen6DOF->setDbgDrawSize(btScalar(5.f));
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
#if ENABLE_ALL_DEMOS
|
|
||||||
{ // create a ConeTwist constraint
|
|
||||||
|
|
||||||
btTransform tr;
|
|
||||||
tr.setIdentity();
|
|
||||||
tr.setOrigin(btVector3(btScalar(-10.), btScalar(5.), btScalar(0.)));
|
|
||||||
tr.getBasis().setEulerZYX(0,0,0);
|
|
||||||
btRigidBody* pBodyA = localCreateRigidBody( 1.0, tr, shape);
|
|
||||||
// btRigidBody* pBodyA = localCreateRigidBody( 0.0, tr, shape);
|
|
||||||
pBodyA->setActivationState(DISABLE_DEACTIVATION);
|
|
||||||
|
|
||||||
tr.setIdentity();
|
|
||||||
tr.setOrigin(btVector3(btScalar(-10.), btScalar(-5.), btScalar(0.)));
|
|
||||||
tr.getBasis().setEulerZYX(0,0,0);
|
|
||||||
btRigidBody* pBodyB = localCreateRigidBody(0.0, tr, shape);
|
|
||||||
// btRigidBody* pBodyB = localCreateRigidBody(1.0, tr, shape);
|
|
||||||
|
|
||||||
btTransform frameInA, frameInB;
|
|
||||||
frameInA = btTransform::getIdentity();
|
|
||||||
frameInA.getBasis().setEulerZYX(0, 0, SIMD_PI_2);
|
|
||||||
frameInA.setOrigin(btVector3(btScalar(0.), btScalar(-5.), btScalar(0.)));
|
|
||||||
frameInB = btTransform::getIdentity();
|
|
||||||
frameInB.getBasis().setEulerZYX(0,0, SIMD_PI_2);
|
|
||||||
frameInB.setOrigin(btVector3(btScalar(0.), btScalar(5.), btScalar(0.)));
|
|
||||||
|
|
||||||
m_ctc = new btConeTwistConstraint(*pBodyA, *pBodyB, frameInA, frameInB);
|
|
||||||
// m_ctc->setLimit(btScalar(SIMD_PI_4), btScalar(SIMD_PI_4), btScalar(SIMD_PI) * 0.8f);
|
|
||||||
// m_ctc->setLimit(btScalar(SIMD_PI_4*0.6f), btScalar(SIMD_PI_4), btScalar(SIMD_PI) * 0.8f, 1.0f); // soft limit == hard limit
|
|
||||||
m_ctc->setLimit(btScalar(SIMD_PI_4*0.6f), btScalar(SIMD_PI_4), btScalar(SIMD_PI) * 0.8f, 0.5f);
|
|
||||||
m_dynamicsWorld->addConstraint(m_ctc, true);
|
|
||||||
m_ctc->setDbgDrawSize(btScalar(5.f));
|
|
||||||
// s_bTestConeTwistMotor = true; // use only with old solver for now
|
|
||||||
s_bTestConeTwistMotor = false;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
#if ENABLE_ALL_DEMOS
|
|
||||||
{ // Hinge connected to the world, with motor (to hinge motor with new and old constraint solver)
|
|
||||||
btTransform tr;
|
|
||||||
tr.setIdentity();
|
|
||||||
tr.setOrigin(btVector3(btScalar(0.), btScalar(0.), btScalar(0.)));
|
|
||||||
btRigidBody* pBody = localCreateRigidBody( 1.0, tr, shape);
|
|
||||||
pBody->setActivationState(DISABLE_DEACTIVATION);
|
|
||||||
const btVector3 btPivotA( 10.0f, 0.0f, 0.0f );
|
|
||||||
btVector3 btAxisA( 0.0f, 0.0f, 1.0f );
|
|
||||||
|
|
||||||
btHingeConstraint* pHinge = new btHingeConstraint( *pBody, btPivotA, btAxisA );
|
|
||||||
// pHinge->enableAngularMotor(true, -1.0, 0.165); // use for the old solver
|
|
||||||
pHinge->enableAngularMotor(true, -1.0f, 1.65f); // use for the new SIMD solver
|
|
||||||
m_dynamicsWorld->addConstraint(pHinge);
|
|
||||||
pHinge->setDbgDrawSize(btScalar(5.f));
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if ENABLE_ALL_DEMOS
|
|
||||||
{
|
|
||||||
// create a universal joint using generic 6DOF constraint
|
|
||||||
// create two rigid bodies
|
|
||||||
// static bodyA (parent) on top:
|
|
||||||
btTransform tr;
|
|
||||||
tr.setIdentity();
|
|
||||||
tr.setOrigin(btVector3(btScalar(20.), btScalar(4.), btScalar(0.)));
|
|
||||||
btRigidBody* pBodyA = localCreateRigidBody( 0.0, tr, shape);
|
|
||||||
pBodyA->setActivationState(DISABLE_DEACTIVATION);
|
|
||||||
// dynamic bodyB (child) below it :
|
|
||||||
tr.setIdentity();
|
|
||||||
tr.setOrigin(btVector3(btScalar(20.), btScalar(0.), btScalar(0.)));
|
|
||||||
btRigidBody* pBodyB = localCreateRigidBody(1.0, tr, shape);
|
|
||||||
pBodyB->setActivationState(DISABLE_DEACTIVATION);
|
|
||||||
// add some (arbitrary) data to build constraint frames
|
|
||||||
btVector3 parentAxis(1.f, 0.f, 0.f);
|
|
||||||
btVector3 childAxis(0.f, 0.f, 1.f);
|
|
||||||
btVector3 anchor(20.f, 2.f, 0.f);
|
|
||||||
|
|
||||||
btUniversalConstraint* pUniv = new btUniversalConstraint(*pBodyA, *pBodyB, anchor, parentAxis, childAxis);
|
|
||||||
pUniv->setLowerLimit(-SIMD_HALF_PI * 0.5f, -SIMD_HALF_PI * 0.5f);
|
|
||||||
pUniv->setUpperLimit(SIMD_HALF_PI * 0.5f, SIMD_HALF_PI * 0.5f);
|
|
||||||
// add constraint to world
|
|
||||||
m_dynamicsWorld->addConstraint(pUniv, true);
|
|
||||||
// draw constraint frames and limits for debugging
|
|
||||||
pUniv->setDbgDrawSize(btScalar(5.f));
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if ENABLE_ALL_DEMOS
|
|
||||||
{ // create a generic 6DOF constraint with springs
|
|
||||||
|
|
||||||
btTransform tr;
|
|
||||||
tr.setIdentity();
|
|
||||||
tr.setOrigin(btVector3(btScalar(-20.), btScalar(16.), btScalar(0.)));
|
|
||||||
tr.getBasis().setEulerZYX(0,0,0);
|
|
||||||
btRigidBody* pBodyA = localCreateRigidBody( 0.0, tr, shape);
|
|
||||||
pBodyA->setActivationState(DISABLE_DEACTIVATION);
|
|
||||||
|
|
||||||
tr.setIdentity();
|
|
||||||
tr.setOrigin(btVector3(btScalar(-10.), btScalar(16.), btScalar(0.)));
|
|
||||||
tr.getBasis().setEulerZYX(0,0,0);
|
|
||||||
btRigidBody* pBodyB = localCreateRigidBody(1.0, tr, shape);
|
|
||||||
pBodyB->setActivationState(DISABLE_DEACTIVATION);
|
|
||||||
|
|
||||||
btTransform frameInA, frameInB;
|
|
||||||
frameInA = btTransform::getIdentity();
|
|
||||||
frameInA.setOrigin(btVector3(btScalar(10.), btScalar(0.), btScalar(0.)));
|
|
||||||
frameInB = btTransform::getIdentity();
|
|
||||||
frameInB.setOrigin(btVector3(btScalar(0.), btScalar(0.), btScalar(0.)));
|
|
||||||
|
|
||||||
btGeneric6DofSpringConstraint* pGen6DOFSpring = new btGeneric6DofSpringConstraint(*pBodyA, *pBodyB, frameInA, frameInB, true);
|
|
||||||
pGen6DOFSpring->setLinearUpperLimit(btVector3(5., 0., 0.));
|
|
||||||
pGen6DOFSpring->setLinearLowerLimit(btVector3(-5., 0., 0.));
|
|
||||||
|
|
||||||
pGen6DOFSpring->setAngularLowerLimit(btVector3(0.f, 0.f, -1.5f));
|
|
||||||
pGen6DOFSpring->setAngularUpperLimit(btVector3(0.f, 0.f, 1.5f));
|
|
||||||
|
|
||||||
m_dynamicsWorld->addConstraint(pGen6DOFSpring, true);
|
|
||||||
pGen6DOFSpring->setDbgDrawSize(btScalar(5.f));
|
|
||||||
|
|
||||||
pGen6DOFSpring->enableSpring(0, true);
|
|
||||||
pGen6DOFSpring->setStiffness(0, 39.478f);
|
|
||||||
pGen6DOFSpring->setDamping(0, 0.5f);
|
|
||||||
pGen6DOFSpring->enableSpring(5, true);
|
|
||||||
pGen6DOFSpring->setStiffness(5, 39.478f);
|
|
||||||
pGen6DOFSpring->setDamping(0, 0.3f);
|
|
||||||
pGen6DOFSpring->setEquilibriumPoint();
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
#if ENABLE_ALL_DEMOS
|
|
||||||
{
|
|
||||||
// create a Hinge2 joint
|
|
||||||
// create two rigid bodies
|
|
||||||
// static bodyA (parent) on top:
|
|
||||||
btTransform tr;
|
|
||||||
tr.setIdentity();
|
|
||||||
tr.setOrigin(btVector3(btScalar(-20.), btScalar(4.), btScalar(0.)));
|
|
||||||
btRigidBody* pBodyA = localCreateRigidBody( 0.0, tr, shape);
|
|
||||||
pBodyA->setActivationState(DISABLE_DEACTIVATION);
|
|
||||||
// dynamic bodyB (child) below it :
|
|
||||||
tr.setIdentity();
|
|
||||||
tr.setOrigin(btVector3(btScalar(-20.), btScalar(0.), btScalar(0.)));
|
|
||||||
btRigidBody* pBodyB = localCreateRigidBody(1.0, tr, shape);
|
|
||||||
pBodyB->setActivationState(DISABLE_DEACTIVATION);
|
|
||||||
// add some data to build constraint frames
|
|
||||||
btVector3 parentAxis(0.f, 1.f, 0.f);
|
|
||||||
btVector3 childAxis(1.f, 0.f, 0.f);
|
|
||||||
btVector3 anchor(-20.f, 0.f, 0.f);
|
|
||||||
btHinge2Constraint* pHinge2 = new btHinge2Constraint(*pBodyA, *pBodyB, anchor, parentAxis, childAxis);
|
|
||||||
pHinge2->setLowerLimit(-SIMD_HALF_PI * 0.5f);
|
|
||||||
pHinge2->setUpperLimit( SIMD_HALF_PI * 0.5f);
|
|
||||||
// add constraint to world
|
|
||||||
m_dynamicsWorld->addConstraint(pHinge2, true);
|
|
||||||
// draw constraint frames and limits for debugging
|
|
||||||
pHinge2->setDbgDrawSize(btScalar(5.f));
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
#if ENABLE_ALL_DEMOS
|
|
||||||
{
|
|
||||||
// create a Hinge joint between two dynamic bodies
|
|
||||||
// create two rigid bodies
|
|
||||||
// static bodyA (parent) on top:
|
|
||||||
btTransform tr;
|
|
||||||
tr.setIdentity();
|
|
||||||
tr.setOrigin(btVector3(btScalar(-20.), btScalar(-2.), btScalar(0.)));
|
|
||||||
btRigidBody* pBodyA = localCreateRigidBody( 1.0f, tr, shape);
|
|
||||||
pBodyA->setActivationState(DISABLE_DEACTIVATION);
|
|
||||||
// dynamic bodyB:
|
|
||||||
tr.setIdentity();
|
|
||||||
tr.setOrigin(btVector3(btScalar(-30.), btScalar(-2.), btScalar(0.)));
|
|
||||||
btRigidBody* pBodyB = localCreateRigidBody(10.0, tr, shape);
|
|
||||||
pBodyB->setActivationState(DISABLE_DEACTIVATION);
|
|
||||||
// add some data to build constraint frames
|
|
||||||
btVector3 axisA(0.f, 1.f, 0.f);
|
|
||||||
btVector3 axisB(0.f, 1.f, 0.f);
|
|
||||||
btVector3 pivotA(-5.f, 0.f, 0.f);
|
|
||||||
btVector3 pivotB( 5.f, 0.f, 0.f);
|
|
||||||
spHingeDynAB = new btHingeConstraint(*pBodyA, *pBodyB, pivotA, pivotB, axisA, axisB);
|
|
||||||
spHingeDynAB->setLimit(-SIMD_HALF_PI * 0.5f, SIMD_HALF_PI * 0.5f);
|
|
||||||
// add constraint to world
|
|
||||||
m_dynamicsWorld->addConstraint(spHingeDynAB, true);
|
|
||||||
// draw constraint frames and limits for debugging
|
|
||||||
spHingeDynAB->setDbgDrawSize(btScalar(5.f));
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if ENABLE_ALL_DEMOS
|
|
||||||
{ // 6DOF connected to the world, with motor
|
|
||||||
btTransform tr;
|
|
||||||
tr.setIdentity();
|
|
||||||
tr.setOrigin(btVector3(btScalar(10.), btScalar(-15.), btScalar(0.)));
|
|
||||||
btRigidBody* pBody = localCreateRigidBody( 1.0, tr, shape);
|
|
||||||
pBody->setActivationState(DISABLE_DEACTIVATION);
|
|
||||||
btTransform frameB;
|
|
||||||
frameB.setIdentity();
|
|
||||||
btGeneric6DofConstraint* pGen6Dof = new btGeneric6DofConstraint( *pBody, frameB, false );
|
|
||||||
m_dynamicsWorld->addConstraint(pGen6Dof);
|
|
||||||
pGen6Dof->setDbgDrawSize(btScalar(5.f));
|
|
||||||
|
|
||||||
pGen6Dof->setAngularLowerLimit(btVector3(0,0,0));
|
|
||||||
pGen6Dof->setAngularUpperLimit(btVector3(0,0,0));
|
|
||||||
pGen6Dof->setLinearLowerLimit(btVector3(-10., 0, 0));
|
|
||||||
pGen6Dof->setLinearUpperLimit(btVector3(10., 0, 0));
|
|
||||||
|
|
||||||
pGen6Dof->getTranslationalLimitMotor()->m_enableMotor[0] = true;
|
|
||||||
pGen6Dof->getTranslationalLimitMotor()->m_targetVelocity[0] = 5.0f;
|
|
||||||
pGen6Dof->getTranslationalLimitMotor()->m_maxMotorForce[0] = 0.1f;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
void ConstraintDemo::exitPhysics()
|
|
||||||
{
|
|
||||||
|
|
||||||
int i;
|
|
||||||
|
|
||||||
//removed/delete constraints
|
|
||||||
for (i=m_dynamicsWorld->getNumConstraints()-1; i>=0 ;i--)
|
|
||||||
{
|
|
||||||
btTypedConstraint* constraint = m_dynamicsWorld->getConstraint(i);
|
|
||||||
m_dynamicsWorld->removeConstraint(constraint);
|
|
||||||
delete constraint;
|
|
||||||
}
|
|
||||||
m_ctc = NULL;
|
|
||||||
|
|
||||||
//remove the rigidbodies from the dynamics world and delete them
|
|
||||||
for (i=m_dynamicsWorld->getNumCollisionObjects()-1; i>=0 ;i--)
|
|
||||||
{
|
|
||||||
btCollisionObject* obj = m_dynamicsWorld->getCollisionObjectArray()[i];
|
|
||||||
btRigidBody* body = btRigidBody::upcast(obj);
|
|
||||||
if (body && body->getMotionState())
|
|
||||||
{
|
|
||||||
delete body->getMotionState();
|
|
||||||
}
|
|
||||||
m_dynamicsWorld->removeCollisionObject( obj );
|
|
||||||
delete obj;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//delete collision shapes
|
|
||||||
for (int j=0;j<m_collisionShapes.size();j++)
|
|
||||||
{
|
|
||||||
btCollisionShape* shape = m_collisionShapes[j];
|
|
||||||
delete shape;
|
|
||||||
}
|
|
||||||
|
|
||||||
m_collisionShapes.clear();
|
|
||||||
|
|
||||||
//delete dynamics world
|
|
||||||
delete m_dynamicsWorld;
|
|
||||||
|
|
||||||
//delete solver
|
|
||||||
delete m_constraintSolver;
|
|
||||||
|
|
||||||
//delete broadphase
|
|
||||||
delete m_overlappingPairCache;
|
|
||||||
|
|
||||||
//delete dispatcher
|
|
||||||
delete m_dispatcher;
|
|
||||||
|
|
||||||
delete m_collisionConfiguration;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
ConstraintDemo::~ConstraintDemo()
|
|
||||||
{
|
|
||||||
//cleanup in the reverse order of creation/initialization
|
|
||||||
|
|
||||||
exitPhysics();
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void ConstraintDemo::clientMoveAndDisplay()
|
|
||||||
{
|
|
||||||
|
|
||||||
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
|
||||||
|
|
||||||
float dt = float(getDeltaTimeMicroseconds()) * 0.000001f;
|
|
||||||
//printf("dt = %f: ",dt);
|
|
||||||
|
|
||||||
// drive cone-twist motor
|
|
||||||
m_Time += 0.03f;
|
|
||||||
if (s_bTestConeTwistMotor)
|
|
||||||
{ // this works only for obsolete constraint solver for now
|
|
||||||
// build cone target
|
|
||||||
btScalar t = 1.25f*m_Time;
|
|
||||||
btVector3 axis(0,sin(t),cos(t));
|
|
||||||
axis.normalize();
|
|
||||||
btQuaternion q1(axis, 0.75f*SIMD_PI);
|
|
||||||
|
|
||||||
// build twist target
|
|
||||||
//btQuaternion q2(0,0,0);
|
|
||||||
//btQuaternion q2(btVehictor3(1,0,0), -0.3*sin(m_Time));
|
|
||||||
btQuaternion q2(btVector3(1,0,0), -1.49f*btSin(1.5f*m_Time));
|
|
||||||
|
|
||||||
// compose cone + twist and set target
|
|
||||||
q1 = q1 * q2;
|
|
||||||
m_ctc->enableMotor(true);
|
|
||||||
m_ctc->setMotorTargetInConstraintSpace(q1);
|
|
||||||
}
|
|
||||||
|
|
||||||
{
|
|
||||||
static bool once = true;
|
|
||||||
if ( m_dynamicsWorld->getDebugDrawer() && once)
|
|
||||||
{
|
|
||||||
m_dynamicsWorld->getDebugDrawer()->setDebugMode(btIDebugDraw::DBG_DrawConstraints+btIDebugDraw::DBG_DrawConstraintLimits);
|
|
||||||
once=false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
{
|
|
||||||
//during idle mode, just run 1 simulation step maximum
|
|
||||||
int maxSimSubSteps = m_idle ? 1 : 1;
|
|
||||||
if (m_idle)
|
|
||||||
dt = 1.0f/420.f;
|
|
||||||
|
|
||||||
int numSimSteps = m_dynamicsWorld->stepSimulation(dt,maxSimSubSteps);
|
|
||||||
|
|
||||||
//optional but useful: debug drawing
|
|
||||||
m_dynamicsWorld->debugDrawWorld();
|
|
||||||
|
|
||||||
bool verbose = false;
|
|
||||||
if (verbose)
|
|
||||||
{
|
|
||||||
if (!numSimSteps)
|
|
||||||
printf("Interpolated transforms\n");
|
|
||||||
else
|
|
||||||
{
|
|
||||||
if (numSimSteps > maxSimSubSteps)
|
|
||||||
{
|
|
||||||
//detect dropping frames
|
|
||||||
printf("Dropped (%i) simulation steps out of %i\n",numSimSteps - maxSimSubSteps,numSimSteps);
|
|
||||||
} else
|
|
||||||
{
|
|
||||||
printf("Simulated (%i) steps\n",numSimSteps);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
renderme();
|
|
||||||
|
|
||||||
// drawLimit();
|
|
||||||
|
|
||||||
glFlush();
|
|
||||||
swapBuffers();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void ConstraintDemo::displayCallback(void) {
|
|
||||||
|
|
||||||
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
|
||||||
|
|
||||||
if (m_dynamicsWorld)
|
|
||||||
m_dynamicsWorld->debugDrawWorld();
|
|
||||||
|
|
||||||
// drawLimit();
|
|
||||||
|
|
||||||
renderme();
|
|
||||||
|
|
||||||
glFlush();
|
|
||||||
swapBuffers();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void ConstraintDemo::keyboardCallback(unsigned char key, int x, int y)
|
|
||||||
{
|
|
||||||
(void)x;
|
|
||||||
(void)y;
|
|
||||||
switch (key)
|
|
||||||
{
|
|
||||||
case 'O' :
|
|
||||||
{
|
|
||||||
bool offectOnOff;
|
|
||||||
if(spDoorHinge)
|
|
||||||
{
|
|
||||||
offectOnOff = spDoorHinge->getUseFrameOffset();
|
|
||||||
offectOnOff = !offectOnOff;
|
|
||||||
spDoorHinge->setUseFrameOffset(offectOnOff);
|
|
||||||
printf("DoorHinge %s frame offset\n", offectOnOff ? "uses" : "does not use");
|
|
||||||
}
|
|
||||||
if(spHingeDynAB)
|
|
||||||
{
|
|
||||||
offectOnOff = spHingeDynAB->getUseFrameOffset();
|
|
||||||
offectOnOff = !offectOnOff;
|
|
||||||
spHingeDynAB->setUseFrameOffset(offectOnOff);
|
|
||||||
printf("HingeDynAB %s frame offset\n", offectOnOff ? "uses" : "does not use");
|
|
||||||
}
|
|
||||||
if(spSlider6Dof)
|
|
||||||
{
|
|
||||||
offectOnOff = spSlider6Dof->getUseFrameOffset();
|
|
||||||
offectOnOff = !offectOnOff;
|
|
||||||
spSlider6Dof->setUseFrameOffset(offectOnOff);
|
|
||||||
printf("Slider6Dof %s frame offset\n", offectOnOff ? "uses" : "does not use");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
default :
|
|
||||||
{
|
|
||||||
DemoApplication::keyboardCallback(key, x, y);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,75 +0,0 @@
|
|||||||
/*
|
|
||||||
Bullet Continuous Collision Detection and Physics Library
|
|
||||||
Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied warranty.
|
|
||||||
In no event will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it freely,
|
|
||||||
subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
|
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
#ifndef CONSTRAINT_DEMO_H
|
|
||||||
#define CONSTRAINT_DEMO_H
|
|
||||||
|
|
||||||
#ifdef _WINDOWS
|
|
||||||
#include "Win32DemoApplication.h"
|
|
||||||
#define PlatformDemoApplication Win32DemoApplication
|
|
||||||
#else
|
|
||||||
#include "GlutDemoApplication.h"
|
|
||||||
#define PlatformDemoApplication GlutDemoApplication
|
|
||||||
#endif
|
|
||||||
|
|
||||||
///ConstraintDemo shows how to create a constraint, like Hinge or btGenericD6constraint
|
|
||||||
class ConstraintDemo : public PlatformDemoApplication
|
|
||||||
{
|
|
||||||
//keep track of variables to delete memory at the end
|
|
||||||
btAlignedObjectArray<btCollisionShape*> m_collisionShapes;
|
|
||||||
|
|
||||||
class btBroadphaseInterface* m_overlappingPairCache;
|
|
||||||
|
|
||||||
class btCollisionDispatcher* m_dispatcher;
|
|
||||||
|
|
||||||
class btConstraintSolver* m_constraintSolver;
|
|
||||||
|
|
||||||
class btDefaultCollisionConfiguration* m_collisionConfiguration;
|
|
||||||
|
|
||||||
void setupEmptyDynamicsWorld();
|
|
||||||
|
|
||||||
void clientResetScene();
|
|
||||||
|
|
||||||
|
|
||||||
public:
|
|
||||||
|
|
||||||
|
|
||||||
virtual ~ConstraintDemo();
|
|
||||||
|
|
||||||
void initPhysics();
|
|
||||||
|
|
||||||
void exitPhysics();
|
|
||||||
|
|
||||||
virtual void clientMoveAndDisplay();
|
|
||||||
|
|
||||||
virtual void displayCallback();
|
|
||||||
|
|
||||||
static DemoApplication* Create()
|
|
||||||
{
|
|
||||||
ConstraintDemo* demo = new ConstraintDemo();
|
|
||||||
demo->myinit();
|
|
||||||
demo->initPhysics();
|
|
||||||
return demo;
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual void keyboardCallback(unsigned char key, int x, int y);
|
|
||||||
|
|
||||||
// for cone-twist motor driving
|
|
||||||
float m_Time;
|
|
||||||
class btConeTwistConstraint* m_ctc;
|
|
||||||
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif //CONSTRAINT_DEMO_H
|
|
||||||
|
|
@ -1,25 +0,0 @@
|
|||||||
#ifdef _WINDOWS
|
|
||||||
/*
|
|
||||||
Bullet Continuous Collision Detection and Physics Library
|
|
||||||
Copyright (c) 2003-2009 Erwin Coumans http://bulletphysics.org
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied warranty.
|
|
||||||
In no event will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it freely,
|
|
||||||
subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
|
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "ConstraintDemo.h"
|
|
||||||
|
|
||||||
///The 'createDemo' function is called from Bullet/Demos/OpenGL/Win32AppMain.cpp to instantiate this particular demo
|
|
||||||
DemoApplication* createDemo()
|
|
||||||
{
|
|
||||||
return new ConstraintDemo();
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
|
20
extern/bullet/Demos/ConstraintDemo/main.cpp
vendored
20
extern/bullet/Demos/ConstraintDemo/main.cpp
vendored
@ -1,20 +0,0 @@
|
|||||||
#include "ConstraintDemo.h"
|
|
||||||
#include "GlutStuff.h"
|
|
||||||
#include "GLDebugDrawer.h"
|
|
||||||
|
|
||||||
#include "btBulletDynamicsCommon.h"
|
|
||||||
|
|
||||||
int main(int argc,char** argv)
|
|
||||||
{
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
ConstraintDemo* constraintDemo = new ConstraintDemo();
|
|
||||||
|
|
||||||
|
|
||||||
constraintDemo->initPhysics();
|
|
||||||
constraintDemo->setDebugMode(btIDebugDraw::DBG_DrawConstraints+btIDebugDraw::DBG_DrawConstraintLimits);
|
|
||||||
|
|
||||||
return glutmain(argc, argv,640,480,"Constraint Demo. http://www.continuousphysics.com/Bullet/phpBB2/",constraintDemo);
|
|
||||||
}
|
|
||||||
|
|
@ -1,47 +0,0 @@
|
|||||||
# This is basically the overall name of the project in Visual Studio this is the name of the Solution File
|
|
||||||
|
|
||||||
|
|
||||||
# For every executable you have with a main method you should have an add_executable line below.
|
|
||||||
# For every add executable line you should list every .cpp and .h file you have associated with that executable.
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# You shouldn't have to modify anything below this line
|
|
||||||
########################################################
|
|
||||||
|
|
||||||
|
|
||||||
INCLUDE_DIRECTORIES(
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/src ${BULLET_PHYSICS_SOURCE_DIR}/Demos/OpenGL
|
|
||||||
)
|
|
||||||
|
|
||||||
LINK_LIBRARIES(
|
|
||||||
OpenGLSupport BulletDynamics BulletCollision LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY}
|
|
||||||
)
|
|
||||||
|
|
||||||
ADD_EXECUTABLE(AppContinuousConvexCollisionDemo
|
|
||||||
ContinuousConvexCollisionDemo.cpp
|
|
||||||
)
|
|
||||||
|
|
||||||
IF (WIN32)
|
|
||||||
IF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES)
|
|
||||||
IF (CMAKE_CL_64)
|
|
||||||
ADD_CUSTOM_COMMAND(
|
|
||||||
TARGET AppContinuousConvexCollisionDemo
|
|
||||||
POST_BUILD
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/glut64.dll ${CMAKE_CURRENT_BINARY_DIR}
|
|
||||||
)
|
|
||||||
ELSE(CMAKE_CL_64)
|
|
||||||
ADD_CUSTOM_COMMAND(
|
|
||||||
TARGET AppContinuousConvexCollisionDemo
|
|
||||||
POST_BUILD
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/GLUT32.DLL ${CMAKE_CURRENT_BINARY_DIR}
|
|
||||||
)
|
|
||||||
ENDIF(CMAKE_CL_64)
|
|
||||||
ENDIF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES)
|
|
||||||
ENDIF(WIN32)
|
|
||||||
|
|
||||||
IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES)
|
|
||||||
SET_TARGET_PROPERTIES(AppContinuousConvexCollisionDemo PROPERTIES DEBUG_POSTFIX "_Debug")
|
|
||||||
SET_TARGET_PROPERTIES(AppContinuousConvexCollisionDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel")
|
|
||||||
SET_TARGET_PROPERTIES(AppContinuousConvexCollisionDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo")
|
|
||||||
ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES)
|
|
@ -1,36 +0,0 @@
|
|||||||
/*
|
|
||||||
Bullet Continuous Collision Detection and Physics Library
|
|
||||||
Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied warranty.
|
|
||||||
In no event will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it freely,
|
|
||||||
subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
|
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
#ifndef CONTINUOUS_CONVEX_COLLISION_DEMO_H
|
|
||||||
#define CONTINUOUS_CONVEX_COLLISION_DEMO_H
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
///ContinuousConvexCollisionDemo shows the working of the continuous collision detection, including linear and angular motion
|
|
||||||
#include "GlutDemoApplication.h"
|
|
||||||
class btContinuousConvexCollisionDemo : public GlutDemoApplication
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
|
|
||||||
void initPhysics();
|
|
||||||
|
|
||||||
virtual void clientMoveAndDisplay();
|
|
||||||
|
|
||||||
virtual void displayCallback();
|
|
||||||
|
|
||||||
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif //CONTINUOUS_CONVEX_COLLISION_DEMO_H
|
|
||||||
|
|
@ -1,287 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (c) 2005 Erwin Coumans http://continuousphysics.com/Bullet/
|
|
||||||
*
|
|
||||||
* Permission to use, copy, modify, distribute and sell this software
|
|
||||||
* and its documentation for any purpose is hereby granted without fee,
|
|
||||||
* provided that the above copyright notice appear in all copies.
|
|
||||||
* Erwin Coumans makes no representations about the suitability
|
|
||||||
* of this software for any purpose.
|
|
||||||
* It is provided "as is" without express or implied warranty.
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
Continuous Convex Collision Demo demonstrates an efficient continuous collision detection algorithm.
|
|
||||||
Both linear and angular velocities are supported. Convex Objects are sampled using Supporting Vertex.
|
|
||||||
Motion using Exponential Map.
|
|
||||||
Future ideas: Comparison with Screwing Motion.
|
|
||||||
Also comparision with Algebraic CCD and Interval Arithmetic methods (Stephane Redon)
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
///This low level demo need internal access, and intentionally doesn't include the btBulletCollisionCommon.h headerfile
|
|
||||||
#include "LinearMath/btQuaternion.h"
|
|
||||||
#include "LinearMath/btTransform.h"
|
|
||||||
#include "BulletCollision/NarrowPhaseCollision/btVoronoiSimplexSolver.h"
|
|
||||||
#include "BulletCollision/CollisionShapes/btBoxShape.h"
|
|
||||||
#include "BulletCollision/CollisionShapes/btMinkowskiSumShape.h"
|
|
||||||
|
|
||||||
#include "BulletCollision/NarrowPhaseCollision/btGjkPairDetector.h"
|
|
||||||
#include "BulletCollision/NarrowPhaseCollision/btGjkConvexCast.h"
|
|
||||||
#include "BulletCollision/NarrowPhaseCollision/btSubSimplexConvexCast.h"
|
|
||||||
#include "BulletCollision/NarrowPhaseCollision/btContinuousConvexCollision.h"
|
|
||||||
|
|
||||||
#include "LinearMath/btTransformUtil.h"
|
|
||||||
#include "DebugCastResult.h"
|
|
||||||
|
|
||||||
#include "BulletCollision/CollisionShapes/btSphereShape.h"
|
|
||||||
|
|
||||||
#include "BulletCollision/CollisionShapes/btTetrahedronShape.h"
|
|
||||||
|
|
||||||
#include "BulletCollision/NarrowPhaseCollision/btVoronoiSimplexSolver.h"
|
|
||||||
#include "BulletCollision/NarrowPhaseCollision/btConvexPenetrationDepthSolver.h"
|
|
||||||
|
|
||||||
#include "GL_ShapeDrawer.h"
|
|
||||||
#include "ContinuousConvexCollision.h"
|
|
||||||
#include "GlutStuff.h"
|
|
||||||
|
|
||||||
|
|
||||||
float yaw=0.f,pitch=0.f,roll=0.f;
|
|
||||||
const int maxNumObjects = 4;
|
|
||||||
const int numObjects = 2;
|
|
||||||
|
|
||||||
btVector3 angVels[numObjects];
|
|
||||||
btVector3 linVels[numObjects];
|
|
||||||
|
|
||||||
btPolyhedralConvexShape* shapePtr[maxNumObjects];
|
|
||||||
|
|
||||||
|
|
||||||
btTransform fromTrans[maxNumObjects];
|
|
||||||
btTransform toTrans[maxNumObjects];
|
|
||||||
|
|
||||||
|
|
||||||
int screenWidth = 640;
|
|
||||||
int screenHeight = 480;
|
|
||||||
|
|
||||||
|
|
||||||
int main(int argc,char** argv)
|
|
||||||
{
|
|
||||||
btContinuousConvexCollisionDemo* ccdDemo = new btContinuousConvexCollisionDemo();
|
|
||||||
|
|
||||||
ccdDemo->setCameraDistance(40.f);
|
|
||||||
|
|
||||||
ccdDemo->initPhysics();
|
|
||||||
|
|
||||||
return glutmain(argc, argv,screenWidth,screenHeight,"Continuous Convex Collision Demo",ccdDemo);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void btContinuousConvexCollisionDemo::initPhysics()
|
|
||||||
{
|
|
||||||
fromTrans[0].setOrigin(btVector3(0,10,20));
|
|
||||||
toTrans[0].setOrigin(btVector3(0,10,-20));
|
|
||||||
fromTrans[1].setOrigin(btVector3(-2,7,0));
|
|
||||||
toTrans[1].setOrigin(btVector3(-2,10,0));
|
|
||||||
|
|
||||||
btMatrix3x3 identBasis;
|
|
||||||
identBasis.setIdentity();
|
|
||||||
|
|
||||||
btMatrix3x3 basisA;
|
|
||||||
basisA.setIdentity();
|
|
||||||
basisA.setEulerZYX(0.f,-SIMD_HALF_PI,0.f);
|
|
||||||
|
|
||||||
fromTrans[0].setBasis(identBasis);
|
|
||||||
toTrans[0].setBasis(basisA);
|
|
||||||
|
|
||||||
fromTrans[1].setBasis(identBasis);
|
|
||||||
toTrans[1].setBasis(identBasis);
|
|
||||||
|
|
||||||
toTrans[1].setBasis(identBasis);
|
|
||||||
btVector3 boxHalfExtentsA(10,1,1);
|
|
||||||
btVector3 boxHalfExtentsB(1.1f,1.1f,1.1f);
|
|
||||||
btBoxShape* boxA = new btBoxShape(boxHalfExtentsA);
|
|
||||||
// btBU_Simplex1to4* boxA = new btBU_Simplex1to4(btVector3(-2,0,-2),btVector3(2,0,-2),btVector3(0,0,2),btVector3(0,2,0));
|
|
||||||
// btBU_Simplex1to4* boxA = new btBU_Simplex1to4(btVector3(-12,0,0),btVector3(12,0,0));
|
|
||||||
|
|
||||||
|
|
||||||
btBoxShape* boxB = new btBoxShape(boxHalfExtentsB);
|
|
||||||
|
|
||||||
shapePtr[0] = boxA;
|
|
||||||
shapePtr[1] = boxB;
|
|
||||||
|
|
||||||
shapePtr[0]->setMargin(0.01f);
|
|
||||||
shapePtr[1]->setMargin(0.01f);
|
|
||||||
|
|
||||||
for (int i=0;i<numObjects;i++)
|
|
||||||
{
|
|
||||||
btTransformUtil::calculateVelocity(fromTrans[i],toTrans[i],1.f,linVels[i],angVels[i]);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
//to be implemented by the demo
|
|
||||||
|
|
||||||
void btContinuousConvexCollisionDemo::clientMoveAndDisplay()
|
|
||||||
{
|
|
||||||
displayCallback();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
static btVoronoiSimplexSolver sVoronoiSimplexSolver;
|
|
||||||
|
|
||||||
btSimplexSolverInterface& gGjkSimplexSolver = sVoronoiSimplexSolver;
|
|
||||||
|
|
||||||
bool drawLine= false;
|
|
||||||
|
|
||||||
int minlines = 0;
|
|
||||||
|
|
||||||
int maxlines = 512;
|
|
||||||
|
|
||||||
|
|
||||||
void btContinuousConvexCollisionDemo::displayCallback(void) {
|
|
||||||
|
|
||||||
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
|
||||||
glDisable(GL_LIGHTING);
|
|
||||||
|
|
||||||
//GL_ShapeDrawer::drawCoordSystem();
|
|
||||||
|
|
||||||
btScalar m[16];
|
|
||||||
int i;
|
|
||||||
|
|
||||||
btVector3 worldBoundsMin(-1000,-1000,-1000);
|
|
||||||
btVector3 worldBoundsMax(1000,1000,1000);
|
|
||||||
|
|
||||||
|
|
||||||
/*for (i=0;i<numObjects;i++)
|
|
||||||
{
|
|
||||||
fromTrans[i].getOpenGLMatrix( m );
|
|
||||||
m_shapeDrawer.drawOpenGL(m,shapePtr[i]);
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
if (getDebugMode()==btIDebugDraw::DBG_DrawAabb)
|
|
||||||
{
|
|
||||||
i=0;//for (i=1;i<numObjects;i++)
|
|
||||||
{
|
|
||||||
//for each object, subdivide the from/to transform in 10 equal steps
|
|
||||||
|
|
||||||
int numSubSteps = 10;
|
|
||||||
for (int s=0;s<10;s++)
|
|
||||||
{
|
|
||||||
btScalar subStep = s * 1.f/(float)numSubSteps;
|
|
||||||
btTransform interpolatedTrans;
|
|
||||||
|
|
||||||
btTransformUtil::integrateTransform(fromTrans[i],linVels[i],angVels[i],subStep,interpolatedTrans);
|
|
||||||
|
|
||||||
//fromTrans[i].getOpenGLMatrix(m);
|
|
||||||
//m_shapeDrawer.drawOpenGL(m,shapePtr[i]);
|
|
||||||
|
|
||||||
//toTrans[i].getOpenGLMatrix(m);
|
|
||||||
//m_shapeDrawer.drawOpenGL(m,shapePtr[i]);
|
|
||||||
|
|
||||||
interpolatedTrans.getOpenGLMatrix( m );
|
|
||||||
m_shapeDrawer->drawOpenGL(m,shapePtr[i],btVector3(1,0,1),getDebugMode(),worldBoundsMin,worldBoundsMax);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
btMatrix3x3 mat;
|
|
||||||
mat.setEulerZYX(yaw,pitch,roll);
|
|
||||||
btQuaternion orn;
|
|
||||||
mat.getRotation(orn);
|
|
||||||
orn.setEuler(yaw,pitch,roll);
|
|
||||||
fromTrans[1].setRotation(orn);
|
|
||||||
toTrans[1].setRotation(orn);
|
|
||||||
|
|
||||||
|
|
||||||
if (m_stepping || m_singleStep)
|
|
||||||
{
|
|
||||||
m_singleStep = false;
|
|
||||||
pitch += 0.005f;
|
|
||||||
// yaw += 0.01f;
|
|
||||||
}
|
|
||||||
// btVector3 fromA(-25,11,0);
|
|
||||||
// btVector3 toA(-15,11,0);
|
|
||||||
|
|
||||||
// btQuaternion ornFromA(0.f,0.f,0.f,1.f);
|
|
||||||
// btQuaternion ornToA(0.f,0.f,0.f,1.f);
|
|
||||||
|
|
||||||
// btTransform rayFromWorld(ornFromA,fromA);
|
|
||||||
// btTransform rayToWorld(ornToA,toA);
|
|
||||||
|
|
||||||
btTransform rayFromWorld = fromTrans[0];
|
|
||||||
btTransform rayToWorld = toTrans[0];
|
|
||||||
|
|
||||||
|
|
||||||
if (drawLine)
|
|
||||||
{
|
|
||||||
glBegin(GL_LINES);
|
|
||||||
glColor3f(0, 0, 1);
|
|
||||||
glVertex3d(rayFromWorld.getOrigin().x(), rayFromWorld.getOrigin().y(),rayFromWorld.getOrigin().z());
|
|
||||||
glVertex3d(rayToWorld.getOrigin().x(),rayToWorld.getOrigin().y(),rayToWorld.getOrigin().z());
|
|
||||||
glEnd();
|
|
||||||
}
|
|
||||||
|
|
||||||
//now perform a raycast on the shapes, in local (shape) space
|
|
||||||
gGjkSimplexSolver.reset();
|
|
||||||
|
|
||||||
//choose one of the following lines
|
|
||||||
|
|
||||||
|
|
||||||
for (i=0;i<numObjects;i++)
|
|
||||||
{
|
|
||||||
fromTrans[i].getOpenGLMatrix(m);
|
|
||||||
m_shapeDrawer->drawOpenGL(m,shapePtr[i],btVector3(1,1,1),getDebugMode(),worldBoundsMin,worldBoundsMax);
|
|
||||||
}
|
|
||||||
|
|
||||||
btDebugCastResult rayResult1(fromTrans[0],shapePtr[0],linVels[0],angVels[0],m_shapeDrawer);
|
|
||||||
|
|
||||||
|
|
||||||
for (i=1;i<numObjects;i++)
|
|
||||||
{
|
|
||||||
btConvexCast::CastResult rayResult2;
|
|
||||||
btConvexCast::CastResult* rayResultPtr;
|
|
||||||
if (btIDebugDraw::DBG_DrawAabb)
|
|
||||||
{
|
|
||||||
rayResultPtr = &rayResult1;
|
|
||||||
} else
|
|
||||||
{
|
|
||||||
rayResultPtr = &rayResult2;
|
|
||||||
}
|
|
||||||
|
|
||||||
//GjkConvexCast convexCaster(&gGjkSimplexSolver);
|
|
||||||
//SubsimplexConvexCast convexCaster(&gGjkSimplexSolver);
|
|
||||||
|
|
||||||
//optional
|
|
||||||
btConvexPenetrationDepthSolver* penetrationDepthSolver = 0;
|
|
||||||
btContinuousConvexCollision convexCaster(shapePtr[0],shapePtr[i],&gGjkSimplexSolver,penetrationDepthSolver );
|
|
||||||
|
|
||||||
gGjkSimplexSolver.reset();
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if (convexCaster.calcTimeOfImpact(fromTrans[0],toTrans[0],fromTrans[i] ,toTrans[i] ,*rayResultPtr))
|
|
||||||
{
|
|
||||||
|
|
||||||
glDisable(GL_DEPTH_TEST);
|
|
||||||
|
|
||||||
btTransform hitTrans;
|
|
||||||
btTransformUtil::integrateTransform(fromTrans[0],linVels[0],angVels[0],rayResultPtr->m_fraction,hitTrans);
|
|
||||||
|
|
||||||
hitTrans.getOpenGLMatrix(m);
|
|
||||||
m_shapeDrawer->drawOpenGL(m,shapePtr[0],btVector3(0,1,0),getDebugMode(),worldBoundsMin,worldBoundsMax);
|
|
||||||
|
|
||||||
btTransformUtil::integrateTransform(fromTrans[i],linVels[i],angVels[i],rayResultPtr->m_fraction,hitTrans);
|
|
||||||
|
|
||||||
hitTrans.getOpenGLMatrix(m);
|
|
||||||
m_shapeDrawer->drawOpenGL(m,shapePtr[i],btVector3(0,1,1),getDebugMode(),worldBoundsMin,worldBoundsMax);
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
swapBuffers();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
@ -1,83 +0,0 @@
|
|||||||
# This is basically the overall name of the project in Visual Studio this is the name of the Solution File
|
|
||||||
|
|
||||||
|
|
||||||
# For every executable you have with a main method you should have an add_executable line below.
|
|
||||||
# For every add executable line you should list every .cpp and .h file you have associated with that executable.
|
|
||||||
|
|
||||||
|
|
||||||
# This is the variable for Windows. I use this to define the root of my directory structure.
|
|
||||||
SET(GLUT_ROOT ${BULLET_PHYSICS_SOURCE_DIR}/Glut)
|
|
||||||
|
|
||||||
# You shouldn't have to modify anything below this line
|
|
||||||
########################################################
|
|
||||||
|
|
||||||
INCLUDE_DIRECTORIES(
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/src
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/Demos/OpenGL
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/Extras/HACD
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/Extras/ConvexDecomposition
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/Extras/Serialize/BulletFileLoader
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/Extras/Serialize/BulletWorldImporter
|
|
||||||
)
|
|
||||||
|
|
||||||
IF (USE_GLUT)
|
|
||||||
|
|
||||||
LINK_LIBRARIES(
|
|
||||||
OpenGLSupport BulletWorldImporter BulletDynamics BulletCollision LinearMath BulletFileLoader HACD ConvexDecomposition ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY}
|
|
||||||
)
|
|
||||||
|
|
||||||
ADD_EXECUTABLE(AppConvexDecompositionDemo
|
|
||||||
main.cpp
|
|
||||||
ConvexDecompositionDemo.cpp
|
|
||||||
ConvexDecompositionDemo.h
|
|
||||||
)
|
|
||||||
IF (WIN32)
|
|
||||||
IF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES)
|
|
||||||
IF (CMAKE_CL_64)
|
|
||||||
ADD_CUSTOM_COMMAND(
|
|
||||||
TARGET AppConvexDecompositionDemo
|
|
||||||
POST_BUILD
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/glut64.dll ${CMAKE_CURRENT_BINARY_DIR}
|
|
||||||
)
|
|
||||||
ELSE(CMAKE_CL_64)
|
|
||||||
ADD_CUSTOM_COMMAND(
|
|
||||||
TARGET AppConvexDecompositionDemo
|
|
||||||
POST_BUILD
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/GLUT32.DLL ${CMAKE_CURRENT_BINARY_DIR}
|
|
||||||
)
|
|
||||||
ENDIF(CMAKE_CL_64)
|
|
||||||
ENDIF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES)
|
|
||||||
ENDIF(WIN32)
|
|
||||||
ELSE (USE_GLUT)
|
|
||||||
|
|
||||||
LINK_LIBRARIES(
|
|
||||||
OpenGLSupport BulletWorldImporter BulletDynamics BulletCollision LinearMath BulletFileLoader HACD ConvexDecomposition ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY}
|
|
||||||
)
|
|
||||||
|
|
||||||
ADD_EXECUTABLE(AppConvexDecompositionDemo
|
|
||||||
WIN32
|
|
||||||
../OpenGL/Win32AppMain.cpp
|
|
||||||
ConvexDecompositionDemo.cpp
|
|
||||||
ConvexDecompositionDemo.h
|
|
||||||
Win32ConvexDecompositionDemo.cpp
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/build/bullet.rc
|
|
||||||
)
|
|
||||||
|
|
||||||
ENDIF (USE_GLUT)
|
|
||||||
|
|
||||||
IF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES)
|
|
||||||
ADD_CUSTOM_COMMAND(
|
|
||||||
TARGET AppConvexDecompositionDemo
|
|
||||||
POST_BUILD
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/Demos/SerializeDemo/testFile.bullet ${CMAKE_CURRENT_BINARY_DIR}/testFile.bullet
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/file.obj ${CMAKE_CURRENT_BINARY_DIR}
|
|
||||||
)
|
|
||||||
ENDIF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES)
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES)
|
|
||||||
SET_TARGET_PROPERTIES(AppConvexDecompositionDemo PROPERTIES DEBUG_POSTFIX "_Debug")
|
|
||||||
SET_TARGET_PROPERTIES(AppConvexDecompositionDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel")
|
|
||||||
SET_TARGET_PROPERTIES(AppConvexDecompositionDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo")
|
|
||||||
ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES)
|
|
@ -1,779 +0,0 @@
|
|||||||
/*
|
|
||||||
Bullet Continuous Collision Detection and Physics Library
|
|
||||||
Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied warranty.
|
|
||||||
In no event will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it freely,
|
|
||||||
subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
|
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "hacdCircularList.h"
|
|
||||||
#include "hacdVector.h"
|
|
||||||
#include "hacdICHull.h"
|
|
||||||
#include "hacdGraph.h"
|
|
||||||
#include "hacdHACD.h"
|
|
||||||
|
|
||||||
#include "cd_wavefront.h"
|
|
||||||
#include "ConvexBuilder.h"
|
|
||||||
|
|
||||||
#include "btBulletDynamicsCommon.h"
|
|
||||||
|
|
||||||
#include "LinearMath/btQuickprof.h"
|
|
||||||
#include "LinearMath/btIDebugDraw.h"
|
|
||||||
#include "LinearMath/btGeometryUtil.h"
|
|
||||||
#include "BulletCollision/CollisionShapes/btShapeHull.h"
|
|
||||||
#include "GLDebugDrawer.h"
|
|
||||||
GLDebugDrawer gDebugDrawer;
|
|
||||||
//#define TEST_SERIALIZATION
|
|
||||||
//#define NO_OBJ_TO_BULLET
|
|
||||||
|
|
||||||
#ifdef TEST_SERIALIZATION
|
|
||||||
#include "LinearMath/btSerializer.h"
|
|
||||||
#include "btBulletFile.h"
|
|
||||||
#include "btBulletWorldImporter.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
//#define USE_PARALLEL_DISPATCHER 1
|
|
||||||
#ifdef USE_PARALLEL_DISPATCHER
|
|
||||||
#include "../../Extras/BulletMultiThreaded/SpuGatheringCollisionDispatcher.h"
|
|
||||||
#include "../../Extras/BulletMultiThreaded/Win32ThreadSupport.h"
|
|
||||||
#include "../../Extras/BulletMultiThreaded/SpuNarrowPhaseCollisionTask/SpuGatheringCollisionTask.h"
|
|
||||||
#endif//USE_PARALLEL_DISPATCHER
|
|
||||||
|
|
||||||
#include "BulletCollision/CollisionDispatch/btCompoundCollisionAlgorithm.h"//for the callback
|
|
||||||
|
|
||||||
bool MyCompoundChildShapeCallback(const btCollisionShape* pShape0, const btCollisionShape* pShape1)
|
|
||||||
{
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
#include "GLDebugFont.h"
|
|
||||||
#include <stdio.h> //printf debugging
|
|
||||||
|
|
||||||
|
|
||||||
#include "ConvexDecompositionDemo.h"
|
|
||||||
#include "GL_ShapeDrawer.h"
|
|
||||||
|
|
||||||
#include "GlutStuff.h"
|
|
||||||
|
|
||||||
|
|
||||||
btVector3 centroid=btVector3(0,0,0);
|
|
||||||
btVector3 convexDecompositionObjectOffset(10,0,0);
|
|
||||||
|
|
||||||
#define CUBE_HALF_EXTENTS 4
|
|
||||||
|
|
||||||
|
|
||||||
////////////////////////////////////
|
|
||||||
|
|
||||||
unsigned int tcount = 0;
|
|
||||||
|
|
||||||
//sEnableSAT creates the data structures required for performing SAT tests between convex polyhedra, as alternative to GJK
|
|
||||||
bool sEnableSAT = false;
|
|
||||||
|
|
||||||
void ConvexDecompositionDemo::initPhysics()
|
|
||||||
{
|
|
||||||
initPhysics("file.obj");
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
///MyContactCallback is just an example to show how to get access to the child shape that collided
|
|
||||||
bool MyContactCallback (
|
|
||||||
btManifoldPoint& cp,
|
|
||||||
const btCollisionObjectWrapper* colObj0Wrap,
|
|
||||||
int partId0,
|
|
||||||
int index0,
|
|
||||||
const btCollisionObjectWrapper* colObj1Wrap,
|
|
||||||
int partId1,
|
|
||||||
int index1)
|
|
||||||
{
|
|
||||||
|
|
||||||
if (colObj0Wrap->getCollisionObject()->getCollisionShape()->getShapeType()==COMPOUND_SHAPE_PROXYTYPE)
|
|
||||||
{
|
|
||||||
btCompoundShape* compound = (btCompoundShape*)colObj0Wrap->getCollisionObject()->getCollisionShape();
|
|
||||||
btCollisionShape* childShape;
|
|
||||||
childShape = compound->getChildShape(index0);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (colObj1Wrap->getCollisionObject()->getCollisionShape()->getShapeType()==COMPOUND_SHAPE_PROXYTYPE)
|
|
||||||
{
|
|
||||||
btCompoundShape* compound = (btCompoundShape*)colObj1Wrap->getCollisionObject()->getCollisionShape();
|
|
||||||
btCollisionShape* childShape;
|
|
||||||
childShape = compound->getChildShape(index1);
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void ConvexDecompositionDemo::setupEmptyDynamicsWorld()
|
|
||||||
{
|
|
||||||
m_collisionConfiguration = new btDefaultCollisionConfiguration();
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef USE_PARALLEL_DISPATCHER
|
|
||||||
#ifdef USE_WIN32_THREADING
|
|
||||||
|
|
||||||
int maxNumOutstandingTasks = 4;//number of maximum outstanding tasks
|
|
||||||
Win32ThreadSupport* threadSupport = new Win32ThreadSupport(Win32ThreadSupport::Win32ThreadConstructionInfo(
|
|
||||||
"collision",
|
|
||||||
processCollisionTask,
|
|
||||||
createCollisionLocalStoreMemory,
|
|
||||||
maxNumOutstandingTasks));
|
|
||||||
#else
|
|
||||||
///@todo other platform threading
|
|
||||||
///Playstation 3 SPU (SPURS) version is available through PS3 Devnet
|
|
||||||
///Libspe2 SPU support will be available soon
|
|
||||||
///pthreads version
|
|
||||||
///you can hook it up to your custom task scheduler by deriving from btThreadSupportInterface
|
|
||||||
#endif
|
|
||||||
|
|
||||||
m_dispatcher = new SpuGatheringCollisionDispatcher(threadSupport,maxNumOutstandingTasks,m_collisionConfiguration);
|
|
||||||
#else
|
|
||||||
m_dispatcher = new btCollisionDispatcher(m_collisionConfiguration);
|
|
||||||
#endif//USE_PARALLEL_DISPATCHER
|
|
||||||
|
|
||||||
gCompoundChildShapePairCallback = MyCompoundChildShapeCallback;
|
|
||||||
|
|
||||||
convexDecompositionObjectOffset.setValue(10,0,0);
|
|
||||||
|
|
||||||
btVector3 worldAabbMin(-10000,-10000,-10000);
|
|
||||||
btVector3 worldAabbMax(10000,10000,10000);
|
|
||||||
|
|
||||||
m_broadphase = new btAxisSweep3(worldAabbMin,worldAabbMax);
|
|
||||||
//m_broadphase = new btSimpleBroadphase();
|
|
||||||
|
|
||||||
m_solver = new btSequentialImpulseConstraintSolver();
|
|
||||||
m_dynamicsWorld = new btDiscreteDynamicsWorld(m_dispatcher,m_broadphase,m_solver,m_collisionConfiguration);
|
|
||||||
|
|
||||||
#ifdef USE_PARALLEL_DISPATCHER
|
|
||||||
m_dynamicsWorld->getDispatchInfo().m_enableSPU = true;
|
|
||||||
#endif //USE_PARALLEL_DISPATCHER
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
void ConvexDecompositionDemo::initPhysics(const char* filename)
|
|
||||||
{
|
|
||||||
|
|
||||||
gContactAddedCallback = &MyContactCallback;
|
|
||||||
|
|
||||||
setupEmptyDynamicsWorld();
|
|
||||||
|
|
||||||
getDynamicsWorld()->setDebugDrawer(&gDebugDrawer);
|
|
||||||
|
|
||||||
setTexturing(true);
|
|
||||||
setShadows(true);
|
|
||||||
|
|
||||||
setCameraDistance(26.f);
|
|
||||||
|
|
||||||
|
|
||||||
#ifndef NO_OBJ_TO_BULLET
|
|
||||||
|
|
||||||
ConvexDecomposition::WavefrontObj wo;
|
|
||||||
|
|
||||||
tcount = wo.loadObj(filename);
|
|
||||||
|
|
||||||
if (!tcount)
|
|
||||||
{
|
|
||||||
//when running this app from visual studio, the default starting folder is different, so make a second attempt...
|
|
||||||
tcount = wo.loadObj("../../file.obj");
|
|
||||||
}
|
|
||||||
if (!tcount)
|
|
||||||
{
|
|
||||||
//cmake generated msvc files need 4 levels deep back... so make a 3rd attempt...
|
|
||||||
tcount = wo.loadObj("../../../../file.obj");
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
btTransform startTransform;
|
|
||||||
startTransform.setIdentity();
|
|
||||||
startTransform.setOrigin(btVector3(0,-4.5,0));
|
|
||||||
|
|
||||||
btCollisionShape* boxShape = new btBoxShape(btVector3(30,2,30));
|
|
||||||
m_collisionShapes.push_back(boxShape);
|
|
||||||
localCreateRigidBody(0.f,startTransform,boxShape);
|
|
||||||
|
|
||||||
class MyConvexDecomposition : public ConvexDecomposition::ConvexDecompInterface
|
|
||||||
{
|
|
||||||
ConvexDecompositionDemo* m_convexDemo;
|
|
||||||
|
|
||||||
public:
|
|
||||||
|
|
||||||
btAlignedObjectArray<btConvexHullShape*> m_convexShapes;
|
|
||||||
btAlignedObjectArray<btVector3> m_convexCentroids;
|
|
||||||
|
|
||||||
MyConvexDecomposition (FILE* outputFile,ConvexDecompositionDemo* demo)
|
|
||||||
:m_convexDemo(demo),
|
|
||||||
mBaseCount(0),
|
|
||||||
mHullCount(0),
|
|
||||||
mOutputFile(outputFile)
|
|
||||||
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual void ConvexDecompResult(ConvexDecomposition::ConvexResult &result)
|
|
||||||
{
|
|
||||||
|
|
||||||
btTriangleMesh* trimesh = new btTriangleMesh();
|
|
||||||
m_convexDemo->m_trimeshes.push_back(trimesh);
|
|
||||||
|
|
||||||
btVector3 localScaling(6.f,6.f,6.f);
|
|
||||||
|
|
||||||
//export data to .obj
|
|
||||||
printf("ConvexResult. ");
|
|
||||||
if (mOutputFile)
|
|
||||||
{
|
|
||||||
fprintf(mOutputFile,"## Hull Piece %d with %d vertices and %d triangles.\r\n", mHullCount, result.mHullVcount, result.mHullTcount );
|
|
||||||
|
|
||||||
fprintf(mOutputFile,"usemtl Material%i\r\n",mBaseCount);
|
|
||||||
fprintf(mOutputFile,"o Object%i\r\n",mBaseCount);
|
|
||||||
|
|
||||||
for (unsigned int i=0; i<result.mHullVcount; i++)
|
|
||||||
{
|
|
||||||
const float *p = &result.mHullVertices[i*3];
|
|
||||||
fprintf(mOutputFile,"v %0.9f %0.9f %0.9f\r\n", p[0], p[1], p[2] );
|
|
||||||
}
|
|
||||||
|
|
||||||
//calc centroid, to shift vertices around center of mass
|
|
||||||
centroid.setValue(0,0,0);
|
|
||||||
|
|
||||||
btAlignedObjectArray<btVector3> vertices;
|
|
||||||
if ( 1 )
|
|
||||||
{
|
|
||||||
//const unsigned int *src = result.mHullIndices;
|
|
||||||
for (unsigned int i=0; i<result.mHullVcount; i++)
|
|
||||||
{
|
|
||||||
btVector3 vertex(result.mHullVertices[i*3],result.mHullVertices[i*3+1],result.mHullVertices[i*3+2]);
|
|
||||||
vertex *= localScaling;
|
|
||||||
centroid += vertex;
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
centroid *= 1.f/(float(result.mHullVcount) );
|
|
||||||
|
|
||||||
if ( 1 )
|
|
||||||
{
|
|
||||||
//const unsigned int *src = result.mHullIndices;
|
|
||||||
for (unsigned int i=0; i<result.mHullVcount; i++)
|
|
||||||
{
|
|
||||||
btVector3 vertex(result.mHullVertices[i*3],result.mHullVertices[i*3+1],result.mHullVertices[i*3+2]);
|
|
||||||
vertex *= localScaling;
|
|
||||||
vertex -= centroid ;
|
|
||||||
vertices.push_back(vertex);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if ( 1 )
|
|
||||||
{
|
|
||||||
const unsigned int *src = result.mHullIndices;
|
|
||||||
for (unsigned int i=0; i<result.mHullTcount; i++)
|
|
||||||
{
|
|
||||||
unsigned int index0 = *src++;
|
|
||||||
unsigned int index1 = *src++;
|
|
||||||
unsigned int index2 = *src++;
|
|
||||||
|
|
||||||
|
|
||||||
btVector3 vertex0(result.mHullVertices[index0*3], result.mHullVertices[index0*3+1],result.mHullVertices[index0*3+2]);
|
|
||||||
btVector3 vertex1(result.mHullVertices[index1*3], result.mHullVertices[index1*3+1],result.mHullVertices[index1*3+2]);
|
|
||||||
btVector3 vertex2(result.mHullVertices[index2*3], result.mHullVertices[index2*3+1],result.mHullVertices[index2*3+2]);
|
|
||||||
vertex0 *= localScaling;
|
|
||||||
vertex1 *= localScaling;
|
|
||||||
vertex2 *= localScaling;
|
|
||||||
|
|
||||||
vertex0 -= centroid;
|
|
||||||
vertex1 -= centroid;
|
|
||||||
vertex2 -= centroid;
|
|
||||||
|
|
||||||
|
|
||||||
trimesh->addTriangle(vertex0,vertex1,vertex2);
|
|
||||||
|
|
||||||
index0+=mBaseCount;
|
|
||||||
index1+=mBaseCount;
|
|
||||||
index2+=mBaseCount;
|
|
||||||
|
|
||||||
fprintf(mOutputFile,"f %d %d %d\r\n", index0+1, index1+1, index2+1 );
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// float mass = 1.f;
|
|
||||||
|
|
||||||
|
|
||||||
//this is a tools issue: due to collision margin, convex objects overlap, compensate for it here:
|
|
||||||
//#define SHRINK_OBJECT_INWARDS 1
|
|
||||||
#ifdef SHRINK_OBJECT_INWARDS
|
|
||||||
|
|
||||||
float collisionMargin = 0.01f;
|
|
||||||
|
|
||||||
btAlignedObjectArray<btVector3> planeEquations;
|
|
||||||
btGeometryUtil::getPlaneEquationsFromVertices(vertices,planeEquations);
|
|
||||||
|
|
||||||
btAlignedObjectArray<btVector3> shiftedPlaneEquations;
|
|
||||||
for (int p=0;p<planeEquations.size();p++)
|
|
||||||
{
|
|
||||||
btVector3 plane = planeEquations[p];
|
|
||||||
plane[3] += collisionMargin;
|
|
||||||
shiftedPlaneEquations.push_back(plane);
|
|
||||||
}
|
|
||||||
btAlignedObjectArray<btVector3> shiftedVertices;
|
|
||||||
btGeometryUtil::getVerticesFromPlaneEquations(shiftedPlaneEquations,shiftedVertices);
|
|
||||||
|
|
||||||
|
|
||||||
btConvexHullShape* convexShape = new btConvexHullShape(&(shiftedVertices[0].getX()),shiftedVertices.size());
|
|
||||||
|
|
||||||
#else //SHRINK_OBJECT_INWARDS
|
|
||||||
|
|
||||||
btConvexHullShape* convexShape = new btConvexHullShape(&(vertices[0].getX()),vertices.size());
|
|
||||||
#endif
|
|
||||||
if (sEnableSAT)
|
|
||||||
convexShape->initializePolyhedralFeatures();
|
|
||||||
convexShape->setMargin(0.01f);
|
|
||||||
m_convexShapes.push_back(convexShape);
|
|
||||||
m_convexCentroids.push_back(centroid);
|
|
||||||
m_convexDemo->m_collisionShapes.push_back(convexShape);
|
|
||||||
mBaseCount+=result.mHullVcount; // advance the 'base index' counter.
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
int mBaseCount;
|
|
||||||
int mHullCount;
|
|
||||||
FILE* mOutputFile;
|
|
||||||
|
|
||||||
};
|
|
||||||
|
|
||||||
if (tcount)
|
|
||||||
{
|
|
||||||
btTriangleMesh* trimesh = new btTriangleMesh();
|
|
||||||
m_trimeshes.push_back(trimesh);
|
|
||||||
|
|
||||||
btVector3 localScaling(6.f,6.f,6.f);
|
|
||||||
|
|
||||||
int i;
|
|
||||||
for ( i=0;i<wo.mTriCount;i++)
|
|
||||||
{
|
|
||||||
int index0 = wo.mIndices[i*3];
|
|
||||||
int index1 = wo.mIndices[i*3+1];
|
|
||||||
int index2 = wo.mIndices[i*3+2];
|
|
||||||
|
|
||||||
btVector3 vertex0(wo.mVertices[index0*3], wo.mVertices[index0*3+1],wo.mVertices[index0*3+2]);
|
|
||||||
btVector3 vertex1(wo.mVertices[index1*3], wo.mVertices[index1*3+1],wo.mVertices[index1*3+2]);
|
|
||||||
btVector3 vertex2(wo.mVertices[index2*3], wo.mVertices[index2*3+1],wo.mVertices[index2*3+2]);
|
|
||||||
|
|
||||||
vertex0 *= localScaling;
|
|
||||||
vertex1 *= localScaling;
|
|
||||||
vertex2 *= localScaling;
|
|
||||||
|
|
||||||
trimesh->addTriangle(vertex0,vertex1,vertex2);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
btConvexShape* tmpConvexShape = new btConvexTriangleMeshShape(trimesh);
|
|
||||||
|
|
||||||
printf("old numTriangles= %d\n",wo.mTriCount);
|
|
||||||
printf("old numIndices = %d\n",wo.mTriCount*3);
|
|
||||||
printf("old numVertices = %d\n",wo.mVertexCount);
|
|
||||||
|
|
||||||
printf("reducing vertices by creating a convex hull\n");
|
|
||||||
|
|
||||||
//create a hull approximation
|
|
||||||
btShapeHull* hull = new btShapeHull(tmpConvexShape);
|
|
||||||
btScalar margin = tmpConvexShape->getMargin();
|
|
||||||
hull->buildHull(margin);
|
|
||||||
tmpConvexShape->setUserPointer(hull);
|
|
||||||
|
|
||||||
|
|
||||||
printf("new numTriangles = %d\n", hull->numTriangles ());
|
|
||||||
printf("new numIndices = %d\n", hull->numIndices ());
|
|
||||||
printf("new numVertices = %d\n", hull->numVertices ());
|
|
||||||
|
|
||||||
btConvexHullShape* convexShape = new btConvexHullShape();
|
|
||||||
bool updateLocalAabb = false;
|
|
||||||
|
|
||||||
for (i=0;i<hull->numVertices();i++)
|
|
||||||
{
|
|
||||||
convexShape->addPoint(hull->getVertexPointer()[i],updateLocalAabb);
|
|
||||||
}
|
|
||||||
convexShape->recalcLocalAabb();
|
|
||||||
|
|
||||||
if (sEnableSAT)
|
|
||||||
convexShape->initializePolyhedralFeatures();
|
|
||||||
delete tmpConvexShape;
|
|
||||||
delete hull;
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
m_collisionShapes.push_back(convexShape);
|
|
||||||
|
|
||||||
float mass = 1.f;
|
|
||||||
|
|
||||||
btTransform startTransform;
|
|
||||||
startTransform.setIdentity();
|
|
||||||
startTransform.setOrigin(btVector3(0,2,14));
|
|
||||||
|
|
||||||
localCreateRigidBody(mass, startTransform,convexShape);
|
|
||||||
|
|
||||||
bool useQuantization = true;
|
|
||||||
btCollisionShape* concaveShape = new btBvhTriangleMeshShape(trimesh,useQuantization);
|
|
||||||
startTransform.setOrigin(convexDecompositionObjectOffset);
|
|
||||||
localCreateRigidBody(0.f,startTransform,concaveShape);
|
|
||||||
|
|
||||||
m_collisionShapes.push_back (concaveShape);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
if (tcount)
|
|
||||||
{
|
|
||||||
//-----------------------------------
|
|
||||||
// Bullet Convex Decomposition
|
|
||||||
//-----------------------------------
|
|
||||||
|
|
||||||
char outputFileName[512];
|
|
||||||
strcpy(outputFileName,filename);
|
|
||||||
char *dot = strstr(outputFileName,".");
|
|
||||||
if ( dot )
|
|
||||||
*dot = 0;
|
|
||||||
strcat(outputFileName,"_convex.obj");
|
|
||||||
FILE* outputFile = fopen(outputFileName,"wb");
|
|
||||||
|
|
||||||
unsigned int depth = 5;
|
|
||||||
float cpercent = 5;
|
|
||||||
float ppercent = 15;
|
|
||||||
unsigned int maxv = 16;
|
|
||||||
float skinWidth = 0.0;
|
|
||||||
|
|
||||||
printf("WavefrontObj num triangles read %i\n",tcount);
|
|
||||||
ConvexDecomposition::DecompDesc desc;
|
|
||||||
desc.mVcount = wo.mVertexCount;
|
|
||||||
desc.mVertices = wo.mVertices;
|
|
||||||
desc.mTcount = wo.mTriCount;
|
|
||||||
desc.mIndices = (unsigned int *)wo.mIndices;
|
|
||||||
desc.mDepth = depth;
|
|
||||||
desc.mCpercent = cpercent;
|
|
||||||
desc.mPpercent = ppercent;
|
|
||||||
desc.mMaxVertices = maxv;
|
|
||||||
desc.mSkinWidth = skinWidth;
|
|
||||||
|
|
||||||
MyConvexDecomposition convexDecomposition(outputFile,this);
|
|
||||||
desc.mCallback = &convexDecomposition;
|
|
||||||
|
|
||||||
|
|
||||||
//-----------------------------------------------
|
|
||||||
// HACD
|
|
||||||
//-----------------------------------------------
|
|
||||||
|
|
||||||
std::vector< HACD::Vec3<HACD::Real> > points;
|
|
||||||
std::vector< HACD::Vec3<long> > triangles;
|
|
||||||
|
|
||||||
for(int i=0; i<wo.mVertexCount; i++ )
|
|
||||||
{
|
|
||||||
int index = i*3;
|
|
||||||
HACD::Vec3<HACD::Real> vertex(wo.mVertices[index], wo.mVertices[index+1],wo.mVertices[index+2]);
|
|
||||||
points.push_back(vertex);
|
|
||||||
}
|
|
||||||
|
|
||||||
for(int i=0;i<wo.mTriCount;i++)
|
|
||||||
{
|
|
||||||
int index = i*3;
|
|
||||||
HACD::Vec3<long> triangle(wo.mIndices[index], wo.mIndices[index+1], wo.mIndices[index+2]);
|
|
||||||
triangles.push_back(triangle);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
HACD::HACD myHACD;
|
|
||||||
myHACD.SetPoints(&points[0]);
|
|
||||||
myHACD.SetNPoints(points.size());
|
|
||||||
myHACD.SetTriangles(&triangles[0]);
|
|
||||||
myHACD.SetNTriangles(triangles.size());
|
|
||||||
myHACD.SetCompacityWeight(0.1);
|
|
||||||
myHACD.SetVolumeWeight(0.0);
|
|
||||||
|
|
||||||
// HACD parameters
|
|
||||||
// Recommended parameters: 2 100 0 0 0 0
|
|
||||||
size_t nClusters = 2;
|
|
||||||
double concavity = 100;
|
|
||||||
bool invert = false;
|
|
||||||
bool addExtraDistPoints = false;
|
|
||||||
bool addNeighboursDistPoints = false;
|
|
||||||
bool addFacesPoints = false;
|
|
||||||
|
|
||||||
myHACD.SetNClusters(nClusters); // minimum number of clusters
|
|
||||||
myHACD.SetNVerticesPerCH(100); // max of 100 vertices per convex-hull
|
|
||||||
myHACD.SetConcavity(concavity); // maximum concavity
|
|
||||||
myHACD.SetAddExtraDistPoints(addExtraDistPoints);
|
|
||||||
myHACD.SetAddNeighboursDistPoints(addNeighboursDistPoints);
|
|
||||||
myHACD.SetAddFacesPoints(addFacesPoints);
|
|
||||||
|
|
||||||
myHACD.Compute();
|
|
||||||
nClusters = myHACD.GetNClusters();
|
|
||||||
|
|
||||||
myHACD.Save("output.wrl", false);
|
|
||||||
|
|
||||||
|
|
||||||
//convexDecomposition.performConvexDecomposition(desc);
|
|
||||||
|
|
||||||
// ConvexBuilder cb(desc.mCallback);
|
|
||||||
// cb.process(desc);
|
|
||||||
//now create some bodies
|
|
||||||
|
|
||||||
if (1)
|
|
||||||
{
|
|
||||||
btCompoundShape* compound = new btCompoundShape();
|
|
||||||
m_collisionShapes.push_back (compound);
|
|
||||||
|
|
||||||
btTransform trans;
|
|
||||||
trans.setIdentity();
|
|
||||||
|
|
||||||
for (int c=0;c<nClusters;c++)
|
|
||||||
{
|
|
||||||
//generate convex result
|
|
||||||
size_t nPoints = myHACD.GetNPointsCH(c);
|
|
||||||
size_t nTriangles = myHACD.GetNTrianglesCH(c);
|
|
||||||
|
|
||||||
float* vertices = new float[nPoints*3];
|
|
||||||
unsigned int* triangles = new unsigned int[nTriangles*3];
|
|
||||||
|
|
||||||
HACD::Vec3<HACD::Real> * pointsCH = new HACD::Vec3<HACD::Real>[nPoints];
|
|
||||||
HACD::Vec3<long> * trianglesCH = new HACD::Vec3<long>[nTriangles];
|
|
||||||
myHACD.GetCH(c, pointsCH, trianglesCH);
|
|
||||||
|
|
||||||
// points
|
|
||||||
for(size_t v = 0; v < nPoints; v++)
|
|
||||||
{
|
|
||||||
vertices[3*v] = pointsCH[v].X();
|
|
||||||
vertices[3*v+1] = pointsCH[v].Y();
|
|
||||||
vertices[3*v+2] = pointsCH[v].Z();
|
|
||||||
}
|
|
||||||
// triangles
|
|
||||||
for(size_t f = 0; f < nTriangles; f++)
|
|
||||||
{
|
|
||||||
triangles[3*f] = trianglesCH[f].X();
|
|
||||||
triangles[3*f+1] = trianglesCH[f].Y();
|
|
||||||
triangles[3*f+2] = trianglesCH[f].Z();
|
|
||||||
}
|
|
||||||
|
|
||||||
delete [] pointsCH;
|
|
||||||
delete [] trianglesCH;
|
|
||||||
|
|
||||||
ConvexResult r(nPoints, vertices, nTriangles, triangles);
|
|
||||||
convexDecomposition.ConvexDecompResult(r);
|
|
||||||
}
|
|
||||||
|
|
||||||
for (int i=0;i<convexDecomposition.m_convexShapes.size();i++)
|
|
||||||
{
|
|
||||||
btVector3 centroid = convexDecomposition.m_convexCentroids[i];
|
|
||||||
trans.setOrigin(centroid);
|
|
||||||
btConvexHullShape* convexShape = convexDecomposition.m_convexShapes[i];
|
|
||||||
compound->addChildShape(trans,convexShape);
|
|
||||||
|
|
||||||
btRigidBody* body;
|
|
||||||
body = localCreateRigidBody( 1.0, trans,convexShape);
|
|
||||||
}
|
|
||||||
/* for (int i=0;i<convexDecomposition.m_convexShapes.size();i++)
|
|
||||||
{
|
|
||||||
|
|
||||||
btVector3 centroid = convexDecomposition.m_convexCentroids[i];
|
|
||||||
trans.setOrigin(centroid);
|
|
||||||
btConvexHullShape* convexShape = convexDecomposition.m_convexShapes[i];
|
|
||||||
compound->addChildShape(trans,convexShape);
|
|
||||||
|
|
||||||
btRigidBody* body;
|
|
||||||
body = localCreateRigidBody( 1.0, trans,convexShape);
|
|
||||||
}*/
|
|
||||||
|
|
||||||
#if 1
|
|
||||||
btScalar mass=10.f;
|
|
||||||
trans.setOrigin(-convexDecompositionObjectOffset);
|
|
||||||
btRigidBody* body = localCreateRigidBody( mass, trans,compound);
|
|
||||||
body->setCollisionFlags(body->getCollisionFlags() | btCollisionObject::CF_CUSTOM_MATERIAL_CALLBACK);
|
|
||||||
|
|
||||||
convexDecompositionObjectOffset.setZ(6);
|
|
||||||
trans.setOrigin(-convexDecompositionObjectOffset);
|
|
||||||
body = localCreateRigidBody( mass, trans,compound);
|
|
||||||
body->setCollisionFlags(body->getCollisionFlags() | btCollisionObject::CF_CUSTOM_MATERIAL_CALLBACK);
|
|
||||||
|
|
||||||
convexDecompositionObjectOffset.setZ(-6);
|
|
||||||
trans.setOrigin(-convexDecompositionObjectOffset);
|
|
||||||
body = localCreateRigidBody( mass, trans,compound);
|
|
||||||
body->setCollisionFlags(body->getCollisionFlags() | btCollisionObject::CF_CUSTOM_MATERIAL_CALLBACK);
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
if (outputFile)
|
|
||||||
fclose(outputFile);
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef TEST_SERIALIZATION
|
|
||||||
//test serializing this
|
|
||||||
|
|
||||||
int maxSerializeBufferSize = 1024*1024*5;
|
|
||||||
|
|
||||||
btDefaultSerializer* serializer = new btDefaultSerializer(maxSerializeBufferSize);
|
|
||||||
m_dynamicsWorld->serialize(serializer);
|
|
||||||
|
|
||||||
FILE* f2 = fopen("testFile.bullet","wb");
|
|
||||||
fwrite(serializer->getBufferPointer(),serializer->getCurrentBufferSize(),1,f2);
|
|
||||||
fclose(f2);
|
|
||||||
|
|
||||||
exitPhysics();
|
|
||||||
|
|
||||||
//now try again from the loaded file
|
|
||||||
setupEmptyDynamicsWorld();
|
|
||||||
#endif //TEST_SERIALIZATION
|
|
||||||
|
|
||||||
#endif //NO_OBJ_TO_BULLET
|
|
||||||
|
|
||||||
#ifdef TEST_SERIALIZATION
|
|
||||||
|
|
||||||
btBulletWorldImporter* fileLoader = new btBulletWorldImporter(m_dynamicsWorld);
|
|
||||||
//fileLoader->setVerboseMode(true);
|
|
||||||
|
|
||||||
fileLoader->loadFile("testFile.bullet");
|
|
||||||
//fileLoader->loadFile("testFile64Double.bullet");
|
|
||||||
//fileLoader->loadFile("testFile64Single.bullet");
|
|
||||||
//fileLoader->loadFile("testFile32Single.bullet");
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#endif //TEST_SERIALIZATION
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
void ConvexDecompositionDemo::clientMoveAndDisplay()
|
|
||||||
{
|
|
||||||
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
|
||||||
|
|
||||||
float dt = getDeltaTimeMicroseconds() * 0.000001f;
|
|
||||||
|
|
||||||
m_dynamicsWorld->stepSimulation(dt);
|
|
||||||
|
|
||||||
//optional but useful: debug drawing
|
|
||||||
m_dynamicsWorld->debugDrawWorld();
|
|
||||||
|
|
||||||
renderme();
|
|
||||||
|
|
||||||
glFlush();
|
|
||||||
swapBuffers();
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void ConvexDecompositionDemo::displayCallback(void) {
|
|
||||||
|
|
||||||
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
|
||||||
|
|
||||||
|
|
||||||
if (m_dynamicsWorld)
|
|
||||||
m_dynamicsWorld->debugDrawWorld();
|
|
||||||
|
|
||||||
renderme();
|
|
||||||
|
|
||||||
|
|
||||||
glFlush();
|
|
||||||
swapBuffers();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void ConvexDecompositionDemo::exitPhysics()
|
|
||||||
{
|
|
||||||
|
|
||||||
|
|
||||||
//cleanup in the reverse order of creation/initialization
|
|
||||||
|
|
||||||
//remove the rigidbodies from the dynamics world and delete them
|
|
||||||
int i;
|
|
||||||
for (i=m_dynamicsWorld->getNumCollisionObjects()-1; i>=0 ;i--)
|
|
||||||
{
|
|
||||||
btCollisionObject* obj = m_dynamicsWorld->getCollisionObjectArray()[i];
|
|
||||||
btRigidBody* body = btRigidBody::upcast(obj);
|
|
||||||
if (body && body->getMotionState())
|
|
||||||
{
|
|
||||||
delete body->getMotionState();
|
|
||||||
}
|
|
||||||
m_dynamicsWorld->removeCollisionObject( obj );
|
|
||||||
delete obj;
|
|
||||||
}
|
|
||||||
|
|
||||||
//delete collision shapes
|
|
||||||
for (i=0;i<m_collisionShapes.size();i++)
|
|
||||||
{
|
|
||||||
btCollisionShape* shape = m_collisionShapes[i];
|
|
||||||
delete shape;
|
|
||||||
}
|
|
||||||
|
|
||||||
m_collisionShapes.clear();
|
|
||||||
|
|
||||||
for (i=0;i<m_trimeshes.size();i++)
|
|
||||||
{
|
|
||||||
btTriangleMesh* mesh = m_trimeshes[i];
|
|
||||||
delete mesh;
|
|
||||||
}
|
|
||||||
|
|
||||||
m_trimeshes.clear();
|
|
||||||
|
|
||||||
|
|
||||||
//delete dynamics world
|
|
||||||
delete m_dynamicsWorld;
|
|
||||||
|
|
||||||
//delete solver
|
|
||||||
delete m_solver;
|
|
||||||
|
|
||||||
//delete broadphase
|
|
||||||
delete m_broadphase;
|
|
||||||
|
|
||||||
//delete dispatcher
|
|
||||||
delete m_dispatcher;
|
|
||||||
|
|
||||||
delete m_collisionConfiguration;
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void ConvexDecompositionDemo::clientResetScene()
|
|
||||||
{
|
|
||||||
exitPhysics();
|
|
||||||
initPhysics("file.obj");
|
|
||||||
}
|
|
||||||
|
|
||||||
void ConvexDecompositionDemo::keyboardCallback(unsigned char key, int x, int y)
|
|
||||||
{
|
|
||||||
if (key=='S')
|
|
||||||
{
|
|
||||||
sEnableSAT= !sEnableSAT;
|
|
||||||
if (sEnableSAT)
|
|
||||||
{
|
|
||||||
printf("SAT enabled after the next restart of the demo\n");
|
|
||||||
} else
|
|
||||||
{
|
|
||||||
printf("SAT disabled after the next restart of the demo\n");
|
|
||||||
}
|
|
||||||
} else
|
|
||||||
{
|
|
||||||
PlatformDemoApplication::keyboardCallback(key,x,y);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -1,93 +0,0 @@
|
|||||||
/*
|
|
||||||
Bullet Continuous Collision Detection and Physics Library
|
|
||||||
Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied warranty.
|
|
||||||
In no event will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it freely,
|
|
||||||
subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
|
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
#ifndef CONVEX_DECOMPOSITION_DEMO_H
|
|
||||||
#define CONVEX_DECOMPOSITION_DEMO_H
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef _WINDOWS
|
|
||||||
#include "Win32DemoApplication.h"
|
|
||||||
#define PlatformDemoApplication Win32DemoApplication
|
|
||||||
#else
|
|
||||||
#include "GlutDemoApplication.h"
|
|
||||||
#define PlatformDemoApplication GlutDemoApplication
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include "LinearMath/btAlignedObjectArray.h"
|
|
||||||
|
|
||||||
class btBroadphaseInterface;
|
|
||||||
class btCollisionShape;
|
|
||||||
class btOverlappingPairCache;
|
|
||||||
class btCollisionDispatcher;
|
|
||||||
class btConstraintSolver;
|
|
||||||
struct btCollisionAlgorithmCreateFunc;
|
|
||||||
class btDefaultCollisionConfiguration;
|
|
||||||
class btTriangleMesh;
|
|
||||||
|
|
||||||
///ConvexDecompositionDemo shows automatic convex decomposition of a concave mesh
|
|
||||||
ATTRIBUTE_ALIGNED16(class) ConvexDecompositionDemo : public PlatformDemoApplication
|
|
||||||
{
|
|
||||||
|
|
||||||
void setupEmptyDynamicsWorld();
|
|
||||||
public:
|
|
||||||
|
|
||||||
BT_DECLARE_ALIGNED_ALLOCATOR();
|
|
||||||
|
|
||||||
//keep the collision shapes, for deletion/cleanup
|
|
||||||
btAlignedObjectArray<btCollisionShape*> m_collisionShapes;
|
|
||||||
|
|
||||||
btAlignedObjectArray<btTriangleMesh*> m_trimeshes;
|
|
||||||
|
|
||||||
btBroadphaseInterface* m_broadphase;
|
|
||||||
|
|
||||||
btCollisionDispatcher* m_dispatcher;
|
|
||||||
|
|
||||||
btConstraintSolver* m_solver;
|
|
||||||
|
|
||||||
btDefaultCollisionConfiguration* m_collisionConfiguration;
|
|
||||||
|
|
||||||
|
|
||||||
virtual void initPhysics();
|
|
||||||
|
|
||||||
void initPhysics(const char* filename);
|
|
||||||
|
|
||||||
void exitPhysics();
|
|
||||||
|
|
||||||
virtual void clientResetScene();
|
|
||||||
|
|
||||||
virtual ~ConvexDecompositionDemo()
|
|
||||||
{
|
|
||||||
exitPhysics();
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual void clientMoveAndDisplay();
|
|
||||||
|
|
||||||
virtual void displayCallback();
|
|
||||||
|
|
||||||
virtual void keyboardCallback(unsigned char key, int x, int y);
|
|
||||||
|
|
||||||
static DemoApplication* Create()
|
|
||||||
{
|
|
||||||
ConvexDecompositionDemo* demo = new ConvexDecompositionDemo();
|
|
||||||
demo->myinit();
|
|
||||||
demo->initPhysics("file.obj");
|
|
||||||
return demo;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif //CONVEX_DECOMPOSITION_DEMO_H
|
|
||||||
|
|
||||||
|
|
@ -1,25 +0,0 @@
|
|||||||
#ifdef _WINDOWS
|
|
||||||
/*
|
|
||||||
Bullet Continuous Collision Detection and Physics Library
|
|
||||||
Copyright (c) 2003-2010 Erwin Coumans http://bulletphysics.org
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied warranty.
|
|
||||||
In no event will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it freely,
|
|
||||||
subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
|
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "ConvexDecompositionDemo.h"
|
|
||||||
|
|
||||||
///The 'createDemo' function is called from Bullet/Demos/OpenGL/Win32AppMain.cpp to instantiate this particular demo
|
|
||||||
DemoApplication* createDemo()
|
|
||||||
{
|
|
||||||
return new ConvexDecompositionDemo();
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
|
@ -1,27 +0,0 @@
|
|||||||
|
|
||||||
|
|
||||||
#include "ConvexDecompositionDemo.h"
|
|
||||||
#include "GlutStuff.h"
|
|
||||||
#include "GLDebugDrawer.h"
|
|
||||||
#include "btBulletDynamicsCommon.h"
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
int main(int argc,char** argv)
|
|
||||||
{
|
|
||||||
const char* filename = "file.obj";
|
|
||||||
|
|
||||||
|
|
||||||
ConvexDecompositionDemo* convexDecompDemo = new ConvexDecompositionDemo();
|
|
||||||
|
|
||||||
convexDecompDemo->initPhysics(filename);
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
glutmain(argc, argv,640,480,"Bullet Physics Demo. http://www.continuousphysics.com/Bullet/phpBB2/",convexDecompDemo);
|
|
||||||
|
|
||||||
delete convexDecompDemo;
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
Binary file not shown.
@ -1,82 +0,0 @@
|
|||||||
# This is basically the overall name of the project in Visual Studio this is the name of the Solution File
|
|
||||||
|
|
||||||
|
|
||||||
# For every executable you have with a main method you should have an add_executable line below.
|
|
||||||
# For every add executable line you should list every .cpp and .h file you have associated with that executable.
|
|
||||||
|
|
||||||
|
|
||||||
# This is the variable for Windows. I use this to define the root of my directory structure.
|
|
||||||
SET(GLUT_ROOT ${BULLET_PHYSICS_SOURCE_DIR}/Glut)
|
|
||||||
|
|
||||||
# You shouldn't have to modify anything below this line
|
|
||||||
########################################################
|
|
||||||
|
|
||||||
INCLUDE_DIRECTORIES(
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/src ${BULLET_PHYSICS_SOURCE_DIR}/Demos/OpenGL
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
IF (USE_GLUT)
|
|
||||||
LINK_LIBRARIES(
|
|
||||||
OpenGLSupport BulletDynamics BulletCollision LinearMath ${GLUT_glut_LIBRARY} ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY}
|
|
||||||
)
|
|
||||||
|
|
||||||
IF (WIN32)
|
|
||||||
ADD_EXECUTABLE(AppConvexHullDistanceDemo
|
|
||||||
|
|
||||||
ConvexHullDistanceDemo.cpp
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/build/bullet.rc
|
|
||||||
)
|
|
||||||
ELSE()
|
|
||||||
ADD_EXECUTABLE(AppConvexHullDistanceDemo
|
|
||||||
ConvexHullDistanceDemo.cpp
|
|
||||||
)
|
|
||||||
ENDIF()
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
IF (WIN32)
|
|
||||||
IF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES)
|
|
||||||
IF (CMAKE_CL_64)
|
|
||||||
ADD_CUSTOM_COMMAND(
|
|
||||||
TARGET AppConvexHullDistanceDemo
|
|
||||||
POST_BUILD
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/glut64.dll ${CMAKE_CURRENT_BINARY_DIR}
|
|
||||||
)
|
|
||||||
ELSE(CMAKE_CL_64)
|
|
||||||
ADD_CUSTOM_COMMAND(
|
|
||||||
TARGET AppConvexHullDistanceDemo
|
|
||||||
POST_BUILD
|
|
||||||
# COMMAND copy /Y ${BULLET_PHYSICS_SOURCE_DIR}/GLUT32.DLL ${CMAKE_CURRENT_BINARY_DIR}
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/GLUT32.DLL ${CMAKE_CURRENT_BINARY_DIR}
|
|
||||||
)
|
|
||||||
ENDIF(CMAKE_CL_64)
|
|
||||||
ENDIF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES)
|
|
||||||
|
|
||||||
ENDIF(WIN32)
|
|
||||||
ELSE (USE_GLUT)
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
LINK_LIBRARIES(
|
|
||||||
OpenGLSupport BulletDynamics BulletCollision LinearMath ${OPENGL_gl_LIBRARY} ${OPENGL_glu_LIBRARY}
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
ADD_EXECUTABLE(AppConvexHullDistanceDemo
|
|
||||||
WIN32
|
|
||||||
../OpenGL/Win32AppMain.cpp
|
|
||||||
ConvexHullDistanceDemo.cpp
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/build/bullet.rc
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
ENDIF (USE_GLUT)
|
|
||||||
|
|
||||||
IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES)
|
|
||||||
SET_TARGET_PROPERTIES(AppConvexHullDistanceDemo PROPERTIES DEBUG_POSTFIX "_Debug")
|
|
||||||
SET_TARGET_PROPERTIES(AppConvexHullDistanceDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel")
|
|
||||||
SET_TARGET_PROPERTIES(AppConvexHullDistanceDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo")
|
|
||||||
ENDIF(INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES)
|
|
@ -1,509 +0,0 @@
|
|||||||
/*
|
|
||||||
Bullet Continuous Collision Detection and Physics Library
|
|
||||||
Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied warranty.
|
|
||||||
In no event will the authors be held liable for any damages arising from the use of this software.
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it freely,
|
|
||||||
subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
|
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
///
|
|
||||||
/// Convex Hull Distance Demo shows distance calculation between two convex hulls of points.
|
|
||||||
/// GJK with the btVoronoiSimplexSolver is used.
|
|
||||||
///
|
|
||||||
|
|
||||||
#include "GL_Simplex1to4.h"
|
|
||||||
#include "LinearMath/btQuaternion.h"
|
|
||||||
#include "LinearMath/btTransform.h"
|
|
||||||
#include "BulletCollision/NarrowPhaseCollision/btVoronoiSimplexSolver.h"
|
|
||||||
#include "BulletCollision/CollisionShapes/btConvexHullShape.h"
|
|
||||||
#include "BulletCollision/CollisionShapes/btCylinderShape.h"
|
|
||||||
|
|
||||||
#include "BulletCollision/NarrowPhaseCollision/btGjkEpaPenetrationDepthSolver.h"
|
|
||||||
#include "BulletCollision/NarrowPhaseCollision/btGjkPairDetector.h"
|
|
||||||
#include "BulletCollision/NarrowPhaseCollision/btPointCollector.h"
|
|
||||||
#include "BulletCollision/NarrowPhaseCollision/btVoronoiSimplexSolver.h"
|
|
||||||
#include "BulletCollision/NarrowPhaseCollision/btConvexPenetrationDepthSolver.h"
|
|
||||||
#include "LinearMath/btIDebugDraw.h"
|
|
||||||
#include "LinearMath/btConvexHullComputer.h"
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#define TaruVtxCount 43
|
|
||||||
|
|
||||||
static btScalar TaruVtx[] = {
|
|
||||||
1.08664f,-1.99237f,0.0f,
|
|
||||||
0.768369f,-1.99237f,-0.768369f,
|
|
||||||
1.28852f,1.34412e-007f,-1.28852f,
|
|
||||||
1.82224f,1.90735e-007f,0.0f,
|
|
||||||
0.0f,-1.99237f,-1.08664f,
|
|
||||||
0.0f,0.0f,-1.82224f,
|
|
||||||
0.0f,-1.99237f,-1.08664f,
|
|
||||||
-0.768369f,-1.99237f,-0.768369f,
|
|
||||||
-1.28852f,1.34412e-007f,-1.28852f,
|
|
||||||
0.0f,0.0f,-1.82224f,
|
|
||||||
-1.08664f,-1.99237f,1.82086e-007f,
|
|
||||||
-1.82224f,1.90735e-007f,1.59305e-007f,
|
|
||||||
-0.768369f,-1.99237f,0.76837f,
|
|
||||||
-1.28852f,2.47058e-007f,1.28852f,
|
|
||||||
1.42495e-007f,-1.99237f,1.08664f,
|
|
||||||
2.38958e-007f,2.70388e-007f,1.82224f,
|
|
||||||
0.768369f,-1.99237f,0.768369f,
|
|
||||||
1.28852f,2.47058e-007f,1.28852f,
|
|
||||||
0.768369f,1.99237f,-0.768369f,
|
|
||||||
1.08664f,1.99237f,0.0f,
|
|
||||||
0.0f,1.99237f,-1.08664f,
|
|
||||||
-0.768369f,1.99237f,-0.768369f,
|
|
||||||
0.0f,1.99237f,-1.08664f,
|
|
||||||
-1.08664f,1.99237f,0.0f,
|
|
||||||
-0.768369f,1.99237f,0.768369f,
|
|
||||||
1.42495e-007f,1.99237f,1.08664f,
|
|
||||||
0.768369f,1.99237f,0.768369f,
|
|
||||||
1.42495e-007f,-1.99237f,1.08664f,
|
|
||||||
-0.768369f,-1.99237f,0.76837f,
|
|
||||||
-1.08664f,-1.99237f,1.82086e-007f,
|
|
||||||
-0.768369f,-1.99237f,-0.768369f,
|
|
||||||
0.0f,-1.99237f,-1.08664f,
|
|
||||||
0.768369f,-1.99237f,-0.768369f,
|
|
||||||
1.08664f,-1.99237f,0.0f,
|
|
||||||
0.768369f,-1.99237f,0.768369f,
|
|
||||||
0.768369f,1.99237f,-0.768369f,
|
|
||||||
0.0f,1.99237f,-1.08664f,
|
|
||||||
-0.768369f,1.99237f,-0.768369f,
|
|
||||||
-1.08664f,1.99237f,0.0f,
|
|
||||||
-0.768369f,1.99237f,0.768369f,
|
|
||||||
1.42495e-007f,1.99237f,1.08664f,
|
|
||||||
0.768369f,1.99237f,0.768369f,
|
|
||||||
1.08664f,1.99237f,0.0f,
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#define USE_GJK
|
|
||||||
|
|
||||||
#ifndef USE_GJK
|
|
||||||
#include "btBulletCollisionCommon.h"
|
|
||||||
|
|
||||||
#endif //USE_GJK
|
|
||||||
#include "GL_ShapeDrawer.h"
|
|
||||||
#ifdef WIN32 //needed for glut.h
|
|
||||||
#include <windows.h>
|
|
||||||
#endif
|
|
||||||
//think different
|
|
||||||
#if defined(__APPLE__) && !defined (VMDMESA)
|
|
||||||
#include <OpenGL/gl.h>
|
|
||||||
#include <OpenGL/glu.h>
|
|
||||||
#include <GLUT/glut.h>
|
|
||||||
#else
|
|
||||||
#include <GL/glut.h>
|
|
||||||
#endif
|
|
||||||
#include "GlutStuff.h"
|
|
||||||
|
|
||||||
|
|
||||||
float yaw=0.f,pitch=0.f,roll=0.f;
|
|
||||||
const int maxNumObjects = 4;
|
|
||||||
const int numObjects = 2;
|
|
||||||
|
|
||||||
GL_Simplex1to4 simplex;
|
|
||||||
|
|
||||||
btConvexShape* shapePtr[maxNumObjects];
|
|
||||||
|
|
||||||
btTransform tr[numObjects];
|
|
||||||
int screenWidth = 640.f;
|
|
||||||
int screenHeight = 480.f;
|
|
||||||
|
|
||||||
void clientResetScene()
|
|
||||||
{
|
|
||||||
tr[0].setOrigin(btVector3(0.0f,3.f,7.f));
|
|
||||||
tr[1].setOrigin(btVector3(0.0f,9.f,2.f));
|
|
||||||
}
|
|
||||||
|
|
||||||
int debugMode = btIDebugDraw::DBG_DrawWireframe;
|
|
||||||
GL_ShapeDrawer shapeDrawer;
|
|
||||||
int m_glutScreenWidth=0;
|
|
||||||
int m_glutScreenHeight=0;
|
|
||||||
float m_frustumZNear = 1.f;
|
|
||||||
float m_frustumZFar = 10000.f;
|
|
||||||
bool m_ortho = false;
|
|
||||||
|
|
||||||
int myglutmain(int argc, char **argv,int width,int height,const char* title);
|
|
||||||
|
|
||||||
|
|
||||||
void updateCamera() {
|
|
||||||
|
|
||||||
|
|
||||||
glMatrixMode(GL_PROJECTION);
|
|
||||||
glLoadIdentity();
|
|
||||||
btScalar rele = 0;
|
|
||||||
btScalar razi = 0;
|
|
||||||
btVector3 m_cameraUp(0,1,0);
|
|
||||||
btScalar m_cameraDistance = 10.f;
|
|
||||||
btVector3 m_cameraPosition;
|
|
||||||
|
|
||||||
|
|
||||||
btVector3 m_cameraTargetPosition = (tr[0].getOrigin()+tr[1].getOrigin())*0.5;
|
|
||||||
|
|
||||||
|
|
||||||
btQuaternion rot(m_cameraUp,razi);
|
|
||||||
|
|
||||||
|
|
||||||
int m_forwardAxis = 2;
|
|
||||||
|
|
||||||
btVector3 eyePos(0,0,0);
|
|
||||||
eyePos[m_forwardAxis] = -m_cameraDistance;
|
|
||||||
|
|
||||||
btVector3 forward(eyePos[0],eyePos[1],eyePos[2]);
|
|
||||||
if (forward.length2() < SIMD_EPSILON)
|
|
||||||
{
|
|
||||||
forward.setValue(1.f,0.f,0.f);
|
|
||||||
}
|
|
||||||
btVector3 right = m_cameraUp.cross(forward);
|
|
||||||
btQuaternion roll(right,-rele);
|
|
||||||
|
|
||||||
eyePos = btMatrix3x3(rot) * btMatrix3x3(roll) * eyePos;
|
|
||||||
|
|
||||||
m_cameraPosition[0] = eyePos.getX();
|
|
||||||
m_cameraPosition[1] = eyePos.getY();
|
|
||||||
m_cameraPosition[2] = eyePos.getZ();
|
|
||||||
m_cameraPosition += m_cameraTargetPosition;
|
|
||||||
|
|
||||||
if (m_glutScreenWidth == 0 && m_glutScreenHeight == 0)
|
|
||||||
return;
|
|
||||||
|
|
||||||
btScalar aspect;
|
|
||||||
btVector3 extents;
|
|
||||||
|
|
||||||
if (m_glutScreenWidth > m_glutScreenHeight)
|
|
||||||
{
|
|
||||||
aspect = m_glutScreenWidth / (btScalar)m_glutScreenHeight;
|
|
||||||
extents.setValue(aspect * 1.0f, 1.0f,0);
|
|
||||||
} else
|
|
||||||
{
|
|
||||||
aspect = m_glutScreenHeight / (btScalar)m_glutScreenWidth;
|
|
||||||
extents.setValue(1.0f, aspect*1.f,0);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
if (m_ortho)
|
|
||||||
{
|
|
||||||
// reset matrix
|
|
||||||
glLoadIdentity();
|
|
||||||
|
|
||||||
|
|
||||||
extents *= m_cameraDistance;
|
|
||||||
btVector3 lower = m_cameraTargetPosition - extents;
|
|
||||||
btVector3 upper = m_cameraTargetPosition + extents;
|
|
||||||
//gluOrtho2D(lower.x, upper.x, lower.y, upper.y);
|
|
||||||
glOrtho(lower.getX(), upper.getX(), lower.getY(), upper.getY(),-1000,1000);
|
|
||||||
|
|
||||||
glMatrixMode(GL_MODELVIEW);
|
|
||||||
glLoadIdentity();
|
|
||||||
//glTranslatef(100,210,0);
|
|
||||||
} else
|
|
||||||
{
|
|
||||||
if (m_glutScreenWidth > m_glutScreenHeight)
|
|
||||||
{
|
|
||||||
// glFrustum (-aspect, aspect, -1.0, 1.0, 1.0, 10000.0);
|
|
||||||
glFrustum (-aspect * m_frustumZNear, aspect * m_frustumZNear, -m_frustumZNear, m_frustumZNear, m_frustumZNear, m_frustumZFar);
|
|
||||||
} else
|
|
||||||
{
|
|
||||||
// glFrustum (-1.0, 1.0, -aspect, aspect, 1.0, 10000.0);
|
|
||||||
glFrustum (-aspect * m_frustumZNear, aspect * m_frustumZNear, -m_frustumZNear, m_frustumZNear, m_frustumZNear, m_frustumZFar);
|
|
||||||
}
|
|
||||||
glMatrixMode(GL_MODELVIEW);
|
|
||||||
glLoadIdentity();
|
|
||||||
gluLookAt(m_cameraPosition[0], m_cameraPosition[1], m_cameraPosition[2],
|
|
||||||
m_cameraTargetPosition[0], m_cameraTargetPosition[1], m_cameraTargetPosition[2],
|
|
||||||
m_cameraUp.getX(),m_cameraUp.getY(),m_cameraUp.getZ());
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
int main(int argc,char** argv)
|
|
||||||
{
|
|
||||||
clientResetScene();
|
|
||||||
|
|
||||||
btMatrix3x3 basisA;
|
|
||||||
basisA.setIdentity();
|
|
||||||
|
|
||||||
btMatrix3x3 basisB;
|
|
||||||
basisB.setIdentity();
|
|
||||||
|
|
||||||
tr[0].setBasis(basisA);
|
|
||||||
tr[1].setBasis(basisB);
|
|
||||||
|
|
||||||
btVector3 points0[3]={btVector3(1,0,0),btVector3(0,1,0),btVector3(0,0,1)};
|
|
||||||
//btVector3 points1[5]={btVector3(1,0,0),btVector3(0,1,0),btVector3(0,0,1),btVector3(0,0,-1),btVector3(-1,-1,0)};
|
|
||||||
|
|
||||||
btConvexHullShape hullA(&points0[0].getX(),3);
|
|
||||||
btConvexHullShape hullB(TaruVtx,TaruVtxCount,3*sizeof(btScalar));
|
|
||||||
|
|
||||||
shapePtr[0] = &hullA;
|
|
||||||
shapePtr[1] = &hullB;
|
|
||||||
|
|
||||||
|
|
||||||
btTransform tr;
|
|
||||||
tr.setIdentity();
|
|
||||||
|
|
||||||
|
|
||||||
return myglutmain(argc, argv,screenWidth,screenHeight,"Convex Hull Distance Demo");
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
static btVoronoiSimplexSolver sGjkSimplexSolver;
|
|
||||||
btSimplexSolverInterface& gGjkSimplexSolver = sGjkSimplexSolver;
|
|
||||||
|
|
||||||
#include <stdio.h>
|
|
||||||
|
|
||||||
|
|
||||||
void clientDisplay(void) {
|
|
||||||
|
|
||||||
|
|
||||||
updateCamera();
|
|
||||||
|
|
||||||
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
|
||||||
glDisable(GL_LIGHTING);
|
|
||||||
|
|
||||||
//GL_ShapeDrawer::drawCoordSystem();
|
|
||||||
|
|
||||||
ATTRIBUTE_ALIGNED16(btScalar) m[16];
|
|
||||||
int i;
|
|
||||||
#ifdef USE_GJK
|
|
||||||
btGjkEpaPenetrationDepthSolver epa;
|
|
||||||
btGjkPairDetector convexConvex(shapePtr[0],shapePtr[1],&sGjkSimplexSolver,&epa);
|
|
||||||
|
|
||||||
btVector3 seperatingAxis(0.00000000f,0.059727669f,0.29259586f);
|
|
||||||
convexConvex.setCachedSeperatingAxis(seperatingAxis);
|
|
||||||
|
|
||||||
btPointCollector gjkOutput;
|
|
||||||
btGjkPairDetector::ClosestPointInput input;
|
|
||||||
input.m_transformA = tr[0];
|
|
||||||
input.m_transformB = tr[1];
|
|
||||||
|
|
||||||
convexConvex.getClosestPoints(input ,gjkOutput,0);
|
|
||||||
|
|
||||||
if (gjkOutput.m_hasResult)
|
|
||||||
{
|
|
||||||
btVector3 endPt = gjkOutput.m_pointInWorld +
|
|
||||||
gjkOutput.m_normalOnBInWorld*gjkOutput.m_distance;
|
|
||||||
|
|
||||||
glBegin(GL_LINES);
|
|
||||||
glColor3f(1, 0, 0);
|
|
||||||
glVertex3d(gjkOutput.m_pointInWorld.x(), gjkOutput.m_pointInWorld.y(),gjkOutput.m_pointInWorld.z());
|
|
||||||
glVertex3d(endPt.x(),endPt.y(),endPt.z());
|
|
||||||
glEnd();
|
|
||||||
|
|
||||||
}
|
|
||||||
#else //USE_GJK
|
|
||||||
|
|
||||||
|
|
||||||
struct MyContactResultCallback : public btCollisionWorld::ContactResultCallback
|
|
||||||
{
|
|
||||||
virtual btScalar addSingleResult(btManifoldPoint& cp, const btCollisionObjectWrapper* colObj0Wrap,int partId0,int index0,const btCollisionObjectWrapper* colObj1Wrap,int partId1,int index1)
|
|
||||||
{
|
|
||||||
glBegin(GL_LINES);
|
|
||||||
glColor3f(1, 0, 0);
|
|
||||||
|
|
||||||
glVertex3d(cp.m_positionWorldOnA.getX(),cp.m_positionWorldOnA.getY(),cp.m_positionWorldOnA.getZ());
|
|
||||||
glVertex3d(cp.m_positionWorldOnB.getX(),cp.m_positionWorldOnB.getY(),cp.m_positionWorldOnB.getZ());
|
|
||||||
glEnd();
|
|
||||||
|
|
||||||
return 1.f;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
btDefaultCollisionConfiguration collisionConfiguration;
|
|
||||||
btCollisionDispatcher dispatcher(&collisionConfiguration);
|
|
||||||
btDbvtBroadphase pairCache;
|
|
||||||
btCollisionWorld world (&dispatcher,&pairCache,&collisionConfiguration);
|
|
||||||
gContactBreakingThreshold=1e10f;
|
|
||||||
|
|
||||||
MyContactResultCallback result;
|
|
||||||
btCollisionObject obA;
|
|
||||||
obA.setCollisionShape(shapePtr[0]);
|
|
||||||
obA.setWorldTransform(tr[0]);
|
|
||||||
btCollisionObject obB;
|
|
||||||
obB.setCollisionShape(shapePtr[1]);
|
|
||||||
obB.setWorldTransform(tr[1]);
|
|
||||||
world.contactPairTest(&obA,&obB,result);
|
|
||||||
|
|
||||||
#endif//USE_GJK
|
|
||||||
|
|
||||||
btVector3 worldMin(-1000,-1000,-1000);
|
|
||||||
btVector3 worldMax(1000,1000,1000);
|
|
||||||
|
|
||||||
for (i=0;i<numObjects;i++)
|
|
||||||
{
|
|
||||||
|
|
||||||
tr[i].getOpenGLMatrix( m );
|
|
||||||
|
|
||||||
if (debugMode)
|
|
||||||
{
|
|
||||||
/// for polyhedral shapes
|
|
||||||
if (shapePtr[i]->isPolyhedral())
|
|
||||||
{
|
|
||||||
if (!shapePtr[i]->getUserPointer())
|
|
||||||
{
|
|
||||||
btConvexHullComputer* convexUtil = new btConvexHullComputer();
|
|
||||||
shapePtr[i]->setUserPointer(convexUtil);
|
|
||||||
|
|
||||||
btPolyhedralConvexShape* polyshape = (btPolyhedralConvexShape*) shapePtr[i];
|
|
||||||
|
|
||||||
btAlignedObjectArray<btVector3> vertices;
|
|
||||||
vertices.resize(polyshape->getNumVertices());
|
|
||||||
for (int i=0;i<polyshape->getNumVertices();i++)
|
|
||||||
{
|
|
||||||
polyshape->getVertex(i,vertices[i]);
|
|
||||||
}
|
|
||||||
|
|
||||||
bool useDoublePrecision = false;
|
|
||||||
convexUtil->compute(&vertices[0].getX(),sizeof(btVector3), polyshape->getNumVertices(),0,0);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (shapePtr[i]->getUserPointer())
|
|
||||||
{
|
|
||||||
btConvexHullComputer* convexUtil = (btConvexHullComputer*)shapePtr[i]->getUserPointer();
|
|
||||||
//printf("num faces = %d\n",convexUtil->faces.size());
|
|
||||||
for (int j=0;j<convexUtil->faces.size();j++)
|
|
||||||
{
|
|
||||||
int face = convexUtil->faces[j];
|
|
||||||
//printf("face=%d\n",face);
|
|
||||||
const btConvexHullComputer::Edge* firstEdge = &convexUtil->edges[face];
|
|
||||||
const btConvexHullComputer::Edge* edge = firstEdge;
|
|
||||||
|
|
||||||
do
|
|
||||||
{
|
|
||||||
int src = edge->getSourceVertex();
|
|
||||||
int targ = edge->getTargetVertex();
|
|
||||||
//printf("src=%d target = %d\n", src,targ);
|
|
||||||
|
|
||||||
btVector3 wa = tr[i] * convexUtil->vertices[src];
|
|
||||||
btVector3 wb = tr[i] * convexUtil->vertices[targ];
|
|
||||||
|
|
||||||
glBegin(GL_LINES);
|
|
||||||
glColor3f(1, 1, 1);
|
|
||||||
glVertex3f(wa.getX(),wa.getY(),wa.getZ());
|
|
||||||
glVertex3f(wb.getX(),wb.getY(),wb.getZ());
|
|
||||||
glEnd();
|
|
||||||
|
|
||||||
edge = edge->getNextEdgeOfFace();
|
|
||||||
} while (edge!=firstEdge);
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else
|
|
||||||
{
|
|
||||||
shapeDrawer.drawOpenGL(m,shapePtr[i],btVector3(1,1,1),debugMode, worldMin, worldMax);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
simplex.setSimplexSolver(&sGjkSimplexSolver);
|
|
||||||
btVector3 ybuf[4],pbuf[4],qbuf[4];
|
|
||||||
int numpoints = sGjkSimplexSolver.getSimplex(pbuf,qbuf,ybuf);
|
|
||||||
simplex.reset();
|
|
||||||
|
|
||||||
for (i=0;i<numpoints;i++)
|
|
||||||
simplex.addVertex(ybuf[i]);
|
|
||||||
|
|
||||||
btTransform ident;
|
|
||||||
ident.setIdentity();
|
|
||||||
ident.getOpenGLMatrix(m);
|
|
||||||
shapeDrawer.drawOpenGL(m,&simplex,btVector3(1,1,1),debugMode, worldMin,worldMax);
|
|
||||||
|
|
||||||
|
|
||||||
btQuaternion orn;
|
|
||||||
orn.setEuler(yaw,pitch,roll);
|
|
||||||
tr[0].setRotation(orn);
|
|
||||||
tr[1].setRotation(orn);
|
|
||||||
|
|
||||||
pitch += 0.005f;
|
|
||||||
yaw += 0.01f;
|
|
||||||
|
|
||||||
glFlush();
|
|
||||||
glutSwapBuffers();
|
|
||||||
}
|
|
||||||
|
|
||||||
void clientMoveAndDisplay()
|
|
||||||
{
|
|
||||||
clientDisplay();
|
|
||||||
}
|
|
||||||
|
|
||||||
static void glutReshapeCallback(int w, int h)
|
|
||||||
{
|
|
||||||
m_glutScreenWidth=w;
|
|
||||||
m_glutScreenHeight=h;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
int myglutmain(int argc, char **argv,int width,int height,const char* title) {
|
|
||||||
|
|
||||||
|
|
||||||
glutInit(&argc, argv);
|
|
||||||
glutInitDisplayMode(GLUT_DOUBLE | GLUT_RGBA | GLUT_DEPTH | GLUT_STENCIL);
|
|
||||||
glutInitWindowPosition(0, 0);
|
|
||||||
glutInitWindowSize(width, height);
|
|
||||||
|
|
||||||
glutCreateWindow(title);
|
|
||||||
#ifdef BT_USE_FREEGLUT
|
|
||||||
glutSetOption (GLUT_ACTION_ON_WINDOW_CLOSE, GLUT_ACTION_GLUTMAINLOOP_RETURNS);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
glutIdleFunc( clientDisplay );
|
|
||||||
glutDisplayFunc( clientDisplay );
|
|
||||||
glutReshapeFunc(glutReshapeCallback);
|
|
||||||
|
|
||||||
//enable vsync to avoid tearing on Apple (todo: for Windows)
|
|
||||||
|
|
||||||
#if defined(__APPLE__) && !defined (VMDMESA)
|
|
||||||
int swap_interval = 1;
|
|
||||||
CGLContextObj cgl_context = CGLGetCurrentContext();
|
|
||||||
CGLSetParameter(cgl_context, kCGLCPSwapInterval, &swap_interval);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
GLfloat light_ambient[] = { btScalar(0.2), btScalar(0.2), btScalar(0.2), btScalar(1.0) };
|
|
||||||
GLfloat light_diffuse[] = { btScalar(1.0), btScalar(1.0), btScalar(1.0), btScalar(1.0) };
|
|
||||||
GLfloat light_specular[] = { btScalar(1.0), btScalar(1.0), btScalar(1.0), btScalar(1.0 )};
|
|
||||||
/* light_position is NOT default value */
|
|
||||||
GLfloat light_position0[] = { btScalar(1.0), btScalar(10.0), btScalar(1.0), btScalar(0.0 )};
|
|
||||||
GLfloat light_position1[] = { btScalar(-1.0), btScalar(-10.0), btScalar(-1.0), btScalar(0.0) };
|
|
||||||
|
|
||||||
glLightfv(GL_LIGHT0, GL_AMBIENT, light_ambient);
|
|
||||||
glLightfv(GL_LIGHT0, GL_DIFFUSE, light_diffuse);
|
|
||||||
glLightfv(GL_LIGHT0, GL_SPECULAR, light_specular);
|
|
||||||
glLightfv(GL_LIGHT0, GL_POSITION, light_position0);
|
|
||||||
|
|
||||||
glLightfv(GL_LIGHT1, GL_AMBIENT, light_ambient);
|
|
||||||
glLightfv(GL_LIGHT1, GL_DIFFUSE, light_diffuse);
|
|
||||||
glLightfv(GL_LIGHT1, GL_SPECULAR, light_specular);
|
|
||||||
glLightfv(GL_LIGHT1, GL_POSITION, light_position1);
|
|
||||||
|
|
||||||
glEnable(GL_LIGHTING);
|
|
||||||
glEnable(GL_LIGHT0);
|
|
||||||
glEnable(GL_LIGHT1);
|
|
||||||
|
|
||||||
|
|
||||||
glShadeModel(GL_SMOOTH);
|
|
||||||
glEnable(GL_DEPTH_TEST);
|
|
||||||
glDepthFunc(GL_LESS);
|
|
||||||
|
|
||||||
glClearColor(btScalar(0.7),btScalar(0.7),btScalar(0.7),btScalar(0));
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
glutMainLoop();
|
|
||||||
return 0;
|
|
||||||
}
|
|
170
extern/bullet/Demos/DX11ClothDemo/CMakeLists.txt
vendored
170
extern/bullet/Demos/DX11ClothDemo/CMakeLists.txt
vendored
@ -1,170 +0,0 @@
|
|||||||
cmake_minimum_required(VERSION 2.4)
|
|
||||||
|
|
||||||
|
|
||||||
#this line has to appear before 'PROJECT' in order to be able to disable incremental linking
|
|
||||||
SET(MSVC_INCREMENTAL_DEFAULT ON)
|
|
||||||
|
|
||||||
PROJECT(AppDX11ClothDemo)
|
|
||||||
SET(BULLET_VERSION 2.76)
|
|
||||||
|
|
||||||
IF (NOT CMAKE_BUILD_TYPE)
|
|
||||||
# SET(CMAKE_BUILD_TYPE "Debug")
|
|
||||||
SET(CMAKE_BUILD_TYPE "Release")
|
|
||||||
ENDIF (NOT CMAKE_BUILD_TYPE)
|
|
||||||
|
|
||||||
|
|
||||||
OPTION(USE_MSVC_RUNTIME_LIBRARY_DLL "Use MSVC Runtime Library DLL (/MD or /MDd)" ON)
|
|
||||||
OPTION(USE_MSVC_INCREMENTAL_LINKING "Use MSVC Incremental Linking" OFF)
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
IF(MSVC)
|
|
||||||
IF (NOT USE_MSVC_INCREMENTAL_LINKING)
|
|
||||||
#MESSAGE("MSVC_INCREMENTAL_DEFAULT"+${MSVC_INCREMENTAL_DEFAULT})
|
|
||||||
SET( MSVC_INCREMENTAL_YES_FLAG "/INCREMENTAL:NO")
|
|
||||||
|
|
||||||
STRING(REPLACE "INCREMENTAL:YES" "INCREMENTAL:NO" replacementFlags ${CMAKE_EXE_LINKER_FLAGS_DEBUG})
|
|
||||||
SET(CMAKE_EXE_LINKER_FLAGS_DEBUG "/INCREMENTAL:NO ${replacementFlags}" )
|
|
||||||
MESSAGE("CMAKE_EXE_LINKER_FLAGS_DEBUG=${CMAKE_EXE_LINKER_FLAGS_DEBUG}")
|
|
||||||
|
|
||||||
STRING(REPLACE "INCREMENTAL:YES" "INCREMENTAL:NO" replacementFlags3 ${CMAKE_EXE_LINKER_FLAGS_RELWITHDEBINFO})
|
|
||||||
SET(CMAKE_EXE_LINKER_FLAGS_RELWITHDEBINFO ${replacementFlags3})
|
|
||||||
SET(CMAKE_EXE_LINKER_FLAGS_RELWITHDEBINFO "/INCREMENTAL:NO ${replacementFlags3}" )
|
|
||||||
ENDIF (NOT USE_MSVC_INCREMENTAL_LINKING)
|
|
||||||
|
|
||||||
IF (NOT USE_MSVC_RUNTIME_LIBRARY_DLL)
|
|
||||||
#We statically link to reduce dependancies
|
|
||||||
FOREACH(flag_var CMAKE_CXX_FLAGS CMAKE_CXX_FLAGS_DEBUG CMAKE_CXX_FLAGS_RELEASE CMAKE_CXX_FLAGS_MINSIZEREL CMAKE_CXX_FLAGS_RELWITHDEBINFO)
|
|
||||||
IF(${flag_var} MATCHES "/MD")
|
|
||||||
STRING(REGEX REPLACE "/MD" "/MT" ${flag_var} "${${flag_var}}")
|
|
||||||
ENDIF(${flag_var} MATCHES "/MD")
|
|
||||||
IF(${flag_var} MATCHES "/MDd")
|
|
||||||
STRING(REGEX REPLACE "/MDd" "/MTd" ${flag_var} "${${flag_var}}")
|
|
||||||
ENDIF(${flag_var} MATCHES "/MDd")
|
|
||||||
ENDFOREACH(flag_var)
|
|
||||||
ENDIF (NOT USE_MSVC_RUNTIME_LIBRARY_DLL)
|
|
||||||
|
|
||||||
IF (CMAKE_CL_64)
|
|
||||||
ADD_DEFINITIONS(-D_WIN64)
|
|
||||||
ELSE()
|
|
||||||
OPTION(USE_MSVC_SSE "Use MSVC /arch:sse option" ON)
|
|
||||||
IF (USE_MSVC_SSE)
|
|
||||||
ADD_DEFINITIONS(/arch:SSE)
|
|
||||||
ENDIF()
|
|
||||||
ENDIF()
|
|
||||||
OPTION(USE_MSVC_FAST_FLOATINGPOINT "Use MSVC /fp:fast option" ON)
|
|
||||||
IF (USE_MSVC_FAST_FLOATINGPOINT)
|
|
||||||
ADD_DEFINITIONS(/fp:fast)
|
|
||||||
ENDIF()
|
|
||||||
ENDIF(MSVC)
|
|
||||||
|
|
||||||
|
|
||||||
IF(COMMAND cmake_policy)
|
|
||||||
cmake_policy(SET CMP0003 NEW)
|
|
||||||
ENDIF(COMMAND cmake_policy)
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
SET(DXSDK_DIR $ENV{DXSDK_DIR})
|
|
||||||
SET(DX11_INCLUDE_PATH "${DXSDK_DIR}Include" CACHE DOCSTRING "Microsoft directX SDK include path")
|
|
||||||
IF (CMAKE_CL_64)
|
|
||||||
SET(DX11_LIB_PATH "${DXSDK_DIR}Lib/x64" CACHE DOCSTRING "Microsoft DirectX SDK library path")
|
|
||||||
ELSE()
|
|
||||||
SET(DX11_LIB_PATH "${DXSDK_DIR}Lib/x86" CACHE DOCSTRING "Microsoft DirectX SDK library path")
|
|
||||||
ENDIF()
|
|
||||||
|
|
||||||
SET(BulletClothExample_SRCS
|
|
||||||
DXUT/Core/DXUT.cpp
|
|
||||||
DXUT/Optional/DXUTcamera.cpp
|
|
||||||
DXUT/Core/DXUTDevice11.cpp
|
|
||||||
DXUT/Core/DXUTDevice9.cpp
|
|
||||||
DXUT/Optional/DXUTgui.cpp
|
|
||||||
DXUT/Core/DXUTmisc.cpp
|
|
||||||
DXUT/Optional/DXUTres.cpp
|
|
||||||
DXUT/Optional/DXUTsettingsdlg.cpp
|
|
||||||
DXUT/Optional/SDKmesh.cpp
|
|
||||||
DXUT/Optional/SDKmisc.cpp
|
|
||||||
|
|
||||||
cloth_renderer.cpp
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
SET(BulletClothExample_HDRS
|
|
||||||
DXUT/Core/DXUT.h
|
|
||||||
DXUT/Optional/DXUTcamera.h
|
|
||||||
DXUT/Core/DXUTDevice11.h
|
|
||||||
DXUT/Core/DXUTDevice9.h
|
|
||||||
DXUT/Optional/DXUTgui.h
|
|
||||||
DXUT/Core/DXUTmisc.h
|
|
||||||
DXUT/Optional/DXUTres.h
|
|
||||||
DXUT/Optional/DXUTsettingsdlg.h
|
|
||||||
DXUT/Optional/SDKmesh.h
|
|
||||||
DXUT/Optional/SDKmisc.h
|
|
||||||
|
|
||||||
btDirectComputeSupport.h
|
|
||||||
cap.h
|
|
||||||
cloth.h
|
|
||||||
cylinder.h
|
|
||||||
# FreeImage.h
|
|
||||||
resource.h
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
INCLUDE_DIRECTORIES(
|
|
||||||
${DX11_INCLUDE_PATH}
|
|
||||||
${BULLET_PHYSICS_SOURCE_DIR}/src
|
|
||||||
"DXUT/Core"
|
|
||||||
"DXUT/Optional"
|
|
||||||
${VECTOR_MATH_INCLUDE}
|
|
||||||
)
|
|
||||||
LINK_DIRECTORIES(
|
|
||||||
${DX11_LIB_PATH}
|
|
||||||
)
|
|
||||||
|
|
||||||
ADD_DEFINITIONS(-DUNICODE)
|
|
||||||
ADD_DEFINITIONS(-D_UNICODE)
|
|
||||||
|
|
||||||
ADD_EXECUTABLE(AppDX11ClothDemo WIN32
|
|
||||||
${BulletClothExample_SRCS}
|
|
||||||
${BulletClothExample_HDRS}
|
|
||||||
)
|
|
||||||
TARGET_LINK_LIBRARIES(AppDX11ClothDemo
|
|
||||||
d3dcompiler
|
|
||||||
dxerr
|
|
||||||
dxguid
|
|
||||||
d3dx9
|
|
||||||
d3d9
|
|
||||||
winmm
|
|
||||||
comctl32
|
|
||||||
d3dx11
|
|
||||||
BulletDynamics
|
|
||||||
BulletCollision
|
|
||||||
LinearMath
|
|
||||||
BulletSoftBody
|
|
||||||
BulletSoftBodySolvers_DX11
|
|
||||||
)
|
|
||||||
|
|
||||||
IF (INTERNAL_ADD_POSTFIX_EXECUTABLE_NAMES)
|
|
||||||
SET_TARGET_PROPERTIES(AppDX11ClothDemo PROPERTIES DEBUG_POSTFIX "_Debug")
|
|
||||||
SET_TARGET_PROPERTIES(AppDX11ClothDemo PROPERTIES MINSIZEREL_POSTFIX "_MinsizeRel")
|
|
||||||
SET_TARGET_PROPERTIES(AppDX11ClothDemo PROPERTIES RELWITHDEBINFO_POSTFIX "_RelWithDebugInfo")
|
|
||||||
ENDIF()
|
|
||||||
|
|
||||||
|
|
||||||
IF (NOT INTERNAL_CREATE_DISTRIBUTABLE_MSVC_PROJECTFILES)
|
|
||||||
ADD_CUSTOM_COMMAND(
|
|
||||||
TARGET AppDX11ClothDemo
|
|
||||||
POST_BUILD
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/Demos/DX11ClothDemo/cloth_renderer_PS.hlsl ${CMAKE_CURRENT_BINARY_DIR}/cloth_renderer_PS.hlsl
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/Demos/DX11ClothDemo/cloth_renderer_VS.hlsl ${CMAKE_CURRENT_BINARY_DIR}/cloth_renderer_VS.hlsl
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/Demos/DX11ClothDemo/texture.bmp ${CMAKE_CURRENT_BINARY_DIR}/texture.bmp
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/Demos/DX11ClothDemo/amdFlag.bmp ${CMAKE_CURRENT_BINARY_DIR}/amdFlag.bmp
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/Demos/DX11ClothDemo/atiFlag.bmp ${CMAKE_CURRENT_BINARY_DIR}/atiFlag.bmp
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/Demos/DX11ClothDemo/texture.png ${CMAKE_CURRENT_BINARY_DIR}/texture.png
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/Demos/DX11ClothDemo/Media/UI/Font.dds ${CMAKE_CURRENT_BINARY_DIR}/Media/UI/Font.dds
|
|
||||||
COMMAND ${CMAKE_COMMAND} ARGS -E copy_if_different ${BULLET_PHYSICS_SOURCE_DIR}/Demos/DX11ClothDemo/Media/Tiny/tiny.sdkmesh ${CMAKE_CURRENT_BINARY_DIR}/Media/Tiny/tiny.sdkmesh
|
|
||||||
|
|
||||||
)
|
|
||||||
ENDIF()
|
|
||||||
|
|
5846
extern/bullet/Demos/DX11ClothDemo/DXUT/Core/DXUT.cpp
vendored
5846
extern/bullet/Demos/DX11ClothDemo/DXUT/Core/DXUT.cpp
vendored
File diff suppressed because it is too large
Load Diff
378
extern/bullet/Demos/DX11ClothDemo/DXUT/Core/DXUT.h
vendored
378
extern/bullet/Demos/DX11ClothDemo/DXUT/Core/DXUT.h
vendored
@ -1,378 +0,0 @@
|
|||||||
//--------------------------------------------------------------------------------------
|
|
||||||
// File: DXUT.h
|
|
||||||
//
|
|
||||||
// Copyright (c) Microsoft Corporation. All rights reserved.
|
|
||||||
//--------------------------------------------------------------------------------------
|
|
||||||
#pragma once
|
|
||||||
#ifndef DXUT_H
|
|
||||||
#define DXUT_H
|
|
||||||
|
|
||||||
#ifndef UNICODE
|
|
||||||
#error "DXUT requires a Unicode build. See the nearby comments for details"
|
|
||||||
//
|
|
||||||
// If you are using Microsoft Visual C++ .NET, under the General tab of the project
|
|
||||||
// properties change the Character Set to 'Use Unicode Character Set'.
|
|
||||||
//
|
|
||||||
// Windows XP and later are native Unicode so Unicode applications will perform better.
|
|
||||||
// For Windows 98 and Windows Me support, consider using the Microsoft Layer for Unicode (MSLU).
|
|
||||||
//
|
|
||||||
// To use MSLU, link against a set of libraries similar to this
|
|
||||||
// /nod:kernel32.lib /nod:advapi32.lib /nod:user32.lib /nod:gdi32.lib /nod:shell32.lib /nod:comdlg32.lib /nod:version.lib /nod:mpr.lib /nod:rasapi32.lib /nod:winmm.lib /nod:winspool.lib /nod:vfw32.lib /nod:secur32.lib /nod:oleacc.lib /nod:oledlg.lib /nod:sensapi.lib UnicoWS.lib kernel32.lib advapi32.lib user32.lib gdi32.lib shell32.lib comdlg32.lib version.lib mpr.lib rasapi32.lib winmm.lib winspool.lib vfw32.lib secur32.lib oleacc.lib oledlg.lib sensapi.lib dxerr.lib dxguid.lib d3dx9d.lib d3d9.lib comctl32.lib
|
|
||||||
// and put the unicows.dll (available for download from msdn.microsoft.com) in the exe's folder.
|
|
||||||
//
|
|
||||||
// For more details see the MSDN article titled:
|
|
||||||
// "MSLU: Develop Unicode Applications for Windows 9x Platforms with the Microsoft Layer for Unicode"
|
|
||||||
// at http://msdn.microsoft.com/msdnmag/issues/01/10/MSLU/default.aspx
|
|
||||||
//
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include "dxsdkver.h"
|
|
||||||
#if ( _DXSDK_PRODUCT_MAJOR < 9 || _DXSDK_BUILD_MAJOR < 1455 )
|
|
||||||
#error The installed DXSDK is out of date.
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef STRICT
|
|
||||||
#define STRICT
|
|
||||||
#endif
|
|
||||||
|
|
||||||
// If app hasn't choosen, set to work with Windows 98, Windows Me, Windows 2000, Windows XP and beyond
|
|
||||||
#ifndef WINVER
|
|
||||||
#define WINVER 0x0500
|
|
||||||
#endif
|
|
||||||
#ifndef _WIN32_WINDOWS
|
|
||||||
#define _WIN32_WINDOWS 0x0500
|
|
||||||
#endif
|
|
||||||
#ifndef _WIN32_WINNT
|
|
||||||
#define _WIN32_WINNT 0x0600
|
|
||||||
#endif
|
|
||||||
|
|
||||||
// #define DXUT_AUTOLIB to automatically include the libs needed for DXUT
|
|
||||||
#ifdef DXUT_AUTOLIB
|
|
||||||
#pragma comment( lib, "dxerr.lib" )
|
|
||||||
#pragma comment( lib, "dxguid.lib" )
|
|
||||||
#pragma comment( lib, "d3d9.lib" )
|
|
||||||
#if defined(DEBUG) || defined(_DEBUG)
|
|
||||||
#pragma comment( lib, "d3dx9d.lib" )
|
|
||||||
#else
|
|
||||||
#pragma comment( lib, "d3dx9.lib" )
|
|
||||||
#endif
|
|
||||||
#pragma comment( lib, "winmm.lib" )
|
|
||||||
#pragma comment( lib, "comctl32.lib" )
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#pragma warning( disable : 4100 ) // disable unreference formal parameter warnings for /W4 builds
|
|
||||||
|
|
||||||
// Enable extra D3D debugging in debug builds if using the debug DirectX runtime.
|
|
||||||
// This makes D3D objects work well in the debugger watch window, but slows down
|
|
||||||
// performance slightly.
|
|
||||||
#if defined(DEBUG) || defined(_DEBUG)
|
|
||||||
#ifndef D3D_DEBUG_INFO
|
|
||||||
#define D3D_DEBUG_INFO
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
// Standard Windows includes
|
|
||||||
#include <windows.h>
|
|
||||||
#include <initguid.h>
|
|
||||||
#include <assert.h>
|
|
||||||
#include <wchar.h>
|
|
||||||
#include <mmsystem.h>
|
|
||||||
#include <commctrl.h> // for InitCommonControls()
|
|
||||||
#include <shellapi.h> // for ExtractIcon()
|
|
||||||
#include <new.h> // for placement new
|
|
||||||
#include <shlobj.h>
|
|
||||||
#include <math.h>
|
|
||||||
#include <limits.h>
|
|
||||||
#include <stdio.h>
|
|
||||||
|
|
||||||
// CRT's memory leak detection
|
|
||||||
#if defined(DEBUG) || defined(_DEBUG)
|
|
||||||
#include <crtdbg.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
// Direct3D9 includes
|
|
||||||
#include <d3d9.h>
|
|
||||||
#include <d3dx9.h>
|
|
||||||
|
|
||||||
|
|
||||||
// Direct3D11 includes
|
|
||||||
#include <dxgi.h>
|
|
||||||
#include <d3d11.h>
|
|
||||||
#include <d3dCompiler.h>
|
|
||||||
#include <d3dx11.h>
|
|
||||||
|
|
||||||
// XInput includes
|
|
||||||
#include <xinput.h>
|
|
||||||
|
|
||||||
// HRESULT translation for Direct3D10 and other APIs
|
|
||||||
#include <dxerr.h>
|
|
||||||
|
|
||||||
|
|
||||||
#if defined(DEBUG) || defined(_DEBUG)
|
|
||||||
#ifndef V
|
|
||||||
#define V(x) { hr = (x); if( FAILED(hr) ) { DXUTTrace( __FILE__, (DWORD)__LINE__, hr, L#x, true ); } }
|
|
||||||
#endif
|
|
||||||
#ifndef V_RETURN
|
|
||||||
#define V_RETURN(x) { hr = (x); if( FAILED(hr) ) { return DXUTTrace( __FILE__, (DWORD)__LINE__, hr, L#x, true ); } }
|
|
||||||
#endif
|
|
||||||
#else
|
|
||||||
#ifndef V
|
|
||||||
#define V(x) { hr = (x); }
|
|
||||||
#endif
|
|
||||||
#ifndef V_RETURN
|
|
||||||
#define V_RETURN(x) { hr = (x); if( FAILED(hr) ) { return hr; } }
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef SAFE_DELETE
|
|
||||||
#define SAFE_DELETE(p) { if (p) { delete (p); (p)=NULL; } }
|
|
||||||
#endif
|
|
||||||
#ifndef SAFE_DELETE_ARRAY
|
|
||||||
#define SAFE_DELETE_ARRAY(p) { if (p) { delete[] (p); (p)=NULL; } }
|
|
||||||
#endif
|
|
||||||
#ifndef SAFE_RELEASE
|
|
||||||
#define SAFE_RELEASE(p) { if (p) { (p)->Release(); (p)=NULL; } }
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------
|
|
||||||
// Structs
|
|
||||||
//--------------------------------------------------------------------------------------
|
|
||||||
struct DXUTD3D9DeviceSettings
|
|
||||||
{
|
|
||||||
UINT AdapterOrdinal;
|
|
||||||
D3DDEVTYPE DeviceType;
|
|
||||||
D3DFORMAT AdapterFormat;
|
|
||||||
DWORD BehaviorFlags;
|
|
||||||
D3DPRESENT_PARAMETERS pp;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct DXUTD3D11DeviceSettings
|
|
||||||
{
|
|
||||||
UINT AdapterOrdinal;
|
|
||||||
D3D_DRIVER_TYPE DriverType;
|
|
||||||
UINT Output;
|
|
||||||
DXGI_SWAP_CHAIN_DESC sd;
|
|
||||||
UINT32 CreateFlags;
|
|
||||||
UINT32 SyncInterval;
|
|
||||||
DWORD PresentFlags;
|
|
||||||
bool AutoCreateDepthStencil; // DXUT will create the depth stencil resource and view if true
|
|
||||||
DXGI_FORMAT AutoDepthStencilFormat;
|
|
||||||
D3D_FEATURE_LEVEL DeviceFeatureLevel;
|
|
||||||
};
|
|
||||||
|
|
||||||
enum DXUTDeviceVersion
|
|
||||||
{
|
|
||||||
DXUT_D3D9_DEVICE,
|
|
||||||
DXUT_D3D11_DEVICE
|
|
||||||
};
|
|
||||||
|
|
||||||
struct DXUTDeviceSettings
|
|
||||||
{
|
|
||||||
DXUTDeviceVersion ver;
|
|
||||||
D3D_FEATURE_LEVEL MinimumFeatureLevel;
|
|
||||||
DXUTD3D9DeviceSettings d3d9; // only valid if ver == DXUT_D3D9_DEVICE
|
|
||||||
DXUTD3D11DeviceSettings d3d11; // only valid if ver == DXUT_D3D11_DEVICE
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------
|
|
||||||
// Error codes
|
|
||||||
//--------------------------------------------------------------------------------------
|
|
||||||
#define DXUTERR_NODIRECT3D MAKE_HRESULT(SEVERITY_ERROR, FACILITY_ITF, 0x0901)
|
|
||||||
#define DXUTERR_NOCOMPATIBLEDEVICES MAKE_HRESULT(SEVERITY_ERROR, FACILITY_ITF, 0x0902)
|
|
||||||
#define DXUTERR_MEDIANOTFOUND MAKE_HRESULT(SEVERITY_ERROR, FACILITY_ITF, 0x0903)
|
|
||||||
#define DXUTERR_NONZEROREFCOUNT MAKE_HRESULT(SEVERITY_ERROR, FACILITY_ITF, 0x0904)
|
|
||||||
#define DXUTERR_CREATINGDEVICE MAKE_HRESULT(SEVERITY_ERROR, FACILITY_ITF, 0x0905)
|
|
||||||
#define DXUTERR_RESETTINGDEVICE MAKE_HRESULT(SEVERITY_ERROR, FACILITY_ITF, 0x0906)
|
|
||||||
#define DXUTERR_CREATINGDEVICEOBJECTS MAKE_HRESULT(SEVERITY_ERROR, FACILITY_ITF, 0x0907)
|
|
||||||
#define DXUTERR_RESETTINGDEVICEOBJECTS MAKE_HRESULT(SEVERITY_ERROR, FACILITY_ITF, 0x0908)
|
|
||||||
#define DXUTERR_DEVICEREMOVED MAKE_HRESULT(SEVERITY_ERROR, FACILITY_ITF, 0x090A)
|
|
||||||
#define DXUTERR_NODIRECT3D11 MAKE_HRESULT(SEVERITY_ERROR, FACILITY_ITF, 0x090)
|
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------
|
|
||||||
// Callback registration
|
|
||||||
//--------------------------------------------------------------------------------------
|
|
||||||
|
|
||||||
// General callbacks
|
|
||||||
typedef void (CALLBACK *LPDXUTCALLBACKFRAMEMOVE)( double fTime, float fElapsedTime, void* pUserContext );
|
|
||||||
typedef void (CALLBACK *LPDXUTCALLBACKKEYBOARD)( UINT nChar, bool bKeyDown, bool bAltDown, void* pUserContext );
|
|
||||||
typedef void (CALLBACK *LPDXUTCALLBACKMOUSE)( bool bLeftButtonDown, bool bRightButtonDown, bool bMiddleButtonDown, bool bSideButton1Down, bool bSideButton2Down, int nMouseWheelDelta, int xPos, int yPos, void* pUserContext );
|
|
||||||
typedef LRESULT (CALLBACK *LPDXUTCALLBACKMSGPROC)( HWND hWnd, UINT uMsg, WPARAM wParam, LPARAM lParam, bool* pbNoFurtherProcessing, void* pUserContext );
|
|
||||||
typedef void (CALLBACK *LPDXUTCALLBACKTIMER)( UINT idEvent, void* pUserContext );
|
|
||||||
typedef bool (CALLBACK *LPDXUTCALLBACKMODIFYDEVICESETTINGS)( DXUTDeviceSettings* pDeviceSettings, void* pUserContext );
|
|
||||||
typedef bool (CALLBACK *LPDXUTCALLBACKDEVICEREMOVED)( void* pUserContext );
|
|
||||||
|
|
||||||
// Direct3D 9 callbacks
|
|
||||||
typedef bool (CALLBACK *LPDXUTCALLBACKISD3D9DEVICEACCEPTABLE)( D3DCAPS9* pCaps, D3DFORMAT AdapterFormat, D3DFORMAT BackBufferFormat, bool bWindowed, void* pUserContext );
|
|
||||||
typedef HRESULT (CALLBACK *LPDXUTCALLBACKD3D9DEVICECREATED)( IDirect3DDevice9* pd3dDevice, const D3DSURFACE_DESC* pBackBufferSurfaceDesc, void* pUserContext );
|
|
||||||
typedef HRESULT (CALLBACK *LPDXUTCALLBACKD3D9DEVICERESET)( IDirect3DDevice9* pd3dDevice, const D3DSURFACE_DESC* pBackBufferSurfaceDesc, void* pUserContext );
|
|
||||||
typedef void (CALLBACK *LPDXUTCALLBACKD3D9FRAMERENDER)( IDirect3DDevice9* pd3dDevice, double fTime, float fElapsedTime, void* pUserContext );
|
|
||||||
typedef void (CALLBACK *LPDXUTCALLBACKD3D9DEVICELOST)( void* pUserContext );
|
|
||||||
typedef void (CALLBACK *LPDXUTCALLBACKD3D9DEVICEDESTROYED)( void* pUserContext );
|
|
||||||
|
|
||||||
class CD3D11EnumAdapterInfo;
|
|
||||||
class CD3D11EnumDeviceInfo;
|
|
||||||
// Direct3D 11 callbacks
|
|
||||||
typedef bool (CALLBACK *LPDXUTCALLBACKISD3D11DEVICEACCEPTABLE)( const CD3D11EnumAdapterInfo *AdapterInfo, UINT Output, const CD3D11EnumDeviceInfo *DeviceInfo, DXGI_FORMAT BackBufferFormat, bool bWindowed, void* pUserContext );
|
|
||||||
typedef HRESULT (CALLBACK *LPDXUTCALLBACKD3D11DEVICECREATED)( ID3D11Device* pd3dDevice, const DXGI_SURFACE_DESC* pBackBufferSurfaceDesc, void* pUserContext );
|
|
||||||
typedef HRESULT (CALLBACK *LPDXUTCALLBACKD3D11SWAPCHAINRESIZED)( ID3D11Device* pd3dDevice, IDXGISwapChain *pSwapChain, const DXGI_SURFACE_DESC* pBackBufferSurfaceDesc, void* pUserContext );
|
|
||||||
typedef void (CALLBACK *LPDXUTCALLBACKD3D11FRAMERENDER)( ID3D11Device* pd3dDevice, ID3D11DeviceContext* pd3dImmediateContext, double fTime, float fElapsedTime, void* pUserContext );
|
|
||||||
typedef void (CALLBACK *LPDXUTCALLBACKD3D11SWAPCHAINRELEASING)( void* pUserContext );
|
|
||||||
typedef void (CALLBACK *LPDXUTCALLBACKD3D11DEVICEDESTROYED)( void* pUserContext );
|
|
||||||
|
|
||||||
// General callbacks
|
|
||||||
void WINAPI DXUTSetCallbackFrameMove( LPDXUTCALLBACKFRAMEMOVE pCallback, void* pUserContext = NULL );
|
|
||||||
void WINAPI DXUTSetCallbackKeyboard( LPDXUTCALLBACKKEYBOARD pCallback, void* pUserContext = NULL );
|
|
||||||
void WINAPI DXUTSetCallbackMouse( LPDXUTCALLBACKMOUSE pCallback, bool bIncludeMouseMove = false, void* pUserContext = NULL );
|
|
||||||
void WINAPI DXUTSetCallbackMsgProc( LPDXUTCALLBACKMSGPROC pCallback, void* pUserContext = NULL );
|
|
||||||
void WINAPI DXUTSetCallbackDeviceChanging( LPDXUTCALLBACKMODIFYDEVICESETTINGS pCallback, void* pUserContext = NULL );
|
|
||||||
void WINAPI DXUTSetCallbackDeviceRemoved( LPDXUTCALLBACKDEVICEREMOVED pCallback, void* pUserContext = NULL );
|
|
||||||
|
|
||||||
// Direct3D 9 callbacks
|
|
||||||
void WINAPI DXUTSetCallbackD3D9DeviceAcceptable( LPDXUTCALLBACKISD3D9DEVICEACCEPTABLE pCallback, void* pUserContext = NULL );
|
|
||||||
void WINAPI DXUTSetCallbackD3D9DeviceCreated( LPDXUTCALLBACKD3D9DEVICECREATED pCallback, void* pUserContext = NULL );
|
|
||||||
void WINAPI DXUTSetCallbackD3D9DeviceReset( LPDXUTCALLBACKD3D9DEVICERESET pCallback, void* pUserContext = NULL );
|
|
||||||
void WINAPI DXUTSetCallbackD3D9FrameRender( LPDXUTCALLBACKD3D9FRAMERENDER pCallback, void* pUserContext = NULL );
|
|
||||||
void WINAPI DXUTSetCallbackD3D9DeviceLost( LPDXUTCALLBACKD3D9DEVICELOST pCallback, void* pUserContext = NULL );
|
|
||||||
void WINAPI DXUTSetCallbackD3D9DeviceDestroyed( LPDXUTCALLBACKD3D9DEVICEDESTROYED pCallback, void* pUserContext = NULL );
|
|
||||||
|
|
||||||
// Direct3D 11 callbacks
|
|
||||||
void WINAPI DXUTSetCallbackD3D11DeviceAcceptable( LPDXUTCALLBACKISD3D11DEVICEACCEPTABLE pCallback, void* pUserContext = NULL );
|
|
||||||
void WINAPI DXUTSetCallbackD3D11DeviceCreated( LPDXUTCALLBACKD3D11DEVICECREATED pCallback, void* pUserContext = NULL );
|
|
||||||
void WINAPI DXUTSetCallbackD3D11SwapChainResized( LPDXUTCALLBACKD3D11SWAPCHAINRESIZED pCallback, void* pUserContext = NULL );
|
|
||||||
void WINAPI DXUTSetCallbackD3D11FrameRender( LPDXUTCALLBACKD3D11FRAMERENDER pCallback, void* pUserContext = NULL );
|
|
||||||
void WINAPI DXUTSetCallbackD3D11SwapChainReleasing( LPDXUTCALLBACKD3D11SWAPCHAINRELEASING pCallback, void* pUserContext = NULL );
|
|
||||||
void WINAPI DXUTSetCallbackD3D11DeviceDestroyed( LPDXUTCALLBACKD3D11DEVICEDESTROYED pCallback, void* pUserContext = NULL );
|
|
||||||
|
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------
|
|
||||||
// Initialization
|
|
||||||
//--------------------------------------------------------------------------------------
|
|
||||||
HRESULT WINAPI DXUTInit( bool bParseCommandLine = true,
|
|
||||||
bool bShowMsgBoxOnError = true,
|
|
||||||
__in_opt WCHAR* strExtraCommandLineParams = NULL,
|
|
||||||
bool bThreadSafeDXUT = false );
|
|
||||||
|
|
||||||
// Choose either DXUTCreateWindow or DXUTSetWindow. If using DXUTSetWindow, consider using DXUTStaticWndProc
|
|
||||||
HRESULT WINAPI DXUTCreateWindow( const WCHAR* strWindowTitle = L"Direct3D Window",
|
|
||||||
HINSTANCE hInstance = NULL, HICON hIcon = NULL, HMENU hMenu = NULL,
|
|
||||||
int x = CW_USEDEFAULT, int y = CW_USEDEFAULT );
|
|
||||||
HRESULT WINAPI DXUTSetWindow( HWND hWndFocus, HWND hWndDeviceFullScreen, HWND hWndDeviceWindowed, bool bHandleMessages = true );
|
|
||||||
LRESULT CALLBACK DXUTStaticWndProc( HWND hWnd, UINT uMsg, WPARAM wParam, LPARAM lParam );
|
|
||||||
|
|
||||||
// Choose either DXUTCreateDevice or DXUTSetD3D*Device or DXUTCreateD3DDeviceFromSettings
|
|
||||||
|
|
||||||
HRESULT WINAPI DXUTCreateDevice(D3D_FEATURE_LEVEL reqFL, bool bWindowed= true, int nSuggestedWidth =0, int nSuggestedHeight =0 );
|
|
||||||
HRESULT WINAPI DXUTCreateDeviceFromSettings( DXUTDeviceSettings* pDeviceSettings, bool bPreserveInput = false, bool bClipWindowToSingleAdapter = true );
|
|
||||||
HRESULT WINAPI DXUTSetD3D9Device( IDirect3DDevice9* pd3dDevice );
|
|
||||||
HRESULT WINAPI DXUTSetD3D11Device( ID3D11Device* pd3dDevice, IDXGISwapChain* pSwapChain );
|
|
||||||
|
|
||||||
// Choose either DXUTMainLoop or implement your own main loop
|
|
||||||
HRESULT WINAPI DXUTMainLoop( HACCEL hAccel = NULL );
|
|
||||||
|
|
||||||
// If not using DXUTMainLoop consider using DXUTRender3DEnvironment
|
|
||||||
void WINAPI DXUTRender3DEnvironment();
|
|
||||||
|
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------
|
|
||||||
// Common Tasks
|
|
||||||
//--------------------------------------------------------------------------------------
|
|
||||||
HRESULT WINAPI DXUTToggleFullScreen();
|
|
||||||
HRESULT WINAPI DXUTToggleREF();
|
|
||||||
HRESULT WINAPI DXUTToggleWARP();
|
|
||||||
void WINAPI DXUTPause( bool bPauseTime, bool bPauseRendering );
|
|
||||||
void WINAPI DXUTSetConstantFrameTime( bool bConstantFrameTime, float fTimePerFrame = 0.0333f );
|
|
||||||
void WINAPI DXUTSetCursorSettings( bool bShowCursorWhenFullScreen = false, bool bClipCursorWhenFullScreen = false );
|
|
||||||
void WINAPI DXUTSetD3DVersionSupport( bool bAppCanUseD3D9 = true, bool bAppCanUseD3D11 = true );
|
|
||||||
void WINAPI DXUTSetHotkeyHandling( bool bAltEnterToToggleFullscreen = true, bool bEscapeToQuit = true, bool bPauseToToggleTimePause = true );
|
|
||||||
void WINAPI DXUTSetMultimonSettings( bool bAutoChangeAdapter = true );
|
|
||||||
void WINAPI DXUTSetShortcutKeySettings( bool bAllowWhenFullscreen = false, bool bAllowWhenWindowed = true ); // Controls the Windows key, and accessibility shortcut keys
|
|
||||||
void WINAPI DXUTSetWindowSettings( bool bCallDefWindowProc = true );
|
|
||||||
HRESULT WINAPI DXUTSetTimer( LPDXUTCALLBACKTIMER pCallbackTimer, float fTimeoutInSecs = 1.0f, UINT* pnIDEvent = NULL, void* pCallbackUserContext = NULL );
|
|
||||||
HRESULT WINAPI DXUTKillTimer( UINT nIDEvent );
|
|
||||||
void WINAPI DXUTResetFrameworkState();
|
|
||||||
void WINAPI DXUTShutdown( int nExitCode = 0 );
|
|
||||||
void WINAPI DXUTSetIsInGammaCorrectMode( bool bGammaCorrect );
|
|
||||||
BOOL WINAPI DXUTGetMSAASwapChainCreated();
|
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------
|
|
||||||
// State Retrieval
|
|
||||||
//--------------------------------------------------------------------------------------
|
|
||||||
|
|
||||||
// Direct3D 9
|
|
||||||
IDirect3D9* WINAPI DXUTGetD3D9Object(); // Does not addref unlike typical Get* APIs
|
|
||||||
IDirect3DDevice9* WINAPI DXUTGetD3D9Device(); // Does not addref unlike typical Get* APIs
|
|
||||||
D3DPRESENT_PARAMETERS WINAPI DXUTGetD3D9PresentParameters();
|
|
||||||
const D3DSURFACE_DESC* WINAPI DXUTGetD3D9BackBufferSurfaceDesc();
|
|
||||||
const D3DCAPS9* WINAPI DXUTGetD3D9DeviceCaps();
|
|
||||||
HRESULT WINAPI DXUTGetD3D9DeviceCaps( DXUTDeviceSettings* pDeviceSettings, D3DCAPS9* pCaps );
|
|
||||||
bool WINAPI DXUTDoesAppSupportD3D9();
|
|
||||||
bool WINAPI DXUTIsAppRenderingWithD3D9();
|
|
||||||
|
|
||||||
|
|
||||||
// Direct3D 11
|
|
||||||
IDXGIFactory1* WINAPI DXUTGetDXGIFactory(); // Does not addref unlike typical Get* APIs
|
|
||||||
IDXGISwapChain* WINAPI DXUTGetDXGISwapChain(); // Does not addref unlike typical Get* APIs
|
|
||||||
const DXGI_SURFACE_DESC* WINAPI DXUTGetDXGIBackBufferSurfaceDesc();
|
|
||||||
bool WINAPI DXUTIsD3D11Available(); // If D3D11 APIs are availible
|
|
||||||
ID3D11Device* WINAPI DXUTGetD3D11Device(); // Does not addref unlike typical Get* APIs
|
|
||||||
ID3D11DeviceContext* WINAPI DXUTGetD3D11DeviceContext(); // Does not addref unlike typical Get* APIs
|
|
||||||
HRESULT WINAPI DXUTSetupD3D11Views( ID3D11DeviceContext* pd3dDeviceContext ); // Supports immediate or deferred context
|
|
||||||
D3D_FEATURE_LEVEL WINAPI DXUTGetD3D11DeviceFeatureLevel(); // Returns the D3D11 devices current feature level
|
|
||||||
ID3D11RenderTargetView* WINAPI DXUTGetD3D11RenderTargetView(); // Does not addref unlike typical Get* APIs
|
|
||||||
ID3D11DepthStencilView* WINAPI DXUTGetD3D11DepthStencilView(); // Does not addref unlike typical Get* APIs
|
|
||||||
bool WINAPI DXUTDoesAppSupportD3D11();
|
|
||||||
bool WINAPI DXUTIsAppRenderingWithD3D11();
|
|
||||||
|
|
||||||
|
|
||||||
// General
|
|
||||||
DXUTDeviceSettings WINAPI DXUTGetDeviceSettings();
|
|
||||||
HINSTANCE WINAPI DXUTGetHINSTANCE();
|
|
||||||
HWND WINAPI DXUTGetHWND();
|
|
||||||
HWND WINAPI DXUTGetHWNDFocus();
|
|
||||||
HWND WINAPI DXUTGetHWNDDeviceFullScreen();
|
|
||||||
HWND WINAPI DXUTGetHWNDDeviceWindowed();
|
|
||||||
RECT WINAPI DXUTGetWindowClientRect();
|
|
||||||
LONG WINAPI DXUTGetWindowWidth();
|
|
||||||
LONG WINAPI DXUTGetWindowHeight();
|
|
||||||
RECT WINAPI DXUTGetWindowClientRectAtModeChange(); // Useful for returning to windowed mode with the same resolution as before toggle to full screen mode
|
|
||||||
RECT WINAPI DXUTGetFullsceenClientRectAtModeChange(); // Useful for returning to full screen mode with the same resolution as before toggle to windowed mode
|
|
||||||
double WINAPI DXUTGetTime();
|
|
||||||
float WINAPI DXUTGetElapsedTime();
|
|
||||||
bool WINAPI DXUTIsWindowed();
|
|
||||||
bool WINAPI DXUTIsInGammaCorrectMode();
|
|
||||||
float WINAPI DXUTGetFPS();
|
|
||||||
LPCWSTR WINAPI DXUTGetWindowTitle();
|
|
||||||
LPCWSTR WINAPI DXUTGetFrameStats( bool bIncludeFPS = false );
|
|
||||||
LPCWSTR WINAPI DXUTGetDeviceStats();
|
|
||||||
|
|
||||||
bool WINAPI DXUTIsVsyncEnabled();
|
|
||||||
bool WINAPI DXUTIsRenderingPaused();
|
|
||||||
bool WINAPI DXUTIsTimePaused();
|
|
||||||
bool WINAPI DXUTIsActive();
|
|
||||||
int WINAPI DXUTGetExitCode();
|
|
||||||
bool WINAPI DXUTGetShowMsgBoxOnError();
|
|
||||||
bool WINAPI DXUTGetAutomation(); // Returns true if -automation parameter is used to launch the app
|
|
||||||
bool WINAPI DXUTIsKeyDown( BYTE vKey ); // Pass a virtual-key code, ex. VK_F1, 'A', VK_RETURN, VK_LSHIFT, etc
|
|
||||||
bool WINAPI DXUTWasKeyPressed( BYTE vKey ); // Like DXUTIsKeyDown() but return true only if the key was just pressed
|
|
||||||
bool WINAPI DXUTIsMouseButtonDown( BYTE vButton ); // Pass a virtual-key code: VK_LBUTTON, VK_RBUTTON, VK_MBUTTON, VK_XBUTTON1, VK_XBUTTON2
|
|
||||||
HRESULT WINAPI DXUTCreateState(); // Optional method to create DXUT's memory. If its not called by the application it will be automatically called when needed
|
|
||||||
void WINAPI DXUTDestroyState(); // Optional method to destroy DXUT's memory. If its not called by the application it will be automatically called after the application exits WinMain
|
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------
|
|
||||||
// DXUT core layer includes
|
|
||||||
//--------------------------------------------------------------------------------------
|
|
||||||
#include "DXUTmisc.h"
|
|
||||||
#include "DXUTDevice9.h"
|
|
||||||
#include "DXUTDevice11.h"
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
File diff suppressed because it is too large
Load Diff
@ -1,210 +0,0 @@
|
|||||||
//--------------------------------------------------------------------------------------
|
|
||||||
// File: DXUTDevice11.h
|
|
||||||
//
|
|
||||||
// Enumerates D3D adapters, devices, modes, etc.
|
|
||||||
//
|
|
||||||
// Copyright (c) Microsoft Corporation. All rights reserved.
|
|
||||||
//--------------------------------------------------------------------------------------
|
|
||||||
#pragma once
|
|
||||||
#ifndef DXUT_DEVICE11_H
|
|
||||||
#define DXUT_DEVICE11_H
|
|
||||||
|
|
||||||
void DXUTApplyDefaultDeviceSettings(DXUTDeviceSettings *modifySettings);
|
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------
|
|
||||||
// Functions to get bit depth from formats
|
|
||||||
//--------------------------------------------------------------------------------------
|
|
||||||
HRESULT WINAPI DXUTGetD3D11AdapterDisplayMode( UINT AdapterOrdinal, UINT Output, DXGI_MODE_DESC* pModeDesc );
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------
|
|
||||||
// Optional memory create/destory functions. If not call, these will be called automatically
|
|
||||||
//--------------------------------------------------------------------------------------
|
|
||||||
HRESULT WINAPI DXUTCreateD3D11Enumeration();
|
|
||||||
void WINAPI DXUTDestroyD3D11Enumeration();
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------
|
|
||||||
// Forward declarations
|
|
||||||
//--------------------------------------------------------------------------------------
|
|
||||||
class CD3D11EnumAdapterInfo;
|
|
||||||
class CD3D11EnumDeviceInfo;
|
|
||||||
class CD3D11EnumOutputInfo;
|
|
||||||
struct CD3D11EnumDeviceSettingsCombo;
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------
|
|
||||||
// Enumerates available Direct3D10 adapters, devices, modes, etc.
|
|
||||||
// Use DXUTGetD3D9Enumeration() to access global instance
|
|
||||||
//--------------------------------------------------------------------------------------
|
|
||||||
class CD3D11Enumeration
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
// These should be called before Enumerate().
|
|
||||||
//
|
|
||||||
// Use these calls and the IsDeviceAcceptable to control the contents of
|
|
||||||
// the enumeration object, which affects the device selection and the device settings dialog.
|
|
||||||
void SetResolutionMinMax( UINT nMinWidth, UINT nMinHeight, UINT nMaxWidth, UINT nMaxHeight );
|
|
||||||
void SetRefreshMinMax( UINT nMin, UINT nMax );
|
|
||||||
void SetForceFeatureLevel( D3D_FEATURE_LEVEL forceFL) {
|
|
||||||
g_forceFL = forceFL;
|
|
||||||
};
|
|
||||||
void SetMultisampleQualityMax( UINT nMax );
|
|
||||||
CGrowableArray<D3DFORMAT>* GetPossibleDepthStencilFormatList();
|
|
||||||
void ResetPossibleDepthStencilFormats();
|
|
||||||
void SetEnumerateAllAdapterFormats( bool bEnumerateAllAdapterFormats );
|
|
||||||
|
|
||||||
// Call Enumerate() to enumerate available D3D11 adapters, devices, modes, etc.
|
|
||||||
bool HasEnumerated() { return m_bHasEnumerated; }
|
|
||||||
HRESULT Enumerate( LPDXUTCALLBACKISD3D11DEVICEACCEPTABLE IsD3D11DeviceAcceptableFunc,
|
|
||||||
void* pIsD3D11DeviceAcceptableFuncUserContext );
|
|
||||||
|
|
||||||
// These should be called after Enumerate() is called
|
|
||||||
CGrowableArray<CD3D11EnumAdapterInfo*>* GetAdapterInfoList();
|
|
||||||
CD3D11EnumAdapterInfo* GetAdapterInfo( UINT AdapterOrdinal );
|
|
||||||
CD3D11EnumDeviceInfo* GetDeviceInfo( UINT AdapterOrdinal, D3D_DRIVER_TYPE DeviceType );
|
|
||||||
CD3D11EnumOutputInfo* GetOutputInfo( UINT AdapterOrdinal, UINT Output );
|
|
||||||
CD3D11EnumDeviceSettingsCombo* GetDeviceSettingsCombo( DXUTD3D11DeviceSettings* pDeviceSettings ) { return GetDeviceSettingsCombo( pDeviceSettings->AdapterOrdinal, pDeviceSettings->DriverType, pDeviceSettings->Output, pDeviceSettings->sd.BufferDesc.Format, pDeviceSettings->sd.Windowed ); }
|
|
||||||
CD3D11EnumDeviceSettingsCombo* GetDeviceSettingsCombo( UINT AdapterOrdinal, D3D_DRIVER_TYPE DeviceType, UINT Output, DXGI_FORMAT BackBufferFormat, BOOL Windowed );
|
|
||||||
|
|
||||||
~CD3D11Enumeration();
|
|
||||||
|
|
||||||
private:
|
|
||||||
friend HRESULT WINAPI DXUTCreateD3D11Enumeration();
|
|
||||||
|
|
||||||
// Use DXUTGetD3D11Enumeration() to access global instance
|
|
||||||
CD3D11Enumeration();
|
|
||||||
|
|
||||||
bool m_bHasEnumerated;
|
|
||||||
LPDXUTCALLBACKISD3D11DEVICEACCEPTABLE m_IsD3D11DeviceAcceptableFunc;
|
|
||||||
void* m_pIsD3D11DeviceAcceptableFuncUserContext;
|
|
||||||
|
|
||||||
CGrowableArray<DXGI_FORMAT> m_DepthStencilPossibleList;
|
|
||||||
|
|
||||||
UINT m_nMinWidth;
|
|
||||||
UINT m_nMaxWidth;
|
|
||||||
UINT m_nMinHeight;
|
|
||||||
UINT m_nMaxHeight;
|
|
||||||
UINT m_nRefreshMin;
|
|
||||||
UINT m_nRefreshMax;
|
|
||||||
UINT m_nMultisampleQualityMax;
|
|
||||||
bool m_bEnumerateAllAdapterFormats;
|
|
||||||
D3D_FEATURE_LEVEL g_forceFL;
|
|
||||||
|
|
||||||
// Array of CD3D9EnumAdapterInfo* with unique AdapterOrdinals
|
|
||||||
CGrowableArray<CD3D11EnumAdapterInfo*> m_AdapterInfoList;
|
|
||||||
|
|
||||||
HRESULT EnumerateOutputs( CD3D11EnumAdapterInfo *pAdapterInfo );
|
|
||||||
HRESULT EnumerateDevices( CD3D11EnumAdapterInfo *pAdapterInfo );
|
|
||||||
HRESULT EnumerateDeviceCombos( IDXGIFactory1 *pFactory, CD3D11EnumAdapterInfo* pAdapterInfo );
|
|
||||||
HRESULT EnumerateDeviceCombosNoAdapter( CD3D11EnumAdapterInfo* pAdapterInfo );
|
|
||||||
|
|
||||||
HRESULT EnumerateDisplayModes( CD3D11EnumOutputInfo *pOutputInfo );
|
|
||||||
void BuildMultiSampleQualityList( DXGI_FORMAT fmt, CD3D11EnumDeviceSettingsCombo* pDeviceCombo );
|
|
||||||
void ClearAdapterInfoList();
|
|
||||||
};
|
|
||||||
|
|
||||||
CD3D11Enumeration* WINAPI DXUTGetD3D11Enumeration(bool bForceEnumerate = false, bool EnumerateAllAdapterFormats = false, D3D_FEATURE_LEVEL forceFL = ((D3D_FEATURE_LEVEL )0) );
|
|
||||||
|
|
||||||
|
|
||||||
#define DXGI_MAX_DEVICE_IDENTIFIER_STRING 128
|
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------
|
|
||||||
// A class describing an adapter which contains a unique adapter ordinal
|
|
||||||
// that is installed on the system
|
|
||||||
//--------------------------------------------------------------------------------------
|
|
||||||
class CD3D11EnumAdapterInfo
|
|
||||||
{
|
|
||||||
const CD3D11EnumAdapterInfo &operator = ( const CD3D11EnumAdapterInfo &rhs );
|
|
||||||
|
|
||||||
public:
|
|
||||||
~CD3D11EnumAdapterInfo();
|
|
||||||
|
|
||||||
UINT AdapterOrdinal;
|
|
||||||
DXGI_ADAPTER_DESC AdapterDesc;
|
|
||||||
WCHAR szUniqueDescription[DXGI_MAX_DEVICE_IDENTIFIER_STRING];
|
|
||||||
IDXGIAdapter *m_pAdapter;
|
|
||||||
bool bAdapterUnavailable;
|
|
||||||
|
|
||||||
CGrowableArray<CD3D11EnumOutputInfo*> outputInfoList; // Array of CD3D11EnumOutputInfo*
|
|
||||||
CGrowableArray<CD3D11EnumDeviceInfo*> deviceInfoList; // Array of CD3D11EnumDeviceInfo*
|
|
||||||
// List of CD3D11EnumDeviceSettingsCombo* with a unique set
|
|
||||||
// of BackBufferFormat, and Windowed
|
|
||||||
CGrowableArray<CD3D11EnumDeviceSettingsCombo*> deviceSettingsComboList;
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
class CD3D11EnumOutputInfo
|
|
||||||
{
|
|
||||||
const CD3D11EnumOutputInfo &operator = ( const CD3D11EnumOutputInfo &rhs );
|
|
||||||
|
|
||||||
public:
|
|
||||||
~CD3D11EnumOutputInfo();
|
|
||||||
|
|
||||||
UINT AdapterOrdinal;
|
|
||||||
UINT Output;
|
|
||||||
IDXGIOutput* m_pOutput;
|
|
||||||
DXGI_OUTPUT_DESC Desc;
|
|
||||||
|
|
||||||
CGrowableArray <DXGI_MODE_DESC> displayModeList; // Array of supported D3DDISPLAYMODEs
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------
|
|
||||||
// A class describing a Direct3D10 device that contains a
|
|
||||||
// unique supported driver type
|
|
||||||
//--------------------------------------------------------------------------------------
|
|
||||||
class CD3D11EnumDeviceInfo
|
|
||||||
{
|
|
||||||
const CD3D11EnumDeviceInfo& operator =( const CD3D11EnumDeviceInfo& rhs );
|
|
||||||
|
|
||||||
public:
|
|
||||||
~CD3D11EnumDeviceInfo();
|
|
||||||
|
|
||||||
UINT AdapterOrdinal;
|
|
||||||
D3D_DRIVER_TYPE DeviceType;
|
|
||||||
D3D_FEATURE_LEVEL SelectedLevel;
|
|
||||||
D3D_FEATURE_LEVEL MaxLevel;
|
|
||||||
BOOL ComputeShaders_Plus_RawAndStructuredBuffers_Via_Shader_4_x;
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------
|
|
||||||
// A struct describing device settings that contains a unique combination of
|
|
||||||
// adapter format, back buffer format, and windowed that is compatible with a
|
|
||||||
// particular Direct3D device and the app.
|
|
||||||
//--------------------------------------------------------------------------------------
|
|
||||||
struct CD3D11EnumDeviceSettingsCombo
|
|
||||||
{
|
|
||||||
UINT AdapterOrdinal;
|
|
||||||
D3D_DRIVER_TYPE DeviceType;
|
|
||||||
DXGI_FORMAT BackBufferFormat;
|
|
||||||
BOOL Windowed;
|
|
||||||
UINT Output;
|
|
||||||
|
|
||||||
CGrowableArray <UINT> multiSampleCountList; // List of valid sampling counts (multisampling)
|
|
||||||
CGrowableArray <UINT> multiSampleQualityList; // List of number of quality levels for each multisample count
|
|
||||||
|
|
||||||
CD3D11EnumAdapterInfo* pAdapterInfo;
|
|
||||||
CD3D11EnumDeviceInfo* pDeviceInfo;
|
|
||||||
CD3D11EnumOutputInfo* pOutputInfo;
|
|
||||||
};
|
|
||||||
|
|
||||||
float DXUTRankD3D11DeviceCombo( CD3D11EnumDeviceSettingsCombo* pDeviceSettingsCombo,
|
|
||||||
DXUTD3D11DeviceSettings* pOptimalDeviceSettings,
|
|
||||||
DXGI_MODE_DESC* pAdapterDisplayMode,
|
|
||||||
int &bestModeIndex,
|
|
||||||
int &bestMSAAIndex
|
|
||||||
);
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
File diff suppressed because it is too large
Load Diff
@ -1,207 +0,0 @@
|
|||||||
//--------------------------------------------------------------------------------------
|
|
||||||
// File: DXUTDevice9.h
|
|
||||||
//
|
|
||||||
// Enumerates D3D adapters, devices, modes, etc.
|
|
||||||
//
|
|
||||||
// Copyright (c) Microsoft Corporation. All rights reserved.
|
|
||||||
//--------------------------------------------------------------------------------------
|
|
||||||
#pragma once
|
|
||||||
#ifndef DXUT_DEVICE9_H
|
|
||||||
#define DXUT_DEVICE9_H
|
|
||||||
|
|
||||||
//void DXUTApplyDefaultDeviceSettings(DXUTDeviceSettings *modifySettings);
|
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------
|
|
||||||
// Functions to get bit depth from formats
|
|
||||||
//--------------------------------------------------------------------------------------
|
|
||||||
UINT WINAPI DXUTGetD3D9ColorChannelBits( D3DFORMAT fmt );
|
|
||||||
UINT WINAPI DXUTGetAlphaChannelBits( D3DFORMAT fmt );
|
|
||||||
UINT WINAPI DXUTGetStencilBits( D3DFORMAT fmt );
|
|
||||||
UINT WINAPI DXUTGetDepthBits( D3DFORMAT fmt );
|
|
||||||
UINT WINAPI DXUTGetDXGIColorChannelBits( DXGI_FORMAT fmt );
|
|
||||||
|
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------
|
|
||||||
// Forward declarations
|
|
||||||
//--------------------------------------------------------------------------------------
|
|
||||||
|
|
||||||
class CD3D9EnumAdapterInfo;
|
|
||||||
class CD3D9EnumDeviceInfo;
|
|
||||||
struct CD3D9EnumDeviceSettingsCombo;
|
|
||||||
struct CD3D9EnumDSMSConflict;
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------
|
|
||||||
// Optional memory create/destory functions. If not call, these will be called automatically
|
|
||||||
//--------------------------------------------------------------------------------------
|
|
||||||
HRESULT WINAPI DXUTCreateD3D9Enumeration();
|
|
||||||
void WINAPI DXUTDestroyD3D9Enumeration();
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------
|
|
||||||
// Enumerates available Direct3D9 adapters, devices, modes, etc.
|
|
||||||
// Use DXUTGetD3D9Enumeration() to access global instance
|
|
||||||
//--------------------------------------------------------------------------------------
|
|
||||||
class CD3D9Enumeration
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
// These should be called before Enumerate().
|
|
||||||
//
|
|
||||||
// Use these calls and the IsDeviceAcceptable to control the contents of
|
|
||||||
// the enumeration object, which affects the device selection and the device settings dialog.
|
|
||||||
void SetRequirePostPixelShaderBlending( bool bRequire ) { m_bRequirePostPixelShaderBlending = bRequire; }
|
|
||||||
void SetResolutionMinMax( UINT nMinWidth, UINT nMinHeight, UINT nMaxWidth, UINT nMaxHeight );
|
|
||||||
void SetRefreshMinMax( UINT nMin, UINT nMax );
|
|
||||||
void SetMultisampleQualityMax( UINT nMax );
|
|
||||||
void GetPossibleVertexProcessingList( bool* pbSoftwareVP, bool* pbHardwareVP, bool* pbPureHarewareVP, bool* pbMixedVP );
|
|
||||||
void SetPossibleVertexProcessingList( bool bSoftwareVP, bool bHardwareVP, bool bPureHarewareVP, bool bMixedVP );
|
|
||||||
CGrowableArray<D3DFORMAT>* GetPossibleDepthStencilFormatList();
|
|
||||||
CGrowableArray<D3DMULTISAMPLE_TYPE>* GetPossibleMultisampleTypeList();
|
|
||||||
CGrowableArray<UINT>* GetPossiblePresentIntervalList();
|
|
||||||
void ResetPossibleDepthStencilFormats();
|
|
||||||
void ResetPossibleMultisampleTypeList();
|
|
||||||
void ResetPossiblePresentIntervalList();
|
|
||||||
|
|
||||||
// Call Enumerate() to enumerate available D3D adapters, devices, modes, etc.
|
|
||||||
bool HasEnumerated() { return m_bHasEnumerated; }
|
|
||||||
HRESULT Enumerate( LPDXUTCALLBACKISD3D9DEVICEACCEPTABLE IsD3D9DeviceAcceptableFunc = NULL,
|
|
||||||
void* pIsD3D9DeviceAcceptableFuncUserContext = NULL );
|
|
||||||
|
|
||||||
// These should be called after Enumerate() is called
|
|
||||||
CGrowableArray<CD3D9EnumAdapterInfo*>* GetAdapterInfoList();
|
|
||||||
CD3D9EnumAdapterInfo* GetAdapterInfo( UINT AdapterOrdinal );
|
|
||||||
CD3D9EnumDeviceInfo* GetDeviceInfo( UINT AdapterOrdinal, D3DDEVTYPE DeviceType );
|
|
||||||
CD3D9EnumDeviceSettingsCombo* GetDeviceSettingsCombo( DXUTD3D9DeviceSettings* pD3D9DeviceSettings ) { return GetDeviceSettingsCombo( pD3D9DeviceSettings->AdapterOrdinal, pD3D9DeviceSettings->DeviceType, pD3D9DeviceSettings->AdapterFormat, pD3D9DeviceSettings->pp.BackBufferFormat, pD3D9DeviceSettings->pp.Windowed ); }
|
|
||||||
CD3D9EnumDeviceSettingsCombo* GetDeviceSettingsCombo( UINT AdapterOrdinal, D3DDEVTYPE DeviceType, D3DFORMAT AdapterFormat, D3DFORMAT BackBufferFormat, BOOL Windowed );
|
|
||||||
|
|
||||||
~CD3D9Enumeration();
|
|
||||||
|
|
||||||
private:
|
|
||||||
friend HRESULT WINAPI DXUTCreateD3D9Enumeration();
|
|
||||||
|
|
||||||
// Use DXUTGetD3D9Enumeration() to access global instance
|
|
||||||
CD3D9Enumeration();
|
|
||||||
|
|
||||||
bool m_bHasEnumerated;
|
|
||||||
IDirect3D9* m_pD3D;
|
|
||||||
LPDXUTCALLBACKISD3D9DEVICEACCEPTABLE m_IsD3D9DeviceAcceptableFunc;
|
|
||||||
void* m_pIsD3D9DeviceAcceptableFuncUserContext;
|
|
||||||
bool m_bRequirePostPixelShaderBlending;
|
|
||||||
CGrowableArray<D3DFORMAT> m_DepthStencilPossibleList;
|
|
||||||
CGrowableArray<D3DMULTISAMPLE_TYPE> m_MultiSampleTypeList;
|
|
||||||
CGrowableArray<UINT> m_PresentIntervalList;
|
|
||||||
|
|
||||||
bool m_bSoftwareVP;
|
|
||||||
bool m_bHardwareVP;
|
|
||||||
bool m_bPureHarewareVP;
|
|
||||||
bool m_bMixedVP;
|
|
||||||
|
|
||||||
UINT m_nMinWidth;
|
|
||||||
UINT m_nMaxWidth;
|
|
||||||
UINT m_nMinHeight;
|
|
||||||
UINT m_nMaxHeight;
|
|
||||||
UINT m_nRefreshMin;
|
|
||||||
UINT m_nRefreshMax;
|
|
||||||
UINT m_nMultisampleQualityMax;
|
|
||||||
|
|
||||||
// Array of CD3D9EnumAdapterInfo* with unique AdapterOrdinals
|
|
||||||
CGrowableArray<CD3D9EnumAdapterInfo*> m_AdapterInfoList;
|
|
||||||
|
|
||||||
HRESULT EnumerateDevices( CD3D9EnumAdapterInfo* pAdapterInfo, CGrowableArray<D3DFORMAT>* pAdapterFormatList );
|
|
||||||
HRESULT EnumerateDeviceCombos( CD3D9EnumAdapterInfo* pAdapterInfo, CD3D9EnumDeviceInfo* pDeviceInfo, CGrowableArray<D3DFORMAT>* pAdapterFormatList );
|
|
||||||
void BuildDepthStencilFormatList( CD3D9EnumDeviceSettingsCombo* pDeviceCombo );
|
|
||||||
void BuildMultiSampleTypeList( CD3D9EnumDeviceSettingsCombo* pDeviceCombo );
|
|
||||||
void BuildDSMSConflictList( CD3D9EnumDeviceSettingsCombo* pDeviceCombo );
|
|
||||||
void BuildPresentIntervalList( CD3D9EnumDeviceInfo* pDeviceInfo, CD3D9EnumDeviceSettingsCombo* pDeviceCombo );
|
|
||||||
void ClearAdapterInfoList();
|
|
||||||
};
|
|
||||||
|
|
||||||
CD3D9Enumeration* WINAPI DXUTGetD3D9Enumeration( bool bForceEnumerate = false );
|
|
||||||
|
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------
|
|
||||||
// A class describing an adapter which contains a unique adapter ordinal
|
|
||||||
// that is installed on the system
|
|
||||||
//--------------------------------------------------------------------------------------
|
|
||||||
class CD3D9EnumAdapterInfo
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
~CD3D9EnumAdapterInfo();
|
|
||||||
|
|
||||||
UINT AdapterOrdinal;
|
|
||||||
D3DADAPTER_IDENTIFIER9 AdapterIdentifier;
|
|
||||||
WCHAR szUniqueDescription[256];
|
|
||||||
|
|
||||||
CGrowableArray <D3DDISPLAYMODE> displayModeList; // Array of supported D3DDISPLAYMODEs
|
|
||||||
CGrowableArray <CD3D9EnumDeviceInfo*> deviceInfoList; // Array of CD3D9EnumDeviceInfo* with unique supported DeviceTypes
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------
|
|
||||||
// A class describing a Direct3D device that contains a
|
|
||||||
// unique supported device type
|
|
||||||
//--------------------------------------------------------------------------------------
|
|
||||||
class CD3D9EnumDeviceInfo
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
~CD3D9EnumDeviceInfo();
|
|
||||||
|
|
||||||
UINT AdapterOrdinal;
|
|
||||||
D3DDEVTYPE DeviceType;
|
|
||||||
D3DCAPS9 Caps;
|
|
||||||
|
|
||||||
// List of CD3D9EnumDeviceSettingsCombo* with a unique set
|
|
||||||
// of AdapterFormat, BackBufferFormat, and Windowed
|
|
||||||
CGrowableArray <CD3D9EnumDeviceSettingsCombo*> deviceSettingsComboList;
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------
|
|
||||||
// A struct describing device settings that contains a unique combination of
|
|
||||||
// adapter format, back buffer format, and windowed that is compatible with a
|
|
||||||
// particular Direct3D device and the app.
|
|
||||||
//--------------------------------------------------------------------------------------
|
|
||||||
struct CD3D9EnumDeviceSettingsCombo
|
|
||||||
{
|
|
||||||
UINT AdapterOrdinal;
|
|
||||||
D3DDEVTYPE DeviceType;
|
|
||||||
D3DFORMAT AdapterFormat;
|
|
||||||
D3DFORMAT BackBufferFormat;
|
|
||||||
BOOL Windowed;
|
|
||||||
|
|
||||||
CGrowableArray <D3DFORMAT> depthStencilFormatList; // List of D3DFORMATs
|
|
||||||
CGrowableArray <D3DMULTISAMPLE_TYPE> multiSampleTypeList; // List of D3DMULTISAMPLE_TYPEs
|
|
||||||
CGrowableArray <DWORD> multiSampleQualityList; // List of number of quality levels for each multisample type
|
|
||||||
CGrowableArray <UINT> presentIntervalList; // List of D3DPRESENT flags
|
|
||||||
CGrowableArray <CD3D9EnumDSMSConflict> DSMSConflictList; // List of CD3D9EnumDSMSConflict
|
|
||||||
|
|
||||||
CD3D9EnumAdapterInfo* pAdapterInfo;
|
|
||||||
CD3D9EnumDeviceInfo* pDeviceInfo;
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------
|
|
||||||
// A depth/stencil buffer format that is incompatible with a
|
|
||||||
// multisample type.
|
|
||||||
//--------------------------------------------------------------------------------------
|
|
||||||
struct CD3D9EnumDSMSConflict
|
|
||||||
{
|
|
||||||
D3DFORMAT DSFormat;
|
|
||||||
D3DMULTISAMPLE_TYPE MSType;
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
float DXUTRankD3D9DeviceCombo( CD3D9EnumDeviceSettingsCombo* pDeviceSettingsCombo,
|
|
||||||
DXUTD3D9DeviceSettings* pOptimalDeviceSettings,
|
|
||||||
D3DDISPLAYMODE* pAdapterDesktopDisplayMode,
|
|
||||||
int &bestModeIndex,
|
|
||||||
int &bestMSAAIndex
|
|
||||||
);
|
|
||||||
|
|
||||||
|
|
||||||
#endif
|
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user