some 'fixes', better solution: change to what it was before the neutron fix.
This commit is contained in:
parent
24d5ca7d4e
commit
fdd3d24031
2
Makefile
2
Makefile
@ -30,7 +30,7 @@ powder-64-sse3-opengl: $(SOURCES)
|
|||||||
$(COMPILER) -m64 -o$@ $(CFLAGS) $(OFLAGS) $(LFLAGS) $(MFLAGS_SSE3) $(SOURCES) -DLIN64 -lGL -lGLU -DOpenGL
|
$(COMPILER) -m64 -o$@ $(CFLAGS) $(OFLAGS) $(LFLAGS) $(MFLAGS_SSE3) $(SOURCES) -DLIN64 -lGL -lGLU -DOpenGL
|
||||||
strip $@
|
strip $@
|
||||||
powder-64-sse3: $(SOURCES)
|
powder-64-sse3: $(SOURCES)
|
||||||
$(COMPILER) -m64 -o$@ $(CFLAGS) $(OFLAGS) $(LFLAGS) $(MFLAGS_SSE3) $(SOURCES) -DLIN64
|
$(COMPILER) -m64 -o$@ $(CFLAGS) $(OFLAGS) $(LFLAGS) $(MFLAGS_SSE3) $(SOURCES) -DLIN64 -j3
|
||||||
strip $@
|
strip $@
|
||||||
mv $@ build
|
mv $@ build
|
||||||
powder-64-sse2: $(SOURCES)
|
powder-64-sse2: $(SOURCES)
|
||||||
|
@ -75,21 +75,21 @@ typedef struct ui_edit ui_edit;
|
|||||||
|
|
||||||
struct save_info
|
struct save_info
|
||||||
{
|
{
|
||||||
char *title;
|
char *title;
|
||||||
char *name;
|
char *name;
|
||||||
char *author;
|
char *author;
|
||||||
char *date;
|
char *date;
|
||||||
char *description;
|
char *description;
|
||||||
int publish;
|
int publish;
|
||||||
int voteup;
|
int voteup;
|
||||||
int votedown;
|
int votedown;
|
||||||
int vote;
|
int vote;
|
||||||
int myvote;
|
int myvote;
|
||||||
int myfav;
|
int myfav;
|
||||||
char *tags;
|
char *tags;
|
||||||
int comment_count;
|
int comment_count;
|
||||||
char *comments[6];
|
char *comments[6];
|
||||||
char *commentauthors[6];
|
char *commentauthors[6];
|
||||||
};
|
};
|
||||||
typedef struct save_info save_info;
|
typedef struct save_info save_info;
|
||||||
|
|
||||||
|
@ -141,54 +141,54 @@ static const unsigned short PROP_DEADLY = 0x12; //18 Is deadly for stickman.
|
|||||||
|
|
||||||
struct particle
|
struct particle
|
||||||
{
|
{
|
||||||
int type;
|
int type;
|
||||||
int life, ctype;
|
int life, ctype;
|
||||||
float x, y, vx, vy;
|
float x, y, vx, vy;
|
||||||
float temp;
|
float temp;
|
||||||
float pavg[2];
|
float pavg[2];
|
||||||
int flags;
|
int flags;
|
||||||
int tmp;
|
int tmp;
|
||||||
};
|
};
|
||||||
typedef struct particle particle;
|
typedef struct particle particle;
|
||||||
|
|
||||||
struct part_type
|
struct part_type
|
||||||
{
|
{
|
||||||
const char *name;
|
const char *name;
|
||||||
pixel pcolors;
|
pixel pcolors;
|
||||||
float advection;
|
float advection;
|
||||||
float airdrag;
|
float airdrag;
|
||||||
float airloss;
|
float airloss;
|
||||||
float loss;
|
float loss;
|
||||||
float collision;
|
float collision;
|
||||||
float gravity;
|
float gravity;
|
||||||
float diffusion;
|
float diffusion;
|
||||||
float hotair;
|
float hotair;
|
||||||
int falldown;
|
int falldown;
|
||||||
int flammable;
|
int flammable;
|
||||||
int explosive;
|
int explosive;
|
||||||
int meltable;
|
int meltable;
|
||||||
int hardness;
|
int hardness;
|
||||||
int menu;
|
int menu;
|
||||||
int weight;
|
int weight;
|
||||||
int menusection;
|
int menusection;
|
||||||
float heat;
|
float heat;
|
||||||
unsigned char hconduct;
|
unsigned char hconduct;
|
||||||
const char *descs;
|
const char *descs;
|
||||||
const unsigned short properties;
|
const unsigned short properties;
|
||||||
};
|
};
|
||||||
typedef struct part_type part_type;
|
typedef struct part_type part_type;
|
||||||
|
|
||||||
struct part_state
|
struct part_state
|
||||||
{
|
{
|
||||||
char state;
|
char state;
|
||||||
int solid;
|
int solid;
|
||||||
float stemp;
|
float stemp;
|
||||||
int liquid;
|
int liquid;
|
||||||
float ltemp;
|
float ltemp;
|
||||||
int gas;
|
int gas;
|
||||||
float gtemp;
|
float gtemp;
|
||||||
int burn;
|
int burn;
|
||||||
float btemp;
|
float btemp;
|
||||||
};
|
};
|
||||||
typedef struct part_state part_state;
|
typedef struct part_state part_state;
|
||||||
//Should probably be const.
|
//Should probably be const.
|
||||||
@ -196,173 +196,173 @@ typedef struct part_state part_state;
|
|||||||
* 1 = Gas ||
|
* 1 = Gas ||
|
||||||
* 2 = Light || Liquids 0-49
|
* 2 = Light || Liquids 0-49
|
||||||
* 98 = Heavy || Powder 50-99
|
* 98 = Heavy || Powder 50-99
|
||||||
* 100 = Solid ||
|
* 100 = Solid ||
|
||||||
* -1 is Neutrons and Photons
|
* -1 is Neutrons and Photons
|
||||||
*/
|
*/
|
||||||
static const part_type ptypes[PT_NUM] =
|
static const part_type ptypes[PT_NUM] =
|
||||||
{
|
{
|
||||||
//Name Colour Advec Airdrag Airloss Loss Collid Grav Diffus Hotair Fal Burn Exp Mel Hrd M Weight Section H Ins(real world, by triclops200) Description
|
//Name Colour Advec Airdrag Airloss Loss Collid Grav Diffus Hotair Fal Burn Exp Mel Hrd M Weight Section H Ins(real world, by triclops200) Description
|
||||||
{"", PIXPACK(0x000000), 0.0f, 0.00f * CFDS, 1.00f, 0.00f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 0, 0, 0, 1, 1, 100, SC_SPECIAL, R_TEMP+0.0f +273.15f, 251, "Erases particles."},
|
{"", PIXPACK(0x000000), 0.0f, 0.00f * CFDS, 1.00f, 0.00f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 0, 0, 0, 1, 1, 100, SC_SPECIAL, R_TEMP+0.0f +273.15f, 251, "Erases particles."},
|
||||||
{"DUST", PIXPACK(0xFFE0A0), 0.7f, 0.02f * CFDS, 0.96f, 0.80f, 0.0f, 0.1f, 0.00f, 0.000f * CFDS, 1, 10, 0, 0, 30, 1, 85, SC_POWDERS, R_TEMP+0.0f +273.15f, 70, "Very light dust. Flammable."},
|
{"DUST", PIXPACK(0xFFE0A0), 0.7f, 0.02f * CFDS, 0.96f, 0.80f, 0.0f, 0.1f, 0.00f, 0.000f * CFDS, 1, 10, 0, 0, 30, 1, 85, SC_POWDERS, R_TEMP+0.0f +273.15f, 70, "Very light dust. Flammable."},
|
||||||
{"WATR", PIXPACK(0x2030D0), 0.6f, 0.01f * CFDS, 0.98f, 0.95f, 0.0f, 0.1f, 0.00f, 0.000f * CFDS, 2, 0, 0, 0, 20, 1, 30, SC_LIQUID, R_TEMP-2.0f +273.15f, 29, "Liquid. Conducts electricity. Freezes. Extinguishes fires."},
|
{"WATR", PIXPACK(0x2030D0), 0.6f, 0.01f * CFDS, 0.98f, 0.95f, 0.0f, 0.1f, 0.00f, 0.000f * CFDS, 2, 0, 0, 0, 20, 1, 30, SC_LIQUID, R_TEMP-2.0f +273.15f, 29, "Liquid. Conducts electricity. Freezes. Extinguishes fires."},
|
||||||
{"OIL", PIXPACK(0x404010), 0.6f, 0.01f * CFDS, 0.98f, 0.95f, 0.0f, 0.1f, 0.00f, 0.000f * CFDS, 2, 20, 0, 0, 5, 1, 20, SC_LIQUID, R_TEMP+0.0f +273.15f, 42, "Liquid. Flammable."},
|
{"OIL", PIXPACK(0x404010), 0.6f, 0.01f * CFDS, 0.98f, 0.95f, 0.0f, 0.1f, 0.00f, 0.000f * CFDS, 2, 20, 0, 0, 5, 1, 20, SC_LIQUID, R_TEMP+0.0f +273.15f, 42, "Liquid. Flammable."},
|
||||||
{"FIRE", PIXPACK(0xFF1000), 0.9f, 0.04f * CFDS, 0.97f, 0.20f, 0.0f, -0.1f, 0.00f, 0.001f * CFDS, 1, 0, 0, 0, 1, 1, 2, SC_EXPLOSIVE, R_TEMP+400.0f +273.15f, 88, "Ignites flammable materials. Heats air."},
|
{"FIRE", PIXPACK(0xFF1000), 0.9f, 0.04f * CFDS, 0.97f, 0.20f, 0.0f, -0.1f, 0.00f, 0.001f * CFDS, 1, 0, 0, 0, 1, 1, 2, SC_EXPLOSIVE, R_TEMP+400.0f +273.15f, 88, "Ignites flammable materials. Heats air."},
|
||||||
{"STNE", PIXPACK(0xA0A0A0), 0.4f, 0.04f * CFDS, 0.94f, 0.95f, -0.1f, 0.3f, 0.00f, 0.000f * CFDS, 1, 0, 0, 5, 1, 1, 90, SC_POWDERS, R_TEMP+0.0f +273.15f, 150, "Heavy particles. Meltable."},
|
{"STNE", PIXPACK(0xA0A0A0), 0.4f, 0.04f * CFDS, 0.94f, 0.95f, -0.1f, 0.3f, 0.00f, 0.000f * CFDS, 1, 0, 0, 5, 1, 1, 90, SC_POWDERS, R_TEMP+0.0f +273.15f, 150, "Heavy particles. Meltable."},
|
||||||
{"LAVA", PIXPACK(0xE05010), 0.3f, 0.02f * CFDS, 0.95f, 0.80f, 0.0f, 0.15f, 0.00f, 0.0003f * CFDS, 2, 0, 0, 0, 2, 1, 45, SC_LIQUID, R_TEMP+1500.0f +273.15f, 60, "Heavy liquid. Ignites flammable materials. Solidifies when cold."},
|
{"LAVA", PIXPACK(0xE05010), 0.3f, 0.02f * CFDS, 0.95f, 0.80f, 0.0f, 0.15f, 0.00f, 0.0003f * CFDS, 2, 0, 0, 0, 2, 1, 45, SC_LIQUID, R_TEMP+1500.0f +273.15f, 60, "Heavy liquid. Ignites flammable materials. Solidifies when cold."},
|
||||||
{"GUN", PIXPACK(0xC0C0D0), 0.7f, 0.02f * CFDS, 0.94f, 0.80f, -0.1f, 0.1f, 0.00f, 0.000f * CFDS, 1, 600, 1, 0, 10, 1, 85, SC_EXPLOSIVE, R_TEMP+0.0f +273.15f, 97, "Light dust. Explosive."},
|
{"GUN", PIXPACK(0xC0C0D0), 0.7f, 0.02f * CFDS, 0.94f, 0.80f, -0.1f, 0.1f, 0.00f, 0.000f * CFDS, 1, 600, 1, 0, 10, 1, 85, SC_EXPLOSIVE, R_TEMP+0.0f +273.15f, 97, "Light dust. Explosive."},
|
||||||
{"NITR", PIXPACK(0x20E010), 0.5f, 0.02f * CFDS, 0.92f, 0.97f, 0.0f, 0.2f, 0.00f, 0.000f * CFDS, 2, 1000, 2, 0, 3, 1, 23, SC_EXPLOSIVE, R_TEMP+0.0f +273.15f, 50, "Liquid. Pressure sensitive explosive."},
|
{"NITR", PIXPACK(0x20E010), 0.5f, 0.02f * CFDS, 0.92f, 0.97f, 0.0f, 0.2f, 0.00f, 0.000f * CFDS, 2, 1000, 2, 0, 3, 1, 23, SC_EXPLOSIVE, R_TEMP+0.0f +273.15f, 50, "Liquid. Pressure sensitive explosive."},
|
||||||
{"CLNE", PIXPACK(0xFFD010), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 0, 0, 0, 1, 1, 100, SC_SPECIAL, R_TEMP+0.0f +273.15f, 251, "Solid. Duplicates any particles it touches."},
|
{"CLNE", PIXPACK(0xFFD010), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 0, 0, 0, 1, 1, 100, SC_SPECIAL, R_TEMP+0.0f +273.15f, 251, "Solid. Duplicates any particles it touches."},
|
||||||
{"GAS", PIXPACK(0xE0FF20), 1.0f, 0.01f * CFDS, 0.99f, 0.30f, -0.1f, 0.0f, 0.75f, 0.001f * CFDS, 0, 600, 0, 0, 1, 1, 1, SC_GAS, R_TEMP+2.0f +273.15f, 42, "Gas. Diffuses. Flammable. Liquifies under pressure."},
|
{"GAS", PIXPACK(0xE0FF20), 1.0f, 0.01f * CFDS, 0.99f, 0.30f, -0.1f, 0.0f, 0.75f, 0.001f * CFDS, 0, 600, 0, 0, 1, 1, 1, SC_GAS, R_TEMP+2.0f +273.15f, 42, "Gas. Diffuses. Flammable. Liquifies under pressure."},
|
||||||
{"C-4", PIXPACK(0xD080E0), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 1000, 2, 50, 1, 1, 100, SC_EXPLOSIVE, R_TEMP+0.0f +273.15f, 88, "Solid. Pressure sensitive explosive."},
|
{"C-4", PIXPACK(0xD080E0), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 1000, 2, 50, 1, 1, 100, SC_EXPLOSIVE, R_TEMP+0.0f +273.15f, 88, "Solid. Pressure sensitive explosive."},
|
||||||
{"GOO", PIXPACK(0x804000), 0.1f, 0.00f * CFDS, 0.97f, 0.50f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 0, 0, 0, 12, 1, 100, SC_SOLIDS, R_TEMP+0.0f +273.15f, 75, "Solid. Deforms and disappears under pressure."},
|
{"GOO", PIXPACK(0x804000), 0.1f, 0.00f * CFDS, 0.97f, 0.50f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 0, 0, 0, 12, 1, 100, SC_SOLIDS, R_TEMP+0.0f +273.15f, 75, "Solid. Deforms and disappears under pressure."},
|
||||||
{"ICE", PIXPACK(0xA0C0FF), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.00f, -0.0003f* CFDS, 0, 0, 0, 0, 20, 1, 100, SC_SOLIDS, R_TEMP-50.0f +273.15f, 46, "Solid. Freezes water. Crushes under pressure. Cools down air."},
|
{"ICE", PIXPACK(0xA0C0FF), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.00f, -0.0003f* CFDS, 0, 0, 0, 0, 20, 1, 100, SC_SOLIDS, R_TEMP-50.0f +273.15f, 46, "Solid. Freezes water. Crushes under pressure. Cools down air."},
|
||||||
{"METL", PIXPACK(0x404060), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 0, 0, 1, 1, 1, 100, SC_ELEC, R_TEMP+0.0f +273.15f, 251, "Solid. Conducts electricity. Meltable."},
|
{"METL", PIXPACK(0x404060), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 0, 0, 1, 1, 1, 100, SC_ELEC, R_TEMP+0.0f +273.15f, 251, "Solid. Conducts electricity. Meltable."},
|
||||||
{"SPRK", PIXPACK(0xFFFF80), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.00f, 0.001f * CFDS, 0, 0, 0, 0, 1, 1, 100, SC_ELEC, R_TEMP+0.0f +273.15f, 251, "Electricity. Conducted by metal and water."},
|
{"SPRK", PIXPACK(0xFFFF80), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.00f, 0.001f * CFDS, 0, 0, 0, 0, 1, 1, 100, SC_ELEC, R_TEMP+0.0f +273.15f, 251, "Electricity. Conducted by metal and water."},
|
||||||
{"SNOW", PIXPACK(0xC0E0FF), 0.7f, 0.01f * CFDS, 0.96f, 0.90f, -0.1f, 0.05f, 0.01f, -0.00005f* CFDS,1, 0, 0, 0, 20, 1, 50, SC_POWDERS, R_TEMP-30.0f +273.15f, 46, "Light particles."},
|
{"SNOW", PIXPACK(0xC0E0FF), 0.7f, 0.01f * CFDS, 0.96f, 0.90f, -0.1f, 0.05f, 0.01f, -0.00005f* CFDS,1, 0, 0, 0, 20, 1, 50, SC_POWDERS, R_TEMP-30.0f +273.15f, 46, "Light particles."},
|
||||||
{"WOOD", PIXPACK(0xC0A040), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 20, 0, 0, 15, 1, 100, SC_SOLIDS, R_TEMP+0.0f +273.15f, 164, "Solid. Flammable. Can be pressurised into COAL"},
|
{"WOOD", PIXPACK(0xC0A040), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 20, 0, 0, 15, 1, 100, SC_SOLIDS, R_TEMP+0.0f +273.15f, 164, "Solid. Flammable. Can be pressurised into COAL"},
|
||||||
{"NEUT", PIXPACK(0x20E0FF), 0.0f, 0.00f * CFDS, 1.00f, 1.00f, -0.99f, 0.0f, 0.01f, 0.002f * CFDS, 0, 0, 0, 0, 0, 1, -1, SC_NUCLEAR, R_TEMP+4.0f +273.15f, 60, "Neutrons. Interact with matter in odd ways."},
|
{"NEUT", PIXPACK(0x20E0FF), 0.0f, 0.00f * CFDS, 1.00f, 1.00f, -0.99f, 0.0f, 0.01f, 0.002f * CFDS, 0, 0, 0, 0, 0, 1, -1, SC_NUCLEAR, R_TEMP+4.0f +273.15f, 60, "Neutrons. Interact with matter in odd ways."},
|
||||||
{"PLUT", PIXPACK(0x407020), 0.4f, 0.01f * CFDS, 0.99f, 0.95f, 0.0f, 0.4f, 0.00f, 0.000f * CFDS, 1, 0, 0, 0, 0, 1, 90, SC_NUCLEAR, R_TEMP+4.0f +273.15f, 251, "Heavy particles. Fissile. Generates neutrons under pressure."},
|
{"PLUT", PIXPACK(0x407020), 0.4f, 0.01f * CFDS, 0.99f, 0.95f, 0.0f, 0.4f, 0.00f, 0.000f * CFDS, 1, 0, 0, 0, 0, 1, 90, SC_NUCLEAR, R_TEMP+4.0f +273.15f, 251, "Heavy particles. Fissile. Generates neutrons under pressure."},
|
||||||
{"PLNT", PIXPACK(0x0CAC00), 0.0f, 0.00f * CFDS, 0.95f, 0.00f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 20, 0, 0, 10, 1, 100, SC_SOLIDS, R_TEMP+0.0f +273.15f, 65, "Plant, drinks water and grows."},
|
{"PLNT", PIXPACK(0x0CAC00), 0.0f, 0.00f * CFDS, 0.95f, 0.00f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 20, 0, 0, 10, 1, 100, SC_SOLIDS, R_TEMP+0.0f +273.15f, 65, "Plant, drinks water and grows."},
|
||||||
{"ACID", PIXPACK(0xED55FF), 0.6f, 0.01f * CFDS, 0.98f, 0.95f, 0.0f, 0.1f, 0.00f, 0.000f * CFDS, 2, 40, 0, 0, 1, 1, 10, SC_LIQUID, R_TEMP+0.0f +273.15f, 34, "Dissolves almost everything."},
|
{"ACID", PIXPACK(0xED55FF), 0.6f, 0.01f * CFDS, 0.98f, 0.95f, 0.0f, 0.1f, 0.00f, 0.000f * CFDS, 2, 40, 0, 0, 1, 1, 10, SC_LIQUID, R_TEMP+0.0f +273.15f, 34, "Dissolves almost everything."},
|
||||||
{"VOID", PIXPACK(0x790B0B), 0.0f, 0.00f * CFDS, 1.00f, 0.00f, 0.0f, 0.0f, 0.00f, -0.0003f* CFDS, 0, 0, 0, 0, 0, 1, 100, SC_SPECIAL, R_TEMP+0.0f +273.15f, 251, "Hole, will drain away any particles."},
|
{"VOID", PIXPACK(0x790B0B), 0.0f, 0.00f * CFDS, 1.00f, 0.00f, 0.0f, 0.0f, 0.00f, -0.0003f* CFDS, 0, 0, 0, 0, 0, 1, 100, SC_SPECIAL, R_TEMP+0.0f +273.15f, 251, "Hole, will drain away any particles."},
|
||||||
{"WTRV", PIXPACK(0xA0A0FF), 1.0f, 0.01f * CFDS, 0.99f, 0.30f, -0.1f, -0.1f, 0.75f, 0.0003f * CFDS, 0, 0, 0, 0, 4, 1, 1, SC_GAS, R_TEMP+100.0f +273.15f, 48, "Steam, heats up air, produced from hot water."},
|
{"WTRV", PIXPACK(0xA0A0FF), 1.0f, 0.01f * CFDS, 0.99f, 0.30f, -0.1f, -0.1f, 0.75f, 0.0003f * CFDS, 0, 0, 0, 0, 4, 1, 1, SC_GAS, R_TEMP+100.0f +273.15f, 48, "Steam, heats up air, produced from hot water."},
|
||||||
{"CNCT", PIXPACK(0xC0C0C0), 0.4f, 0.04f * CFDS, 0.94f, 0.95f, -0.1f, 0.3f, 0.00f, 0.000f * CFDS, 1, 0, 0, 2, 25, 1, 55, SC_POWDERS, R_TEMP+0.0f +273.15f, 100, "Concrete, stronger than stone."},
|
{"CNCT", PIXPACK(0xC0C0C0), 0.4f, 0.04f * CFDS, 0.94f, 0.95f, -0.1f, 0.3f, 0.00f, 0.000f * CFDS, 1, 0, 0, 2, 25, 1, 55, SC_POWDERS, R_TEMP+0.0f +273.15f, 100, "Concrete, stronger than stone."},
|
||||||
{"DSTW", PIXPACK(0x1020C0), 0.6f, 0.01f * CFDS, 0.98f, 0.95f, 0.0f, 0.1f, 0.00f, 0.000f * CFDS, 2, 0, 0, 0, 20, 1, 30, SC_LIQUID, R_TEMP-2.0f +273.15f, 23, "Distilled water, does not conduct electricity."},
|
{"DSTW", PIXPACK(0x1020C0), 0.6f, 0.01f * CFDS, 0.98f, 0.95f, 0.0f, 0.1f, 0.00f, 0.000f * CFDS, 2, 0, 0, 0, 20, 1, 30, SC_LIQUID, R_TEMP-2.0f +273.15f, 23, "Distilled water, does not conduct electricity."},
|
||||||
{"SALT", PIXPACK(0xFFFFFF), 0.4f, 0.04f * CFDS, 0.94f, 0.95f, -0.1f, 0.3f, 0.00f, 0.000f * CFDS, 1, 0, 0, 5, 1, 1, 75, SC_POWDERS, R_TEMP+0.0f +273.15f, 110, "Salt, dissolves in water."},
|
{"SALT", PIXPACK(0xFFFFFF), 0.4f, 0.04f * CFDS, 0.94f, 0.95f, -0.1f, 0.3f, 0.00f, 0.000f * CFDS, 1, 0, 0, 5, 1, 1, 75, SC_POWDERS, R_TEMP+0.0f +273.15f, 110, "Salt, dissolves in water."},
|
||||||
{"SLTW", PIXPACK(0x4050F0), 0.6f, 0.01f * CFDS, 0.98f, 0.95f, 0.0f, 0.1f, 0.00f, 0.000f * CFDS, 2, 0, 0, 0, 20, 1, 35, SC_LIQUID, R_TEMP+0.0f +273.15f, 75, "Saltwater, conducts electricity, difficult to freeze."},
|
{"SLTW", PIXPACK(0x4050F0), 0.6f, 0.01f * CFDS, 0.98f, 0.95f, 0.0f, 0.1f, 0.00f, 0.000f * CFDS, 2, 0, 0, 0, 20, 1, 35, SC_LIQUID, R_TEMP+0.0f +273.15f, 75, "Saltwater, conducts electricity, difficult to freeze."},
|
||||||
{"DMND", PIXPACK(0xCCFFFF), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 0, 0, 0, 0, 1, 100, SC_SPECIAL, R_TEMP+0.0f +273.15f, 186, "Diamond. Indestructable."}, //ief015 - Added diamond. Because concrete blocks are kinda pointless.
|
{"DMND", PIXPACK(0xCCFFFF), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 0, 0, 0, 0, 1, 100, SC_SPECIAL, R_TEMP+0.0f +273.15f, 186, "Diamond. Indestructable."}, //ief015 - Added diamond. Because concrete blocks are kinda pointless.
|
||||||
{"BMTL", PIXPACK(0x505070), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 0, 0, 1, 1, 1, 100, SC_SOLIDS, R_TEMP+0.0f +273.15f, 251, "Breakable metal."},
|
{"BMTL", PIXPACK(0x505070), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 0, 0, 1, 1, 1, 100, SC_SOLIDS, R_TEMP+0.0f +273.15f, 251, "Breakable metal."},
|
||||||
{"BRMT", PIXPACK(0x705060), 0.4f, 0.04f * CFDS, 0.94f, 0.95f, -0.1f, 0.3f, 0.00f, 0.000f * CFDS, 1, 0, 0, 2, 2, 1, 90, SC_POWDERS, R_TEMP+0.0f +273.15f, 211, "Broken metal."},
|
{"BRMT", PIXPACK(0x705060), 0.4f, 0.04f * CFDS, 0.94f, 0.95f, -0.1f, 0.3f, 0.00f, 0.000f * CFDS, 1, 0, 0, 2, 2, 1, 90, SC_POWDERS, R_TEMP+0.0f +273.15f, 211, "Broken metal."},
|
||||||
{"PHOT", PIXPACK(0xFFFFFF), 0.0f, 0.00f * CFDS, 1.00f, 1.00f, -0.99f, 0.0f, 0.00f, 0.000f * CFDS, 0, 0, 0, 0, 0, 1, -1, SC_ELEC, R_TEMP+900.0f +273.15f, 251, "Photons. Travel in straight lines."},
|
{"PHOT", PIXPACK(0xFFFFFF), 0.0f, 0.00f * CFDS, 1.00f, 1.00f, -0.99f, 0.0f, 0.00f, 0.000f * CFDS, 0, 0, 0, 0, 0, 1, -1, SC_ELEC, R_TEMP+900.0f +273.15f, 251, "Photons. Travel in straight lines."},
|
||||||
{"URAN", PIXPACK(0x707020), 0.4f, 0.01f * CFDS, 0.99f, 0.95f, 0.0f, 0.4f, 0.00f, 0.000f * CFDS, 1, 0, 0, 0, 0, 1, 90, SC_NUCLEAR, R_TEMP+30.0f +273.15f, 251, "Heavy particles. Generates heat under pressure."},
|
{"URAN", PIXPACK(0x707020), 0.4f, 0.01f * CFDS, 0.99f, 0.95f, 0.0f, 0.4f, 0.00f, 0.000f * CFDS, 1, 0, 0, 0, 0, 1, 90, SC_NUCLEAR, R_TEMP+30.0f +273.15f, 251, "Heavy particles. Generates heat under pressure."},
|
||||||
{"WAX", PIXPACK(0xF0F0BB), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 0, 0, 0, 10, 1, 100, SC_SOLIDS, R_TEMP+0.0f +273.15f, 44, "Wax. Melts at moderately high temperatures."},
|
{"WAX", PIXPACK(0xF0F0BB), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 0, 0, 0, 10, 1, 100, SC_SOLIDS, R_TEMP+0.0f +273.15f, 44, "Wax. Melts at moderately high temperatures."},
|
||||||
{"MWAX", PIXPACK(0xE0E0AA), 0.3f, 0.02f * CFDS, 0.95f, 0.80f, 0.0f, 0.15f, 0.00f, 0.000001f* CFDS,2, 5, 0, 0, 2, 1, 25, SC_LIQUID, R_TEMP+28.0f +273.15f, 44, "Liquid Wax."},
|
{"MWAX", PIXPACK(0xE0E0AA), 0.3f, 0.02f * CFDS, 0.95f, 0.80f, 0.0f, 0.15f, 0.00f, 0.000001f* CFDS,2, 5, 0, 0, 2, 1, 25, SC_LIQUID, R_TEMP+28.0f +273.15f, 44, "Liquid Wax."},
|
||||||
{"PSCN", PIXPACK(0x805050), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 0, 0, 1, 1, 1, 100, SC_ELEC, R_TEMP+0.0f +273.15f, 251, "P-Type Silicon, Will transfer current to any conductor."},
|
{"PSCN", PIXPACK(0x805050), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 0, 0, 1, 1, 1, 100, SC_ELEC, R_TEMP+0.0f +273.15f, 251, "P-Type Silicon, Will transfer current to any conductor."},
|
||||||
{"NSCN", PIXPACK(0x505080), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 0, 0, 1, 1, 1, 100, SC_ELEC, R_TEMP+0.0f +273.15f, 251, "N-Type Silicon, Will only transfer current to P-Type Silicon."},
|
{"NSCN", PIXPACK(0x505080), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 0, 0, 1, 1, 1, 100, SC_ELEC, R_TEMP+0.0f +273.15f, 251, "N-Type Silicon, Will only transfer current to P-Type Silicon."},
|
||||||
{"LN2", PIXPACK(0x80A0DF), 0.6f, 0.01f * CFDS, 0.98f, 0.95f, 0.0f, 0.1f, 0.00f, 0.000f * CFDS, 2, 0, 0, 0, 0, 1, 30, SC_LIQUID, 70.15f, 70, "Liquid Nitrogen. Very cold."},
|
{"LN2", PIXPACK(0x80A0DF), 0.6f, 0.01f * CFDS, 0.98f, 0.95f, 0.0f, 0.1f, 0.00f, 0.000f * CFDS, 2, 0, 0, 0, 0, 1, 30, SC_LIQUID, 70.15f, 70, "Liquid Nitrogen. Very cold."},
|
||||||
{"INSL", PIXPACK(0x9EA3B6), 0.0f, 0.00f * CFDS, 0.95f, 0.00f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 7, 0, 0, 10, 1, 100, SC_SPECIAL, R_TEMP+0.0f +273.15f, 0, "Insulator, does not conduct heat or electricity."},
|
{"INSL", PIXPACK(0x9EA3B6), 0.0f, 0.00f * CFDS, 0.95f, 0.00f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 7, 0, 0, 10, 1, 100, SC_SPECIAL, R_TEMP+0.0f +273.15f, 0, "Insulator, does not conduct heat or electricity."},
|
||||||
{"BHOL", PIXPACK(0x202020), 0.0f, 0.00f * CFDS, 0.95f, 0.00f, 0.0f, 0.0f, 0.00f, -0.01f * CFDS, 0, 0, 0, 0, 0, 1, 100, SC_SPECIAL, R_TEMP+70.0f +273.15f, 255, "Black hole, sucks in other particles and heats up."},
|
{"BHOL", PIXPACK(0x202020), 0.0f, 0.00f * CFDS, 0.95f, 0.00f, 0.0f, 0.0f, 0.00f, -0.01f * CFDS, 0, 0, 0, 0, 0, 1, 100, SC_SPECIAL, R_TEMP+70.0f +273.15f, 255, "Black hole, sucks in other particles and heats up."},
|
||||||
{"WHOL", PIXPACK(0xEFEFEF), 0.0f, 0.00f * CFDS, 0.95f, 0.00f, 0.0f, 0.0f, 0.00f, 0.010f * CFDS, 0, 0, 0, 0, 0, 1, 100, SC_SPECIAL, R_TEMP-16.0f +273.15f, 255, "White hole, pushes other particles away."},
|
{"WHOL", PIXPACK(0xEFEFEF), 0.0f, 0.00f * CFDS, 0.95f, 0.00f, 0.0f, 0.0f, 0.00f, 0.010f * CFDS, 0, 0, 0, 0, 0, 1, 100, SC_SPECIAL, R_TEMP-16.0f +273.15f, 255, "White hole, pushes other particles away."},
|
||||||
{"RBDM", PIXPACK(0xCCCCCC), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 1000, 1, 50, 1, 1, 100, SC_EXPLOSIVE, R_TEMP+0.0f +273.15f, 240, "Rubidium, explosive, especially on contact with water, low melting point"},
|
{"RBDM", PIXPACK(0xCCCCCC), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 1000, 1, 50, 1, 1, 100, SC_EXPLOSIVE, R_TEMP+0.0f +273.15f, 240, "Rubidium, explosive, especially on contact with water, low melting point"},
|
||||||
{"LRBD", PIXPACK(0xAAAAAA), 0.3f, 0.02f * CFDS, 0.95f, 0.80f, 0.0f, 0.15f, 0.00f, 0.000001f* CFDS,2, 1000, 1, 0, 2, 1, 45, SC_EXPLOSIVE, R_TEMP+45.0f +273.15f, 170, "Liquid Rubidium."},
|
{"LRBD", PIXPACK(0xAAAAAA), 0.3f, 0.02f * CFDS, 0.95f, 0.80f, 0.0f, 0.15f, 0.00f, 0.000001f* CFDS,2, 1000, 1, 0, 2, 1, 45, SC_EXPLOSIVE, R_TEMP+45.0f +273.15f, 170, "Liquid Rubidium."},
|
||||||
{"NTCT", PIXPACK(0x505040), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 0, 0, 1, 1, 1, 100, SC_ELEC, R_TEMP+0.0f +273.15f, 251, "Semi-conductor. Only conducts electricity when hot (More than 100C)"},
|
{"NTCT", PIXPACK(0x505040), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 0, 0, 1, 1, 1, 100, SC_ELEC, R_TEMP+0.0f +273.15f, 251, "Semi-conductor. Only conducts electricity when hot (More than 100C)"},
|
||||||
{"SAND", PIXPACK(0xFFD090), 0.4f, 0.04f * CFDS, 0.94f, 0.95f, -0.1f, 0.3f, 0.00f, 0.000f * CFDS, 1, 0, 0, 5, 1, 1, 90, SC_POWDERS, R_TEMP+0.0f +273.15f, 150, "Sand, Heavy particles. Meltable."},
|
{"SAND", PIXPACK(0xFFD090), 0.4f, 0.04f * CFDS, 0.94f, 0.95f, -0.1f, 0.3f, 0.00f, 0.000f * CFDS, 1, 0, 0, 5, 1, 1, 90, SC_POWDERS, R_TEMP+0.0f +273.15f, 150, "Sand, Heavy particles. Meltable."},
|
||||||
{"GLAS", PIXPACK(0x404040), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 0, 0, 0, 1, 1, 100, SC_SOLIDS, R_TEMP+0.0f +273.15f, 150, "Solid. Meltable. Shatters under pressure"},
|
{"GLAS", PIXPACK(0x404040), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 0, 0, 0, 1, 1, 100, SC_SOLIDS, R_TEMP+0.0f +273.15f, 150, "Solid. Meltable. Shatters under pressure"},
|
||||||
{"PTCT", PIXPACK(0x405050), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 0, 0, 1, 1, 1, 100, SC_ELEC, R_TEMP+0.0f +273.15f, 251, "Semi-conductor. Only conducts electricity when cold (Less than 120C)"},
|
{"PTCT", PIXPACK(0x405050), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 0, 0, 1, 1, 1, 100, SC_ELEC, R_TEMP+0.0f +273.15f, 251, "Semi-conductor. Only conducts electricity when cold (Less than 120C)"},
|
||||||
{"BGLA", PIXPACK(0x606060), 0.4f, 0.04f * CFDS, 0.94f, 0.95f, -0.1f, 0.3f, 0.00f, 0.000f * CFDS, 1, 0, 0, 5, 2, 1, 90, SC_POWDERS, R_TEMP+0.0f +273.15f, 150, "Broken Glass, Heavy particles. Meltable. Bagels."},
|
{"BGLA", PIXPACK(0x606060), 0.4f, 0.04f * CFDS, 0.94f, 0.95f, -0.1f, 0.3f, 0.00f, 0.000f * CFDS, 1, 0, 0, 5, 2, 1, 90, SC_POWDERS, R_TEMP+0.0f +273.15f, 150, "Broken Glass, Heavy particles. Meltable. Bagels."},
|
||||||
{"THDR", PIXPACK(0xFFFFA0), 0.0f, 0.00f * CFDS, 1.0f, 0.30f, -0.99f, 0.6f, 0.62f, 0.000f * CFDS, 0, 0, 0, 0, 0, 1, 1, SC_ELEC, 9000.0f +273.15f, 251, "Lightning! Very hot, inflicts damage upon most materials, transfers current to metals."},
|
{"THDR", PIXPACK(0xFFFFA0), 0.0f, 0.00f * CFDS, 1.0f, 0.30f, -0.99f, 0.6f, 0.62f, 0.000f * CFDS, 0, 0, 0, 0, 0, 1, 1, SC_ELEC, 9000.0f +273.15f, 251, "Lightning! Very hot, inflicts damage upon most materials, transfers current to metals."},
|
||||||
{"PLSM", PIXPACK(0xBB99FF), 0.9f, 0.04f * CFDS, 0.97f, 0.20f, 0.0f, -0.1f, 0.30f, 0.001f * CFDS, 0, 0, 0, 0, 0, 1, 1, SC_GAS, 9000.0f +273.15f, 115, "Plasma, extremely hot."},
|
{"PLSM", PIXPACK(0xBB99FF), 0.9f, 0.04f * CFDS, 0.97f, 0.20f, 0.0f, -0.1f, 0.30f, 0.001f * CFDS, 0, 0, 0, 0, 0, 1, 1, SC_GAS, 9000.0f +273.15f, 115, "Plasma, extremely hot."},
|
||||||
{"ETRD", PIXPACK(0x404040), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 0, 0, 1, 1, 1, 100, SC_ELEC, R_TEMP+0.0f +273.15f, 251, "Electrode. Creates a surface that allows Plasma arcs. (Use sparingly)"},
|
{"ETRD", PIXPACK(0x404040), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 0, 0, 1, 1, 1, 100, SC_ELEC, R_TEMP+0.0f +273.15f, 251, "Electrode. Creates a surface that allows Plasma arcs. (Use sparingly)"},
|
||||||
{"NICE", PIXPACK(0xC0E0FF), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.00f, -0.0005f* CFDS, 0, 0, 0, 0, 20, 1, 100, SC_SOLIDS, 35.0f, 46, "Nitrogen Ice."},
|
{"NICE", PIXPACK(0xC0E0FF), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.00f, -0.0005f* CFDS, 0, 0, 0, 0, 20, 1, 100, SC_SOLIDS, 35.0f, 46, "Nitrogen Ice."},
|
||||||
{"NBLE", PIXPACK(0xEB4917), 1.0f, 0.01f * CFDS, 0.99f, 0.30f, -0.1f, 0.0f, 0.75f, 0.001f * CFDS, 0, 0, 0, 0, 1, 1, 1, SC_GAS, R_TEMP+2.0f +273.15f, 106, "Noble Gas. Diffuses. Conductive. Ionizes into plasma when intruduced to electricity"},
|
{"NBLE", PIXPACK(0xEB4917), 1.0f, 0.01f * CFDS, 0.99f, 0.30f, -0.1f, 0.0f, 0.75f, 0.001f * CFDS, 0, 0, 0, 0, 1, 1, 1, SC_GAS, R_TEMP+2.0f +273.15f, 106, "Noble Gas. Diffuses. Conductive. Ionizes into plasma when intruduced to electricity"},
|
||||||
{"BTRY", PIXPACK(0x858505), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 0, 0, 1, 1, 1, 100, SC_ELEC, R_TEMP+0.0f +273.15f, 251, "Solid. Generates Electricity."},
|
{"BTRY", PIXPACK(0x858505), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 0, 0, 1, 1, 1, 100, SC_ELEC, R_TEMP+0.0f +273.15f, 251, "Solid. Generates Electricity."},
|
||||||
{"LCRY", PIXPACK(0x505050), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 0, 0, 1, 1, 1, 100, SC_ELEC, R_TEMP+0.0f +273.15f, 251, "Liquid Crystal. Changes colour when charged. (PSCN Charges, NSCN Discharges)"},
|
{"LCRY", PIXPACK(0x505050), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 0, 0, 1, 1, 1, 100, SC_ELEC, R_TEMP+0.0f +273.15f, 251, "Liquid Crystal. Changes colour when charged. (PSCN Charges, NSCN Discharges)"},
|
||||||
{"STKM", PIXPACK(0x000000), 0.5f, 0.00f * CFDS, 0.2f, 1.0f, 0.0f, 0.0f, 0.0f, 0.00f * CFDS, 0, 0, 0, 0, 0, 1, 50, SC_SPECIAL, R_TEMP+14.6f +273.15f, 0, "Stickman. Don't kill him!"},
|
{"STKM", PIXPACK(0x000000), 0.5f, 0.00f * CFDS, 0.2f, 1.0f, 0.0f, 0.0f, 0.0f, 0.00f * CFDS, 0, 0, 0, 0, 0, 1, 50, SC_SPECIAL, R_TEMP+14.6f +273.15f, 0, "Stickman. Don't kill him!"},
|
||||||
{"SWCH", PIXPACK(0x103B11), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 0, 0, 0, 1, 1, 100, SC_ELEC, R_TEMP+0.0f +273.15f, 251, "Solid. Only conducts when switched on. (PSCN switches on, NSCN switches off)"},
|
{"SWCH", PIXPACK(0x103B11), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 0, 0, 0, 1, 1, 100, SC_ELEC, R_TEMP+0.0f +273.15f, 251, "Solid. Only conducts when switched on. (PSCN switches on, NSCN switches off)"},
|
||||||
{"SMKE", PIXPACK(0x222222), 0.9f, 0.04f * CFDS, 0.97f, 0.20f, 0.0f, -0.1f, 0.00f, 0.001f * CFDS, 1, 0, 0, 0, 1, 1, 1, SC_GAS, R_TEMP+320.0f +273.15f, 88, "Smoke"},
|
{"SMKE", PIXPACK(0x222222), 0.9f, 0.04f * CFDS, 0.97f, 0.20f, 0.0f, -0.1f, 0.00f, 0.001f * CFDS, 1, 0, 0, 0, 1, 1, 1, SC_GAS, R_TEMP+320.0f +273.15f, 88, "Smoke"},
|
||||||
{"DESL", PIXPACK(0x440000), 1.0f, 0.01f * CFDS, 0.98f, 0.95f, 0.0f, 0.1f, 0.0f, 0.0f * CFDS, 2, 2, 0, 0, 5, 1, 15, SC_LIQUID, R_TEMP+0.0f +273.15f, 42, "Liquid. Explodes under high pressure and temperatures"},
|
{"DESL", PIXPACK(0x440000), 1.0f, 0.01f * CFDS, 0.98f, 0.95f, 0.0f, 0.1f, 0.0f, 0.0f * CFDS, 2, 2, 0, 0, 5, 1, 15, SC_LIQUID, R_TEMP+0.0f +273.15f, 42, "Liquid. Explodes under high pressure and temperatures"},
|
||||||
{"COAL", PIXPACK(0x222222), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.0f, 0.0f * CFDS, 0, 0, 0, 0, 20, 1, 100, SC_SOLIDS, R_TEMP+0.0f +273.15f, 200, "Solid. Burns slowly."},
|
{"COAL", PIXPACK(0x222222), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.0f, 0.0f * CFDS, 0, 0, 0, 0, 20, 1, 100, SC_SOLIDS, R_TEMP+0.0f +273.15f, 200, "Solid. Burns slowly."},
|
||||||
{"LO2", PIXPACK(0x80A0EF), 0.6f, 0.01f * CFDS, 0.98f, 0.95f, 0.0f, 0.1f, 0.00f, 0.000f * CFDS, 2, 5000, 0, 0, 0, 1, 30, SC_LIQUID, 80.0f, 70, "Liquid Oxygen. Very cold. Reacts with fire"},
|
{"LO2", PIXPACK(0x80A0EF), 0.6f, 0.01f * CFDS, 0.98f, 0.95f, 0.0f, 0.1f, 0.00f, 0.000f * CFDS, 2, 5000, 0, 0, 0, 1, 30, SC_LIQUID, 80.0f, 70, "Liquid Oxygen. Very cold. Reacts with fire"},
|
||||||
{"O2", PIXPACK(0x80A0FF), 2.0f, 0.00f * CFDS, 0.99f, 0.30f, -0.1f, 0.0f, 3.0f, 0.000f * CFDS, 0, 1000, 0, 0, 0, 1, 1, SC_GAS, R_TEMP+0.0f +273.15f, 70, "Gas. Ignites easily."},
|
{"O2", PIXPACK(0x80A0FF), 2.0f, 0.00f * CFDS, 0.99f, 0.30f, -0.1f, 0.0f, 3.0f, 0.000f * CFDS, 0, 1000, 0, 0, 0, 1, 1, SC_GAS, R_TEMP+0.0f +273.15f, 70, "Gas. Ignites easily."},
|
||||||
{"INWR", PIXPACK(0x544141), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 0, 0, 1, 1, 1, 100, SC_ELEC, R_TEMP+0.0f +273.15f, 251, "Insulated Wire. Doesn't conduct to metal or semiconductors."},
|
{"INWR", PIXPACK(0x544141), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 0, 0, 1, 1, 1, 100, SC_ELEC, R_TEMP+0.0f +273.15f, 251, "Insulated Wire. Doesn't conduct to metal or semiconductors."},
|
||||||
{"YEST", PIXPACK(0xEEE0C0), 0.7f, 0.02f * CFDS, 0.96f, 0.80f, 0.0f, 0.1f, 0.00f, 0.000f * CFDS, 1, 15, 0, 0, 30, 1, 80, SC_POWDERS, R_TEMP+0.0f +273.15f, 70, "Yeast, grows when warm (~37C)."},
|
{"YEST", PIXPACK(0xEEE0C0), 0.7f, 0.02f * CFDS, 0.96f, 0.80f, 0.0f, 0.1f, 0.00f, 0.000f * CFDS, 1, 15, 0, 0, 30, 1, 80, SC_POWDERS, R_TEMP+0.0f +273.15f, 70, "Yeast, grows when warm (~37C)."},
|
||||||
{"DYST", PIXPACK(0xBBB0A0), 0.7f, 0.02f * CFDS, 0.96f, 0.80f, 0.0f, 0.1f, 0.00f, 0.000f * CFDS, 1, 20, 0, 0, 30, 0, 80, SC_POWDERS, R_TEMP+0.0f +273.15f, 70, "Deat Yeast."},
|
{"DYST", PIXPACK(0xBBB0A0), 0.7f, 0.02f * CFDS, 0.96f, 0.80f, 0.0f, 0.1f, 0.00f, 0.000f * CFDS, 1, 20, 0, 0, 30, 0, 80, SC_POWDERS, R_TEMP+0.0f +273.15f, 70, "Deat Yeast."},
|
||||||
{"THRM", PIXPACK(0xA08090), 0.4f, 0.04f * CFDS, 0.94f, 0.95f, -0.1f, 0.3f, 0.00f, 0.000f * CFDS, 1, 0, 0, 2, 2, 1, 90, SC_EXPLOSIVE, R_TEMP+0.0f +273.15f, 211, "Thermite. Burns at extremly high temperature."},
|
{"THRM", PIXPACK(0xA08090), 0.4f, 0.04f * CFDS, 0.94f, 0.95f, -0.1f, 0.3f, 0.00f, 0.000f * CFDS, 1, 0, 0, 2, 2, 1, 90, SC_EXPLOSIVE, R_TEMP+0.0f +273.15f, 211, "Thermite. Burns at extremly high temperature."},
|
||||||
{"GLOW", PIXPACK(0x445544), 0.3f, 0.02f * CFDS, 0.95f, 0.80f, 0.0f, 0.15f, 0.00f, 0.000f * CFDS, 2, 0, 0, 0, 2, 1, 40, SC_LIQUID, R_TEMP+20.0f +273.15f, 44, "Glow, Glows under pressure"},
|
{"GLOW", PIXPACK(0x445544), 0.3f, 0.02f * CFDS, 0.95f, 0.80f, 0.0f, 0.15f, 0.00f, 0.000f * CFDS, 2, 0, 0, 0, 2, 1, 40, SC_LIQUID, R_TEMP+20.0f +273.15f, 44, "Glow, Glows under pressure"},
|
||||||
{"BRCK", PIXPACK(0x808080), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 0, 0, 0, 1, 1, 100, SC_SOLIDS, R_TEMP+0.0f +273.15f, 251, "Brick, breakable building material."},
|
{"BRCK", PIXPACK(0x808080), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 0, 0, 0, 1, 1, 100, SC_SOLIDS, R_TEMP+0.0f +273.15f, 251, "Brick, breakable building material."},
|
||||||
{"CFLM", PIXPACK(0x8080FF), 0.9f, 0.04f * CFDS, 0.97f, 0.20f, 0.0f, -0.1f, 0.00f, 0.0005f * CFDS, 1, 0, 0, 0, 1, 1, 2, SC_SPECIAL, 0.0f, 88, "Sub-zero flame."},
|
{"CFLM", PIXPACK(0x8080FF), 0.9f, 0.04f * CFDS, 0.97f, 0.20f, 0.0f, -0.1f, 0.00f, 0.0005f * CFDS, 1, 0, 0, 0, 1, 1, 2, SC_SPECIAL, 0.0f, 88, "Sub-zero flame."},
|
||||||
{"FIRW", PIXPACK(0xFFA040), 0.7f, 0.02f * CFDS, 0.96f, 0.80f, -0.99f, 0.1f, 0.00f, 0.000f * CFDS, 1, 0, 0, 0, 30, 1, 55, SC_EXPLOSIVE, R_TEMP+0.0f +273.15f, 70, "Fireworks!"},
|
{"FIRW", PIXPACK(0xFFA040), 0.7f, 0.02f * CFDS, 0.96f, 0.80f, -0.99f, 0.1f, 0.00f, 0.000f * CFDS, 1, 0, 0, 0, 30, 1, 55, SC_EXPLOSIVE, R_TEMP+0.0f +273.15f, 70, "Fireworks!"},
|
||||||
{"FUSE", PIXPACK(0x0A5706), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.0f, 0.0f * CFDS, 0, 0, 0, 0, 20, 1, 100, SC_SOLIDS, R_TEMP+0.0f +273.15f, 200, "Solid. Burns slowly. Ignites at somewhat high temperatures and electricity."},
|
{"FUSE", PIXPACK(0x0A5706), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.0f, 0.0f * CFDS, 0, 0, 0, 0, 20, 1, 100, SC_SOLIDS, R_TEMP+0.0f +273.15f, 200, "Solid. Burns slowly. Ignites at somewhat high temperatures and electricity."},
|
||||||
{"FSEP", PIXPACK(0x63AD5F), 0.7f, 0.02f * CFDS, 0.96f, 0.80f, 0.0f, 0.1f, 0.00f, 0.000f * CFDS, 1, 0, 0, 0, 30, 1, 70, SC_POWDERS, R_TEMP+0.0f +273.15f, 70, "Fuse Powder. See FUSE."},
|
{"FSEP", PIXPACK(0x63AD5F), 0.7f, 0.02f * CFDS, 0.96f, 0.80f, 0.0f, 0.1f, 0.00f, 0.000f * CFDS, 1, 0, 0, 0, 30, 1, 70, SC_POWDERS, R_TEMP+0.0f +273.15f, 70, "Fuse Powder. See FUSE."},
|
||||||
{"AMTR", PIXPACK(0x808080), 0.7f, 0.02f * CFDS, 0.96f, 0.80f, 0.00f, 0.10f, 1.00f, 0.0000f * CFDS, 0, 0, 0, 0, 0, 1, 100, SC_NUCLEAR, R_TEMP+0.0f +273.15f, 70, "Anti-Matter, Destroys a majority of particles"},
|
{"AMTR", PIXPACK(0x808080), 0.7f, 0.02f * CFDS, 0.96f, 0.80f, 0.00f, 0.10f, 1.00f, 0.0000f * CFDS, 0, 0, 0, 0, 0, 1, 100, SC_NUCLEAR, R_TEMP+0.0f +273.15f, 70, "Anti-Matter, Destroys a majority of particles"},
|
||||||
{"BCOL", PIXPACK(0x333333), 0.4f, 0.04f * CFDS, 0.94f, 0.95f, -0.1f, 0.3f, 0.00f, 0.000f * CFDS, 1, 0, 0, 5, 2, 1, 90, SC_POWDERS, R_TEMP+0.0f +273.15f, 150, "Broken Coal. Heavy particles. See COAL"},
|
{"BCOL", PIXPACK(0x333333), 0.4f, 0.04f * CFDS, 0.94f, 0.95f, -0.1f, 0.3f, 0.00f, 0.000f * CFDS, 1, 0, 0, 5, 2, 1, 90, SC_POWDERS, R_TEMP+0.0f +273.15f, 150, "Broken Coal. Heavy particles. See COAL"},
|
||||||
{"PCLN", PIXPACK(0x3B3B10), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 0, 0, 0, 1, 1, 100, SC_ELEC, R_TEMP+0.0f +273.15f, 251, "Solid. When actived, duplicates any particles it touches."},
|
{"PCLN", PIXPACK(0x3B3B10), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 0, 0, 0, 1, 1, 100, SC_ELEC, R_TEMP+0.0f +273.15f, 251, "Solid. When actived, duplicates any particles it touches."},
|
||||||
{"HSWC", PIXPACK(0x3B1010), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 0, 0, 1, 1, 1, 100, SC_ELEC, R_TEMP+0.0f +273.15f, 251, "Heat switch. Conducts Heat only when activated"},
|
{"HSWC", PIXPACK(0x3B1010), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 0, 0, 1, 1, 1, 100, SC_ELEC, R_TEMP+0.0f +273.15f, 251, "Heat switch. Conducts Heat only when activated"},
|
||||||
{"IRON", PIXPACK(0x707070), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 0, 0, 1, 50, 0, 100, SC_SOLIDS, R_TEMP+0.0f +273.15f, 251, "Rusts with salt, can be used for electrlosis of WATR"},
|
{"IRON", PIXPACK(0x707070), 0.0f, 0.00f * CFDS, 0.90f, 0.00f, 0.0f, 0.0f, 0.00f, 0.000f * CFDS, 0, 0, 0, 1, 50, 0, 100, SC_SOLIDS, R_TEMP+0.0f +273.15f, 251, "Rusts with salt, can be used for electrlosis of WATR"},
|
||||||
{"MORT", PIXPACK(0xE0E0E0), 0.0f, 0.00f * CFDS, 1.00f, 1.00f, -0.99f, 0.0f, 0.01f, 0.002f * CFDS, 0, 0, 0, 0, 0, 1, -1, SC_NUCLEAR, R_TEMP+4.0f +273.15f, 60, "Steam Train."},
|
{"MORT", PIXPACK(0xE0E0E0), 0.0f, 0.00f * CFDS, 1.00f, 1.00f, -0.99f, 0.0f, 0.01f, 0.002f * CFDS, 0, 0, 0, 0, 0, 1, -1, SC_NUCLEAR, R_TEMP+4.0f +273.15f, 60, "Steam Train."},
|
||||||
//Name Colour Advec Airdrag Airloss Loss Collid Grav Diffus Hotair Fal Burn Exp Mel Hrd M Weights Section H Ins(real world, by triclops200) Description
|
//Name Colour Advec Airdrag Airloss Loss Collid Grav Diffus Hotair Fal Burn Exp Mel Hrd M Weights Section H Ins(real world, by triclops200) Description
|
||||||
};
|
};
|
||||||
|
|
||||||
static part_state pstates[PT_NUM] =
|
static part_state pstates[PT_NUM] =
|
||||||
{
|
{
|
||||||
// Name Solid Frzp Liquid Mpnt Gas Bpoint
|
// Name Solid Frzp Liquid Mpnt Gas Bpoint
|
||||||
/* NONE */ {ST_NONE, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* NONE */ {ST_NONE, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* DUST */ {ST_SOLID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* DUST */ {ST_SOLID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* WATR */ {ST_LIQUID, PT_ICEI, 273.15f, PT_NONE, 0.0f, PT_WTRV, 373.0f, PT_NONE, 0.0f},
|
/* WATR */ {ST_LIQUID, PT_ICEI, 273.15f, PT_NONE, 0.0f, PT_WTRV, 373.0f, PT_NONE, 0.0f},
|
||||||
/* OIL */ {ST_LIQUID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_GAS, 333.0f, PT_NONE, 0.0f},
|
/* OIL */ {ST_LIQUID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_GAS, 333.0f, PT_NONE, 0.0f},
|
||||||
/* FIRE */ {ST_GAS, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_PLSM, 2773.0f},
|
/* FIRE */ {ST_GAS, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_PLSM, 2773.0f},
|
||||||
/* STNE */ {ST_SOLID, PT_NONE, 0.0f, PT_LAVA, 983.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* STNE */ {ST_SOLID, PT_NONE, 0.0f, PT_LAVA, 983.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* LAVA */ {ST_LIQUID, PT_STNE, 973.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* LAVA */ {ST_LIQUID, PT_STNE, 973.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* GUN */ {ST_SOLID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_FIRE, 673.0f},
|
/* GUN */ {ST_SOLID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_FIRE, 673.0f},
|
||||||
/* NITR */ {ST_LIQUID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_FIRE, 673.0f},
|
/* NITR */ {ST_LIQUID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_FIRE, 673.0f},
|
||||||
/* CLNE */ {ST_SOLID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* CLNE */ {ST_SOLID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* GAS */ {ST_GAS, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 50.0f, PT_FIRE, 573.0f},
|
/* GAS */ {ST_GAS, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 50.0f, PT_FIRE, 573.0f},
|
||||||
/* C-4 */ {ST_SOLID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_FIRE, 673.0f},
|
/* C-4 */ {ST_SOLID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_FIRE, 673.0f},
|
||||||
/* GOO */ {ST_SOLID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* GOO */ {ST_SOLID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* ICE */ {ST_SOLID, PT_NONE, 0.0f, PT_WATR, 274.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* ICE */ {ST_SOLID, PT_NONE, 0.0f, PT_WATR, 274.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* METL */ {ST_SOLID, PT_NONE, 0.0f, PT_LAVA, 1273.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* METL */ {ST_SOLID, PT_NONE, 0.0f, PT_LAVA, 1273.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* SPRK */ {ST_SOLID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* SPRK */ {ST_SOLID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* SNOW */ {ST_SOLID, PT_NONE, 0.0f, PT_WATR, 273.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* SNOW */ {ST_SOLID, PT_NONE, 0.0f, PT_WATR, 273.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* WOOD */ {ST_SOLID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_FIRE, 873.0f},
|
/* WOOD */ {ST_SOLID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_FIRE, 873.0f},
|
||||||
/* NEUT */ {ST_GAS, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* NEUT */ {ST_GAS, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* PLUT */ {ST_SOLID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* PLUT */ {ST_SOLID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* PLNT */ {ST_SOLID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_FIRE, 573.0f},
|
/* PLNT */ {ST_SOLID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_FIRE, 573.0f},
|
||||||
/* ACID */ {ST_LIQUID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* ACID */ {ST_LIQUID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* VOID */ {ST_SOLID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* VOID */ {ST_SOLID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* WTRV */ {ST_GAS, PT_ICEI, 273.0f, PT_DSTW, 371.0f, PT_NONE, 373.0f, PT_NONE, 0.0f},
|
/* WTRV */ {ST_GAS, PT_ICEI, 273.0f, PT_DSTW, 371.0f, PT_NONE, 373.0f, PT_NONE, 0.0f},
|
||||||
/* CNCT */ {ST_SOLID, PT_NONE, 0.0f, PT_LAVA, 1123.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* CNCT */ {ST_SOLID, PT_NONE, 0.0f, PT_LAVA, 1123.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* DSTW */ {ST_LIQUID, PT_ICEI, 273.15f, PT_NONE, 0.0f, PT_WTRV, 373.0f, PT_NONE, 0.0f},
|
/* DSTW */ {ST_LIQUID, PT_ICEI, 273.15f, PT_NONE, 0.0f, PT_WTRV, 373.0f, PT_NONE, 0.0f},
|
||||||
/* SALT */ {ST_SOLID, PT_NONE, 0.0f, PT_LAVA, 1173.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* SALT */ {ST_SOLID, PT_NONE, 0.0f, PT_LAVA, 1173.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* SLTW */ {ST_LIQUID, PT_ICEI, 233.0f, PT_NONE, 0.0f, PT_WTRV, 483.0f, PT_NONE, 0.0f},
|
/* SLTW */ {ST_LIQUID, PT_ICEI, 233.0f, PT_NONE, 0.0f, PT_WTRV, 483.0f, PT_NONE, 0.0f},
|
||||||
/* DMND */ {ST_SOLID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* DMND */ {ST_SOLID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* BMTL */ {ST_SOLID, PT_NONE, 0.0f, PT_LAVA, 1273.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* BMTL */ {ST_SOLID, PT_NONE, 0.0f, PT_LAVA, 1273.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* BRMT */ {ST_SOLID, PT_NONE, 0.0f, PT_LAVA, 1273.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* BRMT */ {ST_SOLID, PT_NONE, 0.0f, PT_LAVA, 1273.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* PHOT */ {ST_GAS, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* PHOT */ {ST_GAS, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* URAN */ {ST_SOLID, PT_NONE, 0.0f, PT_NONE, 2373.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* URAN */ {ST_SOLID, PT_NONE, 0.0f, PT_NONE, 2373.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* WAX */ {ST_SOLID, PT_NONE, 0.0f, PT_MWAX, 319.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* WAX */ {ST_SOLID, PT_NONE, 0.0f, PT_MWAX, 319.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* MWAX */ {ST_LIQUID, PT_WAX, 318.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_FIRE, 673.0f},
|
/* MWAX */ {ST_LIQUID, PT_WAX, 318.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_FIRE, 673.0f},
|
||||||
/* PSCN */ {ST_SOLID, PT_NONE, 0.0f, PT_LAVA, 1687.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* PSCN */ {ST_SOLID, PT_NONE, 0.0f, PT_LAVA, 1687.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* NSCN */ {ST_SOLID, PT_NONE, 0.0f, PT_LAVA, 1687.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* NSCN */ {ST_SOLID, PT_NONE, 0.0f, PT_LAVA, 1687.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* LNTG */ {ST_SOLID, PT_NICE, 63.0f, PT_NONE, 0.0f, PT_NONE, 77.0f, PT_NONE, 0.0f},
|
/* LNTG */ {ST_SOLID, PT_NICE, 63.0f, PT_NONE, 0.0f, PT_NONE, 77.0f, PT_NONE, 0.0f},
|
||||||
/* FOAM */ {ST_SOLID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* FOAM */ {ST_SOLID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* BHOL */ {ST_NONE, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* BHOL */ {ST_NONE, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* WHOL */ {ST_NONE, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* WHOL */ {ST_NONE, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* RBDM */ {ST_SOLID, PT_NONE, 0.0f, PT_LRBD, 312.0f, PT_NONE, 0.0f, PT_FIRE, 961.0f},
|
/* RBDM */ {ST_SOLID, PT_NONE, 0.0f, PT_LRBD, 312.0f, PT_NONE, 0.0f, PT_FIRE, 961.0f},
|
||||||
/* LRBD */ {ST_LIQUID, PT_RBDM, 311.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_FIRE, 961.0f},
|
/* LRBD */ {ST_LIQUID, PT_RBDM, 311.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_FIRE, 961.0f},
|
||||||
/* HSCN */ {ST_SOLID, PT_NONE, 0.0f, PT_LAVA, 1687.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* HSCN */ {ST_SOLID, PT_NONE, 0.0f, PT_LAVA, 1687.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* SAND */ {ST_SOLID, PT_NONE, 0.0f, PT_LAVA, 1973.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* SAND */ {ST_SOLID, PT_NONE, 0.0f, PT_LAVA, 1973.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* GLAS */ {ST_SOLID, PT_NONE, 0.0f, PT_LAVA, 1973.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* GLAS */ {ST_SOLID, PT_NONE, 0.0f, PT_LAVA, 1973.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* CSCN */ {ST_SOLID, PT_NONE, 0.0f, PT_LAVA, 1414.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* CSCN */ {ST_SOLID, PT_NONE, 0.0f, PT_LAVA, 1414.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* BGLA */ {ST_SOLID, PT_NONE, 0.0f, PT_LAVA, 1973.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* BGLA */ {ST_SOLID, PT_NONE, 0.0f, PT_LAVA, 1973.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* THDR */ {ST_NONE, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* THDR */ {ST_NONE, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* PLSM */ {ST_NONE, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* PLSM */ {ST_NONE, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* ETRD */ {ST_NONE, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* ETRD */ {ST_NONE, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* NICE */ {ST_SOLID, PT_NONE, 0.0f, PT_LNTG, 63.1f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* NICE */ {ST_SOLID, PT_NONE, 0.0f, PT_LNTG, 63.1f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* NBLE */ {ST_GAS, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* NBLE */ {ST_GAS, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* BTRY */ {ST_SOLID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_PLSM, 2273.0f},
|
/* BTRY */ {ST_SOLID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_PLSM, 2273.0f},
|
||||||
/* LCRY */ {ST_SOLID, PT_NONE, 0.0f, PT_BGLA, 1273.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* LCRY */ {ST_SOLID, PT_NONE, 0.0f, PT_BGLA, 1273.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* STKM */ {ST_NONE, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_FIRE, 620.0f},
|
/* STKM */ {ST_NONE, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_FIRE, 620.0f},
|
||||||
/* SWCH */ {ST_SOLID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* SWCH */ {ST_SOLID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* SMKE */ {ST_SOLID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_FIRE, 625.0f},
|
/* SMKE */ {ST_SOLID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_FIRE, 625.0f},
|
||||||
/* DESL */ {ST_LIQUID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_FIRE, 335.0f},
|
/* DESL */ {ST_LIQUID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_FIRE, 335.0f},
|
||||||
/* COAL */ {ST_SOLID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* COAL */ {ST_SOLID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* LO2 */ {ST_LIQUID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_O2, 90.1f, PT_NONE, 0.0f},
|
/* LO2 */ {ST_LIQUID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_O2, 90.1f, PT_NONE, 0.0f},
|
||||||
/* O2 */ {ST_GAS, PT_NONE, 0.0f, PT_LO2, 90.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* O2 */ {ST_GAS, PT_NONE, 0.0f, PT_LO2, 90.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* INWR */ {ST_SOLID, PT_NONE, 0.0f, PT_LAVA, 1687.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* INWR */ {ST_SOLID, PT_NONE, 0.0f, PT_LAVA, 1687.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* YEST */ {ST_SOLID, PT_NONE, 0.0f, PT_DYST, 373.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* YEST */ {ST_SOLID, PT_NONE, 0.0f, PT_DYST, 373.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* DYST */ {ST_SOLID, PT_NONE, 0.0f, PT_DUST, 473.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* DYST */ {ST_SOLID, PT_NONE, 0.0f, PT_DUST, 473.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* THRM */ {ST_SOLID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* THRM */ {ST_SOLID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* GLOW */ {ST_LIQUID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* GLOW */ {ST_LIQUID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* BRCK */ {ST_SOLID, PT_NONE, 0.0f, PT_LAVA, 1223.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* BRCK */ {ST_SOLID, PT_NONE, 0.0f, PT_LAVA, 1223.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* HFLM */ {ST_GAS, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* HFLM */ {ST_GAS, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* FIRW */ {ST_SOLID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* FIRW */ {ST_SOLID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* FUSE */ {ST_SOLID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* FUSE */ {ST_SOLID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* FSEP */ {ST_SOLID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* FSEP */ {ST_SOLID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* AMtr */ {ST_NONE, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* AMtr */ {ST_NONE, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* BCOL */ {ST_SOLID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* BCOL */ {ST_SOLID, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* PCLN */ {ST_NONE, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* PCLN */ {ST_NONE, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* HSWC */ {ST_NONE, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* HSWC */ {ST_NONE, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
/* IRON */ {ST_SOLID, PT_NONE, 0.0f, PT_LAVA, 1687.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
/* IRON */ {ST_SOLID, PT_NONE, 0.0f, PT_LAVA, 1687.0f, PT_NONE, 0.0f, PT_NONE, 0.0f},
|
||||||
};
|
};
|
||||||
|
|
||||||
extern int isplayer;
|
extern int isplayer;
|
||||||
|
180
src/graphics.c
180
src/graphics.c
@ -849,15 +849,15 @@ int drawtextwrap(pixel *vid, int x, int y, int w, const char *s, int r, int g, i
|
|||||||
#ifdef OpenGL
|
#ifdef OpenGL
|
||||||
#else
|
#else
|
||||||
int sx = x;
|
int sx = x;
|
||||||
int rh = 12;
|
int rh = 12;
|
||||||
int rw = 0;
|
int rw = 0;
|
||||||
int cw = x;
|
int cw = x;
|
||||||
for(; *s; s++)
|
for(; *s; s++)
|
||||||
{
|
{
|
||||||
if(*s == '\n')
|
if(*s == '\n')
|
||||||
{
|
{
|
||||||
x = sx;
|
x = sx;
|
||||||
rw = 0;
|
rw = 0;
|
||||||
y += FONT_H+2;
|
y += FONT_H+2;
|
||||||
}
|
}
|
||||||
else if(*s == '\b')
|
else if(*s == '\b')
|
||||||
@ -887,15 +887,15 @@ int drawtextwrap(pixel *vid, int x, int y, int w, const char *s, int r, int g, i
|
|||||||
s++;
|
s++;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if(x-cw>=w){
|
if(x-cw>=w) {
|
||||||
x = sx;
|
x = sx;
|
||||||
rw = 0;
|
rw = 0;
|
||||||
y+=FONT_H+2;
|
y+=FONT_H+2;
|
||||||
rh+=FONT_H+2;
|
rh+=FONT_H+2;
|
||||||
}
|
}
|
||||||
x = drawchar(vid, x, y, *(unsigned char *)s, r, g, b, a);
|
x = drawchar(vid, x, y, *(unsigned char *)s, r, g, b, a);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
return rh;
|
return rh;
|
||||||
@ -1476,20 +1476,20 @@ void draw_parts(pixel *vid)
|
|||||||
cg = 0;
|
cg = 0;
|
||||||
cb = 0;
|
cb = 0;
|
||||||
cr = 0;
|
cr = 0;
|
||||||
for(x=0; x<12; x++) {
|
for(x=0; x<12; x++) {
|
||||||
cr += (parts[i].ctype >> (x+18)) & 1;
|
cr += (parts[i].ctype >> (x+18)) & 1;
|
||||||
cb += (parts[i].ctype >> x) & 1;
|
cb += (parts[i].ctype >> x) & 1;
|
||||||
}
|
}
|
||||||
for(x=0; x<14; x++)
|
for(x=0; x<14; x++)
|
||||||
cg += (parts[i].ctype >> (x+9)) & 1;
|
cg += (parts[i].ctype >> (x+9)) & 1;
|
||||||
x = 624/(cr+cg+cb+1);
|
x = 624/(cr+cg+cb+1);
|
||||||
cr *= x;
|
cr *= x;
|
||||||
cg *= x;
|
cg *= x;
|
||||||
cb *= x;
|
cb *= x;
|
||||||
vid[ny*(XRES+BARSIZE)+nx] = PIXRGB(cr>255?255:cr,cg>255?255:cg,cb>255?255:cb);
|
vid[ny*(XRES+BARSIZE)+nx] = PIXRGB(cr>255?255:cr,cg>255?255:cg,cb>255?255:cb);
|
||||||
cr >>= 4;
|
cr >>= 4;
|
||||||
cg >>= 4;
|
cg >>= 4;
|
||||||
cb >>= 4;
|
cb >>= 4;
|
||||||
x = nx/CELL;
|
x = nx/CELL;
|
||||||
y = ny/CELL;
|
y = ny/CELL;
|
||||||
cg += fire_g[y][x];
|
cg += fire_g[y][x];
|
||||||
@ -1504,22 +1504,22 @@ void draw_parts(pixel *vid)
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
cg = 0;
|
cg = 0;
|
||||||
cb = 0;
|
cb = 0;
|
||||||
cr = 0;
|
cr = 0;
|
||||||
for(x=0; x<12; x++) {
|
for(x=0; x<12; x++) {
|
||||||
cr += (parts[i].ctype >> (x+18)) & 1;
|
cr += (parts[i].ctype >> (x+18)) & 1;
|
||||||
cb += (parts[i].ctype >> x) & 1;
|
cb += (parts[i].ctype >> x) & 1;
|
||||||
}
|
}
|
||||||
for(x=0; x<14; x++)
|
for(x=0; x<14; x++)
|
||||||
cg += (parts[i].ctype >> (x+9)) & 1;
|
cg += (parts[i].ctype >> (x+9)) & 1;
|
||||||
x = 624/(cr+cg+cb+1);
|
x = 624/(cr+cg+cb+1);
|
||||||
cr *= x;
|
cr *= x;
|
||||||
cg *= x;
|
cg *= x;
|
||||||
cb *= x;
|
cb *= x;
|
||||||
cr = cr>255?255:cr;
|
cr = cr>255?255:cr;
|
||||||
cg = cg>255?255:cg;
|
cg = cg>255?255:cg;
|
||||||
cb = cb>255?255:cb;
|
cb = cb>255?255:cb;
|
||||||
blendpixel(vid, nx, ny, cr, cg, cb, 192);
|
blendpixel(vid, nx, ny, cr, cg, cb, 192);
|
||||||
blendpixel(vid, nx+1, ny, cr, cg, cb, 96);
|
blendpixel(vid, nx+1, ny, cr, cg, cb, 96);
|
||||||
blendpixel(vid, nx-1, ny, cr, cg, cb, 96);
|
blendpixel(vid, nx-1, ny, cr, cg, cb, 96);
|
||||||
@ -1952,30 +1952,30 @@ void draw_parts(pixel *vid)
|
|||||||
}
|
}
|
||||||
else if(t==PT_FIRE && parts[i].life)
|
else if(t==PT_FIRE && parts[i].life)
|
||||||
{
|
{
|
||||||
float ttemp = (float)((int)(parts[i].life/2));
|
float ttemp = (float)((int)(parts[i].life/2));
|
||||||
int caddress = restrict_flt(restrict_flt(ttemp, 0.0f, 200.0f)*3, 0.0f, (200.0f*3)-3);
|
int caddress = restrict_flt(restrict_flt(ttemp, 0.0f, 200.0f)*3, 0.0f, (200.0f*3)-3);
|
||||||
uint8 R = flm_data[caddress];
|
uint8 R = flm_data[caddress];
|
||||||
uint8 G = flm_data[caddress+1];
|
uint8 G = flm_data[caddress+1];
|
||||||
uint8 B = flm_data[caddress+2];
|
uint8 B = flm_data[caddress+2];
|
||||||
if(cmode == 3||cmode==4 || cmode==6)
|
if(cmode == 3||cmode==4 || cmode==6)
|
||||||
{
|
{
|
||||||
cr = R/8;
|
cr = R/8;
|
||||||
cg = G/8;
|
cg = G/8;
|
||||||
cb = B/8;
|
cb = B/8;
|
||||||
x = nx/CELL;
|
x = nx/CELL;
|
||||||
y = ny/CELL;
|
y = ny/CELL;
|
||||||
cg += fire_g[y][x];
|
cg += fire_g[y][x];
|
||||||
if(cg > 255) cg = 255;
|
if(cg > 255) cg = 255;
|
||||||
fire_g[y][x] = cg;
|
fire_g[y][x] = cg;
|
||||||
cb += fire_b[y][x];
|
cb += fire_b[y][x];
|
||||||
if(cb > 255) cb = 255;
|
if(cb > 255) cb = 255;
|
||||||
fire_b[y][x] = cb;
|
fire_b[y][x] = cb;
|
||||||
cr += fire_r[y][x];
|
cr += fire_r[y][x];
|
||||||
if(cr > 255) cr = 255;
|
if(cr > 255) cr = 255;
|
||||||
fire_r[y][x] = cr;
|
fire_r[y][x] = cr;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
cr = parts[i].life * 8;
|
cr = parts[i].life * 8;
|
||||||
cg = parts[i].life * 2;
|
cg = parts[i].life * 2;
|
||||||
cb = parts[i].life;
|
cb = parts[i].life;
|
||||||
@ -1991,9 +1991,9 @@ void draw_parts(pixel *vid)
|
|||||||
blendpixel(vid, nx-1, ny+1, cr, cg, cb, 32);
|
blendpixel(vid, nx-1, ny+1, cr, cg, cb, 32);
|
||||||
blendpixel(vid, nx+1, ny+1, cr, cg, cb, 32);
|
blendpixel(vid, nx+1, ny+1, cr, cg, cb, 32);
|
||||||
blendpixel(vid, nx-1, ny-1, cr, cg, cb, 32);
|
blendpixel(vid, nx-1, ny-1, cr, cg, cb, 32);
|
||||||
}
|
}
|
||||||
// Older Code
|
// Older Code
|
||||||
/*if(cmode == 3||cmode==4 || cmode==6)
|
/*if(cmode == 3||cmode==4 || cmode==6)
|
||||||
{
|
{
|
||||||
cr = parts[i].life / 4;
|
cr = parts[i].life / 4;
|
||||||
cg = parts[i].life / 16;
|
cg = parts[i].life / 16;
|
||||||
@ -2137,28 +2137,28 @@ void draw_parts(pixel *vid)
|
|||||||
}
|
}
|
||||||
if(cmode == 4&&t!=PT_FIRE&&t!=PT_PLSM&&t!=PT_HFLM&&t!=PT_NONE&&t!=PT_ACID&&t!=PT_LCRY&&t!=PT_GLOW&&t!=PT_SWCH&&t!=PT_SMKE&&t!=PT_WTRV&&!(t==PT_FIRW&&parts[i].tmp==3))
|
if(cmode == 4&&t!=PT_FIRE&&t!=PT_PLSM&&t!=PT_HFLM&&t!=PT_NONE&&t!=PT_ACID&&t!=PT_LCRY&&t!=PT_GLOW&&t!=PT_SWCH&&t!=PT_SMKE&&t!=PT_WTRV&&!(t==PT_FIRW&&parts[i].tmp==3))
|
||||||
{
|
{
|
||||||
if(t==PT_PHOT){
|
if(t==PT_PHOT) {
|
||||||
cg = 0;
|
cg = 0;
|
||||||
cb = 0;
|
cb = 0;
|
||||||
cr = 0;
|
cr = 0;
|
||||||
for(x=0; x<12; x++) {
|
for(x=0; x<12; x++) {
|
||||||
cr += (parts[i].ctype >> (x+18)) & 1;
|
cr += (parts[i].ctype >> (x+18)) & 1;
|
||||||
cb += (parts[i].ctype >> x) & 1;
|
cb += (parts[i].ctype >> x) & 1;
|
||||||
}
|
}
|
||||||
for(x=0; x<14; x++)
|
for(x=0; x<14; x++)
|
||||||
cg += (parts[i].ctype >> (x+9)) & 1;
|
cg += (parts[i].ctype >> (x+9)) & 1;
|
||||||
x = 624/(cr+cg+cb+1);
|
x = 624/(cr+cg+cb+1);
|
||||||
cr *= x;
|
cr *= x;
|
||||||
cg *= x;
|
cg *= x;
|
||||||
cb *= x;
|
cb *= x;
|
||||||
cr = cr>255?255:cr;
|
cr = cr>255?255:cr;
|
||||||
cg = cg>255?255:cg;
|
cg = cg>255?255:cg;
|
||||||
cb = cb>255?255:cb;
|
cb = cb>255?255:cb;
|
||||||
} else {
|
} else {
|
||||||
cr = PIXR(ptypes[t].pcolors);
|
cr = PIXR(ptypes[t].pcolors);
|
||||||
cg = PIXG(ptypes[t].pcolors);
|
cg = PIXG(ptypes[t].pcolors);
|
||||||
cb = PIXB(ptypes[t].pcolors);
|
cb = PIXB(ptypes[t].pcolors);
|
||||||
}
|
}
|
||||||
|
|
||||||
//if(vid[(ny-1)*YRES+(nx-1)]!=0){
|
//if(vid[(ny-1)*YRES+(nx-1)]!=0){
|
||||||
// blendpixel(vid, nx, ny-1, R, G, B, 46);
|
// blendpixel(vid, nx, ny-1, R, G, B, 46);
|
||||||
|
454
src/interface.c
454
src/interface.c
@ -1871,8 +1871,8 @@ int search_ui(pixel *vid_buf)
|
|||||||
drawtext(vid_buf, XRES-61+16, 11, "\x93", 255, 255, 255, 255);
|
drawtext(vid_buf, XRES-61+16, 11, "\x93", 255, 255, 255, 255);
|
||||||
drawtext(vid_buf, XRES-46+16, 13, "My Own", 255, 255, 255, 255);
|
drawtext(vid_buf, XRES-46+16, 13, "My Own", 255, 255, 255, 255);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(search_fav)
|
if(search_fav)
|
||||||
{
|
{
|
||||||
fillrect(vid_buf, XRES-134, 7, 18, 18, 255, 255, 255, 255);
|
fillrect(vid_buf, XRES-134, 7, 18, 18, 255, 255, 255, 255);
|
||||||
drawtext(vid_buf, XRES-130, 11, "\xCC", 192, 160, 64, 255);
|
drawtext(vid_buf, XRES-130, 11, "\xCC", 192, 160, 64, 255);
|
||||||
@ -2155,7 +2155,7 @@ int search_ui(pixel *vid_buf)
|
|||||||
search_date = !search_date;
|
search_date = !search_date;
|
||||||
lasttime = TIMEOUT;
|
lasttime = TIMEOUT;
|
||||||
}
|
}
|
||||||
if(b && !bq && mx>=XRES-134 && mx<=XRES-134+16 && my>=8 && my<=24)
|
if(b && !bq && mx>=XRES-134 && mx<=XRES-134+16 && my>=8 && my<=24)
|
||||||
{
|
{
|
||||||
search_fav = !search_fav;
|
search_fav = !search_fav;
|
||||||
lasttime = TIMEOUT;
|
lasttime = TIMEOUT;
|
||||||
@ -2197,10 +2197,10 @@ int search_ui(pixel *vid_buf)
|
|||||||
|
|
||||||
if((b && !bq && mp!=-1 && !st && !uih) || do_open==1)
|
if((b && !bq && mp!=-1 && !st && !uih) || do_open==1)
|
||||||
{
|
{
|
||||||
if(open_ui(vid_buf, search_ids[mp], search_dates[mp]?search_dates[mp]:NULL)==1){
|
if(open_ui(vid_buf, search_ids[mp], search_dates[mp]?search_dates[mp]:NULL)==1) {
|
||||||
goto finish;
|
goto finish;
|
||||||
}
|
}
|
||||||
/*
|
/*
|
||||||
fillrect(vid_buf, 0, 0, XRES+BARSIZE, YRES+MENUSIZE, 0, 0, 0, 255);
|
fillrect(vid_buf, 0, 0, XRES+BARSIZE, YRES+MENUSIZE, 0, 0, 0, 255);
|
||||||
info_box(vid_buf, "Loading...");
|
info_box(vid_buf, "Loading...");
|
||||||
|
|
||||||
@ -2349,7 +2349,7 @@ int search_ui(pixel *vid_buf)
|
|||||||
last_own = search_own;
|
last_own = search_own;
|
||||||
last_date = search_date;
|
last_date = search_date;
|
||||||
last_page = search_page;
|
last_page = search_page;
|
||||||
last_fav = search_fav;
|
last_fav = search_fav;
|
||||||
active = 1;
|
active = 1;
|
||||||
// TODO: Create a better fix for this bug
|
// TODO: Create a better fix for this bug
|
||||||
uri = malloc(strlen(last)*3+180+strlen(SERVER)+strlen(svf_user)+20); //Increase "padding" from 80 to 180 to fix the search memory corruption bug
|
uri = malloc(strlen(last)*3+180+strlen(SERVER)+strlen(svf_user)+20); //Increase "padding" from 80 to 180 to fix the search memory corruption bug
|
||||||
@ -2381,10 +2381,10 @@ int search_ui(pixel *vid_buf)
|
|||||||
strcaturl(uri, " user:");
|
strcaturl(uri, " user:");
|
||||||
strcaturl(uri, svf_user);
|
strcaturl(uri, svf_user);
|
||||||
}
|
}
|
||||||
if(search_fav)
|
if(search_fav)
|
||||||
{
|
{
|
||||||
strcaturl(uri, " cat:favs");
|
strcaturl(uri, " cat:favs");
|
||||||
}
|
}
|
||||||
if(search_date)
|
if(search_date)
|
||||||
strcaturl(uri, " sort:date");
|
strcaturl(uri, " sort:date");
|
||||||
|
|
||||||
@ -2524,71 +2524,71 @@ finish:
|
|||||||
|
|
||||||
int open_ui(pixel *vid_buf, char *save_id, char *save_date)
|
int open_ui(pixel *vid_buf, char *save_id, char *save_date)
|
||||||
{
|
{
|
||||||
int b=1,bq,mx,my,ca=0,thumb_w,thumb_h,active=0,active_2=0,cc=0,ccy=0,cix=0,hasdrawninfo=0,hasdrawnthumb=0,authoritah=0,queue_open=0,data_size=0,retval=0;
|
int b=1,bq,mx,my,ca=0,thumb_w,thumb_h,active=0,active_2=0,cc=0,ccy=0,cix=0,hasdrawninfo=0,hasdrawnthumb=0,authoritah=0,queue_open=0,data_size=0,retval=0;
|
||||||
char *uri, *uri_2;
|
char *uri, *uri_2;
|
||||||
void *data, *info_data;
|
void *data, *info_data;
|
||||||
save_info *info = malloc(sizeof(save_info));
|
save_info *info = malloc(sizeof(save_info));
|
||||||
void *http = NULL, *http_2 = NULL;
|
void *http = NULL, *http_2 = NULL;
|
||||||
int lasttime = TIMEOUT;
|
int lasttime = TIMEOUT;
|
||||||
int status, status_2, info_ready = 0, data_ready = 0;
|
int status, status_2, info_ready = 0, data_ready = 0;
|
||||||
time_t http_last_use = HTTP_TIMEOUT, http_last_use_2 = HTTP_TIMEOUT;
|
time_t http_last_use = HTTP_TIMEOUT, http_last_use_2 = HTTP_TIMEOUT;
|
||||||
pixel *save_pic;// = malloc((XRES/2)*(YRES/2));
|
pixel *save_pic;// = malloc((XRES/2)*(YRES/2));
|
||||||
|
|
||||||
pixel *old_vid=(pixel *)calloc((XRES+BARSIZE)*(YRES+MENUSIZE), PIXELSIZE);
|
pixel *old_vid=(pixel *)calloc((XRES+BARSIZE)*(YRES+MENUSIZE), PIXELSIZE);
|
||||||
fillrect(vid_buf, -1, -1, XRES+BARSIZE, YRES+MENUSIZE, 0, 0, 0, 192);
|
fillrect(vid_buf, -1, -1, XRES+BARSIZE, YRES+MENUSIZE, 0, 0, 0, 192);
|
||||||
|
|
||||||
fillrect(vid_buf, 50, 50, XRES+BARSIZE-100, YRES+MENUSIZE-100, 0, 0, 0, 255);
|
fillrect(vid_buf, 50, 50, XRES+BARSIZE-100, YRES+MENUSIZE-100, 0, 0, 0, 255);
|
||||||
drawrect(vid_buf, 50, 50, XRES+BARSIZE-100, YRES+MENUSIZE-100, 255, 255, 255, 255);
|
drawrect(vid_buf, 50, 50, XRES+BARSIZE-100, YRES+MENUSIZE-100, 255, 255, 255, 255);
|
||||||
drawrect(vid_buf, 50, 50, (XRES/2)+1, (YRES/2)+1, 255, 255, 255, 155);
|
drawrect(vid_buf, 50, 50, (XRES/2)+1, (YRES/2)+1, 255, 255, 255, 155);
|
||||||
drawrect(vid_buf, 50+(XRES/2)+1, 50, XRES+BARSIZE-100-((XRES/2)+1), YRES+MENUSIZE-100, 155, 155, 155, 255);
|
drawrect(vid_buf, 50+(XRES/2)+1, 50, XRES+BARSIZE-100-((XRES/2)+1), YRES+MENUSIZE-100, 155, 155, 155, 255);
|
||||||
drawtext(vid_buf, 50+(XRES/4)-textwidth("Loading...")/2, 50+(YRES/4), "Loading...", 255, 255, 255, 128);
|
drawtext(vid_buf, 50+(XRES/4)-textwidth("Loading...")/2, 50+(YRES/4), "Loading...", 255, 255, 255, 128);
|
||||||
|
|
||||||
memcpy(old_vid, vid_buf, ((XRES+BARSIZE)*(YRES+MENUSIZE))*PIXELSIZE);
|
memcpy(old_vid, vid_buf, ((XRES+BARSIZE)*(YRES+MENUSIZE))*PIXELSIZE);
|
||||||
|
|
||||||
while(!sdl_poll())
|
while(!sdl_poll())
|
||||||
{
|
{
|
||||||
b = SDL_GetMouseState(&mx, &my);
|
b = SDL_GetMouseState(&mx, &my);
|
||||||
if(!b)
|
if(!b)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
//Begin Async loading of data
|
//Begin Async loading of data
|
||||||
if(save_date) {
|
if(save_date) {
|
||||||
// We're loading an historical save
|
// We're loading an historical save
|
||||||
uri = malloc(strlen(save_id)*3+strlen(save_date)*3+strlen(SERVER)+71);
|
uri = malloc(strlen(save_id)*3+strlen(save_date)*3+strlen(SERVER)+71);
|
||||||
strcpy(uri, "http://" SERVER "/Get.api?Op=save&ID=");
|
strcpy(uri, "http://" SERVER "/Get.api?Op=save&ID=");
|
||||||
strcaturl(uri, save_id);
|
strcaturl(uri, save_id);
|
||||||
strappend(uri, "&Date=");
|
strappend(uri, "&Date=");
|
||||||
strcaturl(uri, save_date);
|
strcaturl(uri, save_date);
|
||||||
|
|
||||||
uri_2 = malloc(strlen(save_id)*3+strlen(save_date)*3+strlen(SERVER)+71);
|
uri_2 = malloc(strlen(save_id)*3+strlen(save_date)*3+strlen(SERVER)+71);
|
||||||
strcpy(uri_2, "http://" SERVER "/Get.api?Op=save&ID=");
|
strcpy(uri_2, "http://" SERVER "/Get.api?Op=save&ID=");
|
||||||
strcaturl(uri_2, save_id);
|
strcaturl(uri_2, save_id);
|
||||||
strappend(uri_2, "&Date=");
|
strappend(uri_2, "&Date=");
|
||||||
strcaturl(uri_2, save_date);
|
strcaturl(uri_2, save_date);
|
||||||
} else {
|
} else {
|
||||||
//We're loading a normal save
|
//We're loading a normal save
|
||||||
uri = malloc(strlen(save_id)*3+strlen(SERVER)+64);
|
uri = malloc(strlen(save_id)*3+strlen(SERVER)+64);
|
||||||
strcpy(uri, "http://" SERVER "/Get.api?Op=save&ID=");
|
strcpy(uri, "http://" SERVER "/Get.api?Op=save&ID=");
|
||||||
strcaturl(uri, save_id);
|
strcaturl(uri, save_id);
|
||||||
|
|
||||||
uri_2 = malloc(strlen(save_id)*3+strlen(SERVER)+64);
|
uri_2 = malloc(strlen(save_id)*3+strlen(SERVER)+64);
|
||||||
strcpy(uri_2, "http://" SERVER "/Info.api?ID=");
|
strcpy(uri_2, "http://" SERVER "/Info.api?ID=");
|
||||||
strcaturl(uri_2, save_id);
|
strcaturl(uri_2, save_id);
|
||||||
}
|
}
|
||||||
http = http_async_req_start(http, uri, NULL, 0, 1);
|
http = http_async_req_start(http, uri, NULL, 0, 1);
|
||||||
http_2 = http_async_req_start(http_2, uri_2, NULL, 0, 1);
|
http_2 = http_async_req_start(http_2, uri_2, NULL, 0, 1);
|
||||||
if(svf_login)
|
if(svf_login)
|
||||||
{
|
{
|
||||||
http_auth_headers(http, svf_user, svf_pass);
|
http_auth_headers(http, svf_user, svf_pass);
|
||||||
http_auth_headers(http_2, svf_user, svf_pass);
|
http_auth_headers(http_2, svf_user, svf_pass);
|
||||||
}
|
}
|
||||||
http_last_use = time(NULL);
|
http_last_use = time(NULL);
|
||||||
http_last_use_2 = time(NULL);
|
http_last_use_2 = time(NULL);
|
||||||
free(uri);
|
free(uri);
|
||||||
free(uri_2);
|
free(uri_2);
|
||||||
active = 1;
|
active = 1;
|
||||||
active_2 = 1;
|
active_2 = 1;
|
||||||
while(!sdl_poll())
|
while(!sdl_poll())
|
||||||
{
|
{
|
||||||
bq = b;
|
bq = b;
|
||||||
@ -2596,188 +2596,188 @@ int open_ui(pixel *vid_buf, char *save_id, char *save_date)
|
|||||||
mx /= sdl_scale;
|
mx /= sdl_scale;
|
||||||
my /= sdl_scale;
|
my /= sdl_scale;
|
||||||
|
|
||||||
if(active && http_async_req_status(http))
|
if(active && http_async_req_status(http))
|
||||||
{
|
{
|
||||||
int imgh, imgw, nimgh, nimgw;
|
int imgh, imgw, nimgh, nimgw;
|
||||||
http_last_use = time(NULL);
|
http_last_use = time(NULL);
|
||||||
data = http_async_req_stop(http, &status, &data_size);
|
data = http_async_req_stop(http, &status, &data_size);
|
||||||
if(status == 200)
|
if(status == 200)
|
||||||
{
|
{
|
||||||
pixel *full_save = prerender_save(data, data_size, &imgw, &imgh);
|
pixel *full_save = prerender_save(data, data_size, &imgw, &imgh);
|
||||||
save_pic = rescale_img(full_save, imgw, imgh, &thumb_w, &thumb_h, 2);
|
save_pic = rescale_img(full_save, imgw, imgh, &thumb_w, &thumb_h, 2);
|
||||||
data_ready = 1;
|
data_ready = 1;
|
||||||
free(full_save);
|
free(full_save);
|
||||||
}
|
}
|
||||||
active = 0;
|
active = 0;
|
||||||
free(http);
|
free(http);
|
||||||
http = NULL;
|
http = NULL;
|
||||||
}
|
}
|
||||||
if(active_2 && http_async_req_status(http_2))
|
if(active_2 && http_async_req_status(http_2))
|
||||||
{
|
{
|
||||||
http_last_use_2 = time(NULL);
|
http_last_use_2 = time(NULL);
|
||||||
info_data = http_async_req_stop(http_2, &status_2, NULL);
|
info_data = http_async_req_stop(http_2, &status_2, NULL);
|
||||||
if(status_2 == 200)
|
if(status_2 == 200)
|
||||||
{
|
{
|
||||||
info_ready = info_parse(info_data, info);
|
info_ready = info_parse(info_data, info);
|
||||||
if(info_ready==-1){
|
if(info_ready==-1) {
|
||||||
error_ui(vid_buf, 0, "Not found");
|
error_ui(vid_buf, 0, "Not found");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
free(info_data);
|
free(info_data);
|
||||||
active_2 = 0;
|
active_2 = 0;
|
||||||
free(http_2);
|
free(http_2);
|
||||||
http_2 = NULL;
|
http_2 = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(data_ready && !hasdrawnthumb){
|
if(data_ready && !hasdrawnthumb) {
|
||||||
draw_image(vid_buf, save_pic, 51, 51, thumb_w, thumb_h, 255);
|
draw_image(vid_buf, save_pic, 51, 51, thumb_w, thumb_h, 255);
|
||||||
hasdrawnthumb = 1;
|
hasdrawnthumb = 1;
|
||||||
memcpy(old_vid, vid_buf, ((XRES+BARSIZE)*(YRES+MENUSIZE))*PIXELSIZE);
|
memcpy(old_vid, vid_buf, ((XRES+BARSIZE)*(YRES+MENUSIZE))*PIXELSIZE);
|
||||||
}
|
}
|
||||||
if(info_ready && !hasdrawninfo){
|
if(info_ready && !hasdrawninfo) {
|
||||||
//drawtext(vid_buf, 2, 2, info->name, 255, 255, 255, 255);
|
//drawtext(vid_buf, 2, 2, info->name, 255, 255, 255, 255);
|
||||||
cix = drawtext(vid_buf, 60, (YRES/2)+60, info->name, 255, 255, 255, 255);
|
cix = drawtext(vid_buf, 60, (YRES/2)+60, info->name, 255, 255, 255, 255);
|
||||||
cix = drawtext(vid_buf, 60, (YRES/2)+72, "Author:", 255, 255, 255, 155);
|
cix = drawtext(vid_buf, 60, (YRES/2)+72, "Author:", 255, 255, 255, 155);
|
||||||
cix = drawtext(vid_buf, cix+4, (YRES/2)+72, info->author, 255, 255, 255, 255);
|
cix = drawtext(vid_buf, cix+4, (YRES/2)+72, info->author, 255, 255, 255, 255);
|
||||||
cix = drawtext(vid_buf, cix+4, (YRES/2)+72, "Date:", 255, 255, 255, 155);
|
cix = drawtext(vid_buf, cix+4, (YRES/2)+72, "Date:", 255, 255, 255, 155);
|
||||||
cix = drawtext(vid_buf, cix+4, (YRES/2)+72, info->date, 255, 255, 255, 255);
|
cix = drawtext(vid_buf, cix+4, (YRES/2)+72, info->date, 255, 255, 255, 255);
|
||||||
drawtextwrap(vid_buf, 62, (YRES/2)+86, (XRES/2)-24, info->description, 255, 255, 255, 200);
|
drawtextwrap(vid_buf, 62, (YRES/2)+86, (XRES/2)-24, info->description, 255, 255, 255, 200);
|
||||||
|
|
||||||
ccy = 0;
|
ccy = 0;
|
||||||
for(cc=0;cc<info->comment_count;cc++){
|
for(cc=0; cc<info->comment_count; cc++) {
|
||||||
drawtext(vid_buf, 60+(XRES/2)+1, ccy+60, info->commentauthors[cc], 255, 255, 255, 255);
|
drawtext(vid_buf, 60+(XRES/2)+1, ccy+60, info->commentauthors[cc], 255, 255, 255, 255);
|
||||||
ccy += 12;
|
ccy += 12;
|
||||||
ccy += drawtextwrap(vid_buf, 60+(XRES/2)+1, ccy+60, XRES+BARSIZE-100-((XRES/2)+1)-20, info->comments[cc], 255, 255, 255, 185);
|
ccy += drawtextwrap(vid_buf, 60+(XRES/2)+1, ccy+60, XRES+BARSIZE-100-((XRES/2)+1)-20, info->comments[cc], 255, 255, 255, 185);
|
||||||
ccy += 10;
|
ccy += 10;
|
||||||
draw_line(vid_buf, 50+(XRES/2)+2, ccy+52, XRES+BARSIZE-50, ccy+52, 100, 100, 100, XRES+BARSIZE);
|
draw_line(vid_buf, 50+(XRES/2)+2, ccy+52, XRES+BARSIZE-50, ccy+52, 100, 100, 100, XRES+BARSIZE);
|
||||||
}
|
}
|
||||||
hasdrawninfo = 1;
|
hasdrawninfo = 1;
|
||||||
authoritah = svf_login && (!strcmp(info->author, svf_user) || svf_admin || svf_mod);
|
authoritah = svf_login && (!strcmp(info->author, svf_user) || svf_admin || svf_mod);
|
||||||
memcpy(old_vid, vid_buf, ((XRES+BARSIZE)*(YRES+MENUSIZE))*PIXELSIZE);
|
memcpy(old_vid, vid_buf, ((XRES+BARSIZE)*(YRES+MENUSIZE))*PIXELSIZE);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(queue_open){
|
if(queue_open) {
|
||||||
if(info_ready && data_ready){
|
if(info_ready && data_ready) {
|
||||||
// Do Open!
|
// Do Open!
|
||||||
status = parse_save(data, data_size, 1, 0, 0);
|
status = parse_save(data, data_size, 1, 0, 0);
|
||||||
if(!status){
|
if(!status) {
|
||||||
//if(svf_last)
|
//if(svf_last)
|
||||||
//free(svf_last);
|
//free(svf_last);
|
||||||
svf_last = data;
|
svf_last = data;
|
||||||
svf_lsize = data_size;
|
svf_lsize = data_size;
|
||||||
|
|
||||||
svf_open = 1;
|
|
||||||
svf_own = svf_login && !strcmp(info->author, svf_user);
|
|
||||||
svf_publish = info->publish && svf_login && !strcmp(info->author, svf_user);
|
|
||||||
|
|
||||||
strcpy(svf_id, save_id);
|
|
||||||
strcpy(svf_name, info->name);
|
|
||||||
if(info->tags)
|
|
||||||
{
|
|
||||||
strncpy(svf_tags, info->tags, 255);
|
|
||||||
svf_tags[255] = 0;
|
|
||||||
} else {
|
|
||||||
svf_tags[0] = 0;
|
|
||||||
}
|
|
||||||
svf_myvote = info->myvote;
|
|
||||||
retval = 1;
|
|
||||||
break;
|
|
||||||
} else {
|
|
||||||
queue_open = 0;
|
|
||||||
|
|
||||||
svf_open = 0;
|
|
||||||
svf_publish = 0;
|
|
||||||
svf_own = 0;
|
|
||||||
svf_myvote = 0;
|
|
||||||
svf_id[0] = 0;
|
|
||||||
svf_name[0] = 0;
|
|
||||||
svf_tags[0] = 0;
|
|
||||||
if(svf_last)
|
|
||||||
free(svf_last);
|
|
||||||
svf_last = NULL;
|
|
||||||
error_ui(vid_buf, 0, "An Error Occurred");
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
fillrect(vid_buf, -1, -1, XRES+BARSIZE, YRES+MENUSIZE, 0, 0, 0, 190);
|
|
||||||
drawtext(vid_buf, XRES+BARSIZE/2, XRES+MENUSIZE, "Loading...", 0, 0, 0, 200);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
//Open Button
|
svf_open = 1;
|
||||||
if(sdl_key==SDLK_RETURN){
|
svf_own = svf_login && !strcmp(info->author, svf_user);
|
||||||
|
svf_publish = info->publish && svf_login && !strcmp(info->author, svf_user);
|
||||||
|
|
||||||
|
strcpy(svf_id, save_id);
|
||||||
|
strcpy(svf_name, info->name);
|
||||||
|
if(info->tags)
|
||||||
|
{
|
||||||
|
strncpy(svf_tags, info->tags, 255);
|
||||||
|
svf_tags[255] = 0;
|
||||||
|
} else {
|
||||||
|
svf_tags[0] = 0;
|
||||||
|
}
|
||||||
|
svf_myvote = info->myvote;
|
||||||
|
retval = 1;
|
||||||
|
break;
|
||||||
|
} else {
|
||||||
|
queue_open = 0;
|
||||||
|
|
||||||
|
svf_open = 0;
|
||||||
|
svf_publish = 0;
|
||||||
|
svf_own = 0;
|
||||||
|
svf_myvote = 0;
|
||||||
|
svf_id[0] = 0;
|
||||||
|
svf_name[0] = 0;
|
||||||
|
svf_tags[0] = 0;
|
||||||
|
if(svf_last)
|
||||||
|
free(svf_last);
|
||||||
|
svf_last = NULL;
|
||||||
|
error_ui(vid_buf, 0, "An Error Occurred");
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
fillrect(vid_buf, -1, -1, XRES+BARSIZE, YRES+MENUSIZE, 0, 0, 0, 190);
|
||||||
|
drawtext(vid_buf, XRES+BARSIZE/2, XRES+MENUSIZE, "Loading...", 0, 0, 0, 200);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//Open Button
|
||||||
|
if(sdl_key==SDLK_RETURN) {
|
||||||
queue_open = 1;
|
queue_open = 1;
|
||||||
}
|
}
|
||||||
drawrect(vid_buf, 70, YRES+MENUSIZE-68, 50, 18, 255, 255, 255, 255);
|
drawrect(vid_buf, 70, YRES+MENUSIZE-68, 50, 18, 255, 255, 255, 255);
|
||||||
drawtext(vid_buf, 93, YRES+MENUSIZE-63, "Open", 255, 255, 255, 255);
|
drawtext(vid_buf, 93, YRES+MENUSIZE-63, "Open", 255, 255, 255, 255);
|
||||||
drawtext(vid_buf, 78, YRES+MENUSIZE-64, "\x81", 255, 255, 255, 255);
|
drawtext(vid_buf, 78, YRES+MENUSIZE-64, "\x81", 255, 255, 255, 255);
|
||||||
if(mx > 70 && mx < 70+50 && my > YRES+MENUSIZE-68 && my < YRES+MENUSIZE-50){
|
if(mx > 70 && mx < 70+50 && my > YRES+MENUSIZE-68 && my < YRES+MENUSIZE-50) {
|
||||||
fillrect(vid_buf, 70, YRES+MENUSIZE-68, 50, 18, 255, 255, 255, 40);
|
fillrect(vid_buf, 70, YRES+MENUSIZE-68, 50, 18, 255, 255, 255, 40);
|
||||||
if(b && !bq){
|
if(b && !bq) {
|
||||||
queue_open = 1;
|
queue_open = 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//Fav Button
|
|
||||||
if(svf_login){
|
|
||||||
drawrect(vid_buf, 140, YRES+MENUSIZE-68, 50, 18, 255, 255, 255, 255);
|
|
||||||
drawtext(vid_buf, 162, YRES+MENUSIZE-63, "Fav.", 255, 255, 255, 255);
|
|
||||||
drawtext(vid_buf, 147, YRES+MENUSIZE-64, "\xCC", 255, 255, 255, 255);
|
|
||||||
if(mx > 140 && mx < 140+50 && my > YRES+MENUSIZE-68 && my < YRES+MENUSIZE-50){
|
|
||||||
fillrect(vid_buf, 140, YRES+MENUSIZE-68, 50, 18, 255, 255, 255, 40);
|
|
||||||
if(b && !bq){
|
|
||||||
//Button Clicked
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
//Report Button
|
//Fav Button
|
||||||
if(svf_login){
|
if(svf_login) {
|
||||||
drawrect(vid_buf, 210, YRES+MENUSIZE-68, 50, 18, 255, 255, 255, 255);
|
drawrect(vid_buf, 140, YRES+MENUSIZE-68, 50, 18, 255, 255, 255, 255);
|
||||||
drawtext(vid_buf, 228, YRES+MENUSIZE-63, "Report", 255, 255, 255, 255);
|
drawtext(vid_buf, 162, YRES+MENUSIZE-63, "Fav.", 255, 255, 255, 255);
|
||||||
drawtext(vid_buf, 218, YRES+MENUSIZE-63, "!", 255, 255, 255, 255);
|
drawtext(vid_buf, 147, YRES+MENUSIZE-64, "\xCC", 255, 255, 255, 255);
|
||||||
if(mx > 210 && mx < 210+50 && my > YRES+MENUSIZE-68 && my < YRES+MENUSIZE-50){
|
if(mx > 140 && mx < 140+50 && my > YRES+MENUSIZE-68 && my < YRES+MENUSIZE-50) {
|
||||||
fillrect(vid_buf, 210, YRES+MENUSIZE-68, 50, 18, 255, 255, 255, 40);
|
fillrect(vid_buf, 140, YRES+MENUSIZE-68, 50, 18, 255, 255, 255, 40);
|
||||||
if(b && !bq){
|
if(b && !bq) {
|
||||||
//Button Clicked
|
//Button Clicked
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//Delete Button
|
//Report Button
|
||||||
if(authoritah){
|
if(svf_login) {
|
||||||
drawrect(vid_buf, 280, YRES+MENUSIZE-68, 50, 18, 255, 255, 255, 255);
|
drawrect(vid_buf, 210, YRES+MENUSIZE-68, 50, 18, 255, 255, 255, 255);
|
||||||
drawtext(vid_buf, 298, YRES+MENUSIZE-63, "Delete", 255, 255, 255, 255);
|
drawtext(vid_buf, 228, YRES+MENUSIZE-63, "Report", 255, 255, 255, 255);
|
||||||
drawtext(vid_buf, 286, YRES+MENUSIZE-64, "\xAA", 255, 255, 255, 255);
|
drawtext(vid_buf, 218, YRES+MENUSIZE-63, "!", 255, 255, 255, 255);
|
||||||
if(mx > 280 && mx < 280+50 && my > YRES+MENUSIZE-68 && my < YRES+MENUSIZE-50){
|
if(mx > 210 && mx < 210+50 && my > YRES+MENUSIZE-68 && my < YRES+MENUSIZE-50) {
|
||||||
fillrect(vid_buf, 280, YRES+MENUSIZE-68, 50, 18, 255, 255, 255, 40);
|
fillrect(vid_buf, 210, YRES+MENUSIZE-68, 50, 18, 255, 255, 255, 40);
|
||||||
if(b && !bq){
|
if(b && !bq) {
|
||||||
//Button Clicked
|
//Button Clicked
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//Delete Button
|
||||||
|
if(authoritah) {
|
||||||
|
drawrect(vid_buf, 280, YRES+MENUSIZE-68, 50, 18, 255, 255, 255, 255);
|
||||||
|
drawtext(vid_buf, 298, YRES+MENUSIZE-63, "Delete", 255, 255, 255, 255);
|
||||||
|
drawtext(vid_buf, 286, YRES+MENUSIZE-64, "\xAA", 255, 255, 255, 255);
|
||||||
|
if(mx > 280 && mx < 280+50 && my > YRES+MENUSIZE-68 && my < YRES+MENUSIZE-50) {
|
||||||
|
fillrect(vid_buf, 280, YRES+MENUSIZE-68, 50, 18, 255, 255, 255, 40);
|
||||||
|
if(b && !bq) {
|
||||||
|
//Button Clicked
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
sdl_blit(0, 0, (XRES+BARSIZE), YRES+MENUSIZE, vid_buf, (XRES+BARSIZE));
|
sdl_blit(0, 0, (XRES+BARSIZE), YRES+MENUSIZE, vid_buf, (XRES+BARSIZE));
|
||||||
memcpy(vid_buf, old_vid, ((XRES+BARSIZE)*(YRES+MENUSIZE))*PIXELSIZE);
|
memcpy(vid_buf, old_vid, ((XRES+BARSIZE)*(YRES+MENUSIZE))*PIXELSIZE);
|
||||||
|
|
||||||
if(sdl_key==SDLK_ESCAPE)
|
if(sdl_key==SDLK_ESCAPE)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
if(lasttime<TIMEOUT)
|
if(lasttime<TIMEOUT)
|
||||||
lasttime++;
|
lasttime++;
|
||||||
}
|
}
|
||||||
return retval;
|
return retval;
|
||||||
}
|
}
|
||||||
|
|
||||||
int info_parse(char *info_data, save_info *info)
|
int info_parse(char *info_data, save_info *info)
|
||||||
{
|
{
|
||||||
int i,j;
|
int i,j;
|
||||||
char *p,*q,*r,*s,*vu,*vd,*pu,*sd;
|
char *p,*q,*r,*s,*vu,*vd,*pu,*sd;
|
||||||
|
|
||||||
memset(info, 0, sizeof(save_info));
|
memset(info, 0, sizeof(save_info));
|
||||||
|
|
||||||
if(!info_data || !*info_data)
|
if(!info_data || !*info_data)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
i = 0;
|
i = 0;
|
||||||
@ -2794,87 +2794,87 @@ int info_parse(char *info_data, save_info *info)
|
|||||||
else
|
else
|
||||||
*(p++) = 0;
|
*(p++) = 0;
|
||||||
|
|
||||||
if(!strncmp(info_data, "TITLE ", 6))
|
if(!strncmp(info_data, "TITLE ", 6))
|
||||||
{
|
{
|
||||||
info->title = mystrdup(info_data+6);
|
info->title = mystrdup(info_data+6);
|
||||||
j++;
|
j++;
|
||||||
}
|
}
|
||||||
else if(!strncmp(info_data, "NAME ", 5))
|
else if(!strncmp(info_data, "NAME ", 5))
|
||||||
{
|
{
|
||||||
info->name = mystrdup(info_data+5);
|
info->name = mystrdup(info_data+5);
|
||||||
j++;
|
j++;
|
||||||
}
|
}
|
||||||
else if(!strncmp(info_data, "AUTHOR ", 7))
|
else if(!strncmp(info_data, "AUTHOR ", 7))
|
||||||
{
|
{
|
||||||
info->author = mystrdup(info_data+7);
|
info->author = mystrdup(info_data+7);
|
||||||
j++;
|
j++;
|
||||||
}
|
}
|
||||||
else if(!strncmp(info_data, "DATE ", 5))
|
else if(!strncmp(info_data, "DATE ", 5))
|
||||||
{
|
{
|
||||||
info->date = mystrdup(info_data+5);
|
info->date = mystrdup(info_data+5);
|
||||||
j++;
|
j++;
|
||||||
}
|
}
|
||||||
else if(!strncmp(info_data, "DESCRIPTION ", 12))
|
else if(!strncmp(info_data, "DESCRIPTION ", 12))
|
||||||
{
|
{
|
||||||
info->description = mystrdup(info_data+12);
|
info->description = mystrdup(info_data+12);
|
||||||
j++;
|
j++;
|
||||||
}
|
}
|
||||||
else if(!strncmp(info_data, "VOTEUP ", 7))
|
else if(!strncmp(info_data, "VOTEUP ", 7))
|
||||||
{
|
{
|
||||||
info->voteup = atoi(info_data+7);
|
info->voteup = atoi(info_data+7);
|
||||||
j++;
|
j++;
|
||||||
}
|
}
|
||||||
else if(!strncmp(info_data, "VOTEDOWN ", 9))
|
else if(!strncmp(info_data, "VOTEDOWN ", 9))
|
||||||
{
|
{
|
||||||
info->votedown = atoi(info_data+9);
|
info->votedown = atoi(info_data+9);
|
||||||
j++;
|
j++;
|
||||||
}
|
}
|
||||||
else if(!strncmp(info_data, "VOTE ", 5))
|
else if(!strncmp(info_data, "VOTE ", 5))
|
||||||
{
|
{
|
||||||
info->vote = atoi(info_data+5);
|
info->vote = atoi(info_data+5);
|
||||||
j++;
|
j++;
|
||||||
}
|
}
|
||||||
else if(!strncmp(info_data, "MYVOTE ", 7))
|
else if(!strncmp(info_data, "MYVOTE ", 7))
|
||||||
{
|
{
|
||||||
info->myvote = atoi(info_data+7);
|
info->myvote = atoi(info_data+7);
|
||||||
j++;
|
j++;
|
||||||
}
|
}
|
||||||
else if(!strncmp(info_data, "MYFAV ", 6))
|
else if(!strncmp(info_data, "MYFAV ", 6))
|
||||||
{
|
{
|
||||||
info->myfav = atoi(info_data+6);
|
info->myfav = atoi(info_data+6);
|
||||||
j++;
|
j++;
|
||||||
}
|
}
|
||||||
else if(!strncmp(info_data, "PUBLISH ", 8))
|
else if(!strncmp(info_data, "PUBLISH ", 8))
|
||||||
{
|
{
|
||||||
info->publish = atoi(info_data+8);
|
info->publish = atoi(info_data+8);
|
||||||
j++;
|
j++;
|
||||||
}
|
}
|
||||||
else if(!strncmp(info_data, "TAGS ", 5))
|
else if(!strncmp(info_data, "TAGS ", 5))
|
||||||
{
|
{
|
||||||
info->tags = mystrdup(info_data+5);
|
info->tags = mystrdup(info_data+5);
|
||||||
j++;
|
j++;
|
||||||
}
|
}
|
||||||
else if(!strncmp(info_data, "COMMENT ", 8))
|
else if(!strncmp(info_data, "COMMENT ", 8))
|
||||||
{
|
{
|
||||||
if(info->comment_count>=6){
|
if(info->comment_count>=6) {
|
||||||
info_data = p;
|
info_data = p;
|
||||||
continue;
|
continue;
|
||||||
} else {
|
} else {
|
||||||
q = strchr(info_data+8, ' ');
|
q = strchr(info_data+8, ' ');
|
||||||
*(q++) = 0;
|
*(q++) = 0;
|
||||||
info->commentauthors[info->comment_count] = mystrdup(info_data+8);
|
info->commentauthors[info->comment_count] = mystrdup(info_data+8);
|
||||||
info->comments[info->comment_count] = mystrdup(q);
|
info->comments[info->comment_count] = mystrdup(q);
|
||||||
info->comment_count++;
|
info->comment_count++;
|
||||||
}
|
}
|
||||||
j++;
|
j++;
|
||||||
}
|
}
|
||||||
info_data = p;
|
info_data = p;
|
||||||
|
}
|
||||||
|
if(j>=8) {
|
||||||
|
return 1;
|
||||||
|
} else {
|
||||||
|
return -1;
|
||||||
}
|
}
|
||||||
if(j>=8){
|
|
||||||
return 1;
|
|
||||||
} else {
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int search_results(char *str, int votes)
|
int search_results(char *str, int votes)
|
||||||
|
22
src/main.c
Executable file → Normal file
22
src/main.c
Executable file → Normal file
@ -272,9 +272,9 @@ void *build_save(int *size, int x0, int y0, int w, int h)
|
|||||||
y = (int)(parts[i].y+0.5f);
|
y = (int)(parts[i].y+0.5f);
|
||||||
if(x>=x0 && x<x0+w && y>=y0 && y<y0+h) {
|
if(x>=x0 && x<x0+w && y>=y0 && y<y0+h) {
|
||||||
if(!m[(x-x0)+(y-y0)*w] ||
|
if(!m[(x-x0)+(y-y0)*w] ||
|
||||||
parts[m[(x-x0)+(y-y0)*w]-1].type == PT_PHOT)
|
parts[m[(x-x0)+(y-y0)*w]-1].type == PT_PHOT)
|
||||||
m[(x-x0)+(y-y0)*w] = i+1;
|
m[(x-x0)+(y-y0)*w] = i+1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
for(j=0; j<w*h; j++)
|
for(j=0; j<w*h; j++)
|
||||||
{
|
{
|
||||||
@ -507,18 +507,18 @@ int parse_save(void *save, int size, int replace, int x0, int y0)
|
|||||||
if(p >= size)
|
if(p >= size)
|
||||||
goto corrupt;
|
goto corrupt;
|
||||||
j=d[p++];
|
j=d[p++];
|
||||||
if(j >= PT_NUM){
|
if(j >= PT_NUM) {
|
||||||
//TODO: Possibly some server side translation
|
//TODO: Possibly some server side translation
|
||||||
j = PT_DUST;//goto corrupt;
|
j = PT_DUST;//goto corrupt;
|
||||||
}
|
}
|
||||||
if(j)// && !(isplayer == 1 && j==PT_STKM))
|
if(j)// && !(isplayer == 1 && j==PT_STKM))
|
||||||
{
|
{
|
||||||
if(pmap[y][x])
|
if(pmap[y][x])
|
||||||
{
|
{
|
||||||
k = pmap[y][x]>>8;
|
k = pmap[y][x]>>8;
|
||||||
parts[k].type = j;
|
parts[k].type = j;
|
||||||
if(j == PT_PHOT)
|
if(j == PT_PHOT)
|
||||||
parts[k].ctype = 0x3fffffff;
|
parts[k].ctype = 0x3fffffff;
|
||||||
parts[k].x = (float)x;
|
parts[k].x = (float)x;
|
||||||
parts[k].y = (float)y;
|
parts[k].y = (float)y;
|
||||||
m[(x-x0)+(y-y0)*w] = k+1;
|
m[(x-x0)+(y-y0)*w] = k+1;
|
||||||
@ -526,8 +526,8 @@ int parse_save(void *save, int size, int replace, int x0, int y0)
|
|||||||
else if(i < nf)
|
else if(i < nf)
|
||||||
{
|
{
|
||||||
parts[fp[i]].type = j;
|
parts[fp[i]].type = j;
|
||||||
if(j == PT_PHOT)
|
if(j == PT_PHOT)
|
||||||
parts[fp[i]].ctype = 0x3fffffff;
|
parts[fp[i]].ctype = 0x3fffffff;
|
||||||
parts[fp[i]].x = (float)x;
|
parts[fp[i]].x = (float)x;
|
||||||
parts[fp[i]].y = (float)y;
|
parts[fp[i]].y = (float)y;
|
||||||
m[(x-x0)+(y-y0)*w] = fp[i]+1;
|
m[(x-x0)+(y-y0)*w] = fp[i]+1;
|
||||||
|
407
src/powder.c
407
src/powder.c
@ -26,10 +26,10 @@ static int pn_junction_sprk(int x, int y, int pt)
|
|||||||
{
|
{
|
||||||
unsigned r = pmap[y][x];
|
unsigned r = pmap[y][x];
|
||||||
if((r & 0xFF) != pt)
|
if((r & 0xFF) != pt)
|
||||||
return 0;
|
return 0;
|
||||||
r >>= 8;
|
r >>= 8;
|
||||||
if(parts[r].type != pt)
|
if(parts[r].type != pt)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
parts[r].ctype = pt;
|
parts[r].ctype = pt;
|
||||||
parts[r].type = PT_SPRK;
|
parts[r].type = PT_SPRK;
|
||||||
@ -42,16 +42,16 @@ static void photoelectric_effect(int nx, int ny)
|
|||||||
unsigned r = pmap[ny][nx];
|
unsigned r = pmap[ny][nx];
|
||||||
|
|
||||||
if((r&0xFF) == PT_PSCN) {
|
if((r&0xFF) == PT_PSCN) {
|
||||||
if((pmap[ny][nx-1] & 0xFF) == PT_NSCN ||
|
if((pmap[ny][nx-1] & 0xFF) == PT_NSCN ||
|
||||||
(pmap[ny][nx+1] & 0xFF) == PT_NSCN ||
|
(pmap[ny][nx+1] & 0xFF) == PT_NSCN ||
|
||||||
(pmap[ny-1][nx] & 0xFF) == PT_NSCN ||
|
(pmap[ny-1][nx] & 0xFF) == PT_NSCN ||
|
||||||
(pmap[ny+1][nx] & 0xFF) == PT_NSCN)
|
(pmap[ny+1][nx] & 0xFF) == PT_NSCN)
|
||||||
pn_junction_sprk(nx, ny, PT_PSCN);
|
pn_junction_sprk(nx, ny, PT_PSCN);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
/*
|
/*
|
||||||
RETURN-value explenation
|
RETURN-value explenation
|
||||||
1 = Swap
|
1 = Swap
|
||||||
0 = No move/Bounce
|
0 = No move/Bounce
|
||||||
2 = Both particles occupy the same space.
|
2 = Both particles occupy the same space.
|
||||||
*/
|
*/
|
||||||
@ -69,16 +69,13 @@ static int eval_move(int pt, int nx, int ny, unsigned *rr)
|
|||||||
*rr = r;
|
*rr = r;
|
||||||
|
|
||||||
if((r&0xFF)==PT_VOID || (r&0xFF)==PT_BHOL)
|
if((r&0xFF)==PT_VOID || (r&0xFF)==PT_BHOL)
|
||||||
return 1;
|
return 1;
|
||||||
|
|
||||||
if(pt==PT_NEUT && (r&0xFF)==PT_GLAS)
|
|
||||||
return 2;
|
|
||||||
|
|
||||||
if(pt==PT_PHOT&&(
|
if(pt==PT_PHOT&&(
|
||||||
(r&0xFF)==PT_GLAS || (r&0xFF)==PT_PHOT ||
|
(r&0xFF)==PT_GLAS || (r&0xFF)==PT_PHOT ||
|
||||||
(r&0xFF)==PT_CLNE || (r&0xFF)==PT_PCLN ||
|
(r&0xFF)==PT_CLNE || (r&0xFF)==PT_PCLN ||
|
||||||
(r&0xFF)==PT_GLOW ||
|
(r&0xFF)==PT_GLOW || (r&0xFF)==PT_WATR ||
|
||||||
(r&0xFF)==PT_WATR || (r&0xFF)==PT_DSTW || (r&0xFF)==PT_SLTW ||
|
(r&0xFF)==PT_DSTW || (r&0xFF)==PT_SLTW ||
|
||||||
((r&0xFF)==PT_LCRY&&parts[r>>8].life > 5)))
|
((r&0xFF)==PT_LCRY&&parts[r>>8].life > 5)))
|
||||||
return 2;
|
return 2;
|
||||||
|
|
||||||
@ -99,17 +96,19 @@ static int eval_move(int pt, int nx, int ny, unsigned *rr)
|
|||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
if(pt == PT_PHOT)
|
if(pt == PT_PHOT)
|
||||||
return 2;
|
return 0;
|
||||||
|
if(pt == PT_NEUT)
|
||||||
if(pt == PT_NEUT)
|
|
||||||
return 1;
|
return 1;
|
||||||
if((r&0xFF) == PT_NEUT)
|
if(pt == PT_NEUT && (r&0xFF == PT_WATR||r&0xFF == PT_SLTW ||r&0xFF == PT_DSTW))
|
||||||
|
return 2;
|
||||||
|
|
||||||
|
if((r&0xFF) == PT_NEUT)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
if (r && ((r&0xFF) >= PT_NUM || (ptypes[pt].weight <= ptypes[(r&0xFF)].weight)))
|
if (r && ((r&0xFF) >= PT_NUM || (ptypes[pt].weight <= ptypes[(r&0xFF)].weight)))
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -127,32 +126,38 @@ int try_move(int i, int x, int y, int nx, int ny)
|
|||||||
|
|
||||||
/* half-silvered mirror */
|
/* half-silvered mirror */
|
||||||
if(!e && parts[i].type==PT_PHOT &&
|
if(!e && parts[i].type==PT_PHOT &&
|
||||||
(((r&0xFF)==PT_BMTL && rand()<RAND_MAX/2) ||
|
(((r&0xFF)==PT_BMTL && rand()<RAND_MAX/2) ||
|
||||||
(pmap[y][x]&0xFF)==PT_BMTL))
|
(pmap[y][x]&0xFF)==PT_BMTL))
|
||||||
e = 2;
|
e = 2;
|
||||||
|
|
||||||
if(!e) {
|
if(!e)
|
||||||
if(!legacy_enable && parts[i].type==PT_PHOT) {
|
{
|
||||||
|
if(!legacy_enable && parts[i].type==PT_PHOT)
|
||||||
|
{
|
||||||
if((r & 0xFF) == PT_COAL || (r & 0xFF) == PT_BCOL)
|
if((r & 0xFF) == PT_COAL || (r & 0xFF) == PT_BCOL)
|
||||||
parts[r>>8].temp = parts[i].temp;
|
parts[r>>8].temp = parts[i].temp;
|
||||||
|
|
||||||
if((r & 0xFF) < PT_NUM)
|
if((r & 0xFF) < PT_NUM)
|
||||||
parts[i].temp = parts[r>>8].temp =
|
parts[i].temp = parts[r>>8].temp = restrict_flt((parts[r>>8].temp+parts[i].temp)/2, MIN_TEMP, MAX_TEMP);
|
||||||
restrict_flt((parts[r>>8].temp+parts[i].temp)/2, MIN_TEMP, MAX_TEMP);
|
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
if(e == 2) {
|
|
||||||
if(parts[i].type == PT_PHOT && (r&0xFF)==PT_GLOW && !parts[r>>8].life)
|
if(e == 2)
|
||||||
if(rand() < RAND_MAX/30) {
|
{
|
||||||
parts[r>>8].life = 120;
|
if(parts[i].type == PT_PHOT && (r&0xFF)==PT_GLOW && !parts[r>>8].life)
|
||||||
create_gain_photon(i);
|
if(rand() < RAND_MAX/30)
|
||||||
}
|
{
|
||||||
if(parts[i].type == PT_NEUT && (r&0xFF)==PT_GLAS) {
|
parts[r>>8].life = 120;
|
||||||
if(rand() < RAND_MAX/10)
|
create_gain_photon(i);
|
||||||
create_cherenkov_photon(i);
|
}
|
||||||
}
|
|
||||||
|
if(parts[i].type == PT_NEUT && (r&0xFF)==PT_GLAS) {
|
||||||
|
if(rand() < RAND_MAX/10)
|
||||||
|
create_cherenkov_photon(i);
|
||||||
|
}
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if((r&0xFF)==PT_VOID)
|
if((r&0xFF)==PT_VOID)
|
||||||
{
|
{
|
||||||
@ -181,13 +186,13 @@ int try_move(int i, int x, int y, int nx, int ny)
|
|||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
if(parts[i].type == PT_PHOT)
|
if(parts[i].type == PT_PHOT)
|
||||||
return 1;
|
return 1;
|
||||||
|
|
||||||
e = r >> 8;
|
e = r >> 8;
|
||||||
if(r && e<NPART)
|
if(r && e<NPART)
|
||||||
{
|
{
|
||||||
if(parts[e].type == PT_PHOT)
|
if(parts[e].type == PT_PHOT)
|
||||||
return 1;
|
return 1;
|
||||||
|
|
||||||
parts[e].x += x-nx;
|
parts[e].x += x-nx;
|
||||||
parts[e].y += y-ny;
|
parts[e].y += y-ny;
|
||||||
@ -327,7 +332,7 @@ int get_normal_interp(int pt, float x0, float y0, float dx, float dy, float *nx,
|
|||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
if(pt == PT_PHOT)
|
if(pt == PT_PHOT)
|
||||||
photoelectric_effect(x, y);
|
photoelectric_effect(x, y);
|
||||||
|
|
||||||
return get_normal(pt, x, y, dx, dy, nx, ny);
|
return get_normal(pt, x, y, dx, dy, nx, ny);
|
||||||
}
|
}
|
||||||
@ -337,11 +342,11 @@ void kill_part(int i)
|
|||||||
int x, y;
|
int x, y;
|
||||||
|
|
||||||
if(parts[i].type != PT_PHOT) {
|
if(parts[i].type != PT_PHOT) {
|
||||||
x = (int)(parts[i].x+0.5f);
|
x = (int)(parts[i].x+0.5f);
|
||||||
y = (int)(parts[i].y+0.5f);
|
y = (int)(parts[i].y+0.5f);
|
||||||
|
|
||||||
if(x>=0 && y>=0 && x<XRES && y<YRES)
|
if(x>=0 && y>=0 && x<XRES && y<YRES)
|
||||||
pmap[y][x] = 0;
|
pmap[y][x] = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
parts[i].type = PT_NONE;
|
parts[i].type = PT_NONE;
|
||||||
@ -421,7 +426,7 @@ inline int create_part(int p, int x, int y, int t)
|
|||||||
(pmap[y][x]&0xFF)!=PT_ETRD &&
|
(pmap[y][x]&0xFF)!=PT_ETRD &&
|
||||||
(pmap[y][x]&0xFF)!=PT_BRMT &&
|
(pmap[y][x]&0xFF)!=PT_BRMT &&
|
||||||
(pmap[y][x]&0xFF)!=PT_NBLE &&
|
(pmap[y][x]&0xFF)!=PT_NBLE &&
|
||||||
(pmap[y][x]&0xFF)!=PT_IRON &&
|
(pmap[y][x]&0xFF)!=PT_IRON &&
|
||||||
(pmap[y][x]&0xFF)!=PT_INWR)
|
(pmap[y][x]&0xFF)!=PT_INWR)
|
||||||
return -1;
|
return -1;
|
||||||
parts[pmap[y][x]>>8].type = PT_SPRK;
|
parts[pmap[y][x]>>8].type = PT_SPRK;
|
||||||
@ -500,15 +505,15 @@ inline int create_part(int p, int x, int y, int t)
|
|||||||
parts[i].vx = r*cosf(a);
|
parts[i].vx = r*cosf(a);
|
||||||
parts[i].vy = r*sinf(a);
|
parts[i].vy = r*sinf(a);
|
||||||
}
|
}
|
||||||
if(t==PT_MORT)
|
if(t==PT_MORT)
|
||||||
{
|
{
|
||||||
parts[i].vx = 2;
|
parts[i].vx = 2;
|
||||||
}
|
}
|
||||||
if(t==PT_PHOT)
|
if(t==PT_PHOT)
|
||||||
{
|
{
|
||||||
float a = (rand()%8) * 0.78540f;
|
float a = (rand()%8) * 0.78540f;
|
||||||
parts[i].life = 680;
|
parts[i].life = 680;
|
||||||
parts[i].ctype = 0x3FFFFFFF;
|
parts[i].ctype = 0x3FFFFFFF;
|
||||||
parts[i].vx = 3.0f*cosf(a);
|
parts[i].vx = 3.0f*cosf(a);
|
||||||
parts[i].vy = 3.0f*sinf(a);
|
parts[i].vy = 3.0f*sinf(a);
|
||||||
}
|
}
|
||||||
@ -569,10 +574,10 @@ static void create_gain_photon(int pp)
|
|||||||
lr = rand() % 2;
|
lr = rand() % 2;
|
||||||
|
|
||||||
if(lr) {
|
if(lr) {
|
||||||
xx = parts[pp].x - 0.3*parts[pp].vy;
|
xx = parts[pp].x - 0.3*parts[pp].vy;
|
||||||
yy = parts[pp].y + 0.3*parts[pp].vx;
|
yy = parts[pp].y + 0.3*parts[pp].vx;
|
||||||
} else {
|
} else {
|
||||||
xx = parts[pp].x + 0.3*parts[pp].vy;
|
xx = parts[pp].x + 0.3*parts[pp].vy;
|
||||||
yy = parts[pp].y - 0.3*parts[pp].vx;
|
yy = parts[pp].y - 0.3*parts[pp].vx;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -580,10 +585,10 @@ static void create_gain_photon(int pp)
|
|||||||
ny = (int)(yy + 0.5f);
|
ny = (int)(yy + 0.5f);
|
||||||
|
|
||||||
if(nx<0 || ny<0 || nx>=XRES || ny>=YRES)
|
if(nx<0 || ny<0 || nx>=XRES || ny>=YRES)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if((pmap[ny][nx] & 0xFF) != PT_GLOW)
|
if((pmap[ny][nx] & 0xFF) != PT_GLOW)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
pfree = parts[i].life;
|
pfree = parts[i].life;
|
||||||
|
|
||||||
@ -614,10 +619,10 @@ static void create_cherenkov_photon(int pp)
|
|||||||
nx = (int)(parts[pp].x + 0.5f);
|
nx = (int)(parts[pp].x + 0.5f);
|
||||||
ny = (int)(parts[pp].y + 0.5f);
|
ny = (int)(parts[pp].y + 0.5f);
|
||||||
if((pmap[ny][nx] & 0xFF) != PT_GLAS)
|
if((pmap[ny][nx] & 0xFF) != PT_GLAS)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if(hypotf(parts[pp].vx, parts[pp].vy) < 1.44f)
|
if(hypotf(parts[pp].vx, parts[pp].vy) < 1.44f)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
pfree = parts[i].life;
|
pfree = parts[i].life;
|
||||||
|
|
||||||
@ -632,11 +637,11 @@ static void create_cherenkov_photon(int pp)
|
|||||||
parts[i].tmp = 0;
|
parts[i].tmp = 0;
|
||||||
|
|
||||||
if(lr) {
|
if(lr) {
|
||||||
parts[i].vx = parts[pp].vx - 2.5f*parts[pp].vy;
|
parts[i].vx = parts[pp].vx - 2.5f*parts[pp].vy;
|
||||||
parts[i].vy = parts[pp].vy + 2.5f*parts[pp].vx;
|
parts[i].vy = parts[pp].vy + 2.5f*parts[pp].vx;
|
||||||
} else {
|
} else {
|
||||||
parts[i].vx = parts[pp].vx + 2.5f*parts[pp].vy;
|
parts[i].vx = parts[pp].vx + 2.5f*parts[pp].vy;
|
||||||
parts[i].vy = parts[pp].vy - 2.5f*parts[pp].vx;
|
parts[i].vy = parts[pp].vy - 2.5f*parts[pp].vx;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* photons have speed of light. no discussion. */
|
/* photons have speed of light. no discussion. */
|
||||||
@ -686,18 +691,18 @@ int get_wavelength_bin(int *wm)
|
|||||||
int i, w0=30, wM=0;
|
int i, w0=30, wM=0;
|
||||||
|
|
||||||
if(!*wm)
|
if(!*wm)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
for(i=0; i<30; i++)
|
for(i=0; i<30; i++)
|
||||||
if(*wm & (1<<i)) {
|
if(*wm & (1<<i)) {
|
||||||
if(i < w0)
|
if(i < w0)
|
||||||
w0 = i;
|
w0 = i;
|
||||||
if(i > wM)
|
if(i > wM)
|
||||||
wM = i;
|
wM = i;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(wM-w0 < 5)
|
if(wM-w0 < 5)
|
||||||
return (wM+w0)/2;
|
return (wM+w0)/2;
|
||||||
|
|
||||||
i = rand() % (wM-w0-3);
|
i = rand() % (wM-w0-3);
|
||||||
i += w0;
|
i += w0;
|
||||||
@ -1288,67 +1293,67 @@ void update_particles_i(pixel *vid, int start, int inc)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if(t==PT_BMTL){
|
else if(t==PT_BMTL) {
|
||||||
if(parts[i].tmp>1){
|
if(parts[i].tmp>1) {
|
||||||
parts[i].tmp--;
|
parts[i].tmp--;
|
||||||
for(nx=-1; nx<2; nx++)
|
for(nx=-1; nx<2; nx++)
|
||||||
for(ny=-1; ny<2; ny++)
|
for(ny=-1; ny<2; ny++)
|
||||||
if(x+nx>=0 && y+ny>0 && x+nx<XRES && y+ny<YRES && (nx || ny))
|
if(x+nx>=0 && y+ny>0 && x+nx<XRES && y+ny<YRES && (nx || ny))
|
||||||
{
|
{
|
||||||
r = pmap[y+ny][x+nx];
|
r = pmap[y+ny][x+nx];
|
||||||
if((r>>8)>=NPART || !r)
|
if((r>>8)>=NPART || !r)
|
||||||
continue;
|
continue;
|
||||||
rt =parts[r>>8].type;
|
rt =parts[r>>8].type;
|
||||||
if((rt==PT_METL || rt==PT_IRON) && 1>(rand()/(RAND_MAX/100)))
|
if((rt==PT_METL || rt==PT_IRON) && 1>(rand()/(RAND_MAX/100)))
|
||||||
{
|
{
|
||||||
parts[r>>8].type=PT_BMTL;
|
parts[r>>8].type=PT_BMTL;
|
||||||
parts[r>>8].tmp=(parts[i].tmp<=7)?parts[i].tmp=1:parts[i].tmp-(rand()%5);//rand()/(RAND_MAX/300)+100;
|
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){
|
} else if(parts[i].tmp==1 && 1>rand()%1000) {
|
||||||
parts[i].tmp = 0;
|
parts[i].tmp = 0;
|
||||||
t = parts[i].type = PT_BRMT;
|
t = parts[i].type = PT_BRMT;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
else if(t==PT_IRON){
|
else if(t==PT_IRON) {
|
||||||
for(nx=-1; nx<2; nx++)
|
for(nx=-1; nx<2; nx++)
|
||||||
for(ny=-1; ny<2; ny++)
|
for(ny=-1; ny<2; ny++)
|
||||||
if(x+nx>=0 && y+ny>0 && x+nx<XRES && y+ny<YRES && (nx || ny))
|
if(x+nx>=0 && y+ny>0 && x+nx<XRES && y+ny<YRES && (nx || ny))
|
||||||
{
|
{
|
||||||
r = pmap[y+ny][x+nx];
|
r = pmap[y+ny][x+nx];
|
||||||
if((r>>8)>=NPART || !r)
|
if((r>>8)>=NPART || !r)
|
||||||
continue;
|
continue;
|
||||||
if((((r&0xFF) == PT_SALT && 15>(rand()/(RAND_MAX/700))) ||
|
if((((r&0xFF) == PT_SALT && 15>(rand()/(RAND_MAX/700))) ||
|
||||||
((r&0xFF) == PT_SLTW && 30>(rand()/(RAND_MAX/2000))) ||
|
((r&0xFF) == PT_SLTW && 30>(rand()/(RAND_MAX/2000))) ||
|
||||||
((r&0xFF) == PT_WATR && 5 >(rand()/(RAND_MAX/6000))) ||
|
((r&0xFF) == PT_WATR && 5 >(rand()/(RAND_MAX/6000))) ||
|
||||||
((r&0xFF) == PT_O2 && 2 >(rand()/(RAND_MAX/500))) ||
|
((r&0xFF) == PT_O2 && 2 >(rand()/(RAND_MAX/500))) ||
|
||||||
((r&0xFF) == PT_LO2))&&
|
((r&0xFF) == PT_LO2))&&
|
||||||
(!(parts[i].life))
|
(!(parts[i].life))
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
parts[i].type=PT_BMTL;
|
parts[i].type=PT_BMTL;
|
||||||
parts[i].tmp=(rand()/(RAND_MAX/10))+20;
|
parts[i].tmp=(rand()/(RAND_MAX/10))+20;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if((t==PT_SPRK||parts[i].type==PT_SPRK) && parts[i].ctype==PT_IRON){
|
else if((t==PT_SPRK||parts[i].type==PT_SPRK) && parts[i].ctype==PT_IRON) {
|
||||||
for(nx=-1; nx<2; nx++)
|
for(nx=-1; nx<2; nx++)
|
||||||
for(ny=-1; ny<2; ny++)
|
for(ny=-1; ny<2; ny++)
|
||||||
if(x+nx>=0 && y+ny>0 && x+nx<XRES && y+ny<YRES && (nx || ny))
|
if(x+nx>=0 && y+ny>0 && x+nx<XRES && y+ny<YRES && (nx || ny))
|
||||||
{
|
{
|
||||||
r = pmap[y+ny][x+nx];
|
r = pmap[y+ny][x+nx];
|
||||||
if((r>>8)>=NPART || !r)
|
if((r>>8)>=NPART || !r)
|
||||||
continue;
|
continue;
|
||||||
if(((r&0xFF) == PT_DSTW && 30>(rand()/(RAND_MAX/1000))) ||
|
if(((r&0xFF) == PT_DSTW && 30>(rand()/(RAND_MAX/1000))) ||
|
||||||
((r&0xFF) == PT_SLTW && 30>(rand()/(RAND_MAX/1000))) ||
|
((r&0xFF) == PT_SLTW && 30>(rand()/(RAND_MAX/1000))) ||
|
||||||
((r&0xFF) == PT_WATR && 30>(rand()/(RAND_MAX/1000))))
|
((r&0xFF) == PT_WATR && 30>(rand()/(RAND_MAX/1000))))
|
||||||
{
|
{
|
||||||
parts[r>>8].type=PT_O2;
|
parts[r>>8].type=PT_O2;
|
||||||
//parts[r>>8].tmp=(rand()/(RAND_MAX/10))+20;
|
//parts[r>>8].tmp=(rand()/(RAND_MAX/10))+20;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if(t==PT_COAL)
|
else if(t==PT_COAL)
|
||||||
{
|
{
|
||||||
if(parts[i].life<=0) {
|
if(parts[i].life<=0) {
|
||||||
@ -1420,15 +1425,15 @@ void update_particles_i(pixel *vid, int start, int inc)
|
|||||||
//t = parts[i].life = PT_NONE;
|
//t = parts[i].life = PT_NONE;
|
||||||
kill_part(i);
|
kill_part(i);
|
||||||
r = create_part(-1, x, y, PT_PLSM);
|
r = create_part(-1, x, y, PT_PLSM);
|
||||||
if(r!=-1)
|
if(r!=-1)
|
||||||
parts[r].life = 50;
|
parts[r].life = 50;
|
||||||
//goto killed;
|
//goto killed;
|
||||||
} else if (parts[i].life < 40) {
|
} else if (parts[i].life < 40) {
|
||||||
parts[i].life--;
|
parts[i].life--;
|
||||||
if((rand()%100)==0) {
|
if((rand()%100)==0) {
|
||||||
r = create_part(-1, (nx=x+rand()%3-1), (ny=y+rand()%3-1), PT_PLSM);
|
r = create_part(-1, (nx=x+rand()%3-1), (ny=y+rand()%3-1), PT_PLSM);
|
||||||
if(r!=-1)
|
if(r!=-1)
|
||||||
parts[r].life = 50;
|
parts[r].life = 50;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if((pv[y/CELL][x/CELL] > 2.7f)&&parts[i].tmp>40)
|
if((pv[y/CELL][x/CELL] > 2.7f)&&parts[i].tmp>40)
|
||||||
@ -1463,15 +1468,15 @@ void update_particles_i(pixel *vid, int start, int inc)
|
|||||||
//t = PT_NONE;
|
//t = PT_NONE;
|
||||||
kill_part(i);
|
kill_part(i);
|
||||||
r = create_part(-1, x, y, PT_PLSM);
|
r = create_part(-1, x, y, PT_PLSM);
|
||||||
if(r!=-1)
|
if(r!=-1)
|
||||||
parts[r].life = 50;
|
parts[r].life = 50;
|
||||||
//goto killed;
|
//goto killed;
|
||||||
} else if (parts[i].life < 40) {
|
} else if (parts[i].life < 40) {
|
||||||
parts[i].life--;
|
parts[i].life--;
|
||||||
if((rand()%10)==0) {
|
if((rand()%10)==0) {
|
||||||
r = create_part(-1, (nx=x+rand()%3-1), (ny=y+rand()%3-1), PT_PLSM);
|
r = create_part(-1, (nx=x+rand()%3-1), (ny=y+rand()%3-1), PT_PLSM);
|
||||||
if(r!=-1)
|
if(r!=-1)
|
||||||
parts[r].life = 50;
|
parts[r].life = 50;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
for(nx=-2; nx<3; nx++)
|
for(nx=-2; nx<3; nx++)
|
||||||
@ -1777,9 +1782,9 @@ void update_particles_i(pixel *vid, int start, int inc)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if(t==PT_MORT){
|
else if(t==PT_MORT) {
|
||||||
create_part(-1, x, y-1, PT_SMKE);
|
create_part(-1, x, y-1, PT_SMKE);
|
||||||
}
|
}
|
||||||
else if(t==PT_LCRY)
|
else if(t==PT_LCRY)
|
||||||
{
|
{
|
||||||
for(nx=-1; nx<2; nx++)
|
for(nx=-1; nx<2; nx++)
|
||||||
@ -1946,7 +1951,7 @@ void update_particles_i(pixel *vid, int start, int inc)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if(parts[i].tmp==2) {
|
else if(parts[i].tmp==2) {
|
||||||
int col = rand()%200+4;
|
int col = rand()%200+4;
|
||||||
for(nx=-2; nx<3; nx++) {
|
for(nx=-2; nx<3; nx++) {
|
||||||
for(ny=-2; ny<3; ny++) {
|
for(ny=-2; ny<3; ny++) {
|
||||||
if(x+nx>=0 && y+ny>0 && x+nx<XRES && y+ny<YRES && (nx || ny))
|
if(x+nx>=0 && y+ny>0 && x+nx<XRES && y+ny<YRES && (nx || ny))
|
||||||
@ -2040,7 +2045,7 @@ void update_particles_i(pixel *vid, int start, int inc)
|
|||||||
continue;
|
continue;
|
||||||
rt = parts[r>>8].type;
|
rt = parts[r>>8].type;
|
||||||
if((a || ptypes[rt].explosive) && ((rt!=PT_RBDM && rt!=PT_LRBD && rt!=PT_INSL && rt!=PT_SWCH) || t!=PT_SPRK) &&
|
if((a || ptypes[rt].explosive) && ((rt!=PT_RBDM && rt!=PT_LRBD && rt!=PT_INSL && rt!=PT_SWCH) || t!=PT_SPRK) &&
|
||||||
!(t==PT_PHOT && rt==PT_INSL) &&
|
!(t==PT_PHOT && rt==PT_INSL) &&
|
||||||
(t!=PT_LAVA || parts[i].life>0 || (rt!=PT_STNE && rt!=PT_PSCN && rt!=PT_NSCN && rt!=PT_NTCT && rt!=PT_PTCT && rt!=PT_METL && rt!=PT_IRON && rt!=PT_ETRD && rt!=PT_BMTL && rt!=PT_BRMT && rt!=PT_SWCH && rt!=PT_INWR)) &&
|
(t!=PT_LAVA || parts[i].life>0 || (rt!=PT_STNE && rt!=PT_PSCN && rt!=PT_NSCN && rt!=PT_NTCT && rt!=PT_PTCT && rt!=PT_METL && rt!=PT_IRON && rt!=PT_ETRD && rt!=PT_BMTL && rt!=PT_BRMT && rt!=PT_SWCH && rt!=PT_INWR)) &&
|
||||||
ptypes[rt].flammable && (ptypes[rt].flammable + (int)(pv[(y+ny)/CELL][(x+nx)/CELL]*10.0f))>(rand()%1000))
|
ptypes[rt].flammable && (ptypes[rt].flammable + (int)(pv[(y+ny)/CELL][(x+nx)/CELL]*10.0f))>(rand()%1000))
|
||||||
{
|
{
|
||||||
@ -2621,8 +2626,8 @@ killed:
|
|||||||
parts[i].ctype = pmap[y+ny][x+nx]&0xFF;
|
parts[i].ctype = pmap[y+ny][x+nx]&0xFF;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
create_part(-1, x+rand()%3-1, y+rand()%3-1, parts[i].ctype);
|
create_part(-1, x+rand()%3-1, y+rand()%3-1, parts[i].ctype);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
if(parts[i].type==PT_PCLN)
|
if(parts[i].type==PT_PCLN)
|
||||||
@ -2641,21 +2646,21 @@ killed:
|
|||||||
(pmap[y+ny][x+nx]&0xFF)!=PT_STKM &&
|
(pmap[y+ny][x+nx]&0xFF)!=PT_STKM &&
|
||||||
(pmap[y+ny][x+nx]&0xFF)!=0xFF)
|
(pmap[y+ny][x+nx]&0xFF)!=0xFF)
|
||||||
parts[i].ctype = pmap[y+ny][x+nx]&0xFF;
|
parts[i].ctype = pmap[y+ny][x+nx]&0xFF;
|
||||||
if(parts[i].ctype && parts[i].life==10){
|
if(parts[i].ctype && parts[i].life==10) {
|
||||||
if(parts[i].ctype==PT_PHOT){
|
if(parts[i].ctype==PT_PHOT) {
|
||||||
for(nx=-1; nx<2; nx++){
|
for(nx=-1; nx<2; nx++) {
|
||||||
for(ny=-1; ny<2; ny++){
|
for(ny=-1; ny<2; ny++) {
|
||||||
r = create_part(-1, x+nx, y+ny, parts[i].ctype);
|
r = create_part(-1, x+nx, y+ny, parts[i].ctype);
|
||||||
if(r!=-1){
|
if(r!=-1) {
|
||||||
parts[r].vx = nx*3;
|
parts[r].vx = nx*3;
|
||||||
parts[r].vy = ny*3;
|
parts[r].vy = ny*3;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
create_part(-1, x+rand()%3-1, y+rand()%3-1, parts[i].ctype);
|
create_part(-1, x+rand()%3-1, y+rand()%3-1, parts[i].ctype);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if(t==PT_YEST)
|
if(t==PT_YEST)
|
||||||
{
|
{
|
||||||
@ -2697,7 +2702,7 @@ killed:
|
|||||||
|
|
||||||
lt = pmap[y][x] & 0xFF;
|
lt = pmap[y][x] & 0xFF;
|
||||||
|
|
||||||
r = eval_move(PT_PHOT, nx, ny, NULL);
|
r = eval_move(PT_PHOT, nx, ny, NULL);
|
||||||
|
|
||||||
if(((rt==PT_GLAS && lt!=PT_GLAS) || (rt!=PT_GLAS && lt==PT_GLAS)) && r) {
|
if(((rt==PT_GLAS && lt!=PT_GLAS) || (rt!=PT_GLAS && lt==PT_GLAS)) && r) {
|
||||||
if(!get_normal_interp(REFRACT|parts[i].type, x, y, parts[i].vx, parts[i].vy, &nrx, &nry)) {
|
if(!get_normal_interp(REFRACT|parts[i].type, x, y, parts[i].vx, parts[i].vy, &nrx, &nry)) {
|
||||||
@ -2705,13 +2710,13 @@ killed:
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
r = get_wavelength_bin(&parts[i].ctype);
|
r = get_wavelength_bin(&parts[i].ctype);
|
||||||
if(r == -1) {
|
if(r == -1) {
|
||||||
kill_part(i);
|
kill_part(i);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
nn = GLASS_IOR - GLASS_DISP*(r-15)/15.0f;
|
nn = GLASS_IOR - GLASS_DISP*(r-15)/15.0f;
|
||||||
nn *= nn;
|
nn *= nn;
|
||||||
|
|
||||||
nrx = -nrx;
|
nrx = -nrx;
|
||||||
nry = -nry;
|
nry = -nry;
|
||||||
@ -2722,10 +2727,10 @@ killed:
|
|||||||
if(ct2 < 0.0f) {
|
if(ct2 < 0.0f) {
|
||||||
parts[i].vx -= 2.0f*ct1*nrx;
|
parts[i].vx -= 2.0f*ct1*nrx;
|
||||||
parts[i].vy -= 2.0f*ct1*nry;
|
parts[i].vy -= 2.0f*ct1*nry;
|
||||||
parts[i].x = lx;
|
parts[i].x = lx;
|
||||||
parts[i].y = ly;
|
parts[i].y = ly;
|
||||||
nx = (int)(lx + 0.5f);
|
nx = (int)(lx + 0.5f);
|
||||||
ny = (int)(ly + 0.5f);
|
ny = (int)(ly + 0.5f);
|
||||||
} else {
|
} else {
|
||||||
ct2 = sqrtf(ct2);
|
ct2 = sqrtf(ct2);
|
||||||
ct2 = ct2 - nn*ct1;
|
ct2 = ct2 - nn*ct1;
|
||||||
@ -2855,25 +2860,25 @@ killed:
|
|||||||
}
|
}
|
||||||
else if(t==PT_NEUT || t==PT_PHOT)
|
else if(t==PT_NEUT || t==PT_PHOT)
|
||||||
{
|
{
|
||||||
r = pmap[ny][nx];
|
r = pmap[ny][nx];
|
||||||
|
|
||||||
/* this should be replaced with a particle type attribute ("photwl" or something) */
|
/* this should be replaced with a particle type attribute ("photwl" or something) */
|
||||||
if((r & 0xFF) == PT_PSCN) parts[i].ctype = 0x00000000;
|
if((r & 0xFF) == PT_PSCN) parts[i].ctype = 0x00000000;
|
||||||
if((r & 0xFF) == PT_NSCN) parts[i].ctype = 0x00000000;
|
if((r & 0xFF) == PT_NSCN) parts[i].ctype = 0x00000000;
|
||||||
if((r & 0xFF) == PT_SPRK) parts[i].ctype = 0x00000000;
|
if((r & 0xFF) == PT_SPRK) parts[i].ctype = 0x00000000;
|
||||||
if((r & 0xFF) == PT_COAL) parts[i].ctype = 0x00000000;
|
if((r & 0xFF) == PT_COAL) parts[i].ctype = 0x00000000;
|
||||||
if((r & 0xFF) == PT_BCOL) parts[i].ctype = 0x00000000;
|
if((r & 0xFF) == PT_BCOL) parts[i].ctype = 0x00000000;
|
||||||
if((r & 0xFF) == PT_PLEX) parts[i].ctype &= 0x1F00003E;
|
if((r & 0xFF) == PT_PLEX) parts[i].ctype &= 0x1F00003E;
|
||||||
if((r & 0xFF) == PT_NITR) parts[i].ctype &= 0x0007C000;
|
if((r & 0xFF) == PT_NITR) parts[i].ctype &= 0x0007C000;
|
||||||
if((r & 0xFF) == PT_NBLE) parts[i].ctype &= 0x3FFF8000;
|
if((r & 0xFF) == PT_NBLE) parts[i].ctype &= 0x3FFF8000;
|
||||||
if((r & 0xFF) == PT_LAVA) parts[i].ctype &= 0x3FF00000;
|
if((r & 0xFF) == PT_LAVA) parts[i].ctype &= 0x3FF00000;
|
||||||
if((r & 0xFF) == PT_ACID) parts[i].ctype &= 0x1FE001FE;
|
if((r & 0xFF) == PT_ACID) parts[i].ctype &= 0x1FE001FE;
|
||||||
if((r & 0xFF) == PT_DUST) parts[i].ctype &= 0x3FFFFFC0;
|
if((r & 0xFF) == PT_DUST) parts[i].ctype &= 0x3FFFFFC0;
|
||||||
if((r & 0xFF) == PT_SNOW) parts[i].ctype &= 0x03FFFFFF;
|
if((r & 0xFF) == PT_SNOW) parts[i].ctype &= 0x03FFFFFF;
|
||||||
if((r & 0xFF) == PT_GOO) parts[i].ctype &= 0x3FFAAA00;
|
if((r & 0xFF) == PT_GOO) parts[i].ctype &= 0x3FFAAA00;
|
||||||
if((r & 0xFF) == PT_PLNT) parts[i].ctype &= 0x0007C000;
|
if((r & 0xFF) == PT_PLNT) parts[i].ctype &= 0x0007C000;
|
||||||
if((r & 0xFF) == PT_PLUT) parts[i].ctype &= 0x001FCE00;
|
if((r & 0xFF) == PT_PLUT) parts[i].ctype &= 0x001FCE00;
|
||||||
if((r & 0xFF) == PT_URAN) parts[i].ctype &= 0x003FC000;
|
if((r & 0xFF) == PT_URAN) parts[i].ctype &= 0x003FC000;
|
||||||
|
|
||||||
if(get_normal_interp(t, lx, ly, parts[i].vx, parts[i].vy, &nrx, &nry)) {
|
if(get_normal_interp(t, lx, ly, parts[i].vx, parts[i].vy, &nrx, &nry)) {
|
||||||
dp = nrx*parts[i].vx + nry*parts[i].vy;
|
dp = nrx*parts[i].vx + nry*parts[i].vy;
|
||||||
@ -2893,10 +2898,10 @@ killed:
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!parts[i].ctype) {
|
if(!parts[i].ctype) {
|
||||||
kill_part(i);
|
kill_part(i);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
else
|
else
|
||||||
@ -2958,9 +2963,9 @@ void update_particles(pixel *vid)
|
|||||||
x = (int)(parts[i].x+0.5f);
|
x = (int)(parts[i].x+0.5f);
|
||||||
y = (int)(parts[i].y+0.5f);
|
y = (int)(parts[i].y+0.5f);
|
||||||
if(x>=0 && y>=0 && x<XRES && y<YRES && t!=PT_PHOT) {
|
if(x>=0 && y>=0 && x<XRES && y<YRES && t!=PT_PHOT) {
|
||||||
if(t!=PT_NEUT || (pmap[y][x]&0xFF)!=PT_GLAS)
|
if(t!=PT_NEUT || (pmap[y][x]&0xFF)!=PT_GLAS)
|
||||||
pmap[y][x] = t|(i<<8);
|
pmap[y][x] = t|(i<<8);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
Reference in New Issue
Block a user