0

Я строю приложение для Android, подобное находкам. Я хочу, чтобы мой карточек вверх и вниз. То, что я делаю еще - я анализирую данные с сервера с помощью webAPI, а затем используя отображение BaseAdapter в cardView. Но теперь мне нужно прокрутить вверх, чтобы он двигался вверх, и должна отображаться следующая карта положения.Как сделать cardView скользить вверх и вниз анимации в Android?

ответ

0

Один из способов сделать это с помощью fragments и ViewPager для загрузки страниц, и вы можете указать свойство анимации анимировать фрагменты.

Если вы новичок в фрагментах, попробуйте начиная с here

И тогда вам нужно ViewPager красть между страницами. here

Недвижимость Анимация часто используется для анимации собственных фрагментов (Android.App.Fragment). see this и увидеть это swap fragments using Animation

1

Вы можете сделать это с ViewPager и Фрагменты, то вам необходимо поместить слайд-анимации с видом на пейджере. Для горизонтального слайда вы можете увидеть ссылки разработчиков http://developer.android.com/training/animation/screen-slide.html.

После этого вам нужно изменить вид пейджера немного так, что он ведет себя как по вертикали, а по горизонтали, и вы можете добиться этого с кодом ниже:

public class VerticalViewPager extends 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 = 0.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); 
     } 

    } 

} 

/** 
* 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)); 
} 
}