2012-05-14 13 views
22

Przepisuję swoją aplikację z obsługą Fragments API. W pierwotnym wniosku Mam AlertDialog który jest tworzony tak:DialogFragment: Używanie AlertDialog z niestandardowym układem

LayoutInflater inflater = (LayoutInflater) getSystemService(Context.LAYOUT_INFLATER_SERVICE); 
    View view = inflater.inflate(R.layout.button_dialog, null); 
    AlertDialog.Builder builder = new AlertDialog.Builder(this); 
    builder.setView(view); 
    ListView mListView = (ListView) view.findViewById(R.id.mblist); 
    builder.setTitle(getString(R.string.sysinfo)).setNeutralButton(
      getString(R.string.okay), null); 
    Cursor dcursor = propManager.propCursor(); 
    if (dcursor.moveToFirst()) { 
     startManagingCursor(dcursor); 
     String[] from = { Constants.NAME_DET, 
       Constants.VALUE_DET }; 
     int[] to = { R.id.mbname, R.id.mbvalue }; 
     SimpleCursorAdapter dadapter = new SimpleCursorAdapter(this, 
       R.layout.info_list_row, dcursor, from, to); 
     mListView.setAdapter(dadapter); 
    } 
    final Dialog dialog = builder.create(); 
    dialog.show(); 

Jak mogę wyświetlać ten sam dialog poprzez DialogFragment? Przeczytałem dokumentację, ale mam problem z ustaleniem, jak to zrobić.

Odpowiedz

43

Jestem zaskoczony, że nikt nie odpowiedział. Jest to rozwiązanie:

public class PropDialogFragment extends DialogFragment { 

    private PropDialogFragment() { /*empty*/ } 

    /** creates a new instance of PropDialogFragment */ 
    public static PropDialogFragment newInstance() { 
     return new PropDialogFragment(); 
    } 

    @Override 
    public Dialog onCreateDialog(Bundle savedInstanceState) { 
     //getting proper access to LayoutInflater is the trick. getLayoutInflater is a     //Function 
     LayoutInflater inflater = getActivity().getLayoutInflater(); 

     View view = inflater.inflate(R.layout.my_dialog, null); 
     AlertDialog.Builder builder = new AlertDialog.Builder(getActivity()); 
     builder.setView(view); 
     builder.setTitle(getActivity().getString(R.string.sysinfo)).setNeutralButton(
       getActivity().getString(R.string.okay), null); 
     return builder.create(); 
    } 
} 

Można pokazać okno przy użyciu:

private void showDialog() { 
    // DialogFragment.show() will take care of adding the fragment 
    // in a transaction. We also want to remove any currently showing 
    // dialog, so make our own transaction and take care of that here. 
    FragmentTransaction ft = getSupportFragmentManager().beginTransaction(); 
    Fragment prev = getSupportFragmentManager().findFragmentByTag("dialog"); 
    if (prev != null) { 
     ft.remove(prev); 
    } 
    ft.addToBackStack(null); 

    // Create and show the dialog. 
    DialogFragment newFragment = PropDialogFragment.newInstance(); 
    newFragment.show(ft, "dialog"); 
} 
+0

To bardzo pomogło. Dzięki. – BruceHill

+1

Wolałbyś 'getActivity(). GetLayoutInflater()' zamiast wywoływać usługę systemową i rzutowanie? –

+0

Niesamowita odpowiedź. Na wszelki wypadek, jeśli ktoś jest ciekawy, [dokumentacja to omawia] (https://developer.android.com/reference/android/app/DialogFragment.html). – Project

1

Zasadniczo można po prostu pokazać swoje Fragment takiego:

SherlockDialogFragment newFragment = new TimePickerFragment(); 
newFragment.show(getActivity().getSupportFragmentManager(), "timePicker"); 

I to byłoby proste TimePickerFragment :

public class TimePickerFragment extends SherlockDialogFragment implements TimePickerDialog.OnTimeSetListener{ 

    @Override 
    public Dialog onCreateDialog(Bundle savedInstanceState) { 

     final Calendar c = Calendar.getInstance(); 
     int hour = c.get(Calendar.HOUR_OF_DAY); 
     int minute = c.get(Calendar.MINUTE); 


     return new TimePickerDialog(getActivity(), this, hour, minute, DateFormat.is24HourFormat(getActivity())); 
} 
} 
Powiązane problemy