ScrollView向上滑动滑动到顶部悬停

本文介绍如何重写ScrollView以实现向上滑动时内容区域到达顶部会悬停的效果。通过创建一个MyScrollView类,监听触摸事件并处理滚动Y值,当用户手指离开屏幕时,通过Handler持续跟踪滚动位置。同时提供了简单的布局示例和MainActivity的代码,展示了如何在滚动过程中调整顶部元素的位置。
摘要由CSDN通过智能技术生成


  • 首先要重写scrollview控件
  • 主要就是对scrollview的监听
  1. /* 
  2.  * ScrollView并没有实现滚动监听,所以我们必须自行实现对ScrollView的监听, 
  3.  * 我们很自然的想到在onTouchEvent()方法中实现对滚动Y轴进行监听 
  4.  * ScrollView的滚动Y值进行监听 
  5.  */  
  6. public class MyScrollView extends ScrollView {  
  7.     private OnScrollListener onScrollListener;    
  8.     /**  
  9.      * 主要是用在用户手指离开MyScrollView,MyScrollView还在继续滑动,我们用来保存Y的距离,然后做比较  
  10.      */    
  11.     private int lastScrollY;  
  12.       
  13.     public MyScrollView(Context context) {  
  14.         super(context, null);  
  15.     }  
  16.     public MyScrollView(Context context, AttributeSet attrs) {  
  17.         super(context, attrs, 0);  
  18.     }  
  19.     public MyScrollView(Context context, AttributeSet attrs, int defStyle) {  
  20.         super(context, attrs, defStyle);  
  21.     }  
  22.     /**  
  23.      * 设置滚动接口  
  24.      * @param onScrollListener  
  25.      */  
  26.     public void setOnScrollListener(OnScrollListener onScrollListener){  
  27.         this.onScrollListener = onScrollListener;  
  28.     }  
  29.     /**  
  30.      * 用于用户手指离开MyScrollView的时候获取MyScrollView滚动的Y距离,然后回调给onScroll方法中  
  31.      */    
  32.     private Handler handler = new Handler() {    
  33.     
  34.         public void handleMessage(android.os.Message msg) {    
  35.             int scrollY = MyScrollView.this.getScrollY();    
  36.                 
  37.             //此时的距离和记录下的距离不相等,在隔5毫秒给handler发送消息    
  38.             if(lastScrollY != scrollY){    
  39.                 lastScrollY = scrollY;    
  40.                 handler.sendMessageDelayed(handler.obtainMessage(), 5);      
  41.             }    
  42.             if(onScrollListener != null){    
  43.                 onScrollListener.onScroll(scrollY);    
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值