Fix crashing when at options group screen then resizing. (Thanks cybertoon)

This commit is contained in:
UnknownShadow200 2017-02-16 22:18:26 +11:00
parent b71970c896
commit 32a00ecd88

View file

@ -9,7 +9,9 @@ namespace ClassicalSharp.Gui.Screens {
public OptionsGroupScreen(Game game) : base(game) { public OptionsGroupScreen(Game game) : base(game) {
} }
TextWidget descWidget; TextWidget descWidget;
string descText;
ButtonWidget selectedWidget; ButtonWidget selectedWidget;
public override void Render(double delta) { public override void Render(double delta) {
@ -49,6 +51,8 @@ namespace ClassicalSharp.Gui.Screens {
MakeBack(false, titleFont, MakeBack(false, titleFont,
(g, w) => g.Gui.SetNewScreen(new PauseScreen(g))), (g, w) => g.Gui.SetNewScreen(new PauseScreen(g))),
}; };
if (descWidget != null) MakeDescWidget(descText);
CheckHacksAllowed(null, null); CheckHacksAllowed(null, null);
} }
@ -67,8 +71,13 @@ namespace ClassicalSharp.Gui.Screens {
if (button == null) return; if (button == null) return;
string text = descriptions[Array.IndexOf<Widget>(widgets, button)]; string text = descriptions[Array.IndexOf<Widget>(widgets, button)];
MakeDescWidget(text);
}
void MakeDescWidget(string text) {
descWidget = TextWidget.Create(game, text, regularFont) descWidget = TextWidget.Create(game, text, regularFont)
.SetLocation(Anchor.Centre, Anchor.Centre, 0, 100); .SetLocation(Anchor.Centre, Anchor.Centre, 0, 100);
descText = text;
} }
ButtonWidget Make(int dir, int y, string text, Action<Game, Widget> onClick) { ButtonWidget Make(int dir, int y, string text, Action<Game, Widget> onClick) {
@ -76,6 +85,7 @@ namespace ClassicalSharp.Gui.Screens {
.SetLocation(Anchor.Centre, Anchor.Centre, dir * 160, y); .SetLocation(Anchor.Centre, Anchor.Centre, dir * 160, y);
} }
public override bool HandlesKeyDown(Key key) { public override bool HandlesKeyDown(Key key) {
if (key == Key.Escape) if (key == Key.Escape)
game.Gui.SetNewScreen(null); game.Gui.SetNewScreen(null);
@ -88,9 +98,12 @@ namespace ClassicalSharp.Gui.Screens {
base.OnResize(width, height); base.OnResize(width, height);
} }
protected override void ContextLost() {
base.ContextLost();
if (descWidget != null) descWidget.Dispose();
}
public override void Dispose() { public override void Dispose() {
if (descWidget != null)
descWidget.Dispose();
base.Dispose(); base.Dispose();
game.Events.HackPermissionsChanged -= CheckHacksAllowed; game.Events.HackPermissionsChanged -= CheckHacksAllowed;
} }