Code rework. Basically cleaned up a mess of tabs and whitespaces.
This commit is contained in:
parent
1585195779
commit
e91d045a37
@ -27,14 +27,14 @@ void Application::init()
|
|||||||
ACGL::Base::Settings::the()->setShaderPath(shaderPath);
|
ACGL::Base::Settings::the()->setShaderPath(shaderPath);
|
||||||
ACGL::Base::Settings::the()->setTexturePath(texturePath);
|
ACGL::Base::Settings::the()->setTexturePath(texturePath);
|
||||||
ACGL::Base::Settings::the()->setGeometryPath(geometryPath);
|
ACGL::Base::Settings::the()->setGeometryPath(geometryPath);
|
||||||
|
|
||||||
// load Level
|
// load Level
|
||||||
level.load();
|
level.load();
|
||||||
Loader loader = Loader();
|
Loader loader = Loader();
|
||||||
std::string levelXmlFilePath = levelXmlPath + "Level1.xml";
|
std::string levelXmlFilePath = levelXmlPath + "Level1.xml";
|
||||||
loader.load(levelXmlFilePath, &level, compositionsPath, scriptPath);
|
loader.load(levelXmlFilePath, &level, compositionsPath, scriptPath);
|
||||||
graphics.init(&level);
|
graphics.init(&level);
|
||||||
|
|
||||||
// just in case: check for errors
|
// just in case: check for errors
|
||||||
openGLCriticalError();
|
openGLCriticalError();
|
||||||
}
|
}
|
||||||
|
@ -13,9 +13,8 @@ class Converter {
|
|||||||
~Converter();
|
~Converter();
|
||||||
void updateComposition(int idG, int idB, float posX, float posZ); //updates the position of a composition
|
void updateComposition(int idG, int idB, float posX, float posZ); //updates the position of a composition
|
||||||
std::vector<int> newComposition(int type, float posX, float posZ);//creates a new composition and returns its ID
|
std::vector<int> newComposition(int type, float posX, float posZ);//creates a new composition and returns its ID
|
||||||
void deleteComposition(int idG, int idB);
|
void deleteComposition(int idG, int idB);
|
||||||
void save(); //writes the xml to file
|
void save(); //writes the xml to file
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void errorCheck(XMLError error);
|
void errorCheck(XMLError error);
|
||||||
std::vector<int> nextID;
|
std::vector<int> nextID;
|
||||||
|
@ -7,7 +7,7 @@ class Entity {
|
|||||||
public:
|
public:
|
||||||
Entity(glm::vec3 position, glm::vec3 rotation);
|
Entity(glm::vec3 position, glm::vec3 rotation);
|
||||||
Entity(glm::vec3 position, glm::mat4 rotation);
|
Entity(glm::vec3 position, glm::mat4 rotation);
|
||||||
Entity();
|
Entity();
|
||||||
~Entity();
|
~Entity();
|
||||||
void setPosition(glm::vec3 positon);
|
void setPosition(glm::vec3 positon);
|
||||||
void setRotation(glm::vec3 rotation);
|
void setRotation(glm::vec3 rotation);
|
||||||
|
49
graphics.cc
49
graphics.cc
@ -22,10 +22,10 @@ Graphics::Graphics() {
|
|||||||
void Graphics::init(Level* level) {
|
void Graphics::init(Level* level) {
|
||||||
// save Level
|
// save Level
|
||||||
this->level = level;
|
this->level = level;
|
||||||
|
|
||||||
// update lights on creation
|
// update lights on creation
|
||||||
lastUpdate = -lightUpdateDelay;
|
lastUpdate = -lightUpdateDelay;
|
||||||
|
|
||||||
// construct VAO to give shader correct Attribute locations
|
// construct VAO to give shader correct Attribute locations
|
||||||
SharedArrayBuffer ab = SharedArrayBuffer(new ArrayBuffer());
|
SharedArrayBuffer ab = SharedArrayBuffer(new ArrayBuffer());
|
||||||
ab->defineAttribute("aPosition", GL_FLOAT, 3);
|
ab->defineAttribute("aPosition", GL_FLOAT, 3);
|
||||||
@ -33,25 +33,25 @@ void Graphics::init(Level* level) {
|
|||||||
ab->defineAttribute("aNormal", GL_FLOAT, 3);
|
ab->defineAttribute("aNormal", GL_FLOAT, 3);
|
||||||
SharedVertexArrayObject vao = SharedVertexArrayObject(new VertexArrayObject());
|
SharedVertexArrayObject vao = SharedVertexArrayObject(new VertexArrayObject());
|
||||||
vao->attachAllAttributes(ab);
|
vao->attachAllAttributes(ab);
|
||||||
|
|
||||||
// look up all shader files starting with 'phong' and build a ShaderProgram from it:
|
// look up all shader files starting with 'phong' and build a ShaderProgram from it:
|
||||||
lightingShader = ShaderProgramCreator("phong").attributeLocations(
|
lightingShader = ShaderProgramCreator("phong").attributeLocations(
|
||||||
vao->getAttributeLocations()).create();
|
vao->getAttributeLocations()).create();
|
||||||
|
|
||||||
depthShader = ShaderProgramCreator("depth")
|
depthShader = ShaderProgramCreator("depth")
|
||||||
.attributeLocations(vao->getAttributeLocations()).create();
|
.attributeLocations(vao->getAttributeLocations()).create();
|
||||||
|
|
||||||
depthTexture = SharedTexture2D( new Texture2D(windowSize, GL_DEPTH_COMPONENT16));
|
depthTexture = SharedTexture2D( new Texture2D(windowSize, GL_DEPTH_COMPONENT16));
|
||||||
depthTexture->setMinFilter(GL_NEAREST);
|
depthTexture->setMinFilter(GL_NEAREST);
|
||||||
depthTexture->setMagFilter(GL_NEAREST);
|
depthTexture->setMagFilter(GL_NEAREST);
|
||||||
depthTexture->setWrapS(GL_CLAMP_TO_EDGE);
|
depthTexture->setWrapS(GL_CLAMP_TO_EDGE);
|
||||||
depthTexture->setWrapT(GL_CLAMP_TO_EDGE);
|
depthTexture->setWrapT(GL_CLAMP_TO_EDGE);
|
||||||
depthTexture->setCompareMode(GL_COMPARE_REF_TO_TEXTURE);
|
depthTexture->setCompareMode(GL_COMPARE_REF_TO_TEXTURE);
|
||||||
|
|
||||||
framebuffer = SharedFrameBufferObject(new FrameBufferObject());
|
framebuffer = SharedFrameBufferObject(new FrameBufferObject());
|
||||||
framebuffer->setDepthTexture(depthTexture);
|
framebuffer->setDepthTexture(depthTexture);
|
||||||
framebuffer->validate();
|
framebuffer->validate();
|
||||||
|
|
||||||
/*depth_cubeMaps = std::vector<ACGL::OpenGL::SharedTextureCubeMap>(level->getLights()->size());
|
/*depth_cubeMaps = std::vector<ACGL::OpenGL::SharedTextureCubeMap>(level->getLights()->size());
|
||||||
for (unsigned int i = 0; i<depth_cubeMaps.size(); i++) {*/
|
for (unsigned int i = 0; i<depth_cubeMaps.size(); i++) {*/
|
||||||
depth_cubeMaps = std::vector<ACGL::OpenGL::SharedTextureCubeMap>(std::min(int(level->getLights()->size()), 1));
|
depth_cubeMaps = std::vector<ACGL::OpenGL::SharedTextureCubeMap>(std::min(int(level->getLights()->size()), 1));
|
||||||
@ -63,9 +63,9 @@ void Graphics::init(Level* level) {
|
|||||||
depth_cubeMaps.at(i)->setWrapT(GL_CLAMP_TO_EDGE);
|
depth_cubeMaps.at(i)->setWrapT(GL_CLAMP_TO_EDGE);
|
||||||
depth_cubeMaps.at(i)->setCompareMode(GL_COMPARE_REF_TO_TEXTURE);
|
depth_cubeMaps.at(i)->setCompareMode(GL_COMPARE_REF_TO_TEXTURE);
|
||||||
}
|
}
|
||||||
|
|
||||||
framebuffer_cube = SharedFrameBufferObject(new FrameBufferObject());
|
framebuffer_cube = SharedFrameBufferObject(new FrameBufferObject());
|
||||||
|
|
||||||
depthTexture_cube = SharedTexture2D( new Texture2D(windowSize, GL_DEPTH_COMPONENT16));
|
depthTexture_cube = SharedTexture2D( new Texture2D(windowSize, GL_DEPTH_COMPONENT16));
|
||||||
depthTexture_cube->setMinFilter(GL_NEAREST);
|
depthTexture_cube->setMinFilter(GL_NEAREST);
|
||||||
depthTexture_cube->setMagFilter(GL_NEAREST);
|
depthTexture_cube->setMagFilter(GL_NEAREST);
|
||||||
@ -87,7 +87,7 @@ void Graphics::render(double time)
|
|||||||
glm::mat4 depthProjectionMatrix_pointlights = glm::perspective(1.571f, (float)cube_size/(float)cube_size, 0.1f, farPlane);
|
glm::mat4 depthProjectionMatrix_pointlights = glm::perspective(1.571f, (float)cube_size/(float)cube_size, 0.1f, farPlane);
|
||||||
glm::vec3 looking_directions[6] = {glm::vec3(-1.0f, 0.0f, 0.0f), glm::vec3(1.0f, 0.0f, 0.0f), glm::vec3(0.0f, 1.0f, 0.0f),
|
glm::vec3 looking_directions[6] = {glm::vec3(-1.0f, 0.0f, 0.0f), glm::vec3(1.0f, 0.0f, 0.0f), glm::vec3(0.0f, 1.0f, 0.0f),
|
||||||
glm::vec3(0.0f, -1.0f, 0.0f), glm::vec3(0.0f, 0.0f, 1.0f), glm::vec3(0.0f, 0.0f, -1.0f)};
|
glm::vec3(0.0f, -1.0f, 0.0f), glm::vec3(0.0f, 0.0f, 1.0f), glm::vec3(0.0f, 0.0f, -1.0f)};
|
||||||
|
|
||||||
framebuffer_cube->bind();
|
framebuffer_cube->bind();
|
||||||
//for (unsigned int i_pointlight = 0; i_pointlight<level->getLights()->size(); i_pointlight++) {
|
//for (unsigned int i_pointlight = 0; i_pointlight<level->getLights()->size(); i_pointlight++) {
|
||||||
for (unsigned int i_pointlight = 0; i_pointlight<1 && i_pointlight<level->getLights()->size(); i_pointlight++) {
|
for (unsigned int i_pointlight = 0; i_pointlight<1 && i_pointlight<level->getLights()->size(); i_pointlight++) {
|
||||||
@ -116,19 +116,19 @@ void Graphics::render(double time)
|
|||||||
if (!framebuffer->isFrameBufferObjectComplete()) {
|
if (!framebuffer->isFrameBufferObjectComplete()) {
|
||||||
printf("Framebuffer incomplete, unknown error occured during shadow generation!\n");
|
printf("Framebuffer incomplete, unknown error occured during shadow generation!\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
// final render pass
|
// final render pass
|
||||||
glBindFramebuffer(GL_FRAMEBUFFER, 0);
|
glBindFramebuffer(GL_FRAMEBUFFER, 0);
|
||||||
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
||||||
|
|
||||||
lightingShader->use();
|
lightingShader->use();
|
||||||
|
|
||||||
if (level->getLights()->size() > 0) {
|
if (level->getLights()->size() > 0) {
|
||||||
lightingShader->setTexture("shadowMap_cube", depth_cubeMaps.at(0), 4);
|
lightingShader->setTexture("shadowMap_cube", depth_cubeMaps.at(0), 4);
|
||||||
}
|
}
|
||||||
|
|
||||||
//set lighting parameters
|
//set lighting parameters
|
||||||
|
|
||||||
// TODO look into doing this less often, offload to another thread?
|
// TODO look into doing this less often, offload to another thread?
|
||||||
// TODO figure out how to deal with bigger numbers of lights. load the nearest on demand?
|
// TODO figure out how to deal with bigger numbers of lights. load the nearest on demand?
|
||||||
double nextUpdate = lastUpdate + lightUpdateDelay;
|
double nextUpdate = lastUpdate + lightUpdateDelay;
|
||||||
@ -137,7 +137,7 @@ void Graphics::render(double time)
|
|||||||
updateLights();
|
updateLights();
|
||||||
lastUpdate = time;
|
lastUpdate = time;
|
||||||
}
|
}
|
||||||
|
|
||||||
// convert texture to homogenouse coordinates
|
// convert texture to homogenouse coordinates
|
||||||
glm::mat4 biasMatrix(
|
glm::mat4 biasMatrix(
|
||||||
0.5, 0.0, 0.0, 0.0,
|
0.5, 0.0, 0.0, 0.0,
|
||||||
@ -146,25 +146,25 @@ void Graphics::render(double time)
|
|||||||
0.5, 0.5, 0.5, 1.0
|
0.5, 0.5, 0.5, 1.0
|
||||||
);
|
);
|
||||||
glm::mat4 depthBiasVP = biasMatrix*depthViewProjectionMatrix;
|
glm::mat4 depthBiasVP = biasMatrix*depthViewProjectionMatrix;
|
||||||
|
|
||||||
lightingShader->setTexture("shadowMap", depthTexture, 1);
|
lightingShader->setTexture("shadowMap", depthTexture, 1);
|
||||||
|
|
||||||
lightingShader->setUniform("farPlane", farPlane);
|
lightingShader->setUniform("farPlane", farPlane);
|
||||||
|
|
||||||
// set fog Parameters
|
// set fog Parameters
|
||||||
lightingShader->setUniform("fogColor", level->getFogColour());
|
lightingShader->setUniform("fogColor", level->getFogColour());
|
||||||
lightingShader->setUniform("cameraCenter", level->getCameraCenter()->getPosition());
|
lightingShader->setUniform("cameraCenter", level->getCameraCenter()->getPosition());
|
||||||
|
|
||||||
// set Material Parameters
|
// set Material Parameters
|
||||||
lightingShader->setUniform("ambientColor", level->getAmbientLight());
|
lightingShader->setUniform("ambientColor", level->getAmbientLight());
|
||||||
lightingShader->setUniform("camera", level->getCameraPosition());
|
lightingShader->setUniform("camera", level->getCameraPosition());
|
||||||
|
|
||||||
//set view and projection matrix
|
//set view and projection matrix
|
||||||
glm::mat4 lightingViewProjectionMatrix = glm::perspective(1.571f, (float)windowSize.x/(float)windowSize.y, 0.1f, farPlane) * buildViewMatrix(level);
|
glm::mat4 lightingViewProjectionMatrix = glm::perspective(1.571f, (float)windowSize.x/(float)windowSize.y, 0.1f, farPlane) * buildViewMatrix(level);
|
||||||
|
|
||||||
std::vector<glm::mat4> shadowVPs = std::vector<glm::mat4>();
|
std::vector<glm::mat4> shadowVPs = std::vector<glm::mat4>();
|
||||||
shadowVPs.push_back(depthBiasVP);
|
shadowVPs.push_back(depthBiasVP);
|
||||||
|
|
||||||
// render the level
|
// render the level
|
||||||
level->render(lightingShader, true, &lightingViewProjectionMatrix, &shadowVPs);
|
level->render(lightingShader, true, &lightingViewProjectionMatrix, &shadowVPs);
|
||||||
}
|
}
|
||||||
@ -172,7 +172,7 @@ void Graphics::render(double time)
|
|||||||
void Graphics::updateLights() {
|
void Graphics::updateLights() {
|
||||||
if (level->getLights()->size() > 0) {
|
if (level->getLights()->size() > 0) {
|
||||||
lightingShader->setUniform("lightCount", (int) level->getLights()->size());
|
lightingShader->setUniform("lightCount", (int) level->getLights()->size());
|
||||||
|
|
||||||
// Build light position array
|
// Build light position array
|
||||||
glm::vec3 lightSources[level->getLights()->size()];
|
glm::vec3 lightSources[level->getLights()->size()];
|
||||||
for(unsigned int i = 0; i<level->getLights()->size(); i++) {
|
for(unsigned int i = 0; i<level->getLights()->size(); i++) {
|
||||||
@ -217,7 +217,6 @@ glm::mat4 Graphics::buildViewMatrix(Level* level) {
|
|||||||
|
|
||||||
return glm::lookAt((level->getCameraCenter()->getPosition() + level->getCamera()->getVector()),
|
return glm::lookAt((level->getCameraCenter()->getPosition() + level->getCamera()->getVector()),
|
||||||
level->getCameraCenter()->getPosition(), glm::vec3(0.0f, 1.0f, 0.0f));
|
level->getCameraCenter()->getPosition(), glm::vec3(0.0f, 1.0f, 0.0f));
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
float Graphics::getFarPlane() {
|
float Graphics::getFarPlane() {
|
||||||
|
6
level.cc
6
level.cc
@ -40,7 +40,7 @@ void Level::load() {
|
|||||||
//Push the level to Lua as a global variable
|
//Push the level to Lua as a global variable
|
||||||
luabridge::push(luaState, this);
|
luabridge::push(luaState, this);
|
||||||
lua_setglobal(luaState, "level");
|
lua_setglobal(luaState, "level");
|
||||||
|
|
||||||
this->camera = Camera(glm::vec2(-0.8f, 0.0f), 3.0f);
|
this->camera = Camera(glm::vec2(-0.8f, 0.0f), 3.0f);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -68,7 +68,7 @@ void Level::update(float runTime, glm::vec2 mouseDelta, bool wPressed, bool aPre
|
|||||||
|
|
||||||
camera.setPosition(physics.getCameraPosition());
|
camera.setPosition(physics.getCameraPosition());
|
||||||
camera.setDirection(physics.getCameraToPlayer());
|
camera.setDirection(physics.getCameraToPlayer());
|
||||||
}
|
}
|
||||||
if(wPressed){
|
if(wPressed){
|
||||||
physics.rollForward(camera.getVector(),strength);
|
physics.rollForward(camera.getVector(),strength);
|
||||||
}
|
}
|
||||||
@ -149,7 +149,7 @@ void Level::moveObject(int objectIndex, float strength, float xPos, float yPos,
|
|||||||
glm::vec3 position = glm::vec3(xPos, yPos, zPos);
|
glm::vec3 position = glm::vec3(xPos, yPos, zPos);
|
||||||
physics.removePositionConstraint(objectIndex);
|
physics.removePositionConstraint(objectIndex);
|
||||||
physics.addPositionConstraint(objectIndex, strength, position);
|
physics.addPositionConstraint(objectIndex, strength, position);
|
||||||
}
|
}
|
||||||
|
|
||||||
//should not be used since objects does not get synchronized and deletion is not implemented in pyhsics
|
//should not be used since objects does not get synchronized and deletion is not implemented in pyhsics
|
||||||
void Level::deleteObject(int objectIndex){
|
void Level::deleteObject(int objectIndex){
|
||||||
|
32
loader.cc
32
loader.cc
@ -20,35 +20,35 @@ void Loader::loadConfig(Application* application) {
|
|||||||
errorCheck(resolution->FirstChildElement("height")->QueryIntText(&windowHeight));
|
errorCheck(resolution->FirstChildElement("height")->QueryIntText(&windowHeight));
|
||||||
errorCheck(config->FirstChildElement("shadowCubeSize")->QueryIntText(&shadowCubeSize));
|
errorCheck(config->FirstChildElement("shadowCubeSize")->QueryIntText(&shadowCubeSize));
|
||||||
errorCheck(config->FirstChildElement("farPlane")->QueryFloatText(&farPlane));
|
errorCheck(config->FirstChildElement("farPlane")->QueryFloatText(&farPlane));
|
||||||
|
|
||||||
const char* charCompositionsPath = config->FirstChildElement("compositionsPath")->GetText();
|
const char* charCompositionsPath = config->FirstChildElement("compositionsPath")->GetText();
|
||||||
if(charCompositionsPath == NULL){
|
if(charCompositionsPath == NULL){
|
||||||
printf("XMLError: No compositionsPath found.\n");
|
printf("XMLError: No compositionsPath found.\n");
|
||||||
exit(-1);
|
exit(-1);
|
||||||
}
|
}
|
||||||
compositionsPath = charCompositionsPath;
|
compositionsPath = charCompositionsPath;
|
||||||
|
|
||||||
const char* charShaderPath = config->FirstChildElement("shaderPath")->GetText();
|
const char* charShaderPath = config->FirstChildElement("shaderPath")->GetText();
|
||||||
if(charShaderPath == NULL){
|
if(charShaderPath == NULL){
|
||||||
printf("XMLError: No shaderPath found.\n");
|
printf("XMLError: No shaderPath found.\n");
|
||||||
exit(-1);
|
exit(-1);
|
||||||
}
|
}
|
||||||
shaderPath = charShaderPath;
|
shaderPath = charShaderPath;
|
||||||
|
|
||||||
const char* charGeometryPath = config->FirstChildElement("geometryPath")->GetText();
|
const char* charGeometryPath = config->FirstChildElement("geometryPath")->GetText();
|
||||||
if(charGeometryPath == NULL){
|
if(charGeometryPath == NULL){
|
||||||
printf("XMLError: No geometryPath found.\n");
|
printf("XMLError: No geometryPath found.\n");
|
||||||
exit(-1);
|
exit(-1);
|
||||||
}
|
}
|
||||||
geometryPath = charGeometryPath;
|
geometryPath = charGeometryPath;
|
||||||
|
|
||||||
const char* charTexturePath = config->FirstChildElement("texturePath")->GetText();
|
const char* charTexturePath = config->FirstChildElement("texturePath")->GetText();
|
||||||
if(charTexturePath == NULL){
|
if(charTexturePath == NULL){
|
||||||
printf("XMLError: No texturePath found.\n");
|
printf("XMLError: No texturePath found.\n");
|
||||||
exit(-1);
|
exit(-1);
|
||||||
}
|
}
|
||||||
texturePath = charTexturePath;
|
texturePath = charTexturePath;
|
||||||
|
|
||||||
const char* charScriptPath = config->FirstChildElement("scriptPath")->GetText();
|
const char* charScriptPath = config->FirstChildElement("scriptPath")->GetText();
|
||||||
if(charScriptPath == NULL){
|
if(charScriptPath == NULL){
|
||||||
printf("XMLError: No scriptPath found.\n");
|
printf("XMLError: No scriptPath found.\n");
|
||||||
@ -62,7 +62,7 @@ void Loader::loadConfig(Application* application) {
|
|||||||
exit(-1);
|
exit(-1);
|
||||||
}
|
}
|
||||||
heightmapPath = charHeightmapPath;
|
heightmapPath = charHeightmapPath;
|
||||||
|
|
||||||
const char* charLevelXmlPath = config->FirstChildElement("levelXmlPath")->GetText();
|
const char* charLevelXmlPath = config->FirstChildElement("levelXmlPath")->GetText();
|
||||||
if(charLevelXmlPath == NULL){
|
if(charLevelXmlPath == NULL){
|
||||||
printf("XMLError: No levelXmlPath found.\n");
|
printf("XMLError: No levelXmlPath found.\n");
|
||||||
@ -116,11 +116,11 @@ void Loader::load(std::string filePath, Level* level, std::string compositionsPa
|
|||||||
errorCheck(terrainElement->FirstChildElement("shininess")->QueryFloatText(&terrainShininess));
|
errorCheck(terrainElement->FirstChildElement("shininess")->QueryFloatText(&terrainShininess));
|
||||||
Material terrainMaterial = Material(terrainTexture, terrainAmbientFactor, terrainDiffuseFactor, terrainSpecularFactor, terrainShininess);
|
Material terrainMaterial = Material(terrainTexture, terrainAmbientFactor, terrainDiffuseFactor, terrainSpecularFactor, terrainShininess);
|
||||||
Object* terrainObject = new Object(terrainModel, terrainMaterial,
|
Object* terrainObject = new Object(terrainModel, terrainMaterial,
|
||||||
glm::vec3(-0.5*(float)level->getTerrain()->getHeightmapHeight(), 0.0f, -0.5f*(float)level->getTerrain()->getHeightmapWidth()),
|
glm::vec3(-0.5*(float)level->getTerrain()->getHeightmapHeight(), 0.0f, -0.5f*(float)level->getTerrain()->getHeightmapWidth()),
|
||||||
glm::vec3(0.0f, 0.0f, 0.0f), true);
|
glm::vec3(0.0f, 0.0f, 0.0f), true);
|
||||||
level->addObject(terrainObject);
|
level->addObject(terrainObject);
|
||||||
level->getPhysics()->addTerrain(level->getTerrain()->getHeightmapWidth(), level->getTerrain()->getHeightmapHeight(), level->getTerrain()->getHeightmap());
|
level->getPhysics()->addTerrain(level->getTerrain()->getHeightmapWidth(), level->getTerrain()->getHeightmapHeight(), level->getTerrain()->getHeightmap());
|
||||||
|
|
||||||
//load the skydome
|
//load the skydome
|
||||||
XMLElement* skydomeElement = doc->FirstChildElement("skydome");
|
XMLElement* skydomeElement = doc->FirstChildElement("skydome");
|
||||||
const char* charSkydomeTexture = skydomeElement->FirstChildElement("texture")->GetText();
|
const char* charSkydomeTexture = skydomeElement->FirstChildElement("texture")->GetText();
|
||||||
@ -135,7 +135,7 @@ void Loader::load(std::string filePath, Level* level, std::string compositionsPa
|
|||||||
glm::vec3(0.0f, 0.0f, 0.0f), true);
|
glm::vec3(0.0f, 0.0f, 0.0f), true);
|
||||||
level->addObject(skydomeObject);
|
level->addObject(skydomeObject);
|
||||||
level->setSkydomeObject(skydomeObject);
|
level->setSkydomeObject(skydomeObject);
|
||||||
|
|
||||||
//load lighting parameters
|
//load lighting parameters
|
||||||
float rColour, gColour, bColour, alpha, xOffset, yOffset, zOffset, intensity;
|
float rColour, gColour, bColour, alpha, xOffset, yOffset, zOffset, intensity;
|
||||||
XMLElement* ambientElement = doc->FirstChildElement("ambientLight");
|
XMLElement* ambientElement = doc->FirstChildElement("ambientLight");
|
||||||
@ -143,14 +143,14 @@ void Loader::load(std::string filePath, Level* level, std::string compositionsPa
|
|||||||
errorCheck(ambientElement->FirstChildElement("gColour")->QueryFloatText(&gColour));
|
errorCheck(ambientElement->FirstChildElement("gColour")->QueryFloatText(&gColour));
|
||||||
errorCheck(ambientElement->FirstChildElement("bColour")->QueryFloatText(&bColour));
|
errorCheck(ambientElement->FirstChildElement("bColour")->QueryFloatText(&bColour));
|
||||||
level->setAmbientLight(glm::vec3(rColour,gColour,bColour));
|
level->setAmbientLight(glm::vec3(rColour,gColour,bColour));
|
||||||
|
|
||||||
XMLElement* fogElement = doc->FirstChildElement("fogColour");
|
XMLElement* fogElement = doc->FirstChildElement("fogColour");
|
||||||
errorCheck(fogElement->FirstChildElement("rColour")->QueryFloatText(&rColour));
|
errorCheck(fogElement->FirstChildElement("rColour")->QueryFloatText(&rColour));
|
||||||
errorCheck(fogElement->FirstChildElement("gColour")->QueryFloatText(&gColour));
|
errorCheck(fogElement->FirstChildElement("gColour")->QueryFloatText(&gColour));
|
||||||
errorCheck(fogElement->FirstChildElement("bColour")->QueryFloatText(&bColour));
|
errorCheck(fogElement->FirstChildElement("bColour")->QueryFloatText(&bColour));
|
||||||
errorCheck(fogElement->FirstChildElement("alpha")->QueryFloatText(&alpha));
|
errorCheck(fogElement->FirstChildElement("alpha")->QueryFloatText(&alpha));
|
||||||
level->setFogColour(glm::vec4(rColour,gColour,bColour, alpha));
|
level->setFogColour(glm::vec4(rColour,gColour,bColour, alpha));
|
||||||
|
|
||||||
XMLElement* directionalElement = doc->FirstChildElement("directionalLight");
|
XMLElement* directionalElement = doc->FirstChildElement("directionalLight");
|
||||||
errorCheck(directionalElement->FirstChildElement("xOffset")->QueryFloatText(&xOffset));
|
errorCheck(directionalElement->FirstChildElement("xOffset")->QueryFloatText(&xOffset));
|
||||||
errorCheck(directionalElement->FirstChildElement("yOffset")->QueryFloatText(&yOffset));
|
errorCheck(directionalElement->FirstChildElement("yOffset")->QueryFloatText(&yOffset));
|
||||||
@ -160,7 +160,7 @@ void Loader::load(std::string filePath, Level* level, std::string compositionsPa
|
|||||||
errorCheck(directionalElement->FirstChildElement("bColour")->QueryFloatText(&bColour));
|
errorCheck(directionalElement->FirstChildElement("bColour")->QueryFloatText(&bColour));
|
||||||
errorCheck(directionalElement->FirstChildElement("intensity")->QueryFloatText(&intensity));
|
errorCheck(directionalElement->FirstChildElement("intensity")->QueryFloatText(&intensity));
|
||||||
level->setDirectionalLight(Light(glm::vec3(xOffset,yOffset,zOffset), glm::vec3(rColour,gColour,bColour), intensity));
|
level->setDirectionalLight(Light(glm::vec3(xOffset,yOffset,zOffset), glm::vec3(rColour,gColour,bColour), intensity));
|
||||||
|
|
||||||
//load Objects
|
//load Objects
|
||||||
std::vector<std::vector<int>> objectIdentifiers = std::vector<std::vector<int>>(); //The first entry is the index in objects, the second one the index in physicObjects, the others are idGreen, idBlue and objectNum.
|
std::vector<std::vector<int>> objectIdentifiers = std::vector<std::vector<int>>(); //The first entry is the index in objects, the second one the index in physicObjects, the others are idGreen, idBlue and objectNum.
|
||||||
XMLDocument* compositions = new XMLDocument();
|
XMLDocument* compositions = new XMLDocument();
|
||||||
@ -259,7 +259,7 @@ void Loader::load(std::string filePath, Level* level, std::string compositionsPa
|
|||||||
objectRot *= 0.0174532925; //transform degrees to radians
|
objectRot *= 0.0174532925; //transform degrees to radians
|
||||||
Object* object = new Object(model, material, objectPosition, compRot+objectRot, renderable);
|
Object* object = new Object(model, material, objectPosition, compRot+objectRot, renderable);
|
||||||
level->addObject(object);
|
level->addObject(object);
|
||||||
|
|
||||||
//add object to physics
|
//add object to physics
|
||||||
const char* charPhysicType = objectData->FirstChildElement("physicType")->GetText();
|
const char* charPhysicType = objectData->FirstChildElement("physicType")->GetText();
|
||||||
if(charPhysicType == NULL){
|
if(charPhysicType == NULL){
|
||||||
@ -315,7 +315,7 @@ void Loader::load(std::string filePath, Level* level, std::string compositionsPa
|
|||||||
printf("XMLError: Not a valid physicType.\n");
|
printf("XMLError: Not a valid physicType.\n");
|
||||||
exit(-1);
|
exit(-1);
|
||||||
}
|
}
|
||||||
|
|
||||||
//create an identifier for this object
|
//create an identifier for this object
|
||||||
std::vector<int> objectIdentifier = std::vector<int>(5);
|
std::vector<int> objectIdentifier = std::vector<int>(5);
|
||||||
objectIdentifier[0] = level->getObjectsVectorSize()-1;
|
objectIdentifier[0] = level->getObjectsVectorSize()-1;
|
||||||
@ -340,7 +340,7 @@ void Loader::load(std::string filePath, Level* level, std::string compositionsPa
|
|||||||
|
|
||||||
objectNum = objectNum + 1;
|
objectNum = objectNum + 1;
|
||||||
}//iterating over all objects of the composition
|
}//iterating over all objects of the composition
|
||||||
|
|
||||||
//iterate over all lights of the composition
|
//iterate over all lights of the composition
|
||||||
XMLElement* xmlLight = composition->FirstChildElement("light");
|
XMLElement* xmlLight = composition->FirstChildElement("light");
|
||||||
for(; xmlLight; xmlLight=xmlLight->NextSiblingElement("light")){
|
for(; xmlLight; xmlLight=xmlLight->NextSiblingElement("light")){
|
||||||
|
41
main.cc
41
main.cc
@ -76,19 +76,19 @@ bool createWindow()
|
|||||||
ACGL::Utils::error() << "Failed to initialize GLFW" << std::endl;
|
ACGL::Utils::error() << "Failed to initialize GLFW" << std::endl;
|
||||||
exit( -1 );
|
exit( -1 );
|
||||||
}
|
}
|
||||||
|
|
||||||
// Configure OpenGL context
|
// Configure OpenGL context
|
||||||
setGLFWHintsForOpenGLVersion( ACGL_OPENGL_VERSION );
|
setGLFWHintsForOpenGLVersion( ACGL_OPENGL_VERSION );
|
||||||
|
|
||||||
// activate multisampling (second parameter is the number of samples):
|
// activate multisampling (second parameter is the number of samples):
|
||||||
//glfwWindowHint( GLFW_SAMPLES, 8 );
|
//glfwWindowHint( GLFW_SAMPLES, 8 );
|
||||||
|
|
||||||
// request an OpenGL debug context:
|
// request an OpenGL debug context:
|
||||||
glfwWindowHint( GLFW_OPENGL_DEBUG_CONTEXT, true );
|
glfwWindowHint( GLFW_OPENGL_DEBUG_CONTEXT, true );
|
||||||
|
|
||||||
// define whether the window can get resized:
|
// define whether the window can get resized:
|
||||||
glfwWindowHint(GLFW_RESIZABLE, true);
|
glfwWindowHint(GLFW_RESIZABLE, true);
|
||||||
|
|
||||||
// try to create an OpenGL context in a window and check the supported OpenGL version:
|
// try to create an OpenGL context in a window and check the supported OpenGL version:
|
||||||
// R,G,B,A, Depth,Stencil
|
// R,G,B,A, Depth,Stencil
|
||||||
window = glfwCreateWindow(app.getGraphics()->getWindowSize().x, app.getGraphics()->getWindowSize().y, "SWP MarbleGame Group C", NULL, NULL);
|
window = glfwCreateWindow(app.getGraphics()->getWindowSize().x, app.getGraphics()->getWindowSize().y, "SWP MarbleGame Group C", NULL, NULL);
|
||||||
@ -104,13 +104,13 @@ bool createWindow()
|
|||||||
int main( int argc, char *argv[] )
|
int main( int argc, char *argv[] )
|
||||||
{
|
{
|
||||||
// app gets created as global variable, to work properly with GLFW
|
// app gets created as global variable, to work properly with GLFW
|
||||||
|
|
||||||
// Create OpenGL capable window:
|
// Create OpenGL capable window:
|
||||||
if ( !createWindow() ) {
|
if ( !createWindow() ) {
|
||||||
glfwTerminate();
|
glfwTerminate();
|
||||||
exit( -1 );
|
exit( -1 );
|
||||||
}
|
}
|
||||||
|
|
||||||
// Set window title to binary name (without the path):
|
// Set window title to binary name (without the path):
|
||||||
std::vector<std::string> tmp = ACGL::Utils::StringHelpers::split( std::string( argv[0] ), '/' );
|
std::vector<std::string> tmp = ACGL::Utils::StringHelpers::split( std::string( argv[0] ), '/' );
|
||||||
glfwSetWindowTitle(window, tmp[tmp.size()-1].c_str() );
|
glfwSetWindowTitle(window, tmp[tmp.size()-1].c_str() );
|
||||||
@ -122,10 +122,10 @@ int main( int argc, char *argv[] )
|
|||||||
glfwSetScrollCallback(window, scrollCallback );
|
glfwSetScrollCallback(window, scrollCallback );
|
||||||
glfwSetWindowFocusCallback(window, focusCallback);
|
glfwSetWindowFocusCallback(window, focusCallback);
|
||||||
glfwSetMouseButtonCallback(window, mouseCallback);
|
glfwSetMouseButtonCallback(window, mouseCallback);
|
||||||
|
|
||||||
// Enable vertical sync (on cards that support it) with parameter 1 - 0 means off
|
// Enable vertical sync (on cards that support it) with parameter 1 - 0 means off
|
||||||
glfwSwapInterval( 0 );
|
glfwSwapInterval( 0 );
|
||||||
|
|
||||||
// OpenGL state:
|
// OpenGL state:
|
||||||
glClearColor( 0.0, 0.0, 0.0, 1.0 );
|
glClearColor( 0.0, 0.0, 0.0, 1.0 );
|
||||||
glEnable( GL_DEPTH_TEST );
|
glEnable( GL_DEPTH_TEST );
|
||||||
@ -133,20 +133,19 @@ int main( int argc, char *argv[] )
|
|||||||
glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);
|
glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);
|
||||||
glEnable(GL_TEXTURE_CUBE_MAP_SEAMLESS);
|
glEnable(GL_TEXTURE_CUBE_MAP_SEAMLESS);
|
||||||
app.init();
|
app.init();
|
||||||
|
|
||||||
int frameCount = 0;
|
int frameCount = 0;
|
||||||
|
|
||||||
const double FPSdelay = 2.0;
|
const double FPSdelay = 2.0;
|
||||||
double startTimeInSeconds = glfwGetTime();
|
double startTimeInSeconds = glfwGetTime();
|
||||||
double showNextFPS = startTimeInSeconds + FPSdelay;
|
double showNextFPS = startTimeInSeconds + FPSdelay;
|
||||||
|
|
||||||
double lastUpdate=0.0f;
|
double lastUpdate=0.0f;
|
||||||
|
|
||||||
|
|
||||||
do {
|
|
||||||
|
|
||||||
double now = glfwGetTime()- startTimeInSeconds;
|
|
||||||
|
|
||||||
|
do {
|
||||||
|
|
||||||
|
double now = glfwGetTime()- startTimeInSeconds;
|
||||||
|
|
||||||
if (showNextFPS <= now) {
|
if (showNextFPS <= now) {
|
||||||
std::stringstream sstream (std::stringstream::in | std::stringstream::out);
|
std::stringstream sstream (std::stringstream::in | std::stringstream::out);
|
||||||
sstream << std::setprecision(1) << std::fixed
|
sstream << std::setprecision(1) << std::fixed
|
||||||
@ -155,8 +154,8 @@ int main( int argc, char *argv[] )
|
|||||||
showNextFPS = now + FPSdelay;
|
showNextFPS = now + FPSdelay;
|
||||||
frameCount = 0;
|
frameCount = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if (app.isLocked() && app.getIgnoredMouseUpdates() == 0) {
|
if (app.isLocked() && app.getIgnoredMouseUpdates() == 0) {
|
||||||
int stateW = glfwGetKey(window, GLFW_KEY_W);
|
int stateW = glfwGetKey(window, GLFW_KEY_W);
|
||||||
int stateA = glfwGetKey(window, GLFW_KEY_A);
|
int stateA = glfwGetKey(window, GLFW_KEY_A);
|
||||||
@ -176,12 +175,12 @@ int main( int argc, char *argv[] )
|
|||||||
app.ignoredOneMouseUpdate();
|
app.ignoredOneMouseUpdate();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
app.getGraphics()->render(now);
|
app.getGraphics()->render(now);
|
||||||
lastUpdate = now;
|
lastUpdate = now;
|
||||||
|
|
||||||
openGLCriticalError();
|
openGLCriticalError();
|
||||||
|
|
||||||
// MacOS X will not swap correctly is another FBO is bound:
|
// MacOS X will not swap correctly is another FBO is bound:
|
||||||
glBindFramebuffer( GL_FRAMEBUFFER, 0 );
|
glBindFramebuffer( GL_FRAMEBUFFER, 0 );
|
||||||
glfwSwapBuffers(window);
|
glfwSwapBuffers(window);
|
||||||
@ -190,7 +189,7 @@ int main( int argc, char *argv[] )
|
|||||||
|
|
||||||
} // Check if the window was closed
|
} // Check if the window was closed
|
||||||
while( !glfwWindowShouldClose(window) );
|
while( !glfwWindowShouldClose(window) );
|
||||||
|
|
||||||
glfwTerminate();
|
glfwTerminate();
|
||||||
exit(0);
|
exit(0);
|
||||||
}
|
}
|
||||||
|
@ -10,7 +10,7 @@ class Material{
|
|||||||
public:
|
public:
|
||||||
Material(std::string filePath, float ambientFactor,
|
Material(std::string filePath, float ambientFactor,
|
||||||
float diffuseFactor, float specularFactor, float shininess);
|
float diffuseFactor, float specularFactor, float shininess);
|
||||||
Material();
|
Material();
|
||||||
ACGL::OpenGL::SharedTexture2D getReference();
|
ACGL::OpenGL::SharedTexture2D getReference();
|
||||||
~Material();
|
~Material();
|
||||||
float getAmbientFactor();
|
float getAmbientFactor();
|
||||||
|
4
model.hh
4
model.hh
@ -7,8 +7,8 @@
|
|||||||
class Model {
|
class Model {
|
||||||
public:
|
public:
|
||||||
Model(std::string filePath, float scale=1.0f);
|
Model(std::string filePath, float scale=1.0f);
|
||||||
Model(ACGL::OpenGL::SharedVertexArrayObject vao, float scale=1.0f);
|
Model(ACGL::OpenGL::SharedVertexArrayObject vao, float scale=1.0f);
|
||||||
Model();
|
Model();
|
||||||
~Model();
|
~Model();
|
||||||
ACGL::OpenGL::SharedVertexArrayObject getReference();
|
ACGL::OpenGL::SharedVertexArrayObject getReference();
|
||||||
void setScale(float scale);
|
void setScale(float scale);
|
||||||
|
516
physics.cc
516
physics.cc
@ -10,11 +10,11 @@ Physics::~Physics() {
|
|||||||
|
|
||||||
void Physics::init(std::string geometryPath) //prepares bullet by creating all initial classes
|
void Physics::init(std::string geometryPath) //prepares bullet by creating all initial classes
|
||||||
{
|
{
|
||||||
colConfig = new btDefaultCollisionConfiguration();
|
colConfig = new btDefaultCollisionConfiguration();
|
||||||
dispatcher = new btCollisionDispatcher(colConfig);
|
dispatcher = new btCollisionDispatcher(colConfig);
|
||||||
broadphase = new btDbvtBroadphase();
|
broadphase = new btDbvtBroadphase();
|
||||||
solver = new btSequentialImpulseConstraintSolver();
|
solver = new btSequentialImpulseConstraintSolver();
|
||||||
world = new btDiscreteDynamicsWorld(dispatcher,broadphase,solver,colConfig);
|
world = new btDiscreteDynamicsWorld(dispatcher,broadphase,solver,colConfig);
|
||||||
world->setGravity(btVector3(0,-10,-0));
|
world->setGravity(btVector3(0,-10,-0));
|
||||||
if (world == NULL) {
|
if (world == NULL) {
|
||||||
printf("No World after init\n");
|
printf("No World after init\n");
|
||||||
@ -23,24 +23,23 @@ void Physics::init(std::string geometryPath) //prepares bullet by creating all i
|
|||||||
}
|
}
|
||||||
|
|
||||||
void Physics::takeUpdateStep(float timeDiff)
|
void Physics::takeUpdateStep(float timeDiff)
|
||||||
{
|
{
|
||||||
|
counter++;
|
||||||
counter++;
|
if(counter<1)
|
||||||
if(counter<1)
|
{
|
||||||
{
|
world->stepSimulation(timeDiff); //allows the world to be simmulated correctly indipendant of the timedifferences between frames
|
||||||
world->stepSimulation(timeDiff);//allows the world to be simmulated correctly indipendant of the timedifferences between frames
|
return;
|
||||||
return;
|
}
|
||||||
}
|
|
||||||
|
for(unsigned i = 0; i < allPositionConstraints.size();i++) //this handles the spring constraints
|
||||||
for(unsigned i = 0; i < allPositionConstraints.size();i++) //this handles the spring constraints
|
{
|
||||||
{
|
if(allPositionConstraints[i].position != allPositionConstraints[i].body->getCenterOfMassPosition()) //if constraint != position of the body because otherwise dir = 0
|
||||||
if(allPositionConstraints[i].position != allPositionConstraints[i].body->getCenterOfMassPosition()) //if constraint != position of the body because otherwise dir = 0
|
{
|
||||||
{
|
btVector3 dir = allPositionConstraints[i].position - allPositionConstraints[i].body->getCenterOfMassPosition();
|
||||||
btVector3 dir = allPositionConstraints[i].position - allPositionConstraints[i].body->getCenterOfMassPosition();
|
dir = dir*allPositionConstraints[i].strength - allPositionConstraints[i].body->getLinearVelocity();
|
||||||
dir = dir*allPositionConstraints[i].strength - allPositionConstraints[i].body->getLinearVelocity();
|
allPositionConstraints[i].body->applyCentralForce(dir*allPositionConstraints[i].strength); //apply a foce upon the object pushing it towards the constraint position
|
||||||
allPositionConstraints[i].body->applyCentralForce(dir*allPositionConstraints[i].strength); //apply a foce upon the object pushing it towards the constraint position
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
btVector3 position = cameraBody->getCenterOfMassPosition() - playerBall->getCenterOfMassPosition(); //gets a vector from the player to the camera
|
btVector3 position = cameraBody->getCenterOfMassPosition() - playerBall->getCenterOfMassPosition(); //gets a vector from the player to the camera
|
||||||
@ -50,32 +49,32 @@ void Physics::takeUpdateStep(float timeDiff)
|
|||||||
|
|
||||||
//prevent the camera from being dragged along on the ground
|
//prevent the camera from being dragged along on the ground
|
||||||
if (position.getY() < playerBall->getCenterOfMassPosition().getY() + 1)
|
if (position.getY() < playerBall->getCenterOfMassPosition().getY() + 1)
|
||||||
position.setY(playerBall->getCenterOfMassPosition().getY() + 1);
|
position.setY(playerBall->getCenterOfMassPosition().getY() + 1);
|
||||||
|
|
||||||
btVector3 dir = cameraBody->getCenterOfMassPosition() - position;
|
btVector3 dir = cameraBody->getCenterOfMassPosition() - position;
|
||||||
float str = 50 * dir.length() / cameraBody->getInvMass();
|
float str = 50 * dir.length() / cameraBody->getInvMass(); //getInvMass() returns the inverted mass
|
||||||
cameraBody->applyCentralForce(-dir*str);//scale the force by camera mass
|
cameraBody->applyCentralForce(-dir*str); //scale the force by camera mass
|
||||||
counter=0;
|
counter=0;
|
||||||
float speed = cameraBody->getLinearVelocity().length();
|
float speed = cameraBody->getLinearVelocity().length();
|
||||||
if(speed>20.0f)
|
if(speed>20.0f)
|
||||||
{
|
{
|
||||||
printf("%f , %f \n", speed, position.length());
|
printf("%f , %f \n", speed, position.length());
|
||||||
position = cameraBody->getLinearVelocity();
|
position = cameraBody->getLinearVelocity();
|
||||||
position.normalize();
|
position.normalize();
|
||||||
cameraBody->setLinearVelocity(position*20);
|
cameraBody->setLinearVelocity(position*20);
|
||||||
}
|
}
|
||||||
world->stepSimulation(timeDiff);
|
world->stepSimulation(timeDiff);
|
||||||
}
|
}
|
||||||
//
|
|
||||||
void Physics::removePositionConstraint(int bodyIndice) //remover function for deleting all pos constraints on one body
|
void Physics::removePositionConstraint(int bodyIndice) //remover function for deleting all pos constraints on one body
|
||||||
{
|
{
|
||||||
for(unsigned i = 0; i < allPositionConstraints.size(); i++)
|
for(unsigned i = 0; i < allPositionConstraints.size(); i++)
|
||||||
{
|
{
|
||||||
if(allPositionConstraints[i].body == bodies[bodyIndice])
|
if(allPositionConstraints[i].body == bodies[bodyIndice])
|
||||||
{
|
{
|
||||||
allPositionConstraints.erase(allPositionConstraints.begin()+i);
|
allPositionConstraints.erase(allPositionConstraints.begin()+i);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void Physics::addPositionConstraint(int bodyIndice, float strength, glm::vec3 position) //function for adding position constraints
|
void Physics::addPositionConstraint(int bodyIndice, float strength, glm::vec3 position) //function for adding position constraints
|
||||||
@ -85,83 +84,83 @@ void Physics::addPositionConstraint(int bodyIndice, float strength, glm::vec3 po
|
|||||||
cons.strength = strength;
|
cons.strength = strength;
|
||||||
cons.position = btVector3(position.x,position.y,position.z);
|
cons.position = btVector3(position.x,position.y,position.z);
|
||||||
allPositionConstraints.push_back(cons);
|
allPositionConstraints.push_back(cons);
|
||||||
}
|
}
|
||||||
|
|
||||||
//players and objects
|
//players and objects
|
||||||
void Physics::addPlayer(float friction, float rad, Entity entity, float mass, float dampningL, float dampningA, unsigned indice)
|
void Physics::addPlayer(float friction, float rad, Entity entity, float mass, float dampningL, float dampningA, unsigned indice)
|
||||||
{
|
{
|
||||||
if(bodies.size() == indice)
|
if(bodies.size() == indice)
|
||||||
throw std::invalid_argument( "Bodies out of Sync" ); //these error are to ensure that level can always communicate with physics without having to worry about synching errors
|
throw std::invalid_argument( "Bodies out of Sync" ); //these error are to ensure that level can always communicate with physics without having to worry about synching errors
|
||||||
|
|
||||||
btSphereShape* sphere = new btSphereShape(rad); //the first thing we need for a rigid body is the shape
|
btSphereShape* sphere = new btSphereShape(rad); //the first thing we need for a rigid body is the shape
|
||||||
btVector3 inertia(0,0,0);
|
btVector3 inertia(0,0,0);
|
||||||
if(mass != 0.0)
|
if(mass != 0.0)
|
||||||
{
|
{
|
||||||
sphere->calculateLocalInertia((btScalar)mass,inertia); //from this shape we can then calculate the innertia, as long as the mass != 0 (otherwise inertia = 0)
|
sphere->calculateLocalInertia((btScalar)mass,inertia); //from this shape we can then calculate the innertia, as long as the mass != 0 (otherwise inertia = 0)
|
||||||
}
|
}
|
||||||
|
|
||||||
glm::quat glmQuat = glm::quat_cast(entity.getRotation());
|
glm::quat glmQuat = glm::quat_cast(entity.getRotation());
|
||||||
|
|
||||||
btDefaultMotionState* motion = new btDefaultMotionState(btTransform(btQuaternion(glmQuat.x,glmQuat.y,glmQuat.z,glmQuat.w),btVector3(entity.getPosition().x,entity.getPosition().y,entity.getPosition().z))); //next we define the motionstate, wich describes the innital position and rotation
|
btDefaultMotionState* motion = new btDefaultMotionState(btTransform(btQuaternion(glmQuat.x,glmQuat.y,glmQuat.z,glmQuat.w),btVector3(entity.getPosition().x,entity.getPosition().y,entity.getPosition().z))); //next we define the motionstate, wich describes the innital position and rotation
|
||||||
|
|
||||||
btRigidBody::btRigidBodyConstructionInfo info(mass,motion,sphere,inertia); //next we process all data for the rigid body into info
|
btRigidBody::btRigidBodyConstructionInfo info(mass,motion,sphere,inertia); //next we process all data for the rigid body into info
|
||||||
|
|
||||||
info.m_friction = friction*2; //here we modify the friction and restitution (bounciness) of the object
|
info.m_friction = friction*2; //here we modify the friction and restitution (bounciness) of the object
|
||||||
info.m_restitution = 0.1f;
|
info.m_restitution = 0.1f;
|
||||||
|
|
||||||
playerBall = new btRigidBody(info); //finally we create the rigid body using the info
|
playerBall = new btRigidBody(info); //finally we create the rigid body using the info
|
||||||
|
|
||||||
playerBall->setDamping(dampningL, dampningA); //here we can set the dampning (how much of the motion is lost)
|
playerBall->setDamping(dampningL, dampningA); //here we can set the dampning (how much of the motion is lost)
|
||||||
|
|
||||||
world->addRigidBody(playerBall,COL_OBJECTS,COL_OBJECTS|COL_OBJECTS_NO_TERRAIN|COL_TERRAIN); //then we add the rigid body to the wiorld, allowing it to be simulated
|
world->addRigidBody(playerBall,COL_OBJECTS,COL_OBJECTS|COL_OBJECTS_NO_TERRAIN|COL_TERRAIN); //then we add the rigid body to the wiorld, allowing it to be simulated
|
||||||
|
|
||||||
bodies.push_back(playerBall); //next we add the rigid body to our own list (for cleanup and for synchronitaation with level)
|
bodies.push_back(playerBall); //next we add the rigid body to our own list (for cleanup and for synchronitaation with level)
|
||||||
//note, while we can always access playerBall through its global name, we add it to this array for synchronization purposes
|
//note, while we can always access playerBall through its global name, we add it to this array for synchronization purposes
|
||||||
|
|
||||||
playerBall->setSleepingThresholds(0,0); //in a final step we make sure that the body never is removed from the active rigid bodies
|
playerBall->setSleepingThresholds(0,0); //in a final step we make sure that the body never is removed from the active rigid bodies
|
||||||
|
|
||||||
if(bodies.size() != indice)
|
if(bodies.size() != indice)
|
||||||
throw std::invalid_argument( "Bodies out of Sync" ); //one last check to make sure level and physics are in synch
|
throw std::invalid_argument( "Bodies out of Sync" ); //one last check to make sure level and physics are in synch
|
||||||
|
|
||||||
addCamera(); //now that the player exists add a camera for the player
|
addCamera(); //now that the player exists add a camera for the player
|
||||||
}
|
}
|
||||||
|
|
||||||
void Physics::addTerrain(int width, int length, float** heightData) //The terrain adding function
|
void Physics::addTerrain(int width, int length, float** heightData) //The terrain adding function
|
||||||
{
|
{
|
||||||
float* heightfield = new float[width * length];//bullet only accepts data in a one dimensional array, so parse data into appropriate format
|
float* heightfield = new float[width * length]; //bullet only accepts data in a one dimensional array, so parse data into appropriate format
|
||||||
int highest = -999999, j = 0, i = 0;
|
int highest = -999999, j = 0, i = 0;
|
||||||
for (i = 0; i < width; i++)
|
for (i = 0; i < width; i++)
|
||||||
{
|
{
|
||||||
for (j = 0; j < length; j++) {
|
for (j = 0; j < length; j++) {
|
||||||
heightfield[i*length+j] = heightData[j][i]; //reverse order because they are loaded backwards
|
heightfield[i*length+j] = heightData[j][i]; //reverse order because they are loaded backwards
|
||||||
|
|
||||||
if (heightData[j][i] > highest)
|
if (heightData[j][i] > highest)
|
||||||
highest = heightData[j][i]; //bullet needs to know the highest point of the heightmap
|
highest = heightData[j][i]; //bullet needs to know the highest point of the heightmap
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
highest++;
|
highest++;
|
||||||
|
|
||||||
btHeightfieldTerrainShape* terrainShape = new btHeightfieldTerrainShape(length,width,heightfield,highest,1,true,false);
|
btHeightfieldTerrainShape* terrainShape = new btHeightfieldTerrainShape(length,width,heightfield,highest,1,true,false);
|
||||||
btRigidBody::btRigidBodyConstructionInfo info(0,new btDefaultMotionState(),terrainShape,btVector3(0,0,0)); //next we process all data for the rigid body into info
|
btRigidBody::btRigidBodyConstructionInfo info(0,new btDefaultMotionState(),terrainShape,btVector3(0,0,0)); //next we process all data for the rigid body into info
|
||||||
info.m_friction = 1;
|
info.m_friction = 1;
|
||||||
info.m_restitution = 0;
|
info.m_restitution = 0;
|
||||||
btRigidBody* tBody = new btRigidBody(info);
|
btRigidBody* tBody = new btRigidBody(info);
|
||||||
|
|
||||||
tBody->getWorldTransform().setOrigin(btVector3(0,((float)highest)/2,0)); //we have to move the origin of our rigid body down, because bullet sets the origin (0,0,0) at (width/2, height/2, length/2) in the map the x and z are correct in our level, but y needs to be addapted
|
tBody->getWorldTransform().setOrigin(btVector3(0,((float)highest)/2,0)); //we have to move the origin of our rigid body down, because bullet sets the origin (0,0,0) at (width/2, height/2, length/2) in the map the x and z are correct in our level, but y needs to be addapted
|
||||||
|
|
||||||
terrainBody = tBody;
|
terrainBody = tBody;
|
||||||
if (world == NULL) {
|
if (world == NULL) {
|
||||||
printf("No World while adding terrain.\n");
|
printf("No World while adding terrain.\n");
|
||||||
}
|
}
|
||||||
world->addRigidBody(terrainBody, COL_TERRAIN, COL_TERRAIN | COL_OBJECTS); //COL_XXXX are collision masks, allowing us to ignore collisions between certain object groups (required for buttons)
|
world->addRigidBody(terrainBody, COL_TERRAIN, COL_TERRAIN | COL_OBJECTS); //COL_XXXX are collision masks, allowing us to ignore collisions between certain object groups (required for buttons)
|
||||||
}
|
}
|
||||||
|
|
||||||
void Physics::addTriangleMeshBody(Entity entity, std::string path, float mass, float dampningL, float dampningA,unsigned indice,float scaling, bool rotate)
|
void Physics::addTriangleMeshBody(Entity entity, std::string path, float mass, float dampningL, float dampningA,unsigned indice,float scaling, bool rotate)
|
||||||
{
|
{
|
||||||
|
|
||||||
if(bodies.size() == indice)
|
if(bodies.size() == indice)
|
||||||
throw std::invalid_argument( "Bodies out of Sync" );
|
throw std::invalid_argument( "Bodies out of Sync" );
|
||||||
|
|
||||||
std::vector< unsigned int > vertexIndices; //temp lists for data sets
|
std::vector< unsigned int > vertexIndices; //temp lists for data sets
|
||||||
std::vector< btVector3 > temp_vertices;
|
std::vector< btVector3 > temp_vertices;
|
||||||
path = "../" + geometryPath + path;
|
path = "../" + geometryPath + path;
|
||||||
@ -171,10 +170,10 @@ void Physics::addTriangleMeshBody(Entity entity, std::string path, float mass, f
|
|||||||
}
|
}
|
||||||
while( 1 ){
|
while( 1 ){
|
||||||
char lineHeader[128];
|
char lineHeader[128];
|
||||||
// read the first word of the line
|
//read the first word of the line
|
||||||
int res = fscanf(file, "%s", lineHeader);
|
int res = fscanf(file, "%s", lineHeader);
|
||||||
if (res == EOF)
|
if (res == EOF)
|
||||||
break; // while not at end do loop
|
break; //while not at end do loop
|
||||||
if ( strcmp( lineHeader, "v" ) == 0 ){ //if a vertex
|
if ( strcmp( lineHeader, "v" ) == 0 ){ //if a vertex
|
||||||
glm::vec3 vertex;
|
glm::vec3 vertex;
|
||||||
fscanf(file, "%f %f %f\n", &vertex.x, &vertex.y, &vertex.z );
|
fscanf(file, "%f %f %f\n", &vertex.x, &vertex.y, &vertex.z );
|
||||||
@ -183,202 +182,198 @@ void Physics::addTriangleMeshBody(Entity entity, std::string path, float mass, f
|
|||||||
else if ( strcmp( lineHeader, "f" ) == 0 ){ //if face (index for 3 vertexes for a triangle)
|
else if ( strcmp( lineHeader, "f" ) == 0 ){ //if face (index for 3 vertexes for a triangle)
|
||||||
std::string vertex1, vertex2, vertex3;
|
std::string vertex1, vertex2, vertex3;
|
||||||
unsigned int vertexIndex[3], uvIndex[3], normalIndex[3];
|
unsigned int vertexIndex[3], uvIndex[3], normalIndex[3];
|
||||||
int matches = fscanf(file, "%d/%d/%d %d/%d/%d %d/%d/%d\n", &vertexIndex[0], &uvIndex[0], &normalIndex[0], &vertexIndex[1], &uvIndex[1], &normalIndex[1], &vertexIndex[2], &uvIndex[2], &normalIndex[2] );
|
int matches = fscanf(file, "%d/%d/%d %d/%d/%d %d/%d/%d\n", &vertexIndex[0], &uvIndex[0], &normalIndex[0], &vertexIndex[1], &uvIndex[1], &normalIndex[1], &vertexIndex[2], &uvIndex[2], &normalIndex[2]);
|
||||||
vertexIndices.push_back(vertexIndex[0]);
|
vertexIndices.push_back(vertexIndex[0]);
|
||||||
vertexIndices.push_back(vertexIndex[1]);
|
vertexIndices.push_back(vertexIndex[1]);
|
||||||
vertexIndices.push_back(vertexIndex[2]); //save 3 indexes in array
|
vertexIndices.push_back(vertexIndex[2]); //save 3 indexes in array
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
//finally start making body
|
//finally start making body
|
||||||
btTriangleMesh* triMesh = new btTriangleMesh();
|
btTriangleMesh* triMesh = new btTriangleMesh();
|
||||||
|
|
||||||
for(unsigned i = 2; i < vertexIndices.size();i+=3)
|
for(unsigned i = 2; i < vertexIndices.size();i+=3)
|
||||||
{
|
{
|
||||||
triMesh->addTriangle(temp_vertices[vertexIndices[i]],temp_vertices[vertexIndices[i-1]],temp_vertices[vertexIndices[i-2]]); // for every face (3 elements in vertexIndices) create triangle use the indices to find correct vertexes to make the triangle
|
triMesh->addTriangle(temp_vertices[vertexIndices[i]],temp_vertices[vertexIndices[i-1]],temp_vertices[vertexIndices[i-2]]); //for every face (3 elements in vertexIndices) create triangle use the indices to find correct vertexes to make the triangle
|
||||||
}
|
}
|
||||||
|
|
||||||
btBvhTriangleMeshShape* shape = new btBvhTriangleMeshShape(triMesh,true);
|
btBvhTriangleMeshShape* shape = new btBvhTriangleMeshShape(triMesh,true);
|
||||||
shape->setLocalScaling(btVector3(scaling,scaling,scaling)); //we need to add a scaling here because the objects seem to have diffrent sizes when loaded (no clue why, see composition.xml for exact scaling factors)
|
shape->setLocalScaling(btVector3(scaling,scaling,scaling)); //we need to add a scaling here because the objects seem to have diffrent sizes when loaded (no clue why, see composition.xml for exact scaling factors)
|
||||||
|
|
||||||
|
|
||||||
glm::quat glmQuat = glm::quat_cast(entity.getRotation());
|
glm::quat glmQuat = glm::quat_cast(entity.getRotation());
|
||||||
|
|
||||||
btDefaultMotionState* motion = new btDefaultMotionState(btTransform(btQuaternion(glmQuat.x,glmQuat.y,glmQuat.z,glmQuat.w),btVector3(entity.getPosition().x,entity.getPosition().y,entity.getPosition().z)));
|
btDefaultMotionState* motion = new btDefaultMotionState(btTransform(btQuaternion(glmQuat.x,glmQuat.y,glmQuat.z,glmQuat.w),btVector3(entity.getPosition().x,entity.getPosition().y,entity.getPosition().z)));
|
||||||
|
|
||||||
btVector3 inertia(0,0,0);
|
btVector3 inertia(0,0,0);
|
||||||
if(mass != 0.0 && rotate) //&& rotate lets certain objects get inertia (0,0,0) (not rotateable)
|
if(mass != 0.0 && rotate) //&& rotate lets certain objects get inertia (0,0,0) (not rotateable)
|
||||||
{
|
{
|
||||||
shape->calculateLocalInertia((btScalar)mass,inertia);
|
shape->calculateLocalInertia((btScalar)mass,inertia);
|
||||||
}
|
}
|
||||||
|
|
||||||
btRigidBody::btRigidBodyConstructionInfo info(mass,motion,shape,inertia);
|
btRigidBody::btRigidBodyConstructionInfo info(mass,motion,shape,inertia);
|
||||||
|
|
||||||
btRigidBody* body = new btRigidBody(info);
|
btRigidBody* body = new btRigidBody(info);
|
||||||
|
|
||||||
body->setDamping(dampningL,dampningA);
|
body->setDamping(dampningL,dampningA);
|
||||||
|
|
||||||
bodies.push_back(body);
|
bodies.push_back(body);
|
||||||
|
|
||||||
world->addRigidBody(body,COL_OBJECTS, objectsPhysicsCollision);
|
world->addRigidBody(body,COL_OBJECTS, objectsPhysicsCollision);
|
||||||
|
|
||||||
|
|
||||||
if(bodies.size() != indice)
|
if(bodies.size() != indice)
|
||||||
throw std::invalid_argument( "Bodies out of Sync" );
|
throw std::invalid_argument( "Bodies out of Sync" );
|
||||||
}
|
}
|
||||||
|
|
||||||
void Physics::addButton(float width, float height, float length, Entity entity, float mass, float dampningL, float dampningA, unsigned indice,bool rotate)
|
void Physics::addButton(float width, float height, float length, Entity entity, float mass, float dampningL, float dampningA, unsigned indice,bool rotate)
|
||||||
{
|
{
|
||||||
|
|
||||||
if(bodies.size() == indice)
|
if(bodies.size() == indice)
|
||||||
throw std::invalid_argument( "Bodies out of Sync" );
|
throw std::invalid_argument( "Bodies out of Sync" );
|
||||||
|
|
||||||
btBoxShape* box = new btBoxShape(btVector3(width/2,height/2,length/2));
|
btBoxShape* box = new btBoxShape(btVector3(width/2,height/2,length/2));
|
||||||
|
|
||||||
glm::quat glmQuat = glm::quat_cast(entity.getRotation());
|
glm::quat glmQuat = glm::quat_cast(entity.getRotation());
|
||||||
|
|
||||||
btDefaultMotionState* motion = new btDefaultMotionState(btTransform(btQuaternion(glmQuat.x,glmQuat.y,glmQuat.z,glmQuat.w),btVector3(entity.getPosition().x,entity.getPosition().y,entity.getPosition().z)));
|
btDefaultMotionState* motion = new btDefaultMotionState(btTransform(btQuaternion(glmQuat.x,glmQuat.y,glmQuat.z,glmQuat.w),btVector3(entity.getPosition().x,entity.getPosition().y,entity.getPosition().z)));
|
||||||
|
|
||||||
btVector3 inertia(0,0,0);
|
btVector3 inertia(0,0,0);
|
||||||
if(mass != 0.0 && rotate) //&& rotate lets certain objects get inertia (0,0,0) (not rotateable)
|
if(mass != 0.0 && rotate) //&& rotate lets certain objects get inertia (0,0,0) (not rotateable)
|
||||||
{
|
{
|
||||||
box->calculateLocalInertia((btScalar)mass,inertia);
|
box->calculateLocalInertia((btScalar)mass,inertia);
|
||||||
}
|
}
|
||||||
btRigidBody::btRigidBodyConstructionInfo info(mass,motion,box,inertia);
|
btRigidBody::btRigidBodyConstructionInfo info(mass,motion,box,inertia);
|
||||||
|
|
||||||
btRigidBody* body = new btRigidBody(info);
|
btRigidBody* body = new btRigidBody(info);
|
||||||
|
|
||||||
body->setDamping(dampningL, dampningA);
|
body->setDamping(dampningL, dampningA);
|
||||||
|
|
||||||
world->addRigidBody(body,COL_OBJECTS_NO_TERRAIN, specialPhysicsCollision); //the specialPhysicsCollision allows these objects to not collide with the terrain
|
world->addRigidBody(body,COL_OBJECTS_NO_TERRAIN, specialPhysicsCollision); //the specialPhysicsCollision allows these objects to not collide with the terrain
|
||||||
|
|
||||||
bodies.push_back(body);
|
bodies.push_back(body);
|
||||||
|
|
||||||
if(bodies.size() != indice)
|
if(bodies.size() != indice)
|
||||||
throw std::invalid_argument( "Bodies out of Sync" );
|
throw std::invalid_argument( "Bodies out of Sync" );
|
||||||
}
|
}
|
||||||
|
|
||||||
void Physics::addBox(float width, float height, float length, Entity entity, float mass, float dampningL, float dampningA, unsigned indice,bool rotate)
|
void Physics::addBox(float width, float height, float length, Entity entity, float mass, float dampningL, float dampningA, unsigned indice,bool rotate)
|
||||||
{
|
{
|
||||||
//similar to other constructors
|
//similar to other constructors
|
||||||
if(bodies.size() == indice)
|
if(bodies.size() == indice)
|
||||||
throw std::invalid_argument( "Bodies out of Sync" );
|
throw std::invalid_argument( "Bodies out of Sync" );
|
||||||
|
|
||||||
glm::quat glmQuat = glm::quat_cast(entity.getRotation());
|
glm::quat glmQuat = glm::quat_cast(entity.getRotation());
|
||||||
btBoxShape* box = new btBoxShape(btVector3(width/2,height/2,length/2));
|
btBoxShape* box = new btBoxShape(btVector3(width/2,height/2,length/2));
|
||||||
btDefaultMotionState* motion = new btDefaultMotionState(btTransform(btQuaternion(glmQuat.x,glmQuat.y,glmQuat.z,glmQuat.w),btVector3(entity.getPosition().x,entity.getPosition().y,entity.getPosition().z)));
|
btDefaultMotionState* motion = new btDefaultMotionState(btTransform(btQuaternion(glmQuat.x,glmQuat.y,glmQuat.z,glmQuat.w),btVector3(entity.getPosition().x,entity.getPosition().y,entity.getPosition().z)));
|
||||||
|
|
||||||
btVector3 inertia(0,0,0);
|
btVector3 inertia(0,0,0);
|
||||||
if(mass != 0.0)
|
if(mass != 0.0)
|
||||||
{
|
{
|
||||||
box->calculateLocalInertia((btScalar)mass,inertia);
|
box->calculateLocalInertia((btScalar)mass,inertia);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
btRigidBody::btRigidBodyConstructionInfo info(mass,motion,box,inertia);
|
||||||
btRigidBody::btRigidBodyConstructionInfo info(mass,motion,box,inertia);
|
|
||||||
|
btRigidBody* body = new btRigidBody(info);
|
||||||
btRigidBody* body = new btRigidBody(info);
|
|
||||||
|
|
||||||
body->setDamping(dampningL, dampningA);
|
body->setDamping(dampningL, dampningA);
|
||||||
|
|
||||||
world->addRigidBody(body,COL_OBJECTS, objectsPhysicsCollision);
|
world->addRigidBody(body,COL_OBJECTS, objectsPhysicsCollision);
|
||||||
|
|
||||||
bodies.push_back(body);
|
bodies.push_back(body);
|
||||||
|
|
||||||
if(bodies.size() != indice)
|
if(bodies.size() != indice)
|
||||||
throw std::invalid_argument( "Bodies out of Sync" );
|
throw std::invalid_argument( "Bodies out of Sync" );
|
||||||
}
|
}
|
||||||
|
|
||||||
void Physics::addSphere(float rad, Entity entity, float mass, float dampningL, float dampningA, unsigned indice,bool rotate)
|
void Physics::addSphere(float rad, Entity entity, float mass, float dampningL, float dampningA, unsigned indice,bool rotate)
|
||||||
{
|
{
|
||||||
if(bodies.size() == indice) //(user's initial) height, not the actual height. More...
|
if(bodies.size() == indice) //(user's initial) height, not the actual height. More...
|
||||||
throw std::invalid_argument( "Bodies out of Sync" );
|
throw std::invalid_argument( "Bodies out of Sync" );
|
||||||
|
|
||||||
btSphereShape* sphere = new btSphereShape(rad);
|
btSphereShape* sphere = new btSphereShape(rad);
|
||||||
btVector3 inertia(0,0,0);
|
btVector3 inertia(0,0,0);
|
||||||
if(mass != 0.0)
|
if(mass != 0.0)
|
||||||
{
|
{
|
||||||
sphere->calculateLocalInertia((btScalar)mass,inertia);
|
sphere->calculateLocalInertia((btScalar)mass,inertia);
|
||||||
}
|
}
|
||||||
|
|
||||||
glm::quat glmQuat = glm::quat_cast(entity.getRotation());
|
glm::quat glmQuat = glm::quat_cast(entity.getRotation());
|
||||||
|
|
||||||
btDefaultMotionState* motion = new btDefaultMotionState(btTransform(btQuaternion(glmQuat.x,glmQuat.y,glmQuat.z,glmQuat.w),btVector3(entity.getPosition().x,entity.getPosition().y,entity.getPosition().z)));
|
btDefaultMotionState* motion = new btDefaultMotionState(btTransform(btQuaternion(glmQuat.x,glmQuat.y,glmQuat.z,glmQuat.w),btVector3(entity.getPosition().x,entity.getPosition().y,entity.getPosition().z)));
|
||||||
|
|
||||||
btRigidBody::btRigidBodyConstructionInfo info(mass,motion,sphere,inertia);
|
btRigidBody::btRigidBodyConstructionInfo info(mass,motion,sphere,inertia);
|
||||||
|
|
||||||
|
btRigidBody* body = new btRigidBody(info);
|
||||||
btRigidBody* body = new btRigidBody(info);
|
|
||||||
|
|
||||||
body->setDamping(dampningL, dampningA);
|
body->setDamping(dampningL, dampningA);
|
||||||
|
|
||||||
world->addRigidBody(body,COL_OBJECTS, objectsPhysicsCollision);
|
world->addRigidBody(body,COL_OBJECTS, objectsPhysicsCollision);
|
||||||
|
|
||||||
bodies.push_back(body);
|
bodies.push_back(body);
|
||||||
|
|
||||||
body->setSleepingThresholds(0,0);
|
body->setSleepingThresholds(0,0);
|
||||||
|
|
||||||
if(bodies.size() != indice)
|
if(bodies.size() != indice)
|
||||||
throw std::invalid_argument( "Bodies out of Sync" );
|
throw std::invalid_argument( "Bodies out of Sync" );
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void Physics::addCamera() //Camera Creator automatically called when player is created
|
void Physics::addCamera() //Camera Creator automatically called when player is created
|
||||||
{
|
{
|
||||||
btSphereShape* sphere = new btSphereShape(0.5f);//we use this to make a more interesting camera, that does not interpenetrate with the terrain/objects
|
btSphereShape* sphere = new btSphereShape(0.5f); //we use this to make a more interesting camera, that does not interpenetrate with the terrain/objects
|
||||||
|
|
||||||
btVector3 inertia(0,0,0); //rotation handled elsewhere (as it always has to look at the player)
|
|
||||||
|
|
||||||
btVector3 direction(1,1,1);
|
|
||||||
direction.normalize();
|
|
||||||
direction*=5; //create a offset of lenth 5 so we have a stable camera at the beginning
|
|
||||||
btDefaultMotionState* motion = new btDefaultMotionState(btTransform(btQuaternion(0,0,0,1),playerBall->getCenterOfMassPosition()+direction));
|
|
||||||
|
|
||||||
btRigidBody::btRigidBodyConstructionInfo info(0.001,motion,sphere,inertia);
|
|
||||||
|
|
||||||
cameraBody = new btRigidBody(info);
|
|
||||||
|
|
||||||
cameraBody->setDamping(0.9,0.5); //this damping factor leaves a relativly smoothe system
|
|
||||||
|
|
||||||
world->addRigidBody(cameraBody,COL_OBJECTS, objectsPhysicsCollision);
|
|
||||||
|
|
||||||
cameraBody->setGravity(btVector3(0,0,0));
|
|
||||||
|
|
||||||
cameraBody->setSleepingThresholds(0,0); //very important, otherwise camera may go to sleep, aka not move until next collision
|
|
||||||
|
|
||||||
|
btVector3 inertia(0,0,0); //rotation handled elsewhere (as it always has to look at the player)
|
||||||
|
|
||||||
|
btVector3 direction(1,1,1);
|
||||||
|
direction.normalize();
|
||||||
|
direction*=5; //create a offset of lenth 5 so we have a stable camera at the beginning
|
||||||
|
btDefaultMotionState* motion = new btDefaultMotionState(btTransform(btQuaternion(0,0,0,1),playerBall->getCenterOfMassPosition()+direction));
|
||||||
|
|
||||||
|
btRigidBody::btRigidBodyConstructionInfo info(0.001,motion,sphere,inertia);
|
||||||
|
|
||||||
|
cameraBody = new btRigidBody(info);
|
||||||
|
|
||||||
|
cameraBody->setDamping(0.9,0.5); //this damping factor leaves a relativly smoothe system
|
||||||
|
|
||||||
|
world->addRigidBody(cameraBody,COL_OBJECTS, objectsPhysicsCollision);
|
||||||
|
|
||||||
|
cameraBody->setGravity(btVector3(0,0,0));
|
||||||
|
|
||||||
|
cameraBody->setSleepingThresholds(0,0); //very important, otherwise camera may go to sleep, aka not move until next collision
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
//update functions
|
//update functions
|
||||||
glm::vec3 Physics::getCameraPosition()
|
glm::vec3 Physics::getCameraPosition()
|
||||||
{
|
{
|
||||||
btVector3 origin = cameraBody->getCenterOfMassPosition();
|
btVector3 origin = cameraBody->getCenterOfMassPosition();
|
||||||
glm::vec3 save(origin.getX(),origin.getY(),origin.getZ());
|
glm::vec3 save(origin.getX(),origin.getY(),origin.getZ());
|
||||||
return save;
|
return save;
|
||||||
}
|
}
|
||||||
|
|
||||||
glm::vec3 Physics::getCameraToPlayer()//returns a glm::vec3 the goes from the camera to the player
|
glm::vec3 Physics::getCameraToPlayer() //returns a glm::vec3 the goes from the camera to the player
|
||||||
{
|
{
|
||||||
btVector3 origin = playerBall->getCenterOfMassPosition() - cameraBody->getCenterOfMassPosition();
|
btVector3 origin = playerBall->getCenterOfMassPosition() - cameraBody->getCenterOfMassPosition();
|
||||||
glm::vec3 save(origin.getX(),origin.getY(),origin.getZ());
|
glm::vec3 save(origin.getX(),origin.getY(),origin.getZ());
|
||||||
return save;
|
return save;
|
||||||
}
|
}
|
||||||
|
|
||||||
glm::vec3 Physics::getPos(int i) //this and the next function are used to synchronize the graphics data and the physics data
|
glm::vec3 Physics::getPos(int i) //this and the next function are used to synchronize the graphics data and the physics data
|
||||||
{
|
{
|
||||||
btVector3 origin = bodies[i]->getCenterOfMassPosition();
|
btVector3 origin = bodies[i]->getCenterOfMassPosition();
|
||||||
glm::vec3 save(origin.getX(),origin.getY(),origin.getZ());
|
glm::vec3 save(origin.getX(),origin.getY(),origin.getZ());
|
||||||
return save;
|
return save;
|
||||||
}
|
}
|
||||||
|
|
||||||
glm::mat4 Physics::getRotation(int i)
|
glm::mat4 Physics::getRotation(int i)
|
||||||
{
|
{
|
||||||
btQuaternion quat = bodies[i]->getOrientation();
|
btQuaternion quat = bodies[i]->getOrientation();
|
||||||
|
|
||||||
glm::mat4 matrix = glm::rotate(
|
glm::mat4 matrix = glm::rotate(
|
||||||
quat.getAngle(),
|
quat.getAngle(),
|
||||||
glm::vec3(quat.getAxis().getX(), quat.getAxis().getY(), quat.getAxis().getZ())
|
glm::vec3(quat.getAxis().getX(), quat.getAxis().getY(), quat.getAxis().getZ())
|
||||||
); //somewhat clunky, but basicly creates a rotation matrix out of the angle of the body, and its axis (from the quaterion in bullet)
|
); //somewhat clunky, but basicly creates a rotation matrix out of the angle of the body, and its axis (from the quaterion in bullet)
|
||||||
return matrix;
|
return matrix;
|
||||||
}
|
}
|
||||||
|
|
||||||
//these are used to apply a force to the camera body according to the movement of the mouse
|
//these are used to apply a force to the camera body according to the movement of the mouse
|
||||||
@ -388,13 +383,12 @@ void Physics::updateCameraPos(glm::vec2 mouseMovement, float strength)
|
|||||||
btVector3 change = playerBall->getCenterOfMassPosition()-cameraBody->getCenterOfMassPosition();
|
btVector3 change = playerBall->getCenterOfMassPosition()-cameraBody->getCenterOfMassPosition();
|
||||||
change.setY(0);
|
change.setY(0);
|
||||||
change.normalize(); //normalize so that the distance between camera and body does not matter
|
change.normalize(); //normalize so that the distance between camera and body does not matter
|
||||||
change *= (mouseMovement.y);//we start with left/right movement because this needs to be calculated via a crossproduct, and the up down value would alter that
|
change *= (mouseMovement.y); //we start with left/right movement because this needs to be calculated via a crossproduct, and the up down value would alter that
|
||||||
change = btCross(btVector3(0,1,0),change);
|
change = btCross(btVector3(0,1,0),change);
|
||||||
change.setY(mouseMovement.x/5);//scaleing because otherwise oup/down much stronger then left right
|
change.setY(mouseMovement.x/5); //scaleing because otherwise oup/down much stronger then left right
|
||||||
change *= strength / cameraBody->getInvMass();
|
change *= strength / cameraBody->getInvMass();
|
||||||
|
|
||||||
cameraBody->applyCentralForce(change);
|
cameraBody->applyCentralForce(change);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//use the crossproduct to correctly apply a torque to the palyer if function called
|
//use the crossproduct to correctly apply a torque to the palyer if function called
|
||||||
@ -441,47 +435,47 @@ void Physics::rollRight(glm::vec3 camPos,float strength)
|
|||||||
|
|
||||||
void Physics::addStaticGroundPlane()
|
void Physics::addStaticGroundPlane()
|
||||||
{
|
{
|
||||||
btCollisionShape* groundShape = new btStaticPlaneShape(btVector3(0, 1, 0), 0);
|
btCollisionShape* groundShape = new btStaticPlaneShape(btVector3(0, 1, 0), 0);
|
||||||
btDefaultMotionState* groundMotionState = new btDefaultMotionState(btTransform(btQuaternion(0, 0, 0, 1), btVector3(0, 0, 0)));
|
btDefaultMotionState* groundMotionState = new btDefaultMotionState(btTransform(btQuaternion(0, 0, 0, 1), btVector3(0, 0, 0)));
|
||||||
btRigidBody::btRigidBodyConstructionInfo groundRigidBodyCI(0, groundMotionState, groundShape, btVector3(0, 0, 0));
|
btRigidBody::btRigidBodyConstructionInfo groundRigidBodyCI(0, groundMotionState, groundShape, btVector3(0, 0, 0));
|
||||||
staticGroundBody = new btRigidBody(groundRigidBodyCI);
|
staticGroundBody = new btRigidBody(groundRigidBodyCI);
|
||||||
|
|
||||||
world->addRigidBody(staticGroundBody);
|
world->addRigidBody(staticGroundBody);
|
||||||
}//not needed anymoer, but still good for debugging
|
} //not needed anymoer, but still good for debugging
|
||||||
|
|
||||||
|
|
||||||
void Physics::kill()//delete dynamically allocated memory
|
void Physics::kill() //delete dynamically allocated memory
|
||||||
{
|
{
|
||||||
if (world == NULL) {
|
if (world == NULL) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
//btDynamimcWorld*
|
//btDynamimcWorld*
|
||||||
for(unsigned i = 0; i < bodies.size();i++)
|
for(unsigned i = 0; i < bodies.size();i++)
|
||||||
{
|
{
|
||||||
world->removeCollisionObject(bodies[i]); //go through the list of bodies in world for each body b, then remove exactly this body b from world
|
world->removeCollisionObject(bodies[i]); //go through the list of bodies in world for each body b, then remove exactly this body b from world
|
||||||
btMotionState* motionState = bodies[i]->getMotionState();
|
btMotionState* motionState = bodies[i]->getMotionState();
|
||||||
btCollisionShape* shape = bodies[i]->getCollisionShape();
|
btCollisionShape* shape = bodies[i]->getCollisionShape();
|
||||||
delete shape;
|
delete shape;
|
||||||
delete motionState;
|
delete motionState;
|
||||||
delete bodies[i];
|
delete bodies[i];
|
||||||
}
|
}
|
||||||
btMotionState* motionState = terrainBody->getMotionState();//delete the rest that are not in the array bodies
|
btMotionState* motionState = terrainBody->getMotionState(); //delete the rest that are not in the array bodies
|
||||||
btCollisionShape* shape = terrainBody->getCollisionShape();
|
btCollisionShape* shape = terrainBody->getCollisionShape();
|
||||||
delete shape;
|
delete shape;
|
||||||
delete motionState;
|
delete motionState;
|
||||||
delete terrainBody;
|
delete terrainBody;
|
||||||
|
|
||||||
motionState = cameraBody->getMotionState();
|
motionState = cameraBody->getMotionState();
|
||||||
shape = cameraBody->getCollisionShape();
|
shape = cameraBody->getCollisionShape();
|
||||||
delete shape;
|
delete shape;
|
||||||
delete motionState;
|
delete motionState;
|
||||||
delete cameraBody; //note: palyerBall is also in the array bodies so we do not need to clean it up
|
delete cameraBody; //note: palyerBall is also in the array bodies so we do not need to clean it up
|
||||||
|
|
||||||
delete dispatcher; //clean up rest
|
delete dispatcher; //clean up rest
|
||||||
delete colConfig;
|
delete colConfig;
|
||||||
delete solver;
|
delete solver;
|
||||||
delete broadphase;
|
delete broadphase;
|
||||||
delete world;
|
delete world;
|
||||||
|
|
||||||
//feel like a good little programmer because everything is clean
|
//feel like a good little programmer because everything is clean
|
||||||
}
|
}
|
||||||
|
@ -81,7 +81,7 @@ class Physics {
|
|||||||
void addCamera(); //Do NOT impliment before Player has been created;
|
void addCamera(); //Do NOT impliment before Player has been created;
|
||||||
|
|
||||||
btDynamicsWorld* world = NULL; //contains physical attributes of the world.
|
btDynamicsWorld* world = NULL; //contains physical attributes of the world.
|
||||||
btDispatcher* dispatcher; //
|
btDispatcher* dispatcher;
|
||||||
btCollisionConfiguration* colConfig; //defines the type of collision detection.
|
btCollisionConfiguration* colConfig; //defines the type of collision detection.
|
||||||
btBroadphaseInterface* broadphase; //defines how objects are culled from collision detection.
|
btBroadphaseInterface* broadphase; //defines how objects are culled from collision detection.
|
||||||
btConstraintSolver* solver; //solver for forces and impulses.
|
btConstraintSolver* solver; //solver for forces and impulses.
|
||||||
@ -103,7 +103,7 @@ enum collisionTypes{
|
|||||||
class btDistanceConstraint : public btPoint2PointConstraint
|
class btDistanceConstraint : public btPoint2PointConstraint
|
||||||
{
|
{
|
||||||
protected:
|
protected:
|
||||||
btScalar m_distance;
|
btScalar m_distance;
|
||||||
public:
|
public:
|
||||||
btDistanceConstraint(btRigidBody& rbA,btRigidBody& rbB, const btVector3& pivotInA,const btVector3& pivotInB, btScalar dist)
|
btDistanceConstraint(btRigidBody& rbA,btRigidBody& rbB, const btVector3& pivotInA,const btVector3& pivotInB, btScalar dist)
|
||||||
: btPoint2PointConstraint(rbA, rbB, pivotInA, pivotInB)
|
: btPoint2PointConstraint(rbA, rbB, pivotInA, pivotInB)
|
||||||
|
45
terrain.cc
45
terrain.cc
@ -18,16 +18,15 @@ void Terrain::load() {
|
|||||||
if (error) {
|
if (error) {
|
||||||
std::cout << "Decoder error " << error << " from Terrain::load: " << lodepng_error_text(error) << std::endl;
|
std::cout << "Decoder error " << error << " from Terrain::load: " << lodepng_error_text(error) << std::endl;
|
||||||
}
|
}
|
||||||
this->heightmap = new float*[this->heightmapHeight]; //initialize the heightmap
|
this->heightmap = new float*[this->heightmapHeight]; //initialize the heightmap
|
||||||
for(unsigned int rowNum = 0; rowNum < this->heightmapHeight; rowNum++){ //read in the heightmap
|
for(unsigned int rowNum = 0; rowNum < this->heightmapHeight; rowNum++){ //read in the heightmap
|
||||||
this->heightmap[rowNum] = new float[this->heightmapWidth];
|
this->heightmap[rowNum] = new float[this->heightmapWidth];
|
||||||
for(unsigned int columnNum = 0; columnNum < this->heightmapWidth; columnNum++){
|
for(unsigned int columnNum = 0; columnNum < this->heightmapWidth; columnNum++){
|
||||||
this->heightmap[rowNum][columnNum] = (float)(image[(rowNum*heightmapWidth+columnNum)*4]) / 6; //<--heightmap is scaled here
|
this->heightmap[rowNum][columnNum] = (float)(image[(rowNum*heightmapWidth+columnNum)*4]) / 6; //<--heightmap is scaled here
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
this->makeTriangleMesh();
|
this->makeTriangleMesh();
|
||||||
heightmapChanged = false; //no need to make a TriangleMesh again before rendering
|
heightmapChanged = false; //no need to make a TriangleMesh again before rendering
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void Terrain::makeTriangleMesh(){
|
void Terrain::makeTriangleMesh(){
|
||||||
@ -37,19 +36,19 @@ void Terrain::makeTriangleMesh(){
|
|||||||
ab->defineAttribute("aPosition", GL_FLOAT, 3);
|
ab->defineAttribute("aPosition", GL_FLOAT, 3);
|
||||||
ab->defineAttribute("aTexCoord", GL_FLOAT, 2);
|
ab->defineAttribute("aTexCoord", GL_FLOAT, 2);
|
||||||
ab->defineAttribute("aNormal", GL_FLOAT, 3);
|
ab->defineAttribute("aNormal", GL_FLOAT, 3);
|
||||||
|
|
||||||
unsigned int rowNum=0, columnNum=0, dataCount=0, floatsPerVertex=8; //initializing:
|
unsigned int rowNum=0, columnNum=0, dataCount=0, floatsPerVertex=8; //initializing:
|
||||||
bool movingRight = true, isUp = true;
|
bool movingRight = true, isUp = true;
|
||||||
int numVertices = (this->heightmapHeight - 1) * (this->heightmapWidth * 2 + 1) + 1;
|
int numVertices = (this->heightmapHeight - 1) * (this->heightmapWidth * 2 + 1) + 1;
|
||||||
float* abData = new float[numVertices * floatsPerVertex];
|
float* abData = new float[numVertices * floatsPerVertex];
|
||||||
|
|
||||||
while(rowNum < this->heightmapHeight){ //traversing the Triangle Strip!
|
while(rowNum < this->heightmapHeight){ //traversing the Triangle Strip!
|
||||||
set_abData(abData, dataCount, rowNum, columnNum);
|
set_abData(abData, dataCount, rowNum, columnNum);
|
||||||
dataCount += floatsPerVertex;
|
dataCount += floatsPerVertex;
|
||||||
if (isUp){
|
if (isUp){
|
||||||
rowNum = rowNum + 1;
|
rowNum = rowNum + 1;
|
||||||
isUp = false;
|
isUp = false;
|
||||||
}
|
}
|
||||||
else if (movingRight) {
|
else if (movingRight) {
|
||||||
if (columnNum == this->heightmapWidth - 1) {
|
if (columnNum == this->heightmapWidth - 1) {
|
||||||
set_abData(abData, dataCount, rowNum, columnNum);
|
set_abData(abData, dataCount, rowNum, columnNum);
|
||||||
@ -58,7 +57,7 @@ void Terrain::makeTriangleMesh(){
|
|||||||
dataCount += floatsPerVertex;
|
dataCount += floatsPerVertex;
|
||||||
movingRight = false;
|
movingRight = false;
|
||||||
rowNum = rowNum + 1;
|
rowNum = rowNum + 1;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
rowNum = rowNum - 1;
|
rowNum = rowNum - 1;
|
||||||
columnNum = columnNum + 1;
|
columnNum = columnNum + 1;
|
||||||
@ -81,7 +80,7 @@ void Terrain::makeTriangleMesh(){
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
ab->setDataElements(numVertices, abData);
|
ab->setDataElements(numVertices, abData);
|
||||||
this->triangleMesh = std::make_shared<ACGL::OpenGL::VertexArrayObject>();
|
this->triangleMesh = std::make_shared<ACGL::OpenGL::VertexArrayObject>();
|
||||||
this->triangleMesh->bind();
|
this->triangleMesh->bind();
|
||||||
@ -96,16 +95,16 @@ void Terrain::set_abData(float* abData, unsigned int dataCount, unsigned int row
|
|||||||
abData[dataCount] = (float)rowNum;
|
abData[dataCount] = (float)rowNum;
|
||||||
abData[dataCount+1] = heightmap[rowNum][columnNum];
|
abData[dataCount+1] = heightmap[rowNum][columnNum];
|
||||||
abData[dataCount+2] = (float)columnNum;
|
abData[dataCount+2] = (float)columnNum;
|
||||||
|
|
||||||
//set Texture Coordinate
|
//set Texture Coordinate
|
||||||
abData[dataCount+3] = (float)(rowNum % 2);
|
abData[dataCount+3] = (float)(rowNum % 2);
|
||||||
abData[dataCount+4] = (float)(columnNum % 2);
|
abData[dataCount+4] = (float)(columnNum % 2);
|
||||||
|
|
||||||
//setNormal
|
//setNormal
|
||||||
if (rowNum==0 || rowNum==(this->heightmapHeight-1) || columnNum==0 || columnNum==(this->heightmapWidth-1)){
|
if (rowNum==0 || rowNum==(this->heightmapHeight-1) || columnNum==0 || columnNum==(this->heightmapWidth-1)){
|
||||||
abData[dataCount+5] = 0.0;
|
abData[dataCount+5] = 0.0;
|
||||||
abData[dataCount+6] = 1.0;
|
abData[dataCount+6] = 1.0;
|
||||||
abData[dataCount+7] = 0.0;
|
abData[dataCount+7] = 0.0;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
glm::vec3 sumNormals = glm::vec3(0.0f, 0.0f, 0.0f);
|
glm::vec3 sumNormals = glm::vec3(0.0f, 0.0f, 0.0f);
|
||||||
|
@ -16,12 +16,12 @@ class Terrain {
|
|||||||
float** getHeightmap();
|
float** getHeightmap();
|
||||||
unsigned int getHeightmapHeight();
|
unsigned int getHeightmapHeight();
|
||||||
unsigned int getHeightmapWidth();
|
unsigned int getHeightmapWidth();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Material material;
|
Material material;
|
||||||
std::string heightmapFilePath;
|
std::string heightmapFilePath;
|
||||||
unsigned int heightmapHeight, heightmapWidth;
|
unsigned int heightmapHeight, heightmapWidth;
|
||||||
float** heightmap; //can be accessed like 'float[][]'
|
float** heightmap; //can be accessed like 'float[][]'
|
||||||
bool heightmapChanged;
|
bool heightmapChanged;
|
||||||
ACGL::OpenGL::SharedVertexArrayObject triangleMesh;
|
ACGL::OpenGL::SharedVertexArrayObject triangleMesh;
|
||||||
void makeTriangleMesh();
|
void makeTriangleMesh();
|
||||||
|
@ -15,7 +15,7 @@ class Level;
|
|||||||
class Trigger {
|
class Trigger {
|
||||||
public:
|
public:
|
||||||
Trigger(glm::vec3 position, float distance, bool isBigger, Object* object, std::string luaScript, lua_State* L, int objectToChange, std::string scriptPath);
|
Trigger(glm::vec3 position, float distance, bool isBigger, Object* object, std::string luaScript, lua_State* L, int objectToChange, std::string scriptPath);
|
||||||
Trigger();
|
Trigger();
|
||||||
~Trigger();
|
~Trigger();
|
||||||
void triggerUpdate();
|
void triggerUpdate();
|
||||||
bool deleteNotification(int deletedObjectIndex);
|
bool deleteNotification(int deletedObjectIndex);
|
||||||
|
Loading…
Reference in New Issue
Block a user