mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-15 12:10:53 +00:00
- sector portals in Blood are working.
This commit is contained in:
parent
368b2319f2
commit
dbbdfaa4ba
9 changed files with 32 additions and 20 deletions
|
@ -171,11 +171,12 @@ void RenderViewpoint(FRenderViewpoint& mainvp, IntRect* bounds, float fov, float
|
||||||
//
|
//
|
||||||
//===========================================================================
|
//===========================================================================
|
||||||
|
|
||||||
FRenderViewpoint SetupView(spritetype* cam, const vec3_t& position, int sectnum, fixed_t q16angle, fixed_t q16horizon, float rollang)
|
FRenderViewpoint SetupViewpoint(spritetype* cam, const vec3_t& position, int sectnum, fixed_t q16angle, fixed_t q16horizon, float rollang)
|
||||||
{
|
{
|
||||||
FRenderViewpoint r_viewpoint{};
|
FRenderViewpoint r_viewpoint{};
|
||||||
r_viewpoint.CameraSprite = cam;
|
r_viewpoint.CameraSprite = cam;
|
||||||
r_viewpoint.SectNum = sectnum;
|
r_viewpoint.SectNums = nullptr;
|
||||||
|
r_viewpoint.SectCount = sectnum;
|
||||||
r_viewpoint.Pos = { position.x / 16.f, position.y / -16.f, position.z / -256.f };
|
r_viewpoint.Pos = { position.x / 16.f, position.y / -16.f, position.z / -256.f };
|
||||||
r_viewpoint.HWAngles.Yaw = -90.f + q16ang(q16angle).asdeg();
|
r_viewpoint.HWAngles.Yaw = -90.f + q16ang(q16angle).asdeg();
|
||||||
r_viewpoint.HWAngles.Pitch = -HorizToPitch(q16horizon);
|
r_viewpoint.HWAngles.Pitch = -HorizToPitch(q16horizon);
|
||||||
|
@ -278,7 +279,7 @@ void render_drawrooms(spritetype* playersprite, const vec3_t& position, int sect
|
||||||
RenderState->SetVertexBuffer(screen->mVertexData);
|
RenderState->SetVertexBuffer(screen->mVertexData);
|
||||||
screen->mVertexData->Reset();
|
screen->mVertexData->Reset();
|
||||||
|
|
||||||
FRenderViewpoint r_viewpoint = SetupView(playersprite, position, sectnum, q16angle, q16horizon, rollang);
|
FRenderViewpoint r_viewpoint = SetupViewpoint(playersprite, position, sectnum, q16angle, q16horizon, rollang);
|
||||||
iter_dlightf = iter_dlight = draw_dlight = draw_dlightf = 0;
|
iter_dlightf = iter_dlight = draw_dlight = draw_dlightf = 0;
|
||||||
|
|
||||||
checkBenchActive();
|
checkBenchActive();
|
||||||
|
|
|
@ -50,7 +50,7 @@ inline void mergePortals()
|
||||||
{
|
{
|
||||||
auto& pt2 = allPortals[j];
|
auto& pt2 = allPortals[j];
|
||||||
if (pt1.type != pt2.type || pt1.dx != pt2.dx || pt1.dy != pt2.dy || pt1.dz != pt2.dz) continue;
|
if (pt1.type != pt2.type || pt1.dx != pt2.dx || pt1.dy != pt2.dy || pt1.dz != pt2.dz) continue;
|
||||||
for (unsigned s = 0; s < pt1.targets.Size(); s++)
|
for (unsigned s = 0; s < pt1.targets.Size() && pt2.targets.Size(); s++)
|
||||||
{
|
{
|
||||||
for (unsigned t = 0; t < pt2.targets.Size(); t++)
|
for (unsigned t = 0; t < pt2.targets.Size(); t++)
|
||||||
{
|
{
|
||||||
|
@ -63,9 +63,9 @@ inline void mergePortals()
|
||||||
{
|
{
|
||||||
//Printf("Merged %d and %d\n", i, j);
|
//Printf("Merged %d and %d\n", i, j);
|
||||||
if (sector[n].portalnum == j) sector[n].portalnum = i;
|
if (sector[n].portalnum == j) sector[n].portalnum = i;
|
||||||
didsomething = true;
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
|
didsomething = true;
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -491,9 +491,10 @@ void BunchDrawer::ProcessSector(int sectnum)
|
||||||
//
|
//
|
||||||
//==========================================================================
|
//==========================================================================
|
||||||
|
|
||||||
void BunchDrawer::RenderScene(int viewsector)
|
void BunchDrawer::RenderScene(const int* viewsectors, unsigned sectcount)
|
||||||
{
|
{
|
||||||
ProcessSector(viewsector);
|
for(unsigned i=0;i<sectcount;i++)
|
||||||
|
ProcessSector(viewsectors[i]);
|
||||||
while (Bunches.Size() > 0)
|
while (Bunches.Size() > 0)
|
||||||
{
|
{
|
||||||
int closest = FindClosestBunch();
|
int closest = FindClosestBunch();
|
||||||
|
|
|
@ -50,5 +50,5 @@ private:
|
||||||
|
|
||||||
public:
|
public:
|
||||||
void Init(HWDrawInfo* _di, Clipper* c, vec2_t& view);
|
void Init(HWDrawInfo* _di, Clipper* c, vec2_t& view);
|
||||||
void RenderScene(int viewsector);
|
void RenderScene(const int* viewsectors, unsigned sectcount);
|
||||||
};
|
};
|
||||||
|
|
|
@ -308,7 +308,10 @@ void HWDrawInfo::CreateScene()
|
||||||
|
|
||||||
vec2_t view = { int(vp.Pos.X * 16), int(vp.Pos.Y * -16) };
|
vec2_t view = { int(vp.Pos.X * 16), int(vp.Pos.Y * -16) };
|
||||||
mDrawer.Init(this, mClipper, view);
|
mDrawer.Init(this, mClipper, view);
|
||||||
mDrawer.RenderScene(vp.SectNum);
|
if (vp.SectNums)
|
||||||
|
mDrawer.RenderScene(vp.SectNums, vp.SectCount);
|
||||||
|
else
|
||||||
|
mDrawer.RenderScene(&vp.SectCount, 1);
|
||||||
|
|
||||||
screen->mLights->Unmap();
|
screen->mLights->Unmap();
|
||||||
screen->mVertexData->Unmap();
|
screen->mVertexData->Unmap();
|
||||||
|
|
|
@ -40,7 +40,8 @@ struct FRenderViewpoint
|
||||||
FRotator HWAngles;
|
FRotator HWAngles;
|
||||||
FAngle FieldOfView;
|
FAngle FieldOfView;
|
||||||
angle_t RotAngle;
|
angle_t RotAngle;
|
||||||
int SectNum;
|
int* SectNums;
|
||||||
|
int SectCount;
|
||||||
double TicFrac;
|
double TicFrac;
|
||||||
};
|
};
|
||||||
//==========================================================================
|
//==========================================================================
|
||||||
|
|
|
@ -398,6 +398,7 @@ void HWPortal::RemoveStencil(HWDrawInfo *di, FRenderState &state, bool usestenci
|
||||||
void HWScenePortalBase::ClearClipper(HWDrawInfo *di, Clipper *clipper)
|
void HWScenePortalBase::ClearClipper(HWDrawInfo *di, Clipper *clipper)
|
||||||
{
|
{
|
||||||
auto outer_di = di->outer;
|
auto outer_di = di->outer;
|
||||||
|
#if 0 // todo: fixme or remove - Unlike for Doom this won't be of great benefit with Build's rendering approach.
|
||||||
// This requires maximum precision, so convert everything to double.
|
// This requires maximum precision, so convert everything to double.
|
||||||
DAngle angleOffset = deltaangle(DAngle(outer_di->Viewpoint.HWAngles.Yaw.Degrees), DAngle(di->Viewpoint.HWAngles.Yaw.Degrees));
|
DAngle angleOffset = deltaangle(DAngle(outer_di->Viewpoint.HWAngles.Yaw.Degrees), DAngle(di->Viewpoint.HWAngles.Yaw.Degrees));
|
||||||
|
|
||||||
|
@ -418,6 +419,7 @@ void HWScenePortalBase::ClearClipper(HWDrawInfo *di, Clipper *clipper)
|
||||||
clipper->SafeRemoveClipRange(startang, endang);
|
clipper->SafeRemoveClipRange(startang, endang);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
// and finally clip it to the visible area
|
// and finally clip it to the visible area
|
||||||
angle_t a1 = di->FrustumAngle();
|
angle_t a1 = di->FrustumAngle();
|
||||||
|
@ -554,7 +556,9 @@ bool HWMirrorPortal::Setup(HWDrawInfo *di, FRenderState &rstate, Clipper *clippe
|
||||||
int newy = int((y << 1) + Scale(dy, i, j) - view.y);
|
int newy = int((y << 1) + Scale(dy, i, j) - view.y);
|
||||||
int newan = ((gethiq16angle(dx, dy) << 1) - bamang(vp.RotAngle).asq16()) & 0x7FFFFFF;
|
int newan = ((gethiq16angle(dx, dy) << 1) - bamang(vp.RotAngle).asq16()) & 0x7FFFFFF;
|
||||||
vp.RotAngle = q16ang(newan).asbam();
|
vp.RotAngle = q16ang(newan).asbam();
|
||||||
vp.SectNum = line->sector;
|
vp.SectNums = nullptr;
|
||||||
|
vp.SectCount = line->sector;
|
||||||
|
|
||||||
|
|
||||||
vp.Pos.X = newx / 16.f;
|
vp.Pos.X = newx / 16.f;
|
||||||
vp.Pos.Y = newy / -16.f;
|
vp.Pos.Y = newy / -16.f;
|
||||||
|
@ -636,7 +640,8 @@ bool HWLineToLinePortal::Setup(HWDrawInfo *di, FRenderState &rstate, Clipper *cl
|
||||||
int origx = vp.Pos.X * 16;
|
int origx = vp.Pos.X * 16;
|
||||||
int origy = vp.Pos.Y * -16;
|
int origy = vp.Pos.Y * -16;
|
||||||
|
|
||||||
vp.SectNum = line->sector;
|
vp.SectNums = nullptr;
|
||||||
|
vp.SectCount = line->sector;
|
||||||
vp.Pos.X = npos.X;
|
vp.Pos.X = npos.X;
|
||||||
vp.Pos.Y = npos.Y;
|
vp.Pos.Y = npos.Y;
|
||||||
|
|
||||||
|
@ -689,7 +694,8 @@ bool HWLineToSpritePortal::Setup(HWDrawInfo* di, FRenderState& rstate, Clipper*
|
||||||
int origx = vp.Pos.X * 16;
|
int origx = vp.Pos.X * 16;
|
||||||
int origy = vp.Pos.Y * -16;
|
int origy = vp.Pos.Y * -16;
|
||||||
|
|
||||||
vp.SectNum = camera->sectnum;
|
vp.SectNums = nullptr;
|
||||||
|
vp.SectCount = camera->sectnum;
|
||||||
vp.Pos.X = npos.X;
|
vp.Pos.X = npos.X;
|
||||||
vp.Pos.Y = npos.Y;
|
vp.Pos.Y = npos.Y;
|
||||||
|
|
||||||
|
@ -803,8 +809,8 @@ bool HWSectorStackPortal::Setup(HWDrawInfo *di, FRenderState &rstate, Clipper *c
|
||||||
auto &vp = di->Viewpoint;
|
auto &vp = di->Viewpoint;
|
||||||
|
|
||||||
vp.Pos += DVector3(portal->dx / 16., portal->dy / -16., portal->dz / -256.);
|
vp.Pos += DVector3(portal->dx / 16., portal->dy / -16., portal->dz / -256.);
|
||||||
//vp.ActorPos += origin->mDisplacement;
|
vp.SectNums = portal->targets.Data();
|
||||||
//vp.ViewActor = nullptr;
|
vp.SectCount = portal->targets.Size();
|
||||||
|
|
||||||
// avoid recursions!
|
// avoid recursions!
|
||||||
screen->instack[origin->type == PORTAL_SECTOR_CEILING ? 1 : 0]++;
|
screen->instack[origin->type == PORTAL_SECTOR_CEILING ? 1 : 0]++;
|
||||||
|
@ -829,7 +835,7 @@ const char *HWSectorStackPortal::GetName() { return "Sectorstack"; }
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
//
|
//
|
||||||
//
|
//
|
||||||
// Plane Mirror Portal
|
// Plane Mirror Portal (currently not needed, Witchaven 2 is the only Build game using such a feature)
|
||||||
//
|
//
|
||||||
//
|
//
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
|
|
|
@ -115,7 +115,7 @@ void HWWall::SkyPlane(HWDrawInfo *di, sectortype *sector, int plane, bool allowr
|
||||||
|
|
||||||
void HWWall::SkyNormal(HWDrawInfo* di, sectortype* fs, FVector2& v1, FVector2& v2, float fch1, float fch2, float ffh1, float ffh2)
|
void HWWall::SkyNormal(HWDrawInfo* di, sectortype* fs, FVector2& v1, FVector2& v2, float fch1, float fch2, float ffh1, float ffh2)
|
||||||
{
|
{
|
||||||
if (fs->ceilingstat & CSTAT_SECTOR_SKY)
|
if ((fs->ceilingstat & CSTAT_SECTOR_SKY) || fs->portalflags == PORTAL_SECTOR_CEILING || fs->portalflags == PORTAL_SECTOR_CEILING_REFLECT)
|
||||||
{
|
{
|
||||||
ztop[0] = ztop[1] = 32768.0f;
|
ztop[0] = ztop[1] = 32768.0f;
|
||||||
zbottom[0] = fch1;
|
zbottom[0] = fch1;
|
||||||
|
@ -123,7 +123,7 @@ void HWWall::SkyNormal(HWDrawInfo* di, sectortype* fs, FVector2& v1, FVector2& v
|
||||||
SkyPlane(di, fs, plane_ceiling, true);
|
SkyPlane(di, fs, plane_ceiling, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (fs->floorstat & CSTAT_SECTOR_SKY)
|
if ((fs->floorstat & CSTAT_SECTOR_SKY) || fs->portalflags == PORTAL_SECTOR_FLOOR || fs->portalflags == PORTAL_SECTOR_FLOOR_REFLECT)
|
||||||
{
|
{
|
||||||
ztop[0] = ffh1;
|
ztop[0] = ffh1;
|
||||||
ztop[1] = ffh2;
|
ztop[1] = ffh2;
|
||||||
|
|
|
@ -136,7 +136,7 @@ void InitMirrors(void)
|
||||||
mirror[mirrorcnt].link = i;
|
mirror[mirrorcnt].link = i;
|
||||||
sector[j].ceilingpicnum = 4080+mirrorcnt;
|
sector[j].ceilingpicnum = 4080+mirrorcnt;
|
||||||
sector[j].portalflags = PORTAL_SECTOR_CEILING;
|
sector[j].portalflags = PORTAL_SECTOR_CEILING;
|
||||||
sector[i].portalnum = portalAdd(PORTAL_SECTOR_CEILING, j, mirror[mirrorcnt].dx, mirror[mirrorcnt].dy, mirror[mirrorcnt].dz);
|
sector[j].portalnum = portalAdd(PORTAL_SECTOR_CEILING, i, mirror[mirrorcnt].dx, mirror[mirrorcnt].dy, mirror[mirrorcnt].dz);
|
||||||
mirrorcnt++;
|
mirrorcnt++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue