網站首頁 編程語言 正文
前言
好久不見,計蒙回來了,最近有粉絲投稿了幾個關于BottomNavigationView的一些問題,今天發篇比較詳細的文章總結一下,希望能夠對你有所幫助。
提示:以下是本篇文章正文內容,下面案例可供參考
一、初識BottomNavigationView
常用屬性:
app:itemTextColor 文字的顏色,可以通過selector來控制選中和未選中的顏色
app:itemIconTint 圖標的顏色,可以通過selector來控制選中和未選中的顏色
app:itemIconSize 圖標大小,默認24dp
app:iteamBackground 背景顏色,默認是主題的顏色
app:itemRippleColor 點擊后的水波紋顏色
app:itemTextAppearanceActive 設置選中時文字樣式
app:itemTextAppearanceInactive 設置默認的文字樣式
app:itemHorizontalTranslationEnabled 在label visibility 模式為
selected
時item水平方向移動app:elevation 控制控件頂部的陰影
app:labelVisibilityMode 文字的顯示模式
app:menu 指定菜單xml文件(文字和圖片都寫在這個里面)
在Android Studio創建新項目時,會有很多小伙伴在模塊中選擇此類型的Activity,如下。
項目運行效果圖如下:
二、BottomNavigationView中的顏色關鍵實現代碼解析(舉例)
是如何定義的顏色的。
關鍵代碼如下(獲取xml中的屬性):
ColorStateList backgroundTint = MaterialResources.getColorStateList( context, a, R.styleable.BottomNavigationView_backgroundTint); DrawableCompat.setTintList(getBackground().mutate(), backgroundTint); setLabelVisibilityMode( a.getInteger( R.styleable.BottomNavigationView_labelVisibilityMode, LabelVisibilityMode.LABEL_VISIBILITY_AUTO)); setItemHorizontalTranslationEnabled( a.getBoolean(R.styleable.BottomNavigationView_itemHorizontalTranslationEnabled, true)); int itemBackground = a.getResourceId(R.styleable.BottomNavigationView_itemBackground, 0); if (itemBackground != 0) { menuView.setItemBackgroundRes(itemBackground); } else { ColorStateList itemRippleColor = MaterialResources.getColorStateList( context, a, R.styleable.BottomNavigationView_itemRippleColor); setItemRippleColor(itemRippleColor); }
可以很明顯的看到起到關鍵作用的是ColorStateList,而處理好這個傳入的參數即可解決顏色問題。
三、開始解決問題
1.如何修改圖標顏色
這里提供兩種解決方式
xml中解決:
首先:新建一個selector_color文件,設置兩種狀態的顏色
<?xml version="1.0" encoding="utf-8"?> <selector xmlns:android="http://schemas.android.com/apk/res/android"> <item android:color="#63F7DE" android:state_checked="true" /> <item android:color="@android:color/black" android:state_checked="false"/> </selector>
然后在BottomNavigationView中調用此文件
app:itemIconTint="@color/selector_color"
java文件中解決:
傳入一個自定義的ColorStateList。
并將其以參數傳入view中
navView.setItemIconTintList();
2.如何使圖標點擊顏色不改變
在java中調用其setItemIconTintList,傳參為空即可
navView.setItemIconTintList(null);
3.如何使點擊時字體不改變大小
在dimens文件中設置以下兩個的值為同一大小即可
//防止字體出現變大效果 <dimen name="design_bottom_navigation_active_text_size">10dp</dimen> <dimen name="design_bottom_navigation_text_size">10dp</dimen>
4.當你的圖標是多色系時
在java中調用其setItemIconTintList,傳參為空
navView.setItemIconTintList(null);
然后設置圖片狀態的item中drawable的選擇,舉例如下
<?xml version="1.0" encoding="utf-8"?> <selector xmlns:android="http://schemas.android.com/apk/res/android"> <item android:drawable="@drawable/ic_home_black_24dp" android:state_checked="true" /> <item android:drawable="@drawable/ic_home_black_false_24dp" android:state_checked="false"/> </selector>
最后在menu中調用此文件即可。舉例文件名為:ic_home
<menu xmlns:android="http://schemas.android.com/apk/res/android"> <item android:id="@+id/navigation_home" android:icon="@drawable/ic_home" android:title="@string/title_home" /> <item android:id="@+id/navigation_dashboard" android:icon="@drawable/ic_dashboard_black_24dp" android:title="@string/title_dashboard" /> <item android:id="@+id/navigation_notifications" android:icon="@drawable/ic_notifications_black_24dp" android:title="@string/title_notifications" /> </menu>
為了節省時間,只修改了第一個,效果如下
5.不想要ActionBar
1.將xml中paddingTop這行刪除
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" android:id="@+id/container" android:layout_width="match_parent" android:layout_height="match_parent" android:paddingTop="?attr/actionBarSize">
2.在java中將以下這行刪除
NavigationUI.setupActionBarWithNavController(this, navController, appBarConfiguration);
3.設置APP樣式為NoActionBar
<style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar">
四、總結
原文鏈接:https://blog.csdn.net/qq_42761395/article/details/122428110
相關推薦
- 2023-01-10 Docker調度器Kubernetes使用過程_docker
- 2022-09-21 使用注解實現Redis緩存功能_Redis
- 2022-07-27 Python中的?enumerate和zip詳情_python
- 2022-03-28 快速創建React項目并配置webpack_React
- 2022-05-17 SQL?Server實現分頁方法介紹_MsSql
- 2023-12-08 maven中mybatis-generator插件執行報錯:Cannot resolve class
- 2022-08-30 MongoDB數據庫權限管理詳解_MongoDB
- 2022-10-10 Android實現藍牙串口通訊_Android
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支