(Redirected from Wait () Secs (block))

"Wait" redirects here. For the other Control block with "wait" in its name, see Wait Until () (block).
Wait () Seconds
wait () seconds
Category Control
Type Stack
Introduced in 14Feb04

The wait () seconds block is a control block and a stack block. It pauses its script for the specified amount of seconds — the wait can also be a decimal number.

This block is one of the most commonly used blocks; it is used whenever a sprite must wait for another action.

Prior to Scratch 3.0, this block was previously called "wait () secs."

Time Waited

This block will always wait at least 1/30 of a second, or one frame. It will always resume upon the closest 1/30 second increment.

Note Note: If the project lags, this will not effect the time waited. Although this may be desirable, if you use other timing systems that do slow down when the project lags, when combined with this block, timing issues and discrepancies can arise.

Example Uses

This block creates a pause whenever needed. As there are many situations where this is necessary, the block is used in many projects. Some common uses:

  • Timers
forever
 wait (60) seconds
 change [minutes v] by (1)
repeat (10)
 wait (0.05) seconds
 next costume
wait (300) seconds
broadcast (Morning v)
when gf clicked
set [var v] to [0]
wait (0) seconds
change [var v] by (1)
  • In the Flash Player, allowing sprites to wait for a screen refresh so sprites can sense objects drawn by the pen.
stamp
go to x: (-50) y: (0)
wait (0) seconds
repeat until <touching color [#000000]?>{
change x by (1)
}::control loop

Workarounds

Main article: List of Block Workarounds

This block can be replicated using any of the following scripts:

Using the Timer

reset timer
wait until <not <(timer) < (value)>>

However, if the project resets the timer for other purposes, a different workaround should be used.

set [variable v] to (timer)
wait until <not <((timer) - (variable)) < (wait duration)>>

The workaround uses the timer as a base instead of a player-made clock because the timer is more accurate; player-made clocks lag from the time it takes to change the clock variable.

Using Glide () Secs to X: () Y: ()

glide (wait duration) secs to x: (x position) y: (y position)

This workaround will muddle whatever movement the sprite is performing at the time, so it is best to keep the workaround to immobile sprites.

Using Say () for () Seconds or Think () for () Seconds

say [ ] for (wait duration) seconds
think [ ] for (wait duration) seconds

These two workarounds will ruin any thoughts or sayings that the sprite has at the time, so they should only be used on sprites that do not think or talk.

Using Rest for () Beats

rest for (((tempo) / (60)) * (wait duration)) beats

Using Play Sound () Until Done

Note Note: This is assuming that the sound is exactly the wanted length.
play sound (silent sound v) until done
Cookies help us deliver our services. By using our services, you agree to our use of cookies.