2013-02-19 2 views
-2

Я использую zxing для сканирования кода qr в android и получения результата. Теперь я хочу передать содержимое кода qr (которое всегда является числом) в запрос выбора sqlite и отобразить результат на экране. Но когда я передаю содержимое в запрос, я получаю исключение Null Exception. КодСканировать qr-код, передать содержимое qr для запроса и отобразить результат на экране в android

Intent intent = new Intent("com.google.zxing.client.android.SCAN"); 
    intent.putExtra("SCAN_MODE", "QR_CODE_MODE"); 
    startActivityForResult(intent, 0); 

protected void onActivityResult(int requestCode, int resultCode, Intent intent) { 
    super.onActivityResult(requestCode, resultCode, intent); 
    if (requestCode == 0) { 
     if (resultCode == RESULT_OK) { 
      String contentId = intent.getStringExtra("SCAN_RESULT"); 
      String format = intent.getStringExtra("SCAN_RESULT_FORMAT");     

      Cursor cursorDetails = db.query("cd_details", new String[] {"location","latitude","longitude","photo"}, "id" + " = " + "'" + contentId + "'", null, null, null, null); 
      cursorDetails.moveToFirst(); 


     } else if (resultCode == RESULT_CANCELED) {     
      Toast toast = Toast.makeText(this, "Scan was Cancelled!", Toast.LENGTH_LONG); 
      toast.setGravity(Gravity.TOP, 25, 400); 
      toast.show();     
     } 
    } 
} 

Я получаю сообщение об ошибке в строке запроса. Ошибка чтения, как это

java.lang.RuntimeException: Unable to resume activity {com.pixel.scanner/com.pixel.scanner.ScannerActivity}: java.lang.RuntimeException: Failure delivering result ResultInfo{who=null, request=0, result=-1, data=Intent { act=com.google.zxing.client.android.SCAN flg=0x80000 (has extras) }} to activity {com.pixel.scanner/com.pixel.scanner.ScannerActivity}: java.lang.NullPointerException 
at android.app.ActivityThread.performResumeActivity(ActivityThread.java:2124) 
at android.app.ActivityThread.handleResumeActivity(ActivityThread.java:2139) 
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1672) 
at android.app.ActivityThread.handleRelaunchActivity(ActivityThread.java:2836) 
at android.app.ActivityThread.access$1600(ActivityThread.java:117) 
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:939) 
at android.os.Handler.dispatchMessage(Handler.java:99) 
at android.os.Looper.loop(Looper.java:130) 
at android.app.ActivityThread.main(ActivityThread.java:3687) 
at java.lang.reflect.Method.invokeNative(Native Method) 
at java.lang.reflect.Method.invoke(Method.java:507) 
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:867) 
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:625) 
at dalvik.system.NativeStart.main(Native Method) 
Caused by: java.lang.RuntimeException: Failure delivering result ResultInfo{who=null, request=0, result=-1, data=Intent { act=com.google.zxing.client.android.SCAN flg=0x80000 (has extras) }} to activity {com.pixel.scanner/com.pixel.scanner.ScannerActivity}: java.lang.NullPointerException 
at android.app.ActivityThread.deliverResults(ActivityThread.java:2536) 
at android.app.ActivityThread.performResumeActivity(ActivityThread.java:2111) 
... 13 more 
Caused by: java.lang.NullPointerException 
at com.pixel.scanner.ScannerActivity.onActivityResult(ScannerActivity.java:70) 
at android.app.Activity.dispatchActivityResult(Activity.java:3908) 
at android.app.ActivityThread.deliverResults(ActivityThread.java:2532) 
... 14 more 

Line 70 в приведенном выше коде

Cursor cursorDetails = db.query("cd_details", new String[] {"location","latitude","longitude","photo"}, "id" + " = " + "'" + contentId + "'", null, null, null, null); 

Все предложения на этот будет большим подспорьем.

+1

В строке 70 ScannerActivity у вас есть нулевой объект. – bmavus

+0

@bmavus благодарит за ответ. Но у меня нет никаких нулевых объектов. – Shrikant

+0

@bmavus проверить мой отредактированный вопрос. Я упомянул строку 70. – Shrikant

ответ

1

Трассировка стека уже сообщает вам ответ. У вашего приложения есть проблема в строке 70. db - null.

+0

Спасибо за ответ. Получил ключ от вашего ответа. – Shrikant

1

Проблема была в том, что я не открыл базу данных для READ/WRITE. Итак, db пришел нулевым. Я добавил нижнюю строку и ее работу сейчас.

db = SQLiteDatabase.openDatabase(fileIsExists.toString(), null, SQLiteDatabase.OPEN_READWRITE);