android 快速实现夜间模式

2019-05-18 12:38:41

参考文章  android 快速实现夜间模式

最近项目中遇到了一个问题,夜间模式在8.0以上的手机中不起作用,查看了一下原因,是夜间模式实现方法的问题。分两种情况介绍一下


先看一下运行效果:




第一种 是目前项目中用到的,是以前的开发人员写的,存在一些问题(不兼容8.0以上的版本),已解决


第二种是Support Library 中自带的一种方法。


 


第一种:

第一步 需要添加夜间模式资源,以-night为后缀

日间模式                    对应                  夜间模式


drawable                                              drawable-night


values                                                     values-night


drawable-hdpi                                     drawable-night-hdpi


。。。


目录结构如下:




例如:color 的色值:在不同的value 下,命名相同,但是色值可以随意设置,适应不同的模式


图片,边框样式等也是一样的道理。




第二步 在application 中添加 切换方法:

public class MyApplication extends Application {

    private static Resources sRes;

    @Override

    public void onCreate() {

        super.onCreate();

        init(this);

    }

    public static void init(Context context) {

        sRes = context.getResources();

    }

    /**

     * 切换 夜间模式

     * @param on true 夜间, false  日间

     */

    public static void updateNightMode(boolean on) {

        DisplayMetrics dm = sRes.getDisplayMetrics();

        Configuration config = sRes.getConfiguration();

        config.uiMode &= ~Configuration.UI_MODE_NIGHT_MASK;

        config.uiMode |= on ? Configuration.UI_MODE_NIGHT_YES : Configuration.UI_MODE_NIGHT_NO;

        sRes.updateConfiguration(config, dm);

    }

}

第三步 调用方法修改主题:

 MyApplication.updateNightMode( false/true );  // 需要保存当前主题的状态。根据状态,进行切换


切换完后 刷新 


recreate();// 会有闪屏,可以使用下面的方法

或者


finish();

startActivity(new Intent( this, this.getClass()));

overridePendingTransition(0, 0);

注意:以上方法只适合 8.0以下的手机,需要兼容的话,就需要用到第二种方法了

 


第二种:

使用Support Library 23.2中新添加的夜间模式主题,并且可以向下兼容最低api 14的,基本满足绝大多数的手机。


介绍:

设置 当前的模式


        AppCompatDelegate.setDefaultNightMode(int mode);


它有四个可选值,分别是:

                    MODE_NIGHT_NO: 使用亮色(light)主题,不使用夜间模式

                    MODE_NIGHT_YES:使用暗色(dark)主题,使用夜间模式

                    MODE_NIGHT_AUTO:根据当前时间自动切换 亮色(light)/暗色(dark)主题

                    MODE_NIGHT_FOLLOW_SYSTEM(默认选项):设置为跟随系统,通常为 MODE_NIGHT_NO


使用方法:

这种夜间模式只需要按照以下几部就可以使用了:


第一步:

添加夜间模式目录,和第一种方法的第一步一致


第二步:

需要   com.android.support:appcompat 23.2及以上的版本


及 在app  的bulid.gradle 中添加(一般创建项目的时候会自动添加):


dependencies {

    implementation 'com.android.support:appcompat-v7:27.1.1'

 

}

第三步:

Activity须继承AppCompatActivity   (一定要继承,否则无效)


第四步:

在 values—>styles.xml 中 修改你的主题样式,将你的主题 parent  改为  Theme.AppCompat.DayNight 或者 它的子类


如: Theme.AppCompat.DayNight.NoActionBar


    <style name="AppTheme" parent="Theme.AppCompat.DayNight.NoActionBar">

 

        <!-- Customize your theme here. -->

        <item name="colorAccent">@color/colorAccent</item>

 

    </style>

第四步:

切换主题


建议在application  onCreate 中切换,


AppCompatDelegate.setDefaultNightMode(int mode);


注意:主题的当前模式 ,需要保存到本地( 可以通过SharePreference),代码中还获取不到当前的模式


  • 2020-01-17 21:20:06

    Nuxt重要点介绍和记录

    nuxt.js简单的说是Vue.js的通用框架,最常用的就是用来作SSR(服务器端渲染).Vue.js是开发SPA(单页应用)的,Nuxt.js这个框架,用Vue开发多页应用,并在服务端完成渲染,可以直接用命令把我们制作的vue项目生成为静态html。

  • 2020-01-17 21:21:42

    nuxtjs打包优化

    然后你再使用 npm run build 打包的时候,会弹出一个界面 当然了,它第一次出来的时候我立马关了,这啥玩意???别着急你慢慢的品,慢慢的看。 原来 这是打包后的JS,面积的大小就是体积的大小。这样我们一目了然的看到了到底那里大了

  • 2020-01-17 23:21:54

    webpack打包优化之外部扩展externals的实际应用

    使用vue-cli创建项目,使用webpack打包。其中,有一个webpack优化webpack.optimize.CommonsChunkPlugin,它会将node_modules中的必需模块提取到vendor文件中,项目开发中,增加第三方模块,比如element-ui、vue-echarts等,vendor的包都会增大。这个时候,就需要考虑减轻vendor包的大小,增加构建速度。我们可以使用webpack的外部扩展(externals)功能。

  • 2020-01-18 01:26:59

    anyProxy使用注意事项

    anyproxy-ca 运行这个命令,如果是mac电脑他会提醒你去通过证书。

  • 2020-01-18 08:54:06

    利用localStorage来处理你的Javascript脚本错误

    localStorage作为HTML5中的新特性,它的出现可以说对于前端性能体验来讲可以获得相当大的改善。存储一些用户经常用到而又不是涉及隐私和安全的东西,的确是一个非常好的选择。下面分享一下用localStorage来处理客户端代码错误的例子来了解一下它的用途吧。

  • 2020-01-20 08:29:14

    js如何生成唯一标识符UUID

    在JavaScript中生成uuid的代码如下,这个函数会直接给你返回uuid,所以直接调用,然后用变量接收即可!