在缩放ImageView时禁用ViewPager中的分页

时间:2013-09-16 11:57:19

标签: android android-viewpager android-imageview

我使用ViewPager进行图像滑动,我需要使用缩放选项查看图像,图像会变焦但分页会在缩放图像时中断。已尝试onTouchEvent()和{{1} }。禁用和启用OnInterceptTouchEvent()会导致强制关闭。

4 个答案:

答案 0 :(得分:2)

子类ViewPager并覆盖canScroll()。您将通过检测到触摸事件的小部件,如果您希望滚动事件传递到该小部件,则可以返回true;如果希望false,则可以ViewPager返回{{1}}使用滚动量。在您的情况下,当您进行缩放时,您将使用自己的自定义逻辑,并在未缩放时直接链接到超类。

答案 1 :(得分:1)

我也遇到了同样的问题,我做了以下事情来解决这个问题。我使用了一个自定义的ViewPager类。

CustomViewPager .java

public class CustomViewPager extends ViewPager {

    private boolean isPagingEnabled;

    public CustomViewPager(Context context, AttributeSet attrs) {
        super(context, attrs);
        this.isPagingEnabled = true;
    }

    @Override
    public boolean onTouchEvent(MotionEvent event) {
        if (this.isPagingEnabled) {
            return super.onTouchEvent(event);
        }

        return false;
    }

    @Override
    public boolean onInterceptTouchEvent(MotionEvent event) {
        if (this.isPagingEnabled) {
            return super.onInterceptTouchEvent(event);
        }

        return false;
    }

    public void setPagingEnabled(boolean b) {
        this.isPagingEnabled = b;
    }
}

并禁用滚动使用以下代码段

CustomViewPager pager = (CustomViewPager) findViewById(R.id.pager);
pager.setPagingEnabled(false);

如果您需要更多信息,那么您可以询问。希望它有所帮助。

答案 2 :(得分:1)

我知道这些问题已经过时但是对于寻找答案的其他人Mike Ortiz TouchImageView开箱即用,(您可能需要切换到开发分支)

答案 3 :(得分:0)

我通过以下方式完成此操作,它将在用户缩放时禁用分页,但当他到达缩放的imageview的边缘时,它将正确地分页到下一个/上一个图像。

 @Override 
        public boolean onTouchEvent(MotionEvent ev) {
            if(handleTouch(ev)) {
                return super.onTouchEvent(ev);
            }
            else {
                return false;
            }

        }

        @Override 
        public boolean onInterceptTouchEvent(MotionEvent ev) {
            if(handleTouch(ev) && !areCommentsOpen()) {
                return super.onInterceptTouchEvent(ev);
            }
            else {
                return false;
            }
        }

        private boolean handleTouch(MotionEvent ev) {
            if (prevX != -666 && ev.getAction() == MotionEvent.ACTION_MOVE) {
                if(ev.getX() <= prevX) {
                    isGoingLeft=false;
                }
                else {
                    isGoingLeft=true;
                }
            }
            else if (ev.getAction() == MotionEvent.ACTION_UP || ev.getAction() == MotionEvent.ACTION_CANCEL) {
                return true;
            }

            ZoomableImageView imageView = getImageView();
            if(imageView == null) {
                return true;
            }
            prevX=ev.getX();
            if(imageView.getZoomLevel() <= 1f) {
                return true;
            }

            else if(imageView.isBoundedLeft()) {
                if(isTransitioning) {
                    return true;
                }
                else if (isGoingLeft) {
                    isTransitioning = true;
                    return true;
                }
                else {
                    return false;
                }
            }

            else if (imageView.isBoundedRight()) {
                if(isTransitioning) {
                    return true;
                }
                else if (!isGoingLeft) {
                    isTransitioning = true;
                    return true;
                }
                else {
                    return false;
                }
            }

            else {
                isTransitioning = false;
                return false;
            }
        }

private ZoomableImageView getImageView() {
        for (int i = 0; i < getChildCount(); i++) {
            ZoomableImageView imageView = (ZoomableImageView) (getChildAt(i).findViewById(R.id.single_image_view));
            if(imageView.getPosition() == getCurrentItem()) {
                return imageView;
            }
        }
        return null;
    }

    public void setTransitioning(boolean trans) {
        this.isTransitioning = trans;
    }

    public void setGoingLeft(boolean left) {
        this.isGoingLeft = left;
    }