362 lines
11 KiB
VB.net
362 lines
11 KiB
VB.net
Public Class Script
|
|
|
|
Public Enum ScriptTypes As Integer
|
|
' V1:
|
|
Move = 0
|
|
MoveAsync = 1
|
|
MovePlayer = 2
|
|
Turn = 3
|
|
TurnPlayer = 4
|
|
Warp = 5
|
|
WarpPlayer = 6
|
|
Heal = 7
|
|
ViewPokemonImage = 8
|
|
GiveItem = 9
|
|
RemoveItem = 10
|
|
GetBadge = 11
|
|
|
|
Pokemon = 12
|
|
NPC = 13
|
|
Player = 14
|
|
Text = 15
|
|
Options = 16
|
|
SelectCase = 17
|
|
Wait = 18
|
|
Camera = 19
|
|
Battle = 20
|
|
Script = 21
|
|
Trainer = 22
|
|
Achievement = 23
|
|
Action = 24
|
|
Music = 25
|
|
Sound = 26
|
|
Register = 27
|
|
Unregister = 28
|
|
MessageBulb = 29
|
|
Entity = 30
|
|
Environment = 31
|
|
Value = 32
|
|
Level = 33
|
|
|
|
SwitchWhen = 34
|
|
SwitchEndWhen = 35
|
|
SwitchIf = 36
|
|
SwitchThen = 37
|
|
SwitchElse = 38
|
|
SwitchEndIf = 39
|
|
SwitchEnd = 40
|
|
|
|
' V2:
|
|
Command = 100
|
|
|
|
[if] = 101
|
|
[when] = 102
|
|
[then] = 103
|
|
[else] = 104
|
|
[endif] = 105
|
|
[end] = 106
|
|
[select] = 107
|
|
[endwhen] = 108
|
|
End Enum
|
|
|
|
Public ScriptV1 As New ScriptV1()
|
|
Public ScriptV2 As New ScriptV2()
|
|
|
|
Public ScriptLine As String = ""
|
|
Public Level As Integer = 0
|
|
|
|
Public Property Value() As String
|
|
Get
|
|
Select Case ActionScript.CSL().ScriptVersion
|
|
Case 1
|
|
Return ScriptV1.Value
|
|
Case 2
|
|
Return ScriptV2.Value
|
|
End Select
|
|
Return ""
|
|
End Get
|
|
Set(value As String)
|
|
Select Case ActionScript.CSL().ScriptVersion
|
|
Case 1
|
|
ScriptV1.Value = value
|
|
Case 2
|
|
ScriptV2.Value = value
|
|
End Select
|
|
End Set
|
|
End Property
|
|
|
|
Public Property ScriptType() As ScriptTypes
|
|
Get
|
|
Select Case ActionScript.CSL().ScriptVersion
|
|
Case 1
|
|
Return CType(ScriptV1.ScriptType, ScriptTypes)
|
|
Case 2
|
|
Return CType(ScriptV2.ScriptType, ScriptTypes)
|
|
End Select
|
|
Return 0
|
|
End Get
|
|
Set(value As ScriptTypes)
|
|
Select Case ActionScript.CSL().ScriptVersion
|
|
Case 1
|
|
ScriptV1.ScriptType = CType(value, ScriptV1.ScriptTypes)
|
|
Case 2
|
|
ScriptV2.ScriptType = CType(value, ScriptV2.ScriptTypes)
|
|
End Select
|
|
End Set
|
|
End Property
|
|
|
|
Public Property started() As Boolean
|
|
Get
|
|
Select Case ActionScript.CSL().ScriptVersion
|
|
Case 1
|
|
Return ScriptV1.started
|
|
Case 2
|
|
Return ScriptV2.started
|
|
End Select
|
|
Return False
|
|
End Get
|
|
Set(value As Boolean)
|
|
Select Case ActionScript.CSL().ScriptVersion
|
|
Case 1
|
|
ScriptV1.started = value
|
|
Case 2
|
|
ScriptV2.started = value
|
|
End Select
|
|
End Set
|
|
End Property
|
|
|
|
Public Property IsReady() As Boolean
|
|
Get
|
|
Select Case ActionScript.CSL().ScriptVersion
|
|
Case 1
|
|
Return ScriptV1.IsReady
|
|
Case 2
|
|
Return ScriptV2.IsReady
|
|
End Select
|
|
Return False
|
|
End Get
|
|
Set(value As Boolean)
|
|
Select Case ActionScript.CSL().ScriptVersion
|
|
Case 1
|
|
ScriptV1.IsReady = value
|
|
Case 2
|
|
ScriptV2.IsReady = value
|
|
End Select
|
|
End Set
|
|
End Property
|
|
|
|
Public Property CanContinue() As Boolean
|
|
Get
|
|
Select Case ActionScript.CSL().ScriptVersion
|
|
Case 1
|
|
Return ScriptV1.CanContinue
|
|
Case 2
|
|
Return ScriptV2.CanContinue
|
|
End Select
|
|
Return False
|
|
End Get
|
|
Set(value As Boolean)
|
|
Select Case ActionScript.CSL().ScriptVersion
|
|
Case 1
|
|
ScriptV1.CanContinue = value
|
|
Case 2
|
|
ScriptV2.CanContinue = value
|
|
End Select
|
|
End Set
|
|
End Property
|
|
|
|
Public Sub New(ByVal Line As String, ByVal Level As Integer)
|
|
Me.Level = Level
|
|
Me.ScriptLine = Line
|
|
|
|
Select Case ActionScript.CSL().ScriptVersion
|
|
Case 1
|
|
ScriptV1.Initialize(Line)
|
|
Case 2
|
|
If Line <> "" Then
|
|
ScriptV2.Initialize(Line)
|
|
End If
|
|
End Select
|
|
End Sub
|
|
|
|
Public Sub Update()
|
|
If Me.Level = ActionScript.ScriptLevelIndex Then
|
|
Select Case ActionScript.CSL().ScriptVersion
|
|
Case 1
|
|
ScriptV1.Update()
|
|
Case 2
|
|
ScriptV2.Update()
|
|
End Select
|
|
Else
|
|
Me.IsReady = True
|
|
End If
|
|
End Sub
|
|
|
|
Public Shared Sub NameRival(ByVal name As String)
|
|
Core.Player.RivalName = name
|
|
End Sub
|
|
|
|
Public Shared SaveNPCTrade() As String
|
|
|
|
Public Shared Sub ExitedNPCTrade()
|
|
Dim message2 As String = SaveNPCTrade(14)
|
|
Screen.TextBox.Show(message2, {}, False, False)
|
|
End Sub
|
|
|
|
Public Shared Sub DoNPCTradeHandler(ByVal params As Object())
|
|
DoNPCTrade(CInt(params(0)))
|
|
End Sub
|
|
|
|
Public Shared Sub DoNPCTrade(ByVal pokeIndex As Integer)
|
|
Core.SetScreen(Core.CurrentScreen.PreScreen)
|
|
|
|
Dim ownPokemon As Pokemon = Core.Player.Pokemons(pokeIndex)
|
|
|
|
Dim ownPokeID As Integer = ScriptConversion.ToInteger(Script.SaveNPCTrade(0))
|
|
Dim oppPokeID As Integer = ScriptConversion.ToInteger(Script.SaveNPCTrade(1))
|
|
|
|
Dim oppPokemon As Pokemon = Pokemon.GetPokemonByID(oppPokeID)
|
|
|
|
Dim Level As Integer = ownPokemon.Level
|
|
|
|
If StringHelper.IsNumeric(Script.SaveNPCTrade(2)) Then
|
|
Level = ScriptConversion.ToInteger(Script.SaveNPCTrade(2))
|
|
End If
|
|
|
|
oppPokemon.Generate(Level, True)
|
|
|
|
Dim Gender As Pokemon.Genders = ownPokemon.Gender
|
|
|
|
If StringHelper.IsNumeric(Script.SaveNPCTrade(3)) Then
|
|
Dim genderID As Integer = ScriptConversion.ToInteger(Script.SaveNPCTrade(3))
|
|
If genderID = -1 Then
|
|
genderID = Core.Random.Next(0, 2)
|
|
End If
|
|
|
|
Select Case genderID
|
|
Case 0
|
|
Gender = Pokemon.Genders.Male
|
|
Case 1
|
|
Gender = Pokemon.Genders.Female
|
|
Case 2
|
|
Gender = Pokemon.Genders.Genderless
|
|
Case Else
|
|
Gender = Pokemon.Genders.Male
|
|
End Select
|
|
End If
|
|
|
|
oppPokemon.Gender = Gender
|
|
|
|
If Script.SaveNPCTrade(4) <> "" Then
|
|
oppPokemon.Attacks.Clear()
|
|
Dim attacks() As String = {Script.SaveNPCTrade(4)}
|
|
If Script.SaveNPCTrade(4).Contains(",") = True Then
|
|
attacks = Script.SaveNPCTrade(4).Split(CChar(","))
|
|
End If
|
|
For Each attackID As String In attacks
|
|
If oppPokemon.Attacks.Count < 4 Then
|
|
oppPokemon.Attacks.Add(BattleSystem.Attack.GetAttackByID(ScriptConversion.ToInteger(attackID)))
|
|
End If
|
|
Next
|
|
End If
|
|
|
|
If Script.SaveNPCTrade(5) <> "" Then
|
|
oppPokemon.IsShiny = CBool(Script.SaveNPCTrade(5))
|
|
End If
|
|
|
|
oppPokemon.OT = Script.SaveNPCTrade(6)
|
|
oppPokemon.CatchTrainerName = Script.SaveNPCTrade(7)
|
|
oppPokemon.CatchBall = Item.GetItemByID(Script.SaveNPCTrade(8))
|
|
|
|
Dim itemID As String = Script.SaveNPCTrade(9)
|
|
If StringHelper.IsNumeric(itemID) Then
|
|
oppPokemon.Item = Item.GetItemByID(itemID)
|
|
End If
|
|
|
|
oppPokemon.CatchLocation = Script.SaveNPCTrade(10)
|
|
oppPokemon.CatchMethod = Script.SaveNPCTrade(11)
|
|
oppPokemon.NickName = Script.SaveNPCTrade(12)
|
|
|
|
Dim message1 As String = Script.SaveNPCTrade(13)
|
|
Dim message2 As String = Script.SaveNPCTrade(14)
|
|
|
|
Dim register As String = Script.SaveNPCTrade(15)
|
|
|
|
If ownPokeID = ownPokemon.Number Then
|
|
Core.Player.Pokemons.RemoveAt(pokeIndex)
|
|
Core.Player.Pokemons.Add(oppPokemon)
|
|
|
|
Dim pokedexType As Integer = 2
|
|
If oppPokemon.IsShiny = True Then
|
|
pokedexType = 3
|
|
End If
|
|
|
|
Dim dexID As String = PokemonForms.GetPokemonDataFileName(oppPokemon.Number, oppPokemon.AdditionalData)
|
|
If dexID.Contains("_") = False Then
|
|
If PokemonForms.GetAdditionalDataForms(oppPokemon.Number) IsNot Nothing AndAlso PokemonForms.GetAdditionalDataForms(oppPokemon.Number).Contains(oppPokemon.AdditionalData) Then
|
|
dexID = oppPokemon.Number & ";" & oppPokemon.AdditionalData
|
|
Else
|
|
dexID = oppPokemon.Number.ToString
|
|
End If
|
|
End If
|
|
|
|
Core.Player.PokedexData = Pokedex.ChangeEntry(Core.Player.PokedexData, dexID, pokedexType)
|
|
|
|
If register <> "" Then
|
|
ActionScript.RegisterID(register)
|
|
End If
|
|
|
|
Core.Player.AddPoints(10, "Traded with NPC.")
|
|
|
|
SoundManager.PlaySound("success_small")
|
|
Screen.TextBox.Show(message1 & "*" & Core.Player.Name & " traded~" & oppPokemon.GetName & " for~" & ownPokemon.GetName & "!", {}, False, False)
|
|
Else
|
|
Screen.TextBox.Show(message2, {}, False, False)
|
|
End If
|
|
End Sub
|
|
|
|
Public Function Clone() As Script
|
|
Return New Script(Me.ScriptLine, Me.Level)
|
|
End Function
|
|
|
|
Public Shared Function ParseArguments(ByVal inputString As String, Optional ByVal SeparatorChar As Char = CChar(",")) As List(Of String)
|
|
Dim arguments As New List(Of String)
|
|
Dim stringDeclaration As Boolean = False
|
|
Dim data As String = inputString
|
|
Dim cArg As String = ""
|
|
|
|
While data.Length > 0
|
|
Select Case data(0)
|
|
Case SeparatorChar
|
|
If stringDeclaration = True Then
|
|
cArg &= data(0).ToString()
|
|
Else
|
|
arguments.Add(cArg)
|
|
cArg = ""
|
|
End If
|
|
Case CChar("""")
|
|
If stringDeclaration = False Then
|
|
stringDeclaration = True
|
|
Else
|
|
If data.Length = 1 OrElse data(1) <> data(0) Then
|
|
stringDeclaration = Not stringDeclaration
|
|
ElseIf data.Length > 1 AndAlso data(1) = data(0) Then
|
|
If stringDeclaration = True Then
|
|
cArg &= """"
|
|
End If
|
|
data = data.Remove(0, 1)
|
|
End If
|
|
End If
|
|
Case Else
|
|
cArg &= data(0).ToString()
|
|
End Select
|
|
|
|
data = data.Remove(0, 1)
|
|
End While
|
|
|
|
arguments.Add(cArg)
|
|
|
|
Return arguments
|
|
End Function
|
|
|
|
End Class |