沉浸式安卓应用设计简单又好用

这个特性是andorid4.4支持的,最少要api19才可以使用。下面介绍一下使用的方法,非常得简单:

 

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
public class MainActivity extends Activity {
 
     @Override
     protected void onCreate(Bundle savedInstanceState) {
         super .onCreate(savedInstanceState);
         setContentView(R.layout.activity_main);
 
         //透明状态栏
         getWindow().addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);
         //透明导航栏
         getWindow().addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_NAVIGATION);
 
     }
 
 
}

 

 

?
1
2
3
4
//透明状态栏
getWindow().addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);
//透明导航栏
getWindow().addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_NAVIGATION);

 

只要加入这两行代码,就可以实现沉浸式通知栏了。效果如图:

\

 

给大家看看这个界面的布局:

 

?
1
2
3
4
<linearlayout android:background= "#ffffff" android:layout_height= "match_parent" android:layout_width= "match_parent" android:orientation= "vertical" tools:context= ".MainActivity" xmlns:android= "http://schemas.android.com/apk/res/android" xmlns:tools= "http://schemas.android.com/tools" >
 
 
     <textview android:background= "#009959" android:layout_height= "100dp" android:layout_width= "match_parent" ><button android:background= "#ff669d/" android:layout_height= "50dp" android:layout_width= "100dp" ></button></textview></linearlayout>

是一个垂直的流布局,但这样,其实还是有问题的,我在textView里面加一些文字,就是绿色的那一块,大家看一下效果:

 

\

大家看到了吧,文字和状态栏重叠在一起了,这肯定是不行的,此时需要添加下面的代码:

 

 

?
1
2
android:fitsSystemWindows= true
android:clipToPadding= true

 

 

?
1
2
3
4
5
<linearlayout android:background= "#ffffff" android:cliptopadding= "true" android:fitssystemwindows= "true" android:layout_height= "match_parent" android:layout_width= "match_parent" android:orientation= "vertical" tools:context= ".MainActivity" xmlns:android= "http://schemas.android.com/apk/res/android" xmlns:tools= "http://schemas.android.com/tools" >
 
 
 
     <textview android:background= "#009959" android:layout_height= "100dp" android:layout_width= "match_parent" ><button android:background= "#ff669d/" android:layout_height= "50dp" android:layout_width= "100dp" ></button></textview></linearlayout>

大家看红色的那部分,加入那两行以后,界面仍然会是沉浸式的,但状态栏那部分,就不会再重叠了,像加了padding一样,如下图:

 

\

大家看图,绿色的textView和红色的一个button都被下移了,状态栏是白色的,是背景linearLayout的颜色。很明显,这也不是我们想要的,我们希望状态栏和我们放在顶部的控件是同一个颜色,同时,控件内容也不和状态栏重复,其实,只要把那两行代码放到我们顶部的控件就可以了。代码如下:

 

 

?
1
2
3
4
5
<linearlayout android:background= "#ffffff" android:layout_height= "match_parent" android:layout_width= "match_parent" android:orientation= "vertical" tools:context= ".MainActivity" xmlns:android= "http://schemas.android.com/apk/res/android" xmlns:tools= "http://schemas.android.com/tools" >
 
 
 
     <textview android:background= "#009959" android:cliptopadding= "true" android:fitssystemwindows= "true" android:layout_height= "100dp" android:layout_width= "match_parent" android:text= "你好,请问你有男朋友吗/" ><button android:background= "#ff669d/" android:layout_height= "50dp" android:layout_width= "100dp" ></button></textview></linearlayout>
就是那两行红色的代码,放在绿色的textView上,这样,就会是下面的效果:

 

这就是我们想要的了。

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值