我正在尝试检测 Orange Pi Zero 的 GPIO 引脚的变化(基本上与 Raspberry Pi 相同)。它正在运行 Armbian Buster(即 Debian 10)
我创建了一个简单的 .Net Core 5 控制台应用程序,使用 .Net 的内置System.Device.Gpio库来检测这一点:
public class GpioComms
{
GpioController _controller = new GpioController();
public GpioComms()
{
_controller.OpenPin(10, PinMode.Input);
_controller.RegisterCallbackForPinValueChangedEvent(10, PinEventTypes.Rising, onSignalPinRiseEvent);
_controller.RegisterCallbackForPinValueChangedEvent(10, PinEventTypes.Falling, onSignalPinFallEvent);
}
private void onSignalPinRiseEvent(object sender, PinValueChangedEventArgs args)
{
Console.WriteLine(DateTime.Now + " " + args.PinNumber + " pin up");
}
private void onSignalPinFallEvent(object sender, PinValueChangedEventArgs args)
{
Console.WriteLine(DateTime.Now + " " + args.PinNumber + " pin down");
}
}
然后我将一个按钮连接到 GPIO 引脚 10(Orange Pi Zero 上的物理引脚 26)并运行程序。当我按下按钮时,大约有一半的时间它会立即检测到这一点。当我松开按钮时,它总是会立即检测到这一点。但大约有一半的时间,它没有检测到按钮的按下,只有当我释放按钮时,onSignalPinRiseEvent 才会触发(连同 onSignalPinFallEvent 事件)
换句话说,大约有一半的时间,按钮的按下(即 GPIO 引脚的上升)仅与按钮的释放(即 GPIO 引脚的下降)一起被检测到,而不是在按下按钮时立即被检测到。按钮被按下。
奇怪的是我包含了一个时间戳,而且大多数时候,即使我在松开按钮之前按住按钮 3 秒,上升和下降的时间戳是相同的(但并非总是 - 有一些极少数情况下,即使上升和下降事件仅在我释放按钮时触发,显示的时间戳也相隔 3 秒)。
然后我尝试只为上升和下降检测注册一个事件处理程序,而不是两个单独的处理程序:
_controller.RegisterCallbackForPinValueChangedEvent((int)Settings.GpioPin.Read, PinEventTypes.Rising | PinEventTypes.Falling, onSignalPinValueChangedEvent);
private void onSignalPinValueChangedEvent(object sender, PinValueChangedEventArgs args)
{
Console.WriteLine(DateTime.Now + " - Pin " + args.PinNumber + " is " + args.ChangeType);
}
但这并没有什么不同。
这是一个示例输出 - 我按下按钮大约 3 秒钟,然后释放大约 3 秒钟:
2/20/2021 9:36:25 AM - Pin 10 is Rising
2/20/2021 9:36:25 AM - Pin 10 is Falling
2/20/2021 9:36:31 AM - Pin 10 is Rising
2/20/2021 9:36:31 AM - Pin 10 is Falling
2/20/2021 9:36:37 AM - Pin 10 is Rising
2/20/2021 9:36:37 AM - Pin 10 is Falling
2/20/2021 9:36:40 AM - Pin 10 is Rising
2/20/2021 9:36:43 AM - Pin 10 is Falling
2/20/2021 9:36:49 AM - Pin 10 is Rising
2/20/2021 9:36:49 AM - Pin 10 is Falling
2/20/2021 9:36:52 AM - Pin 10 is Rising
2/20/2021 9:36:55 AM - Pin 10 is Falling
2/20/2021 9:37:01 AM - Pin 10 is Rising
2/20/2021 9:37:01 AM - Pin 10 is Falling
2/20/2021 9:37:07 AM - Pin 10 is Rising
2/20/2021 9:37:07 AM - Pin 10 is Falling
2/20/2021 9:37:10 AM - Pin 10 is Rising
2/20/2021 9:37:13 AM - Pin 10 is Falling
2/20/2021 9:37:16 AM - Pin 10 is Rising
2/20/2021 9:37:18 AM - Pin 10 is Falling
2/20/2021 9:37:22 AM - Pin 10 is Rising
2/20/2021 9:37:24 AM - Pin 10 is Falling
2/20/2021 9:37:30 AM - Pin 10 is Rising
2/20/2021 9:37:30 AM - Pin 10 is Falling
在上面,具有相同时间戳的对是有问题的对。那些是当我按下按钮时没有写入控制台的那些,然后,三秒钟后,当我释放按钮时,它同时写了两行(上升和下降)具有相同的时间戳。
有任何想法吗?