Procedures
Procedure (aka function) is a named group of puzzles that performs a specific task. By organizing your puzzles in procedures you can make your scenarios more compact and maintainable.
- Creating Procedures
- Calling Procedures
- Procedures with Return Value
- Using "if return" Puzzle
- Calling Procedures from JavaScript
Creating Procedures
A new procedure can be created by dragging out the procedure definition puzzle from the toolbox:
data:image/s3,"s3://crabby-images/041a1/041a14b4d2729ad8a6c70dcffe2c48af82939fba" alt="Procedures in visual programming editor"
A newly created procedure puzzle can be renamed and filled up with other puzzles to perform some task:
data:image/s3,"s3://crabby-images/4e3a7/4e3a79a3793129effeb0619e7c8f01261aa57e82" alt="Example of a visual logic procedure"
Calling Procedures
To be able to trigger (to call) a procedure, drag out the corresponding puzzle from the toolbox:
data:image/s3,"s3://crabby-images/0a1d7/0a1d7c0a34be46f39dd48e36c887bccc151eb34e" alt="Running visual programming procedure"
A procedure can be triggered several times and from several places of a Puzzles scenario. This may allow for re-using puzzles rather than straight-copying similar set of puzzles several times. For example, an animation can be launched whenever the user clicks the object itself or an HTML button (thus securing duplicate controls).
data:image/s3,"s3://crabby-images/4b576/4b576709096abd6742397fa473afe6c4122a4d56" alt="Running visual programming procedure multiple times"
A procedure may have additional input parameters (aka arguments). To add an input to your procedure, click the gear icon and drag out a parameter puzzle from the toolbox on the left, sticking it in the inputs puzzle:
data:image/s3,"s3://crabby-images/2b561/2b5614b82f26429286054eb661c61521a4754899" alt="Arguments of visual programming procedures"
To be able to use an input parameter inside a procedure, drag out the corresponding "get" variable puzzle created automatically in "Variables":
data:image/s3,"s3://crabby-images/de70e/de70e2a9b06cc03c4d5b79671b3359af9b0d9fc0" alt="Procedure params shown as variables in the visual logic editor"
This variable can be used as a substitute for actual data (such as object names) to perform some task with.
data:image/s3,"s3://crabby-images/c0274/c02747d7e5842c5b8e31988ddcfb138a59f0b345" alt="Example of procedure argument"
When triggering a procedure with inputs, provide the data for each trigger puzzle.
data:image/s3,"s3://crabby-images/3ea16/3ea168f67ae1acd1724a6f27ef4935541086ca7d" alt="Calling visual programming procedures with arguments multiple times"
You can jump from a trigger puzzle to the corresponding procedure definition puzzle using the right-click menu:
data:image/s3,"s3://crabby-images/7d2fb/7d2fbc4195da01e254345eb2cc775a3c642381c9" alt="Jump to procedure in visual logic editor"
Procedures can also be called by using the get procedure and call procedure puzzles. This way a procedure can be obtained, stored in a variable, passed into another procedure as a parameter and called later whenever needed.
Procedures with Return Value
A procedure may output a computed value to its caller (aka return value). To create such a procedure, from the toolbox drag out the variant of the procedure puzzle with the return slot.
data:image/s3,"s3://crabby-images/ba76a/ba76aaad22292eb3bb5f7f4a2bc67f4dba0f79f7" alt="Returning value from visual programming procedure"
Using "if return" Puzzle
A procedure may return a value upon some condition before all inside puzzles are interpreted. In this case the procedure stops running prematurely.
data:image/s3,"s3://crabby-images/f59b2/f59b2d166a6e86741aabcd68eafa55b964232fe5" alt="Early return from visual logic procedure"
Calling Procedures from JavaScript
To execute Puzzles procedures from JavaScript code use either the puzzles
argument of the runCode()
function of your_app_name.js module or the built-in puzzles
variable inside the exec script puzzle:
puzzles.procedures['myProcedure']();
Having Troubles with Puzzles?
Seek help on the forums!