Java 相机意图在几张照片后使我的应用程序崩溃
我从android.provider.MediaStore.ACTION\u IMAGE\u CAPTURE回来时遇到一些手机问题。在HTC和阿尔卡特,它工作得很好,但在LG,它使我的应用程序崩溃。我可以保存一些图片,然后我的应用程序崩溃,很抱歉!我的应用程序已停止。我已经尝试了很多方法来避免这种情况,但我仍然得到同样的错误 首先我用的是这个 1:尝试 使用图像路径拍照(未获得任何异常): 关于活动结果(未获得任何异常): 2:尝试 然后我尝试使用异步任务(只是为了确保这不是内存泄漏)。我从AsyncTask类调用了saveImage函数,但仍然遇到同样的问题。(没有收到任何电子邮件) 3:尝试 在不使用图像保存路径的情况下调用intent: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
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;