【发布时间】:2014-09-04 20:38:03
【问题描述】:
在写这个问题之前我搜索了很多。 我有一个意图从相机中选择带有 extra_output 的图像以存储在 Uri 中
当图像以纵向和/或没有自动旋转时完美运行。 但是,如果您在横向和自动旋转中,某些模型会给我错误。
我的意图代码:
Intent camera = new Intent(MediaStore.ACTION_IMAGE_CAPTURE);
camera.putExtra(MediaStore.EXTRA_OUTPUT, Uri.fromFile(imageFile));
startActivityForResult(camera, REQUEST_CAMERA);
我的onActivityResult片段代码:
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
ImageView imageFoto = (ImageView) findViewById(R.id.imageIncidenciaDetail);
imatgeOriginal = null;
if (requestCode == REQUEST_CAMERA && resultCode == RESULT_OK) {
//if(imageFile != null)
imatgeOriginal = BitmapFactory.decodeFile(imageFile.getAbsolutePath());
我实际上有两个不同的错误:
java.lang.RuntimeException: Unable to resume activity {com.vicopo.com.lapoblainfo/com.vicopo.com.lapoblainfo.incidencia_detail}: java.lang.RuntimeException: Failure delivering result ResultInfo{who=null, request=1, result=-1, data=null} to activity {com.vicopo.com.lapoblainfo/com.vicopo.com.lapoblainfo.incidencia_detail}: java.lang.NullPointerException
at android.app.ActivityThread.performResumeActivity(ActivityThread.java:2899)
at android.app.ActivityThread.handleResumeActivity(ActivityThread.java:2928)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2363)
at android.app.ActivityThread.handleRelaunchActivity(ActivityThread.java:3865)
at android.app.ActivityThread.access$700(ActivityThread.java:156)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1346)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:153)
at android.app.ActivityThread.main(ActivityThread.java:5297)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:833)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:600)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.RuntimeException: Failure delivering result ResultInfo{who=null, request=1, result=-1, data=null} to activity {com.vicopo.com.lapoblainfo/com.vicopo.com.lapoblainfo.incidencia_detail}: java.lang.NullPointerException
at android.app.ActivityThread.deliverResults(ActivityThread.java:3488)
at android.app.ActivityThread.performResumeActivity(ActivityThread.java:2883)
... 13 more
Caused by: java.lang.NullPointerException
at com.vicopo.com.lapoblainfo.incidencia_detail.onActivityResult(incidencia_detail.java:145)
at android.app.Activity.dispatchActivityResult(Activity.java:5311)
at android.app.ActivityThread.deliverResults(ActivityThread.java:3484)
... 14 more
和
java.lang.RuntimeException: Failure delivering result ResultInfo{who=null, request=1, result=-1, data=null} to activity {com.vicopo.com.lapoblainfo/com.vicopo.com.lapoblainfo.incidencia_detail}: java.lang.NullPointerException
at android.app.ActivityThread.deliverResults(ActivityThread.java:3135)
at android.app.ActivityThread.handleSendResult(ActivityThread.java:3178)
at android.app.ActivityThread.access$1100(ActivityThread.java:134)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1277)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:154)
at android.app.ActivityThread.main(ActivityThread.java:4624)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:809)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:576)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.NullPointerException
at com.vicopo.com.lapoblainfo.incidencia_detail.onActivityResult(incidencia_detail.java:145)
at android.app.Activity.dispatchActivityResult(Activity.java:4663)
at android.app.ActivityThread.deliverResults(ActivityThread.java:3131)
... 11 more
和Android Manifest活动代码:
<activity
android:name=".incidencia_detail"
android:label="@string/title_activity_incidencia_detail"
android:screenOrientation="portrait"
android:configChanges="orientation"
>
我可以做一个 if 和检查图像不为空。如果我这样做,该应用程序不会崩溃,但图像为空。
【问题讨论】:
-
您的进程可能会在第三方相机应用程序控制权返回给您之前终止。你如何坚持
imageFile,这样在这种情况下就不会是null了? -
当您说“图像为空”时,您的意思是
imatgeOriginal或imageFoto? -
当我说“图像为空”时,我的意思是 imageFile imageFile 是我传递给 output_extra 的文件 imageFoto 是 imageView。这永远不会为空,默认情况下我把一个内部图像 imageOriginal 是一个位图。当我从相机或图库接收到文件时,我将文件转换为位图我再次看到我的代码并且我没有 super.onActivityResult。这可能是问题吗?
-
我在 onclick 按钮中创建了
imageFile。也许,如果系统删除了活动,当它返回时创建一个新活动,但imageFile实例为空,因为没有调用 onclick。
标签: android android-intent camera landscape