Gave sun rise more different colors.
This commit is contained in:
parent
eda952df70
commit
6e8d3c36df
@ -13056,12 +13056,26 @@
|
|||||||
<bColour>1.0</bColour>
|
<bColour>1.0</bColour>
|
||||||
</ambientLight>
|
</ambientLight>
|
||||||
|
|
||||||
<fogColour>
|
<fogColourDay>
|
||||||
<rColour>0.10</rColour>
|
<rColour>0.10</rColour>
|
||||||
<gColour>0.14</gColour>
|
<gColour>0.14</gColour>
|
||||||
<bColour>0.14</bColour>
|
<bColour>0.14</bColour>
|
||||||
<alpha>1.0</alpha>
|
<alpha>1.0</alpha>
|
||||||
</fogColour>
|
</fogColourDay>
|
||||||
|
|
||||||
|
<fogColourRise>
|
||||||
|
<rColour>0.60</rColour>
|
||||||
|
<gColour>0.14</gColour>
|
||||||
|
<bColour>0.14</bColour>
|
||||||
|
<alpha>1.0</alpha>
|
||||||
|
</fogColourRise>
|
||||||
|
|
||||||
|
<fogColourNight>
|
||||||
|
<rColour>0.05</rColour>
|
||||||
|
<gColour>0.07</gColour>
|
||||||
|
<bColour>0.34</bColour>
|
||||||
|
<alpha>1.0</alpha>
|
||||||
|
</fogColourNight>
|
||||||
|
|
||||||
<directionalLight>
|
<directionalLight>
|
||||||
<xOffset>-1.0</xOffset>
|
<xOffset>-1.0</xOffset>
|
||||||
|
@ -39,7 +39,9 @@ uniform vec3 lightColors[32];
|
|||||||
uniform float lightIntensities[32];
|
uniform float lightIntensities[32];
|
||||||
uniform bool isFlame[32];
|
uniform bool isFlame[32];
|
||||||
uniform float farPlane;
|
uniform float farPlane;
|
||||||
uniform vec4 fogColor;
|
uniform vec4 fogColorDay;
|
||||||
|
uniform vec4 fogColorRise;
|
||||||
|
uniform vec4 fogColorNight;
|
||||||
uniform vec3 cameraCenter;
|
uniform vec3 cameraCenter;
|
||||||
uniform bool movingTexture;
|
uniform bool movingTexture;
|
||||||
uniform vec2 movement;
|
uniform vec2 movement;
|
||||||
@ -68,6 +70,38 @@ float flickerFunction(int index) {
|
|||||||
return 0.7*pow(sin(20.0*time + lightSources[index].x*lightSources[index].z), 2) + 0.3;
|
return 0.7*pow(sin(20.0*time + lightSources[index].x*lightSources[index].z), 2) + 0.3;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
vec4 fogColor(float dot) {
|
||||||
|
float riseFactor = 0.0;
|
||||||
|
float dayFactor = 0.0;
|
||||||
|
|
||||||
|
if(dot<-0.52) {
|
||||||
|
riseFactor = 0.0;
|
||||||
|
}
|
||||||
|
else if (dot>0.52) {
|
||||||
|
riseFactor = 0.0;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
riseFactor = cos(3*dot);
|
||||||
|
}
|
||||||
|
|
||||||
|
if(dot<0.0) {
|
||||||
|
dayFactor = 0.0;
|
||||||
|
}
|
||||||
|
else if(dot>0.51) {
|
||||||
|
dayFactor = 1.0;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
dayFactor = sin(3*dot);
|
||||||
|
}
|
||||||
|
if (dot <0.0) {
|
||||||
|
return mix(fogColorNight, fogColorRise, riseFactor);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
return mix(fogColorRise, fogColorDay, dayFactor);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
float sampleDirectionalShadow(sampler2DShadow shadowMap, vec4 shadowCoord, float maxBias ) {
|
float sampleDirectionalShadow(sampler2DShadow shadowMap, vec4 shadowCoord, float maxBias ) {
|
||||||
float visibility = 1.0;
|
float visibility = 1.0;
|
||||||
const float stretching = 650.0;
|
const float stretching = 650.0;
|
||||||
@ -112,9 +146,11 @@ void main()
|
|||||||
|
|
||||||
|
|
||||||
// direction lighting
|
// direction lighting
|
||||||
|
float sunAngle = -1.0;
|
||||||
if(length(directionalLightVector)>0.0f) {
|
if(length(directionalLightVector)>0.0f) {
|
||||||
vec3 directionalVector = normalize(directionalLightVector);
|
vec3 directionalVector = normalize(directionalLightVector);
|
||||||
if (dot(vec3(0.0, 1.0, 0.0), directionalVector) > 0.0) {
|
sunAngle = dot(vec3(0.0, 1.0, 0.0), directionalVector);
|
||||||
|
if ( sunAngle > -0.5) {
|
||||||
float directionalVisibility = 1.0f;
|
float directionalVisibility = 1.0f;
|
||||||
if (distanceToBorder(shadowCoord1.xy) <= 0.5 && distanceToBorder(shadowCoord1.xy) > 0.2) {
|
if (distanceToBorder(shadowCoord1.xy) <= 0.5 && distanceToBorder(shadowCoord1.xy) > 0.2) {
|
||||||
if (distanceToBorder(shadowCoord0.xy) <= 0.5 && distanceToBorder(shadowCoord0.xy) > 0.2) {
|
if (distanceToBorder(shadowCoord0.xy) <= 0.5 && distanceToBorder(shadowCoord0.xy) > 0.2) {
|
||||||
@ -215,5 +251,5 @@ void main()
|
|||||||
textureColor = texture(uTexture, vTexCoord).rgba;
|
textureColor = texture(uTexture, vTexCoord).rgba;
|
||||||
}
|
}
|
||||||
oColor = vec4(finalColor, 1.0f)*textureColor;
|
oColor = vec4(finalColor, 1.0f)*textureColor;
|
||||||
oColor = mix(oColor, fogColor, fogFactor);
|
oColor = mix(oColor, fogColor(sunAngle), fogFactor);
|
||||||
}
|
}
|
||||||
|
@ -9,13 +9,61 @@ out vec4 oColor;
|
|||||||
uniform sampler2D uTexture;
|
uniform sampler2D uTexture;
|
||||||
uniform sampler2D nightTexture;
|
uniform sampler2D nightTexture;
|
||||||
uniform float farPlane;
|
uniform float farPlane;
|
||||||
uniform vec4 fogColor;
|
uniform vec4 fogColorDay;
|
||||||
|
uniform vec4 fogColorRise;
|
||||||
|
uniform vec4 fogColorNight;
|
||||||
uniform vec3 cameraCenter;
|
uniform vec3 cameraCenter;
|
||||||
uniform vec3 sunColor;
|
uniform vec3 sunColor;
|
||||||
uniform vec3 directionalVector;
|
uniform vec3 directionalVector;
|
||||||
|
|
||||||
const float sunSize = 20.0;
|
const float sunSize = 20.0;
|
||||||
|
|
||||||
|
vec4 fogColor(float dot) {
|
||||||
|
float riseFactor = 0.0;
|
||||||
|
float dayFactor = 0.0;
|
||||||
|
|
||||||
|
if(dot<-0.52) {
|
||||||
|
riseFactor = 0.0;
|
||||||
|
}
|
||||||
|
else if (dot>0.52) {
|
||||||
|
riseFactor = 0.0;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
riseFactor = cos(3*dot);
|
||||||
|
}
|
||||||
|
|
||||||
|
if(dot<0.0) {
|
||||||
|
dayFactor = 0.0;
|
||||||
|
}
|
||||||
|
else if(dot>0.77) {
|
||||||
|
dayFactor = 1.0;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
dayFactor = sin(2*dot);
|
||||||
|
}
|
||||||
|
if (dot <0.0) {
|
||||||
|
return mix(fogColorNight, fogColorRise, riseFactor);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
return mix(fogColorRise, fogColorDay, dayFactor);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
vec3 sunColorFunc(float dot) {
|
||||||
|
float riseFactor = 0.0;
|
||||||
|
if(dot<-0.79) {
|
||||||
|
riseFactor = 0.0;
|
||||||
|
}
|
||||||
|
else if (dot>0.876) {
|
||||||
|
riseFactor = 0.0;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
riseFactor = cos(2*dot);
|
||||||
|
}
|
||||||
|
return mix(sunColor, vec3(fogColorRise), riseFactor);
|
||||||
|
}
|
||||||
|
|
||||||
void main() {
|
void main() {
|
||||||
vec4 textureColor = vec4(0.0, 0.0, 0.0, 1.0);
|
vec4 textureColor = vec4(0.0, 0.0, 0.0, 1.0);
|
||||||
float sunAngle = -dot(normalize(directionalVector), vec3(0.0, 1.0, 0.0));
|
float sunAngle = -dot(normalize(directionalVector), vec3(0.0, 1.0, 0.0));
|
||||||
@ -32,10 +80,10 @@ void main() {
|
|||||||
fogFactor *= clamp((1.0-((fragPosition.y-40.0)/30.0)), 0.0, 1.0);
|
fogFactor *= clamp((1.0-((fragPosition.y-40.0)/30.0)), 0.0, 1.0);
|
||||||
if (distanceToSun < sunSize) {
|
if (distanceToSun < sunSize) {
|
||||||
float sunIntensity = clamp(0.3*exp(1/(distanceToSun/sunSize))-exp(1.0)*0.3, 0.0, 1.0);
|
float sunIntensity = clamp(0.3*exp(1/(distanceToSun/sunSize))-exp(1.0)*0.3, 0.0, 1.0);
|
||||||
vec4 color = mix(textureColor, vec4(sunColor, sunIntensity), sunIntensity);
|
vec4 color = mix(textureColor, vec4(sunColorFunc(sunAngle), sunIntensity), sunIntensity);
|
||||||
oColor = mix(color, fogColor, fogFactor);
|
oColor = mix(color, fogColor(-sunAngle), fogFactor);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
oColor = mix(textureColor, fogColor, fogFactor);
|
oColor = mix(textureColor, fogColor(-sunAngle), fogFactor);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
10
graphics.cc
10
graphics.cc
@ -265,7 +265,7 @@ void Graphics::render(double time)
|
|||||||
for (unsigned int i = 0; i<framebuffer_directional.size(); i++) {
|
for (unsigned int i = 0; i<framebuffer_directional.size(); i++) {
|
||||||
framebuffer_directional.at(i)->bind();
|
framebuffer_directional.at(i)->bind();
|
||||||
glClear(GL_DEPTH_BUFFER_BIT);
|
glClear(GL_DEPTH_BUFFER_BIT);
|
||||||
if (sunAngle > 0.0f) {
|
if (sunAngle > -0.5f) {
|
||||||
float projection_size = 0.0f;
|
float projection_size = 0.0f;
|
||||||
switch(i) {
|
switch(i) {
|
||||||
case 0:
|
case 0:
|
||||||
@ -302,7 +302,9 @@ void Graphics::render(double time)
|
|||||||
// set fog Parameters
|
// set fog Parameters
|
||||||
skydomeShader->setUniform("farPlane", farPlane);
|
skydomeShader->setUniform("farPlane", farPlane);
|
||||||
skydomeShader->setUniform("skydomeSize", level->getSkydomeSize());
|
skydomeShader->setUniform("skydomeSize", level->getSkydomeSize());
|
||||||
skydomeShader->setUniform("fogColor", level->getFogColour());
|
skydomeShader->setUniform("fogColorDay", level->getFogColourDay());
|
||||||
|
skydomeShader->setUniform("fogColorRise", level->getFogColourRise());
|
||||||
|
skydomeShader->setUniform("fogColorNight", level->getFogColourNight());
|
||||||
skydomeShader->setUniform("cameraCenter", level->getCameraCenter()->getPosition());
|
skydomeShader->setUniform("cameraCenter", level->getCameraCenter()->getPosition());
|
||||||
skydomeShader->setUniform("directionalVector", level->getDirectionalLight()->getPosition());
|
skydomeShader->setUniform("directionalVector", level->getDirectionalLight()->getPosition());
|
||||||
skydomeShader->setUniform("sunColor", level->getDirectionalLight()->getColour());
|
skydomeShader->setUniform("sunColor", level->getDirectionalLight()->getColour());
|
||||||
@ -332,7 +334,9 @@ void Graphics::render(double time)
|
|||||||
lightingShader->setUniform("farPlane", farPlane);
|
lightingShader->setUniform("farPlane", farPlane);
|
||||||
|
|
||||||
// set fog Parameters
|
// set fog Parameters
|
||||||
lightingShader->setUniform("fogColor", level->getFogColour());
|
lightingShader->setUniform("fogColorDay", level->getFogColourDay());
|
||||||
|
lightingShader->setUniform("fogColorRise", level->getFogColourRise());
|
||||||
|
lightingShader->setUniform("fogColorNight", level->getFogColourNight());
|
||||||
lightingShader->setUniform("cameraCenter", level->getCameraCenter()->getPosition());
|
lightingShader->setUniform("cameraCenter", level->getCameraCenter()->getPosition());
|
||||||
|
|
||||||
// set Material Parameters
|
// set Material Parameters
|
||||||
|
24
level.cc
24
level.cc
@ -151,8 +151,16 @@ Light* Level::getDirectionalLight() {
|
|||||||
return &directionalLight;
|
return &directionalLight;
|
||||||
}
|
}
|
||||||
|
|
||||||
glm::vec4 Level::getFogColour() {
|
glm::vec4 Level::getFogColourDay() {
|
||||||
return fogColour;
|
return fogColourDay;
|
||||||
|
}
|
||||||
|
|
||||||
|
glm::vec4 Level::getFogColourRise() {
|
||||||
|
return fogColourRise;
|
||||||
|
}
|
||||||
|
|
||||||
|
glm::vec4 Level::getFogColourNight() {
|
||||||
|
return fogColourNight;
|
||||||
}
|
}
|
||||||
|
|
||||||
glm::vec3 Level::getCameraPosition() {
|
glm::vec3 Level::getCameraPosition() {
|
||||||
@ -227,8 +235,16 @@ void Level::setAmbientLight(glm::vec3 colour) {
|
|||||||
this->ambientLight = colour;
|
this->ambientLight = colour;
|
||||||
}
|
}
|
||||||
|
|
||||||
void Level::setFogColour(glm::vec4 colour) {
|
void Level::setFogColourDay(glm::vec4 colour) {
|
||||||
this->fogColour = colour;
|
this->fogColourDay = colour;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Level::setFogColourRise(glm::vec4 colour) {
|
||||||
|
this->fogColourRise = colour;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Level::setFogColourNight(glm::vec4 colour) {
|
||||||
|
this->fogColourNight = colour;
|
||||||
}
|
}
|
||||||
|
|
||||||
void Level::setDirectionalLight(Light light) {
|
void Level::setDirectionalLight(Light light) {
|
||||||
|
12
level.hh
12
level.hh
@ -34,7 +34,9 @@ class Level {
|
|||||||
Object* getCameraCenter();
|
Object* getCameraCenter();
|
||||||
Camera* getCamera();
|
Camera* getCamera();
|
||||||
glm::vec3 getCameraPosition();
|
glm::vec3 getCameraPosition();
|
||||||
glm::vec4 getFogColour();
|
glm::vec4 getFogColourDay();
|
||||||
|
glm::vec4 getFogColourRise();
|
||||||
|
glm::vec4 getFogColourNight();
|
||||||
void setSkydomeSize(float size);
|
void setSkydomeSize(float size);
|
||||||
float getSkydomeSize();
|
float getSkydomeSize();
|
||||||
Skydome* getSkydome();
|
Skydome* getSkydome();
|
||||||
@ -47,7 +49,9 @@ class Level {
|
|||||||
void addObject(Object* object);
|
void addObject(Object* object);
|
||||||
void addPhysicsObject(Object* object);
|
void addPhysicsObject(Object* object);
|
||||||
void setAmbientLight(glm::vec3 colour);
|
void setAmbientLight(glm::vec3 colour);
|
||||||
void setFogColour(glm::vec4 colour);
|
void setFogColourDay(glm::vec4 colour);
|
||||||
|
void setFogColourRise(glm::vec4 colour);
|
||||||
|
void setFogColourNight(glm::vec4 colour);
|
||||||
void setDirectionalLight(Light light);
|
void setDirectionalLight(Light light);
|
||||||
void setSunDirection(float x, float y, float z);
|
void setSunDirection(float x, float y, float z);
|
||||||
Physics* getPhysics();
|
Physics* getPhysics();
|
||||||
@ -73,7 +77,9 @@ class Level {
|
|||||||
std::vector<Light> lights;
|
std::vector<Light> lights;
|
||||||
std::vector<Trigger> triggers;
|
std::vector<Trigger> triggers;
|
||||||
glm::vec3 ambientLight;
|
glm::vec3 ambientLight;
|
||||||
glm::vec4 fogColour;
|
glm::vec4 fogColourDay;
|
||||||
|
glm::vec4 fogColourRise;
|
||||||
|
glm::vec4 fogColourNight;
|
||||||
Light directionalLight;
|
Light directionalLight;
|
||||||
Object* cameraCenter;
|
Object* cameraCenter;
|
||||||
int playerIndex;
|
int playerIndex;
|
||||||
|
18
loader.cc
18
loader.cc
@ -158,12 +158,26 @@ void Loader::load(std::string filePath, Level* level, std::string compositionsPa
|
|||||||
bColour = queryFloat(ambientElement, "bColour");
|
bColour = queryFloat(ambientElement, "bColour");
|
||||||
level->setAmbientLight(glm::vec3(rColour,gColour,bColour));
|
level->setAmbientLight(glm::vec3(rColour,gColour,bColour));
|
||||||
|
|
||||||
XMLElement* fogElement = doc->FirstChildElement("fogColour");
|
XMLElement* fogElement = doc->FirstChildElement("fogColourDay");
|
||||||
rColour = queryFloat(fogElement, "rColour");
|
rColour = queryFloat(fogElement, "rColour");
|
||||||
gColour = queryFloat(fogElement, "gColour");
|
gColour = queryFloat(fogElement, "gColour");
|
||||||
bColour = queryFloat(fogElement, "bColour");
|
bColour = queryFloat(fogElement, "bColour");
|
||||||
alpha = queryFloat(fogElement, "alpha");
|
alpha = queryFloat(fogElement, "alpha");
|
||||||
level->setFogColour(glm::vec4(rColour,gColour,bColour, alpha));
|
level->setFogColourDay(glm::vec4(rColour,gColour,bColour, alpha));
|
||||||
|
|
||||||
|
fogElement = doc->FirstChildElement("fogColourRise");
|
||||||
|
rColour = queryFloat(fogElement, "rColour");
|
||||||
|
gColour = queryFloat(fogElement, "gColour");
|
||||||
|
bColour = queryFloat(fogElement, "bColour");
|
||||||
|
alpha = queryFloat(fogElement, "alpha");
|
||||||
|
level->setFogColourRise(glm::vec4(rColour,gColour,bColour, alpha));
|
||||||
|
|
||||||
|
fogElement = doc->FirstChildElement("fogColourNight");
|
||||||
|
rColour = queryFloat(fogElement, "rColour");
|
||||||
|
gColour = queryFloat(fogElement, "gColour");
|
||||||
|
bColour = queryFloat(fogElement, "bColour");
|
||||||
|
alpha = queryFloat(fogElement, "alpha");
|
||||||
|
level->setFogColourNight(glm::vec4(rColour,gColour,bColour, alpha));
|
||||||
|
|
||||||
XMLElement* directionalElement = doc->FirstChildElement("directionalLight");
|
XMLElement* directionalElement = doc->FirstChildElement("directionalLight");
|
||||||
xOffset = queryFloat(directionalElement, "xOffset");
|
xOffset = queryFloat(directionalElement, "xOffset");
|
||||||
|
Loading…
Reference in New Issue
Block a user