Android全屏,隐藏状态栏和标题栏,本来以为这个功能很简单,不必拿出来说,但这个问题让我在互联网上找了N多例子,花了数个小时,看来还是有必要好好说说的。

网络上的许多方案都是正确的,但要放到合适的环境里才起作用。出现了下面这几种情况。

1、看第一个出问题的,直接使用android:theme="@android:style/Theme.Black.NoTitleBar.Fullscreen",但等我的是一个错误

<?xml version="1.0" encoding="utf-8"?>                                                                                
错误信息如下

java.lang.IllegalStateException: You need to use a Theme.AppCompat theme (or descendant) with this activity.

看到错误了,看出来了,说让我们使用Theme.AppCompat theme,看来Theme.Black.NoTitleBar.Fullscreen在继承了AppCompatActivity的Activyty中会出问题。

2、将上面的代码都删除了,然后就代码来隐藏状态栏和标题栏。代码如下

public class MainActivity extends AppCompatActivity {    @Override    protected void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        Window window = getWindow();        //隐藏标题栏        requestWindowFeature(Window.FEATURE_NO_TITLE);        //隐藏状态栏        //定义全屏参数        int flag=WindowManager.LayoutParams.FLAG_FULLSCREEN;        //设置当前窗体为全屏显示        window.setFlags(flag, flag);                setContentView(R.layout.activity_main);    }}

运行一下,状态栏真的没有了,但标题栏仍然在哪里。为什么标题栏还在哪里?肯定有些情况下是可以的!不再研究它了。

又查到下面的代码

        ActionBar actionBar = getSupportActionBar();        if (actionBar != null) {            actionBar.hide();        }
终于标题栏ActionBar消失了。

推荐方法:在自定义的styles中设置隐藏状态栏和标题栏的theme,并在AndroidManifest.xml文件中的application或某个activity中设置。

styles文件如下

            
AndroidManifest.xml文件如下:

<?xml version="1.0" encoding="utf-8"?>                                                                                

实现状态栏和标题栏终于消失了,效果如下图



我建了一个Git仓库,存放我尝试过的例子,完整 代码都放在那里。

https://code.csdn.net/do168/androidtestcenter

欢迎下载


更多相关文章

  1. 深入解读Linux与Android的相互关系
  2. [android] 将Java程序移植到android上
  3. Android中的横竖屏、资源、国际化的使用
  4. Linux和Android的区别和联系
  5. Android与linux的区别与联系
  6. Android与Linux的区别与联系
  7. 7种形式的Android(安卓)Dialog使用举例
  8. 深入解读Linux与Android的相互关系
  9. Android防止内存溢出浅析/应用自动更新功能的代码实现

随机推荐

  1. 成都PowerBI培训和技术支持
  2. Zookeeper安装与调优部署参考文档(Linux)
  3. 面向对象与函数式编程的简单案例
  4. 万字长文!剑指offer全题解思路汇总
  5. 一道 React 面试题:在浏览器、组件和元素
  6. Vue3对于一个前端来讲意味着什么?
  7. 检查 JavaScript 变量是否为数字的几种方
  8. 闭眼,闷声,发大财!
  9. 剑指offer(一):找出数组中重复的数字
  10. 函数作用域与闭包、回调使用场景与参数调