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
|
|
|
|
|
|
|
"""
|
2022-05-12 14:45:20 +01:00
|
|
|
An example of how to read the speed a mechanical rotary encoder is being turned at.
|
2022-04-19 20:22:35 +01:00
|
|
|
"""
|
|
|
|
|
|
|
|
# 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
|
|
|
capture = enc.capture()
|
|
|
|
|
|
|
|
print("Count =", capture.count, end=", ")
|
|
|
|
print("Angle =", capture.degrees, end=", ")
|
|
|
|
print("Freq =", capture.frequency, end=", ")
|
|
|
|
print("Speed =", capture.degrees_per_second)
|
2022-04-19 20:22:35 +01:00
|
|
|
|
|
|
|
time.sleep(0.1)
|