ViewPager amp; ImageView zooming issue(ViewPager amp;ImageView 缩放问题)
问题描述
我正在尝试使用 ViewPager 实现图像库.此外,为了实现缩放功能,我正在使用来自 github 的 TouchImageView.我也尝试过使用 ZoomableImageView.
I am trying to implement a Gallery of images using ViewPager. Also, to implement zoom feature in that, I am using TouchImageView from github. I have also tried using ZoomableImageView.
但是,问题是,如果我缩放图像 &如果我滚动图像,那么 ViewPager
会滚动而不是图像ViewPager
的下一个视图正在加载.
But, the problem is, if I zoom the image & if I scroll the image , then instead of image, ViewPager
is getting scrolled & next view of ViewPager
is getting loaded.
如果我缩放图像然后如果我滚动它,那么图像必须移动而不是 ViewPager
If I zoom the image then if I scroll that, then image has to move instead of ViewPager
ViewPager 的下一个视图只有在到达缩放图像的末尾时才需要加载.该怎么做?
ViewPager's next view has to load only if reach the end of the zoomed image. How to do that?
我找不到那个.如果我触摸 &对角拖动图像,然后图像才会移动.否则 ViewPager 的拖动被调用.
I am not able to find that.If I touch & drag the image diagonally, only then image is getting moved. or else ViewPager's drag is getting invoked.
ps:这不是重复的.缩放完成.但问题是在图像缩放之后.
ps: this is not duplicate. Zooming is done. But the problem is after image zooming.
推荐答案
是的,我也有同样的问题,不是 TouchImageView.
Yes I too had the same problem not with TouchImageView.
解决了当我的视图获得焦点时禁用 ViewPager 的问题.
Too solved the problem what i did is disabled the ViewPager when my view is getting the focus.
public class EnableDisableViewPager extends ViewPager {
private boolean enabled = true;
public EnableDisableViewPager(Context context, AttributeSet attrs) {
super(context, attrs);
}
@Override
public boolean onInterceptTouchEvent(MotionEvent arg0) {
if(enabled)
return super.onInterceptTouchEvent(arg0);
return false;
}
public boolean isEnabled() {
return enabled;
}
public void setEnabled(boolean enabled) {
this.enabled = enabled;
}
}
所以在 TouchImageView 中实现你的监听器来触发一个事件,无论是缩放还是拖动.
so in TouchImageView implement your listener to trigger an event whether its zooming or dragging.
在您的 Activity 中为您的视图对象设置监听器.因此,当这些事件发生时,只需禁用视图寻呼机.
set listener to your view object in your Activity. So when those event occur just disable the view Pager.
注意:您还需要一个鼠标向上事件来启用 viewpager.
Note: you will also need a mouse up event to enable the viewpager.
已编辑
这仅适用于缩放,因此要让 ViewPager 滑动页面,您应该缩放回原始页面.
This will work only for Zoom, so for ViewPager to swipe pages you should zoom back to original.
将这些代码添加到您的 TouchImageView
Add these code to your TouchImageView
public class TouchImageView extends ImageView {
...
private TouchEventListener touchEventListener;
private void sharedConstructing(Context context) {
...
setOnTouchListener(new OnTouchListener() {
@Override
public boolean onTouch(View v, MotionEvent event) {
...
case MotionEvent.ACTION_UP:
...
if(touchEventListener != null)
{
if(saveScale == 1.0)
touchEventListener.onZoomToOriginal();
else
touchEventListener.onZoom();
}
break;
...
}
...
}
});
}
...
public TouchEventListener getTouchEventListener() {
return touchEventListener;
}
public void setTouchEventListener(TouchEventListener touchEventListener) {
this.touchEventListener = touchEventListener;
}
public interface TouchEventListener
{
void onZoom();
void onZoomToOriginal();
}
}
更好的解决方案
我们可以通过使用下面给出的方法,在不将 ViewPager 扩展到新类的情况下实现这一点.
We could achieve this without extending ViewPager to a new Class by using the method given below.
requestDisallowInterceptTouchEvent(true);
有了这个,我们可以在不缩小到原始位置的情况下滑动,就像我们在图库和许多其他应用程序中看到的那样.
And with this we could swipe without zooming out to original position as we see in Gallery and many other apps.
public class TouchImageView extends ImageView {
...
private void stopInterceptEvent()
{
getParent().requestDisallowInterceptTouchEvent(true);
}
private void startInterceptEvent()
{
getParent().requestDisallowInterceptTouchEvent(false);
}
private void sharedConstructing(Context context) {
super.setClickable(true);
this.context = context;
mScaleDetector = new ScaleGestureDetector(context, new ScaleListener());
matrix.setTranslate(1f, 1f);
m = new float[9];
setImageMatrix(matrix);
setScaleType(ScaleType.MATRIX);
setOnTouchListener(new OnTouchListener() {
@Override
public boolean onTouch(View v, MotionEvent event) {
mScaleDetector.onTouchEvent(event);
matrix.getValues(m);
float x = m[Matrix.MTRANS_X];
float y = m[Matrix.MTRANS_Y];
PointF curr = new PointF(event.getX(), event.getY());
switch (event.getAction()) {
case MotionEvent.ACTION_DOWN:
last.set(event.getX(), event.getY());
start.set(last);
mode = DRAG;
stopInterceptEvent();
break;
case MotionEvent.ACTION_MOVE:
if (mode == DRAG) {
float deltaX = curr.x - last.x;
float deltaY = curr.y - last.y;
float scaleWidth = Math.round(origWidth * saveScale);
float scaleHeight = Math.round(origHeight * saveScale);
if (scaleWidth < width) {
deltaX = 0;
if (y + deltaY > 0)
deltaY = -y;
else if (y + deltaY < -bottom)
deltaY = -(y + bottom);
} else if (scaleHeight < height) {
deltaY = 0;
if (x + deltaX > 0)
deltaX = -x;
else if (x + deltaX < -right)
deltaX = -(x + right);
} else {
if (x + deltaX > 0)
deltaX = -x;
else if (x + deltaX < -right)
deltaX = -(x + right);
if (y + deltaY > 0)
deltaY = -y;
else if (y + deltaY < -bottom)
deltaY = -(y + bottom);
}
if(deltaX == 0)
startInterceptEvent();
else
stopInterceptEvent();
matrix.postTranslate(deltaX, deltaY);
last.set(curr.x, curr.y);
}
break;
case MotionEvent.ACTION_UP:
mode = NONE;
int xDiff = (int) Math.abs(curr.x - start.x);
int yDiff = (int) Math.abs(curr.y - start.y);
if (xDiff < CLICK && yDiff < CLICK)
performClick();
startInterceptEvent();
break;
case MotionEvent.ACTION_POINTER_UP:
mode = NONE;
break;
}
setImageMatrix(matrix);
invalidate();
return true; // indicate event was handled
}
});
}
}
这篇关于ViewPager &ImageView 缩放问题的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:ViewPager &ImageView 缩放问题


基础教程推荐
- 在 iOS 上默认是 char 签名还是 unsigned? 2022-01-01
- 使用 Ryzen 处理器同时运行 WSL2 和 Android Studio 2022-01-01
- :hover 状态不会在 iOS 上结束 2022-01-01
- Android ViewPager:在 ViewPager 中更新屏幕外但缓存的片段 2022-01-01
- 如何使用 YouTube API V3? 2022-01-01
- 如何使 UINavigationBar 背景透明? 2022-01-01
- “让"到底是怎么回事?关键字在 Swift 中的作用? 2022-01-01
- LocationClient 与 LocationManager 2022-01-01
- 固定小数的Android Money Input 2022-01-01
- Android文本颜色不会改变颜色 2022-01-01