网站建设资讯

NEWS

网站建设资讯

iOS消除应用角标的方法

这篇文章主要介绍iOS消除应用角标的方法,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

创新互联建站专注于修武企业网站建设,响应式网站建设,购物商城网站建设。修武网站建设公司,为修武等地区提供建站服务。全流程按需网站设计,专业设计,全程项目跟踪,创新互联建站专业和态度为您提供的服务

应用角标

1>何为应用角标

应用角标就是底下截图这哥们,本初截图是MAC上截的,手机上也是一样的效果:

iOS消除应用角标的方法

2>应用角标原理

应用角标其实是由系统设置的,APNs将推送的消息传送到系统的时候根据上面的消息payload内容中的badge数值来给应用的图标赋值,这样应用的HomeScreen上显示的图标右上角就会出现相应的数字,不管你应用启动没启动都会显示相应的数字。所以如果是我们自己后台来实现这个推送功能的话,那么就需要一套角标逻辑来完善用户体验了。

消除角标

一般情况下,我们都会用此方法来消除角标:

[UIApplication sharedApplication].applicationIconBadgeNumber = 0;

然而这种方法会使得系统通知栏的历史推送消息全部被清除。

试了下即使用 iOS 10 的消息推送框架 UserNotification 也存在这种情况。

会造成相同效果的还有

[UIApplication sharedApplication].scheduledLocalNotifications = nil;

解决方案:

- (void)applicationDidEnterBackground:(UIApplication *)application {
 UILocalNotification *clearEpisodeNotification = [[UILocalNotification alloc] init];
 clearEpisodeNotification.fireDate = [NSDate dateWithTimeIntervalSinceNow:1];
 clearEpisodeNotification.timeZone = [NSTimeZone systemTimeZone];
 clearEpisodeNotification.applicationIconBadgeNumber = -1;
 [[UIApplication sharedApplication] scheduleLocalNotification: clearEpisodeNotification];
}

在程序退到后台后,添加该通知。

关键的地方在于 applicationIconBadgeNumber 是 -1。

接着你可以看到红点带着动画优雅地消失了,

同时,历史推送消息被保留了下来。

不过,上述这个方式到 iOS 11 就失效了。

本来以为没辙了,直到发现某个新闻客户端仍然可以实现。

于是,我反编译了该新闻客户端。

从 applicationDidEnterBackground 入手,很快就找到了相关代码。

iOS消除应用角标的方法

iOS消除应用角标的方法

那么答案就出来了,直接使用 UserNotifications 即可,猜测 badge 应该还是 -1。

- (void)applicationDidEnterBackground:(UIApplication *)application {
 UNMutableNotificationContent *content = [[UNMutableNotificationContent alloc] init];
 content.badge = @(-1);
 UNNotificationRequest *request = [UNNotificationRequest requestWithIdentifier:@"clearBadge" content:content trigger:nil];
 [[UNUserNotificationCenter currentNotificationCenter] addNotificationRequest:request withCompletionHandler:^(NSError * _Nullable error) {
 }];
}

最后记得不要设置 title,否则会收到空白通知。

以上是“iOS消除应用角标的方法”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注创新互联行业资讯频道!


网页标题:iOS消除应用角标的方法
文章路径:http://cdweb.net/article/pspsoo.html