diff options
| author | Simon Robertshaw <simon@hardwired.org.uk> | 2012-06-12 18:26:47 (GMT) |
|---|---|---|
| committer | Simon Robertshaw <simon@hardwired.org.uk> | 2012-06-12 18:26:47 (GMT) |
| commit | 780682c22d6215e655d53c0adb167d9064947928 (patch) | |
| tree | 50fa4f7a56e81be324eafecfbcd26160b455142f /src/simulation/elements | |
| parent | a93caaa3c7fbb0f3ac7d9edf46eb2b4a89f0aeab (diff) | |
| download | powder-780682c22d6215e655d53c0adb167d9064947928.zip powder-780682c22d6215e655d53c0adb167d9064947928.tar.gz | |
TPT: oxygen fusion, fix two small bugs
Diffstat (limited to 'src/simulation/elements')
| -rw-r--r-- | src/simulation/elements/CO2.cpp | 5 | ||||
| -rw-r--r-- | src/simulation/elements/ELEC.cpp | 2 | ||||
| -rw-r--r-- | src/simulation/elements/O2.cpp | 60 |
3 files changed, 43 insertions, 24 deletions
diff --git a/src/simulation/elements/CO2.cpp b/src/simulation/elements/CO2.cpp index 2015883..3e1f4d9 100644 --- a/src/simulation/elements/CO2.cpp +++ b/src/simulation/elements/CO2.cpp @@ -84,14 +84,15 @@ int Element_CO2::update(UPDATE_FUNC_ARGS) j = sim->create_part(-3,x+rand()%3-1,y+rand()%3-1,PT_NEUT); if (j != -1) parts[j].temp = 15000; j = sim->create_part(-3,x+rand()%3-1,y+rand()%3-1,PT_ELEC); if (j != -1) parts[j].temp = 15000; j = sim->create_part(-3,x+rand()%3-1,y+rand()%3-1,PT_O2); if (j != -1) parts[j].temp = 15000; - j = sim->create_part(-3,x+rand()%3-1,y+rand()%3-1,PT_SING); if (j != -1) { parts[j].temp = 15000; parts[i].life = rand()%100+450; } + if (rand()%1000 < 1) { j = sim->create_part(-3,x+rand()%3-1,y+rand()%3-1,PT_SING); if (j != -1) { parts[j].temp = 15000; parts[i].life = 3; } } parts[i].temp += 15000; sim->pv[y/CELL][x/CELL] += 100; + return 1; } } return 0; } -Element_CO2::~Element_CO2() {}
\ No newline at end of file +Element_CO2::~Element_CO2() {} diff --git a/src/simulation/elements/ELEC.cpp b/src/simulation/elements/ELEC.cpp index c0f92db..4081f83 100644 --- a/src/simulation/elements/ELEC.cpp +++ b/src/simulation/elements/ELEC.cpp @@ -127,7 +127,7 @@ int Element_ELEC::update(UPDATE_FUNC_ARGS) sim->kill_part(i); return 1; } - if ((sim->elements[r&0xFF].Properties & PROP_CONDUCTS) && ((r&0xFF)!=PT_H2||parts[i].temp<2273.15)) + if ((sim->elements[r&0xFF].Properties & PROP_CONDUCTS) && ((r&0xFF)!=PT_NBLE||parts[i].temp<2273.15)) { sim->create_part(-1, x+rx, y+ry, PT_SPRK); sim->kill_part(i); diff --git a/src/simulation/elements/O2.cpp b/src/simulation/elements/O2.cpp index 385d1f3..fdc8b98 100644 --- a/src/simulation/elements/O2.cpp +++ b/src/simulation/elements/O2.cpp @@ -48,34 +48,52 @@ Element_O2::Element_O2() //#TPT-Directive ElementHeader Element_O2 static int update(UPDATE_FUNC_ARGS) int Element_O2::update(UPDATE_FUNC_ARGS) - { int r,rx,ry; - 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) - continue; - - if ((r&0xFF)==PT_FIRE) + if (parts[i].temp < 9773.15) + { + 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)) { - parts[r>>8].temp+=(rand()/(RAND_MAX/100)); - if(parts[r>>8].tmp&0x01) + r = pmap[y+ry][x+rx]; + if (!r) + continue; + + if ((r&0xFF)==PT_FIRE) + { + parts[r>>8].temp+=(rand()/(RAND_MAX/100)); + if(parts[r>>8].tmp&0x01) parts[r>>8].temp=3473; - parts[r>>8].tmp |= 2; - } - if ((r&0xFF)==PT_FIRE || (r&0xFF)==PT_PLSM) - { - sim->create_part(i,x,y,PT_FIRE); - parts[i].temp+=(rand()/(RAND_MAX/100)); - parts[i].tmp |= 2; + parts[r>>8].tmp |= 2; + } + if ((r&0xFF)==PT_FIRE || (r&0xFF)==PT_PLSM) + { + sim->create_part(i,x,y,PT_FIRE); + parts[i].temp+=(rand()/(RAND_MAX/100)); + parts[i].tmp |= 2; + } + } + } + else if (parts[i].temp > 9973.15 && sim->pv[y/CELL][x/CELL] > 250.0f && abs(sim->gravx[((y/CELL)*(XRES/CELL))+(x/CELL)]) + abs(sim->gravy[((y/CELL)*(XRES/CELL))+(x/CELL)]) > 50) + { + if (rand()%5 < 1) + { + int j; + sim->part_change_type(i,x,y,PT_PLSM); + parts[i].life = rand()%150+50; + j = sim->create_part(-3,x+rand()%3-1,y+rand()%3-1,PT_NEUT); if (j != -1) parts[j].temp = 15000; + j = sim->create_part(-3,x+rand()%3-1,y+rand()%3-1,PT_PHOT); if (j != -1) parts[j].temp = 15000; + j = sim->create_part(-3,x+rand()%3-1,y+rand()%3-1,PT_BRMT); if (j != -1) parts[j].temp = 15000; + j = sim->create_part(-3,x+rand()%3-1,y+rand()%3-1,PT_SING); if (j != -1) { parts[j].temp = 15000; parts[i].life = rand()%25+50; } - } + parts[i].temp += 15000; + sim->pv[y/CELL][x/CELL] += 300; + } + } return 0; } -Element_O2::~Element_O2() {}
\ No newline at end of file +Element_O2::~Element_O2() {} |
