P3D-Legacy/P3D/Screens/NewOptionScreen.vb

1852 lines
67 KiB
VB.net

Imports P3D.Screens.UI
Public Class NewOptionScreen
Inherits Screen
Dim TextSpeed As Integer = 2
Dim CameraSpeed As Integer = 12
Dim FOV As Single = 45.0F
Dim Music As Integer = 50
Dim Sound As Integer = 50
Dim RenderDistance As Integer = 0
Dim GraphicStyle As Integer = 1
Dim ShowBattleAnimations As Integer = 1
Dim DiagonalMovement As Boolean = True
Dim Difficulty As Integer = 0
Dim InterfaceScale As Integer = 0
Dim BattleStyle As Integer = 1
Dim LoadOffsetMaps As Integer = 1
Dim ViewBobbing As Boolean = True
Dim ShowModels As Integer = 1
Dim Muted As Integer = 0
Dim GamePadEnabled As Boolean = True
Dim RunMode As Boolean = True
Dim PreferMultiSampling As Boolean = True
Dim TempMusicVolume As Integer = 50
Dim TempSoundVolume As Integer = 50
Dim TempMuted As Integer = 0
Private _subMenu As Integer = 0
Private _screenSize As Size = New Size(CInt(windowSize.Width), CInt(windowSize.Height))
Private Property SelectPackNoiseDelay As Integer = 10
Private Languages As New List(Of String)
Private LanguageNames As New List(Of String)
Private currentLanguage As String = Localization.LanguageSuffix
Private TempLanguage As String = Localization.LanguageSuffix
Public Shared languageMenuIndex(3) As Integer
Private PackNames As New List(Of String)
Private EnabledPackNames As New List(Of String)
Public Shared isSelectedEnabled As Boolean = False
Private packsMenuIndex(3) As Integer
Private packInfoIndex As Integer = 0
Dim savedOptions As Boolean = True
Public Shared ScreenIndex As Integer = 0
Dim _nextIndex As Integer = 0
Dim ControlList As New List(Of Control)
'New stuff
''' <summary>
''' Texture from file: GUI\Menus\General
''' </summary>
Private _texture As Texture2D
''' <summary>
''' Texture from file: GUI\Menus\Options
''' </summary>
Private _menuTexture As Texture2D
'Interface animation state values:
Private _interfaceFade As Single = 0F
Private _closing As Boolean = False
Private _opening As Boolean = False
Private _enrollY As Single = 0F
Private _itemIntro As Single = 0F
Private _pageFade As Single = 1.0F
Private _pageOpening As Boolean = False
Private _pageClosing As Boolean = False
'cursor animation:
Private _cursorPosition As Vector2 = New Vector2(CInt(Core.windowSize.Width / 2) - 400 + 90, CInt(Core.windowSize.Height / 2) - 200 + 80)
Private _cursorDestPosition As Vector2 = New Vector2(CInt(Core.windowSize.Width / 2) - 400 + 90, CInt(Core.windowSize.Height / 2) - 200 + 80)
Private _selectedScrollBar As Boolean = False
Public Sub New(ByVal currentScreen As Screen, Optional ByVal Submenu As Integer = 0)
'New stuff
_texture = TextureManager.GetTexture("GUI\Menus\General")
_menuTexture = TextureManager.GetTexture("GUI\Menus\Options")
'''
Me.Identification = Identifications.OptionScreen
Me.PreScreen = currentScreen
Me.CanChat = False
Me.MouseVisible = True
Me.CanBePaused = False
Me._opening = True
GetLanguages()
GetPacks()
If Camera Is Nothing Then
Camera = New OverworldCamera()
End If
SetFunctionality()
If Submenu > 0 AndAlso PreScreen.Identification = Identifications.MainMenuScreen Then
_subMenu = Submenu
Select Case _subMenu
Case 1
SwitchToLanguage()
Case 2
SwitchToAudio()
Case 3
SwitchToControls()
Case 4
SwitchToContentPacks()
End Select
Else
_subMenu = 0
ScreenIndex = 0
End If
End Sub
Private Sub SetFunctionality()
If PreScreen.Identification <> Identifications.MainMenuScreen Then
Camera = CType(Screen.Camera, OverworldCamera)
Me.FOV = Camera.FOV
Me.TextSpeed = TextBox.TextSpeed
Me.CameraSpeed = CInt(Camera.RotationSpeed * 10000)
Me.Difficulty = Core.Player.DifficultyMode
Me.RunMode = Core.Player.RunMode
End If
Me.TempMusicVolume = CInt(MusicManager.MasterVolume * 100)
Me.TempSoundVolume = CInt(SoundManager.Volume * 100)
Me.TempMuted = CInt(MusicManager.Muted.ToNumberString())
Me.Muted = CInt(MusicManager.Muted.ToNumberString())
Me.Music = CInt(MusicManager.MasterVolume * 100)
Me.Sound = CInt(SoundManager.Volume * 100)
Me.RenderDistance = Core.GameOptions.RenderDistance
Me.GraphicStyle = Core.GameOptions.GraphicStyle
Me.InterfaceScale = Core.GameOptions.InterfaceScale
Me.ShowBattleAnimations = Core.Player.ShowBattleAnimations
Me.DiagonalMovement = Core.Player.DiagonalMovement
Me.BattleStyle = Core.Player.BattleStyle
Me.ShowModels = CInt(Core.Player.ShowModelsInBattle)
If Core.GameOptions.LoadOffsetMaps = 0 Then
Me.LoadOffsetMaps = 0
Else
Me.LoadOffsetMaps = 101 - Core.GameOptions.LoadOffsetMaps
End If
Me.ViewBobbing = Core.GameOptions.ViewBobbing
Me.GamePadEnabled = Core.GameOptions.GamePadEnabled
Me.PreferMultiSampling = Core.GraphicsManager.PreferMultiSampling
End Sub
Public Overrides Sub Draw()
PreScreen.Draw()
DrawBackground()
If ScreenIndex = 6 Then
DrawLanguageMenu()
End If
If ScreenIndex = 7 Then
DrawPacksMenu()
End If
If ScreenIndex = 8 Then
DrawPackInformationMenu()
End If
DrawCurrentPage()
DrawCursor()
DrawMessage()
TextBox.Draw()
ChooseBox.Draw()
End Sub
#Region "LanguageMenu"
Private Sub DrawLanguageMenu()
For i = 0 To 3
Dim c As Color = New Color(255, 255, 255, CInt(255 * _interfaceFade * _pageFade))
If i + languageMenuIndex(2) = languageMenuIndex(0) Then
c = New Color(77, 147, 198, CInt(255 * _interfaceFade * _pageFade))
End If
Canvas.DrawRectangle(New Rectangle(CInt(windowSize.Width / 2 - 258), CInt(Core.windowSize.Height / 2 - 128 + i * 50), 480, 48), c, False)
Next
Canvas.DrawScrollBar(New Vector2(CInt(windowSize.Width / 2 + 250), CInt(Core.windowSize.Height / 2 - 128)), Languages.Count, 4, languageMenuIndex(2), New Size(4, 200), False, New Color(77, 147, 198, CInt(255 * _interfaceFade * _pageFade)), New Color(255, 255, 255, CInt(255 * _interfaceFade * _pageFade)), False)
Dim x As Integer = Languages.Count - 1
x = CInt(MathHelper.Clamp(x, 0, 3))
For i = 0 To x
Dim Name As String = LanguageNames(i + languageMenuIndex(2))
If i + languageMenuIndex(2) = languageMenuIndex(0) Then
SpriteBatch.DrawString(FontManager.InGameFont, Name, New Vector2(CInt(windowSize.Width / 2 - 246), CInt(Core.windowSize.Height / 2 - 128 + 8 + 2 + i * 50)), New Color(0, 0, 0, CInt(255 * _interfaceFade * _pageFade)))
SpriteBatch.DrawString(FontManager.InGameFont, Name, New Vector2(CInt(windowSize.Width / 2 - 248), CInt(Core.windowSize.Height / 2 - 128 + 8 + i * 50)), New Color(255, 255, 255, CInt(255 * _interfaceFade * _pageFade)))
Else
SpriteBatch.DrawString(FontManager.InGameFont, Name, New Vector2(CInt(windowSize.Width / 2 - 248), CInt(Core.windowSize.Height / 2 - 128 + 8 + i * 50)), New Color(0, 0, 0, CInt(255 * _interfaceFade * _pageFade)))
End If
Next
End Sub
Private Sub UpdateLanguageMenu()
Dim currentIndex As Integer = languageMenuIndex(0)
If Controls.Up(True, True, True) = True Then
languageMenuIndex(0) -= 1
If languageMenuIndex(0) - languageMenuIndex(2) < 0 Then
languageMenuIndex(2) -= 1
End If
End If
If Controls.Down(True, True, True) = True Then
languageMenuIndex(0) += 1
If languageMenuIndex(0) + languageMenuIndex(2) > 3 Then
languageMenuIndex(2) += 1
End If
End If
If GameInstance.IsMouseVisible = True Then
For i = 0 To 3
If New Rectangle(CInt(windowSize.Width / 2) - 258, CInt(Core.windowSize.Height / 2 - 128 + i * 50), 480, 48).Contains(MouseHandler.MousePosition) = True Then
If MouseHandler.ButtonPressed(MouseHandler.MouseButtons.LeftButton) = True Then
languageMenuIndex(0) = i + languageMenuIndex(2)
End If
End If
Next
End If
languageMenuIndex(0) = CInt(MathHelper.Clamp(languageMenuIndex(0), 0, Languages.Count - 1))
languageMenuIndex(2) = CInt(MathHelper.Clamp(languageMenuIndex(2), 0, Languages.Count - 4))
If languageMenuIndex(0) <> currentIndex Then
Localization.Load(Languages(languageMenuIndex(0)))
End If
End Sub
Private Sub GetLanguages()
Languages.Clear()
LanguageNames.Clear()
For Each file As String In IO.Directory.GetFiles(GameController.GamePath & "\Content\Localization\")
If file.EndsWith(".dat") = True Then
Dim content() As String = IO.File.ReadAllLines(file)
file = IO.Path.GetFileNameWithoutExtension(file)
If file.StartsWith("Tokens_") = True Then
Dim TokenName As String = file.Remove(0, 7)
Dim LanguageName As String = ""
For Each line As String In content
If line.StartsWith("language_name,") = True Then
LanguageName = content(0).GetSplit(1)
Languages.Add(TokenName)
LanguageNames.Add(LanguageName)
Exit For
End If
Next
End If
End If
Next
End Sub
#End Region
Private Sub GetPacks(Optional ByVal reload As Boolean = False)
PackNames.Clear()
If reload = False Then
EnabledPackNames.Clear()
EnabledPackNames.AddRange(Core.GameOptions.ContentPackNames)
End If
PackNames.AddRange(EnabledPackNames)
If IO.Directory.Exists(GameController.GamePath & "\ContentPacks\") = True Then
For Each ContentPackFolder As String In IO.Directory.GetDirectories(GameController.GamePath & "\ContentPacks\")
Dim newContentPack As String = ContentPackFolder.Remove(0, (GameController.GamePath & "\ContentPacks\").Length)
If PackNames.Contains(newContentPack) = False Then
PackNames.Add(newContentPack)
End If
Next
End If
End Sub
#Region "PacksMenu"
Private Sub DrawPacksMenu()
For i = 0 To 3
Dim c As Color = New Color(255, 255, 255, CInt(255 * _interfaceFade * _pageFade))
If i + packsMenuIndex(2) = packsMenuIndex(0) Then
c = New Color(77, 147, 198, CInt(255 * _interfaceFade * _pageFade))
If EnabledPackNames.Count > 0 Then
If EnabledPackNames.Contains(PackNames(i + packsMenuIndex(2))) = True Then
isSelectedEnabled = True
Else
isSelectedEnabled = False
End If
End If
End If
Canvas.DrawRectangle(New Rectangle(CInt(windowSize.Width / 2) - 328, CInt(Core.windowSize.Height / 2 - 128 + i * 50), 500, 48), c, False)
Next
Canvas.DrawScrollBar(New Vector2(CInt(windowSize.Width / 2) + 188, CInt(Core.windowSize.Height / 2 - 128)), PackNames.Count, 4, packsMenuIndex(2), New Size(4, 200), False, New Color(77, 147, 198, CInt(255 * _interfaceFade * _pageFade)), New Color(255, 255, 255, CInt(255 * _interfaceFade * _pageFade)), False)
Dim x As Integer = PackNames.Count - 1
x = CInt(MathHelper.Clamp(x, 0, 3))
Dim textColor As Color = New Color(0, 0, 0, CInt(255 * _interfaceFade * _pageFade))
If PackNames.Count > 0 Then
For i = 0 To x
Dim Name As String = PackNames(i + packsMenuIndex(2))
If EnabledPackNames.Contains(Name) = True Then
If i + packsMenuIndex(2) = packsMenuIndex(0) Then
SpriteBatch.DrawString(FontManager.InGameFont, Name, New Vector2(CInt(windowSize.Width / 2) - 320 + 2, CInt(Core.windowSize.Height / 2 - 120 + i * 50 + 2)), New Color(0, 0, 0, CInt(255 * _interfaceFade * _pageFade)))
SpriteBatch.DrawString(FontManager.InGameFont, Name, New Vector2(CInt(windowSize.Width / 2) - 320, CInt(Core.windowSize.Height / 2 - 120 + i * 50)), New Color(181, 255, 82, CInt(255 * _interfaceFade * _pageFade)))
Else
SpriteBatch.DrawString(FontManager.InGameFont, Name, New Vector2(CInt(windowSize.Width / 2) - 320, CInt(Core.windowSize.Height / 2 - 120 + i * 50)), New Color(98, 205, 8, CInt(255 * _interfaceFade * _pageFade)))
End If
Else
If i + packsMenuIndex(2) = packsMenuIndex(0) Then
SpriteBatch.DrawString(FontManager.InGameFont, Name, New Vector2(CInt(windowSize.Width / 2) - 320 + 2, CInt(Core.windowSize.Height / 2 - 120 + i * 50 + 2)), textColor)
SpriteBatch.DrawString(FontManager.InGameFont, Name, New Vector2(CInt(windowSize.Width / 2) - 320, CInt(Core.windowSize.Height / 2 - 120 + i * 50)), New Color(255, 255, 255, CInt(255 * _interfaceFade * _pageFade)))
Else
SpriteBatch.DrawString(FontManager.InGameFont, Name, New Vector2(CInt(windowSize.Width / 2) - 320, CInt(Core.windowSize.Height / 2 - 120 + i * 50)), textColor)
End If
End If
Next
End If
End Sub
Private Sub UpdatePacksMenu()
Dim currentIndex As Integer = packsMenuIndex(0)
Dim currentControl As Control = Nothing
For Each control As Control In ControlList
If control._position = _cursorDestPosition Then
currentControl = control
Exit For
End If
Next
If Controls.Up(True, True, True) = True Then
If currentControl.ID > 4 Then
packsMenuIndex(0) -= 1
If packsMenuIndex(0) - packsMenuIndex(2) < 0 Then
packsMenuIndex(2) -= 1
End If
If SelectPackNoiseDelay = 0 Then
SoundManager.PlaySound("select", 0.0F, 0.0F, 0.5F, False)
SelectPackNoiseDelay = 10
End If
End If
End If
If Controls.Down(True, True, True) = True Then
If currentControl.ID > 4 Then
packsMenuIndex(0) += 1
If packsMenuIndex(0) + packsMenuIndex(2) > 3 Then
packsMenuIndex(2) += 1
End If
If SelectPackNoiseDelay = 0 Then
SoundManager.PlaySound("select", 0.0F, 0.0F, 0.5F, False)
SelectPackNoiseDelay = 10
End If
End If
End If
If GameInstance.IsMouseVisible = True Then
For i = 0 To 3
If New Rectangle(CInt(windowSize.Width / 2 - 328), CInt(windowSize.Height / 2 - 128 + i * 50), 500, 48).Contains(MouseHandler.MousePosition) = True Then
If MouseHandler.ButtonPressed(MouseHandler.MouseButtons.LeftButton) = True Then
packsMenuIndex(0) = i + packsMenuIndex(2)
If SelectPackNoiseDelay = 0 Then
SoundManager.PlaySound("select", 0.0F, 0.0F, 0.5F, False)
SelectPackNoiseDelay = 10
End If
End If
End If
Next
End If
packsMenuIndex(0) = CInt(MathHelper.Clamp(packsMenuIndex(0), 0, PackNames.Count - 1))
packsMenuIndex(2) = CInt(MathHelper.Clamp(packsMenuIndex(2), 0, PackNames.Count - 4))
If SelectPackNoiseDelay > 0 Then
SelectPackNoiseDelay -= 1
End If
End Sub
Private Sub ButtonPackInformation()
If PackNames.Count = 0 Then
Exit Sub
End If
Dim packName As String = PackNames(packsMenuIndex(0))
PInfoSplash = Nothing
Try
If IO.File.Exists(GameController.GamePath & "\ContentPacks\" & packName & "\splash.png") = True Then
Using stream As IO.Stream = IO.File.Open(GameController.GamePath & "\ContentPacks\" & packName & "\splash.png", IO.FileMode.OpenOrCreate)
PInfoSplash = Texture2D.FromStream(GraphicsDevice, stream)
End Using
End If
Catch ex As Exception
Logger.Log(Logger.LogTypes.ErrorMessage, "MainMenuScreen.vb/ButtonPackInformation: An error occurred trying to load the splash image at """ & GameController.GamePath & "\ContentPacks\" & packName & "\splash.png" & """. This could have been caused by an invalid file header. (Exception: " & ex.Message & ")")
End Try
Dim contentPackPath As String = GameController.GamePath & "\ContentPacks\" & packName & "\"
Dim s() As String = ContentPackManager.GetContentPackInfo(packName)
If s.Length > 0 Then
PInfoVersion = s(0).CropStringToWidth(FontManager.InGameFont, 540 - 16 - CInt(FontManager.InGameFont.MeasureString(Localization.GetString("option_screen_contentpacks_version")).X))
End If
If s.Length > 1 Then
PInfoAuthor = s(1).CropStringToWidth(FontManager.InGameFont, 540 - 16 - CInt(FontManager.InGameFont.MeasureString(Localization.GetString("option_screen_contentpacks_by")).X))
End If
If s.Length > 2 Then
PInfoDescription = s(2).CropStringToWidth(FontManager.InGameFont, 540)
End If
PInfoName = packName
End Sub
Private PInfoName As String = ""
Private PInfoSplash As Texture2D = Nothing
Private PInfoVersion As String = ""
Private PInfoAuthor As String = ""
Private PInfoDescription As String = ""
Private Sub DrawPackInformationMenu()
If Not PInfoSplash Is Nothing Then
SpriteBatch.Draw(PInfoSplash, windowSize, Color.White)
End If
Dim CanvasTexture As Texture2D = TextureManager.GetTexture("GUI\Menus\Menu", New Rectangle(0, 0, 48, 48), "")
Canvas.DrawRectangle(New Rectangle(CInt(windowSize.Width / 2) - CInt(FontManager.InGameFont.MeasureString(Localization.GetString("option_screen_contentpacks_name") & ": " & PInfoName).X / 2) - 32, CInt(Core.windowSize.Height / 2 - 144), CInt(FontManager.InGameFont.MeasureString(Localization.GetString("option_screen_contentpacks_name") & ": " & PInfoName).X) + 64, 64), New Color(77, 147, 198, CInt(255 * _interfaceFade * _pageFade)))
SpriteBatch.DrawString(FontManager.InGameFont, Localization.GetString("option_screen_contentpacks_name") & ": " & PInfoName, New Vector2(CInt(windowSize.Width / 2) - CInt(FontManager.InGameFont.MeasureString(Localization.GetString("option_screen_contentpacks_name") & ": " & PInfoName).X / 2) + 2, CInt(Core.windowSize.Height / 2 - 128 + 2)), New Color(0, 0, 0, CInt(255 * _interfaceFade * _pageFade)))
SpriteBatch.DrawString(FontManager.InGameFont, Localization.GetString("option_screen_contentpacks_name") & ": " & PInfoName, New Vector2(CInt(windowSize.Width / 2) - CInt(FontManager.InGameFont.MeasureString(Localization.GetString("option_screen_contentpacks_name") & ": " & PInfoName).X / 2), CInt(Core.windowSize.Height / 2 - 128)), New Color(255, 255, 255, CInt(255 * _interfaceFade * _pageFade)))
Canvas.DrawRectangle(New Rectangle(CInt(windowSize.Width / 2) - 278, CInt(Core.windowSize.Height / 2 - 72), 556, 196), New Color(255, 255, 255, CInt(255 * _interfaceFade * _pageFade)))
SpriteBatch.DrawString(FontManager.InGameFont, Localization.GetString("option_screen_contentpacks_version") & ": " & PInfoVersion & Environment.NewLine & Localization.GetString("option_screen_contentpacks_by") & ": " & PInfoAuthor & Environment.NewLine & Localization.GetString("option_screen_contentpacks_description") & ": " & Environment.NewLine & PInfoDescription.Replace("<br>", Environment.NewLine).Replace("~", Environment.NewLine), New Vector2(CInt(windowSize.Width / 2) - 278 + 16, CInt(Core.windowSize.Height / 2 - 64)), New Color(0, 0, 0, CInt(255 * _interfaceFade * _pageFade)))
End Sub
Private Sub UpdatePackInformationMenu()
If KeyBoardHandler.KeyPressed(KeyBindings.EscapeKey) Or KeyBoardHandler.KeyPressed(KeyBindings.BackKey1) Or KeyBoardHandler.KeyPressed(KeyBindings.BackKey2) Or MouseHandler.ButtonPressed(MouseHandler.MouseButtons.RightButton) Or ControllerHandler.ButtonPressed(Buttons.B) Then
SwitchToContentPacks()
End If
End Sub
Private Sub ButtonUp()
If PackNames.Count > 0 Then
If EnabledPackNames.Contains(PackNames(packsMenuIndex(0))) = True Then
Dim idx As Integer = EnabledPackNames.IndexOf(PackNames(packsMenuIndex(0)))
If idx > 0 Then
Dim tempString As String = EnabledPackNames(idx - 1)
EnabledPackNames(idx - 1) = EnabledPackNames(idx)
EnabledPackNames(idx) = tempString
GetPacks(True)
End If
End If
End If
End Sub
Private Sub ButtonDown()
If PackNames.Count > 0 Then
If EnabledPackNames.Contains(PackNames(packsMenuIndex(0))) = True Then
Dim idx As Integer = EnabledPackNames.IndexOf(PackNames(packsMenuIndex(0)))
If idx < EnabledPackNames.Count - 1 Then
Dim tempString As String = EnabledPackNames(idx + 1)
EnabledPackNames(idx + 1) = EnabledPackNames(idx)
EnabledPackNames(idx) = tempString
GetPacks(True)
End If
End If
End If
End Sub
Private Sub PackEnabledToggle(ByVal c As ToggleButton)
If PackNames.Count > 0 Then
If EnabledPackNames.Contains(PackNames(packsMenuIndex(0))) Then
isSelectedEnabled = False
c.Toggled = False
ButtonToggle(PackNames(packsMenuIndex(0)))
Else
isSelectedEnabled = True
c.Toggled = True
ButtonToggle(PackNames(packsMenuIndex(0)))
End If
Else
isSelectedEnabled = False
c.Toggled = False
End If
End Sub
Private Sub ButtonToggle(ByVal PackName As String)
If PackNames.Count > 0 Then
If EnabledPackNames.Contains(PackName) = True Then
EnabledPackNames.Remove(PackName)
GetPacks(True)
Else
EnabledPackNames.Add(PackName)
GetPacks(True)
End If
Else
GetPacks(True)
End If
End Sub
Private Sub PacksApply()
If PackNames.Count > 0 Then
Core.GameOptions.ContentPackNames = EnabledPackNames.ToArray()
Core.GameOptions.SaveOptions()
FontManager.LoadFonts()
MusicManager.PlayNoMusic()
ContentPackManager.Clear()
GameModeManager.ForceWaterSpeed = -1
For Each s As String In Core.GameOptions.ContentPackNames
ContentPackManager.Load(GameController.GamePath & "\ContentPacks\" & s & "\exceptions.dat")
Next
Core.OffsetMaps.Clear()
Dim PressStart = Me.PreScreen.PreScreen
Me.PreScreen = New NewMainMenuScreen(PressStart)
Dim MainMenu As NewMainMenuScreen = CType(Me.PreScreen, NewMainMenuScreen)
SetScreen(New NewOptionScreen(Me.PreScreen, 4))
MainMenu._fadeInMain = 1.0F
MainMenu._fadeInOptions = 1.0F
MainMenu._screenOffsetTarget.Y = 0 - 180 - 32
MainMenu._screenOffset.Y = MainMenu._screenOffsetTarget.Y
MainMenu._screenOffsetTarget.X = 180
MainMenu._screenOffset.X = MainMenu._screenOffsetTarget.X
MainMenu._optionsOffsetTarget.X = -360
MainMenu._optionsOffset.X = MainMenu._optionsOffsetTarget.X
NewMainMenuScreen._selectedProfileTemp = 0
NewMainMenuScreen._selectedProfile = 3
NewMainMenuScreen._menuIndex = 2
SoundManager.PlaySound("save", False)
MusicManager.Play("title")
End If
End Sub
#End Region
Private Sub DrawBackground()
Dim mainBackgroundColor As Color = Color.White
If _closing Then
mainBackgroundColor = New Color(255, 255, 255, CInt(255 * _interfaceFade))
End If
Dim halfWidth As Integer = CInt(Core.windowSize.Width / 2)
Dim halfHeight As Integer = CInt(Core.windowSize.Height / 2)
Canvas.DrawRectangle(New Rectangle(halfWidth - 400, halfHeight - 232, 260, 32), New Color(ColorProvider.MainColor(False).R, ColorProvider.MainColor(False).G, ColorProvider.MainColor(False).B, mainBackgroundColor.A))
Canvas.DrawRectangle(New Rectangle(halfWidth - 140, halfHeight - 216, 16, 16), New Color(ColorProvider.MainColor(False).R, ColorProvider.MainColor(False).G, ColorProvider.MainColor(False).B, mainBackgroundColor.A))
SpriteBatch.Draw(_texture, New Rectangle(halfWidth - 140, halfHeight - 232, 16, 16), New Rectangle(80, 0, 16, 16), mainBackgroundColor)
SpriteBatch.Draw(_texture, New Rectangle(halfWidth - 124, halfHeight - 216, 16, 16), New Rectangle(80, 0, 16, 16), mainBackgroundColor)
SpriteBatch.DrawString(FontManager.ChatFont, Localization.GetString("option_screen_title", "Options"), New Vector2(halfWidth - 390, halfHeight - 228), mainBackgroundColor)
For y = 0 To CInt(_enrollY) Step 16
For x = 0 To 800 Step 16
SpriteBatch.Draw(_texture, New Rectangle(halfWidth - 400 + x, halfHeight - 200 + y, 16, 16), New Rectangle(64, 0, 4, 4), mainBackgroundColor)
Next
Next
Dim modRes As Integer = CInt(_enrollY) Mod 16
If modRes > 0 Then
For x = 0 To 800 Step 16
SpriteBatch.Draw(_texture, New Rectangle(halfWidth - 400 + x, CInt(_enrollY + (halfHeight - 200)), 16, modRes), New Rectangle(64, 0, 4, 4), mainBackgroundColor)
Next
End If
End Sub
Private Sub DrawCursor()
Dim t As Texture2D = TextureManager.GetTexture("GUI\Menus\General", New Rectangle(0, 0, 16, 16), "")
Core.SpriteBatch.Draw(t, New Rectangle(CInt(_cursorPosition.X) + 60, CInt(_cursorPosition.Y) - 28, 48, 48), New Rectangle(0, 0, 16, 16), New Color(255, 255, 255, CInt(255 * Me._interfaceFade)), 0.0F, Vector2.Zero, SpriteEffects.None, 0.0F)
End Sub
Private Sub DrawCurrentPage()
For Each C As Control In ControlList
C.Draw()
Next
End Sub
Private Sub DrawMessage()
End Sub
Public Overrides Sub Update()
Me.PreScreen.Update()
'New stuff
If _opening Then
InitializeControls()
_opening = False
End If
'Refresh button positions
If windowSize.Width <> _screenSize.Width Or windowSize.Height <> _screenSize.Height Then
_screenSize = New Size(CInt(windowSize.Width), CInt(windowSize.Height))
InitializeControls()
End If
If _closing Then
' When the interface is closing, only update the closing animation
' Once the interface is completely closed, set to the previous screen.
If _interfaceFade > 0F Then
_interfaceFade = MathHelper.Lerp(0, _interfaceFade, 0.8F)
If _interfaceFade < 0F Then
_interfaceFade = 0F
End If
End If
If _enrollY > 0 Then
_enrollY = MathHelper.Lerp(0, _enrollY, 0.8F)
If _enrollY <= 0 Then
_enrollY = 0
End If
End If
If _enrollY <= 2.0F Then
'TODO: Set the interface state to PlayerTemp.
SetScreen(PreScreen)
End If
Else
'Update intro animation:
Dim maxWindowHeight As Integer = 400
If _enrollY < maxWindowHeight Then
_enrollY = MathHelper.Lerp(maxWindowHeight, _enrollY, 0.8F)
If _enrollY >= maxWindowHeight Then
_enrollY = maxWindowHeight
End If
End If
If _interfaceFade < 1.0F Then
_interfaceFade = MathHelper.Lerp(1.0F, _interfaceFade, 0.95F)
If _interfaceFade > 1.0F Then
_interfaceFade = 1.0F
End If
End If
If _itemIntro < 1.0F Then
_itemIntro += 0.05F
If _itemIntro > 1.0F Then
_itemIntro = 1.0F
End If
End If
'Update the Dialogues:
ChooseBox.Update()
If ChooseBox.Showing = False Then
TextBox.Update()
End If
If _pageClosing = True Then
If _pageFade >= 0F Then
_pageFade -= 0.07F
If _pageFade <= 0F Then
_pageFade = 0F
_pageClosing = False
_pageOpening = True
ScreenIndex = _nextIndex
InitializeControls()
End If
End If
End If
If _pageOpening = True Then
If _pageFade <= 1.0F Then
_pageFade += 0.07F
If _pageFade >= 1.0F Then
_pageFade = 1.0F
_pageClosing = False
_pageOpening = False
End If
End If
End If
If _cursorDestPosition.X <> _cursorPosition.X Or _cursorDestPosition.Y <> _cursorPosition.Y Then
_cursorPosition.X = MathHelper.Lerp(_cursorDestPosition.X, _cursorPosition.X, 0.75F)
_cursorPosition.Y = MathHelper.Lerp(_cursorDestPosition.Y, _cursorPosition.Y, 0.75F)
If Math.Abs(_cursorDestPosition.X - _cursorPosition.X) < 0.1F Then
_cursorPosition.X = _cursorDestPosition.X
End If
If Math.Abs(_cursorDestPosition.Y - _cursorPosition.Y) < 0.1F Then
_cursorPosition.Y = _cursorDestPosition.Y
End If
End If
If Not _selectedScrollBar Then
If Controls.Up(True, True, False, True, True, True) = True Then
SetCursorPosition("up")
End If
If Controls.Down(True, True, False, True, True, True) = True Then
SetCursorPosition("down")
End If
If Controls.Right(True, True, False, True, True, True) = True Then
SetCursorPosition("right")
End If
If Controls.Left(True, True, False, True, True, True) = True Then
SetCursorPosition("left")
End If
If ScreenIndex <> 6 Then
If Controls.Left(False, False, True, False, False, False) = True Then
SetCursorPosition("previous")
End If
If Controls.Right(False, False, True, False, False, False) = True Then
SetCursorPosition("next")
End If
End If
If KeyBoardHandler.KeyPressed(KeyBindings.EscapeKey) Or KeyBoardHandler.KeyPressed(KeyBindings.BackKey1) Or KeyBoardHandler.KeyPressed(KeyBindings.BackKey2) Or MouseHandler.ButtonPressed(MouseHandler.MouseButtons.RightButton) Or ControllerHandler.ButtonPressed(Buttons.B) Then
If _pageClosing = False And _pageOpening = False Then
SoundManager.PlaySound("select")
If ScreenIndex = 0 Or _subMenu <> 0 Then
If ScreenIndex = 8 Then
SwitchToContentPacks()
Else
_closing = True
End If
Else
SwitchToMain()
End If
End If
End If
End If
Select Case ScreenIndex
Case 6
UpdateLanguageMenu()
Case 7
UpdatePacksMenu()
Case 8
UpdatePackInformationMenu()
End Select
For i = 0 To ControlList.Count
If i <= ControlList.Count - 1 Then
ControlList(i).Update(Me)
End If
Next
End If
End Sub
Private Sub SetCursorPosition(ByVal direction As String)
Dim ScrollControl As Control = Nothing
Dim pos = GetButtonPosition(direction)
Dim cPosition As Vector2 = New Vector2(pos.X, pos.Y)
'Dim cPosition As Vector2 = New Vector2(pos.X + 180, pos.Y - 42)
For Each control As Control In ControlList
If control._position = New Vector2(pos.X, pos.Y) Then
If control.ControlType = "ScrollBar" Then
ScrollControl = control
Exit For
End If
End If
Next
If ScrollControl IsNot Nothing Then
_cursorDestPosition = New Vector2(cPosition.X + 332, cPosition.Y)
Else
_cursorDestPosition = cPosition
End If
End Sub
Private Function GetButtonPosition(ByVal direction As String) As Vector2
Dim EligibleControls As New List(Of Control)
Dim currentControl As Control = Nothing
For Each control As Control In ControlList
If control.ControlType = "ScrollBar" Then
If control._position.Y = _cursorDestPosition.Y Then
currentControl = control
Exit For
End If
Else
If control._position = _cursorDestPosition Then
currentControl = control
Exit For
End If
End If
Next
For Each control As Control In ControlList
Dim R2 As Vector2 = control._position
Dim R1 As Vector2 = currentControl._position
If R1 = R2 Then
Continue For
End If
Select Case direction
Case "up"
If ScreenIndex = 0 Then
Select Case currentControl.ID
Case 4
If control.ID = 1 Then
EligibleControls.Add(control)
End If
Case 5
If control.ID = 3 Then
EligibleControls.Add(control)
End If
Case 6, 7
If control.ID = 4 Then
EligibleControls.Add(control)
End If
Case 8
If control.ID = 5 Then
EligibleControls.Add(control)
End If
End Select
Else
If ScreenIndex = 7 Then
If currentControl.ID <= 4 Then
If control.ID = currentControl.ID - 1 Then
EligibleControls.Add(control)
End If
End If
ElseIf ScreenIndex = 5 Then
If currentControl.ID > 3 Then
If control.ID = 3 Then
EligibleControls.Add(control)
End If
ElseIf control.ID = currentControl.ID - 1 Then
EligibleControls.Add(control)
End If
ElseIf Math.Abs(R2.X - R1.X) <= -(R2.Y - R1.Y) Then 'because Y axis points down
EligibleControls.Add(control)
End If
End If
Case "down"
If ScreenIndex = 0 Then
Select Case currentControl.ID
Case 1, 2
If control.ID = 4 Then
EligibleControls.Add(control)
End If
Case 3
If control.ID = 5 Then
EligibleControls.Add(control)
End If
Case 4
If control.ID = 6 Then
EligibleControls.Add(control)
End If
Case 5
If control.ID = 8 Then
EligibleControls.Add(control)
End If
End Select
ElseIf ScreenIndex = 5 Then
If currentControl.ID < 4 Then
If control.ID = currentControl.ID + 1 Then
EligibleControls.Add(control)
End If
End If
ElseIf Math.Abs(R2.X - R1.X) <= -(R1.Y - R2.Y) Then 'because Y axis points down
EligibleControls.Add(control)
End If
Case "right"
If ScreenIndex = 7 Then
If currentControl.ID = 5 And control.ID = 6 Then
EligibleControls.Add(control)
ElseIf currentControl.ID = 6 And control.ID = 4 Then
EligibleControls.Add(control)
End If
ElseIf control.ID = currentControl.ID + 1 Then
EligibleControls.Add(control)
End If
Case "left"
If ScreenIndex = 7 Then
If currentControl.ID <= 4 And control.ID = 6 Then
EligibleControls.Add(control)
ElseIf currentControl.ID = 6 And control.ID = 5 Then
EligibleControls.Add(control)
End If
ElseIf control.ID = currentControl.ID - 1 Then
EligibleControls.Add(control)
End If
Case "next"
If ScreenIndex = 7 And currentControl.ID < 4 Then
If control.ID = currentControl.ID + 1 Then
EligibleControls.Add(control)
End If
ElseIf ScreenIndex <> 7 Then
If control.ID = currentControl.ID + 1 Then
EligibleControls.Add(control)
End If
End If
Case "previous"
If ScreenIndex = 7 And currentControl.ID <= 4 Then
If control.ID = currentControl.ID - 1 Then
EligibleControls.Add(control)
End If
ElseIf ScreenIndex <> 7 Then
If control.ID = currentControl.ID - 1 Then
EligibleControls.Add(control)
End If
End If
End Select
Next
Dim NextPosition As New Vector2(currentControl._position.X, currentControl._position.Y)
Dim cDistance As Double = 99999D
For Each control As Control In EligibleControls
Dim R2 As Vector2 = control._position
Dim R1 As Vector2 = currentControl._position
Dim DeltaR As Vector2 = R2 - R1
Dim Distance As Double = DeltaR.Length
If Distance < cDistance Then
NextPosition = control._position
cDistance = Distance
End If
Next
Return NextPosition
End Function
Private Sub InitializeControls()
Me.ControlList.Clear()
Me._selectedScrollBar = False
Dim halfWidth As Integer = CInt(Core.windowSize.Width / 2)
Dim halfHeight As Integer = CInt(Core.windowSize.Height / 2)
Dim Delta_X As Integer = halfWidth - 400
Dim Delta_Y As Integer = halfHeight - 200
Select Case ScreenIndex
Case 0 ' Main Options menu.
Me.ControlList.Add(New CommandButton(New Vector2(Delta_X + 90, Delta_Y + 80), 1, 64, Localization.GetString("option_screen_game", "Game"), AddressOf SwitchToGame, 1))
Me.ControlList.Add(New CommandButton(New Vector2(Delta_X + 310, Delta_Y + 80), 1, 64, Localization.GetString("option_screen_graphics", "Graphics"), AddressOf SwitchToGraphics, 2))
Me.ControlList.Add(New CommandButton(New Vector2(Delta_X + 530, Delta_Y + 80), 1, 64, Localization.GetString("option_screen_battle", "Battle"), AddressOf SwitchToBattle, 3))
Me.ControlList.Add(New CommandButton(New Vector2(Delta_X + 200, Delta_Y + 168), 1, 64, Localization.GetString("option_screen_controls", "Controls"), AddressOf SwitchToControls, 4))
Me.ControlList.Add(New CommandButton(New Vector2(Delta_X + 420, Delta_Y + 168), 1, 64, Localization.GetString("option_screen_audio", "Audio"), AddressOf SwitchToAudio, 5))
Me.ControlList.Add(New CommandButton(New Vector2(Delta_X + 90 + 24, Delta_Y + 336), 1, 48, Localization.GetString("global_apply", "Apply"), AddressOf Apply, 6))
Me.ControlList.Add(New CommandButton(New Vector2(Delta_X + 286 + 24, Delta_Y + 336), 2, 48, Localization.GetString("option_screen_resetoptions", "Reset Options"), AddressOf Reset, 7))
Me.ControlList.Add(New CommandButton(New Vector2(Delta_X + 530 + 24, Delta_Y + 336), 1, 48, Localization.GetString("global_close", "Close"), AddressOf Close, 8))
Case 1 ' "Game" from the Options menu.
Me.ControlList.Add(New ScrollBar(New Vector2(Delta_X + 100, Delta_Y + 60), 400, Localization.GetString("option_screen_game_textspeed", "Text Speed"), Me.TextSpeed, 1, 3, AddressOf ChangeTextspeed, 1))
If CBool(GameModeManager.GetGameRuleValue("LockDifficulty", "0")) = False Then
Dim d As New Dictionary(Of Integer, String)
d.Add(0, Localization.GetString("option_screen_game_difficulty_easy", "Easy"))
d.Add(1, Localization.GetString("option_screen_game_difficulty_hard", "Hard"))
d.Add(2, Localization.GetString("option_screen_game_difficulty_superhard", "Super Hard"))
Me.ControlList.Add(New ScrollBar(New Vector2(Delta_X + 100, Delta_Y + 120), 400, Localization.GetString("option_screen_game_difficulty", "Difficulty"), Me.Difficulty, 0, 2, AddressOf ChangeDifficulty, d, 2))
End If
Dim s As New Dictionary(Of Integer, String)
s.Add(0, Localization.GetString("option_screen_game_interfacescale_automatic", "Automatic"))
s.Add(1, "0.5x")
s.Add(2, "1x")
s.Add(3, "2x")
Me.ControlList.Add(New ScrollBar(New Vector2(Delta_X + 100, Delta_Y + 180), 400, Localization.GetString("option_screen_game_interfacescale", "Interface Scale"), Me.InterfaceScale, 0, 3, AddressOf ChangeInterfaceScale, s, 3))
Me.ControlList.Add(New ToggleButton(New Vector2(Delta_X + 100, Delta_Y + 240), 3, 64, Localization.GetString("option_screen_game_viewbobbing", "View Bobbing"), Me.ViewBobbing, AddressOf ToggleBobbing, {Localization.GetString("global_off", "Off"), Localization.GetString("global_on", "On")}.ToList(), 4))
Me.ControlList.Add(New CommandButton(New Vector2(Delta_X + 530 + 24, Delta_Y + 336), 1, 48, Localization.GetString("global_back", "Back"), AddressOf SwitchToMain, 5))
Case 2 ' "Graphics" from the Options menu.
Me.ControlList.Add(New ScrollBar(New Vector2(Delta_X + 100, Delta_Y + 40), 400, Localization.GetString("option_screen_graphics_fov", "Field of View"), CInt(Me.FOV), 45, 120, AddressOf ChangeFOV, 1))
Dim d As New Dictionary(Of Integer, String)
d.Add(0, Localization.GetString("option_screen_graphics_renderdistance_tiny", "Tiny"))
d.Add(1, Localization.GetString("option_screen_graphics_renderdistance_small", "Small"))
d.Add(2, Localization.GetString("option_screen_graphics_renderdistance_normal", "Normal"))
d.Add(3, Localization.GetString("option_screen_graphics_renderdistance_far", "Far"))
d.Add(4, Localization.GetString("option_screen_graphics_renderdistance_extreme", "Extreme"))
Me.ControlList.Add(New ScrollBar(New Vector2(Delta_X + 100, Delta_Y + 100), 400, Localization.GetString("option_screen_graphics_renderdistance", "Render Distance"), Me.RenderDistance, 0, 4, AddressOf ChangeRenderDistance, d, 2))
Dim d1 As New Dictionary(Of Integer, String)
d1.Add(0, "Off")
Me.ControlList.Add(New ScrollBar(New Vector2(Delta_X + 100, Delta_Y + 160), 400, Localization.GetString("option_screen_graphics_offset_mapquality", "Offset Map Quality"), Me.LoadOffsetMaps, 0, 100, AddressOf ChangeOffsetMaps, d1, 3))
Me.ControlList.Add(New ToggleButton(New Vector2(Delta_X + 100, Delta_Y + 220), 3, 64, Localization.GetString("option_screen_graphics_graphics", "Graphics"), CBool(Me.GraphicStyle), AddressOf ToggleGraphicsStyle, {Localization.GetString("option_screen_graphics_graphics_fast", "Fast"), Localization.GetString("option_screen_graphics_graphics_fancy", "Fancy")}.ToList(), 4))
Me.ControlList.Add(New ToggleButton(New Vector2(Delta_X + 100, Delta_Y + 300), 3, 64, Localization.GetString("option_screen_graphics_multisampling", "Multi Sampling"), Me.PreferMultiSampling, AddressOf ToggleMultiSampling, {"Off", "On"}.ToList(), 5))
Me.ControlList.Add(New CommandButton(New Vector2(Delta_X + 530 + 24, Delta_Y + 336), 1, 48, Localization.GetString("global_back", "Back"), AddressOf SwitchToMain, 6))
Case 3 ' "Battle" from the Options menu.
Me.ControlList.Add(New ToggleButton(New Vector2(Delta_X + 100 + 20, Delta_Y + 100), 2, 64, Localization.GetString("option_screen_battle_3dmodels", "3D Models"), CBool(ShowModels), AddressOf ToggleShowModels, {Localization.GetString("global_off", "Off"), Localization.GetString("global_on", "On")}.ToList(), 1))
Me.ControlList.Add(New ToggleButton(New Vector2(Delta_X + 400 + 20, Delta_Y + 100), 2, 64, Localization.GetString("option_screen_battle_animations", "Animations"), CBool(Me.ShowBattleAnimations), AddressOf ToggleAnimations, {Localization.GetString("global_off", "Off"), Localization.GetString("global_on", "On")}.ToList(), 2))
Me.ControlList.Add(New ToggleButton(New Vector2(Delta_X + 100 + 20, Delta_Y + 200), 2, 64, Localization.GetString("option_screen_battle_battlestyle", "Battle Style"), CBool(Me.BattleStyle), AddressOf ToggleBattleStyle, {Localization.GetString("option_screen_battle_battlestyle_shift", "Shift"), Localization.GetString("option_screen_battle_battlestyle_set", "Set")}.ToList(), 3))
Me.ControlList.Add(New CommandButton(New Vector2(Delta_X + 530 + 24, Delta_Y + 336), 1, 48, Localization.GetString("global_back", "Back"), AddressOf SwitchToMain, 4))
Case 4 ' "Controls" from the Options menu.
If PreScreen.Identification = Identifications.MainMenuScreen Then
Me.ControlList.Add(New ToggleButton(New Vector2(Delta_X + 100, Delta_Y + 100), 5, 64, Localization.GetString("option_screen_controls_xboxgamepad", "Xbox Gamepad"), Me.GamePadEnabled, AddressOf ToggleXBOX360Controller, {"Disabled", "Enabled"}.ToList(), 1))
Me.ControlList.Add(New CommandButton(New Vector2(Delta_X + 100, Delta_Y + 200), 3, 64, Localization.GetString("option_screen_controls_resetkeybindings", "Reset Key Bindings"), AddressOf ResetKeyBindings, 2))
Me.ControlList.Add(New CommandButton(New Vector2(Delta_X + 90 + 24, Delta_Y + 336), 1, 48, Localization.GetString("global_apply", "Apply"), AddressOf ControlsApply, 3))
Me.ControlList.Add(New CommandButton(New Vector2(Delta_X + 530 + 24, Delta_Y + 336), 1, 48, Localization.GetString("global_back", "Back"), AddressOf Close, 4))
Else
Dim d As New Dictionary(Of Integer, String)
d.Add(1, Localization.GetString("option_screen_controls_cameraspeed_slow", "...Slow..."))
d.Add(12, Localization.GetString("option_screen_controls_cameraspeed_medium", "Standard"))
d.Add(38, Localization.GetString("option_screen_controls_cameraspeed_fast", "Super fast!"))
d.Add(50, Localization.GetString("option_screen_controls_cameraspeed_fastest", "SPEED OF LIGHT!"))
Me.ControlList.Add(New ScrollBar(New Vector2(Delta_X + 100, Delta_Y + 60), 400, Localization.GetString("option_screen_controls_cameraspeed", "Camera Speed"), Me.CameraSpeed, 1, 50, AddressOf ChangeCameraSpeed, d, 1))
Me.ControlList.Add(New ToggleButton(New Vector2(Delta_X + 100, Delta_Y + 120), 5, 64, Localization.GetString("option_screen_controls_xboxgamepad", "Xbox Gamepad"), Me.GamePadEnabled, AddressOf ToggleXBOX360Controller, {"Disabled", "Enabled"}.ToList(), 2))
Me.ControlList.Add(New ToggleButton(New Vector2(Delta_X + 100, Delta_Y + 200), 5, 64, Localization.GetString("option_screen_controls_running", "Running"), Me.RunMode, AddressOf ToggleRunningToggle, {"Hold", "Toggle"}.ToList(), 3))
Me.ControlList.Add(New CommandButton(New Vector2(Delta_X + 100, Delta_Y + 280), 3, 64, Localization.GetString("option_screen_controls_resetkeybindings", "Reset Key Bindings"), AddressOf ResetKeyBindings, 4))
Me.ControlList.Add(New CommandButton(New Vector2(Delta_X + 530 + 24, Delta_Y + 336), 1, 48, Localization.GetString("global_back", "Back"), AddressOf SwitchToMain, 5))
End If
Case 5 ' "Audio" from the Options menu.
Me.ControlList.Add(New ScrollBar(New Vector2(Delta_X + 100, Delta_Y + 60), 400, Localization.GetString("option_screen_audio_volume_music", "Music Volume"), Me.Music, 0, 100, AddressOf ChangeMusicVolume, 1))
Me.ControlList.Add(New ScrollBar(New Vector2(Delta_X + 100, Delta_Y + 120), 400, Localization.GetString("option_screen_audio_volume_sfx", "SoundFX Volume"), Me.Sound, 0, 100, AddressOf ChangeSoundVolume, 2))
Me.ControlList.Add(New ToggleButton(New Vector2(Delta_X + 100, Delta_Y + 200), 1, 64, Localization.GetString("option_screen_audio_muted", "Muted"), CBool(Me.Muted), AddressOf ToggleMute, {"No", "Yes"}.ToList(), 3))
If PreScreen.Identification = Identifications.MainMenuScreen Then
Me.ControlList.Add(New CommandButton(New Vector2(Delta_X + 90 + 24, Delta_Y + 336), 1, 48, Localization.GetString("global_apply", "Apply"), AddressOf AudioSave, 4))
Me.ControlList.Add(New CommandButton(New Vector2(Delta_X + 530 + 24, Delta_Y + 336), 1, 48, Localization.GetString("global_back", "Back"), AddressOf Close, 5))
Else
Me.ControlList.Add(New CommandButton(New Vector2(Delta_X + 530 + 24, Delta_Y + 336), 1, 48, Localization.GetString("global_back", "Back"), AddressOf SwitchToMain, 4))
End If
Case 6 ' "Language" from the Options menu.
Me.ControlList.Add(New CommandButton(New Vector2(Delta_X + 90 + 24, Delta_Y + 336), 1, 48, Localization.GetString("global_apply", "Apply"), AddressOf LanguageApply, 1))
Me.ControlList.Add(New CommandButton(New Vector2(Delta_X + 530 + 24, Delta_Y + 336), 1, 48, Localization.GetString("global_back", "Back"), AddressOf Close, 2))
Case 7 ' "ContentPacks" from the Options menu.
Me.ControlList.Add(New CommandButton(New Vector2(Delta_X + 604, Delta_Y + 64), 2, 48, Localization.GetString("option_screen_contentpacks_up"), AddressOf ButtonUp, 1))
Me.ControlList.Add(New CommandButton(New Vector2(Delta_X + 604, Delta_Y + 120), 2, 48, Localization.GetString("option_screen_contentpacks_down"), AddressOf ButtonDown, 2))
Me.ControlList.Add(New ToggleButton(New Vector2(Delta_X + 604, Delta_Y + 176), 2, 48, "", isSelectedEnabled, AddressOf PackEnabledToggle, {Localization.GetString("global_enable"), Localization.GetString("global_disable")}.ToList(), 3))
Me.ControlList.Add(New CommandButton(New Vector2(Delta_X + 604, Delta_Y + 232), 2, 48, Localization.GetString("option_screen_contentpacks_information"), AddressOf SwitchToPackInformation, 4))
Me.ControlList.Add(New CommandButton(New Vector2(Delta_X + 90 + 24, Delta_Y + 336), 1, 48, Localization.GetString("global_apply", "Apply"), AddressOf PacksApply, 5))
Me.ControlList.Add(New CommandButton(New Vector2(Delta_X + 310 + 24, Delta_Y + 336), 1, 48, Localization.GetString("global_back", "Back"), AddressOf Close, 6))
Case 8 ' "Information" from the ContentPacks menu.
Me.ControlList.Add(New ToggleButton(New Vector2(Delta_X + 90 + 24, Delta_Y + 336), 2, 48, Localization.GetString("global_enabled"), isSelectedEnabled, AddressOf PackEnabledToggle, {Localization.GetString("global_no"), Localization.GetString("global_yes")}.ToList(), 1))
Me.ControlList.Add(New CommandButton(New Vector2(Delta_X + 530 + 24, Delta_Y + 336), 1, 48, Localization.GetString("global_back", "Back"), AddressOf SwitchToContentPacks, 2))
End Select
If ScreenIndex <> 7 Then
If ControlList(0).ControlType = "ScrollBar" Then
_cursorDestPosition = New Vector2(ControlList(0)._position.X + 332, ControlList(0)._position.Y)
Else
_cursorDestPosition = ControlList(0)._position
End If
Else
If ControlList(0).ControlType = "ScrollBar" Then
_cursorDestPosition = New Vector2(ControlList(4)._position.X + 332, ControlList(4)._position.Y)
Else
_cursorDestPosition = ControlList(4)._position
End If
End If
End Sub
Private Sub Apply()
Save()
Close()
End Sub
Private Sub Close()
If PreScreen.Identification = Identifications.MainMenuScreen Then
If currentLanguage <> TempLanguage Then
Localization.Load(TempLanguage)
End If
If MusicManager.MasterVolume * 100 <> Me.TempMusicVolume Then
MusicManager.MasterVolume = CSng(Me.TempMusicVolume / 100)
End If
If SoundManager.Volume * 100 <> Me.TempSoundVolume Then
SoundManager.Volume = CSng(Me.TempSoundVolume / 100)
End If
If MusicManager.Muted <> CBool(Me.TempMuted) Or SoundManager.Muted <> CBool(Me.TempMuted) Then
MusicManager.Muted = CBool(Me.TempMuted)
SoundManager.Muted = CBool(Me.TempMuted)
End If
End If
_closing = True
End Sub
Private Sub ControlsApply()
Core.GameOptions.GamePadEnabled = Me.GamePadEnabled
Core.GameOptions.SaveOptions()
SoundManager.PlaySound("save")
_closing = True
End Sub
Private Sub Reset()
Me.FOV = 45.0F
Me.TextSpeed = 2
Me.CameraSpeed = 12
Me.Music = 50
Me.Sound = 50
Me.RenderDistance = 2
Me.GraphicStyle = 1
Me.InterfaceScale = 0
Me.ShowBattleAnimations = 1
Me.DiagonalMovement = False
Me.Difficulty = 0
Me.BattleStyle = 1
Me.LoadOffsetMaps = 100
Me.ViewBobbing = True
Me.ShowModels = 1
Me.Muted = 0
Me.GamePadEnabled = True
Me.PreferMultiSampling = True
MusicManager.Muted = CBool(Me.Muted)
SoundManager.Muted = CBool(Me.Muted)
End Sub
Private Sub Save()
MusicManager.MasterVolume = CSng(Me.Music / 100)
SoundManager.Volume = CSng(Me.Sound / 100)
MusicManager.Muted = CBool(Me.Muted)
SoundManager.Muted = CBool(Me.Muted)
Core.GameOptions.RenderDistance = Me.RenderDistance
Core.GameOptions.GraphicStyle = Me.GraphicStyle
Core.GameOptions.InterfaceScale = Me.InterfaceScale
If PreScreen.Identification <> Identifications.MainMenuScreen Then
Camera.CreateNewProjection(Me.FOV)
TextBox.TextSpeed = Me.TextSpeed
Camera.RotationSpeed = CSng(Me.CameraSpeed / 10000)
Screen.Level.World.Initialize(Screen.Level.EnvironmentType, Screen.Level.WeatherType)
Core.Player.RunMode = Me.RunMode
Me.PreScreen.Update()
End If
Core.Player.ShowBattleAnimations = Me.ShowBattleAnimations
Core.Player.DiagonalMovement = Me.DiagonalMovement
Core.Player.DifficultyMode = Me.Difficulty
Core.Player.BattleStyle = Me.BattleStyle
Core.Player.ShowModelsInBattle = CBool(Me.ShowModels)
Core.GameOptions.GamePadEnabled = Me.GamePadEnabled
Core.GraphicsManager.PreferMultiSampling = Me.PreferMultiSampling
If LoadOffsetMaps = 0 Then
Core.GameOptions.LoadOffsetMaps = Me.LoadOffsetMaps
Else
Core.GameOptions.LoadOffsetMaps = 101 - Me.LoadOffsetMaps
End If
Core.GameOptions.ViewBobbing = Me.ViewBobbing
Core.GameOptions.SaveOptions()
SoundManager.PlaySound("save")
End Sub
Public Overrides Sub ToggledMute()
If ScreenIndex = 5 Then
Me.Muted = CInt(MusicManager.Muted)
InitializeControls()
End If
End Sub
#Region "ControlCommands"
#Region "Switch"
Private Sub SwitchToMain()
Me._nextIndex = 0
Me._pageClosing = True
End Sub
Private Sub SwitchToGame()
Me._nextIndex = 1
Me._pageClosing = True
End Sub
Private Sub SwitchToGraphics()
Me._nextIndex = 2
Me._pageClosing = True
End Sub
Private Sub SwitchToBattle()
Me._nextIndex = 3
Me._pageClosing = True
End Sub
Private Sub SwitchToControls()
Me._nextIndex = 4
If PreScreen.Identification = Identifications.MainMenuScreen Then
ScreenIndex = _nextIndex
InitializeControls()
Else
Me._pageClosing = True
End If
End Sub
Private Sub SwitchToAudio()
Me._nextIndex = 5
If PreScreen.Identification = Identifications.MainMenuScreen Then
ScreenIndex = _nextIndex
InitializeControls()
Else
Me._pageClosing = True
End If
End Sub
Private Sub SwitchToLanguage()
GetLanguages()
If Languages.Contains(currentLanguage) = True Then
languageMenuIndex(0) = Languages.IndexOf(currentLanguage)
TempLanguage = currentLanguage
End If
languageMenuIndex(1) = 0
languageMenuIndex(2) = 0
Me._nextIndex = 6
ScreenIndex = _nextIndex
InitializeControls()
End Sub
Private Sub SwitchToContentPacks()
If ScreenIndex <> 7 And ScreenIndex <> 8 Then
GetPacks()
packsMenuIndex(0) = 0
packsMenuIndex(1) = 0
packsMenuIndex(2) = 0
End If
Me._nextIndex = 7
If ScreenIndex = 8 Then
Me._pageClosing = True
Else
ScreenIndex = _nextIndex
End If
InitializeControls()
End Sub
Private Sub SwitchToPackInformation()
If PackNames.Count > 0 Then
Me._nextIndex = 8
Me._pageClosing = True
End If
ButtonPackInformation()
End Sub
#End Region
#Region "SettingsGraphics"
Private Sub ChangeFOV(ByVal c As ScrollBar)
Me.FOV = c.Value
End Sub
Private Sub ChangeRenderDistance(ByVal c As ScrollBar)
Me.RenderDistance = c.Value
End Sub
Private Sub ToggleGraphicsStyle(ByVal c As ToggleButton)
If c.Toggled = True Then
Me.GraphicStyle = 1
Else
Me.GraphicStyle = 0
End If
End Sub
Private Sub ChangeOffsetMaps(ByVal c As ScrollBar)
Me.LoadOffsetMaps = c.Value
End Sub
Private Sub ToggleMultiSampling(ByVal c As ToggleButton)
Me.PreferMultiSampling = Not Me.PreferMultiSampling
End Sub
#End Region
#Region "SettingsGame"
Private Sub ToggleBobbing(ByVal c As ToggleButton)
Me.ViewBobbing = Not Me.ViewBobbing
End Sub
Private Sub ChangeTextspeed(ByVal c As ScrollBar)
Me.TextSpeed = c.Value
End Sub
Private Sub ChangeDifficulty(ByVal c As ScrollBar)
Me.Difficulty = c.Value
End Sub
Private Sub ChangeInterfaceScale(ByVal c As ScrollBar)
Me.InterfaceScale = c.Value
End Sub
#End Region
#Region "SettingsBattle"
Private Sub ToggleShowModels(ByVal c As ToggleButton)
If Me.ShowModels = 0 Then
Me.ShowModels = 1
Else
Me.ShowModels = 0
End If
End Sub
Private Sub ToggleAnimations(ByVal c As ToggleButton)
If Me.ShowBattleAnimations <> 1 Then
Me.ShowBattleAnimations = 1
Else
Me.ShowBattleAnimations = 0
End If
End Sub
Private Sub ToggleBattleStyle(ByVal c As ToggleButton)
If Me.BattleStyle = 0 Then
Me.BattleStyle = 1
Else
Me.BattleStyle = 0
End If
End Sub
#End Region
#Region "SettingsControls"
Private Sub ToggleXBOX360Controller(ByVal c As ToggleButton)
Me.GamePadEnabled = Not Me.GamePadEnabled
End Sub
Private Sub ToggleRunningToggle(ByVal c As ToggleButton)
Me.RunMode = Not Me.RunMode
End Sub
Private Sub ChangeCameraSpeed(ByVal c As ScrollBar)
Me.CameraSpeed = c.Value
End Sub
Private Sub ResetKeyBindings(ByVal c As CommandButton)
KeyBindings.CreateKeySave(True)
KeyBindings.LoadKeys()
End Sub
#End Region
#Region "SettingsAudio"
Private Sub ChangeMusicVolume(ByVal c As ScrollBar)
Me.Music = c.Value
ApplyAudioChange()
End Sub
Private Sub ChangeSoundVolume(ByVal c As ScrollBar)
Me.Sound = c.Value
ApplyAudioChange()
End Sub
Private Sub ToggleMute(ByVal c As ToggleButton)
If Me.Muted = 0 Then
Me.Muted = 1
Else
Me.Muted = 0
End If
ApplyAudioChange()
End Sub
Private Sub ApplyAudioChange()
MusicManager.Muted = CBool(Me.Muted)
SoundManager.Muted = CBool(Me.Muted)
MusicManager.MasterVolume = CSng(Me.Music / 100)
SoundManager.Volume = CSng(Me.Sound / 100)
End Sub
Private Sub AudioSave()
MusicManager.MasterVolume = CSng(Me.Music / 100)
SoundManager.Volume = CSng(Me.Sound / 100)
MusicManager.Muted = CBool(Me.Muted)
SoundManager.Muted = CBool(Me.Muted)
Core.GameOptions.SaveOptions()
SoundManager.PlaySound("save")
_closing = True
End Sub
#End Region
#Region "SettingsLanguage"
Private Sub LanguageApply()
If currentLanguage <> Languages(languageMenuIndex(0)) Then
currentLanguage = Languages(languageMenuIndex(0))
End If
Localization.Load(currentLanguage)
Core.GameOptions.SaveOptions()
SoundManager.PlaySound("save")
_closing = True
End Sub
#End Region
#End Region
#Region "Controls"
MustInherit Class Control
Public Property ControlType As String
Public MustOverride Sub Draw()
Public MustOverride Sub Update(ByRef s As NewOptionScreen)
Public _position As Vector2 = New Vector2(0)
Public _size As Integer = 1
Public Property ID As Integer
Public Property Size As Integer
Get
Return Me._size
End Get
Set(value As Integer)
Me._size = value
End Set
End Property
Sub New()
End Sub
End Class
Class ToggleButton
Inherits Control
Private _buttonWidth As Integer = 1
Private _text As String = ""
Private _toggled As Boolean = False
Public Property Position As Vector2
Get
Return _position
End Get
Set(value As Vector2)
Me._position = value
End Set
End Property
Public Property ButtonWidth As Integer
Get
Return Me._buttonWidth
End Get
Set(value As Integer)
Me._buttonWidth = value
End Set
End Property
Public Property Text As String
Get
Return Me._text
End Get
Set(value As String)
Me._text = value
End Set
End Property
Public Property Toggled As Boolean
Get
Return Me._toggled
End Get
Set(value As Boolean)
Me._toggled = value
End Set
End Property
Public Delegate Sub OnToggle(ByVal T As ToggleButton)
Public OnToggleTrigger As OnToggle
Public Settings As New List(Of String)
Public Sub New(ByVal TriggerSub As OnToggle)
MyBase.New
Me.OnToggleTrigger = TriggerSub
End Sub
Public Sub New(ByVal Position As Vector2, ByVal ButtonWidth As Integer, ByVal Size As Integer, ByVal Text As String, ByVal Toggled As Boolean, ByVal TriggerSub As OnToggle, ID As Integer)
Me.New(Position, Size, ButtonWidth, Text, Toggled, TriggerSub, New List(Of String), ID)
End Sub
Public Sub New(ByVal Position As Vector2, ByVal ButtonWidth As Integer, ByVal Size As Integer, ByVal Text As String, ByVal Toggled As Boolean, ByVal TriggerSub As OnToggle, ByVal Settings As List(Of String), ID As Integer)
MyBase.New
Me._position = Position
Me._buttonWidth = ButtonWidth
Me.ControlType = "ToggleButton"
Me.Size = Size
Me._text = Text
Me._toggled = Toggled
Me.ID = ID
Me.OnToggleTrigger = TriggerSub
Me.Settings = Settings
End Sub
Public Overrides Sub Draw()
Dim s As NewOptionScreen = CType(CurrentScreen, NewOptionScreen)
Dim pos As Vector2 = Me.Position
Dim c As Color = New Color(255, 255, 255, CInt(255 * s._interfaceFade * s._pageFade))
Dim size As Integer = Me.Size
Dim ToggleDivider As String = ": "
If Me.Text = "" Then
ToggleDivider = ""
End If
Dim B As New Vector2
Dim t As String = Me.Text
Dim textColor As New Color
If Toggled Then
t &= ToggleDivider & Settings(1)
B.X = 16
B.Y = 32
textColor = (New Color(255, 255, 255, CInt(255 * s._interfaceFade * s._pageFade)))
Else
t &= ToggleDivider & Settings(0)
B.X = 16
B.Y = 16
textColor = (New Color(0, 0, 0, CInt(255 * s._interfaceFade * s._pageFade)))
End If
Core.SpriteBatch.Draw(s._menuTexture, New Rectangle(CInt(pos.X), CInt(pos.Y), size, size), New Rectangle(CInt(B.X), CInt(B.Y), 16, 16), c)
Core.SpriteBatch.Draw(s._menuTexture, New Rectangle(CInt(pos.X) + size, CInt(pos.Y), size * ButtonWidth, size), New Rectangle(CInt(B.X) + 16, CInt(B.Y), 16, 16), c)
Core.SpriteBatch.Draw(s._menuTexture, New Rectangle(CInt(pos.X) + size * (ButtonWidth + 1), CInt(pos.Y), size, size), New Rectangle(CInt(B.X), CInt(B.Y), 16, 16), c, 0.0F, Vector2.Zero, SpriteEffects.FlipHorizontally, 0.0F)
Dim fontWidth As Integer = CInt(FontManager.MainFont.MeasureString(t).X * 1.0)
Core.SpriteBatch.DrawString(FontManager.MainFont, t, New Vector2(CInt((pos.X + (size * (2 + ButtonWidth) - fontWidth) * 0.5F)), CInt(pos.Y) + CInt(16 * size / 64)), textColor, 0.0F, Vector2.Zero, 1.0F, SpriteEffects.None, 0.0F)
End Sub
Public Overrides Sub Update(ByRef s As NewOptionScreen)
If ScreenIndex = 7 And Me.ID = 3 Then
If isSelectedEnabled = False Then
Me.Toggled = False
Else
Me.Toggled = True
End If
ElseIf ScreenIndex = 8 Then
If isSelectedEnabled = False Then
Me.Toggled = False
Else
Me.Toggled = True
End If
End If
Dim r As New Rectangle(CInt(_position.X), CInt(_position.Y), (2 + ButtonWidth) * Size, Size)
If r.Contains(MouseHandler.MousePosition) = True Then
If P3D.Controls.Accept(True, False, False) = True Then
Me._toggled = Not Me._toggled
OnToggleTrigger(Me)
SoundManager.PlaySound("select")
End If
End If
If Controls.Accept(False, True, True) Then
If Position = s._cursorDestPosition Then
Me._toggled = Not Me._toggled
OnToggleTrigger(Me)
SoundManager.PlaySound("select")
End If
End If
End Sub
End Class
Class CommandButton
Inherits Control
Private _buttonWidth As Integer = 1
Private _text As String = ""
Private TextureY As Integer
Public Property Position As Vector2
Get
Return _position
End Get
Set(value As Vector2)
Me._position = value
End Set
End Property
Public Property ButtonWidth As Integer
Get
Return Me._buttonWidth
End Get
Set(value As Integer)
Me._buttonWidth = value
End Set
End Property
Public Property Text As String
Get
Return Me._text
End Get
Set(value As String)
Me._text = value
End Set
End Property
Public Delegate Sub OnClick(ByVal C As CommandButton)
Public OnClickTrigger As OnClick
Public Sub New(ByVal ClickSub As OnClick)
MyBase.New
Me.OnClickTrigger = ClickSub
End Sub
Public Sub New(ByVal Position As Vector2, ByVal ButtonWidth As Integer, ByVal Size As Integer, ByVal Text As String, ByVal ClickSub As OnClick, ByVal ID As Integer)
MyBase.New
Me._position = Position
Me._buttonWidth = ButtonWidth
Me.ControlType = "CommandButton"
Me.Size = Size
Me._text = Text
Me.ID = ID
Me.OnClickTrigger = ClickSub
TextureY = 16
End Sub
Public Overrides Sub Draw()
Dim s As NewOptionScreen = CType(CurrentScreen, NewOptionScreen)
Dim pos As Vector2 = Me.Position
Dim c As Color = New Color(255, 255, 255, CInt(255 * s._interfaceFade * s._pageFade))
Core.SpriteBatch.Draw(s._menuTexture, New Rectangle(CInt(pos.X), CInt(pos.Y), Size, Size), New Rectangle(16, TextureY, 16, 16), c)
Core.SpriteBatch.Draw(s._menuTexture, New Rectangle(CInt(pos.X) + Size, CInt(pos.Y), Size * ButtonWidth, Size), New Rectangle(32, TextureY, 16, 16), c)
Core.SpriteBatch.Draw(s._menuTexture, New Rectangle(CInt(pos.X) + Size * (ButtonWidth + 1), CInt(pos.Y), Size, Size), New Rectangle(16, TextureY, 16, 16), c, 0.0F, Vector2.Zero, SpriteEffects.FlipHorizontally, 0.0F)
Dim fontWidth As Integer = CInt(FontManager.MainFont.MeasureString(Text).X * 1.0)
Core.SpriteBatch.DrawString(FontManager.MainFont, Text, New Vector2(CInt((pos.X + (Size * (2 + ButtonWidth) - fontWidth) * 0.5F)), CInt(pos.Y) + CInt(16 * Size / 64)), New Color(0, 0, 0, CInt(255 * s._interfaceFade * s._pageFade)), 0.0F, Vector2.Zero, 1.0F, SpriteEffects.None, 0.0F)
End Sub
Public Overrides Sub Update(ByRef s As NewOptionScreen)
Dim r As New Rectangle(CInt(_position.X), CInt(_position.Y), (2 + ButtonWidth) * Size, Size)
Dim Click As Boolean = False
If s._pageClosing = False And s._pageOpening = False Then
If r.Contains(MouseHandler.MousePosition) = True Then
If P3D.Controls.Accept(True, False, False) = True Then
SoundManager.PlaySound("select")
Click = True
OnClickTrigger(Me)
End If
End If
If Click = True Then
TextureY = 32
End If
If MouseHandler.ButtonUp(MouseHandler.MouseButtons.LeftButton) Then
TextureY = 16
Click = False
End If
If Controls.Accept(False, True, True) = True Then
If Position = s._cursorDestPosition Then
SoundManager.PlaySound("select")
OnClickTrigger(Me)
End If
End If
If KeyBoardHandler.KeyDown(KeyBindings.EnterKey1) = True Or KeyBoardHandler.KeyDown(KeyBindings.EnterKey2) = True Or ControllerHandler.ButtonDown(Buttons.A) = True Then
If Position = s._cursorDestPosition Then
TextureY = 32
Else
TextureY = 16
End If
End If
Else
Click = False
End If
End Sub
End Class
Class ScrollBar
Inherits Control
Private _value As Integer = 0
Private _max As Integer = 0
Private _min As Integer = 0
Private _text As String = ""
Private _drawPercentage As Boolean = False
Public Property Position As Vector2
Get
Return _position
End Get
Set(value As Vector2)
Me._position = value
End Set
End Property
Public Property Value As Integer
Get
Return Me._value
End Get
Set(value As Integer)
Me._value = value
End Set
End Property
Public Property Max As Integer
Get
Return Me._max
End Get
Set(value As Integer)
Me._max = value
End Set
End Property
Public Property Min As Integer
Get
Return Me._min
End Get
Set(value As Integer)
Me._min = value
End Set
End Property
Public Property Text As String
Get
Return Me._text
End Get
Set(value As String)
Me._text = value
End Set
End Property
Public Property DrawPercentage As Boolean
Get
Return Me._drawPercentage
End Get
Set(value As Boolean)
Me._drawPercentage = value
End Set
End Property
Public Delegate Sub OnChange(ByVal S As ScrollBar)
Public OnChangeTrigger As OnChange
Public Settings As New Dictionary(Of Integer, String)
Dim Selected As Boolean = False
Dim Clicked As Boolean = False
Public Sub New(ByVal ChangeSub As OnChange)
MyBase.New
Me.OnChangeTrigger = ChangeSub
End Sub
Public Sub New(ByVal Position As Vector2, ByVal Size As Integer, ByVal Text As String, ByVal Value As Integer, ByVal Min As Integer, ByVal Max As Integer, ByVal ChangeSub As OnChange, ID As Integer)
Me.New(Position, Size, Text, Value, Min, Max, ChangeSub, New Dictionary(Of Integer, String), ID)
End Sub
Public Sub New(ByVal Position As Vector2, ByVal Size As Integer, ByVal Text As String, ByVal Value As Integer, ByVal Min As Integer, ByVal Max As Integer, ByVal ChangeSub As OnChange, ByVal Settings As Dictionary(Of Integer, String), ID As Integer)
MyBase.New
Me._position = Position
Me.Size = Size
Me._text = Text
Me._value = Value
Me._max = Max
Me._min = Min
Me.ControlType = "ScrollBar"
Me.Settings = Settings
Me.OnChangeTrigger = ChangeSub
Me.ID = ID
End Sub
Public Overrides Sub Draw()
Dim length As Integer = Size + 16
Dim height As Integer = 36
Dim s As NewOptionScreen = CType(CurrentScreen, NewOptionScreen)
Dim pos As Vector2 = Me.Position
Dim c As Color = New Color(255, 255, 255, CInt(255 * s._interfaceFade * s._pageFade))
Dim BarRectangle1 As Rectangle
Dim BarRectangle2 As Rectangle
Dim SliderRectangle As Rectangle
Dim TextColor As Color
If Selected OrElse Clicked Then
BarRectangle1 = New Rectangle(0, 60, 12, 12)
BarRectangle2 = New Rectangle(12, 60, 12, 12)
SliderRectangle = New Rectangle(6, 32, 6, 12)
TextColor = New Color(25, 67, 91, CInt(255 * s._interfaceFade * s._pageFade))
Else
BarRectangle1 = New Rectangle(0, 48, 12, 12)
BarRectangle2 = New Rectangle(12, 48, 12, 12)
SliderRectangle = New Rectangle(0, 32, 6, 12)
TextColor = New Color(0, 0, 0, CInt(255 * s._interfaceFade * s._pageFade))
End If
Core.SpriteBatch.Draw(s._menuTexture, New Rectangle(CInt(pos.X), CInt(pos.Y), height, height), BarRectangle1, c)
Core.SpriteBatch.Draw(s._menuTexture, New Rectangle(CInt(pos.X) + 36, CInt(pos.Y), length - 72, height), BarRectangle2, c)
Core.SpriteBatch.Draw(s._menuTexture, New Rectangle(CInt(pos.X) + length - 36, CInt(pos.Y), height, height), BarRectangle1, c, 0.0F, Vector2.Zero, SpriteEffects.FlipHorizontally, 0.0F)
Core.SpriteBatch.Draw(s._menuTexture, GetSliderBox, SliderRectangle, c)
Dim t As String = Text & ": "
If Settings.ContainsKey(Value) = True Then
t &= Settings(Value)
Else
If Me._drawPercentage = True Then
t &= CStr(Me._value / (Me._max - Me._min) * 100)
Else
t &= Me._value.ToString()
End If
End If
Core.SpriteBatch.DrawString(FontManager.MainFont, t, New Vector2(Me.Position.X + CSng((400 / 2) - (FontManager.MainFont.MeasureString(t).X / 2)), Me._position.Y + 6 - 32), TextColor)
End Sub
Public Overrides Sub Update(ByRef s As NewOptionScreen)
If MouseHandler.ButtonDown(MouseHandler.MouseButtons.LeftButton) Then
If GetSliderBox().Contains(MouseHandler.MousePosition.X, MouseHandler.MousePosition.Y) And Clicked = False Then
Clicked = True
Selected = False
s._selectedScrollBar = False
End If
If Clicked = True Then
Dim x As Double = MouseHandler.MousePosition.X - Me._position.X
If x < 0 Then
x = 0D
End If
If x > Me.Size + 16 Then
x = Me.Size + 16
End If
Me.Value = CInt(x * ((Me._max - Min) / 100) * (100 / Me._size)) + Min
Me.Value = Value.Clamp(Min, Max)
OnChangeTrigger(Me)
End If
Else
Clicked = False
If Selected Then
If Controls.Dismiss(False, True, True) OrElse Controls.Accept(False, True, True) Then
Selected = False
s._selectedScrollBar = False
ElseIf Controls.Left(True) Then
Me.Value = Me.Value - 1
Me.Value = Value.Clamp(Min, Max)
OnChangeTrigger(Me)
ElseIf Controls.Right(True) Then
Me.Value = Me.Value + 1
Me.Value = Value.Clamp(Min, Max)
OnChangeTrigger(Me)
End If
Else
If Controls.Accept(False, True, True) Then
If s._cursorDestPosition.Y = Me.Position.Y Then
Selected = True
s._selectedScrollBar = True
End If
End If
End If
End If
End Sub
Private Function GetSliderBox() As Rectangle
Dim x As Integer = CInt(((100 / (Me._max - Min)) * (Me._value - Min)) * (Size / 100))
If Me._value = Min Then
x = 0
Else
If x = 0 And _value > 0 Then
x = 1
End If
End If
Return New Rectangle(x + CInt(Me.Position.X), CInt(Me.Position.Y), 18, 36)
End Function
End Class
#End Region
End Class