From 28f1b88ea09be8da1c363122b49eaa724b204659 Mon Sep 17 00:00:00 2001 From: Cracker64 Date: Sat, 1 Jan 2011 01:01:19 -0500 Subject: [PATCH 1/2] fix INST crash, forgot to change PCLN to work with all GoL. --- src/powder.c | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/src/powder.c b/src/powder.c index 13b01b7f1..5409ee923 100644 --- a/src/powder.c +++ b/src/powder.c @@ -4882,7 +4882,7 @@ killed: } } } - else if(parts[i].ctype>77&&parts[i].ctype<77+NGOL) { + else if(ptypes[parts[i].ctype].properties&PROP_LIFE) { for(nx=-1; nx<2; nx++) { for(ny=-1; ny<2; ny++) { create_part(-1, x+nx, y+ny, parts[i].ctype); @@ -6071,7 +6071,8 @@ int create_parts(int x, int y, int rx, int ry, int c) } if(rx==0&&ry==0)//workaround for 1pixel brush/floodfill crashing. todo: find a better fix later. { - create_part(-2, x, y, c); + if(create_part(-2, x, y, c)==-1) + f = 1; } else for(j=-ry; j<=ry; j++) From 5b86cd5c217efa50df96a2ad36ee137646387655 Mon Sep 17 00:00:00 2001 From: Cracker64 Date: Sat, 1 Jan 2011 01:31:25 -0500 Subject: [PATCH 2/2] QRTZ and powder will have heat glow, also changed heat glow code a bit. --- src/graphics.c | 46 +++++++++++++++++++++++++++++++++++----------- 1 file changed, 35 insertions(+), 11 deletions(-) diff --git a/src/graphics.c b/src/graphics.c index bfc60b431..6e503c7d1 100644 --- a/src/graphics.c +++ b/src/graphics.c @@ -1521,14 +1521,38 @@ void draw_parts(pixel *vid) } else if(t==PT_QRTZ || t==PT_PQRT) { - int q = parts[i].tmp; - cr = q * 16 + PIXR(ptypes[t].pcolors); - cg = q * 16 + PIXG(ptypes[t].pcolors); - cb = q * 16 + PIXB(ptypes[t].pcolors); - cr = cr>255?255:cr; - cg = cg>255?255:cg; - cb = cb>255?255:cb; - blendpixel(vid, nx, ny, cr, cg, cb, 255); + int z = parts[i].tmp; + if(parts[i].temp>(pstates[t].ltemp-800.0f)) + { + float frequency = 3.1415/(2*pstates[t].ltemp-(pstates[t].ltemp-800.0f)); + int q = (parts[i].temp>pstates[t].ltemp)?pstates[t].ltemp-(pstates[t].ltemp-800.0f):parts[i].temp-(pstates[t].ltemp-800.0f); + cr = sin(frequency*q) * 226 + (z * 16 + PIXR(ptypes[t].pcolors)); + cg = sin(frequency*q*4.55 +3.14) * 34 + (z * 16 + PIXR(ptypes[t].pcolors)); + cb = sin(frequency*q*2.22 +3.14) * 64 + (z * 16 + PIXR(ptypes[t].pcolors)); + if(cr>=255) + cr = 255; + if(cg>=255) + cg = 255; + if(cb>=255) + cb = 255; + if(cr<=0) + cr = 0; + if(cg<=0) + cg = 0; + if(cb<=0) + cb = 0; + blendpixel(vid, nx, ny, cr, cg, cb, 255); + } + else + { + cr = z * 16 + PIXR(ptypes[t].pcolors); + cg = z * 16 + PIXG(ptypes[t].pcolors); + cb = z * 16 + PIXB(ptypes[t].pcolors); + cr = cr>255?255:cr; + cg = cg>255?255:cg; + cb = cb>255?255:cb; + blendpixel(vid, nx, ny, cr, cg, cb, 255); + } } else if(t==PT_SPNG) { @@ -2528,10 +2552,10 @@ void draw_parts(pixel *vid) } } - else if(ptypes[t].properties&PROP_HOT_GLOW && parts[i].temp>473.0f) + else if(ptypes[t].properties&PROP_HOT_GLOW && parts[i].temp>(pstates[t].ltemp-800.0f)) { - float frequency = 3.1415/(2*pstates[t].ltemp-473.0); - int q = (parts[i].temp>pstates[t].ltemp)?pstates[t].ltemp-473:parts[i].temp-473; + float frequency = 3.1415/(2*pstates[t].ltemp-(pstates[t].ltemp-800.0f)); + int q = (parts[i].temp>pstates[t].ltemp)?pstates[t].ltemp-(pstates[t].ltemp-800.0f):parts[i].temp-(pstates[t].ltemp-800.0f); cr = sin(frequency*q) * 226 + PIXR(ptypes[t].pcolors); cg = sin(frequency*q*4.55 +3.14) * 34 + PIXG(ptypes[t].pcolors); cb = sin(frequency*q*2.22 +3.14) * 64 + PIXB(ptypes[t].pcolors);