我的笔记
android沉浸式布局
日常笔记
[1] : 沉浸式布局
【1】<!-- Base application theme. -->
<style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar">
<item name="colorPrimary">@color/colorPrimary</item>
<item name="colorPrimaryDark">@color/colorPrimaryDark</item>
<item name="colorAccent">@color/colorAccent</item>
</style>
<style name="AppTheme.Main" parent="AppTheme" />
【2】我们在values-v19中加入同样的AppTheme.Main
<style name="AppTheme.Main" parent="AppTheme.NoActionBar">
<item name="android:windowTranslucentStatus">true</item>
</style>
【3】透明状态栏
getWindow().addFlags(WindowManger.LayoutParams.Flag_TRANSLUCENT_STATUS);
透明导航栏
getwindow().addFlags(WindowManger.LayoutParams.FlagTRANSLUCENT_NAVIGATION)
【4】之后状态栏会被透明,但是文字会重叠为了修复这个问题,我们应该在布局文件的根布局中加入android:fitsSystemWindows=”true” 就可以了
//推荐使用沉浸状态栏
implementation 'com.gyf.barlibrary:barlibrary:2.3.0'
mImmersionBar = ImmersionBar.with(this);
mImmersionBar.titleBar(toolbar).transparentStatusBar().init();
或者
mImmersionBar.transparentStatusBar()
.statusBarDarkFont(true)
.keyboardEnable(true)
.init();
[2] : Toolbar
XML 布局
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="?attr/colorPrimary"
android:fitsSystemWindows="true"
android:minHeight="?attr/actionBarSize"
android:theme="@style/Theme.Drawer.ArrowAnimation"
toolbar:popupTheme="@style/Theme.ToolBar.Base">
<!--自定义控件-->
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="自定义" />
</android.support.v7.widget.Toolbar>
JAVA 代码:
toolbar.setNavigationIcon(R.mipmap.ic_drawer_home);//设置导航栏图标
toolbar.setLogo(R.mipmap.ic_launcher);//设置app logo
toolbar.setTitle("Title");//设置主标题
toolbar.setTitleTextColor(getResources().getColor(android.R.color.white));//设置主标题颜色
toolbar.setTitleTextAppearance(this, R.style.Theme_ToolBar_Base_Title);//修改主标题的外观,包括文字颜色,文字大小等
toolbar.setSubtitle("Subtitle");//设置子标题
toolbar.setSubtitleTextColor(getResources().getColor(android.R.color.darker_gray));//设置子标题颜色
toolbar.setSubtitleTextAppearance(this, R.style.Theme_ToolBar_Base_Subtitle);//设置子标题的外观,包括文字颜色,文字大小等
toolbar.inflateMenu(R.menu.base_toolbar_menu);//设置右上角的填充菜单
//打开抽屉页面
toolbar.setNavigationOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
drawerlayout.openDrawer(navigation_view);
}
});
toolbar.setOnMenuItemClickListener(new Toolbar.OnMenuItemClickListener() {
@Override
public boolean onMenuItemClick(MenuItem item) {
int menuItemId = item.getItemId();
if (menuItemId == R.id.action_search) {
Toast.makeText(MainActivity.this, "搜索", Toast.LENGTH_SHORT).show();
} else if (menuItemId == R.id.action_notification) {
Toast.makeText(MainActivity.this, "通知", Toast.LENGTH_SHORT).show();
} else if (menuItemId == R.id.action_item1) {
Toast.makeText(MainActivity.this, "设置", Toast.LENGTH_SHORT).show();
} else if (menuItemId == R.id.action_item2) {
Toast.makeText(MainActivity.this, "关于", Toast.LENGTH_SHORT).show();
}
return true;
}
});