Implemented loading of physical objects. Compositions.xml holds mostly Dummy-Values for those.
This commit is contained in:
parent
f8773134f5
commit
f43f866fc4
@ -96,6 +96,8 @@
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<objectData>
|
<objectData>
|
||||||
<modelPath>marbleSmooth.obj</modelPath>
|
<modelPath>marbleSmooth.obj</modelPath>
|
||||||
<texturePath>MarbleTexture.png</texturePath>
|
<texturePath>MarbleTexture.png</texturePath>
|
||||||
@ -104,6 +106,8 @@
|
|||||||
<specularFactor>0.5</specularFactor>
|
<specularFactor>0.5</specularFactor>
|
||||||
<shininess>3.0</shininess>
|
<shininess>3.0</shininess>
|
||||||
<physicType>Player</physicType>
|
<physicType>Player</physicType>
|
||||||
|
<radius>1.25</radius>
|
||||||
|
<mass>8.0</mass>
|
||||||
</objectData>
|
</objectData>
|
||||||
|
|
||||||
<objectData>
|
<objectData>
|
||||||
@ -129,8 +133,8 @@
|
|||||||
<shininess>2.0</shininess>
|
<shininess>2.0</shininess>
|
||||||
<physicType>TriangleMeshBody</physicType>
|
<physicType>TriangleMeshBody</physicType>
|
||||||
<mass>2.0</mass>
|
<mass>2.0</mass>
|
||||||
<dampningL></dampningL>
|
<dampningL>1.0</dampningL>
|
||||||
<dampningA></dampningA>
|
<dampningA>1.0</dampningA>
|
||||||
</objectData>
|
</objectData>
|
||||||
|
|
||||||
<objectData>
|
<objectData>
|
||||||
@ -142,8 +146,8 @@
|
|||||||
<shininess>10.0</shininess>
|
<shininess>10.0</shininess>
|
||||||
<physicType>TriangleMeshBody</physicType>
|
<physicType>TriangleMeshBody</physicType>
|
||||||
<mass>0.0</mass>
|
<mass>0.0</mass>
|
||||||
<dampningL></dampningL>
|
<dampningL>1.0</dampningL>
|
||||||
<dampningA></dampningA>
|
<dampningA>1.0</dampningA>
|
||||||
</objectData>
|
</objectData>
|
||||||
|
|
||||||
<objectData>
|
<objectData>
|
||||||
@ -155,8 +159,8 @@
|
|||||||
<shininess>2.0</shininess>
|
<shininess>2.0</shininess>
|
||||||
<physicType>TriangleMeshBody</physicType>
|
<physicType>TriangleMeshBody</physicType>
|
||||||
<mass>1.0</mass>
|
<mass>1.0</mass>
|
||||||
<dampningL></dampningL>
|
<dampningL>1.0</dampningL>
|
||||||
<dampningA></dampningA>
|
<dampningA>1.0</dampningA>
|
||||||
</objectData>
|
</objectData>
|
||||||
|
|
||||||
<objectData>
|
<objectData>
|
||||||
@ -168,6 +172,6 @@
|
|||||||
<shininess>2.0</shininess>
|
<shininess>2.0</shininess>
|
||||||
<physicType>TriangleMeshBody</physicType>
|
<physicType>TriangleMeshBody</physicType>
|
||||||
<mass>0.0</mass>
|
<mass>0.0</mass>
|
||||||
<dampningL></dampningL>
|
<dampningL>1.0</dampningL>
|
||||||
<dampningA></dampningA>
|
<dampningA>1.0</dampningA>
|
||||||
</objectData>
|
</objectData>
|
||||||
|
31
level.cc
31
level.cc
@ -174,16 +174,37 @@ void Level::load() {
|
|||||||
glm::vec3 objectPosition = compPos + glm::vec3(rotatedObjectOffset.x,rotatedObjectOffset.y,rotatedObjectOffset.z);
|
glm::vec3 objectPosition = compPos + glm::vec3(rotatedObjectOffset.x,rotatedObjectOffset.y,rotatedObjectOffset.z);
|
||||||
Object* object = new Object(model, material, objectPosition, compRot);
|
Object* object = new Object(model, material, objectPosition, compRot);
|
||||||
objects.push_back(object);
|
objects.push_back(object);
|
||||||
//physicObjects.push_back(object);
|
physicObjects.push_back(object);
|
||||||
const char* charPhysicType = objectData->FirstChildElement("physicType")->GetText();
|
const char* charPhysicType = objectData->FirstChildElement("physicType")->GetText();
|
||||||
if(charPhysicType == NULL){
|
if(charPhysicType == NULL){
|
||||||
printf("XMLError: No physicType found.\n");
|
printf("XMLError: No physicType found.\n");
|
||||||
}
|
}
|
||||||
std::string physicType = charPhysicType;
|
std::string physicType = charPhysicType;
|
||||||
//TODO switch (physicType) and add object to physics
|
//add Object to physics
|
||||||
//if(compositionType == 20){
|
if (physicType.compare("Player") == 0){
|
||||||
// cameraCenter = object;
|
float radius, mass;
|
||||||
//}
|
errorCheck(objectData->FirstChildElement("radius")->QueryFloatText(&radius));
|
||||||
|
errorCheck(objectData->FirstChildElement("mass")->QueryFloatText(&mass));
|
||||||
|
this->physics.addPlayer(radius, *object, mass, physicObjects.size());
|
||||||
|
}
|
||||||
|
if (physicType.compare("Box") == 0){
|
||||||
|
float width, height, length, mass;
|
||||||
|
errorCheck(objectData->FirstChildElement("width")->QueryFloatText(&width));
|
||||||
|
errorCheck(objectData->FirstChildElement("height")->QueryFloatText(&height));
|
||||||
|
errorCheck(objectData->FirstChildElement("length")->QueryFloatText(&length));
|
||||||
|
errorCheck(objectData->FirstChildElement("mass")->QueryFloatText(&mass));
|
||||||
|
this->physics.addBox(width, height, length, *object, mass, physicObjects.size());
|
||||||
|
}
|
||||||
|
if (physicType.compare("TriangleMeshBody") == 0){
|
||||||
|
float mass, dampningL, dampningA;
|
||||||
|
errorCheck(objectData->FirstChildElement("mass")->QueryFloatText(&mass));
|
||||||
|
errorCheck(objectData->FirstChildElement("dampningL")->QueryFloatText(&dampningL));
|
||||||
|
errorCheck(objectData->FirstChildElement("dampningA")->QueryFloatText(&dampningA));
|
||||||
|
this->physics.addTriangleMeshBody(*object, mass, dampningL, dampningA, physicObjects.size());
|
||||||
|
}
|
||||||
|
if(compositionType == 20){
|
||||||
|
cameraCenter = object;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user