之前看过一些文章,大多都是在ScrollView的头部加入布局和在底部加入布局,我这个呢,我比较懒,就没有写头部布局和尾部布局,就只是添加了两个方法,不过还是可以实现刷新的,但是刷新的时候需要显示的布局就得自己重新写了,比较简单哈,勿喷哦!
/判断是否滑动到顶部/
public class ResechScrollView extends ScrollView {
private boolean IsScrollToStart = false;
/判断是否滑动到顶部/
private boolean IsScrollToEnd=false;
/判断是否滑动到底部/
private final static int SCROLL_START=100;
private final static int SCROLL_END=200;
private Handler handler=new Handler(){
@Override
public void handleMessage(Message msg) {
super.handleMessage(msg);
switch (msg.what){
case SCROLL_START:
IsScrollToStart=false;
break;
case SCROLL_END:
IsScrollToEnd=false;
break;
}
}
};
private OnScrollChangeListener mOnScrollChangeListener;
public ResechScrollView(Context context) {
super(context);
}
public ResechScrollView(Context context, AttributeSet attrs) {
super(context, attrs);
}
public ResechScrollView(Context context, AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
}
@Override
protected void onScrollChanged(int l, int t, int oldl, int oldt) {
super.onScrollChanged(l, t, oldl, oldt);
if (mOnScrollChangeListener!=null){
if (getScrollY()==0){
/优化反复调用/
if (!IsScrollToStart) {
IsScrollToStart = true;
mOnScrollChangeListener.OnScrollToStart();
handler.sendEmptyMessage(100);
}
}else {
View contentView=getChildAt(0);
if (contentView != null && contentView.getMeasuredHeight() == (getScrollY() + getHeight())) {
//滚动到底部,ScrollView存在回弹效果效应
//优化,只过滤第一次
if (!IsScrollToEnd) {
IsScrollToEnd = true;
handler.sendEmptyMessage(200);
mOnScrollChangeListener.OnScrollToEnd();
}
}
}
}
}
public interface OnScrollChangeListener{
void OnScrollToStart();
void OnScrollToEnd();
}
public void setmOnScrollChangeListener(OnScrollChangeListener mOnScrollChangeListener) {
this.mOnScrollChangeListener = mOnScrollChangeListener;
}}