带有交互式视图的android标签

时间:2012-05-07 18:54:52

标签: android tabs views android-tabhost tabwidget

我试图避免在tabhost和tabwidget中使用意图和活动

这段代码开始变得混乱,只是使用了所有内容的视图。

我的问题是我无法保留信息。在一个选项卡中,我有一个视图,其中有4个按钮,每个按钮加载另一个视图,这将占用该选项卡中屏幕上的视觉信息。问题是,当我“返回”加载该选项卡中的上一个视图时,没有任何信息是该视图被保留,即使按钮侦听器也不会重新实例化。

我该如何处理?我在选项卡中看到了一些非常基本的视图示例,但没有任何交互式加载更多视图。

(viewflippers和操作栏不是一个选项,我试图避免在活动中使用标签页)

2 个答案:

答案 0 :(得分:2)

忘记活动小组。忘记标签主机。这就是ActionBar Tabs和ViewPager Fragments的全部内容。 API演示示例应用程序(也是Android兼容性库示例应用程序)提供了一个实现,它结合了片段之间的Tab和ViewPager导航,但它有点伪造Tabs(即,它们不是真正的ActionBar选项卡)。见FragmentTabsPager.java。您可以使用此功能并使其与真正的ActionBar选项卡一起使用。

这是有趣的一点。 (我删除了一堆东西,所以不要在这里寻找完整的工作解决方案。)

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

    setContentView(R.layout.fragment_tabs_pager);

    mViewPager = (ViewPager)findViewById(R.id.pager);

    // This block thanks to https://stackoverflow.com/q/9790279/517561
    ActionBar bar = getSupportActionBar();
    bar.setNavigationMode(ActionBar.NAVIGATION_MODE_TABS);
    bar.setDisplayShowTitleEnabled(true);
    bar.setDisplayShowHomeEnabled(true);
    //

    mTabsAdapter = new TabsAdapter(this, mViewPager);

    mTabsAdapter.addTab("simple", "Simple", 
            FragmentStackSupport.CountingFragment.class, null);
    mTabsAdapter.addTab("contacts", "Contacts",
        LoaderCursorSupport.CursorLoaderListFragment.class, null);
    mTabsAdapter.addTab("custom", "Custom",
        LoaderCustomSupport.AppListFragment.class, null);
    mTabsAdapter.addTab("throttle", "Throttle",
        LoaderThrottleSupport.ThrottledLoaderListFragment.class, null);
}

public static class TabsAdapter extends FragmentPagerAdapter
        implements ViewPager.OnPageChangeListener, ActionBar.TabListener {
    private final SherlockFragmentActivity mContext;
    private final ViewPager mViewPager;
    private final ArrayList<TabInfo> mTabs = new ArrayList<TabInfo>();

    static final class TabInfo {
        @SuppressWarnings("unused")
        private final String tag;
        private final Class<?> clss;
        private final Bundle args;

        TabInfo(String _tag, Class<?> _class, Bundle _args) {
            tag = _tag;
            clss = _class;
            args = _args;
        }
    }

    static class DummyTabFactory implements TabHost.TabContentFactory {
        private final Context mContext;

        public DummyTabFactory(Context context) {
            mContext = context;
        }

        @Override
        public View createTabContent(String tag) {
            View v = new View(mContext);
            v.setMinimumWidth(0);
            v.setMinimumHeight(0);
            return v;
        }
    }

    public TabsAdapter(SherlockFragmentActivity activity, ViewPager pager) {
        super(activity.getSupportFragmentManager());
        mContext = activity;
        mViewPager = pager;
        mViewPager.setAdapter(this);
        mViewPager.setOnPageChangeListener(this);
    }

    public void addTab(String tag, CharSequence label, Class<?> clss, Bundle args) {
        ActionBar.Tab tab = mContext.getSupportActionBar().newTab();
        tab.setText(label);
        tab.setTabListener(this);
        mContext.getSupportActionBar().addTab(tab);
        TabInfo info = new TabInfo(tag, clss, args);
        mTabs.add(info);
        notifyDataSetChanged();    
    }

    @Override
    public Fragment getItem(int position) {
        TabInfo info = mTabs.get(position);
        return Fragment.instantiate(mContext, info.clss.getName(), info.args);
    }

    @Override
    public void onPageSelected(int position) {
        mContext.getSupportActionBar().setSelectedNavigationItem(position);
    }

    @Override
    public void onTabSelected(Tab tab, FragmentTransaction ft) {
      mViewPager.setCurrentItem(mContext.getSupportActionBar().getSelectedNavigationIndex());
    }
}

我的完整解决方案:http://code.google.com/p/sherlock-demo/

注意:需要ActionBarSherlock。 注意:感谢ActionBarSherlock and FragmentTabsPager

答案 1 :(得分:-1)

标签的用户活动组,并为标签或活动创建您创建的任何漂亮的布局。

我们走了:http://ericharlow.blogspot.com/2010/09/experience-multiple-android-activities.html