Public Class ChooseBox Public Delegate Sub DoAnswer(ByVal result As Integer) Public Options() As String Public index As Integer = 0 Dim PositionY As Single = 0 Public Showing As Boolean = False Public readyForResult As Boolean = False Public result As Integer = 0 Public resultID As Integer = 0 Public ActionScript As Boolean = False Public Shared CancelIndex As Integer = -1 Public TextFont As FontContainer Public DoDelegate As Boolean = False Dim Subs As DoAnswer Public UpdateEntities() As Entity Public Sub Show(ByVal Options() As String, ByVal DoSubs As DoAnswer) Me.resultID = 0 Me.Options = Options Me.index = 0 Me.readyForResult = False Me.Showing = True Me.Subs = DoSubs Me.ActionScript = False Me.DoDelegate = True Me.TextFont = FontManager.GetFontContainer("textfont") SetupOptions() End Sub Public Sub Show(ByVal Options() As String, ByVal ID As Integer, ByVal ActionScript As Boolean) Me.resultID = ID Me.Options = Options Me.index = 0 Me.readyForResult = False Me.Showing = True Me.ActionScript = ActionScript Me.DoDelegate = False Me.TextFont = FontManager.GetFontContainer("textfont") SetupOptions() End Sub Public Sub Show(ByVal Options() As String, ByVal ID As Integer, ByVal UpdateEntities() As Entity) Me.resultID = ID Me.Options = Options Me.index = 0 Me.readyForResult = False Me.Showing = True Me.UpdateEntities = UpdateEntities Me.ActionScript = False Me.DoDelegate = False Me.TextFont = FontManager.GetFontContainer("textfont") SetupOptions() End Sub Private Sub SetupOptions() For i = 0 To Options.Count - 1 Options(i) = Options(i).Replace("", Core.Player.Name) Next End Sub Public Function getResult(ByVal ID As Integer) As Integer If Me.readyForResult = True Then If Me.resultID = ID Then Return result Else Return -1 End If Else Return -1 End If End Function Public Sub Update() Update(True) End Sub Public Sub Update(ByVal RaiseClickEvent As Boolean) If Me.Showing = True Then If Controls.Down(True, True, True) Then Me.index += 1 End If If Controls.Up(True, True, True) Then Me.index -= 1 End If If Me.index < 0 Then Me.index = Me.Options.Count - 1 End If If Me.index = Me.Options.Count Then Me.index = 0 End If If RaiseClickEvent = True Then If Controls.Accept() = True Then Me.PlayClickSound() Me.result = index Me.HandleResult() End If If Controls.Dismiss() = True And CancelIndex > -1 Then Me.PlayClickSound() Me.result = CancelIndex Me.HandleResult() End If End If End If End Sub Private Sub PlayClickSound() If Screen.TextBox.Showing = False Then SoundManager.PlaySound("select") End If End Sub Private Sub HandleResult() ChooseBox.CancelIndex = -1 Me.readyForResult = True Me.Showing = False If Me.DoDelegate = True Then Subs(result) Else If Core.CurrentScreen.Identification = Screen.Identifications.OverworldScreen Then If Me.ActionScript = True Then Dim c As OverworldScreen = CType(Core.CurrentScreen, OverworldScreen) c.ActionScript.Switch(Me.Options(result)) Else For Each Entity As Entity In UpdateEntities Entity.ResultFunction(result) Next End If End If End If End Sub Public Sub Draw(ByVal Position As Vector2, Optional ByVal DrawBox As Boolean = True, Optional ByVal Size As Single = 1.0F) If Me.Showing = True Then With Core.SpriteBatch Dim sizeMultiplier As Integer = CInt(3 * Math.Ceiling(Core.SpriteBatch.InterfaceScale)) 'Bounding box If DrawBox Then Dim MaxWidth = 0 For i = 0 To Options.Count - 1 While Me.TextFont.SpriteFont.MeasureString(Options(i).Replace("[POKE]", "Poké")).X - 16 > MaxWidth MaxWidth += 16 End While If MaxWidth < 48 Then MaxWidth = 48 End If Next Canvas.DrawImageBorder(TextureManager.GetTexture("GUI\Overworld\ChooseBox", New Rectangle(0, 0, 48, 48), ""), sizeMultiplier, New Rectangle(CInt(Position.X), CInt(Position.Y), CInt((MaxWidth * sizeMultiplier) * Size), CInt(48 * Size * Math.Ceiling(Core.SpriteBatch.InterfaceScale) * Options.Count)), False) End If 'Text For i = 0 To Options.Count - 1 Dim useSize As Single = Size Select Case Me.TextFont.FontName.ToLower() Case "textfont", "braille" useSize = 2 * Size End Select useSize = CInt(useSize * Math.Ceiling(Core.SpriteBatch.InterfaceScale)) .DrawString(Me.TextFont.SpriteFont, Options(i).Replace("[POKE]", "Poké"), New Vector2(CInt(Position.X + CInt(48 * Math.Ceiling(Core.SpriteBatch.InterfaceScale))), CInt(Position.Y) + CInt((32 + i * 48 * Size) * Math.Ceiling(Core.SpriteBatch.InterfaceScale))), Color.Black, 0.0F, Vector2.Zero, useSize, SpriteEffects.None, 0.0F) Next 'Cursor .Draw(TextureManager.GetTexture("GUI\Overworld\ChooseBox"), New Rectangle(CInt(Position.X + CInt(24 * Math.Ceiling(Core.SpriteBatch.InterfaceScale))), CInt(Position.Y) + CInt((34 + CInt(index * 48 * Size)) * Math.Ceiling(Core.SpriteBatch.InterfaceScale)), CInt(24 * Size * Math.Ceiling(Core.SpriteBatch.InterfaceScale)), CInt(24 * Size * Math.Ceiling(Core.SpriteBatch.InterfaceScale))), New Rectangle(72, 0, 8, 8), Color.White) End With End If End Sub Public Sub Draw() If Me.Showing = True Then Dim Position As Vector2 = New Vector2(CInt(Core.windowSize.Width / 2) - CInt(48 * Math.Ceiling(Core.SpriteBatch.InterfaceScale)), Core.windowSize.Height - CInt(160.0F * Math.Ceiling(Core.SpriteBatch.InterfaceScale)) - CInt(96.0F * Math.Ceiling(Core.SpriteBatch.InterfaceScale)) - CInt((Options.Count - 1) * 48 * Math.Ceiling(Core.SpriteBatch.InterfaceScale))) Me.Draw(Position) End If End Sub End Class