Android Activity全屏平滑切换非全屏最佳实践,告别蜜汁卡顿

前言

项目中我们通常将启动Activity命名为SplashActivity,并设置全屏,稍许停顿后再跳转LoginActivity或者MainActivity等非全屏Activity(后面统称为NormalActivity)。但是在跳到新界面的瞬间,状态栏生硬地从内容区挤出空间,插入在屏幕顶端,造成页面出现一次蜜汁卡顿。事故现场:

过渡时蜜汁卡顿.gif

一般实践

Google后可以找到一些解决方案,其中主要围绕这篇文章《Switching-from-Full-Screen-to-Non-Full-Screen-Smoothly-in-Android》的思想。总结一下,首先在onCreate()中调用setContentView()之前插入两行代码:

getWindow().addFlags(WindowManager.LayoutParams.FLAG_LAYOUT_IN_SCREEN);
getWindow().addFlags(WindowManager.LayoutParams.FLAG_LAYOUT_NO_LIMITS);

这样做起到的效果是内容区会一直延伸到屏幕顶部,状态栏盖在内容区上面。如图:

内容区与状态栏重叠.jpg

然后,只需要想办法让内容区回到原来的高度,避免和状态栏重叠。

拓展
如果有小伙伴跟我一样还不熟悉setContentView()背后的布局层次,可以阅读Android DecorView浅析》这篇博客,能帮你快速地了解。我在此借用了原博的一张图,谢过博主。

DecorView的层次结构.png

结合拓展,想必大家已经有还原内容区的思路了。我的总结如下:

  1. 为顶部控件(ToolBarTitleBar或自定义View)设置paddingTop,值为状态栏高度;
  2. 通过findViewById(android.R.id.content))得到编号21FrameLayout的实例,设置其marginTop,值为状态栏高度;
  3. 手动new一个高为状态栏高度view,利用编号1的LinearLayoutaddView()方法add到0位置上;
  4. 手动new一个高为状态栏高度view,add到由编号21FrameLayout.addView(),然后为我们的contentView设置MarginTop,高度为状态栏高度。

获取状态栏高度的方法:

int resId = getResources().getIdentifier("status_bar_height", "dimen", "android");
int statusBarHeight = getResources().getDimensionPixelSize(resId);
// getResources()也可以替换为Resources.getSystem(),这样的好处是不受Context的限制,从而可在任意地方调用

经试验以上方法均能够解决Activity跳转卡顿的问题。然鹅,主要在适配方面又会造成新的困扰(开发5分钟,适配两小时 (ಥ _ ಥ))。

  • 如果你的应用采用了沉浸状态栏设计,但状态栏颜色和ToolBar颜色不完全一致(比如微信),使用方法1会造成整体设计风格被破坏。
  • 方法2较方法1看上去差不多,然而,一些国内的ROM(如Flyme)系统可以自动帮你的App实现沉浸状态栏(即使你什么都没做)可谓非常先进和人性化。但是设置margin后有可能看到的状态栏背景和状态图标颜色几乎相近,既分辨不出图标又相当难看。
  • 方法3、4的方式更为灵活,就是稍微麻烦一点。

最佳实践

我们费尽心思在NormalActivity上做文章,结果到头来发现还会遇到适配这个坑,累觉不爱啊!前面扯了那么多,终归一句话:太!麻!烦!了!
所以重点来了。在SplashActivity中有没有文章可做呢?嘿嘿,当然是有的,而且思想非常简单:
设置SplashActivity为全屏,跳转其他Activity前退出全屏模式。

第一步,设置SplashActivity全屏
方法1:AndroidManifest注册全屏(AppCompat)
AndroidManifest.xml

   <activity
      android:name=".SplashActivity"
      android:theme="@style/AppFullScreenTheme">
         <intent-filter>
            <action android:name="android.intent.action.MAIN"/>
            <category android:name="android.intent.category.LAUNCHER"/>
         </intent-filter>
    </activity>

style.xml

<style name="AppFullScreenTheme" parent="@style/Theme.AppCompat.Light">
    <item name="windowNoTitle">true</item>
    <item name="windowActionBar">false</item>
    <item name="android:windowFullscreen">true</item>
    <item name="android:windowContentOverlay">@null</item>
</style>

方法2:在Activity的onCreate()中,调用setContentView()之前调用

   getWindow().setFlags(
           WindowManager.LayoutParams.FLAG_FULLSCREEN, 
           WindowManager.LayoutParams.FLAG_FULLSCREEN);

第二步,在finish()之前调用

   getWindow().setFlags(
           WindowManager.LayoutParams.FLAG_FORCE_NOT_FULLSCREEN, 
           WindowManager.LayoutParams.FLAG_FORCE_NOT_FULLSCREEN);

最终效果:

平滑过渡.gif
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,383评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,522评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,852评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,621评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,741评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,929评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,076评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,803评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,265评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,582评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,716评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,395评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,039评论 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,798评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,027评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,488评论 2 361
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,612评论 2 350

推荐阅读更多精彩内容