樹莓派內(nèi)核中已經(jīng)編譯自帶了 gpio 的驅(qū)動,我們常通過一些第三方寫好的庫函數(shù)來完成具體的操作,比較常見的操作庫函數(shù)有:
python GPIO
wiringPi
BCM2835 C Library
先安裝 python-dev,輸入以下指令。
sudo apt-get install python-dev
安裝 RPi.GPIO,依次輸入以下指令。
例子:
# -*- coding: utf-8 -*-
import RPi.GPIO as GPIO
import time
# BOARD編號方式,基于插座引腳編號
GPIO.setmode(GPIO.BOARD)
# 輸出模式
GPIO.setup(11, GPIO.OUT)
while True:
GPIO.output(11, GPIO.HIGH)
time.sleep(1)
GPIO.output(11, GPIO.LOW)
time.sleep(1)
執(zhí)行:
sudo python led.py
說明:
WiringPi 是應(yīng)用于樹莓派平臺的 GPIO 控制庫函數(shù),WiringPi 遵守 GUN Lv3。wiringPi 使用 C 或者 C++ 開發(fā)并且可以被其他語言包轉(zhuǎn),例如 Python、ruby 或者 PHP 等。 wiringPi 包括一套 gpio 控制命令,使用 gpio 命令可以控制樹莓派 GPIO 管腳。用戶可以利用 gpio 命令通過 shell 腳本控制或查詢 GPIO 管腳。wiringPi 是可以擴(kuò)展的,可以利用 wiringPi 的內(nèi)部模塊擴(kuò)展模擬量輸入芯片,可以使用 MCP23x17/MCP23x08(I2C 或者 SPI)擴(kuò)展 GPIO 接口。另外可通過樹莓派上的串口和 Atmega(例如 arduino 等)擴(kuò)展更多的 GPIO 功能。另外,用戶可以自己編寫擴(kuò)展模塊并把自定義的擴(kuò)展模塊集成到 wiringPi 中。WiringPi 支持模擬量的讀取和設(shè)置功能,不過在樹莓派上并沒有模擬量設(shè)備。但是使用 WiringPi 中的軟件模塊卻可以輕松地應(yīng)用 AD 或 DA 芯片。
git clone git://git.drogon.net/wiringPi
cd wiringPi
./build
build 腳本會幫助你編譯和安裝 wiringPi。
tar xfz wiringPi-xx.tar.gz
cd wiringPi-xx
./build
wiringPi 包括一套 gpio 命令,使用 gpio 命令可以控制樹莓派上的各種接口,通過以下指令可以測試wiringPi 是否安裝成功。
$gpio -v
$gpio readall
即可出現(xiàn)上面的 io 圖。
[cpp] view plaincopy 在 CODE 上查看代碼片派生到我的代碼片
#include <wiringPi.h>
int main(void)
{
wiringPiSetup() ;
pinMode (0, OUTPUT) ;
for(;;)
{
digitalWrite(0, HIGH) ; delay (500) ;
digitalWrite(0, LOW) ; delay (500) ;
}
}
在樹莓派上:
gcc -Wall -o test test.c -lwiringPi
sudo ./test
在虛擬機(jī)中:
am-linux-gcc -Wall -o test test.c -lwiringPi
sudo ./test
#include <bcm2835.h>
// P1插座第11腳
#define PIN RPI_GPIO_P1_11
int main(int argc, char **argv)
{
if (!bcm2835_init())
return 1;
// 輸出方式
bcm2835_gpio_fsel(PIN, BCM2835_GPIO_FSEL_OUTP);
while (1)
{
bcm2835_gpio_write(PIN, HIGH);
bcm2835_delay(100);
bcm2835_gpio_write(PIN, LOW);
bcm2835_delay(100);
}
bcm2835_close();
return 0;
}
注意事項(xiàng):
- IO 的編號方式略有不同,采用 wiring 編碼方式。
- -lwiringPi 表示動態(tài)加載 wiringPi 共享庫。
更多建議: