在ViewPager上,在onPageSelected上的片段上启动动画

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了在ViewPager上,在onPageSelected上的片段上启动动画相关的知识,希望对你有一定的参考价值。

我有一个带有FragmentPagerAdapter的ViewPager。当显示片段时,我希望它开始动画(淡入片段中的视图)。

但是,动画运行不一致,当我向左/向右滑动时,它会在每几页上运行。我想我需要在onPageSelected事件上启动动画,但我无法弄清楚如何获取片段并启动动画。

我的代码如下。 TourFragment是我使用FragmentPageAdapter添加到ViewPager的片段,而TourActivty包含ViewPager。

TourFragment

public class TourFragment extends Fragment  {

    Tour tour;
    ImageView ivTitle;

@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
        Bundle savedInstanceState) {

    View v = inflater.inflate(R.layout.fragment_tour,
            container, false);

    RelativeLayout rlImageContainer = (RelativeLayout) v.findViewById(R.id.tour_image_container);

    Resources resources = getActivity().getResources();

    ivTitle = (ImageView) v.findViewById(R.id.tour_title);
    ivTitle.setImageDrawable(resources.getDrawable(tour.getDrawableTitleId()));

    Animation fadeInAnimation = AnimationUtils.loadAnimation(getActivity(), R.anim.fadein);
    ivTitle.startAnimation(fadeInAnimation );

    return v;
}

@Override
public void onResume() {
    super.onResume();
    Animation fadeInAnimation = AnimationUtils.loadAnimation(getActivity(), R.anim.fadein);
    ivTitle.startAnimation(fadeInAnimation );
}



public static Fragment newInstance(Tour tour) {

    TourFragment f = new TourFragment();
    f.tour = tour;
    return f;
}
}

TourActivity

public class TourActivity extends FragmentActivity {

MyPageAdapter pageAdapter;
String tourType;
Drawable drawableSelected;
Drawable drawableNotSelected;
LinearLayout llIndicators;
int prevPagePosition = 0;

@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_tour);

    List<Fragment> fragments = getFragments();
    pageAdapter = new MyPageAdapter(getSupportFragmentManager(), fragments);
    ViewPager pager = (ViewPager) findViewById(R.id.viewpager);
    pager.setAdapter(pageAdapter);

    pager.setOnPageChangeListener(new ViewPager.OnPageChangeListener() {
        @Override
        public void onPageScrolled(int i, float v, int i2) {

        }

        @Override
        public void onPageSelected(int position) {

        }

        @Override
        public void onPageScrollStateChanged(int i) {

        }
        });
    }

    private List<Fragment> getFragments(){
    List<Fragment> fList = new ArrayList<Fragment>();

    List<Tour> tours = new ArrayList<Tour>();

        messages = getResources().getStringArray(R.array.guess_tour_messages);
        Tour tour = new Tour();
        tour.setDrawableImageId(R.drawable.tu_guest_image_1);
        tour.setDrawableTitleId(R.drawable.tu_guest_text_1);
        tour.setMessage(messages[0]);
        tour.setPageIndex(0);
        tour.setTotalPages(messages.length);
        tours.add(tour);

        tour = new Tour();
        tour.setDrawableImageId(R.drawable.tu_guest_image_2);
        tour.setDrawableTitleId(R.drawable.tu_guest_text_2);
        tour.setMessage(messages[1]);
        tour.setPageIndex(1);
        tour.setTotalPages(messages.length);
        tours.add(tour);

        tour = new Tour();
        tour.setDrawableImageId(R.drawable.tu_guest_image_3);
        tour.setDrawableTitleId(R.drawable.tu_guest_text_3);
        tour.setMessage(messages[2]);
        tour.setPageIndex(2);
        tour.setTotalPages(messages.length);
        tours.add(tour);

        tour = new Tour();
        tour.setDrawableImageId(R.drawable.tu_guest_image_4);
        tour.setDrawableTitleId(R.drawable.tu_guest_text_4);
        tour.setMessage(messages[3]);
        tour.setPageIndex(3);
        tour.setTotalPages(messages.length);
        tours.add(tour);


    for (Tour tour : tours) {
        fList.add(TourFragment.newInstance(tour));
    }


    return fList;
}

}

class MyPageAdapter extends FragmentPagerAdapter {
private List<Fragment> fragments;

public MyPageAdapter(FragmentManager fm, List<Fragment> fragments) {
    super(fm);
    this.fragments = fragments;
}

@Override
public Fragment getItem(int position) {
    return this.fragments.get(position);
}

@Override
public int getCount() {
    return this.fragments.size();
}
}
答案

你应该在你的片段中使用

@Override
public void setUserVisibleHint(boolean isVisibleToUser) {
    super.setUserVisibleHint(isVisibleToUser);
    if (isVisibleToUser) { 
        Log.v(TAG, "run now");
            Animation animationFadeIn = AnimationUtils.loadAnimation(getActivity(), R.anim.fade_view);
            iv.startAnimation(animationFadeIn);
            animationFadeIn.setFillAfter(true);
    }
    else {  }
}
另一答案

我想到了。

在onPageSelected上,我使用片段中的getView来获取我想要动画的视图。

    pager.setOnPageChangeListener(new ViewPager.OnPageChangeListener() {
        @Override
        public void onPageScrolled(int i, float v, int i2) {

        }

        @Override
        public void onPageSelected(int position) {

            View v = pageAdapter.getItem(position).getView();

            ImageView ivTitle = (ImageView) v.findViewById(R.id.tour_title);

            Animation fadeInAnimation = AnimationUtils.loadAnimation(TourActivity.this, R.anim.fadein);
            ivTitle.startAnimation(fadeInAnimation );
        }

        @Override
        public void onPageScrollStateChanged(int i) {

        }
    });
另一答案

在你的FragmentPagerAdapter实现中,你需要覆盖public Object instantiateItem(viewGroup container, int index)。在基类中,只有在首次创建适配器时才会使用FragmentManager实例添加片段。每当您离开屏幕时,屏幕外的碎片都会分离但不会被移除。 FragmentManager使用对象上的标记缓存实例。然后在他们被分页时将它们附加。 instantiateItem项目的默认实现使用硬编码标签在Fragment内部标记每个FragmentAdapter。您需要使用唯一标记标记您使用的每个Fragment。有了这个地方,您可以使用FragmentManager从应用程序中的任何public abstract Fragment findFragmentByTag (String tag)实例中检索片段实例。

String[] tags = {"tag1", "tag2", "tag3", "tag4", "tag5"};

@Override
public Object instantiateItem(ViewGroup container, int index) {
    FragmentTransaction ft = fm.beginTransaction();

    Fragment fragment = fm.findFragmentByTag(tags[index]);
    if (fragment == null) {
        fragment = getItem(index);
        ft.add(container.getId(), fragment, mTags[index]);
    }
    else {
        ft.attach(fragment);
    }

    ft.commit();

    return fragment;
}

public String getTag(int index) {
    return mTags[index];
}

您现在应该能够访问onPageSelected中的实例。

另一答案

我有一个类似的问题,在这里解决了它:Animation of nested fragment within ViewPager fragment is triggered before render

在您的情况下,相同的解决方案将如下所示:

Java的:

v.post(new Runnable() {
  @Override
  public void run() {
    ivTitle.startAnimation(fadeInAnimation)
  }
})

科特林:

v.post(Runnable {
  ivTitle.startAnimation(fadeInAnimation)
})

它确保确实绘制了视图

以上是关于在ViewPager上,在onPageSelected上的片段上启动动画的主要内容,如果未能解决你的问题,请参考以下文章

如何从 ViewPager 的 onPageSelected AsyncTask 到 Fragments?

改变方向调用 onpageselected 在 oncreateview 之前

FragmentStatePagerAdapter onPageSelected事件

不正确地工作viewPager

android ViewPager滑动事件讲解

Fragment在ViewPager里面的可见、隐藏