2017-09-20 61 views
0

我经常需要来自不是Activity或Fragment的子类的自定义类的用户交互(对话框)。以下是我目前正在做这件事的一个例子。我从创建自定义类的片段的片段管理器中打开对话框,然后使用一个小的内部类作为目标,以便获得对话结果。这使所有相关的代码在一个地方,而不是在父片段将onActivityResult:自定义类中的对话框在Android中崩溃O

09-20 14:06:12.852 24301-24301/com.bizname.appname E/AndroidRuntime: FATAL EXCEPTION: main 
    Process: com.bizname.appname, PID: 24301 
    java.lang.IllegalStateException: Fragment ALAlert{1ace4cd #8 confirmDelete} declared target fragment DocumentViewerAlertListener{7e21182} that does not belong to this FragmentManager! 
     at android.app.FragmentManagerImpl.moveToState(FragmentManager.java:1209) 
     at android.app.FragmentManagerImpl.moveFragmentToExpectedState(FragmentManager.java:1549) 
     at android.app.FragmentManagerImpl.moveToState(FragmentManager.java:1611) 
     at android.app.BackStackRecord.executeOps(BackStackRecord.java:807) 
     at android.app.FragmentManagerImpl.executeOps(FragmentManager.java:2394) 
     at android.app.FragmentManagerImpl.executeOpsTogether(FragmentManager.java:2189) 
     at android.app.FragmentManagerImpl.removeRedundantOperationsAndExecute(FragmentManager.java:2142) 
     at android.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:2049) 
     at android.app.FragmentManagerImpl$1.run(FragmentManager.java:718) 
     at android.os.Handler.handleCallback(Handler.java:789) 
     at android.os.Handler.dispatchMessage(Handler.java:98) 
     at android.os.Looper.loop(Looper.java:164) 
     at android.app.ActivityThread.main(ActivityThread.java:6541) 
     at java.lang.reflect.Method.invoke(Native Method) 
     at com.android.internal.os.Zygote$MethodAndArgsCaller.run(Zygote.java:240) 
     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:767) 

public class DocumentViewer extends RelativeLayout { 

    public void deleteAnnotations() { 
     DialogFragment dialog = new DialogFragment(); 
     Bundle args = new Bundle(); 
     args.putString("title", this.app.getString(R.string.DELETE_ANNOTATIONS)); 
     args.putString("message", this.app.getString(R.string.CONFIRM_DELETE_ANNOTATIONS)); 
     args.putString("button1Text", this.app.getString(R.string.BUTTON_DELETE)); 
     args.putString("button2Text", this.app.getString(R.string.BUTTON_CANCEL)); 
     dialog.setArguments(args); 
     DocumentViewerAlertListener listener = new DocumentViewerAlertListener(); 
     listener.canvas = this.canvas; 
     dialog.setTargetFragment(listener, R.id.confirmDelete); 
     dialog.show(this.fragment.getFragmentManager(), "confirmDelete"); 
    } 

    public static class DocumentViewerAlertListener extends ALFragment { 
     public ALCanvas canvas; 

     @Override 
     public void onActivityResult(int requestCode, int resultCode, Intent resultData) { 
      if ((requestCode == R.id.confirmDelete)&&(resultCode == 1)) { 
       this.canvas.clearItems(); 
      } 
     } 
    } 

} 

不幸的是,在Android的O,在dialog.show符合该堆栈跟踪崩溃

这是有道理的,我使用的片段管理器不知道这个内部类,但有什么选择?我试着用内部类的片段经理...

dialog.show(listener.getFragmentManager(), "confirmDelete"); 

...并没有崩溃,但是对话没有出现,也许是因为从不显示听者片段。

我愿意为我目前的方法进行快速修复,或者完成相同事情的其他方法(但希望快速修复!)。

回答

0

在写出问题时,我有一个基于“听众片段从不显示”的想法。我显示的对话框前加入这一行:

this.fragment.getFragmentManager().beginTransaction().add(listener, "confirmDelete").commit(); 

我认为这让片段经理知道我的听众片段,所以它不会抛出异常。

这似乎是一个简单而合乎逻辑的修复方法,但我仍然接受其他方法。