qzdoom/src/swrenderer/segments/r_drawsegment.h

79 lines
2.5 KiB
C
Raw Normal View History

//
// Copyright (C) 1993-1996 by id Software, Inc.
//
// This source is available for distribution and/or modification
// only under the terms of the DOOM Source Code License as
// published by id Software. All rights reserved.
//
// The source is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// FITNESS FOR A PARTICULAR PURPOSE. See the DOOM Source Code License
// for more details.
//
#pragma once
2017-01-01 09:28:35 +00:00
#include "swrenderer/line/r_line.h"
2016-12-30 05:08:47 +00:00
namespace swrenderer
{
2017-01-26 06:03:27 +00:00
struct DrawSegment
{
seg_t *curline;
float light, lightstep;
float iscale, iscalestep;
short x1, x2; // Same as sx1 and sx2, but clipped to the drawseg
short sx1, sx2; // left, right of parent seg on screen
float sz1, sz2; // z for left, right of parent seg on screen
float siz1, siz2; // 1/z for left, right of parent seg on screen
float cx, cy, cdx, cdy;
float yscale;
uint8_t silhouette; // 0=none, 1=bottom, 2=top, 3=both
uint8_t bFogBoundary;
uint8_t bFakeBoundary; // for fake walls
int shade;
2017-01-12 19:13:21 +00:00
bool foggy;
// Pointers to lists for sprite clipping, all three adjusted so [x1] is first value.
2017-01-15 21:21:21 +00:00
short *sprtopclip;
short *sprbottomclip;
fixed_t *maskedtexturecol;
float *swall;
short *bkup; // sprtopclip backup, for mid and fake textures
FWallTmapVals tmapvals;
int fake; // ident fake drawseg, don't draw and clip sprites backups
int CurrentPortalUniq; // [ZZ] to identify the portal that this drawseg is in. used for sprite clipping.
};
2017-01-26 07:01:44 +00:00
class DrawSegmentList
{
public:
DrawSegmentList(RenderThread *thread);
2017-01-26 07:01:44 +00:00
2017-02-03 20:11:55 +00:00
unsigned int BeginIndex() const { return StartIndices.Last(); }
unsigned int EndIndex() const { return Segments.Size(); }
2017-02-03 20:25:51 +00:00
DrawSegment *Segment(unsigned int index) const { return Segments[Segments.Size() - 1 - index]; }
2017-01-26 07:01:44 +00:00
2017-02-03 20:11:55 +00:00
unsigned int BeginInterestingIndex() const { return StartInterestingIndices.Last(); }
unsigned int EndInterestingIndex() const { return InterestingSegments.Size(); }
2017-02-03 20:25:51 +00:00
DrawSegment *InterestingSegment(unsigned int index) const { return InterestingSegments[InterestingSegments.Size() - 1 - index]; }
2017-01-26 07:01:44 +00:00
void Clear();
2017-02-03 20:11:55 +00:00
void PushPortal();
void PopPortal();
void Push(DrawSegment *segment);
void PushInteresting(DrawSegment *segment);
2017-01-26 07:01:44 +00:00
RenderThread *Thread = nullptr;
2017-01-26 07:01:44 +00:00
private:
2017-02-03 20:11:55 +00:00
TArray<DrawSegment *> Segments;
TArray<unsigned int> StartIndices;
TArray<DrawSegment *> InterestingSegments; // drawsegs that have something drawn on them
TArray<unsigned int> StartInterestingIndices;
2017-01-26 07:01:44 +00:00
};
}