524 lines
19 KiB
VB.net
524 lines
19 KiB
VB.net
Public Class ApricornScreen
|
|
|
|
Inherits Screen
|
|
|
|
Private Enum States
|
|
CanGive
|
|
CanTake
|
|
Wait
|
|
None
|
|
End Enum
|
|
|
|
Dim owner As String
|
|
Dim State As States = States.Wait
|
|
|
|
Dim Apricorns As New List(Of String)
|
|
|
|
Dim Buttons As New List(Of ButtonIcon)
|
|
Dim Labels As New List(Of Label)
|
|
|
|
Dim mainTexture As Texture2D
|
|
Dim lastUpdateState As States = States.None
|
|
|
|
Dim CursorIndex As Integer = 0
|
|
|
|
Public Sub New(ByVal currentScreen As Screen, ByVal owner As String)
|
|
Me.Identification = Identifications.ApricornScreen
|
|
|
|
Me.PreScreen = currentScreen
|
|
Me.mainTexture = TextureManager.GetTexture("GUI\Menus\Menu")
|
|
Me.owner = owner
|
|
Me.MouseVisible = True
|
|
|
|
Me.GetSavedApricorns()
|
|
|
|
If CheckApricornStatus() >= 1440 Then
|
|
If Me.HasApricorns() = True Then
|
|
Me.State = States.CanTake
|
|
Else
|
|
Me.State = States.CanGive
|
|
End If
|
|
Else
|
|
Me.State = States.Wait
|
|
End If
|
|
|
|
InitializeScreen()
|
|
End Sub
|
|
|
|
Private Sub InitializeScreen()
|
|
If Me.lastUpdateState <> Me.State Then
|
|
Me.lastUpdateState = Me.State
|
|
|
|
Me.Buttons.Clear()
|
|
Me.Labels.Clear()
|
|
|
|
Me.Labels.Add(New Label(Localization.GetString("apricorn_screen_apricorns"), New Vector2(80, 128), FontManager.MainFont))
|
|
|
|
Select Case Me.State
|
|
Case States.Wait
|
|
Me.Labels.Add(New Label(Localization.GetString("apricorn_screen_producing").Replace("~", Environment.NewLine), New Vector2(100, 200), FontManager.MainFont))
|
|
Me.Labels.Add(New Label(Localization.GetString("apricorn_screen_backadvice"), New Vector2(100, 260), Color.DarkGray, FontManager.MainFont))
|
|
Case States.CanGive
|
|
Dim T As Texture2D = TextureManager.GetTexture("Items\ItemSheet")
|
|
|
|
Me.Labels.Add(New Label(Localization.GetString("apricorn_screen_choose_apricorns"), New Vector2(100, 200), FontManager.MainFont))
|
|
Dim RedApricorn As ButtonIcon = New ButtonIcon(AddressOf Me.GiveApricorn, "0 / " & Core.Player.Inventory.GetItemAmount(85), FontManager.MainFont, T, New Rectangle(240, 72, 24, 24), New Vector2(98, 240), New Size(48, 48), "85")
|
|
Dim BlueApricorn As ButtonIcon = New ButtonIcon(AddressOf Me.GiveApricorn, "0 / " & Core.Player.Inventory.GetItemAmount(89), FontManager.MainFont, T, New Rectangle(336, 72, 24, 24), New Vector2(98, 304), New Size(48, 48), "89")
|
|
Dim YellowApricorn As ButtonIcon = New ButtonIcon(AddressOf Me.GiveApricorn, "0 / " & Core.Player.Inventory.GetItemAmount(92), FontManager.MainFont, T, New Rectangle(384, 72, 24, 24), New Vector2(98, 368), New Size(48, 48), "92")
|
|
Dim GreenApricorn As ButtonIcon = New ButtonIcon(AddressOf Me.GiveApricorn, "0 / " & Core.Player.Inventory.GetItemAmount(93), FontManager.MainFont, T, New Rectangle(408, 72, 24, 24), New Vector2(98, 432), New Size(48, 48), "93")
|
|
Dim WhiteApricorn As ButtonIcon = New ButtonIcon(AddressOf Me.GiveApricorn, "0 / " & Core.Player.Inventory.GetItemAmount(97), FontManager.MainFont, T, New Rectangle(0, 96, 24, 24), New Vector2(98, 496), New Size(48, 48), "97")
|
|
Dim BlackApricorn As ButtonIcon = New ButtonIcon(AddressOf Me.GiveApricorn, "0 / " & Core.Player.Inventory.GetItemAmount(99), FontManager.MainFont, T, New Rectangle(48, 96, 24, 24), New Vector2(162, 240), New Size(48, 48), "99")
|
|
Dim PinkApricorn As ButtonIcon = New ButtonIcon(AddressOf Me.GiveApricorn, "0 / " & Core.Player.Inventory.GetItemAmount(101), FontManager.MainFont, T, New Rectangle(72, 96, 24, 24), New Vector2(162, 304), New Size(48, 48), "101")
|
|
|
|
Dim GiveButton As ButtonIcon = New ButtonIcon(AddressOf Me.Give, Localization.GetString("apricorn_screen_ok"), FontManager.MainFont, mainTexture, New Rectangle(48, 128, 16, 16), New Vector2(162, 496), New Size(48, 48), "OK")
|
|
GiveButton.Enabled = False
|
|
Dim ClearButton As ButtonIcon = New ButtonIcon(AddressOf Me.ClearApricorns, Localization.GetString("apricorn_screen_clear"), FontManager.MainFont, mainTexture, New Rectangle(64, 128, 16, 16), New Vector2(162, 432), New Size(48, 48), "Clear")
|
|
|
|
Buttons.AddRange({RedApricorn, BlueApricorn, YellowApricorn, GreenApricorn, WhiteApricorn, BlackApricorn, PinkApricorn, ClearButton, GiveButton})
|
|
Case States.CanTake
|
|
Dim TakeButton As ButtonIcon = New ButtonIcon(AddressOf Me.Take, Localization.GetString("apricorn_screen_take"), FontManager.MainFont, mainTexture, New Rectangle(48, 128, 16, 16), New Vector2(98, 450), New Size(48, 48))
|
|
Buttons.AddRange({TakeButton})
|
|
Me.Labels.Add(New Label(Localization.GetString("apricorn_screen_ready"), New Vector2(100, 200), FontManager.MainFont))
|
|
End Select
|
|
End If
|
|
End Sub
|
|
|
|
Public Overrides Sub Update()
|
|
TextBox.Update()
|
|
InitializeScreen()
|
|
|
|
If TextBox.Showing = False Then
|
|
If Controls.Dismiss() = True Then
|
|
Core.SetScreen(Me.PreScreen)
|
|
End If
|
|
|
|
If Controls.Up(True, True) = True Or Controls.Left(True, True) = True Then
|
|
Me.CursorIndex -= 1
|
|
If Me.CursorIndex < 0 Then
|
|
Me.CursorIndex = Me.Buttons.Count - 1
|
|
End If
|
|
End If
|
|
If Controls.Down(True, True) = True Or Controls.Right(True, True) = True Then
|
|
Me.CursorIndex += 1
|
|
If Me.CursorIndex > Me.Buttons.Count - 1 Then
|
|
Me.CursorIndex = 0
|
|
End If
|
|
End If
|
|
|
|
If Me.Buttons.Count > 0 Then
|
|
If Controls.Accept(False, True, True) = True Then
|
|
Me.Buttons(Me.CursorIndex).Click()
|
|
End If
|
|
End If
|
|
|
|
For Each B As ButtonIcon In Buttons
|
|
B.Update()
|
|
Next
|
|
|
|
Select Case Me.State
|
|
Case States.Wait
|
|
UpdateWait()
|
|
Case States.CanGive
|
|
UpdateGive()
|
|
Case States.CanTake
|
|
UpdateTake()
|
|
End Select
|
|
End If
|
|
End Sub
|
|
|
|
Private Sub UpdateWait()
|
|
|
|
End Sub
|
|
|
|
Private Sub UpdateGive()
|
|
|
|
End Sub
|
|
|
|
Private Sub UpdateTake()
|
|
|
|
End Sub
|
|
|
|
Public Overrides Sub Draw()
|
|
Me.PreScreen.Draw()
|
|
|
|
Canvas.DrawImageBorder(TextureManager.GetTexture("GUI\Menus\Menu", New Rectangle(0, 0, 48, 48), ""), 2, New Rectangle(60, 100, 800, 480))
|
|
|
|
For i = 0 To Me.Buttons.Count - 1
|
|
Dim b As ButtonIcon = Me.Buttons(i)
|
|
|
|
If i = Me.CursorIndex Then
|
|
Canvas.DrawRectangle(New Rectangle(CInt(b.Position.X) - 2, CInt(b.Position.Y) - 2, 52, 52), New Color(0, 125, 255))
|
|
Canvas.DrawRectangle(New Rectangle(CInt(b.Position.X), CInt(b.Position.Y), 48, 48), New Color(102, 196, 255))
|
|
End If
|
|
|
|
b.Draw()
|
|
Next
|
|
|
|
For Each Button As ButtonIcon In Buttons
|
|
Button.Draw()
|
|
Next
|
|
|
|
For Each Label As Label In Labels
|
|
Label.Draw()
|
|
Next
|
|
|
|
Select Case Me.State
|
|
Case States.Wait
|
|
DrawWait()
|
|
Case States.CanGive
|
|
DrawGive()
|
|
Case States.CanTake
|
|
DrawTake()
|
|
End Select
|
|
|
|
TextBox.Draw()
|
|
End Sub
|
|
|
|
Private Sub DrawWait()
|
|
|
|
End Sub
|
|
|
|
Private Sub DrawTake()
|
|
For i = 0 To 6
|
|
Dim x As Integer = 0
|
|
Dim y As Integer = i
|
|
While y > 1
|
|
y -= 2
|
|
x += 1
|
|
End While
|
|
|
|
Dim ItemID As Integer = 0
|
|
Select Case i
|
|
Case 0
|
|
ItemID = 159
|
|
Case 1
|
|
ItemID = 160
|
|
Case 2
|
|
ItemID = 165
|
|
Case 3
|
|
ItemID = 164
|
|
Case 4
|
|
ItemID = 161
|
|
Case 5
|
|
ItemID = 157
|
|
Case 6
|
|
ItemID = 166
|
|
End Select
|
|
|
|
Dim Item As Item = Item.GetItemByID(ItemID)
|
|
Core.SpriteBatch.Draw(Item.Texture, New Rectangle(100 + x * 64, 260 + y * 96, 48, 48), Color.White)
|
|
Core.SpriteBatch.DrawString(FontManager.MainFont, "x" & Apricorns(i), New Vector2(110 + x * 64, 300 + y * 96), Color.Black)
|
|
Next
|
|
End Sub
|
|
|
|
Private Sub DrawGive()
|
|
|
|
End Sub
|
|
|
|
Private Sub GiveApricorn(ByVal b As ButtonIcon)
|
|
Dim apricornID As Integer = 0
|
|
|
|
Select Case CInt(b.AdditionalValue)
|
|
Case 85
|
|
apricornID = 0
|
|
Case 89
|
|
apricornID = 1
|
|
Case 92
|
|
apricornID = 2
|
|
Case 93
|
|
apricornID = 3
|
|
Case 97
|
|
apricornID = 4
|
|
Case 99
|
|
apricornID = 5
|
|
Case 101
|
|
apricornID = 6
|
|
End Select
|
|
|
|
If Core.Player.Inventory.GetItemAmount(CInt(b.AdditionalValue)) > CInt(Me.Apricorns(apricornID)) Then
|
|
Me.Apricorns(apricornID) = CStr(CInt(Me.Apricorns(apricornID)) + 1)
|
|
|
|
If HasApricorns() = True Then
|
|
For Each Button As ButtonIcon In Me.Buttons
|
|
If Button.AdditionalValue = "OK" Then
|
|
Button.Enabled = True
|
|
End If
|
|
Next
|
|
End If
|
|
End If
|
|
|
|
AdjustButtonTexts()
|
|
End Sub
|
|
|
|
Private Sub AdjustButtonTexts()
|
|
For Each b As ButtonIcon In Buttons
|
|
If StringHelper.IsNumeric(b.AdditionalValue) Then
|
|
Dim apricornID As Integer = 0
|
|
|
|
Select Case CInt(b.AdditionalValue)
|
|
Case 85
|
|
apricornID = 0
|
|
Case 89
|
|
apricornID = 1
|
|
Case 92
|
|
apricornID = 2
|
|
Case 93
|
|
apricornID = 3
|
|
Case 97
|
|
apricornID = 4
|
|
Case 99
|
|
apricornID = 5
|
|
Case 101
|
|
apricornID = 6
|
|
End Select
|
|
|
|
b.Text = Me.Apricorns(apricornID) & " / " & Core.Player.Inventory.GetItemAmount(CInt(b.AdditionalValue))
|
|
End If
|
|
Next
|
|
End Sub
|
|
|
|
Private Sub ClearApricorns()
|
|
Me.Apricorns = {"0", "0", "0", "0", "0", "0", "0"}.ToList()
|
|
|
|
AdjustButtonTexts()
|
|
End Sub
|
|
|
|
Private Sub Give()
|
|
Me.State = States.Wait
|
|
|
|
Core.Player.Inventory.RemoveItem(85, CInt(Me.Apricorns(0)))
|
|
Core.Player.Inventory.RemoveItem(89, CInt(Me.Apricorns(1)))
|
|
Core.Player.Inventory.RemoveItem(92, CInt(Me.Apricorns(2)))
|
|
Core.Player.Inventory.RemoveItem(93, CInt(Me.Apricorns(3)))
|
|
Core.Player.Inventory.RemoveItem(97, CInt(Me.Apricorns(4)))
|
|
Core.Player.Inventory.RemoveItem(99, CInt(Me.Apricorns(5)))
|
|
Core.Player.Inventory.RemoveItem(101, CInt(Me.Apricorns(6)))
|
|
|
|
Dim d As Date = Date.Now
|
|
|
|
Dim s As String = "{" & Me.owner & "|" &
|
|
Me.Apricorns(0) & "," &
|
|
Me.Apricorns(1) & "," &
|
|
Me.Apricorns(2) & "," &
|
|
Me.Apricorns(3) & "," &
|
|
Me.Apricorns(4) & "," &
|
|
Me.Apricorns(5) & "," &
|
|
Me.Apricorns(6) & "|" &
|
|
d.Year & "," & d.Month & "," & d.Day & "," & d.Hour & "," & d.Minute & "," & d.Second & "}"
|
|
|
|
If Core.Player.ApricornData <> "" Then
|
|
Core.Player.ApricornData &= Environment.NewLine
|
|
End If
|
|
|
|
Core.Player.ApricornData &= s
|
|
End Sub
|
|
|
|
Private Sub Take()
|
|
Me.State = States.CanGive
|
|
|
|
Dim text As String = Core.Player.Name & Localization.GetString("apricorn_screen_obtain")
|
|
|
|
If CInt(Apricorns(0)) > 0 Then
|
|
Core.Player.Inventory.AddItem(159, CInt(Apricorns(0)))
|
|
text &= "~" & Apricorns(0) & " " & Item.GetItemByID(159).Name
|
|
End If
|
|
If CInt(Apricorns(1)) > 0 Then
|
|
Core.Player.Inventory.AddItem(160, CInt(Apricorns(1)))
|
|
text &= ",~" & Apricorns(1) & " " & Item.GetItemByID(160).Name
|
|
End If
|
|
If CInt(Apricorns(2)) > 0 Then
|
|
Core.Player.Inventory.AddItem(165, CInt(Apricorns(2)))
|
|
text &= ",~" & Apricorns(2) & " " & Item.GetItemByID(165).Name
|
|
End If
|
|
If CInt(Apricorns(3)) > 0 Then
|
|
Core.Player.Inventory.AddItem(164, CInt(Apricorns(3)))
|
|
text &= ",~" & Apricorns(3) & " " & Item.GetItemByID(164).Name
|
|
End If
|
|
If CInt(Apricorns(4)) > 0 Then
|
|
Core.Player.Inventory.AddItem(161, CInt(Apricorns(4)))
|
|
text &= ",~" & Apricorns(4) & " " & Item.GetItemByID(161).Name
|
|
End If
|
|
If CInt(Apricorns(5)) > 0 Then
|
|
Core.Player.Inventory.AddItem(157, CInt(Apricorns(5)))
|
|
text &= ",~" & Apricorns(5) & " " & Item.GetItemByID(157).Name
|
|
End If
|
|
If CInt(Apricorns(6)) > 0 Then
|
|
Core.Player.Inventory.AddItem(166, CInt(Apricorns(6)))
|
|
text &= ",~" & Apricorns(6) & " " & Item.GetItemByID(166).Name
|
|
End If
|
|
|
|
text &= "."
|
|
ClearApricorns()
|
|
|
|
Dim s As String = ""
|
|
Dim Data() As String = Core.Player.ApricornData.SplitAtNewline()
|
|
|
|
For i = 0 To Data.Count() - 1
|
|
If Data(i).StartsWith("{" & Me.owner & "|") = False Then
|
|
If s <> "" Then
|
|
s &= Environment.NewLine
|
|
End If
|
|
s &= Data(i)
|
|
End If
|
|
Next
|
|
|
|
Core.Player.ApricornData = s
|
|
|
|
TextBox.Show(text, {}, True, False)
|
|
End Sub
|
|
|
|
Private Function HasApricorns() As Boolean
|
|
For i = 0 To 6
|
|
If CInt(Apricorns(i)) > 0 Then
|
|
Return True
|
|
End If
|
|
Next
|
|
|
|
Return False
|
|
End Function
|
|
|
|
Private Sub GetSavedApricorns()
|
|
ClearApricorns()
|
|
|
|
If Core.Player.ApricornData <> "" Then
|
|
Dim ApricornsData As List(Of String) = Core.Player.ApricornData.SplitAtNewline().ToList()
|
|
|
|
For i = 0 To ApricornsData.Count - 1
|
|
If i < ApricornsData.Count Then
|
|
Dim Apricorn As String = ApricornsData(i)
|
|
|
|
Apricorn = Apricorn.Remove(0, 1)
|
|
Apricorn = Apricorn.Remove(Apricorn.Length - 1, 1)
|
|
|
|
Dim ApricornData() As String = Apricorn.Split(CChar("|"))
|
|
|
|
If ApricornData(0) = Me.owner Then
|
|
Me.Apricorns = ApricornData(1).Split(CChar(",")).ToList()
|
|
End If
|
|
End If
|
|
Next
|
|
End If
|
|
End Sub
|
|
|
|
Private Function CheckApricornStatus() As Integer
|
|
Dim diff As Integer = 1440
|
|
|
|
If Core.Player.ApricornData <> "" Then
|
|
Dim ApricornsData As List(Of String) = Core.Player.ApricornData.SplitAtNewline().ToList()
|
|
|
|
For i = 0 To ApricornsData.Count - 1
|
|
If i < ApricornsData.Count Then
|
|
Dim Apricorn As String = ApricornsData(i)
|
|
|
|
Apricorn = Apricorn.Remove(0, 1)
|
|
Apricorn = Apricorn.Remove(Apricorn.Length - 1, 1)
|
|
|
|
Dim ApricornData() As String = Apricorn.Split(CChar("|"))
|
|
|
|
If ApricornData(0) = Me.owner Then
|
|
Dim d() As String = ApricornData(2).Split(CChar(","))
|
|
Dim gaveDate As Date = New Date(CInt(d(0)), CInt(d(1)), CInt(d(2)), CInt(d(3)), CInt(d(4)), CInt(d(5)))
|
|
|
|
diff = CInt((Date.Now - gaveDate).TotalMinutes)
|
|
End If
|
|
End If
|
|
Next
|
|
End If
|
|
|
|
Return diff
|
|
End Function
|
|
|
|
Private Class Label
|
|
|
|
Public Position As Vector2
|
|
Public Text As String
|
|
Public ForeColor As Color = Color.Black
|
|
Public Font As SpriteFont
|
|
|
|
Public Sub New(ByVal Text As String, ByVal Position As Vector2, ByVal Font As SpriteFont)
|
|
Me.New(Text, Position, Color.Black, Font)
|
|
End Sub
|
|
|
|
Public Sub New(ByVal Text As String, ByVal Position As Vector2, ByVal ForeColor As Color, ByVal Font As SpriteFont)
|
|
Me.Position = Position
|
|
Me.Text = Text
|
|
Me.ForeColor = ForeColor
|
|
Me.Font = Font
|
|
End Sub
|
|
|
|
Public Sub Draw()
|
|
Core.SpriteBatch.DrawString(Me.Font, Me.Text, Me.Position, Me.ForeColor)
|
|
End Sub
|
|
|
|
End Class
|
|
|
|
Public Class ButtonIcon
|
|
|
|
Public Delegate Sub DoOnClick(ByVal e As ButtonIcon)
|
|
|
|
Public Text As String
|
|
Public Font As SpriteFont
|
|
Public Position As Vector2
|
|
Public Texture As Texture2D
|
|
Public TextureRectangle As Rectangle
|
|
Public Size As Size
|
|
Public AdditionalValue As String = ""
|
|
Public Enabled As Boolean = True
|
|
|
|
Dim State As Integer = 0
|
|
|
|
Dim DoSub As DoOnClick
|
|
|
|
Public Sub New(ByVal DoOnClick As DoOnClick, ByVal Text As String, ByVal Font As SpriteFont, ByVal Texture As Texture2D, ByVal TextureRectangle As Rectangle, ByVal Position As Vector2, ByVal Size As Size, Optional ByVal AdditionalValue As String = "")
|
|
Me.DoSub = DoOnClick
|
|
|
|
Me.Text = Text
|
|
Me.Font = Font
|
|
Me.Position = Position
|
|
Me.Size = Size
|
|
|
|
Me.Texture = Texture
|
|
Me.TextureRectangle = TextureRectangle
|
|
Me.AdditionalValue = AdditionalValue
|
|
End Sub
|
|
|
|
Public Sub Update()
|
|
If Enabled = True Then
|
|
Dim MousePosition As Point = New Point(MouseHandler.MousePosition.X, MouseHandler.MousePosition.Y)
|
|
Me.State = 0
|
|
|
|
If New Rectangle(CInt(Me.Position.X), CInt(Me.Position.Y), Me.Size.Width, Me.Size.Height).Contains(MousePosition) = True Then
|
|
If MouseHandler.ButtonPressed(MouseHandler.MouseButtons.LeftButton) = True Then
|
|
Me.DoSub(Me)
|
|
Else
|
|
If MouseHandler.ButtonDown(MouseHandler.MouseButtons.LeftButton) = True Then
|
|
State = 2
|
|
Else
|
|
State = 1
|
|
End If
|
|
End If
|
|
End If
|
|
End If
|
|
End Sub
|
|
|
|
Public Sub Draw()
|
|
Dim bColor As Color = New Color(Color.White.R - (State * 50), Color.White.G - (State * 50), Color.White.B - (State * 50))
|
|
|
|
If Me.Enabled = False Then
|
|
bColor = Color.DarkGray
|
|
End If
|
|
|
|
Core.SpriteBatch.Draw(Me.Texture, New Rectangle(CInt(Me.Position.X), CInt(Me.Position.Y), Me.Size.Width, Me.Size.Height), TextureRectangle, bColor)
|
|
|
|
Dim TextSize As Vector2 = Font.MeasureString(Me.Text)
|
|
Dim TColor As Color = Color.Black
|
|
Core.SpriteBatch.DrawString(Me.Font, Me.Text, New Vector2(CInt(Me.Size.Width / 2) - CInt(TextSize.X / 2) + Me.Position.X, Me.Size.Height + Me.Position.Y), TColor)
|
|
End Sub
|
|
|
|
Public Sub Click()
|
|
Me.DoSub(Me)
|
|
End Sub
|
|
|
|
End Class
|
|
|
|
End Class |