[英]How to prevent auto scroll in RecyclerView after notifyDataSetChanged?
[英]recyclerview scroll to top after notifyDataSetChanged()
我有一個非常奇怪的問題,我試着解決它約2天。 我有一個RecyclerView
其嵌套在NestedScrollView
。 我為我的NestedScrollView
創建了EndlessScrollListener
並且它正確加載了更多數據,但是當我調用notifyDataSetChanged()
或notifyItemRangeChanged()
我的列表滾動到第二個項目的頂部。 此外,當我想要更新我的SwipeRefreshLayout
所有項目時,它可能會混合(例如,第四項中的圖像可能在第一項中設置等)。 只有當我想要更新項目時才會發生這種情況,當我第一次打開我的應用程序時一切正常。 我不知道為什么會這樣,請幫幫我。 提前致謝。 我的代碼這是我初始化適配器的功能
private void setFeedRecycler(RecyclerView feedRecyclerView, List<Edge<Activity>> feeds){
noFeedsTitle.setVisibility(View.GONE);
feedsArray.addAll(feeds);
LinearLayoutManager layoutManager = new LinearLayoutManager(getActivity());
feedRecyclerView.setHasFixedSize(true);
feedRecyclerView.setNestedScrollingEnabled(false);
feedRecyclerView.setLayoutManager(layoutManager);
feedsDashboardAdapter = new FeedsDashboardAdapter(getActivity(), this, feedsArray, feedRecyclerView, mainDashboardLayout);
feedsDashboardAdapter.setOnLoadMoreListener(loadMoreListenerFeeds);
feedRecyclerView.setAdapter(feedsDashboardAdapter);
}
從服務器獲取數據后,我從主UI更新我的適配器
getActivity().runOnUiThread(new Runnable() {
public void run() {
feedsArray.addAll(feedMobile.getEdges());
feedsDashboardAdapter.notifyDataSetChanged();
}});
當我想更新我的所有項目時
private SwipeRefreshLayout.OnRefreshListener refreshListener = new SwipeRefreshLayout.OnRefreshListener() {
@Override
public void onRefresh() {
loadAfterCursorFeed = "";
feedsArray.clear();
getUserFeeds(user.getAccessToken(), user.getClientId(), loadAfterCursorFeed);
}
};
loadAfterCursorFeed它就像是下一頁數據的id。 最后我的適配器
public FeedsDashboardAdapter(Context context, DashboardFragment fragment, ArrayList<Edge<Activity>> feeds, RecyclerView recyclerView,
NestedScrollView mainDashboardLayout){
this.feeds = feeds;
this.context = context;
this.fragment = fragment;
this.mainDashboardLayout = mainDashboardLayout;
this.linearLayoutManager = (LinearLayoutManager) recyclerView.getLayoutManager();
this.client = new RestClient().getApiService();
SharedPreferences sharedPreferences = PreferenceManager.getDefaultSharedPreferences(context);
user = new Gson().fromJson(sharedPreferences.getString("user", null), User.class );
mainDashboardLayout.setOnScrollChangeListener(new EndlessParentScrollListener(linearLayoutManager) {
@Override
public void onLoadMore(int page, int totalItemsCount) {
Log.d(TAG, "page " + page + " totalItemsCount " + totalItemsCount);
if (onLoadMoreListener != null) {
onLoadMoreListener.onLoadMore();
}
}
});
}
@Override
public RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
if (viewType == VIEW_TYPE_USER_FEEDS) {
View layoutView = LayoutInflater.from(parent.getContext()).inflate(R.layout.item_user_feed, parent, false);
return new CategoryUserFeedHolder(layoutView, context);
} else if(viewType == VIEW_TYPE_SHARE_EVENT) {
View layoutView = LayoutInflater.from(parent.getContext()).inflate(R.layout.item_feed_shared_event, parent, false);
return new CategoryShareEventHolder(layoutView);
} else if (viewType == VIEW_TYPE_LOADING) {
View layoutView = LayoutInflater.from(parent.getContext()).inflate(R.layout.loading_item_layout, parent, false);
return new LoadingViewHolder(layoutView);
}
return null;
}
@Override
public void onBindViewHolder(RecyclerView.ViewHolder holder, int position) {
if (holder instanceof CategoryShareEventHolder) {
//set necessary field
}
else if(holder instanceof CategoryUserFeedHolder){
//set necessary field
}
}
@Override
public int getItemCount() {
return this.feeds ==null ? 0 : this.feeds.size();
}
@Override
public int getItemViewType(int position) {
if (feeds.get(position) == null)
return VIEW_TYPE_LOADING;
else if (feeds.get(position).getResponse().getEvent() != null)
return VIEW_TYPE_SHARE_EVENT;
return VIEW_TYPE_USER_FEEDS;
}
public void setOnLoadMoreListener(OnLoadMoreListener listener){
this.onLoadMoreListener = listener;
}
嘗試在布局中使用RecyclerView而不使用NestedScrollView,看看這個答案https://stackoverflow.com/a/31818632/6926324
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.