2023-05-29 15:33:57 +02:00
Imports P3D . Items
''' <summary>
''' Provides an interface to load additional GameMode items.
''' </summary>
Public Class GameModeItemLoader
'The default relative path to load items from (Content folder).
Const PATH As String = " Data\Items\ "
'List of loaded items.
Shared LoadedItems As New List ( Of GameModeItem )
''' <summary>
''' Load the attack list for the loaded GameMode.
''' </summary>
''' <remarks>The game won't try to load the list if the default GameMode is selected.</remarks>
Public Shared Sub Load ( )
LoadedItems . Clear ( )
If GameModeManager . ActiveGameMode . IsDefaultGamemode = False Then
If System . IO . Directory . Exists ( GameController . GamePath & " \ " & GameModeManager . ActiveGameMode . ContentPath & " \ " & PATH ) = True Then
For Each file As String In System . IO . Directory . GetFiles ( GameController . GamePath & " \ " & GameModeManager . ActiveGameMode . ContentPath & PATH , " *.dat " )
LoadItem ( file )
Next
End If
End If
If LoadedItems . Count > 0 Then
Logger . Debug ( " Loaded " & LoadedItems . Count . ToString ( ) & " GameMode item(s). " )
End If
End Sub
''' <summary>
''' Loads a item from a file.
''' </summary>
''' <param name="file">The file to load the item from.</param>
Private Shared Sub LoadItem ( ByVal file As String )
Dim item As New GameModeItem
Dim content ( ) As String = System . IO . File . ReadAllLines ( file )
Dim key As String = " "
Dim value As String = " "
Dim setID As Boolean = False 'Controls if the item sets its ID.
Dim setName As Boolean = False 'Controls if the item sets its ID.
2023-07-07 12:05:57 +02:00
Dim nonCommentLines As Integer = 0
2023-05-29 15:33:57 +02:00
Try
'Go through lines of the file and set the properties depending on the content.
'Lines starting with # are comments.
For Each l As String In content
If l . Contains ( " | " ) = True And l . StartsWith ( " # " ) = False Then
2023-07-07 12:05:57 +02:00
nonCommentLines += 1
2023-05-29 15:33:57 +02:00
key = l . Remove ( l . IndexOf ( " | " ) )
value = l . Remove ( 0 , l . IndexOf ( " | " ) + 1 )
Select Case key . ToLower ( )
Case " id "
item . gmID = " gm " & CInt ( value ) . ToString
setID = True
Case " name "
item . gmName = value
setName = True
Case " pluralname "
item . gmPluralName = value
Case " description "
item . gmDescription = value
Case " type "
2023-05-30 12:00:18 +02:00
Select Case value . ToLower ( )
2023-05-29 15:33:57 +02:00
Case " standard " , " 0 "
item . gmItemType = ItemTypes . Standard
Case " medicine " , " 1 "
item . gmItemType = ItemTypes . Medicine
Case " plants " , " 2 "
item . gmItemType = ItemTypes . Plants
2023-05-30 12:00:18 +02:00
Case " balls " , " pokeballs " , " 3 "
2023-05-29 15:33:57 +02:00
item . gmItemType = ItemTypes . Pokéballs
Case " machines " , " 4 "
item . gmItemType = ItemTypes . Machines
Case " keyitems " , " 5 "
item . gmItemType = ItemTypes . KeyItems
Case " mail " , " 6 "
item . gmItemType = ItemTypes . Mail
Case " battleitems " , " 7 "
item . gmItemType = ItemTypes . BattleItems
End Select
2023-06-01 12:40:58 +02:00
Case " textureindex "
Dim itemX As Integer = CInt ( value )
Dim itemY As Integer = 0
Dim sheetWidth As Integer = CInt ( TextureManager . GetTexture ( item . gmTextureSource ) . Width / 24 )
While itemX > sheetWidth - 1
itemX -= sheetWidth
itemY += 1
End While
item . gmTextureRectangle = New Rectangle ( CInt ( itemX * 24 ) , CInt ( itemY * 24 ) , 24 , 24 )
2023-05-29 15:33:57 +02:00
Case " canbeused "
item . gmCanBeUsed = CBool ( value )
Case " canbeusedinbattle "
item . gmCanBeUsedInBattle = CBool ( value )
Case " useonpokemoninbattle "
item . gmBattleSelectPokemon = CBool ( value )
Case " canbetossed "
item . gmCanBeTossed = CBool ( value )
Case " canbeheld "
item . gmCanBeHeld = CBool ( value )
Case " canbetraded "
item . gmCanBeTraded = CBool ( value )
Case " price "
item . gmPrice = CInt ( value )
Case " battlepointsprice "
item . gmBattlePointsPrice = CInt ( value )
Case " catchmultiplier "
2023-05-30 12:00:18 +02:00
item . gmCatchMultiplier = CSng ( value . ReplaceDecSeparator )
2024-01-24 17:27:59 +01:00
Case " expmultiplier "
If value . Split ( " , " ) . Count > 1 Then
item . gmOverrideTradeExp = CBool ( value . GetSplit ( 1 , " , " ) )
End If
item . gmExpMultiplier = CDbl ( value . GetSplit ( 0 , " , " ) . ReplaceDecSeparator )
2023-05-29 15:33:57 +02:00
Case " maxstack "
item . gmMaxStack = CInt ( value )
Case " flingdamage "
item . gmFlingDamage = CInt ( value )
Case " ishealingitem "
item . gmIsHealingItem = CBool ( value )
2023-08-02 14:36:19 +02:00
Case " ismail "
item . gmIsMail = CBool ( value )
2023-05-29 15:33:57 +02:00
Case " healhpamount "
item . gmHealHPAmount = CInt ( value )
Added a GameMode Move property and 2 functions
* Fixed an issue with GameMode Items in battles
* Updated the example files for GameMode Items and GameMode Moves
* Maybe fixed something audio volume related
* Made it possible to disable the reduction of PP using the DeductPP (bool) property for GameModeMoves
* Added the new functions "SetTrigger" and "RemoveTrigger" for GameModeMoves:
Function "SetTrigger" checks if a Pokémon does or does not have a certain Status and prevents functions after it from executing if the Pokémon does not have the desired Status.
The function is formatted like this: Function|SetTrigger,Target,Triggers
* "Target" determines which Pokémon's Status is checked and has to be either 0 or 1 (0 = check own Pokémon, 1 = check opponent's Pokémon)
* "Triggers" determines the status effect(s) that should or should not be on the target Pokémon. You can add multiple possible status effects to check for by separating them with a semicolon (;), the values can be: "burn", "freeze", "paralyze", "poison", "badpoison", "anypoison", "sleep", "noburn", "nofreeze", "noparalyze", "nopoison", "nobadpoison", "nopoison", "nosleep"
Function "RemoveTrigger" removes such a trigger so that functions after it are executed
2023-06-13 20:22:35 +02:00
Case " curestatus "
2023-05-30 11:38:59 +02:00
Dim StatusEffectList As New List ( Of String )
2023-05-29 15:33:57 +02:00
Dim valueSplit As String ( ) = value . Split ( " , " )
For i = 0 To valueSplit . Count - 1
Select Case valueSplit ( i ) . ToLower
2023-05-30 12:00:18 +02:00
Case " brn " , " frz " , " prz " , " psn " , " bpsn " , " slp " , " fnt " , " confusion " , " allwithoutfnt " , " all "
2023-05-30 11:38:59 +02:00
StatusEffectList . Add ( valueSplit ( i ) )
2023-05-29 15:33:57 +02:00
End Select
Next
If item . gmCureStatusEffects Is Nothing Then
item . gmCureStatusEffects = StatusEffectList
Else
item . gmCureStatusEffects . AddRange ( StatusEffectList )
End If
Case " evolutionpokemon "
Dim PokemonList As New List ( Of Integer )
2023-06-01 12:40:58 +02:00
Dim valueSplit As String ( ) = value . Split ( CChar ( " , " ) )
2023-05-29 15:33:57 +02:00
For i = 0 To valueSplit . Count - 1
2023-07-12 20:09:06 +02:00
If Pokemon . PokemonDataExists ( valueSplit ( i ) ) Then
2023-05-29 15:33:57 +02:00
PokemonList . Add ( CInt ( valueSplit ( i ) ) )
End If
Next
If item . gmEvolutionPokemon Is Nothing Then
item . gmEvolutionPokemon = PokemonList
Else
item . gmEvolutionPokemon . AddRange ( PokemonList )
End If
2023-05-31 16:25:38 +02:00
Case " script "
item . gmScriptPath = value
2023-08-14 18:40:52 +02:00
Case " ishm "
item . gmIsHM = CBool ( value )
2023-05-31 20:37:02 +02:00
Case " teachmove "
item . gmTeachMove = BattleSystem . Attack . GetAttackByID ( CInt ( value ) )
2023-08-14 18:40:52 +02:00
Case " canteachalways "
item . gmCanTeachAlways = CBool ( value )
Case " canteachwhenfullyevolved "
item . gmCanTeachWhenFullyEvolved = CBool ( value )
Case " canteachwhengendered "
item . gmCanTeachWhenGendered = CBool ( value )
2023-05-29 15:33:57 +02:00
End Select
End If
Next
Catch ex As Exception
'If an error occurs loading a item, log the error.
Logger . Log ( Logger . LogTypes . ErrorMessage , " GameModeItemLoader.vb: Error loading GameMode Item from file "" " & file & " "" : " & ex . Message & " ; Last Key/Value pair successfully loaded: " & key & " | " & value )
End Try
2023-07-07 12:05:57 +02:00
If nonCommentLines > 0 Then
If setID = True AndAlso setName = True Then
If item . gmIsMegaStone = True AndAlso item . gmMegaPokemonNumber <> Nothing AndAlso item . gmDescription = " " Then
2023-07-23 18:39:26 +02:00
Dim MegaPokemonName As String = Pokemon . GetPokemonByID ( item . gmMegaPokemonNumber ) . GetName
2023-07-07 12:05:57 +02:00
item . gmDescription = " One variety of the mysterious Mega Stones. Have " & MegaPokemonName & " hold it, and this stone will enable it to Mega Evolve during battle. "
item . gmCanBeTossed = False
item . gmCanBeTraded = False
item . gmCanBeUsed = False
item . gmCanBeUsedInBattle = False
2023-06-06 20:35:05 +02:00
End If
2023-08-14 18:40:52 +02:00
If item . gmTeachMove IsNot Nothing AndAlso item . gmDescription = " " Then
2023-07-07 12:05:57 +02:00
Dim AttackName As String = item . gmTeachMove . Name
item . gmDescription = " Teaches "" " & AttackName & " "" to a Pokémon. "
item . gmItemType = ItemTypes . Machines
item . gmCanBeHeld = False
item . gmCanBeTossed = True
item . gmCanBeTraded = True
item . gmCanBeUsed = True
item . gmCanBeUsedInBattle = False
If item . gmName . StartsWith ( " TM " ) Then
item . gmSortValue = CInt ( item . gmName . Remove ( 0 , 3 ) ) + 190
ElseIf item . gmName . StartsWith ( " TM " ) Then
item . gmSortValue = CInt ( item . gmName . Remove ( 0 , 2 ) ) + 190
End If
If item . gmName . StartsWith ( " HM " ) Then
item . gmSortValue = - 100000 + CInt ( item . gmName . Remove ( 0 , 3 ) )
ElseIf item . gmName . StartsWith ( " HM " ) Then
item . gmSortValue = - 100000 + CInt ( item . gmName . Remove ( 0 , 2 ) )
End If
2023-12-10 20:19:14 +01:00
If item . gmTeachMove . Type . IsGameModeElement = False Then
item . gmTextureSource = " Items\ItemSheet "
Else
item . gmTextureSource = item . gmTeachMove . Type . gmMachineTextureSource
End If
2023-07-07 12:05:57 +02:00
item . SetTeachMoveTextureRectangle ( )
2023-05-31 20:37:02 +02:00
2023-07-07 12:05:57 +02:00
End If
If item . gmTextureRectangle = Nothing Then
Dim itemX As Integer = CInt ( item . gmID . Remove ( 0 , 2 ) )
Dim itemY As Integer = 0
Dim sheetWidth As Integer = CInt ( TextureManager . GetTexture ( item . gmTextureSource ) . Width / 24 )
While itemX > sheetWidth - 1
itemX -= sheetWidth
itemY += 1
End While
item . gmTextureRectangle = New Rectangle ( CInt ( itemX * 24 ) , CInt ( itemY * 24 ) , 24 , 24 )
End If
LoadedItems . Add ( item ) 'Add the item.
Else
Logger . Log ( Logger . LogTypes . ErrorMessage , " GameModeItemLoader.vb: User defined Items must set their ID through the "" ID "" property and their Name through the "" Name "" property, however the item loaded from "" " & file & " "" has no ID or Name set so it will be ignored. " )
2023-05-31 20:37:02 +02:00
End If
2023-05-29 15:33:57 +02:00
Else
2023-07-07 12:05:57 +02:00
Debug . Print ( " GameModeItemLoader.vb: The item loaded from "" " & file & " "" has no valid lines so it will be ignored. " )
2023-05-29 15:33:57 +02:00
End If
End Sub
''' <summary>
''' Returns a custom item based on its ID.
''' </summary>
''' <param name="ID">The ID of the custom item.</param>
''' <returns>Returns a item or nothing.</returns>
Public Shared Function GetItemByID ( ByVal ID As String ) As GameModeItem
For Each i As GameModeItem In LoadedItems
If i . gmID = ID Then
Return i
End If
Next
Return Nothing
End Function
Public Shared Function GetItemByName ( ByVal Name As String ) As GameModeItem
For Each i As GameModeItem In LoadedItems
If i . gmName . ToLowerInvariant ( ) = Name . ToLowerInvariant ( ) Then
Return i
End If
Next
Return Nothing
End Function
End Class