fixed remove/hide main-menu when sub-menus are closed
This commit is contained in:
committed by
Scott_NZ
parent
3ce68d2f7d
commit
4470d67617
@@ -14,33 +14,62 @@ namespace OpenRA.Mods.RA.Widgets.Logic
|
|||||||
{
|
{
|
||||||
public class MainMenuButtonsLogic
|
public class MainMenuButtonsLogic
|
||||||
{
|
{
|
||||||
|
|
||||||
|
enum MenuType { Main, None }
|
||||||
|
MenuType Menu = MenuType.Main;
|
||||||
|
|
||||||
Widget rootMenu;
|
Widget rootMenu;
|
||||||
|
|
||||||
[ObjectCreator.UseCtor]
|
[ObjectCreator.UseCtor]
|
||||||
public MainMenuButtonsLogic(Widget widget)
|
public MainMenuButtonsLogic(Widget widget)
|
||||||
{
|
{
|
||||||
rootMenu = widget;
|
rootMenu = widget;
|
||||||
|
rootMenu.IsVisible = () => Menu == MenuType.Main;
|
||||||
|
|
||||||
Game.modData.WidgetLoader.LoadWidget( new WidgetArgs(), Ui.Root, "PERF_BG" );
|
Game.modData.WidgetLoader.LoadWidget( new WidgetArgs(), Ui.Root, "PERF_BG" );
|
||||||
|
|
||||||
widget.Get<ButtonWidget>("MAINMENU_BUTTON_JOIN").OnClick = () => OpenGamePanel("JOINSERVER_BG");
|
widget.Get<ButtonWidget>("MAINMENU_BUTTON_JOIN").OnClick = () => OpenGamePanel("JOINSERVER_BG");
|
||||||
widget.Get<ButtonWidget>("MAINMENU_BUTTON_CREATE").OnClick = () => OpenGamePanel("CREATESERVER_BG");
|
widget.Get<ButtonWidget>("MAINMENU_BUTTON_CREATE").OnClick = () => OpenGamePanel("CREATESERVER_BG");
|
||||||
widget.Get<ButtonWidget>("MAINMENU_BUTTON_DIRECTCONNECT").OnClick = () => OpenGamePanel("DIRECTCONNECT_BG");
|
widget.Get<ButtonWidget>("MAINMENU_BUTTON_DIRECTCONNECT").OnClick = () => OpenGamePanel("DIRECTCONNECT_BG");
|
||||||
widget.Get<ButtonWidget>("MAINMENU_BUTTON_SETTINGS").OnClick = () => Ui.OpenWindow("SETTINGS_MENU");
|
|
||||||
widget.Get<ButtonWidget>("MAINMENU_BUTTON_MUSIC").OnClick = () => Ui.OpenWindow("MUSIC_MENU");
|
widget.Get<ButtonWidget>("MAINMENU_BUTTON_SETTINGS").OnClick = () =>
|
||||||
|
{
|
||||||
|
Menu = MenuType.None;
|
||||||
|
Ui.OpenWindow("SETTINGS_MENU", new WidgetArgs()
|
||||||
|
{
|
||||||
|
{ "onExit", () => Menu = MenuType.Main }
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
widget.Get<ButtonWidget>("MAINMENU_BUTTON_MUSIC").OnClick = () =>
|
||||||
|
{
|
||||||
|
Menu = MenuType.None;
|
||||||
|
Ui.OpenWindow("MUSIC_MENU", new WidgetArgs()
|
||||||
|
{
|
||||||
|
{ "onExit", () => Menu = MenuType.Main }
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
widget.Get<ButtonWidget>("MAINMENU_BUTTON_MODS").OnClick = () =>
|
widget.Get<ButtonWidget>("MAINMENU_BUTTON_MODS").OnClick = () =>
|
||||||
|
{
|
||||||
|
Menu = MenuType.None;
|
||||||
Ui.OpenWindow("MODS_PANEL", new WidgetArgs()
|
Ui.OpenWindow("MODS_PANEL", new WidgetArgs()
|
||||||
{
|
{
|
||||||
{ "onExit", () => {} },
|
{ "onExit", () => Menu = MenuType.Main },
|
||||||
{ "onSwitch", RemoveShellmapUI }
|
{ "onSwitch", RemoveShellmapUI }
|
||||||
});
|
});
|
||||||
|
};
|
||||||
|
|
||||||
widget.Get<ButtonWidget>("MAINMENU_BUTTON_REPLAY_VIEWER").OnClick = () =>
|
widget.Get<ButtonWidget>("MAINMENU_BUTTON_REPLAY_VIEWER").OnClick = () =>
|
||||||
|
{
|
||||||
|
Menu = MenuType.None;
|
||||||
Ui.OpenWindow("REPLAYBROWSER_BG", new WidgetArgs()
|
Ui.OpenWindow("REPLAYBROWSER_BG", new WidgetArgs()
|
||||||
{
|
{
|
||||||
{ "onExit", () => {} },
|
{ "onExit", () => Menu = MenuType.Main },
|
||||||
{ "onStart", RemoveShellmapUI }
|
{ "onStart", RemoveShellmapUI }
|
||||||
});
|
});
|
||||||
|
};
|
||||||
|
|
||||||
widget.Get<ButtonWidget>("MAINMENU_BUTTON_QUIT").OnClick = () => Game.Exit();
|
widget.Get<ButtonWidget>("MAINMENU_BUTTON_QUIT").OnClick = () => Game.Exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -51,18 +80,20 @@ namespace OpenRA.Mods.RA.Widgets.Logic
|
|||||||
|
|
||||||
void OpenGamePanel(string id)
|
void OpenGamePanel(string id)
|
||||||
{
|
{
|
||||||
|
Menu = MenuType.None;
|
||||||
Ui.OpenWindow(id, new WidgetArgs()
|
Ui.OpenWindow(id, new WidgetArgs()
|
||||||
{
|
{
|
||||||
{ "onExit", () => {} },
|
{ "onExit", () => Menu = MenuType.Main },
|
||||||
{ "openLobby", () => OpenLobbyPanel() }
|
{ "openLobby", () => OpenLobbyPanel() }
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
void OpenLobbyPanel()
|
void OpenLobbyPanel()
|
||||||
{
|
{
|
||||||
|
Menu = MenuType.None;
|
||||||
Game.OpenWindow("SERVER_LOBBY", new WidgetArgs()
|
Game.OpenWindow("SERVER_LOBBY", new WidgetArgs()
|
||||||
{
|
{
|
||||||
{ "onExit", () => { Game.Disconnect(); } },
|
{ "onExit", () => { Game.Disconnect(); Menu = MenuType.Main; } },
|
||||||
{ "onStart", RemoveShellmapUI },
|
{ "onStart", RemoveShellmapUI },
|
||||||
{ "addBots", false }
|
{ "addBots", false }
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -32,7 +32,8 @@ namespace OpenRA.Mods.RA.Widgets.Logic
|
|||||||
() => Play( Game.Settings.Sound.Repeat ? CurrentSong : GetNextSong() ));
|
() => Play( Game.Settings.Sound.Repeat ? CurrentSong : GetNextSong() ));
|
||||||
}
|
}
|
||||||
|
|
||||||
public MusicPlayerLogic()
|
[ObjectCreator.UseCtor]
|
||||||
|
public MusicPlayerLogic(Action onExit)
|
||||||
{
|
{
|
||||||
bg = Ui.Root.Get("MUSIC_MENU");
|
bg = Ui.Root.Get("MUSIC_MENU");
|
||||||
CurrentSong = GetNextSong();
|
CurrentSong = GetNextSong();
|
||||||
@@ -41,7 +42,7 @@ namespace OpenRA.Mods.RA.Widgets.Logic
|
|||||||
bg.Get( "BUTTON_PLAY" ).IsVisible = () => !Sound.MusicPlaying;
|
bg.Get( "BUTTON_PLAY" ).IsVisible = () => !Sound.MusicPlaying;
|
||||||
|
|
||||||
bg.Get<ButtonWidget>("BUTTON_CLOSE").OnClick =
|
bg.Get<ButtonWidget>("BUTTON_CLOSE").OnClick =
|
||||||
() => { Game.Settings.Save(); Ui.CloseWindow(); };
|
() => { Game.Settings.Save(); Ui.CloseWindow(); onExit(); };
|
||||||
|
|
||||||
bg.Get("BUTTON_INSTALL").IsVisible = () => false;
|
bg.Get("BUTTON_INSTALL").IsVisible = () => false;
|
||||||
|
|
||||||
|
|||||||
@@ -21,7 +21,8 @@ namespace OpenRA.Mods.RA.Widgets.Logic
|
|||||||
{
|
{
|
||||||
Widget bg;
|
Widget bg;
|
||||||
|
|
||||||
public SettingsMenuLogic()
|
[ObjectCreator.UseCtor]
|
||||||
|
public SettingsMenuLogic(Action onExit)
|
||||||
{
|
{
|
||||||
bg = Ui.Root.Get<BackgroundWidget>("SETTINGS_MENU");
|
bg = Ui.Root.Get<BackgroundWidget>("SETTINGS_MENU");
|
||||||
var tabs = bg.Get<ContainerWidget>("TAB_CONTAINER");
|
var tabs = bg.Get<ContainerWidget>("TAB_CONTAINER");
|
||||||
@@ -247,6 +248,7 @@ namespace OpenRA.Mods.RA.Widgets.Logic
|
|||||||
int.TryParse(maxFrameRate.Text, out gs.MaxFramerate);
|
int.TryParse(maxFrameRate.Text, out gs.MaxFramerate);
|
||||||
Game.Settings.Save();
|
Game.Settings.Save();
|
||||||
Ui.CloseWindow();
|
Ui.CloseWindow();
|
||||||
|
onExit();
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user