185 lines
7.1 KiB
VB.net
185 lines
7.1 KiB
VB.net
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("<playername>", Core.Player.Name).Replace("<player.name>", 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 OrElse Core.CurrentScreen.Identification = Screen.Identifications.NewGameScreen 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 |