I have a Custom adapter with a ListFragment
but the adapters getView()
is not getting called at all.
This is how the adapter looks like -
public class ModuleListItemAdapter extends BaseAdapter {
List<ModuleItem> list;
Context context;
Module mod;
public ModuleListItemAdapter() {
super();
// TODO Auto-generated constructor stub
}
public ModuleListItemAdapter(Context context, List<ModuleItem> list, Module mod) {
super();
this.list = list;
this.context = context;
this.mod = mod;
// TODO Auto-generated constructor stub
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
LayoutInflater inflater = (LayoutInflater) context
.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
RelativeLayout rl = (RelativeLayout) inflater.inflate(R.layout.moduleitem, null);
GenerateModuleItemView gmiv = new GenerateModuleItemView(context);
rl.addView(gmiv.itemDispView(mod.getFields(), list.get(position)));
return rl;
}
public void setValue(List<ModuleItem> l) {
this.list = l;
notifyDataSetChanged();
}
public void addValue(ModuleItem item) {
this.list.add(item);
notifyDataSetChanged();
}
@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 0;
}
}
And the Fragment -
public class ModuleItemListFragment extends ListFragment {
List<ModuleItem> list;
Module mod;
public ModuleItemListFragment() {
super();
// TODO Auto-generated constructor stub
}
public ModuleItemListFragment(List<ModuleItem> list, Module mod) {
super();
this.list = list;
this.mod = mod;
// TODO Auto-generated constructor stub
}
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
// TODO Auto-generated method stub
return inflater.inflate(R.layout.list, container, false);
}
@Override
public void onActivityCreated(Bundle savedInstanceState) {
super.onActivityCreated(savedInstanceState);
ModuleListItemAdapter adapter = new ModuleListItemAdapter(getActivity(), list, mod);
setListAdapter(adapter);
}
}
And this is how my layout looks like -
<ListView xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@android:id/list"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:divider="#000000"
android:dividerHeight="1dip" />
I don't know what the problem is here.
I solved this problem cleanly by reading the
ArrayAdapter
code. Apparently it keeps reference to an internal list of objects. All I had to do was to pass my ArrayList pointer to super constructor thus:and I didn't have to override any
getItem
orgetCount
methods.Note: This is for
ArrayAdapter
and API level 23+ so it may not apply to you.getView() method is calling when the data set has at least one record to display in the view.
getView() : Returns: A View corresponding to the data at the specified position.
And if we the size of data set is 0 therefore, the position is also 0.
As a result getView() method is not calling.
It's because getCount() returns zero. The number you return in getCount() is the times the getView() will be called. In getCount() you should always return the size of the list.
Therefore
Also, maybe the layout's ListView id is not android.R.id.list?
Make sure you have in xml
Also, don't ever pass any data to a fragment in constructor.
WRONG:
RIGHT:
Of course, you have to make your Module Parcelable or Serializable.
You must specify args because the Fragment can be killed and restored by the system and if you pass data via setters or constructors they will not be restored and therefore can become null in some circumstances.
I have same problem, in my case i did't initialized my local array list in my
Fragment
constructor.I missed the
mImageList = itemList;
part.It is only a man made error but it might be helpful to someone facing the same issue.
I had this problem and in my case, the problem was that I mistakenly created 2 adapters. One of them I was passing to
setAdapter
and the other one I was using to add items to usingadd
. So the adapter that mattered was never being added to.