Ionic4设置沉浸式状态栏

设置沉浸式状态栏体验比较好,而且有些页面设计需要频繁的改变状态栏的颜色,如果不使用沉浸式,就需要页面离开和进入单独设置状态栏背景色,这就导致会有一个非常明显的过度问题,但是使用沉浸式就可以避免这个问题,因为沉浸式状态下状态栏是透明的,只需要设置ion-header的背景色就可以了。
app.component.ts中设置:

this.statusBar.styleLightContent(); // 深色文本
this.statusBar.overlaysWebView(true);

到这一步,IOS就可以了,不用再设置其他的东西,但是Android还需要,如不设置,在Android中,页面头部就会和状态栏重叠,还需要设置padding-top将内容顶下来,我是使用指令来实现的:

import { Directive, ElementRef, Input, OnInit } from '@angular/core';
import { Platform } from '@ionic/angular';
@Directive({
  selector: '[appOverlayPadding]',
  exportAs: 'appOverlayPadding'
})
export class StatuabrOverlayPaddingDirective implements OnInit {

  @Input('appOverlayPadding') options: {
    top?: string;
  };
  constructor(
    private ele: ElementRef,
    private platform: Platform,
  ) {
  }

  ngOnInit() {
    this.setPaddingTop();
  }
  // 适配 沉浸式状态下 statusbar将header遮住的情况,
  setPaddingTop() {
    if (this.platform.is('android')) {
      this.ele.nativeElement.style.paddingTop = this.options && this.options.top ? this.options.top : '25px';
    }
  }
}

引用:

<ion-header>
  <ion-toolbar color="primary" appOverlayPadding>
    <ion-buttons slot="start">
      <ion-back-button></ion-back-button>
    </ion-buttons>
    <ion-title>商品描述</ion-title>
  </ion-toolbar>
</ion-header>

然后,有的Android机中,页面一打开,不会立即切换成沉浸式,需要手动触发,比如input获取焦点,所以需要在statusbar插件源码中加点东西:

platforms/android/app/src/main/java/org/apache/cordova/statusbar/Statusbar.java中59行加入:

window.addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);
window.addFlags(WindowManager.LayoutParams.FLAG_DRAWS_SYSTEM_BAR_BACKGROUNDS);
window.setStatusBarColor(Color.TRANSPARENT);
window.setNavigationBarColor(Color.WHITE); // 设置底部虚拟导航栏的背景色
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 6
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

废柴前端

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值