gpt4 book ai didi

安卓 : AutoCompleteTextView listview scroll listener (for endless scrolling)

转载 作者:搜寻专家 更新时间:2023-11-01 08:45:03 28 4
gpt4 key购买 nike



我正在使用 AutoCompleteTextView 让我的 Android 应用程序的用户使用自定义网络服务搜索内容:它按预期工作,但目前我找不到实现“无尽滚动”的方法"在下拉 ListView 上。

现在,我的 AutoCompleteTextView 适配器是一个实现了 Filterable 接口(interface)的 ArrayAdapter;每当用户更改 AutoCompleteTextView 的文本时,我的过滤器的 performFiltering() 方法就会被触发,我可以向我的自定义 Web 服务发出 HTTP 请求以显示适当的内容。但我想在用户滚动下拉菜单时加载更多内容,这是一个分页系统,这样我就可以避免一次加载数百个结果……我不知道该怎么做!< br/>

  • 如何获取与 AutoCompleteTextView 关联的 ListView实现我自己的 OnScrollListener/EndlessScrollListener?
  • 还有其他办法吗?

谢谢大家:)

我的 fragment 代码

AutoCompleteTextView search = (AutoCompleteTextView) view.findViewById(R.id.search);

SearchAdapter searchAdapter = new SearchAdapter(getActivity(), 0);

search.setAdapter(searchAdapter);

我的适配器代码(已编辑)

class SearchAdapter extends ArrayAdapter<Parcelable> implements Filterable {

Integer numberPerPage = 10;
Boolean moreDataIsAvailable = false;

FragmentActivity activity;
public ArrayList<Parcelable> items = new ArrayList<Parcelable>();

public SearchAdapter(FragmentActivity a, int textViewResourceId) {
super(a, textViewResourceId);
activity = a;
}

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

@Override
public Parcelable getItem(int index) {
if(items.size() > index) {
return items.get(index);
} else {
return null;
}
}

@Override
public Filter getFilter() {
Filter filter = new Filter() {
@Override
protected FilterResults performFiltering(CharSequence constraint) {
FilterResults filterResults = new FilterResults();
if (constraint != null && constraint.toString().length() >= 3) {
autocomplete(constraint.toString(), items);
filterResults.count = items.size();
filterResults.values = items;
} else {
items.clear();
filterResults.count = items.size();
filterResults.values = items;
}
return filterResults;
}

@Override
protected void publishResults(CharSequence constraint, FilterResults results) {
if (results != null && results.count > 0) {
notifyDataSetChanged();
} else {
notifyDataSetInvalidated();
}
}
};
return filter;
}

static class ViewHolder {
}

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

ViewHolder holder = null;

View rowView = convertView;

if (rowView == null) {

rowView = LayoutInflater.from(activity).inflate(R.layout.search_row, parent, false);
holder = new ViewHolder();
rowView.setTag(holder);

} else {

holder = (ViewHolder) rowView.getTag();

}

// Setting my row data

return rowView;

}

private void autocomplete(String input, ArrayList<Parcelable> items) {

ArrayList<Parcelable> data = new ArrayList<Parcelable>();

try {

RequestHandler request = new RequestHandler();

JSONObject requestParameters = new JSONObject();
requestParameters.put("offset", 0);
requestParameters.put("keyword", input);
requestParameters.put("limit", numberPerPage);

ResponseDescription response = request.request(activity, requestParameters);

if(!response.error) {

JSONArray searchedItems = response.getJSONArray("items");

if(searchedItems.length() == numberPerPage) {
moreDataIsAvailable = true;
} else {
moreDataIsAvailable = false;
}

for(int i = 0 ; i < searchedItems.length(); i++) {

JSONObject searchedItem = searchedItems.getJSONObject(i);

MyObject object = new MyObject();
object.initWithJSONObject(searchedItem);
data.add(object);

}
}

} catch (Exception e) {

e.printStackTrace();

}

items.clear();
items.addAll(data);

}

}

最佳答案

不幸的是,没有用于自动完成的 OnScrollListener 接口(interface),但我认为您可以解决这个问题。

这是我认为的食谱:

  • 为偏移量的 autocomplete 方法添加另一个 argument 参数。

我注意到您将偏移量硬编码为“0”。您将希望能够使用相应的值调用 autocomplete。此外,您在 autocomplete 的末尾有 items.clear() 并且您只想在偏移量为零时执行此操作。

  • 为您的自动完成方法制作一个AsyncTask

或者除了 Filter 中的 performFiltering 方法之外,您还可以在后台运行 autocomplete 方法。此异步任务需要访问您的适配器,以便它可以将其结果添加到 items 列表并像过滤器一样调用 notifyDataSetChanged()

您的适配器需要保留对此任务的引用,以便您可以在用户再次开始输入时取消它。

  • getView() 添加一些逻辑以执行异步任务。

我们没有 OnScrollListener,所以我们将使用 getView() 作为它的一种代理。

为启动下一个请求设置一个常量阈值。它需要小于您的 numberPerPage,所以我们以“5”为例。

现在,当 ListView 调用 getView() 并从末尾开始在阈值范围内的位置时,执行异步任务。例如,在第一次筛选操作之后,您的列表中有 10 个项目。当 ListView 请求第 5 项的 View 时,使用等于您的列表大小的偏移量启动异步任务 - 在本例中为 10(以获取第 11-20 项)。

我的假设是 ListView 只会在用户向下滚动到该项目时请求项目 View 。

  • performFiltering() 中,取消任何正在运行的异步任务。

我已经完成了这种类型的“无限”滚动,使用 ListViewOnScrollListener 调用 AsyncTask 以逐页返回搜索结果,我认为它对我有用的原因是请求响应包含总大小,因此我能够将其用于 getCount()

我还使用了自动完成功能来获取远程结果,但我不必对这些结果进行分页。事实上,我想我只是在输入发生变化并且我的过滤器方法是空操作时运行了异步任务。

结合自动完成和分页的情况不同。如果用户在异步任务可以更新它之前到达列表末尾,则滚动下拉列表可能会出现一些卡顿行为。因此,您可能需要调整页面大小、阈值甚至 getCount() 的返回值以获得可接受的滚动体验。但我认为这是可行的。

关于安卓 : AutoCompleteTextView listview scroll listener (for endless scrolling),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29276545/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com