Der beste Ansatz ist auf jeden Fall die Verwendung von DialogFragment.
Hier ist meine Lösung der Wrapper-Klasse, die verhindert, dass verschiedene Dialoge innerhalb eines Fragments (oder einer Aktivität mit kleinem Refactoring) geschlossen werden. Es hilft auch, massives Code-Refactoring zu vermeiden, wenn aus bestimmten Gründen viele AlertDialogs
im Code verstreut sind und sich geringfügig in Bezug auf Aktionen, Erscheinungsbild oder etwas anderes unterscheiden.
public class DialogWrapper extends DialogFragment {
private static final String ARG_DIALOG_ID = "ARG_DIALOG_ID";
private int mDialogId;
/**
* Display dialog fragment.
* @param invoker The fragment which will serve as {@link AlertDialog} alert dialog provider
* @param dialogId The ID of dialog that should be shown
*/
public static <T extends Fragment & DialogProvider> void show(T invoker, int dialogId) {
Bundle args = new Bundle();
args.putInt(ARG_DIALOG_ID, dialogId);
DialogWrapper dialogWrapper = new DialogWrapper();
dialogWrapper.setArguments(args);
dialogWrapper.setTargetFragment(invoker, 0);
dialogWrapper.show(invoker.getActivity().getSupportFragmentManager(), null);
}
@Override
public void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
mDialogId = getArguments().getInt(ARG_DIALOG_ID);
}
@NonNull
@Override
public Dialog onCreateDialog(Bundle savedInstanceState) {
return getDialogProvider().getDialog(mDialogId);
}
private DialogProvider getDialogProvider() {
return (DialogProvider) getTargetFragment();
}
public interface DialogProvider {
Dialog getDialog(int dialogId);
}
}
Wenn es um die Aktivität kommt , kann man aufrufen getContext()
innen onCreateDialog()
, werfen es in die DialogProvider
Schnittstelle und anfordern , indem Sie einen bestimmten DialogmDialogId
. Alle Logik zum Umgang mit einem Zielfragment sollte gelöscht werden.
Verwendung aus Fragment:
public class MainFragment extends Fragment implements DialogWrapper.DialogProvider {
private static final int ID_CONFIRMATION_DIALOG = 0;
@Override
public void onViewCreated(View view, @Nullable Bundle savedInstanceState) {
Button btnHello = (Button) view.findViewById(R.id.btnConfirm);
btnHello.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
DialogWrapper.show(MainFragment.this, ID_CONFIRMATION_DIALOG);
}
});
}
@Override
public Dialog getDialog(int dialogId) {
switch (dialogId) {
case ID_CONFIRMATION_DIALOG:
return createConfirmationDialog(); //Your AlertDialog
default:
throw new IllegalArgumentException("Unknown dialog id: " + dialogId);
}
}
}
Sie können den vollständigen Artikel in meinem Blog lesen. Wie kann verhindert werden, dass Dialog entlassen wird? und mit dem Quellcode spielen .