P3D-Legacy/P3D/Network/GameJolt/GTS/GTSSetupScreen.vb

1486 lines
73 KiB
VB.net

Namespace GameJolt
Public Class GTSSetupScreen
Inherits Screen
Dim SetupList As New List(Of GTSDataItem)
Dim loaded As Boolean = False
Dim Selected As Integer = -1
Dim ScrollIndex As Integer = 0
Dim Emblem As Emblem = Nothing
Public Sub New(ByVal currentScreen As Screen)
Me.PreScreen = currentScreen
Me.Identification = Identifications.GTSSetupScreen
Me.CanBePaused = False
Me.CanChat = False
Me.CanDrawDebug = True
Me.CanMuteMusic = True
Me.CanTakeScreenshot = True
Me.MouseVisible = True
End Sub
Dim TempPokemon As Pokemon = Nothing
Private Sub DrawStringC(ByVal t As String, ByVal p As Vector2)
Core.SpriteBatch.DrawString(FontManager.MiniFont, t, New Vector2(p.X + 2, p.Y + 2), Color.Black)
Core.SpriteBatch.DrawString(FontManager.MiniFont, t, p, Color.White)
End Sub
Public Overrides Sub Draw()
Core.SpriteBatch.Draw(TextureManager.GetTexture("GUI\Menus\GTS"), Core.windowSize, New Rectangle(320, 176, 192, 160), Color.White)
For Each F As Furr In GTSMainScreen.Furrs
F.Draw()
Next
If Me.IsCurrentScreen() = True Then
Core.SpriteBatch.DrawString(FontManager.InGameFont, "Setup", New Vector2(132, 100), Color.White)
Core.SpriteBatch.Draw(TextureManager.GetTexture("GUI\Menus\GTS"), New Rectangle(CInt(Core.windowSize.Width / 2 - 104), CInt(32), 208, 96), New Rectangle(304, 0, 208, 96), Color.White)
End If
If Working = False And Received = Lines Then
If Me.IsCurrentScreen() = True Then
If SetupList.Count > 0 Then
For i = ScrollIndex To ScrollIndex + 5
If i < SetupList.Count Then
Dim Y As Integer = 132 + (i - ScrollIndex) * 64
Dim D As GTSDataItem = SetupList(i)
Dim Touching As Boolean = New Rectangle(116, Y + 16, 64, 64).Contains(MouseHandler.MousePosition)
Dim C As Color = New Color(255, 255, 255, 150)
If i = Me.Selected Then
C = New Color(0, 217, 237)
End If
If Touching = True Then
C = Color.White
End If
If i = Me.Selected Then
Canvas.DrawRectangle(New Rectangle(142, Y + 32, 358, 32), C)
Else
Canvas.DrawRectangle(New Rectangle(142, Y + 32, 320, 32), C)
End If
Core.SpriteBatch.Draw(TextureManager.GetTexture("GUI\Menus\GTS"), New Rectangle(100, Y, 96, 96), New Rectangle(320, 96, 48, 48), Color.White)
Core.SpriteBatch.Draw(D.Pokemon.GetMenuTexture(), New Rectangle(116, Y + 16, 64, 64), C)
Core.SpriteBatch.DrawString(FontManager.MiniFont, D.Pokemon.GetDisplayName(), New Vector2(198, Y + 37), Color.Black)
Core.SpriteBatch.DrawString(FontManager.MiniFont, "Lv. " & D.Pokemon.Level, New Vector2(360, Y + 37), Color.Black)
End If
Next
Else
DrawStringC("There are no Pokémon setup for trade.", New Vector2(132, 160))
End If
If CanSetup() = True Then
DrawButton(New Vector2(180, 200 + (SetupList.Count - ScrollIndex) * 64), "Setup new trade", 4)
End If
If Selected > -1 Then
Dim D As GTSDataItem = Me.SetupList(Selected)
Canvas.DrawRectangle(New Rectangle(500, 164, 600, 500), New Color(255, 255, 255, 150))
If D.TradeID <> "" Then
Core.SpriteBatch.DrawString(FontManager.MiniFont, "Transaction ID: " & D.TradeID, New Vector2(510, 166), Color.Black)
End If
'Pokemon image/data:
Core.SpriteBatch.Draw(D.Pokemon.GetTexture(True), New Rectangle(500, 164, 128, 128), Color.White)
If D.Pokemon.GetDisplayName() <> D.Pokemon.OriginalName Then
Core.SpriteBatch.DrawString(FontManager.MainFont, D.Pokemon.GetDisplayName(), New Vector2(630, 190), Color.Black)
Core.SpriteBatch.DrawString(FontManager.MainFont, "/" & D.Pokemon.OriginalName, New Vector2(640, 220), Color.Black)
Else
Core.SpriteBatch.DrawString(FontManager.MainFont, D.Pokemon.GetDisplayName(), New Vector2(630, 205), Color.Black)
End If
Dim ItemString As String = "None"
If Not D.Pokemon.Item Is Nothing Then
ItemString = " " & D.Pokemon.Item.Name
Core.SpriteBatch.Draw(D.Pokemon.Item.Texture, New Rectangle(882, 314, 24, 24), Color.White)
End If
Core.SpriteBatch.DrawString(FontManager.MiniFont, "Level: " & D.Pokemon.Level & Environment.NewLine & Environment.NewLine &
"Gender: " & D.Pokemon.Gender.ToString() & Environment.NewLine & Environment.NewLine &
"OT: " & D.Pokemon.CatchTrainerName & "/" & D.Pokemon.OT & Environment.NewLine & Environment.NewLine &
"Item: " & ItemString & Environment.NewLine & Environment.NewLine &
"Message: " & Environment.NewLine & D.Message, New Vector2(524, 360), Color.Black)
'Stars:
GTSMainScreen.DrawStars(D.Pokemon.TradeValue, New Vector2(630, 256))
'RequestPokemon:
Dim p As Pokemon = TempPokemon
Core.SpriteBatch.Draw(p.GetTexture(True), New Rectangle(800, 164, 128, 128), Color.White)
If D.Pokemon.GetDisplayName() <> p.OriginalName Then
Core.SpriteBatch.DrawString(FontManager.MainFont, p.GetDisplayName(), New Vector2(930, 190), Color.Black)
Core.SpriteBatch.DrawString(FontManager.MainFont, "/" & p.OriginalName, New Vector2(940, 220), Color.Black)
Else
Core.SpriteBatch.DrawString(FontManager.MainFont, p.GetDisplayName(), New Vector2(930, 205), Color.Black)
End If
Core.SpriteBatch.DrawString(FontManager.MiniFont, "Request:" & Environment.NewLine & Environment.NewLine &
"Number: " & D.RequestID & Environment.NewLine & Environment.NewLine &
"Level: " & D.RequestLevel & Environment.NewLine & Environment.NewLine &
"Gender: " & D.RequestGender, New Vector2(824, 360), Color.Black)
'Stars:
GTSMainScreen.DrawStars(p.TradeValue, New Vector2(930, 256))
'From:
If Core.Player.IsGameJoltSave = True Then
Core.SpriteBatch.DrawString(FontManager.MiniFont, "From:", New Vector2(516, 320), Color.Black)
Dim ownEmblem As Emblem = New Emblem(API.username, Core.GameJoltSave.GameJoltID, Core.GameJoltSave.Points, Core.GameJoltSave.Gender, Core.GameJoltSave.Emblem)
Dim SpriteSize As New Size(CInt(ownEmblem.SpriteTexture.Width / 3), CInt(ownEmblem.SpriteTexture.Height / 4))
Core.SpriteBatch.Draw(ownEmblem.SpriteTexture, New Rectangle(564, 310, 32, 32), New Rectangle(0, SpriteSize.Height * 2, SpriteSize.Width, SpriteSize.Height), Color.White)
Core.SpriteBatch.DrawString(FontManager.MiniFont, ownEmblem.Username & " (" & ownEmblem.GameJoltID & ")", New Vector2(600, 320), Color.Black)
End If
'To:
Core.SpriteBatch.DrawString(FontManager.MiniFont, "To:", New Vector2(816, 320), Color.Black)
If SetupList(Selected).SecurityArea = GTSDataItem.SecurityCode.Private Then
If Not Emblem Is Nothing Then
If Emblem.DoneLoading = True Then
Dim SpriteSize As New Size(CInt(Emblem.SpriteTexture.Width / 3), CInt(Emblem.SpriteTexture.Height / 4))
Core.SpriteBatch.Draw(Emblem.SpriteTexture, New Rectangle(854, 310, 32, 32), New Rectangle(0, SpriteSize.Height * 2, SpriteSize.Width, SpriteSize.Height), Color.White)
Core.SpriteBatch.DrawString(FontManager.MiniFont, Emblem.Username & " (" & Emblem.GameJoltID & ")", New Vector2(890, 320), Color.Black)
Else
Core.SpriteBatch.DrawString(FontManager.MiniFont, "Loading" & LoadingDots.Dots, New Vector2(864, 320), Color.Black)
End If
Else
Core.SpriteBatch.DrawString(FontManager.MiniFont, "Loading" & LoadingDots.Dots, New Vector2(864, 320), Color.Black)
End If
Else
Core.SpriteBatch.DrawString(FontManager.MiniFont, "Global", New Vector2(864, 320), Color.Black)
End If
'Buttons:
DrawButton(New Vector2(600, 610), "Change", 3)
If Core.Player.Pokemons.Count < 6 Then
DrawButton(New Vector2(800, 610), "Withdraw", 3)
End If
End If
If Core.Player.Pokemons.Count > 6 Then
Canvas.DrawScrollBar(New Vector2(90, 96 + 54), Me.SetupList.Count, 6, ScrollIndex, New Size(6, 380), False, New Color(4, 84, 157), New Color(125, 214, 234))
End If
End If
Else
DrawStringC("Loading" & LoadingDots.Dots, New Vector2(132, 160))
DrawStringC("Please wait.", New Vector2(240, 160))
End If
Core.SpriteBatch.DrawString(FontManager.MiniFont, "Version " & GTSMainScreen.GTSVersion, New Vector2(4, Core.windowSize.Height - 1 - FontManager.MiniFont.MeasureString("Version " & GTSMainScreen.GTSVersion).Y), Color.DarkGray)
End Sub
Private Sub DrawButton(ByVal Position As Vector2, ByVal Text As String, ByVal Size As Integer)
Dim t As Texture2D = TextureManager.GetTexture("GUI\Menus\GTS")
Dim touching As Boolean = New Rectangle(CInt(Position.X), CInt(Position.Y), 64 + Size * 32, 32).Contains(MouseHandler.MousePosition)
Dim Y As Integer = 0
If touching = True Then
Y = 16
End If
Core.SpriteBatch.Draw(t, New Rectangle(CInt(Position.X), CInt(Position.Y), 32, 32), New Rectangle(0, Y, 16, 16), Color.White)
For i = 1 To Size
Core.SpriteBatch.Draw(t, New Rectangle(CInt(Position.X + i * 32), CInt(Position.Y), 32, 32), New Rectangle(16, Y, 16, 16), Color.White)
Next
Core.SpriteBatch.Draw(t, New Rectangle(CInt(Position.X + Size * 32 + 32), CInt(Position.Y), 32, 32), New Rectangle(32, Y, 16, 16), Color.White)
Dim sizeX As Integer = Size * 32 + 64
Dim TextSizeX As Integer = CInt(FontManager.MiniFont.MeasureString(Text).X)
Core.SpriteBatch.DrawString(FontManager.MiniFont, Text, New Vector2(CSng(Position.X + sizeX / 2 - TextSizeX / 2 - 2), Position.Y + 4), Color.Black)
End Sub
Private Function CanSetup() As Boolean
If Me.SetupList.Count < 6 And Core.Player.CountFightablePokemon > 1 Then
Return True
End If
Return False
End Function
Public Overrides Sub Update()
For i = 0 To GTSMainScreen.Furrs.Count - 1
If i < GTSMainScreen.Furrs.Count Then
Dim f As Furr = GTSMainScreen.Furrs(i)
If f.IsOutOfBorder() = True Then
GTSMainScreen.Furrs.Remove(f)
i -= 1
Else
f.Update()
End If
End If
Next
If Core.Random.Next(0, 100) = 0 Then
GTSMainScreen.Furrs.Add(New Furr())
End If
SetupList = (From d As GTSDataItem In SetupList Order By CInt(d.TradeID) Ascending).ToList()
If loaded = False Then
loaded = True
Selected = -1
Me.SetupList.Clear()
Working = True
Dim APICall As New APICall(AddressOf GotKeys)
APICall.GetKeys(False, "GTSTradeV" & GTSMainScreen.GTSVersion & "|Set|" & Core.GameJoltSave.GameJoltID & "|*|*|*|Pokemon 3D|*|*")
Else
If Working = False And Received = Lines Then
If Me.SetupList.Count > 0 Then
For i = 0 To 5
If i < Me.SetupList.Count Then
If New Rectangle(116, 148 + i * 64, 64, 64).Contains(MouseHandler.MousePosition) = True Then
If Controls.Accept(True, True) = True Then
If Selected = i + ScrollIndex Then
Selected = -1
Else
Selected = i + ScrollIndex
TempPokemon = Pokemon.GetPokemonByID(CInt(SetupList(Selected).RequestID))
If SetupList(Selected).SecurityArea = GTSDataItem.SecurityCode.Private Then
Emblem = New Emblem(SetupList(Selected).ToUserID, 0)
End If
End If
End If
End If
End If
Next
If SetupList.Count > 6 Then
If Controls.Up(True, True, True, True) = True Then
If Controls.ShiftDown() = True Then
Me.ScrollIndex -= 5
Else
Me.ScrollIndex -= 1
End If
End If
If Controls.Down(True, True, True, True) = True Then
If Controls.ShiftDown() = True Then
Me.ScrollIndex += 5
Else
Me.ScrollIndex += 1
End If
End If
Me.ScrollIndex = ScrollIndex.Clamp(0, Me.SetupList.Count - 6)
End If
If Selected > -1 Then
If New Rectangle(600, 610, 32 * 3 + 64, 32).Contains(MouseHandler.MousePosition) = True Then
If Controls.Accept(True, False) = True Then
Core.SetScreen(New GTSEditTradeScreen(Me, SetupList(Selected)))
End If
End If
If New Rectangle(800, 610, 32 * 3 + 64, 32).Contains(MouseHandler.MousePosition) = True Then
If Controls.Accept(True, False) = True Then
If Core.Player.Pokemons.Count < 6 Then
Working = True
FetchBack = Me.SetupList(Selected)
Dim APICall As New APICall(AddressOf FetchTradeBack)
APICall.RemoveKey(Me.SetupList(Selected).Key, False)
End If
End If
End If
End If
End If
If CanSetup() = True Then
If New Rectangle(180, 200 + (SetupList.Count - ScrollIndex) * 64, 32 * 4 + 64, 32).Contains(MouseHandler.MousePosition) = True Then
If Controls.Accept(True, False) = True Then
Core.SetScreen(New GTSEditTradeScreen(Me, Nothing))
End If
End If
End If
If Controls.Dismiss(True, True) = True Then
If Selected > -1 Then
Selected = -1
Else
Core.SetScreen(Me.PreScreen)
End If
End If
End If
End If
End Sub
Dim Lines As Integer = 0
Dim Received As Integer = 0
Dim Working As Boolean = True
Dim BufferList As New Dictionary(Of String, String)
Private Sub GotKeys(ByVal result As String)
Dim l As List(Of API.JoltValue) = API.HandleData(result)
Lines = l.Count - 1
Received = 0
Working = False
If l(1).Value <> "" Then
For Each Item As API.JoltValue In l
If Item.Name.ToLower() = "key" Then
If BufferList.ContainsKey(Item.Value) = True Then
GotData("success:""true""" & Environment.NewLine & "data:""" & BufferList(Item.Value) & """")
Else
Dim APICall As New APICall(AddressOf GotData)
APICall.GetStorageData(Item.Value, False)
End If
End If
Next
Else
Lines = 0
End If
End Sub
Private Sub GotData(ByVal result As String)
Dim l As List(Of API.JoltValue) = API.HandleData(result)
Dim data As String = l(1).Value
Dim D As New GTSDataItem(data)
If BufferList.ContainsKey(D.Key) = False Then
BufferList.Add(D.Key, data)
End If
Received += 1
Me.SetupList.Add(D)
End Sub
Dim FetchBack As GTSDataItem = Nothing
Private Sub FetchTradeBack(ByVal result As String)
Core.Player.Pokemons.Add(FetchBack.Pokemon)
Core.Player.SaveGame(False)
loaded = False
End Sub
Class GTSEditTradeScreen
Inherits Screen
Dim D As GTSDataItem
Dim NewTrade As Boolean = False
Dim GTSSetupScreen As GTSSetupScreen
Dim ToEmblem As Emblem = Nothing
Dim TempPokemon As Pokemon = Nothing
Dim PaidStars As Integer = 0
Public Sub New(ByVal GTSSetupScreen As GTSSetupScreen, ByVal D As GTSDataItem)
Me.GTSSetupScreen = GTSSetupScreen
If Not D Is Nothing Then
Me.D = D
NewTrade = False
If D.RequestID <> "" Then
TempPokemon = Pokemon.GetPokemonByID(CInt(D.RequestID))
If D.SecurityArea = GTSDataItem.SecurityCode.Global Then
Dim v As Integer = TempPokemon.TradeValue - D.Pokemon.TradeValue
If v.ToString().EndsWith("5") = True Then
v += 5
End If
If v > 0 Then
PaidStars = v
End If
End If
End If
Else
Me.D = New GTSDataItem(Core.GameJoltSave.GameJoltID, "", "", "9 and under", "", "", "", "Pokemon 3D", "", GTSDataItem.SecurityCode.Global, GTSDataItem.ActionSwitches.Set, "")
NewTrade = True
End If
Me.Identification = Identifications.GTSEditTradeScreen
Me.CanBePaused = False
Me.CanChat = False
Me.CanDrawDebug = True
Me.CanMuteMusic = True
Me.CanTakeScreenshot = True
Me.MouseVisible = True
End Sub
Public Overrides Sub Draw()
Me.GTSSetupScreen.Draw()
If Uploading = True Then
Canvas.DrawRectangle(New Rectangle(CInt(Core.windowSize.Width / 2 - 200), 250, 400, 200), New Color(255, 255, 255, 150))
Core.SpriteBatch.DrawString(FontManager.MainFont, "Uploading" & LoadingDots.Dots, New Vector2(CSng(Core.windowSize.Width / 2 - FontManager.MainFont.MeasureString("Uploading").X / 2), 300), Color.Black)
If AssignedTradeID = True Then
Core.SpriteBatch.DrawString(FontManager.MainFont, "Transaction ID: " & NewTradeID, New Vector2(CSng(Core.windowSize.Width / 2 - FontManager.MainFont.MeasureString("Transaction ID: " & NewTradeID).X / 2), 370), Color.Black)
End If
Exit Sub
End If
Canvas.DrawRectangle(New Rectangle(50, 100, 320, 500), New Color(255, 255, 255, 150))
Canvas.DrawRectangle(New Rectangle(400, 100, 750, 500), New Color(255, 255, 255, 150))
If Not D.Pokemon Is Nothing Then
Core.SpriteBatch.Draw(D.Pokemon.GetTexture(True), New Rectangle(50, 120, 128, 128), Color.White)
If D.Pokemon.GetDisplayName() <> D.Pokemon.OriginalName Then
Core.SpriteBatch.DrawString(FontManager.MainFont, D.Pokemon.GetDisplayName(), New Vector2(180, 146), Color.Black)
Core.SpriteBatch.DrawString(FontManager.MainFont, "/" & D.Pokemon.OriginalName, New Vector2(190, 176), Color.Black)
Else
Core.SpriteBatch.DrawString(FontManager.MainFont, D.Pokemon.GetDisplayName(), New Vector2(180, 161), Color.Black)
End If
Dim ItemString As String = "None"
If Not D.Pokemon.Item Is Nothing Then
ItemString = " " & D.Pokemon.Item.Name
Core.SpriteBatch.Draw(D.Pokemon.Item.Texture, New Rectangle(124, 475, 24, 24), Color.White)
End If
Core.SpriteBatch.DrawString(FontManager.MiniFont, "Level: " & D.Pokemon.Level & Environment.NewLine & Environment.NewLine &
"Gender: " & D.Pokemon.Gender.ToString() & Environment.NewLine & Environment.NewLine &
"OT: " & D.Pokemon.CatchTrainerName & "/" & D.Pokemon.OT & Environment.NewLine & Environment.NewLine &
"Item: " & ItemString, New Vector2(74, 356), Color.Black)
'Stars:
GTSMainScreen.DrawStars(D.Pokemon.TradeValue, New Vector2(180, 222))
End If
DrawButton(New Vector2(100, 300), "Choose Pokémon", 5)
If D.TradeID <> "" Then
Core.SpriteBatch.DrawString(FontManager.MiniFont, "Transaction ID: " & D.TradeID, New Vector2(925, 102), Color.Black)
End If
Core.SpriteBatch.DrawString(FontManager.MainFont, "Request:", New Vector2(420, 140), Color.Black)
If StringHelper.IsNumeric(D.RequestID) = True Then
DrawFilter(New Vector2(420, 200), 4, "Pokémon:", Pokemon.GetPokemonByID(CInt(D.RequestID)).GetDisplayName() & " (" & D.RequestID & ")")
Else
DrawFilter(New Vector2(420, 200), 4, "Pokémon:", "")
End If
DrawFilter(New Vector2(420, 280), 4, "Level:", D.RequestLevel)
DrawFilter(New Vector2(420, 360), 4, "Gender:", D.RequestGender)
DrawFilter(New Vector2(600, 200), 4, "Area:", D.SecurityArea.ToString())
If D.SecurityArea = GTSDataItem.SecurityCode.Private Then
Dim RecipientName As String = ""
If Not Me.ToEmblem Is Nothing Then
RecipientName = Me.ToEmblem.Username
End If
DrawFilter(New Vector2(600, 280), 4, "To (" & D.ToUserID & "):", RecipientName)
End If
If StringHelper.IsNumeric(D.RequestID) = True Then
If CInt(D.RequestID) > 0 Then
If TempPokemon Is Nothing OrElse TempPokemon.Number <> CInt(D.RequestID) Then
TempPokemon = Pokemon.GetPokemonByID(CInt(D.RequestID))
End If
Dim p As Pokemon = TempPokemon
Core.SpriteBatch.Draw(p.GetTexture(True), New Rectangle(800, 120, 128, 128), Color.White)
Core.SpriteBatch.DrawString(FontManager.MainFont, p.OriginalName, New Vector2(180 + 750, 176), Color.Black)
'Stars:
GTSMainScreen.DrawStars(p.TradeValue, New Vector2(930, 222))
'If Not D.Pokemon Is Nothing Then
' If p.TradeValue > D.Pokemon.TradeValue And D.SecurityArea = GTSDataItem.SecurityCode.Global Then
' Basic.SpriteBatch.DrawString(Basic.miniFont, "Needed stars:", New Vector2(780, 280), Color.Black)
' Dim v As Integer = p.TradeValue - D.Pokemon.TradeValue
' If v.ToString().EndsWith("5") = True Then
' v += 5
' End If
' GTSMainScreen.DrawStars(v, New Vector2(780, 314))
' If PaidStars > 0 Then
' Basic.SpriteBatch.DrawString(Basic.miniFont, "Paid stars:", New Vector2(780, 380), Color.Black)
' GTSMainScreen.DrawStars(PaidStars, New Vector2(780, 414))
' Basic.SpriteBatch.DrawString(Basic.miniFont, "Additional stars:", New Vector2(970, 380), Color.Black)
' If v - PaidStars > 0 Then
' GTSMainScreen.DrawStars(v - PaidStars, New Vector2(970, 414))
' End If
' End If
' Basic.SpriteBatch.DrawString(Basic.miniFont, "Your stars:", New Vector2(970, 280), Color.Black)
' GTSMainScreen.DrawStars(Basic.Player.GTSStars * 10, New Vector2(970, 314))
' End If
'End If
End If
End If
If TradeReady() = True Then
If NewTrade = True Then
If IsPresent() = True Then
If Not ToEmblem Is Nothing And Not D.Pokemon Is Nothing Then
Core.SpriteBatch.DrawString(FontManager.MiniFont, "You will send " & D.Pokemon.GetDisplayName() & " to " & Environment.NewLine & ToEmblem.Username & " and you cannot get it back!", New Vector2(480, 495), Color.Black)
End If
DrawButton(New Vector2(480, 540), "Send", 3)
Else
DrawButton(New Vector2(480, 540), "Setup", 3)
End If
Else
DrawButton(New Vector2(480, 540), "Change", 3)
End If
Else
Dim message As String = "1 ERROR"
If Not D.Pokemon Is Nothing Then
If D.RequestID <> "" Then
If D.RequestLevel <> "" Then
If D.Pokemon.IsEgg() = False Then
If D.Pokemon.HasHMMove() = False Then
If D.SecurityArea = GTSDataItem.SecurityCode.Private And D.ToUserID <> "" Or D.SecurityArea = GTSDataItem.SecurityCode.Global Then
Dim v As Integer = TempPokemon.TradeValue - D.Pokemon.TradeValue
If v.ToString().EndsWith("5") = True Then
v += 5
End If
If v - PaidStars > Core.Player.GTSStars * 10 Then
message = "You don't have enough stars!"
End If
Else
message = "Choose recipient!"
End If
Else
message = "Choose a Pokémon without HM moves!"
End If
Else
message = "You can't trade an egg!"
End If
Else
message = "Choose request level cap!"
End If
Else
message = "Choose request Pokémon!"
End If
Else
message = "Choose own Pokémon!"
End If
Core.SpriteBatch.DrawString(FontManager.MiniFont, message, New Vector2(430, 545), Color.Black)
End If
DrawButton(New Vector2(700, 540), "Back", 3)
End Sub
Private Function IsPresent() As Boolean
If D.SecurityArea = GTSDataItem.SecurityCode.Private And D.ToUserID <> "" And D.RequestID = "" Then
Return True
End If
Return False
End Function
Private Function TradeReady() As Boolean
If Not D.Pokemon Is Nothing Then
If D.SecurityArea = GTSDataItem.SecurityCode.Private Then
If D.ToUserID <> "" Then
Return True
End If
Else
If D.RequestID <> "" And D.RequestLevel <> "" And D.Pokemon.IsEgg() = False And D.Pokemon.HasHMMove() = False Then
Return True
'Dim v As Integer = TempPokemon.TradeValue - D.Pokemon.TradeValue
'If v.ToString().EndsWith("5") = True Then
' v += 5
'End If
'Dim HasPermission As Boolean = False
'For Each StaffMember As StaffProfile In StaffProfile.Staff
' If StaffMember.GameJoltID = GamejoltSave.user_id Then
' If StaffMember.StaffAreas.Contains(StaffProfile.StaffArea.GTSAdmin) = True Or StaffMember.StaffAreas.Contains(StaffProfile.StaffArea.GTSDaily) = True Then
' HasPermission = True
' Exit For
' End If
' End If
'Next
'If v - PaidStars <= Basic.Player.GTSStars * 10 Or D.SecurityArea = GTSDataItem.SecurityCode.Private Or HasPermission = True Then
' Return True
'End If
End If
End If
End If
Return False
End Function
Private Sub DrawFilter(ByVal Position As Vector2, ByVal Size As Integer, ByVal Label As String, ByVal Text As String)
Dim TexX As Integer = 368
If New Rectangle(CInt(Position.X), CInt(Position.Y), (Size + 1) * 32, 64).Contains(MouseHandler.MousePosition) = True And Me.IsCurrentScreen() = True Then
TexX = 400
End If
For i = 0 To Size - 1
Core.SpriteBatch.Draw(TextureManager.GetTexture("GUI\Menus\GTS"), New Rectangle(CInt(Position.X + i * 32), CInt(Position.Y), 32, 64), New Rectangle(TexX, 112, 16, 32), Color.White)
Next
Core.SpriteBatch.Draw(TextureManager.GetTexture("GUI\Menus\GTS"), New Rectangle(CInt(Position.X + Size * 32), CInt(Position.Y), 32, 64), New Rectangle(TexX + 16, 112, 16, 32), Color.White)
Core.SpriteBatch.DrawString(FontManager.MiniFont, Label, New Vector2(Position.X + 4, Position.Y + 4), New Color(100, 100, 100))
Core.SpriteBatch.DrawString(FontManager.MiniFont, Text, New Vector2(Position.X + 4, Position.Y + 32), Color.Black)
End Sub
Private Sub DrawButton(ByVal Position As Vector2, ByVal Text As String, ByVal Size As Integer)
Dim t As Texture2D = TextureManager.GetTexture("GUI\Menus\GTS")
Dim touching As Boolean = New Rectangle(CInt(Position.X), CInt(Position.Y), 64 + Size * 32, 32).Contains(MouseHandler.MousePosition)
Dim Y As Integer = 0
If touching = True And Me.IsCurrentScreen() = True Then
Y = 16
End If
Core.SpriteBatch.Draw(t, New Rectangle(CInt(Position.X), CInt(Position.Y), 32, 32), New Rectangle(0, Y, 16, 16), Color.White)
For i = 1 To Size
Core.SpriteBatch.Draw(t, New Rectangle(CInt(Position.X + i * 32), CInt(Position.Y), 32, 32), New Rectangle(16, Y, 16, 16), Color.White)
Next
Core.SpriteBatch.Draw(t, New Rectangle(CInt(Position.X + Size * 32 + 32), CInt(Position.Y), 32, 32), New Rectangle(32, Y, 16, 16), Color.White)
Dim sizeX As Integer = Size * 32 + 64
Dim TextSizeX As Integer = CInt(FontManager.MiniFont.MeasureString(Text).X)
Core.SpriteBatch.DrawString(FontManager.MiniFont, Text, New Vector2(CSng(Position.X + sizeX / 2 - TextSizeX / 2 - 2), Position.Y + 4), Color.Black)
End Sub
Public Overrides Sub Update()
For i = 0 To GTSMainScreen.Furrs.Count - 1
If i < GTSMainScreen.Furrs.Count Then
Dim f As Furr = GTSMainScreen.Furrs(i)
If f.IsOutOfBorder() = True Then
GTSMainScreen.Furrs.Remove(f)
i -= 1
Else
f.Update()
End If
End If
Next
If Core.Random.Next(0, 100) = 0 Then
GTSMainScreen.Furrs.Add(New Furr())
End If
If Uploading = False Then
If D.SecurityArea = GTSDataItem.SecurityCode.Private Then
If D.ToUserID <> "" Then
Dim makeNew As Boolean = False
If Me.ToEmblem Is Nothing Then
makeNew = True
Else
If CInt(Me.ToEmblem.GameJoltID) <> CInt(D.ToUserID) Then
makeNew = True
End If
End If
If makeNew = True Then
ToEmblem = New Emblem(D.ToUserID, 0)
End If
End If
End If
If Controls.Accept(True, False) = True Then
If New Rectangle(420, 200, 5 * 32, 64).Contains(MouseHandler.MousePosition) = True Then
Core.SetScreen(New SelectPokemonScreen(Me, "Request"))
End If
If New Rectangle(420, 280, 5 * 32, 64).Contains(MouseHandler.MousePosition) = True Then
Core.SetScreen(New SelectLevelScreen(Me))
End If
If New Rectangle(420, 360, 5 * 32, 64).Contains(MouseHandler.MousePosition) = True Then
Core.SetScreen(New SelectGenderScreen(Me))
End If
If New Rectangle(600, 200, 5 * 32, 64).Contains(MouseHandler.MousePosition) = True Then
Core.SetScreen(New SelectAreaScreen(Me))
End If
If New Rectangle(600, 280, 5 * 32, 64).Contains(MouseHandler.MousePosition) = True Then
Core.SetScreen(New SelectFriendScreen(Me))
End If
If New Rectangle(100, 300, 32 * 5 + 64, 32).Contains(MouseHandler.MousePosition) = True Then
Dim selScreen = New PartyScreen(Me, Item.GetItemByID(5), AddressOf ChosenPokemon, "Choose Pokémon for Trade", True, True, False) With {.Mode = Screens.UI.ISelectionScreen.ScreenMode.Selection, .CanExit = True}
AddHandler selScreen.SelectedObject, AddressOf ChosenPokemonHandler
Core.SetScreen(selScreen)
CType(Core.CurrentScreen, PartyScreen).CanChooseHMPokemon = False
End If
If New Rectangle(700, 540, 32 * 3 + 64, 32).Contains(MouseHandler.MousePosition) = True Then
Me.GTSSetupScreen.loaded = False
Core.SetScreen(Me.GTSSetupScreen)
End If
If TradeReady() = True AndAlso New Rectangle(480, 540, 32 * 3 + 64, 32).Contains(MouseHandler.MousePosition) = True Then
Uploading = True
AssignedTradeID = False
Dim APICall As New APICall(AddressOf GotTradeID)
APICall.GetStorageData("GTSTRADEID", False)
End If
End If
If Controls.Dismiss(True, True) = True Then
Me.GTSSetupScreen.loaded = False
Core.SetScreen(Me.GTSSetupScreen)
End If
End If
End Sub
Private Sub ChosenPokemonHandler(ByVal params As Object())
ChosenPokemon(CInt(params(0)))
End Sub
Private Sub ChosenPokemon(ByVal PokeIndex As Integer)
If Me.PokeIndex = -1 And NewTrade = False Then
LoadedPokemon = D.Pokemon
End If
Me.PokeIndex = PokeIndex
D.Pokemon = Core.Player.Pokemons(PokeIndex)
D.PokemonData = D.Pokemon.GetSaveData()
End Sub
Dim NewTradeID As String = "1"
Dim AssignedTradeID As Boolean = False
Dim Uploading As Boolean = False
Dim PokeIndex As Integer = -1
Dim LoadedPokemon As Pokemon
Private Sub GotTradeID(ByVal result As String)
Dim l As List(Of API.JoltValue) = API.HandleData(result)
If CBool(l(0).Value) = True Then
NewTradeID = CStr(CDbl(l(1).Value) + 1)
Else
NewTradeID = "1"
End If
AssignedTradeID = True
Logger.Debug("New trade set to: " & NewTradeID)
If NewTrade = False Then
Dim APICall As New APICall(AddressOf KeyRemoved)
APICall.RemoveKey(D.Key, False)
Else
KeyRemoved("success:""true""")
End If
End Sub
Private Sub KeyRemoved(ByVal result As String)
Dim l As List(Of API.JoltValue) = API.HandleData(result)
If CBool(l(0).Value) = True Then
Dim APICall As New APICall()
If IsPresent() = True Then
Dim nD As New GTSDataItem(D.FromUserID, D.ToUserID, "", "", "", "", D.PokemonData, D.GameMode, "Sent as gift.", GTSDataItem.SecurityCode.Private, GTSDataItem.ActionSwitches.Got, NewTradeID)
APICall.SetStorageData(nD.Key, nD.Data, False)
Else
Dim nD As New GTSDataItem(D.FromUserID, D.ToUserID, D.RequestID, D.RequestLevel, D.RequestItemID, D.RequestGender, D.PokemonData, D.GameMode, D.Message, D.SecurityArea, D.ActionSwitch, NewTradeID)
APICall.SetStorageData(nD.Key, nD.Data, False)
End If
If PokeIndex > -1 And NewTrade = False Then
Core.Player.Pokemons.Add(LoadedPokemon)
End If
Dim nAPICall As New APICall(AddressOf UploadComplete)
nAPICall.SetStorageData("GTSTRADEID", NewTradeID, False)
End If
End Sub
Private Sub UploadComplete(ByVal result As String)
Uploading = False
If PokeIndex > -1 Then
Core.Player.Pokemons.RemoveAt(PokeIndex)
End If
If Not TempPokemon Is Nothing Then
Dim v As Integer = TempPokemon.TradeValue - D.Pokemon.TradeValue
If v.ToString().EndsWith("5") = True Then
v += 5
End If
v -= PaidStars
If v > 0 Then
Core.Player.GTSStars -= CInt(v / 10)
End If
End If
Core.Player.SaveGame(False)
Me.GTSSetupScreen.loaded = False
Core.SetScreen(Me.GTSSetupScreen)
End Sub
Class SelectPokemonScreen
Inherits Screen
Dim GTSEditTradeScreen As GTSEditTradeScreen
Dim Mode As String = "Request"
Dim Page As Integer = 0
Dim CurrentPokemon As New SortedDictionary(Of Integer, String)
Dim SpriteList As New List(Of Texture2D)
Shared TempOfferPage As Integer = 0
Shared TempRequestPage As Integer = 0
Public Sub New(ByVal GTSEditTradeScreen As GTSEditTradeScreen, ByVal Mode As String)
Me.GTSEditTradeScreen = GTSEditTradeScreen
Me.Identification = Identifications.GTSSelectPokemonScreen
Me.Mode = Mode
Me.CanBePaused = False
Me.CanChat = False
Me.CanDrawDebug = True
Me.CanMuteMusic = True
Me.CanTakeScreenshot = True
Me.MouseVisible = True
If Me.Mode = "Request" Then
Me.Page = TempRequestPage
ElseIf Me.Mode = "Offer" Then
Me.Page = TempOfferPage
End If
GetPokemon()
End Sub
Private Sub GetPokemon()
CurrentPokemon.Clear()
SpriteList.Clear()
Dim index As Integer = Page * 20
Dim noMorePokemon As Boolean = False
Dim fileList As New List(Of Integer)
Dim d As List(Of String) = System.IO.Directory.GetFiles(GameController.GamePath & "\Content\Pokemon\Data\").ToList()
For Each file As String In d
Dim fileName As String = System.IO.Path.GetFileNameWithoutExtension(file)
If StringHelper.IsNumeric(fileName) = True Then
If CInt(fileName) > 0 And CInt(fileName) <= Pokedex.POKEMONCOUNT Then
If GTSMainScreen.GTSPokemon.Contains(CInt(fileName)) = True Then
fileList.Add(CInt(fileName))
End If
End If
End If
Next
fileList.Sort()
While CurrentPokemon.Count < 20 And noMorePokemon = False
If index <= fileList.Count - 1 Then
Dim fileName As Integer = fileList(index)
Dim p As Pokemon = Pokemon.GetPokemonByID(fileName)
CurrentPokemon.Add(p.Number, p.OriginalName)
SpriteList.Add(p.GetMenuTexture())
index += 1
Else
noMorePokemon = True
End If
End While
End Sub
Public Overrides Sub Draw()
Me.GTSEditTradeScreen.Draw()
Canvas.DrawRectangle(Core.windowSize, New Color(255, 255, 255, 150))
For i = 0 To 19
If i < CurrentPokemon.Count Then
Dim x As Integer = i
Dim y As Integer = 0
While x > 4
x -= 5
y += 1
End While
Dim Number As String = CurrentPokemon.Keys(i).ToString()
While Number.Length < 3
Number = "0" & Number
End While
DrawButton(New Vector2(100 + x * 160, 200 + y * 100), 4, "Pokémon " & Number, CurrentPokemon.Values(i), SpriteList(i))
End If
Next
DrawButton(New Vector2(900, 200), 4, "Navigation", "Last Page", Nothing)
DrawButton(New Vector2(900, 300), 4, "Navigation", "Next Page", Nothing)
DrawButton(New Vector2(900, 400), 4, "Pokémon", "No entry", Nothing)
DrawButton(New Vector2(900, 500), 4, "Navigation", "Back", Nothing)
End Sub
Private Sub DrawButton(ByVal Position As Vector2, ByVal Size As Integer, ByVal Label As String, ByVal Text As String, ByVal Texture As Texture2D)
Dim TexX As Integer = 368
If New Rectangle(CInt(Position.X), CInt(Position.Y), Size * 32, 64).Contains(MouseHandler.MousePosition) = True And Me.IsCurrentScreen() = True Then
TexX = 400
End If
For i = 0 To Size - 1
Core.SpriteBatch.Draw(TextureManager.GetTexture("GUI\Menus\GTS"), New Rectangle(CInt(Position.X + i * 32), CInt(Position.Y), 32, 64), New Rectangle(TexX, 112, 16, 32), Color.White)
Next
If Not Texture Is Nothing Then
Dim s As New Size(Size * 32, 64)
Core.SpriteBatch.Draw(Texture, New Rectangle(CInt(s.Width / 2 - Texture.Width + Position.X), CInt(s.Height / 2 - Texture.Height + Position.Y), Texture.Width * 2, Texture.Height * 2), New Color(255, 255, 255, 100))
End If
Core.SpriteBatch.DrawString(FontManager.MiniFont, Label, New Vector2(Position.X + 4, Position.Y + 4), New Color(100, 100, 100))
Core.SpriteBatch.DrawString(FontManager.MiniFont, Text, New Vector2(Position.X + 4, Position.Y + 32), Color.Black)
End Sub
Public Overrides Sub Update()
For i = 0 To GTSMainScreen.Furrs.Count - 1
If i < GTSMainScreen.Furrs.Count Then
Dim f As Furr = GTSMainScreen.Furrs(i)
If f.IsOutOfBorder() = True Then
GTSMainScreen.Furrs.Remove(f)
i -= 1
Else
f.Update()
End If
End If
Next
If Core.Random.Next(0, 100) = 0 Then
GTSMainScreen.Furrs.Add(New Furr())
End If
If Controls.Accept(True, False) = True Then
For i = 0 To 19
If i < CurrentPokemon.Count Then
Dim x As Integer = i
Dim y As Integer = 0
While x > 4
x -= 5
y += 1
End While
If New Rectangle(100 + x * 160, 200 + y * 100, 32 * 4, 64).Contains(MouseHandler.MousePosition) = True Then
Dim newSetting As String = CurrentPokemon.Values(i) & " (" & CurrentPokemon.Keys(i).ToString() & ")"
If Mode = "Request" Then
Me.GTSEditTradeScreen.D.RequestID = CurrentPokemon.Keys(i).ToString()
ElseIf Mode = "Offer" Then
Me.GTSEditTradeScreen.D.RequestID = CurrentPokemon.Keys(i).ToString()
End If
Close()
End If
End If
Next
If New Rectangle(900, 200, 32 * 4, 64).Contains(MouseHandler.MousePosition) = True Then
If Me.Page > 0 Then
Me.Page -= 1
GetPokemon()
If Me.Mode = "Request" Then
TempRequestPage = Me.Page
ElseIf Me.Mode = "Offer" Then
TempOfferPage = Me.Page
End If
End If
End If
If New Rectangle(900, 300, 32 * 4, 64).Contains(MouseHandler.MousePosition) = True Then
If CurrentPokemon.Count = 20 Then
Me.Page += 1
GetPokemon()
If Me.Mode = "Request" Then
TempRequestPage = Me.Page
ElseIf Me.Mode = "Offer" Then
TempOfferPage = Me.Page
End If
End If
End If
If New Rectangle(900, 400, 32 * 4, 64).Contains(MouseHandler.MousePosition) = True Then
If Mode = "Request" Then
Me.GTSEditTradeScreen.D.RequestID = ""
ElseIf Mode = "Offer" Then
Me.GTSEditTradeScreen.D.RequestID = ""
End If
Close()
End If
If New Rectangle(900, 500, 32 * 4, 64).Contains(MouseHandler.MousePosition) = True Then
Close()
End If
End If
If Controls.Dismiss(True, True) = True Then
Close()
End If
End Sub
Private Sub Close()
If Me.Mode = "Request" Then
TempRequestPage = Me.Page
ElseIf Me.Mode = "Offer" Then
TempOfferPage = Me.Page
End If
Core.SetScreen(Me.GTSEditTradeScreen)
End Sub
End Class
Class SelectLevelScreen
Inherits Screen
Dim GTSEditTradeScreen As GTSEditTradeScreen
Public Sub New(ByVal GTSEditTradeScreen As GTSEditTradeScreen)
Me.GTSEditTradeScreen = GTSEditTradeScreen
Me.Identification = Identifications.GTSSelectLevelScreen
Me.CanBePaused = False
Me.CanChat = False
Me.CanDrawDebug = True
Me.CanMuteMusic = True
Me.CanTakeScreenshot = True
Me.MouseVisible = True
End Sub
Public Overrides Sub Draw()
Me.GTSEditTradeScreen.Draw()
Canvas.DrawRectangle(Core.windowSize, New Color(255, 255, 255, 150))
DrawButton(New Vector2(100, 200), 4, "Level", "9 and under")
DrawButton(New Vector2(260, 200), 4, "Level", "10 - 19")
DrawButton(New Vector2(420, 200), 4, "Level", "20 - 29")
DrawButton(New Vector2(580, 200), 4, "Level", "30 - 39")
DrawButton(New Vector2(740, 200), 4, "Level", "40 - 49")
DrawButton(New Vector2(100, 300), 4, "Level", "50 - 59")
DrawButton(New Vector2(260, 300), 4, "Level", "60 - 69")
DrawButton(New Vector2(420, 300), 4, "Level", "70 - 79")
DrawButton(New Vector2(580, 300), 4, "Level", "80 - 89")
DrawButton(New Vector2(740, 300), 4, "Level", "90 - 100")
DrawButton(New Vector2(900, 200), 4, "Navigation", "Back")
End Sub
Private Sub DrawButton(ByVal Position As Vector2, ByVal Size As Integer, ByVal Label As String, ByVal Text As String)
Dim TexX As Integer = 368
If New Rectangle(CInt(Position.X), CInt(Position.Y), Size * 32, 64).Contains(MouseHandler.MousePosition) = True And Me.IsCurrentScreen() = True Then
TexX = 400
End If
For i = 0 To Size - 1
Core.SpriteBatch.Draw(TextureManager.GetTexture("GUI\Menus\GTS"), New Rectangle(CInt(Position.X + i * 32), CInt(Position.Y), 32, 64), New Rectangle(TexX, 112, 16, 32), Color.White)
Next
Core.SpriteBatch.DrawString(FontManager.MiniFont, Label, New Vector2(Position.X + 4, Position.Y + 4), New Color(100, 100, 100))
Core.SpriteBatch.DrawString(FontManager.MiniFont, Text, New Vector2(Position.X + 4, Position.Y + 32), Color.Black)
End Sub
Public Overrides Sub Update()
For i = 0 To GTSMainScreen.Furrs.Count - 1
If i < GTSMainScreen.Furrs.Count Then
Dim f As Furr = GTSMainScreen.Furrs(i)
If f.IsOutOfBorder() = True Then
GTSMainScreen.Furrs.Remove(f)
i -= 1
Else
f.Update()
End If
End If
Next
If Core.Random.Next(0, 100) = 0 Then
GTSMainScreen.Furrs.Add(New Furr())
End If
If Controls.Accept(True, False) = True Then
For i = 0 To 9
Dim x As Integer = i
Dim y As Integer = 0
If x > 4 Then
x -= 5
y += 1
End If
If New Rectangle(100 + x * 160, 200 + y * 100, 32 * 4, 64).Contains(MouseHandler.MousePosition) = True Then
Dim newSetting As String = "9 and under"
Select Case i
Case 0
newSetting = "9 and under"
Case 1
newSetting = "10 - 19"
Case 2
newSetting = "20 - 29"
Case 3
newSetting = "30 - 39"
Case 4
newSetting = "40 - 49"
Case 5
newSetting = "50 - 59"
Case 6
newSetting = "60 - 69"
Case 7
newSetting = "70 - 79"
Case 8
newSetting = "80 - 89"
Case 9
newSetting = "90 - 100"
End Select
Me.GTSEditTradeScreen.D.RequestLevel = newSetting
Core.SetScreen(Me.GTSEditTradeScreen)
End If
Next
If New Rectangle(900, 200, 32 * 4, 64).Contains(MouseHandler.MousePosition) = True Then
Core.SetScreen(Me.GTSEditTradeScreen)
End If
End If
If Controls.Dismiss(True, True) = True Then
Core.SetScreen(Me.GTSEditTradeScreen)
End If
End Sub
End Class
Class SelectGenderScreen
Inherits Screen
Dim GTSEditTradeScreen As GTSEditTradeScreen
Public Sub New(ByVal GTSEditTradeScreen As GTSEditTradeScreen)
Me.GTSEditTradeScreen = GTSEditTradeScreen
Me.Identification = Identifications.GTSSelectGenderScreen
Me.CanBePaused = False
Me.CanChat = False
Me.CanDrawDebug = True
Me.CanMuteMusic = True
Me.CanTakeScreenshot = True
Me.MouseVisible = True
End Sub
Public Overrides Sub Draw()
Me.GTSEditTradeScreen.Draw()
Canvas.DrawRectangle(Core.windowSize, New Color(255, 255, 255, 150))
DrawButton(New Vector2(100, 200), 4, "Gender", "Male")
DrawButton(New Vector2(260, 200), 4, "Gender", "Female")
DrawButton(New Vector2(420, 200), 4, "Gender", "Genderless")
DrawButton(New Vector2(580, 200), 4, "Gender", "No entry")
DrawButton(New Vector2(900, 200), 4, "Navigation", "Back")
End Sub
Private Sub DrawButton(ByVal Position As Vector2, ByVal Size As Integer, ByVal Label As String, ByVal Text As String)
Dim TexX As Integer = 368
If New Rectangle(CInt(Position.X), CInt(Position.Y), Size * 32, 64).Contains(MouseHandler.MousePosition) = True And Me.IsCurrentScreen() = True Then
TexX = 400
End If
For i = 0 To Size - 1
Core.SpriteBatch.Draw(TextureManager.GetTexture("GUI\Menus\GTS"), New Rectangle(CInt(Position.X + i * 32), CInt(Position.Y), 32, 64), New Rectangle(TexX, 112, 16, 32), Color.White)
Next
Core.SpriteBatch.DrawString(FontManager.MiniFont, Label, New Vector2(Position.X + 4, Position.Y + 4), New Color(100, 100, 100))
Core.SpriteBatch.DrawString(FontManager.MiniFont, Text, New Vector2(Position.X + 4, Position.Y + 32), Color.Black)
End Sub
Public Overrides Sub Update()
For i = 0 To GTSMainScreen.Furrs.Count - 1
If i < GTSMainScreen.Furrs.Count Then
Dim f As Furr = GTSMainScreen.Furrs(i)
If f.IsOutOfBorder() = True Then
GTSMainScreen.Furrs.Remove(f)
i -= 1
Else
f.Update()
End If
End If
Next
If Core.Random.Next(0, 100) = 0 Then
GTSMainScreen.Furrs.Add(New Furr())
End If
If Controls.Accept(True, False) = True Then
If New Rectangle(100, 200, 32 * 4, 64).Contains(MouseHandler.MousePosition) = True Then
Me.GTSEditTradeScreen.D.RequestGender = "Male"
Core.SetScreen(Me.GTSEditTradeScreen)
End If
If New Rectangle(260, 200, 32 * 4, 64).Contains(MouseHandler.MousePosition) = True Then
Me.GTSEditTradeScreen.D.RequestGender = "Female"
Core.SetScreen(Me.GTSEditTradeScreen)
End If
If New Rectangle(420, 200, 32 * 4, 64).Contains(MouseHandler.MousePosition) = True Then
Me.GTSEditTradeScreen.D.RequestGender = "Genderless"
Core.SetScreen(Me.GTSEditTradeScreen)
End If
If New Rectangle(580, 200, 32 * 4, 64).Contains(MouseHandler.MousePosition) = True Then
Me.GTSEditTradeScreen.D.RequestGender = ""
Core.SetScreen(Me.GTSEditTradeScreen)
End If
If New Rectangle(900, 200, 32 * 4, 64).Contains(MouseHandler.MousePosition) = True Then
Core.SetScreen(Me.GTSEditTradeScreen)
End If
End If
If Controls.Dismiss(True, True) = True Then
Core.SetScreen(Me.GTSEditTradeScreen)
End If
End Sub
End Class
Class SelectAreaScreen
Inherits Screen
Dim GTSEditTradeScreen As GTSEditTradeScreen
Public Sub New(ByVal GTSEditTradeScreen As GTSEditTradeScreen)
Me.GTSEditTradeScreen = GTSEditTradeScreen
Me.Identification = Identifications.GTSSelectAreaScreen
Me.CanBePaused = False
Me.CanChat = False
Me.CanDrawDebug = True
Me.CanMuteMusic = True
Me.CanTakeScreenshot = True
Me.MouseVisible = True
End Sub
Public Overrides Sub Draw()
Me.GTSEditTradeScreen.Draw()
Canvas.DrawRectangle(Core.windowSize, New Color(255, 255, 255, 150))
DrawButton(New Vector2(100, 200), 4, "Area", "Global")
DrawButton(New Vector2(260, 200), 4, "Area", "Private")
DrawButton(New Vector2(900, 200), 4, "Navigation", "Back")
End Sub
Private Sub DrawButton(ByVal Position As Vector2, ByVal Size As Integer, ByVal Label As String, ByVal Text As String)
Dim TexX As Integer = 368
If New Rectangle(CInt(Position.X), CInt(Position.Y), Size * 32, 64).Contains(MouseHandler.MousePosition) = True And Me.IsCurrentScreen() = True Then
TexX = 400
End If
For i = 0 To Size - 1
Core.SpriteBatch.Draw(TextureManager.GetTexture("GUI\Menus\GTS"), New Rectangle(CInt(Position.X + i * 32), CInt(Position.Y), 32, 64), New Rectangle(TexX, 112, 16, 32), Color.White)
Next
Core.SpriteBatch.DrawString(FontManager.MiniFont, Label, New Vector2(Position.X + 4, Position.Y + 4), New Color(100, 100, 100))
Core.SpriteBatch.DrawString(FontManager.MiniFont, Text, New Vector2(Position.X + 4, Position.Y + 32), Color.Black)
End Sub
Public Overrides Sub Update()
For i = 0 To GTSMainScreen.Furrs.Count - 1
If i < GTSMainScreen.Furrs.Count Then
Dim f As Furr = GTSMainScreen.Furrs(i)
If f.IsOutOfBorder() = True Then
GTSMainScreen.Furrs.Remove(f)
i -= 1
Else
f.Update()
End If
End If
Next
If Core.Random.Next(0, 100) = 0 Then
GTSMainScreen.Furrs.Add(New Furr())
End If
If Controls.Accept(True, False) = True Then
If New Rectangle(100, 200, 32 * 4, 64).Contains(MouseHandler.MousePosition) = True Then
Me.GTSEditTradeScreen.D.SecurityArea = GTSDataItem.SecurityCode.Global
Core.SetScreen(Me.GTSEditTradeScreen)
End If
If New Rectangle(260, 200, 32 * 4, 64).Contains(MouseHandler.MousePosition) = True Then
Me.GTSEditTradeScreen.D.SecurityArea = GTSDataItem.SecurityCode.Private
Core.SetScreen(Me.GTSEditTradeScreen)
End If
If New Rectangle(900, 200, 32 * 4, 64).Contains(MouseHandler.MousePosition) = True Then
Core.SetScreen(Me.GTSEditTradeScreen)
End If
End If
If Controls.Dismiss(True, True) = True Then
Core.SetScreen(Me.GTSEditTradeScreen)
End If
End Sub
End Class
Class SelectFriendScreen
Inherits Screen
Dim GTSEditTradeScreen As GTSEditTradeScreen
Shared Users As New Dictionary(Of Integer, String)
Dim UserIDs As New Dictionary(Of Integer, Emblem)
Dim Page As Integer = 0
Public Shared Sub Clear()
Users.Clear()
End Sub
Public Sub New(ByVal GTSEditTradeScreen As GTSEditTradeScreen)
Me.GTSEditTradeScreen = GTSEditTradeScreen
Me.Identification = Identifications.GTSSelectUserScreen
Me.CanBePaused = False
Me.CanChat = False
Me.CanDrawDebug = True
Me.CanMuteMusic = True
Me.CanTakeScreenshot = True
Me.MouseVisible = True
If Core.GameJoltSave.Friends <> "" Then
For Each fr As String In Core.GameJoltSave.Friends.Split(CChar(","))
If Users.ContainsKey(CInt(fr)) = False Then
UserIDs.Add(CInt(fr), New Emblem(fr, 0))
End If
Next
End If
End Sub
Public Overrides Sub Draw()
Me.GTSEditTradeScreen.Draw()
Canvas.DrawRectangle(Core.windowSize, New Color(255, 255, 255, 150))
For i = 0 To 19
If i + Page * 20 < Users.Count Then
Dim x As Integer = i
Dim y As Integer = 0
While x > 4
x -= 5
y += 1
End While
Dim UserID As String = Users.Keys(i + Page * 20).ToString()
Dim UserName As String = Users.Values(i + Page * 20)
DrawButton(New Vector2(100 + x * 160, 200 + y * 100), 4, "User (" & UserID & ")", UserName)
End If
Next
DrawButton(New Vector2(900, 200), 4, "Navigation", "Last Page")
DrawButton(New Vector2(900, 300), 4, "Navigation", "Next Page")
DrawButton(New Vector2(900, 400), 4, "Friend", "No entry")
DrawButton(New Vector2(900, 500), 4, "Navigation", "Back")
End Sub
Private Sub DrawButton(ByVal Position As Vector2, ByVal Size As Integer, ByVal Label As String, ByVal Text As String)
Dim TexX As Integer = 368
If New Rectangle(CInt(Position.X), CInt(Position.Y), Size * 32, 64).Contains(MouseHandler.MousePosition) = True And Me.IsCurrentScreen() = True Then
TexX = 400
End If
For i = 0 To Size - 1
Core.SpriteBatch.Draw(TextureManager.GetTexture("GUI\Menus\GTS"), New Rectangle(CInt(Position.X + i * 32), CInt(Position.Y), 32, 64), New Rectangle(TexX, 112, 16, 32), Color.White)
Next
Core.SpriteBatch.DrawString(FontManager.MiniFont, Label, New Vector2(Position.X + 4, Position.Y + 4), New Color(100, 100, 100))
Core.SpriteBatch.DrawString(FontManager.MiniFont, Text, New Vector2(Position.X + 4, Position.Y + 32), Color.Black)
End Sub
Public Overrides Sub Update()
For i = 0 To GTSMainScreen.Furrs.Count - 1
If i < GTSMainScreen.Furrs.Count Then
Dim f As Furr = GTSMainScreen.Furrs(i)
If f.IsOutOfBorder() = True Then
GTSMainScreen.Furrs.Remove(f)
i -= 1
Else
f.Update()
End If
End If
Next
If Core.Random.Next(0, 100) = 0 Then
GTSMainScreen.Furrs.Add(New Furr())
End If
For t = 0 To UserIDs.Count - 1
If Users.ContainsKey(UserIDs.Keys(t)) = False Then
If UserIDs.Values(t).DoneLoading = True Then
Users.Add(UserIDs.Keys(t), UserIDs.Values(t).Username)
End If
End If
Next
If Controls.Accept(True, False) = True Then
For i = 0 To 19
If i + Page * 20 < Users.Count Then
Dim x As Integer = i
Dim y As Integer = 0
While x > 4
x -= 5
y += 1
End While
If New Rectangle(100 + x * 160, 200 + y * 100, 32 * 4, 64).Contains(MouseHandler.MousePosition) = True Then
Me.GTSEditTradeScreen.D.ToUserID = Users.Keys(i + Page * 20).ToString()
Core.SetScreen(Me.GTSEditTradeScreen)
End If
End If
Next
If New Rectangle(900, 200, 32 * 4, 64).Contains(MouseHandler.MousePosition) = True Then
If Page > 0 Then
Page -= 1
End If
End If
If New Rectangle(900, 300, 32 * 4, 64).Contains(MouseHandler.MousePosition) = True Then
If Users.Count - Page * 20 > 20 Then
Page += 1
End If
End If
If New Rectangle(900, 400, 32 * 4, 64).Contains(MouseHandler.MousePosition) = True Then
Me.GTSEditTradeScreen.D.ToUserID = ""
Me.GTSEditTradeScreen.ToEmblem = Nothing
Core.SetScreen(Me.GTSEditTradeScreen)
End If
If New Rectangle(900, 500, 32 * 4, 64).Contains(MouseHandler.MousePosition) = True Then
Core.SetScreen(Me.GTSEditTradeScreen)
End If
End If
Users = (From entry In Users Order By entry.Value Ascending).ToDictionary(Function(pair) pair.Key, Function(pair) pair.Value)
If Controls.Dismiss(True, True) = True Then
Core.SetScreen(Me.GTSEditTradeScreen)
End If
End Sub
End Class
End Class
End Class
End Namespace