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),代码中还获取不到当前的模式


  • 2019-08-06 15:30:08

    小程序展示富文本

    然而rich-text有个问题,它不能够给内联img设置宽度100%,这样图片就容易溢出屏幕。我们只能在后台返回富文本的时候对图片的img标签进行格式化。或者前端进行格式化也行,我赞成使用后端,因为很多种情况我们不一定都能想得到。

  • 2019-08-07 09:07:32

    最全的Service Worker讲解

    Service Worker 最主要的特点是:在页面中注册并安装成功后,运行于浏览器后台,不受页面刷新的影响,可以监听和截拦作用域范围内所有页面的 HTTP 请求。 基于 Service Worker API 的特性,结合 Fetch API、Cache API、Push API、postMessage API 和 Notification API,可以在基于浏览器的 web 应用中实现如离线缓存、消息推送、静默更新等 native 应用常见的功能,以给 web 应用提供更好更丰富的使用体验。

  • 2019-08-07 09:09:19

    windows系统下定时关闭程序

    其中xxx.exe是你要关闭的进程中运行的exe,可以ctrl+alt+del打开任务管理器,进到详细信息查看 然后把.txt文件后缀改成.bat(此时要在查看一栏勾上文件拓展名,要不还是txt文档)

  • 2019-08-07 09:16:43

    一个比较完美的PWA例子

    但就目前来讲,PWA是Google主推的一项技术标准,FireFox,Chrome以及一些基于Blink的浏览器已经支持渐进式Web应用了,Edge上对渐进式Web应用的支持还在开发。Apple公司也表示会考虑在自己Safari支持PWA。然而这项功能已经进入了WebKit内核的五年计划中。长期来看,对浏览器兼容性的支持方面应该已经不算太大问题了。况且在现阶段,在不支持渐进式Web应用的浏览器中,你的应用也只是无法使用渐进式Web应用的离线功能而已,除此之外的功能均可以正常使用。

  • 2019-08-07 09:57:48

    spring data jpa 实体类中字段不与数据库表映射

    当我们使用spring data jpa开发的时候,会将实体类中的成员变量与表中的字段一一对应,当我们在实体类中加上一个不与数据库表一一对应的成员变量的时候,此时我们只要在这个成员变量上加上注解@Transient @

  • 2019-08-07 17:16:53

    如何在 Node.js 中使用 import / export 的三种方法

    因为一些历史原因,虽然 Node.js 已经实现了 99% 的 ES6 新特性,不过截止 2018.8.10,How To Enable ES6 Imports in Node.JS 仍然是老大难问题,下面我来介绍三种方法可以让我们在 Node.js 中使用 import/export 。

  • 2019-08-13 08:56:46

    nuxtjs组合element

    添加elementUI 插件,plugins->ele.js,代码如下

  • 2019-08-13 20:06:42

    修改 Nginx 进程最大可打开文件数(worker_processes和worker_connections)

    worker_processes:操作系统启动多少个工作进程运行Nginx。注意是工作进程,不是有多少个nginx工程。在Nginx运行的时候,会启动两种进程,一种是主进程master process;一种是工作进程worker process。例如我在配置文件中将worker_processes设置为4,启动Nginx后,使用进程查看命令观察名字叫做nginx的进程信息,我会看到如下结果: