Hopefully fix waterfalls this time

This commit is contained in:
JappaWakka 2023-04-20 15:54:53 +02:00
parent 46c814410c
commit 489af57626
4 changed files with 20 additions and 11 deletions

View File

@ -71,6 +71,9 @@
s &= ":end"
CType(Core.CurrentScreen, OverworldScreen).ActionScript.StartScript(s, 2, False)
If CType(Core.CurrentScreen, OverworldScreen).ActionScript.IsReady = True And CType(Screen.Camera, OverworldCamera).PreventMovement = True Then
CType(Screen.Camera, OverworldCamera).PreventMovement = False
End If
Return True
Else
CType(Screen.Camera, OverworldCamera).PreventMovement = False
@ -169,6 +172,9 @@
s &= ":end"
CType(Core.CurrentScreen, OverworldScreen).ActionScript.StartScript(s, 2, False)
If CType(Core.CurrentScreen, OverworldScreen).ActionScript.IsReady = True And CType(Screen.Camera, OverworldCamera).PreventMovement = True Then
CType(Screen.Camera, OverworldCamera).PreventMovement = False
End If
Else
CType(Screen.Camera, OverworldCamera).PreventMovement = False
End If

View File

@ -199,7 +199,7 @@
If Me.ActionValue = 1 Then
Exit Sub
End If
CType(Screen.Camera, OverworldCamera).PreventMovement = True
Dim isOnTop As Boolean = True
Dim OnTopcheckPosition As Vector3 = New Vector3(Me.Position.X, Me.Position.Y + 1, Me.Position.Z)
Dim Oe As Entity = GetEntity(Screen.Level.Entities, OnTopcheckPosition, True, {GetType(Waterfall)})
@ -234,6 +234,7 @@
End While
s = "version=2" & Environment.NewLine &
"@player.preventmovement" & Environment.NewLine &
"@player.stopmovement" & Environment.NewLine &
"@player.move(2)" & Environment.NewLine &
"@player.setmovement(0,-1,0)" & Environment.NewLine &
@ -243,6 +244,9 @@
":end"
CType(Core.CurrentScreen, OverworldScreen).ActionScript.StartScript(s, 2)
If CType(Core.CurrentScreen, OverworldScreen).ActionScript.IsReady = True And CType(Screen.Camera, OverworldCamera).PreventMovement = True Then
CType(Screen.Camera, OverworldCamera).PreventMovement = False
End If
End If
End Sub
@ -253,7 +257,6 @@
Dim p As Pokemon = ReturnWaterFallPokemonName()
If GameController.IS_DEBUG_ACTIVE = True OrElse Core.Player.SandBoxMode = True OrElse Badge.CanUseHMMove(Badge.HMMoves.Waterfall) = True AndAlso Not p Is Nothing Then
CType(Screen.Camera, OverworldCamera).PreventMovement = True
Dim s As String = ""
Dim pName As String = ""
@ -284,6 +287,7 @@
End If
End While
s = "version=2" & Environment.NewLine &
"@player.preventmovement" & Environment.NewLine &
"@player.stopmovement" & Environment.NewLine &
"@pokemon.cry(" & pNumber & ")" & Environment.NewLine &
"@sound.play(select)" & Environment.NewLine &
@ -297,7 +301,9 @@
PlayerStatistics.Track("Waterfall used", 1)
CType(Core.CurrentScreen, OverworldScreen).ActionScript.StartScript(s, 2)
If CType(Core.CurrentScreen, OverworldScreen).ActionScript.IsReady = True And CType(Screen.Camera, OverworldCamera).PreventMovement = True Then
CType(Screen.Camera, OverworldCamera).PreventMovement = False
End If
Return False
Else
CType(Screen.Camera, OverworldCamera).PreventMovement = False

View File

@ -3,7 +3,6 @@ Public Class ActionScript
Public Scripts As New List(Of Script)
Public AllowMovementAfterEnd As Boolean = False
Public Class ScriptLevel
Public WaitingEndWhen As New List(Of Boolean)
Public Switched As New List(Of Boolean)
@ -80,10 +79,6 @@ nextScript:
reDelay = 0.0F
End If
End If
If AllowMovementAfterEnd = True Then
CType(Screen.Camera, OverworldCamera).PreventMovement = False
AllowMovementAfterEnd = False
End If
End If
End Sub

View File

@ -228,9 +228,11 @@
IsReady = True
Case "allowmovement"
CType(CurrentScreen, OverworldScreen).ActionScript.AllowMovementAfterEnd = True
If CType(Screen.Camera, OverworldCamera)._moved = 0.0F Then
CType(Screen.Camera, OverworldCamera).PreventMovement = False
IsReady = True
End If
Case "money", "addmoney"
Core.Player.Money += int(argument)