#include "simulation/Elements.h" //#TPT-Directive ElementClass Element_BMTL PT_BMTL 29 Element_BMTL::Element_BMTL() { Identifier = "DEFAULT_PT_BMTL"; Name = "BMTL"; Colour = PIXPACK(0x505070); MenuVisible = 1; MenuSection = SC_SOLIDS; Enabled = 1; Advection = 0.0f; AirDrag = 0.00f * CFDS; AirLoss = 0.90f; Loss = 0.00f; Collision = 0.0f; Gravity = 0.0f; Diffusion = 0.00f; HotAir = 0.000f * CFDS; Falldown = 0; Flammable = 0; Explosive = 0; Meltable = 1; Hardness = 1; Weight = 100; Temperature = R_TEMP+0.0f +273.15f; HeatConduct = 251; Description = "Breakable metal."; State = ST_SOLID; Properties = TYPE_SOLID|PROP_CONDUCTS|PROP_LIFE_DEC|PROP_HOT_GLOW; LowPressure = IPL; LowPressureTransition = NT; HighPressure = 1.0f; HighPressureTransition = ST; LowTemperature = ITL; LowTemperatureTransition = NT; HighTemperature = 1273.0f; HighTemperatureTransition = PT_LAVA; Update = &Element_BMTL::update; } //#TPT-Directive ElementHeader Element_BMTL static int update(UPDATE_FUNC_ARGS) int Element_BMTL::update(UPDATE_FUNC_ARGS) { int r, rx, ry, rt, tempFactor; if (parts[i].tmp>1) { parts[i].tmp--; for (rx=-1; rx<2; rx++) for (ry=-1; ry<2; ry++) if (x+rx>=0 && y+ry>0 && x+rx>8].type; if ((rt==PT_METL || rt==PT_IRON) && 1>(rand()/(RAND_MAX/100))) { sim->part_change_type(r>>8,x+rx,y+ry,PT_BMTL); parts[r>>8].tmp=(parts[i].tmp<=7)?parts[i].tmp=1:parts[i].tmp-(rand()%5);//rand()/(RAND_MAX/300)+100; } } } else if (parts[i].tmp==1 && 1>rand()%1000) { parts[i].tmp = 0; sim->part_change_type(i,x,y,PT_BRMT); } return 0; } Element_BMTL::~Element_BMTL() {}