Options Menu update 2

- Applying ContentPacks works perfectly now and plays the Save sound when done
- ScrollBars in the options menu work correctly again
This commit is contained in:
Jasper "JappaWakka" Speelman 2021-09-25 00:27:12 +02:00
parent 8263bbe390
commit b0ca5ab1d9
5 changed files with 50 additions and 42 deletions

View File

@ -15,6 +15,7 @@
Public MaxOffsetLevel As Integer = 0 Public MaxOffsetLevel As Integer = 0
Public UpdateDisabled As Boolean = False Public UpdateDisabled As Boolean = False
Public Extras As New List(Of String) Public Extras As New List(Of String)
Public ChangedPack As Boolean = False
Public Sub LoadOptions() Public Sub LoadOptions()
KeyBindings.CreateKeySave(False) KeyBindings.CreateKeySave(False)

View File

@ -407,6 +407,11 @@ Public Class OverworldScreen
c.ResetCursor() c.ResetCursor()
Player.Temp.IsInBattle = False Player.Temp.IsInBattle = False
If Core.GameOptions.ChangedPack = True Then
Screen.Level.Load(Screen.Level.LevelFile)
Core.GameOptions.ChangedPack = False
End If
'Set to correct music: 'Set to correct music:
If TrainerEncountered = False Then If TrainerEncountered = False Then
Dim x = 0 Dim x = 0

View File

@ -558,7 +558,7 @@ Public Class GameMode
Dim SkinNames As List(Of String) = {"Ethan", "Lyra", "Nate", "Rosa", "Hilbert", "Hilda"}.ToList() Dim SkinNames As List(Of String) = {"Ethan", "Lyra", "Nate", "Rosa", "Hilbert", "Hilda"}.ToList()
Dim gameMode As New GameMode("Pokemon 3D", "The normal game mode.", GameController.GAMEVERSION, "Kolben Games", "\Content\Data\maps\", "\Content\Data\Scripts\", "\Content\Data\maps\poke\", "\Content\Pokemon\Data\", "\Content\", "\Content\Localization\", New List(Of GameRule), Dim gameMode As New GameMode("Pokemon 3D", "The normal game mode.", GameController.GAMEVERSION, "Kolben Games", "\Content\Data\maps\", "\Content\Data\Scripts\", "\Content\Data\maps\poke\", "\Content\Pokemon\Data\", "\Content\", "\Content\Localization\", New List(Of GameRule),
"newgame\intro0.dat", New Vector3(1.0F, 0.1F, 3.0F), MathHelper.PiOver2, "Your Room", "", New Color(59, 123, 165), "0", "welcome", "0", SkinColors, SkinFiles, SkinNames) "newgame\intro0.dat", New Vector3(1.0F, 0.1F, 3.0F), MathHelper.PiOver2, "Your Room", "", New Color(59, 123, 165), "0", "welcome", "1", SkinColors, SkinFiles, SkinNames)
Dim gameRules As New List(Of GameRule) Dim gameRules As New List(Of GameRule)
gameRules.Add(New GameRule("MaxLevel", "100")) gameRules.Add(New GameRule("MaxLevel", "100"))

View File

@ -1314,9 +1314,9 @@ Public Class GameModeSelectionScreen
GameModeManager.SetGameModePointer(_gameModes(_index).DirectoryName) GameModeManager.SetGameModePointer(_gameModes(_index).DirectoryName)
SoundManager.PlaySound("select") SoundManager.PlaySound("select")
If GameModeManager.ActiveGameMode.IntroType = "0" Then If GameModeManager.ActiveGameMode.IntroType = "0" Then
SetScreen(New Screens.MainMenu.NewNewGameScreen(PreScreen))
Else
SetScreen(New TransitionScreen(Me.PreScreen, New NewGameScreen(), Color.Black, False)) SetScreen(New TransitionScreen(Me.PreScreen, New NewGameScreen(), Color.Black, False))
Else
SetScreen(New Screens.MainMenu.NewNewGameScreen(PreScreen))
End If End If
End If End If

View File

