Saxum/level.cc

314 lines
13 KiB
C++
Raw Normal View History

#include "level.hh"
using namespace tinyxml2;
2014-12-04 14:07:31 +00:00
Level::Level(std::string levelNum){
this->levelNum = levelNum;
this->terrain = Terrain(levelNum);
2014-11-21 23:39:58 +00:00
skydomeSize = 50.0f;
}
Level::Level() {
}
Level::~Level() {
for(unsigned int i = 0; i<objects.size(); i++) {
delete(objects.at(i));
}
}
void Level::errorCheck(XMLError error){
if (error) {
printf("XMLError: ");
if (error == XML_WRONG_ATTRIBUTE_TYPE) {
printf("Wrong attribute type.\n");
}
else if (error == XML_NO_ATTRIBUTE) {
printf("No attribute.\n");
}
else if (error == XML_CAN_NOT_CONVERT_TEXT) {
printf("Can not convert text.\n");
}
else if (error == XML_NO_TEXT_NODE) {
printf("No text.\n");
}
else {
printf("Unknown error.\n");
}
}
}
void Level::load() {
XMLError error=XML_NO_ERROR;
this->physics = Physics();
this->physics.init();
// currently hard coded should later read this stuff out of a file
this->camera = Camera(glm::vec2(-0.8f, 0.0f), 3.0f);
2014-11-21 15:22:36 +00:00
// load terrain
this->terrain.load();
Model terrainModel = Model(this->terrain.getModel());
// load a texture:
Material terrainMaterial = Material("seamlessTerrain.png", 0.1f, 0.8f, 0.2f, 3.0f);
//Create object
Object* terrainObject = new Object(terrainModel, terrainMaterial,
glm::vec3(-0.5f*(float)this->terrain.getHeightmapHeight(), 0.0f, -0.5f*(float)this->terrain.getHeightmapWidth()),
glm::vec3(0.0f, 0.0f, 0.0f));
objects.push_back(terrainObject);
//addTerrainPhysic
physics.addTerrain(terrain.getHeightmapWidth(), terrain.getHeightmapHeight(), terrain.getHeightmap());
//Loading Objects via xml
2014-12-04 14:07:31 +00:00
XMLDocument* doc = new XMLDocument();
const char* xmlFile = ("../Levels/ObjectSetups/Level" + levelNum + ".xml").c_str();
doc->LoadFile(xmlFile);
if (doc->ErrorID()!=0){
printf("Could not open ObjectSetupXml!\n");
exit(-1);
}
XMLDocument* compositions = new XMLDocument();
const char* compositionsFile = "../Levels/ObjectSetups/Compositions.xml";
compositions->LoadFile(compositionsFile);
if (compositions->ErrorID()!=0){
printf("Could not open Compositions!\n");
exit(-1);
}
XMLElement* thisComposition = doc->FirstChildElement("composition");
for(; thisComposition; thisComposition=thisComposition->NextSiblingElement("composition")){
int thisType = 0;
error = thisComposition->FirstChildElement("typeID")->QueryIntText(&thisType);
errorCheck(error);
XMLElement* composition = compositions->FirstChildElement("composition");
for(; composition; composition=composition->NextSiblingElement("composition")){
int compositionType = 0;
error = composition->FirstChildElement("typeID")->QueryIntText(&compositionType);
errorCheck(error);
if(thisType == compositionType){
XMLElement* object = composition->FirstChildElement("object");
for(; object; object=object->NextSiblingElement("object")){
const char* charModelPath = object->FirstChildElement("modelPath")->GetText();
if(charModelPath == NULL){
printf("XMLError: No modelPath found in object.\n");
}
std::string modelPath = charModelPath;
float objectScale, compScale;
error = object->FirstChildElement("scale")->QueryFloatText(&objectScale);
errorCheck(error);
error = thisComposition->FirstChildElement("scale")->QueryFloatText(&compScale);
errorCheck(error);
//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();
if(charDataModelPath == NULL){
printf("XMLError: No modelPath found in objectData.\n");
}
std::string dataModelPath = charDataModelPath;
if(dataModelPath == modelPath){
float ambientFactor, diffuseFactor, specularFactor, shininess;
error = objectData->FirstChildElement("ambientFactor")->QueryFloatText(&ambientFactor);
errorCheck(error);
error = objectData->FirstChildElement("diffuseFactor")->QueryFloatText(&diffuseFactor);
errorCheck(error);
error = objectData->FirstChildElement("specularFactor")->QueryFloatText(&specularFactor);
errorCheck(error);
error = objectData->FirstChildElement("shininess")->QueryFloatText(&shininess);
errorCheck(error);
const char* charTexturePath = objectData->FirstChildElement("texturePath")->GetText();
if(charTexturePath == NULL){
printf("XMLError: No texturePath found in objectData.\n");
}
std::string texturePath = charTexturePath;
//material = Material(texturePath, ambientFactor, diffuseFactor, specularFactor, shininess);
}
}
float compXPos, compYOffset, compZPos;
glm::vec3 objectOffset, compRot, compPos;
error = object->FirstChildElement("xOffset")->QueryFloatText(&objectOffset[0]);
errorCheck(error);
error = object->FirstChildElement("yOffset")->QueryFloatText(&objectOffset[1]);
errorCheck(error);
error = object->FirstChildElement("zOffset")->QueryFloatText(&objectOffset[2]);
errorCheck(error);
error = thisComposition->FirstChildElement("xPos")->QueryFloatText(&compXPos);
errorCheck(error);
error = thisComposition->FirstChildElement("yOffset")->QueryFloatText(&compYOffset);
errorCheck(error);
error = thisComposition->FirstChildElement("zPos")->QueryFloatText(&compZPos);
errorCheck(error);
error = thisComposition->FirstChildElement("xRot")->QueryFloatText(&compRot[0]);
errorCheck(error);
error = thisComposition->FirstChildElement("yRot")->QueryFloatText(&compRot[1]);
errorCheck(error);
error = thisComposition->FirstChildElement("zRot")->QueryFloatText(&compRot[2]);
errorCheck(error);
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;
//TODO calculate position from objectOffset, compRot and compPos
//Object* object = new Object(model, material, position, compRot);
//objects.push_back(object);
//TODO if object has physics: physicObjects.push_back(object);
//TODO add object to physics
//if(compositionType == 20){
// cameraCenter = object;
//}
}
XMLElement* light = composition->FirstChildElement("light");
for(; light; light=light->NextSiblingElement("light")){
//TODO add lights
}
}
2014-12-04 14:07:31 +00:00
}
}
2014-12-04 14:07:31 +00:00
2014-11-21 15:22:36 +00:00
//add player
Model marbleModel = Model("marbleSmooth.obj", 0.75f);
Material marbleMaterial = Material("marbleTexture_small.png", 0.1f, 0.5f, 0.5f, 3.0f);
Object* object = new Object(marbleModel, marbleMaterial, glm::vec3(2.0f, 10.0f, 2.0f),
glm::vec3(0.0f, 0.0f, 0.0f));
2014-11-21 15:22:36 +00:00
objects.push_back(object);
physicObjects.push_back(object);
this->physics.addPlayer(1.25f,*object,8.0f,physicObjects.size());
cameraCenter = object;
2014-11-21 15:22:36 +00:00
2014-11-21 23:39:58 +00:00
Model skydomeModel = Model("skydome.obj", skydomeSize);
Material skydomeMaterial = Material("skydome.png", 0.7f, 0.0f, 0.0f, 0.0f);
Object* skydomeObject = new Object(skydomeModel, skydomeMaterial, glm::vec3(0.0f, 0.0f, 0.0f),
glm::vec3(0.0f, 0.0f, 0.0f));
2014-11-21 23:39:58 +00:00
objects.push_back(skydomeObject);
skydome = skydomeObject;
2014-11-17 13:23:23 +00:00
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));
2014-11-17 13:23:23 +00:00
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));
2014-11-17 14:29:38 +00:00
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());
2014-11-17 14:29:38 +00:00
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));
2014-11-17 14:29:38 +00:00
objects.push_back(columnObject);
2014-11-21 15:22:36 +00:00
//make non physics objects
//set lighting parameters
2014-11-08 00:15:09 +00:00
ambientLight = glm::vec3(1.0f, 1.0f, 1.0f);
fogColor = glm::vec4(0.10f, 0.14f, 0.14f, 1.0f);
directionalLight = Light(glm::vec3(-1.0f, 1.5f, 1.0f), glm::vec3(1.0f, 1.0f, 0.9f), 0.2f);
Light light = Light(glm::vec3(-3.0f, 7.0f, 0.0f), glm::vec3(1.0f, 1.0f, 1.0f), 5.0f);
2014-10-31 11:56:09 +00:00
lights.push_back(light);
Light light2 = Light(glm::vec3(3.0f, 7.0f, 0.0f), glm::vec3(1.0f, 1.0f, 1.0f), 10.0f);
2014-10-31 11:56:09 +00:00
lights.push_back(light2);
}
void Level::render(ACGL::OpenGL::SharedShaderProgram shader, bool lightingPass) {
for(unsigned int i = 0; i<objects.size(); i++) {
// do not project shadow of skydome
if(lightingPass || objects.at(i) != skydome) {
objects.at(i)->render(shader, lightingPass);
}
}
}
2014-10-30 22:59:03 +00:00
void Level::update(float runTime, glm::vec2 mouseDelta, bool wPressed, bool aPressed, bool sPressed, bool dPressed) {
// Ignore first two mouse updates, because they are incorrect
2014-11-25 15:01:13 +00:00
// DON'T try to move this functionallity elsewhere
static int i = 0;
if (i <2) {
i++;
}
else {
2014-11-17 15:28:31 +00:00
mouseDelta.x = -mouseDelta.x;
camera.updateRotation(mouseDelta/100.0f);
}
2014-11-21 15:22:36 +00:00
float str = 20;
if(wPressed){
2014-11-21 15:22:36 +00:00
physics.rollForward(camera.getVector(),str);
}
if(aPressed) {
2014-11-21 15:22:36 +00:00
physics.rollLeft(camera.getVector(),str);
}
if(sPressed) {
2014-11-21 15:22:36 +00:00
physics.rollBack(camera.getVector(),str);
}
if(dPressed){
2014-11-21 15:22:36 +00:00
physics.rollRight(camera.getVector(),str);
}
physics.takeUpdateStep(runTime);
cameraCenter->setPosition(physics.getPos(0));
cameraCenter->setRotation(physics.getRotation(0));
2014-11-21 15:22:36 +00:00
for(unsigned i = 0; i < physicObjects.size();i++)
{
physicObjects[i]->setPosition(physics.getPos(i));
physicObjects[i]->setRotation(physics.getRotation(i));
}
skydome->setPosition(glm::vec3(cameraCenter->getPosition().x,
0.0f, cameraCenter->getPosition().z));
}
2014-10-30 22:59:03 +00:00
glm::vec3 Level::getAmbientLight() {
return ambientLight;
}
std::vector<Light> Level::getLights() {
return lights;
}
2014-11-15 13:54:44 +00:00
Camera* Level::getCamera() {
return &camera;
}
Object* Level::getCameraCenter() {
return cameraCenter;
}
2014-11-17 16:51:15 +00:00
Light* Level::getDirectionalLight() {
return &directionalLight;
}
glm::vec4 Level::getFogColor() {
2014-11-19 00:58:48 +00:00
return fogColor;
}
glm::vec3 Level::getCameraPosition() {
return cameraCenter->getPosition() + camera.getVector();
}
2014-11-21 23:39:58 +00:00
void Level::setSkydomeSize(float size) {
skydomeSize = size;
}