如何实现水平滚动的标签?

Posted

技术标签:

【中文标题】如何实现水平滚动的标签?【英文标题】:How to implement horizontally scrollable tabs? 【发布时间】:2012-03-31 00:34:39 【问题描述】:

我正在尝试实现这个应用程序。目前我已经在上面设计了标签,因为我有超过 7 个标签,它看起来太拥挤了。如何设计它以使 tabwidget 可以水平滚动。我在市场上的少数应用程序上看到过这种设计,但不知道如何在我的应用程序中实现它。

我看到的一个应用程序有一个水平滚动视图,它可以自行滚动,当您按下特定的图像/按钮时,它会显示一些内容。我猜它似乎不是标签。

那么有人知道这个吗?

【问题讨论】:

【参考方案1】:

TabLayout 来自 android 设计库

<android.support.design.widget.TabLayout
    android:id="@+id/categories"
    android:layout_
    android:layout_
    app:tabMode="scrollable" />

【讨论】:

【参考方案2】:

这是一个很好的使用 Horizo​​ntalScrollView 的例子。 http://java.dzone.com/articles/scrolling-tabs-android

【讨论】:

嗨,卡尔文,感谢您的帖子。它对我有用。我为平板电脑开发了一个应用程序。但标签不占用文本的宽度>。希望你明白我的意思它看起来很拥挤我可以为它包含完整文本的选项卡定义一个宽度吗?例如:如果有一个标签显示“用户个人资料”,但它只显示为“用户”【参考方案3】:

请查看 Jake Wharton 的 ViewPager 应用程序。这正是您所需要的。它是一个库项目,因此您必须将其包含在您的项目中。

JakeWharton / Android-ViewPagerIndicator

【讨论】:

嗨,卡尔文,感谢您的帖子。它对我有用。我为平板电脑开发了一个应用程序。但标签不占用文本的宽度>。希望你明白我的意思它看起来很拥挤我可以为它包含完整文本的选项卡定义一个宽度吗?例如:如果有一个标签显示“用户个人资料”,但它只显示为“用户” @roses_r 只需从库的 TabPageIndicator 类中删除 onMeasure(int, int) 方法。它有效。【参考方案4】:
<HorizontalScrollView 
    android:id="@+id/vTabs" 
    android:scrollbars="none" 
    android:layout_ 
    android:layout_alignParentBottom="true"
    android:layout_>
    <LinearLayout 
        android:orientation="horizontal" 
        android:background="@color/main_color_gray_dk" 
        android:layout_ 
        android:layout_>
        <Button 
            android:enabled="false" 
            android:id="@+id/tab1" 
            android:layout_ 
            android:layout_ 
            android:text="@string/popular" />
        <View 
            android:id="@id/view1" 
            android:layout_ 
            android:layout_ />
        <Button 
            android:id="@id/tab2" 
            android:layout_ 
            android:layout_ 
            android:text="@string/newest" />
        <View 
            android:id="@id/view1" 
            android:layout_ 
            android:layout_  />
        <Button 
            android:id="@id/tab3" 
            android:layout_ 
            android:layout_ 
            android:text="@string/distance" />
        <View 
            android:id="@id/view1" 
            android:layout_ 
            android:layout_  />
        <Button 
            android:id="@+id/tab4" 
            android:layout_ 
            android:layout_ 
            android:text="@string/minimum"  />
    </LinearLayout>
</HorizontalScrollView>

根据您的喜好更改文本。 放置在 relatveLayout 和 alignToParentBottom="true" 希望这会有所帮助

【讨论】:

【参考方案5】:

查看此链接:https://dzone.com/articles/scrolling-tabs-android

用 Horizo​​ntalScrollView 包裹你的 TabWidget,标签集将 能够扩展到超出屏幕宽度并且用户可以拖动 根据需要左右选项卡:

<?xml version="1.0" encoding="utf-8"?><TabHost xmlns:android="http://schemas.android.com/apk/res/android"         android:id="@android:id/tabhost"         android:layout_         android:layout_>  <LinearLayout android:orientation="vertical"                android:layout_                android:layout_>    <HorizontalScrollView android:layout_                          android:layout_                          android:fillViewport="true"                          android:scrollbars="none">      <TabWidget android:id="@android:id/tabs"                 android:layout_                 android:layout_/>    </HorizontalScrollView>    <FrameLayout android:id="@android:id/tabcontent"                 android:layout_                 android:layout_ />  </LinearLayout></TabHost>

【讨论】:

以上是关于如何实现水平滚动的标签?的主要内容,如果未能解决你的问题,请参考以下文章

如何实现类似自定义搜索栏的水平滚动小部件?

IOS UIScrollView + UIButton 实现页面和顶部标签页水平滚动效果

如何实现水平滚动flatlist react native

如何在 Google Play 等标签页中启用水平滚动?

delphi6 两个dbgrid如何实现水平滚动条同步滚动?

如何使 UITableView 水平和垂直滚动