ToolBar、沉浸式状态栏的应用(简单粗暴)

原创 2016年08月28日 15:53:40

一、toolbar的应用
依赖: compile ‘com.android.support:design:24.1.0’
styles.xml文件

 <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>
    </style>

这一种,不用修改清单文件,只需修改它的父类为NoActionBar;

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

    </style>

    <style name="AppBaseTheme" parent="Theme.AppCompat.Light.NoActionBar">
        <item name="colorPrimary">@color/colorPrimary</item>
        <item name="colorPrimaryDark">@color/colorPrimaryDark</item>
        <item name="colorAccent">@color/colorAccent</item>
    </style>

这也不用修改清单文件,修改它的父类;

 <style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
        <!-- Customize your theme here. -->
        <item name="colorPrimary">@color/colorPrimary</item>
        <item name="colorPrimaryDark">@color/colorPrimaryDark</item>
        <item name="colorAccent">@color/colorAccent</item>
    </style>

 <style name="AppBaseTheme" parent="Theme.AppCompat.Light.NoActionBar">
        <item name="colorPrimary">@color/colorPrimary</item>
        <item name="colorPrimaryDark">@color/colorPrimaryDark</item>
        <item name="colorAccent">@color/colorAccent</item>
    </style>

这种原来的文件不变,自己添加个主题,这必须在清单文件中修改android:theme="@style/AppBaseTheme"

二、沉浸式状态栏:(注意一下,沉浸式状态只适用于Android 4.4 以上,不然没效果)网站上找了一堆,都比较麻烦,一个简单布局都写得那么麻烦谁还用,简单的最实用。
Activity:

 if(Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) {
            //透明状态栏
            getWindow().addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);

        }

这样还不够,另外在你的布局文件父布局加上这两句话:

  android:fitsSystemWindows="true"
    android:clipToPadding="true"

这样就可以了,当然想看到效果,要和你的toolbar颜色设置一样,否则默认白色。
这里写图片描述
上边这种顶部会出现黑边,如果不想要这种效果的话,可以改成这样

if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
            Window window = getWindow();
            window.clearFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS
                    | WindowManager.LayoutParams.FLAG_TRANSLUCENT_NAVIGATION);
            window.getDecorView().setSystemUiVisibility(View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN
                    | View.SYSTEM_UI_FLAG_LAYOUT_HIDE_NAVIGATION
                    | View.SYSTEM_UI_FLAG_LAYOUT_STABLE);
            window.addFlags(WindowManager.LayoutParams.FLAG_DRAWS_SYSTEM_BAR_BACKGROUNDS);
            window.setStatusBarColor(Color.TRANSPARENT);
            window.setNavigationBarColor(Color.TRANSPARENT);
        }
版权声明:本文为博主原创文章,未经博主允许不得转载。

toolbar实现沉浸式状态栏

  • 2017年04月30日 10:48
  • 19.65MB
  • 下载

画廊etiennelawlor imagegallery真正全屏,使用隐藏状态栏和沉浸式浮动Toolbar

画廊etiennelawlor imagegallery真正全屏,使用隐藏状态栏和沉浸式浮动Toolbar
  • do168
  • do168
  • 2016年06月07日 11:01
  • 388

TOOLBAR和沉浸式状态栏入门

简单toolbar 步骤 首先写好style false true     styles.xml(v19) ...

优雅地实现 Android Toolbar 及沉浸式状态栏(二)

前面一篇已经简单地介绍了Toolbar及沉浸式状态栏的实现方式,这篇作为对前面的一些补充,希望能够帮助到你 文字介绍不多,主要内容在注释里写明了,仔细阅读代码应该能很好地理解。使用Toolbar需要...

toolbar实现沉浸式状态栏

效果图: 前一篇说的是三步实现状态栏背景颜色的修改,那样不能动态实现,局限性太大了。用toolbar就可以实现。现在主流APP,首页都是1个activity+多个fragment的形式,除个性...

优雅地实现 Android Toolbar 及沉浸式状态栏

在某些系统上主页面和状态栏存在两种极不搭的画风,处女座看了一定会很难受,不要问我怎么知道的,你猜啊!~猜啊~ 前戏有了,哦不,需求,那么现在直入主题,让我们帮助处女座脱离苦海。 例子用了Toolb...

DrawerLayout侧滑菜单、Toolbar和沉浸式状态栏的使用

最近在开发中需要用到侧滑菜单,以前使用的SlidingMenu,但似乎已经被Google淘汰了(过时了),于是乎使用了DrawerLayout来实现,既然是在项目使用的,那么Toolbar和沉浸式状态...

Toolbar实现沉浸式状态栏

沉浸式状态栏实现方式方法一:调整状态栏颜色和Toolbar背景色相同theme中设置 @android:color/white 但是此方法在使用DrawerLayout侧滑时,toolbar颜色会变...

Android,沉浸式状态栏,状态栏以及Toolbar颜色分开设置

这里的状态栏和Toolbar 颜色是分开的,请看代码 :    首先 :    /** * 设置状态栏颜色 */ public class StatusBarUtils { ...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:ToolBar、沉浸式状态栏的应用(简单粗暴)
举报原因:
原因补充:

(最多只允许输入30个字)