mirror of
https://github.com/ZDoom/Raze.git
synced 2025-01-22 16:31:23 +00:00
d064706f93
All map geometry npw uses texture IDs and no longer depends on Build's tile system. (What's missing is a new map format, though, but this was a necessary prerequisite to make that worthwile...)
176 lines
4.5 KiB
C++
176 lines
4.5 KiB
C++
//-------------------------------------------------------------------------
|
|
/*
|
|
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.
|
|
*/
|
|
//-------------------------------------------------------------------------
|
|
#include "ns.h" // Must come before everything else!
|
|
|
|
#include "build.h"
|
|
#include "automap.h"
|
|
#include "savegamehelp.h"
|
|
|
|
#include "blood.h"
|
|
#include "render.h"
|
|
|
|
BEGIN_BLD_NS
|
|
|
|
int mirrorcnt, mirrorsector, mirrorwall[4];
|
|
|
|
MIRROR mirror[16]; // only needed by Polymost.
|
|
|
|
//---------------------------------------------------------------------------
|
|
//
|
|
//
|
|
//
|
|
//---------------------------------------------------------------------------
|
|
|
|
void InitMirrors(void)
|
|
{
|
|
mirrorcnt = 0;
|
|
portalClear();
|
|
|
|
for (int i = (int)wall.Size() - 1; i >= 0; i--)
|
|
{
|
|
auto pWalli = &wall[i];
|
|
if (mirrorcnt == 16)
|
|
break;
|
|
if (pWalli->overtexture == mirrortile)
|
|
{
|
|
if (pWalli->extra > 0 && pWalli->type == kWallStack)
|
|
{
|
|
mirror[mirrorcnt].mynum = i;
|
|
mirror[mirrorcnt].type = 0;
|
|
pWalli->cstat |= CSTAT_WALL_1WAY;
|
|
int tmp = pWalli->xw().data;
|
|
int j;
|
|
for (j = (int)wall.Size() - 1; j >= 0; j--)
|
|
{
|
|
if (j == i)
|
|
continue;
|
|
auto pWallj = &wall[j];
|
|
if (pWallj->extra > 0 && pWallj->type == kWallStack)
|
|
{
|
|
if (tmp != pWallj->xw().data)
|
|
continue;
|
|
pWalli->hitag = j; // hitag is only used by Polymost, the new renderer uses external links.
|
|
pWallj->hitag = i;
|
|
mirror[mirrorcnt].link = j;
|
|
break;
|
|
}
|
|
}
|
|
if (j < 0)
|
|
{
|
|
Printf(PRINT_HIGH, "wall[%d] has no matching wall link! (data=%d)\n", i, tmp);
|
|
}
|
|
else
|
|
{
|
|
mirrorcnt++;
|
|
pWalli->portalflags = PORTAL_WALL_VIEW;
|
|
pWalli->portalnum = j;
|
|
}
|
|
}
|
|
continue;
|
|
}
|
|
if (pWalli->walltexture == mirrortile)
|
|
{
|
|
mirror[mirrorcnt].link = i;
|
|
mirror[mirrorcnt].mynum = i;
|
|
mirror[mirrorcnt].type = 0;
|
|
pWalli->cstat |= CSTAT_WALL_1WAY;
|
|
pWalli->portalflags = PORTAL_WALL_MIRROR;
|
|
mirrorcnt++;
|
|
continue;
|
|
}
|
|
}
|
|
for (int i = (int)sector.Size() - 1; i >= 0; i--)
|
|
{
|
|
if (mirrorcnt >= 15)
|
|
break;
|
|
|
|
auto secti = §or[i];
|
|
if (secti->floortexture == mirrortile)
|
|
{
|
|
auto link = barrier_cast<DBloodActor*>(secti->upperLink);
|
|
if (link == nullptr)
|
|
continue;
|
|
auto link2 = link->GetOwner();
|
|
if (link2 == nullptr)
|
|
continue;
|
|
|
|
auto sectj = link2->sector();
|
|
int j = sectindex(sectj);
|
|
if (sectj->ceilingtexture != mirrortile)
|
|
I_Error("Lower link sector %d doesn't have mirror picnum\n", j);
|
|
mirror[mirrorcnt].type = 2;
|
|
mirror[mirrorcnt].diff = link2->spr.pos - link->spr.pos;
|
|
mirror[mirrorcnt].mynum = i;
|
|
mirror[mirrorcnt].link = j;
|
|
secti->portalflags = PORTAL_SECTOR_FLOOR;
|
|
secti->portalnum = portalAdd(PORTAL_SECTOR_FLOOR, j, mirror[mirrorcnt].diff);
|
|
mirrorcnt++;
|
|
mirror[mirrorcnt].type = 1;
|
|
mirror[mirrorcnt].diff = link->spr.pos - link2->spr.pos;
|
|
mirror[mirrorcnt].mynum = j;
|
|
mirror[mirrorcnt].link = i;
|
|
sectj->portalflags = PORTAL_SECTOR_CEILING;
|
|
sectj->portalnum = portalAdd(PORTAL_SECTOR_CEILING, i, mirror[mirrorcnt].diff);
|
|
mirrorcnt++;
|
|
}
|
|
}
|
|
mirrorsector = sector.Size();
|
|
mergePortals();
|
|
}
|
|
|
|
//---------------------------------------------------------------------------
|
|
//
|
|
//
|
|
//
|
|
//---------------------------------------------------------------------------
|
|
|
|
FSerializer& Serialize(FSerializer& arc, const char* keyname, MIRROR& w, MIRROR* def)
|
|
{
|
|
if (arc.BeginObject(keyname))
|
|
{
|
|
arc("type", w.type)
|
|
("link", w.link)
|
|
("diff", w.diff)
|
|
("wallnum", w.mynum)
|
|
.EndObject();
|
|
}
|
|
return arc;
|
|
}
|
|
|
|
//---------------------------------------------------------------------------
|
|
//
|
|
//
|
|
//
|
|
//---------------------------------------------------------------------------
|
|
|
|
void SerializeMirrors(FSerializer& arc)
|
|
{
|
|
if (arc.BeginObject("mirror"))
|
|
{
|
|
arc("mirrorcnt", mirrorcnt)
|
|
.Array("mirror", mirror, countof(mirror))
|
|
.EndObject();
|
|
}
|
|
}
|
|
|
|
END_BLD_NS
|