#include "simulation/Elements.h" //#TPT-Directive ElementClass Element_CBNW PT_CBNW 82 Element_CBNW::Element_CBNW() { Identifier = "DEFAULT_PT_CBNW"; Name = "BUBW"; Colour = PIXPACK(0x2030D0); MenuVisible = 1; MenuSection = SC_LIQUID; Enabled = 1; Advection = 0.6f; AirDrag = 0.01f * CFDS; AirLoss = 0.98f; Loss = 0.95f; Collision = 0.0f; Gravity = 0.1f; Diffusion = 0.00f; HotAir = 0.000f * CFDS; Falldown = 2; Flammable = 0; Explosive = 0; Meltable = 0; Hardness = 20; Weight = 30; Temperature = R_TEMP-2.0f +273.15f; HeatConduct = 29; Description = "Carbonated water. Conducts electricity. Freezes. Extinguishes fires."; State = ST_LIQUID; Properties = TYPE_LIQUID|PROP_CONDUCTS|PROP_LIFE_DEC|PROP_NEUTPENETRATE; LowPressure = IPL; LowPressureTransition = NT; HighPressure = IPH; HighPressureTransition = NT; LowTemperature = 273.15f; LowTemperatureTransition = PT_ICEI; HighTemperature = 373.0f; HighTemperatureTransition = PT_WTRV; Update = &Element_CBNW::update; Graphics = &Element_CBNW::graphics; } //#TPT-Directive ElementHeader Element_CBNW static int update(UPDATE_FUNC_ARGS) int Element_CBNW::update(UPDATE_FUNC_ARGS) { int r, rx, ry, oldt; oldt = parts[i].tmp; if (sim->pv[y/CELL][x/CELL]<=3) { if(20>(rand()%80000)) { sim->part_change_type(i,x,y,PT_CO2); parts[i].ctype = 5; sim->pv[y/CELL][x/CELL] += 0.5f; } else if(sim->pv[y/CELL][x/CELL]<=-0.5) { sim->part_change_type(i,x,y,PT_CO2); parts[i].ctype = 5; sim->pv[y/CELL][x/CELL] += 0.5f; } } if (parts[i].tmp>0) parts[i].tmp--; if(!(rand()%200)) { parts[i].tmp2 = rand()%40; } else if(parts[i].tmp2!=20) { parts[i].tmp2 -= (parts[i].tmp2>20)?1:-1; } if(oldt==1) { //Explode if(rand()%4) { sim->part_change_type(i,x,y,PT_CO2); parts[i].ctype = 5; sim->pv[y/CELL][x/CELL] += 0.2f; } } for (rx=-2; rx<3; rx++) for (ry=-2; ry<3; ry++) if (x+rx>=0 && y+ry>0 && x+rxelements[r&0xFF].Properties&TYPE_PART) && parts[i].tmp == 0 && 1>(rand()%250)) { //Start explode parts[i].tmp = rand()%25;//(rand()%100)+50; } else if((sim->elements[r&0xFF].Properties&TYPE_SOLID) && (r&0xFF)!=PT_DMND && (r&0xFF)!=PT_GLAS && parts[i].tmp == 0 && (2-sim->pv[y/CELL][x/CELL])>(rand()%20000)) { if(rand()%2) { sim->part_change_type(i,x,y,PT_CO2); parts[i].ctype = 5; sim->pv[y/CELL][x/CELL] += 0.2f; } } if ((r&0xFF)==PT_CBNW) { if(!parts[i].tmp && parts[r>>8].tmp) { parts[i].tmp = parts[r>>8].tmp; if((r>>8)>i) //If the other particle hasn't been life updated parts[i].tmp--; } else if(parts[i].tmp && !parts[r>>8].tmp) { parts[r>>8].tmp = parts[i].tmp; if((r>>8)>i) //If the other particle hasn't been life updated parts[r>>8].tmp++; } } if (((r&0xFF)==PT_RBDM||(r&0xFF)==PT_LRBD) && (sim->legacy_enable||parts[i].temp>(273.15f+12.0f)) && 1>(rand()%500)) { sim->part_change_type(i,x,y,PT_FIRE); parts[i].life = 4; parts[i].ctype = PT_WATR; } if ((r&0xFF)==PT_FIRE && parts[r>>8].ctype!=PT_WATR){ sim->kill_part(r>>8); if(1>(rand()%150)){ sim->kill_part(i); return 1; } } } return 0; } //#TPT-Directive ElementHeader Element_CBNW static int graphics(GRAPHICS_FUNC_ARGS) int Element_CBNW::graphics(GRAPHICS_FUNC_ARGS) { int z = cpart->tmp2 - 20;//speckles! *colr += z * 1; *colg += z * 2; *colb += z * 8; return 0; } Element_CBNW::~Element_CBNW() {}