2012-04-24 47 views
3

我下載一個大約ViewPager和CirclePageIndicator項目。它運作良好,在我的平板電腦和它的代碼是:如何使用ViewPager在片段

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

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

現在我想在片段中使用此ViewPager而不是活動,但我感到困惑。 TestFragmentAdapter的構造函數接受類型android.support.v4.app.FragmentManager參數,但在一個片段我只能用getFragmentManager()得到一個android.app.FragmentManager類型,因此

mAdapter = new TestFragmentAdapter(getSupportFragmentManager()); 

是總是錯的。 我必須在幾天內完成我的項目,那麼你能告訴我如何修改我的代碼以實現片段中的相同功能嗎?

Thx !!

+0

[在片段的Android viewpager](的可能的複製http://stackoverflow.com/questions/33103320/android-viewpager-in-片段) – 2016-01-03 19:51:24

回答

0

你有沒有嘗試extends android.support.v4.app.Fragment更換extends Fragment

當你做到這一點,getFragmentManager()是指android.support.v4.app.FragmentManager。

+0

我應該把代碼mAdapter = new TestFragmentAdapter(getSupportFragmentManager());哪部分?在activity中的onCreate()或片段中的onCreateActivity()中? – 2012-04-24 14:36:27

+0

您必須創建一個像TestFragmentViewPager一個新的片段包括ViewPager並在CreateView的方法,您只需添加'mViewPager =(ViewPager)getView()findViewById(R.id.viewPager)。 \t \t mViewPager.setAdapter(new TestFragmentAdapter(getFragmentManager()));' – 2012-04-24 14:42:12

+0

另外,我不確定TestFragmentAdapter中的getItem方法是否正確。你可以做的是創建一個TestFragment的新實例,併爲傳遞值添加一些額外的值,例如:'TestFragment fragment = new TestFragment(); \t Bundle args = new Bundle(); \t args.putString(「content」,CONTENT [position%CONTENT.length]); \t fragment.setArguments(args); \t返回片段;' – 2012-04-24 14:46:58

2

Android不支持片段的內部片段。無論是切換你ViewPager使用PagerAdapter不使用的片段,或者不把ViewPager的片段。

編輯:

現在,機器人通過使用Fragment.getChildFragmentManager()支持內部片段的片段。看看this answer

+0

我想提出的片段在一個活動,並且該片段可同時顯示6幅圖像,並且用戶可以滑動片段看其他6倍的圖像。可以使用帶有PagerAdapter的ViewPager嗎? – 2012-04-24 14:30:18

+0

@EiffelZhu:讓你的活動持有'ViewPager',並讓'ViewPager'擁有片段。或者,讓活動持有一個片段,該片段包含一個不包含片段的'ViewPager'。 – CommonsWare 2012-04-24 14:40:13

+0

第一個想法是好的!Thx很多! – 2012-04-24 15:02:15

1

將此代碼放在您的MainActivity。以下代碼將在您的佈局中加載碎片。

步驟1

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

接下來,我們需要實現ViewPager

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

步驟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; 
    } 
    } 
0

檢查片段延伸類應該從android.support.v4.app.Fragment導入不android.app.Fragment