New def token for "multipsky": "yscale".

multipsky <tile> { yscale <yscale> }

Default value is 65536.

Patch from Fox.

git-svn-id: https://svn.eduke32.com/eduke32@6519 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
hendricks266 2017-11-29 07:29:48 +00:00
parent 6164e3dae8
commit 5fbe1b89be
6 changed files with 25 additions and 10 deletions

View file

@ -727,6 +727,8 @@ typedef struct {
int8_t lognumtiles; // 1<<lognumtiles: number of tiles in multi-sky int8_t lognumtiles; // 1<<lognumtiles: number of tiles in multi-sky
int8_t tileofs[MAXPSKYTILES]; // for 0 <= j < (1<<lognumtiles): tile offset relative to basetile int8_t tileofs[MAXPSKYTILES]; // for 0 <= j < (1<<lognumtiles): tile offset relative to basetile
int32_t yscale;
} psky_t; } psky_t;
// Index of map-global (legacy) multi-sky: // Index of map-global (legacy) multi-sky:

View file

@ -2646,6 +2646,7 @@ static int32_t defsparser(scriptfile *script)
{ "lognumtiles", T_LOGNUMTILES }, { "lognumtiles", T_LOGNUMTILES },
{ "tile", T_TILE }, { "tile", T_TILE },
{ "panel", T_TILE }, { "panel", T_TILE },
{ "yscale", T_YSCALE },
}; };
if (scriptfile_getsymbol(script,&tile)) if (scriptfile_getsymbol(script,&tile))
@ -2708,6 +2709,14 @@ static int32_t defsparser(scriptfile *script)
newpsky->tileofs[panel] = offset; newpsky->tileofs[panel] = offset;
break; break;
} }
case T_YSCALE:
{
int32_t yscale;
scriptfile_getsymbol(script,&yscale);
newpsky->yscale = yscale;
break;
}
default: default:
break; break;
} }

View file

@ -3618,8 +3618,8 @@ static void parascan(int32_t dax1, int32_t dax2, int32_t sectnum, char dastat, i
return; return;
int32_t dapyscale, dapskybits, dapyoffs; int32_t dapyscale, dapskybits, dapyoffs, daptileyscale;
int8_t const * const dapskyoff = getpsky(globalpicnum, &dapyscale, &dapskybits, &dapyoffs); int8_t const * const dapskyoff = getpsky(globalpicnum, &dapyscale, &dapskybits, &dapyoffs, &daptileyscale);
globalshiftval = logtilesizy; globalshiftval = logtilesizy;
@ -3642,6 +3642,7 @@ static void parascan(int32_t dax1, int32_t dax2, int32_t sectnum, char dastat, i
globalyscale = (8<<(globalshiftval-19)); globalyscale = (8<<(globalshiftval-19));
globalzd = (((tsizy>>1)+dapyoffs)<<globalshiftval) + ((uint32_t)globalypanning<<24); globalzd = (((tsizy>>1)+dapyoffs)<<globalshiftval) + ((uint32_t)globalypanning<<24);
} }
globalyscale = divscale16(globalyscale,daptileyscale);
//if (globalorientation&256) globalyscale = -globalyscale, globalzd = -globalzd; //if (globalorientation&256) globalyscale = -globalyscale, globalzd = -globalzd;
@ -7514,6 +7515,7 @@ psky_t * E_DefinePsky(int32_t const tilenum)
psky_t * const newPsky = &multipsky[newPskyID]; psky_t * const newPsky = &multipsky[newPskyID];
Bmemset(newPsky, 0, sizeof(psky_t)); Bmemset(newPsky, 0, sizeof(psky_t));
multipskytile[newPskyID] = tilenum; multipskytile[newPskyID] = tilenum;
newPsky->yscale = 65536;
return newPsky; return newPsky;
} }

View file

