P3D-Legacy/P3D/Network/Profiles/Emblem.vb

1293 lines
50 KiB
VB.net

Namespace GameJolt
''' <summary>
''' A class to handle emblem rendering and management.
''' </summary>
Public Class Emblem
#Region "Enumrations"
''' <summary>
''' The names of male trainer types.
''' </summary>
Public Enum MaleEmblemSpriteType
Preschooler = 0
SchoolKid = 1
Youngster = 2
Waiter = 3
Backpacker = 4
Pokefan = 5
Butler = 6
Cheerleader = 7
Clerk = 8
PokemonBreeder = 9
Drummer = 10
Cyclist = 11
RichBoy = 12
Ranger = 13
Athlete = 14
Scientist = 15
Doctor = 16
Gentleman = 17
AceTrainer = 18
Veteran = 19
End Enum
''' <summary>
''' The names of female trainer types.
''' </summary>
Public Enum FemaleEmblemSpriteType
Preschooler = 0
SchoolKid = 1
Lass = 2
Waitress = 3
Backpacker = 4
Pokefan = 5
Maid = 6
Cheerleader = 7
Clerk = 8
PokemonBreeder = 9
Guitarist = 10
Cyclist = 11
Lady = 12
Ranger = 13
Athlete = 14
Scientist = 15
Nurse = 16
Socialite = 17
AceTrainer = 18
Veteran = 19
End Enum
''' <summary>
''' The sprites of male trainers.
''' </summary>
Public Enum MaleEmblemSprites
NN40 = 0
NN42 = 1
NN44 = 2
NN46 = 3
NN48 = 4
NN51 = 5
NN74 = 6
NN76 = 7
NN53 = 8
NN55 = 9
NN80 = 10
NN72 = 11
NN57 = 12
NN59 = 13
NN78 = 14
NN64 = 15
NN66 = 16
NN68 = 17
NN70 = 18
NN38 = 19
End Enum
''' <summary>
''' The sprites of female trainers.
''' </summary>
Public Enum FemaleEmblemSprites
NN41 = 0
NN43 = 1
NN45 = 2
NN47 = 3
NN50 = 4
NN52 = 5
NN75 = 6
NN77 = 7
NN54 = 8
NN56 = 9
NN81 = 10
NN73 = 11
NN58 = 12
NN60 = 13
NN79 = 14
NN65 = 15
NN67 = 16
NN69 = 17
NN71 = 18
NN39 = 19
End Enum
#End Region
''' <summary>
''' Renders an emblem to the screen.
''' </summary>
''' <param name="Name">The name of the player.</param>
''' <param name="ID">The GameJolt ID.</param>
''' <param name="Points">The points of the player.</param>
''' <param name="Gender">The gender of the player (0=male, 1=female).</param>
''' <param name="EmblemBackground">The emblem background name.</param>
''' <param name="Position">The position on the screen.</param>
''' <param name="Scale">The scale of the emblem.</param>
''' <param name="SpriteTexture">An alternative sprite to draw.</param>
Public Shared Sub Draw(ByVal Name As String, ByVal ID As String, ByVal Points As Integer, ByVal Gender As String, ByVal EmblemBackground As String, ByVal Position As Vector2, ByVal Scale As Single, ByVal SpriteTexture As Texture2D)
Draw(Name, ID, Points, Gender, EmblemBackground, Position, Scale, SpriteTexture, Nothing)
End Sub
''' <summary>
''' Renders an emblem to the screen.
''' </summary>
''' <param name="Name">The name of the player.</param>
''' <param name="ID">The GameJolt ID.</param>
''' <param name="Points">The points of the player.</param>
''' <param name="Gender">The gender of the player (0=male, 1=female).</param>
''' <param name="EmblemBackground">The emblem background name.</param>
''' <param name="Position">The position on the screen.</param>
''' <param name="Scale">The scale of the emblem.</param>
''' <param name="SpriteTexture">An alternative sprite to draw.</param>
''' <param name="PokemonList">A list of 0-6 Pokémon to render below the player information.</param>
Public Shared Sub Draw(ByVal Name As String, ByVal ID As String, ByVal Points As Integer, ByVal Gender As String, ByVal EmblemBackground As String, ByVal Position As Vector2, ByVal Scale As Single, ByVal SpriteTexture As Texture2D, ByVal PokemonList As List(Of Pokemon))
'Generate OT:
Dim OT As String = ID
While OT.Length < 5
OT = "0" & OT
End While
'Check if user is banned.
Dim UserBanned As Boolean = LogInScreen.UserBanned(ID)
Dim PlayerName As String = Name & " (" & OT & ")"
Dim PlayerPoints As String = CStr(Points)
Dim PlayerLevel As Integer = GetPlayerLevel(Points)
Dim PlayerTexture As Texture2D = SpriteTexture
If PlayerTexture Is Nothing Then
PlayerTexture = GetPlayerSprite(PlayerLevel, ID, Gender)
End If
Dim frameSize As New Size(CInt(PlayerTexture.Width / 3), CInt(PlayerTexture.Height / 4))
Dim PlayerTitle As String = GetPlayerTitle(PlayerLevel, ID, Gender)
If UserBanned = True Then
PlayerTitle = "Lonely"
End If
Dim EmblemBackgroundTexture As Texture2D = Nothing
Dim EmblemFontColor As Color = GetEmblemFontColor(EmblemBackground)
If UserBanned = True Then
EmblemBackgroundTexture = GetEmblemBackgroundTexture("missingno")
EmblemFontColor = Color.White
Else
EmblemBackgroundTexture = GetEmblemBackgroundTexture(EmblemBackground)
End If
Core.SpriteBatch.Draw(EmblemBackgroundTexture, New Rectangle(CInt(Position.X), CInt(Position.Y), CInt(128 * Scale), CInt(32 * Scale)), Color.White)
Core.SpriteBatch.Draw(PlayerTexture, New Rectangle(CInt(Position.X), CInt(Position.Y), CInt(32 * Scale), CInt(32 * Scale)), New Rectangle(0, frameSize.Height * 2, frameSize.Width, frameSize.Height), Color.White)
If PokemonList Is Nothing OrElse PokemonList.Count = 0 Then
Core.SpriteBatch.DrawString(FontManager.MiniFont, PlayerName & Environment.NewLine & PlayerTitle & Environment.NewLine & Environment.NewLine & "Level: " & PlayerLevel & Environment.NewLine & "(Points: " & PlayerPoints & ")", New Vector2(32 * Scale + 10 + Position.X, 10 + Position.Y), EmblemFontColor, 0.0F, Vector2.Zero, CSng(Scale / 4), SpriteEffects.None, 0.0F)
Else
Core.SpriteBatch.DrawString(FontManager.MiniFont, PlayerName & Environment.NewLine & PlayerTitle & Environment.NewLine & "Level: " & PlayerLevel & Environment.NewLine & "(Points: " & PlayerPoints & ")", New Vector2(32 * Scale + 10 + Position.X, 6 + Position.Y), EmblemFontColor, 0.0F, Vector2.Zero, CSng(Scale / 4), SpriteEffects.None, 0.0F)
For i = 0 To 5
Core.SpriteBatch.Draw(TextureManager.GetTexture("GUI\Menus\Menu", New Rectangle(192, 0, 32, 32), ""), New Rectangle(CInt(32 * Scale + (10 / 4) * Scale + Position.X + i * (10 * Scale)), CInt(Position.Y + 22.5F * Scale), CInt(Scale * 8), CInt(Scale * 8)), Color.White)
If PokemonList.Count - 1 >= i Then
Dim p As Pokemon = PokemonList(i)
Core.SpriteBatch.Draw(p.GetMenuTexture(), New Rectangle(CInt(32 * Scale + (10 / 4) * Scale + Position.X + i * (10 * Scale)), CInt(Position.Y + 22.5F * Scale), CInt(Scale * 8), CInt(Scale * 8)), Color.White)
End If
Next
End If
If UserBanned = False Then
If IsFriend(ID) = True Then
Core.SpriteBatch.Draw(TextureManager.GetTexture("GUI\Menus\Menu", New Rectangle(80, 144, 32, 32), ""), New Rectangle(CInt(Position.X), CInt(Position.Y), CInt(32 * CSng(Scale / 4)), CInt(32 * CSng(Scale / 4))), Color.White)
End If
If SentRequest(ID) = True Then
Core.SpriteBatch.Draw(TextureManager.GetTexture("GUI\Menus\Menu", New Rectangle(112, 176, 32, 32), ""), New Rectangle(CInt(Position.X), CInt(Position.Y), CInt(32 * CSng(Scale / 4)), CInt(32 * CSng(Scale / 4))), Color.White)
End If
If ReceivedRequest(ID) = True Then
Core.SpriteBatch.Draw(TextureManager.GetTexture("GUI\Menus\Menu", New Rectangle(80, 176, 32, 32), ""), New Rectangle(CInt(Position.X), CInt(Position.Y), CInt(32 * CSng(Scale / 4)), CInt(32 * CSng(Scale / 4))), Color.White)
End If
Else
Core.SpriteBatch.Draw(TextureManager.GetTexture("GUI\Menus\Menu", New Rectangle(144, 176, 32, 32), ""), New Rectangle(CInt(Position.X), CInt(Position.Y), CInt(32 * CSng(Scale / 4)), CInt(32 * CSng(Scale / 4))), Color.White)
End If
End Sub
#Region "EmblemHelperFunctions"
Public Shared Function GetPlayerLevel(ByVal playerPoints As Integer) As Integer
Dim level As Integer = CInt(Math.Floor(xRoot(3, (4 / 5) * playerPoints * 10)))
level = level.Clamp(1, 100)
Return level
End Function
Public Shared Function GetPlayerTitle(ByVal level As Integer, ByVal id As String, ByVal gender As String) As String
For Each staffMember As StaffProfile In StaffProfile.Staff
If staffMember.GameJoltID.ToLower() = id.ToLower() And staffMember.RankName <> "" Then
Return staffMember.RankName
End If
Next
Dim t As Integer = CInt(Math.Ceiling(level / 5)) - 1
t = t.Clamp(0, 19)
If gender = "1" Then
Return CType(t, FemaleEmblemSpriteType).ToString()
End If
Return CType(t, MaleEmblemSpriteType).ToString()
End Function
Public Shared Function GetPlayerSpriteFile(ByVal level As Integer, ByVal id As String, ByVal gender As String) As String
For Each staffMember As StaffProfile In StaffProfile.Staff
If staffMember.GameJoltID.ToLower() = id.ToLower() And staffMember.Sprite <> "" Then
Return staffMember.Sprite
End If
Next
Dim t As Integer = CInt(Math.Ceiling(level / 5)) - 1
t = t.Clamp(0, 19)
Dim tFile As String = CType(t, MaleEmblemSprites).ToString()
If gender = "1" Then
tFile = CType(t, FemaleEmblemSprites).ToString()
End If
If tFile.StartsWith("NN") = True Then
tFile = tFile.Remove(0, 2)
End If
Return tFile
End Function
Public Shared Function GetPlayerSprite(ByVal level As Integer, ByVal id As String, ByVal gender As String) As Texture2D
For Each staffMember As StaffProfile In StaffProfile.Staff
If staffMember.GameJoltID.ToLower() = id.ToLower() And staffMember.Sprite <> "" Then
Return TextureManager.GetTexture("Textures\NPC\" & staffMember.Sprite)
End If
Next
Dim t As Integer = CInt(Math.Ceiling(level / 5)) - 1
t = t.Clamp(0, 19)
Dim tFile As String = CType(t, MaleEmblemSprites).ToString()
If gender = "1" Then
tFile = CType(t, FemaleEmblemSprites).ToString()
End If
If tFile.StartsWith("NN") = True Then
tFile = tFile.Remove(0, 2)
End If
Return TextureManager.GetTexture("Textures\NPC\" & tFile)
End Function
Public Shared Function GetEmblemBackgroundTexture(ByVal emblemName As String) As Texture2D
'Don't load from TextureManager, because ContentPack emblems are not allowed.
Return TextureManager.LoadDirect("Textures\Emblem\" & emblemName & ".png")
End Function
Public Shared Function GetEmblemFontColor(ByVal emblemName As String) As Color
Select Case emblemName.ToLower()
Case "alph", "genetics", "legendary", "stars", "champion", "overkill", "cyber", "glowing", "material", "fog", "mineral", "storm", "eggsplosion", "missingno", "thunder", "rainbow", "marsh", "volcano", "earth", "shooting star", "victorious", "mega", "time", "deep sea", "heart gold", "soul silver"
Return Color.White
Case "eevee", "pokedex", "snow", "trainer", "kanto", "glacier", "hive", "plain", "zephyr", "rising", "mailman", "cascade", "boulder", "unodostres", "silver ability", "gold ability", "silver knowledge", "gold knowledge", "johto", "eruption", "ancestor", "tao", "floral"
Return Color.Black
End Select
Return Color.White
End Function
Public Shared Function GetPointsForLevel(ByVal level As Integer) As Integer
If level = 1 Then
Return 0
End If
Dim points As Double = Math.Ceiling((5 / 4) * (Math.Pow(level, 3) / 10))
Return CInt(points)
End Function
#End Region
#Region "OnlineSprites"
Shared TempDownloadedSprites As New Dictionary(Of String, Texture2D)
Public Shared Function HasDownloadedSprite(ByVal GameJoltID As String) As Boolean
Return TempDownloadedSprites.ContainsKey(GameJoltID)
End Function
Public Shared Function GetOnlineSprite(ByVal GameJoltID As String) As Texture2D
If LogInScreen.UserBanned(GameJoltID) = True Then
Return Nothing
End If
If TempDownloadedSprites.ContainsKey(GameJoltID) = True Then
Dim tempT As Texture2D = TempDownloadedSprites(GameJoltID)
Return tempT
End If
Dim t As Texture2D = DownloadTexture2D.n_Remote_Texture2D(Core.GraphicsDevice, $"{Classified.Remote_Texture_URL}{GameJoltID}.png", False)
If TempDownloadedSprites.ContainsKey(GameJoltID) = False Then
TempDownloadedSprites.Add(GameJoltID, t)
End If
If Not t Is Nothing Then
If t.Width >= 96 And t.Height >= 128 Then
If t.Width / 3 = t.Height / 4 Then
Return t
End If
End If
Else
Logger.Debug("GetOnlineSprite.vb: Getting sprite for " & GameJoltID & " failed.")
End If
Return Nothing
End Function
Public Shared Sub ClearOnlineSpriteCache()
Try
TempDownloadedSprites.Clear()
Catch : End Try
End Sub
#End Region
#Region "UserEmblem"
Public Emblem As String = "trainer"
Public Points As Integer = 0
Public Gender As String = "0"
Public Username As String = ""
Public GameJoltID As String = ""
Public ValidProfile As Boolean = False
Private loadedInstances As Integer = 0
Public startedLoading As Boolean = False
Public DownloadedSprite As Texture2D = Nothing
Public OnlineTeam As List(Of Pokemon) = Nothing
Public ReadOnly Property DoneLoading As Boolean
Get
If loadedInstances = 3 Then
Return True
Else
Return False
End If
End Get
End Property
Public ReadOnly Property BackgroundTexture() As Texture2D
Get
Return GetEmblemBackgroundTexture(Emblem)
End Get
End Property
Public ReadOnly Property SpriteTexture() As Texture2D
Get
If Not Me.DownloadedSprite Is Nothing Then
Return Me.DownloadedSprite
End If
Return GetPlayerSprite(GetPlayerLevel(Points), GameJoltID, Gender)
End Get
End Property
Dim PublicKeys As String = ""
Public Sub New(ByVal username As String)
Me.StartLoading(username)
End Sub
Public Sub New(ByVal GameJoltID As String, ByVal unimportant As Integer)
StartLoadingID(GameJoltID)
End Sub
Public Sub New(ByVal username As String, ByVal Keys As String)
Me.New(username)
PublicKeys = Keys
End Sub
Public Sub New(ByVal username As String, ByVal Keys As String, ByVal startLoading As Boolean)
PublicKeys = Keys
Me.Username = username
If startLoading = True Then
Me.StartLoading(username)
End If
End Sub
Public Sub StartLoading(ByVal userName As String)
Dim APICall As New APICall(AddressOf GotGameJoltID)
APICall.FetchUserdata(userName)
Me.Username = userName
Me.startedLoading = True
End Sub
Public Sub StartLoadingID(ByVal GameJoltID As String)
Me.GameJoltID = GameJoltID
Dim APICall As New APICall(AddressOf GotGameJoltID)
APICall.FetchUserdataByID(GameJoltID)
Me.startedLoading = True
End Sub
Public Sub New(ByVal username As String, ByVal user_id As String, ByVal points As Integer, ByVal gender As String, ByVal emblem As String)
Me.Username = username
Me.GameJoltID = user_id
Me.Points = points
Me.Gender = gender
Me.Emblem = emblem
Dim t As Texture2D = GetOnlineSprite(Me.GameJoltID)
DownloadedSprite = t
loadedInstances = 3
ValidProfile = True
End Sub
Private Sub GotGameJoltID(ByVal result As String)
Dim list As List(Of GameJolt.API.JoltValue) = GameJolt.API.HandleData(result)
Dim founduserid As Boolean = False
For Each Item As GameJolt.API.JoltValue In list
If Item.Name.ToLower() = "id" Then
Me.GameJoltID = Item.Value
ValidProfile = True
If PublicKeys <> "" Then
GotPublicKeys(PublicKeys)
Else
Dim APICall As New APICall(AddressOf GotPublicKeys)
APICall.GetKeys(False, "saveStorageV" & GameJolt.GamejoltSave.VERSION & "|" & GameJoltID & "|*")
End If
Dim APICall1 As New APICall(AddressOf GotOnlineTeamKey)
APICall1.GetKeys(False, "RegisterBattleV" & RegisterBattleScreen.REGISTERBATTLEVERSION & "|" & Me.GameJoltID & "|*")
Dim t As Texture2D = GetOnlineSprite(Me.GameJoltID)
DownloadedSprite = t
founduserid = True
End If
If Item.Name.ToLower() = "username" Then
Me.Username = Item.Value
End If
Next
If founduserid = False Then loadedInstances = 3
End Sub
Private Sub GotPublicKeys(ByVal result As String)
Dim list As List(Of API.JoltValue) = API.HandleData(result)
Dim exists(3) As Boolean
For Each Item As API.JoltValue In list
If Item.Value = "saveStorageV" & GameJolt.GamejoltSave.VERSION & "|" & GameJoltID & "|points" Then
If exists(0) = False Then
Dim APICall As New APICall(AddressOf GetPlayerPoints)
APICall.GetStorageData(Item.Value, False)
exists(0) = True
End If
End If
If Item.Value = "saveStorageV" & GameJolt.GamejoltSave.VERSION & "|" & GameJoltID & "|emblem" Then
If exists(1) = False Then
Dim APICall As New APICall(AddressOf GetPlayerEmblem)
APICall.GetStorageData(Item.Value, False)
exists(1) = True
End If
End If
If Item.Value = "saveStorageV" & GameJolt.GamejoltSave.VERSION & "|" & GameJoltID & "|gender" Then
If exists(2) = False Then
Dim APICall As New APICall(AddressOf GetPlayerGender)
APICall.GetStorageData(Item.Value, False)
exists(2) = True
End If
End If
Next
If exists(0) = False Then
Points = 0
loadedInstances += 1
End If
If exists(1) = False Then
Me.Emblem = "trainer"
loadedInstances += 1
End If
If exists(2) = False Then
Me.Gender = "0"
loadedInstances += 1
End If
End Sub
Private Sub GotOnlineTeamKey(ByVal result As String)
Dim list As List(Of API.JoltValue) = API.HandleData(result)
For Each Item As API.JoltValue In list
If Item.Value.StartsWith("RegisterBattleV" & RegisterBattleScreen.REGISTERBATTLEVERSION & "|" & Me.GameJoltID & "|") = True Then
If Me.OnlineTeam Is Nothing Then
Dim APICall As New APICall(AddressOf GetOnlineTeam)
APICall.GetStorageData(Item.Value, False)
End If
End If
Next
End Sub
Private Sub GetPlayerPoints(ByVal result As String)
Dim list As List(Of API.JoltValue) = API.HandleData(result)
If CBool(list(0).Value) = True Then
Dim data As String = result.Remove(0, 22)
data = data.Remove(data.LastIndexOf(""""))
Points = CInt(data.Replace("\""", """"))
Else
Points = 0
End If
loadedInstances += 1
End Sub
Private Sub GetPlayerEmblem(ByVal result As String)
Dim list As List(Of API.JoltValue) = API.HandleData(result)
If CBool(list(0).Value) = True Then
Dim data As String = result.Remove(0, 22)
data = data.Remove(data.LastIndexOf(""""))
Emblem = data.Replace("\""", """")
Else
Emblem = "trainer"
End If
loadedInstances += 1
End Sub
Private Sub GetPlayerGender(ByVal result As String)
Dim list As List(Of API.JoltValue) = API.HandleData(result)
If CBool(list(0).Value) = True Then
Dim data As String = result.Remove(0, 22)
data = data.Remove(data.LastIndexOf(""""))
Gender = data.Replace("\""", """")
Else
Gender = "0"
End If
loadedInstances += 1
End Sub
Private Sub GetOnlineTeam(ByVal result As String)
Dim list As List(Of API.JoltValue) = API.HandleData(result)
If CBool(list(0).Value) = True Then
Me.OnlineTeam = New List(Of Pokemon)
Dim data As String = result.Remove(0, 22)
data = data.Remove(data.LastIndexOf(""""))
Dim dataArray() As String = data.SplitAtNewline()
For Each line As String In dataArray
If line.StartsWith("{") = True And line.EndsWith("}") = True Then
Dim pokemonData As String = line.Replace("\""", """")
Me.OnlineTeam.Add(Pokemon.GetPokemonByData(pokemonData))
End If
Next
Else
Me.OnlineTeam = Nothing
End If
End Sub
Public Sub Draw(ByVal Position As Vector2, ByVal Size As Integer)
Draw(Username, GameJoltID, Points, Gender, Emblem, Position, Size, Me.DownloadedSprite, Me.OnlineTeam)
End Sub
Public ReadOnly Property IsFriend() As Boolean
Get
If Me.DoneLoading = True Then
If Me.GameJoltID <> Core.GameJoltSave.GameJoltID Then
Dim Friends() As String = Core.GameJoltSave.Friends.Split(CChar(","))
If Friends.Count > 0 Then
If Friends.Contains(Me.GameJoltID) = True Then
Return True
End If
End If
End If
End If
Return False
End Get
End Property
Public Shared ReadOnly Property IsFriend(ByVal GameJoltID As String) As Boolean
Get
If GameJoltID <> Core.GameJoltSave.GameJoltID Then
Dim Friends() As String = Core.GameJoltSave.Friends.Split(CChar(","))
If Friends.Count > 0 Then
If Friends.Contains(GameJoltID) = True Then
Return True
End If
End If
End If
Return False
End Get
End Property
Public Shared ReadOnly Property SentRequest(ByVal GameJoltID As String) As Boolean
Get
If GameJoltID <> Core.GameJoltSave.GameJoltID Then
Dim Requests() As String = Core.GameJoltSave.SentRequests.Split(CChar(","))
If Requests.Count > 0 Then
If Requests.Contains(GameJoltID) = True Then
Return True
End If
End If
End If
Return False
End Get
End Property
Public Shared ReadOnly Property ReceivedRequest(ByVal GameJoltID As String) As Boolean
Get
If GameJoltID <> Core.GameJoltSave.GameJoltID Then
Dim Requests() As String = Core.GameJoltSave.ReceivedRequests.Split(CChar(","))
If Requests.Count > 0 Then
If Requests.Contains(GameJoltID) = True Then
Return True
End If
End If
End If
Return False
End Get
End Property
Public ReadOnly Property HasOnlineTeam() As Boolean
Get
If Not Me.OnlineTeam Is Nothing Then
If Me.OnlineTeam.Count > 0 Then
Return True
End If
End If
Return False
End Get
End Property
#End Region
#Region "Trophy"
Public Shared Function EmblemToTrophyID(ByVal emblem As String) As Integer
Select Case emblem.ToLower()
Case "alph"
Return 1958
Case "material"
Return 1960
Case "cyber"
Return 1973
Case "johto"
Return 1963
Case "kanto"
Return 1962
Case "legendary"
Return 1964
Case "genetics"
Return 1972
Case "unodostres"
Return 1974
Case "champion"
Return 1959
Case "snow"
Return 1967
Case "eevee"
Return 1961
Case "stars"
Return 1971
Case "glowing"
Return 1968
Case "overkill"
Return 1969
Case "pokedex"
Return 1970
Case "zephyr"
Return 1994
Case "hive"
Return 1995
Case "plain"
Return 1996
Case "fog"
Return 1997
Case "storm"
Return 1998
Case "mineral"
Return 1999
Case "glacier"
Return 2000
Case "rising"
Return 2001
Case "eggsplosion"
Return 2581
Case "mailman"
Return 3746
Case "silver ability"
Return 4765
Case "silver knowledge"
Return 4767
Case "gold ability"
Return 4766
Case "gold knowledge"
Return 4768
Case "boulder"
Return 5776
Case "cascade"
Return 5777
Case "thunder"
Return 5767
Case "rainbow"
Return 8677
Case "marsh"
Return 8678
Case "soul"
Return 10829
Case "volcano"
Return 8752
Case "earth"
Return 17001
Case "shooting star"
Return 17559
'Requires GameJolt side support
'Case "victorious"
' Return ???
'Case "deep sea"
' Return ???
'Case "eruption"
' Return ???
'Case "ancestor"
' Return ???
'Case "time"
' Return ???
'Case "mega"
' Return ???
'Case "heart gold"
' Return ???
'Case "soul silver"
' Return ???
'Case "tao"
' Return ???
'Case "floral"
' Return ???
Case Else
Return 0
End Select
End Function
Public Shared Function TrophyIDToEmblem(ByVal trophy_id As Integer) As String
Select Case trophy_id
Case 1958
Return "alph"
Case 1959
Return "champion"
Case 1960
Return "material"
Case 1961
Return "eevee"
Case 1962
Return "kanto"
Case 1963
Return "johto"
Case 1964
Return "legendary"
Case 1967
Return "snow"
Case 1968
Return "glowing"
Case 1969
Return "overkill"
Case 1970
Return "pokedex"
Case 1971
Return "stars"
Case 1972
Return "genetics"
Case 1973
Return "cyber"
Case 1974
Return "unodostres"
Case 1994
Return "zephyr"
Case 1995
Return "hive"
Case 1996
Return "plain"
Case 1997
Return "fog"
Case 1998
Return "storm"
Case 1999
Return "mineral"
Case 2000
Return "glacier"
Case 2001
Return "rising"
Case 2581
Return "eggsplosion"
Case 3746
Return "mailman"
Case 4765
Return "silver ability"
Case 4766
Return "gold ability"
Case 4767
Return "silver knowledge"
Case 4768
Return "gold knowledge"
Case 5767
Return "thunder"
Case 5776
Return "boulder"
Case 5777
Return "cascade"
Case 8677
Return "rainbow"
Case 8678
Return "marsh"
Case 10829
Return "soul"
Case 8752
Return "volcano"
Case 17001
Return "earth"
Case 17559
Return "shooting star"
'Requires GameJolt side support
'Case ???
' Return "victorious"
'Case ???
' Return "deep sea"
'Case ???
' Return "eruption"
'Case ???
' Return "ancestor"
'Case ???
' Return "time"
'Case ???
' Return "mega"
'Case "heart gold"
' Return ???
'Case "soul silver"
' Return ???
'Case "tao"
' Return ???
'Case "floral"
' Return ???
Case Else
Return "fail"
End Select
End Function
Public Shared Sub GetAchievedEmblems()
Dim APICall As New APICall(AddressOf AddAchievedEmblems)
APICall.FetchAllAchievedTrophies()
End Sub
Private Shared Sub AddAchievedEmblems(ByVal result As String)
'Dim list As List(Of API.JoltValue) = API.HandleData(result)
'If CBool(list(0).Value) = True Then
' Dim currentTrophyID As Integer = 0
' For i = 0 To list.Count - 1
' Select Case list(i).Name
' Case "id"
' currentTrophyID = CInt(list(i).Value)
' Case "achieved"
' If list(i).Value <> "false" Then
' Dim newEmblem As String = TrophyIDToEmblem(currentTrophyID)
' If newEmblem <> "fail" Then
' If Core.GameJoltSave.AchievedEmblems.Contains(newEmblem) = False Then
' Core.GameJoltSave.AchievedEmblems.Add(newEmblem)
' End If
' End If
' End If
' End Select
' Next
'End If
'Temporary workaround till Emblems get GJ support back again
For Each newEmblem In Core.Player.EarnedAchievements
If Not Core.GameJoltSave.AchievedEmblems.Contains(newEmblem) Then
Core.GameJoltSave.AchievedEmblems.Add(newEmblem)
End If
Next
If Core.GameJoltSave.AchievedEmblems.Contains("trainer") = False Then
Core.GameJoltSave.AchievedEmblems.Add("trainer")
End If
End Sub
Public Shared Sub AchieveEmblem(ByVal emblem As String)
'If Core.Player.IsGameJoltSave = True Then
' If Core.GameJoltSave.AchievedEmblems.Contains(emblem.ToLower()) = False Then
' Dim trophy_id As Integer = EmblemToTrophyID(emblem)
' Dim APICall As New APICall(AddressOf AddedAchievement)
' APICall.TrophyAchieved(trophy_id)
' Dim APICallShow As New APICall(AddressOf ShowAchievedEmblem)
' APICallShow.FetchTrophy(trophy_id)
' End If
'End If
'Temporary, remove when GameJolt side support is brought back
If Not Core.GameJoltSave.AchievedEmblems.Contains(emblem) Then
Core.GameJoltSave.AchievedEmblems.Add(emblem)
Dim emblemTexture As Texture2D = TextureManager.GetTexture("Textures\Emblem\Square\" & emblem)
achieved_emblem_Texture = emblemTexture
achieved_emblem_title = GetEmblemTitle(emblem)
achieved_emblem_description = GetEmblemDescription(emblem)
achieved_emblem_difficulty = GetEmblemDifficulty(emblem)
displayEmblemDelay = 35.0F
End If
'End Temporary
If Core.Player.EarnedAchievements.Contains(emblem.ToLower()) = False Then
If ConnectScreen.Connected = True Then
Core.ServersManager.ServerConnection.SendGameStateMessage("achieved the emblem """ & emblem.ToUpper() & """!")
End If
Core.Player.EarnedAchievements.Add(emblem.ToLower())
End If
End Sub
Private Shared Function GetEmblemTitle(ByVal emblem As String) As String
Select Case emblem
Case "alph"
Return "Alph"
Case "material"
Return "Material"
Case "cyber"
Return "Cyber"
Case "johto"
Return "Johto"
Case "kanto"
Return "Kanto"
Case "legendary"
Return "Legendary"
Case "genetics"
Return "Genetics"
Case "unodostres"
Return "UnoDosTres"
Case "champion"
Return "Champion"
Case "snow"
Return "Snow"
Case "eevee"
Return "Eevee"
Case "stars"
Return "Stars"
Case "glowing"
Return "Glowing"
Case "overkill"
Return "Overkill"
Case "pokedex"
Return "Pokédex"
Case "zephyr"
Return "Zephyr"
Case "hive"
Return "Hive"
Case "plain"
Return "Plain"
Case "fog"
Return "Fog"
Case "storm"
Return "Storm"
Case "mineral"
Return "Mineral"
Case "glacier"
Return "Glacier"
Case "rising"
Return "Rising"
Case "eggsplosion"
Return "Eggsplosion"
Case "mailman"
Return "Mailman"
Case "silver ability"
Return "Silver Ability"
Case "silver knowledge"
Return "Silver Knowledge"
Case "gold ability"
Return "Gold Ability"
Case "gold knowledge"
Return "Gold Knowledge"
Case "boulder"
Return "Boulder"
Case "cascade"
Return "Cascade"
Case "thunder"
Return "Thunder"
Case "rainbow"
Return "Rainbow"
Case "marsh"
Return "Marsh"
Case "soul"
Return "Soul"
Case "volcano"
Return "Volcano"
Case "earth"
Return "Earth"
Case "shooting star"
Return "Shooting Star"
Case "victorious"
Return "Victorious"
Case "deep sea"
Return "Deep Sea"
Case "eruption"
Return "Eruption"
Case "ancestor"
Return "Ancestor"
Case "time"
Return "Time"
Case "mega"
Return "Mega"
Case "beast"
Return "Beast"
Case "heart gold"
Return "Heart Gold"
Case "soul silver"
Return "Soul Silver"
Case "tao"
Return "Tao"
Case "floral"
Return "Floral"
Case Else
Return "???"
End Select
End Function
Private Shared Function GetEmblemDescription(ByVal emblem As String) As String
Select Case emblem
Case "alph"
Return "Solve the Ruins of Alph puzzles."
Case "material"
Return "Battle and defeat or catch the Red Gyarados in the Lake of Rage to obtain the Red Scale."
Case "cyber"
Return "Trade on the GTS."
Case "johto"
Return "Get all the badges from the Johto region."
Case "kanto"
Return "Get all the badges from the Kanto region."
Case "legendary"
Return "Have Ho-oh, Lugia and Suicune in your party."
Case "genetics"
Return "Have a legendary encounter."
Case "unodostres"
Return "Have Articuno, Zapdos, and Moltres in your party."
Case "champion"
Return "Defeat Lance to become the Champion."
Case "snow"
Return "Defeat Red on Mt. Silver."
Case "eevee"
Return "Get the 8 eevolutions (Vaporeon, Flareon, Jolteon, Umbreon, Espeon, Leafeon, Glaceon and Sylveon)."
Case "stars"
Return "Catch a shiny Pokémon (except a shiny Gyarados)."
Case "glowing"
Return "???"
Case "overkill"
Return "Get a full party of level 100 Pokemon."
Case "pokedex"
Return "Complete the Johto Pokédex!"
Case "zephyr"
Return "Get the Zephyr-Badge from Falkner."
Case "hive"
Return "Get the Hive-Badge from Bugsy."
Case "plain"
Return "Get the Plain-Badge from Whitney."
Case "fog"
Return "Get the Fog-Badge from Morty."
Case "storm"
Return "Get the Plain-Badge from Whitney."
Case "mineral"
Return "Get the Mineral-Badge from Jasmine."
Case "glacier"
Return "Get the Glacier-Badge from Pryce."
Case "rising"
Return "Get the Rising-Badge from Clair."
Case "eggsplosion"
Return "Breed a Pokémon and pass down an egg move."
Case "mailman"
Return "Get all the available mail items in the game."
Case "silver ability"
Return "Defeat 21 trainers in a row in Battle Tower Challenge Mode."
Case "silver knowledge"
Return "Defeat 21 trainers in a row in Battle Factory Challenge Mode."
Case "gold ability"
Return "Defeat the Battle Tower Brain once."
Case "gold knowledge"
Return "Defeat the Battle Factory Brain once."
Case "boulder"
Return "Get the Boulder-Badge from Brock."
Case "cascade"
Return "Get the Cascade-Badge from Misty."
Case "thunder"
Return "Get the Thunder-Badge from Lt.Surge."
Case "rainbow"
Return "Get the Rainbow-Badge from Erika."
Case "marsh"
Return "Get the Marsh-Badge from Sabrina."
Case "soul"
Return "Get the Soul-Badge from Jasmine."
Case "volcano"
Return "Get the Volcano-Badge from Blaine."
Case "earth"
Return "Get the Earth-Badge from Blue."
Case "shooting star"
Return "Have a stellar encounter."
Case "victorious"
Return "Have a victorious encounter."
Case "deep sea"
Return "Find a mysterious egg at the bottom of the sea."
Case "eruption"
Return "Have an explosive enounter."
Case "ancestor"
Return "Have a mythical encounter."
Case "time"
Return "Have an adventure through time."
Case "mega"
Return "Receive the Mega Bracelet from Professor Oak."
Case "beast"
Return "Have Raikou, Entei, and Suicune in your party."
Case "heart gold"
Return "Have an encounter with the magnificent Ho-oh."
Case "soul silver"
Return "Have an encounter with the mysterious Lugia."
Case "tao"
Return "Have a heroic encounter."
Case "floral"
Return "Have a mythical encounter."
Case Else
Return "Unknown emblem."
End Select
End Function
Private Shared Function GetEmblemDifficulty(ByVal emblem As String) As String
Select Case emblem
Case "alph", "material", "cyber", "mega", "zephyr", "hive", "plain", "fog", "storm", "mineral", "glacier", "rising", "boulder",
"cascade", "thunder", "rainbow", "marsh", "soul", "volcano", "earth"
Return "Bronze"
Case "johto", "kanto", "legendary", "shooting star", "genetics", "eggsplosion", "mailman", "silver ability", "silver knowledge",
"deep sea", "eruption", "victorious", "floral"
Return "Silver"
Case "champion", "snow", "eevee", "stars", "unodostres", "gold ability", "gold knowledge", "time", "ancestor", "beast", "tao", "heart gold", "soul silver"
Return "Gold"
Case "overkill", "pokedex"
Return "Platinum"
Case Else
Return "Unknown emblem."
End Select
End Function
Private Shared Sub AddedAchievement(ByVal result As String)
Dim APICall As New APICall(AddressOf AddAchievedEmblems)
APICall.FetchAllAchievedTrophies()
End Sub
Private Shared Sub ShowAchievedEmblem(ByVal result As String)
Dim list As List(Of API.JoltValue) = API.HandleData(result)
For Each line As API.JoltValue In list
Select Case line.Name.ToLower()
Case "title"
achieved_emblem_title = line.Value
Case "description"
achieved_emblem_description = line.Value
Case "difficulty"
achieved_emblem_difficulty = line.Value
Case "image_url"
Dim t As New Threading.Thread(AddressOf DownloadAchievedEmblemTextrure)
t.IsBackground = True
t.Start(line.Value)
End Select
Next
End Sub
Private Shared Sub DownloadAchievedEmblemTextrure(ByVal url As Object)
Dim t As Texture2D = DownloadTexture2D.n_Remote_Texture2D(Core.GraphicsDevice, url.ToString(), True)
achieved_emblem_Texture = t
displayEmblemDelay = 35.0F
End Sub
Shared displayEmblemDelay As Single = 0.0F
Shared emblemPositionX As Integer = Core.windowSize.Width
Shared achieved_emblem_description As String = ""
Shared achieved_emblem_Texture As Texture2D = Nothing
Shared achieved_emblem_title As String = ""
Shared achieved_emblem_difficulty As String = ""
Public Shared Sub SetDebugAchieve(ByVal emblem As String)
If Core.GameJoltSave.AchievedEmblems.Contains(emblem) = False Then
displayEmblemDelay = 35.0F
Core.GameJoltSave.AchievedEmblems.Add(emblem)
End If
End Sub
Public Shared Sub DrawNewEmblems()
If displayEmblemDelay > 0.0F Then
displayEmblemDelay -= 0.1F
If displayEmblemDelay <= 6.4F Then
If emblemPositionX < Core.windowSize.Width Then
emblemPositionX += 8
End If
Else
If emblemPositionX > Core.windowSize.Width - 512 Then
emblemPositionX -= 8
End If
End If
Canvas.DrawRectangle(New Rectangle(emblemPositionX + 10, 0, 512, 98), Color.Black)
If Not achieved_emblem_Texture Is Nothing Then
Core.SpriteBatch.Draw(achieved_emblem_Texture, New Rectangle(emblemPositionX + 2, 2, 75, 75), Color.White)
End If
Core.SpriteBatch.Draw(TextureManager.GetTexture("Textures\Emblem\border"), New Rectangle(emblemPositionX, 0, 79, 98), Color.White)
Dim fontColor As Color = Color.White
Select Case achieved_emblem_difficulty.ToLower()
Case "bronze"
fontColor = New Color(220, 171, 117)
Case "silver"
fontColor = New Color(207, 207, 207)
Case "gold"
fontColor = New Color(255, 207, 39)
Case "platinum"
fontColor = New Color(172, 201, 202)
End Select
Core.SpriteBatch.DrawString(FontManager.MiniFont, achieved_emblem_difficulty, New Vector2(emblemPositionX + (38 - CInt(FontManager.MiniFont.MeasureString(achieved_emblem_difficulty).X / 2)), 77), fontColor)
Core.SpriteBatch.DrawString(FontManager.MiniFont, "Achieved new emblem background: " & achieved_emblem_title, New Vector2(emblemPositionX + 88, 4), fontColor)
Dim desText As String = achieved_emblem_description.CropStringToWidth(FontManager.MiniFont, 300)
Core.SpriteBatch.DrawString(FontManager.MiniFont, desText, New Vector2(emblemPositionX + 94, 24), Color.White)
If displayEmblemDelay <= 0.0F Then
displayEmblemDelay = 0.0F
emblemPositionX = Core.windowSize.Width
End If
End If
End Sub
#End Region
End Class
End Namespace