美文网首页
ScrollView 嵌套 EditText抢占焦点问题

ScrollView 嵌套 EditText抢占焦点问题

作者: 吴_永健 | 来源:发表于2017-04-13 14:27 被阅读0次

    场景描述:
    ScrollView 的布局超过一个屏幕大小,其中有一个 EditText 在靠近底部的位置,这样,我们在这个 EditText 上输入内容时,向上滑动 ScrollView,由于焦点还在这个 EditText 上,所以,会出现我们向上滑动结束后,会自动下滑到这个 EditText 情况。
    解决方案:

    1. API 23 以上有 setOnScrollChangeListener() 可以调用,但是不兼容低版本,我们可以重写 ScrollView 的 computeScroll()方法,
      或者重写 View 的 onScrollChanged()方法, 设置滑动监听,来实现对滑动距离的监听。
    1. 重写 computeScroll()
    public class MyScrollView extends ScrollView {
    
        private OnScrollListener listener;
    
        /**
         * 设置滑动距离监听器
         */
        public void setOnScrollListener(OnScrollListener listener) {
            this.listener = listener;
        }
    
        public MyScrollView(Context context) {
            super(context);
        }
    
        public MyScrollView(Context context, AttributeSet attrs) {
            super(context, attrs);
        }
    
        public MyScrollView(Context context, AttributeSet attrs, int defStyleAttr) {
            super(context, attrs, defStyleAttr);
        }
    
        // 滑动距离监听器
        public interface OnScrollListener{
    
            /**
             * 在滑动的时候调用,scrollY为已滑动的距离
             */
            void onScroll(int scrollY);
        }
    
        @Override
        public void computeScroll() {
            super.computeScroll();
            if(listener!=null){
                listener.onScroll(getScrollY());
            }
        }
    }
    
    1. 重写 onScrollChanged()
    public class MyScrollView extends ScrollView {
    
        private OnScrollListener listener;
    
        public void setOnScrollListener(OnScrollListener listener) {
            this.listener = listener;
        }
    
        public MyScrollView(Context context) {
            super(context);
        }
    
        public MyScrollView(Context context, AttributeSet attrs) {
            super(context, attrs);
        }
    
        public MyScrollView(Context context, AttributeSet attrs, int defStyleAttr) {
            super(context, attrs, defStyleAttr);
        }
    
        public interface OnScrollListener{
            void onScroll(int scrollY);
        }
    
        @Override
        protected void onScrollChanged(int l, int t, int oldl, int oldt) {
            super.onScrollChanged(l, t, oldl, oldt);
            if(listener != null){
                listener.onScroll(t);
            }
        }
    }
    

    2.有了滑动监听后,需要知道什么时候清除 EditText 的焦点,我们可以在 这个 EditText 处在屏幕不可见位置时候,去清除焦点。

    Point p = new Point();
    getWindowManager().getDefaultDisplay().getSize(p);
    int screenWidth = p.x;
    int screenHeight = p.y;
    final Rect rect = new Rect(0, 0, screenWidth, screenHeight);
    int[] location = new int[2];
    edt_validate_code.getLocationInWindow(location);
    scroll_view.setOnScrollListener(new MyScrollView.OnScrollListener() {
        @Override
        public void onScroll(int scrollY) {
            if (edt_validate_code.getLocalVisibleRect(rect)) {
                // 控件在屏幕可见区域
            } else {
                // 控件已不在屏幕可见区域,清除焦点
                edt_validate_code.clearFocus();
            }
        }
    });
    

    相关文章

      网友评论

          本文标题:ScrollView 嵌套 EditText抢占焦点问题

          本文链接:https://www.haomeiwen.com/subject/ttrbattx.html