mirror of
https://github.com/ZDoom/gzdoom.git
synced 2024-11-22 12:11:25 +00:00
- building the new base class.
This commit is contained in:
parent
783d532bbe
commit
1169922bf0
4 changed files with 257 additions and 126 deletions
|
@ -56,12 +56,12 @@ IMPLEMENT_CLASS(DHUDFont, true, false);
|
||||||
|
|
||||||
|
|
||||||
CVAR(Color, crosshaircolor, 0xff0000, CVAR_ARCHIVE);
|
CVAR(Color, crosshaircolor, 0xff0000, CVAR_ARCHIVE);
|
||||||
CVAR(Int, crosshairhealth, 1, CVAR_ARCHIVE);
|
CVAR(Int, crosshairhealth, 2, CVAR_ARCHIVE);
|
||||||
CVAR(Float, crosshairscale, 1.0, CVAR_ARCHIVE);
|
CVAR(Float, crosshairscale, 1.0, CVAR_ARCHIVE);
|
||||||
CVAR(Bool, crosshairgrow, false, CVAR_ARCHIVE);
|
CVAR(Bool, crosshairgrow, false, CVAR_ARCHIVE);
|
||||||
EXTERN_CVAR(Bool, vid_fps)
|
EXTERN_CVAR(Bool, vid_fps)
|
||||||
|
|
||||||
|
EXTERN_CVAR(Float, hud_scalefactor)
|
||||||
|
|
||||||
void ST_LoadCrosshair(int num, bool alwaysload)
|
void ST_LoadCrosshair(int num, bool alwaysload)
|
||||||
{
|
{
|
||||||
|
@ -249,6 +249,178 @@ void DStatusBarCore::ValidateResolution(int& hres, int& vres) const
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
//============================================================================
|
||||||
|
//
|
||||||
|
//
|
||||||
|
//
|
||||||
|
//============================================================================
|
||||||
|
|
||||||
|
void DStatusBarCore::SetSize(int reltop, int hres, int vres, int hhres, int hvres)
|
||||||
|
{
|
||||||
|
ValidateResolution(hres, vres);
|
||||||
|
|
||||||
|
BaseRelTop = reltop;
|
||||||
|
BaseSBarHorizontalResolution = hres;
|
||||||
|
BaseSBarVerticalResolution = vres;
|
||||||
|
BaseHUDHorizontalResolution = hhres < 0 ? hres : hhres;
|
||||||
|
BaseHUDVerticalResolution = hvres < 0 ? vres : hvres;
|
||||||
|
SetDrawSize(reltop, hres, vres);
|
||||||
|
}
|
||||||
|
|
||||||
|
//============================================================================
|
||||||
|
//
|
||||||
|
// calculates a clean scale for the status bar
|
||||||
|
//
|
||||||
|
//============================================================================
|
||||||
|
|
||||||
|
static void ST_CalcCleanFacs(int designwidth, int designheight, int realwidth, int realheight, int* cleanx, int* cleany)
|
||||||
|
{
|
||||||
|
float ratio;
|
||||||
|
int cwidth;
|
||||||
|
int cheight;
|
||||||
|
int cx1, cy1, cx2, cy2;
|
||||||
|
|
||||||
|
ratio = ActiveRatio(realwidth, realheight);
|
||||||
|
if (AspectTallerThanWide(ratio))
|
||||||
|
{
|
||||||
|
cwidth = realwidth;
|
||||||
|
cheight = realheight * AspectMultiplier(ratio) / 48;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
cwidth = realwidth * AspectMultiplier(ratio) / 48;
|
||||||
|
cheight = realheight;
|
||||||
|
}
|
||||||
|
// Use whichever pair of cwidth/cheight or width/height that produces less difference
|
||||||
|
// between CleanXfac and CleanYfac.
|
||||||
|
cx1 = MAX(cwidth / designwidth, 1);
|
||||||
|
cy1 = MAX(cheight / designheight, 1);
|
||||||
|
cx2 = MAX(realwidth / designwidth, 1);
|
||||||
|
cy2 = MAX(realheight / designheight, 1);
|
||||||
|
if (abs(cx1 - cy1) <= abs(cx2 - cy2) || MAX(cx1, cx2) >= 4)
|
||||||
|
{ // e.g. 640x360 looks better with this.
|
||||||
|
*cleanx = cx1;
|
||||||
|
*cleany = cy1;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{ // e.g. 720x480 looks better with this.
|
||||||
|
*cleanx = cx2;
|
||||||
|
*cleany = cy2;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (*cleanx < *cleany)
|
||||||
|
*cleany = *cleanx;
|
||||||
|
else
|
||||||
|
*cleanx = *cleany;
|
||||||
|
}
|
||||||
|
|
||||||
|
//============================================================================
|
||||||
|
//
|
||||||
|
//
|
||||||
|
//
|
||||||
|
//============================================================================
|
||||||
|
|
||||||
|
void DStatusBarCore::SetDrawSize(int reltop, int hres, int vres)
|
||||||
|
{
|
||||||
|
ValidateResolution(hres, vres);
|
||||||
|
|
||||||
|
RelTop = reltop;
|
||||||
|
HorizontalResolution = hres;
|
||||||
|
VerticalResolution = vres;
|
||||||
|
|
||||||
|
int x, y;
|
||||||
|
ST_CalcCleanFacs(hres, vres, twod->GetWidth(), twod->GetHeight(), &x, &y);
|
||||||
|
defaultScale = { (double)x, (double)y };
|
||||||
|
|
||||||
|
SetScale(); // recalculate positioning info.
|
||||||
|
}
|
||||||
|
|
||||||
|
//---------------------------------------------------------------------------
|
||||||
|
//
|
||||||
|
// PROC SetScaled
|
||||||
|
//
|
||||||
|
//---------------------------------------------------------------------------
|
||||||
|
|
||||||
|
void DStatusBarCore::SetScale()
|
||||||
|
{
|
||||||
|
ValidateResolution(HorizontalResolution, VerticalResolution);
|
||||||
|
|
||||||
|
int w = twod->GetWidth();
|
||||||
|
int h = twod->GetHeight();
|
||||||
|
double refw, refh;
|
||||||
|
|
||||||
|
int horz = HorizontalResolution;
|
||||||
|
int vert = VerticalResolution;
|
||||||
|
double refaspect = horz / double(vert);
|
||||||
|
double screenaspect = w / double(h);
|
||||||
|
|
||||||
|
if ((horz == 320 && vert == 200) || (horz == 640 && vert == 400))
|
||||||
|
{
|
||||||
|
refaspect = 1.333;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (screenaspect < refaspect)
|
||||||
|
{
|
||||||
|
refw = w;
|
||||||
|
refh = w / refaspect;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
refh = h;
|
||||||
|
refw = h * refaspect;
|
||||||
|
}
|
||||||
|
refw *= hud_scalefactor;
|
||||||
|
refh *= hud_scalefactor;
|
||||||
|
|
||||||
|
int sby = VerticalResolution - RelTop;
|
||||||
|
// Use full pixels for destination size.
|
||||||
|
|
||||||
|
ST_X = xs_CRoundToInt((w - refw) / 2);
|
||||||
|
ST_Y = xs_CRoundToInt(h - refh);
|
||||||
|
SBarTop = Scale(sby, h, VerticalResolution);
|
||||||
|
SBarScale.X = refw / horz;
|
||||||
|
SBarScale.Y = refh / vert;
|
||||||
|
}
|
||||||
|
|
||||||
|
//---------------------------------------------------------------------------
|
||||||
|
//
|
||||||
|
// PROC GetHUDScale
|
||||||
|
//
|
||||||
|
//---------------------------------------------------------------------------
|
||||||
|
|
||||||
|
DVector2 DStatusBarCore::GetHUDScale() const
|
||||||
|
{
|
||||||
|
return SBarScale;
|
||||||
|
}
|
||||||
|
|
||||||
|
//---------------------------------------------------------------------------
|
||||||
|
//
|
||||||
|
//
|
||||||
|
//
|
||||||
|
//---------------------------------------------------------------------------
|
||||||
|
|
||||||
|
void DStatusBarCore::BeginStatusBar(int resW, int resH, int relTop, bool forceScaled)
|
||||||
|
{
|
||||||
|
SetDrawSize(relTop < 0 ? BaseRelTop : relTop, resW < 0 ? BaseSBarHorizontalResolution : resW, resH < 0 ? BaseSBarVerticalResolution : resH);
|
||||||
|
ForcedScale = forceScaled;
|
||||||
|
fullscreenOffsets = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
//---------------------------------------------------------------------------
|
||||||
|
//
|
||||||
|
//
|
||||||
|
//
|
||||||
|
//---------------------------------------------------------------------------
|
||||||
|
|
||||||
|
void DStatusBarCore::BeginHUD(int resW, int resH, double Alpha, bool forcescaled)
|
||||||
|
{
|
||||||
|
SetDrawSize(RelTop, resW < 0 ? BaseHUDHorizontalResolution : resW, resH < 0 ? BaseHUDVerticalResolution : resH);
|
||||||
|
this->Alpha = Alpha;
|
||||||
|
ForcedScale = forcescaled;
|
||||||
|
CompleteBorder = false;
|
||||||
|
fullscreenOffsets = true;
|
||||||
|
}
|
||||||
|
|
||||||
//============================================================================
|
//============================================================================
|
||||||
//
|
//
|
||||||
// draw stuff
|
// draw stuff
|
||||||
|
@ -280,15 +452,22 @@ void DStatusBarCore::StatusbarToRealCoords(double& x, double& y, double& w, doub
|
||||||
//
|
//
|
||||||
//============================================================================
|
//============================================================================
|
||||||
|
|
||||||
void DStatusBarCore::DrawGraphic(FTextureID texture, double x, double y, int flags, double Alpha, double boxwidth, double boxheight, double scaleX, double scaleY)
|
void DStatusBarCore::DrawGraphic(FTextureID texture, double x, double y, int flags, double Alpha, double boxwidth, double boxheight, double scaleX, double scaleY, PalEntry color, int translation, double rotate, ERenderStyle style)
|
||||||
{
|
{
|
||||||
if (!texture.isValid())
|
if (!texture.isValid())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
FGameTexture* tex = TexMan.GetGameTexture(texture, !(flags & DI_DONTANIMATE));
|
FGameTexture* tex = TexMan.GetGameTexture(texture, !(flags & DI_DONTANIMATE));
|
||||||
|
DrawGraphic(tex, x, y, flags, Alpha, boxwidth, boxheight, scaleX, scaleY, color, translation, rotate, style);
|
||||||
|
}
|
||||||
|
|
||||||
|
void DStatusBarCore::DrawGraphic(FGameTexture* tex, double x, double y, int flags, double Alpha, double boxwidth, double boxheight, double scaleX, double scaleY, PalEntry color, int translation, double rotate, ERenderStyle style)
|
||||||
|
{
|
||||||
double texwidth = tex->GetDisplayWidth() * scaleX;
|
double texwidth = tex->GetDisplayWidth() * scaleX;
|
||||||
double texheight = tex->GetDisplayHeight() * scaleY;
|
double texheight = tex->GetDisplayHeight() * scaleY;
|
||||||
|
double texleftoffs = tex->GetDisplayLeftOffset() * scaleY;
|
||||||
|
double textopoffs = tex->GetDisplayTopOffset() * scaleY;
|
||||||
|
double boxleftoffs, boxtopoffs;
|
||||||
|
|
||||||
if (boxwidth > 0 || boxheight > 0)
|
if (boxwidth > 0 || boxheight > 0)
|
||||||
{
|
{
|
||||||
|
@ -314,12 +493,16 @@ void DStatusBarCore::DrawGraphic(FTextureID texture, double x, double y, int fla
|
||||||
|
|
||||||
boxwidth = texwidth * scale1;
|
boxwidth = texwidth * scale1;
|
||||||
boxheight = texheight * scale1;
|
boxheight = texheight * scale1;
|
||||||
|
boxleftoffs = texleftoffs * scale1;
|
||||||
|
boxtopoffs = textopoffs * scale1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
boxwidth = texwidth;
|
boxwidth = texwidth;
|
||||||
boxheight = texheight;
|
boxheight = texheight;
|
||||||
|
boxleftoffs = texleftoffs;
|
||||||
|
boxtopoffs = textopoffs;
|
||||||
}
|
}
|
||||||
|
|
||||||
// resolve auto-alignment before making any adjustments to the position values.
|
// resolve auto-alignment before making any adjustments to the position values.
|
||||||
|
@ -336,18 +519,28 @@ void DStatusBarCore::DrawGraphic(FTextureID texture, double x, double y, int fla
|
||||||
x += drawOffset.X;
|
x += drawOffset.X;
|
||||||
y += drawOffset.Y;
|
y += drawOffset.Y;
|
||||||
|
|
||||||
switch (flags & DI_ITEM_HMASK)
|
if (flags & DI_ITEM_RELCENTER)
|
||||||
{
|
{
|
||||||
case DI_ITEM_HCENTER: x -= boxwidth / 2; break;
|
if (flags & DI_MIRROR) boxleftoffs = -boxleftoffs;
|
||||||
case DI_ITEM_RIGHT: x -= boxwidth; break;
|
if (flags & DI_MIRRORY) boxtopoffs = -boxtopoffs;
|
||||||
case DI_ITEM_HOFFSET: x -= tex->GetDisplayLeftOffset() * boxwidth / texwidth; break;
|
x -= boxwidth / 2 + boxleftoffs;
|
||||||
|
y -= boxheight / 2 + boxtopoffs;
|
||||||
}
|
}
|
||||||
|
else
|
||||||
switch (flags & DI_ITEM_VMASK)
|
|
||||||
{
|
{
|
||||||
case DI_ITEM_VCENTER: y -= boxheight / 2; break;
|
switch (flags & DI_ITEM_HMASK)
|
||||||
case DI_ITEM_BOTTOM: y -= boxheight; break;
|
{
|
||||||
case DI_ITEM_VOFFSET: y -= tex->GetDisplayTopOffset() * boxheight / texheight; break;
|
case DI_ITEM_HCENTER: x -= boxwidth / 2; break;
|
||||||
|
case DI_ITEM_RIGHT: x -= boxwidth; break;
|
||||||
|
case DI_ITEM_HOFFSET: x -= boxleftoffs; break;
|
||||||
|
}
|
||||||
|
|
||||||
|
switch (flags & DI_ITEM_VMASK)
|
||||||
|
{
|
||||||
|
case DI_ITEM_VCENTER: y -= boxheight / 2; break;
|
||||||
|
case DI_ITEM_BOTTOM: y -= boxheight; break;
|
||||||
|
case DI_ITEM_VOFFSET: y -= boxtopoffs; break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!fullscreenOffsets)
|
if (!fullscreenOffsets)
|
||||||
|
@ -389,12 +582,16 @@ void DStatusBarCore::DrawGraphic(FTextureID texture, double x, double y, int fla
|
||||||
DTA_LeftOffset, 0,
|
DTA_LeftOffset, 0,
|
||||||
DTA_DestWidthF, boxwidth,
|
DTA_DestWidthF, boxwidth,
|
||||||
DTA_DestHeightF, boxheight,
|
DTA_DestHeightF, boxheight,
|
||||||
DTA_TranslationIndex, (flags & DI_TRANSLATABLE) ? GetTranslation() : 0,
|
DTA_Color, color,
|
||||||
|
DTA_TranslationIndex, translation? translation : (flags & DI_TRANSLATABLE) ? GetTranslation() : 0,
|
||||||
DTA_ColorOverlay, (flags & DI_DIM) ? MAKEARGB(170, 0, 0, 0) : 0,
|
DTA_ColorOverlay, (flags & DI_DIM) ? MAKEARGB(170, 0, 0, 0) : 0,
|
||||||
DTA_Alpha, Alpha,
|
DTA_Alpha, Alpha,
|
||||||
DTA_AlphaChannel, !!(flags & DI_ALPHAMAPPED),
|
DTA_AlphaChannel, !!(flags & DI_ALPHAMAPPED),
|
||||||
DTA_FillColor, (flags & DI_ALPHAMAPPED) ? 0 : -1,
|
DTA_FillColor, (flags & DI_ALPHAMAPPED) ? 0 : -1,
|
||||||
DTA_FlipX, !!(flags & DI_MIRROR),
|
DTA_FlipX, !!(flags & DI_MIRROR),
|
||||||
|
DTA_FlipY, !!(flags& DI_MIRRORY),
|
||||||
|
DTA_Rotate, rotate,
|
||||||
|
DTA_LegacyRenderStyle, style,
|
||||||
TAG_DONE);
|
TAG_DONE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -476,11 +673,12 @@ void DStatusBarCore::DrawString(FFont* font, const FString& cstring, double x, d
|
||||||
}
|
}
|
||||||
|
|
||||||
int width;
|
int width;
|
||||||
auto c = font->GetChar(ch, fontcolor, &width);
|
FGameTexture* c = font->GetChar(ch, fontcolor, &width);
|
||||||
if (c == NULL) //missing character.
|
if (c == NULL) //missing character.
|
||||||
{
|
{
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
width += font->GetDefaultKerning();
|
||||||
|
|
||||||
if (!monospaced) //If we are monospaced lets use the offset
|
if (!monospaced) //If we are monospaced lets use the offset
|
||||||
x += (c->GetDisplayLeftOffset() + 1); //ignore x offsets since we adapt to character size
|
x += (c->GetDisplayLeftOffset() + 1); //ignore x offsets since we adapt to character size
|
||||||
|
|
|
@ -20,6 +20,8 @@ enum DI_Flags
|
||||||
DI_SKIPSPAWN = 0x4,
|
DI_SKIPSPAWN = 0x4,
|
||||||
DI_SKIPREADY = 0x8,
|
DI_SKIPREADY = 0x8,
|
||||||
DI_ALTICONFIRST = 0x10,
|
DI_ALTICONFIRST = 0x10,
|
||||||
|
|
||||||
|
|
||||||
DI_TRANSLATABLE = 0x20,
|
DI_TRANSLATABLE = 0x20,
|
||||||
DI_FORCESCALE = 0x40,
|
DI_FORCESCALE = 0x40,
|
||||||
DI_DIM = 0x80,
|
DI_DIM = 0x80,
|
||||||
|
@ -28,6 +30,8 @@ enum DI_Flags
|
||||||
DI_DIMDEPLETED = 0x400,
|
DI_DIMDEPLETED = 0x400,
|
||||||
DI_DONTANIMATE = 0x800, // do not animate the texture
|
DI_DONTANIMATE = 0x800, // do not animate the texture
|
||||||
DI_MIRROR = 0x1000, // flip the texture horizontally, like a mirror
|
DI_MIRROR = 0x1000, // flip the texture horizontally, like a mirror
|
||||||
|
DI_ITEM_RELCENTER = 0x2000,
|
||||||
|
DI_MIRRORY = 0x40000000,
|
||||||
|
|
||||||
DI_SCREEN_AUTO = 0, // decide based on given offsets.
|
DI_SCREEN_AUTO = 0, // decide based on given offsets.
|
||||||
DI_SCREEN_MANUAL_ALIGN = 0x4000, // If this is on, the following flags will have an effect
|
DI_SCREEN_MANUAL_ALIGN = 0x4000, // If this is on, the following flags will have an effect
|
||||||
|
@ -148,21 +152,35 @@ public:
|
||||||
int ST_X;
|
int ST_X;
|
||||||
int ST_Y;
|
int ST_Y;
|
||||||
int SBarTop;
|
int SBarTop;
|
||||||
DVector2 SBarScale;
|
|
||||||
int RelTop;
|
int RelTop;
|
||||||
int HorizontalResolution, VerticalResolution;
|
int HorizontalResolution, VerticalResolution;
|
||||||
double Alpha = 1.;
|
double Alpha = 1.;
|
||||||
|
DVector2 SBarScale;
|
||||||
DVector2 drawOffset = { 0,0 }; // can be set by subclasses to offset drawing operations
|
DVector2 drawOffset = { 0,0 }; // can be set by subclasses to offset drawing operations
|
||||||
|
DVector2 defaultScale; // factor for clean fully scaled display.
|
||||||
double drawClip[4] = { 0,0,0,0 }; // defines a clipping rectangle (not used yet)
|
double drawClip[4] = { 0,0,0,0 }; // defines a clipping rectangle (not used yet)
|
||||||
bool fullscreenOffsets = false; // current screen is displayed with fullscreen behavior.
|
bool fullscreenOffsets = false; // current screen is displayed with fullscreen behavior.
|
||||||
bool ForcedScale = false;
|
bool ForcedScale = false;
|
||||||
|
bool CompleteBorder = false;
|
||||||
|
|
||||||
|
int BaseRelTop;
|
||||||
|
int BaseSBarHorizontalResolution;
|
||||||
|
int BaseSBarVerticalResolution;
|
||||||
|
int BaseHUDHorizontalResolution;
|
||||||
|
int BaseHUDVerticalResolution;
|
||||||
|
|
||||||
|
|
||||||
virtual DVector2 GetHUDScale() const = 0;
|
void BeginStatusBar(int resW, int resH, int relTop, bool forceScaled = false);
|
||||||
|
void BeginHUD(int resW, int resH, double Alpha, bool forceScaled = false);
|
||||||
|
void SetSize(int reltop = 32, int hres = 320, int vres = 200, int hhres = -1, int hvres = -1);
|
||||||
|
virtual DVector2 GetHUDScale() const;
|
||||||
virtual uint32_t GetTranslation() const { return 0; }
|
virtual uint32_t GetTranslation() const { return 0; }
|
||||||
|
void SetDrawSize(int reltop, int hres, int vres);
|
||||||
|
virtual void SetScale();
|
||||||
void ValidateResolution(int& hres, int& vres) const;
|
void ValidateResolution(int& hres, int& vres) const;
|
||||||
void StatusbarToRealCoords(double& x, double& y, double& w, double& h) const;
|
void StatusbarToRealCoords(double& x, double& y, double& w, double& h) const;
|
||||||
void DrawGraphic(FTextureID texture, double x, double y, int flags, double Alpha, double boxwidth, double boxheight, double scaleX, double scaleY);
|
void DrawGraphic(FGameTexture* texture, double x, double y, int flags, double Alpha, double boxwidth, double boxheight, double scaleX, double scaleY, PalEntry color = 0xffffffff, int translation = 0, double rotate = 0, ERenderStyle style = STYLE_Translucent);
|
||||||
|
void DrawGraphic(FTextureID texture, double x, double y, int flags, double Alpha, double boxwidth, double boxheight, double scaleX, double scaleY, PalEntry color = 0xffffffff, int translation = 0, double rotate = 0, ERenderStyle style = STYLE_Translucent);
|
||||||
void DrawString(FFont* font, const FString& cstring, double x, double y, int flags, double Alpha, int translation, int spacing, EMonospacing monospacing, int shadowX, int shadowY, double scaleX, double scaleY);
|
void DrawString(FFont* font, const FString& cstring, double x, double y, int flags, double Alpha, int translation, int spacing, EMonospacing monospacing, int shadowX, int shadowY, double scaleX, double scaleY);
|
||||||
void TransformRect(double& x, double& y, double& w, double& h, int flags = 0);
|
void TransformRect(double& x, double& y, double& w, double& h, int flags = 0);
|
||||||
void Fill(PalEntry color, double x, double y, double w, double h, int flags = 0);
|
void Fill(PalEntry color, double x, double y, double w, double h, int flags = 0);
|
||||||
|
|
|
@ -369,7 +369,6 @@ public:
|
||||||
|
|
||||||
|
|
||||||
DBaseStatusBar ();
|
DBaseStatusBar ();
|
||||||
void SetSize(int reltop = 32, int hres = 320, int vres = 200, int hhres = -1, int hvres = -1);
|
|
||||||
void OnDestroy() override;
|
void OnDestroy() override;
|
||||||
|
|
||||||
void AttachMessage (DHUDMessageBase *msg, uint32_t id=0, int layer=HUDMSGLayer_Default);
|
void AttachMessage (DHUDMessageBase *msg, uint32_t id=0, int layer=HUDMSGLayer_Default);
|
||||||
|
@ -407,8 +406,6 @@ public:
|
||||||
void CreateAltHUD();
|
void CreateAltHUD();
|
||||||
void DrawAltHUD();
|
void DrawAltHUD();
|
||||||
|
|
||||||
void BeginStatusBar(int resW, int resH, int relTop, bool forceScaled);
|
|
||||||
void BeginHUD(int resW, int resH, double Alpha, bool forceScaled = false);
|
|
||||||
bool ForceHUDScale(bool on) { std::swap(ForcedScale, on); return on; } // This is for SBARINFO which should not use BeginStatusBar or BeginHUD.
|
bool ForceHUDScale(bool on) { std::swap(ForcedScale, on); return on; } // This is for SBARINFO which should not use BeginStatusBar or BeginHUD.
|
||||||
int GetTopOfStatusbar() const
|
int GetTopOfStatusbar() const
|
||||||
{
|
{
|
||||||
|
@ -433,11 +430,9 @@ public:
|
||||||
|
|
||||||
// Sizing info for ths status bar.
|
// Sizing info for ths status bar.
|
||||||
bool Scaled; // This needs to go away.
|
bool Scaled; // This needs to go away.
|
||||||
DVector2 defaultScale; // factor for fully scaled fullscreen display.
|
|
||||||
|
|
||||||
bool Centering;
|
bool Centering;
|
||||||
bool FixedOrigin;
|
bool FixedOrigin;
|
||||||
bool CompleteBorder;
|
|
||||||
double CrosshairSize;
|
double CrosshairSize;
|
||||||
double Displacement;
|
double Displacement;
|
||||||
bool ShowLog;
|
bool ShowLog;
|
||||||
|
@ -453,16 +448,8 @@ private:
|
||||||
void DrawMessages (int layer, int bottom);
|
void DrawMessages (int layer, int bottom);
|
||||||
void DrawConsistancy () const;
|
void DrawConsistancy () const;
|
||||||
void DrawWaiting () const;
|
void DrawWaiting () const;
|
||||||
void SetDrawSize(int reltop, int hres, int vres);
|
|
||||||
|
|
||||||
TObjPtr<DHUDMessageBase*> Messages[NUM_HUDMSGLAYERS];
|
TObjPtr<DHUDMessageBase*> Messages[NUM_HUDMSGLAYERS];
|
||||||
|
|
||||||
int BaseRelTop;
|
|
||||||
int BaseSBarHorizontalResolution;
|
|
||||||
int BaseSBarVerticalResolution;
|
|
||||||
int BaseHUDHorizontalResolution;
|
|
||||||
int BaseHUDVerticalResolution;
|
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
extern DBaseStatusBar *StatusBar;
|
extern DBaseStatusBar *StatusBar;
|
||||||
|
|
|
@ -92,6 +92,7 @@ EXTERN_CVAR(Bool, ui_screenborder_classic_scaling)
|
||||||
|
|
||||||
CVAR(Int, hud_scale, 0, CVAR_ARCHIVE);
|
CVAR(Int, hud_scale, 0, CVAR_ARCHIVE);
|
||||||
CVAR(Bool, log_vgafont, false, CVAR_ARCHIVE)
|
CVAR(Bool, log_vgafont, false, CVAR_ARCHIVE)
|
||||||
|
CVAR(Bool, hud_oldscale, true, CVAR_ARCHIVE)
|
||||||
|
|
||||||
DBaseStatusBar *StatusBar;
|
DBaseStatusBar *StatusBar;
|
||||||
|
|
||||||
|
@ -103,6 +104,18 @@ CVAR (Flag, pf_poison, paletteflash, PF_POISON)
|
||||||
CVAR (Flag, pf_ice, paletteflash, PF_ICE)
|
CVAR (Flag, pf_ice, paletteflash, PF_ICE)
|
||||||
CVAR (Flag, pf_hazard, paletteflash, PF_HAZARD)
|
CVAR (Flag, pf_hazard, paletteflash, PF_HAZARD)
|
||||||
|
|
||||||
|
CUSTOM_CVARD(Float, hud_scalefactor, 1, CVAR_ARCHIVE, "changes the hud scale")
|
||||||
|
{
|
||||||
|
if (self < 0.36f) self = 0.36f;
|
||||||
|
else if (self > 1) self = 1;
|
||||||
|
else if (StatusBar)
|
||||||
|
{
|
||||||
|
StatusBar->SetScale();
|
||||||
|
setsizeneeded = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
// Stretch status bar to full screen width?
|
// Stretch status bar to full screen width?
|
||||||
CUSTOM_CVAR (Int, st_scale, 0, CVAR_ARCHIVE)
|
CUSTOM_CVAR (Int, st_scale, 0, CVAR_ARCHIVE)
|
||||||
{
|
{
|
||||||
|
@ -400,74 +413,6 @@ DBaseStatusBar::DBaseStatusBar ()
|
||||||
CreateAltHUD();
|
CreateAltHUD();
|
||||||
}
|
}
|
||||||
|
|
||||||
void DBaseStatusBar::SetSize(int reltop, int hres, int vres, int hhres, int hvres)
|
|
||||||
{
|
|
||||||
ValidateResolution(hres, vres);
|
|
||||||
|
|
||||||
BaseRelTop = reltop;
|
|
||||||
BaseSBarHorizontalResolution = hres;
|
|
||||||
BaseSBarVerticalResolution = vres;
|
|
||||||
BaseHUDHorizontalResolution = hhres < 0? hres : hhres;
|
|
||||||
BaseHUDVerticalResolution = hvres < 0? vres : hvres;
|
|
||||||
SetDrawSize(reltop, hres, vres);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void ST_CalcCleanFacs(int designwidth, int designheight, int realwidth, int realheight, int *cleanx, int *cleany)
|
|
||||||
{
|
|
||||||
float ratio;
|
|
||||||
int cwidth;
|
|
||||||
int cheight;
|
|
||||||
int cx1, cy1, cx2, cy2;
|
|
||||||
|
|
||||||
ratio = ActiveRatio(realwidth, realheight);
|
|
||||||
if (AspectTallerThanWide(ratio))
|
|
||||||
{
|
|
||||||
cwidth = realwidth;
|
|
||||||
cheight = realheight * AspectMultiplier(ratio) / 48;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
cwidth = realwidth * AspectMultiplier(ratio) / 48;
|
|
||||||
cheight = realheight;
|
|
||||||
}
|
|
||||||
// Use whichever pair of cwidth/cheight or width/height that produces less difference
|
|
||||||
// between CleanXfac and CleanYfac.
|
|
||||||
cx1 = MAX(cwidth / designwidth, 1);
|
|
||||||
cy1 = MAX(cheight / designheight, 1);
|
|
||||||
cx2 = MAX(realwidth / designwidth, 1);
|
|
||||||
cy2 = MAX(realheight / designheight, 1);
|
|
||||||
if (abs(cx1 - cy1) <= abs(cx2 - cy2) || MAX(cx1, cx2) >= 4)
|
|
||||||
{ // e.g. 640x360 looks better with this.
|
|
||||||
*cleanx = cx1;
|
|
||||||
*cleany = cy1;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{ // e.g. 720x480 looks better with this.
|
|
||||||
*cleanx = cx2;
|
|
||||||
*cleany = cy2;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (*cleanx < *cleany)
|
|
||||||
*cleany = *cleanx;
|
|
||||||
else
|
|
||||||
*cleanx = *cleany;
|
|
||||||
}
|
|
||||||
|
|
||||||
void DBaseStatusBar::SetDrawSize(int reltop, int hres, int vres)
|
|
||||||
{
|
|
||||||
ValidateResolution(hres, vres);
|
|
||||||
|
|
||||||
RelTop = reltop;
|
|
||||||
HorizontalResolution = hres;
|
|
||||||
VerticalResolution = vres;
|
|
||||||
int x, y;
|
|
||||||
ST_CalcCleanFacs(hres, vres, twod->GetWidth(), twod->GetHeight(), &x, &y);
|
|
||||||
defaultScale = { (double)x, (double)y };
|
|
||||||
|
|
||||||
SetScale(); // recalculate positioning info.
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
//
|
//
|
||||||
// PROP Destroy
|
// PROP Destroy
|
||||||
|
@ -500,6 +445,12 @@ void DBaseStatusBar::OnDestroy ()
|
||||||
|
|
||||||
void DBaseStatusBar::SetScale ()
|
void DBaseStatusBar::SetScale ()
|
||||||
{
|
{
|
||||||
|
if (!hud_oldscale)
|
||||||
|
{
|
||||||
|
Super::SetScale();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
ValidateResolution(HorizontalResolution, VerticalResolution);
|
ValidateResolution(HorizontalResolution, VerticalResolution);
|
||||||
|
|
||||||
int w = twod->GetWidth();
|
int w = twod->GetWidth();
|
||||||
|
@ -561,6 +512,11 @@ void DBaseStatusBar::SetScale ()
|
||||||
|
|
||||||
DVector2 DBaseStatusBar::GetHUDScale() const
|
DVector2 DBaseStatusBar::GetHUDScale() const
|
||||||
{
|
{
|
||||||
|
if (!hud_oldscale)
|
||||||
|
{
|
||||||
|
return Super::GetHUDScale();
|
||||||
|
}
|
||||||
|
|
||||||
int scale;
|
int scale;
|
||||||
if (hud_scale < 0 || ForcedScale) // a negative value is the equivalent to the old boolean hud_scale. This can yield different values for x and y for higher resolutions.
|
if (hud_scale < 0 || ForcedScale) // a negative value is the equivalent to the old boolean hud_scale. This can yield different values for x and y for higher resolutions.
|
||||||
{
|
{
|
||||||
|
@ -579,34 +535,6 @@ DVector2 DBaseStatusBar::GetHUDScale() const
|
||||||
return{ double(realscale), double(realscale * (hud_aspectscale ? 1.2 : 1.)) };
|
return{ double(realscale), double(realscale * (hud_aspectscale ? 1.2 : 1.)) };
|
||||||
}
|
}
|
||||||
|
|
||||||
//---------------------------------------------------------------------------
|
|
||||||
//
|
|
||||||
//
|
|
||||||
//
|
|
||||||
//---------------------------------------------------------------------------
|
|
||||||
|
|
||||||
void DBaseStatusBar::BeginStatusBar(int resW, int resH, int relTop, bool forceScaled)
|
|
||||||
{
|
|
||||||
SetDrawSize(relTop < 0? BaseRelTop : relTop, resW < 0? BaseSBarHorizontalResolution : resW, resH < 0? BaseSBarVerticalResolution : resH);
|
|
||||||
ForcedScale = forceScaled;
|
|
||||||
fullscreenOffsets = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
//---------------------------------------------------------------------------
|
|
||||||
//
|
|
||||||
//
|
|
||||||
//
|
|
||||||
//---------------------------------------------------------------------------
|
|
||||||
|
|
||||||
void DBaseStatusBar::BeginHUD(int resW, int resH, double Alpha, bool forcescaled)
|
|
||||||
{
|
|
||||||
SetDrawSize(RelTop, resW < 0? BaseHUDHorizontalResolution : resW, resH < 0? BaseHUDVerticalResolution : resH);
|
|
||||||
this->Alpha = Alpha;
|
|
||||||
ForcedScale = forcescaled;
|
|
||||||
CompleteBorder = false;
|
|
||||||
fullscreenOffsets = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
//============================================================================
|
//============================================================================
|
||||||
//
|
//
|
||||||
// automap HUD common drawer
|
// automap HUD common drawer
|
||||||
|
|
Loading…
Reference in a new issue