summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorjacksonmj <mj-pt@jacksonmj.co.uk>2011-07-23 18:24:32 (GMT)
committer Simon Robertshaw <simon@hardwired.org.uk>2011-07-24 12:10:43 (GMT)
commitaeaaa1c4dabbb1816f2afd39dc80b2eb4f3be34e (patch)
treed26548eb456be816da3dad22d652e54f41ee3f0c /src
parent89cc8d4ded6cf96941520e5d0097224f60b79929 (diff)
downloadpowder-aeaaa1c4dabbb1816f2afd39dc80b2eb4f3be34e.zip
powder-aeaaa1c4dabbb1816f2afd39dc80b2eb4f3be34e.tar.gz
update_air now runs 10% faster
Diffstat (limited to 'src')
-rw-r--r--src/air.c22
1 files changed, 10 insertions, 12 deletions
diff --git a/src/air.c b/src/air.c
index 8a3f915..1b83665 100644
--- a/src/air.c
+++ b/src/air.c
@@ -25,6 +25,7 @@ float *th_gravxf;
float vx[YRES/CELL][XRES/CELL], ovx[YRES/CELL][XRES/CELL];
float vy[YRES/CELL][XRES/CELL], ovy[YRES/CELL][XRES/CELL];
float pv[YRES/CELL][XRES/CELL], opv[YRES/CELL][XRES/CELL];
+unsigned char bmap_blockair[YRES/CELL][XRES/CELL];
float cb_vx[YRES/CELL][XRES/CELL];
float cb_vy[YRES/CELL][XRES/CELL];
@@ -215,6 +216,11 @@ void update_air(void)
int x, y, i, j;
float dp, dx, dy, f, tx, ty;
+ for (y=0; y<YRES/CELL; y++)
+ for (x=0; x<XRES/CELL; x++)
+ {
+ bmap_blockair[y][x] = (bmap[y][x]==WL_WALL || bmap[y][x]==WL_WALLELEC || (bmap[y][x]==WL_EWALL && !emap[y][x]));
+ }
if (airMode != 4) { //airMode 4 is no air/pressure update
for (i=0; i<YRES/CELL; i++) //reduces pressure/velocity on the edges every frame
@@ -254,7 +260,7 @@ void update_air(void)
{
for (i=1; i<XRES/CELL; i++)
{
- if (bmap[j][i]==WL_WALL || bmap[j][i]==WL_WALLELEC || (bmap[j][i]==WL_EWALL && !emap[j][i]))
+ if (bmap_blockair[j][i])
{
vx[j][i] = 0.0f;
vx[j][i-1] = 0.0f;
@@ -284,15 +290,9 @@ void update_air(void)
vy[y][x] *= AIR_VLOSS;
vx[y][x] += dx*AIR_TSTEPV;
vy[y][x] += dy*AIR_TSTEPV;
- if (bmap[y][x]==WL_WALL || bmap[y][x+1]==WL_WALL ||
- bmap[y][x]==WL_WALLELEC || bmap[y][x+1]==WL_WALLELEC ||
- (bmap[y][x]==WL_EWALL && !emap[y][x]) ||
- (bmap[y][x+1]==WL_EWALL && !emap[y][x+1]))
+ if (bmap_blockair[y][x] || bmap_blockair[y][x+1])
vx[y][x] = 0;
- if (bmap[y][x]==WL_WALL || bmap[y+1][x]==WL_WALL ||
- bmap[y][x]==WL_WALLELEC || bmap[y+1][x]==WL_WALLELEC ||
- (bmap[y][x]==WL_EWALL && !emap[y][x]) ||
- (bmap[y+1][x]==WL_EWALL && !emap[y+1][x]))
+ if (bmap_blockair[y][x] || bmap_blockair[y+1][x])
vy[y][x] = 0;
}
@@ -306,9 +306,7 @@ void update_air(void)
for (i=-1; i<2; i++)
if (y+j>0 && y+j<YRES/CELL-1 &&
x+i>0 && x+i<XRES/CELL-1 &&
- bmap[y+j][x+i]!=WL_WALL &&
- bmap[y+j][x+i]!=WL_WALLELEC &&
- (bmap[y+j][x+i]!=WL_EWALL || emap[y+j][x+i]))
+ !bmap_blockair[y+j][x+i])
{
f = kernel[i+1+(j+1)*3];
dx += vx[y+j][x+i]*f;