如何将手势检测器添加到 ViewPager
How to add gesture detector to a ViewPager
我想做的事情:
图像可以通过 viewpager 滑动,但人们可以通过手势检测器放大或缩小。
问题:
我可以使用 viewpager 滑动图像,但不知道如何在我的 Viewpager 中添加手势检测器。
代码:
Activity:
public class ImageSlider extends AppCompatActivity {
private ViewPager viewPager;
CustomSwipeAdpater customSwipeAdpater;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_image_slider);
viewPager = (ViewPager) findViewById(R.id.pager);
customSwipeAdpater = new CustomSwipeAdpater(this);
viewPager.setAdapter(customSwipeAdpater);
}
}
PagerAdpater:
public class CustomSwipeAdpater extends PagerAdapter {
private int[] image_resources = {R.drawable.wall,R.drawable.welcome};
private Context context;
private LayoutInflater inflater;
private Animator mCurrentAnimator;
private ImageView imageView;
public CustomSwipeAdpater(Context context){
this.context = context;
}
@Override
public int getCount() {
return image_resources.length;
}
@Override
public boolean isViewFromObject(View view, Object object) {
return (view == (RelativeLayout)object);
}
@Override
public Object instantiateItem(ViewGroup container, final int position) {
inflater = (LayoutInflater)context.getSystemService(context.LAYOUT_INFLATER_SERVICE);
View item_view = inflater.inflate(R.layout. swipe_layout,container,false);
imageView = (ImageView) item_view.findViewById(R.id.ivSliderImage);
TextView textView = (TextView) item_view.findViewById(R.id.tvSliderImageText);
imageView.setImageResource(image_resources[position]);
textView.setText("Image:" + position);
container.addView(item_view);
imageView.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
}
});
return item_view;
}
@Override
public void destroyItem(ViewGroup container, int position, Object object) {
container.removeView((RelativeLayout) object);
}
}
如何在此代码中添加手势检测器?
Photoview 图书馆做你想做的事它也支持旋转。
创建 touchAttacher 并将您的图像传递给它,然后就完成了。
这是 PhotoViewAttacher 代码的一部分,它完全符合您的要求:
public PhotoViewAttacher(ImageView imageView, boolean zoomable) {
mImageView = new WeakReference<>(imageView);
imageView.setDrawingCacheEnabled(true);
imageView.setOnTouchListener(this);
ViewTreeObserver observer = imageView.getViewTreeObserver();
if (null != observer)
observer.addOnGlobalLayoutListener(this);
// Make sure we using MATRIX Scale Type
setImageViewScaleTypeMatrix(imageView);
if (imageView.isInEditMode()) {
return;
}
// Create Gesture Detectors...
mScaleDragDetector = VersionedGestureDetector.newInstance(
imageView.getContext(), this);
mGestureDetector = new GestureDetector(imageView.getContext(),
new GestureDetector.SimpleOnGestureListener() {
// forward long click listener
@Override
public void onLongPress(MotionEvent e) {
if (null != mLongClickListener) {
mLongClickListener.onLongClick(getImageView());
}
}
});
mGestureDetector.setOnDoubleTapListener(new DefaultOnDoubleTapListener(this));
// Finally, update the UI so that we're zoomable
setZoomable(zoomable);
}
我想做的事情:
图像可以通过 viewpager 滑动,但人们可以通过手势检测器放大或缩小。
问题:
我可以使用 viewpager 滑动图像,但不知道如何在我的 Viewpager 中添加手势检测器。
代码:
Activity:
public class ImageSlider extends AppCompatActivity {
private ViewPager viewPager;
CustomSwipeAdpater customSwipeAdpater;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_image_slider);
viewPager = (ViewPager) findViewById(R.id.pager);
customSwipeAdpater = new CustomSwipeAdpater(this);
viewPager.setAdapter(customSwipeAdpater);
}
}
PagerAdpater:
public class CustomSwipeAdpater extends PagerAdapter {
private int[] image_resources = {R.drawable.wall,R.drawable.welcome};
private Context context;
private LayoutInflater inflater;
private Animator mCurrentAnimator;
private ImageView imageView;
public CustomSwipeAdpater(Context context){
this.context = context;
}
@Override
public int getCount() {
return image_resources.length;
}
@Override
public boolean isViewFromObject(View view, Object object) {
return (view == (RelativeLayout)object);
}
@Override
public Object instantiateItem(ViewGroup container, final int position) {
inflater = (LayoutInflater)context.getSystemService(context.LAYOUT_INFLATER_SERVICE);
View item_view = inflater.inflate(R.layout. swipe_layout,container,false);
imageView = (ImageView) item_view.findViewById(R.id.ivSliderImage);
TextView textView = (TextView) item_view.findViewById(R.id.tvSliderImageText);
imageView.setImageResource(image_resources[position]);
textView.setText("Image:" + position);
container.addView(item_view);
imageView.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
}
});
return item_view;
}
@Override
public void destroyItem(ViewGroup container, int position, Object object) {
container.removeView((RelativeLayout) object);
}
}
如何在此代码中添加手势检测器?
Photoview 图书馆做你想做的事它也支持旋转。 创建 touchAttacher 并将您的图像传递给它,然后就完成了。
这是 PhotoViewAttacher 代码的一部分,它完全符合您的要求:
public PhotoViewAttacher(ImageView imageView, boolean zoomable) {
mImageView = new WeakReference<>(imageView);
imageView.setDrawingCacheEnabled(true);
imageView.setOnTouchListener(this);
ViewTreeObserver observer = imageView.getViewTreeObserver();
if (null != observer)
observer.addOnGlobalLayoutListener(this);
// Make sure we using MATRIX Scale Type
setImageViewScaleTypeMatrix(imageView);
if (imageView.isInEditMode()) {
return;
}
// Create Gesture Detectors...
mScaleDragDetector = VersionedGestureDetector.newInstance(
imageView.getContext(), this);
mGestureDetector = new GestureDetector(imageView.getContext(),
new GestureDetector.SimpleOnGestureListener() {
// forward long click listener
@Override
public void onLongPress(MotionEvent e) {
if (null != mLongClickListener) {
mLongClickListener.onLongClick(getImageView());
}
}
});
mGestureDetector.setOnDoubleTapListener(new DefaultOnDoubleTapListener(this));
// Finally, update the UI so that we're zoomable
setZoomable(zoomable);
}