From d67b7b5b235129538d15ba30f03ae8e9a5f427ec Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Steffen=20F=C3=BCndgens?= Date: Fri, 12 Dec 2014 16:24:47 +0100 Subject: [PATCH] Implemented loading of gloabal lighting. Added physics parameters to Compositions.xml. --- Levels/ObjectSetups/Compositions.xml | 24 +++++- Levels/ObjectSetups/Level0.png | Bin 117 -> 146 bytes Levels/ObjectSetups/Level0.xml | 97 +++++++++++++++++++++++ level.cc | 110 +++++++++++---------------- 4 files changed, 165 insertions(+), 66 deletions(-) diff --git a/Levels/ObjectSetups/Compositions.xml b/Levels/ObjectSetups/Compositions.xml index c5f1ef9..b741e7d 100644 --- a/Levels/ObjectSetups/Compositions.xml +++ b/Levels/ObjectSetups/Compositions.xml @@ -5,7 +5,7 @@ 0.0 0.0 0.0 - 1.0 + 0.75 @@ -103,6 +103,7 @@ 0.5 0.5 3.0 + Player @@ -112,6 +113,11 @@ 0.6 0.4 2.0 + Box + 1.0 + 1.0 + 3.0 + 2.0 @@ -121,6 +127,10 @@ 0.6 0.4 2.0 + TriangleMeshBody + 2.0 + + @@ -130,6 +140,10 @@ 0.3 0.7 10.0 + TriangleMeshBody + 0.0 + + @@ -139,6 +153,10 @@ 0.6 0.4 2.0 + TriangleMeshBody + 1.0 + + @@ -148,4 +166,8 @@ 0.6 0.4 2.0 + TriangleMeshBody + 0.0 + + diff --git a/Levels/ObjectSetups/Level0.png b/Levels/ObjectSetups/Level0.png index 0d36b6d3a02fc77e05c7c685e6a2b25241552e62..05eaad6501129948e8a28620b703e4e2c3af3ff3 100644 GIT binary patch delta 116 zcmV-)0E_>1k^zt;ZXQrfR7GO}0ssI1V*vtV0Rv+J1Y-dOV*v(Z0S99N2x9>WLBH(1 z0000lNklnW1} delta 87 zcmbQlSUN!^kUzjD#P$FG|H+KZ$&75tj2y{~oSQ6mSTZm$D0;d$hEy^>bP0l+XkKgp?XP diff --git a/Levels/ObjectSetups/Level0.xml b/Levels/ObjectSetups/Level0.xml index 9f032f5..a93a3fa 100644 --- a/Levels/ObjectSetups/Level0.xml +++ b/Levels/ObjectSetups/Level0.xml @@ -26,6 +26,20 @@ 99 + + 1.0 + 0.0 + 0.0 + 0.0 + false + 2.500000 + 0.0 + -2.500000 + 1 + 7 + 99 + + 1.0 0.0 @@ -40,6 +54,34 @@ 99 + + 1.0 + 0.0 + 0.0 + 0.0 + false + -0.500000 + 0.0 + 1.500000 + 1 + 5 + 99 + + + + 1.0 + 0.0 + 0.0 + 0.0 + false + -0.500000 + 0.0 + -1.500000 + 1 + 4 + 99 + + 1.0 0.0 @@ -53,3 +95,58 @@ 3 99 + + + 1.0 + 0.0 + 0.0 + 0.0 + false + -3.500000 + 0.0 + -3.500000 + 1 + 2 + 99 + + + + 1.0 + 0.0 + 0.0 + 0.0 + false + -4.500000 + 0.0 + -4.500000 + 1 + 1 + 99 + + + + 1.0 + 1.0 + 1.0 + + + + 0.10 + 0.14 + 0.14 + 1.0 + + + + -1.0 + 1.5 + 1.0 + 1.0 + 1.0 + 0.9 + 0.2 + + + + skydome.png + diff --git a/level.cc b/level.cc index 89315d4..88e9f13 100644 --- a/level.cc +++ b/level.cc @@ -1,4 +1,5 @@ #include "level.hh" +#include using namespace tinyxml2; @@ -82,7 +83,7 @@ void Level::load() { objects.push_back(skydomeObject); skydome = skydomeObject; //load lighting parameters - float rColour, gColour, bColour, alpha, xOffset, yOffset, zOffset; + float rColour, gColour, bColour, alpha, xOffset, yOffset, zOffset, intensity; XMLElement* ambientElement = doc->FirstChildElement("ambientLight"); errorCheck(ambientElement->FirstChildElement("rColour")->QueryFloatText(&rColour)); errorCheck(ambientElement->FirstChildElement("gColour")->QueryFloatText(&gColour)); @@ -94,9 +95,15 @@ void Level::load() { errorCheck(fogElement->FirstChildElement("bColour")->QueryFloatText(&bColour)); errorCheck(fogElement->FirstChildElement("alpha")->QueryFloatText(&alpha)); fogColour = glm::vec4(rColour,gColour,bColour, alpha); - directionalLight = Light(glm::vec3(-1.0f, 1.5f, 1.0f), glm::vec3(1.0f, 1.0f, 0.9f), 0.2f); - - + XMLElement* directionalElement = doc->FirstChildElement("directionalLight"); + errorCheck(directionalElement->FirstChildElement("xOffset")->QueryFloatText(&xOffset)); + errorCheck(directionalElement->FirstChildElement("yOffset")->QueryFloatText(&yOffset)); + errorCheck(directionalElement->FirstChildElement("zOffset")->QueryFloatText(&zOffset)); + errorCheck(directionalElement->FirstChildElement("rColour")->QueryFloatText(&rColour)); + errorCheck(directionalElement->FirstChildElement("gColour")->QueryFloatText(&gColour)); + errorCheck(directionalElement->FirstChildElement("bColour")->QueryFloatText(&bColour)); + errorCheck(directionalElement->FirstChildElement("intensity")->QueryFloatText(&intensity)); + directionalLight = Light(glm::vec3(xOffset,yOffset,zOffset), glm::vec3(rColour,gColour,bColour), intensity); //load Objects XMLDocument* compositions = new XMLDocument(); const char* compositionsFile = "../Levels/ObjectSetups/Compositions.xml"; @@ -125,7 +132,6 @@ void Level::load() { errorCheck(object->FirstChildElement("scale")->QueryFloatText(&objectScale)); errorCheck(thisComposition->FirstChildElement("scale")->QueryFloatText(&compScale)); Model model = Model(modelPath, objectScale * compScale); - Material material; XMLElement* objectData = compositions->FirstChildElement("objectData"); for(; objectData; objectData=objectData->NextSiblingElement("objectData")){ const char* charDataModelPath = objectData->FirstChildElement("modelPath")->GetText(); @@ -144,38 +150,42 @@ void Level::load() { printf("XMLError: No texturePath found in objectData.\n"); } std::string texturePath = charTexturePath; - material = Material(texturePath, ambientFactor, diffuseFactor, specularFactor, shininess); + Material material = Material(texturePath, ambientFactor, diffuseFactor, specularFactor, shininess); + float compXPos, compYOffset, compZPos; + glm::vec3 objectOffset, compRot; + errorCheck(object->FirstChildElement("xOffset")->QueryFloatText(&objectOffset[0])); + errorCheck(object->FirstChildElement("yOffset")->QueryFloatText(&objectOffset[1])); + errorCheck(object->FirstChildElement("zOffset")->QueryFloatText(&objectOffset[2])); + errorCheck(thisComposition->FirstChildElement("xPos")->QueryFloatText(&compXPos)); + errorCheck(thisComposition->FirstChildElement("yOffset")->QueryFloatText(&compYOffset)); + errorCheck(thisComposition->FirstChildElement("zPos")->QueryFloatText(&compZPos)); + errorCheck(thisComposition->FirstChildElement("xRot")->QueryFloatText(&compRot[0])); + errorCheck(thisComposition->FirstChildElement("yRot")->QueryFloatText(&compRot[1])); + errorCheck(thisComposition->FirstChildElement("zRot")->QueryFloatText(&compRot[2])); + glm::vec3 compPos = glm::vec3(compXPos, + compYOffset+terrain.getHeightmap()[int(compXPos-0.5+0.5*terrain.getHeightmapHeight())] + [int(compZPos-0.5+0.5*terrain.getHeightmapWidth())], + compZPos); + objectOffset = objectOffset * compScale; + glm::vec4 rotatedObjectOffset = glm::rotate(compRot.x, glm::vec3(1.0f, 0.0f, 0.0f)) + * glm::rotate(compRot.y, glm::vec3(0.0f, 1.0f, 0.0f)) + * glm::rotate(compRot.z, glm::vec3(0.0f, 0.0f, 1.0f)) + * glm::vec4(objectOffset, 0); + glm::vec3 objectPosition = compPos + glm::vec3(rotatedObjectOffset.x,rotatedObjectOffset.y,rotatedObjectOffset.z); + Object* object = new Object(model, material, objectPosition, compRot); + objects.push_back(object); + //physicObjects.push_back(object); + const char* charPhysicType = objectData->FirstChildElement("physicType")->GetText(); + if(charPhysicType == NULL){ + printf("XMLError: No physicType found.\n"); + } + std::string physicType = charPhysicType; + //TODO switch (physicType) and add object to physics + //if(compositionType == 20){ + // cameraCenter = object; + //} } } - float compXPos, compYOffset, compZPos; - glm::vec3 objectOffset, compRot; - errorCheck(object->FirstChildElement("xOffset")->QueryFloatText(&objectOffset[0])); - errorCheck(object->FirstChildElement("yOffset")->QueryFloatText(&objectOffset[1])); - errorCheck(object->FirstChildElement("zOffset")->QueryFloatText(&objectOffset[2])); - errorCheck(thisComposition->FirstChildElement("xPos")->QueryFloatText(&compXPos)); - errorCheck(thisComposition->FirstChildElement("yOffset")->QueryFloatText(&compYOffset)); - errorCheck(thisComposition->FirstChildElement("zPos")->QueryFloatText(&compZPos)); - errorCheck(thisComposition->FirstChildElement("xRot")->QueryFloatText(&compRot[0])); - errorCheck(thisComposition->FirstChildElement("yRot")->QueryFloatText(&compRot[1])); - errorCheck(thisComposition->FirstChildElement("zRot")->QueryFloatText(&compRot[2])); - glm::vec3 compPos = glm::vec3(compXPos, - compYOffset+terrain.getHeightmap()[int(compXPos-0.5+0.5*terrain.getHeightmapHeight())] - [int(compZPos-0.5+0.5*terrain.getHeightmapWidth())], - compZPos); - objectOffset = objectOffset * compScale; - glm::vec4 rotatedObjectOffset = glm::rotate(compRot.x, glm::vec3(1.0f, 0.0f, 0.0f)) - * glm::rotate(compRot.y, glm::vec3(0.0f, 1.0f, 0.0f)) - * glm::rotate(compRot.z, glm::vec3(0.0f, 0.0f, 1.0f)) - * glm::vec4(objectOffset, 0); - glm::vec3 objectPosition = compPos + glm::vec3(rotatedObjectOffset.x,rotatedObjectOffset.y,rotatedObjectOffset.z); - Object* object = new Object(model, material, objectPosition, compRot); - objects.push_back(object); - //TODO if object has physics: physicObjects.push_back(object); //should not all objects have physics in the end? - //TODO add object to physics - //if(compositionType == 20){ - // cameraCenter = object; - // this->physics.addPlayer(1.25f,*object,8.0f,physicObjects.size()); - //} } XMLElement* light = composition->FirstChildElement("light"); for(; light; light=light->NextSiblingElement("light")){ @@ -222,36 +232,6 @@ void Level::load() { physicObjects.push_back(object); this->physics.addPlayer(1.25f,*object,8.0f,physicObjects.size()); cameraCenter = object; - - Model torchModel = Model("torch.obj", 0.75f); - Material torchMaterial = Material("torchTexture.png", 0.1f, 0.3f, 0.7f, 10.0f); - //Create object - Object* torchObject = new Object(torchModel, torchMaterial, glm::vec3(-3.0f, 6.0f, 0.0f), - glm::vec3(0.0f, 1.0472f, 0.0f)); - objects.push_back(torchObject); - - Model blockModel = Model("block.obj", 1.0f); - Material blockMaterial = Material("blockTexture_small.png", 0.1f, 0.6, 0.4f, 2.0f); - Object* blockObject = new Object(blockModel, blockMaterial, glm::vec3(0.0f, 10.0f, 0.0f), - glm::vec3(0.0f, 0.0f, 0.0f)); - objects.push_back(blockObject); - physicObjects.push_back(blockObject); - physics.addBox(1,3.0f,1,*blockObject,2,physicObjects.size()); - - Object* blockObject2 = new Object(blockModel, blockMaterial, glm::vec3(5.0f, 10.0f, 5.0f), - glm::vec3(0.0f, 0.0f, 0.0f)); - objects.push_back(blockObject2); - physicObjects.push_back(blockObject2); - physics.addBox(1,3.0f,1,*blockObject2,2,physicObjects.size()); - - Model columnModel = Model("column.obj", 1.0f); - Material columnMaterial = Material("columnTexture2.png", 0.1f, 0.6, 0.4f, 2.0f); - Object* columnObject = new Object(columnModel, columnMaterial, glm::vec3(-2.0f, 7.0f, -2.0f), - glm::vec3(0.0f, 0.0f, 0.0f)); - objects.push_back(columnObject); - - - } void Level::render(ACGL::OpenGL::SharedShaderProgram shader, bool lightingPass) {