#include "element.h" int update_BOYL(UPDATE_FUNC_ARGS) { int r, rx, ry; if (sim->pv[y/CELL][x/CELL]<(parts[i].temp/100)) sim->pv[y/CELL][x/CELL] += 0.001f*((parts[i].temp/100)-sim->pv[y/CELL][x/CELL]); if (y+CELLpv[y/CELL+1][x/CELL]<(parts[i].temp/100)) sim->pv[y/CELL+1][x/CELL] += 0.001f*((parts[i].temp/100)-sim->pv[y/CELL+1][x/CELL]); if (x+CELLpv[y/CELL][x/CELL+1] += 0.001f*((parts[i].temp/100)-sim->pv[y/CELL][x/CELL+1]); if (y+CELLpv[y/CELL+1][x/CELL+1] += 0.001f*((parts[i].temp/100)-sim->pv[y/CELL+1][x/CELL+1]); } if (y-CELL>=0 && sim->pv[y/CELL-1][x/CELL]<(parts[i].temp/100)) sim->pv[y/CELL-1][x/CELL] += 0.001f*((parts[i].temp/100)-sim->pv[y/CELL-1][x/CELL]); if (x-CELL>=0) { sim->pv[y/CELL][x/CELL-1] += 0.001f*((parts[i].temp/100)-sim->pv[y/CELL][x/CELL-1]); if (y-CELL>=0) sim->pv[y/CELL-1][x/CELL-1] += 0.001f*((parts[i].temp/100)-sim->pv[y/CELL-1][x/CELL-1]); } for (rx=-1; rx<2; rx++) for (ry=-1; ry<2; ry++) if (x+rx>=0 && y+ry>0 && x+rxrand()%30) { sim->part_change_type(r>>8,x+rx,y+ry,PT_FOG); } else if ((r&0xFF)==PT_O2 && 1>rand()%9) { sim->kill_part(r>>8); sim->part_change_type(i,x,y,PT_WATR); sim->pv[y/CELL][x/CELL] += 4.0; } } return 0; }