具有交互式视图的 android 选项卡

Posted

技术标签:

【中文标题】具有交互式视图的 android 选项卡【英文标题】:android tabs with interactive views 【发布时间】:2012-05-07 18:54:51 【问题描述】:

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

仅对所有内容都使用视图,这段代码开始变得混乱。

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

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

(viewflippers 和操作栏不是一个选项,我试图避免使用带有活动的选项卡)

【问题讨论】:

【参考方案1】:

忘记活动组。忘记标签主机。现在都是关于 ActionBar Tabs 和 ViewPager Fragments 的。 API Demos 示例应用程序(也是 android 兼容性库示例应用程序)提供了一个在 Fragment 之间结合 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://***.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

【讨论】:

好的,现在给我一个可以在 Android 2.2+ 上运行并且在屏幕底部有标签/“操作栏”的实现。接受挑战了吗? 在我的 android 2.3.3 手机上,一半的 android v4 支持示例类因“ClassNotFoundException”而崩溃 在更新的答案中查看解决方案。手边没有手机,但运行在 2.1 AVD 中。 哦,忘了说:我选择传递底部标签,因为这违反了developer.android.com/design/patterns/actionbar.html【参考方案2】:

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

我们开始吧:http://ericharlow.blogspot.com/2010/09/experience-multiple-android-activities.html

【讨论】:

我知道如何在选项卡中进行活动,但我认为在选项卡中使用意图是不好的做法,这就是谷歌最终完全弃用选项卡活动的原因。所以我试图只使用平面视图和 layoutInflater 但它似乎太有限了

以上是关于具有交互式视图的 android 选项卡的主要内容,如果未能解决你的问题,请参考以下文章

SwiftUI 确认按钮 - 在任何其他视图交互时重置状态

与powershell的第二个浏览器选项卡进行交互

SwiftUI:输入字段键盘动画导致选项卡视图中的其他视图动画

选项卡式内容的angularjs组件交互

zTree树形菜单交互选项卡效果实现

单击ListViewItem时Android加载片段