我使用了ViewPager
进行图像滑动,我需要查看具有缩放选项的图像,图像被放大,但在缩放图像时分页会中断。尝试过onTouchEvent()
和OnInterceptTouchEvent()
。禁用和启用ViewPager
会导致强制关闭。
我使用了ViewPager
进行图像滑动,我需要查看具有缩放选项的图像,图像被放大,但在缩放图像时分页会中断。尝试过onTouchEvent()
和OnInterceptTouchEvent()
。禁用和启用ViewPager
会导致强制关闭。
继承 ViewPager
并覆盖 canScroll()
方法。你将会获得检测到触摸事件的小部件,如果你想要滚动事件传递给该小部件,可以返回 true
,如果你想要 ViewPager
使用该滚动量,则返回 false
。在你的情况下,当你处于缩放状态时,你可以采用自己的定制逻辑,并在没有缩放时链接到超类。
ViewPager
子类只有十几行代码,使用库似乎过于浪费。更糟糕的是,库不会事先知道需要缩放的内容,因此我甚至不知道如何实现这样的库。 - CommonsWarepublic 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);
pager.setPagingEnabled(boolean);
进行设置。 - Spring Breaker @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;
}