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