如何在android中创建固定的操作栏并在其下面启动新的活动

时间:2013-04-23 19:35:01

标签: java android actionbarsherlock

我正在开发一个使用ActionBarSherlock作为操作栏的应用程序。我想在所有操作中修复此操作栏,并希望启动在此操作栏下生成的所有活动。

例如,如果用户点击任何操作栏项目,则应在其下方呈现下一个活动(在演示区域中)。

我还希望操作栏下方有一个swipy标签(不应该是我们操作栏的一部分,但应该通过点击任何一个操作栏项来生成)。

如果有人可以为我分享任何指示,我真的很感激。

我阅读了很多文档并尝试了一些示例,但我没有在操作栏下面渲染新活动,而是在整个屏幕中启动了活动!

请帮忙。

1 个答案:

答案 0 :(得分:4)

您不能将Activity放在另一个活动

您可以在Activity中使用Fragments,并将现有的Fragment替换为另一个。

如果您要定位API< 11那么您需要使用包含FragmentActivitysupport Fragments

因此,使用您的swipey标签示例,这些标签将是由适配器管理的片段,该适配器处理ViewPager

Here's an example in the ActionBarSherlock samples

我正在粘贴静态内部类,以确保在链接消失时将其保留在此处

public static class TabsAdapter extends FragmentPagerAdapter
        implements TabHost.OnTabChangeListener, ViewPager.OnPageChangeListener {
    private final Context mContext;
    private final TabHost mTabHost;
    private final ViewPager mViewPager;
    private final ArrayList<TabInfo> mTabs = new ArrayList<TabInfo>();

    static final class TabInfo {
        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(FragmentActivity activity, TabHost tabHost, ViewPager pager) {
        super(activity.getSupportFragmentManager());
        mContext = activity;
        mTabHost = tabHost;
        mViewPager = pager;
        mTabHost.setOnTabChangedListener(this);
        mViewPager.setAdapter(this);
        mViewPager.setOnPageChangeListener(this);
    }

    public void addTab(TabHost.TabSpec tabSpec, Class<?> clss, Bundle args) {
        tabSpec.setContent(new DummyTabFactory(mContext));
        String tag = tabSpec.getTag();

        TabInfo info = new TabInfo(tag, clss, args);
        mTabs.add(info);
        mTabHost.addTab(tabSpec);
        notifyDataSetChanged();
    }

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

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

    @Override
    public void onTabChanged(String tabId) {
        int position = mTabHost.getCurrentTab();
        mViewPager.setCurrentItem(position);
    }

    @Override
    public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
    }

    @Override
    public void onPageSelected(int position) {
        // Unfortunately when TabHost changes the current tab, it kindly
        // also takes care of putting focus on it when not in touch mode.
        // The jerk.
        // This hack tries to prevent this from pulling focus out of our
        // ViewPager.
        TabWidget widget = mTabHost.getTabWidget();
        int oldFocusability = widget.getDescendantFocusability();
        widget.setDescendantFocusability(ViewGroup.FOCUS_BLOCK_DESCENDANTS);
        mTabHost.setCurrentTab(position);
        widget.setDescendantFocusability(oldFocusability);
    }

    @Override
    public void onPageScrollStateChanged(int state) {
    }
}