android沉浸式工具类,Android沉浸式状态栏

废话少说 先上效果图

f448c42d67d4

f448c42d67d4

实现代码

在onCreate方法中 加入如下代码实现

//设置状态栏的颜色

StateBarUtil.setStatusBar(this,false, Color.WHITE);

//设置状态栏文字和图标是否使用深色图案

StateBarUtil.setStatusTextColor(true,this);

StateBarUtil工具类

public class StateBarUtil {

/**

* 动态的设置状态栏  实现沉浸式状态栏

*/

public static void initState(View view, Activity activity) {

//当系统版本为4.4或者4.4以上时可以使用沉浸式状态栏

if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) {

view.setVisibility(View.VISIBLE);

//获取到状态栏的高度

int statusHeight =getStatusBarHeight(activity);

try {

if (view.getParent()instanceof LinearLayout) {

//动态的设置隐藏布局的高度

LinearLayout.LayoutParams params = (LinearLayout.LayoutParams) view.getLayoutParams();

params.height = statusHeight;

view.setLayoutParams(params);

}else if (view.getParent()instanceof RelativeLayout) {

//动态的设置隐藏布局的高度

RelativeLayout.LayoutParams params = (RelativeLayout.LayoutParams) view.getLayoutParams();

params.height = statusHeight;

view.setLayoutParams(params);

}else if (view.getParent()instanceof FrameLayout) {

//动态的设置隐藏布局的高度

FrameLayout.LayoutParams params = (FrameLayout.LayoutParams) view.getLayoutParams();

params.height = statusHeight;

view.setLayoutParams(params);

}

}catch (Exception e) {

e.printStackTrace();

Toast.makeText(activity,"调用initState()时布局类型转换错误", Toast.LENGTH_LONG).show();

}

}

}

/**

* @param activity

* @param useThemeStatusBarColor 是否要设置状态栏的颜色,不设置则为透明色

*/

public static void setStatusBar(Activity activity,boolean useThemeStatusBarColor,int color) {

if (checkDeviceHasNavigationBar(activity)) {

//            activity.getWindow().getDecorView().findViewById(android.R.id.content).setPadding(0, 0, 0, StateBarUtil.getNavigationBarHeight(activity));

activity.getWindow().getDecorView().findViewById(android.R.id.content).setPadding(0,0,0,0);

}

if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {//5.0及以上

View decorView = activity.getWindow().getDecorView();

int option = View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN | View.SYSTEM_UI_FLAG_LAYOUT_STABLE;

decorView.setSystemUiVisibility(option);

//根据上面设置是否对状态栏单独设置颜色

if (useThemeStatusBarColor) {

activity.getWindow().setStatusBarColor(color);

}else {

//部分机型的stateBar会有半透明的黑色背景

activity.getWindow().addFlags(WindowManager.LayoutParams.FLAG_DRAWS_SYSTEM_BAR_BACKGROUNDS);

activity.getWindow().clearFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS/* | WindowManager.LayoutParams.FLAG_TRANSLUCENT_NAVIGATION*/);

activity.getWindow().setStatusBarColor(Color.TRANSPARENT);

}

}else if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) {//4.4到5.0  状态栏的颜色以最外层布局的背景色为准。

WindowManager.LayoutParams localLayoutParams = activity.getWindow().getAttributes();

localLayoutParams.flags = (WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS | localLayoutParams.flags);

}

}

/**

* 改变魅族的状态栏字体为黑色,要求FlyMe4以上

*/

private static void processFlyMe(boolean isLightStatusBar, Activity activity) {

WindowManager.LayoutParams lp = activity.getWindow().getAttributes();

try {

Class instance = Class.forName("android.view.WindowManager$LayoutParams");

int value = instance.getDeclaredField("MEIZU_FLAG_DARK_STATUS_BAR_ICON").getInt(lp);

Field field = instance.getDeclaredField("meizuFlags");

field.setAccessible(true);

int origin = field.getInt(lp);

if (isLightStatusBar) {

field.set(lp, origin | value);

}else {

field.set(lp, (~value) & origin);

}

}catch (Exception ignored) {

ignored.printStackTrace();

}

}

/**

* 改变小米的状态栏字体颜色为黑色, 要求MiUi6以上  lightStatusBar为真时表示黑色字体

*/

private static void processMIUI(boolean lightStatusBar, Activity activity) {

Class clazz = activity.getWindow().getClass();

try {

int darkModeFlag;

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);

extraFlagField.invoke(activity.getWindow(), lightStatusBar ? darkModeFlag :0, darkModeFlag);

//开发版 7.7.13 及以后版本采用了系统API,旧方法无效但不会报错,所以两个方式都要加上

if (lightStatusBar) {

setStatusDarkTextColor(activity);

}else {

setStatusTintTextColor(activity);

}

}catch (Exception ignored) {

ignored.printStackTrace();

}

}

private static final StringKEY_MI_VERSION_CODE ="ro.miui.ui.version.code";

private static final StringKEY_MI_VERSION_NAME ="ro.miui.ui.version.name";

private static final StringKEY_MI_INTERNAL_STORAGE ="ro.miui.internal.storage";

/**

* 判断手机是否是小米

*

* @return

*/

private static boolean isMiUi() {

try {

final BuildProperties prop = BuildProperties.newInstance();

return prop.getProperty(KEY_MI_VERSION_CODE,null) !=null

|| prop.getProperty(KEY_MI_VERSION_NAME,null) !=null

|| prop.getProperty(KEY_MI_INTERNAL_STORAGE,null) !=null;

}catch (final IOException e) {

return false;

}

}

