2011-12-16 12 views
21

Szukałem o ListDialogs. Za każdym razem można umieścić element, który chce z:Ikony w oknie dialogowym Lista

builder.setItems(items, new DialogInterface.OnClickListener() 
{ 
    public void onClick(DialogInterface dialog, int item) 
    { 

    } 
}); 

i myślenia o elementy obiektu, wich jest CharSequence tak:

CharSequence[] items = getResources().getStringArray(R.array.share_dialog_list); 

Chcę wiedzieć, czy sposób (jakiś inny koniecznością zrobiły to: D), aby ten istnieje, ale przy użyciu niestandardowego widoku z ikonami po lewej stronie, podobnie jak to:

enter image description here

Odpowiedz

56

Oto kompletne rozwiązanie z rozszerzonym ArrayAdapter że zezwala na ikony.

Patrz uwagi projektowe dla okien dialogowych na http://developer.android.com/design/building-blocks/dialogs.html Iconogaphy w http://developer.android.com/design/style/iconography.html i IconPacks na http://developer.android.com/design/downloads/index.html

Uwaga, że wielkość tych wygląda całkiem nieźle przy 48 x 48 dp, który nie jest dołączony rozmiar, dzięki czemu” Będę musiał skalować twoją ikonę z pobranych plików.

ZASTOSOWANIE:

  @Override 
     public void onClick(View v) { 
      final String [] items = new String[] {"From Gallery", "From Camera"}; 
      final Integer[] icons = new Integer[] {R.drawable.dialog_gallery_icon, R.drawable.dialog_camera_icon}; 
      ListAdapter adapter = new ArrayAdapterWithIcon(getActivity(), items, icons); 

      new AlertDialog.Builder(getActivity()).setTitle("Select Image") 
       .setAdapter(adapter, new DialogInterface.OnClickListener() { 
        public void onClick(DialogInterface dialog, int item) { 
         Toast.makeText(getActivity(), "Item Selected: " + item, Toast.LENGTH_SHORT).show(); 
        } 
      }).show(); 
     } 

ArrayAdapterWithIcon.java

public class ArrayAdapterWithIcon extends ArrayAdapter<String> { 

private List<Integer> images; 

public ArrayAdapterWithIcon(Context context, List<String> items, List<Integer> images) { 
    super(context, android.R.layout.select_dialog_item, items); 
    this.images = images; 
} 

public ArrayAdapterWithIcon(Context context, String[] items, Integer[] images) { 
    super(context, android.R.layout.select_dialog_item, items); 
    this.images = Arrays.asList(images); 
} 

public ArrayAdapterWithIcon(Context context, int items, int images) { 
    super(context, android.R.layout.select_dialog_item, context.getResources().getTextArray(items)); 

    final TypedArray imgs = context.getResources().obtainTypedArray(images); 
    this.images = new ArrayList<Integer>() {{ for (int i = 0; i < imgs.length(); i++) {add(imgs.getResourceId(i, -1));} }}; 

    // recycle the array 
    imgs.recycle(); 
} 

@Override 
public View getView(int position, View convertView, ViewGroup parent) { 
    View view = super.getView(position, convertView, parent); 
    TextView textView = (TextView) view.findViewById(android.R.id.text1); 

    if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.JELLY_BEAN_MR1) { 
     textView.setCompoundDrawablesRelativeWithIntrinsicBounds(images.get(position), 0, 0, 0); 
    } else { 
     textView.setCompoundDrawablesWithIntrinsicBounds(images.get(position), 0, 0, 0); 
    } 
    textView.setCompoundDrawablePadding(
      (int) TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP, 12, getContext().getResources().getDisplayMetrics())); 
    return view; 
} 

} 
+0

Ikona nie zmienia rozmiar na podstawie rozmiaru ekranu ... prawda? – Si8

+1

@ SiKni8, jeśli chcesz mieć różne rozmiary dla innych rozmiarów ekranu, musisz podać różne zasoby. – aaronvargas

+0

@ SiKni8: ponieważ odwołujesz się do zasobów, które mają być rysowane, prawy jest podejmowany w zależności od rozmiaru ekranu, jeśli umieścisz go w odpowiednim katalogu (res/drawable-? Dpi /) – chteuchteu

2

dokonać widoku niestandardowego jak tworzymy dla lista widok

alert_customlist.xml

<?xml version="1.0" encoding="utf-8"?> 
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    android:orientation="horizontal" 
    android:layout_width="wrap_content" 
    android:layout_height="wrap_content" 
    android:padding="10dp" android:background="#ffffffff"> 
    <ImageView android:layout_width="50dp" android:layout_height="50dp" 
     android:textColor="#ffff0000" android:textSize="20dp" android:id="@+id/text1"/> 
    <TextView android:text="text view two" android:layout_width="fill_parent" android:layout_height="wrap_content" 
     android:textColor="#ffff0000" android:textSize="20dp" android:id="@+id/text2"/> 
</LinearLayout> 

teraz dodać ten pogląd do obiektu AlertDialog jak ten sposób

wyboru ten post http://mgmblog.com/2010/06/10/arrayadapter-and-alertdialog-for-single-choice-items/

+1

link jest martwy ... – kirtan403

Powiązane problemy