@ -583,12 +583,13 @@
If PackNames.Count > 0 Then If PackNames.Count > 0 Then
Core.GameOptions.ContentPackNames = EnabledPackNames.ToArray() Core.GameOptions.ContentPackNames = EnabledPackNames.ToArray()
Core.GameOptions.SaveOptions() Core.GameOptions.SaveOptions()
MusicManager.Stop() MusicManager.PlayNoMusic()
ContentPackManager.Clear() ContentPackManager.Clear()
For Each s As String In Core.GameOptions.ContentPackNames For Each s As String In Core.GameOptions.ContentPackNames
ContentPackManager.Load(GameController.GamePath & "\ContentPacks\" & s & "\exceptions.dat") ContentPackManager.Load(GameController.GamePath & "\ContentPacks\" & s & "\exceptions.dat")
Next Next
MusicManager.PlayNoMusic() SoundManager.PlaySound("save")
Core.GameOptions.ChangedPack = True
Core.OffsetMaps.Clear() Core.OffsetMaps.Clear()
End If End If
End Sub End Sub
@ -1284,7 +1285,7 @@
Public MustOverride Sub Draw() Public MustOverride Sub Draw()
Public MustOverride Sub Update(ByRef s As NewOptionScreen) Public MustOverride Sub Update(ByRef s As NewOptionScreen)
Public _position As Vector2 = New Vector2(0) Public _position As Vector2 = New Vector2(0)
Private _size As Integer = 1 Public _size As Integer = 1
Public Property ID As Integer Public Property ID As Integer
Public Property Size As Integer Public Property Size As Integer
@ -1529,7 +1530,6 @@
Inherits Control Inherits Control
Private _size As Integer = 0
Private _value As Integer = 0 Private _value As Integer = 0
Private _max As Integer = 0 Private _max As Integer = 0
Private _min As Integer = 0 Private _min As Integer = 0
@ -1610,7 +1610,7 @@
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) 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 MyBase.New
Me._position = Position Me._position = Position
Me._size = Size Me.Size = Size
Me._text = Text Me._text = Text
Me._value = Value Me._value = Value
Me._max = Max Me._max = Max
@ -1622,7 +1622,7 @@
End Sub End Sub
Public Overrides Sub Draw() Public Overrides Sub Draw()
Dim length As Integer = _size + 16 Dim length As Integer = Size + 16
Dim height As Integer = 36 Dim height As Integer = 36
Dim s As NewOptionScreen = CType(CurrentScreen, NewOptionScreen) Dim s As NewOptionScreen = CType(CurrentScreen, NewOptionScreen)
@ -1667,7 +1667,6 @@
End Sub End Sub
Public Overrides Sub Update(ByRef s As NewOptionScreen) Public Overrides Sub Update(ByRef s As NewOptionScreen)
If s._pageClosing = False And s._pageOpening = False Then
If MouseHandler.ButtonDown(MouseHandler.MouseButtons.LeftButton) Then If MouseHandler.ButtonDown(MouseHandler.MouseButtons.LeftButton) Then
If GetSliderBox().Contains(MouseHandler.MousePosition.X, MouseHandler.MousePosition.Y) And Clicked = False Then If GetSliderBox().Contains(MouseHandler.MousePosition.X, MouseHandler.MousePosition.Y) And Clicked = False Then
Clicked = True Clicked = True
@ -1676,10 +1675,14 @@
End If End If
If Clicked = True Then If Clicked = True Then
Dim x As Double = MouseHandler.MousePosition.X - Me._position.X Dim x As Double = MouseHandler.MousePosition.X - Me._position.X
Dim distance As Double = Me._position.X + Me.Size + 16 + 1 If x < 0 Then
Dim percent As Double = x / distance * 100 x = 0D
End If
If x > Me.Size + 16 Then
x = Me.Size + 16
End If
Me.Value = CInt(percent * (Max / Min)) Me.Value = CInt(x * ((Me._max - Min) / 100) * (100 / Me._size)) + Min
Me.Value = Value.Clamp(Min, Max) Me.Value = Value.Clamp(Min, Max)
OnChangeTrigger(Me) OnChangeTrigger(Me)
@ -1708,11 +1711,10 @@
End If End If
End If End If
End If End If
End If
End Sub End Sub
Private Function GetSliderBox() As Rectangle Private Function GetSliderBox() As Rectangle
Dim x As Integer = CInt(((100 / (Me._max - Min)) * (Me._value - Min)) * (_size / 100)) Dim x As Integer = CInt(((100 / (Me._max - Min)) * (Me._value - Min)) * (Size / 100))
If Me._value = Min Then If Me._value = Min Then
x = 0 x = 0