diff options
| author | Simon <simon@hardwired.org.uk> | 2011-03-24 20:06:22 (GMT) |
|---|---|---|
| committer | Simon <simon@hardwired.org.uk> | 2011-03-24 20:06:22 (GMT) |
| commit | 82d0d63be9b940998849d1e58573ad7aa920b27e (patch) | |
| tree | a86e6cdb813755aa0c3d80046c3239f518718d31 /src/elements | |
| parent | 635ad0afdc33c7ae7c0679fd37ab665705e1b824 (diff) | |
| download | powder-82d0d63be9b940998849d1e58573ad7aa920b27e.zip powder-82d0d63be9b940998849d1e58573ad7aa920b27e.tar.gz | |
Awesome QRTZ from Cate
Diffstat (limited to 'src/elements')
| -rw-r--r-- | src/elements/qrtz.c | 63 |
1 files changed, 63 insertions, 0 deletions
diff --git a/src/elements/qrtz.c b/src/elements/qrtz.c index 74d8c99..6e3d2e2 100644 --- a/src/elements/qrtz.c +++ b/src/elements/qrtz.c @@ -1,11 +1,74 @@ #include <element.h> int update_QRTZ(UPDATE_FUNC_ARGS) { + int r, tmp, trade, rx, ry; parts[i].pavg[0] = parts[i].pavg[1]; parts[i].pavg[1] = pv[y/CELL][x/CELL]; if (parts[i].pavg[1]-parts[i].pavg[0] > 0.05*(parts[i].temp/3) || parts[i].pavg[1]-parts[i].pavg[0] < -0.05*(parts[i].temp/3)) { part_change_type(i,x,y,PT_PQRT); } + + for (rx=-2; rx<3; rx++) + for (ry=-2; ry<3; ry++) + if (x+rx>=0 && y+ry>0 && x+rx<XRES && y+ry<YRES && (rx || ry)) + { + r = pmap[y+ry][x+rx]; + if ((r>>8)>=NPART || !r) + continue; + else if ((r&0xFF)==PT_SLTW && (1>rand()%5000)) + { + kill_part(r>>8); + + parts[i].life = 1; + } + } + + if (parts[i].life==1) + { + for (rx=-1; rx<2; rx++) + for (ry=-1; ry<2; ry++) + if (x+rx>=0 && y+ry>0 && x+rx<XRES && y+ry<YRES && (rx || ry)) + { + r = pmap[y+ry][x+rx]; + if ((r>>8)>=NPART || r) + continue; + create_part(-1,x+rx,y+ry,PT_QRTZ); + parts[i].life = 0; + } + + + } + + + for ( trade = 0; trade<9; trade ++) + { + rx = rand()%5-2; + ry = rand()%5-2; + if (x+rx>=0 && y+ry>0 && x+rx<XRES && y+ry<YRES && (rx || ry)) + { + r = pmap[y+ry][x+rx]; + if ((r>>8)>=NPART || !r) + continue; + if ((r&0xFF)==PT_QRTZ&&(parts[i].life>parts[r>>8].life)&&parts[i].life>0)//diffusion + { + tmp = parts[i].life - parts[r>>8].life; + if (tmp ==1) + { + parts[r>>8].life ++; + parts[i].life --; + trade = 9; + } + if (tmp>0) + { + parts[r>>8].life += tmp/2; + parts[i].life -= tmp/2; + trade = 9; + } + } + } + } + + return 0; } |
