mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-26 08:50:55 +00:00
Menu stuff
git-svn-id: https://svn.eduke32.com/eduke32@6751 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
328fec27fb
commit
6895ca0fc0
1 changed files with 22 additions and 5 deletions
|
@ -1580,6 +1580,8 @@ static MenuEntry_t *Menu_AdjustForCurrentEntryAssignmentBlind(MenuMenu_t *menu)
|
||||||
return Menu_AdjustForCurrentEntryAssignment(menu);
|
return Menu_AdjustForCurrentEntryAssignment(menu);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int32_t SELECTDIR_z = 65536;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
This function prepares data after ART and CON have been processed.
|
This function prepares data after ART and CON have been processed.
|
||||||
It also initializes some data in loops rather than statically at compile time.
|
It also initializes some data in loops rather than statically at compile time.
|
||||||
|
@ -1835,6 +1837,8 @@ void Menu_Init(void)
|
||||||
MEF_MainMenu.marginBottom = 7<<16;
|
MEF_MainMenu.marginBottom = 7<<16;
|
||||||
|
|
||||||
M_OPTIONS.title = NoTitle;
|
M_OPTIONS.title = NoTitle;
|
||||||
|
|
||||||
|
SELECTDIR_z = 16384;
|
||||||
}
|
}
|
||||||
|
|
||||||
// prepare shareware
|
// prepare shareware
|
||||||
|
@ -2112,6 +2116,9 @@ static void Menu_PreDrawBackground(MenuID_t cm, const vec2_t origin)
|
||||||
|
|
||||||
case MENU_LOAD:
|
case MENU_LOAD:
|
||||||
case MENU_SAVE:
|
case MENU_SAVE:
|
||||||
|
if (KXDWN)
|
||||||
|
break;
|
||||||
|
fallthrough__;
|
||||||
case MENU_CREDITS4:
|
case MENU_CREDITS4:
|
||||||
case MENU_CREDITS5:
|
case MENU_CREDITS5:
|
||||||
Menu_DrawBackground(origin);
|
Menu_DrawBackground(origin);
|
||||||
|
@ -5333,10 +5340,12 @@ static void Menu_Run_MouseReturn(Menu_t *cm, const vec2_t origin)
|
||||||
if (cm->menuID == MENU_MAIN)
|
if (cm->menuID == MENU_MAIN)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
rotatesprite_(origin.x + (tilesiz[SELECTDIR].y << 16), 0, 65536, 512, SELECTDIR,
|
uint32_t const posx = tilesiz[SELECTDIR].y * SELECTDIR_z;
|
||||||
|
|
||||||
|
rotatesprite_(origin.x + posx, 0, SELECTDIR_z, 512, SELECTDIR,
|
||||||
Menu_RunInput_MouseReturn_status ? 4 - (sintable[(totalclock << 4) & 2047] >> 11) : 6, 0,
|
Menu_RunInput_MouseReturn_status ? 4 - (sintable[(totalclock << 4) & 2047] >> 11) : 6, 0,
|
||||||
2 | 8 | 16 | RS_ALIGN_L, MOUSEALPHA, 0, xdim_from_320_16(origin.x + x_widescreen_left()), 0,
|
2 | 8 | 16 | RS_ALIGN_L, MOUSEALPHA, 0, xdim_from_320_16(origin.x + x_widescreen_left()), 0,
|
||||||
xdim_from_320_16(origin.x + x_widescreen_left() + (tilesiz[SELECTDIR].y << 15)), ydim - 1);
|
xdim_from_320_16(origin.x + x_widescreen_left() + (posx>>1)), ydim - 1);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -5355,7 +5364,9 @@ static int32_t Menu_RunInput_MouseReturn(void)
|
||||||
|
|
||||||
const int32_t MouseReturnRegionX = x_widescreen_left();
|
const int32_t MouseReturnRegionX = x_widescreen_left();
|
||||||
|
|
||||||
if (!Menu_MouseOutsideBounds(&m_mousepos, MouseReturnRegionX, 0, tilesiz[SELECTDIR].y<<15, tilesiz[SELECTDIR].x<<16))
|
vec2_t backbuttonbound = { (tilesiz[SELECTDIR].y * SELECTDIR_z)>>1, tilesiz[SELECTDIR].x * SELECTDIR_z };
|
||||||
|
|
||||||
|
if (!Menu_MouseOutsideBounds(&m_mousepos, MouseReturnRegionX, 0, backbuttonbound.x, backbuttonbound.y))
|
||||||
{
|
{
|
||||||
#if !defined EDUKE32_TOUCH_DEVICES
|
#if !defined EDUKE32_TOUCH_DEVICES
|
||||||
Menu_RunInput_MouseReturn_status = 1;
|
Menu_RunInput_MouseReturn_status = 1;
|
||||||
|
@ -5363,7 +5374,7 @@ static int32_t Menu_RunInput_MouseReturn(void)
|
||||||
Menu_RunInput_MouseReturn_status = (mousepressstate == Mouse_Pressed || mousepressstate == Mouse_Held);
|
Menu_RunInput_MouseReturn_status = (mousepressstate == Mouse_Pressed || mousepressstate == Mouse_Held);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return !m_mousecaught && mousepressstate == Mouse_Released && !Menu_MouseOutsideBounds(&m_mousedownpos, MouseReturnRegionX, 0, tilesiz[SELECTDIR].y<<15, tilesiz[SELECTDIR].x<<16);
|
return !m_mousecaught && mousepressstate == Mouse_Released && !Menu_MouseOutsideBounds(&m_mousedownpos, MouseReturnRegionX, 0, backbuttonbound.x, backbuttonbound.y);
|
||||||
}
|
}
|
||||||
|
|
||||||
Menu_RunInput_MouseReturn_status = 0;
|
Menu_RunInput_MouseReturn_status = 0;
|
||||||
|
@ -6917,6 +6928,7 @@ void M_DisplayMenus(void)
|
||||||
uint32_t o = 2;
|
uint32_t o = 2;
|
||||||
|
|
||||||
auto const oyxaspect = yxaspect;
|
auto const oyxaspect = yxaspect;
|
||||||
|
int32_t alpha;
|
||||||
if (KXDWN)
|
if (KXDWN)
|
||||||
{
|
{
|
||||||
setaspect(viewingrange, 65536);
|
setaspect(viewingrange, 65536);
|
||||||
|
@ -6925,9 +6937,14 @@ void M_DisplayMenus(void)
|
||||||
z = scale(32768, ydim << 2, xdim * 3);
|
z = scale(32768, ydim << 2, xdim * 3);
|
||||||
p = 0;
|
p = 0;
|
||||||
o |= 1024;
|
o |= 1024;
|
||||||
|
alpha = MOUSEALPHA;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
alpha = CURSORALPHA;
|
||||||
}
|
}
|
||||||
|
|
||||||
rotatesprite_fs_alpha(cursorpos.x, cursorpos.y, z, 0, a, 0, p, o, CURSORALPHA);
|
rotatesprite_fs_alpha(cursorpos.x, cursorpos.y, z, 0, a, 0, p, o, alpha);
|
||||||
|
|
||||||
if (KXDWN)
|
if (KXDWN)
|
||||||
setaspect(viewingrange, oyxaspect);
|
setaspect(viewingrange, oyxaspect);
|
||||||
|
|
Loading…
Reference in a new issue