mirror of
https://github.com/AquariaOSE/Aquaria.git
synced 2025-01-26 02:07:26 +00:00
invert two x,y loops for more efficient grid updating
This commit is contained in:
parent
d94219e91c
commit
6686080ddb
1 changed files with 30 additions and 24 deletions
|
@ -82,25 +82,30 @@ void RenderGrid::update(float dt)
|
||||||
{
|
{
|
||||||
gridTimer += dt * drawGridTimeMultiplier;
|
gridTimer += dt * drawGridTimeMultiplier;
|
||||||
reset();
|
reset();
|
||||||
size_t hx = grid.width()/2;
|
const size_t w = grid.width();
|
||||||
for (size_t x = 0; x < grid.width(); x++)
|
const size_t h = grid.height();
|
||||||
{
|
|
||||||
float yoffset = x * drawGridOffsetY;
|
size_t nx = w;
|
||||||
float addY = 0;
|
if(drawGridOut)
|
||||||
if (drawGridModY != 0)
|
nx /= 2;
|
||||||
addY = cosf(gridTimer+yoffset)*drawGridModY;
|
|
||||||
for (size_t y = 0; y < grid.height(); y++)
|
for (size_t y = 0; y < h; y++)
|
||||||
{
|
{
|
||||||
float xoffset = y * drawGridOffsetX;
|
Vector * const row = grid.row(y);
|
||||||
if (drawGridModX != 0)
|
const float xoffset = y * drawGridOffsetX;
|
||||||
|
const float addx = sinf(gridTimer+xoffset)*drawGridModX;
|
||||||
|
|
||||||
|
size_t x;
|
||||||
|
for (x = 0; x < nx; x++)
|
||||||
|
row[x].x -= addx;
|
||||||
|
for (; x < w; x++)
|
||||||
|
row[x].x += addx;
|
||||||
|
|
||||||
|
if(const float dgmy = drawGridModY)
|
||||||
|
for (x = 0; x < w; x++)
|
||||||
{
|
{
|
||||||
float addX = (sinf(gridTimer+xoffset)*drawGridModX);
|
float yoffset = x * drawGridOffsetY;
|
||||||
if (drawGridOut && x < hx)
|
row[x].y += cosf(gridTimer+yoffset)*dgmy;
|
||||||
grid(x,y).x += addX;
|
|
||||||
else
|
|
||||||
grid(x,y).x -= addX;
|
|
||||||
}
|
|
||||||
grid(x,y).y += addY;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -155,16 +160,17 @@ void RenderGrid::setFromWavy(const Vector* wavy, size_t len, float width)
|
||||||
const size_t H = grid.height();
|
const size_t H = grid.height();
|
||||||
|
|
||||||
const float iw = 1.0f / width;
|
const float iw = 1.0f / width;
|
||||||
for (size_t x = 0; x < NX; x++) // TODO invert loop
|
|
||||||
{
|
|
||||||
for (size_t y = 0; y < H; y++)
|
for (size_t y = 0; y < H; y++)
|
||||||
{
|
{
|
||||||
const size_t wavy_y = (H - y)-1;
|
const size_t wavy_y = (H - y)-1;
|
||||||
if (wavy_y < len)
|
if (wavy_y < len)
|
||||||
{
|
{
|
||||||
const float tmp = wavy[wavy_y].x * iw;
|
const float tmp = wavy[wavy_y].x * iw;
|
||||||
grid(x,y).x = tmp - 0.5f;
|
Vector * const row = grid.row(y);
|
||||||
grid(x+1,y).x = tmp + 0.5f;
|
for (size_t x = 0; x < NX; x++)
|
||||||
|
{
|
||||||
|
row[x].x = tmp - 0.5f;
|
||||||
|
row[x+1].x = tmp + 0.5f;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue