安卓透明状态栏Translucent bar
来源:互联网 发布:qq网络大型游戏 编辑:程序博客网 时间:2024/06/05 11:19
参考问题:http://www.zhihu.com/question/27365732
demo地址:https://github.com/Millais/Translucent-BaseApplication
什么是透明状态栏?
从 3.0 (honeycomb) 开始,Navigation Bar采用虚拟键,一直都占据一块不小的空间,对很多人来说,整个屏幕无法充利用,是一件相当痛苦的事情。也因此,有些人会刻意去挑选仍维持着实体键设计的手机。
而 Google 似乎也意识到这个状况,从 4.4 (KitKat) 提供了开发者一个新的作法,让我们可以把导航栏 (Navigation Bar)给透明化,并让内容延伸到该处,甚至是状态列 (Status Bar) 也可以被设定透明,这样再搭配 Action Bar 的配色,让整个 APP 更显得一致。
举个例子,第三方微博客户端Fuubo就用到了这个特性
MIUI6中,所有系统自带的应用也用到这个特性。雷布斯将其称之为沉浸式状态栏,沉浸式体验。其实并没有没有沉浸状态栏的说法,倒是有个沉浸模式,叫immersive mode,就是全屏显示,一般游戏中会用到。
而MIUI中用到的就是Translucent Bar这个特性。
实现方式
1.theme 属性设定
若我们的 APP 可以从 4.4 (KitKat) 开始支持,那其实可以直接theme里面进行设定,我们可以在官网上看到对透明化的说明里,官方提供了两种 no title 的主题风格可以让我们使用,分别如下
android:theme="@android:style/Theme.DeviceDefault.Light.NoActionBar.TranslucentDecor" android:theme="@android:style/Theme.Holo.Light.NoActionBar.TranslucentDecor" android:theme="@android:style/Theme.Holo.NoActionBar.TranslucentDecor"
如果我们希望可以维持Action Bar的存在,那只需要继承一般的主题,并在主题中分别加入两个属性值即可
<style name="AppTheme" parent="AppBaseTheme"> <!-- Status Bar --> <item name="android:windowTranslucentStatus">true</item> <!-- Navigation Bar --> <item name="android:windowTranslucentNavigation">true</item></style>
上面一行是设定Status Bar、下面一行是设定Navigation Bar 。
设置完这个主题,这时候会发现一个问题,你会发现你的 view 跑到Action Bar上面去了。
那有没有办法使你的 view 保持原来大小呢?
如果不希望内容被 Action Bar 压住,你需要在这个 activity 的 layout xml 文件添加两个属性
android:fitsSystemWindows="true" android:clipToPadding="true"
这样状态栏的背景就是你的 activity 的主背景,倘若actionbar 在,将仍然会很难看.....
个人觉得比较好的办法是给layout设置padding来解决。
我们可以把根布局设置一个高度为系统栏高度和ActionBar高度的内边距就可以。
//设置根布局的内边距 FrameLayout frameLayout = (FrameLayout) findViewById(R.id.layout); frameLayout.setPadding(0, getActionBarHeight()+getStatusBarHeight(), 0, 0);
// 获取手机状态栏高度 public int getStatusBarHeight() { Class<?> c = null; Object obj = null; Field field = null; int x = 0, statusBarHeight = 0; try { c = Class.forName("com.android.internal.R$dimen"); obj = c.newInstance(); field = c.getField("status_bar_height"); x = Integer.parseInt(field.get(obj).toString()); statusBarHeight = getResources().getDimensionPixelSize(x); } catch (Exception e1) { e1.printStackTrace(); } return statusBarHeight; } // 获取ActionBar的高度 public int getActionBarHeight() { TypedValue tv = new TypedValue(); int actionBarHeight = 0; if (getTheme().resolveAttribute(android.R.attr.actionBarSize, tv, true))// 如果资源是存在的、有效的 { actionBarHeight = TypedValue.complexToDimensionPixelSize(tv.data, getResources().getDisplayMetrics()); } return actionBarHeight; }
2.代码的方式实现
if(VERSION.SDK_INT >= VERSION_CODES.KITKAT) {//透明状态栏getWindow().addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);//透明导航栏getWindow().addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_NAVIGATION);}
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) { Window window = getWindow(); // Translucent status bar window.setFlags( WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS, WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS); // Translucent navigation bar window.setFlags( WindowManager.LayoutParams.FLAG_TRANSLUCENT_NAVIGATION, WindowManager.LayoutParams.FLAG_TRANSLUCENT_NAVIGATION);}
同样别忘了,如果不希望内容被 Action Bar 压住,那先前提及的 Layout 属性 android:fitsSystemWindows=”true” 要设置到。
即使没有Action Bar,也要注意下,不要出现MIUI中下图的情况:
这就是不加android:fitsSystemWindows=”true”属性的下场。
3.设置颜色
// 创建TextView,为了设置StatusBar的颜色 TextView textView = new TextView(this); LinearLayout.LayoutParams lParams = new LinearLayout.LayoutParams(LayoutParams.MATCH_PARENT, getStatusBarHeight()); textView.setBackgroundColor(Color.parseColor("#ffaa66cc")); textView.setLayoutParams(lParams); // 获得根视图并把TextView加进去。 ViewGroup view = (ViewGroup) getWindow().getDecorView(); view.addView(textView);
看看效果:
- 安卓透明状态栏Translucent bar
- Translucent Bar 透明状态栏---沉浸式状态栏
- Android 4.4 实现透明状态栏Translucent system bar(Status bar)
- Android 4.4 上实现透明导航栏和状态栏 Translucent system bar
- Android 4.4 以上实现透明导航栏和状态栏 Translucent system bar
- # 安卓透明状态栏
- Translucent System Bar 半透明状态栏的使用
- 安卓获取状态栏(Status Bar)高度
- Android透明状态栏status bar
- 沉浸式状态栏Immersive Mode & 透明式状态栏Translucent Bars
- Android UI之沉浸式状态栏Translucent System Bar
- 安卓实现状态栏透明主题
- 安卓4.4后实现透明状态栏
- 安卓4.4后实现透明状态栏
- 安卓4.4后实现透明状态栏
- 安卓4.4实现透明状态栏
- 安卓沉浸透明状态栏导航栏
- 安卓透明状态栏小技巧
- java反射机制不支持可变参数
- SOA标准之----SCA架构思想
- 数据存储(2)---文件存储
- java正则去掉小数点后多余0
- 用JavaScript实现下拉菜单
- 安卓透明状态栏Translucent bar
- Apache下禁止php文件被直接访问的解决方案
- Prim算法
- 深入Android通过Apache HTTP访问HTTP资源(二)(转)
- A. Boredom
- 测试sphinx/coreseek xmlpipe2 support NOT compiled
- Pascal's Triangle II
- Java中的内部类
- HTTP Status Code