TabLayout 宽度错误
TabLayout width bug
我遇到了一个错误,它在不同的 android 版本上产生了不同的制表符宽度。在 android 4.1.1 和 android 5.1 上,制表符宽度服从模式 'fill' 并且制表符布局宽度匹配 perent。在 android 上,4.4.4 宽度看起来像 wrap_content
。设计库版本 23.3.0。如何解决?
布局
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:orientation="vertical"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@color/white"
android:clickable="true"
>
<android.support.design.widget.TabLayout
android:id="@+id/tabs"
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:tabMode="fixed"
app:tabGravity="fill"
app:tabIndicatorHeight="0dip"
app:tabIndicatorColor="@android:color/transparent"
app:tabBackground="@drawable/tab_request_background"
app:tabTextColor="@color/colorPrimary"
app:tabSelectedTextColor="@color/white"
/>
<android.support.v4.view.ViewPager
android:id="@+id/viewpager"
android:layout_width="match_parent"
android:layout_height="match_parent"
app:layout_behavior="@string/appbar_scrolling_view_behavior"
/>
</LinearLayout>
似乎没有简单的方法可以修复它,因为:
/// Android SDK 24.2.0 TabLayout.java
public void setTabGravity(@TabGravity int gravity) {
if (mTabGravity != gravity) {
mTabGravity = gravity;
applyModeAndGravity();
}
}
private void applyModeAndGravity() {
int paddingStart = 0;
if (mMode == MODE_SCROLLABLE) {
// If we're scrollable, or fixed at start, inset using padding
paddingStart = Math.max(0, mContentInsetStart - mTabPaddingStart);
}
ViewCompat.setPaddingRelative(mTabStrip, paddingStart, 0, 0, 0);
switch (mMode) {
case MODE_FIXED:
mTabStrip.setGravity(Gravity.CENTER_HORIZONTAL);
break;
case MODE_SCROLLABLE:
mTabStrip.setGravity(GravityCompat.START);
break;
}
updateTabViews(true);
}
太蠢了:(
发现将制表符最小宽度设置为 0 可以解决此问题。它似乎也不是 feature
而是 feature
因为在高宽度设备上选项卡与很多 space 分开(特别是在横向模式的平板电脑上)并且支持库开发人员迫使我们处理它制作更好的界面
我遇到了一个错误,它在不同的 android 版本上产生了不同的制表符宽度。在 android 4.1.1 和 android 5.1 上,制表符宽度服从模式 'fill' 并且制表符布局宽度匹配 perent。在 android 上,4.4.4 宽度看起来像 wrap_content
。设计库版本 23.3.0。如何解决?
布局
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:orientation="vertical"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@color/white"
android:clickable="true"
>
<android.support.design.widget.TabLayout
android:id="@+id/tabs"
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:tabMode="fixed"
app:tabGravity="fill"
app:tabIndicatorHeight="0dip"
app:tabIndicatorColor="@android:color/transparent"
app:tabBackground="@drawable/tab_request_background"
app:tabTextColor="@color/colorPrimary"
app:tabSelectedTextColor="@color/white"
/>
<android.support.v4.view.ViewPager
android:id="@+id/viewpager"
android:layout_width="match_parent"
android:layout_height="match_parent"
app:layout_behavior="@string/appbar_scrolling_view_behavior"
/>
</LinearLayout>
似乎没有简单的方法可以修复它,因为:
/// Android SDK 24.2.0 TabLayout.java
public void setTabGravity(@TabGravity int gravity) {
if (mTabGravity != gravity) {
mTabGravity = gravity;
applyModeAndGravity();
}
}
private void applyModeAndGravity() {
int paddingStart = 0;
if (mMode == MODE_SCROLLABLE) {
// If we're scrollable, or fixed at start, inset using padding
paddingStart = Math.max(0, mContentInsetStart - mTabPaddingStart);
}
ViewCompat.setPaddingRelative(mTabStrip, paddingStart, 0, 0, 0);
switch (mMode) {
case MODE_FIXED:
mTabStrip.setGravity(Gravity.CENTER_HORIZONTAL);
break;
case MODE_SCROLLABLE:
mTabStrip.setGravity(GravityCompat.START);
break;
}
updateTabViews(true);
}
太蠢了:(
发现将制表符最小宽度设置为 0 可以解决此问题。它似乎也不是 feature
而是 feature
因为在高宽度设备上选项卡与很多 space 分开(特别是在横向模式的平板电脑上)并且支持库开发人员迫使我们处理它制作更好的界面