2012-11-27 8 views
13

ho notato che TwoLineListItem è deprecato come di API 17. Qual è l'alternativa a questo se io sono la creazione di un adattatore ListActivity come segue ?:ListActivity TwoLineListItem alternativa

ArrayAdapter<File> adapter = new ArrayAdapter<File>(this,android.R.layout.simple_list_item_2,filesArrayList){ 
      @Override 
      public View getView(int position, View convertView, ViewGroup parent){ 
       final TwoLineListItem row; 
       if(convertView == null){ 
        LayoutInflater inflater = (LayoutInflater)getApplicationContext().getSystemService(Context.LAYOUT_INFLATER_SERVICE); 
        row = (TwoLineListItem)inflater.inflate(android.R.layout.simple_list_item_2, null); 
       }else{ 
        row = (TwoLineListItem)convertView; 
       } 
       row.getText1().setText(filesArrayList.get(position).getTitle()); 
       row.getText2().setText2(filesArrayList.get(position).getDescription()); 
       return row; 
      } 

     }; 
+0

È possibile scrivere il proprio 'View' che ha due testo' View's in essa con lo stile appropriato. – prprcupofcoffee

risposta

15

Basta tagliare e incollare il codice sorgente TwoLineListItem in un layout del proprio:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    android:layout_width="match_parent" 
    android:layout_height="wrap_content" 
    android:orientation="vertical"> 

    <TextView android:id="@+id/text1" 
     android:textSize="16sp" 
     android:textStyle="bold" 
     android:layout_width="match_parent" 
     android:layout_height="wrap_content"/> 

    <TextView android:id="@+id/text2" 
     android:textSize="16sp" 
     android:layout_width="match_parent" 
     android:layout_height="wrap_content"/> 

</LinearLayout> 

(Notate ho cambiato gli iD di coerenza.)

Ora utilizzare un ViewHolder che mantiene i riferimenti a entrambi TextV iews:

public View getView(int position, View convertView, ViewGroup parent){ 
    ViewHolder holder; 
    if(convertView == null){ 
     // You should fetch the LayoutInflater once in your constructor 
     LayoutInflater inflater = (LayoutInflater)getApplicationContext().getSystemService(Context.LAYOUT_INFLATER_SERVICE); 
     convertView = inflater.inflate(R.layout.list_item_2, null); 

     // Initialize ViewHolder here 
    }else{ 
     holder = (ViewHolder) convertView.getTag(); 
    } 

    File file = filesArrayList.get(position); 
    holder.text1.setText(file.getTitle()); 
    holder.text2.setText2(file.getDescription()); 
    return convertView; 
} 
+0

Questo non funziona se usato con 'ArrayAdapter's. – SagunKho

6

Ecco come ho fatto:

mAdapter = new ArrayAdapter<String>(getActivity(), android.R.layout.simple_list_item_2, mListItems) 
    { 
     @Override 
     public View getView(int position, View convertView, ViewGroup parent) 
     { 
      View row; 
      if(convertView == null) 
      { 
       row = (View)mInflater.inflate(android.R.layout.simple_list_item_2, parent, null); 
      } 
      else 
      { 
       row = (View)convertView; 
      } 
      TextView v = (TextView) row.findViewById(android.R.id.text1); 
      v.setText(mListItems[position]); 
      v = (TextView) row.findViewById(android.R.id.text2); 
      v.setText(mListSubItems[position]); 
      return row; 
     } 
    }; 
ListView lv = (ListView) getActivity().findViewById(R.id.runsListView); 
    lv.setAdapter(mAdapter); 
    lv.setOnItemClickListener(mMessageClickedHandler); 
0

In primo luogo è deprecato, in modo che non è male per te. Perché sarà supportato per sempre. ;)

If it ain’t broke, don’t fix it.

Siete liberi di utilizzare qualsiasi layout! Basta aggiungere qualche informazione per rispondere stato selezionato se si utilizza una selezione modalità, come:

android:background="?android:attr/activatedBackgroundIndicator" 
+2

La deprecazione è come dire che qualcosa non dovrebbe essere usato, e in futuro potrebbe non funzionare come previsto. Quindi perché rischiare se lo sai? –