Android: 如何在自定义tabLayout中滚动填充标签?
Android: How to fill tabs with scrolling in custom tabLayout?
我有一个有 6 个标签的 tablayout
。选项卡固定在显示屏中,但其文本未完全显示。我在 中做了解决方案,这样我就可以在这些行中总结它们:
<android.support.design.widget.TabLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:tabMaxWidth="0dp"
app:tabGravity="fill"
app:tabMode="fixed" />
但是并没有解决我的问题。我也在 here 中使用自定义 TabLayout
,但我仍然遇到同样的问题。
这是我的代码:
我将自定义 tablayout
与此 custom_tab.xml
文件一起使用:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="vertical">
<ImageView
android:layout_width="22dp"
android:layout_height="22dp"
android:layout_gravity="center"
android:layout_marginTop="8dp"
android:layout_centerHorizontal="true"
android:id="@+id/tabIcon"/>
<CustomViews.CustomTextView
android:id="@+id/basket_badge"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentTop="true"
android:layout_marginLeft="15dp"
android:background="@drawable/notification_circle"
android:padding="2dp"
android:textColor="#ffffff"
android:textSize="8sp" />
<CustomViews.CustomTextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textColor="@color/tab_inactive"
android:textSize="8sp"
android:layout_centerHorizontal="true"
android:layout_below="@id/tabIcon"
android:layout_marginBottom="2dp"
android:maxLines="1"
android:id="@+id/tabTitle"/>
</RelativeLayout>
第一个 ImageView
显示选项卡图标。接下来的 ImageView
用于徽章,CustomTextView
用于显示选项卡标题。
这是我的布局文件包括 tablayout
:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:orientation="vertical">
<android.support.design.widget.TabLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:tabGravity="fill"
app:tabMode="scrollable"
app:tabMaxWidth="0dp"
android:layoutDirection="rtl"
android:id="@+id/avatar_tabLayout"
app:tabIndicatorColor="@null"
/>
</LinearLayout>
有没有办法设置 tab
宽度和最大存在选项卡大小?或任何其他解决方案?
试着摆脱掉
app:tabGravity="fill"
app:tabMode="fixed"
在你的<android.support.design.widget.TabLayout
替换为app:tabMode="scrollable"
我有一个有 6 个标签的 tablayout
。选项卡固定在显示屏中,但其文本未完全显示。我在
<android.support.design.widget.TabLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:tabMaxWidth="0dp"
app:tabGravity="fill"
app:tabMode="fixed" />
但是并没有解决我的问题。我也在 here 中使用自定义 TabLayout
,但我仍然遇到同样的问题。
这是我的代码:
我将自定义 tablayout
与此 custom_tab.xml
文件一起使用:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="vertical">
<ImageView
android:layout_width="22dp"
android:layout_height="22dp"
android:layout_gravity="center"
android:layout_marginTop="8dp"
android:layout_centerHorizontal="true"
android:id="@+id/tabIcon"/>
<CustomViews.CustomTextView
android:id="@+id/basket_badge"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentTop="true"
android:layout_marginLeft="15dp"
android:background="@drawable/notification_circle"
android:padding="2dp"
android:textColor="#ffffff"
android:textSize="8sp" />
<CustomViews.CustomTextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textColor="@color/tab_inactive"
android:textSize="8sp"
android:layout_centerHorizontal="true"
android:layout_below="@id/tabIcon"
android:layout_marginBottom="2dp"
android:maxLines="1"
android:id="@+id/tabTitle"/>
</RelativeLayout>
第一个 ImageView
显示选项卡图标。接下来的 ImageView
用于徽章,CustomTextView
用于显示选项卡标题。
这是我的布局文件包括 tablayout
:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:orientation="vertical">
<android.support.design.widget.TabLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:tabGravity="fill"
app:tabMode="scrollable"
app:tabMaxWidth="0dp"
android:layoutDirection="rtl"
android:id="@+id/avatar_tabLayout"
app:tabIndicatorColor="@null"
/>
</LinearLayout>
有没有办法设置 tab
宽度和最大存在选项卡大小?或任何其他解决方案?
试着摆脱掉
app:tabGravity="fill"
app:tabMode="fixed"
在你的<android.support.design.widget.TabLayout
替换为app:tabMode="scrollable"