前提・実現したいこと
Android Studioを使い始めて2か月の初心者です。このようなサイトを利用するのが初めてですので、足りない点があればご指摘お願いします。
現在、Android StudioのCamera2 APIを用いてカメラを実装しました。次に、追加機能としてカメラのシャッターを押す(画面をタッチする)タイミングで撮影画面にQRコードがあった場合にQRコードを読み取るということを実現しようと考えています。
QRコードを読み取る機能を実装中に以下のような問題が発生しました。
発生している問題・エラーメッセージ
QRコードを読み取るために画像からBinaryBitmapを取得するところまではスムーズにいったのですが、BinaryBitmapから文字列に直す際にエラーが出てしまっているようです。エラーが出てしまったことにより、try文から抜けて例外処理に移ってしまいます。try文の最後に、読み取ったQRコードの文字列をToastで画面に表示するようにしたいです。logcatを見たところエラーメッセージは以下でした。 [ImageReader-1920x1080f100m2-4628-2] Fail to release buffer: Unknown error -1 (1) 全体のソースコードは以下のURLにあげましたのでよろしくお願いします。 https://github.com/keinosuketarou/CameraView エラーの発生位置は、CameraViewクラスのTakePictureメソッド内にある以下の文になっています。 result = mQrReader.decode(bitmap); エラー部分のソースコードを以下に記載します。
該当のソースコード
CameraView
1private void takePicture(){ 2 if (cameraDevice == null) return; 3 try { 4 ImageReader reader = ImageReader.newInstance(previewSize.getWidth(),previewSize.getHeight(),ImageFormat.JPEG,2); 5 reader.setOnImageAvailableListener(new ImageReader.OnImageAvailableListener() { 6 QRCodeReader mQrReader; 7 @Override 8 public void onImageAvailable(ImageReader reader){ 9 Image img = null; 10 Result result = null; 11 try { 12 img = reader.acquireLatestImage(); 13 byte[] data = image2data(img); 14 savePhoto(data); 15 16 PlanarYUVLuminanceSource source = new PlanarYUVLuminanceSource(data,previewSize.getWidth(),previewSize.getHeight(),0,0,previewSize.getWidth(),previewSize.getHeight(),false); 17 BinaryBitmap bitmap = new BinaryBitmap(new HybridBinarizer(source)); 18 try { 19 result = mQrReader.decode(bitmap); 20 String text = result.getText(); 21 toast(text); 22 }catch (Exception e){ 23 toast("not found"); 24 } 25 26 27 } catch (Exception e){ 28 if (img != null) img.close(); 29 } 30 31 32 } 33 },workHandler); 34 35 final CaptureRequest.Builder captureBuilder = cameraDevice.createCaptureRequest(CameraDevice.TEMPLATE_STILL_CAPTURE); 36 captureBuilder.addTarget(reader.getSurface()); 37 captureBuilder.set(CaptureRequest.CONTROL_MODE, CameraMetadata.CONTROL_MODE_AUTO); 38 captureBuilder.set(CaptureRequest.JPEG_ORIENTATION,getPhotoOrientation()); 39 List<Surface> outputSurfaces = new LinkedList<>(); 40 outputSurfaces.add(reader.getSurface()); 41 42 cameraDevice.createCaptureSession(outputSurfaces, new CameraCaptureSession.StateCallback() { 43 @Override 44 public void onConfigured(CameraCaptureSession session) { 45 46 try { 47 session.capture(captureBuilder.build(),new CameraCaptureSession.CaptureCallback(){ 48 @Override 49 public void onCaptureCompleted(CameraCaptureSession session,CaptureRequest request,TotalCaptureResult result){ 50 super.onCaptureCompleted(session,request,result); 51 startPreview(); 52 53 54 } 55 },workHandler); 56 } catch (CameraAccessException e){ 57 e.printStackTrace(); 58 } 59 } 60 61 @Override 62 public void onConfigureFailed(CameraCaptureSession session) { 63 toast("キャプチャーセッションの生成に失敗しました"); 64 startPreview(); 65 } 66 },workHandler); 67 } catch (CameraAccessException e){ 68 e.printStackTrace(); 69 } 70 } 71
試したこと
Camera2を使用してQRコードリーダーを作っているサイトを参考にしたのですが、エラーを解決することができませんでした。
補足情報(FW/ツールのバージョンなど)
開発環境はAndroid Studio3.1.4を使用しています。
言語はJavaを使用しています。
パソコンはWindows10のものを使用しています。
Android Nexus5Xの実機を使い実行しています。

回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2018/12/09 15:49 編集