iOS实现支付宝后台模糊效果

废话不多说,先来张图,直接看下效果

上图的效果就是我们这篇文章要达到的效果。

对于没做过类似效果的盆友们来说,可能最开始想到的会是,是否有这么一个方法能监听到手机APP进入任务管理或者是进入任务切换这么一个动作?然鹅,事实并非那么麻烦,其实想要实现这种效果只需要监听AppDelegate里的下面两个方法即可

- (void)applicationDidEnterBackground:(UIApplication*)application

- (void)applicationWillEnterForeground:(UIApplication*)application

在这两个方法里需要做的事情也是很简单,就是在- (void)applicationDidEnterBackground:(UIApplication*)application里给window添加一个玻璃效果的view

在- (void)applicationWillEnterForeground:(UIApplication*)application里让这个玻璃效果的view从window上移除即可

代码如下,首先添加一个属性

@interface AppDelegate ()

/* blurView */

@property (strong, nonatomic) UIVisualEffectView *blurView;

@end

之后在- (void)applicationDidEnterBackground:(UIApplication*)application里在window上添加这个view

- (void)applicationDidEnterBackground:(UIApplication*)application {

    if(!_blurView) {

        UIBlurEffect *blurEffect = [UIBlurEffect effectWithStyle:UIBlurEffectStyleLight];

        _blurView = [[UIVisualEffectView alloc] initWithEffect:blurEffect];

        _blurView.frame = self.window.bounds;

    }

    //进入后台实现模糊效果

    [self.window addSubview:_blurView];

}

在即将进入前台的时候,移除这个view

- (void)applicationWillEnterForeground:(UIApplication*)application {

    [_blurView removeFromSuperview];

}

至此,就实现了和支付宝一毛一样的模糊效果了。

其实网上已经很多此类文章了,我为何在此还要写一些呢,其实就是,网上大部分的文章说的都是在- (void)applicationWillResignActive:(UIApplication*)application这个方法里添加模糊view,在- (void)applicationDidBecomeActive:(UIApplication*)application这个方法里移除模糊view。然鹅我自己也实际试过这种方式,这种方式达到的效果和支付宝的差距甚大,并且因为是在- (void)applicationWillResignActive:(UIApplication*)application方法里添加模糊view,因此会导致下拉通知栏和通知中心的时候都会直接显示这个模糊view,并且由于是在这个- (void)applicationDidBecomeActive:(UIApplication*)application方法中移除模糊view的,就会出现移除模糊view稍有延迟的效果,最终效果都没支付宝的那种实现来得好。我也不知道写这些文章的作者们有没实际的验证过,这种方式不仅会出现下拉通知中心显示模糊view,而且还会在下拉通知中心显示的模糊view最终不会被移除,因为下拉通知中心,之后通知中心上划消失后并不会调用- (void)applicationWillResignActive:(UIApplication*)application这个方法,也就是说,模糊view将不会被移除。

现在看看官方文档对active和inactive的解释吧,看完后您将豁然开朗

case active

The app is running in the foreground and currently receiving events.

//app当前运行在前台,并且会接收事件

case inactive

The app is running in the foreground but is not receiving events. This might happen as a result of an interruption or because the app is transitioning to or from the background.

//app当前运行在前台但是不接收事件。这种情况可能会发生在中断之后或者是因为app正切换到后台或从后台切换回前台

case background

The app is running in the background.

//app正运行在后台

因此,这也是我写此篇文章的目的之一吧,就是想让大家能对一个技术点有自己的想法和看法,意思就是,不要盲目全信网上的文章,对文章提到的技术点,最好能亲自验证一下是否正确,即使是你搜到的大部分文章都是一样的答案,您也应该亲自验证一番。

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

推荐阅读更多精彩内容