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);//全屏状态改为非全屏状态位置保存不变

  • 相关阅读:
    window.location 对象所包含的属性
    控制器如何获取一条url中存在多个Id
    js 生成GUID
    JS控制前端控件的显示与隐藏
    ASP.NET CORE根据后台数值在razor页面进行判断单选按钮选中
    Selectize 控件使用以及js执行文件的时间差问题
    理解css中的position属性
    本地预览的vue项目,在githubpage静态展示
    关于img底部空白
    [优化]Steamroller-freecodecamp算法题目
  • 原文地址:https://www.cnblogs.com/Shadowing/p/3460557.html
Copyright © 2011-2022 走看看