質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.32%

Android : カメラアプリで撮影したら、アプリが落ちてしまう。

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 718

pira

score 11

カメラで撮影した後、画像を保存したい。

Android Studioでカメラアプリの修正をしているのですがデバック実行したら、
ExifInterface exif = new ExifInterface(f.getPath());のところで
Utiles.d("-- Error in Camera Shoot image");にいってしまいアプリが落ちてしまいます。、原因がわからず困っています。わかる方いましたらご教示していただけると助かります。

発生している問題・エラーメッセージ

                      java.lang.IllegalStateException: Could not execute method for android:onClick
                                                                      at android.view.View$DeclaredOnClickListener.onClick(View.java:4745)
                                                                      at android.view.View.performClick(View.java:5657)
                                                                      at android.view.View$PerformClick.run(View.java:22314)
                                                                      at android.os.Handler.handleCallback(Handler.java:751)
                                                                      at android.os.Handler.dispatchMessage(Handler.java:95)
                                                                      at android.os.Looper.loop(Looper.java:241)
                                                                      at android.app.ActivityThread.main(ActivityThread.java:6223)
                                                                      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: java.lang.reflect.InvocationTargetException
                                                                      at java.lang.reflect.Method.invoke(Native Method)
                                                                      at android.view.View$DeclaredOnClickListener.onClick(View.java:4740)
                                                                      at android.view.View.performClick(View.java:5657) 
                                                                      at android.view.View$PerformClick.run(View.java:22314) 
                                                                      at android.os.Handler.handleCallback(Handler.java:751) 
                                                                      at android.os.Handler.dispatchMessage(Handler.java:95) 
                                                                      at android.os.Looper.loop(Looper.java:241) 
                                                                      at android.app.ActivityThread.main(ActivityThread.java:6223) 
                                                                      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: java.lang.RuntimeException: autoFocus failed
                                                                      at android.hardware.Camera.native_autoFocus(Native Method)
                                                                      at android.hardware.Camera.autoFocus(Camera.java:1321)
                                                                      at com.scandal.camera.MyCameraView.onShutterButton(MyCameraView.java:143)
                                                                      at com.scandal.camera.CameraShootActivity.onShoot(CameraShootActivity.java:115)
                                                                      at java.lang.reflect.Method.invoke(Native Method) 
                                                                      at android.view.View$DeclaredOnClickListener.onClick(View.java:4740) 
                                                                      at android.view.View.performClick(View.java:5657) 
                                                                      at android.view.View$PerformClick.run(View.java:22314) 
                                                                      at android.os.Handler.handleCallback(Handler.java:751) 
                                                                      at android.os.Handler.dispatchMessage(Handler.java:95) 
                                                                      at android.os.Looper.loop(Looper.java:241) 
                                                                      at android.app.ActivityThread.main(ActivityThread.java:6223) 
                                                                      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) 

