1. 程式人生 > 其它 >Android視訊聊天app原始碼,暗黑模式快速適配

Android視訊聊天app原始碼,暗黑模式快速適配

Android視訊聊天app原始碼,暗黑模式快速適配實現的相關程式碼
很明顯這是切換暗黑模式的方法,在呼叫前必選先適配App的暗黑樣式。
如何適配
1.顏色資源
新建values-night資料夾,將頁面中使用的色值都替換成暗黑模式下的色值。
2.圖片資源
新建mipmap-night/drawable-night資料夾,將頁面中使用的圖片和樣式資源都替換成暗黑模式下的對應資源。
3.狀態列
通過上方程式碼中最後一個方法isDarkMode判斷顯示什麼顏色的狀態列。最好在BaseActivity中操作,否則Activity很多的話很麻煩。
4.呼叫
呼叫上方的方法切換App的暗黑模式。需要注意的點如下:
**需要注意**
1.androidx上直接呼叫即可。support上使用並且在Activity中切換暗黑模式,需要動態呼叫一下activity.recreate()方法。具體原因看下面原始碼:
androidx版本:

/**
* Sets the default night mode. This is the default value used for all components, but can
* be overridden locally via {@link #setLocalNightMode(int)}.
*
* <p>This is the primary method to control the DayNight functionality, since it allows
* the delegates to avoid unnecessary recreations when possible.</p>
*
* <p>If this method is called after any host components with attached
* {@link AppCompatDelegate}s have been 'started', a {@code uiMode} configuration change
* will occur in each. This may result in those components being recreated, depending
* on their manifest configuration.</p>
*
* <p>Defaults to {@link #MODE_NIGHT_FOLLOW_SYSTEM}.</p>
*
* @see #setLocalNightMode(int)
* @see #getDefaultNightMode()
*/ public static void setDefaultNightMode(@NightMode int mode) { switch (mode) { case MODE_NIGHT_NO: case MODE_NIGHT_YES: case MODE_NIGHT_FOLLOW_SYSTEM: case MODE_NIGHT_AUTO_TIME: case MODE_NIGHT_AUTO_BATTERY: if (sDefaultNightMode != mode) { sDefaultNightMode = mode; applyDayNightToActiveDelegates(); }
break; default: Log.d(TAG, "setDefaultNightMode() called with an unknown mode"); break; } }

support版本:

public static void setDefaultNightMode(int mode) {
switch(mode) {
case -1:
case 0:
case 1:
case 2:
sDefaultNightMode = mode;
break;
default:
Log.d("AppCompatDelegate", "setDefaultNightMode() called with an unknown mode");
}
}



對比後可以發現androidx切換暗黑模式後,自己主動呼叫了apply方法,使Activity重建。而support上沒有,僅僅是賦值而已。所以support版本上使用需要自己呼叫activity.recreate()方法。

以上就是 Android視訊聊天app原始碼,暗黑模式快速適配實現的相關程式碼,更多內容歡迎關注之後的文章