如何在片段中使用 ViewPager

2023-12-01

我下载了一个关于 ViewPager 和 CirclePageIndicator 的项目。它在我的平板电脑上运行良好,其代码是:

Test1Activity.java:

TestFragmentAdapter mAdapter;
ViewPager mPager;
@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);


    //The look of this sample is set via a style in the manifest
    setContentView(R.layout.simple_circles);

    mAdapter = new TestFragmentAdapter(getSupportFragmentManager());

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

    CirclePageIndicator indicator = (CirclePageIndicator)findViewById(R.id.indicator);
    indicator.setViewPager(mPager);
}   

TestFragmentAdapter.java:

class TestFragmentAdapter extends FragmentPagerAdapter {
protected static final String[] CONTENT = new String[] { "Page1", "Page2", "Page3", "Page4", };

private int mCount = CONTENT.length;

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

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

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

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

测试片段:

public final class TestFragment extends Fragment {
private static final String KEY_CONTENT = "TestFragment:Content";

public static TestFragment newInstance(String content) {
    TestFragment fragment = new TestFragment();

    fragment.mContent = content;

    return fragment;
}

private String mContent = "???";

@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
    if ((savedInstanceState != null) && savedInstanceState.containsKey(KEY_CONTENT)) {
        mContent = savedInstanceState.getString(KEY_CONTENT);
    }

    TextView text = new TextView(getActivity());
    text.setGravity(Gravity.CENTER);
    text.setText(mContent);
    text.setTextSize(20 * getResources().getDisplayMetrics().density);
    text.setPadding(20, 20, 20, 20);

    LinearLayout layout = new LinearLayout(getActivity());
    layout.setLayoutParams(new LayoutParams(LayoutParams.FILL_PARENT, LayoutParams.FILL_PARENT));
    layout.setGravity(Gravity.CENTER);
    layout.addView(text);

    return layout;
}

@Override
public void onSaveInstanceState(Bundle outState) {
    super.onSaveInstanceState(outState);
    outState.putString(KEY_CONTENT, mContent);
}}

现在我想在Fragment而不是Activity中使用这个ViewPager,但我很困惑。 TestFragmentAdapter 的构造函数接受 android.support.v4.app.FragmentManager 类型的参数,但在片段中我只能使用 getFragmentManager() 来获取 android.app.FragmentManager 类型,因此

mAdapter = new TestFragmentAdapter(getSupportFragmentManager());

总是错的。 我必须在几天内完成我的项目,所以你能告诉我如何修改我的代码以在片段中实现相同的功能吗?

Thx!!


将此代码放入您的 MainActivity 中。下面的代码将在布局中加载片段。

Step 1

Fragment fragment = new PageSlider();
FragmentManager manager = getSupportFragmentManager();
manager.beginTransaction().replace(R.id.content, fragment).commit();

接下来我们需要实现ViewPager

Step 2

public class PageSlider extends Fragment {
public PageSlider() {
// Required empty public constructor
}
@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
}
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
// Inflate the layout for this fragment
    return inflater.inflate(R.layout.page_slider, container, false);
}
@Override
public void onViewCreated(View view, Bundle savedInstanceState) {
// TODO Auto-generated method stub
  super.onViewCreated(view, savedInstanceState);
  PagerSlidingTabStrip tab = (PagerSlidingTabStrip) view
.findViewById(com.akshay.protocol10.asplayer.R.id.tabs);

 ViewPager pager=(ViewPager)view  .findViewById(com.akshay.protocol10.asplayer.R.id.view_pager);
MyPagerAdapter adapter = new MyPagerAdapter(getChildFragmentManager());
pager.setAdapter(adapter);
tab.setViewPager(pager);
}
// TODO: Rename method, update argument and hook method into UI event
public void onButtonPressed(Uri uri) {
}
@Override
public void onAttach(Activity activity) {
super.onAttach(activity);
}
@Override
public void onDetach() {
super.onDetach();
}
public interface OnFragmentInteractionListener {
// TODO: Update argument type and name
public void onFragmentInteraction(Uri uri);
}
}

Step 3:创建适配器

    public class MyPagerAdapter extends FragmentPagerAdapter {
        private final String[] TITLES = { "Album", "Artist", "Songs", "Genre" };
        public MyPagerAdapter(FragmentManager childFragmentManager) {
      // TODO Auto-generated constructor stub
    super(childFragmentManager);
    }
    @Override
    public CharSequence getPageTitle(int position) {
    // TODO Auto-generated method stub
    return TITLES[position];
    }
    @Override
    public Fragment getItem(int index) {
    // TODO Auto-generated method stub
       Fragment fragment = null;
       if (index == 0) {
       fragment = new Albums();
       } else if (index == 1) {
       fragment = new ArtistFragment();
       } else if (index == 2) {
        fragment = new TracksFragment();
       } else if (index == 3) {
       fragment = new GenreFragment();
      }
     return fragment;
    }

    @Override
    public int getCount() {
    // TODO Auto-generated method stub
    return TITLES.length;
    }
   }
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

如何在片段中使用 ViewPager 的相关文章