不绘制标签下的条带

时间:2012-04-12 13:51:05

标签: android tabs strip

在我的活动中,我这样做是为了设置TabHost:

//...     
        mTabHost = (TabHost) findViewById(android.R.id.tabhost);
        mTabHost.getTabWidget().setDividerDrawable(R.drawable.my_divider_tab);
        mTabHost.getTabWidget().setStripEnabled(true);
        mTabHost.getTabWidget().setLeftStripDrawable(R.drawable.my_strip_tab);
        mTabHost.getTabWidget().setRightStripDrawable(R.drawable.my_strip_tab);
        setupTab(new TextView(this), getString(R.string.device_text_tab));
        setupTab(new TextView(this), getString(R.string.sensor_text_tab));
        setupTab(new TextView(this), getString(R.string.actuator_text_tab));
//...

private void setupTab(final View view, final String tag) {

    View tabview = createTabView(mTabHost.getContext(), tag);
        TabSpec setContent = mTabHost.newTabSpec(tag).setIndicator(tabview).setContent(new TabContentFactory() {
        public View createTabContent(String tag) {return view;}
    });
    mTabHost.addTab(setContent);
}

private static View createTabView(final Context context, final String text) {

    View view = LayoutInflater.from(context).inflate(R.layout.state_tabwidget, null);
    TextView tv = (TextView) view.findViewById(R.id.tabsText);
    tv.setText(text);
    return view;
}

my_strip_tab.xml 只是一个矩形形状:

<?xml version="1.0" encoding="utf-8"?>
<shape  
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle">

    <solid 
        android:color="#FFFFFF"/>

    <size 
        android:width="0dp"
        android:height="2dp"/>
</shape>

绘制垂直分隔线。但标签下的条带未显示......

可能是什么问题? my_strip_tab的大小?

我刚发现:

/**
 * Controls whether the bottom strips on the tab indicators are drawn or
 * not.  The default is to draw them.  If the user specifies a custom
 * view for the tab indicators, then the TabHost class calls this method
 * to disable drawing of the bottom strips.
 * @param stripEnabled true if the bottom strips should be drawn.
 */

此处:TabWidgetExample

所以看起来当我们为标签使用自定义视图时(就像我正在做的那样),条带会自动禁用... 我该如何启用它?

2 个答案:

答案 0 :(得分:2)

你唯一需要做的就是移动这段代码

    mTabHost.getTabWidget().setStripEnabled(true);
    mTabHost.getTabWidget().setLeftStripDrawable(R.drawable.my_strip_tab);
    mTabHost.getTabWidget().setRightStripDrawable(R.drawable.my_strip_tab);

完成所有setupTab()

之后

如果您查看Google文档,原因是当您对选项卡指示符使用自定义视图时,将自动调用setStripEnabled(false)。您只需在设置所有自定义视图或选项卡指示符后再次重新启用它。

答案 1 :(得分:1)

我找到解决此问题的唯一解决方案是:

//...
<TabWidget
        android:id="@android:id/tabs"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"/>

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


        <View
            android:id="@+id/my_strip_tab"
            android:layout_width="fill_parent"
            android:layout_height="3dp" 
            android:background="@drawable/my_strip_tab"/>

//...

    </FrameLayout>

<强> my_strip_tab.xml

<?xml version="1.0" encoding="utf-8"?>
<shape  
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle">

    <solid 
        android:color="#67E667"/>

</shape>