在plugin新的23.2版本中,我们发现了一个新的主题:
Theme.AppCompat.DayNight.
这个主题可以让我们app实现自由切换白天和夜晚的主题,当然系统中默认的情况是通过系统时间来进行自动的切换的功能。
使用当前主题的时候需要注意的是,当我们在API 14以上使用时,这个主题才会有效果,在API 14以下的主题使用会默认使用light主题。
我们只需要在style文件中进行该主题的声明即可:
<style name="MyTheme" parent="Theme.AppCompat.DayNight">
-- Blah blah -->
style>
通过上述方法,我们就可以在app张使用这个新的特性的了,我们通过使用AppCompatDelegate.setDefaultNightMode() 方法来进行昼夜主题的设置,在其中有四个变量供我们选择:
AppCompatDelegate.setDefaultNightMode() 是一个静态的方法,我们可以在任何时候使用这个方法,需要注意的是,我们设置的值并不会持续的存在,因此你需要每次都进行设置当你的app启动的时候,所以官方推荐的做法是在自定义一个application类,通过静态代码块的方法来设置,当然在activity中设置也是可以的,设置代码如下所示:
static {
AppCompatDelegate.setDefaultNightMode(
AppCompatDelegate.MODE_NIGHT_...);
}
public class MyApplication extends Application {
你可以在任何组件中覆盖上述的4个主题值,通过使用AppCompatDelegate’s setLocalNightMode(),当你只需要特定的组件实现一个主题模式,如一个Activity或者一个Dialog,这是一个非常好用的方法。
请注意,当一个页面的初始化操作已经完成了,这个方法将不会起到任何的作用,在这种情境下,你需要重新去掉用recreate()方法来进行设置,如下图所示:
public class MyActivity extends AppCompatActivity {
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
if (savedInstanceState == null) {
// Set the local night mode to some value
getDelegate().setLocalNightMode(
AppCompatDelegate.MODE_NIGHT_...);
// Now recreate for it to take effect
recreate();
}
}
}
我们可以通过如下方式进行确认:
int currentNightMode = getResources().getConfiguration().uiMode
& Configuration.UI_MODE_NIGHT_MASK;
switch (currentNightMode) {
case Configuration.UI_MODE_NIGHT_NO:
// Night mode is not active, we're in day time
case Configuration.UI_MODE_NIGHT_YES:
// Night mode is active, we're at night!
case Configuration.UI_MODE_NIGHT_UNDEFINED:
// We don't know what mode we're in, assume notnight
}
可能会遇到的问题:
当使用昼夜主题的时候,一定要保证你的ayouts/styles/drawables拥有白天和夜晚的主题。
当我们使用这种主题的时候,我们需要尽可能的去使用主题中的相关属性:
使用这种新特性的时候,有一个非常大的问题存在:WebView,因为他们并不能使用主题相关的属性,你也几乎不能去控制任何网页的style,在其中有很大的概率网页的显示效果跟当前主题拥有很大的冲突性,如WebView白色,而主题是黑色的,所以尽量的去检查这些方面的问题。
为了能够准确的计算到实际中夜晚的切换时间,需要能够定位到地理位置,如果app中已经有了定位的权限,AppCompat会通过LocationManager获取最近时间的地理位置去计算切换时间。
如果app没有相对应的权限,则系统会通过finger-in-the-air fixed(这是个啥)计算值,系统会标准的使用6点为白天起点,晚上10点为夜晚七点来进行切换。
我们可以通过如下方法来进行自定义的昼夜的主题的切换:
res/values/themes.xml
<style name="Theme.AppCompat.DayNight"
parent="Theme.AppCompat.Light" />
res/values-night/themes.xml
<style name="Theme.AppCompat.DayNight"
parent="Theme.AppCompat" />
翻译原文:
https://medium.com/@chrisbanes/appcompat-v23-2-daynight-d10f90c83e94#.t4x6lmu7w