【问题标题】:Unable to resume activity on onActivityResult when ACTION_IMAGE_CAPTURE intent returns on landscape camera orientation当 ACTION_IMAGE_CAPTURE 意图在横向相机方向上返回时,无法在 onActivityResult 上恢复活动
【发布时间】: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了?
  • 当您说“图像为空”时,您的意思是imatgeOriginalimageFoto
  • 当我说“图像为空”时,我的意思是 imageFile imageFile 是我传递给 output_extra 的文件 imageFoto 是 imageView。这永远不会为空,默认情况下我把一个内部图像 imageOriginal 是一个位图。当我从相机或图库接收到文件时,我将文件转换为位图我再次看到我的代码并且我没有 super.onActivityResult。这可能是问题吗?
  • 我在 onclick 按钮中创建了imageFile。也许,如果系统删除了活动,当它返回时创建一个新活动,但imageFile 实例为空,因为没有调用 onclick。

标签: android android-intent camera landscape


【解决方案1】:

imageFile 路径保存在ActivitysaveInstanceState(Bundle out) 上,并在onCreate(Bundle savedInstanceState) 上恢复imageFile,如果savedInstanceState != null。您可能需要将imageFile 存储为String,以便将其保存到Bundle

【讨论】:

    猜你喜欢
    • 2011-10-12
    • 1970-01-01
    • 1970-01-01
    • 2020-02-13
    • 2013-06-11
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多