mirror of
https://github.com/DrBeef/Raze.git
synced 2024-12-11 21:31:16 +00:00
79 lines
2.2 KiB
C++
79 lines
2.2 KiB
C++
|
#include "build.h"
|
||
|
#include "pragmas.h"
|
||
|
#include "common_game.h"
|
||
|
//-------------------------------------------------------------------------
|
||
|
/*
|
||
|
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 "resource.h"
|
||
|
#include "trig.h"
|
||
|
|
||
|
int costable[2048];
|
||
|
|
||
|
int OctantTable[8] = { 5, 6, 2, 1, 4, 7, 3, 0 };
|
||
|
|
||
|
int GetOctant(int x, int y)
|
||
|
{
|
||
|
int vc = klabs(x)-klabs(y);
|
||
|
return OctantTable[7-(x<0)-(y<0)*2-(vc<0)*4];
|
||
|
}
|
||
|
|
||
|
void RotateVector(int *dx, int *dy, int nAngle)
|
||
|
{
|
||
|
int ox = *dx;
|
||
|
int oy = *dy;
|
||
|
*dx = dmulscale30r(ox, Cos(nAngle), -oy, Sin(nAngle));
|
||
|
*dy = dmulscale30r(ox, Sin(nAngle), oy, Cos(nAngle));
|
||
|
}
|
||
|
|
||
|
void RotatePoint(int *x, int *y, int nAngle, int ox, int oy)
|
||
|
{
|
||
|
int dx = *x-ox;
|
||
|
int dy = *y-oy;
|
||
|
*x = ox+dmulscale30r(dx, Cos(nAngle), -dy, Sin(nAngle));
|
||
|
*y = oy+dmulscale30r(dx, Sin(nAngle), dy, Cos(nAngle));
|
||
|
}
|
||
|
|
||
|
void trigInit(Resource &Res)
|
||
|
{
|
||
|
DICTNODE *pTable = Res.Lookup("cosine","dat");
|
||
|
if (!pTable)
|
||
|
ThrowError("Cosine table not found");
|
||
|
if (pTable->size != 2048)
|
||
|
ThrowError("Cosine table incorrect size");
|
||
|
memcpy(costable, Res.Load(pTable), pTable->size);
|
||
|
#if B_BIG_ENDIAN == 1
|
||
|
for (int i = 0; i < 512; i++)
|
||
|
{
|
||
|
costable[i] = B_LITTLE32(costable[i]);
|
||
|
}
|
||
|
#endif
|
||
|
costable[512] = 0;
|
||
|
for (int i = 513; i <= 1024; i++)
|
||
|
{
|
||
|
costable[i] = -costable[1024-i];
|
||
|
}
|
||
|
for (int i = 1025; i < 2048; i++)
|
||
|
{
|
||
|
costable[i] = costable[2048 - i];
|
||
|
}
|
||
|
}
|