ios uilocalnotification 多个本地通知,怎么有区分的删除

本文详细介绍如何在iOS应用中实现本地通知功能,包括设置通知时间、提示文字、提示音及应用图标上的数字显示,并解决了通知重复及右上角数字显示不准确等问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

iOS的本地通知是用到了OC的UILocalNotification对象,加入一个通知很简单,创建一个UILocalNotification对象设置一些对应的参数就行了。
  // 添加本地通知
  UILocalNotification *notification=[[UILocalNotification alloc] init];
if (notification!=nil) 
  {
NSDate *now = [NSDate date];
  // 设置提醒时间,倒计时以秒为单位。以下是从现在开始55秒以后通知
notification.fireDate=[now dateByAddingTimeInterval:55];
  // 设置时区,使用本地时区
notification.timeZone=[NSTimeZone defaultTimeZone];
  // 设置提示的文字
notification.alertBody=@"时间到了,洗洗睡吧";
  // 设置提示音,使用默认的
notification.soundName= UILocalNotificationDefaultSoundName;
  // 锁屏后提示文字,一般来说,都会设置与alertBody一样
notification.alertAction=NSLocalizedString(@"锁屏了,洗洗睡吧", nil);
  // 这个通知到时间时,你的应用程序右上角显示的数字. 获取当前的数字+1
  notification.applicationIconBadgeNumber = [[[UIApplication sharedApplication] scheduledLocalNotifications] count]+1;
//给这个通知增加key 便于半路取消。nfkey这个key是自己随便写的,还有notificationtag也是自己定义的ID。假如你的通知不会在还没到时间的时候手动取消,那下面的两行代码你可以不用写了。取消通知的时候判断key和ID相同的就是同一个通知了。
  NSDictionary *dict =[NSDictionary dictionaryWithObjectsAndKeys:[NSNumber numberWithInt:notificationtag],@"nfkey",nil];
[notification setUserInfo:dict];
  // 启用这个通知
[[UIApplication sharedApplication] scheduleLocalNotification:notification];
// 创建了就要学会释放。如果不加这一句,通知到时间了,发现顶部通知栏提示的地方有了,然后你通过通知栏进去,然后你发现通知栏里边还有这个提示,除非你手动清除
  [notification release];
  }
  // 手动删除通知
  // 这里我们要根据我们添加时设置的key和自定义的ID来删
  NSArray *narry=[[UIApplication sharedApplication] scheduledLocalNotifications];
NSUInteger acount=[narry count];
if (acount>0) 
  {
  // 遍历找到对应nfkey和notificationtag的通知
for (int i=0; i<acount; i++) 
  {
UILocalNotification *myUILocalNotification = [narry objectAtIndex:i];
NSDictionary *userInfo = myUILocalNotification.userInfo;
NSNumber *obj = [userInfo objectForKey:@"nfkey"];
int mytag=[obj intValue];
if (mytag==notificationtag) 
  {
  // 删除本地通知
[[UIApplication sharedApplication] cancelLocalNotification:myUILocalNotification];
break;
}
}
}

  一个右上角提示的问题。你触发了5个通知,后台运行的情况下,3个已经到了,所以你的app右上角此时显示3。那么你通过通知栏或者直接点app进去以后,app右上角应该变为0。按照之前在addNotification里面的设置,等到第4个通知到了以后,app右上角会显示4,第五个到了以后,会显示5,很明显这是不对的。所以我们需要在通过通知栏进去,或者直接点app进去以后,重新去设置第四个第五个通知到了以后,app右上角的数字。
  这个重写AppDelegate中的两个方法:didReceiveLocalNotification和applicationDidBecomeActive。
  didReceiveLdidReceiveLocalNotification是app在前台运行,通知时间到了,调用的方法。如果程序在后台运行,时间到了以后是不会走这个方法的。
  applicationDidBecomeActive是app在后台运行,通知时间到了,你从通知栏进入,或者直接点app图标进入时,会走的方法。ocalNotification和applicationDidBecomeActive
  - (void)applicationDidBecomeActive:(UIApplication *)application
  {
// Restart any tasks that were paused (or not yet started) while the application was inactive. If the application was previously in the background, optionally refresh the user interface.

//reset applicationIconBadgeNumber;
application.applicationIconBadgeNumber=0;
int count =[[[UIApplication sharedApplication] scheduledLocalNotifications] count];
if(count>0)
{
NSMutableArray *newarry= [NSMutableArray arrayWithCapacity:0];
for (int i=0; i<count; i++) 
  {
UILocalNotification *notif=[[[UIApplication sharedApplication] scheduledLocalNotifications] objectAtIndex:i];
notif.applicationIconBadgeNumber=i+1;
[newarry addObject:notif];
}
[[UIApplication sharedApplication] cancelAllLocalNotifications];
if (newarry.count>0) 
  {
for (int i=0; i<newarry.count; i++) 
  {
UILocalNotification *notif = [newarry objectAtIndex:i];
[[UIApplication sharedApplication] scheduleLocalNotification:notif];
}
}
}
}
- (void)application:(UIApplication *)application didReceiveLocalNotification:(UILocalNotification *)notification
  {
if (notification)
{
application.applicationIconBadgeNumber=0;
int count =[[[UIApplication sharedApplication] scheduledLocalNotifications] count];
if(count>0)
{
NSMutableArray *newarry= [NSMutableArray arrayWithCapacity:0];
for (int i=0; i<count; i++) 
  {
UILocalNotification *notif=[[[UIApplication sharedApplication] scheduledLocalNotifications] objectAtIndex:i];
notif.applicationIconBadgeNumber=i+1;
[newarry addObject:notif];
}
[[UIApplication sharedApplication] cancelAllLocalNotifications];
if (newarry.count>0)
  {
for (int i=0; i<newarry.count; i++) 
  {
UILocalNotification *notif = [newarry objectAtIndex:i];
[[UIApplication sharedApplication] scheduleLocalNotification:notif];
}
}
}
}
}
  还有一个问题,本地通知是系统给缓存的,不管应用程序是否在前后台运行,通知都会存在。但我们把应用程序关了再重新运行时,按应用的逻辑,有些通知可能会重复添加,这不是我们想要的结果。所以,比较简单的办法是在程序启动的时候清空所有的本地通知,然后按应用逻辑判断再次重新添加。这个在程序首次起动回调函didFinishLaunchingWithOptions中加一个清空通知和重设应用提示数字了
  - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{

  // about notification
application.applicationIconBadgeNumber = 0;
[[UIApplication sharedApplication] cancelAllLocalNotifications];

  
  return YES;
}
  当然,还有一种解决办法是每次添加时判断ID是否已存在,如果存在删了重加。个人觉得这个是一个比较蛋疼的方法,还不如程序起动时清空之后再来重加的好。。
