7

目前我正忙于为我的公司开发 WHMCS 应用程序。作为导航,我想在操作栏中使用 Tab 功能。

但是,如何编辑选项卡的宽度?我需要在一个屏幕上同时显示 5 个,而无需滚动。我已经尝试过一些这样的样式:

<style name="AppBaseTheme" parent="android:Theme.Light">
</style>

<style name="AppTheme" parent="AppBaseTheme">
    <item name="@android:attr/actionBarTabStyle">@style/tab_nav</item>
    <item name="android:actionBarTabTextStyle">@style/actionBarTabTextStyle</item>
</style>

<style name="actionBarTabTextStyle" parent="android:Widget.Holo.Light.ActionBar.TabText.Inverse">
    <item name="android:padding">1dp</item>
</style>

<style name="tab_nav" parent="android:style/Widget.Holo.Light.Tab">
 <item name="android:paddingLeft">-25dp</item>
</style> 

<style name="CustomTabTextStyle" parent="@android:style/TextAppearance.Holo">
    <item name="android:textColor">#2456c2</item>
</style>

但是,当使用更高的负值时,宽度不会缩小。

4

2 回答 2

3

嗨,我认为这可能会对您有所帮助...此代码实际上是使操作栏绑定到屏幕宽度,因此选项卡将自行调整 =)

private void setTabsMaxWidth() {
   DisplayMetrics displaymetrics = new DisplayMetrics();
   getWindowManager().getDefaultDisplay().getMetrics(displaymetrics);
   int screenWidth = displaymetrics.widthPixels;
   final ActionBar actionBar = getActionBar();
   final View tabView = actionBar.getTabAt(0).getCustomView();
   final View tabContainerView = (View) tabView.getParent();
   final int tabPadding = tabContainerView.getPaddingLeft() + tabContainerView.getPaddingRight();
   final int tabs = actionBar.getTabCount();
   for(int i=0 ; i < tabs ; i++) {
      View tab = actionBar.getTabAt(i).getCustomView();
      TextView text1 = (TextView) tab.findViewById(R.id.text1);
      text1.setMaxWidth(screenWidth/tabs-tabPadding-1);
  }
}
于 2013-07-26T22:38:24.327 回答
0

如果您需要“在一个屏幕上同时显示 5 个而不需要滚动”,最好在布局顶部使用TabHost 。

于 2014-08-22T15:35:02.847 回答