バーコードをスキャンして結果を返送しようとするCordovaプラグインの次のコードがあります。
public class Scan extends CordovaPlugin {
private CallbackContext callbackContext;
private Intent intentService = new Intent("com.hyipc.core.service.barcode.BarcodeService2D");
private String strBarcode = "";
BroadcastReceiver receiver;
@Override
public boolean execute(String action, JSONArray data, CallbackContext callbackContext) throws JSONException {
if (action.equals("scan")) {
scan();
return true;
} else {
return false;
}
}
public void scan() {
IntentFilter filter = new IntentFilter();
filter.addAction("action_barcode_broadcast");
if (this.receiver == null) {
this.receiver = new BroadcastReceiver() {
@Override
public void onReceive(Context context, Intent intent) {
if(intent.getAction().equals("action_barcode_broadcast")) {
strBarcode = intent.getExtras().getString("key_barcode_string");
callbackContext.success(strBarcode);
}
}
};
cordova.getActivity().startService(intentService);
cordova.getActivity().registerReceiver(this.receiver, filter);
}
}
}
実行すると、アプリがクラッシュし、ログに次のように記録されます。
07-18 08:53:28.583: E/AndroidRuntime(2345): FATAL EXCEPTION: main
07-18 08:53:28.583: E/AndroidRuntime(2345): java.lang.RuntimeException: Error receiving broadcast Intent { act=action_barcode_broadcast flg=0x10 (has extras) } in com.example.plugin.Scan$1@414f29f0
07-18 08:53:28.583: E/AndroidRuntime(2345): at android.app.LoadedApk$ReceiverDispatcher$Args.run(LoadedApk.java:798)
07-18 08:53:28.583: E/AndroidRuntime(2345): at android.os.Handler.handleCallback(Handler.java:800)
07-18 08:53:28.583: E/AndroidRuntime(2345): at android.os.Handler.dispatchMessage(Handler.java:100)
07-18 08:53:28.583: E/AndroidRuntime(2345): at android.os.Looper.loop(Looper.java:194)
07-18 08:53:28.583: E/AndroidRuntime(2345): at android.app.ActivityThread.main(ActivityThread.java:5392)
07-18 08:53:28.583: E/AndroidRuntime(2345): at java.lang.reflect.Method.invokeNative(Native Method)
07-18 08:53:28.583: E/AndroidRuntime(2345): at java.lang.reflect.Method.invoke(Method.java:525)
07-18 08:53:28.583: E/AndroidRuntime(2345): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:833)
07-18 08:53:28.583: E/AndroidRuntime(2345): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:600)
07-18 08:53:28.583: E/AndroidRuntime(2345): at dalvik.system.NativeStart.main(Native Method)
07-18 08:53:28.583: E/AndroidRuntime(2345): Caused by: java.lang.NullPointerException
07-18 08:53:28.583: E/AndroidRuntime(2345): at com.example.plugin.Scan$1.onReceive(Scan.java:74)
07-18 08:53:28.583: E/AndroidRuntime(2345): at android.app.LoadedApk$ReceiverDispatcher$Args.run(LoadedApk.java:788)
07-18 08:53:28.583: E/AndroidRuntime(2345): ... 9 more
07-18 08:53:28.608: E/AppErrorDialog(586): Failed to get ILowStorageHandle instance
07-18 08:53:28.640: E/jdwp(2401): Failed sending reply to debugger: Success
07-18 08:53:29.221: E/AEE/DUMPSTATE(2424): copy_file: Copy /data/anr/2345.hprof to PROCESS_OOME_HPROF failed(2), No such file or directory
07-18 08:53:30.547: E/AEE/DUMPSTATE(2424): copy_file: Copy /proc/gpulog to SYS_GPU_INFO failed(2), No such file or directory
07-18 08:53:33.084: E/AEE/DUMPSTATE(2446): copy_process: execv /system/xbin/proc_mem failed(2), No such file or directory
07-18 08:53:33.097: E/AEE/DUMPSTATE(2447): copy_process: execv /system/bin/dmlog failed(2), No such file or directory
07-18 08:53:34.130: E/jdwp(2401): Failed sending reply to debugger: Success
ログがエラーの原因であることを示している74行目は、callbackContext.success
メソッドを呼び出している行です。関数にstrBarcode
ログインできるので、それは確かに存在しonReceive
ます。
あなただけのためのオブジェクトを作成しているCallbackContext
クラスのデフォルトコンストラクタを呼び出すことによって、それを初期化ししかしない...ザッツをyのnull pointer exception
発生しています
だからこの方法を試してください
public void scan(CallbackContext context) {
this.callbackContext = context;
IntentFilter filter = new IntentFilter();
filter.addAction("action_barcode_broadcast");
if (this.receiver == null) {
this.receiver = new BroadcastReceiver() {
@Override
public void onReceive(Context context, Intent intent) {
if(intent.getAction().equals("action_barcode_broadcast")) {
strBarcode = intent.getExtras().getString("key_barcode_string");
callbackContext.success(strBarcode);
}
}
};
cordova.getActivity().startService(intentService);
cordova.getActivity().registerReceiver(this.receiver, filter);
}
}
これは修正されます Null pointer Exception
編集
問題は、返されたものcallbackContext
と作成されたcallbackContext
ものが同じ名前であるということでした。scan()
このように見えるように
scan(callbackContext);
そして関数の内部
public void scan(CallbackContext clBackCtxt) {
this.callbackContext = clBackCtxt;
// your rest code
この記事はインターネットから収集されたものであり、転載の際にはソースを示してください。
侵害の場合は、連絡してください[email protected]
コメントを追加