android.view.WindowManager$BadTokenException: Unable to add window -- token null for displayid = 0 is not valid; is your activity running?
at android.view.ViewRootImpl.setView(ViewRootImpl.java:931)
at android.view.WindowManagerGlobal.addView(WindowManagerGlobal.java:400)
at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:129)
at android.app.Dialog.show(Dialog.java:471)
at android.support.v4.app.DialogFragment.onStart(DialogFragment.java:418)
复现问题步骤 Steps to reproduce the problem
demo1里的MyDialogFragment
public class MyDialogFragment extends DialogFragment {
public MyDialogFragment() {
}
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
LayoutInflater pluginInflater = LayoutInflater.from(RePlugin.getPluginContext());
return pluginInflater.inflate(R.layout.main_fragment, container, false);
}
}
Android API Version:-
Android 手机型号&ROM(Phone model & ROM): -
Logcat上下文 Logcat context
Process: com.qihoo360.replugin.sample.host, PID: 12841
android.view.WindowManager$BadTokenException: Unable to add window -- token null for displayid = 0 is not valid; is your activity running?
at android.view.ViewRootImpl.setView(ViewRootImpl.java:931)
at android.view.WindowManagerGlobal.addView(WindowManagerGlobal.java:400)
at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:129)
at android.app.Dialog.show(Dialog.java:471)
at android.support.v4.app.DialogFragment.onStart(DialogFragment.java:418)
at android.support.v4.app.Fragment.performStart(Fragment.java:2218)
at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1340)
at android.support.v4.app.FragmentManagerImpl.moveFragmentToExpectedState(FragmentManager.java:1528)
at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1595)
at android.support.v4.app.BackStackRecord.executeOps(BackStackRecord.java:758)
at android.support.v4.app.FragmentManagerImpl.executeOps(FragmentManager.java:2363)
at android.support.v4.app.FragmentManagerImpl.executeOpsTogether(FragmentManager.java:2149)
at android.support.v4.app.FragmentManagerImpl.optimizeAndExecuteOps(FragmentManager.java:2103)
at android.support.v4.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:2013)
at android.support.v4.app.FragmentManagerImpl$1.run(FragmentManager.java:710)
at android.os.Handler.handleCallback(Handler.java:891)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:207)
at android.app.ActivityThread.main(ActivityThread.java:7539)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:524)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:958)
问题详细描述 Detailed description of the problem
参照官方demo1和host,在demo1里新增加一个MyDialogFragment,在host里参照PluginFragmentActivity的方式,能够生成MyDialogFragment对象,但是
fragment.show(getSupportFragmentManager(), "testdialog2");
时崩溃。复现问题步骤 Steps to reproduce the problem
demo1里的MyDialogFragment
其它重要信息 Other important information
replugin-host-lib/gradle Version: 2.3.1 rePlugin-plugin-lib/gradle Version: 2.3.1
Android API Version:- Android 手机型号&ROM(Phone model & ROM): -
Logcat上下文 Logcat context