/**

* 判断手机是否是魅族

*

* @return

*/

private static boolean isFly() {

try {

final Method method = Build.class.getMethod("hasSmartBar");

return method !=null;

}catch (final Exception e) {

return false;

}

}

/**

* 深色

*

* @param activity

*/

private static void setStatusDarkTextColor(Activity activity) {

if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {//6.0

activity.getWindow().getDecorView().setSystemUiVisibility(View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN | View.SYSTEM_UI_FLAG_LIGHT_STATUS_BAR);

}

}

/**

* 浅色

*

* @param activity

*/

private static void setStatusTintTextColor(Activity activity) {

activity.getWindow().getDecorView().setSystemUiVisibility(

View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN | View.SYSTEM_UI_FLAG_LAYOUT_STABLE);

}

/**

* 设置状态栏文字色值为深色调

*

* @param useDart  是否使用深色调

* @param activity

*/

public static void setStatusTextColor(boolean useDart, Activity activity) {

if (isFly()) {

processFlyMe(useDart, activity);

}else if (isMiUi()) {

processMIUI(useDart, activity);

}else {

if (useDart) {

setStatusDarkTextColor(activity);

}else {

setStatusTintTextColor(activity);

}

}

}

/**

* 通过反射的方式获取状态栏高度

*

* @return

*/

public static int getStatusBarHeight(Context context) {

try {

Class c = Class.forName("com.android.internal.R$dimen");

Object obj = c.newInstance();

Field field = c.getField("status_bar_height");

int x = Integer.parseInt(field.get(obj).toString());

return context.getResources().getDimensionPixelSize(x);

}catch (Exception e) {

e.printStackTrace();

}

return 0;

}

/**

* 判断是否有底部导航栏

*

* @param context

* @return

*/

private static boolean checkDeviceHasNavigationBar(Context context) {

boolean hasNavigationBar =false;

Resources rs = context.getResources();

int id = rs.getIdentifier("config_showNavigationBar","bool","android");

if (id >0) {

hasNavigationBar = rs.getBoolean(id);

}

try {

Class systemPropertiesClass = Class.forName("android.os.SystemProperties");

Method m = systemPropertiesClass.getMethod("get", String.class);

String navBarOverride = (String) m.invoke(systemPropertiesClass,"qemu.hw.mainkeys");

if ("1".equals(navBarOverride)) {

hasNavigationBar =false;

}else if ("0".equals(navBarOverride)) {

hasNavigationBar =true;

}

}catch (Exception e) {

e.getStackTrace();

}

return hasNavigationBar;

}

/**

* 获取底部导航栏高度

*

* @return

*/

private static int getNavigationBarHeight(Context context) {

Resources resources = context.getResources();

int resourceId = resources.getIdentifier("navigation_bar_height","dimen","android");

return resources.getDimensionPixelSize(resourceId);

}

private static class BuildProperties {

private final Propertiesproperties;

private BuildProperties()throws IOException {

properties =new Properties();

properties.load(new FileInputStream(new File(Environment.getRootDirectory(),"build.prop")));

}

public boolean containsKey(final Object key) {

return properties.containsKey(key);

}

public boolean containsValue(final Object value) {

return properties.containsValue(value);

}

public Set> entrySet() {

return properties.entrySet();

}

public String getProperty(final String name) {

return properties.getProperty(name);

}

private String getProperty(final String name,final String defaultValue) {

return properties.getProperty(name, defaultValue);

}

public boolean isEmpty() {

return properties.isEmpty();

}

public Enumeration keys() {

return properties.keys();

}

public Set keySet() {

return properties.keySet();

}

public int size() {

return properties.size();

}

public Collection values() {

return properties.values();

}

private static BuildProperties newInstance()throws IOException {

return new BuildProperties();

}

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,关于Android沉浸、全屏、隐藏底部导航栏、隐藏顶部状态栏和标题栏的工具类,我可以帮你封装。具体实现方法如下: 1. 沉浸: 在 res/values/styles.xml 文件中添加如下代码: ```xml <style name="AppTheme.NoActionBar"> <item name="android:windowNoTitle">true</item> <item name="android:windowFullscreen">true</item> <item name="android:windowContentOverlay">@null</item> <item name="android:windowIsTranslucent">false</item> </style> ``` 然后在清单文件(AndroidManifest.xml)中找到<application>标签,将其修改为以下内容: ```xml <application android:theme="@style/AppTheme.NoActionBar" android:fitsSystemWindows="true"> </application> ``` 2. 全屏: 在 Activity 的 onCreate() 方法中添加如下代码: ```java getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN, WindowManager.LayoutParams.FLAG_FULLSCREEN); ``` 3. 隐藏底部导航栏: 在 res/values/styles.xml 文件中添加如下代码: ```xml <style name="AppTheme.NoActionBar"> <item name="android:windowNoTitle">true</item> <item name="android:windowFullscreen">true</item> <item name="android:windowContentOverlay">@null</item> <item name="android:windowIsTranslucent">false</item> </style> ``` 然后在清单文件(AndroidManifest.xml)中找到<application>标签,将其修改为以下内容: ```xml <application android:theme="@style/AppTheme.NoActionBar" android:fitsSystemWindows="true"> </application> ``` 4. 隐藏顶部状态栏和标题栏: 在 Activity 的 onCreate() 方法中添加如下代码: ```java getWindow().requestFeature(Window.FEATURE_NO_TITLE); getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN, WindowManager.LayoutParams.FLAG_FULLSCREEN); ``` 以上就是封装Android沉浸、全屏、隐藏底部导航栏、隐藏顶部状态栏和标题栏的工具类。希望对你有所帮助。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值