Quickly-Return实现思路小结:
1、通过View.getViewTreeObserver().addOnGlobalLayoutListener()的回调方法onGlobalLayout()计算出ListView每个Item项的高度和ListView“全部显示时”的高度;
1.1、“全部显示时”即:
public void computeScrollY() {
mHeight = 0;
mItemCount = getAdapter().getCount();
if (mItemOffsetY == null) {
mItemOffsetY = new int[mItemCount];
}
for (int i = 0; i < mItemCount; ++i) {
View view = getAdapter().getView(i, null, this);
view.measure(
MeasureSpec.makeMeasureSpec(0, MeasureSpec.UNSPECIFIED),
MeasureSpec.makeMeasureSpec(0, MeasureSpec.UNSPECIFIED));
mItemOffsetY[i] = mHeight;
mHeight += view.getMeasuredHeight();
System.out.println(mHeight);
}
scrollIsComputed = true;
}对应的mHeight的高度,它和ListView.getHeight是不同的。
2、通过监听ListView.setOnScrollListener(),在回调方法onScroll()中,判定当前滑动的位移方向及所处位置,并以此控制“QuicklyView”的位置。
2.1、一种可以借鉴的 实现“控制“QuicklyView”的位置”的手段-----------“通过移动动画(setFillAfter(true))控制位置”
细节:
//计算当前ListView“最顶部显示的Item”距离“QuicklyView”顶部的长度,
//由于“QuicklyView”实际是HeaderView,
//即可理解为“计算当前ListView “最顶部显示的Item” 距离 第一个子View顶部的长度”
public int getComputedScrollY() {
int pos, nScrollY, nItemY;
View view = null;
pos = getFirstVisiblePosition();
view = getChildAt(0);
nItemY = view.getTop();
nScrollY = mItemOffsetY[pos] - nItemY;
return nScrollY;
1、通过View.getViewTreeObserver().addOnGlobalLayoutListener()的回调方法onGlobalLayout()计算出ListView每个Item项的高度和ListView“全部显示时”的高度;
1.1、“全部显示时”即:
public void computeScrollY() {
mHeight = 0;
mItemCount = getAdapter().getCount();
if (mItemOffsetY == null) {
mItemOffsetY = new int[mItemCount];
}
for (int i = 0; i < mItemCount; ++i) {
View view = getAdapter().getView(i, null, this);
view.measure(
MeasureSpec.makeMeasureSpec(0, MeasureSpec.UNSPECIFIED),
MeasureSpec.makeMeasureSpec(0, MeasureSpec.UNSPECIFIED));
mItemOffsetY[i] = mHeight;
mHeight += view.getMeasuredHeight();
System.out.println(mHeight);
}
scrollIsComputed = true;
}对应的mHeight的高度,它和ListView.getHeight是不同的。
2、通过监听ListView.setOnScrollListener(),在回调方法onScroll()中,判定当前滑动的位移方向及所处位置,并以此控制“QuicklyView”的位置。
2.1、一种可以借鉴的 实现“控制“QuicklyView”的位置”的手段-----------“通过移动动画(setFillAfter(true))控制位置”
细节:
//计算当前ListView“最顶部显示的Item”距离“QuicklyView”顶部的长度,
//由于“QuicklyView”实际是HeaderView,
//即可理解为“计算当前ListView “最顶部显示的Item” 距离 第一个子View顶部的长度”
public int getComputedScrollY() {
int pos, nScrollY, nItemY;
View view = null;
pos = getFirstVisiblePosition();
view = getChildAt(0);
nItemY = view.getTop();
nScrollY = mItemOffsetY[pos] - nItemY;
return nScrollY;
}
参考:https://github.com/LarsWerkman/QuickReturnListView
https://github.com/ManuelPeinado/QuickReturnHeader
两个项目的实现手段,均为上面描述的原理,不同点只是控制“QuicklyView”位置的逻辑上存在不同,以及实现框架上有些差异。