gpio: only setmode if it hasn't been set yet
This commit is contained in:
@@ -11,7 +11,8 @@ class Encoder:
|
|||||||
_curr_steps: int = 0
|
_curr_steps: int = 0
|
||||||
|
|
||||||
def setup(self):
|
def setup(self):
|
||||||
gpio.setmode(gpio.BCM)
|
if not gpio.getmode():
|
||||||
|
gpio.setmode(gpio.BCM)
|
||||||
|
|
||||||
gpio.setup(self.pin_a, gpio.IN)
|
gpio.setup(self.pin_a, gpio.IN)
|
||||||
gpio.setup(self.pin_b, gpio.IN)
|
gpio.setup(self.pin_b, gpio.IN)
|
||||||
|
|||||||
@@ -7,7 +7,10 @@ def main():
|
|||||||
motor = Motor([13, 19, 26])
|
motor = Motor([13, 19, 26])
|
||||||
motor.setup()
|
motor.setup()
|
||||||
motor.set_speed(10)
|
motor.set_speed(10)
|
||||||
motor.step(24 * 2)
|
|
||||||
|
while True:
|
||||||
|
input()
|
||||||
|
motor.step(1)
|
||||||
|
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
|
|||||||
@@ -13,12 +13,15 @@ class Motor:
|
|||||||
_step_configs: list[list[int]] = field(default_factory=lambda: [
|
_step_configs: list[list[int]] = field(default_factory=lambda: [
|
||||||
[[1, 0, 0], [0, 1, 0], [0, 0, 1]],
|
[[1, 0, 0], [0, 1, 0], [0, 0, 1]],
|
||||||
])
|
])
|
||||||
|
_next_step: int = 0
|
||||||
|
_period: int = 3
|
||||||
|
|
||||||
def __post_init__(self) -> None:
|
def __post_init__(self) -> None:
|
||||||
self.set_speed(4)
|
self.set_speed(4)
|
||||||
|
|
||||||
def setup(self) -> None:
|
def setup(self) -> None:
|
||||||
gpio.setmode(gpio.BCM)
|
if not gpio.getmode():
|
||||||
|
gpio.setmode(gpio.BCM)
|
||||||
|
|
||||||
for pin in self.pins:
|
for pin in self.pins:
|
||||||
gpio.setup(pin, gpio.OUT)
|
gpio.setup(pin, gpio.OUT)
|
||||||
@@ -28,22 +31,18 @@ class Motor:
|
|||||||
direction = int(steps / abs(steps))
|
direction = int(steps / abs(steps))
|
||||||
steps = abs(steps)
|
steps = abs(steps)
|
||||||
|
|
||||||
if direction > 0:
|
for i in range(steps):
|
||||||
_steps = range(0, steps)
|
self._step(direction)
|
||||||
else:
|
|
||||||
_steps = range(steps, 0, -1)
|
|
||||||
|
|
||||||
for i in _steps:
|
|
||||||
self._step(i % 3)
|
|
||||||
sleep(self._delay)
|
sleep(self._delay)
|
||||||
|
|
||||||
def set_speed(self, rpm: int) -> None:
|
def set_speed(self, rpm: int) -> None:
|
||||||
self._delay = 60 / self.rev_steps / rpm
|
self._delay = 60 / self.rev_steps / rpm
|
||||||
|
|
||||||
def _step(self, step_num: int):
|
def _step(self, direction: int):
|
||||||
assert (step_num >= 0 and step_num < 3)
|
print(self._next_step, self._next_step % self._period)
|
||||||
|
|
||||||
conf = self._step_configs[0][step_num]
|
conf = self._step_configs[0][self._next_step % self._period]
|
||||||
|
self._next_step += direction
|
||||||
|
|
||||||
for p, c in zip(self.pins, conf):
|
for p, c in zip(self.pins, conf):
|
||||||
gpio.output(p, c)
|
gpio.output(p, c)
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
import signal
|
import signal
|
||||||
|
|
||||||
|
|
||||||
def _cleanup(sig, frame):
|
def _cleanup(*args, **kwargs):
|
||||||
import sys
|
import sys
|
||||||
import RPi.GPIO as gpio
|
import RPi.GPIO as gpio
|
||||||
gpio.cleanup()
|
gpio.cleanup()
|
||||||
|
|||||||
Reference in New Issue
Block a user