(Holding Script)
(Non-Holding Script)
Line 22: Line 22:
  
 
===Non-Holding Script===
 
===Non-Holding Script===
This is the non-holding-allowed script, which you will want to use.
+
This is the script which does ''not'' allow holding, which you will want to use.
 
<scratchblocks>
 
<scratchblocks>
 
when flag clicked
 
when flag clicked
 
forever
 
forever
wait until <key [...] pressed>
+
wait until <key [... v] pressed>
 
next backdrop
 
next backdrop
wait until <not <key [...] pressed?>>
+
wait until <not <key [... v] pressed?>>
 
end
 
end
 
</scratchblocks>
 
</scratchblocks>
This will make it begin to sense the next key action after the key is released, which means you press the key and the backdrop will switch, then you need to release it and press it again to switch to next backdrop.
+
This will make it sense the key, perform an action, and wait for the key to be released before checking again. <!--This will make it begin to sense the next key action after the key is released, which means you press the key and the backdrop will switch, then you need to release it and press it again to switch to next backdrop.-->
 
You can also change the order to:
 
You can also change the order to:
 
<scratchblocks>
 
<scratchblocks>

Revision as of 16:11, 21 February 2016

Document stub.png This article or section may not have content matching Scratch Wiki editing standards. Please improve it according to Scratch Wiki:Guidelines and Scratch Wiki:Editing Conventions. (Date?)
Reason: Not enough information

Without much work, when you hold a button, it can do things the button was set to do for a repeated amount of times. However, if you want to make the button be not held, but only pressed once at a time, you can use the scripting in this tutorial.

What To Do

Holding Script

This is the script which will allow holding, which you want to avoid:

when flag clicked
forever
if <key [... v] pressed?>
next backdrop
end
end

If you use this one, you might go forward more than one backdrop before you release the key. You can also use this one:

when key [... v] pressed
next backdrop

That will make it a little better because there will be a tiny pause after a hat block, although holding will still work. This is why you do not want to use it in a platformer.

Non-Holding Script

This is the script which does not allow holding, which you will want to use.

when flag clicked
forever
wait until <key [... v] pressed>
next backdrop
wait until <not <key [... v] pressed?>>
end

This will make it sense the key, perform an action, and wait for the key to be released before checking again. You can also change the order to:

when flag clicked
forever
wait until <key [...] pressed?>
wait until <not <key [...] pressed?>>
next backdrop


If you use this code, you have to press the key, and the backdrop will not change until you release it.

Uses

A key tapping sensor could be useful for many things, such as announcement projects, or projects with only words. It's often important in these projects, that users don't skip through the information quickly, so this script could be useful. If one wants to create a platformer, the first code could be used to to create nice, smooth controls.