简体   繁体   English

如何在片段中使用ViewPager

[英]how to use a ViewPager in a fragment

I download a project about ViewPager and CirclePageIndicator. 我下载了一个关于ViewPager和CirclePageIndicator的项目。 It works well on my tablet and its code is : 它适用于我的平板电脑,其代码为:

Test1Activity.java: 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: 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();
    }
}}

TestFragment: TestFragment:

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);
}}

now I want to use this ViewPager in a Fragment instead of Activity, but I am puzzled. 现在我想在Fragment中使用这个ViewPager而不是Activity,但我很困惑。 The constructor of TestFragmentAdapter accept a parameter with type android.support.v4.app.FragmentManager, but in a fragment I can only use getFragmentManager() to get an android.app.FragmentManager type, thus the TestFragmentAdapter的构造函数接受类型为android.support.v4.app.FragmentManager的参数,但是在一个片段中我只能使用getFragmentManager()来获取android.app.FragmentManager类型,因此

mAdapter = new TestFragmentAdapter(getSupportFragmentManager());

is always wrong. 总是错的。 I must finish my project within days, so can u tell me how to modify my code to achieve same function in a fragment? 我必须在几天内完成我的项目,所以你能告诉我如何修改我的代码以在片段中实现相同的功能吗?

Thx!! 谢谢!!

Put this code in your MainActivity. 将此代码放在MainActivity中。 The below code will load the Fragment in your Layout. 下面的代码将在您的布局中加载片段。

Step 1 步骤1

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

Next we need to implement the ViewPager 接下来我们需要实现ViewPager

Step 2 第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: Create the Adapter 第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;
    }
   }

Android does not support fragments inside of fragments. Android不支持片段内的片段。 Either switch your ViewPager to use a PagerAdapter that does not use fragments, or do not put the ViewPager in a fragment. 无论是切换你ViewPager使用PagerAdapter不使用的片段,或者不把ViewPager的片段。

EDIT: 编辑:

Now, Android supports fragments inside fragments by using Fragment.getChildFragmentManager() . 现在,Android通过使用Fragment.getChildFragmentManager()支持片段内的片段。 Have a look at this answer . 看看这个答案

Have you try to replace extends Fragment by extends android.support.v4.app.Fragment ? 您是否尝试通过extends android.support.v4.app.Fragment替换extends Fragment

When you do this, getFragmentManager() refers to android.support.v4.app.FragmentManager. 执行此操作时,getFragmentManager()引用android.support.v4.app.FragmentManager。

检查片段extends class它应该从android.support.v4.app.Fragment导入而不是android.app.Fragment

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM