mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-14 11:50:49 +00:00
- sky code cleanup and transitioning of Duke's.
This commit is contained in:
parent
4598cf13d7
commit
2fd2ad2212
20 changed files with 127 additions and 273 deletions
|
@ -29,7 +29,6 @@ set( PCH_SOURCES
|
|||
src/blood.cpp
|
||||
src/callback.cpp
|
||||
src/choke.cpp
|
||||
src/common.cpp
|
||||
src/config.cpp
|
||||
src/controls.cpp
|
||||
src/credits.cpp
|
||||
|
|
|
@ -1,64 +0,0 @@
|
|||
//-------------------------------------------------------------------------
|
||||
/*
|
||||
Copyright (C) 2010-2019 EDuke32 developers and contributors
|
||||
Copyright (C) 2019 Nuke.YKT
|
||||
|
||||
This file is part of NBlood.
|
||||
|
||||
NBlood is free software; you can redistribute it and/or
|
||||
modify it under the terms of the GNU General Public License version 2
|
||||
as published by the Free Software Foundation.
|
||||
|
||||
This program is distributed in the hope that it will be useful,
|
||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||
|
||||
See the GNU General Public License for more details.
|
||||
|
||||
You should have received a copy of the GNU General Public License
|
||||
along with this program; if not, write to the Free Software
|
||||
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||
*/
|
||||
//-------------------------------------------------------------------------
|
||||
|
||||
//
|
||||
// Common non-engine code/data for EDuke32 and Mapster32
|
||||
//
|
||||
|
||||
#include "ns.h" // Must come before everything else!
|
||||
|
||||
#include "compat.h"
|
||||
#include "build.h"
|
||||
#include "baselayer.h"
|
||||
#include "cmdlib.h"
|
||||
#include "palette.h"
|
||||
#include "gamecvars.h"
|
||||
|
||||
|
||||
#include "common.h"
|
||||
#include "common_game.h"
|
||||
|
||||
BEGIN_BLD_NS
|
||||
|
||||
void G_SetupGlobalPsky(void)
|
||||
{
|
||||
int skyIdx = 0;
|
||||
|
||||
// NOTE: Loop must be running backwards for the same behavior as the game
|
||||
// (greatest sector index with matching parallaxed sky takes precedence).
|
||||
for (bssize_t i = numsectors - 1; i >= 0; i--)
|
||||
{
|
||||
if (sector[i].ceilingstat & 1)
|
||||
{
|
||||
skyIdx = getpskyidx(sector[i].ceilingpicnum);
|
||||
if (skyIdx > 0)
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
g_pskyidx = skyIdx;
|
||||
}
|
||||
|
||||
|
||||
|
||||
END_BLD_NS
|
|
@ -717,15 +717,11 @@ int dbLoadMap(const char *pPath, int *pX, int *pY, int *pZ, short *pAngle, short
|
|||
mapHeader.at23 = B_LITTLE16(mapHeader.at23);
|
||||
#endif
|
||||
|
||||
psky_t *pSky = tileSetupSky(0);
|
||||
pSky->horizfrac = 65536;
|
||||
|
||||
*pX = mapHeader.at0;
|
||||
*pY = mapHeader.at4;
|
||||
*pZ = mapHeader.at8;
|
||||
*pAngle = mapHeader.atc;
|
||||
*pSector = mapHeader.ate;
|
||||
pSky->lognumtiles = mapHeader.at10;
|
||||
gVisibility = g_visibility = mapHeader.at12;
|
||||
gSongId = mapHeader.at16;
|
||||
if (byte_1A76C8)
|
||||
|
@ -770,16 +766,21 @@ int dbLoadMap(const char *pPath, int *pX, int *pY, int *pZ, short *pAngle, short
|
|||
{
|
||||
memset(&byte_19AE44, 0, 128);
|
||||
}
|
||||
gSkyCount = 1<<pSky->lognumtiles;
|
||||
gSkyCount = 1<< mapHeader.at10;
|
||||
IOBuffer1.Read(tpskyoff, gSkyCount*sizeof(tpskyoff[0]));
|
||||
if (byte_1A76C8)
|
||||
{
|
||||
dbCrypt((char*)tpskyoff, gSkyCount*sizeof(tpskyoff[0]), gSkyCount*2);
|
||||
}
|
||||
|
||||
psky_t* pSky = tileSetupSky(DEFAULTPSKY);
|
||||
pSky->horizfrac = 65536;
|
||||
pSky->lognumtiles = mapHeader.at10;
|
||||
for (int i = 0; i < ClipHigh(gSkyCount, MAXPSKYTILES); i++)
|
||||
{
|
||||
pSky->tileofs[i] = B_LITTLE16(tpskyoff[i]);
|
||||
}
|
||||
|
||||
for (int i = 0; i < numsectors; i++)
|
||||
{
|
||||
sectortype *pSector = §or[i];
|
||||
|
|
|
@ -626,7 +626,7 @@ public:
|
|||
|
||||
void MyLoadSave::Load(void)
|
||||
{
|
||||
psky_t *pSky = tileSetupSky(0);
|
||||
psky_t *pSky = tileSetupSky(DEFAULTPSKY);
|
||||
int id;
|
||||
Read(&id, sizeof(id));
|
||||
if (id != 0x5653424e/*'VSBN'*/)
|
||||
|
@ -706,10 +706,9 @@ void MyLoadSave::Load(void)
|
|||
#ifdef NOONE_EXTENSIONS
|
||||
Read(&gModernMap, sizeof(gModernMap));
|
||||
#endif
|
||||
psky_t skyInfo;
|
||||
Read(&skyInfo, sizeof(skyInfo));
|
||||
|
||||
*tileSetupSky(0) = skyInfo;
|
||||
psky_t *skyInfo = tileSetupSky(DEFAULTPSKY);
|
||||
Read(skyInfo, sizeof(*skyInfo));
|
||||
skyInfo->combinedtile = -1;
|
||||
gCheatMgr.sub_5BCF4();
|
||||
|
||||
}
|
||||
|
@ -797,8 +796,8 @@ void MyLoadSave::Save(void)
|
|||
#ifdef NOONE_EXTENSIONS
|
||||
Write(&gModernMap, sizeof(gModernMap));
|
||||
#endif
|
||||
psky_t skyInfo = *tileSetupSky(0);
|
||||
Write(&skyInfo, sizeof(skyInfo));
|
||||
psky_t *skyInfo = tileSetupSky(DEFAULTPSKY);
|
||||
Write(skyInfo, sizeof(*skyInfo));
|
||||
}
|
||||
|
||||
void LoadSavedInfo(void)
|
||||
|
|
|
@ -400,6 +400,7 @@ EXTERN vec2_t windowxy1, windowxy2;
|
|||
#define DEFAULTPSKY -1
|
||||
|
||||
typedef struct {
|
||||
int tilenum;
|
||||
// The proportion at which looking up/down affects the apparent 'horiz' of
|
||||
// a parallaxed sky, scaled by 65536 (so, a value of 65536 makes it align
|
||||
// with the drawn surrounding scene):
|
||||
|
@ -410,32 +411,27 @@ typedef struct {
|
|||
int32_t yoffs;
|
||||
|
||||
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
|
||||
int16_t tileofs[MAXPSKYTILES]; // for 0 <= j < (1<<lognumtiles): tile offset relative to basetile
|
||||
|
||||
int32_t yscale;
|
||||
int combinedtile;
|
||||
} psky_t;
|
||||
|
||||
// Index of map-global (legacy) multi-sky:
|
||||
EXTERN int32_t g_pskyidx;
|
||||
// New multi-psky
|
||||
EXTERN int32_t pskynummultis;
|
||||
EXTERN psky_t * multipsky;
|
||||
// Mapping of multi-sky index to base sky tile number:
|
||||
EXTERN int32_t * multipskytile;
|
||||
EXTERN TArray<psky_t> multipskies;
|
||||
|
||||
static FORCE_INLINE int32_t getpskyidx(int32_t picnum)
|
||||
static FORCE_INLINE psky_t *getpskyidx(int32_t picnum)
|
||||
{
|
||||
int32_t j;
|
||||
for (auto& sky : multipskies)
|
||||
if (picnum == sky.tilenum) return &sky;
|
||||
|
||||
for (j=pskynummultis-1; j>0; j--) // NOTE: j==0 on non-early loop end
|
||||
if (picnum == multipskytile[j])
|
||||
break; // Have a match.
|
||||
|
||||
return j;
|
||||
return &multipskies[0];
|
||||
}
|
||||
|
||||
|
||||
EXTERN psky_t * tileSetupSky(int32_t tilenum);
|
||||
psky_t* defineSky(int32_t const tilenum, int horiz, int lognumtiles, const uint16_t* tileofs, int yoff = 0);
|
||||
|
||||
EXTERN char parallaxtype;
|
||||
EXTERN int32_t parallaxyoffs_override, parallaxyscale_override;
|
||||
|
|
|
@ -1024,22 +1024,51 @@ int32_t rayintersect(int32_t x1, int32_t y1, int32_t z1, int32_t vx, int32_t vy,
|
|||
|
||||
psky_t * tileSetupSky(int32_t const tilenum)
|
||||
{
|
||||
for (bssize_t i = 0; i < pskynummultis; i++)
|
||||
if (multipskytile[i] == tilenum)
|
||||
return &multipsky[i];
|
||||
for (auto& sky : multipskies)
|
||||
if (tilenum == sky.tilenum)
|
||||
{
|
||||
sky.combinedtile = -1; // invalidate the old content
|
||||
return &sky;
|
||||
}
|
||||
|
||||
int32_t const newPskyID = pskynummultis++;
|
||||
multipsky = (psky_t *)Xrealloc(multipsky, pskynummultis * sizeof(psky_t));
|
||||
multipskytile = (int32_t *)Xrealloc(multipskytile, pskynummultis * sizeof(int32_t));
|
||||
|
||||
psky_t * const newPsky = &multipsky[newPskyID];
|
||||
Bmemset(newPsky, 0, sizeof(psky_t));
|
||||
multipskytile[newPskyID] = tilenum;
|
||||
newPsky->yscale = 65536;
|
||||
|
||||
return newPsky;
|
||||
multipskies.Reserve(1);
|
||||
multipskies.Last() = {};
|
||||
multipskies.Last().tilenum = tilenum;
|
||||
multipskies.Last().combinedtile = -1;
|
||||
multipskies.Last().yscale = 65536;
|
||||
return &multipskies.Last();
|
||||
}
|
||||
|
||||
psky_t * defineSky(int32_t const tilenum, int horiz, int lognumtiles, const uint16_t *tileofs, int yoff)
|
||||
{
|
||||
auto sky = tileSetupSky(tilenum);
|
||||
sky->horizfrac = horiz;
|
||||
sky->lognumtiles = lognumtiles;
|
||||
sky->yoffs = yoff;
|
||||
memcpy(sky->tileofs, tileofs, 2 << lognumtiles);
|
||||
return sky;
|
||||
}
|
||||
|
||||
// Get properties of parallaxed sky to draw.
|
||||
// Returns: pointer to tile offset array. Sets-by-pointer the other three.
|
||||
const int16_t* getpsky(int32_t picnum, int32_t* dapyscale, int32_t* dapskybits, int32_t* dapyoffs, int32_t* daptileyscale)
|
||||
{
|
||||
psky_t const* const psky = getpskyidx(picnum);
|
||||
|
||||
if (dapskybits)
|
||||
*dapskybits = (pskybits_override == -1 ? psky->lognumtiles : pskybits_override);
|
||||
if (dapyscale)
|
||||
*dapyscale = (parallaxyscale_override == 0 ? psky->horizfrac : parallaxyscale_override);
|
||||
if (dapyoffs)
|
||||
*dapyoffs = psky->yoffs + parallaxyoffs_override;
|
||||
if (daptileyscale)
|
||||
*daptileyscale = psky->yscale;
|
||||
|
||||
return psky->tileofs;
|
||||
}
|
||||
|
||||
|
||||
|
||||
//
|
||||
// preinitengine
|
||||
//
|
||||
|
@ -1174,10 +1203,6 @@ void engineUnInit(void)
|
|||
}
|
||||
DO_FREE_AND_NULL(usermaphacks);
|
||||
num_usermaphacks = 0;
|
||||
|
||||
DO_FREE_AND_NULL(multipsky);
|
||||
DO_FREE_AND_NULL(multipskytile);
|
||||
pskynummultis = 0;
|
||||
}
|
||||
|
||||
|
||||
|
|
|
@ -160,21 +160,7 @@ static FORCE_INLINE void setgotpic(int32_t tilenume)
|
|||
|
||||
// Get properties of parallaxed sky to draw.
|
||||
// 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, int32_t *daptileyscale)
|
||||
{
|
||||
psky_t const * const psky = &multipsky[getpskyidx(picnum)];
|
||||
|
||||
if (dapskybits)
|
||||
*dapskybits = (pskybits_override == -1 ? psky->lognumtiles : pskybits_override);
|
||||
if (dapyscale)
|
||||
*dapyscale = (parallaxyscale_override == 0 ? psky->horizfrac : parallaxyscale_override);
|
||||
if (dapyoffs)
|
||||
*dapyoffs = psky->yoffs + parallaxyoffs_override;
|
||||
if (daptileyscale)
|
||||
*daptileyscale = psky->yscale;
|
||||
|
||||
return psky->tileofs;
|
||||
}
|
||||
const int16_t* getpsky(int32_t picnum, int32_t* dapyscale, int32_t* dapskybits, int32_t* dapyoffs, int32_t* daptileyscale);
|
||||
|
||||
static FORCE_INLINE void set_globalpos(int32_t const x, int32_t const y, int32_t const z)
|
||||
{
|
||||
|
|
|
@ -1300,7 +1300,7 @@ static void polymost_flatskyrender(vec2f_t const* const dpxy, int32_t const n, i
|
|||
|
||||
float const fglobalang = fix16_to_float(qglobalang);
|
||||
int32_t dapyscale, dapskybits, dapyoffs, daptileyscale;
|
||||
int8_t const * dapskyoff = getpsky(globalpicnum, &dapyscale, &dapskybits, &dapyoffs, &daptileyscale);
|
||||
int16_t const * dapskyoff = getpsky(globalpicnum, &dapyscale, &dapskybits, &dapyoffs, &daptileyscale);
|
||||
|
||||
ghoriz = (qglobalhoriz*(1.f/65536.f)-float(ydimen>>1))*dapyscale*(1.f/65536.f)+float(ydimen>>1)+ghorizcorrect;
|
||||
|
||||
|
@ -1574,7 +1574,7 @@ static void polymost_drawalls(int32_t const bunch)
|
|||
tileUpdatePicnum(&globalpicnum, sectnum);
|
||||
|
||||
int32_t dapyscale, dapskybits, dapyoffs, daptileyscale;
|
||||
int8_t const * dapskyoff = getpsky(globalpicnum, &dapyscale, &dapskybits, &dapyoffs, &daptileyscale);
|
||||
int16_t const * dapskyoff = getpsky(globalpicnum, &dapyscale, &dapskybits, &dapyoffs, &daptileyscale);
|
||||
|
||||
global_cf_fogpal = sec->fogpal;
|
||||
global_cf_shade = sec->floorshade, global_cf_pal = sec->floorpal; global_cf_z = sec->floorz; // REFACT
|
||||
|
|
|
@ -1668,4 +1668,3 @@ void S_SoundReset()
|
|||
soundEngine->Reset();
|
||||
S_RestartMusic();
|
||||
}
|
||||
|
||||
|
|
|
@ -160,7 +160,7 @@ uint8_t LoadLevel(int nMap)
|
|||
PlayerList[i].nSprite = -1;
|
||||
}
|
||||
|
||||
psky_t* pSky = tileSetupSky(0);
|
||||
psky_t* pSky = tileSetupSky(DEFAULTPSKY);
|
||||
|
||||
pSky->tileofs[0] = 0;
|
||||
pSky->tileofs[1] = 0;
|
||||
|
|
|
@ -54,7 +54,7 @@ bool GameInterface::LoadGame(FSaveGameNode* sv)
|
|||
FinishSavegameRead();
|
||||
|
||||
// reset the sky in case it hasn't been done yet.
|
||||
psky_t* pSky = tileSetupSky(0);
|
||||
psky_t* pSky = tileSetupSky(DEFAULTPSKY);
|
||||
pSky->tileofs[0] = 0;
|
||||
pSky->tileofs[1] = 0;
|
||||
pSky->tileofs[2] = 0;
|
||||
|
|
|
@ -44,7 +44,6 @@ set( PCH_SOURCES
|
|||
src/spawn.cpp
|
||||
src/spawn_d.cpp
|
||||
src/spawn_r.cpp
|
||||
src/zz_common.cpp
|
||||
src/zz_game.cpp
|
||||
src/zz_global.cpp
|
||||
src/zz_player.cpp
|
||||
|
|
|
@ -84,8 +84,7 @@ static inline void G_NewGame_EnterLevel(MapRecord *map, int skill)
|
|||
G_BackToMenu();
|
||||
}
|
||||
|
||||
extern void G_InitMultiPsky(int CLOUDYOCEAN__DYN, int MOONSKY1__DYN, int BIGORBIT1__DYN, int LA__DYN);
|
||||
extern void G_SetupGlobalPsky(void);
|
||||
extern void setupbackdrop();
|
||||
|
||||
//////////
|
||||
|
||||
|
|
|
@ -863,5 +863,58 @@ int startrts(int lumpNum, int localPlayer)
|
|||
}
|
||||
|
||||
|
||||
//---------------------------------------------------------------------------
|
||||
//
|
||||
// Define sky layouts.
|
||||
// This one's easy - the other games are a total mess
|
||||
//
|
||||
//---------------------------------------------------------------------------
|
||||
|
||||
void setupbackdrop()
|
||||
{
|
||||
static const uint16_t pskyoff[8] = {};
|
||||
static const uint16_t moonoff[8] = { 0, 2, 3, 0, 2, 0, 1, 0 };
|
||||
static const uint16_t orbitoff[8] = { 0, 0, 4, 0, 0, 1, 2, 3 };
|
||||
static const uint16_t laoff[8] = { 1, 2, 1, 3, 4, 0, 2, 3 };
|
||||
static const uint16_t defoff[8] = { 0, 1, 2, 3, 4, 5, 6, 7 };
|
||||
static const uint16_t defoff1[8] = { 1, 2, 3, 4, 5, 6, 7, 0 };
|
||||
static const uint16_t defoff4[8] = { 4, 5, 6, 7, 0, 1, 2, 3 };
|
||||
static const uint16_t defoff7[8] = { 7, 0, 1, 2, 3, 4, 5, 6 };
|
||||
|
||||
defineSky(DEFAULTPSKY, 32768, 3, pskyoff);
|
||||
defineSky(TILE_CLOUDYOCEAN, 65536, 3, pskyoff);
|
||||
defineSky(TILE_MOONSKY1, 32768, 3, moonoff);
|
||||
defineSky(TILE_BIGORBIT1, 32768, 3, orbitoff);
|
||||
defineSky(TILE_LA, 16384 + 1024, 3, laoff);
|
||||
if (isWorldTour())
|
||||
{
|
||||
defineSky(5284, 65536, 3, defoff);
|
||||
defineSky(5412, 65536, 3, defoff, 48);
|
||||
defineSky(5420, 65536, 3, defoff, 48);
|
||||
defineSky(5450, 65536, 3, defoff7, 48);
|
||||
defineSky(5548, 65536, 3, defoff, 48);
|
||||
defineSky(5556, 65536, 3, defoff1, 48);
|
||||
defineSky(5720, 65536, 3, defoff4, 48);
|
||||
defineSky(5814, 65536, 3, defoff, 48);
|
||||
}
|
||||
|
||||
// Ugh... Since we do not know up front which of these tiles are skies we have to set them all...
|
||||
if (isRRRA())
|
||||
{
|
||||
for (int i = 0; i < MAXUSERTILES; i++)
|
||||
{
|
||||
if (tilesiz[i].x == 512)
|
||||
{
|
||||
defineSky(i, 32768, 1, pskyoff);
|
||||
}
|
||||
else if (tilesiz[i].x == 1024)
|
||||
{
|
||||
defineSky(i, 32768, 0, pskyoff);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
END_DUKE_NS
|
||||
|
||||
|
|
|
@ -888,8 +888,6 @@ static int LoadTheMap(MapRecord *mi, struct player_struct *p, int gamemode)
|
|||
if (isRR()) prelevel_r(gamemode);
|
||||
else prelevel_d(gamemode);
|
||||
|
||||
G_InitRRRASkies();
|
||||
|
||||
if (isRRRA() && mi->levelNumber == levelnum(2, 0))
|
||||
{
|
||||
for (int i = PISTOL_WEAPON; i < MAX_WEAPONS; i++)
|
||||
|
|
|
@ -31,7 +31,6 @@ extern int16_t ambientlotag[64];
|
|||
extern int16_t ambienthitag[64];
|
||||
void P_ResetPlayer(int pn);
|
||||
void G_ResetInterpolations(void);
|
||||
void G_InitRRRASkies(void);
|
||||
|
||||
|
||||
END_DUKE_NS
|
||||
|
|
|
@ -342,14 +342,14 @@ void GameInterface::set_hud_layout(int layout)
|
|||
ud.screen_size = isRR()? screen_size_vals_rr[layout] : screen_size_vals[layout];
|
||||
ud.statusbarmode = layout >= 8;
|
||||
ud.althud = layout >= 10;
|
||||
updateviewport();
|
||||
if (xdim > 0 && ydim > 0) updateviewport();
|
||||
}
|
||||
}
|
||||
|
||||
void GameInterface::set_hud_scale(int scale)
|
||||
{
|
||||
ud.statusbarscale = clamp(scale, 36, 100);
|
||||
updateviewport();
|
||||
if (xdim > 0 && ydim > 0) updateviewport();
|
||||
}
|
||||
|
||||
void GameInterface::UpdateScreenSize()
|
||||
|
|
|
@ -1,133 +0,0 @@
|
|||
//
|
||||
// Common non-engine code/data for EDuke32 and Mapster32
|
||||
//
|
||||
#include "ns.h" // Must come before everything else!
|
||||
|
||||
#include "compat.h"
|
||||
#include "build.h"
|
||||
#include "baselayer.h"
|
||||
#include "palette.h"
|
||||
#include "cmdlib.h"
|
||||
#include "gamecvars.h"
|
||||
#include "rts.h"
|
||||
#include "gamecontrol.h"
|
||||
#include "palettecontainer.h"
|
||||
#include "names.h"
|
||||
|
||||
#include "common.h"
|
||||
|
||||
BEGIN_DUKE_NS
|
||||
|
||||
//////////
|
||||
|
||||
// Set up new-style multi-psky handling.
|
||||
void G_InitMultiPsky(int CLOUDYOCEAN__DYN, int MOONSKY1__DYN, int BIGORBIT1__DYN, int LA__DYN)
|
||||
{
|
||||
// When adding other multi-skies, take care that the tileofs[] values are
|
||||
// <= PSKYOFF_MAX. (It can be increased up to MAXPSKYTILES, but should be
|
||||
// set as tight as possible.)
|
||||
|
||||
// The default sky properties (all others are implicitly zero):
|
||||
psky_t *sky = tileSetupSky(DEFAULTPSKY);
|
||||
sky->lognumtiles = 3;
|
||||
sky->horizfrac = 32768;
|
||||
|
||||
// TILE_CLOUDYOCEAN
|
||||
// Aligns with the drawn scene horizon because it has one itself.
|
||||
sky = tileSetupSky(CLOUDYOCEAN__DYN);
|
||||
sky->lognumtiles = 3;
|
||||
sky->horizfrac = 65536;
|
||||
|
||||
// TILE_MOONSKY1
|
||||
// earth mountain mountain sun
|
||||
sky = tileSetupSky(MOONSKY1__DYN);
|
||||
sky->lognumtiles = 3;
|
||||
sky->horizfrac = 32768;
|
||||
sky->tileofs[6] = 1;
|
||||
sky->tileofs[1] = 2;
|
||||
sky->tileofs[4] = 2;
|
||||
sky->tileofs[2] = 3;
|
||||
|
||||
// TILE_BIGORBIT1 // orbit
|
||||
// earth1 2 3 moon/sun
|
||||
sky = tileSetupSky(BIGORBIT1__DYN);
|
||||
sky->lognumtiles = 3;
|
||||
sky->horizfrac = 32768;
|
||||
sky->tileofs[5] = 1;
|
||||
sky->tileofs[6] = 2;
|
||||
sky->tileofs[7] = 3;
|
||||
sky->tileofs[2] = 4;
|
||||
|
||||
// TILE_LA // la city
|
||||
// earth1 2 3 moon/sun
|
||||
sky = tileSetupSky(LA__DYN);
|
||||
sky->lognumtiles = 3;
|
||||
sky->horizfrac = 16384 + 1024;
|
||||
sky->tileofs[0] = 1;
|
||||
sky->tileofs[1] = 2;
|
||||
sky->tileofs[2] = 1;
|
||||
sky->tileofs[3] = 3;
|
||||
sky->tileofs[4] = 4;
|
||||
sky->tileofs[5] = 0;
|
||||
sky->tileofs[6] = 2;
|
||||
sky->tileofs[7] = 3;
|
||||
|
||||
#if 0
|
||||
// This assertion should hold. See note above.
|
||||
for (bssize_t i=0; i<pskynummultis; ++i)
|
||||
for (bssize_t j=0; j<(1<<multipsky[i].lognumtiles); ++j)
|
||||
Bassert(multipsky[i].tileofs[j] <= PSKYOFF_MAX);
|
||||
#endif
|
||||
}
|
||||
|
||||
void G_SetupGlobalPsky(void)
|
||||
{
|
||||
int skyIdx = 0;
|
||||
|
||||
// NOTE: Loop must be running backwards for the same behavior as the game
|
||||
// (greatest sector index with matching parallaxed sky takes precedence).
|
||||
for (bssize_t i = numsectors - 1; i >= 0; i--)
|
||||
{
|
||||
if (sector[i].ceilingstat & 1)
|
||||
{
|
||||
skyIdx = getpskyidx(sector[i].ceilingpicnum);
|
||||
if (skyIdx > 0)
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
g_pskyidx = skyIdx;
|
||||
}
|
||||
|
||||
void G_InitRRRASkies(void)
|
||||
{
|
||||
if (!isRRRA())
|
||||
return;
|
||||
|
||||
for (int i = 0; i < MAXSECTORS; i++)
|
||||
{
|
||||
if (sector[i].ceilingpicnum != TILE_LA && sector[i].ceilingpicnum != TILE_MOONSKY1 && sector[i].ceilingpicnum != TILE_BIGORBIT1)
|
||||
{
|
||||
int const picnum = sector[i].ceilingpicnum;
|
||||
if (tileWidth(picnum) == 512)
|
||||
{
|
||||
psky_t *sky = tileSetupSky(picnum);
|
||||
sky->horizfrac = 32768;
|
||||
sky->lognumtiles = 1;
|
||||
sky->tileofs[0] = 0;
|
||||
sky->tileofs[1] = 0;
|
||||
}
|
||||
else if (tileWidth(picnum) == 1024)
|
||||
{
|
||||
psky_t *sky = tileSetupSky(picnum);
|
||||
sky->horizfrac = 32768;
|
||||
sky->lognumtiles = 0;
|
||||
sky->tileofs[0] = 0;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
END_DUKE_NS
|
|
@ -361,7 +361,7 @@ static void G_Startup(void)
|
|||
G_FatalEngineError();
|
||||
|
||||
// These depend on having the dynamic tile and/or sound mappings set up:
|
||||
G_InitMultiPsky(TILE_CLOUDYOCEAN, TILE_MOONSKY1, TILE_BIGORBIT1, TILE_LA);
|
||||
setupbackdrop();
|
||||
//Net_SendClientInfo();
|
||||
|
||||
if (userConfig.CommandMap.IsNotEmpty())
|
||||
|
@ -560,8 +560,6 @@ int GameInterface::app_main()
|
|||
ud.camera_time = 0;//4;
|
||||
playerteam = 0;
|
||||
|
||||
hud_size.Callback();
|
||||
hud_scale.Callback();
|
||||
S_InitSound();
|
||||
|
||||
|
||||
|
@ -616,6 +614,8 @@ int GameInterface::app_main()
|
|||
userConfig.AddDefs.reset();
|
||||
|
||||
enginePostInit();
|
||||
hud_size.Callback();
|
||||
hud_scale.Callback();
|
||||
|
||||
tileDelete(TILE_MIRROR);
|
||||
skiptile = TILE_W_FORCEFIELD + 1;
|
||||
|
|
|
@ -624,7 +624,6 @@ static const dataspec_t svgm_anmisc[] =
|
|||
{ 0, &clouds[0], sizeof(clouds), 1 },
|
||||
{ 0, &cloudx, sizeof(cloudx), 1 },
|
||||
{ 0, &cloudy, sizeof(cloudy), 1 },
|
||||
{ 0, &g_pskyidx, sizeof(g_pskyidx), 1 }, // DS_NOCHK?
|
||||
{ 0, &g_earthquakeTime, sizeof(g_earthquakeTime), 1 },
|
||||
|
||||
// RR stuff
|
||||
|
@ -1142,7 +1141,6 @@ static void postloadplayer(int32_t savegamep)
|
|||
for (i=0; i<MAXPLAYERS; i++)
|
||||
g_player[i].ps->drug_timer = 0;
|
||||
|
||||
G_InitRRRASkies();
|
||||
}
|
||||
|
||||
////////// END GENERIC SAVING/LOADING SYSTEM //////////
|
||||
|
|
Loading…
Reference in a new issue