PagerAdapter 在滑动时更改 TextView

PagerAdapter change TextView when swiping

我正在使用 PagerAdapter 滑动浏览几个 ImageView,效果非常好。我的画廊里有很多人,我想给他们加一个人 name/description (id: speaker_name)。我所要做的就是对所有这些进行相同的描述。我对此绝对陌生,现在我正在努力让它工作一天。我找到的所有解决方案都使用了片段或 OnPageChangeListener,但我不知道如何实现它。

这是我得到的:

<?xml version="1.0" encoding="utf-8"?>
    <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:tools="http://schemas.android.com/tools"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        tools:context=".MainActivity" >

        <FrameLayout
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:layout_alignParentTop="true"
            android:layout_alignParentStart="true">

            <android.support.v4.view.ViewPager
                android:id="@+id/view_pager"
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                android:background="@color/basicBackground">
            </android.support.v4.view.ViewPager>

            <TextView
                android:id="@+id/speaker_name"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:layout_marginTop="50sp"
                android:text="The Name"
                android:textAlignment="center"
                android:textColor="@android:color/white"
                android:textSize="30sp" />
        </FrameLayout>
    </RelativeLayout>`

寻呼机适配器:

public class ImageAdapter extends PagerAdapter {

SpeakerActivity sa;
Context context;
int i = 0;

public int[] GalImages = new int[] {
        R.drawable.ben,
        R.drawable.brett,
        R.drawable.mark,
        R.drawable.dusan,
        R.drawable.michael,
        R.drawable.mike,
        R.drawable.ollie,
        R.drawable.rebecca,
        R.drawable.sebastian,
        R.drawable.thomas,
        R.drawable.tomasz,
        R.drawable.toni,
};
ImageAdapter(Context context){
    this.context=context;
}
@Override
public int getCount() {
    return GalImages.length;
}

@Override
public boolean isViewFromObject(View view, Object object) {
    return view == ((ImageView) object);
}

@Override
public Object instantiateItem(ViewGroup container, int position) {
    ImageView imageView = new ImageView(context);
    int padding = context.getResources().getDimensionPixelSize(R.dimen.padding_medium);
    imageView.setPadding(padding, padding, padding, padding);
    imageView.setScaleType(ImageView.ScaleType.CENTER_INSIDE);
    imageView.setImageResource(GalImages[position]);
    ((ViewPager) container).addView(imageView, 0);
    return imageView;
}

@Override
public void destroyItem(ViewGroup container, int position, Object object) {
    ((ViewPager) container).removeView((ImageView) object);
}
}

Activity:

public class SpeakerActivity extends Activity {

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

    ViewPager viewPager = (ViewPager) findViewById(R.id.view_pager);
    ImageAdapter adapter = new ImageAdapter(this);
    viewPager.setAdapter(adapter);
}
}

要在滑动时更改文本视图文本,您可以在 oncreate() 方法中执行此操作:

viewPager.addOnPageChangeListener(new ViewPager.OnPageChangeListener() {

                @Override
                public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {

                }

                @Override
                public void onPageSelected(int position) {
                    switch (position){
                        case 0:
                             //Do stuff
                            textview.setText("Ben");
                            break;
                        case 1:
                            //Do stuff
                            textview.setText("Brett");
                            break;
                     //Add other cases for the pages

                    }

                }

                @Override
                public void onPageScrollStateChanged(int state) {

                }

            });

这是实现viewpager OnPageChangeListener()对我来说最好的方法。

让我告诉你基本的想法

  1. Activity 布局绑定到的 ViewPager。
  2. 扩展 ViewPager/FragmentPager 的 ImageAdapter,基本上将视图或片段添加到 viewpager 中,以便 activity 可以向您显示它。
  3. activity 通过将 viewpager 的适配器设置为您的 ImageAdapter 来连接两个对象 就像我在 #2 中所说的那样,您可以通过多种方式实现 ViewPager,那里有很多网站。 参考https://www.bignerdranch.com/ 解释的很详细