drivers: vibrator: Finalize docstrings

This commit is contained in:
Daniel Thompson 2020-05-14 21:42:16 +01:00
parent 95f1788347
commit 42fe7bf352
2 changed files with 18 additions and 3 deletions

View file

@ -56,7 +56,6 @@ Device drivers
.. automodule:: drivers.vibrator
:members:
:undoc-members:
Libraries
---------

View file

@ -1,13 +1,25 @@
# SPDX-License-Identifier: LGPL-3.0-or-later
# Copyright (C) 2020 Daniel Thompson
# Generic PWM capable vibrator
"""Generic PWM capable vibration motor driver
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
"""
import time
from machine import PWM
class Vibrator(object):
"""Vibration motor driver.
.. automethod:: __init__
"""
def __init__(self, pin, active_low=False):
"""Specify the pin and configuration used to operate the motor.
:param machine.Pin pin: The PWM-capable pin used to driver the
vibration motor.
:param bool active_low: Invert the resting state of the motor.
"""
pin.value(active_low)
self.pin = pin
self.freq = PWM.FREQ_16MHZ
@ -15,9 +27,13 @@ class Vibrator(object):
self.active_low = active_low
def pulse(self, duty=25, ms=40):
"""Briefly pulse the motor.
:param int duty: Duty cycle, in percent.
:param int ms: Duration, in milliseconds.
"""
pwm = PWM(0, self.pin, freq=self.freq, duty=duty, period=self.period)
pwm.init()
time.sleep_ms(ms)
pwm.deinit()
self.pin.value(self.active_low)