2017-02-11 21:10:52 +00:00
|
|
|
//
|
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// Voxel rendering
|
|
|
|
// Copyright(c) 1998 - 2016 Randy Heit
|
|
|
|
// All rights reserved.
|
|
|
|
//
|
|
|
|
// This program is free software: you can redistribute it and/or modify
|
|
|
|
// it under the terms of the GNU Lesser General Public License as published by
|
|
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
|
|
// (at your option) any later version.
|
|
|
|
//
|
|
|
|
// 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 Lesser General Public License for more details.
|
|
|
|
//
|
|
|
|
// You should have received a copy of the GNU Lesser General Public License
|
|
|
|
// along with this program. If not, see http://www.gnu.org/licenses/
|
|
|
|
//
|
|
|
|
//--------------------------------------------------------------------------
|
|
|
|
//
|
2016-12-25 10:07:50 +00:00
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
2017-01-26 07:13:39 +00:00
|
|
|
#include "r_visiblesprite.h"
|
|
|
|
|
2016-12-26 04:09:01 +00:00
|
|
|
struct kvxslab_t;
|
2017-01-11 14:41:42 +00:00
|
|
|
struct FVoxelMipLevel;
|
2017-01-16 04:26:22 +00:00
|
|
|
struct FVoxel;
|
2016-12-26 04:09:01 +00:00
|
|
|
|
2016-12-25 10:07:50 +00:00
|
|
|
namespace swrenderer
|
|
|
|
{
|
2017-01-30 10:27:58 +00:00
|
|
|
class SpriteDrawerArgs;
|
2017-01-28 15:36:39 +00:00
|
|
|
|
2017-01-09 13:20:47 +00:00
|
|
|
// [RH] A c-buffer. Used for keeping track of offscreen voxel spans.
|
|
|
|
struct FCoverageBuffer
|
|
|
|
{
|
|
|
|
struct Span
|
|
|
|
{
|
|
|
|
Span *NextSpan;
|
|
|
|
short Start, Stop;
|
|
|
|
};
|
|
|
|
|
|
|
|
FCoverageBuffer(int size);
|
|
|
|
~FCoverageBuffer();
|
|
|
|
|
|
|
|
void Clear();
|
|
|
|
void InsertSpan(int listnum, int start, int stop);
|
|
|
|
Span *AllocSpan();
|
|
|
|
|
|
|
|
FMemArena SpanArena;
|
|
|
|
Span **Spans; // [0..NumLists-1] span lists
|
|
|
|
Span *FreeSpans;
|
|
|
|
unsigned int NumLists;
|
|
|
|
};
|
2017-01-11 17:25:14 +00:00
|
|
|
|
2017-01-16 04:26:22 +00:00
|
|
|
class RenderVoxel : public VisibleSprite
|
2017-01-11 17:25:14 +00:00
|
|
|
{
|
|
|
|
public:
|
2017-02-03 23:25:37 +00:00
|
|
|
static void Project(RenderThread *thread, AActor *thing, DVector3 pos, FVoxelDef *voxel, const DVector2 &spriteScale, int renderflags, WaterFakeSide fakeside, F3DFloor *fakefloor, F3DFloor *fakeceiling, sector_t *current_sector, int spriteshade, bool foggy, FDynamicColormap *basecolormap);
|
2017-01-11 17:25:14 +00:00
|
|
|
|
|
|
|
static void Deinit();
|
|
|
|
|
2017-01-16 04:43:56 +00:00
|
|
|
protected:
|
2017-01-16 04:26:22 +00:00
|
|
|
bool IsVoxel() const override { return true; }
|
2018-03-08 03:05:35 +00:00
|
|
|
void Render(RenderThread *thread, short *cliptop, short *clipbottom, int minZ, int maxZ, Fake3DTranslucent clip3DFloor) override;
|
2017-01-16 04:26:22 +00:00
|
|
|
|
2017-01-11 17:25:14 +00:00
|
|
|
private:
|
2017-01-16 04:26:22 +00:00
|
|
|
struct posang
|
|
|
|
{
|
2017-01-24 01:28:32 +00:00
|
|
|
FVector3 vpos = { 0.0f, 0.0f, 0.0f }; // view origin
|
|
|
|
FAngle vang = { 0.0f }; // view angle
|
2017-01-16 04:26:22 +00:00
|
|
|
};
|
|
|
|
|
2017-07-02 18:09:46 +00:00
|
|
|
struct VoxelBlockEntry
|
|
|
|
{
|
|
|
|
VoxelBlock *block;
|
|
|
|
VoxelBlockEntry *next;
|
|
|
|
};
|
|
|
|
|
2017-01-16 04:26:22 +00:00
|
|
|
posang pa;
|
2017-01-24 01:28:32 +00:00
|
|
|
DAngle Angle = { 0.0 };
|
|
|
|
fixed_t xscale = 0;
|
|
|
|
FVoxel *voxel = nullptr;
|
2017-02-11 21:10:52 +00:00
|
|
|
bool bInMirror = false;
|
2017-01-16 04:26:22 +00:00
|
|
|
|
2017-01-24 01:28:32 +00:00
|
|
|
uint32_t Translation = 0;
|
|
|
|
uint32_t FillColor = 0;
|
2017-01-16 04:26:22 +00:00
|
|
|
|
2017-07-02 18:09:46 +00:00
|
|
|
enum { DVF_OFFSCREEN = 1, DVF_SPANSONLY = 2, DVF_MIRRORED = 4, DVF_FIND_X1X2 = 8 };
|
2017-01-11 17:25:14 +00:00
|
|
|
|
|
|
|
static kvxslab_t *GetSlabStart(const FVoxelMipLevel &mip, int x, int y);
|
|
|
|
static kvxslab_t *GetSlabEnd(const FVoxelMipLevel &mip, int x, int y);
|
|
|
|
static kvxslab_t *NextSlab(kvxslab_t *slab);
|
|
|
|
|
|
|
|
static void CheckOffscreenBuffer(int width, int height, bool spansonly);
|
|
|
|
|
|
|
|
static FCoverageBuffer *OffscreenCoverageBuffer;
|
|
|
|
static int OffscreenBufferWidth;
|
|
|
|
static int OffscreenBufferHeight;
|
|
|
|
static uint8_t *OffscreenColorBuffer;
|
2017-02-11 21:10:52 +00:00
|
|
|
|
|
|
|
void DrawVoxel(
|
|
|
|
RenderThread *thread, SpriteDrawerArgs &drawerargs,
|
|
|
|
const FVector3 &globalpos, FAngle viewangle, const FVector3 &dasprpos, DAngle dasprang, fixed_t daxscale, fixed_t dayscale,
|
|
|
|
FVoxel *voxobj, short *daumost, short *dadmost, int minslabz, int maxslabz, int flags);
|
|
|
|
|
|
|
|
int sgn(int v)
|
|
|
|
{
|
|
|
|
return v < 0 ? -1 : v > 0 ? 1 : 0;
|
|
|
|
}
|
2017-01-11 17:25:14 +00:00
|
|
|
};
|
2016-12-25 10:07:50 +00:00
|
|
|
}
|