Control#
Introduction#
Control in Python lets you tell the robot when to wait, when to repeat actions, how to make decisions, and when to end the project.
Below is a list of available controls, including methods and core Python keywords:
wait– Pauses the project for a given time.for– Repeats code for each item in a sequence.if– Runs code if a condition is true.if/else– Runs different code depending on a condition.if/elif/else– Checks multiple conditions in order.while– Repeats code while a condition is true.break– Exits a loop immediately.program_stop– Ends the running program.pass– Placeholder used when no action is needed.
wait#
wait pauses for a specific amount of time before moving to the next line of code.
Usage:wait(time, units)
Parameters |
Description |
|---|---|
|
The amount of time to wait, as a positive whole number or decimal. |
|
The unit that represents the wait time: |
# Move the arm to the desired position and then blink the signal tower
arm.move_to(40, 140, 210, False)
wait(1, SECONDS)
signaltower_1.set_color(signal_tower.BLUE, signal_tower.BLINK)
for#
for repeats a set of actions a specific number of times. for can be used to loop through items in lists, tuples, dictionaries, sets, strings, or for a specified amount of loops with range.
Usage:
for value in expression_list:
pass
Components |
Description |
|---|---|
|
A temporary variable that stores the current element in the iteration. |
|
The collection of elements being looped through (e.g., list, string, range). |
# Move the arm 4 times by 100 millimeters on the y axis
for index in range(4):
arm.move_inc(0, 100, 0)
if#
if runs the indented block of code if the condition is True.
Usage:
if condition:
pass
Components |
Description |
|---|---|
|
An expression or variable that is checked when the statement runs. If it is |
# Display the time until the move is completed
arm.move_to(-100, 200, 100, False)
while True:
print("\033[2J")
print(timer.time(SECONDS))
wait(50, MSEC)
if arm.is_done():
timer.clear()
if/else#
if and else determine which indented block of code runs based on whether the condition is True or False.
Usage:
if condition:
pass
else:
pass
Components |
Description |
|---|---|
|
An expression or variable that is checked when the statement runs. If it is |
# Display the time until the move is completed
arm.move_to(-100, 200, 100, False)
while True:
if arm.is_done():
timer.clear()
else:
print("\033[2J")
print(timer.time(SECONDS))
wait(50, MSEC)
if/elif/else#
The if/elif/else structure selects which indented block of code runs based on conditions:
ifruns its block if the condition isTrue.elifchecks additional conditions only if all previous conditions areFalse. Multipleelifstatements can be used.elseruns its block only if none of the previous conditions areTrue.
Usage:
if condition:
pass
elif condition:
pass
else:
pass
Components |
Description |
|---|---|
|
An expression or variable that is checked when the statement runs. The first condition that is |
# Change the signal tower light if arm can reach to the desired position
while True:
if arm.can_arm_reach_to(200, 200, 200):
signaltower_1.set_color(signal_tower.BLUE, signal_tower.BLINK)
elif arm.can_arm_reach_to(300, 300, 300):
signaltower_1.set_color(signal_tower.GREEN, signal_tower.BLINK)
else:
signaltower_1.set_color(signal_tower.OFF, signal_tower.OFF)
wait(50, MSEC)
while#
while repeatedly runs code as long as the condition is True. It can also be used like a “forever” by using True as the condition, or a “wait until” by adding not to the condition, as shown in the examples below.
Usage:
while condition:
pass
Components |
Description |
|---|---|
|
An expression or variable that is checked before each iteration. If it is |
# Display the time until the move is completed
arm.move_to(-100, 200, 100, False)
while True:
if arm.is_done():
break
else:
print("\033[2J")
print(timer.time(SECONDS))
wait(50, MSEC)
# Blink blue light until the move is completed
signaltower_1.set_color(signal_tower.BLUE, signal_tower.BLINK)
arm.move_to(-100, 200, 100, False)
while not arm.is_done():
wait(0.2, SECONDS)
signaltower_1.set_color(signal_tower.BLUE, signal_tower.ON)
break#
break exits a loop immediately. break can be used to leave loops that otherwise would loop forever.
# Display the time until the move is completed
arm.move_to(-100, 200, 100, False)
while True:
if arm.is_done():
break
else:
print("\033[2J")
print(timer.time(SECONDS))
wait(50, MSEC)
program_stop#
program_stop ends a running project.
Usage:brain.program_stop()
Parameters |
Description |
|---|---|
This method has no parameters. |
# Stop the project until the move is completed
arm.move_to(-100, 200, 100, False)
while True:
if arm.is_done():
break
else:
print("\033[2J")
print(timer.time(SECONDS))
wait(50, MSEC)
brain.program_stop()
pass#
pass is a placeholder for future code and can be used to avoid errors in empty loops, conditionals, and functions.
if condition:
pass
def function():
pass