mirror of
https://github.com/bulletphysics/bullet3
synced 2025-01-10 17:30:12 +00:00
28e580c203
fixed several warnings, thanks to sparkprime added comments patch for linear math, thanks to Tully Foote
113 lines
3.5 KiB
C++
113 lines
3.5 KiB
C++
#ifndef CONVEX_BUILDER_H
|
|
#define CONVEX_BUILDER_H
|
|
|
|
/*----------------------------------------------------------------------
|
|
Copyright (c) 2004 Open Dynamics Framework Group
|
|
www.physicstools.org
|
|
All rights reserved.
|
|
|
|
Redistribution and use in source and binary forms, with or without modification, are permitted provided
|
|
that the following conditions are met:
|
|
|
|
Redistributions of source code must retain the above copyright notice, this list of conditions
|
|
and the following disclaimer.
|
|
|
|
Redistributions in binary form must reproduce the above copyright notice,
|
|
this list of conditions and the following disclaimer in the documentation
|
|
and/or other materials provided with the distribution.
|
|
|
|
Neither the name of the Open Dynamics Framework Group nor the names of its contributors may
|
|
be used to endorse or promote products derived from this software without specific prior written permission.
|
|
|
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 'AS IS' AND ANY EXPRESS OR IMPLIED WARRANTIES,
|
|
INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
|
DISCLAIMED. IN NO EVENT SHALL THE INTEL OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
|
EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
|
LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER
|
|
IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
|
|
THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
-----------------------------------------------------------------------*/
|
|
|
|
// http://codesuppository.blogspot.com
|
|
//
|
|
// mailto: jratcliff@infiniplex.net
|
|
//
|
|
// http://www.amillionpixels.us
|
|
//
|
|
|
|
|
|
#include "ConvexDecomposition.h"
|
|
#include "vlookup.h"
|
|
#include "LinearMath/btAlignedObjectArray.h"
|
|
|
|
using namespace ConvexDecomposition;
|
|
|
|
|
|
class CHull
|
|
{
|
|
public:
|
|
CHull(const ConvexResult &result);
|
|
|
|
~CHull(void);
|
|
|
|
bool overlap(const CHull &h) const;
|
|
|
|
float mMin[3];
|
|
float mMax[3];
|
|
float mVolume;
|
|
float mDiagonal; // long edge..
|
|
ConvexResult *mResult;
|
|
};
|
|
|
|
// Usage: std::sort( list.begin(), list.end(), StringSortRef() );
|
|
class CHullSort
|
|
{
|
|
public:
|
|
|
|
inline bool operator()(const CHull *a,const CHull *b) const
|
|
{
|
|
return a->mVolume < b->mVolume;
|
|
}
|
|
};
|
|
|
|
|
|
typedef btAlignedObjectArray< CHull * > CHullVector;
|
|
|
|
|
|
|
|
class ConvexBuilder : public ConvexDecompInterface
|
|
{
|
|
public:
|
|
ConvexBuilder(ConvexDecompInterface *callback);
|
|
|
|
virtual ~ConvexBuilder(void);
|
|
|
|
bool isDuplicate(unsigned int i1,unsigned int i2,unsigned int i3,
|
|
unsigned int ci1,unsigned int ci2,unsigned int ci3);
|
|
|
|
void getMesh(const ConvexResult &cr,VertexLookup vc,UintVector &indices);
|
|
|
|
CHull * canMerge(CHull *a,CHull *b);
|
|
|
|
bool combineHulls(void);
|
|
|
|
unsigned int process(const DecompDesc &desc);
|
|
|
|
virtual void ConvexDebugTri(const float *p1,const float *p2,const float *p3,unsigned int color);
|
|
|
|
virtual void ConvexDebugOBB(const float *sides, const float *matrix,unsigned int color);
|
|
virtual void ConvexDebugPoint(const float *p,float dist,unsigned int color);
|
|
|
|
virtual void ConvexDebugBound(const float *bmin,const float *bmax,unsigned int color);
|
|
|
|
virtual void ConvexDecompResult(ConvexResult &result);
|
|
|
|
void sortChulls(CHullVector &hulls);
|
|
|
|
CHullVector mChulls;
|
|
ConvexDecompInterface *mCallback;
|
|
};
|
|
|
|
#endif //CONVEX_BUILDER_H
|
|
|