mirror of
https://github.com/ZDoom/ZDRay.git
synced 2025-01-25 00:51:20 +00:00
Use ZDRayInfo's angle and pitch to determine the sun direction
This commit is contained in:
parent
b42d771e17
commit
7f822dd250
1 changed files with 9 additions and 12 deletions
|
@ -104,6 +104,15 @@ void FLevel::SetupLights()
|
||||||
vec3 sundir(0.0f, 0.0f, 0.0f);
|
vec3 sundir(0.0f, 0.0f, 0.0f);
|
||||||
vec3 suncolor(1.0f, 1.0f, 1.0f);
|
vec3 suncolor(1.0f, 1.0f, 1.0f);
|
||||||
|
|
||||||
|
// to do: is the math here correct?
|
||||||
|
float sdx = (float)std::cos(radians(thing->angle)) * (float)std::cos(radians(thing->pitch));
|
||||||
|
float sdy = (float)std::sin(radians(thing->angle)) * (float)std::cos(radians(thing->pitch));
|
||||||
|
float sdz = (float)-std::sin(radians(thing->pitch));
|
||||||
|
sundir.x = -sdx;
|
||||||
|
sundir.y = -sdy;
|
||||||
|
sundir.z = -sdz;
|
||||||
|
//printf("sun vector: %f, %f, %f\n", sundir.x, sundir.y, sundir.z);
|
||||||
|
|
||||||
for (unsigned int propIndex = 0; propIndex < thing->props.Size(); propIndex++)
|
for (unsigned int propIndex = 0; propIndex < thing->props.Size(); propIndex++)
|
||||||
{
|
{
|
||||||
const UDMFKey& key = thing->props[propIndex];
|
const UDMFKey& key = thing->props[propIndex];
|
||||||
|
@ -111,18 +120,6 @@ void FLevel::SetupLights()
|
||||||
{
|
{
|
||||||
lightcolor = atoi(key.value);
|
lightcolor = atoi(key.value);
|
||||||
}
|
}
|
||||||
else if (!stricmp(key.key, "sundirx"))
|
|
||||||
{
|
|
||||||
sundir.x = atof(key.value);
|
|
||||||
}
|
|
||||||
else if (!stricmp(key.key, "sundiry"))
|
|
||||||
{
|
|
||||||
sundir.y = atof(key.value);
|
|
||||||
}
|
|
||||||
else if (!stricmp(key.key, "sundirz"))
|
|
||||||
{
|
|
||||||
sundir.z = atof(key.value);
|
|
||||||
}
|
|
||||||
else if (!stricmp(key.key, "sampledistance"))
|
else if (!stricmp(key.key, "sampledistance"))
|
||||||
{
|
{
|
||||||
Samples = atoi(key.value);
|
Samples = atoi(key.value);
|
||||||
|
|
Loading…
Reference in a new issue