0

私はアンドロイドの初心者で、チュートリアルを使用してビューページのレイアウトを構築しています。ただし、pagertitle ストリップの実装方法も示すチュートリアルを見つけることができませんでした。断片を集めてバーを表示することはできましたが、テキストを適切に表示する方法がわかりません。現在、一度に複数のタイトルが表示され、ページとの同期が失われます。どんな助けでも大歓迎です。

public class MyPagerActivity extends Activity {

PagerTitleStrip mTitleStrip;
String myTitle;

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

    MyPagerAdapter adapter = new MyPagerAdapter();
    ViewPager myPager = (ViewPager) findViewById(R.id.myfivepanelpager);
    myPager.setAdapter(adapter);
    myPager.setCurrentItem(2);
    mTitleStrip = (PagerTitleStrip) findViewById(R.id.title_strip);


    //some code
}


private class MyPagerAdapter extends PagerAdapter {

    public int getCount() {
        return 5;
    }

    public Object instantiateItem(View collection, int position) {

        LayoutInflater inflater = (LayoutInflater) collection.getContext().getSystemService(Context.LAYOUT_INFLATER_SERVICE);


        int resId = 0;
        switch (position) {
        case 0:
            resId = R.layout.news;              
            view = inflater.inflate(resId, null);
            LinearLayout layout0=(LinearLayout)view.findViewById(R.id.LLnews);
            WebView newsfeed = (WebView) view.findViewById(R.id.webViewnews);
            ((ViewPager) collection).addView(view, 0);
            return view;

        case 1:
            resId = R.layout.coinshows;
            view = inflater.inflate(resId, null);
            LinearLayout layout1=(LinearLayout)view.findViewById(R.id.LLcoinshows);
            WebView coinshows = (WebView) view.findViewById(R.id.webViewcoinshows);
            ((ViewPager) collection).addView(view, 0);
            return view;


        }
        return resId;
}

}

    @Override
    public void destroyItem(View arg0, int arg1, Object arg2) {
        ((ViewPager) arg0).removeView((View) arg2);

    }


    @Override
    public boolean isViewFromObject(View arg0, Object arg1) {
        return arg0 == ((View) arg1);

    }


    @Override
    public Parcelable saveState() {
        // TODO Auto-generated method stub
        return null;
    }


    @Override
    public CharSequence getPageTitle(int position) {
        return myTitle;
    }

}
4

1 に答える 1

0

PagerSlidingTabStripを使用することをお勧めします。使い方はとても簡単で、Play ストアのルック アンド フィールをエミュレートしていてとてもいいです。

使用法

1.このプロジェクトの実用的な実装については、sample/ フォルダーを参照してください。

ビューに PagerSlidingTabStrip ウィジェットを含めます。これは通常、それが表す ViewPager に隣接して配置する必要があります。

  <com.astuetz.viewpager.extensions.PagerSlidingTabStrip
     android:id="@+id/tabs"
     android:layout_width="match_parent"
     android:layout_height="48dip" /> 

2. onCreate メソッド (フラグメントの場合は onCreateView) で、ウィジェットを ViewPager にバインドします。

  // Set the pager with an adapter  
  ViewPager pager = (ViewPager) findViewById(R.id.pager);  
  pager.setAdapter(new TestAdapter(getSupportFragmentManager()));

  // Bind the widget to the adapter  
  PagerSlidingTabStrip tabs = (PagerSlidingTabStrip) findViewById(R.id.tabs); 
  tabs.setViewPager(pager);

3.(オプション) ビュー ページャーで OnPageChangeListener を使用する場合は、ページャーに直接設定するのではなく、ウィジェットに設定する必要があります。

  // continued from above 
  tabs.setOnPageChangeListener(mPageChangeListener);
于 2013-08-08T14:18:29.413 に答える