这是 Raspberry PI | 类别中带有 40P 电缆的 T 型 GPIO 扩展板 板/传感器/显示器。
特点: - 兼容 Raspberry Pi 1B+、2B 和 3B;常用于增加输入、输出端口。
-40 针 GPIO 电缆可确保合适的连接,并可根据您的需求进行扩展。
-T型GPIO扩展板,扩展简单;适用于面包板测试。
规格:
适用型号:Raspberry Pi 1B+、2B 和 3B
铜芯电缆颜色有彩色和灰色
40 针母对母电缆连接器类型电缆长度:约 20 厘米/7.9 英寸 GPIO 扩展板尺寸:约 74 x 59 x 20 毫米/2.9 x 2.3 x 0.8 英寸
树莓派 Raspberry Pi B+ 专用配件 T型GPIO扩展板 开发板
可以用下面的代码导入RPi.GPIO模块。
importRPi.GPIOasGPIO
引入之后,就可以使用GPIO模块的函数了。如果你想检查模块是否引入成功,也可以这样写:
try:
importRPi.GPIOasGPIO
exceptRuntimeError:
print(“引入错误”)
针脚编号
在RPi.GPIO中,同时支持树莓派上的两种GPIO引脚编号。第一种编号是BOARD编号,这和树莓派电路板上的物理引脚编号相对应。使用这种编号的好处是,你的硬件将是一直可以使用的,不用担心树莓派的版本问题。因此,在电路板升级后,你不需要重写连接器或代码。
第二种编号是BCM规则,是更底层的工作方式,它和Broadcom的片上系统中信道编号相对应。在使用一个引脚时,你需要查找信道号和物理引脚编号之间的对应规则。对于不同的树莓派版本,编写的脚本文件也可能是无法通用的。
你可以使用下列代码(强制的)指定一种编号规则:
GPIO.setmode(GPIO.BOARD)
#or
GPIO.setmode(GPIO.BCM)
下面代码将返回被设置的编号规则
mode=GPIO.getmode()
警告
如果RPi.GRIO检测到一个引脚已经被设置成了非默认值,那么你将看到一个警告信息。你可以通过下列代码禁用警告:
GPIO.setwarnings(False)
引脚设置
在使用一个引脚前,你需要设置这些引脚作为输入还是输出。配置一个引脚的代码如下:
#将引脚设置为输入模式
GPIO.setup(channel,GPIO.IN)
#将引脚设置为输出模式
GPIO.setup(channel,GPIO.OUT)
#为输出的引脚设置默认值
GPIO.setup(channel,GPIO.OUT,initial=GPIO.HIGH)
释放
一般来说,程序到达最后都需要释放资源,这个好习惯可以避免偶然损坏树莓派。释放脚本中的使用的引脚:
GPIO.cleanup()
注意,GPIO.cleanup()只会释放掉脚本中使用的GPIO引脚,并会清除设置的引脚编号规则。
将端口设置为输出的状态:
要想点亮一个LED灯,或者驱动某个设备,都需要给电流和电压他们,这个步骤也很简单,设置引脚的输出状态就可以了,代码如下:
GPIO.output(channel,state)
状态可以设置为0/GPIO.LOW/False/1/GPIO.HIGH/True。如果编码规则为,GPIO.BOARD,那么channel就是对应引脚的数字。
如果想一次性设置多个引脚,可使用下面的代码:
chan_list=[11,12]
GPIO.output(chan_list,GPIO.LOW)
GPIO.output(chan_list,(GPIO.HIGH,GPIO.LOW))
你还可以使用Input()函数读取一个输出引脚的状态并将其作为输出值,例如:
GPIO.output(12,notGPIO.input(12))
读取
我们也常常需要读取引脚的输入状态,获取引脚输入状态如下代码:
GPIO.input(channel)
低电平返回0/GPIO.LOW/False,高电平返回1/GPIO.HIGH/True。
如果输入引脚处于悬空状态,引脚的值将是漂动的。换句话说,读取到的值是未知的,因为它并没有被连接到任何的信号上,直到按下一个按钮或开关。由于干扰的影响,输入的值可能会反复的变化。使用如下代码可以解决问题:
GPIO.setup(channel,GPIO.IN,pull_up_down=GPIO.PUD_UP)
#or
GPIO.setup(channel,GPIO.IN,pull_up_down=GPIO.PUD_DOWN)
需要注意的是,上面的读取代码只是获取当前一瞬间的引脚输入信号。
如果需要实时监控引脚的状态变化,可以有两种办法。最简单原始的方式是每隔一段时间检查输入的信号值,这种方式被称为轮询。如果你的程序读取的时机错误,则很可能会丢失输入信号。轮询是在循环中执行的,这种方式比较占用处理器资源。另一种响应GPIO输入的方式是使用中断(边缘检测),这里的边缘是指信号从高到低的变换(下降沿)或从低到高的变换(上升沿)。
轮询方式
whileGPIO.input(channel)==GPIO.LOW:
time.sleep(0.01)#wait10mstogiveCPUchancetodootherthings
边缘检测
边缘是指信号状态的改变,从低到高(上升沿)或从高到低(下降沿)。通常情况下,我们更关心于输入状态的该边而不是输入信号的值。这种状态的该边被称为事件。先介绍两个函数:
wait_for_edge()函数。wait_for_edge()被用于阻止程序的继续执行,直到检测到一个边沿。也就是说,上文中等待按钮按下的实例可以改写为:channel=GPIO.wait_for_edge(channel,GPIO_RISING,timeout=5000)
ifchannelisNone:
print(‘Timeoutoccurred’)
else:
print(‘Edgedetectedonchannel’,channel)
add_event_detect()函数该函数对一个引脚进行监听,一旦引脚输入状态发生了改变,调用event_detected()函数会返回true,如下代码:GPIO.add_event_detect(channel,GPIO.RISING)#addrisingedgedetectiononachannel
do_something()
//下面的代码放在一个线程循环执行。
ifGPIO.event_detected(channel):
print(‘Buttonpressed’)
上面的代码需要自己新建一个线程去循环检测event_detected()的值,还算是比较麻烦的。
不过可采用另一种办法轻松检测状态,这种方式是直接传入一个回调函数:
defmy_callback(channel):
print(‘Thisisaedgeeventcallbackfunction!’)
print(‘Edgedetectedonchannel%s’%channel)
print(‘Thisisruninadifferentthreadtoyourmainprogram’)
GPIO.add_event_detect(channel,GPIO.RISING,callback=my_callback)
如果你想设置多个回调函数,可以这样:
defmy_callback_one(channel):
print(‘Callbackone’)
defmy_callback_two(channel):
print(‘Callbacktwo’)
GPIO.add_event_detect(channel,GPIO.RISING)
GPIO.add_event_callback(channel,my_callback_one)
GPIO.add_event_callback(channel,my_callback_two)
注意:回调触发时,并不会同时执行回调函数,而是根据设置的顺序调用它们。
综合例子:点亮LED灯
上面说明了一大堆函数库的用法,那么现在就应该来个简单的实验了。这个实验很简单,点亮一个LED灯。
编写代码之前,首先你需要将led灯的针脚通过杜邦线连接到树莓派的引脚上,比如你可以连接到11号引脚。
新建一个main.py文件,写入如下代码:
importRPi.GPIOasGPIO//引入函数库
importtime
RPi.GPIO.setmode(GPIO.BOARD)//设置引脚编号规则
RPi.GPIO.setup(11,RPi.GPIO.OUT)//将11号引脚设置成输出模式
whileTrue
GPIO.output(channel,1)//将引脚的状态设置为高电平,此时LED亮了
time.sleep(1)//程序休眠1秒钟,让LED亮1秒
GPIO.output(channel,0)//将引脚状态设置为低电平,此时LED灭了
time.sleep(1)//程序休眠1秒钟,让LED灭1秒
GPIO.cleanup()//程序的最后别忘记清除所有资源
保存,并退出文件。执行python3main.py,即可观看效果。Ctrl+C可以关闭程序。
此外,不妨也试试其它的函数吧,增强印象。
使用PWM
这个python函数库还支持PWM模式的输出,我们可以利用PWM来制作呼吸灯效果。详情看代码:
importtime
importRPi.GPIOasGPIO//引入库
GPIO.setmode(GPIO.BOARD)//设置编号方式
GPIO.setup(12,GPIO.OUT)//设置12号引脚为输出模式
p=GPIO.PWM(12,50)//将12号引脚初始化为PWM实例,频率为50Hz
p.start(0)//开始脉宽调制,参数范围为:(0.0《=dc《=100.0)
try:
while1:
fordcinrange(0,101,5):
p.ChangeDutyCycle(dc)//修改占空比参数范围为:(0.0《=dc《=100.0)
time.sleep(0.1)
fordcinrange(100,-1,-5):
p.ChangeDutyCycle(dc)
time.sleep(0.1)
exceptKeyboardInterrupt:
pass
p.stop()//停止输出PWM波
GPIO.cleanup()//清除
结语
在文中,主要讲解了GPIO的概念,以及如何使用python操作GPIO。但是想要充分了解树莓派gpio编程,还需要自己实际动手操作以及分析总结。
以下为测试程序
# -*- coding: utf-8 -*- #通过声明可以在程序中书写中文
import RPi.GPIO as GPIO #引入RPi.GPIO库函数命名为GPIO
import time #引入计时time函数
# BOARD编号方式,基于插座引脚编号
GPIO.setmode(GPIO.BOARD) #将GPIO编程方式设置为BOARD模式
# 输出模式
GPIO.setup(11, GPIO.OUT) #将GPIO引脚11设置为输出引脚
while True: # 条件为真,下面程序一直循环执行
GPIO.output(11, GPIO.HIGH) #将11引脚电压置高,点亮LED灯
time.sleep(1) #延时1秒
GPIO.output(11, GPIO.LOW) #将11引脚电压置低,熄灭LED灯
time.sleep(1)