Min*_*ntz 5 android bottomnavigationview
如何在BottomNavigationView中的选定项目上应用文本样式?我可以更改颜色,但无法弄清楚如何更改所选菜单项上的字体样式(如字体系列或使其加粗/斜体)。有没有办法只用 XML 来做到这一点?
在上面的示例图片中,我只希望 SEARCH 使用不同的字体和粗体。MESSAGE 和 DASHBOARD 保持不变。
在活动 xml 中:
<android.support.design.widget.BottomNavigationView
android:id="@+id/navigation"
android:layout_width="0dp"
android:layout_height="49dp"
android:background="?android:attr/windowBackground"
android:paddingBottom="5dp"
android:paddingTop="5dp"
app:itemIconTint="@color/bottom_nav_color"
app:itemTextColor="@color/bottom_nav_color"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintHorizontal_bias="0.0"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
app:menu="@menu/navigation"/>
Run Code Online (Sandbox Code Playgroud)
res/menu/navigation.xml
<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android">
<item
android:id="@+id/navigation_search"
android:icon="@drawable/ic_search"
android:title="SEARCH" />
<item
android:id="@+id/navigation_messages"
android:icon="@drawable/ic_question_answer"
android:title="MESSAGES" />
<item
android:id="@+id/navigation_dashboard"
android:icon="@drawable/ic_dashboard_black_24dp"
android:title="DASHBOARD" />
</menu>
Run Code Online (Sandbox Code Playgroud)
res/color/bottom_nav_color.xml
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:state_checked="true" android:color="@color/colorPrimary" />
<item android:state_checked="false" android:color="#666666"/>
</selector>
Run Code Online (Sandbox Code Playgroud)
小智 17
在BottomNavigationView 中有名为itemTextAppearanceActive 和itemTextAppearanceInactive 的属性。只需在 res/values/styles.xml 中创建一个样式:
<style name="BottomNavigation.ActiveItemTextAppearance" parent="TextAppearance.AppCompat">
<item name="android:textStyle">bold</item>
<item name="android:fontFamily">@font/whatever</item>
</style>
Run Code Online (Sandbox Code Playgroud)
然后在BottomNavigationView中引用它:
app:itemTextAppearanceActive="@style/BottomNavigation.ActiveItemTextAppearance"
Run Code Online (Sandbox Code Playgroud)
对于非活动项目,反之亦然。
我认为这里值得一提的是,通过更改文本样式,您不会更改文本颜色。因此仍然需要使用app:itemTextColor
<com.google.android.material.bottomnavigation.BottomNavigationView
...
app:itemIconTint="@color/bottom_nav_color_selector"
app:itemTextColor="@color/bottom_nav_color_selector"
app:itemTextAppearanceInactive="@style/BottomNavigationText"
app:itemTextAppearanceActive="@style/BottomNavigationText.Selected"
tools:menu="@menu/menu_bottom_navigation"
/>
Run Code Online (Sandbox Code Playgroud)
bottom_nav_color_selector在res/colors
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:color="@color/bottom_nav_selected" android:state_checked="true" />
<item android:color="@color/bottom_nav_normal" />
</selector>
Run Code Online (Sandbox Code Playgroud)
风格
<style name="BottomNavigationText" parent="@android:style/TextAppearance"/>
<style name="BottomNavigationText.Selected">
<item name="android:textStyle">bold</item>
</style>
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
3580 次 |
| 最近记录: |