Compare commits
14 Commits
| Author | SHA1 | Date |
|---|---|---|
|
|
edc377261d | 4 years ago |
|
|
93a6e40cd7 | 5 years ago |
|
|
3db354710a | 6 years ago |
|
|
ece03e240c | 6 years ago |
|
|
3315e8ec75 | 6 years ago |
|
|
08cf3e43c1 | 8 years ago |
|
|
f91da63947 | 8 years ago |
|
|
e525fc5e5e | 8 years ago |
|
|
bd6b1c6a47 | 8 years ago |
|
|
747527fda6 | 8 years ago |
|
|
db5caf3ccb | 8 years ago |
|
|
ed4f8cb882 | 8 years ago |
|
|
bafb611350 | 8 years ago |
|
|
dfa3c420f2 | 8 years ago |
@ -1,3 +1,3 @@
|
|||||||
[submodule "WiringPi"]
|
[submodule "WiringPi"]
|
||||||
path = WiringPi
|
path = WiringPi
|
||||||
url = http://github.com/wiringPi/WiringPi
|
url = https://github.com/wiringPi/WiringPi
|
||||||
|
|||||||
@ -1,12 +0,0 @@
|
|||||||
all: bindings
|
|
||||||
python setup.py build
|
|
||||||
|
|
||||||
bindings:
|
|
||||||
swig3.0 -python -threads wiringpi.i
|
|
||||||
|
|
||||||
clean:
|
|
||||||
rm -rf build/
|
|
||||||
rm -rf dist/
|
|
||||||
|
|
||||||
install:
|
|
||||||
sudo python setup.py install
|
|
||||||
@ -1,90 +0,0 @@
|
|||||||
### Note
|
|
||||||
|
|
||||||
This is an unofficial port of Gordon's WiringPi library. Please do not email Gordon if you have issues, he will not be able to help.
|
|
||||||
|
|
||||||
For support, comments, questions, etc please join the WiringPi Discord channel: https://discord.gg/SM4WUVG
|
|
||||||
|
|
||||||
# WiringPi for Python
|
|
||||||
|
|
||||||
WiringPi: An implementation of most of the Arduino Wiring
|
|
||||||
functions for the Raspberry Pi
|
|
||||||
|
|
||||||
WiringPi implements new functions for managing IO expanders.
|
|
||||||
|
|
||||||
# Quick Install
|
|
||||||
|
|
||||||
`pip install wiringpi`
|
|
||||||
|
|
||||||
# Usage
|
|
||||||
|
|
||||||
import wiringpi
|
|
||||||
|
|
||||||
wiringpi.wiringPiSetup() # For sequential pin numbering, one of these MUST be called before using IO functions
|
|
||||||
# OR
|
|
||||||
wiringpi.wiringPiSetupSys() # For /sys/class/gpio with GPIO pin numbering
|
|
||||||
# OR
|
|
||||||
wiringpi.wiringPiSetupGpio() # For GPIO pin numbering
|
|
||||||
|
|
||||||
|
|
||||||
Setting up IO expanders (This example was tested on a quick2wire board with one digital IO expansion board connected via I2C):
|
|
||||||
|
|
||||||
wiringpi.mcp23017Setup(65,0x20)
|
|
||||||
wiringpi.pinMode(65,1)
|
|
||||||
wiringpi.digitalWrite(65,1)
|
|
||||||
|
|
||||||
**General IO:**
|
|
||||||
|
|
||||||
wiringpi.pinMode(6,1) # Set pin 6 to 1 ( OUTPUT )
|
|
||||||
wiringpi.digitalWrite(6,1) # Write 1 ( HIGH ) to pin 6
|
|
||||||
wiringpi.digitalRead(6) # Read pin 6
|
|
||||||
|
|
||||||
**Setting up a peripheral:**
|
|
||||||
WiringPi2 supports expanding your range of available "pins" by setting up a port expander. The implementation details of
|
|
||||||
your port expander will be handled transparently, and you can write to the additional pins ( starting from PIN_OFFSET >= 64 )
|
|
||||||
as if they were normal pins on the Pi.
|
|
||||||
|
|
||||||
wiringpi.mcp23017Setup(PIN_OFFSET,I2C_ADDR)
|
|
||||||
|
|
||||||
**Soft Tone**
|
|
||||||
|
|
||||||
Hook a speaker up to your Pi and generate music with softTone. Also useful for generating frequencies for other uses such as modulating A/C.
|
|
||||||
|
|
||||||
wiringpi.softToneCreate(PIN)
|
|
||||||
wiringpi.softToneWrite(PIN,FREQUENCY)
|
|
||||||
|
|
||||||
**Bit shifting:**
|
|
||||||
|
|
||||||
wiringpi.shiftOut(1,2,0,123) # Shift out 123 (b1110110, byte 0-255) to data pin 1, clock pin 2
|
|
||||||
|
|
||||||
**Serial:**
|
|
||||||
|
|
||||||
serial = wiringpi.serialOpen('/dev/ttyAMA0',9600) # Requires device/baud and returns an ID
|
|
||||||
wiringpi.serialPuts(serial,"hello")
|
|
||||||
wiringpi.serialClose(serial) # Pass in ID
|
|
||||||
|
|
||||||
**Full details at:**
|
|
||||||
http://www.wiringpi.com
|
|
||||||
|
|
||||||
# Manual Build
|
|
||||||
|
|
||||||
## Get/setup repo
|
|
||||||
```bash
|
|
||||||
git clone --recursive https://github.com/WiringPi/WiringPi-Python.git
|
|
||||||
cd WiringPi-Python
|
|
||||||
```
|
|
||||||
|
|
||||||
## Prerequisites
|
|
||||||
To rebuild the bindings
|
|
||||||
you **must** first have python-dev, python-setuptools and swig installed. Wiring Pi should also be installed system-wide
|
|
||||||
for access to the `gpio` tool.
|
|
||||||
```bash
|
|
||||||
sudo apt-get install python-dev python-setuptools swig wiringpi
|
|
||||||
```
|
|
||||||
|
|
||||||
## Build & install with
|
|
||||||
|
|
||||||
`sudo python setup.py install`
|
|
||||||
|
|
||||||
Or Python 3:
|
|
||||||
|
|
||||||
`sudo python3 setup.py install`
|
|
||||||
@ -0,0 +1,152 @@
|
|||||||
|
Note
|
||||||
|
~~~~
|
||||||
|
|
||||||
|
This is an unofficial port of Gordon's WiringPi library. Please do not
|
||||||
|
email Gordon if you have issues, he will not be able to help.
|
||||||
|
|
||||||
|
For support, comments, questions, etc please join the WiringPi Discord
|
||||||
|
channel: https://discord.gg/SM4WUVG
|
||||||
|
|
||||||
|
WiringPi for Python
|
||||||
|
~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
WiringPi: An implementation of most of the Arduino Wiring functions for
|
||||||
|
the Raspberry Pi.
|
||||||
|
|
||||||
|
WiringPi implements new functions for managing IO expanders.
|
||||||
|
|
||||||
|
**Alternative**
|
||||||
|
|
||||||
|
* `GPIO Zero <https://github.com/gpiozero/gpiozero>`_ is another Python library for controlling GPIO. It is installed by default in Raspberry Pi OS and is used in the `Raspberry Pi GPIO documentation <https://www.raspberrypi.org/documentation/usage/gpio/python/>`_.
|
||||||
|
|
||||||
|
Quick Install
|
||||||
|
=============
|
||||||
|
|
||||||
|
.. image:: https://badge.fury.io/py/wiringpi.svg
|
||||||
|
:alt: PyPI version badge
|
||||||
|
:target: https://pypi.org/project/wiringpi/
|
||||||
|
|
||||||
|
The library is packaged on PyPI and can be installed with pip:
|
||||||
|
|
||||||
|
``pip install wiringpi``
|
||||||
|
|
||||||
|
Usage
|
||||||
|
=====
|
||||||
|
|
||||||
|
.. code:: python
|
||||||
|
|
||||||
|
import wiringpi
|
||||||
|
|
||||||
|
# One of the following MUST be called before using IO functions:
|
||||||
|
wiringpi.wiringPiSetup() # For sequential pin numbering
|
||||||
|
# OR
|
||||||
|
wiringpi.wiringPiSetupSys() # For /sys/class/gpio with GPIO pin numbering
|
||||||
|
# OR
|
||||||
|
wiringpi.wiringPiSetupGpio() # For GPIO pin numbering
|
||||||
|
|
||||||
|
**General IO:**
|
||||||
|
|
||||||
|
.. code:: python
|
||||||
|
|
||||||
|
wiringpi.pinMode(6, 1) # Set pin 6 to 1 ( OUTPUT )
|
||||||
|
wiringpi.digitalWrite(6, 1) # Write 1 ( HIGH ) to pin 6
|
||||||
|
wiringpi.digitalRead(6) # Read pin 6
|
||||||
|
|
||||||
|
**Setting up a peripheral:**
|
||||||
|
|
||||||
|
WiringPi supports expanding your range of available "pins" by setting up
|
||||||
|
a port expander. The implementation details of your port expander will
|
||||||
|
be handled transparently, and you can write to the additional pins
|
||||||
|
(starting from PIN\_OFFSET >= 64) as if they were normal pins on the Pi.
|
||||||
|
|
||||||
|
.. code:: python
|
||||||
|
|
||||||
|
wiringpi.mcp23017Setup(PIN_OFFSET, I2C_ADDR)
|
||||||
|
|
||||||
|
This example was tested on a quick2wire board with one digital IO
|
||||||
|
expansion board connected via I2C:
|
||||||
|
|
||||||
|
.. code:: python
|
||||||
|
|
||||||
|
wiringpi.mcp23017Setup(65, 0x20)
|
||||||
|
wiringpi.pinMode(65, 1)
|
||||||
|
wiringpi.digitalWrite(65, 1)
|
||||||
|
|
||||||
|
**Soft Tone:**
|
||||||
|
|
||||||
|
Hook a speaker up to your Pi and generate music with softTone. Also
|
||||||
|
useful for generating frequencies for other uses such as modulating A/C.
|
||||||
|
|
||||||
|
.. code:: python
|
||||||
|
|
||||||
|
wiringpi.softToneCreate(PIN)
|
||||||
|
wiringpi.softToneWrite(PIN, FREQUENCY)
|
||||||
|
|
||||||
|
**Bit shifting:**
|
||||||
|
|
||||||
|
.. code:: python
|
||||||
|
|
||||||
|
wiringpi.shiftOut(1, 2, 0, 123) # Shift out 123 (b1110110, byte 0-255) to data pin 1, clock pin 2
|
||||||
|
|
||||||
|
**Serial:**
|
||||||
|
|
||||||
|
.. code:: python
|
||||||
|
|
||||||
|
serial = wiringpi.serialOpen('/dev/ttyAMA0', 9600) # Requires device/baud and returns an ID
|
||||||
|
wiringpi.serialPuts(serial, "hello")
|
||||||
|
wiringpi.serialClose(serial) # Pass in ID
|
||||||
|
|
||||||
|
**SPI:**
|
||||||
|
|
||||||
|
The ``wiringPiSPIDataRW()`` function needs to be passed a ``bytes``
|
||||||
|
object in Python 3. In Python 2, it takes a string. The following should
|
||||||
|
work in either Python 2 or 3:
|
||||||
|
|
||||||
|
.. code:: python
|
||||||
|
|
||||||
|
wiringpi.wiringPiSPISetup(channel, speed)
|
||||||
|
buf = bytes([your data here])
|
||||||
|
retlen, retdata = wiringpi.wiringPiSPIDataRW(0, buf)
|
||||||
|
|
||||||
|
Now, ``retlen`` will contain the number of bytes received/read by the
|
||||||
|
call. ``retdata`` will contain the data itself, and in Python 3, ``buf``
|
||||||
|
will have been modified to contain it as well (that won't happen in
|
||||||
|
Python 2, because then ``buf`` is a string, and strings are immutable).
|
||||||
|
|
||||||
|
**Full details of the API at:** http://www.wiringpi.com
|
||||||
|
|
||||||
|
Manual Build
|
||||||
|
============
|
||||||
|
|
||||||
|
Get/setup repo
|
||||||
|
--------------
|
||||||
|
|
||||||
|
.. code:: bash
|
||||||
|
|
||||||
|
git clone --recursive https://github.com/WiringPi/WiringPi-Python.git
|
||||||
|
cd WiringPi-Python
|
||||||
|
|
||||||
|
Don't forget the ``--recursive``; it is required to also pull in the
|
||||||
|
WiringPi C code from its own repository.
|
||||||
|
|
||||||
|
Prerequisites
|
||||||
|
-------------
|
||||||
|
|
||||||
|
To rebuild the bindings you **must** first have installed ``swig``,
|
||||||
|
``python-dev``, and ``python-setuptools`` (or their ``python3-``
|
||||||
|
equivalents). WiringPi should also be installed system-wide for access
|
||||||
|
to the ``gpio`` tool.
|
||||||
|
|
||||||
|
.. code:: bash
|
||||||
|
|
||||||
|
sudo apt-get install python-dev python-setuptools swig wiringpi
|
||||||
|
|
||||||
|
Build & install with
|
||||||
|
--------------------
|
||||||
|
|
||||||
|
``sudo python setup.py install``
|
||||||
|
|
||||||
|
Or Python 3:
|
||||||
|
|
||||||
|
``sudo python3 setup.py install``
|
||||||
|
|
||||||
@ -1 +1 @@
|
|||||||
Subproject commit c9476436016c995d3327e4765a73de7848d4af56
|
Subproject commit e9821abdb4b4fe46a2ea9243471d339435fa7bde
|
||||||
@ -0,0 +1,16 @@
|
|||||||
|
# Test of the softTone module in wiringPi
|
||||||
|
# Plays a scale out on pin 3 - connect pizeo disc to pin 3 & 0v
|
||||||
|
import wiringpi
|
||||||
|
|
||||||
|
PIN = 3
|
||||||
|
|
||||||
|
SCALE = [262, 294, 330, 349, 392, 440, 494, 525]
|
||||||
|
|
||||||
|
wiringpi.wiringPiSetup()
|
||||||
|
wiringpi.softToneCreate(PIN)
|
||||||
|
|
||||||
|
while True:
|
||||||
|
for idx in range(8):
|
||||||
|
print(idx)
|
||||||
|
wiringpi.softToneWrite(PIN, SCALE[idx])
|
||||||
|
wiringpi.delay(500)
|
||||||
Loading…
Reference in new issue