MPU6050是一款广泛应用在惯性测量单元(IMU)中的微型传感器,由InvenSense公司生产。它集成了三轴加速度计和三轴陀螺仪,能够检测设备在三维空间中的线性加速度和角速度,进而计算出物体的姿态、运动和方向。在本项目中,MPU6050被用来获取设备的YAW、PITCH、ROLL这三个关键的姿态角,这些数据将通过OLED显示屏进行实时显示。 1. **MPU6050工作原理**: MPU6050内部包含两个主要传感器:加速度计用于测量重力加速度,提供X、Y、Z三个轴的线性加速度信息;陀螺仪则测量绕三个轴的旋转速率。通过融合这两个传感器的数据,可以计算出设备的动态运动状态。 2. **姿态角的定义**: - **YAW(偏航角)**:表示设备相对于一个参考方向的旋转角度,通常以水平面为基准。 - **PITCH(俯仰角)**:是设备沿垂直轴相对于水平面的倾斜角度,向上为正,向下为负。 - **ROLL(翻滚角)**:是设备围绕前向轴的旋转角度,向右为正,向左为负。 3. **数据处理与姿态解算**: 为了从原始的加速度和角速度数据中获取准确的姿态角,需要应用卡尔曼滤波、互补滤波或者Madgwick算法等高级数据融合方法。这些算法可以有效地消除噪声,提高姿态估计的稳定性和精度。 4. **OLED显示屏**: OLED(有机发光二极管)显示器是一种自发光技术,具有高对比度、快速响应时间以及广视角的优点。在该项目中,OLED用于实时显示YAW、PITCH、ROLL角,为用户提供了直观的视觉反馈。 5. **硬件连接与编程**: 实现这一功能需要将MPU6050通过I2C或SPI接口连接到微控制器(如Arduino、Raspberry Pi等)。编写相应的固件程序来读取传感器数据,并将其转换为姿态角,然后将结果显示在OLED屏幕上。 6. **软件实现**: 在编程过程中,通常会用到相关的库文件,如Arduino IDE中的Wire库来处理I2C通信,Adafruit的MPU6050库来与传感器交互,以及Adafruit_GFX和Adafruit_SSD1306库来驱动OLED屏幕。 7. **调试与优化**: 项目实施过程中可能遇到的问题包括传感器漂移、数据不准确等,可以通过调整滤波器参数、校准传感器以及优化算法来改善。 综上,"MPU6050(OLED显示姿态角)"项目涉及了传感器技术、微控制器编程、数据融合算法、嵌入式显示等多个领域的知识,对于学习和实践物联网、机器人、无人机等领域的开发者来说,是一个很好的动手实践项目。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值