zoukankan      html  css  js  c++  java
  • android 动态控制状态栏显示和隐藏

    方法一:(经试验无效,但网上广为流传,也许是我使用方法不当,有待进一步验证……)

    android想要应用运行时全屏有一种方法是在activity的onCreat方法中加入如下代码:
    getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN, 
                    WindowManager.LayoutParams.FLAG_FULLSCREEN);

    并且需要在setContentView()之前,否则无效过。从这么多的苛刻条件可以看出这种方法无法满足动态控制。

    下面的方法可以满足这个需要。调用View的 setSystemUiVisibility()

    方法,其参数如下:

                  View.SYSTEM_UI_FLAG_FULLSCREEN,			//全屏,状态栏和导航栏不显示
    			View.SYSTEM_UI_FLAG_HIDE_NAVIGATION,	//隐藏导航栏
    			View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN,	//全屏,状态栏会盖在布局上
    			View.SYSTEM_UI_FLAG_LAYOUT_HIDE_NAVIGATION,	
    			View.SYSTEM_UI_FLAG_LAYOUT_STABLE,
    			View.SYSTEM_UI_FLAG_LOW_PROFILE,
    			View.SYSTEM_UI_FLAG_VISIBLE,		//显示状态栏和导航栏
    			View.SYSTEM_UI_LAYOUT_FLAGS
    方法二:(试验成功)
      直接调用此方法即可实现对状态栏的控制;
        private void full(boolean enable) {
            if (enable) {
                WindowManager.LayoutParams lp = getWindow().getAttributes();
                lp.flags |= WindowManager.LayoutParams.FLAG_FULLSCREEN;
                getWindow().setAttributes(lp);
                getWindow().addFlags(WindowManager.LayoutParams.FLAG_LAYOUT_NO_LIMITS);
            } else {
                WindowManager.LayoutParams attr = getWindow().getAttributes();
                attr.flags &= (~WindowManager.LayoutParams.FLAG_FULLSCREEN);
                getWindow().setAttributes(attr);
                getWindow().clearFlags(WindowManager.LayoutParams.FLAG_LAYOUT_NO_LIMITS);
            }
        }

     PS:getWindow().setFlags(WindowManager.LayoutParams.FLAG_LAYOUT_IN_SCREEN, WindowManager.LayoutParams.FLAG_LAYOUT_INSET_DECOR);//全屏状态改为非全屏状态位置保存不变

  • 相关阅读:
    纯CSS打造圆角Table效果
    [RabbitMQ+Python入门经典] 兔子和兔子窝[转]
    salesforce 调用webservice
    maven+spring+cxf编写web service
    Appfuse 教程
    eclipse的maven project,如何添加.m2里的那些jar包?
    java fullstack 框架
    Maven Jetty Plugin运行配置jetty:run
    Appfuse下载及安装步骤
    fullstack设计
  • 原文地址:https://www.cnblogs.com/Shadowing/p/3460557.html
Copyright © 2011-2022 走看看