Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/redoxcode/micropython-servo
A micropython library to control rc servos in a tidy way
https://github.com/redoxcode/micropython-servo
micropython servo servo-motor
Last synced: 3 months ago
JSON representation
A micropython library to control rc servos in a tidy way
- Host: GitHub
- URL: https://github.com/redoxcode/micropython-servo
- Owner: redoxcode
- License: mit
- Created: 2023-01-05T15:44:53.000Z (about 2 years ago)
- Default Branch: main
- Last Pushed: 2023-09-27T06:57:12.000Z (over 1 year ago)
- Last Synced: 2024-10-10T06:28:16.001Z (3 months ago)
- Topics: micropython, servo, servo-motor
- Language: Python
- Homepage:
- Size: 9.77 KB
- Stars: 13
- Watchers: 1
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-micropython - micropython-servo - Library to control RC servos using direct PWM output in a tidy way. (Libraries / Motion)
README
[![pypi version shield](https://img.shields.io/pypi/v/micropython-servo)](https://pypi.org/project/micropython-servo/) [![pypi downloads per month shield](https://img.shields.io/pypi/dm/micropython-servo?color=brightgreen)](https://pypi.org/project/micropython-servo/)
## Description
A micropython library to control rc servos in a tidy way.This uses hardware PWM as an efficient way to generate the ouput signal.
But therefore servos need to be connected to pins with PWM functionallity.The servos can be calibrated using 2 points (min / max position).
The default values should work for most servos, but won't set the servo to the exact position, as these values are different for each servo model.## Examples
### Move servo
```Python
import time
from servo import Servo
my_servo = Servo(pin_id=28)
my_servo.write(30)
time.sleep(2.0)
my_servo.write(60)
time.sleep(2.0)
my_servo.write(90)```
## API
### class Servo(pin_id,min_us=544.0,max_us=2400.0,min_deg=0.0,max_deg=180.0,freq=50)
- pin_id: id of the pin connected to the servo
- min_us: minimal pulse width (calibration point 1 / there is no clipping if you try to set the servo to a lower value)
- max_us: maximal pulse width (calibration point 2 / there is no clipping if you try to set the servo to a higher value)
- min_deg: minimal position in degrees (calibration point 1 / there is no clipping if you try to set the servo to a lower value)
- max_deg: maximal position in degrees (calibration point 2 / there is no clipping if you try to set the servo to a higher value)```write(deg)```
- move the servo to the given position
- deg: Position in degrees```read()```
- returns the position last set in degrees```write_rad(rad)```
- move the servo to the given position
- rad: Position in radians```read_rad()```
- returns the position last set in radians```write_us(us)```
- set the pulse width for the servo
- us: Pulse width in us```read_us()```
- returns the last set puls width```off()```
- disables the output