From 5ea5f4bc9b2e7ddc9b2b6831acc65a05fce49149 Mon Sep 17 00:00:00 2001 From: terminx Date: Wed, 30 Sep 2009 21:46:07 +0000 Subject: [PATCH] Mapster32 SE40 and SE50 support (stfu frenchie!) git-svn-id: https://svn.eduke32.com/eduke32@1508 1a8010ca-5511-0410-912e-c29ae57300e0 --- polymer/eduke32/source/astub.c | 185 ++++++++++++++++++++++++++++++--- 1 file changed, 173 insertions(+), 12 deletions(-) diff --git a/polymer/eduke32/source/astub.c b/polymer/eduke32/source/astub.c index 25d7982fe..8d55572f8 100644 --- a/polymer/eduke32/source/astub.c +++ b/polymer/eduke32/source/astub.c @@ -102,6 +102,19 @@ static int32_t mouseaction=0, mouseax=0, mouseay=0; static int32_t repeatcountx, repeatcounty; static int32_t infobox=3; // bit0: current window, bit1: mouse pointer, the variable should be renamed +static char wallshades[MAXWALLS]; +static char sectorshades[MAXSECTORS][2]; +static char spriteshades[MAXSPRITES]; +static char wallpals[MAXWALLS]; +static char sectorpals[MAXSECTORS][2]; +static char spritepals[MAXSPRITES]; +static char wallflag[MAXWALLS]; +#ifdef POLYMER +static int16_t spritelightid[MAXSPRITES]; +_prlight *spritelightptr[MAXSPRITES]; +#endif +extern int32_t graphicsmode; + extern int32_t mskip; extern int16_t capturecount; extern int32_t editorgridextent; // in engine.c @@ -5969,6 +5982,14 @@ static void Keys3d(void) SetGAMEPalette(); FX_StopAllSounds(); S_ClearSoundLocks(); +#ifdef POLYMER + for (i=0;i= 0) + spritelightptr[i] = &prlights[spritelightid[i]]; + } + else + { + if (Bmemcmp(&sprite[i], spritelightptr[i], sizeof(vec3_t))) + { + Bmemcpy(spritelightptr[i], &sprite[i], sizeof(vec3_t)); + spritelightptr[i]->sector = sprite[i].sectnum; + spritelightptr[i]->flags.invalidate = 1; + } + if (SHT != spritelightptr[i]->range) + { + spritelightptr[i]->range = SHT; + spritelightptr[i]->flags.invalidate = 1; + } + if ((sprite[i].xvel != spritelightptr[i]->color[0]) || + (sprite[i].yvel != spritelightptr[i]->color[1]) || + (sprite[i].zvel != spritelightptr[i]->color[2])) + { + spritelightptr[i]->color[0] = sprite[i].xvel; + spritelightptr[i]->color[1] = sprite[i].yvel; + spritelightptr[i]->color[2] = sprite[i].zvel; + } + } + } + } + if (sprite[i].lotag == 50) + { + if (getrendermode() == 4) + { + if (spritelightptr[i] == NULL) + { +#pragma pack(push,1) + _prlight mylight; +#pragma pack(pop) + + mylight.sector = SECT; + Bmemcpy(&mylight, &sprite[i], sizeof(vec3_t)); + mylight.range = SHT; + mylight.color[0] = sprite[i].xvel; + mylight.color[1] = sprite[i].yvel; + mylight.color[2] = sprite[i].zvel; + mylight.radius = (256-(SS+128))<<1; + mylight.faderadius = (int16_t)(mylight.radius * 0.75f); + mylight.angle = SA; + mylight.horiz = SH; + mylight.minshade = sprite[i].xoffset; + mylight.maxshade = sprite[i].yoffset; + + if (CS & 2) + { + if (CS & 512) + mylight.priority = PR_LIGHT_PRIO_LOW; + else + mylight.priority = PR_LIGHT_PRIO_HIGH; + } + else + mylight.priority = PR_LIGHT_PRIO_MAX; + + spritelightid[i] = polymer_addlight(&mylight); + if (spritelightid[i] >= 0) + spritelightptr[i] = &prlights[spritelightid[i]]; + } + else + { + if (Bmemcmp(&sprite[i], spritelightptr[i], sizeof(vec3_t))) + { + Bmemcpy(spritelightptr[i], &sprite[i], sizeof(vec3_t)); + spritelightptr[i]->sector = sprite[i].sectnum; + spritelightptr[i]->flags.invalidate = 1; + } + if (SHT != spritelightptr[i]->range) + { + spritelightptr[i]->range = SHT; + spritelightptr[i]->flags.invalidate = 1; + } + if ((sprite[i].xvel != spritelightptr[i]->color[0]) || + (sprite[i].yvel != spritelightptr[i]->color[1]) || + (sprite[i].zvel != spritelightptr[i]->color[2])) + { + spritelightptr[i]->color[0] = sprite[i].xvel; + spritelightptr[i]->color[1] = sprite[i].yvel; + spritelightptr[i]->color[2] = sprite[i].zvel; + } + if (((256-(SS+128))<<1) != spritelightptr[i]->radius) + { + spritelightptr[i]->radius = (256-(SS+128))<<1; + spritelightptr[i]->faderadius = (int16_t)(spritelightptr[i]->radius * 0.75f); + spritelightptr[i]->flags.invalidate = 1; + } + if (SA != spritelightptr[i]->angle) + { + spritelightptr[i]->angle = SA; + spritelightptr[i]->flags.invalidate = 1; + } + if (SH != spritelightptr[i]->horiz) + { + spritelightptr[i]->horiz = SH; + spritelightptr[i]->flags.invalidate = 1; + } + } + } + } +#endif // POLYMER + } } if (floor_over_floor) SE40Code(pos.x,pos.y,pos.z,ang,horiz); if (purpleon) clearview(255); @@ -10746,7 +10906,8 @@ void ExtCheckKeys(void) if (sidemode != 1) { editinput(); - if (infobox&2)m32_showmouse(); + if (infobox&2) + m32_showmouse(); } } else Keys2d();