(Redirected from Procedures)
Custom blocks allow for one to make their own programming blocks. Using custom blocks, similar scripts can be compressed into one reusable block. In some other programming languages, custom blocks are called "procedures," "functions," or "methods." This block is useful for reusing a sequence of blocks in different parts of code, without duplicating the blocks each usage.
Custom Blocks in Scratch
define jump (how far) change y by (how far) wait (0.5) secs change y by ((0) - (how far)) when gf clicked jump (10) move (20) steps jump (20)
The custom block palette starts off empty and only shows a "Make a Block" button (similar to the "Make a Variable/List" buttons in the data palette). For each Define block (whether from the make a block button, or by dragging in from the backpack or another sprite), a custom block is shown in the palette. The custom block is only available to the sprite that has the Define block.
Custom blocks can only be stack blocks, and can not be reporters or booleans (though they may be added in the future). They support recursion, so blocks can call themselves (This does not stop the current block executing, unlike broadcasts). This allows for things like creating fractals and finding the factorial of a number.
Creating a Custom Block
To create a custom block, open the "More Blocks" category and press the "Make a Block" button. A new block menu will open, where you can name your custom block.
After naming and adding arguments, a Define () block is created. A custom block's settings can later be changed by right-clicking on its Define block or the custom block itself and selecting "edit". You can define what your custom block does by snapping a script onto its Define block, as shown below.
spin right (360) degrees define spin right (amount) degrees repeat (amount) turn right (1) degrees end
|Note:||When a custom block is created, it exists only for the sprite where it was created. To use a custom block in another sprite, you must create it again in that sprite.|
Scratch 1.x Workaround
when gf clicked set [how far v] to  broadcast [jump v] and wait when I receive [jump v] change y by (how far) wait (.5) secs change y by ((0) - (how far))