现在好多的app都已经实现了沉浸式,已经是app开发中不可缺少的一部分。关于沉浸式只能在android4.4以上的版本才能实现,而且4.4和5.0以上的版本又有着不同。网上关于沉浸式的文章有很多,但我总感觉处理方法有些不合适(在开发的时候遇到了坑,布局位置计算出现错误),闲话少说直接上代码。
因为版本的不同所以我们要新建两个value资源文件夹value-v19和value-v21, 把value中的style文件复制到两个文件夹下。如在图1所示:
我们再来定义一些颜色用来设置statusbar和toolbar
<?xml version="1.0" encoding="utf-8"?>
<resources>
<color name="theme_color">#11ADF4</color>
<color name="statusBarColor">#FF0F8DC6</color>
<color name="white">#FFFFFF</color>
</resources>
activity_main.xml
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/activity_main"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context="com.feeling.statusbar.MainActivity">
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@color/theme_color"
android:fitsSystemWindows="true">
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:text="@string/app_name"
android:textSize="18sp"
android:textColor="@color/white"/>
</android.support.v7.widget.Toolbar>
</RelativeLayout>
这里说一下 android:fitsSystemWindows属性,主要是通过调整当前设置这个属性的view的padding去为我们的status_bar留下空间。
如果在4.4版本中你不写,那么状态栏和Toolbar就会有挤一块的感觉了,类似会这样:
MainActivity.class
public class MainActivity extends AppCompatActivity {
private Toolbar toolbar;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
toolbar= (Toolbar) findViewById(R.id.toolbar);
toolbar.setTitle("");
setSupportActionBar(toolbar);
}
}
先说一下5.0以上的版本如何做,比较简单,我们只要在value-v21下的style文件中添加如下代码即可实现:
<resources>
<!-- Base application theme. -->
<style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
<item name="windowNoTitle">true</item>
<item name="windowActionBar">false</item>
<item name="android:windowDrawsSystemBarBackgrounds">true</item>//5.0以下没有该属性
<item name="android:statusBarColor">@color/statusBarColor</item>
</style>//设置statusbar的颜色,5.0以下没有此属性
</resources>
在4.4版本上就少有些复杂,定义style样式,在value-v19中的style.xml中添加
<resources>
<!-- Base application theme. -->
<style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
<item name="windowNoTitle">true</item>
<item name="windowActionBar">false</item>
<item name="android:windowTranslucentStatus">true</item>
</style>
</resources>
最终效果如下
4.4版本:
5.0以上的效果图:
可以看到4.4中没有渐变色,为了达到与5.0以上版本相同的效果,我们可以这么做,画一个带有渐变色的背景图,在drawable文件下新建一个toolbar_bg.xml。
<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
<item>
<shape android:shape="rectangle">
<solid android:color="@color/statusBarColor"/>
</shape>
</item>
<item android:top="@dimen/status_bar_size">
<shape android:shape="rectangle">
<solid android:color="@color/theme_color"/>
</shape>
</item>
</layer-list>
然后把activity_main.xml文件中的toolbar的背景色改成android:background="@drawable/toolbar_bg"即可。效果图如下:
效果终于实现了,但是5.0的出现了问题:
没办法得再做一次适配新建layout-v19和layout-v21(如图1所示)创建toolbar_layout.xml (v19)
<?xml version="1.0" encoding="utf-8"?>
<merge xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent">
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@drawable/toolbar_bg"
android:fitsSystemWindows="true">
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:text="@string/app_name"
android:textSize="18sp"
android:textColor="@color/white"/>
</android.support.v7.widget.Toolbar>
</merge>
v-21中的只需要把ToolBar中的背景设置成android:background="@color/theme_color"
然后更改activity_main.xml文件代码
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/activity_main"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context="com.feeling.statusbar.MainActivity">
<include layout="@layout/toolbar_layout" />
</RelativeLayout>
运行效果完美适配。(图就不贴出来了)
也可以通过适配dimen.xml,在style-v19和style-v21中新建dimen.xml
v-19:
<resources>
<dimen name="status_bar_size">26dp</dimen>
</resources>
v-21
<resources>
<dimen name="status_bar_size">0dp</dimen>
</resources>
效果一样,两种处理方法原理一样。
本文详细介绍如何在Android应用中实现不同版本间的沉浸式UI效果,包括4.4和5.0以上版本的区别处理方法。文章提供了具体代码实例,演示如何通过适配不同API级别来确保UI一致性和美观。
964

被折叠的 条评论
为什么被折叠?



