2022-10-06 12:27:46 +01:00
|
|
|
import time
|
|
|
|
from automation import Automation2040W, SWITCH_A
|
|
|
|
|
2022-10-06 15:54:16 +01:00
|
|
|
# Uncomment for Automation2040W Mini and comment out above import
|
|
|
|
# from automation import Automation2040WMini, SWITCH_A
|
|
|
|
|
2022-10-06 12:27:46 +01:00
|
|
|
"""
|
|
|
|
Demonstrates how to toggle each of Automation 2040 W's output terminals.
|
|
|
|
|
|
|
|
Press "A" to exit the program.
|
|
|
|
"""
|
|
|
|
|
|
|
|
TIME_PER_TOGGLE = 0.5 # How much time to wait between each toggle (in seconds)
|
|
|
|
OUTPUT_NAMES = ("O1", "O2", "O3") # The friendly names to give each digital output
|
|
|
|
|
|
|
|
# Create a new Automation2040W
|
|
|
|
board = Automation2040W()
|
2022-10-06 15:54:16 +01:00
|
|
|
# Uncomment for Automation2040W Mini
|
|
|
|
# board = Automation2040WMini()
|
2022-10-06 12:27:46 +01:00
|
|
|
|
|
|
|
# Enable the LED of the switch used to exit the loop
|
|
|
|
board.switch_led(SWITCH_A, 50) # Half Brightness
|
|
|
|
|
|
|
|
toggle = True
|
|
|
|
index = 0
|
|
|
|
|
|
|
|
# Toggle the outputs until the user switch is pressed
|
|
|
|
while not board.switch_pressed(SWITCH_A):
|
|
|
|
|
|
|
|
# Toggle an output
|
|
|
|
for output_percentage in range(101):
|
|
|
|
|
|
|
|
if toggle is True:
|
|
|
|
board.output(index, output_percentage)
|
|
|
|
else:
|
|
|
|
board.output(index, 100.0 - output_percentage)
|
|
|
|
|
|
|
|
# Print the state of all outputs
|
|
|
|
for i in range(board.NUM_OUTPUTS):
|
|
|
|
print(OUTPUT_NAMES[i], " = ", board.output_percent(i), sep="", end=", ")
|
|
|
|
|
|
|
|
# Print a new line
|
|
|
|
print()
|
|
|
|
time.sleep(0.01)
|
|
|
|
|
|
|
|
index += 1 # Move on to the next output
|
|
|
|
if index >= board.NUM_OUTPUTS:
|
|
|
|
index = 0 # Go back to the first output
|
|
|
|
toggle = not toggle # Invert the toggle value
|
|
|
|
|
|
|
|
time.sleep(TIME_PER_TOGGLE)
|
|
|
|
|
|
|
|
# Put the board back into a safe state
|
|
|
|
board.reset()
|