Android 使用PhotoView库时未触发滑动事件

Android 使用PhotoView库时未触发滑动事件,android,Android,我想在我的应用程序中实现左右滑动,但当我使用PhotoView库时,滑动事件不会触发 如何使用PhotoView库实现刷卡操作 OnSwipeTouchListener.java 我使用SwipeEvent和PhotoView的主要活动 @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.

我想在我的应用程序中实现左右滑动,但当我使用PhotoView库时,滑动事件不会触发

如何使用PhotoView库实现刷卡操作

OnSwipeTouchListener.java

我使用SwipeEvent和PhotoView的主要活动

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    // Setup Universial Image Loader
    DisplayImageOptions defaultOptions = new DisplayImageOptions.Builder()
            .cacheInMemory(true)
            .cacheOnDisc(true)
            .build();

    ImageLoaderConfiguration config = new ImageLoaderConfiguration.Builder(getApplicationContext())
            .defaultDisplayImageOptions(defaultOptions)
            .build();
    ImageLoader.getInstance().init(config);


    imageViewComic = (ImageView) findViewById(R.id.imageViewComic);

    imageViewComic.setOnTouchListener(new OnSwipeTouchListener(this) {
        @Override
        public void onSwipeDown() {
            Toast.makeText(MainActivity.this, "Down", Toast.LENGTH_SHORT).show();
        }

        @Override
        public void onSwipeLeft() {
            Toast.makeText(MainActivity.this, "Left", Toast.LENGTH_SHORT).show();
        }

        @Override
        public void onSwipeUp() {
            Toast.makeText(MainActivity.this, "Up", Toast.LENGTH_SHORT).show();
        }

        @Override
        public void onSwipeRight() {
            Toast.makeText(MainActivity.this, "Right", Toast.LENGTH_SHORT).show();
        }
    });

    mAttacher = new PhotoViewAttacher(imageViewComic);


    // Button for loading latest comic
    btnLatestComic = (Button) findViewById(R.id.btnLoadComic);
    btnLatestComic.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View view) {
            new JSONParse().execute("http://xkcd.com/info.0.json");
        }
    });


    // Button for loading previous comic
    btnPrevComic = (Button) findViewById(R.id.btnPrevComic);
    btnPrevComic.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View view) {
           getPrevComic();
        }
    });


    // Button for loading next comic
    btnNextComic = (Button) findViewById(R.id.btnNextComic);
    btnNextComic.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View view) {
            getNextComic();
        }
    });





    SharedPreferences Sharedsettings;
    SharedPreferences.Editor editor;
    Sharedsettings = PreferenceManager.getDefaultSharedPreferences(getApplicationContext());
    boolean load_latest = Sharedsettings.getBoolean("load_latest_startup", true);

    if( load_latest == true) {
        //Load latest comic
        new JSONParse().execute("http://xkcd.com/info.0.json");
    }
    else
    {
        getLastComic();
    }


}

使用此类创建fling函数,该函数将简单地扩展SimpleGestureListener,然后使用该fling函数滑动图像。这里我使用的是ViewPager

现在为MyGestureDetector创建一个对象,并使用OnTouchListener设置手势功能

final GestureDetector gestureDetector = new GestureDetector(new MyGestureDetector());
    view_pager.setOnTouchListener(new OnTouchListener() {
        public boolean onTouch(View v, MotionEvent event) {
            return gestureDetector.onTouchEvent(event);
        }
    });
    view_pager.setOnPageChangeListener(new OnPageChangeListener() {

        public void onPageSelected(int position) {
            selectedPg = position;
        }
class MyGestureDetector extends SimpleOnGestureListener {
    @Override
    public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY) {
        try {
            if (Math.abs(e1.getY() - e2.getY()) > SWIPE_MAX_OFF_PATH)
                return false;
            // right to left swipe
            if (e1.getX() - e2.getX() > SWIPE_MIN_DISTANCE  && Math.abs(velocityX) > SWIPE_THRESHOLD_VELOCITY
                    && selectedPg == (pageCount - 1)) {
                shop_view_pager.setCurrentItem(0);
                return true;
            } else if (e2.getX() - e1.getX() > SWIPE_MIN_DISTANCE   && Math.abs(velocityX) > SWIPE_THRESHOLD_VELOCITY
                    && selectedPg == 0) {
                shop_view_pager.setCurrentItem(pageCount - 1);
                return true;
            }
        } catch (Exception e) {
            // nothing
        }
        return false;
    }
}
final GestureDetector gestureDetector = new GestureDetector(new MyGestureDetector());
    view_pager.setOnTouchListener(new OnTouchListener() {
        public boolean onTouch(View v, MotionEvent event) {
            return gestureDetector.onTouchEvent(event);
        }
    });
    view_pager.setOnPageChangeListener(new OnPageChangeListener() {

        public void onPageSelected(int position) {
            selectedPg = position;
        }