2022-04-19 20:22:35 +01:00
|
|
|
import gc
|
|
|
|
import time
|
|
|
|
from encoder import Encoder
|
2022-05-12 16:15:40 +01:00
|
|
|
# from encoder import REVERSED_DIR
|
2022-04-19 20:22:35 +01:00
|
|
|
|
|
|
|
"""
|
|
|
|
An example of how to read a mechanical rotary encoder.
|
|
|
|
"""
|
|
|
|
|
|
|
|
# Free up hardware resources ahead of creating a new Encoder
|
|
|
|
gc.collect()
|
|
|
|
|
|
|
|
# Create an encoder on the 3 ADC pins, using PIO 0 and State Machine 0
|
|
|
|
PIN_A = 26 # The A channel pin
|
|
|
|
PIN_B = 28 # The B channel pin
|
|
|
|
PIN_C = 27 # The common pin
|
|
|
|
enc = Encoder(0, 0, (PIN_A, PIN_B), PIN_C)
|
|
|
|
|
|
|
|
# Uncomment the below line (and the top import) to reverse the counting direction
|
2022-05-12 16:15:40 +01:00
|
|
|
# enc.direction(REVERSED_DIR)
|
2022-04-19 20:22:35 +01:00
|
|
|
|
2022-05-12 14:45:20 +01:00
|
|
|
|
2022-04-19 20:22:35 +01:00
|
|
|
# Loop forever
|
|
|
|
while True:
|
2022-05-12 14:45:20 +01:00
|
|
|
|
2022-04-19 20:22:35 +01:00
|
|
|
# Print out the count, delta, step, and turn
|
|
|
|
print("Count =", enc.count(), end=", ")
|
|
|
|
print("Delta =", enc.delta(), end=", ")
|
|
|
|
print("Step =", enc.step(), end=", ")
|
|
|
|
print("Turn =", enc.turn())
|
|
|
|
|
|
|
|
time.sleep(0.1)
|