Splash 闪屏页流程与功能分析

0. 闪屏流程分析

要说到闪屏,几乎已经是所有 App 的标配了。但是各家对于闪屏的理解和应用方式各不相同。比如 Google 自己并不建议在闪屏页中设置过长的停留时间,而只是作为冷启动过程的一种变相缓冲,以就是仅在背景上设置一个 APP Logo 来避免屏幕留白。但在中国,几乎所有的流量还不错的 App 都会在闪屏页中加入广告,或者自己应用中某个主题活动的宣传,在增强品牌效应。这其中又有不同的使用流派,但基本都可以归为一个流程:

部分 App 会直接省略 Logo 这一环,直接加载闪屏页。观察了几个常用 App 后,我发现网易云音乐的闪屏逻辑是最好的,这不是说网易云音乐的闪屏流程与上面的图片有什么不同,而是网易优化了冷启动过程。一般来说,App 在点击 back 退出以后,再次打开会重新进入冷启动流程,也就是会再次进入闪屏显示流程,但是网易云音乐就不会:它只会在你第一次打开该 App 的时候加载 Loge 和 Splash,然后即使你按了 back 退出到屏幕,再次打开就不会再走闪屏流程了。这样即使用户多次退出打开也只会显示一次 Splash 页面,那么就算网易云的 Splash 时间稍微长一点你也不会在乎的吧(斜眼笑)。

1. 闪屏流程优化

那么这种模式是如何实现的呢?开始我以为是因为是通过检测后台服务是否运行栏判断是否跳过 splash 逻辑,但是我实际实验后发现,这个方法虽然可行,但是在此打开时的页面动画就不是那么舒服了,有点生硬的感觉,而且不是所有的 App 都有后台服务的。不管简单的搜索就找到了我觉得正确的方式:

Activity 类中有一个方法:moveTaskToBack,接受一个 boolean 类型参数,传入 true 就会让 App 退出进入后台,但是不会停止该进程。这不就是我们想要的方式么?试了下果然跟网易云一毛一样,这样也是变相的避免了 App 冷启动,减少了用户的等待时间,提升了那么一点用户体验吧。

除了这个方法还有另一种办法:

  Intent intent = new Intent(Intent.ACTION_MAIN);
  intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
  intent.addCategory(Intent.CATEGORY_HOME);
  startActivity(intent);

效果与 moveTaskToBack 是相同的。

但是这两个方法都有一个共同的弊端,如果 App 处于后台超过一定时间没有任务执行也会被杀死的。而且这个时间非常短。我在自己手机上测试是 7 秒左右。不过这大概是因为我手机打开了某些清理工具的原因,毕竟写在 onDestroy 里的 log 都没打出来,可见是被强制杀死的。所以我又在虚拟机上测试了下,点击返回以后等了三分钟发现还是处于存活状态我就没有继续测试了,基本已经证明如果没有第三方干涉,应用应该会在后台存活较长时间,直到内存不足被系统杀死。当然作为一个有尊严的 App 应该在用户退出后开个定时器,十分钟用户还没有回来就自毁吧,毕竟占着内存不工作也不太好是吧。

不过相比于很多 App 用 再按一次返回退出 来挽留用户,我觉得这种方式可能更加舒服一点。

2. 闪屏页需求分析

首先要说的是,我这里所说的闪屏页并不包括引导页,这相对是另一个功能了。一般对闪屏而言,无外乎就这么几个功能:

  • 显示 Logo,增强品牌效应
  • 打广告,挣点零花钱
  • 内部活动推广,会带有内链

2.1 显示 Logo

首先说显示 Logo,如果 App 的 Logo 与开始的图片上的流程是一样的,那么 Logo 是可以有两种方式来显示的。

  1. 通过 windowBackground 来设置:可以在屏幕背景里放一个非全屏显示的图片,作为打开的留白的间隙的替代,当正常内容加载完就会被覆盖掉。Logo 的显示时间取决于正常内容的加载时间,如果加载很快,Logo 就会一闪而过。但为什么是非全屏显示呢,对于 windowBackgroung,很难设置图片的拉伸模式,那么屏幕适配就非常麻烦。所以放一个非全屏图片,设置个背景色或许是个不错的选择。这种方式也是 Google Photos 在用的。至于一闪而过对于用户的体验是否良好就仁者见仁了。另外值得一提的是网易云应该也是使用这种方式,因为 Logo 的显示时间并不总是相同而且没有丝毫的留白间隙,但是它的 Logo 是全屏的,这就得佩服下网易的技术水平了(微笑脸)。

  2. 除了这种方式就是常规的用一个单独的页面来显示 Logo 了,这种没什么好说的,全屏往里面放图片就行了。

2.2 显示广告

然后说打广告,这里的广告是指接的外部广告,比如网易的闪屏经常会放某某车的广告,或者天猫什么节的,还是有很酷炫的动画和声音的那种,简单的图片动态加载比较简单,但是带有多媒体效果的广告就略复杂了,这里就只说动态下拉图片广告吧。

