Android 状态栏的设置适配问题详解

Android 状态栏的设置适配问题详解

最近看了很多关于状态栏的问题的处理,总结出处理状态栏分两个方向1>5.0一下2>5.0以上的手机状态栏的设置,,,,,,,,这里说的都是自定义的toolbar,我这里已经把titlebar给隐藏掉了

(1) 关于5.0一下:首先我们需要在res文件下的style中设置,

<!-- Base application theme. -->
<style name="AppTheme" parent="AppTheme.Base">
  <!-- Customize your theme here. -->

</style>
<style name="AppTheme.Base" parent="Theme.AppCompat.Light.NoActionBar">
  <item name="colorPrimary">@color/colorPrimary</item>
  <item name="colorPrimaryDark">@color/colorPrimaryDark</item>
  <item name="colorAccent">@color/colorAccent</item>
  <item name="android:windowBackground">@android:color/white</item>
  <item name="android:windowNoTitle">true</item>
</style>

这里我为什么设置AppTheme.Base  而不直接用AppTheme,因为我继承的是AppCompatActivity,如果直接对titlebar进行隐藏的话不做这个base处理,程序会报错,,,,,,如果你继承的是Activity的话那不会报错 ,,,,为了处理 版本的更高适配,,,,就必须继承   AppCompatActivity ,,,所以在适配5.0一下的系统的时候,就要做一个 base 来过渡 加载 style...

5.0一下的到此就结束了....

(2) 关于5.0以上的版本,,我门要在res下方增加一个 values-21文件,结构如图

置于style中的代码:如下

<style name="AppTheme.NoActionBar">
  <item name="windowActionBar">false</item>
  <item name="windowNoTitle">true</item>
  <item name="android:windowDrawsSystemBarBackgrounds">true</item>
  <item name="android:statusBarColor">@android:color/transparent</item>
</style>

<style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar">
  <item name="colorPrimary">@color/colorPrimary</item>
  <item name="colorPrimaryDark">@color/colorPrimaryDark</item>
  <item name="colorAccent">@color/colorAccent</item>
  <item name="android:windowDrawsSystemBarBackgrounds">true</item>
  <!-- 标题颜色 -->
  <item name="android:textColorPrimary">#000</item>
  <!-- 溢出菜单图标颜色 -->
  <item name="colorControlNormal">@color/white</item>
  <!-- 箭头 -->
  <item name="drawerArrowStyle">@style/DrawerArrowStyle</item>
  <!-- 溢出菜单文字颜色 -->
  <item name="textAppearanceLargePopupMenu">@style/OverflowMenuTextAppearance</item>
  <!-- 菜单项点击selector -->
  <item name="actionBarItemBackground">@drawable/abc_item_background_holo_dark</item>
</style>

<!-- 左边的箭头指示 -->
<style name="DrawerArrowStyle" parent="Widget.AppCompat.DrawerArrowToggle">
  <item name="spinBars">true</item>
  <item name="color">@color/white</item>
</style>

<!-- 溢出菜单文字样式 -->
<style name="OverflowMenuTextAppearance" parent="@style/TextAppearance.AppCompat.Widget.PopupMenu.Large">
  <item name="android:textColor">@color/white</item>
</style>

手机会 根据 你手机的系统版本去加载,这两个style,5.x以上的 加载第二个 ,针对 不同的系统版本修改对应的style..........

当然 这两步足够做适配的了,但是 我们 可能需要进入不同界面 显示不通的状态栏,,,这时候 就要我们用代码控制,修改了,,,,代码 我也直接贴出来 ,,,一下 代码 是 看别人的.......

 (1)  在activity设置 这些,,,

   int color = getResources().getColor(R.color.red);

//    View view = LayoutInflater.from(this).inflate(R.layout.statusbar,null);
    StatusBarManager statusBarManager = new StatusBarManager(this,color);
    //这里如果要移动titlebar,则在布局中指定为include的自定义statusbar的view
    //如果不指定,则调用setStatusBarView();会自动加一个view
//    statusBarManager.setStatusBarView(view);
    statusBarManager.setStatusBarView();

(2)重写 一个类StatusBarManager 进行修改 :

package com.example.administrator.statusbartest;

import android.annotation.TargetApi;
import android.app.Activity;
import android.content.Context;
import android.graphics.Color;
import android.os.Build;
import android.view.View;
import android.view.ViewGroup;
import android.view.Window;
import android.widget.FrameLayout;
import android.widget.LinearLayout;