該当のソースコード

    @Override
    public void run() {
        // TODO 自動生成されたメソッド・スタブ
        try {
            BitmapFactory.Options myOption = new BitmapFactory.Options();
            // 実際に読み込まないで情報だけ取得する
            myOption.inJustDecodeBounds = true;
            BitmapFactory.decodeByteArray(mData, 0, mData.length,myOption);
            if (11<=APIver) {//MAXまでメモリ解放してる
                if ((myOption.outWidth * myOption.outHeight) > 1024*1024*4) {// 2Mピクセル 1024*1024*2
                    Msample_size = 2;
                    myOption.inPreferredConfig = Bitmap.Config.ARGB_4444;
                    Utiles.d("Camera shot image over 4M,Msample_size = 2");
                }else{
                    Msample_size = 1;
                    Utiles.d("Camera shot image under 4M");
                }
            } else {
                if ((myOption.outWidth * myOption.outHeight) > 1024*1024*2) {// 2Mピクセル 1024*1024*2
                    Msample_size = 2;
                    myOption.inPreferredConfig = Bitmap.Config.ARGB_4444;
                    Utiles.d("Camera shot image over 2M,Msample_size = 2");
                }else{
                    Msample_size = 1;
                    Utiles.d("Camera shot image under 2M");
                }
                if (maxMem < 24) {
                    // さらにheapが24mb以下だったら画質落とす
                    myOption.inPreferredConfig = Bitmap.Config.RGB_565;
                }
            }
            myOption.inSampleSize = Msample_size;
            // 実際に読み込む
            myOption.inJustDecodeBounds = false;
            Bitmap bitmap = BitmapFactory.decodeByteArray(mData, 0, mData.length,myOption);
            try {
                // IMG name
                Uri uri = Uri.parse(Utiles.getDCIM(ctx) + "/" + createName());
                final String savePathString = uri.toString();
                File f = new File(savePathString);
                ExifInterface exif = new ExifInterface(f.getPath());
                int orientation = exif.getAttributeInt(
                        ExifInterface.TAG_ORIENTATION,
                        ExifInterface.ORIENTATION_NORMAL);

                int angle = 0;

                if (orientation == ExifInterface.ORIENTATION_ROTATE_90) {
                    angle = 90;
                } else if (orientation == ExifInterface.ORIENTATION_ROTATE_180) {
                    angle = 180;
                } else if (orientation == ExifInterface.ORIENTATION_ROTATE_270) {
                    angle = 270;
                } else {
                    angle = 90;
                }

                Matrix mat = new Matrix();
                mat.postRotate(angle);
                // get rotated bitmap
                Bitmap correctBmp = Bitmap.createBitmap(bitmap, 0, 0,bitmap.getWidth(), bitmap.getHeight(), mat, true);
                // save bitmap
                Utiles.saveAndInsertDB_BMP(ctx, correctBmp, savePathString);

                bitmap.recycle();
                correctBmp.recycle();

                Utiles.d("Camera shot image width", "" + bitmap.getWidth());
                Utiles.d("Camera shot image height", "" + bitmap.getHeight());
                Utiles.d("onPictureTaken - bitmap sending..");

                pActivity.runOnUiThread(new Runnable(){
                    @Override
                    public void run() {
                        pActivity.closeProgressDialog();
                        // intent send data
                        Intent intent = new Intent(pActivity, EditActivity.class);
                        //渡した先でファイル名を探すために使う
                        intent.putExtra(EditActivity.KEY_CAMERA_IMG_PATH, savePathString);
                        intent.putExtra("from", "camera");

                        MySharedPref mPref = new MySharedPref(ctx);
                        mPref.putPrefString(EditActivity.KEY_CAMERA_IMG_PATH, savePathString);
                        mPref.putPrefString("from", "camera");

                        Cursor c = ctx.getContentResolver().query(Uri.parse(savePathString), null, null, null, null);
                        if (c != null) {
                            c.moveToFirst();
                            String path = c.getString(c.getColumnIndex(MediaStore.MediaColumns.DATA));
                            c.close();
                            Utiles.d("onPictureTaken MyCameraView savePathString=",path);
                        }
                        ctx.startActivity(intent);
                        pActivity.finish();
                    }
                });

            } catch (IOException e) {
                Utiles.d("-- Error in Camera Shoot image");
            } catch (OutOfMemoryError oom) {
                Utiles.d("-- OOM Error in Camera Shoot image");
            }    

試したこと

ExifInterface exif = new ExifInterface(f.getPath());
int orientation = exif.getAttributeInt(ExifInterface.TAG_ORIENTATION,ExifInterface.ORIENTATION_NORMAL);の部分をコメントアウトして実行すると画像の向きは横向きのままだが、撮影できて画像もちゃんと保存できる。

補足情報(言語/FW/ツール等のバージョンなど)

ツール : Android Studio2.3.3

compileSdkVersion 26
buildToolsVersion "26.0.0"
minSdkVersion 15
targetSdkVersion 19
  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

checkベストアンサー

0

その処理の時点でファイルは存在しないので、Exifを読み取れないんじゃないでしょうか。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/07/03 09:26

    返答が遅くなって申し訳ありません。
    ExifInterface exif = new ExifInterface(f.getPath());の前に画像ファイルを保存すればいけるということですね!ちょっとやってみます!ありがとうございます!

    キャンセル

  • 2017/07/03 11:56

    無事、解決することができました!ありがとうございます!

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 90.32%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

同じタグがついた質問を見る