Android标签布局不占用自定义视图的全宽度

时间:2016-03-08 06:16:12

标签: android android-tablayout androiddesignsupport

Android TabLayout tabPaddingTop and tabPaddingBottom not being removed

请参阅上述问题。

即使我将我的设计库更新为" 23.2.0",Tab布局也搞砸了。

下图是我的标签布局。

Xml部分: -

<android.support.design.widget.TabLayout
    android:id="@+id/sliding_tabs"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    app:tabIndicatorColor="@android:color/white"
    app:tabIndicatorHeight="@dimen/dp2"
    app:tabMode="fixed"
    app:tabSelectedTextColor="@android:color/white"
    app:tabTextAppearance="@style/MyCustomTabTextAppearance" />

样式xml: -

<resources>

<!-- Base application theme. -->
<style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar">
    <item name="colorPrimary">@color/colorPrimary</item>
    <item name="colorPrimaryDark">@color/color_156084</item>
</style>

<style name="MyCustomTabTextAppearance" parent="TextAppearance.Design.Tab">
    <item name="android:textSize">@dimen/sp14</item>
    <item name="android:textColor">@android:color/white</item>
    <item name="textAllCaps">false</item>
</style>

我已将padding设置为-1dp,甚至将tabGravity填充,但没有任何工作。

此代码曾用于早期版本,但现在如果我降级它,我在TintManager上得到一个没有类def找到错误。

enter image description here

8 个答案:

答案 0 :(得分:7)

设置不同的值或布局参数不起作用,所以我得到的唯一解决方案是在将标签添加到标签布局后添加以下内容,

final ViewGroup test = (ViewGroup)(tabs.getChildAt(0));//tabs is your Tablayout
int tabLen = test.getChildCount();

for (int i = 0; i < tabLen; i++) {
            View v = test.getChildAt(i);
            v.setPadding(0, 0, 0, 0);
        }

答案 1 :(得分:2)

您无需直接处理TabLayout子视图,而可以直接访问TabLayout.Tab视图,并将填充设置为0,就像下面的代码一样。

for (int i = 0; i < tabLayout.getTabCount(); i++) {
    View tabView = tabLayout.getTabAt(i).view;
    tabView.setPadding(0, 0, 0, 0);
}

我正在onCreateView回调中做到这一点,并且效果很好。

答案 2 :(得分:1)

尝试将以下属性添加到TabLayout:

app:tabPaddingStart="-1dp"
app:tabPaddingEnd="-1dp"

希望它能够发挥作用。

答案 3 :(得分:1)

我被困了几个小时,直到找到方法tab.setCustomView(idRes)。从充气转变为充气对我有用。另外,如果要夸大,可以使用TabLayout.TabView作为根视图组。

除此之外,我不确定是否有帮助,但是我在自定义视图布局中使用了minWidth

这就是我wanted

答案 4 :(得分:0)

尝试在LinearLayout中添加TabLayout,如:

 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical">

    <android.support.design.widget.TabLayout
        android:id="@+id/sliding_tabs"
        style="@style/MyCustomTabLayout"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="#FFF" />
</LinearLayout>

在Styles.xml中添加:

 <style name="MyCustomTabLayout" parent="Widget.Design.TabLayout">
    <item name="tabTextAppearance">@style/MyCustomTextAppearance</item>
</style>

<style name="MyCustomTextAppearance" parent="TextAppearance.Design.Tab">
    <item name="textAllCaps">false</item>
</style>

答案 5 :(得分:0)

只需将您的tabLayout传递给此方法即可!

private void setTabLayoutMatchParent(TabLayout tabLayout) {
    final ViewGroup tabLayoutChild = (ViewGroup)(tabLayout.getChildAt(0));
    int tabLen = tabLayoutChild.getChildCount();

    for (int j = 0; j < tabLen; j++) {
        View v = tabLayoutChild.getChildAt(j);
        v.setPadding(0, 0, 0, 0);
    }
}

答案 6 :(得分:0)

在我的情况下,问题是给我用于标签的自定义布局提供了固定高度。 使用match_parent解决了我的问题。

答案 7 :(得分:0)

TabLayout中有一些属性: app:tabPaddingStar t和 app:tabPaddingEnd

您可以将两者都设置为-1,以便在TabLayout的自定义视图中删除填充开始和结束。

<com.google.android.material.tabs.TabLayout
        android:id="@+id/tlEmojis"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        app:tabPaddingStart="-1dp"
        app:tabPaddingEnd="-1dp"
        app:tabMaxWidth="@dimen/dimen_48dp"
        app:tabMode="scrollable" />