android状态栏工具类

package com.example.pengganggui.tuhu_test.cn.Tuhu.util;

import android.annotation.TargetApi;
import android.app.Activity;
import android.graphics.Color;
import android.os.Build;
import android.support.v4.view.ViewCompat;
import android.view.View;
import android.view.ViewGroup;
import android.view.Window;
import android.view.WindowManager;
import android.widget.FrameLayout;

import java.lang.reflect.Field;
import java.lang.reflect.Method;

/**
 * Created by pengganggui on 2018/7/8.
 * android状态栏设置的工具类
 */

public class StatusBarUtil {

    public static final int DEFAULT_STATUS_BAR_ALPHA=0;

    /**
     * 设置状态栏颜色
     * @param activity 需要设置的activity
     * @param color 状态栏颜色值
     */
    public static void setColor(Activity activity,int color){
        setColor(activity,color,DEFAULT_STATUS_BAR_ALPHA);
    }

    /**
     * 设置状态栏颜色
     * @param activity 需要设置的activity
     * @param color 状态栏颜色值
     * @param defaultStatusBarAlpha 状态栏透明度
     */
    private static void setColor(Activity activity, int color, int defaultStatusBarAlpha) {
        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
            activity.getWindow().clearFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);
            //Then call setStatusBarColor.
            activity.getWindow().addFlags(WindowManager.LayoutParams.FLAG_DRAWS_SYSTEM_BAR_BACKGROUNDS);
            //activity.getWindow().setStatusBarColor(calculateStatusColor(color, statusBarAlpha));
            activity.getWindow().setStatusBarColor(color);
        }
    }

    /**
     * 计算状态栏颜色
     * @param color color值
     * @param alpha alpha值
     * @return 最终状态栏的颜色
     */
    private static int calculateStatusColor(int color,int alpha){
        float a=1-alpha/255f;
        int red=color>>16&0xff;
        int green = color >> 8 & 0xff;
        int blue = color & 0xff;
        red = (int) (red * a + 0.5);
        green = (int) (green * a + 0.5);
        blue = (int) (blue * a + 0.5);
        return 0xff << 24 | red << 16 | green << 8 | blue;
    }

    /**
     * 修改状态栏透明
     * @param activity 要修改的activity
     */
    @TargetApi(19)
    public static void transparencyBar(Activity activity){
        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
            Window window = activity.getWindow();
            window.clearFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);
            window.getDecorView().setSystemUiVisibility(View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN
                    | View.SYSTEM_UI_FLAG_LAYOUT_STABLE);
            window.addFlags(WindowManager.LayoutParams.FLAG_DRAWS_SYSTEM_BAR_BACKGROUNDS);
            window.setStatusBarColor(Color.TRANSPARENT);
        } else if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) {
            Window window = activity.getWindow();
            window.setFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS,
                    WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);
        }
    }

    /**
     * 状态栏亮色模式,设置状态栏黑色文字、图标,
     * 适配4.4以上版本MIUIV、Flyme和6.0以上版本其他Android
     *
     * @return 1:MIUUI 2:Flyme 3:android6.0
     */
    public static int StatusBarLightMode(Activity activity) {
        int result = 0;
        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) {
            if (MIUISetStatusBarLightMode(activity, true)) {
                result = 1;
            } else if (FlymeSetStatusBarLightMode(activity.getWindow(), true)) {
                result = 2;
            } else if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
                activity.getWindow()
                        .getDecorView()
                        .setSystemUiVisibility(
                                View.SYSTEM_UI_FLAG_LIGHT_STATUS_BAR);//View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN|
                result = 3;
            }
        }
        return result;
    }

    /**
     * 需要MIUIV6以上
     *
     * @param dark 是否把状态栏文字及图标颜色设置为深色
     * @return boolean 成功执行返回true
     */
    public static boolean MIUISetStatusBarLightMode(Activity activity, boolean dark) {
        boolean result = false;
        Window window = activity.getWindow();
        if (window != null) {
            Class clazz = window.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);
                if (dark) {
                    extraFlagField.invoke(window, darkModeFlag, darkModeFlag);//状态栏透明且黑色字体
                } else {
                    extraFlagField.invoke(window, 0, darkModeFlag);//清除黑色字体
                }
                result = true;

                if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
                    //开发版 7.7.13 及以后版本采用了系统API,旧方法无效但不会报错,所以两个方式都要加上
                    if (dark) {
                        activity.getWindow()
                                .getDecorView()
                                .setSystemUiVisibility(
                                        View.SYSTEM_UI_FLAG_LIGHT_STATUS_BAR);//View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN|
                    } else {
                        activity.getWindow().getDecorView().setSystemUiVisibility(View.SYSTEM_UI_FLAG_VISIBLE);
                    }
                }
            } catch (Exception e) {

            }
        }
        return result;
    }


    /**
     * 设置状态栏图标为深色和魅族特定的文字风格
     * 可以用来判断是否为Flyme用户
     *
     * @param window 需要设置的窗口
     * @param dark 是否把状态栏文字及图标颜色设置为深色
     * @return boolean 成功执行返回true
     */
    public static boolean FlymeSetStatusBarLightMode(Window window, boolean dark) {
        boolean result = false;
        if (window != null) {
            try {
                WindowManager.LayoutParams lp = window.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);
                window.setAttributes(lp);
                result = true;
            } catch (Exception e) {

            }
        }
        return result;
    }


    /**
     * 已知系统类型时,设置状态栏黑色文字、图标。
     * 适配4.4以上版本MIUIV、Flyme和6.0以上版本其他Android
     *
     * @param type 1:MIUUI 2:Flyme 3:android6.0
     */
    public static void StatusBarLightMode(Activity activity, int type) {
        if (type == 1) {
            MIUISetStatusBarLightMode(activity, true);
        } else if (type == 2) {
            FlymeSetStatusBarLightMode(activity.getWindow(), true);
        } else if (type == 3) {
            activity.getWindow()
                    .getDecorView()
                    .setSystemUiVisibility(
                            View.SYSTEM_UI_FLAG_LIGHT_STATUS_BAR);//View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN|
        }
    }

    /**
     * 状态栏暗色模式,清除MIUI、flyme或6.0以上版本状态栏黑色文字、图标
     */
    public static void StatusBarDarkMode(Activity activity, int type) {
        if (type == 1) {
            MIUISetStatusBarLightMode(activity, false);
        } else if (type == 2) {
            FlymeSetStatusBarLightMode(activity.getWindow(), false);
        } else if (type == 3) {
            activity.getWindow().getDecorView().setSystemUiVisibility(View.SYSTEM_UI_FLAG_VISIBLE);
        }
    }


    /**
     * 设置状态栏为透明
     * @param activity
     */
    public static void setStatusBarTranslucent(Activity activity) {
        Window window = activity.getWindow();
        ViewGroup contentView = activity.findViewById(Window.ID_ANDROID_CONTENT);
        if (null != contentView) {
            View childView = contentView.getChildAt(0);
            if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
                // 设置透明状态栏,这样才能让 ContentView 向上
                window.addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);

                // 需要设置这个 flag 才能调用 setStatusBarColor 来设置状态栏颜色
                window.addFlags(WindowManager.LayoutParams.FLAG_DRAWS_SYSTEM_BAR_BACKGROUNDS);
                // 设置状态栏颜色
                window.setStatusBarColor(Color.TRANSPARENT);
                if (childView != null) {
                    // 注意不是设置 ContentView 的 FitsSystemWindows, 而是设置 ContentView 的第一个子 View .
                    // 使其不为系统 View 预留空间.
                    ViewCompat.setFitsSystemWindows(childView, false);
                }
            } else if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) {
                if (childView != null) {
                    ViewCompat.setFitsSystemWindows(childView, false);
                }

                int statusBarHeight = contentView.getTop();
                // 需要设置这个 flag 才能设置状态栏
                window.addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);
                // 避免多次调用该方法时,多次移除了 View
                if (childView != null && childView.getLayoutParams() != null
                        && childView.getLayoutParams().height == statusBarHeight) {
                    // 移除假的 View.
                    contentView.removeView(childView);
                    childView = contentView.getChildAt(0);
                }
                if (childView != null) {
                    FrameLayout.LayoutParams lp = (FrameLayout.LayoutParams) childView.getLayoutParams();
                    // 清除 ChildView 的 marginTop 属性
                    if (lp != null && lp.topMargin >= statusBarHeight) {
                        lp.topMargin -= statusBarHeight;
                        childView.setLayoutParams(lp);
                    }
                }
            } else if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.JELLY_BEAN) {
                window.getDecorView().setSystemUiVisibility(
                        View.SYSTEM_UI_FLAG_LAYOUT_STABLE
                                | View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN);
            }
        }
    }
}
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Android通知工具是指用于管理和展示Android设备上通知的应用程序或服务。通知Android系统中用于显示各种通知的一个区域,用户可以从通知中查看和操作通知消息。 通知工具通常具有以下功能: 1. 通知管理:可以管理并展示来自各个应用程序的通知消息,包括短信、电话、社交媒体等各种类型的通知。用户可以通过通知工具集中查看和处理这些通知,提高管理效率。 2. 快捷操作:通知工具可以提供一些快捷操作,例如回复短信、拒接来电、播放音乐等,用户可以直接在通知中完成这些操作,无需打开具体的应用程序。 3. 状态显示:通知工具可以显示设备的一些状态信息,例如电量、网络连接状态、音量等。用户可以通过通知随时查看这些状态信息,方便实时监控设备的运行情况。 4. 个性化设置:通知工具通常支持各种个性化设置,用户可以自定义通知的样式、主题、通知显示方式等,以满足个人需求和喜好。 5. 通知过滤:通知工具可以根据用户的设置对通知进行过滤,屏蔽一些不重要的通知或者将其归类整理。这样可以减少通知的干扰,提高通知的有效性。 总之,Android通知工具为用户提供了一个方便管理和操作通知的工具,帮助用户更高效地处理来自各个应用程序的通知消息,使得使用Android设备更加便捷和舒适。 ### 回答2: Android通知工具是一个用于在Android设备上显示通知的功能。通知工具可以在应用程序运行时发送各种类型的通知,包括文本、图标、声音、振动等。通过使用通知工具,用户可以接收到来自应用程序的重要信息和提示,而无需打开应用程序。 通知工具可以帮助应用程序在后台运行或用户退出应用程序后继续发送通知。它提供了一种简单而高效的方式来向用户发送通知,帮助用户及时了解到关键信息。 通知工具还可以支持用户与通知进行交互。用户可以通过点击通知来打开相关的应用程序或执行其他操作。此外,通知工具还提供了通知的展示方式的设置选项,用户可以根据自己的偏好设置通知的显示样式。 在Android开发中,通知工具是一个很重要的模块。开发人员可以通过使用Android提供的通知相关的API,轻松地创建和发送通知。他们可以定义通知的标题、内容、图标、声音等属性,并设置通知的行为和交互。 总的来说,Android通知工具为应用程序提供了一种方便、快捷的方式来与用户进行沟通和交互。通过使用通知工具,应用程序可以将重要信息推送给用户,并提供与用户的实时互动。这使得Android设备的用户体验更加完善和高效。 ### 回答3: Android通知工具是一种用于在Android设备上显示通知的工具。在Android操作系统中,通知是一个重要的功能,它可以显示各种通知,如消息、提醒、更新等。通知工具提供了一种便捷的方式来管理和显示这些通知通知工具可以帮助用户及时了解到重要的信息,无论是收到短信、电话、邮件,还是其他应用的通知,都可以通过通知工具进行展示。用户可以通过下拉通知来查看通知的详细内容,并进行相应的操作,例如回复短信、接听电话、打开邮件等。 通知工具还可以提供一些额外的功能,如展示音乐播放器控制按钮、显示天气信息、提供快捷操作按钮等。这些功能可以提升用户体验,让用户方便地控制和获取信息。 通知工具还支持通知的管理和设置。用户可以根据自己的喜好和需求,对通知进行分类、过滤和优先级设置。用户还可以通过设置来自定义通知的样式、铃声和震动模式等。 总之,Android通知工具是一种非常实用的工具,它可以帮助用户及时了解到各种通知,并提供了方便的操作和管理功能。通过使用通知工具,用户可以更好地掌控自己的Android设备和获取重要的信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值