2014-07-04 17 views
5

Ich bin daran interessiert, einen generischen BaseAdapter zu erstellen, der auf jedes ListView mit einem list_item angewendet wird. Und es wird die item_row für die list_view setzen.Erstellen Sie einen generischen Basisadapter?

public class GenericAdapter extends BaseAdapter 
    { 

    Context context; 

    ArrayList<HashMap<String, String>> list; 

    LayoutInflater inflater; 

    public GenericAdapter (Context context, ArrayList<HashMap<String, String>> list) 
     { 
      this.context = context; 

      this.list = list; 

      inflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE); 
    } 

     @Override 
     public int getCount() 
     { 
      return list.size(); 
     } 

     @Override 
     public Object getItem(int position) 
     { 
      return list.get(position); 
     } 

     @Override 
     public long getItemId(int position) 
     { 
      return position; 
     } 

     @Override 
     public View getView(int position, View convertView, ViewGroup parent) 
     { 
      View view = convertView; 

      if(view == null) 
      { 
      view = inflater.inflate(R.layout.item_of_any_list, parent, false); 

// i have to do something here like there may be a method which must be call 

      } 

      /*HashMap<String, String> map = list.get(position); 

      TextView textViewName = (TextView) view.findViewById(R.id.name); 

      TextView textViewDate = (TextView) view.findViewById(R.id.date); 

      //TextView textViewDesc = (TextView) view.findViewById(R.id.desc); 

      textViewName.setText(map.get("name")); 

      textViewDate.setText(map.get("date")); 

      //textViewDesc.setText(map.get("description")); 
    */  
      return view; 
     } 

Ich denke, ich muss eine Schnittstelle erstellen, die erhalten und die item_row für einzelne Artikel festlegen. Aber ich weiß nicht, dass es möglich ist. Kann mir jemand sagen, wie ich es erreichen kann?

Meine Idee ist es, eine Schnittstelle zu erstellen, und GenericAdapter implementiert diese Schnittstelle. In dieser Schnittstelle gibt es eine Methode, um item_row zu erhalten und zu setzen. Jede Klasse, die GenericAdapter erweitert, muss diese Methode implementieren. Es wird uns helfen, einen generischen Adapter zu machen.

Wenn wir diesen Adapter erweitern, müssen wir nicht den gesamten Code wie getCount, getItem, getItemId schreiben, wir müssen nur eine Funktion überschreiben, die inflationLayout ist. die

Vielen Dank im Voraus innerhalb getView sein muss

+2

Wenn Sie nicht über benutzerdefinierte Adapter schreiben wollen prüfen, mit eine vorhandene Bibliothek, wie https://github.com/ribot/easy-adapter oder http://amigold.github.io/FunDapter/ – CommonsWare

+0

Siehe [Generic Adapter] (https://github.com/sa jadshokri/Core-Adapter) – FarshidABZ

Antwort

3

Antworten.

Um Generisches Adapter Sie benötigen abstract Methoden in parent class zu machen, die durch child umgesetzt werden sollten. So muss GenericAdapterAbstract sein und abstract Methoden für Daten erstellen, die Sie ändern möchten.

Ich habe verschiedene Arten von ArrayList im Adapter nur zu zeigen, es ist model class ist anders. Also entschied ich mich, eine genericAdapter zu schreiben. Dies ist für recyclerview wenn someone interested für listview. Gib mir Bescheid.

GenericAdapter

public abstract class GenericAdapter<T> extends RecyclerView.Adapter<RecyclerView.ViewHolder> { 

    private Context context; 
    private ArrayList<T> items; 

    public abstract RecyclerView.ViewHolder setViewHolder(ViewGroup parent); 

    public abstract void onBindData(RecyclerView.ViewHolder holder, T val); 

    public GenericAdapter(Context context, ArrayList<T> items){ 
     this.context = context; 
     this.items = items; 
    } 

    @Override 
    public RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) { 
     RecyclerView.ViewHolder holder = setViewHolder(parent); 
     return holder; 
    } 

    @Override 
    public void onBindViewHolder(RecyclerView.ViewHolder holder, int position) { 
     onBindData(holder,items.get(position)); 
    } 

    @Override 
    public int getItemCount() { 
     return items.size(); 
    } 

    public void addItems(ArrayList<T> savedCardItemz){ 
     items = savedCardItemz; 
     this.notifyDataSetChanged(); 
    } 

    public T getItem(int position){ 
     return items.get(position); 
    } 
} 

Und ich benutze es wie

 adapter = new GenericAdapter<DataModel>(context,modelList) { 
     @Override 
     public RecyclerView.ViewHolder setViewHolder(ViewGroup parent) { 
      final View view =   LayoutInflater.from(context).inflate(R.layout.item_view_holder, parent, false); 
      ItemViewHolder viewHolder = new ItemViewHolder(context, view); 
      return viewHolder; 
     } 

     @Override 
     public void onBindData(RecyclerView.ViewHolder holder1, DataModel val) { 
       DataModel userModel = val; 

       ItemViewHolder holder = (ItemViewHolder)holder1; 
       holder.name.setText(userModel.getName()); 
       holder.fatherName.setText(userModel.getFatherName()); 
     } 
    }; 
    mRecyclerView.setAdapter(adapter); 

RecyclerView with Search sort functionality

+1

Können Sie Ihren Adapter für Listview –

+0

@Nepster zeigen Sie Ihren Code ** funktioniert nicht für mehrere Typen Adapter **. Eigentlich kann ich sehen, dass es nicht genug "generisch" ist. Ihre abstrakten Methoden sind nichts anderes als Wrapper-Methoden von RecycleView Adapter ("setViewHolder" ist ein Wrapper von 'onCreateViewHolder',' onBindData' ist Wrapping für 'onBindViewHolder'). Dieses Muster funktioniert für Adapter ListView anstelle von Recycle Adapter. Nur mein obwohl – R4j

+0

@ R4j Geben Sie einen Vorschlag, um es zu verbessern. Und wie kann ich generische Filter auf der Basis von Typ – Nepster

-1
import java.util.ArrayList; 

import android.app.Activity; 
import android.app.Fragment; 
import android.content.Context; 
import android.content.Intent; 
import android.os.Bundle; 
import android.view.LayoutInflater; 
import android.view.View; 
import android.view.ViewGroup; 
import android.widget.AdapterView; 
import android.widget.Button; 
import android.widget.ListView; 
import android.widget.AdapterView.OnItemClickListener; 

import com.accel.cloudRDB.model.OpenTask; 

public class Open_task_fragment extends Fragment { 
    View view; 
    ListView mListView; 
    Open_task_adapter open_task_adapter; 
    Context mContext; 
    ArrayList<OpenTask> items; 
    Button main_menu; 
    @Override 
    public View onCreateView(LayoutInflater inflater,ViewGroup container, Bundle savedInstanceState) 
    { 

     mContext=getActivity(); 
     view=inflater.inflate(R.layout.open_task_layout, container,false); 
     items=new ArrayList<OpenTask>(); 
     initXML(); 
     OpenTask open=new OpenTask(); 
     open.setDate("10/10/2014"); 
     open.setTime("12:00 pm"); 
     open.setAddress("chennai Dlf,[email protected]"); 
     open.setStatus("Deliver ABC"); 
     OpenTask open1=new OpenTask(); 
     open1.setDate("10/10/2014"); 
     open1.setTime("12:00 pm"); 
     open1.setAddress("chennai Dlf,[email protected]"); 
     open1.setStatus("Deliver ABC2"); 
     items.add(open); 
     items.add(open1); 
     open_task_adapter=new Open_task_adapter(mContext,items); 
//  open_task_adapter=new Open_task_adapter(mContext,items); 
     mListView.setAdapter(open_task_adapter); 
     mListView.setOnItemClickListener(new OnItemClickListener() { 

      @Override 
      public void onItemClick(AdapterView<?> parent, View arg1, int position, 
        long arg3) { 

        Intent intent=new Intent(mContext,Task_detail_activity.class); 
        ((Activity)mContext).startActivity(intent); 
      } 

     }); 
     return view; 
    } 
    public void initXML() 
    { 
     mListView=(ListView)view.findViewById(R.id.listView1); 
     main_menu=(Button)view.findViewById(R.id.main_menu); 
    } 

} 

Modell:

public class OpenTask { 

    String Date,Time,Address,Status; 

    public String getDate() { 
     return Date; 
    } 

    public void setDate(String date) { 
     Date = date; 
    } 

    public String getTime() { 
     return Time; 
    } 

    public void setTime(String time) { 
     Time = time; 
    } 

    public String getAddress() { 
     return Address; 
    } 

    public void setAddress(String address) { 
     Address = address; 
    } 

    public String getStatus() { 
     return Status; 
    } 

    public void setStatus(String status) { 
     Status = status; 
    } 

} 

Adapter: meine eigene Frage nach zwei Jahren

