2015-04-16 16:55:32 +00:00
|
|
|
/*
|
|
|
|
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>
|
|
|
|
|
2018-09-23 21:17:31 +00:00
|
|
|
void BspConverter::convertBsp(BspLoader& bspLoader, float scaling)
|
2015-04-16 16:55:32 +00:00
|
|
|
{
|
|
|
|
{
|
2018-09-23 21:17:31 +00:00
|
|
|
float playstartf[3] = {0, 0, 100};
|
2015-04-16 16:55:32 +00:00
|
|
|
|
2018-09-23 21:17:31 +00:00
|
|
|
if (bspLoader.findVectorByName(&playstartf[0], "info_player_start"))
|
2015-04-16 16:55:32 +00:00
|
|
|
{
|
|
|
|
printf("found playerstart\n");
|
2018-09-23 21:17:31 +00:00
|
|
|
}
|
2015-04-16 16:55:32 +00:00
|
|
|
else
|
|
|
|
{
|
2018-09-23 21:17:31 +00:00
|
|
|
if (bspLoader.findVectorByName(&playstartf[0], "info_player_deathmatch"))
|
2015-04-16 16:55:32 +00:00
|
|
|
{
|
|
|
|
printf("found deatchmatch start\n");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-09-23 21:17:31 +00:00
|
|
|
btVector3 playerStart(playstartf[0], playstartf[1], playstartf[2]);
|
2015-04-16 16:55:32 +00:00
|
|
|
|
2018-09-23 21:17:31 +00:00
|
|
|
playerStart[2] += 20.f; //start a bit higher
|
2015-04-16 16:55:32 +00:00
|
|
|
|
|
|
|
playerStart *= scaling;
|
|
|
|
|
|
|
|
//progressBegin("Loading bsp");
|
|
|
|
|
2018-09-23 21:17:31 +00:00
|
|
|
for (int i = 0; i < bspLoader.m_numleafs; i++)
|
2015-04-16 16:55:32 +00:00
|
|
|
{
|
2018-09-23 21:17:31 +00:00
|
|
|
printf("Reading bspLeaf %i from total %i (%f procent)\n", i, bspLoader.m_numleafs, (100.f * (float)i / float(bspLoader.m_numleafs)));
|
|
|
|
|
2015-04-16 16:55:32 +00:00
|
|
|
bool isValidBrush = false;
|
2018-09-23 21:17:31 +00:00
|
|
|
|
|
|
|
BSPLeaf& leaf = bspLoader.m_dleafs[i];
|
|
|
|
|
|
|
|
for (int b = 0; b < leaf.numLeafBrushes; b++)
|
2015-04-16 16:55:32 +00:00
|
|
|
{
|
|
|
|
btAlignedObjectArray<btVector3> planeEquations;
|
2018-09-23 21:17:31 +00:00
|
|
|
|
|
|
|
int brushid = bspLoader.m_dleafbrushes[leaf.firstLeafBrush + b];
|
2015-04-16 16:55:32 +00:00
|
|
|
|
|
|
|
BSPBrush& brush = bspLoader.m_dbrushes[brushid];
|
2018-09-23 21:17:31 +00:00
|
|
|
if (brush.shaderNum != -1)
|
2015-04-16 16:55:32 +00:00
|
|
|
{
|
2018-09-23 21:17:31 +00:00
|
|
|
if (bspLoader.m_dshaders[brush.shaderNum].contentFlags & BSPCONTENTS_SOLID)
|
2015-04-16 16:55:32 +00:00
|
|
|
{
|
|
|
|
brush.shaderNum = -1;
|
|
|
|
|
2018-09-23 21:17:31 +00:00
|
|
|
for (int p = 0; p < brush.numSides; p++)
|
2015-04-16 16:55:32 +00:00
|
|
|
{
|
2018-09-23 21:17:31 +00:00
|
|
|
int sideid = brush.firstSide + p;
|
2015-04-16 16:55:32 +00:00
|
|
|
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]);
|
2018-09-23 21:17:31 +00:00
|
|
|
planeEq[3] = scaling * -plane.dist;
|
2015-04-16 16:55:32 +00:00
|
|
|
|
|
|
|
planeEquations.push_back(planeEq);
|
2018-09-23 21:17:31 +00:00
|
|
|
isValidBrush = true;
|
2015-04-16 16:55:32 +00:00
|
|
|
}
|
|
|
|
if (isValidBrush)
|
|
|
|
{
|
2018-09-23 21:17:31 +00:00
|
|
|
btAlignedObjectArray<btVector3> vertices;
|
|
|
|
btGeometryUtil::getVerticesFromPlaneEquations(planeEquations, vertices);
|
2015-04-16 16:55:32 +00:00
|
|
|
|
|
|
|
bool isEntity = false;
|
2018-09-23 21:17:31 +00:00
|
|
|
btVector3 entityTarget(0.f, 0.f, 0.f);
|
|
|
|
addConvexVerticesCollider(vertices, isEntity, entityTarget);
|
2015-04-16 16:55:32 +00:00
|
|
|
}
|
|
|
|
}
|
2018-09-23 21:17:31 +00:00
|
|
|
}
|
2015-04-16 16:55:32 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#define USE_ENTITIES
|
|
|
|
#ifdef USE_ENTITIES
|
|
|
|
|
|
|
|
{
|
|
|
|
int i;
|
2018-09-23 21:17:31 +00:00
|
|
|
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"))
|
2015-04-16 16:55:32 +00:00
|
|
|
{
|
2018-09-23 21:17:31 +00:00
|
|
|
btVector3 targetLocation(0.f, 0.f, 0.f);
|
2015-04-16 16:55:32 +00:00
|
|
|
|
2018-09-23 21:17:31 +00:00
|
|
|
cl = bspLoader.getValueForKey(&entity, "target");
|
|
|
|
if (strcmp(cl, ""))
|
|
|
|
{
|
|
|
|
//its not empty so ...
|
2015-04-16 16:55:32 +00:00
|
|
|
|
2018-09-23 21:17:31 +00:00
|
|
|
/*
|
2015-04-16 16:55:32 +00:00
|
|
|
//lookup the target position for the jumppad:
|
|
|
|
const BSPEntity* targetentity = bspLoader.getEntityByValue( "targetname" , cl );
|
|
|
|
if (targetentity)
|
|
|
|
{
|
|
|
|
if (bspLoader.getVectorForKey( targetentity , "origin",&targetLocation[0]))
|
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
*/
|
|
|
|
|
2018-09-23 21:17:31 +00:00
|
|
|
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))
|
2015-04-16 16:55:32 +00:00
|
|
|
{
|
2018-09-23 21:17:31 +00:00
|
|
|
const BSPModel& model = bspLoader.m_dmodels[modelnr];
|
|
|
|
for (int n = 0; n < model.numBrushes; n++)
|
2015-04-16 16:55:32 +00:00
|
|
|
{
|
2018-09-23 21:17:31 +00:00
|
|
|
btAlignedObjectArray<btVector3> planeEquations;
|
|
|
|
bool isValidBrush = false;
|
2015-04-16 16:55:32 +00:00
|
|
|
|
2018-09-23 21:17:31 +00:00
|
|
|
//convert brush
|
|
|
|
const BSPBrush& brush = bspLoader.m_dbrushes[model.firstBrush + n];
|
|
|
|
{
|
|
|
|
for (int p = 0; p < brush.numSides; p++)
|
2015-04-16 16:55:32 +00:00
|
|
|
{
|
2018-09-23 21:17:31 +00:00
|
|
|
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;
|
2015-04-16 16:55:32 +00:00
|
|
|
}
|
2018-09-23 21:17:31 +00:00
|
|
|
if (isValidBrush)
|
|
|
|
{
|
|
|
|
btAlignedObjectArray<btVector3> vertices;
|
|
|
|
btGeometryUtil::getVerticesFromPlaneEquations(planeEquations, vertices);
|
2015-04-16 16:55:32 +00:00
|
|
|
|
2018-09-23 21:17:31 +00:00
|
|
|
bool isEntity = true;
|
|
|
|
addConvexVerticesCollider(vertices, isEntity, targetLocation);
|
|
|
|
}
|
2015-04-16 16:55:32 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2018-09-23 21:17:31 +00:00
|
|
|
else
|
|
|
|
{
|
|
|
|
printf("unsupported trigger_push model, md3 ?\n");
|
|
|
|
}
|
2015-04-16 16:55:32 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2018-09-23 21:17:31 +00:00
|
|
|
}
|
2015-04-16 16:55:32 +00:00
|
|
|
|
2018-09-23 21:17:31 +00:00
|
|
|
#endif //USE_ENTITIES
|
2015-04-16 16:55:32 +00:00
|
|
|
|
|
|
|
//progressEnd();
|
|
|
|
}
|
2018-09-23 21:17:31 +00:00
|
|
|
}
|