class ExtInt – 配置 I/O 引脚以在外部事件上触发中断¶
总共有22条中断线路。其中16条可以来自 GPIO引脚,剩下6条来自内部源。
对于 0 到 15 号线,给定的线路可以映射到任意端口的相应线路。因此,线路 0 可以映射到 Px0,其中 x 是 A、B、C,…,而线路 1 可以映射到 Px1,其中 x 是 A、B、C,…
def callback(line):
print("line =", line)
注意:ExtInt 将自动将 gpio 引线配置为输入。:
extint = pyb.ExtInt(pin, pyb.ExtInt.IRQ_FALLING, pyb.Pin.PULL_UP, callback)
现在,每当在引脚上看到下降沿时,将调用回调函数。注意:机械按键存在“抖动”,按下或释放开关通常会生成多个边缘。参见:http://www.eng.utah.edu/~cs5780/debouncing.pdf,其中详细说明了去抖动的各种技术。
尝试在用一个引脚上注册2个回调将引发异常。
如果将引脚传递为整数,则假定它映射到内部中断源之一,并且必须在16到22范围内。
所以其他引脚对象都通过引脚映射器来获取其中一个GPIO引脚。:
extint = pyb.ExtInt(pin, mode, pull, callback)
有效的模式为 pyb.ExtInt.IRQ_RISING、pyb.ExtInt.IRQ_FALLING、pyb.ExtInt.IRQ_RISING_FALLING、pyb.ExtInt.EVT_RISING、pyb.ExtInt.EVT_FALLING 和 pyb.ExtInt.EVT_RISING_FALLING。
只测试了 IRQ_xxx 模式。EVT_xxx 模式与睡眠模式和 WFE 指令有关。
有效的拉电阻值为 pyb.Pin.PULL_UP、pyb.Pin.PULL_DOWN、pyb.Pin.PULL_NONE。
还有一个 C API,因此需要 EXTI 中断线路的驱动程序也可以使用此代码。请参阅 extint.h 以获取可用函数和 usrsw.h 以获取使用示例。
构造¶
- class pyb.ExtInt(pin, mode, pull, callback)¶
创建一个 ExtInt 对象:
pin
是要启用中断的引脚(可以是引脚对象或任何有效的引脚名称)。mode
可以是以下之一:-ExtInt.IRQ_RISING
- 在上升沿触发;-ExtInt.IRQ_FALLING
- 在下降沿触发;-ExtInt.IRQ_RISING_FALLING
- 在上升沿或下降沿触发。pull
可以是以下之一:-pyb.Pin.PULL_NONE
- 无拉电阻;-pyb.Pin.PULL_UP
- 启用上拉电阻;-pyb.Pin.PULL_DOWN
- 启用下拉电阻。callback
是触发中断时要调用的函数。回调函数必须接受恰好 1 个参数,即触发中断的线路。
类方法¶
- classmethod ExtInt.regs()¶
转储 EXTI 寄存器的值。
方法¶
- ExtInt.disable()¶
禁用与 ExtInt 对象关联的中断。这对去抖动可能很有用。
- ExtInt.enable()¶
启用已禁用的中断。
- ExtInt.line()¶
返回引脚映射到的线路号。
- ExtInt.swint()¶
通过软件触发回调。
常量¶
- ExtInt.IRQ_FALLING¶
下降沿中断
- ExtInt.IRQ_RISING¶
上升沿中断
- ExtInt.IRQ_RISING_FALLING¶
上升沿和下降沿中断