@ -372,7 +372,7 @@ static FORCE_INLINE void setgotpic(int32_t tilenume)
// Get properties of parallaxed sky to draw. // Get properties of parallaxed sky to draw.
// Returns: pointer to tile offset array. Sets-by-pointer the other three. // Returns: pointer to tile offset array. Sets-by-pointer the other three.
static FORCE_INLINE const int8_t *getpsky(int32_t picnum, int32_t *dapyscale, int32_t *dapskybits, int32_t *dapyoffs) static FORCE_INLINE const int8_t *getpsky(int32_t picnum, int32_t *dapyscale, int32_t *dapskybits, int32_t *dapyoffs, int32_t *daptileyscale)
{ {
psky_t const * const psky = &multipsky[getpskyidx(picnum)]; psky_t const * const psky = &multipsky[getpskyidx(picnum)];
@ -382,6 +382,8 @@ static FORCE_INLINE const int8_t *getpsky(int32_t picnum, int32_t *dapyscale, in
*dapyscale = (parallaxyscale_override == 0 ? psky->horizfrac : parallaxyscale_override); *dapyscale = (parallaxyscale_override == 0 ? psky->horizfrac : parallaxyscale_override);
if (dapyoffs) if (dapyoffs)
*dapyoffs = psky->yoffs + parallaxyoffs_override; *dapyoffs = psky->yoffs + parallaxyoffs_override;
if (daptileyscale)
*daptileyscale = psky->yscale;
return psky->tileofs; return psky->tileofs;
} }

View file

@ -4102,7 +4102,7 @@ static void polymer_getsky(void)
curskypal = sector[i].ceilingpal; curskypal = sector[i].ceilingpal;
curskyshade = sector[i].ceilingshade; curskyshade = sector[i].ceilingshade;
getpsky(cursky, &horizfrac, NULL, NULL); getpsky(cursky, &horizfrac, NULL, NULL, NULL);
switch (horizfrac) switch (horizfrac)
{ {
@ -4178,7 +4178,7 @@ static void polymer_drawartsky(int16_t tilenum, char palnum, int8_t shad
GLfloat height = 2.45f / 2.0f; GLfloat height = 2.45f / 2.0f;
int32_t dapskybits; int32_t dapskybits;
const int8_t *dapskyoff = getpsky(tilenum, NULL, &dapskybits, NULL); const int8_t *dapskyoff = getpsky(tilenum, NULL, &dapskybits, NULL, NULL);
const int32_t numskytilesm1 = (1<<dapskybits)-1; const int32_t numskytilesm1 = (1<<dapskybits)-1;
i = 0; i = 0;

View file

@ -2976,8 +2976,8 @@ static void polymost_drawalls(int32_t const bunch)
DO_TILE_ANIM(globalpicnum, sectnum); DO_TILE_ANIM(globalpicnum, sectnum);
int32_t dapskybits, dapyoffs; int32_t dapskybits, dapyoffs, daptileyscale;
int8_t const * dapskyoff = getpsky(globalpicnum, NULL, &dapskybits, &dapyoffs); int8_t const * dapskyoff = getpsky(globalpicnum, NULL, &dapskybits, &dapyoffs, &daptileyscale);
global_cf_fogpal = sec->fogpal; global_cf_fogpal = sec->fogpal;
global_cf_shade = sec->floorshade, global_cf_pal = sec->floorpal; global_cf_z = sec->floorz; // REFACT global_cf_shade = sec->floorshade, global_cf_pal = sec->floorpal; global_cf_z = sec->floorz; // REFACT
@ -3006,7 +3006,7 @@ static void polymost_drawalls(int32_t const bunch)
float const dd = fxdimen*.0000001f; //Adjust sky depth based on screen size! float const dd = fxdimen*.0000001f; //Adjust sky depth based on screen size!
float vv[2]; float vv[2];
float t = (float)((1<<(picsiz[globalpicnum]&15))<<dapskybits); float t = (float)((1<<(picsiz[globalpicnum]&15))<<dapskybits);
vv[1] = dd*((float)xdimscale*fviewingrange) * (1.f/(65536.f*65536.f)); vv[1] = dd*((float)xdimscale*fviewingrange) * (1.f/(daptileyscale*65536.f));
vv[0] = dd*((float)((tilesiz[globalpicnum].y>>1)+dapyoffs)) - vv[1]*ghoriz; vv[0] = dd*((float)((tilesiz[globalpicnum].y>>1)+dapyoffs)) - vv[1]*ghoriz;
int i = (1<<(picsiz[globalpicnum]>>4)); if (i != tilesiz[globalpicnum].y) i += i; int i = (1<<(picsiz[globalpicnum]>>4)); if (i != tilesiz[globalpicnum].y) i += i;
vec3f_t o; vec3f_t o;
@ -3269,7 +3269,7 @@ static void polymost_drawalls(int32_t const bunch)
DO_TILE_ANIM(globalpicnum, sectnum); DO_TILE_ANIM(globalpicnum, sectnum);
dapskyoff = getpsky(globalpicnum, NULL, &dapskybits, &dapyoffs); dapskyoff = getpsky(globalpicnum, NULL, &dapskybits, &dapyoffs, &daptileyscale);
global_cf_fogpal = sec->fogpal; global_cf_fogpal = sec->fogpal;
global_cf_shade = sec->ceilingshade, global_cf_pal = sec->ceilingpal; global_cf_z = sec->ceilingz; // REFACT global_cf_shade = sec->ceilingshade, global_cf_pal = sec->ceilingpal; global_cf_z = sec->ceilingz; // REFACT
@ -3298,7 +3298,7 @@ static void polymost_drawalls(int32_t const bunch)
float const dd = fxdimen*.0000001f; //Adjust sky depth based on screen size! float const dd = fxdimen*.0000001f; //Adjust sky depth based on screen size!
float vv[2]; float vv[2];
float t = (float)((1<<(picsiz[globalpicnum]&15))<<dapskybits); float t = (float)((1<<(picsiz[globalpicnum]&15))<<dapskybits);
vv[1] = dd*((float)xdimscale*fviewingrange) * (1.f/(65536.f*65536.f)); vv[1] = dd*((float)xdimscale*fviewingrange) * (1.f/(daptileyscale*65536.f));
vv[0] = dd*((float)((tilesiz[globalpicnum].y>>1)+dapyoffs)) - vv[1]*ghoriz; vv[0] = dd*((float)((tilesiz[globalpicnum].y>>1)+dapyoffs)) - vv[1]*ghoriz;
int i = (1<<(picsiz[globalpicnum]>>4)); if (i != tilesiz[globalpicnum].y) i += i; int i = (1<<(picsiz[globalpicnum]>>4)); if (i != tilesiz[globalpicnum].y) i += i;
vec3f_t o; vec3f_t o;