raze/source/games/exhumed/src/map.cpp

90 lines
3.2 KiB
C++
Raw Normal View History

//-------------------------------------------------------------------------
/*
Copyright (C) 2010-2019 EDuke32 developers and contributors
Copyright (C) 2019 sirlemonhead, Nuke.YKT
This file is part of PCExhumed.
PCExhumed 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"
#include <string.h>
#include "player.h"
#include "engine.h"
#include "exhumed.h"
#include "view.h"
#include "v_2ddrawer.h"
2020-09-06 10:44:58 +00:00
#include "automap.h"
#include "v_draw.h"
BEGIN_PS_NS
bool bShowTowers = false;
void GrabMap()
{
for(auto&sec: sector)
2021-12-02 00:05:07 +00:00
MarkSectorSeen(&sec);
}
void UpdateMap()
{
2021-11-22 23:41:21 +00:00
if (initsectp->ceilingpal != 3 || (PlayerList[nLocalPlayer].nTorch != 0)) {
2021-12-02 00:05:07 +00:00
MarkSectorSeen(initsectp);
}
}
void DrawMap(double const smoothratio)
{
if (!nFreeze && automapMode != am_off)
{
auto pPlayerActor = PlayerList[nLocalPlayer].pActor;
auto ang = !SyncInput() ? PlayerList[nLocalPlayer].angle.sum() : PlayerList[nLocalPlayer].angle.interpolatedsum(smoothratio);
DrawOverheadMap(pPlayerActor->interpolatedvec3(smoothratio * (1. / MaxSmoothRatio)).XY(), ang, smoothratio);
}
}
void GetActorExtents(DExhumedActor* actor, int* top, int* bottom)
{
2022-01-31 22:33:44 +00:00
*top = *bottom = actor->int_pos().Z;
if ((actor->spr.cstat & CSTAT_SPRITE_ALIGNMENT_MASK) != CSTAT_SPRITE_ALIGNMENT_FLOOR)
{
int height = tileHeight(actor->spr.picnum);
int center = height / 2 + tileTopOffset(actor->spr.picnum);
*top -= (actor->spr.yrepeat << 2) * center;
*bottom += (actor->spr.yrepeat << 2) * (height - center);
}
}
bool GameInterface::DrawAutomapPlayer(const DVector2& mxy, const DVector2& cpos, const DAngle cang, const DVector2& xydim, const double czoom, double const smoothratio)
{
auto cangsin = cang.Sin();
auto cangcos = cang.Cos();
for (int i = connecthead; i >= 0; i = connectpoint2[i])
{
if (i == nLocalPlayer)// || gGameOptions.nGameType == 1)
{
2022-09-01 13:27:51 +00:00
auto pPlayerActor = PlayerList[i].pActor;
auto vect = OutAutomapVector(mxy - cpos, cangsin, cangcos, czoom, xydim);
2022-09-01 13:27:51 +00:00
DrawTexture(twod, tileGetTexture(pPlayerActor->spr.picnum /*+ ((PlayClock >> 4) & 3)*/, true), vect.X, vect.Y, DTA_ClipLeft, viewport3d.Left(), DTA_ClipTop, viewport3d.Top(), DTA_ScaleX, czoom * (2. / 3.), DTA_ScaleY, czoom * (2. / 3.), DTA_CenterOffset, true,
DTA_ClipRight, viewport3d.Right(), DTA_ClipBottom, viewport3d.Bottom(), DTA_Alpha, (pPlayerActor->spr.cstat & CSTAT_SPRITE_TRANSLUCENT ? 0.5 : 1.), TAG_DONE);
break;
}
}
return true;
}
END_PS_NS