P3D-Legacy/P3D/Screens/NewOptionScreen.vb

1834 lines
80 KiB
VB.net
Raw Normal View History

2017-10-15 21:12:47 +02:00
Public Class NewOptionScreen
Inherits Screen
Dim TextSpeed As Integer = 2
Dim CameraSpeed As Integer = 12
2017-10-15 21:12:47 +02:00
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
2017-10-15 21:12:47 +02:00
Dim DiagonalMovement As Boolean = True
Dim Difficulty As Integer = 0
2023-01-15 09:34:42 +01:00
Dim BattleStyle As Integer = 1
2021-09-21 17:45:29 +02:00
Dim LoadOffsetMaps As Integer = 1
2017-10-15 21:12:47 +02:00
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
2017-10-15 21:12:47 +02:00
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))
2017-10-15 21:12:47 +02:00
Private Property SelectPackNoiseDelay As Integer = 10
2021-09-21 17:45:29 +02:00
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
2021-09-21 17:45:29 +02:00
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
2017-10-15 21:12:47 +02:00
Dim savedOptions As Boolean = True
2021-09-21 17:45:29 +02:00
Public Shared ScreenIndex As Integer = 0
2017-10-15 21:12:47 +02:00
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
2021-09-21 17:45:29 +02:00
Public Sub New(ByVal currentScreen As Screen, Optional ByVal Submenu As Integer = 0)
2017-10-15 21:12:47 +02:00
'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
2021-09-21 17:45:29 +02:00
GetLanguages()
GetPacks()
If Camera Is Nothing Then
Camera = New OverworldCamera()
End If
2017-10-15 21:12:47 +02:00
SetFunctionality()
If Submenu > 0 AndAlso PreScreen.Identification = Identifications.MainMenuScreen Then
_subMenu = Submenu
Select Case _subMenu
2021-09-21 17:45:29 +02:00
Case 1
SwitchToLanguage()
Case 2
SwitchToAudio()
Case 3
SwitchToControls()
Case 4
SwitchToContentPacks()
End Select
Else
_subMenu = 0
ScreenIndex = 0
2021-09-21 17:45:29 +02:00
End If
2017-10-15 21:12:47 +02:00
End Sub
Private Sub SetFunctionality()
2021-09-21 17:45:29 +02:00
If PreScreen.Identification <> Identifications.MainMenuScreen Then
Camera = CType(Screen.Camera, OverworldCamera)
2021-09-21 17:45:29 +02:00
Me.FOV = Camera.FOV
Me.TextSpeed = TextBox.TextSpeed
Me.CameraSpeed = CInt(Camera.RotationSpeed * 10000)
2021-09-21 17:45:29 +02:00
Me.Difficulty = Core.Player.DifficultyMode
Me.RunMode = Core.Player.RunMode
2021-09-21 17:45:29 +02:00
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())
2017-10-15 21:12:47 +02:00
Me.Music = CInt(MusicManager.MasterVolume * 100)
Me.Sound = CInt(SoundManager.Volume * 100)
Me.RenderDistance = Core.GameOptions.RenderDistance
Me.GraphicStyle = Core.GameOptions.GraphicStyle
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()
2021-09-21 17:45:29 +02:00
If ScreenIndex = 6 Then
DrawLanguageMenu()
End If
If ScreenIndex = 7 Then
DrawPacksMenu()
End If
If ScreenIndex = 8 Then
DrawPackInformationMenu()
End If
2017-10-15 21:12:47 +02:00
DrawCurrentPage()
DrawCursor()
DrawMessage()
TextBox.Draw()
ChooseBox.Draw()
End Sub
2021-09-21 17:45:29 +02:00
#Region "LanguageMenu"
Private Sub DrawLanguageMenu()
For i = 0 To 3
Dim c As Color = New Color(255, 255, 255, CInt(255 * _interfaceFade * _pageFade))
2021-09-21 17:45:29 +02:00
If i + languageMenuIndex(2) = languageMenuIndex(0) Then
c = New Color(77, 147, 198, CInt(255 * _interfaceFade * _pageFade))
2021-09-21 17:45:29 +02:00
End If
Canvas.DrawRectangle(New Rectangle(CInt(windowSize.Width / 2 - 258), CInt(Core.windowSize.Height / 2 - 128 + i * 50), 480, 48), c, False)
2021-09-21 17:45:29 +02:00
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)
2021-09-21 17:45:29 +02:00
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)))
2021-09-21 17:45:29 +02:00
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)))
2021-09-21 17:45:29 +02:00
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
2021-09-21 17:45:29 +02:00
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))
2021-09-21 17:45:29 +02:00
If i + packsMenuIndex(2) = packsMenuIndex(0) Then
c = New Color(77, 147, 198, CInt(255 * _interfaceFade * _pageFade))
2021-09-21 17:45:29 +02:00
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)
2021-09-21 17:45:29 +02:00
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)
2021-09-21 17:45:29 +02:00
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))
2021-09-21 17:45:29 +02:00
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
2021-09-21 17:45:29 +02:00
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
2021-09-21 17:45:29 +02:00
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
2021-09-21 17:45:29 +02:00
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
2021-09-21 17:45:29 +02:00
End If
End If
If GameInstance.IsMouseVisible = True Then
For i = 0 To 3
2021-11-06 12:05:15 +01:00
If New Rectangle(CInt(windowSize.Width / 2 - 328), CInt(windowSize.Height / 2 - 128 + i * 50), 500, 48).Contains(MouseHandler.MousePosition) = True Then
2021-09-21 17:45:29 +02:00
If MouseHandler.ButtonPressed(MouseHandler.MouseButtons.LeftButton) = True Then
packsMenuIndex(0) = i + packsMenuIndex(2)
2021-11-06 12:05:15 +01:00
If SelectPackNoiseDelay = 0 Then
SoundManager.PlaySound("select", 0.0F, 0.0F, 0.5F, False)
SelectPackNoiseDelay = 10
End If
2021-09-21 17:45:29 +02:00
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
2021-09-21 17:45:29 +02:00
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
2022-05-06 22:45:13 +02:00
PInfoVersion = s(0).CropStringToWidth(FontManager.InGameFont, 540 - 16 - CInt(FontManager.InGameFont.MeasureString(Localization.GetString("option_screen_contentpacks_version")).X))
2021-09-21 17:45:29 +02:00
End If
If s.Length > 1 Then
2022-05-06 22:45:13 +02:00
PInfoAuthor = s(1).CropStringToWidth(FontManager.InGameFont, 540 - 16 - CInt(FontManager.InGameFont.MeasureString(Localization.GetString("option_screen_contentpacks_by")).X))
2021-09-21 17:45:29 +02:00
End If
If s.Length > 2 Then
PInfoDescription = s(2).CropStringToWidth(FontManager.InGameFont, 540)
2021-09-21 17:45:29 +02:00
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)
2021-09-21 17:45:29 +02:00
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)))
2021-09-21 17:45:29 +02:00
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)))
2021-09-21 17:45:29 +02:00
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
2021-09-21 17:45:29 +02:00
isSelectedEnabled = False
c.Toggled = False
ButtonToggle(PackNames(packsMenuIndex(0)))
2021-09-21 17:45:29 +02:00
Else
isSelectedEnabled = True
c.Toggled = True
ButtonToggle(PackNames(packsMenuIndex(0)))
2021-09-21 17:45:29 +02:00
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()
2021-09-21 17:45:29 +02:00
ContentPackManager.Clear()
Water.WaterSpeed = 8
2021-09-21 17:45:29 +02:00
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")
2021-09-21 17:45:29 +02:00
End If
End Sub
#End Region
2017-10-15 21:12:47 +02:00
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(84, 198, 216, mainBackgroundColor.A))
Canvas.DrawRectangle(New Rectangle(halfWidth - 140, halfHeight - 216, 16, 16), New Color(84, 198, 216, 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)
2017-10-15 21:12:47 +02:00
SpriteBatch.DrawString(FontManager.ChatFont, Localization.GetString("option_screen_title", "Options"), New Vector2(halfWidth - 390, halfHeight - 228), mainBackgroundColor)
2017-10-15 21:12:47 +02:00
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)
2017-10-15 21:12:47 +02:00
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)
2017-10-15 21:12:47 +02:00
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)
2017-10-15 21:12:47 +02:00
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()
2021-09-21 17:45:29 +02:00
Me.PreScreen.Update()
2017-10-15 21:12:47 +02:00
'New stuff
If _opening Then
InitializeControls()
2017-10-15 21:12:47 +02:00
_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
2017-10-15 21:12:47 +02:00
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()
2017-10-15 21:12:47 +02:00
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
2021-09-21 17:45:29 +02:00
If Controls.Right(True, True, False, True, True, True) = True Then
2017-10-15 21:12:47 +02:00
SetCursorPosition("right")
End If
2021-09-21 17:45:29 +02:00
If Controls.Left(True, True, False, True, True, True) = True Then
2017-10-15 21:12:47 +02:00
SetCursorPosition("left")
End If
If ScreenIndex <> 6 Then
2021-09-21 17:45:29 +02:00
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
2017-10-15 21:12:47 +02:00
2021-09-21 17:45:29 +02:00
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
2021-09-21 17:45:29 +02:00
Else
SwitchToMain()
End If
2017-10-15 21:12:47 +02:00
End If
End If
End If
2021-09-21 17:45:29 +02:00
Select Case ScreenIndex
Case 6
UpdateLanguageMenu()
Case 7
UpdatePacksMenu()
Case 8
UpdatePackInformationMenu()
End Select
2017-10-15 21:12:47 +02:00
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
2017-10-15 21:12:47 +02:00
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
cPosition.X += 332
End If
2017-10-15 21:12:47 +02:00
_cursorDestPosition = cPosition
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
2017-10-15 21:12:47 +02:00
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
2021-09-21 17:45:29 +02:00
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
2021-09-21 17:45:29 +02:00
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)
2021-09-21 17:45:29 +02:00
End If
2017-10-15 21:12:47 +02:00
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
2021-09-21 17:45:29 +02:00
End If
ElseIf Math.Abs(R2.X - R1.X) <= -(R1.Y - R2.Y) Then 'because Y axis points down
EligibleControls.Add(control)
2017-10-15 21:12:47 +02:00
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
2021-09-21 17:45:29 +02:00
EligibleControls.Add(control)
End If
ElseIf control.ID = currentControl.ID + 1 Then
EligibleControls.Add(control)
2017-10-15 21:12:47 +02:00
End If
Case "left"
If ScreenIndex = 7 Then
If currentControl.ID <= 4 And control.ID = 6 Then
2021-09-21 17:45:29 +02:00
EligibleControls.Add(control)
ElseIf currentControl.ID = 6 And control.ID = 5 Then
2021-09-21 17:45:29 +02:00
EligibleControls.Add(control)
End If
ElseIf control.ID = currentControl.ID - 1 Then
EligibleControls.Add(control)
2021-09-21 17:45:29 +02:00
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
2017-10-15 21:12:47 +02:00
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
2021-09-21 17:45:29 +02:00
Select Case ScreenIndex
2017-10-15 21:12:47 +02:00
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))
2017-10-15 21:12:47 +02:00
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))
2017-10-15 21:12:47 +02:00
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))
2017-10-15 21:12:47 +02:00
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"))
2017-10-15 21:12:47 +02:00
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))
2017-10-15 21:12:47 +02:00
End If
Me.ControlList.Add(New ToggleButton(New Vector2(Delta_X + 100, Delta_Y + 180), 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(), 3))
Me.ControlList.Add(New CommandButton(New Vector2(Delta_X + 530 + 24, Delta_Y + 327), 1, 48, Localization.GetString("global_back", "Back"), AddressOf SwitchToMain, 4))
2017-10-15 21:12:47 +02:00
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))
2017-10-15 21:12:47 +02:00
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))
2017-10-15 21:12:47 +02:00
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))
2017-10-15 21:12:47 +02:00
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))
2017-10-15 21:12:47 +02:00
Me.ControlList.Add(New CommandButton(New Vector2(Delta_X + 530 + 24, Delta_Y + 327), 1, 48, Localization.GetString("global_back", "Back"), AddressOf SwitchToMain, 6))
2017-10-15 21:12:47 +02:00
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))
2017-10-15 21:12:47 +02:00
Me.ControlList.Add(New CommandButton(New Vector2(Delta_X + 530 + 24, Delta_Y + 327), 1, 48, Localization.GetString("global_back", "Back"), AddressOf SwitchToMain, 4))
2017-10-15 21:12:47 +02:00
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 + 327), 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 + 327), 1, 48, Localization.GetString("global_back", "Back"), AddressOf SwitchToMain, 5))
End If
2021-09-21 17:45:29 +02:00
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 + 327), 1, 48, Localization.GetString("global_apply", "Apply"), AddressOf AudioSave, 4))
Me.ControlList.Add(New CommandButton(New Vector2(Delta_X + 530 + 24, Delta_Y + 327), 1, 48, Localization.GetString("global_back", "Back"), AddressOf Close, 5))
Else
Me.ControlList.Add(New CommandButton(New Vector2(Delta_X + 530 + 24, Delta_Y + 327), 1, 48, Localization.GetString("global_back", "Back"), AddressOf SwitchToMain, 4))
End If
2021-09-21 17:45:29 +02:00
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 + 327), 1, 48, Localization.GetString("global_back", "Back"), AddressOf Close, 2))
2021-09-21 17:45:29 +02:00
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))
2021-09-21 17:45:29 +02:00
Me.ControlList.Add(New CommandButton(New Vector2(Delta_X + 90 + 24, Delta_Y + 327), 1, 48, Localization.GetString("global_apply", "Apply"), AddressOf PacksApply, 5))
Me.ControlList.Add(New CommandButton(New Vector2(Delta_X + 310 + 24, Delta_Y + 327), 1, 48, Localization.GetString("global_back", "Back"), AddressOf Close, 6))
2021-09-21 17:45:29 +02:00
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))
2017-10-15 21:12:47 +02:00
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
2017-10-15 21:12:47 +02:00
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
2017-10-15 21:12:47 +02:00
_closing = True
End Sub
Private Sub ControlsApply()
Core.GameOptions.GamePadEnabled = Me.GamePadEnabled
Core.GameOptions.SaveOptions()
SoundManager.PlaySound("save")
_closing = True
End Sub
2017-10-15 21:12:47 +02:00
Private Sub Reset()
Me.FOV = 45.0F
Me.TextSpeed = 2
Me.CameraSpeed = 12
2017-10-15 21:12:47 +02:00
Me.Music = 50
Me.Sound = 50
Me.RenderDistance = 2
Me.GraphicStyle = 1
Me.ShowBattleAnimations = 1
2017-10-15 21:12:47 +02:00
Me.DiagonalMovement = False
Me.Difficulty = 0
Me.BattleStyle = 1
2021-09-21 17:45:29 +02:00
Me.LoadOffsetMaps = 100
2017-10-15 21:12:47 +02:00
Me.ViewBobbing = True
Me.ShowModels = 1
Me.Muted = 0
Me.GamePadEnabled = True
Me.PreferMultiSampling = True
2018-03-12 08:58:57 +01:00
MusicManager.Muted = CBool(Me.Muted)
SoundManager.Muted = CBool(Me.Muted)
2017-10-15 21:12:47 +02:00
End Sub
Private Sub Save()
MusicManager.MasterVolume = CSng(Me.Music / 100)
SoundManager.Volume = CSng(Me.Sound / 100)
MusicManager.Muted = CBool(Me.Muted)
2018-02-22 03:40:20 +01:00
SoundManager.Muted = CBool(Me.Muted)
2017-10-15 21:12:47 +02:00
Core.GameOptions.RenderDistance = Me.RenderDistance
Core.GameOptions.GraphicStyle = Me.GraphicStyle
2021-09-21 17:45:29 +02:00
If PreScreen.Identification <> Identifications.MainMenuScreen Then
Camera.CreateNewProjection(Me.FOV)
TextBox.TextSpeed = Me.TextSpeed
Camera.RotationSpeed = CSng(Me.CameraSpeed / 10000)
2021-09-21 17:45:29 +02:00
Screen.Level.World.Initialize(Screen.Level.EnvironmentType, Screen.Level.WeatherType)
Core.Player.RunMode = Me.RunMode
2021-09-21 17:45:29 +02:00
Me.PreScreen.Update()
End If
2017-10-15 21:12:47 +02:00
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()
2021-09-21 17:45:29 +02:00
If ScreenIndex = 5 Then
Fix audio engine & contentpacks (#35) * Replaced existing Gen 2 SFX with better sounding ones (no ugly reverb) Replaced MediaPlayer with NAudio(and NAudio.Vorbis) for playing music in order to fix random stopping issues. The game now directly loads .ogg files instead of the .wma/.xnb combination from before. ContentPacks are now able to replace Music and SFX again (I haven't added a menu yet for choosing ContentPacks). To make older GameModes work with current versions, you can add the GameMode property EnterType and set it to "1", this will make the game use the older 2D NewGameScreen. * Delete GameController.vb * Add gamecontroller.vb back * Fix sfx missing * Battleintro doodle now doesn't loop anymore (for no trainer) Changed the shutter sound (aka Large Door sound) to something more large door-y Made the enter sound slightly louder The enter sound now plays when going through any warp to or from an indoor map (including falling through holes) The flying sound effect is played earlier in the animation after selecting a location Changed played sound effect when using the Escape Rope to "teleport" instead of "destroy" The bump noise now also plays when bumping into something in first person Fixed small gap between the end of the intro song and the start of the main song Replaced some songs with better songs * Fixed some more intro issues * Forgot to change a thing * Fixed an error where the main music would play, ignoring the muted musicmanager. * fix indenting in musicmanager * The music player will now only start playback on a new song if the music player is not muted, fixed the end time calculation of the intro of a song after muting, Music can't be unmuted now as long as a sound effect plays that stops the music. * Fixed league restplace position, fixed sound effects sharing the volume slider of the music, sound effects are now also muted when pressing M, changed music on/off popup to audio on/off, removed bump delay in first person, added more control on whether played songs should be looping or not. * Fixed some more scripts that turn on thirdperson mode but don't check if it was on before or set it back to what it was before afterwards, also fixed a small error in creditsscreen.vb. * Fixed indenting error in musicmanager.vb, fixed an error of mine where the loopsong parameter would be seen as the playintro parameter. * Added more music commands, added quite some menu select noises, will add more later * More select sound effects! * Fix music not resuming after soundeffect * Trainer using item now plays the single_heal soundeffect * Pokémon cries now sound louder * Possibly fixing crash when playing Pokémon cry at volume higher than 0.71 * Added better quality Pokémon cries, made random overworld cries slightly less loud, added cries for 719 and 720. * Sound effects now sound louder * Revert "Added better quality Pokémon cries, made random overworld cries slightly less loud, added cries for 719 and 720." This reverts commit 8c9296ed1a82144d17f303a52c3f2e9e65a5bfea. * Fixed the cause of why the title screen music plays even when the game is muted * Tabs to spaces * Revert Co-authored-by: darkfire006 <blazer257@live.com> Co-authored-by: JappaWakkaP3D <66885565+JappaWakkaP3D@users.noreply.github.com> Co-authored-by: JappaWakkaP3D <jasper.speelman@outlook.com> Co-authored-by: Vitaly Mikhailov <personal@aragas.org>
2020-07-09 19:59:42 +02:00
Me.Muted = CInt(MusicManager.Muted)
2017-10-15 21:12:47 +02:00
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
2017-10-15 21:12:47 +02:00
End Sub
2021-09-21 17:45:29 +02:00
Private Sub SwitchToAudio()
2017-10-15 21:12:47 +02:00
Me._nextIndex = 5
If PreScreen.Identification = Identifications.MainMenuScreen Then
ScreenIndex = _nextIndex
InitializeControls()
Else
Me._pageClosing = True
End If
2017-10-15 21:12:47 +02:00
End Sub
2021-09-21 17:45:29 +02:00
Private Sub SwitchToLanguage()
GetLanguages()
If Languages.Contains(currentLanguage) = True Then
languageMenuIndex(0) = Languages.IndexOf(currentLanguage)
TempLanguage = currentLanguage
2021-09-21 17:45:29 +02:00
End If
languageMenuIndex(1) = 0
languageMenuIndex(2) = 0
2017-10-15 21:12:47 +02:00
Me._nextIndex = 6
ScreenIndex = _nextIndex
InitializeControls()
2017-10-15 21:12:47 +02:00
End Sub
2021-09-21 17:45:29 +02:00
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()
2021-09-21 17:45:29 +02:00
End Sub
Private Sub SwitchToPackInformation()
If PackNames.Count > 0 Then
Me._nextIndex = 8
Me._pageClosing = True
End If
2021-09-21 17:45:29 +02:00
ButtonPackInformation()
End Sub
2017-10-15 21:12:47 +02:00
#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
#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
2017-10-15 21:12:47 +02:00
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
2017-10-15 21:12:47 +02:00
Private Sub ChangeCameraSpeed(ByVal c As ScrollBar)
Me.CameraSpeed = c.Value
2017-10-15 21:12:47 +02:00
End Sub
Private Sub ResetKeyBindings(ByVal c As CommandButton)
KeyBindings.CreateKeySave(True)
KeyBindings.LoadKeys()
End Sub
#End Region
2021-09-21 17:45:29 +02:00
#Region "SettingsAudio"
2017-10-15 21:12:47 +02:00
Private Sub ChangeMusicVolume(ByVal c As ScrollBar)
Me.Music = c.Value
ApplyAudioChange()
2017-10-15 21:12:47 +02:00
End Sub
Private Sub ChangeSoundVolume(ByVal c As ScrollBar)
Me.Sound = c.Value
ApplyAudioChange()
2017-10-15 21:12:47 +02:00
End Sub
Private Sub ToggleMute(ByVal c As ToggleButton)
If Me.Muted = 0 Then
Me.Muted = 1
Else
Me.Muted = 0
End If
ApplyAudioChange()
2017-10-15 21:12:47 +02:00
End Sub
Private Sub ApplyAudioChange()
MusicManager.Muted = CBool(Me.Muted)
2018-02-22 03:40:20 +01:00
SoundManager.Muted = CBool(Me.Muted)
2017-10-15 21:12:47 +02:00
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
2017-10-15 21:12:47 +02:00
#End Region
2021-09-21 17:45:29 +02:00
#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
2021-09-21 17:45:29 +02:00
End Sub
#End Region
2017-10-15 21:12:47 +02:00
#End Region
#Region "Controls"
MustInherit Class Control
2021-09-21 17:45:29 +02:00
Public Property ControlType As String
2017-10-15 21:12:47 +02:00
Public MustOverride Sub Draw()
Public MustOverride Sub Update(ByRef s As NewOptionScreen)
Public _position As Vector2 = New Vector2(0)
Public _size As Integer = 1
2021-09-21 17:45:29 +02:00
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
2017-10-15 21:12:47 +02:00
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
2021-09-21 17:45:29 +02:00
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)
2017-10-15 21:12:47 +02:00
End Sub
2021-09-21 17:45:29 +02:00
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)
2017-10-15 21:12:47 +02:00
MyBase.New
Me._position = Position
Me._buttonWidth = ButtonWidth
2021-09-21 17:45:29 +02:00
Me.ControlType = "ToggleButton"
Me.Size = Size
2017-10-15 21:12:47 +02:00
Me._text = Text
Me._toggled = Toggled
2021-09-21 17:45:29 +02:00
Me.ID = ID
2017-10-15 21:12:47 +02:00
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
2017-10-15 21:12:47 +02:00
Dim B As New Vector2
Dim t As String = Me.Text
Dim textColor As New Color
If Toggled Then
t &= ToggleDivider & Settings(1)
2017-10-15 21:12:47 +02:00
B.X = 16
B.Y = 32
textColor = (New Color(255, 255, 255, CInt(255 * s._interfaceFade * s._pageFade)))
Else
t &= ToggleDivider & Settings(0)
2017-10-15 21:12:47 +02:00
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)
2021-09-21 17:45:29 +02:00
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)
2017-10-15 21:12:47 +02:00
End Sub
Public Overrides Sub Update(ByRef s As NewOptionScreen)
2021-09-21 17:45:29 +02:00
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
2017-10-15 21:12:47 +02:00
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
2017-10-15 21:12:47 +02:00
Me._toggled = Not Me._toggled
OnToggleTrigger(Me)
Fix audio engine & contentpacks (#35) * Replaced existing Gen 2 SFX with better sounding ones (no ugly reverb) Replaced MediaPlayer with NAudio(and NAudio.Vorbis) for playing music in order to fix random stopping issues. The game now directly loads .ogg files instead of the .wma/.xnb combination from before. ContentPacks are now able to replace Music and SFX again (I haven't added a menu yet for choosing ContentPacks). To make older GameModes work with current versions, you can add the GameMode property EnterType and set it to "1", this will make the game use the older 2D NewGameScreen. * Delete GameController.vb * Add gamecontroller.vb back * Fix sfx missing * Battleintro doodle now doesn't loop anymore (for no trainer) Changed the shutter sound (aka Large Door sound) to something more large door-y Made the enter sound slightly louder The enter sound now plays when going through any warp to or from an indoor map (including falling through holes) The flying sound effect is played earlier in the animation after selecting a location Changed played sound effect when using the Escape Rope to "teleport" instead of "destroy" The bump noise now also plays when bumping into something in first person Fixed small gap between the end of the intro song and the start of the main song Replaced some songs with better songs * Fixed some more intro issues * Forgot to change a thing * Fixed an error where the main music would play, ignoring the muted musicmanager. * fix indenting in musicmanager * The music player will now only start playback on a new song if the music player is not muted, fixed the end time calculation of the intro of a song after muting, Music can't be unmuted now as long as a sound effect plays that stops the music. * Fixed league restplace position, fixed sound effects sharing the volume slider of the music, sound effects are now also muted when pressing M, changed music on/off popup to audio on/off, removed bump delay in first person, added more control on whether played songs should be looping or not. * Fixed some more scripts that turn on thirdperson mode but don't check if it was on before or set it back to what it was before afterwards, also fixed a small error in creditsscreen.vb. * Fixed indenting error in musicmanager.vb, fixed an error of mine where the loopsong parameter would be seen as the playintro parameter. * Added more music commands, added quite some menu select noises, will add more later * More select sound effects! * Fix music not resuming after soundeffect * Trainer using item now plays the single_heal soundeffect * Pokémon cries now sound louder * Possibly fixing crash when playing Pokémon cry at volume higher than 0.71 * Added better quality Pokémon cries, made random overworld cries slightly less loud, added cries for 719 and 720. * Sound effects now sound louder * Revert "Added better quality Pokémon cries, made random overworld cries slightly less loud, added cries for 719 and 720." This reverts commit 8c9296ed1a82144d17f303a52c3f2e9e65a5bfea. * Fixed the cause of why the title screen music plays even when the game is muted * Tabs to spaces * Revert Co-authored-by: darkfire006 <blazer257@live.com> Co-authored-by: JappaWakkaP3D <66885565+JappaWakkaP3D@users.noreply.github.com> Co-authored-by: JappaWakkaP3D <jasper.speelman@outlook.com> Co-authored-by: Vitaly Mikhailov <personal@aragas.org>
2020-07-09 19:59:42 +02:00
SoundManager.PlaySound("select")
2017-10-15 21:12:47 +02:00
End If
End If
If Controls.Accept(False, True, True) Then
If Position = s._cursorDestPosition Then
Me._toggled = Not Me._toggled
OnToggleTrigger(Me)
Fix audio engine & contentpacks (#35) * Replaced existing Gen 2 SFX with better sounding ones (no ugly reverb) Replaced MediaPlayer with NAudio(and NAudio.Vorbis) for playing music in order to fix random stopping issues. The game now directly loads .ogg files instead of the .wma/.xnb combination from before. ContentPacks are now able to replace Music and SFX again (I haven't added a menu yet for choosing ContentPacks). To make older GameModes work with current versions, you can add the GameMode property EnterType and set it to "1", this will make the game use the older 2D NewGameScreen. * Delete GameController.vb * Add gamecontroller.vb back * Fix sfx missing * Battleintro doodle now doesn't loop anymore (for no trainer) Changed the shutter sound (aka Large Door sound) to something more large door-y Made the enter sound slightly louder The enter sound now plays when going through any warp to or from an indoor map (including falling through holes) The flying sound effect is played earlier in the animation after selecting a location Changed played sound effect when using the Escape Rope to "teleport" instead of "destroy" The bump noise now also plays when bumping into something in first person Fixed small gap between the end of the intro song and the start of the main song Replaced some songs with better songs * Fixed some more intro issues * Forgot to change a thing * Fixed an error where the main music would play, ignoring the muted musicmanager. * fix indenting in musicmanager * The music player will now only start playback on a new song if the music player is not muted, fixed the end time calculation of the intro of a song after muting, Music can't be unmuted now as long as a sound effect plays that stops the music. * Fixed league restplace position, fixed sound effects sharing the volume slider of the music, sound effects are now also muted when pressing M, changed music on/off popup to audio on/off, removed bump delay in first person, added more control on whether played songs should be looping or not. * Fixed some more scripts that turn on thirdperson mode but don't check if it was on before or set it back to what it was before afterwards, also fixed a small error in creditsscreen.vb. * Fixed indenting error in musicmanager.vb, fixed an error of mine where the loopsong parameter would be seen as the playintro parameter. * Added more music commands, added quite some menu select noises, will add more later * More select sound effects! * Fix music not resuming after soundeffect * Trainer using item now plays the single_heal soundeffect * Pokémon cries now sound louder * Possibly fixing crash when playing Pokémon cry at volume higher than 0.71 * Added better quality Pokémon cries, made random overworld cries slightly less loud, added cries for 719 and 720. * Sound effects now sound louder * Revert "Added better quality Pokémon cries, made random overworld cries slightly less loud, added cries for 719 and 720." This reverts commit 8c9296ed1a82144d17f303a52c3f2e9e65a5bfea. * Fixed the cause of why the title screen music plays even when the game is muted * Tabs to spaces * Revert Co-authored-by: darkfire006 <blazer257@live.com> Co-authored-by: JappaWakkaP3D <66885565+JappaWakkaP3D@users.noreply.github.com> Co-authored-by: JappaWakkaP3D <jasper.speelman@outlook.com> Co-authored-by: Vitaly Mikhailov <personal@aragas.org>
2020-07-09 19:59:42 +02:00
SoundManager.PlaySound("select")
2017-10-15 21:12:47 +02:00
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
2017-10-15 21:12:47 +02:00
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
2021-09-21 17:45:29 +02:00
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)
2017-10-15 21:12:47 +02:00
MyBase.New
Me._position = Position
Me._buttonWidth = ButtonWidth
2021-09-21 17:45:29 +02:00
Me.ControlType = "CommandButton"
Me.Size = Size
2017-10-15 21:12:47 +02:00
Me._text = Text
2021-09-21 17:45:29 +02:00
Me.ID = ID
2017-10-15 21:12:47 +02:00
Me.OnClickTrigger = ClickSub
TextureY = 16
2017-10-15 21:12:47 +02:00
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)
2017-10-15 21:12:47 +02:00
2021-09-21 17:45:29 +02:00
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)
2017-10-15 21:12:47 +02:00
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
2021-09-21 17:45:29 +02:00
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
2021-09-21 17:45:29 +02:00
OnClickTrigger(Me)
End If
2017-10-15 21:12:47 +02:00
End If
If Click = True Then
TextureY = 32
End If
If MouseHandler.ButtonUp(MouseHandler.MouseButtons.LeftButton) Then
TextureY = 16
Click = False
End If
2017-10-15 21:12:47 +02:00
If Controls.Accept(False, True, True) = True Then
2021-09-21 17:45:29 +02:00
If Position = s._cursorDestPosition Then
SoundManager.PlaySound("select")
OnClickTrigger(Me)
End If
2017-10-15 21:12:47 +02:00
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
2017-10-15 21:12:47 +02:00
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
2021-09-21 17:45:29 +02:00
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)
2017-10-15 21:12:47 +02:00
End Sub
2021-09-21 17:45:29 +02:00
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)
2017-10-15 21:12:47 +02:00
MyBase.New
Me._position = Position
Me.Size = Size
2017-10-15 21:12:47 +02:00
Me._text = Text
Me._value = Value
Me._max = Max
Me._min = Min
2021-09-21 17:45:29 +02:00
Me.ControlType = "ScrollBar"
2017-10-15 21:12:47 +02:00
Me.Settings = Settings
Me.OnChangeTrigger = ChangeSub
2021-09-21 17:45:29 +02:00
Me.ID = ID
2017-10-15 21:12:47 +02:00
End Sub
Public Overrides Sub Draw()
Dim length As Integer = Size + 16
2017-10-15 21:12:47 +02:00
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
2021-09-21 17:45:29 +02:00
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)
2017-10-15 21:12:47 +02:00
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
2021-09-21 17:45:29 +02:00
End If
Me.Value = CInt(x * ((Me._max - Min) / 100) * (100 / Me._size)) + Min
Me.Value = Value.Clamp(Min, Max)
2021-09-21 17:45:29 +02:00
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)
2017-10-15 21:12:47 +02:00
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
2017-10-15 21:12:47 +02:00
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))
2017-10-15 21:12:47 +02:00
If Me._value = Min Then
x = 0
Else
If x = 0 And _value > 0 Then
x = 1
End If
End If
2021-09-21 17:45:29 +02:00
Return New Rectangle(x + CInt(Me.Position.X), CInt(Me.Position.Y), 18, 36)
2017-10-15 21:12:47 +02:00
End Function
End Class
#End Region
End Class