使用ViewPager滑动时,TabHost选项卡不会水平滚动

时间:2013-05-10 11:20:51

标签: android actionbarsherlock android-viewpager android-tabhost horizontal-scrolling

我正在编写一个使用许多片段的应用。我使用了ActionBarSherlock(带ActionBar)。为了解决bug#240,我决定切换一个功能正常的实现,将ActionBarSherlock与 TabHost 结合使用。 经过半个小时的工作,它工作正常,除了我在页面之间滑动时:相应的选项卡被选中,但是没有居中,往往甚至看不见所以用户不能看看选中了哪个标签。

enter image description here

在图片中,您可以看到可见片段(“WEEKLY S ..”),但标签只有一半可见。下一次滑动只会使“WEEKLY S ...”看起来像“CALENDAR EVENTS”,除非我手动滑动TabWidget,否则我不知道选择了哪个Tab。

这是我的activity_main.xml:

<TabHost xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@android:id/tabhost"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent" >

    <LinearLayout
        android:orientation="vertical"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent">

        <HorizontalScrollView 
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:fillViewport="true"
            android:scrollbars="none" >

            <TabWidget
                android:id="@android:id/tabs"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:tabStripEnabled="true"
                android:orientation="horizontal" />

        </HorizontalScrollView>

        <FrameLayout
            android:id="@android:id/tabcontent"
            android:layout_width="fill_parent"
            android:layout_height="0dp"
            android:layout_weight="0"/>

        <android.support.v4.view.ViewPager
            android:id="@+id/pager"
            android:layout_width="match_parent"
            android:layout_height="0dp"
            android:layout_weight="1"/>

    </LinearLayout>

</TabHost>

我的TabsAdapter与Jake WhartonFragmentTabsPager示例相同。

欢迎任何建议!

2 个答案:

答案 0 :(得分:6)

感谢这个post,特别是jucas,我设法让它发挥作用。这是代码:

@Override
public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
    View tabView = mTabHost.getTabWidget().getChildAt(position);
    if (tabView != null)
    {
        final int width = mHorizontalScroll.getWidth();
        final int scrollPos = tabView.getLeft() - (width - tabView.getWidth()) / 2;
        mHorizontalScroll.scrollTo(scrollPos, 0);
    } else {
        mHorizontalScroll.scrollBy(positionOffsetPixels, 0);
    }
}

当然,我必须在几个地方初始化mHorizontalScroll。 (如果有人不知道该怎么做,我会很乐意发布完整的代码。)

答案 1 :(得分:0)

我在onPageChangeListener中添加了以下代码来解决问题。

mViewPager.setOnPageChangeListener(new ViewPager.OnPageChangeListener() {


        @Override
        public void onPageSelected(int position) {
            // on changing the page make respected tab selected
            //actionBar.setSelectedNavigationItem(position);
            mTabHost.setCurrentTab(position);
        }

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

            View tabView = mTabHost.getTabWidget().getChildAt(position);
            View mHorizontalScroll = (HorizontalScrollView) findViewById(R.id.mHorizontalScroll);
            if (tabView != null)
            {
                int width = mHorizontalScroll.getWidth();
                int scrollPos = tabView.getLeft() - (width - tabView.getWidth()) / 2;
                mHorizontalScroll.scrollTo(scrollPos, 0);
            } else {
                mHorizontalScroll.scrollBy(positionOffsetPixels, 0);
            }
        }

        @Override
        public void onPageScrollStateChanged(int arg0) {

        }
    });