要实现的效果是:上下滑动 ScrollView ,松手时其回到一个固定的位置,
参考了很多资料以及编码调试,终于研究出来了~~ 与大家分享:
—————————————— 事件处理代码 ——————————————
在触摸监听事件中,设立对onKeyUp的监听,在手指离开屏幕后用
handler.sendMessageDelayed(
handler.obtainMessage(TOUCH_EVENT_ID,scroller), 5);
每隔5毫秒getScrollY()一次,然后比较getScrollY()的值,
直到与上次得到的相等时,就是scrollview停止滑动了。
代码如下:
mScrollView.setOnTouchListener(new OnTouchListener() {
private int lastY = 0;
private static final int TOUCH_EVENT_ID = 1;
@Override
public boolean onTouch(View v, MotionEvent event) {
// TODO Auto-generated method stub
if(event.getAction() == MotionEvent.ACTION_UP) {//触摸松手时
handler.sendMessageDelayed(handler.obtainMessage(TOUCH_EVENT_ID,v), 5);
}
return false;
}
Handler handler = new Handler() {
@Override
public void handleMessage(Message msg) {
super.handleMessage(msg);
View scroller = (View)msg.obj;
if(msg.what==TOUCH_EVENT_ID) {
if(lastY ==scroller.getScrollY()) {
handleStop(scroller);//调用停止时处理方法
}else {
handler.sendMessageDelayed(
handler.obtainMessage(TOUCH_EVENT_ID,scroller), 5);
lastY = scroller.getScrollY();
}
}
}
};
//这里写真正的事件
private void handleStop(Object view) {//滑动停止时要进行的处理
ScrollView scroller = (ScrollView) view;
scroller.scrollTo(0, mScrollOffset);
}
});
———————————————— 关于布局 ————————————————————
若ScrollView内包围的东西没超出一屏时,是不会滚动的,所以要弄些添补组件使整个界面超出一屏,比如以下边红色的 TextView 作添充,可以这样做:
<ScrollView
android:id="@+id/scrollView"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
>
<LinearLayout
android:id="@+id/linearLayout"
android:orientation="vertical"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:gravity="center_horizontal">
<TextView
android:layout_width="fill_parent"
android:layout_height="70dp"
/>
<ImageView
android:layout_width="wrap_content"
android:layout_height="240dp"
android:scaleType="matrix"
android:src="@drawable/tip"
/>
<TextView
android:id="@+id/conversation_emptyImageView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/tip"
/>
<TextView
android:layout_width="fill_parent"
android:layout_height="160dp"
/>
</LinearLayout>
</ScrollView>