簡體   English   中英

沒有收到Android Things GpioCallback

[英]Android Things GpioCallback not received

我正在嘗試從simplepio實現按鈕示例。 我已經如原理圖所示建立了連接。 按下按鈕后,我沒有得到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. 通過使用以下代碼在raspbian jessie運行python按鈕程序,驗證電路和按鈕是否正常工作

     #!/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。

以下是我的設置圖片

在此輸入圖像描述

它只是我還是你錯誤的面包板行中的電阻器

錯誤

箭頭顯示它的位置,圓圈顯示它應該在哪里。

根據fritzing圖:

在此輸入圖像描述

我發現在使用Android的Raspberry PI上,Button驅動程序非常不可靠,畢竟驅動程序與您擁有的代碼完全相同。

但是,ButtonInputDriver完美無缺。

實際上,您不需要直接尋址GPIO,並且可以使用更簡單的驅動程序層。 按鈕驅動程序在這里: https//github.com/androidthings/contrib-drivers/tree/master/cap12xx

我建議你試試ButtonInputDriver。

我可能沒有按照原理圖連接電路,或者電阻可能沒有良好的接觸。 最好的調試方法是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) 

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM