This commit is contained in:
sfroitzheim 2014-11-17 18:31:48 +01:00
commit c403814cd6
10 changed files with 118 additions and 40 deletions

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.6 MiB

View File

@ -14,6 +14,9 @@ uniform float specularFactor;
uniform vec3 camera; uniform vec3 camera;
uniform float shininess; uniform float shininess;
uniform int lightCount; uniform int lightCount;
uniform vec3 directionalLightVector;
uniform vec3 directionalColor;
uniform float directionalIntensity;
uniform vec3 lightSources[128]; uniform vec3 lightSources[128];
uniform vec3 lightColors[128]; uniform vec3 lightColors[128];
uniform float lightIntensities[128]; uniform float lightIntensities[128];
@ -23,6 +26,15 @@ void main()
vec3 ambientColor = ambientFactor * ambientColor; vec3 ambientColor = ambientFactor * ambientColor;
vec3 diffuseColor = vec3(0.0, 0.0, 0.0); vec3 diffuseColor = vec3(0.0, 0.0, 0.0);
vec3 specularColor = vec3(0.0, 0.0, 0.0); vec3 specularColor = vec3(0.0, 0.0, 0.0);
if(length(directionalLightVector)>0.0f) {
vec3 directionalVector = normalize(directionalLightVector);
diffuseColor += dot(normalize(vNormal), directionalVector)
*diffuseFactor*directionalIntensity*directionalColor;
vec3 cameraVector = normalize(camera - vec3(fragPosition));
specularColor += clamp(pow((dot((cameraVector+directionalVector),normalize(vNormal))/(length(cameraVector+directionalVector)*length(normalize(vNormal)))),shininess), 0.0, 1.0)
*specularFactor*directionalIntensity*directionalColor;
}
for(int i = 0; i<lightCount; i++) { for(int i = 0; i<lightCount; i++) {
float distance = distance(lightSources[i], vec3(fragPosition)); float distance = distance(lightSources[i], vec3(fragPosition));
// only take lights into account with meaningful contribution // only take lights into account with meaningful contribution
@ -38,6 +50,6 @@ void main()
} }
vec3 finalColor = specularColor + diffuseColor + ambientColor; vec3 finalColor = specularColor + diffuseColor + ambientColor;
vec3 texture = texture(uTexture, vTexCoord).rgb; vec4 texture = texture(uTexture, vTexCoord).rgba;
oColor = vec4(finalColor*texture, 1.0 ); oColor = vec4(finalColor, 1.0f)*texture;
} }

View File

@ -129,6 +129,15 @@ void Graphics::render(Level* level, ACGL::OpenGL::SharedShaderProgram shader)
glUniform1fv(shader->getUniformLocation("lightIntensities"), glUniform1fv(shader->getUniformLocation("lightIntensities"),
sizeof(lightIntensities), (GLfloat*) lightIntensities); sizeof(lightIntensities), (GLfloat*) lightIntensities);
} }
// set directional Light
if(level->getDirectionalLight()) {
shader->setUniform("directionalLightVector",
level->getDirectionalLight()->getPosition());
shader->setUniform("directionalColor",
level->getDirectionalLight()->getColour());
shader->setUniform("directionalIntensity",
level->getDirectionalLight()->getIntensity());
}
// set Material Parameters // set Material Parameters
shader->setUniform("ambientColor", level->getAmbientLight()); shader->setUniform("ambientColor", level->getAmbientLight());

View File