import java.lang.reflect.Method;

/**
 * Created by Administrator on 2017/3/21.
 */
public class StatusBarManager {

  private static final int BUILD_VERSION_KITKAT = 19;
  private static final int BUILD_VERSION_LOLLIPOP = 21;
  //WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS
  public static final int FLAG_TRANSLUCENT_STATUS = 0x04000000;
  //WindowManager.LayoutParams.FLAG_DRAWS_SYSTEM_BAR_BACKGROUNDS
  public static final int FLAG_DRAWS_SYSTEM_BAR_BACKGROUNDS = 0x80000000;
  private Activity mActivity;
  private View statusBarView;
  private int statusBarHeight;

  //设置状态蓝的颜色值
  int color;

  public StatusBarManager(Activity activity,int color) {
    this.mActivity = activity;
    this.color = color;
    statusBarHeight = getStatusBarHeight(activity);
  }
  public void setStatusBarView(View statusBarView) {
    this.statusBarView = statusBarView;
    setTransparent();
  }
  public void setStatusBarView() {
    setTransparent();
  }
  public int getStatusBarHeight() {
    return statusBarHeight;
  }
  /**
   * 设置状态栏全透明
   *
   */
  private void setTransparent() {
    //4.0没有转太烂
    if (Build.VERSION.SDK_INT < BUILD_VERSION_KITKAT) {
      return;
    }
    if(statusBarHeight <= 0){
      return;
    }

    transparentStatusBar();
    showStatusBarView();
  }
  @TargetApi(19)
  private void showStatusBarView() {
    /**
     * 设置状态栏颜色的位置
     */
    if(statusBarView == null){
      statusBarView = new View(mActivity);
      LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT,
          getStatusBarHeight(mActivity));
      statusBarView.setLayoutParams(params);
      statusBarView.setBackgroundColor(color);
      ViewGroup decorView = (ViewGroup) mActivity.getWindow().getDecorView();
      FrameLayout content = (FrameLayout) decorView.findViewById(android.R.id.content);
      FrameLayout.LayoutParams layoutParams = (FrameLayout.LayoutParams) content.getChildAt(0).getLayoutParams();
      layoutParams.setMargins(0,statusBarHeight,0,0);
      decorView.addView(statusBarView);
    }else{
      ViewGroup.LayoutParams layoutParams = statusBarView.getLayoutParams();
      layoutParams.height = getStatusBarHeight(mActivity);
      statusBarView.setLayoutParams(layoutParams);
      statusBarView.setBackgroundColor(color);
    }
  }

  /**
   * 参考上面注释掉的代码 因为需要用隐藏API 调用方式进行改成反射
   */
  private void transparentStatusBar(){
    Window window = mActivity.getWindow();
    if (Build.VERSION.SDK_INT >= BUILD_VERSION_LOLLIPOP) {
      //不add此条flag 会导致在EMUI3.1(华为)上失效,add这个flag 会导致在其它机型上面添加一个半透明黑条
      window.addFlags(FLAG_TRANSLUCENT_STATUS);
      //下面的代码段是不加上面的flag时,要显示纯色的状态栏时需要加的代码 不用了
/*      window.clearFlags(FLAG_TRANSLUCENT_STATUS);
      window.getDecorView().setSystemUiVisibility(View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN
          | View.SYSTEM_UI_FLAG_LAYOUT_STABLE);
      window.addFlags(FLAG_DRAWS_SYSTEM_BAR_BACKGROUNDS);*/
      //因为需要用隐藏API,没有重新编译5.x版本的android.jar,使用的还是18的api,这里用的反射
      try {
        Class[] argsClass=new Class[]{int.class};
        Method setStatusBarColorMethod = Window.class.getMethod("setStatusBarColor",argsClass);
        setStatusBarColorMethod.invoke(window, Color.TRANSPARENT);
      } catch (Exception e) {
        e.printStackTrace();
      }
    }else{
      window.addFlags(FLAG_TRANSLUCENT_STATUS);
    }
  }
  /**
   * 获取状态栏高度
   *
   * @param context context
   * @return 状态栏高度
   */
  private static int getStatusBarHeight(Context context) {
    if (Build.VERSION.SDK_INT < BUILD_VERSION_KITKAT) {
      return 0;
    }
    // 获得状态栏高度
    int resourceId = context.getResources().getIdentifier("status_bar_height", "dimen", "android");
    return context.getResources().getDimensionPixelSize(resourceId);
  }
  public void setStatusbarVisibility(int visibility){
    if(statusBarView != null) {
      this.statusBarView.setVisibility(visibility);
    }
  }
  public void setColor(int color){
    if(statusBarView != null){
      this.statusBarView.setBackgroundColor(color);
    }
  }

}

