- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
public View getView(int index, View view, ViewGroup parent){
if (view == null) { // for the first time, inflate the view
LayoutInflater inflater =
LayoutInflater.from(parent.getContext());
view = inflater.inflate(
R.layout.time_list_item, parent, false);
}
/**
* The layout under consideration has two TextViews in it
* one to display the time and other to display some text.
*/
TimeRecord time = times.get(index);
timeTextView.setText(time.getTime());
TextView timeTextView = (TextView)
view.findViewById(R.id.time_view);
notesTextView.setText(time.getNotes());
TextView notesTextView = (TextView)
view.findViewById(R.id.notes_view);
return view;
}
我知道 getView()
会针对要显示的集合中的每个项目重复调用。我正在使用的引用资料说,要优化性能,您应该重用 View 。现在,这种“重用”让我感到困惑。
这些返回的 View 将显示在 ListView
中。如果我只返回一个用新数据重新填充的 View
,数据将如何正确显示?怎么会有多个条目?
换句话说,我不只是返回一个 View 并期望看到多个 ListView
条目吗?不应该是我返回新的 Views
吗?
最佳答案
How does getView() work in a custom adapter?
getView() 方法被调用的次数与行数 e.q 一样多。每行都有自己的 View 。
Now, this 'reuse' is confusing me.
这叫做 View 回收。换句话说,如果行不可见,则它不为空(如果已创建并且至少可见一次)但是如果您不创建将保存行的 subview 的机制,则回收将不起作用,在您的情况下您的 findViewById()将为每一行调用(例如在 1000 行的情况下,它不是很有效)。
为此使用了 Holder 设计模式。它是简单的任意对象,包含每一行的 subview 的引用。
你可以这样实现它:
public class RowHolder {
private View row;
// childs widgets in row
private TextView name;
public RowHolder(View row) {
this.row = row; // row in ListView (in your case)
}
public TextView getName() {
if (name == null) {
name = (TextView) row.findViewById(<id>);
}
return name;
}
...
}
还有一个用法:
LayoutInflater inflater;
RowHolder holder = null;
// row created first time
if (convertView == null) {
convertView = inflater.inflate(<rowXMLLayout>, null, false);
holder = new RowHolder(convertView); // adding row to arbitrary obj
convertView.setTag(holder) // adding this obj to row at position
}
else {
// recycling started
holder = (RowHolder) convertView.getTag();
}
// updating rows
holder.getName().setText(<value?>);
...
关于android - getView() 如何在自定义适配器中工作?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18053482/
我想要自定义微调器,在下拉列表中包含图像和 TextView ,因此我创建了不同的布局并对其进行了膨胀,其工作正常,但对于按微调器之前的微调器布局,我只想有一个类似“选择”的文本来自列表”但是当我用
所以我正在开发实时 ListView ,我需要 ListView 在单击按钮时更新,这些也是如此: private void ReloadData(){ DataList.clear();
我知道其他人也问过这个问题,但我看过其他解决方案,但仍然无法使其发挥作用。 适配器代码: private class CustomTextAndImageAdapter extends ArrayAd
我有一个通过 asynctask 填充的自定义 ListView 适配器,我在 onprogress 函数中调用 notificationdatasetchanged,并且 getCount() 返回
我正在显示联系人列表。一切都很好,除了设备有 1620 个联系人,所以列表滚动非常慢,甚至有时会挂起。 请帮帮我。 我尝试使用检查 ConvertView!=null 的 getView 方法,但它总
我想在每张图片下方添加一个文本,这是我的实际代码: @Override public View getView(int position, View convertView, ViewGroup pa
我在 Adapter extensions override of getView 中经常看到这一点: @Override public View getView(int position,
我正在尝试在对话框中制作 ListView 。但是我的适配器中的 getView 函数永远不会被调用。有什么想法吗? 适配器: public class DialogAdapter extends B
我有 public class MainActivity extends FragmentActivity 我编写了实现 AsyncResponse 的 Loader 类: public class
我有这样一段代码:)我想编辑我的自定义首选项布局的文本属性。但是从 getView 函数对对象所做的任何更改都不会影响首选项屏幕中的实际列表。有任何想法吗?我知道我不能扩展 PreferenceScr
我有一个扩展 simplecursoradapter 的适配器。新 View 应该从数据库中获取光标和图像,用几个复选框填充列表。出于某种原因,我似乎看不到,我的 getView 甚至没有被调用。我在
谁能解释一下这两种 getView() 实现之间的区别是什么? 第一个简单地检查 convertView 是否为 null;如果它为 null,则膨胀一个新的 View 对象。然后给子View设置合适
我做了一个 SingleItemAdapter extends ArrayAdapter,这个定制的 Adapter 用于 ListView。 在这个 SingleItemAdapter 中,我做了一
这里是相当新的 Android 开发者。 我遇到了一个奇怪的问题,我不确定如何解决。我在这里阅读了很多问题,听起来它们与我遇到的问题相同,但他们问题的解决方案似乎永远不适用于这里发生的事情。 我使用扩
我有一个带有 ListFragment 的自定义适配器,但根本没有调用适配器 getView()。 这是适配器的样子 - public class ModuleListItemAdapter exte
我正在将自定义 SimpleCursorAdapter 设置为 ListView。出于某种原因,对于数据库中的每个项目,FriendAdapter 的 getView() 被调用两次。经过一些调查(我
我有一个包含自定义适配器和自定义行的列表。 问题是当我滚动 ListView 时,图像位于错误的位置... 这是自定义行 xml: 这是 GetView: List it
public View getView(int index, View view, ViewGroup parent){ if (view == null) { // for the firs
我添加了两个按钮(添加和删除)来控制 ListView ,当我删除一个项目时,该项目不会立即在 ListView 中消失,只有当我在 ListView 上滑动时,新项目才会消失。除非我触摸屏幕或在 L
我已经多次尝试在我的 Controller 上使用 this.getView(),但我总是在我的控制台上收到 getView is not a function 错误。 是否有任何“技巧”或我可以做的
我是一名优秀的程序员,十分优秀!