2017-06-07 54 views
0

我使用垂直viewpager,但它不像feedly android應用程序光滑我不知道feedly使用什麼組件。如何使縱向動畫像餵食安卓應用

任何幫助將不勝感激。

公共類VerticalViewPager擴展ViewPager {

public VerticalViewPager(Context context) { 
    super(context); 
    init(); 
} 

public VerticalViewPager(Context context, AttributeSet attrs) { 
    super(context, attrs); 
    init(); 
} 

private void init() { 
    // The majority of the magic happens here 
    setPageTransformer(true, new VerticalPageTransformer()); 
    // The easiest way to get rid of the overscroll drawing that happens on the left and right 
    setOverScrollMode(OVER_SCROLL_NEVER); 
} 

private class VerticalPageTransformer implements ViewPager.PageTransformer { 
    private static final float MIN_SCALE = .75f; 
    @Override 
    public void transformPage(View view, float position) { 

     if (position < -1) { // [-Infinity,-1) 
      // This page is way off-screen to the left. 
      view.setAlpha(0); 

     } else if (position <= 0) { // [-1,0] 
      // Use the default slide transition when moving to the left page 
      view.setAlpha(1); 
      // Counteract the default slide transition 
      view.setTranslationX(view.getWidth() * -position); 

      //set Y position to swipe in from top 
      float yPosition = position * view.getHeight(); 
      view.setTranslationY(yPosition); 
      view.setScaleX(1); 
      view.setScaleY(1); 

     } else if (position <= 1) { // [0,1] 
      view.setAlpha(1); 

      // Counteract the default slide transition 
      view.setTranslationX(view.getWidth() * -position); 


      // Scale the page down (between MIN_SCALE and 1) 
      float scaleFactor = MIN_SCALE 
        + (1 - MIN_SCALE) * (1 - Math.abs(position)); 
      view.setScaleX(scaleFactor); 
      view.setScaleY(scaleFactor); 

     } else { // (1,+Infinity] 
      // This page is way off-screen to the right. 
      view.setAlpha(0); 
     } 
    } 
} 


/*private class VerticalPageTransformer implements ViewPager.PageTransformer { 

    @Override 
    public void transformPage(View view, float position) { 

     if (position < -1) { // [-Infinity,-1) 
      // This page is way off-screen to the left. 
      view.setAlpha(0); 

     } else if (position <= 1) { // [-1,1] 
      view.setAlpha(1); 

      // Counteract the default slide transition 
      view.setTranslationX(view.getWidth() * -position); 

      //set Y position to swipe in from top 
      float yPosition = position * view.getHeight(); 
      view.setTranslationY(yPosition); 

     } else { // (1,+Infinity] 
      // This page is way off-screen to the right. 
      view.setAlpha(0); 
     } 
    } 
}*/ 

/** 
* Swaps the X and Y coordinates of your touch event. 
*/ 
private MotionEvent swapXY(MotionEvent ev) { 
    float width = getWidth(); 
    float height = getHeight(); 

    float newX = (ev.getY()/height) * width; 
    float newY = (ev.getX()/width) * height; 

    ev.setLocation(newX, newY); 

    return ev; 
} 

@Override 
public boolean onInterceptTouchEvent(MotionEvent ev){ 
    boolean intercepted = super.onInterceptTouchEvent(swapXY(ev)); 
    swapXY(ev); // return touch coordinates to original reference frame for any child views 
    return intercepted; 
} 

@Override 
public boolean onTouchEvent(MotionEvent ev) { 
    //return super.onTouchEvent(swapXY(ev)); 
    final boolean toHandle = super.onTouchEvent(swapXY(ev)); 
    // Return MotionEvent to normal 
    swapXY(ev); 
    return toHandle; 
} 


@Override 
public boolean canScrollVertically(int direction) { 
    return true; 
} 


@Override 
public boolean canScrollHorizontally(int direction) { 
    return false; 
} 

}

+1

一些代碼添加到你的問題具有u實現自定義視圖尋呼機如果是,那麼將代碼粘貼 –

+0

機會,你在UI線程 – lelloman

+0

歡迎StackOverflow上做太多的計算。請說明你的努力到目前爲止你做了什麼。 –

回答

0

我認爲你必須去與這個環節,我想在你的XML兩個渦旋函數調用,這就是爲什麼它給人的問題。

https://stackoverflow.com/questions/14326317/view-pager-not-smooth-when-embedded-within-scrollview 
+0

我沒有使用scrollview。 Viewpager只是在直線垂直滑動 –