一个片段,包含许多标签的多个内部片段

时间:2013-03-10 11:44:20

标签: android android-layout android-fragments android-viewpager android-framelayout

我想要一个标签布局,其中在每个标签上有两个片段,一个在上面显示任务的进度通过在3个标签中输入来完成,从开始到结束,以及将进行输入的进度片段下面的另一个主要片段。

在每个标签中标题和详细信息,标题片段相同且详细信息片段(每个标签上的输入片段不同)!

我尝试了两天的所有方法:(

我的解决方案 我尝试了一个布局,其中包含两个用于主片段的framelayout,它被添加到ViewPager的两个标签中,如下所示:

public static class ScreenSlidePagerAdapter extends
        FragmentStatePagerAdapter {

    public static ArrayList<Fragment> tabs_fragments = new ArrayList<Fragment>(
            3);

    public ScreenSlidePagerAdapter(FragmentManager fm,
            ArrayList<Fragment> tabs) {
        super(fm);
        ScreenSlidePagerAdapter.tabs_fragments = tabs;

    }

    @Override
    public Fragment getItem(int arg0) {
        return tabs_fragments.get(arg0);
    }

    @Override
    public int getCount() {
        return tabs_fragments.size();
    }

    @Override
    public int getItemPosition(Object object) {
        if (tabs_fragments.contains(object)) {
            return POSITION_UNCHANGED;
        }
        return POSITION_NONE;
    }

    public static void setItem(Fragment fr, int position) {
        if (position <= 2 && position >= 0) {
            tabs_fragments.remove(position);
            tabs_fragments.add(position, fr);
        } else
            Log.d("adding tab", "wrong tab position to add fragment at");
    }
}

在活动开始时,我这样做,请参阅我在主片段中使用的标签位置,用于加载不同标签位置的详细信息片段:

    mPager = (ViewPager) findViewById(R.id.pager);
    // fragments for pagers
    ArrayList<Fragment> tabs = new ArrayList<Fragment>();
    tabs.add(new FrEventDetails());
    tabs.add(new FrEventDetails());
    tabs.add(new FrRuleSave());
    mPagerAdapter = new ScreenSlidePagerAdapter(getFragmentManager(), tabs);
    mPager.setAdapter(mPagerAdapter);

    bar = getActionBar();
    bar.setTitle("Add Rule");
    bar.setSubtitle("select event for rule");
    bar.setDisplayShowTitleEnabled(true);
    bar.setNavigationMode(ActionBar.NAVIGATION_MODE_TABS);
    bar.setDisplayOptions(0, ActionBar.DISPLAY_SHOW_TITLE);
    bar.setDisplayHomeAsUpEnabled(true);

    bar.addTab(bar.newTab().setText("Select Event")
            .setTabListener(new TabListener(mPager)));
    bar.addTab(bar.newTab().setText("Select Action")
            .setTabListener(new TabListener(mPager)));
    bar.addTab(bar.newTab().setText("Save Rule")
            .setTabListener(new TabListener(mPager)));

    if (savedInstanceState != null) {
        bar.setSelectedNavigationItem(savedInstanceState.getInt("tab", 0));
    }
    mPager.setOnPageChangeListener(new ViewPager.SimpleOnPageChangeListener() {
        @Override
        public void onPageSelected(int position) {
            // When swiping between pages, select the
            // corresponding tab.
            if (bar.getSelectedNavigationIndex() != position)
                bar.setSelectedNavigationItem(position);
            tab = position;
        }

然后当这个片段附加到活动时,我添加一个进度布局(标题(对于一个帧布局并基于所选选项卡,为细节框架布局添加另一个片段(用于输入)。 在这里显示:

public class FrEventDetails extends Fragment {
Context context;

@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    context = (Context) activity;
    int tab = AddRule1.tab;
    android.app.FragmentTransaction ft = activity.getFragmentManager()
            .beginTransaction();
     ft.add(R.id.fr_rule_progress_container, new FrProgress());

    if (tab == 1) {
        ft.replace(R.id.fr_event_input_container, new FrActionSelect(),
                "cell1_1").commit();
    } else if (tab == 0) {
        ft.replace(R.id.fr_event_action_container, new FrEventSelect(),
                "cell1_2").commit();
    }

}

注意* 此主片段的布局很简单,包含两个framelayout。

结果:它会在第一个标签上显示标题和细节,但在第二个标签上,只显示主要片段和   当我滑到第三个片段然后回来时,第二个片段被精美地填充(在显示1秒后)但是第一个片段现在是空的。  我无法理解如何处理这件事。
请为这两天的泪流满面的问题提供一些解决方案

1 个答案:

答案 0 :(得分:0)

  1. 要在开始时同时显示所有标签,请增加PagerOffSetLimit(在本例中为3个标签为2)
  2. 要刷新片段的状态或在当前选项卡旁边的选项卡中调用片段上的某些方法,请使用Pager.instantiateItem方法。
    1. 一秒延迟是因为您拥有xml中的animateLayoutChanges。