1

http://viewpagerindicator.com/ライブラリを使用しています。TitlePageIndicatorGmailアプリで以下のような画像を作成したいと思います。

ここに画像の説明を入力してください

最初のタイトルが「新しい」、最後のタイトルが「古い」、中央のタイトルが「[合計ページ]の[ページ位置]」であるのとまったく同じことを実現したいと思います。使用しているライブラリでこれを実現することは可能ですか、それとも変更する必要がありますか?

4

1 に答える 1

1

同じ問題がありました。Matthieu の助けを借りて、このように解決しました。これは、ViewPagerIndicator に付属のサンプルに基づいています。

基本的に、ページが変更されたときにリッスンし、アダプタを変更して、現在の位置に応じて異なるページ タイトルを付けます。以下に示すコードは、私にとってはうまくいきます。

これらのサンプルが機能していて、これら 2 つのファイルを置き換えるだけの場合は、このサンプルを試してください。

TestFragmentAdapter のコードを次のように変更しました。

class TestFragmentAdapter extends FragmentPagerAdapter implements IconPagerAdapter {
    protected static final String[] CONTENT = new String[] { "This", "Is", "stack", "overflow"  };
    protected static final int[] ICONS = new int[] {
        R.drawable.perm_group_calendar,
        R.drawable.perm_group_camera,
        R.drawable.perm_group_device_alarms,
        R.drawable.perm_group_location
};

private int mCount = CONTENT.length;

// CHANGE START HERE
private int current_position=0;

public void set_current_position(int i) {
    current_position = i;
}
// CHANGE ENDS HERE

public TestFragmentAdapter(FragmentManager fm) {
    super(fm);
}

@Override
public Fragment getItem(int position) {
    return TestFragment.newInstance(CONTENT[position % CONTENT.length]);
}

@Override
public int getCount() {
    return mCount;
}

@Override
public CharSequence getPageTitle(int position) {
    // CHANGE START HERE
    if (position == current_position-1) {
        return "Previous";
    } else if (position == current_position+1) {
        return "Next";
    }
    // CHANGE ENDS HERE
    return TestFragmentAdapter.CONTENT[position % CONTENT.length];
}

@Override
public int getIconResId(int index) {
  return ICONS[index % ICONS.length];
}

public void setCount(int count) {
    if (count > 0 && count <= 10) {
        mCount = count;
        notifyDataSetChanged();
    }
}
}

このような SampleTitlesDefault のコード (OnPageChangeListener を追加)

public class SampleTitlesDefault extends BaseSampleActivity implements ViewPager.OnPageChangeListener {
@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.simple_titles);

    mAdapter = new TestFragmentAdapter(getSupportFragmentManager());

    mPager = (ViewPager)findViewById(R.id.pager);
    mPager.setAdapter(mAdapter);

    mIndicator = (TitlePageIndicator)findViewById(R.id.indicator);
    mIndicator.setViewPager(mPager);
    // CHANGE START HERE
    mIndicator.setOnPageChangeListener(this);
    // CHANGE ENDS HERE
}

// CHANGE START HERE
@Override
public void onPageScrolled(int i, float v, int i1) {
}

@Override
public void onPageSelected(int i) {
    mPager = (ViewPager)findViewById(R.id.pager);
    ((TestFragmentAdapter)mPager.getAdapter()).set_current_position(i);
}

@Override
public void onPageScrollStateChanged(int i) {
}
// CHANGE ENDS HERE
}
于 2012-12-08T11:02:15.773 に答える