Android事物GpioCallback未收到

时间:2017-01-15 12:58:41

标签: raspberry-pi raspberry-pi3 android-things

我正在尝试从simplepio实施按钮示例。我已按schematics所示建立连接。按下按钮后,我没有收到GPIO回拨。

我使用的代码与示例代码相同。没有例外,只有“开始活动”在日志中打印

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    Log.i(TAG, "Starting ButtonActivity");

    PeripheralManagerService service = new PeripheralManagerService();
    try {
        String pinName = BoardDefaults.getGPIOForButton();
        mButtonGpio = service.openGpio(pinName);
        mButtonGpio.setDirection(Gpio.DIRECTION_IN);
        mButtonGpio.setEdgeTriggerType(Gpio.EDGE_FALLING);
        mButtonGpio.registerGpioCallback(new GpioCallback() {
            @Override
            public boolean onGpioEdge(Gpio gpio) {
                Log.i(TAG, "GPIO changed, button pressed");
                // Return true to continue listening to events
                return true;
            }
        });
    } catch (IOException e) {
        Log.e(TAG, "Error on PeripheralIO API", e);
    }
}

到目前为止我尝试了什么:

  1. 通过运行a验证电路和按钮是否正常工作 python中的raspbian jessie按钮程序,代码为

    #!/usr/bin/env python
    
    import os
    from time import sleep
    
    import RPi.GPIO as GPIO
    
    GPIO.setmode(GPIO.BCM)
    GPIO.setup(21, GPIO.IN, pull_up_down = GPIO.PUD_UP)
    
    while True:
        if (GPIO.input(21) == False):
            print("Button Clicked")
    
        sleep(0.1)
    

    按下按钮时,上面的代码会打印“按钮单击”。所以我 我确定我的PI上的按钮和GPIO引脚不是问题。

  2. 为了确保日志记录没有问题,我也试过了 修改原始程序以包含TextView和计数器 因此,当单击按钮时,计数器值会递增 显示在TextView但是再次没有收到回叫 TextView未更新。
  3. 尝试了不同的边缘触发类型,但永远不会调用onGpioEdge。
  4. 以下是我的设置图片

    enter image description here

3 个答案:

答案 0 :(得分:3)

它只是我还是你的电阻器在错误的面包板行

wrong

箭头显示它的位置,圆圈显示它应该在哪里。

根据fritzing图:

enter image description here

答案 1 :(得分:0)

我发现在使用Android的Raspberry PI上,Button驱动程序非常不可靠,毕竟驱动程序与您的代码完全相同。

然而,ButtonInputDriver完美无瑕地工作。

实际上,您不需要直接寻址GPIO并且可以使用更简单的驱动程序层。按钮驱动程序位于:https://github.com/androidthings/contrib-drivers/tree/master/cap12xx

我建议你试试ButtonInputDriver。

答案 2 :(得分:0)

我可能没有按照原理图连接电路,或者电阻可能没有良好的接触。最好的调试方法是Dave McKelvie建议使用电压表测量电压。

Python代码工作的原因是因为Raspberry PI 3具有内部上拉电阻,Dave McKelvie在评论中建议使用该电阻。

按钮可能无法工作的另一个原因是GPIO引脚是否已被其他应用程序使用。记录器为以下方案显示以下错误

Error on PeripheralIO API
    com.google.android.things.pio.PioException: android.os.ServiceSpecificException: BCM21 is already in use
       at com.google.android.things.pio.GpioImpl.<init>(GpioImpl.java:53)
       at com.google.android.things.pio.PeripheralManagerService.openGpio(PeripheralManagerService.java:169)
       at com.example.androidthings.simplepio.ButtonActivity.onCreate(ButtonActivity.java:129)
       at android.app.Activity.performCreate(Activity.java:6662)
       at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1118)
       at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2599)
       at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2707)
       at android.app.ActivityThread.-wrap12(ActivityThread.java)
       at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1460)
       at android.os.Handler.dispatchMessage(Handler.java:102)
       at android.os.Looper.loop(Looper.java:154)
       at android.app.ActivityThread.main(ActivityThread.java:6077)
       at java.lang.reflect.Method.invoke(Native Method)
       at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:865)
       at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:755)
    Caused by: android.os.ServiceSpecificException: BCM21 is already in use
       at android.os.Parcel.readException(Parcel.java:1697)
       at android.os.Parcel.readException(Parcel.java:1636)
       at com.google.android.things.pio.IPeripheralManagerClient$Stub$Proxy.OpenGpio(IPeripheralManagerClient.java:776)
       at com.google.android.things.pio.GpioImpl.<init>(GpioImpl.java:51)
       at com.google.android.things.pio.PeripheralManagerService.openGpio(PeripheralManagerService.java:169) 
       at com.example.androidthings.simplepio.ButtonActivity.onCreate(ButtonActivity.java:129) 
       at android.app.Activity.performCreate(Activity.java:6662) 
       at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1118) 
       at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2599) 
       at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2707) 
       at android.app.ActivityThread.-wrap12(ActivityThread.java) 
       at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1460) 
       at android.os.Handler.dispatchMessage(Handler.java:102) 
       at android.os.Looper.loop(Looper.java:154) 
       at android.app.ActivityThread.main(ActivityThread.java:6077) 
       at java.lang.reflect.Method.invoke(Native Method) 
       at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:865) 
       at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:755)