Java 相机意图在几张照片后使我的应用程序崩溃

Java 相机意图在几张照片后使我的应用程序崩溃,java,android,android-intent,camera,crash,Java,Android,Android Intent,Camera,Crash,我从android.provider.MediaStore.ACTION\u IMAGE\u CAPTURE回来时遇到一些手机问题。在HTC和阿尔卡特,它工作得很好,但在LG,它使我的应用程序崩溃。我可以保存一些图片,然后我的应用程序崩溃,很抱歉!我的应用程序已停止。我已经尝试了很多方法来避免这种情况,但我仍然得到同样的错误 首先我用的是这个 1:尝试 使用图像路径拍照(未获得任何异常): 关于活动结果(未获得任何异常): 2:尝试 然后我尝试使用异步任务(只是为了确保这不是内存泄漏)。我从As

我从android.provider.MediaStore.ACTION\u IMAGE\u CAPTURE回来时遇到一些手机问题。在HTC和阿尔卡特,它工作得很好,但在LG,它使我的应用程序崩溃。我可以保存一些图片,然后我的应用程序崩溃,很抱歉!我的应用程序已停止。我已经尝试了很多方法来避免这种情况,但我仍然得到同样的错误

首先我用的是这个

1:尝试

使用图像路径拍照(未获得任何异常):

关于活动结果(未获得任何异常):

2:尝试

然后我尝试使用异步任务(只是为了确保这不是内存泄漏)。我从AsyncTask类调用了saveImage函数,但仍然遇到同样的问题。(没有收到任何电子邮件)

3:尝试

在不使用图像保存路径的情况下调用intent:

public static void saveImage(int TAKE_PHOTO_CODE, Activity activity) {
        try {
            GlobalVariables.incorrectButtonPressed = false;
            // CREATE DIR IF NOT EXISTS
            Intent it = new Intent(android.provider.MediaStore.ACTION_IMAGE_CAPTURE);
            activity.startActivityForResult(it, TAKE_PHOTO_CODE);
        } catch (Exception ex) {
            Log.d("CAMPROBLEM", "bblockScenario", ex);
        }

    }
并在onActivityResult中保存我的图片

@Override
    protected void onActivityResult(int requestCode, int resultCode, Intent data) {
        try {
            String image = ServerTime.getServerDate() + ".jpg";
            File file = new File(saveImgDirectory + File.separator + image);
            try {
                if (data == null) {
                    Toast.makeText(context, "IMAGE NOT SAVED", Toast.LENGTH_LONG).show();
                    bblockScenario();
                    Log.d("CAMPROBLEM", "NULL DATA");
                    return;
                }
                Bitmap photo = (Bitmap) data.getExtras().get("data");
                FileOutputStream out = null;

                out = new FileOutputStream(file);
                photo.compress(Bitmap.CompressFormat.PNG, 90, out);
                if (out != null) {
                    out.close();
                }
            } catch (Exception e) {
                Toast.makeText(context, "IMAGE NOT SAVED", Toast.LENGTH_LONG).show();
                bblockScenario();
                Log.d("CAMPROBLEM", "E", e);
                return;
            } finally {
                try {

                } catch (Throwable ignore) {
                }
            }
            Toast.makeText(context, "IMAGE SAVED", Toast.LENGTH_LONG).show();
            return;
        } catch (Exception ex) {
            Log.d("CAMPROBLEM", "bblockScenario", ex);
        }

    }
if(resultcode != RESULT_OK)
return;
在onActivityResult中,我在每3张图片上获得空数据。我不明白为什么

我的舱单上有所有的前提:

<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.CAMERA" />
<uses-feature android:name="android.hardware.camera" android:required="false"/>

您可以在onActivityResult()中处理此异常,请在onActivityResult()的开头使用以下代码


如果你在写我的第三个解决方案,是的,我可以。我还可以让用户在保存前拍摄每张照片2、3次,但这不是我想要的。这甚至不试图回答这个问题。这应该是一个评论,但不是很好。应用程序在我的工作电脑上,我明天会用logcat编辑这篇文章。@interlude这篇文章已经编辑并包含了logcat
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.CAMERA" />
<uses-feature android:name="android.hardware.camera" android:required="false"/>
05-23 10:26:17.412: E/AndroidRuntime(14022): FATAL EXCEPTION: main
05-23 10:26:17.412: E/AndroidRuntime(14022): java.lang.IllegalArgumentException: View not attached to window manager
05-23 10:26:17.412: E/AndroidRuntime(14022):    at android.view.WindowManagerImpl.findViewLocked(WindowManagerImpl.java:671)
05-23 10:26:17.412: E/AndroidRuntime(14022):    at android.view.WindowManagerImpl.removeView(WindowManagerImpl.java:364)
05-23 10:26:17.412: E/AndroidRuntime(14022):    at android.view.WindowManagerImpl$CompatModeWrapper.removeView(WindowManagerImpl.java:163)
05-23 10:26:17.412: E/AndroidRuntime(14022):    at android.app.Dialog.dismissDialog(Dialog.java:347)
05-23 10:26:17.412: E/AndroidRuntime(14022):    at android.app.Dialog.dismiss(Dialog.java:330)
05-23 10:26:17.412: E/AndroidRuntime(14022):    at es.zonsko.bitola.blocator.activity.BlocatorTabHostActivity$SyncTask.onPostExecute(BlocatorTabHostActivity.java:381)
05-23 10:26:17.412: E/AndroidRuntime(14022):    at es.zonsko.bitola.blocator.activity.BlocatorTabHostActivity$SyncTask.onPostExecute(BlocatorTabHostActivity.java:1)
05-23 10:26:17.412: E/AndroidRuntime(14022):    at android.os.AsyncTask.finish(AsyncTask.java:631)
05-23 10:26:17.412: E/AndroidRuntime(14022):    at android.os.AsyncTask.access$600(AsyncTask.java:177)
05-23 10:26:17.412: E/AndroidRuntime(14022):    at android.os.AsyncTask$InternalHandler.handleMessage(AsyncTask.java:644)
05-23 10:26:17.412: E/AndroidRuntime(14022):    at android.os.Handler.dispatchMessage(Handler.java:99)
05-23 10:26:17.412: E/AndroidRuntime(14022):    at android.os.Looper.loop(Looper.java:153)
05-23 10:26:17.412: E/AndroidRuntime(14022):    at android.app.ActivityThread.main(ActivityThread.java:5070)
05-23 10:26:17.412: E/AndroidRuntime(14022):    at java.lang.reflect.Method.invokeNative(Native Method)
05-23 10:26:17.412: E/AndroidRuntime(14022):    at java.lang.reflect.Method.invoke(Method.java:511)
05-23 10:26:17.412: E/AndroidRuntime(14022):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:790)
05-23 10:26:17.412: E/AndroidRuntime(14022):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:557)
05-23 10:26:17.412: E/AndroidRuntime(14022):    at dalvik.system.NativeStart.main(Native Method)
if(resultcode != RESULT_OK)
return;