如何在ViewPager的每个页面上显示不同的文本,instantiateItem()混淆

时间:2012-09-23 18:06:55

标签: android android-viewpager

在ViewPager的CustomPagerAdapter中,在instantiateItem()方法中,我正在尝试创建一个TextView,然后根据特定条件为每个页面设置不同的文本。从页面Cursor读取文本。这是一个代码:

@Override
public Object instantiateItem(ViewGroup collection, int position) {

sc = new ScrollView(context);
sc.setLayoutParams(new LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT));
sc.setFillViewport(true);
tv = new TextView(context);


if(position < count) {
  tv.setText(pages.getString(1));   
  pages.moveToPosition(position);

}else {
  tv.setText("LOCKED");
}          

  tv.setTag(TAG_PAGE + position);

  tv.setGravity(Gravity.CENTER);
  tv.setTextColor(Color.BLACK);
  tv.setTextSize(30);
  sc.addView(tv);

  ((ViewPager) collection).addView(sc);

  return sc;            
}

然而,ViewPager的行为并不像预期的那样。第一页和第二页具有相同的文本,其余页面具有预期的“已锁定”符号。当我滑入第4页并返回第一页时,第一页包含假定位于第二页的文本。我也尝试使用myViewPager.setOffscreenPageLimit(numberOfPages),但它没有帮助。

我找到了这个答案:

“在instantiateItem内部,position参数是需要渲染的位置。它不是用户可以看到的当前焦点项目的位置。当前显示的视图左侧和右侧的页面需要预先渲染在内存中,以便这些屏幕的动画流畅。“

这对我有意义,但我怎样才能正确显示网页内容,然后根据需要更新?请告诉我是否有不同的方法来跳过instantiateItem()方法,将问题引入混乱和混乱。谢谢。

2 个答案:

答案 0 :(得分:2)

我通过使用不同的实现解决了这个问题:

// Adapter class
private static class MyFragmentPagerAdapter extends FragmentPagerAdapter {
public MyFragmentPagerAdapter(FragmentManager fm)   {
    super(fm);
}

@Override
public Fragment getItem(int index) {
    return PageFragment.newInstance(pages[index]);  // Pages is an array of Strings
    }

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


// PageFragment class
public class PageFragment extends Fragment {

TextView tv;

public static PageFragment newInstance(String page) {
    PageFragment pageFragment = new PageFragment();
    Bundle bundle = new Bundle();
    bundle.putString("pageContent", page);
    pageFragment.setArguments(bundle);

    return pageFragment;
}

@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
}

@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState)   {
    View view = inflater.inflate(R.layout.fragment, container, false);
    tv = (TextView) view.findViewById(R.id.text_view);
    tv.setText(getArguments().getString("pageContent"));

    return view;
    }
}

答案 1 :(得分:0)

您可以创建ViewPager对象,然后在此对象上设置Listener。

               ViewPager myPager = (ViewPager) findViewById(R.id.yourPagerid);
            myPager.setAdapter(adapter);
                 myPager.setCurrentItem(0);

                    myPager.setOnPageChangeListener(new OnPageChangeListener() {

        @Override
        public void onPageSelected(int position) {
                      //You can change textview word according to current page

            switch (position) {
            case 0:

                break;
            case 1:

                break;
            case 2:

                break;
            }
        }

        @Override
        public void onPageScrolled(int arg0, float arg1, int arg2) {
            // Log.d("check","onPageScrolled");

        }

        @Override
        public void onPageScrollStateChanged(int arg0) {
            // Log.d("check","onPageScrollStateChanged");

        }
    });