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
- android更改EditText下劃線顏色Android
- 直播軟體搭建,修改狀態列、導航條顏色及文字顏色
- 直播系統搭建,設定透明背景(去掉蒙層)狀態列顏色不改變
- Android的標題欄,狀態列圖示文字顏色及背景動態變化Android
- 動態更改svg圖片的顏色SVG
- 直播軟體搭建,狀態列顏色跟隨裝置系統變化而變化
- 更改placeholder顏色
- Android開發——Java程式碼動態改變顏色字型的方法AndroidJava
- 線上直播原始碼,單獨修改狀態列顏色原始碼
- 線上直播系統原始碼,iOS 根據滑動距離改變狀態列顏色原始碼iOS
- css 更改svg顏色CSSSVG
- CSS 顏色與字型CSS
- 短視訊系統,android Switch修改顏色修改樣式滑塊顏色Android
- 設定toast的字型顏色和背景顏色AST
- XMind怎麼更改線條顏色?XMind更改線條顏色的方法
- Android 狀態列透明Android
- Win10系統怎麼修改桌面工作列顏色?工作列顏色修改步驟教程Win10
- echarts調節字型顏色Echarts
- win10系統如何更改Word2010頁面背景顏色Win10
- 直播系統原始碼,修改ToolBar的標題的字型顏色大小原始碼
- win10怎麼改變工作列顏色 w10系統如何設定工作列顏色Win10
- Print輸出顏色字型方法
- Win10系統怎麼更改半透明選擇框矩形顏色Win10
- win10 如何更改檔案筐顏色_win10更改檔案筐顏色方法Win10
- Android獲取狀態列高度Android
- react-native android狀態列ReactAndroid
- Android全屏與透明狀態列Android
- CSS 設定字型顏色和大小CSS
- word 中批次替換字型顏色
- markdown字型顏色和背景設定
- CSS 實現字型顏色漸變CSS
- win10 更改控制檯預設顏色方法 win10怎麼更改控制檯顏色Win10