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:
parent
8263bbe390
commit
b0ca5ab1d9
|
@ -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)
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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"))
|
||||||
|
|
|
@ -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
|
||||||
|
|
||||||
|
|
|
@ -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
|
||||||
|
|
Loading…
Reference in New Issue