From aab26efaa969cfc627f01b476d2956fbde402a9a Mon Sep 17 00:00:00 2001 From: chaohui Date: Wed, 20 Jul 2016 14:19:09 +0800 Subject: [PATCH] Fixed the problem that addHeaderView doesn't show after removeHeaderView. --- .../base/BaseItemDraggableAdapter.java | 2 +- .../adapter/base/BaseQuickAdapter.java | 82 ++++++++++++------- 2 files changed, 54 insertions(+), 30 deletions(-) diff --git a/library/src/main/java/com/chad/library/adapter/base/BaseItemDraggableAdapter.java b/library/src/main/java/com/chad/library/adapter/base/BaseItemDraggableAdapter.java index d6d98418e..cfe4b72ca 100644 --- a/library/src/main/java/com/chad/library/adapter/base/BaseItemDraggableAdapter.java +++ b/library/src/main/java/com/chad/library/adapter/base/BaseItemDraggableAdapter.java @@ -190,7 +190,7 @@ public void setOnItemDragListener(OnItemDragListener onItemDragListener) { } public int getViewHolderPosition(RecyclerView.ViewHolder viewHolder) { - return viewHolder.getAdapterPosition() - getHeaderViewsCount(); + return viewHolder.getAdapterPosition() - getHeaderLayoutCount(); } public void onItemDragStart(RecyclerView.ViewHolder viewHolder) { diff --git a/library/src/main/java/com/chad/library/adapter/base/BaseQuickAdapter.java b/library/src/main/java/com/chad/library/adapter/base/BaseQuickAdapter.java index 3d1e1279b..2b02de2dc 100755 --- a/library/src/main/java/com/chad/library/adapter/base/BaseQuickAdapter.java +++ b/library/src/main/java/com/chad/library/adapter/base/BaseQuickAdapter.java @@ -55,6 +55,8 @@ public abstract class BaseQuickAdapter extends RecyclerView.Adapter data) { */ public void remove(int position) { mData.remove(position); - notifyItemRemoved(position + getHeaderViewsCount()); + notifyItemRemoved(position + getHeaderLayoutCount()); } @@ -379,7 +381,8 @@ public T getItem(int position) { } /** - * if setHeadView will be return 1 if not will be return 0 + * if setHeadView will be return 1 if not will be return 0. + * notice: Deprecated! Use {@link ViewGroup#getChildCount()} of {@link #getHeaderLayout()} to replace. * * @return */ @@ -389,7 +392,8 @@ public int getHeaderViewsCount() { } /** - * if mFooterLayout will be return 1 or not will be return 0 + * if mFooterLayout will be return 1 or not will be return 0. + * notice: Deprecated! Use {@link ViewGroup#getChildCount()} of {@link #getFooterLayout()} to replace. * * @return */ @@ -399,21 +403,17 @@ public int getFooterViewsCount() { } /** - * if mHeaderLayout is null will be return false or not will be true - * - * @return + * if addHeaderView will be return 1, if not will be return 0 */ - public boolean hasHeaderLayout() { - return mHeaderLayout != null; + public int getHeaderLayoutCount() { + return mHeaderLayout == null ? 0 : 1; } /** - * if mFooterLayout is null will be return false or not will be true - * - * @return + * if addFooterView will be return 1, if not will be return 0 */ - public boolean hasFooterLayout() { - return mFooterLayout != null; + public int getFooterLayoutCount() { + return mFooterLayout == null ? 0 : 1; } /** @@ -433,7 +433,7 @@ public int getmEmptyViewCount() { @Override public int getItemCount() { int i = isLoadMore() ? 1 : 0; - int count = mData.size() + i + getHeaderViewsCount() + getFooterViewsCount(); + int count = mData.size() + i + getHeaderLayoutCount() + getFooterLayoutCount(); if (mData.size() == 0 && mEmptyView != null) { /** * setEmptyView(false) and add emptyView @@ -447,7 +447,7 @@ public int getItemCount() { count += getmEmptyViewCount(); } - if ((mHeadAndEmptyEnable && getHeaderViewsCount() == 1 && count == 1) || count == 0) { + if ((mHeadAndEmptyEnable && getHeaderLayoutCount() == 1 && count == 1) || count == 0) { mEmptyEnable = true; count += getmEmptyViewCount(); } @@ -514,13 +514,13 @@ else if ((!mFootAndEmptyEnable || !mHeadAndEmptyEnable) && position == 1 && mFoo } } else if (mData.size() == 0 && mEmptyView != null && getItemCount() == (mHeadAndEmptyEnable ? 2 : 1) && mEmptyEnable) { return EMPTY_VIEW; - } else if (position == mData.size() + getHeaderViewsCount()) { + } else if (position == mData.size() + getHeaderLayoutCount()) { if (mNextLoadEnable) return LOADING_VIEW; else return FOOTER_VIEW; } - return getDefItemViewType(position - getHeaderViewsCount()); + return getDefItemViewType(position - getHeaderLayoutCount()); } protected int getDefItemViewType(int position) { @@ -621,7 +621,7 @@ public void onBindViewHolder(final RecyclerView.ViewHolder holder, int positions switch (viewType) { case 0: - convert((BaseViewHolder) holder, mData.get(holder.getLayoutPosition() - getHeaderViewsCount())); + convert((BaseViewHolder) holder, mData.get(holder.getLayoutPosition() - getHeaderLayoutCount())); addAnimation(holder); break; case LOADING_VIEW: @@ -634,8 +634,8 @@ public void onBindViewHolder(final RecyclerView.ViewHolder holder, int positions case FOOTER_VIEW: break; default: - convert((BaseViewHolder) holder, mData.get(holder.getLayoutPosition() - getHeaderViewsCount())); - onBindDefViewHolder((BaseViewHolder) holder, mData.get(holder.getLayoutPosition() - getHeaderViewsCount())); + convert((BaseViewHolder) holder, mData.get(holder.getLayoutPosition() - getHeaderLayoutCount())); + onBindDefViewHolder((BaseViewHolder) holder, mData.get(holder.getLayoutPosition() - getHeaderLayoutCount())); break; } @@ -652,6 +652,20 @@ protected BaseViewHolder createBaseViewHolder(ViewGroup parent, int layoutResId) return new BaseViewHolder(mContentView); } + /** + * Return root layout of header + */ + public LinearLayout getHeaderLayout() { + return mHeaderLayout; + } + + /** + * Return root layout of footer + */ + public LinearLayout getFooterLayout() { + return mFooterLayout; + } + /** * Append header to the rear of the mHeaderLayout. * @@ -673,9 +687,14 @@ public void addHeaderView(View header) { */ public void addHeaderView(View header, int index) { if (mHeaderLayout == null) { - mHeaderLayout = new LinearLayout(header.getContext()); - mHeaderLayout.setOrientation(LinearLayout.VERTICAL); - mHeaderLayout.setLayoutParams(new LayoutParams(MATCH_PARENT, WRAP_CONTENT)); + if (mCopyHeaderLayout == null) { + mHeaderLayout = new LinearLayout(header.getContext()); + mHeaderLayout.setOrientation(LinearLayout.VERTICAL); + mHeaderLayout.setLayoutParams(new LayoutParams(MATCH_PARENT, WRAP_CONTENT)); + mCopyHeaderLayout = mHeaderLayout; + } else { + mHeaderLayout = mCopyHeaderLayout; + } } index = index >= mHeaderLayout.getChildCount() ? -1 : index; mHeaderLayout.addView(header, index); @@ -704,9 +723,14 @@ public void addFooterView(View footer) { public void addFooterView(View footer, int index) { mNextLoadEnable = false; if (mFooterLayout == null) { - mFooterLayout = new LinearLayout(footer.getContext()); - mFooterLayout.setOrientation(LinearLayout.VERTICAL); - mFooterLayout.setLayoutParams(new LayoutParams(MATCH_PARENT, WRAP_CONTENT)); + if (mCopyFooterLayout == null) { + mFooterLayout = new LinearLayout(footer.getContext()); + mFooterLayout.setOrientation(LinearLayout.VERTICAL); + mFooterLayout.setLayoutParams(new LayoutParams(MATCH_PARENT, WRAP_CONTENT)); + mCopyFooterLayout = mFooterLayout; + } else { + mFooterLayout = mCopyFooterLayout; + } } index = index >= mFooterLayout.getChildCount() ? -1 : index; mFooterLayout.addView(footer, index); @@ -859,7 +883,7 @@ private void initItemClickListener(final BaseViewHolder baseViewHolder) { baseViewHolder.itemView.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { - onRecyclerViewItemClickListener.onItemClick(v, baseViewHolder.getLayoutPosition() - getHeaderViewsCount()); + onRecyclerViewItemClickListener.onItemClick(v, baseViewHolder.getLayoutPosition() - getHeaderLayoutCount()); } }); } @@ -867,7 +891,7 @@ public void onClick(View v) { baseViewHolder.itemView.setOnLongClickListener(new View.OnLongClickListener() { @Override public boolean onLongClick(View v) { - return onRecyclerViewItemLongClickListener.onItemLongClick(v, baseViewHolder.getLayoutPosition() - getHeaderViewsCount()); + return onRecyclerViewItemLongClickListener.onItemLongClick(v, baseViewHolder.getLayoutPosition() - getHeaderLayoutCount()); } }); }