【问题标题】:How to do Tab Host like Iphone in android? [closed]如何在 android 中像 Iphone 一样做 Tab Host? [关闭]
【发布时间】:2020-05-12 07:12:02
【问题描述】:

我是 Android 新手。我正在做android应用程序。我必须在 android 中做 TabHost 看起来像 iPhone,我正在分享图像。请帮我排版。

我尝试了很多,但没有得到确切的解决方案。

【问题讨论】:

  • 如果您要求某人为您编写 TabHost 的整个端口,这对于 Stack Overflow 问题来说太宽泛了。否则,不清楚您在现有解决方案中遇到的问题是什么。

标签: android android-layout styles android-tabhost android-style-tabhost


【解决方案1】:

您可以为选项卡应用自定义形状和选择器。

shape_tab_selected.xml

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle">

    <!-- radius should be half of the desired TabLayout height -->
    <corners android:radius="15dp" />
    <solid android:color="@color/colorWhite"/>

</shape>

shape_tab_un_selected.xml

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle">

    <!-- color of the selected tab -->
    <solid android:color="@android:color/transparent" />


</shape>

selector_tab.xml

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">

    <!-- drawable for selected tab -->
    <item
        android:drawable="@drawable/shape_tab_selected"
        android:state_selected="true"/>

    <!-- drawable for unselected tab -->
    <item
        android:drawable="@drawable/shape_tab_unselected"
        android:state_selected="false"/>

</selector>

在您的活动布局中添加选项卡布局,并将 selector_tab 设置为 tabBackground

<com.google.android.material.tabs.TabLayout 
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@color/colorGray"
app:tabGravity="fill"
app:tabBackground="@drawable/selector_tab"
app:tabIndicatorColor="@android:color/transparent"
app:tabIndicatorHeight="0dp"
app:tabMode="fixed"
app:tabRippleColor="@null"
app:tabSelectedTextColor="@color/colorBlack"
app:tabTextColor="@color/colorBlack"  />

根据您的需要自定义其他属性。您可以找到更多关于 TabLayout here

就是这样。

编码愉快! :)

【讨论】:

  • 感谢您的回答。我在找 Tabhost
  • 您也可以使用标签布局。
  • @Jaymin 我试图应用您的答案,但它没有给我预期的结果,有关更多详细信息,请查看我的问题stackoverflow.com/questions/70002616/…希望您能提供帮助:)
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2013-07-02
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2018-05-18
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多