如何为标签主机设置滚动条

时间:2014-02-24 14:44:48

标签: android tabs scroll android-tabhost

我想在标签host.in标签中设置滚动条有五个标签,但我只想显示三个 一次选项卡以及如何制作滚动条,因此选项卡可以滚动以获取更多选项卡...请提供一些解决方案.......

这是m xml文件.....

<RelativeLayout
    android:id="@+id/rl3"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content" >

    <TabHost
        android:id="@+id/tabhost"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:layout_alignParentBottom="true"
        android:layout_alignParentLeft="true"
        android:background="@drawable/gray" >

        <RelativeLayout
            android:layout_width="fill_parent"
            android:layout_height="fill_parent" >

            <RelativeLayout
                android:id="@+id/layTab"
                android:layout_width="fill_parent"
                android:layout_height="wrap_content"
                android:layout_alignParentBottom="true"
                android:layout_centerVertical="true"
                android:gravity="center" >

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

                    <TabWidget
                        android:id="@android:id/tabs"
                        android:layout_width="match_parent"
                        android:layout_height="wrap_content" >
                    </TabWidget>
                </HorizontalScrollView>
            </RelativeLayout>

            <FrameLayout
                android:id="@android:id/tabcontent"
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                android:scrollbars="vertical" >

                <fragment
                    android:id="@+id/fragment1"
                    android:name="info.tech.slidermenu.Home_feed"
                    android:layout_width="fill_parent"
                    android:layout_height="fill_parent"
                    android:layout_marginTop="50dp" />

                <fragment
                    android:id="@+id/fragment2"
                    android:name="info.tech.slidermenu.Upcoming_tennise_match"
                    android:layout_width="fill_parent"
                    android:layout_height="fill_parent"
                    android:layout_marginTop="50dp" />

                <fragment
                    android:id="@+id/fragment3"
                    android:name="info.tech.slidermenu.Upcoming_tennise_match"
                    android:layout_width="fill_parent"
                    android:layout_height="fill_parent"
                    android:layout_marginTop="50dp" />

                <fragment
                    android:id="@+id/fragment4"
                    android:name="info.tech.slidermenu.Upcoming_tennise_match"
                    android:layout_width="fill_parent"
                    android:layout_height="fill_parent"
                    android:layout_marginTop="50dp" />

                <fragment
                    android:id="@+id/fragment5"
                    android:name="info.tech.slidermenu.Upcoming_tennise_match"
                    android:layout_width="fill_parent"
                    android:layout_height="fill_parent"
                    android:layout_marginTop="50dp" />
            </FrameLayout>
        </RelativeLayout>
    </TabHost>
</RelativeLayout>

这是类文件....

public void tabselect() {
    TabHost tab = (TabHost) findViewById(R.id.tabhost);
    tab.setup();
    tab.setHorizontalScrollBarEnabled(true);
    TabHost.TabSpec spec = tab.newTabSpec("tab1");
    spec.setContent(R.id.fragment1);
    spec.setIndicator("Feed");

    tab.addTab(spec);
    spec = tab.newTabSpec("tab2");
    spec.setContent(R.id.fragment2);
    spec.setIndicator("tennis");
    tab.addTab(spec);

    spec = tab.newTabSpec("tab3");
    spec.setContent(R.id.fragment3);
    spec.setIndicator("boxing");
    tab.addTab(spec);

    spec = tab.newTabSpec("tab3");
    spec.setContent(R.id.fragment4);
    spec.setIndicator("cricket");
    tab.addTab(spec);

    spec = tab.newTabSpec("tab3");
    spec.setContent(R.id.fragment5);
    spec.setIndicator("base ball");
    tab.addTab(spec);

    tab.setCurrentTab(0);

}

屏幕截图....

enter image description here

1 个答案:

答案 0 :(得分:1)

您已经为HorizontalScrollView使用了TabWidget,所以这是正确的方法。如果你这样做就不能流口水,可能是你有布局问题。

你没有详细说明你是否在为TabWidget使用自定义布局,但如果没有,这将是一个很好的方法来实现你想要的,因为没有办法说“我只是想要一次显示3个标签“。

只需为标签定义一个新的布局,这样三个一起适合屏幕的宽度,其余的可以通过滚动来访问。

----编辑----

我在代码中看到了很多LinearLayout个。尝试这样的事情:

<LinearLayout
            android:id="@+id/TabContainer"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_weight="99"
            android:orientation="vertical">
  <TabHost
            android:id="@+android:id/tabhost"
            android:layout_width="match_parent"
            android:layout_height="match_parent">
    <LinearLayout
            android:id="@+id/TabLinearLayout"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:orientation="vertical">
      <HorizontalScrollView
            android:layout_width="fill_parent"
            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"></TabWidget>
      </HorizontalScrollView>
      <FrameLayout
            android:id="@+android:id/tabcontent"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:layout_marginTop="10dp" />
    </LinearLayout>
  </TabHost>
</LinearLayout>