@ -25,52 +25,50 @@ void Level::load(ACGL::OpenGL::SharedShaderProgram shader) {
// load a texture: // load a texture:
Material material = Material("marbleTexture.png", 0.1f, 0.5f, 0.5f, 3.0f); Material material = Material("marbleTexture.png", 0.1f, 0.5f, 0.5f, 3.0f);
//Create object //Create object
Object object = Object(model, material, glm::vec3(0.0f, 5.0f, 0.0f), Object object = Object(model, material, glm::vec3(0.0f, 10.0f, 0.0f),
glm::vec3(0.0f, 0.0f, 0.0f), glm::vec3(0.0f, 0.0f, 0.0f), glm::vec3(0.0f, 0.0f, 0.0f), glm::vec3(0.0f, 0.0f, 0.0f),
glm::vec3(0.0f, 0.0f, 0.0f), shader); glm::vec3(0.0f, 0.0f, 0.0f), shader);
//add player to phy //add player to phy
this->physics.addPlayer(0.75f,0.0f,5.0f,0.0f,1.0f,0); this->physics.addPlayer(1.25f,0.0f,10.0f,0.0f,1.0f,0);
objects.push_back(object); objects.push_back(object);
physics.addStaticGroundPlane(); //physics.addStaticGroundPlane();
Model torchModel = Model("torch.obj", 0.75f); Model torchModel = Model("torch.obj", 0.75f);
Material torchMaterial = Material("torchTexture.png", 0.1f, 0.3f, 0.7f, 10.0f); Material torchMaterial = Material("torchTexture.png", 0.1f, 0.3f, 0.7f, 10.0f);
//Create object //Create object
Object torchObject = Object(torchModel, torchMaterial, glm::vec3(-3.0f, 5.0f, 0.0f), Object torchObject = Object(torchModel, torchMaterial, glm::vec3(-3.0f, 6.0f, 0.0f),
glm::vec3(0.0f, 1.0472f, 0.0f), glm::vec3(0.0f, 0.0f, 0.0f), glm::vec3(0.0f, 1.0472f, 0.0f), glm::vec3(0.0f, 0.0f, 0.0f),
glm::vec3(0.0f, 0.0f, 0.0f), shader); glm::vec3(0.0f, 0.0f, 0.0f), shader);
objects.push_back(torchObject); objects.push_back(torchObject);
Model blockModel = Model("Block.obj", 1.0f); Model blockModel = Model("Block.obj", 1.0f);
Material blockMaterial = Material("blockTexture.png", 0.1f, 0.6, 0.4f, 2.0f); Material blockMaterial = Material("blockTexture.png", 0.1f, 0.6, 0.4f, 2.0f);
Object blockObject = Object(blockModel, blockMaterial, glm::vec3(2.0f, 5.0f, 2.0f), Object blockObject = Object(blockModel, blockMaterial, glm::vec3(2.0f, 7.0f, 2.0f),
glm::vec3(0.0f, 0.0f, 0.0f), glm::vec3(0.0f, 0.0f, 0.0f), glm::vec3(0.0f, 0.0f, 0.0f), glm::vec3(0.0f, 0.0f, 0.0f), glm::vec3(0.0f, 0.0f, 0.0f), glm::vec3(0.0f, 0.0f, 0.0f),
shader); shader);
objects.push_back(blockObject); objects.push_back(blockObject);
Model columnModel = Model("Column.obj", 1.0f); Model columnModel = Model("Column.obj", 1.0f);
Material columnMaterial = Material("columnTexture.png", 0.1f, 0.6, 0.4f, 2.0f); Material columnMaterial = Material("columnTexture.png", 0.1f, 0.6, 0.4f, 2.0f);
Object columnObject = Object(columnModel, columnMaterial, glm::vec3(-2.0f, 5.0f, -2.0f), Object columnObject = Object(columnModel, columnMaterial, glm::vec3(-2.0f, 7.0f, -2.0f),
glm::vec3(0.0f, 0.0f, 0.0f), glm::vec3(0.0f, 0.0f, 0.0f), glm::vec3(0.0f, 0.0f, 0.0f), glm::vec3(0.0f, 0.0f, 0.0f), glm::vec3(0.0f, 0.0f, 0.0f), glm::vec3(0.0f, 0.0f, 0.0f),
shader); shader);
objects.push_back(columnObject); objects.push_back(columnObject);
//set lighting parameters //set lighting parameters
ambientLight = glm::vec3(1.0f, 1.0f, 1.0f); ambientLight = glm::vec3(1.0f, 1.0f, 1.0f);
Light light = Light(glm::vec3(-3.0f, 6.0f, 0.0f), glm::vec3(0.0f, 0.0f, 0.0f), glm::vec3(1.0f, 1.0f, 1.0f), 10.0f); directionalLight = Light(glm::vec3(-0.5f, 0.0f, -0.5f), glm::vec3(1.0f, 1.0f, 0.0f), 0.4f);
Light light = Light(glm::vec3(-3.0f, 7.0f, 0.0f), glm::vec3(1.0f, 1.0f, 1.0f), 10.0f);
lights.push_back(light); lights.push_back(light);
Light light2 = Light(glm::vec3(3.0f, 6.0f, 0.0f), glm::vec3(0.0f, 0.0f, 0.0f), glm::vec3(1.0f, 1.0f, 1.0f), 10.0f); Light light2 = Light(glm::vec3(3.0f, 6.0f, 0.0f), glm::vec3(1.0f, 1.0f, 1.0f), 10.0f);
lights.push_back(light2); lights.push_back(light2);
Light light3 = Light(glm::vec3(0.0f, 5.0f, 0.0f), glm::vec3(0.0f, 0.0f, 0.0f), glm::vec3(0.5f, 0.5f, 1.0f), 4.0f);
lights.push_back(light3);
// load terrain // load terrain
this->terrain.load(); this->terrain.load();
Model terrainModel = Model(this->terrain.getModel()); Model terrainModel = Model(this->terrain.getModel());
// load a texture: // load a texture:
Material terrainMaterial = Material("terrainTexture.png", 0.1f, 0.8f, 0.2f, 3.0f); Material terrainMaterial = Material("seamlessTerrain.png", 0.1f, 0.8f, 0.2f, 3.0f);
//Create object //Create object
Object terrainObject = Object(terrainModel, terrainMaterial, Object terrainObject = Object(terrainModel, terrainMaterial,
glm::vec3(-0.5f*(float)this->terrain.getHeightmapHeight(), 0.0f, -0.5f*(float)this->terrain.getHeightmapWidth()), glm::vec3(-0.5f*(float)this->terrain.getHeightmapHeight(), 0.0f, -0.5f*(float)this->terrain.getHeightmapWidth()),
@ -78,6 +76,9 @@ void Level::load(ACGL::OpenGL::SharedShaderProgram shader) {
glm::vec3(0.0f, 0.0f, 0.0f), shader); glm::vec3(0.0f, 0.0f, 0.0f), shader);
objects.push_back(terrainObject); objects.push_back(terrainObject);
cameraCenter = &objects[0]; cameraCenter = &objects[0];
//addTerrainPhysic
physics.addTerrain(terrain.getHeightmapWidth(), terrain.getHeightmapHeight(), terrain.getHeightmap());
} }
void Level::render() { void Level::render() {
@ -86,7 +87,7 @@ void Level::render() {
} }
} }
void Level::update(float runTime, glm::vec2 mouseDelta, bool wPressed, bool aPressed, bool dPressed, bool sPressed) { void Level::update(float runTime, glm::vec2 mouseDelta, bool wPressed, bool aPressed, bool sPressed, bool dPressed) {
// rotate bunny // rotate bunny
//cameraCenter->setRotation(glm::vec3(0.0f, 1.0472f * runTime, 0.0f)); //cameraCenter->setRotation(glm::vec3(0.0f, 1.0472f * runTime, 0.0f));
// Ignore first two mouse updates, because they are incorrect // Ignore first two mouse updates, because they are incorrect
@ -95,18 +96,27 @@ void Level::update(float runTime, glm::vec2 mouseDelta, bool wPressed, bool aPre
i++; i++;
} }
else { else {
mouseDelta.x = -mouseDelta.x;
camera.updateRotation(mouseDelta/100.0f); camera.updateRotation(mouseDelta/100.0f);
} }
if(wPressed) if(wPressed){
{ physics.rollForward(camera.getVector(),1.0f);
//physics.rollForward(camera.getRotation); }
if(aPressed) {
physics.rollLeft(camera.getVector(),1.0f);
}
if(sPressed) {
physics.rollBack(camera.getVector(),1.0f);
}
if(dPressed){
physics.rollRight(camera.getVector(),1.0f);
} }
physics.takeUpdateStep(runTime); physics.takeUpdateStep(runTime);
objects[0].setPosition(physics.getPos(0)); objects[0].setPosition(physics.getPos(0));
lights[2].setPosition(physics.getPos(0)); objects[0].setRotation(physics.getRotation(0));
} }
glm::vec3 Level::getAmbientLight() { glm::vec3 Level::getAmbientLight() {
@ -124,3 +134,7 @@ Camera* Level::getCamera() {
Object* Level::getCameraCenter() { Object* Level::getCameraCenter() {
return cameraCenter; return cameraCenter;
} }
Light* Level::getDirectionalLight() {
return &directionalLight;
}

View File

@ -19,6 +19,7 @@ class Level {
void update(float runTime, glm::vec2 mouseDelta,bool wPressed, bool aPressed,bool sPressed, bool dPressed); void update(float runTime, glm::vec2 mouseDelta,bool wPressed, bool aPressed,bool sPressed, bool dPressed);
void render(); void render();
glm::vec3 getAmbientLight(); glm::vec3 getAmbientLight();
Light* getDirectionalLight();
std::vector<Light> getLights(); std::vector<Light> getLights();
Object* getCameraCenter(); Object* getCameraCenter();
Camera* getCamera(); Camera* getCamera();
@ -27,6 +28,7 @@ class Level {
std::vector<Object> objects; std::vector<Object> objects;
std::vector<Light> lights; std::vector<Light> lights;
glm::vec3 ambientLight; glm::vec3 ambientLight;
Light directionalLight;
Object* cameraCenter; Object* cameraCenter;
Physics physics; Physics physics;
Camera camera; Camera camera;

View File

@ -1,11 +1,14 @@
#include "light.hh" #include "light.hh"
Light::Light(glm::vec3 position, glm::vec3 rotation, glm::vec3 colour, float intensity) Light::Light(glm::vec3 position, glm::vec3 colour, float intensity)
: Entity(position, rotation) { : Entity(position, glm::vec3(0.0f, 0.0f, 0.0f)) {
this->colour = colour; this->colour = colour;
this->intensity = intensity; this->intensity = intensity;
} }
Light::Light() {
}
Light::~Light() { Light::~Light() {
} }

View File

@ -6,7 +6,8 @@
class Light : public Entity { class Light : public Entity {
public: public:
Light(glm::vec3 position, glm::vec3 rotation, glm::vec3 colour, float intensity); Light(glm::vec3 position, glm::vec3 colour, float intensity);
Light();
glm::vec3 getColour(); glm::vec3 getColour();
float getIntensity(); float getIntensity();
~Light(); ~Light();

12
main.cc
View File

@ -112,6 +112,8 @@ int main( int argc, char *argv[] )
// //
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 );
glEnable(GL_BLEND);
glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);
app.init(); app.init();
int frameCount = 0; int frameCount = 0;
@ -122,15 +124,16 @@ int main( int argc, char *argv[] )
double lastUpdate=0.0f; double lastUpdate=0.0f;
int stateW = glfwGetKey(app.getGraphics()->getWindow(), GLFW_KEY_W);
int stateA = glfwGetKey(app.getGraphics()->getWindow(), GLFW_KEY_A);
int stateS = glfwGetKey(app.getGraphics()->getWindow(), GLFW_KEY_S);
int stateD = glfwGetKey(app.getGraphics()->getWindow(), GLFW_KEY_D);
do { do {
double now = glfwGetTime()- startTimeInSeconds; double now = glfwGetTime()- startTimeInSeconds;
int stateW = glfwGetKey(app.getGraphics()->getWindow(), GLFW_KEY_W);
int stateA = glfwGetKey(app.getGraphics()->getWindow(), GLFW_KEY_A);
int stateS = glfwGetKey(app.getGraphics()->getWindow(), GLFW_KEY_S);
int stateD = glfwGetKey(app.getGraphics()->getWindow(), GLFW_KEY_D);
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
@ -158,6 +161,7 @@ int main( int argc, char *argv[] )
glfwSwapBuffers(app.getGraphics()->getWindow()); glfwSwapBuffers(app.getGraphics()->getWindow());
glfwPollEvents(); glfwPollEvents();
frameCount++; frameCount++;
} // Check if the window was closed } // Check if the window was closed
while( !glfwWindowShouldClose(app.getGraphics()->getWindow()) ); while( !glfwWindowShouldClose(app.getGraphics()->getWindow()) );

View File

@ -32,21 +32,32 @@ void Physics::init()
void Physics::takeUpdateStep(float timeDiff) void Physics::takeUpdateStep(float timeDiff)
{ {
world->stepSimulation(timeDiff); world->stepSimulation(timeDiff);
} }
void Physics::addTerrain(int width, int length, float** heightData) void Physics::addTerrain(int width, int length, float** heightData)
{ {
float* heightfield = new float[width * length]; float* heightfield = new float[width * length];
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[j*length+i] = heightData[i][j]; heightfield[i*length+j] = heightData[j][i];
if (heightData[j][i] > highest)
highest = heightData[j][i];
}
}
/*
heightfield[j*length+i] = heightData[i][j];
if (heightData[i][j] > highest) if (heightData[i][j] > highest)
highest = heightData[i][j]; highest = heightData[i][j];
} */
btHeightfieldTerrainShape* terrianShape = new btHeightfieldTerrainShape(width,length,heightData,highest,1,true,false); btHeightfieldTerrainShape* terrianShape = new btHeightfieldTerrainShape(length,width,heightfield,highest,1,true,false);
btRigidBody* tBody = new btRigidBody(0,new btDefaultMotionState(),terrianShape); btRigidBody* tBody = new btRigidBody(0,new btDefaultMotionState(),terrianShape);
@ -55,7 +66,7 @@ void Physics::addTerrain(int width, int length, float** heightData)
//tBody->getWoorldTransform().setRotation(btQuaternion(0,0,0,1)); //tBody->getWoorldTransform().setRotation(btQuaternion(0,0,0,1));
terrainBody = tBody; terrainBody = tBody;
world->addRigidBody(terrainBody); world->addRigidBody(terrainBody);
/* /*
@ -101,11 +112,14 @@ void Physics::addPlayer(float rad, float x, float y, float z, float mass, unsign
btRigidBody::btRigidBodyConstructionInfo info(mass,motion,sphere,inertia); btRigidBody::btRigidBodyConstructionInfo info(mass,motion,sphere,inertia);
playerBall = new btRigidBody(info); playerBall = new btRigidBody(info);
playerBall->setDamping(0.1f,0.3f);
world->addRigidBody(playerBall); world->addRigidBody(playerBall);
bodies.push_back(playerBall); bodies.push_back(playerBall);
playerBall->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" );
@ -127,13 +141,15 @@ void Physics::addSphere(float rad, float x, float y, float z, float mass, unsign
btDefaultMotionState* motion = new btDefaultMotionState(btTransform(btQuaternion(0,0,0,1),btVector3(x,y,z))); btDefaultMotionState* motion = new btDefaultMotionState(btTransform(btQuaternion(0,0,0,1),btVector3(x,y,z)));
btRigidBody::btRigidBodyConstructionInfo info(mass,motion,sphere,inertia); btRigidBody::btRigidBodyConstructionInfo info(mass,motion,sphere,inertia);
//info.
btRigidBody* body = new btRigidBody(info); btRigidBody* body = new btRigidBody(info);
world->addRigidBody(body); world->addRigidBody(body);
bodies.push_back(body); bodies.push_back(body);
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" );
@ -158,16 +174,30 @@ glm::mat4 Physics::getRotation(int i)
return matrix; return matrix;
} }
void Physics::rollForward(glm::vec3 camPos) void Physics::rollForward(glm::vec3 camPos,float strength)
{ {
btVector3 pos(camPos.x,camPos.y,camPos.z); btVector3 pos(camPos.x,0,camPos.z);
pos -= playerBody->getCenterOfMassPosition(); pos = btCross(pos,btVector3(0,1,0));
pos.cross(btVector3(0,1,0));
playerBall->applyTorque(pos); playerBall->applyTorque(pos);
}
/* glm::vec3 saveVector= glm::vec3(1,0,0) * rotCamera; void Physics::rollBack(glm::vec3 camPos,float strength)
saveVector = glm::cross(glm::vec3(0,1,0),saveVector); {
playerBall->applyTorque(btVector3(saveVector[0],saveVector[1],saveVector[2]));*/ btVector3 pos(camPos.x,0,camPos.z);
pos = btCross(btVector3(0,1,0),pos);
playerBall->applyTorque(pos);
}
void Physics::rollLeft(glm::vec3 camPos,float strength)
{
btVector3 pos(camPos.x,0,camPos.z);
playerBall->applyTorque(pos);
}
void Physics::rollRight(glm::vec3 camPos,float strength)
{
btVector3 pos(camPos.x,0,camPos.z);
playerBall->applyTorque(-pos);
} }
/* /*

View File

@ -37,6 +37,9 @@ class Physics {
void init(); void init();
void takeUpdateStep(float timeDiff); void takeUpdateStep(float timeDiff);
void rollForward(glm::vec3 camPos, float strength); void rollForward(glm::vec3 camPos, float strength);
void rollLeft(glm::vec3 camPos, float strength);
void rollRight(glm::vec3 camPos, float strength);
void rollBack(glm::vec3 camPos, float strength);
glm::vec3 getPos(int i); glm::vec3 getPos(int i);
glm::mat4 getRotation(int i); glm::mat4 getRotation(int i);
void rollForward(glm::vec3 camPos); void rollForward(glm::vec3 camPos);