做了这些就可以自定义你的状态栏了,,,

(0)

相关推荐

  • Android之沉浸式状态栏的实现方法、状态栏透明

    现在越来越多的软件都开始使用沉浸式状态栏了,下面总结一下沉浸式状态栏的两种使用方法 注意!沉浸式状态栏只支持安卓4.4及以上的版本 状态栏:4.4上是渐变色,5.0上是完全透明,本文模拟器为4.4演示 效果图: 注意!两种方法的区别: 第一种:为顶部栏跟随当前activity的布局文件的背景的颜色,使用方便,不过也有点问题就是,如果有底部虚拟导航键的话,导航键的背景跟顶部的颜色一样,比如: 第二种:是通过设置顶部栏的颜色来显示的,可以解决第一种的不足,比如: 第一种使用方法: 第一.首先在val

  • Android实现个人资料页面头像背景模糊显示包(状态栏)

    最近要实现这样一个效果,然后拿出来与大家分享一下主要的几段代码,希望大家能够用到,与人方便自己方便嘛! 首先: 要实现的是浮动状态栏效果,通过在Activity的onCreate方法中调用这个方法,然后就可以让整个布局浮现在整个手机屏幕之下了,这是我觉着最简单的一种方法了. public static void alphaTask(Activity context) { context.getWindow().requestFeature(Window.FEATURE_NO_TITLE); if

  • Android 状态栏虚拟导航键透明效果的实现方法

    状态栏和虚拟导航键 4.4上半透明,5.0以上可以全透明 先上效果 4.4 半透明效果 5.0及以上 全透明效果 上代码 MainActivity代码 public class MainActivity extends AppCompatActivity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); // 隐藏标题栏 supportReque

  • Android中隐藏状态栏和标题栏的方法汇总(隐藏状态栏、标题栏的五种方法)

      方法一: public class MainActivity extends Activity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); // 隐藏标题栏 requestWindowFeature(Window.FEATURE_NO_TITLE); // 隐藏状态栏 getWindow().setFlags(WindowManager

  • Android 动态显示和隐藏状态栏详解及实例

    Android 动态显示和隐藏状态栏 View类提供了setSystemUiVisibility和getSystemUiVisibility方法,这两个方法实现对状态栏的动态显示或隐藏的操作,以及获取状态栏当前可见性. setSystemUiVisibility(int visibility)方法可传入的实参为: 1. View.SYSTEM_UI_FLAG_VISIBLE:显示状态栏,Activity不全屏显示(恢复到有状态的正常情况). 2. View.INVISIBLE:隐藏状态栏,同时A

  • Android五种隐藏状态栏和标题栏的方法

    Android五种隐藏状态栏和标题栏的方法 方法一: public class MainActivity extends Activity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); // 隐藏标题栏 requestWindowFeature(Window.FEATURE_NO_TITLE); // 隐藏状态栏 getWindow().se

  • Android中使用Notification实现状态栏的通知

    在使用手机时,当有未接来电或者新短消息时,手机会给出响应的提示信息,这些提示信息通常会显示到手机屏幕的状态栏上. Android也提供了用于处理这些信息的类,它们是Notification和NotificationManager.其中,Notification代表的是具有全局效果的通知,而NotificationManager则是用于发送Notification通知的系统服务. 使用Notification和NotificationManager类发送和显示通知也比较简单,大致可以分为以下四个步

  • Android 状态栏的设置适配问题详解

    Android 状态栏的设置适配问题详解 最近看了很多关于状态栏的问题的处理,总结出处理状态栏分两个方向1>5.0一下2>5.0以上的手机状态栏的设置,,,,,,,,这里说的都是自定义的toolbar,我这里已经把titlebar给隐藏掉了 (1) 关于5.0一下:首先我们需要在res文件下的style中设置, <!-- Base application theme. --> <style name="AppTheme" parent="AppT

  • 关于Android Webview 设置Cookie问题详解

    最近遇到一个比较坑爹的问题就是webview里添加第三方H5页面,但是数据获取不到,经过一天的折磨发现cookie值每次都会变,再根据谷歌开发者模式定位,cookie每次应该都是固定,每次变化说明本地的cookie有问题,或者为空. webview有一个CookieManager这个类,他是专门管理cookie的,这个类可以设置一个或多个cookie,而且当你在里面设置好cookie以后接口会自动根据你设置时的url来使用. 一共有两种获取cookie的方法一种是HttpURLConnectio

  • ​​​​​​​Android H5通用容器架构设计详解

    目录 背景 术语对齐 探索 如何优雅地提供接口调用? 怎样封装多个不同类型的H5容器容器? 整体架构 通用容器 框架容器 基础组件 这样的架构能带来什么样的好处? 背景 大家如果经历过Hybrid项目的开发,即项目中涉及到H5与Native之间的交互,那么很有可能会遇到各种各样的H5容器.为什么会有那么多各种各样的容器呢...这也是轮子多的通病了,轮子多到业务方不知道选哪个.当然,也有可能大家压根就不会使用到H5容器,直接用系统WebView就完事儿了,比如我的前东家就是这样做的.那这篇文章的主

  • Android 实现锚点定位思路详解

    相信做前端的都做过页面锚点定位的功能,通过<a href="#head" rel="external nofollow" > 去设置页面内锚点定位跳转. 本篇文章就使用tablayout.scrollview来实现android锚点定位的功能. 效果图: 实现思路 1.监听scrollview滑动到的位置,tablayout切换到对应标签 2.tablayout各标签点击,scrollview可滑动到对应区域 自定义scrollview 因为我们需要监听

  • android尺子的自定义view——RulerView详解

    项目中用到自定义尺子的样式: 原代码在github上找的,地址:https://github.com/QQabby/HorizontalRuler 原效果为 因为跟自己要使用的view稍有不同 所以做了一些修改,修改的注释都放在代码中了,特此记录一下. 首先是一个自定义View: public class RuleView extends View { private Paint paint; private Context context; private int maxValue = 500

  • Android Location服务之LocationManager案例详解

    上次介绍了位置服务中的Geocoder,这次就来介绍一下LocationManager.LocationManager系统服务是位置服务的核心组件,它提供了一系列方法来处理与位置相关的问题,包括查询上一个已知位置.注册和注销来自某个LocationProvider的周期性的位置更新.注册和注销接近某个坐标时对一个已定义的Intent的触发等.今天我们就一起探讨一下LocationManager的简单应用. 在进入正题之前,朋友们需要了解与LocationManager相关的两个知识点: prov

  • Android性能优化大图治理示例详解

    目录 引言 1 自定义大图View 1.1 准备工作 1.2 图片宽高适配 1.3 BitmapRegionDecoder 2 大图View的手势事件处理 2.1 GestureDetector 2.2 双击放大效果处理 2.3 手指放大效果处理 引言 在实际的Android项目开发中,图片是必不可少的元素,几乎所有的界面都是由图片构成的:像列表页.查看大图页等,都是需要展示图片,而且这两者是有共同点的,列表展示的Item数量多,如果全部加载进来势必会造成OOM,因此列表页通常采用分页加载,加上

  • Android 广播大全 Intent Action 事件详解

    具体内容如下所示: Intent.ACTION_AIRPLANE_MODE_CHANGED; //关闭或打开飞行模式时的广播 Intent.ACTION_BATTERY_CHANGED; //充电状态,或者电池的电量发生变化 //电池的充电状态.电荷级别改变,不能通过组建声明接收这个广播,只有通过Context.registerReceiver()注册 Intent.ACTION_BATTERY_LOW; //表示电池电量低 Intent.ACTION_BATTERY_OKAY; //表示电池电

  • Android MTU 值修改的实例详解

    Android MTU 值修改的实例详解 通信术语 最大传输单元(Maximum Transmission Unit,MTU)是指一种通信协议的某一层上面所能通过的最大数据包大小(以字节为单位).最大传输单元这个参数通常与通信接口有关(网络接口卡.串口等). 1.首先使用 adb 命令进入系统,然后 ifconfig 查看可用网络 C:\>adb shell $ su su # ifconfig ifconfig lo Link encap:Local Loopback inet addr:12

  • Android 逐帧动画创建实例详解

    Android 逐帧动画创建实例详解 前言: 我们看早期电影的时候,电影通常是一张一张播放,用我们现在专有名词来说,就是一帧帧来,安卓同样有这样动画效果的编排形式. 那么我们先定义逐帧动画xml文件 <?xml version="1.0" encoding="utf-8"?> <animation-list xmlns:android="http://schemas.android.com/apk/res/android" an

随机推荐