2016-01-06 115 views
1

我试着运行一个名为IrDude的GitHub库,但它失败,应用程序强制关闭。它生成以下日志:Android IR三星S4 irda服务失败

FATAL EXCEPTION: main 
    Process: com.rngtng.irdude, PID: 28350 
    java.lang.RuntimeException: Unable to start activity ComponentInfo{com.rngtng.irdude/com.rngtng.irdude.MainActivity}: java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.Class java.lang.Object.getClass()' on a null object reference 
     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2702) 
     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2767) 
     at android.app.ActivityThread.access$900(ActivityThread.java:177) 
     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1449) 
     at android.os.Handler.dispatchMessage(Handler.java:102) 
     at android.os.Looper.loop(Looper.java:145) 
     at android.app.ActivityThread.main(ActivityThread.java:5951) 
     at java.lang.reflect.Method.invoke(Native Method) 
     at java.lang.reflect.Method.invoke(Method.java:372) 
     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1399) 
     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1194) 
    Caused by: java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.Class java.lang.Object.getClass()' on a null object reference 
     at com.rngtng.irdude.MainActivity.irInit(MainActivity.java:57) 
     at com.rngtng.irdude.MainActivity.onCreate(MainActivity.java:51) 
     at android.app.Activity.performCreate(Activity.java:6289) 
     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1119) 
     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2655) 
     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2767) 
     at android.app.ActivityThread.access$900(ActivityThread.java:177) 
     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1449) 
     at android.os.Handler.dispatchMessage(Handler.java:102) 
     at android.os.Looper.loop(Looper.java:145) 
     at android.app.ActivityThread.main(ActivityThread.java:5951) 
     at java.lang.reflect.Method.invoke(Native Method) 
     at java.lang.reflect.Method.invoke(Method.java:372) 
     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1399) 
     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1194) 

而且虽然应用程序构建成功它仍然显示在下面的代码行的“红外线”的服务1个错误:

irdaService = this.getSystemService("irda"); 
+4

[IR Remote control app]的可能重复(http://stackoverflow.com/questions/24753587/ir-remote-control-app) – chedabob

+1

正如在@chedabob链接的提问中提到的那样,“irda”服务是仅适用于Samsung设备**之前**至KitKat。你的设备上运行什么操作系统版本? –

+0

@EdGeorge Mine使用版本5.0.1 – dexter87

回答

1

通过将固定我的错误以下几行代码:

if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT){ 

     irInit4KitKat(); 
    }else{ 
     irInit4JellyBean(); 
    } 

@TargetApi(Build.VERSION_CODES.KITKAT) 
public void irInit4KitKat() { 

    // Get a reference to the ConsumerIrManager 
    mCIR = (ConsumerIrManager)getSystemService(Context.CONSUMER_IR_SERVICE); 

} 

原因是“irda”服务仅适用于KitKat之前的三星设备。