diff --git a/.gitignore b/.gitignore index 93e58f0..6dbd318 100644 --- a/.gitignore +++ b/.gitignore @@ -5,4 +5,4 @@ CMakeLists.txt.user *.cbp *~ *.zip - +*.db diff --git a/Levels/ObjectSetups/Compositions.xml b/Levels/ObjectSetups/Compositions.xml index 852e2c2..c28a0dd 100644 --- a/Levels/ObjectSetups/Compositions.xml +++ b/Levels/ObjectSetups/Compositions.xml @@ -110,7 +110,7 @@ marbleSmooth.obj - MarbleTexture.png + Marbletexture.png 0.1 0.5 0.5 diff --git a/Levels/ObjectSetups/Level1.xml b/Levels/ObjectSetups/Level1.xml new file mode 100644 index 0000000..2840e1c --- /dev/null +++ b/Levels/ObjectSetups/Level1.xml @@ -0,0 +1,94 @@ + + + + 1.0 + 0.0 + 0.0 + 0.0 + false + 0.000000 + 30.0 + 0.000000 + 1 + 100 + 20 + + + + + + 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 + + + + bla + 5.0 + 14.0 + 0.0 + 4.0 + false + 1 + 100 + 0 + 0 + + + + - + 0.0 + 0.0 + 0.0 + 1.0 + false + 0 + 0 + 0 + - + diff --git a/application.cc b/application.cc index 6019fdb..5a35281 100644 --- a/application.cc +++ b/application.cc @@ -8,7 +8,7 @@ Application::Application() { void Application::init() { // choose Level TODO: Choose this in a menu - this->level = Level("0"); + this->level = Level("1"); // Don't change this! ignoredMouseUpdates = 0; cameraLock = true; diff --git a/level.cc b/level.cc index 5ec8c22..cb9f2b7 100644 --- a/level.cc +++ b/level.cc @@ -107,7 +107,7 @@ void Level::load() { directionalLight = Light(glm::vec3(xOffset,yOffset,zOffset), glm::vec3(rColour,gColour,bColour), intensity); //load Objects - std::vector objectIdentifiers; //The first entry is the index in objects, the others are idGreen, idBlue and objectNum. + std::vector> objectIdentifiers = std::vector>(); //The first entry is the index in objects, the others are idGreen, idBlue and objectNum. XMLDocument* compositions = new XMLDocument(); const char* compositionsFile = "../Levels/ObjectSetups/Compositions.xml"; compositions->LoadFile(compositionsFile); @@ -186,7 +186,7 @@ void Level::load() { Object* object = new Object(model, material, objectPosition, compRot); objects.push_back(object); //create an identifier for this object - int* objectIdentifier = new int[4]; + std::vector objectIdentifier = std::vector(4); objectIdentifier[0] = objects.size()-1; int idGreen, idBlue; errorCheck(thisComposition->FirstChildElement("idGreen")->QueryIntText(&idGreen)); @@ -219,9 +219,7 @@ void Level::load() { float dampningL, dampningA; errorCheck(objectData->FirstChildElement("dampningL")->QueryFloatText(&dampningL)); errorCheck(objectData->FirstChildElement("dampningA")->QueryFloatText(&dampningA)); - std::string bulletModelPath = modelPath.substr(0, modelPath.length()-3); - bulletModelPath += "bullet"; - this->physics.addTriangleMeshBody(*object,modelPath,mass,0.5,0.5,physicObjects.size()); + this->physics.addTriangleMeshBody(*object, modelPath, mass, dampningL, dampningA, physicObjects.size()); } else{ printf("XMLError: Not a valid physicType.\n"); } @@ -281,35 +279,55 @@ void Level::load() { std::string name = charName; if (name.compare("-") != 0){ float xPos, yPos, zPos, distance; - std::vector position; + glm::vec3 position; bool isBigger; - int idGreen, idBlue, objectNum; + int idGreen, idBlue, objectNum, functionPointer_int; errorCheck(xmlTrigger->FirstChildElement("xPosition")->QueryFloatText(&xPos)); errorCheck(xmlTrigger->FirstChildElement("yPosition")->QueryFloatText(&yPos)); errorCheck(xmlTrigger->FirstChildElement("zPosition")->QueryFloatText(&zPos)); errorCheck(xmlTrigger->FirstChildElement("distance")->QueryFloatText(&distance)); - position.push_back(xPos); - position.push_back(yPos); - position.push_back(zPos); + position = glm::vec3(xPos, yPos, zPos); errorCheck(xmlTrigger->FirstChildElement("isBiggerThan")->QueryBoolText(&isBigger)); errorCheck(xmlTrigger->FirstChildElement("idGreen")->QueryIntText(&idGreen)); errorCheck(xmlTrigger->FirstChildElement("idBlue")->QueryIntText(&idBlue)); errorCheck(xmlTrigger->FirstChildElement("objectNum")->QueryIntText(&objectNum)); - //TODO find the object - //Trigger trigger = Trigger::Trigger(position, distance, isBigger, Object* object, void (*functionPointer)()); - //triggers.push_back(trigger); + Object* object=0; + for (unsigned int i = 0; iFirstChildElement("functionPointer")->QueryIntText(&functionPointer_int)); + void (*functionPointer)() = NULL; + switch(functionPointer_int) { + case 0: + functionPointer = &trigger_function_0; + break; + case 1: + functionPointer = &trigger_function_1; + break; + case 2: + functionPointer = &trigger_function_2; + break; + case 3: + functionPointer = &trigger_function_3; + break; + case 4: + functionPointer = &trigger_function_4; + break; + default: + printf("Trigger function could not be found."); + } + if (object != 0) { + Trigger trigger = Trigger(position, distance, isBigger, object, functionPointer); + triggers.push_back(trigger); + } + else { + printf("Trigger object not found.\n"); + } } } - - //add player (//TODO remove this as soon as we have a levelSetup with a player) - Model marbleModel = Model("marbleSmooth.obj", 0.75f); - Material marbleMaterial = Material("Marbletexture.png", 0.1f, 0.5f, 0.5f, 3.0f); - Object* object = new Object(marbleModel, marbleMaterial, glm::vec3(2.0f, 20.0f, 2.0f), - glm::vec3(0.0f, 0.0f, 0.0f)); - objects.push_back(object); - physicObjects.push_back(object); - this->physics.addPlayer(1.25f,*object,8.0f,physicObjects.size()); - cameraCenter = object; } void Level::render(ACGL::OpenGL::SharedShaderProgram shader, bool lightingPass, @@ -362,6 +380,10 @@ void Level::update(float runTime, glm::vec2 mouseDelta, bool wPressed, bool aPre skydome->setPosition(glm::vec3(cameraCenter->getPosition().x, 0.0f, cameraCenter->getPosition().z)); + + for(unsigned int i = 0; i position, float distance, bool isBigger, Object* object, void (*functionPointer)()) { +Trigger::Trigger(glm::vec3 position, float distance, bool isBigger, Object* object, void (*functionPointer)()) { this->position=position; this->distance=distance; this->isBigger=isBigger; this->object=object; - this->functionPointer=functionPointer; + this->functionPointer = functionPointer; } Trigger::Trigger(){ @@ -15,5 +15,10 @@ Trigger::~Trigger(){ } void Trigger::triggerUpdate(){ - + if (isBigger && (glm::distance(object->getPosition(), position) > distance)) { + (*functionPointer)(); + } + else if (!isBigger && (glm::distance(object->getPosition(), position) < distance)) { + (*functionPointer)(); + } } diff --git a/trigger.hh b/trigger.hh index 04fbac1..d9c74fb 100644 --- a/trigger.hh +++ b/trigger.hh @@ -6,12 +6,12 @@ class Trigger { public: - Trigger(std::vector position, float distance, bool isBigger, Object* object, void (*functionPointer)()); + Trigger(glm::vec3 position, float distance, bool isBigger, Object* object, void (*functionPointer)()); Trigger(); ~Trigger(); void triggerUpdate(); private: - std::vector position; + glm::vec3 position; float distance; bool isBigger; Object* object;