动态下拉图片广告需要后台 API 的配合。比如检测是不是要下载新的广告,广告的过期时间,紧急停用某个广告等。因为我不是后台,所以自己写了个简单的后台广告接口,勉强够用:

  • 请求
    • 地址:
    • 方法:GET
    • 格式:<K,V>
    • 参数:
      • Long : splashId //当前 splash id,为空则返回最新 splash 信息
  • 返回
    • 数据:闪屏信息
    • 格式:json
    • 例子:
      {
          "splash":
          {
              "id":1,                 //闪屏识别 id
              "imgUrl":"",            //闪屏图片下载地址
              "eventUrl":"",          //闪屏活动地址
              "eventTitle":"",        //闪屏活动标题
              "deadDate":0,           //有效期至(Long 毫秒值)
              "disable":true          //是否停用,用于紧急下线闪屏
          }
      }
      
    • 服务器行为:
      • 根据 id 检查是否存在新的 splash 信息,存在则返回 splash 对象,不存在返回空,停用该 splash 则返回 id 相同、 disable=true 的 splash 对象

如果 App 某段时间内只维持一个 Splash,也就是显示同一个广告,那么对象信息可以存在 SP 里,如果要维持多个 Splash,那还是单独建个数据表来存储比较方便。我这个接口只适合维持一个 Splash,因此也不存在考虑显示频次的问题,如果要适配多 Splash 的需求,我想你们肯定能做到的(斜眼笑)。

对移动端来说,每次打开 App 都要请求该接口,以保证 Splash 的最新。当发送 id 与接收到的 id 不同,那么就要开启子线程与下载新的 Splash 图片了。如果相同,但 disable=true,下次冷启动就不会再显示这个 Splash 了。

2.3 显示活动推广

本来我以为只有 App 自己的活动推广才会带有内链,不过网易显然又刷新了我的认知,它竟然在网易云里面加载天猫某某节的页面!不愧是网易,果然有态度。其实看上一小节的 API 文档,就知道 Splash 里还带有两个 url 属性的,imgUrl 是广告图片的下载地址,eventUrl 是活动页面地址,至于 eventTitle 就是活动页面的标题了。

这个其实只要给 Splash 图片设置个点击事件就行了,不过有一点还是要说下:点击图片进入了活动页面,如果 Splash 页面已经 finish 掉了,那么 App 不是就直接退出了么,如果推广是给别家推广的,有种给别人做了嫁衣裳的感觉啊。因此,对于活动页面的退出,还得加一层判断逻辑。考虑到内链不仅会是 web 页面,也可能是内部的某个常规 Activity,因此需要在所有可能由 Splash 跳转而来的页面里进行判断:

首先在开启 Activity 的传入参数:

    public static void actionStart(Context context, String url, String title, boolean isFromSplash) {
        Intent intent = new Intent(context, CommonWebActivity.class);
        intent.putExtra("url", url);
        intent.putExtra("title", title);
        intent.putExtra("isFromSplash", isFromSplash);
        context.startActivity(intent);
    }

然后在需要做退出判断的地方:

    @Override
    public void onBackPressed() {
        if (webView.canGoBack()) {//优先让内置浏览器返回至上一页
            webView.goBack();
        } else if (isFromSplash) {//如果从闪屏跳转而来,则关闭返回至首页
            MainActivity.actionStart(this);
        } else {
            super.onBackPressed();
        }
    }

如果你有抽取 BaseActivity,那么在 BaseActivty 中判断更好:

    @Override
    public void onBackPressed() {
        if (isFromSplash) {//如果从闪屏跳转而来,则关闭返回至首页
            MainActivity.actionStart(this);
        } else {
            super.onBackPressed();
        }
    }

至此,闪屏的分析就结束了,一般来说 Splash 页面就这么些功能了,这里我没有贴上完整的实现代码,因为测试 API 是用 SpringBoot 建的,而且大家的后台并不一定是自己可以控制的,因此主要还是提供个思路,具体的实现方式还是要因公司(需求)而异。

本文最早发布于 alphagao.com.

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

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,856评论 25 707
  • 最近在整理做产品以来收集到的各种资料,准备针对app的常见功能模块总结下经验,一来加深学习效果,二来供大家学习交流...
    jason_peng阅读 1,682评论 0 22
  • 前几天看到一个观点,深以为然。一个人要在某个领域做到领先很难,但是做到前四分之一并不是特别难。然后在另外一个领域也...
    chinawzck阅读 108评论 0 1
  • 为你踏泥折竹 -亚平 从姥姥家...
    过好一生阅读 234评论 0 0
  • 我总想拨一个电话 问你还好吗?怎么样啊? 可是,我拨了又挂 我恐,你又哭了...
    风在摇曳阅读 228评论 0 2