2011-03-27 17:33:54 -05:00
|
|
|
#include <element.h>
|
|
|
|
|
|
|
|
int update_O2(UPDATE_FUNC_ARGS)
|
|
|
|
{
|
2011-04-08 05:09:42 -05:00
|
|
|
int r,rx,ry;
|
|
|
|
for (rx=-2; rx<3; rx++)
|
|
|
|
for (ry=-2; ry<3; ry++)
|
2011-04-05 10:14:23 -05:00
|
|
|
if (x+rx>=0 && y+ry>=0 && x+rx<XRES && y+ry<YRES && (rx || ry))
|
2011-03-27 17:33:54 -05:00
|
|
|
{
|
|
|
|
r = pmap[y+ry][x+rx];
|
|
|
|
if ((r>>8)>=NPART || !r)
|
|
|
|
continue;
|
|
|
|
|
2011-04-08 05:09:42 -05:00
|
|
|
if ((r&0xFF)==PT_FIRE)
|
|
|
|
{
|
|
|
|
parts[r>>8].life+=(rand()/(RAND_MAX/100))*2;
|
|
|
|
parts[r>>8].temp+=(rand()/(RAND_MAX/100));
|
|
|
|
parts[i].tmp++;
|
|
|
|
}
|
2011-03-29 15:35:14 -05:00
|
|
|
|
2011-04-08 05:09:42 -05:00
|
|
|
}
|
2011-03-29 15:35:14 -05:00
|
|
|
|
2011-04-08 05:09:42 -05:00
|
|
|
if (pv[y/CELL][x/CELL] > 8.0f)
|
|
|
|
{
|
|
|
|
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;
|
|
|
|
if ((r&0xFF)==PT_H2)
|
2011-04-05 18:22:29 -05:00
|
|
|
{
|
|
|
|
part_change_type(r>>8,x+rx,y+ry,PT_WATR);
|
2011-04-08 05:09:42 -05:00
|
|
|
if (50<(rand()/(RAND_MAX/100))) {
|
|
|
|
part_change_type(i,x,y,PT_WATR);
|
2011-04-05 18:22:29 -05:00
|
|
|
rx = ry = 3;
|
2011-04-04 10:40:22 -05:00
|
|
|
}
|
2011-04-05 18:22:29 -05:00
|
|
|
}
|
2011-04-08 05:09:42 -05:00
|
|
|
}
|
|
|
|
}
|
2011-03-29 15:35:14 -05:00
|
|
|
|
|
|
|
|
2011-04-08 05:09:42 -05:00
|
|
|
if (parts[i].tmp>=50)
|
|
|
|
{
|
|
|
|
create_part(i,x,y,PT_FIRE);
|
|
|
|
parts[i].life+=(rand()/(RAND_MAX/100))+50;
|
|
|
|
parts[i].temp+=(rand()/(RAND_MAX/100));
|
|
|
|
}
|
|
|
|
return 0;
|
2011-03-27 17:33:54 -05:00
|
|
|
}
|