12

我有一个带有 a的自定义适配器ListFragment,但getView()根本没有调用适配器。

这就是适配器的样子——

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;
    }
}

还有碎片——

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);
    }
}

这就是我的布局的样子 -

<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" />

我不知道这里有什么问题。

4

5 回答 5

35

这是因为 getCount() 返回零。您在 getCount() 中返回的数字是调用 getView() 的次数。在 getCount() 中,您应该始终返回列表的大小。

所以

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

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

另外,也许布局的 ListView id 不是 android.R.id.list?

确保你有 xml

<ListView
    android:id="@android:id/list"
    ...

此外,永远不要将任何数据传递给构造函数中的片段。

错误

public ModuleItemListFragment(List<ModuleItem> list,Module mod) {
    super();
    this.list=list;
    this.mod=mod;
}

private static final String EXTRA_LIST = "ModuleItemListFragment.EXTRA_LIST";
private static final String EXTRA_MODULE = "ModuleItemListFragment.EXTRA_MODULE";

public static ModuleItemListFragment instantiate(ArrayList<ModuleItem> list, Module mod) {
    final Bundle args = new Bundle();
    args.putParcelable(EXTRA_LIST, list);
    args.putParcelable(EXTRA_MODULE, module);

    final ModuleItemListFragment f = new ModuleItemListFragment();
    f.setArguments(args);
    return f;
}

@Override
public void onCreate(Bundle state) {
    super.onCreate(state);
    final Bundle args = getArguments();
    this.list = args.getParcelable(EXTRA_LIST);
    this.module = args.getParcelable(EXTRA_MODULE);
}

当然,您必须使您的模块可打包或可序列化。

您必须指定 args,因为 Fragment 可以被系统杀死和恢复,如果您通过 setter 或构造函数传递数据,它们将不会被恢复,因此在某些情况下可能会变为 null。

于 2013-04-27T09:16:32.703 回答
2

我通过阅读ArrayAdapter代码干净地解决了这个问题。显然它保持对内部对象列表的引用。我所要做的就是将我的 ArrayList 指针传递给超级构造函数:

public FriendsAdapter(Context context, int resource, ArrayList<FriendItem> friends) {
    super(context, resource, friends);
} 

而且我不必重写任何getItemgetCount方法。

注意:这适用于ArrayAdapterAPI 级别 23+,因此可能不适用于您。

于 2016-05-22T21:18:23.120 回答
0

getView()当数据集至少有一条要在视图中显示的记录时调用该方法。

getView():返回:指定位置的数据对应的View。

因此,如果我们数据集的大小为 0,则位置也为 0。

结果getView()方法没有调用。

于 2016-04-20T16:05:42.113 回答
0

我遇到了这个问题,就我而言,问题是我错误地创建了 2 个适配器。其中一个是我传递给setAdapter的,另一个是我用来添加项目的 using add。因此,重要的适配器从未被添加到。

于 2016-04-24T22:14:52.487 回答
0

Fragment我有同样的问题,在我的情况下,我没有在我的构造函数中初始化我的本地数组列表。

ArrayList<Image> mImageList;

public ImageCategoryAdapter(Context context, ArrayList<Image> itemList) {
    super(context, 0);

    mImageList = itemList;
}

我错过了这个mImageList = itemList;部分。

这只是一个人为错误,但它可能对面临同样问题的人有所帮助。

于 2016-01-13T03:04:34.737 回答