mirror of
https://github.com/ZDoom/qzdoom-gpl.git
synced 2024-11-27 22:22:08 +00:00
- did some preparations to ParseDrawTextureTags to allow using the same code for parsing tag lists generated by the VM.
- removed the fixed point alpha tag from DrawTexture and replaced all uses with the floating point version.
This commit is contained in:
parent
abac756289
commit
d3ed83942f
14 changed files with 139 additions and 113 deletions
|
@ -2935,7 +2935,7 @@ static void DrawMarker (FTexture *tex, double x, double y, int yadjust,
|
||||||
DTA_ClipRight, f_x + f_w,
|
DTA_ClipRight, f_x + f_w,
|
||||||
DTA_FlipX, flip,
|
DTA_FlipX, flip,
|
||||||
DTA_Translation, TranslationToTable(translation),
|
DTA_Translation, TranslationToTable(translation),
|
||||||
DTA_AlphaF, alpha,
|
DTA_Alpha, alpha,
|
||||||
DTA_FillColor, fillcolor,
|
DTA_FillColor, fillcolor,
|
||||||
DTA_RenderStyle, DWORD(renderstyle),
|
DTA_RenderStyle, DWORD(renderstyle),
|
||||||
TAG_DONE);
|
TAG_DONE);
|
||||||
|
|
|
@ -1003,23 +1003,23 @@ void FNotifyBuffer::Draw()
|
||||||
{
|
{
|
||||||
if (!center)
|
if (!center)
|
||||||
screen->DrawText (SmallFont, color, 0, line, notify.Text,
|
screen->DrawText (SmallFont, color, 0, line, notify.Text,
|
||||||
DTA_CleanNoMove, true, DTA_AlphaF, alpha, TAG_DONE);
|
DTA_CleanNoMove, true, DTA_Alpha, alpha, TAG_DONE);
|
||||||
else
|
else
|
||||||
screen->DrawText (SmallFont, color, (SCREENWIDTH -
|
screen->DrawText (SmallFont, color, (SCREENWIDTH -
|
||||||
SmallFont->StringWidth (notify.Text)*CleanXfac)/2,
|
SmallFont->StringWidth (notify.Text)*CleanXfac)/2,
|
||||||
line, notify.Text, DTA_CleanNoMove, true,
|
line, notify.Text, DTA_CleanNoMove, true,
|
||||||
DTA_AlphaF, alpha, TAG_DONE);
|
DTA_Alpha, alpha, TAG_DONE);
|
||||||
}
|
}
|
||||||
else if (active_con_scaletext() == 1)
|
else if (active_con_scaletext() == 1)
|
||||||
{
|
{
|
||||||
if (!center)
|
if (!center)
|
||||||
screen->DrawText (SmallFont, color, 0, line, notify.Text,
|
screen->DrawText (SmallFont, color, 0, line, notify.Text,
|
||||||
DTA_AlphaF, alpha, TAG_DONE);
|
DTA_Alpha, alpha, TAG_DONE);
|
||||||
else
|
else
|
||||||
screen->DrawText (SmallFont, color, (SCREENWIDTH -
|
screen->DrawText (SmallFont, color, (SCREENWIDTH -
|
||||||
SmallFont->StringWidth (notify.Text))/2,
|
SmallFont->StringWidth (notify.Text))/2,
|
||||||
line, notify.Text,
|
line, notify.Text,
|
||||||
DTA_AlphaF, alpha, TAG_DONE);
|
DTA_Alpha, alpha, TAG_DONE);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -1028,7 +1028,7 @@ void FNotifyBuffer::Draw()
|
||||||
DTA_VirtualWidth, screen->GetWidth() / active_con_scaletext(),
|
DTA_VirtualWidth, screen->GetWidth() / active_con_scaletext(),
|
||||||
DTA_VirtualHeight, screen->GetHeight() / active_con_scaletext(),
|
DTA_VirtualHeight, screen->GetHeight() / active_con_scaletext(),
|
||||||
DTA_KeepRatio, true,
|
DTA_KeepRatio, true,
|
||||||
DTA_AlphaF, alpha, TAG_DONE);
|
DTA_Alpha, alpha, TAG_DONE);
|
||||||
else
|
else
|
||||||
screen->DrawText (SmallFont, color, (screen->GetWidth() -
|
screen->DrawText (SmallFont, color, (screen->GetWidth() -
|
||||||
SmallFont->StringWidth (notify.Text) * active_con_scaletext()) / 2 / active_con_scaletext(),
|
SmallFont->StringWidth (notify.Text) * active_con_scaletext()) / 2 / active_con_scaletext(),
|
||||||
|
@ -1036,7 +1036,7 @@ void FNotifyBuffer::Draw()
|
||||||
DTA_VirtualWidth, screen->GetWidth() / active_con_scaletext(),
|
DTA_VirtualWidth, screen->GetWidth() / active_con_scaletext(),
|
||||||
DTA_VirtualHeight, screen->GetHeight() / active_con_scaletext(),
|
DTA_VirtualHeight, screen->GetHeight() / active_con_scaletext(),
|
||||||
DTA_KeepRatio, true,
|
DTA_KeepRatio, true,
|
||||||
DTA_AlphaF, alpha, TAG_DONE);
|
DTA_Alpha, alpha, TAG_DONE);
|
||||||
}
|
}
|
||||||
line += lineadv;
|
line += lineadv;
|
||||||
canskip = false;
|
canskip = false;
|
||||||
|
@ -1117,7 +1117,7 @@ void C_DrawConsole (bool hw2d)
|
||||||
DTA_DestWidth, screen->GetWidth(),
|
DTA_DestWidth, screen->GetWidth(),
|
||||||
DTA_DestHeight, screen->GetHeight(),
|
DTA_DestHeight, screen->GetHeight(),
|
||||||
DTA_ColorOverlay, conshade,
|
DTA_ColorOverlay, conshade,
|
||||||
DTA_AlphaF, (hw2d && gamestate != GS_FULLCONSOLE) ? (double)con_alpha : 1.,
|
DTA_Alpha, (hw2d && gamestate != GS_FULLCONSOLE) ? (double)con_alpha : 1.,
|
||||||
DTA_Masked, false,
|
DTA_Masked, false,
|
||||||
TAG_DONE);
|
TAG_DONE);
|
||||||
if (conline && visheight < screen->GetHeight())
|
if (conline && visheight < screen->GetHeight())
|
||||||
|
|
|
@ -457,7 +457,7 @@ void DHUDMessage::DoDraw (int linenum, int x, int y, bool clean, int hudheight)
|
||||||
{
|
{
|
||||||
screen->DrawText (Font, TextColor, x, y, Lines[linenum].Text,
|
screen->DrawText (Font, TextColor, x, y, Lines[linenum].Text,
|
||||||
DTA_CleanNoMove, clean,
|
DTA_CleanNoMove, clean,
|
||||||
DTA_AlphaF, Alpha,
|
DTA_Alpha, Alpha,
|
||||||
DTA_RenderStyle, Style,
|
DTA_RenderStyle, Style,
|
||||||
TAG_DONE);
|
TAG_DONE);
|
||||||
}
|
}
|
||||||
|
@ -466,7 +466,7 @@ void DHUDMessage::DoDraw (int linenum, int x, int y, bool clean, int hudheight)
|
||||||
screen->DrawText (Font, TextColor, x, y, Lines[linenum].Text,
|
screen->DrawText (Font, TextColor, x, y, Lines[linenum].Text,
|
||||||
DTA_VirtualWidth, SCREENWIDTH / active_con_scaletext(),
|
DTA_VirtualWidth, SCREENWIDTH / active_con_scaletext(),
|
||||||
DTA_VirtualHeight, SCREENHEIGHT / active_con_scaletext(),
|
DTA_VirtualHeight, SCREENHEIGHT / active_con_scaletext(),
|
||||||
DTA_AlphaF, Alpha,
|
DTA_Alpha, Alpha,
|
||||||
DTA_RenderStyle, Style,
|
DTA_RenderStyle, Style,
|
||||||
DTA_KeepRatio, true,
|
DTA_KeepRatio, true,
|
||||||
TAG_DONE);
|
TAG_DONE);
|
||||||
|
@ -481,7 +481,7 @@ void DHUDMessage::DoDraw (int linenum, int x, int y, bool clean, int hudheight)
|
||||||
DTA_ClipRight, ClipRight,
|
DTA_ClipRight, ClipRight,
|
||||||
DTA_ClipTop, ClipTop,
|
DTA_ClipTop, ClipTop,
|
||||||
DTA_ClipBottom, ClipBot,
|
DTA_ClipBottom, ClipBot,
|
||||||
DTA_AlphaF, Alpha,
|
DTA_Alpha, Alpha,
|
||||||
DTA_RenderStyle, Style,
|
DTA_RenderStyle, Style,
|
||||||
TAG_DONE);
|
TAG_DONE);
|
||||||
}
|
}
|
||||||
|
@ -560,7 +560,7 @@ void DHUDMessageFadeOut::DoDraw (int linenum, int x, int y, bool clean, int hudh
|
||||||
{
|
{
|
||||||
screen->DrawText (Font, TextColor, x, y, Lines[linenum].Text,
|
screen->DrawText (Font, TextColor, x, y, Lines[linenum].Text,
|
||||||
DTA_CleanNoMove, clean,
|
DTA_CleanNoMove, clean,
|
||||||
DTA_AlphaF, trans,
|
DTA_Alpha, trans,
|
||||||
DTA_RenderStyle, Style,
|
DTA_RenderStyle, Style,
|
||||||
TAG_DONE);
|
TAG_DONE);
|
||||||
}
|
}
|
||||||
|
@ -569,7 +569,7 @@ void DHUDMessageFadeOut::DoDraw (int linenum, int x, int y, bool clean, int hudh
|
||||||
screen->DrawText (Font, TextColor, x, y, Lines[linenum].Text,
|
screen->DrawText (Font, TextColor, x, y, Lines[linenum].Text,
|
||||||
DTA_VirtualWidth, SCREENWIDTH / active_con_scaletext(),
|
DTA_VirtualWidth, SCREENWIDTH / active_con_scaletext(),
|
||||||
DTA_VirtualHeight, SCREENHEIGHT / active_con_scaletext(),
|
DTA_VirtualHeight, SCREENHEIGHT / active_con_scaletext(),
|
||||||
DTA_AlphaF, trans,
|
DTA_Alpha, trans,
|
||||||
DTA_RenderStyle, Style,
|
DTA_RenderStyle, Style,
|
||||||
DTA_KeepRatio, true,
|
DTA_KeepRatio, true,
|
||||||
TAG_DONE);
|
TAG_DONE);
|
||||||
|
@ -584,7 +584,7 @@ void DHUDMessageFadeOut::DoDraw (int linenum, int x, int y, bool clean, int hudh
|
||||||
DTA_ClipRight, ClipRight,
|
DTA_ClipRight, ClipRight,
|
||||||
DTA_ClipTop, ClipTop,
|
DTA_ClipTop, ClipTop,
|
||||||
DTA_ClipBottom, ClipBot,
|
DTA_ClipBottom, ClipBot,
|
||||||
DTA_AlphaF, trans,
|
DTA_Alpha, trans,
|
||||||
DTA_RenderStyle, Style,
|
DTA_RenderStyle, Style,
|
||||||
TAG_DONE);
|
TAG_DONE);
|
||||||
}
|
}
|
||||||
|
@ -660,7 +660,7 @@ void DHUDMessageFadeInOut::DoDraw (int linenum, int x, int y, bool clean, int hu
|
||||||
{
|
{
|
||||||
screen->DrawText (Font, TextColor, x, y, Lines[linenum].Text,
|
screen->DrawText (Font, TextColor, x, y, Lines[linenum].Text,
|
||||||
DTA_CleanNoMove, clean,
|
DTA_CleanNoMove, clean,
|
||||||
DTA_AlphaF, trans,
|
DTA_Alpha, trans,
|
||||||
DTA_RenderStyle, Style,
|
DTA_RenderStyle, Style,
|
||||||
TAG_DONE);
|
TAG_DONE);
|
||||||
}
|
}
|
||||||
|
@ -669,7 +669,7 @@ void DHUDMessageFadeInOut::DoDraw (int linenum, int x, int y, bool clean, int hu
|
||||||
screen->DrawText (Font, TextColor, x, y, Lines[linenum].Text,
|
screen->DrawText (Font, TextColor, x, y, Lines[linenum].Text,
|
||||||
DTA_VirtualWidth, SCREENWIDTH / active_con_scaletext(),
|
DTA_VirtualWidth, SCREENWIDTH / active_con_scaletext(),
|
||||||
DTA_VirtualHeight, SCREENHEIGHT / active_con_scaletext(),
|
DTA_VirtualHeight, SCREENHEIGHT / active_con_scaletext(),
|
||||||
DTA_AlphaF, trans,
|
DTA_Alpha, trans,
|
||||||
DTA_RenderStyle, Style,
|
DTA_RenderStyle, Style,
|
||||||
DTA_KeepRatio, true,
|
DTA_KeepRatio, true,
|
||||||
TAG_DONE);
|
TAG_DONE);
|
||||||
|
@ -684,7 +684,7 @@ void DHUDMessageFadeInOut::DoDraw (int linenum, int x, int y, bool clean, int hu
|
||||||
DTA_ClipRight, ClipRight,
|
DTA_ClipRight, ClipRight,
|
||||||
DTA_ClipTop, ClipTop,
|
DTA_ClipTop, ClipTop,
|
||||||
DTA_ClipBottom, ClipBot,
|
DTA_ClipBottom, ClipBot,
|
||||||
DTA_AlphaF, trans,
|
DTA_Alpha, trans,
|
||||||
DTA_RenderStyle, Style,
|
DTA_RenderStyle, Style,
|
||||||
TAG_DONE);
|
TAG_DONE);
|
||||||
}
|
}
|
||||||
|
@ -842,7 +842,7 @@ void DHUDMessageTypeOnFadeOut::DoDraw (int linenum, int x, int y, bool clean, in
|
||||||
screen->DrawText (Font, TextColor, x, y, Lines[linenum].Text,
|
screen->DrawText (Font, TextColor, x, y, Lines[linenum].Text,
|
||||||
DTA_CleanNoMove, clean,
|
DTA_CleanNoMove, clean,
|
||||||
DTA_TextLen, LineVisible,
|
DTA_TextLen, LineVisible,
|
||||||
DTA_AlphaF, Alpha,
|
DTA_Alpha, Alpha,
|
||||||
DTA_RenderStyle, Style,
|
DTA_RenderStyle, Style,
|
||||||
TAG_DONE);
|
TAG_DONE);
|
||||||
}
|
}
|
||||||
|
@ -853,7 +853,7 @@ void DHUDMessageTypeOnFadeOut::DoDraw (int linenum, int x, int y, bool clean, in
|
||||||
DTA_VirtualHeight, SCREENHEIGHT / active_con_scaletext(),
|
DTA_VirtualHeight, SCREENHEIGHT / active_con_scaletext(),
|
||||||
DTA_KeepRatio, true,
|
DTA_KeepRatio, true,
|
||||||
DTA_TextLen, LineVisible,
|
DTA_TextLen, LineVisible,
|
||||||
DTA_AlphaF, Alpha,
|
DTA_Alpha, Alpha,
|
||||||
DTA_RenderStyle, Style,
|
DTA_RenderStyle, Style,
|
||||||
TAG_DONE);
|
TAG_DONE);
|
||||||
}
|
}
|
||||||
|
@ -867,7 +867,7 @@ void DHUDMessageTypeOnFadeOut::DoDraw (int linenum, int x, int y, bool clean, in
|
||||||
DTA_ClipRight, ClipRight,
|
DTA_ClipRight, ClipRight,
|
||||||
DTA_ClipTop, ClipTop,
|
DTA_ClipTop, ClipTop,
|
||||||
DTA_ClipBottom, ClipBot,
|
DTA_ClipBottom, ClipBot,
|
||||||
DTA_AlphaF, Alpha,
|
DTA_Alpha, Alpha,
|
||||||
DTA_TextLen, LineVisible,
|
DTA_TextLen, LineVisible,
|
||||||
DTA_RenderStyle, Style,
|
DTA_RenderStyle, Style,
|
||||||
TAG_DONE);
|
TAG_DONE);
|
||||||
|
|
|
@ -138,7 +138,7 @@ void SetHUDIcon(PClassInventory *cls, FTextureID tex)
|
||||||
// center of the box. The image is scaled down if it doesn't fit
|
// center of the box. The image is scaled down if it doesn't fit
|
||||||
//
|
//
|
||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
static void DrawImageToBox(FTexture * tex, int x, int y, int w, int h, int trans=0xc000)
|
static void DrawImageToBox(FTexture * tex, int x, int y, int w, int h, double trans = 0.75)
|
||||||
{
|
{
|
||||||
double scale1, scale2;
|
double scale1, scale2;
|
||||||
|
|
||||||
|
@ -174,7 +174,7 @@ static void DrawImageToBox(FTexture * tex, int x, int y, int w, int h, int trans
|
||||||
//
|
//
|
||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
|
|
||||||
static void DrawHudText(FFont *font, int color, char * text, int x, int y, int trans=0xc000)
|
static void DrawHudText(FFont *font, int color, char * text, int x, int y, double trans = 0.75)
|
||||||
{
|
{
|
||||||
int zerowidth;
|
int zerowidth;
|
||||||
FTexture *tex_zero = font->GetChar('0', &zerowidth);
|
FTexture *tex_zero = font->GetChar('0', &zerowidth);
|
||||||
|
@ -207,7 +207,7 @@ static void DrawHudText(FFont *font, int color, char * text, int x, int y, int t
|
||||||
//
|
//
|
||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
|
|
||||||
static void DrawHudNumber(FFont *font, int color, int num, int x, int y, int trans=0xc000)
|
static void DrawHudNumber(FFont *font, int color, int num, int x, int y, double trans = 0.75)
|
||||||
{
|
{
|
||||||
char text[15];
|
char text[15];
|
||||||
|
|
||||||
|
@ -227,11 +227,11 @@ static void DrawStatLine(int x, int &y, const char *prefix, const char *string)
|
||||||
y -= SmallFont->GetHeight()-1;
|
y -= SmallFont->GetHeight()-1;
|
||||||
screen->DrawText(SmallFont, hudcolor_statnames, x, y, prefix,
|
screen->DrawText(SmallFont, hudcolor_statnames, x, y, prefix,
|
||||||
DTA_KeepRatio, true,
|
DTA_KeepRatio, true,
|
||||||
DTA_VirtualWidth, hudwidth, DTA_VirtualHeight, hudheight, DTA_Alpha, 0xc000, TAG_DONE);
|
DTA_VirtualWidth, hudwidth, DTA_VirtualHeight, hudheight, DTA_Alpha, 0.75, TAG_DONE);
|
||||||
|
|
||||||
screen->DrawText(SmallFont, hudcolor_stats, x+statspace, y, string,
|
screen->DrawText(SmallFont, hudcolor_stats, x+statspace, y, string,
|
||||||
DTA_KeepRatio, true,
|
DTA_KeepRatio, true,
|
||||||
DTA_VirtualWidth, hudwidth, DTA_VirtualHeight, hudheight, DTA_Alpha, 0xc000, TAG_DONE);
|
DTA_VirtualWidth, hudwidth, DTA_VirtualHeight, hudheight, DTA_Alpha, 0.75, TAG_DONE);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void DrawStatus(player_t * CPlayer, int x, int y)
|
static void DrawStatus(player_t * CPlayer, int x, int y)
|
||||||
|
@ -654,7 +654,7 @@ static int DrawAmmo(player_t *CPlayer, int x, int y)
|
||||||
FTextureID icon = !AltIcon.isNull()? AltIcon : inv->Icon;
|
FTextureID icon = !AltIcon.isNull()? AltIcon : inv->Icon;
|
||||||
if (!icon.isValid()) continue;
|
if (!icon.isValid()) continue;
|
||||||
|
|
||||||
int trans= (wi && (type==wi->AmmoType1 || type==wi->AmmoType2)) ? 0xc000:0x6000;
|
double trans= (wi && (type==wi->AmmoType1 || type==wi->AmmoType2)) ? 0.75 : 0.375;
|
||||||
|
|
||||||
int maxammo = inv->MaxAmount;
|
int maxammo = inv->MaxAmount;
|
||||||
int ammo = ammoitem? ammoitem->Amount : 0;
|
int ammo = ammoitem? ammoitem->Amount : 0;
|
||||||
|
@ -731,16 +731,16 @@ FTextureID GetInventoryIcon(AInventory *item, DWORD flags, bool *applyscale=NULL
|
||||||
|
|
||||||
static void DrawOneWeapon(player_t * CPlayer, int x, int & y, AWeapon * weapon)
|
static void DrawOneWeapon(player_t * CPlayer, int x, int & y, AWeapon * weapon)
|
||||||
{
|
{
|
||||||
int trans;
|
double trans;
|
||||||
|
|
||||||
// Powered up weapons and inherited sister weapons are not displayed.
|
// Powered up weapons and inherited sister weapons are not displayed.
|
||||||
if (weapon->WeaponFlags & WIF_POWERED_UP) return;
|
if (weapon->WeaponFlags & WIF_POWERED_UP) return;
|
||||||
if (weapon->SisterWeapon && weapon->IsKindOf(weapon->SisterWeapon->GetClass())) return;
|
if (weapon->SisterWeapon && weapon->IsKindOf(weapon->SisterWeapon->GetClass())) return;
|
||||||
|
|
||||||
trans=0x6666;
|
trans=0.4;
|
||||||
if (CPlayer->ReadyWeapon)
|
if (CPlayer->ReadyWeapon)
|
||||||
{
|
{
|
||||||
if (weapon==CPlayer->ReadyWeapon || weapon==CPlayer->ReadyWeapon->SisterWeapon) trans=0xd999;
|
if (weapon==CPlayer->ReadyWeapon || weapon==CPlayer->ReadyWeapon->SisterWeapon) trans = 0.85;
|
||||||
}
|
}
|
||||||
|
|
||||||
FTextureID picnum = GetInventoryIcon(weapon, DI_ALTICONFIRST);
|
FTextureID picnum = GetInventoryIcon(weapon, DI_ALTICONFIRST);
|
||||||
|
@ -809,7 +809,7 @@ static void DrawInventory(player_t * CPlayer, int x,int y)
|
||||||
{
|
{
|
||||||
screen->DrawTexture(invgems[!!(level.time&4)], x-10, y,
|
screen->DrawTexture(invgems[!!(level.time&4)], x-10, y,
|
||||||
DTA_KeepRatio, true,
|
DTA_KeepRatio, true,
|
||||||
DTA_VirtualWidth, hudwidth, DTA_VirtualHeight, hudheight, DTA_Alpha, 0x6666, TAG_DONE);
|
DTA_VirtualWidth, hudwidth, DTA_VirtualHeight, hudheight, DTA_Alpha, 0.4, TAG_DONE);
|
||||||
}
|
}
|
||||||
|
|
||||||
for(i=0;i<numitems && rover;rover=rover->NextInv())
|
for(i=0;i<numitems && rover;rover=rover->NextInv())
|
||||||
|
@ -820,7 +820,7 @@ static void DrawInventory(player_t * CPlayer, int x,int y)
|
||||||
|
|
||||||
if (AltIcon.Exists() && (rover->Icon.isValid() || AltIcon.isValid()) )
|
if (AltIcon.Exists() && (rover->Icon.isValid() || AltIcon.isValid()) )
|
||||||
{
|
{
|
||||||
int trans = rover==CPlayer->mo->InvSel ? 0x10000 : 0x6666;
|
double trans = rover==CPlayer->mo->InvSel ? 1.0 : 0.4;
|
||||||
|
|
||||||
DrawImageToBox(TexMan[AltIcon.isValid()? AltIcon : rover->Icon], x, y, 19, 25, trans);
|
DrawImageToBox(TexMan[AltIcon.isValid()? AltIcon : rover->Icon], x, y, 19, 25, trans);
|
||||||
if (rover->Amount>1)
|
if (rover->Amount>1)
|
||||||
|
@ -845,7 +845,7 @@ static void DrawInventory(player_t * CPlayer, int x,int y)
|
||||||
{
|
{
|
||||||
screen->DrawTexture(invgems[2 + !!(level.time&4)], x-10, y,
|
screen->DrawTexture(invgems[2 + !!(level.time&4)], x-10, y,
|
||||||
DTA_KeepRatio, true,
|
DTA_KeepRatio, true,
|
||||||
DTA_VirtualWidth, hudwidth, DTA_VirtualHeight, hudheight, DTA_Alpha, 0x6666, TAG_DONE);
|
DTA_VirtualWidth, hudwidth, DTA_VirtualHeight, hudheight, DTA_Alpha, 0.4, TAG_DONE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1270,7 +1270,7 @@ public:
|
||||||
DTA_Translation, translate ? GetTranslation() : 0,
|
DTA_Translation, translate ? GetTranslation() : 0,
|
||||||
DTA_ColorOverlay, dim ? DIM_OVERLAY : 0,
|
DTA_ColorOverlay, dim ? DIM_OVERLAY : 0,
|
||||||
DTA_CenterBottomOffset, (offsetflags & SBarInfoCommand::CENTER_BOTTOM) == SBarInfoCommand::CENTER_BOTTOM,
|
DTA_CenterBottomOffset, (offsetflags & SBarInfoCommand::CENTER_BOTTOM) == SBarInfoCommand::CENTER_BOTTOM,
|
||||||
DTA_AlphaF, Alpha,
|
DTA_Alpha, Alpha,
|
||||||
DTA_AlphaChannel, alphaMap,
|
DTA_AlphaChannel, alphaMap,
|
||||||
DTA_FillColor, 0,
|
DTA_FillColor, 0,
|
||||||
TAG_DONE);
|
TAG_DONE);
|
||||||
|
@ -1287,7 +1287,7 @@ public:
|
||||||
DTA_Translation, translate ? GetTranslation() : 0,
|
DTA_Translation, translate ? GetTranslation() : 0,
|
||||||
DTA_ColorOverlay, dim ? DIM_OVERLAY : 0,
|
DTA_ColorOverlay, dim ? DIM_OVERLAY : 0,
|
||||||
DTA_CenterBottomOffset, (offsetflags & SBarInfoCommand::CENTER_BOTTOM) == SBarInfoCommand::CENTER_BOTTOM,
|
DTA_CenterBottomOffset, (offsetflags & SBarInfoCommand::CENTER_BOTTOM) == SBarInfoCommand::CENTER_BOTTOM,
|
||||||
DTA_AlphaF, Alpha,
|
DTA_Alpha, Alpha,
|
||||||
TAG_DONE);
|
TAG_DONE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1347,7 +1347,7 @@ public:
|
||||||
DTA_Translation, translate ? GetTranslation() : 0,
|
DTA_Translation, translate ? GetTranslation() : 0,
|
||||||
DTA_ColorOverlay, dim ? DIM_OVERLAY : 0,
|
DTA_ColorOverlay, dim ? DIM_OVERLAY : 0,
|
||||||
DTA_CenterBottomOffset, (offsetflags & SBarInfoCommand::CENTER_BOTTOM) == SBarInfoCommand::CENTER_BOTTOM,
|
DTA_CenterBottomOffset, (offsetflags & SBarInfoCommand::CENTER_BOTTOM) == SBarInfoCommand::CENTER_BOTTOM,
|
||||||
DTA_AlphaF, Alpha,
|
DTA_Alpha, Alpha,
|
||||||
DTA_AlphaChannel, alphaMap,
|
DTA_AlphaChannel, alphaMap,
|
||||||
DTA_FillColor, 0,
|
DTA_FillColor, 0,
|
||||||
TAG_DONE);
|
TAG_DONE);
|
||||||
|
@ -1364,7 +1364,7 @@ public:
|
||||||
DTA_Translation, translate ? GetTranslation() : 0,
|
DTA_Translation, translate ? GetTranslation() : 0,
|
||||||
DTA_ColorOverlay, dim ? DIM_OVERLAY : 0,
|
DTA_ColorOverlay, dim ? DIM_OVERLAY : 0,
|
||||||
DTA_CenterBottomOffset, (offsetflags & SBarInfoCommand::CENTER_BOTTOM) == SBarInfoCommand::CENTER_BOTTOM,
|
DTA_CenterBottomOffset, (offsetflags & SBarInfoCommand::CENTER_BOTTOM) == SBarInfoCommand::CENTER_BOTTOM,
|
||||||
DTA_AlphaF, Alpha,
|
DTA_Alpha, Alpha,
|
||||||
TAG_DONE);
|
TAG_DONE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1487,7 +1487,7 @@ public:
|
||||||
screen->DrawTexture(character, srx, sry,
|
screen->DrawTexture(character, srx, sry,
|
||||||
DTA_DestWidthF, rw,
|
DTA_DestWidthF, rw,
|
||||||
DTA_DestHeightF, rh,
|
DTA_DestHeightF, rh,
|
||||||
DTA_AlphaF, salpha,
|
DTA_Alpha, salpha,
|
||||||
DTA_FillColor, 0,
|
DTA_FillColor, 0,
|
||||||
TAG_DONE);
|
TAG_DONE);
|
||||||
}
|
}
|
||||||
|
@ -1495,7 +1495,7 @@ public:
|
||||||
DTA_DestWidthF, rw,
|
DTA_DestWidthF, rw,
|
||||||
DTA_DestHeightF, rh,
|
DTA_DestHeightF, rh,
|
||||||
DTA_Translation, remap,
|
DTA_Translation, remap,
|
||||||
DTA_AlphaF, Alpha,
|
DTA_Alpha, Alpha,
|
||||||
TAG_DONE);
|
TAG_DONE);
|
||||||
if(script->spacingCharacter == '\0')
|
if(script->spacingCharacter == '\0')
|
||||||
ax += width + spacing - (character->LeftOffset+1);
|
ax += width + spacing - (character->LeftOffset+1);
|
||||||
|
|
|
@ -451,7 +451,7 @@ private:
|
||||||
screen->DrawTexture (Images[CursorImage],
|
screen->DrawTexture (Images[CursorImage],
|
||||||
42 + 35*i + ST_X, 12 + ST_Y,
|
42 + 35*i + ST_X, 12 + ST_Y,
|
||||||
DTA_Bottom320x200, Scaled,
|
DTA_Bottom320x200, Scaled,
|
||||||
DTA_AlphaF, 1. - ItemFlash,
|
DTA_Alpha, 1. - ItemFlash,
|
||||||
TAG_DONE);
|
TAG_DONE);
|
||||||
}
|
}
|
||||||
if (item->Icon.isValid())
|
if (item->Icon.isValid())
|
||||||
|
@ -523,7 +523,7 @@ private:
|
||||||
DTA_HUDRules, HUD_Normal,
|
DTA_HUDRules, HUD_Normal,
|
||||||
DTA_LeftOffset, cursor->GetWidth(),
|
DTA_LeftOffset, cursor->GetWidth(),
|
||||||
DTA_TopOffset, cursor->GetHeight(),
|
DTA_TopOffset, cursor->GetHeight(),
|
||||||
DTA_AlphaF, ItemFlash,
|
DTA_Alpha, ItemFlash,
|
||||||
TAG_DONE);
|
TAG_DONE);
|
||||||
}
|
}
|
||||||
DrINumberOuter (CPlayer->mo->InvSel->Amount, -51, -10, false, 7);
|
DrINumberOuter (CPlayer->mo->InvSel->Amount, -51, -10, false, 7);
|
||||||
|
@ -547,7 +547,7 @@ private:
|
||||||
{
|
{
|
||||||
screen->DrawTexture (Images[CursorImage], -100+i*35, -21,
|
screen->DrawTexture (Images[CursorImage], -100+i*35, -21,
|
||||||
DTA_HUDRules, HUD_HorizCenter,
|
DTA_HUDRules, HUD_HorizCenter,
|
||||||
DTA_Alpha, TRANSLUC75,
|
DTA_Alpha, 0.75,
|
||||||
TAG_DONE);
|
TAG_DONE);
|
||||||
}
|
}
|
||||||
if (item->Icon.isValid())
|
if (item->Icon.isValid())
|
||||||
|
@ -580,7 +580,7 @@ private:
|
||||||
left = screen->GetWidth()/2 - 160*CleanXfac;
|
left = screen->GetWidth()/2 - 160*CleanXfac;
|
||||||
top = bottom + height * yscale;
|
top = bottom + height * yscale;
|
||||||
|
|
||||||
screen->DrawTexture (Images[back], left, top, DTA_CleanNoMove, true, DTA_AlphaF, 0.75, TAG_DONE);
|
screen->DrawTexture (Images[back], left, top, DTA_CleanNoMove, true, DTA_Alpha, 0.75, TAG_DONE);
|
||||||
screen->DrawTexture (Images[bars], left, top, DTA_CleanNoMove, true, TAG_DONE);
|
screen->DrawTexture (Images[bars], left, top, DTA_CleanNoMove, true, TAG_DONE);
|
||||||
|
|
||||||
|
|
||||||
|
@ -874,7 +874,7 @@ void DStrifeStatusBar::DrINumberOuter(signed int val, int x, int y, bool center,
|
||||||
else if (val == 0)
|
else if (val == 0)
|
||||||
{
|
{
|
||||||
screen->DrawTexture(Images[imgINumbers], x + 1, y + 1,
|
screen->DrawTexture(Images[imgINumbers], x + 1, y + 1,
|
||||||
DTA_FillColor, 0, DTA_AlphaF, HR_SHADOW,
|
DTA_FillColor, 0, DTA_Alpha, HR_SHADOW,
|
||||||
DTA_HUDRules, center ? HUD_HorizCenter : HUD_Normal, TAG_DONE);
|
DTA_HUDRules, center ? HUD_HorizCenter : HUD_Normal, TAG_DONE);
|
||||||
screen->DrawTexture(Images[imgINumbers], x, y,
|
screen->DrawTexture(Images[imgINumbers], x, y,
|
||||||
DTA_HUDRules, center ? HUD_HorizCenter : HUD_Normal, TAG_DONE);
|
DTA_HUDRules, center ? HUD_HorizCenter : HUD_Normal, TAG_DONE);
|
||||||
|
@ -888,7 +888,7 @@ void DStrifeStatusBar::DrINumberOuter(signed int val, int x, int y, bool center,
|
||||||
while (val != 0)
|
while (val != 0)
|
||||||
{
|
{
|
||||||
screen->DrawTexture(Images[imgINumbers + val % 10], x + 1, y + 1,
|
screen->DrawTexture(Images[imgINumbers + val % 10], x + 1, y + 1,
|
||||||
DTA_FillColor, 0, DTA_AlphaF, HR_SHADOW,
|
DTA_FillColor, 0, DTA_Alpha, HR_SHADOW,
|
||||||
DTA_HUDRules, center ? HUD_HorizCenter : HUD_Normal, TAG_DONE);
|
DTA_HUDRules, center ? HUD_HorizCenter : HUD_Normal, TAG_DONE);
|
||||||
x -= w;
|
x -= w;
|
||||||
val /= 10;
|
val /= 10;
|
||||||
|
@ -896,7 +896,7 @@ void DStrifeStatusBar::DrINumberOuter(signed int val, int x, int y, bool center,
|
||||||
if (negative)
|
if (negative)
|
||||||
{
|
{
|
||||||
screen->DrawTexture(Images[imgNEGATIVE], x + 1, y + 1,
|
screen->DrawTexture(Images[imgNEGATIVE], x + 1, y + 1,
|
||||||
DTA_FillColor, 0, DTA_AlphaF, HR_SHADOW,
|
DTA_FillColor, 0, DTA_Alpha, HR_SHADOW,
|
||||||
DTA_HUDRules, center ? HUD_HorizCenter : HUD_Normal, TAG_DONE);
|
DTA_HUDRules, center ? HUD_HorizCenter : HUD_Normal, TAG_DONE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -947,7 +947,7 @@ void DStrifeStatusBar::DrBNumberOuterFont(signed int val, int x, int y, int size
|
||||||
pic = BigFont->GetChar('0', &v);
|
pic = BigFont->GetChar('0', &v);
|
||||||
screen->DrawTexture(pic, xpos - v / 2 + 2, y + 2,
|
screen->DrawTexture(pic, xpos - v / 2 + 2, y + 2,
|
||||||
DTA_HUDRules, HUD_Normal,
|
DTA_HUDRules, HUD_Normal,
|
||||||
DTA_AlphaF, HR_SHADOW,
|
DTA_Alpha, HR_SHADOW,
|
||||||
DTA_FillColor, 0,
|
DTA_FillColor, 0,
|
||||||
DTA_Translation, BigFont->GetColorTranslation(CR_UNTRANSLATED),
|
DTA_Translation, BigFont->GetColorTranslation(CR_UNTRANSLATED),
|
||||||
TAG_DONE);
|
TAG_DONE);
|
||||||
|
@ -972,7 +972,7 @@ void DStrifeStatusBar::DrBNumberOuterFont(signed int val, int x, int y, int size
|
||||||
pic = BigFont->GetChar('0' + val % 10, &v);
|
pic = BigFont->GetChar('0' + val % 10, &v);
|
||||||
screen->DrawTexture(pic, xpos - v / 2 + 2, y + 2,
|
screen->DrawTexture(pic, xpos - v / 2 + 2, y + 2,
|
||||||
DTA_HUDRules, HUD_Normal,
|
DTA_HUDRules, HUD_Normal,
|
||||||
DTA_AlphaF, HR_SHADOW,
|
DTA_Alpha, HR_SHADOW,
|
||||||
DTA_FillColor, 0,
|
DTA_FillColor, 0,
|
||||||
DTA_Translation, BigFont->GetColorTranslation(CR_UNTRANSLATED),
|
DTA_Translation, BigFont->GetColorTranslation(CR_UNTRANSLATED),
|
||||||
TAG_DONE);
|
TAG_DONE);
|
||||||
|
@ -986,7 +986,7 @@ void DStrifeStatusBar::DrBNumberOuterFont(signed int val, int x, int y, int size
|
||||||
{
|
{
|
||||||
screen->DrawTexture(pic, xpos - v / 2 + 2, y + 2,
|
screen->DrawTexture(pic, xpos - v / 2 + 2, y + 2,
|
||||||
DTA_HUDRules, HUD_Normal,
|
DTA_HUDRules, HUD_Normal,
|
||||||
DTA_AlphaF, HR_SHADOW,
|
DTA_Alpha, HR_SHADOW,
|
||||||
DTA_FillColor, 0,
|
DTA_FillColor, 0,
|
||||||
DTA_Translation, BigFont->GetColorTranslation(CR_UNTRANSLATED),
|
DTA_Translation, BigFont->GetColorTranslation(CR_UNTRANSLATED),
|
||||||
TAG_DONE);
|
TAG_DONE);
|
||||||
|
|
|
@ -630,7 +630,7 @@ void DIntermissionScreenCast::Drawer ()
|
||||||
DTA_DestHeightF, pic->GetScaledHeightDouble() * castscale.Y,
|
DTA_DestHeightF, pic->GetScaledHeightDouble() * castscale.Y,
|
||||||
DTA_DestWidthF, pic->GetScaledWidthDouble() * castscale.X,
|
DTA_DestWidthF, pic->GetScaledWidthDouble() * castscale.X,
|
||||||
DTA_RenderStyle, mDefaults->RenderStyle,
|
DTA_RenderStyle, mDefaults->RenderStyle,
|
||||||
DTA_AlphaF, mDefaults->Alpha,
|
DTA_Alpha, mDefaults->Alpha,
|
||||||
DTA_Translation, casttranslation,
|
DTA_Translation, casttranslation,
|
||||||
TAG_DONE);
|
TAG_DONE);
|
||||||
}
|
}
|
||||||
|
|
|
@ -305,7 +305,7 @@ void DMenu::Drawer ()
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
screen->DrawTexture(tex, x, y, DTA_CleanNoMove, true, DTA_AlphaF, BackbuttonAlpha, TAG_DONE);
|
screen->DrawTexture(tex, x, y, DTA_CleanNoMove, true, DTA_Alpha, BackbuttonAlpha, TAG_DONE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -105,7 +105,7 @@ void DReadThisMenu::Drawer()
|
||||||
{
|
{
|
||||||
screen->DrawTexture (prevpic, 0, 0, DTA_Fullscreen, true, TAG_DONE);
|
screen->DrawTexture (prevpic, 0, 0, DTA_Fullscreen, true, TAG_DONE);
|
||||||
}
|
}
|
||||||
screen->DrawTexture (tex, 0, 0, DTA_Fullscreen, true, DTA_AlphaF, alpha, TAG_DONE);
|
screen->DrawTexture (tex, 0, 0, DTA_Fullscreen, true, DTA_Alpha, alpha, TAG_DONE);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1061,10 +1061,10 @@ public:
|
||||||
|
|
||||||
mysnprintf(goldstr, countof(goldstr), "%d", coin != NULL ? coin->Amount : 0);
|
mysnprintf(goldstr, countof(goldstr), "%d", coin != NULL ? coin->Amount : 0);
|
||||||
screen->DrawText(SmallFont, CR_GRAY, 21, 191, goldstr, DTA_320x200, true,
|
screen->DrawText(SmallFont, CR_GRAY, 21, 191, goldstr, DTA_320x200, true,
|
||||||
DTA_FillColor, 0, DTA_AlphaF, HR_SHADOW, TAG_DONE);
|
DTA_FillColor, 0, DTA_Alpha, HR_SHADOW, TAG_DONE);
|
||||||
screen->DrawTexture(TexMan(((AInventory *)GetDefaultByType(cointype))->Icon),
|
screen->DrawTexture(TexMan(((AInventory *)GetDefaultByType(cointype))->Icon),
|
||||||
3, 190, DTA_320x200, true,
|
3, 190, DTA_320x200, true,
|
||||||
DTA_FillColor, 0, DTA_AlphaF, HR_SHADOW, TAG_DONE);
|
DTA_FillColor, 0, DTA_Alpha, HR_SHADOW, TAG_DONE);
|
||||||
screen->DrawText(SmallFont, CR_GRAY, 20, 190, goldstr, DTA_320x200, true, TAG_DONE);
|
screen->DrawText(SmallFont, CR_GRAY, 20, 190, goldstr, DTA_320x200, true, TAG_DONE);
|
||||||
screen->DrawTexture(TexMan(((AInventory *)GetDefaultByType(cointype))->Icon),
|
screen->DrawTexture(TexMan(((AInventory *)GetDefaultByType(cointype))->Icon),
|
||||||
2, 189, DTA_320x200, true, TAG_DONE);
|
2, 189, DTA_320x200, true, TAG_DONE);
|
||||||
|
|
|
@ -1720,7 +1720,7 @@ void R_DrawRemainingPlayerSprites()
|
||||||
DTA_ClipTop, viewwindowy,
|
DTA_ClipTop, viewwindowy,
|
||||||
DTA_ClipRight, viewwindowx + viewwidth,
|
DTA_ClipRight, viewwindowx + viewwidth,
|
||||||
DTA_ClipBottom, viewwindowy + viewheight,
|
DTA_ClipBottom, viewwindowy + viewheight,
|
||||||
DTA_AlphaF, vis->Style.Alpha,
|
DTA_Alpha, vis->Style.Alpha,
|
||||||
DTA_RenderStyle, vis->RenderStyle,
|
DTA_RenderStyle, vis->RenderStyle,
|
||||||
DTA_FillColor, vis->FillColor,
|
DTA_FillColor, vis->FillColor,
|
||||||
DTA_SpecialColormap, special,
|
DTA_SpecialColormap, special,
|
||||||
|
|
139
src/v_draw.cpp
139
src/v_draw.cpp
|
@ -431,6 +431,37 @@ bool DCanvas::SetTextureParms(DrawParms *parms, FTexture *img, double xx, double
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void ListEnd(va_list &tags)
|
||||||
|
{
|
||||||
|
va_end(tags);
|
||||||
|
}
|
||||||
|
|
||||||
|
static int ListGetInt(va_list &tags)
|
||||||
|
{
|
||||||
|
return va_arg(tags, int);
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline double ListGetDouble(va_list &tags)
|
||||||
|
{
|
||||||
|
return va_arg(tags, double);
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline FRemapTable* ListGetTranslation(va_list &tags)
|
||||||
|
{
|
||||||
|
return va_arg(tags, FRemapTable*);
|
||||||
|
}
|
||||||
|
|
||||||
|
// These two options are only being used by the D3D version of the HUD weapon drawer, they serve no purpose anywhere else.
|
||||||
|
static inline FSpecialColormap * ListGetSpecialColormap(va_list &tags)
|
||||||
|
{
|
||||||
|
return va_arg(tags, FSpecialColormap *);
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline FColormapStyle * ListGetColormapStyle(va_list &tags)
|
||||||
|
{
|
||||||
|
return va_arg(tags, FColormapStyle *);
|
||||||
|
}
|
||||||
|
|
||||||
bool DCanvas::ParseDrawTextureTags (FTexture *img, double x, double y, DWORD tag, va_list tags, DrawParms *parms, bool fortext) const
|
bool DCanvas::ParseDrawTextureTags (FTexture *img, double x, double y, DWORD tag, va_list tags, DrawParms *parms, bool fortext) const
|
||||||
{
|
{
|
||||||
INTBOOL boolval;
|
INTBOOL boolval;
|
||||||
|
@ -442,7 +473,7 @@ bool DCanvas::ParseDrawTextureTags (FTexture *img, double x, double y, DWORD tag
|
||||||
{
|
{
|
||||||
if (img == NULL || img->UseType == FTexture::TEX_Null)
|
if (img == NULL || img->UseType == FTexture::TEX_Null)
|
||||||
{
|
{
|
||||||
va_end(tags);
|
ListEnd(tags);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -450,7 +481,7 @@ bool DCanvas::ParseDrawTextureTags (FTexture *img, double x, double y, DWORD tag
|
||||||
// Do some sanity checks on the coordinates.
|
// Do some sanity checks on the coordinates.
|
||||||
if (x < -16383 || x > 16383 || y < -16383 || y > 16383)
|
if (x < -16383 || x > 16383 || y < -16383 || y > 16383)
|
||||||
{
|
{
|
||||||
va_end(tags);
|
ListEnd(tags);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -497,39 +528,39 @@ bool DCanvas::ParseDrawTextureTags (FTexture *img, double x, double y, DWORD tag
|
||||||
switch (tag)
|
switch (tag)
|
||||||
{
|
{
|
||||||
default:
|
default:
|
||||||
data = va_arg(tags, DWORD);
|
ListGetInt(tags);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DTA_DestWidth:
|
case DTA_DestWidth:
|
||||||
assert(fortext == false);
|
assert(fortext == false);
|
||||||
if (fortext) return false;
|
if (fortext) return false;
|
||||||
parms->cleanmode = DTA_Base;
|
parms->cleanmode = DTA_Base;
|
||||||
parms->destwidth = va_arg(tags, int);
|
parms->destwidth = ListGetInt(tags);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DTA_DestWidthF:
|
case DTA_DestWidthF:
|
||||||
assert(fortext == false);
|
assert(fortext == false);
|
||||||
if (fortext) return false;
|
if (fortext) return false;
|
||||||
parms->cleanmode = DTA_Base;
|
parms->cleanmode = DTA_Base;
|
||||||
parms->destwidth = va_arg(tags, double);
|
parms->destwidth = ListGetDouble(tags);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DTA_DestHeight:
|
case DTA_DestHeight:
|
||||||
assert(fortext == false);
|
assert(fortext == false);
|
||||||
if (fortext) return false;
|
if (fortext) return false;
|
||||||
parms->cleanmode = DTA_Base;
|
parms->cleanmode = DTA_Base;
|
||||||
parms->destheight = va_arg(tags, int);
|
parms->destheight = ListGetInt(tags);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DTA_DestHeightF:
|
case DTA_DestHeightF:
|
||||||
assert(fortext == false);
|
assert(fortext == false);
|
||||||
if (fortext) return false;
|
if (fortext) return false;
|
||||||
parms->cleanmode = DTA_Base;
|
parms->cleanmode = DTA_Base;
|
||||||
parms->destheight = va_arg(tags, double);
|
parms->destheight = ListGetDouble(tags);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DTA_Clean:
|
case DTA_Clean:
|
||||||
boolval = va_arg(tags, INTBOOL);
|
boolval = ListGetInt(tags);
|
||||||
if (boolval)
|
if (boolval)
|
||||||
{
|
{
|
||||||
parms->scalex = 1;
|
parms->scalex = 1;
|
||||||
|
@ -539,7 +570,7 @@ bool DCanvas::ParseDrawTextureTags (FTexture *img, double x, double y, DWORD tag
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DTA_CleanNoMove:
|
case DTA_CleanNoMove:
|
||||||
boolval = va_arg(tags, INTBOOL);
|
boolval = ListGetInt(tags);
|
||||||
if (boolval)
|
if (boolval)
|
||||||
{
|
{
|
||||||
parms->scalex = CleanXfac;
|
parms->scalex = CleanXfac;
|
||||||
|
@ -549,7 +580,7 @@ bool DCanvas::ParseDrawTextureTags (FTexture *img, double x, double y, DWORD tag
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DTA_CleanNoMove_1:
|
case DTA_CleanNoMove_1:
|
||||||
boolval = va_arg(tags, INTBOOL);
|
boolval = ListGetInt(tags);
|
||||||
if (boolval)
|
if (boolval)
|
||||||
{
|
{
|
||||||
parms->scalex = CleanXfac_1;
|
parms->scalex = CleanXfac_1;
|
||||||
|
@ -559,7 +590,7 @@ bool DCanvas::ParseDrawTextureTags (FTexture *img, double x, double y, DWORD tag
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DTA_320x200:
|
case DTA_320x200:
|
||||||
boolval = va_arg(tags, INTBOOL);
|
boolval = ListGetInt(tags);
|
||||||
if (boolval)
|
if (boolval)
|
||||||
{
|
{
|
||||||
parms->cleanmode = DTA_Base;
|
parms->cleanmode = DTA_Base;
|
||||||
|
@ -571,7 +602,7 @@ bool DCanvas::ParseDrawTextureTags (FTexture *img, double x, double y, DWORD tag
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DTA_Bottom320x200:
|
case DTA_Bottom320x200:
|
||||||
boolval = va_arg(tags, INTBOOL);
|
boolval = ListGetInt(tags);
|
||||||
if (boolval)
|
if (boolval)
|
||||||
{
|
{
|
||||||
parms->cleanmode = DTA_Base;
|
parms->cleanmode = DTA_Base;
|
||||||
|
@ -584,32 +615,32 @@ bool DCanvas::ParseDrawTextureTags (FTexture *img, double x, double y, DWORD tag
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DTA_HUDRules:
|
case DTA_HUDRules:
|
||||||
intval = va_arg(tags, int);
|
intval = ListGetInt(tags);
|
||||||
parms->cleanmode = intval == HUD_HorizCenter ? DTA_HUDRulesC : DTA_HUDRules;
|
parms->cleanmode = intval == HUD_HorizCenter ? DTA_HUDRulesC : DTA_HUDRules;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DTA_VirtualWidth:
|
case DTA_VirtualWidth:
|
||||||
parms->cleanmode = DTA_Base;
|
parms->cleanmode = DTA_Base;
|
||||||
parms->virtWidth = va_arg(tags, int);
|
parms->virtWidth = ListGetInt(tags);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DTA_VirtualWidthF:
|
case DTA_VirtualWidthF:
|
||||||
parms->cleanmode = DTA_Base;
|
parms->cleanmode = DTA_Base;
|
||||||
parms->virtWidth = va_arg(tags, double);
|
parms->virtWidth = ListGetDouble(tags);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DTA_VirtualHeight:
|
case DTA_VirtualHeight:
|
||||||
parms->cleanmode = DTA_Base;
|
parms->cleanmode = DTA_Base;
|
||||||
parms->virtHeight = va_arg(tags, int);
|
parms->virtHeight = ListGetInt(tags);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DTA_VirtualHeightF:
|
case DTA_VirtualHeightF:
|
||||||
parms->cleanmode = DTA_Base;
|
parms->cleanmode = DTA_Base;
|
||||||
parms->virtHeight = va_arg(tags, double);
|
parms->virtHeight = ListGetDouble(tags);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DTA_Fullscreen:
|
case DTA_Fullscreen:
|
||||||
boolval = va_arg(tags, INTBOOL);
|
boolval = ListGetInt(tags);
|
||||||
if (boolval)
|
if (boolval)
|
||||||
{
|
{
|
||||||
assert(fortext == false);
|
assert(fortext == false);
|
||||||
|
@ -621,24 +652,20 @@ bool DCanvas::ParseDrawTextureTags (FTexture *img, double x, double y, DWORD tag
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DTA_Alpha:
|
case DTA_Alpha:
|
||||||
parms->Alpha = FIXED2FLOAT(MIN<fixed_t>(OPAQUE, va_arg (tags, fixed_t)));
|
parms->Alpha = (float)(MIN<double>(1., ListGetDouble(tags)));
|
||||||
break;
|
|
||||||
|
|
||||||
case DTA_AlphaF:
|
|
||||||
parms->Alpha = (float)(MIN<double>(1., va_arg(tags, double)));
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DTA_AlphaChannel:
|
case DTA_AlphaChannel:
|
||||||
parms->alphaChannel = va_arg(tags, INTBOOL);
|
parms->alphaChannel = ListGetInt(tags);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DTA_FillColor:
|
case DTA_FillColor:
|
||||||
parms->fillcolor = va_arg(tags, uint32);
|
parms->fillcolor = ListGetInt(tags);
|
||||||
fillcolorset = true;
|
fillcolorset = true;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DTA_Translation:
|
case DTA_Translation:
|
||||||
parms->remap = va_arg(tags, FRemapTable *);
|
parms->remap = ListGetTranslation(tags);
|
||||||
if (parms->remap != NULL && parms->remap->Inactive)
|
if (parms->remap != NULL && parms->remap->Inactive)
|
||||||
{ // If it's inactive, pretend we were passed NULL instead.
|
{ // If it's inactive, pretend we were passed NULL instead.
|
||||||
parms->remap = NULL;
|
parms->remap = NULL;
|
||||||
|
@ -646,41 +673,41 @@ bool DCanvas::ParseDrawTextureTags (FTexture *img, double x, double y, DWORD tag
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DTA_ColorOverlay:
|
case DTA_ColorOverlay:
|
||||||
parms->colorOverlay = va_arg(tags, DWORD);
|
parms->colorOverlay = ListGetInt(tags);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DTA_FlipX:
|
case DTA_FlipX:
|
||||||
parms->flipX = va_arg(tags, INTBOOL);
|
parms->flipX = ListGetInt(tags);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DTA_TopOffset:
|
case DTA_TopOffset:
|
||||||
assert(fortext == false);
|
assert(fortext == false);
|
||||||
if (fortext) return false;
|
if (fortext) return false;
|
||||||
parms->top = va_arg(tags, int);
|
parms->top = ListGetInt(tags);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DTA_TopOffsetF:
|
case DTA_TopOffsetF:
|
||||||
assert(fortext == false);
|
assert(fortext == false);
|
||||||
if (fortext) return false;
|
if (fortext) return false;
|
||||||
parms->top = va_arg(tags, double);
|
parms->top = ListGetDouble(tags);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DTA_LeftOffset:
|
case DTA_LeftOffset:
|
||||||
assert(fortext == false);
|
assert(fortext == false);
|
||||||
if (fortext) return false;
|
if (fortext) return false;
|
||||||
parms->left = va_arg(tags, int);
|
parms->left = ListGetInt(tags);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DTA_LeftOffsetF:
|
case DTA_LeftOffsetF:
|
||||||
assert(fortext == false);
|
assert(fortext == false);
|
||||||
if (fortext) return false;
|
if (fortext) return false;
|
||||||
parms->left = va_arg(tags, double);
|
parms->left = ListGetDouble(tags);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DTA_CenterOffset:
|
case DTA_CenterOffset:
|
||||||
assert(fortext == false);
|
assert(fortext == false);
|
||||||
if (fortext) return false;
|
if (fortext) return false;
|
||||||
if (va_arg(tags, int))
|
if (ListGetInt(tags))
|
||||||
{
|
{
|
||||||
parms->left = img->GetScaledWidthDouble() * 0.5;
|
parms->left = img->GetScaledWidthDouble() * 0.5;
|
||||||
parms->top = img->GetScaledHeightDouble() * 0.5;
|
parms->top = img->GetScaledHeightDouble() * 0.5;
|
||||||
|
@ -690,7 +717,7 @@ bool DCanvas::ParseDrawTextureTags (FTexture *img, double x, double y, DWORD tag
|
||||||
case DTA_CenterBottomOffset:
|
case DTA_CenterBottomOffset:
|
||||||
assert(fortext == false);
|
assert(fortext == false);
|
||||||
if (fortext) return false;
|
if (fortext) return false;
|
||||||
if (va_arg(tags, int))
|
if (ListGetInt(tags))
|
||||||
{
|
{
|
||||||
parms->left = img->GetScaledWidthDouble() * 0.5;
|
parms->left = img->GetScaledWidthDouble() * 0.5;
|
||||||
parms->top = img->GetScaledHeightDouble();
|
parms->top = img->GetScaledHeightDouble();
|
||||||
|
@ -700,29 +727,29 @@ bool DCanvas::ParseDrawTextureTags (FTexture *img, double x, double y, DWORD tag
|
||||||
case DTA_WindowLeft:
|
case DTA_WindowLeft:
|
||||||
assert(fortext == false);
|
assert(fortext == false);
|
||||||
if (fortext) return false;
|
if (fortext) return false;
|
||||||
parms->windowleft = va_arg(tags, int);
|
parms->windowleft = ListGetInt(tags);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DTA_WindowLeftF:
|
case DTA_WindowLeftF:
|
||||||
assert(fortext == false);
|
assert(fortext == false);
|
||||||
if (fortext) return false;
|
if (fortext) return false;
|
||||||
parms->windowleft = va_arg(tags, double);
|
parms->windowleft = ListGetDouble(tags);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DTA_WindowRight:
|
case DTA_WindowRight:
|
||||||
assert(fortext == false);
|
assert(fortext == false);
|
||||||
if (fortext) return false;
|
if (fortext) return false;
|
||||||
parms->windowright = va_arg(tags, int);
|
parms->windowright = ListGetInt(tags);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DTA_WindowRightF:
|
case DTA_WindowRightF:
|
||||||
assert(fortext == false);
|
assert(fortext == false);
|
||||||
if (fortext) return false;
|
if (fortext) return false;
|
||||||
parms->windowright = va_arg(tags, double);
|
parms->windowright = ListGetDouble(tags);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DTA_ClipTop:
|
case DTA_ClipTop:
|
||||||
parms->uclip = va_arg(tags, int);
|
parms->uclip = ListGetInt(tags);
|
||||||
if (parms->uclip < 0)
|
if (parms->uclip < 0)
|
||||||
{
|
{
|
||||||
parms->uclip = 0;
|
parms->uclip = 0;
|
||||||
|
@ -730,7 +757,7 @@ bool DCanvas::ParseDrawTextureTags (FTexture *img, double x, double y, DWORD tag
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DTA_ClipBottom:
|
case DTA_ClipBottom:
|
||||||
parms->dclip = va_arg(tags, int);
|
parms->dclip = ListGetInt(tags);
|
||||||
if (parms->dclip > this->GetHeight())
|
if (parms->dclip > this->GetHeight())
|
||||||
{
|
{
|
||||||
parms->dclip = this->GetHeight();
|
parms->dclip = this->GetHeight();
|
||||||
|
@ -738,7 +765,7 @@ bool DCanvas::ParseDrawTextureTags (FTexture *img, double x, double y, DWORD tag
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DTA_ClipLeft:
|
case DTA_ClipLeft:
|
||||||
parms->lclip = va_arg(tags, int);
|
parms->lclip = ListGetInt(tags);
|
||||||
if (parms->lclip < 0)
|
if (parms->lclip < 0)
|
||||||
{
|
{
|
||||||
parms->lclip = 0;
|
parms->lclip = 0;
|
||||||
|
@ -746,7 +773,7 @@ bool DCanvas::ParseDrawTextureTags (FTexture *img, double x, double y, DWORD tag
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DTA_ClipRight:
|
case DTA_ClipRight:
|
||||||
parms->rclip = va_arg(tags, int);
|
parms->rclip = ListGetInt(tags);
|
||||||
if (parms->rclip > this->GetWidth())
|
if (parms->rclip > this->GetWidth())
|
||||||
{
|
{
|
||||||
parms->rclip = this->GetWidth();
|
parms->rclip = this->GetWidth();
|
||||||
|
@ -754,18 +781,18 @@ bool DCanvas::ParseDrawTextureTags (FTexture *img, double x, double y, DWORD tag
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DTA_ShadowAlpha:
|
case DTA_ShadowAlpha:
|
||||||
parms->shadowAlpha = MIN<fixed_t>(OPAQUE, va_arg (tags, fixed_t));
|
parms->shadowAlpha = (float)MIN(1., ListGetDouble(tags));
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DTA_ShadowColor:
|
case DTA_ShadowColor:
|
||||||
parms->shadowColor = va_arg(tags, int);
|
parms->shadowColor = ListGetInt(tags);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DTA_Shadow:
|
case DTA_Shadow:
|
||||||
boolval = va_arg(tags, INTBOOL);
|
boolval = ListGetInt(tags);
|
||||||
if (boolval)
|
if (boolval)
|
||||||
{
|
{
|
||||||
parms->shadowAlpha = FRACUNIT/2;
|
parms->shadowAlpha = 0.5;
|
||||||
parms->shadowColor = 0;
|
parms->shadowColor = 0;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -775,45 +802,45 @@ bool DCanvas::ParseDrawTextureTags (FTexture *img, double x, double y, DWORD tag
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DTA_Masked:
|
case DTA_Masked:
|
||||||
parms->masked = va_arg(tags, INTBOOL);
|
parms->masked = ListGetInt(tags);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DTA_BilinearFilter:
|
case DTA_BilinearFilter:
|
||||||
parms->bilinear = va_arg(tags, INTBOOL);
|
parms->bilinear = ListGetInt(tags);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DTA_KeepRatio:
|
case DTA_KeepRatio:
|
||||||
// I think this is a terribly misleading name, since it actually turns
|
// I think this is a terribly misleading name, since it actually turns
|
||||||
// *off* aspect ratio correction.
|
// *off* aspect ratio correction.
|
||||||
parms->keepratio = va_arg(tags, INTBOOL);
|
parms->keepratio = ListGetInt(tags);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DTA_RenderStyle:
|
case DTA_RenderStyle:
|
||||||
parms->style.AsDWORD = va_arg(tags, DWORD);
|
parms->style.AsDWORD = ListGetInt(tags);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DTA_SpecialColormap:
|
case DTA_SpecialColormap:
|
||||||
parms->specialcolormap = va_arg(tags, FSpecialColormap *);
|
parms->specialcolormap = ListGetSpecialColormap(tags);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DTA_ColormapStyle:
|
case DTA_ColormapStyle:
|
||||||
parms->colormapstyle = va_arg(tags, FColormapStyle *);
|
parms->colormapstyle = ListGetColormapStyle(tags);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DTA_TextLen:
|
case DTA_TextLen:
|
||||||
parms->maxstrlen = va_arg(tags, int);
|
parms->maxstrlen = ListGetInt(tags);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DTA_CellX:
|
case DTA_CellX:
|
||||||
parms->cellx = va_arg(tags, int);
|
parms->cellx = ListGetInt(tags);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DTA_CellY:
|
case DTA_CellY:
|
||||||
parms->celly = va_arg(tags, int);
|
parms->celly = ListGetInt(tags);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
}
|
}
|
||||||
tag = va_arg(tags, DWORD);
|
tag = ListGetInt(tags);
|
||||||
}
|
}
|
||||||
va_end (tags);
|
va_end (tags);
|
||||||
|
|
||||||
|
|
|
@ -75,7 +75,6 @@ enum
|
||||||
DTA_DestWidth, // width of area to draw to
|
DTA_DestWidth, // width of area to draw to
|
||||||
DTA_DestHeight, // height of area to draw to
|
DTA_DestHeight, // height of area to draw to
|
||||||
DTA_Alpha, // alpha value for translucency
|
DTA_Alpha, // alpha value for translucency
|
||||||
DTA_AlphaF, // alpha value for translucency
|
|
||||||
DTA_FillColor, // color to stencil onto the destination (RGB is the color for truecolor drawers, A is the palette index for paletted drawers)
|
DTA_FillColor, // color to stencil onto the destination (RGB is the color for truecolor drawers, A is the palette index for paletted drawers)
|
||||||
DTA_Translation, // translation table to recolor the source
|
DTA_Translation, // translation table to recolor the source
|
||||||
DTA_AlphaChannel, // bool: the source is an alpha channel; used with DTA_FillColor
|
DTA_AlphaChannel, // bool: the source is an alpha channel; used with DTA_FillColor
|
||||||
|
@ -163,7 +162,7 @@ struct DrawParms
|
||||||
uint32 colorOverlay;
|
uint32 colorOverlay;
|
||||||
INTBOOL alphaChannel;
|
INTBOOL alphaChannel;
|
||||||
INTBOOL flipX;
|
INTBOOL flipX;
|
||||||
fixed_t shadowAlpha;
|
float shadowAlpha;
|
||||||
int shadowColor;
|
int shadowColor;
|
||||||
INTBOOL keepratio;
|
INTBOOL keepratio;
|
||||||
INTBOOL masked;
|
INTBOOL masked;
|
||||||
|
|
|
@ -724,7 +724,7 @@ static int WI_DrawCharPatch (FFont *font, int charcode, int x, int y, EColorRang
|
||||||
int width;
|
int width;
|
||||||
screen->DrawTexture(font->GetChar(charcode, &width), x, y,
|
screen->DrawTexture(font->GetChar(charcode, &width), x, y,
|
||||||
nomove ? DTA_CleanNoMove : DTA_Clean, true,
|
nomove ? DTA_CleanNoMove : DTA_Clean, true,
|
||||||
DTA_ShadowAlpha, (gameinfo.gametype & GAME_DoomChex) ? 0 : OPAQUE/2,
|
DTA_ShadowAlpha, (gameinfo.gametype & GAME_DoomChex) ? 0 : 0.5,
|
||||||
DTA_Translation, font->GetColorTranslation(translation),
|
DTA_Translation, font->GetColorTranslation(translation),
|
||||||
TAG_DONE);
|
TAG_DONE);
|
||||||
return x - width;
|
return x - width;
|
||||||
|
|
Loading…
Reference in a new issue