mirror of
https://github.com/AquariaOSE/Aquaria.git
synced 2025-01-26 02:07:26 +00:00
Improvements to water surface rendering; get rid of magic number fudgery.
Adjustments to make it a bit wider and make the reflection independent of the camera position. Still broken with vertical resolutions. Not worse than what it was though.
This commit is contained in:
parent
d47aeea2ce
commit
b8dee723a2
1 changed files with 21 additions and 19 deletions
|
@ -17,7 +17,6 @@ WaterSurfaceRender::WaterSurfaceRender() : Quad()
|
||||||
}
|
}
|
||||||
|
|
||||||
this->renderBorder = false;
|
this->renderBorder = false;
|
||||||
this->renderCenter = false;
|
|
||||||
this->borderAlpha = 1;
|
this->borderAlpha = 1;
|
||||||
|
|
||||||
qLine = new Quad("water/water-line", Vector(0,0));
|
qLine = new Quad("water/water-line", Vector(0,0));
|
||||||
|
@ -52,6 +51,8 @@ void WaterSurfaceRender::onEndOfLife()
|
||||||
void WaterSurfaceRender::prepareRender()
|
void WaterSurfaceRender::prepareRender()
|
||||||
{
|
{
|
||||||
bool fbEffectVisible = false;
|
bool fbEffectVisible = false;
|
||||||
|
const float vw = core->getVirtualWidth();
|
||||||
|
const float vh = core->getVirtualHeight();
|
||||||
if (game->waterLevel.x > 0)
|
if (game->waterLevel.x > 0)
|
||||||
{
|
{
|
||||||
qLine->alpha = qSurface->alpha = 1;
|
qLine->alpha = qSurface->alpha = 1;
|
||||||
|
@ -59,12 +60,15 @@ void WaterSurfaceRender::prepareRender()
|
||||||
position.x = core->screenCenter.x;
|
position.x = core->screenCenter.x;
|
||||||
position.y = game->waterLevel.x;
|
position.y = game->waterLevel.x;
|
||||||
|
|
||||||
width = core->getVirtualWidth()*core->invGlobalScale;
|
width = vw * core->invGlobalScale;
|
||||||
height = 100;
|
height = vh * 0.4f; // how wide the water line gets in total
|
||||||
|
|
||||||
|
|
||||||
float dist = (core->screenCenter.y - position.y);
|
float dist = (core->screenCenter.y - position.y);
|
||||||
float maxdist = core->invGlobalScale * 250.0f;
|
// 0.5 makes it align right as the top of the water surface touches the top of the screen
|
||||||
|
// < 0.5 makes the surface line appear flat before it reaches the top of the screen
|
||||||
|
const float topAlignFactor = 0.48f;
|
||||||
|
float maxdist = core->invGlobalScale * vh * topAlignFactor;
|
||||||
if (dist > 0)
|
if (dist > 0)
|
||||||
{
|
{
|
||||||
if (dist > maxdist)
|
if (dist > maxdist)
|
||||||
|
@ -73,17 +77,13 @@ void WaterSurfaceRender::prepareRender()
|
||||||
scale.y = 1.0f-(dist/maxdist);
|
scale.y = 1.0f-(dist/maxdist);
|
||||||
}
|
}
|
||||||
|
|
||||||
offset.y = (height*scale.y);
|
offset.y = height*scale.y*0.5f; // top boundary of quad must touch water surface
|
||||||
|
|
||||||
offset.y -= 40*scale.y;
|
qLine->position = position + offset * 2; // water line is at bottom side of the quad
|
||||||
|
qLine->position.y -= qLine->height * 0.25f; // adjust to align with quad boundaries
|
||||||
|
|
||||||
qLine->position = position + offset + Vector(0,42)*scale.y;
|
|
||||||
qLine->alphaMod = 0.5f;
|
qLine->alphaMod = 0.5f;
|
||||||
qLine->setWidth(width);
|
qLine->setWidth(width);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
qSurface->position = position+offset;
|
qSurface->position = position+offset;
|
||||||
qSurface->scale = scale.y;
|
qSurface->scale = scale.y;
|
||||||
|
|
||||||
|
@ -108,20 +108,22 @@ void WaterSurfaceRender::prepareRender()
|
||||||
|
|
||||||
if (fbEffectVisible)
|
if (fbEffectVisible)
|
||||||
{
|
{
|
||||||
const float reflectSize = 123; //97;
|
const Vector effpos = Vector(0, game->waterLevel.x);
|
||||||
const float reflectPos = (game->waterLevel.x - core->cameraPos.y)
|
const Vector reflectSurface = core->getWindowPosition(effpos);
|
||||||
+ (game->waterLevel.x - core->screenCenter.y) / 3;
|
// Reflect from the water surface seam to xx game units, going up
|
||||||
const float reflectOffset = -0.124f;
|
const Vector reflectLimit = core->getWindowPosition(effpos - Vector(0, 250));
|
||||||
const float coordMul = 1.0f / 768;
|
|
||||||
const float v0 = 1 + reflectOffset - (reflectPos * core->globalScale.x) * coordMul;
|
const float coordMul = 1.0f / vh;
|
||||||
const float v1 = v0 + (reflectSize * core->globalScale.x) * coordMul;
|
|
||||||
|
const float v0 = 1 - (reflectSurface.y * coordMul);
|
||||||
|
const float v1 = 1 - (reflectLimit.y * coordMul);
|
||||||
|
|
||||||
texcoords.u1 = 0;
|
texcoords.u1 = 0;
|
||||||
texcoords.u2 = core->frameBuffer.getWidthP();
|
texcoords.u2 = core->frameBuffer.getWidthP();
|
||||||
|
|
||||||
const float hperc = core->frameBuffer.getHeightP();
|
const float hperc = core->frameBuffer.getHeightP();
|
||||||
texcoords.v1 = v0 * hperc;
|
texcoords.v1 = v0 * hperc;
|
||||||
texcoords.v2 = v1 * hperc;
|
texcoords.v2 = std::min(1.0f, v1) * hperc; // the min() here is not to let texcoords go out of bounds. this is st
|
||||||
|
|
||||||
color = Vector(0.4f,0.9f,1.0f);
|
color = Vector(0.4f,0.9f,1.0f);
|
||||||
alpha = 0.75f;
|
alpha = 0.75f;
|
||||||
|
|
Loading…
Reference in a new issue