import java.util.ArrayList; 

import android.content.Context; 
import android.view.LayoutInflater; 
import android.view.View; 
import android.view.ViewGroup; 
import android.widget.BaseAdapter; 
import android.widget.TextView; 


public class Open_task_adapter extends BaseAdapter { 

    Context context; 

    ArrayList<OpenTask> list; 

    public Open_task_adapter(Context context,ArrayList<OpenTask> list) { 

     this.context = context; 
     this.list = list; 

    } 

    @Override 
    public int getCount() { 
     // TODO Auto-generated method stub 
     return list.size(); 
    } 

    @Override 
    public Object getItem(int position) { 
     // TODO Auto-generated method stub 
     return list.get(position); 
    } 

    @Override 
    public long getItemId(int position) { 
     // TODO Auto-generated method stub 
     return position; 
    } 

    @Override 
    public View getView(int position, View convertView, ViewGroup parent) { 
     // TODO Auto-generated method stub 
     OpenTaskHolder hodler; 
     LayoutInflater inflater; 
     OpenTask open=list.get(position); 
     if (convertView == null) 
     { 
      inflater = (LayoutInflater)context.getSystemService(Context.LAYOUT_INFLATER_SERVICE); 
      convertView = inflater.inflate(R.layout.open_task_list_item_layout, null); 
      hodler = new OpenTaskHolder(); 
      hodler.date = (TextView)convertView.findViewById(R.id.Date); 
      hodler.time = (TextView)convertView.findViewById(R.id.Time); 
      hodler.address = (TextView)convertView.findViewById(R.id.Address); 
      hodler.status = (TextView)convertView.findViewById(R.id.Status); 

      convertView.setTag(hodler); 
     } else { 
      hodler = (OpenTaskHolder)convertView.getTag(); 
     } 

     hodler.date.setText(open.getDate()); 
     hodler.time.setText(open.getTime()); 
     hodler.address.setText(open.getAddress()); 
     hodler.status.setText(open.getStatus()); 

     return convertView; 
    } 

    class OpenTaskHolder { 
     TextView date,time,address,status; 
    } 
} 
+7

Bitte erläutern Sie, wie dies die Frage beantwortet. – CommonsWare

+0

@CommonsWare können wir auf diese Weise erreichen – Boopathi

+0

faule Feiglinge, down Voter geben Kommentar, was habe ich falsch von hier? – Boopathi

1

ich eine generische Adapter erstellt haben, die AAR und die Quellen sind bei this url:

es die einfache Nutzung ist:

RecyclerAdapter<Customer> mAdapter = new RecyclerAdapter(customerList, CustomerViewHolder.class); 

URL Link, um mehr Details zu sehen

0
import android.content.Context; 
import android.view.LayoutInflater; 
import android.view.View; 
import android.view.ViewGroup; 
import android.widget.BaseAdapter; 

import java.util.List; 

public abstract class GenericAdapter<T> extends BaseAdapter { 
    LayoutInflater layoutInflater; 
    Context context; 
    private List<T> tList; 



public GenericAdapter(Context context, List<T> tList) { 
     this.context = context; 
     this.tList = tList; 
     layoutInflater = LayoutInflater.from(context); 
    } 

    @Override 
    public int getCount() { 
     if (tList == null) 
      return 0; 
     return tList.size(); 
    } 

    @Override 
    public Object getItem(int position) { 
     return tList.get(position); 
    } 


    @Override 
    public long getItemId(int position) { 
     return 0; 
    } 

    public abstract View getMyView(int position, View convertView, ViewGroup parent,T t); 

    @Override 
    public View getView(int position, View convertView, ViewGroup parent) { 
     return getMyView(position, convertView, parent,tList.get(position)); 
    } 

} 

und Sie können es verwenden, wie

spnDistrict.setAdapter(new GenericAdapter<Institutions>(getContext(), institutionsList) { 
      @Override 
      public View getMyView(int position, View convertView, ViewGroup parent, Institutions institutions) { 
       TextView textView = (TextView) convertView; 
       if (textView == null) { 
        textView = (TextView) getLayoutInflater().inflate(android.R.layout.simple_list_item_1, null); 
        textView.setTextColor(getContext().getResources().getColor(R.color.black)); 
       } 
       textView.setText(institutions.getName()); 
       return textView; 
      } 
     }); 
+0

Während dies beantworten kann Frage, es ist besser, die wesentlichen Teile der Antwort zu erklären und möglicherweise, was das Problem mit OP-Code war. – pirho

Verwandte Themen