P3D-Legacy/P3D/Screens/VoltorbFlipScreen.vb

1320 lines
62 KiB
VB.net

Imports P3D.Screens.UI
Namespace VoltorbFlip
Public Class VoltorbFlipScreen
Inherits Screen
' Variables & Properties
Private _screenTransitionY As Single = 0F
Public Shared _interfaceFade As Single = 0F
Private Delay As Integer = 0
Private MemoMenuX As Single = 0F
Private MemoMenuSize As New Size(112, 112)
Private Shared ReadOnly GameSize As New Size(576, 544)
Public Shared ReadOnly BoardSize As New Size(384, 384)
Public Shared ReadOnly TileSize As New Size(64, 64)
Private Shared ReadOnly GridSize As Integer = 5
Public Shared GameOrigin As New Vector2(CInt(windowSize.Width / 2 - GameSize.Width / 2 - 32), CInt(windowSize.Height / 2 - GameSize.Height / 2))
Public Shared BoardOrigin As New Vector2(GameOrigin.X + 32, GameOrigin.Y + 160)
Private BoardCursorPosition As New Vector2(0, 0)
Private BoardCursorDestination As New Vector2(0, 0)
Private MemoIndex As Integer = 0
Public Shared GameState As States = States.Opening
Public Shared Property PreviousLevel As Integer = 1
Public Shared Property CurrentLevel As Integer = 1
Public Shared ReadOnly MinLevel As Integer = 1
Public Shared ReadOnly MaxLevel As Integer = 7
Public Shared Property CurrentFlips As Integer = 0
Public Shared Property TotalFlips As Integer = 0
Public Shared Property CurrentCoins As Integer = 0
Public Shared Property TotalCoins As Integer = -1
Public Shared Property ConsecutiveWins As Integer = 0
Public Shared MaxCoins As Integer = 1
Public Board As List(Of List(Of Tile))
Public VoltorbSums As List(Of List(Of Integer))
Public CoinSums As List(Of List(Of Integer))
Public Enum States
Opening
Closing
QuitQuestion
Game
Memo
GameWon
GameLost
FlipWon
FlipLost
NewLevel
End Enum
'Stuff related to blurred PreScreens
Private _blur As Resources.Blur.BlurHandler
Private _preScreenTexture As RenderTarget2D
Private _preScreenTarget As RenderTarget2D
Private _blurScreens As Identifications() = {Identifications.BattleScreen,
Identifications.OverworldScreen,
Identifications.DirectTradeScreen,
Identifications.WonderTradeScreen,
Identifications.GTSSetupScreen,
Identifications.GTSTradeScreen,
Identifications.PVPLobbyScreen}
Public Sub New(ByVal currentScreen As Screen)
GameState = States.Opening
GameOrigin = New Vector2(CInt(windowSize.Width / 2 - GameSize.Width / 2 - 32), CInt(windowSize.Height / 2 - _screenTransitionY))
BoardOrigin = New Vector2(GameOrigin.X + 32, GameOrigin.Y + 160)
BoardCursorDestination = GetCursorOffset(0, 0)
BoardCursorPosition = GetCursorOffset(0, 0)
Board = CreateBoard(CurrentLevel)
TotalCoins = 0
_preScreenTarget = New RenderTarget2D(GraphicsDevice, windowSize.Width, windowSize.Height, False, SurfaceFormat.Color, DepthFormat.Depth24Stencil8)
_blur = New Resources.Blur.BlurHandler(windowSize.Width, windowSize.Height)
Identification = Identifications.VoltorbFlipScreen
PreScreen = currentScreen
IsDrawingGradients = True
Me.MouseVisible = True
Me.CanChat = Me.PreScreen.CanChat
Me.CanBePaused = Me.PreScreen.CanBePaused
End Sub
Public Overrides Sub Draw()
If _blurScreens.Contains(PreScreen.Identification) Then
DrawPrescreen()
Else
PreScreen.Draw()
End If
DrawGradients(CInt(255 * _interfaceFade))
DrawBackground()
DrawMemoMenuAndButton()
If Board IsNot Nothing Then
DrawBoard()
DrawCursor()
End If
DrawHUD()
DrawQuitButton()
ChooseBox.Draw()
TextBox.Draw()
End Sub
Private Sub DrawPrescreen()
If _preScreenTexture Is Nothing OrElse _preScreenTexture.IsContentLost Then
SpriteBatch.EndBatch()
Dim target As RenderTarget2D = _preScreenTarget
GraphicsDevice.SetRenderTarget(target)
GraphicsDevice.Clear(BackgroundColor)
SpriteBatch.BeginBatch()
PreScreen.Draw()
SpriteBatch.EndBatch()
GraphicsDevice.SetRenderTarget(Nothing)
SpriteBatch.BeginBatch()
_preScreenTexture = target
End If
If _interfaceFade < 1.0F Then
SpriteBatch.Draw(_preScreenTexture, windowSize, Color.White)
End If
SpriteBatch.Draw(_blur.Perform(_preScreenTexture), windowSize, New Color(255, 255, 255, CInt(255 * _interfaceFade * 2).Clamp(0, 255)))
End Sub
Private Sub DrawBackground()
Dim mainBackgroundColor As Color = New Color(255, 255, 255)
If GameState = States.Closing Or GameState = States.Opening Then
mainBackgroundColor = New Color(255, 255, 255, CInt(255 * _interfaceFade))
End If
Canvas.DrawImageBorder(TextureManager.GetTexture("Textures\VoltorbFlip\Background"), 2, New Rectangle(CInt(GameOrigin.X), CInt(GameOrigin.Y), CInt(GameSize.Width), CInt(GameSize.Height)), mainBackgroundColor, False)
End Sub
Private Sub DrawHUD()
Dim mainBackgroundColor As Color = New Color(255, 255, 255)
If GameState = States.Closing Or GameState = States.Opening Then
mainBackgroundColor = New Color(255, 255, 255, CInt(255 * _interfaceFade))
End If
Dim Fontcolor As Color = New Color(0, 0, 0)
If GameState = States.Closing Or GameState = States.Opening Then
Fontcolor = New Color(0, 0, 0, CInt(255 * _interfaceFade))
End If
'Level
Dim LevelText As String = "LV." & CurrentLevel.ToString
Canvas.DrawImageBorder(TextureManager.GetTexture("Textures\VoltorbFlip\HUD"), 2, New Rectangle(CInt(GameOrigin.X + 32), CInt(GameOrigin.Y + 32), 96, 96), mainBackgroundColor, False)
SpriteBatch.DrawString(FontManager.MainFont, LevelText, New Vector2(CInt(GameOrigin.X + 80 + 4 - FontManager.MainFont.MeasureString(LevelText).X / 2), CInt(GameOrigin.Y + 80 + 4 - FontManager.MainFont.MeasureString(LevelText).Y / 2)), Fontcolor)
'Current Coins
Canvas.DrawImageBorder(TextureManager.GetTexture("Textures\VoltorbFlip\HUD"), 2, New Rectangle(CInt(GameOrigin.X + 128 + 24), CInt(GameOrigin.Y + 32), 192, 96), mainBackgroundColor, False)
Dim CurrentCoinsText1 As String = "Coins found"
Dim CurrentCoinsText2 As String = "in this LV."
Dim CurrentCoinsText3 As String = ""
CurrentCoinsText3 &= "["
If CurrentCoins < 10000 Then
CurrentCoinsText3 &= "0"
End If
If CurrentCoins < 1000 Then
CurrentCoinsText3 &= "0"
End If
If CurrentCoins < 100 Then
CurrentCoinsText3 &= "0"
End If
If CurrentCoins < 10 Then
CurrentCoinsText3 &= "0"
End If
CurrentCoinsText3 &= CurrentCoins.ToString & "]"
SpriteBatch.DrawString(FontManager.MainFont, CurrentCoinsText1, New Vector2(CInt(GameOrigin.X + 232 + 20 - FontManager.MainFont.MeasureString(CurrentCoinsText1).X / 2), CInt(GameOrigin.Y + 80 + 4 - FontManager.MainFont.MeasureString(CurrentCoinsText2).Y / 2 - FontManager.MainFont.MeasureString(CurrentCoinsText1).Y)), Fontcolor)
SpriteBatch.DrawString(FontManager.MainFont, CurrentCoinsText2, New Vector2(CInt(GameOrigin.X + 232 + 20 - FontManager.MainFont.MeasureString(CurrentCoinsText2).X / 2), CInt(GameOrigin.Y + 80 + 4 - FontManager.MainFont.MeasureString(CurrentCoinsText2).Y / 2)), Fontcolor)
SpriteBatch.DrawString(FontManager.MainFont, CurrentCoinsText3, New Vector2(CInt(GameOrigin.X + 232 + 20 - FontManager.MainFont.MeasureString(CurrentCoinsText3).X / 2), CInt(GameOrigin.Y + 80 + 4 + FontManager.MainFont.MeasureString(CurrentCoinsText2).Y / 2)), Fontcolor)
'Total Coins
Canvas.DrawImageBorder(TextureManager.GetTexture("Textures\VoltorbFlip\HUD"), 2, New Rectangle(CInt(GameOrigin.X + 336 + 32), CInt(GameOrigin.Y + 32), 192, 96), mainBackgroundColor, False)
Dim TotalCoinsText1 As String = "Total Coins"
Dim TotalCoinsText2 As String = "earned"
Dim TotalCoinsText3 As String = ""
TotalCoinsText3 &= "["
If TotalCoins < 10000 Then
TotalCoinsText3 &= "0"
End If
If TotalCoins < 1000 Then
TotalCoinsText3 &= "0"
End If
If TotalCoins < 100 Then
TotalCoinsText3 &= "0"
End If
If TotalCoins < 10 Then
TotalCoinsText3 &= "0"
End If
TotalCoinsText3 &= TotalCoins.ToString & "]"
SpriteBatch.DrawString(FontManager.MainFont, TotalCoinsText1, New Vector2(CInt(GameOrigin.X + 440 + 28 - FontManager.MainFont.MeasureString(TotalCoinsText1).X / 2), CInt(GameOrigin.Y + 80 + 4 - FontManager.MainFont.MeasureString(TotalCoinsText2).Y / 2 - FontManager.MainFont.MeasureString(TotalCoinsText1).Y)), Fontcolor)
SpriteBatch.DrawString(FontManager.MainFont, TotalCoinsText2, New Vector2(CInt(GameOrigin.X + 440 + 28 - FontManager.MainFont.MeasureString(TotalCoinsText2).X / 2), CInt(GameOrigin.Y + 80 + 4 - FontManager.MainFont.MeasureString(TotalCoinsText2).Y / 2)), Fontcolor)
SpriteBatch.DrawString(FontManager.MainFont, TotalCoinsText3, New Vector2(CInt(GameOrigin.X + 440 + 28 - FontManager.MainFont.MeasureString(TotalCoinsText3).X / 2), CInt(GameOrigin.Y + 80 + 4 + FontManager.MainFont.MeasureString(TotalCoinsText2).Y / 2)), Fontcolor)
End Sub
Private Sub DrawBoard()
Dim mainBackgroundColor As Color = New Color(255, 255, 255)
If GameState = States.Closing Or GameState = States.Opening Then
mainBackgroundColor = New Color(255, 255, 255, CInt(255 * _interfaceFade))
End If
SpriteBatch.Draw(TextureManager.GetTexture("Textures\VoltorbFlip\Board"), New Rectangle(CInt(BoardOrigin.X), CInt(BoardOrigin.Y), BoardSize.Width, BoardSize.Height), mainBackgroundColor)
DrawTiles()
DrawSums()
End Sub
Private Sub DrawTiles()
For _row = 0 To GridSize - 1
For _column = 0 To GridSize - 1
Dim _tile As Tile = Board(_row)(_column)
_tile.Draw()
Next
Next
End Sub
Private Sub DrawSums()
Dim mainBackgroundColor As Color = New Color(255, 255, 255)
If GameState = States.Closing Or GameState = States.Opening Then
mainBackgroundColor = New Color(255, 255, 255, CInt(255 * _interfaceFade))
End If
'Draw Rows
'Coins
For RowIndex = 0 To GridSize - 1
Dim CoinSumString As String = "00"
If GameState = States.Game Or GameState = States.Memo Or GameState = States.QuitQuestion Then
Dim CoinSumInteger As Integer = CoinSums(0)(RowIndex)
If CoinSumInteger < 10 Then
CoinSumString = "0" & CoinSumInteger.ToString
Else
CoinSumString = CoinSumInteger.ToString
End If
End If
SpriteBatch.DrawString(FontManager.VoltorbFlipFont, CoinSumString, New Vector2(CInt(BoardOrigin.X + TileSize.Width * (GridSize + 1) - 8 - FontManager.VoltorbFlipFont.MeasureString(CoinSumString).X), BoardOrigin.Y + TileSize.Height * RowIndex + 8), mainBackgroundColor)
Next
'Voltorbs
For RowIndex = 0 To GridSize - 1
Dim VoltorbSumString As String = "0"
If GameState = States.Game Or GameState = States.Memo Or GameState = States.QuitQuestion Then
VoltorbSumString = VoltorbSums(0)(RowIndex).ToString
End If
SpriteBatch.DrawString(FontManager.VoltorbFlipFont, VoltorbSumString, New Vector2(CInt(BoardOrigin.X + TileSize.Width * (GridSize + 1) - 8 - FontManager.VoltorbFlipFont.MeasureString(VoltorbSumString).X), BoardOrigin.Y + TileSize.Height * RowIndex + 34), mainBackgroundColor)
Next
'Draw Columns
'Coins
For ColumnIndex = 0 To GridSize - 1
Dim CoinSumString As String = "00"
If GameState = States.Game Or GameState = States.Memo Or GameState = States.QuitQuestion Then
Dim CoinSumInteger As Integer = CoinSums(1)(ColumnIndex)
If CoinSumInteger < 10 Then
CoinSumString = "0" & CoinSumInteger.ToString
Else
CoinSumString = CoinSumInteger.ToString
End If
End If
SpriteBatch.DrawString(FontManager.VoltorbFlipFont, CoinSumString, New Vector2(CInt(BoardOrigin.X + TileSize.Width * ColumnIndex + TileSize.Width - 8 - FontManager.VoltorbFlipFont.MeasureString(CoinSumString).X), BoardOrigin.Y + TileSize.Height * GridSize + 8), mainBackgroundColor)
Next
'Voltorbs
For ColumnIndex = 0 To GridSize - 1
Dim VoltorbSumString As String = "0"
If GameState = States.Game Or GameState = States.Memo Or GameState = States.QuitQuestion Then
VoltorbSumString = VoltorbSums(1)(ColumnIndex).ToString
End If
SpriteBatch.DrawString(FontManager.VoltorbFlipFont, VoltorbSumString, New Vector2(CInt(BoardOrigin.X + TileSize.Width * ColumnIndex + TileSize.Width - 8 - FontManager.VoltorbFlipFont.MeasureString(VoltorbSumString).X), BoardOrigin.Y + TileSize.Height * GridSize + 34), mainBackgroundColor)
Next
End Sub
Private Sub DrawMemoMenuAndButton()
Dim mainBackgroundColor As Color = New Color(255, 255, 255)
If GameState = States.Closing Or GameState = States.Opening Then
mainBackgroundColor = New Color(255, 255, 255, CInt(255 * _interfaceFade))
End If
Dim Fontcolor As Color = New Color(0, 0, 0)
If GameState = States.Closing Or GameState = States.Opening Then
Fontcolor = New Color(0, 0, 0, CInt(255 * _interfaceFade))
End If
'Draw Button
Dim ButtonOriginX As Integer = CInt(BoardOrigin.X + BoardSize.Width + TileSize.Width / 4)
SpriteBatch.Draw(TextureManager.GetTexture("VoltorbFlip\Memo_Button", New Rectangle(0, 0, 56, 56)), New Rectangle(ButtonOriginX, CInt(BoardOrigin.Y), MemoMenuSize.Width, MemoMenuSize.Height), mainBackgroundColor)
Dim ButtonTextTop As String = "Open"
Dim ButtonTextBottom As String = "Memos"
If GameState = States.Memo Then
ButtonTextTop = "Close"
End If
SpriteBatch.DrawString(FontManager.MainFont, ButtonTextTop, New Vector2(CInt(ButtonOriginX + MemoMenuSize.Width / 2 - FontManager.MainFont.MeasureString(ButtonTextTop).X / 2), CInt(BoardOrigin.Y + 40)), Fontcolor)
SpriteBatch.DrawString(FontManager.MainFont, ButtonTextBottom, New Vector2(CInt(ButtonOriginX + MemoMenuSize.Width / 2 - FontManager.MainFont.MeasureString(ButtonTextBottom).X / 2), CInt(BoardOrigin.Y + 40 + FontManager.MainFont.MeasureString(ButtonTextTop).Y)), Fontcolor)
'Draw Memo Menu
If MemoMenuX > 0 Then
Dim CurrentTile As Tile = Board(CInt(GetCurrentTile.Y))(CInt(GetCurrentTile.X))
'Draw Background
SpriteBatch.Draw(TextureManager.GetTexture("VoltorbFlip\Memo_Background", New Rectangle(0, 0, 56, 56)), New Rectangle(CInt(BoardOrigin.X + BoardSize.Width - MemoMenuSize.Width + MemoMenuX), CInt(BoardOrigin.Y + MemoMenuSize.Height + TileSize.Height / 2), MemoMenuSize.Width, MemoMenuSize.Height), mainBackgroundColor)
If GameState = States.Memo Then
'Draw lit up Memos in the Memo menu when it's enabled on a tile
If CurrentTile.GetMemo(0) = True Then 'Voltorb
SpriteBatch.Draw(TextureManager.GetTexture("VoltorbFlip\Memo_Enabled", New Rectangle(0, 0, 56, 56)), New Rectangle(CInt(BoardOrigin.X + BoardSize.Width - MemoMenuSize.Width + MemoMenuX), CInt(BoardOrigin.Y + MemoMenuSize.Height + TileSize.Height / 2), MemoMenuSize.Width, MemoMenuSize.Height), mainBackgroundColor)
End If
If CurrentTile.GetMemo(1) = True Then 'x1
SpriteBatch.Draw(TextureManager.GetTexture("VoltorbFlip\Memo_Enabled", New Rectangle(56, 0, 56, 56)), New Rectangle(CInt(BoardOrigin.X + BoardSize.Width - MemoMenuSize.Width + MemoMenuX), CInt(BoardOrigin.Y + MemoMenuSize.Height + TileSize.Height / 2), MemoMenuSize.Width, MemoMenuSize.Height), mainBackgroundColor)
End If
If CurrentTile.GetMemo(2) = True Then 'x2
SpriteBatch.Draw(TextureManager.GetTexture("VoltorbFlip\Memo_Enabled", New Rectangle(56 + 56, 0, 56, 56)), New Rectangle(CInt(BoardOrigin.X + BoardSize.Width - MemoMenuSize.Width + MemoMenuX), CInt(BoardOrigin.Y + MemoMenuSize.Height + TileSize.Height / 2), MemoMenuSize.Width, MemoMenuSize.Height), mainBackgroundColor)
End If
If CurrentTile.GetMemo(3) = True Then 'x3
SpriteBatch.Draw(TextureManager.GetTexture("VoltorbFlip\Memo_Enabled", New Rectangle(56 + 56 + 56, 0, 56, 56)), New Rectangle(CInt(BoardOrigin.X + BoardSize.Width - MemoMenuSize.Width + MemoMenuX), CInt(BoardOrigin.Y + MemoMenuSize.Height + TileSize.Height / 2), MemoMenuSize.Width, MemoMenuSize.Height), mainBackgroundColor)
End If
'Draw indicator of currently selected Memo
SpriteBatch.Draw(TextureManager.GetTexture("VoltorbFlip\Memo_Index", New Rectangle(56 * MemoIndex, 0, 56, 56)), New Rectangle(CInt(BoardOrigin.X + BoardSize.Width - MemoMenuSize.Width + MemoMenuX), CInt(BoardOrigin.Y + MemoMenuSize.Height + TileSize.Height / 2), MemoMenuSize.Width, MemoMenuSize.Height), mainBackgroundColor)
End If
End If
End Sub
Private Sub DrawCursor()
If GameState = States.Game OrElse GameState = States.Memo Then
Dim mainBackgroundColor As Color = New Color(255, 255, 255)
If GameState = States.Closing Or GameState = States.Opening Then
mainBackgroundColor = New Color(255, 255, 255, CInt(255 * _interfaceFade))
End If
Dim CursorImage As Texture2D = TextureManager.GetTexture("Textures\VoltorbFlip\Cursor_Game")
If GameState = States.Memo Then
CursorImage = TextureManager.GetTexture("Textures\VoltorbFlip\Cursor_Memo")
End If
SpriteBatch.Draw(CursorImage, New Rectangle(CInt(VoltorbFlipScreen.BoardOrigin.X + BoardCursorPosition.X), CInt(VoltorbFlipScreen.BoardOrigin.Y + BoardCursorPosition.Y), TileSize.Width, TileSize.Height), mainBackgroundColor)
End If
End Sub
Private Sub DrawQuitButton()
Dim mainBackgroundColor As Color = New Color(255, 255, 255)
If GameState = States.Closing Or GameState = States.Opening Then
mainBackgroundColor = New Color(255, 255, 255, CInt(255 * _interfaceFade))
End If
Dim QuitButtonRectangle As New Rectangle(CInt(GameOrigin.X + 424), CInt(GameOrigin.Y + 448), 128, 56)
SpriteBatch.Draw(TextureManager.GetTexture("Textures\VoltorbFlip\Quit_Button"), QuitButtonRectangle, mainBackgroundColor)
End Sub
Private Function CreateBoard(ByVal Level As Integer) As List(Of List(Of Tile))
Dim Board As List(Of List(Of Tile)) = CreateGrid()
Dim Data As List(Of Integer) = GetLevelData(Level)
Dim Spots As List(Of List(Of Integer)) = New List(Of List(Of Integer))
For i = 0 To Data(0) + Data(1) + Data(2) - 1
If Spots.Count > 0 Then
Dim ValueX As Integer = Random.Next(0, 5)
Dim ValueY As Integer = Random.Next(0, 5)
TryAgain:
Dim IsUnique As Boolean = True
For SpotIndex = 0 To Spots.Count - 1
If Spots(SpotIndex)(0) = ValueX AndAlso Spots(SpotIndex)(1) = ValueY Then
IsUnique = False
Exit For
End If
Next
If IsUnique = False Then
ValueX = Random.Next(0, 5)
ValueY = Random.Next(0, 5)
GoTo TryAgain
Else
Spots.Add(New List(Of Integer)({ValueX, ValueY}.ToList))
End If
Else
Spots.Add(New List(Of Integer)({Random.Next(0, 5), Random.Next(0, 5)}.ToList))
End If
Next
If Data(0) > 0 Then
For a = 0 To Data(0) - 1
Dim TileX As Integer = Spots(a)(0)
Dim TileY As Integer = Spots(a)(1)
Board(TileY)(TileX).Value = Tile.Values.Two
Next
End If
If Data(1) > 0 Then
For b = 0 To Data(1) - 1
Dim TileX As Integer = Spots(b + Data(0))(0)
Dim TileY As Integer = Spots(b + Data(0))(1)
Board(TileY)(TileX).Value = Tile.Values.Three
Next
End If
If Data(2) > 0 Then
For c = 0 To Data(2) - 1
Dim TileX As Integer = Spots(c + Data(0) + Data(1))(0)
Dim TileY As Integer = Spots(c + Data(0) + Data(1))(1)
Board(TileY)(TileX).Value = Tile.Values.Voltorb
Next
End If
If Data(0) > 0 AndAlso Data(1) > 0 Then
MaxCoins = CInt(Math.Pow(2, Data(0)) * Math.Pow(3, Data(1)))
End If
If Data(0) > 0 AndAlso Data(1) = 0 Then
MaxCoins = CInt(Math.Pow(2, Data(0)))
End If
If Data(0) = 0 AndAlso Data(1) > 0 Then
MaxCoins = CInt(Math.Pow(3, Data(1)))
End If
VoltorbSums = GenerateSums(Board, True)
CoinSums = GenerateSums(Board, False)
Return Board
End Function
''' <summary>
''' Returns an empty grid of Tiles
''' </summary>
''' <returns></returns>
Private Function CreateGrid() As List(Of List(Of Tile))
Dim Grid As New List(Of List(Of Tile))
For _row = 0 To VoltorbFlipScreen.GridSize - 1
Dim Column As New List(Of Tile)
For _column = 0 To VoltorbFlipScreen.GridSize - 1
Column.Add(New VoltorbFlip.Tile(_row, _column, VoltorbFlip.Tile.Values.One, False))
Next
Grid.Add(Column)
Next
Return Grid
End Function
''' <summary>
''' Returns amount of either Coins or Voltorbs in each row and column of a grid of Tiles
''' </summary>
''' <param name="Board"></param> A grid of Tiles
''' <param name="CoinsOrVoltorbs"></param> True returns amount of Voltorbs, False returns amount of Coins
''' <returns></returns>
Private Function GenerateSums(ByVal Board As List(Of List(Of Tile)), ByVal CoinsOrVoltorbs As Boolean) As List(Of List(Of Integer))
Dim RowSums As New List(Of Integer)
Dim ColumnSums As New List(Of Integer)
Dim RowBombs As New List(Of Integer)
Dim ColumnBombs As New List(Of Integer)
RowSums.AddRange({0, 0, 0, 0, 0}.ToList)
ColumnSums.AddRange({0, 0, 0, 0, 0}.ToList)
RowBombs.AddRange({0, 0, 0, 0, 0}.ToList)
ColumnBombs.AddRange({0, 0, 0, 0, 0}.ToList)
'Rows
For _row = 0 To GridSize - 1
For _column = 0 To GridSize - 1
If Board(_row)(_column).Value = Tile.Values.Voltorb Then
RowBombs(_row) += 1
Else
RowSums(_row) += Board(_row)(_column).Value
End If
Next
Next
'Columns
For _column = 0 To GridSize - 1
For _row = 0 To GridSize - 1
If Board(_row)(_column).Value = Tile.Values.Voltorb Then
ColumnBombs(_column) += 1
Else
ColumnSums(_column) += Board(_row)(_column).Value
End If
Next
Next
If CoinsOrVoltorbs = False Then
Dim Sums As New List(Of List(Of Integer))
Sums.AddRange({RowSums, ColumnSums})
Return Sums
Else
Dim Voltorbs As New List(Of List(Of Integer))
Voltorbs.AddRange({RowBombs, ColumnBombs})
Return Voltorbs
End If
End Function
Public Function GetCursorOffset(Optional ByVal Column As Integer = 0, Optional ByVal Row As Integer = 0) As Vector2
Return New Vector2(TileSize.Width * Column, TileSize.Height * Row)
End Function
''' <summary>
''' Get the tile that the cursor is on
''' </summary>
''' <returns></returns>
Public Function GetCurrentTile() As Vector2
Return New Vector2((BoardCursorDestination.X / TileSize.Width).Clamp(0, GridSize - 1), (BoardCursorDestination.Y / TileSize.Height).Clamp(0, GridSize - 1))
End Function
Public Function GetTileUnderMouse() As Vector2
Dim AbsoluteMousePosition As Vector2 = MouseHandler.MousePosition.ToVector2
Dim RelativeMousePosition As Vector2 = New Vector2(Clamp(AbsoluteMousePosition.X - BoardOrigin.X, 0, BoardSize.Width), Clamp(AbsoluteMousePosition.Y - BoardOrigin.Y, 0, BoardSize.Height))
Return New Vector2(CInt(Math.Floor(RelativeMousePosition.X / TileSize.Width).Clamp(0, GridSize - 1)), CInt(Math.Floor(RelativeMousePosition.Y / TileSize.Height).Clamp(0, GridSize - 1)))
End Function
Public Function GetLevelData(ByVal LevelNumber As Integer) As List(Of Integer)
Select Case LevelNumber
Case 1
Dim chance As Integer = CInt(Random.Next(0, 5))
Select Case chance
Case 0
Return {3, 1, 6}.ToList
Case 1
Return {0, 3, 6}.ToList
Case 2
Return {5, 0, 6}.ToList
Case 3
Return {2, 2, 6}.ToList
Case 4
Return {4, 1, 6}.ToList
End Select
Case 2
Dim chance As Integer = CInt(Random.Next(0, 5))
Select Case chance
Case 0
Return {1, 3, 7}.ToList
Case 1
Return {6, 0, 7}.ToList
Case 2
Return {3, 2, 7}.ToList
Case 3
Return {0, 4, 7}.ToList
Case 4
Return {5, 1, 7}.ToList
End Select
Case 3
Dim chance As Integer = CInt(Random.Next(0, 5))
Select Case chance
Case 0
Return {2, 3, 8}.ToList
Case 1
Return {7, 0, 8}.ToList
Case 2
Return {4, 2, 8}.ToList
Case 3
Return {1, 4, 8}.ToList
Case 4
Return {6, 1, 8}.ToList
End Select
Case 4
Dim chance As Integer = CInt(Random.Next(0, 5))
Select Case chance
Case 0
Return {3, 3, 8}.ToList
Case 1
Return {0, 5, 8}.ToList
Case 2
Return {8, 0, 10}.ToList
Case 3
Return {5, 2, 10}.ToList
Case 4
Return {2, 4, 10}.ToList
End Select
Case 5
Dim chance As Integer = CInt(Random.Next(0, 5))
Select Case chance
Case 0
Return {7, 1, 10}.ToList
Case 1
Return {4, 3, 10}.ToList
Case 2
Return {1, 5, 10}.ToList
Case 3
Return {9, 0, 10}.ToList
Case 4
Return {6, 2, 10}.ToList
End Select
Case 6
Dim chance As Integer = CInt(Random.Next(0, 5))
Select Case chance
Case 0
Return {3, 4, 10}.ToList
Case 1
Return {0, 6, 10}.ToList
Case 2
Return {8, 1, 10}.ToList
Case 3
Return {5, 3, 10}.ToList
Case 4
Return {2, 5, 10}.ToList
End Select
Case 7
Dim chance As Integer = CInt(Random.Next(0, 5))
Select Case chance
Case 0
Return {7, 2, 10}.ToList
Case 1
Return {4, 4, 10}.ToList
Case 2
Return {1, 6, 13}.ToList
Case 3
Return {9, 1, 13}.ToList
Case 4
Return {6, 3, 10}.ToList
End Select
Case 8
Dim chance As Integer = CInt(Random.Next(0, 5))
Select Case chance
Case 0
Return {0, 7, 10}.ToList
Case 1
Return {8, 2, 10}.ToList
Case 2
Return {5, 4, 10}.ToList
Case 3
Return {2, 6, 10}.ToList
Case 4
Return {7, 3, 10}.ToList
End Select
Case Else
Return Nothing
End Select
Return Nothing
End Function
Protected Overrides Function GetFontRenderer() As SpriteBatch
If IsCurrentScreen() AndAlso _interfaceFade + 0.01F >= 1.0F Then
Return FontRenderer
Else
Return SpriteBatch
End If
End Function
Public Overrides Sub SizeChanged()
GameOrigin = New Vector2(CInt(windowSize.Width / 2 - GameSize.Width / 2 - 32), CInt(windowSize.Height / 2 - _screenTransitionY))
BoardOrigin = New Vector2(GameOrigin.X + 32, GameOrigin.Y + 160)
BoardCursorDestination = GetCursorOffset(0, 0)
BoardCursorPosition = GetCursorOffset(0, 0)
End Sub
Public Sub UpdateTiles()
For _row = 0 To GridSize - 1
For _column = 0 To GridSize - 1
Dim _tile As Tile = Board(_row)(_column)
_tile.Update()
Next
Next
End Sub
Public Overrides Sub Update()
ChooseBox.Update()
If ChooseBox.Showing = False Then
TextBox.Update()
End If
If ChooseBox.Showing = False AndAlso TextBox.Showing = False Then
If Delay > 0 Then
Delay -= 1
If Delay <= 0 Then
Delay = 0
End If
End If
End If
If Board IsNot Nothing Then
UpdateTiles()
End If
If Delay = 0 Then
If ChooseBox.Showing = False AndAlso TextBox.Showing = False Then
If GameState = States.Game Or GameState = States.Memo Then
'Moving the cursor between Tiles on the board
If Controls.Up(True, True, False) Then
If BoardCursorDestination.Y > GetCursorOffset(Nothing, 0).Y Then
BoardCursorDestination.Y -= GetCursorOffset(Nothing, 1).Y
Else
BoardCursorDestination.Y = GetCursorOffset(Nothing, 4).Y
End If
End If
If Controls.Down(True, True, False) = True Then
If BoardCursorDestination.Y < GetCursorOffset(Nothing, 4).Y Then
BoardCursorDestination.Y += GetCursorOffset(Nothing, 1).Y
Else
BoardCursorDestination.Y = GetCursorOffset(Nothing, 0).Y
End If
End If
If Controls.Left(True, True, False) = True Then
If BoardCursorDestination.X > GetCursorOffset(0, Nothing).X Then
BoardCursorDestination.X -= GetCursorOffset(1, Nothing).X
Else
BoardCursorDestination.X = GetCursorOffset(4, Nothing).X
End If
End If
If Controls.Right(True, True, False) = True Then
If BoardCursorDestination.X < GetCursorOffset(4, Nothing).X Then
BoardCursorDestination.X += GetCursorOffset(1, Nothing).X
Else
BoardCursorDestination.X = GetCursorOffset(0, Nothing).X
End If
End If
'Animation of Cursor
BoardCursorPosition.X = MathHelper.Lerp(BoardCursorPosition.X, BoardCursorDestination.X, 0.6F)
BoardCursorPosition.Y = MathHelper.Lerp(BoardCursorPosition.Y, BoardCursorDestination.Y, 0.6F)
Else
'Reset cursor position between levels
BoardCursorDestination = GetCursorOffset(0, 0)
BoardCursorPosition = GetCursorOffset(0, 0)
End If
'Switching between Game and Memo GameStates (Keys & GamePad)
If KeyBoardHandler.KeyPressed(KeyBindings.RunKey) Or ControllerHandler.ButtonPressed(Buttons.X) Then
If GameState = States.Game Then
GameState = States.Memo
SoundManager.PlaySound("select")
ElseIf GameState = States.Memo Then
GameState = States.Game
SoundManager.PlaySound("select")
End If
End If
'Switching between Game and Memo GameStates (Mouse)
Dim ButtonRectangle As Rectangle = New Rectangle(CInt(BoardOrigin.X + BoardSize.Width + TileSize.Width / 4), CInt(BoardOrigin.Y), MemoMenuSize.Width, MemoMenuSize.Height)
If Controls.Accept(True, False, False) = True AndAlso MouseHandler.IsInRectangle(ButtonRectangle) AndAlso Delay = 0 Then
If GameState = States.Game Then
GameState = States.Memo
SoundManager.PlaySound("select")
ElseIf GameState = States.Memo Then
GameState = States.Game
SoundManager.PlaySound("select")
End If
End If
If GameState = States.Memo Then
'Animate opening the Memo window
If MemoMenuX < MemoMenuSize.Width + TileSize.Width / 4 Then
MemoMenuX = MathHelper.Lerp(CSng(MemoMenuSize.Width + TileSize.Width / 4), MemoMenuX, 0.9F)
If MemoMenuX >= MemoMenuSize.Width + TileSize.Width / 4 Then
MemoMenuX = CInt(MemoMenuSize.Width + TileSize.Width / 4)
End If
End If
'Cycling through the 4 Memo types (Voltorb, One, Two, Three)
If Controls.Left(True, False, True, False, False, False) = True OrElse ControllerHandler.ButtonPressed(Buttons.LeftShoulder) Then
MemoIndex -= 1
If MemoIndex < 0 Then
MemoIndex = 3
End If
SoundManager.PlaySound("select")
End If
If Controls.Right(True, False, True, False, False, False) = True OrElse ControllerHandler.ButtonPressed(Buttons.RightShoulder) Then
MemoIndex += 1
If MemoIndex > 3 Then
MemoIndex = 0
End If
SoundManager.PlaySound("select")
End If
'Set the Memo type to the one under the mouse
Dim MemoMenuRectangle As New Rectangle(CInt(BoardOrigin.X + BoardSize.Width - MemoMenuSize.Width + MemoMenuX), CInt(BoardOrigin.Y + MemoMenuSize.Height + TileSize.Height / 2), MemoMenuSize.Width, MemoMenuSize.Height)
If Controls.Accept(True, False, False) = True Then
If MouseHandler.IsInRectangle(New Rectangle(MemoMenuRectangle.X, MemoMenuRectangle.Y, CInt(MemoMenuRectangle.Width / 2), CInt(MemoMenuRectangle.Height / 2))) = True Then
'Voltorb
MemoIndex = 0
SoundManager.PlaySound("select")
End If
If MouseHandler.IsInRectangle(New Rectangle(MemoMenuRectangle.X + CInt(MemoMenuRectangle.Width / 2), MemoMenuRectangle.Y, CInt(MemoMenuRectangle.Width / 2), CInt(MemoMenuRectangle.Height / 2))) = True Then
'One
MemoIndex = 1
SoundManager.PlaySound("select")
End If
If MouseHandler.IsInRectangle(New Rectangle(MemoMenuRectangle.X, MemoMenuRectangle.Y + CInt(MemoMenuRectangle.Height / 2), CInt(MemoMenuRectangle.Width / 2), CInt(MemoMenuRectangle.Height / 2))) = True Then
'Two
MemoIndex = 2
SoundManager.PlaySound("select")
End If
If MouseHandler.IsInRectangle(New Rectangle(MemoMenuRectangle.X + CInt(MemoMenuRectangle.Width / 2), MemoMenuRectangle.Y + CInt(MemoMenuRectangle.Height / 2), CInt(MemoMenuRectangle.Width / 2), CInt(MemoMenuRectangle.Height / 2))) = True Then
'Three
MemoIndex = 3
SoundManager.PlaySound("select")
End If
End If
Else
'Animate Closing the Memo window
If MemoMenuX > 0F Then
MemoMenuX = MathHelper.Lerp(0F, MemoMenuX, 0.9F)
If MemoMenuX <= 0F Then
MemoMenuX = 0F
End If
End If
End If
Dim QuitQuestionText As String = "Do you want to stop~playing Voltorb Flip?%Yes|No%"
'Quiting Voltorb Flip
If Controls.Dismiss(False, True, True) AndAlso GameState = States.Game AndAlso Delay = 0 Then
TextBox.Show(QuitQuestionText)
SoundManager.PlaySound("select")
GameState = States.QuitQuestion
End If
'Quiting Voltorb Flip using the mouse
Dim QuitButtonRectangle As New Rectangle(CInt(GameOrigin.X + 424), CInt(GameOrigin.Y + 448), 128, 56)
If Controls.Accept(True, False, False) AndAlso MouseHandler.IsInRectangle(QuitButtonRectangle) AndAlso GameState = States.Game AndAlso Delay = 0 Then
TextBox.Show(QuitQuestionText)
SoundManager.PlaySound("select")
GameState = States.QuitQuestion
End If
If GameState = States.QuitQuestion Then
If ChooseBox.readyForResult = True Then
If ChooseBox.result = 0 Then
Quit()
Else
Delay = 15
GameState = States.Game
End If
End If
End If
'Flip currently selected Tile
If Controls.Accept(False, True, True) AndAlso GameState = States.Game AndAlso Delay = 0 Then
Dim CurrentTile As Vector2 = GetCurrentTile()
If Board(CInt(CurrentTile.Y))(CInt(CurrentTile.X)).Flipped = False Then
SoundManager.PlaySound("select")
End If
Board(CInt(CurrentTile.Y))(CInt(CurrentTile.X)).Flip()
End If
'Flip the Tile that the mouse is on
If Controls.Accept(True, False, False) AndAlso GameState = States.Game AndAlso MouseHandler.IsInRectangle(New Rectangle(CInt(BoardOrigin.X), CInt(BoardOrigin.Y), BoardSize.Width, BoardSize.Height)) AndAlso Delay = 0 Then
Dim TileUnderMouse As Vector2 = GetTileUnderMouse()
BoardCursorDestination = GetCursorOffset(CInt(TileUnderMouse.X), CInt(TileUnderMouse.Y))
If Board(CInt(TileUnderMouse.Y))(CInt(TileUnderMouse.X)).Flipped = False Then
SoundManager.PlaySound("select")
End If
Board(CInt(TileUnderMouse.Y))(CInt(TileUnderMouse.X)).Flip()
End If
'Adding currently selected Memo to currently selected Tile
If Controls.Accept(False, True, True) AndAlso GameState = States.Memo AndAlso Board(CInt(GetCurrentTile.Y))(CInt(GetCurrentTile.X)).Flipped = False AndAlso Delay = 0 Then
If Board(CInt(GetCurrentTile.Y))(CInt(GetCurrentTile.X)).GetMemo(MemoIndex) = False Then
SoundManager.PlaySound("select")
End If
Board(CInt(GetCurrentTile.Y))(CInt(GetCurrentTile.X)).SetMemo(MemoIndex, True)
End If
'Adding currently selected Memo to Tile that the mouse is on
If Controls.Accept(True, False, False) AndAlso GameState = States.Memo AndAlso MouseHandler.IsInRectangle(New Rectangle(CInt(BoardOrigin.X), CInt(BoardOrigin.Y), BoardSize.Width, BoardSize.Height)) AndAlso Delay = 0 Then
Dim TileUnderMouse As Vector2 = GetTileUnderMouse()
BoardCursorDestination = GetCursorOffset(CInt(TileUnderMouse.X), CInt(TileUnderMouse.Y))
If Board(CInt(TileUnderMouse.Y))(CInt(TileUnderMouse.X)).Flipped = False Then
If Board(CInt(TileUnderMouse.Y))(CInt(TileUnderMouse.X)).GetMemo(MemoIndex) = False Then
SoundManager.PlaySound("select")
End If
Board(CInt(TileUnderMouse.Y))(CInt(TileUnderMouse.X)).SetMemo(MemoIndex, True)
End If
End If
'Removing currently selected Memo from currently selected Tile
If Controls.Dismiss(False, True, True) AndAlso GameState = States.Memo AndAlso Board(CInt(GetCurrentTile.Y))(CInt(GetCurrentTile.X)).Flipped = False AndAlso Delay = 0 Then
If Board(CInt(GetCurrentTile.Y))(CInt(GetCurrentTile.X)).GetMemo(MemoIndex) = True Then
SoundManager.PlaySound("select")
End If
Board(CInt(GetCurrentTile.Y))(CInt(GetCurrentTile.X)).SetMemo(MemoIndex, False)
End If
'Removing currently selected Memo from Tile that the mouse is on
If Controls.Dismiss(True, False, False) AndAlso GameState = States.Memo AndAlso MouseHandler.IsInRectangle(New Rectangle(CInt(BoardOrigin.X), CInt(BoardOrigin.Y), BoardSize.Width, BoardSize.Height)) AndAlso Delay = 0 Then
Dim TileUnderMouse As Vector2 = GetTileUnderMouse()
BoardCursorDestination = GetCursorOffset(CInt(TileUnderMouse.X), CInt(TileUnderMouse.Y))
If Board(CInt(TileUnderMouse.Y))(CInt(TileUnderMouse.X)).Flipped = False Then
If Board(CInt(TileUnderMouse.Y))(CInt(TileUnderMouse.X)).GetMemo(MemoIndex) = True Then
SoundManager.PlaySound("select")
End If
Board(CInt(TileUnderMouse.Y))(CInt(TileUnderMouse.X)).SetMemo(MemoIndex, False)
End If
End If
End If
End If
'Level complete!
If CurrentCoins >= MaxCoins AndAlso GameState = States.Game Then
Dim GameClearText = "Game clear! You received~" & CurrentCoins.ToString & " " & "Coins!"
SoundManager.PlaySound("VoltorbFlip\WinGame")
TextBox.Show(GameClearText)
If Delay = 0 Then
PreviousLevel = CurrentLevel
If CurrentFlips >= 8 Then
TotalFlips += 1
End If
CurrentFlips = 0
ConsecutiveWins += 1
If ConsecutiveWins = 5 AndAlso TotalFlips = 5 Then
CurrentLevel = MaxLevel + 1
Else
If CurrentLevel + 1 > MaxLevel Then
CurrentLevel = MaxLevel
Else
CurrentLevel += 1
End If
End If
GameState = States.GameWon
Delay = 5
End If
End If
'Completed the level
If GameState = States.GameWon Then
If Core.Player.Coins + TotalCoins > 50000 Then
TotalCoins = 50000 - Core.Player.Coins
CurrentCoins = 0
TextBox.Show("Your Coin Case can't fit~any more Coins!*You received~" & TotalCoins.ToString & " " & "Coins instead!")
Quit()
Else
TotalCoins += CurrentCoins
CurrentCoins = 0
End If
'Flip all Tiles to reveal contents
Dim ReadyAmount As Integer = 0
For _row = 0 To GridSize - 1
For _column = 0 To GridSize - 1
Board(_row)(_column).Reveal()
If Board(_row)(_column).FlipProgress = 0 Then
ReadyAmount += 1
End If
Next
Next
If Controls.Accept = True AndAlso TextBox.Showing = False Then
If ReadyAmount = CInt(GridSize * GridSize) Then
SoundManager.PlaySound("select")
GameState = States.FlipWon
End If
End If
End If
'Revealed a Voltorb
If GameState = States.GameLost Then
CurrentCoins = 0
'Flip all Tiles to reveal contents
Dim ReadyAmount As Integer = 0
For _row = 0 To GridSize - 1
For _column = 0 To GridSize - 1
Board(_row)(_column).Reveal()
If Board(_row)(_column).FlipProgress = 0 Then
ReadyAmount += 1
End If
Next
Next
If ReadyAmount = CInt(GridSize * GridSize) Then
If Controls.Accept = True AndAlso TextBox.Showing = False Then
PreviousLevel = CurrentLevel
If CurrentFlips < CurrentLevel Then
CurrentLevel = Math.Max(1, CurrentFlips)
Else
CurrentLevel = 1
End If
SoundManager.PlaySound("select")
GameState = States.FlipLost
End If
End If
End If
'Increase Level, reset Tiles
If GameState = States.FlipWon Then
Dim ReadyAmount As Integer = 0
For _row = 0 To GridSize - 1
For _column = 0 To GridSize - 1
Board(_row)(_column).Reset()
If Board(_row)(_column).FlipProgress = 0 Then
ReadyAmount += 1
End If
Next
Next
If ReadyAmount = CInt(GridSize * GridSize) Then
GameState = States.NewLevel
End If
End If
'Drop Level, reset Tiles
If GameState = States.FlipLost Then
Dim ReadyAmount As Integer = 0
For _row = 0 To GridSize - 1
For _column = 0 To GridSize - 1
Board(_row)(_column).Reset()
If Board(_row)(_column).FlipProgress = 0 Then
ReadyAmount += 1
End If
Next
Next
CurrentFlips = 0
If ReadyAmount = CInt(GridSize * GridSize) Then
GameState = States.NewLevel
End If
End If
'Prepare new Level
If GameState = States.NewLevel Then
If TextBox.Showing = False Then
SoundManager.PlaySound("VoltorbFlip\StartGame")
Board = CreateBoard(CurrentLevel)
If CurrentLevel = 8 Then
TotalFlips = 0
ConsecutiveWins = 0
End If
If CurrentLevel < PreviousLevel Then
TextBox.Show("Dropped to Game Lv." & " " & CurrentLevel & "!")
End If
If CurrentLevel = PreviousLevel Then
TextBox.Show("Ready to play Game Lv." & " " & CurrentLevel & "!")
End If
If CurrentLevel > PreviousLevel Then
TextBox.Show("Advanced to Game Lv." & " " & CurrentLevel & "!")
End If
Else
Delay = 15
GameState = States.Game
End If
End If
'Animation of opening/closing the window
If GameState = States.Closing Then
Dim ResultCoins As Integer = 0
Dim AnimationCurrentCoins As Single = CurrentCoins
If CurrentCoins > ResultCoins Then
CurrentCoins = 0
End If
If _interfaceFade > 0F Then
_interfaceFade = MathHelper.Lerp(0, _interfaceFade, 0.8F)
If _interfaceFade < 0F Then
_interfaceFade = 0F
End If
End If
If _screenTransitionY > 0 Then
_screenTransitionY = MathHelper.Lerp(0, _screenTransitionY, 0.8F)
If _screenTransitionY <= 0 Then
_screenTransitionY = 0
End If
End If
GameOrigin.Y = CInt(windowSize.Height / 2 - _screenTransitionY)
BoardOrigin = New Vector2(GameOrigin.X + 32, GameOrigin.Y + 160)
If _screenTransitionY <= 2.0F Then
SetScreen(PreScreen)
End If
Else
Dim maxWindowHeight As Integer = CInt(GameSize.Height / 2)
If _screenTransitionY < maxWindowHeight Then
_screenTransitionY = MathHelper.Lerp(maxWindowHeight, _screenTransitionY, 0.8F)
If _screenTransitionY >= maxWindowHeight - 0.8 Then
If GameState = States.Opening Then
GameState = States.NewLevel
End If
_screenTransitionY = maxWindowHeight
End If
End If
GameOrigin.Y = CInt(windowSize.Height / 2 - _screenTransitionY)
BoardOrigin = New Vector2(GameOrigin.X + 32, GameOrigin.Y + 160)
If _interfaceFade < 1.0F Then
_interfaceFade = MathHelper.Lerp(1, _interfaceFade, 0.95F)
If _interfaceFade = 1.0F Then
_interfaceFade = 1.0F
End If
End If
End If
End Sub
Public Sub Quit()
If CurrentFlips < CurrentLevel Then
CurrentLevel = Math.Max(1, CurrentFlips)
Else
CurrentLevel = 1
End If
PreviousLevel = CurrentLevel
SoundManager.PlaySound("VoltorbFlip\QuitGame", True)
TextBox.Show("Game Over!~Dropped to Game Lv." & " " & CurrentLevel & "!")
CurrentFlips = 0
TotalFlips = 0
CurrentCoins = 0
GameState = States.Closing
End Sub
End Class
Public Class Tile
Public Enum Values
Voltorb
One
Two
Three
End Enum
Public Property Row As Integer = 0
Public Property Column As Integer = 0
Public Property Value As Integer = Tile.Values.Voltorb
Public Property Flipped As Boolean = False
Private Property MemoVoltorb As Boolean = False
Private Property Memo1 As Boolean = False
Private Property Memo2 As Boolean = False
Private Property Memo3 As Boolean = False
Private Property FlipWidth As Single = 1.0F
Private Property Activated As Boolean = False
Public Property FlipProgress As Integer = 0
Public Sub Flip()
If Flipped = False Then
FlipProgress = 3
If Value <> Values.Voltorb Then
VoltorbFlipScreen.CurrentFlips += 1
End If
End If
End Sub
Public Sub Reveal()
If Flipped = False Then
FlipProgress = 1
End If
End Sub
Public Sub Reset()
If Flipped = True Then
FlipProgress = 1
Activated = False
End If
End Sub
Public Sub Draw()
Dim mainBackgroundColor As Color = New Color(255, 255, 255)
If VoltorbFlipScreen.GameState = VoltorbFlipScreen.States.Closing Or VoltorbFlipScreen.GameState = VoltorbFlipScreen.States.Opening Then
mainBackgroundColor = New Color(255, 255, 255, CInt(255 * VoltorbFlipScreen._interfaceFade))
End If
Dim TileWidth = VoltorbFlipScreen.TileSize.Width
Dim TileHeight = VoltorbFlipScreen.TileSize.Height
If FlipProgress = 1 OrElse FlipProgress = 3 Then
If FlipWidth > 0F Then
FlipWidth -= 0.1F
End If
If FlipWidth <= 0F Then
FlipWidth = 0F
If Flipped = False Then
SetMemo(0, False)
SetMemo(1, False)
SetMemo(2, False)
SetMemo(3, False)
Flipped = True
Else
Flipped = False
End If
FlipProgress += 1
End If
End If
If FlipProgress = 2 OrElse FlipProgress = 4 Then
If FlipWidth < 1.0F Then
FlipWidth += 0.1F
End If
If FlipWidth >= 1.0F Then
FlipWidth = 1.0F
FlipProgress = 0
End If
End If
'Draw Tile
SpriteBatch.Draw(GetImage, New Rectangle(CInt(VoltorbFlipScreen.BoardOrigin.X + TileWidth * Column + (TileWidth - FlipWidth * TileWidth) / 2), CInt(VoltorbFlipScreen.BoardOrigin.Y + TileHeight * Row), CInt(TileWidth * FlipWidth), TileHeight), mainBackgroundColor)
'Draw Memos
If GetMemo(0) = True Then 'Voltorb
SpriteBatch.Draw(TextureManager.GetTexture("VoltorbFlip\Tile_MemoIcons", New Rectangle(0, 0, 32, 32)), New Rectangle(CInt(VoltorbFlipScreen.BoardOrigin.X + TileWidth * Column + (TileWidth - FlipWidth * TileWidth)), CInt(VoltorbFlipScreen.BoardOrigin.Y + TileHeight * Row), CInt(TileWidth * FlipWidth), TileHeight), mainBackgroundColor)
End If
If GetMemo(1) = True Then 'x1
SpriteBatch.Draw(TextureManager.GetTexture("VoltorbFlip\Tile_MemoIcons", New Rectangle(32, 0, 32, 32)), New Rectangle(CInt(VoltorbFlipScreen.BoardOrigin.X + TileWidth * Column + (TileWidth - FlipWidth * TileWidth)), CInt(VoltorbFlipScreen.BoardOrigin.Y + TileHeight * Row), CInt(TileWidth * FlipWidth), TileHeight), mainBackgroundColor)
End If
If GetMemo(2) = True Then 'x2
SpriteBatch.Draw(TextureManager.GetTexture("VoltorbFlip\Tile_MemoIcons", New Rectangle(32 + 32, 0, 32, 32)), New Rectangle(CInt(VoltorbFlipScreen.BoardOrigin.X + TileWidth * Column + (TileWidth - FlipWidth * TileWidth)), CInt(VoltorbFlipScreen.BoardOrigin.Y + TileHeight * Row), CInt(TileWidth * FlipWidth), TileHeight), mainBackgroundColor)
End If
If GetMemo(3) = True Then 'x3
SpriteBatch.Draw(TextureManager.GetTexture("VoltorbFlip\Tile_MemoIcons", New Rectangle(32 + 32 + 32, 0, 32, 32)), New Rectangle(CInt(VoltorbFlipScreen.BoardOrigin.X + TileWidth * Column + (TileWidth - FlipWidth * TileWidth)), CInt(VoltorbFlipScreen.BoardOrigin.Y + TileHeight * Row), CInt(TileWidth * FlipWidth), TileHeight), mainBackgroundColor)
End If
End Sub
Public Sub Update()
If FlipProgress <= 2 Then
Activated = False
Else
If Flipped = True Then
If Activated = False Then
If Me.Value = Values.Voltorb Then
If VoltorbFlipScreen.GameState = VoltorbFlipScreen.States.Game Then
SoundManager.PlaySound("VoltorbFlip\LoseGame", True)
End If
Screen.TextBox.Show("Oh no! You get 0 coins!")
VoltorbFlipScreen.ConsecutiveWins = 0
VoltorbFlipScreen.GameState = VoltorbFlipScreen.States.GameLost
Else
If VoltorbFlipScreen.CurrentCoins = 0 Then
VoltorbFlipScreen.CurrentCoins = Me.Value
Else
VoltorbFlipScreen.CurrentCoins *= Me.Value
End If
Activated = True
End If
End If
End If
End If
End Sub
Public Function GetImage() As Texture2D
If Flipped = True Then
Return TextureManager.GetTexture("VoltorbFlip\Tile_Front", New Rectangle(Value * 32, 0, 32, 32))
Else
Return TextureManager.GetTexture("VoltorbFlip\Tile_Back", New Rectangle(0, 0, 32, 32))
End If
End Function
Public Function GetMemo(ByVal MemoNumber As Integer) As Boolean
Select Case MemoNumber
Case 0
Return MemoVoltorb
Case 1
Return Memo1
Case 2
Return Memo2
Case 3
Return Memo3
Case Else
Return Nothing
End Select
End Function
Public Sub SetMemo(ByVal MemoNumber As Integer, ByVal Value As Boolean)
Select Case MemoNumber
Case Tile.Values.Voltorb
MemoVoltorb = Value
Case Tile.Values.One
Memo1 = Value
Case Tile.Values.Two
Memo2 = Value
Case Tile.Values.Three
Memo3 = Value
End Select
End Sub
Public Sub New(ByVal Row As Integer, ByVal Column As Integer, ByVal Value As Integer, ByVal Flipped As Boolean)
Me.Row = Row
Me.Column = Column
Me.Value = Value
Me.Flipped = Flipped
End Sub
End Class
End Namespace