Android系統更改狀態列字型顏色
隨著時代的發展,Android的狀態列都不是烏黑一片了,在Android4.4之後我們可以修改狀態列的顏色或者讓我們自己的View延伸到狀態列下面。我們可以進行更多的定製化了,然而有的時候我們使用的是淡色的顏色比如白色,由於狀態列上面的文字為白色,這樣的話狀態列上面的文字就無法看清了。因此本文提供一些解決方案,可以是MIUI6+,Flyme4+,Android6.0+支援切換狀態列的文字顏色為暗色。
修改MIUI
public static boolean setMiuiStatusBarDarkMode(Activity activity, boolean darkmode) { Class<? extends Window> clazz = activity.getWindow().getClass(); try { int darkModeFlag = 0; Class<?> layoutParams = Class.forName("android.view.MiuiWindowManager$LayoutParams"); Field field = layoutParams.getField("EXTRA_FLAG_STATUS_BAR_DARK_MODE"); darkModeFlag = field.getInt(layoutParams); Method extraFlagField = clazz.getMethod("setExtraFlags", int.class, int.class); extraFlagField.invoke(activity.getWindow(), darkmode ? darkModeFlag : 0, darkModeFlag); return true; } catch (Exception e) { e.printStackTrace(); } return false; }
上面為小米官方提供的解決方案,主要為MIUI內建了可以修改狀態列的模式,支援Dark和Light兩種模式。
修改Flyme
public static boolean setMeizuStatusBarDarkIcon(Activity activity, boolean dark) { boolean result = false; if (activity != null) { try { WindowManager.LayoutParams lp = activity.getWindow().getAttributes(); Field darkFlag = WindowManager.LayoutParams.class .getDeclaredField("MEIZU_FLAG_DARK_STATUS_BAR_ICON"); Field meizuFlags = WindowManager.LayoutParams.class .getDeclaredField("meizuFlags"); darkFlag.setAccessible(true); meizuFlags.setAccessible(true); int bit = darkFlag.getInt(null); int value = meizuFlags.getInt(lp); if (dark) { value |= bit; } else { value &= ~bit; } meizuFlags.setInt(lp, value); activity.getWindow().setAttributes(lp); result = true; } catch (Exception e) { } } return result; }
同理使用跟miui類似的方式
修改Android6.0+
Android 6.0開始,谷歌官方提供了支援,在style屬性中配置 android:windowLightStatusBar
即可, 設定為 true 時,當statusbar的背景顏色為淡色時,statusbar的文字顏色會變成灰色,為 false 時同理。
<style name="statusBarStyle" parent="@android:style/Theme.DeviceDefault.Light"> <item name="android:statusBarColor">@color/status_bar_color</item> <item name="android:windowLightStatusBar">false</item> </style>
目前為止,android6.0的市場佔有率還很少,而MIUI和flyme在國內佔有率還算可以,因此,我們可以儘自己所能,適配更多。如果你還有其他的奇淫技巧,也歡迎分享補充。
相關文章
- 短視訊直播系統,Android狀態列設定顏色字型Android
- 搭建自己的直播平臺,更改狀態列的字型顏色
- Flutter改變狀態列字型、狀態列背景顏色、Appbar背景顏色的方式FlutterAPP
- Android實現修改狀態列背景 字型 圖示顏色Android
- android狀態列一體化(改變狀態列的背景顏色)Android
- iOS 修改狀態列StatusBar的顏色及文字顏色iOS
- 短視訊系統,不改變背景顏色的基礎上更改邊框和字型顏色
- Android 沉浸式狀態列 漸變顏色的實現Android
- IOS設定狀態列的背景顏色iOS
- 直播軟體搭建,修改狀態列、導航條顏色及文字顏色
- 直播系統搭建,設定透明背景(去掉蒙層)狀態列顏色不改變
- 線上直播原始碼,單獨修改狀態列顏色原始碼
- 【iOS開發】強制修改iOS狀態列顏色iOS
- Android 隱藏系統狀態列Android
- win10工作列顏色更改方法Win10
- 動態更改svg圖片的顏色SVG
- 直播軟體搭建,狀態列顏色跟隨裝置系統變化而變化
- 線上直播系統原始碼,iOS 根據滑動距離改變狀態列顏色原始碼iOS
- Android的標題欄,狀態列圖示文字顏色及背景動態變化Android
- android更改EditText下劃線顏色Android
- Android 沉浸式狀態列攻略 讓你的狀態列變色吧Android
- Android的RadioButton隨著選中狀態的改變字型顏色也改變Android
- 修改UITabBarItem字型顏色UItabBar
- CSS 顏色與字型CSS
- css 更改svg顏色CSSSVG
- Android開發——Java程式碼動態改變顏色字型的方法AndroidJava
- Win10如何更改CMD命令視窗顏色及字型大小Win10
- iOS button背景顏色狀態設定iOS
- 設定toast的字型顏色和背景顏色AST
- Win10如何修改便籤字型和顏色 win10系統便籤字型和顏色的設定方法Win10
- Win10系統怎麼修改桌面工作列顏色?工作列顏色修改步驟教程Win10
- Android 系統狀態列一體化實現Android
- 設定Toast字型顏色AST
- UIAlertController字型顏色UIController
- 【iOS開發】修改present出來的ViewController狀態列顏色iOSViewController
- 智慧變色T恤 顏色隨運動狀態變
- 短視訊系統,android Switch修改顏色修改樣式滑塊顏色Android
- win10怎麼改變工作列顏色 w10系統如何設定工作列顏色Win10