博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
NSLocalNotification的用法示例
阅读量:4110 次
发布时间:2019-05-25

本文共 2337 字,大约阅读时间需要 7 分钟。

1、增加一个本地推送
//设置20秒之后 

NSDate *date = [NSDatedateWithTimeIntervalSinceNow:20];

    //chuagjian一个本地推送

   UILocalNotification *noti = [[[UILocalNotificationallocinit]autorelease];

    if (noti) {

        //设置推送时间

        noti.fireDate = date;

        //设置时区

        noti.timeZone = [NSTimeZonedefaultTimeZone];

        //设置重复间隔

        noti.repeatInterval =NSWeekCalendarUnit;

        //推送声音

        noti.soundName =UILocalNotificationDefaultSoundName;

        //内容

        noti.alertBody =@"推送内容";

        //显示在icon上的红色圈中的数子

        noti.applicationIconBadgeNumber =1;

        //设置userinfo 方便在之后需要撤销的时候使用

        NSDictionary *infoDic = [NSDictionarydictionaryWithObject:@"name"forKey:@"key"];

        noti.userInfo = infoDic;

        //添加推送到uiapplication        

       UIApplication *app = [UIApplicationsharedApplication];

        [appscheduleLocalNotification:noti];  

    }

2、程序运行时接收到本地推送消息

如果此时你的客户端 软件仍在打开,则会调用

- (void)application:(UIApplication *)application didReceiveLocalNotification:(UILocalNotification*)notification

{

UIAlertView *alert = [[UIAlertViewallocinitWithTitle:@"接收到本地提醒 in app"

message:notification.alertBody

  delegate:nil

 cancelButtonTitle:@"确定"

 otherButtonTitles:nil];

[alertshow];

//这里,你就可以通过notification的useinfo,干一些你想做的事情了

application.applicationIconBadgeNumber -=1;

}

设置的时间到了以后,会自动在桌面弹出一个提示框,点显示后,就可以启动软件。然后在
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{


    UILocalNotification *localNotif = [launchOptions objectForKey:UIApplicationLaunchOptionsLocalNotificationKey];
    if (localNotif) 
    {

        NSLog(@"Recieved Notification %@",localNotif);
        NSDictionary* infoDic = localNotif.userInfo;
        NSLog(@"userInfo description=%@",[infoDic description]);
        NSString* codeStr = [infoDic objectForKey:CODE];
    }
}里,对lanchOptions进行处理,找到它里面的信息,就可以拿到设置时的需要处理的东西,就可以继续操作了。

3、取消一个本地推送

UIApplication *app = [UIApplicationsharedApplication];

   //获取本地推送数组

   NSArray *localArr = [appscheduledLocalNotifications];

    

   //声明本地通知对象

   UILocalNotification *localNoti;

    

    if (localArr) {

        for (UILocalNotification *notiin localArr) {

            NSDictionary *dict = noti.userInfo;

            if (dict) {

                NSString *inKey = [dict objectForKey:@"key"];

                if ([inKey isEqualToString:key]) {

                    if (localNoti){

                        [localNoti release];

                        localNoti = nil;

                    }

                    localNoti = [noti retain];

                    break;

                }

            }

        }

        

       //判断是否找到已经存在的相同key的推送

        if (!localNoti) {

            //不存在初始化

            localNoti = [[UILocalNotificationallocinit];

        }

        

        if (localNoti && !state) {

            //不推送 取消推送

            [app cancelLocalNotification:localNoti];

            [localNoti release];

            return;

        }

}

转载地址:http://hjosi.baihongyu.com/

你可能感兴趣的文章
表单提交enter触发提交
查看>>
解决bootstrapTable中的width值设置无效的问题方法
查看>>
bootstrap table th内容太多表格撑破(自动换行)
查看>>
layui快速使用
查看>>
layui引用layui.css,layui.js后为什么表单不显示,不渲染?
查看>>
layui提交表单复选框CheckBox点击第一次无效解决方案
查看>>
js针对禁用ie浏览器(包括ie11)在内打开网页弹窗提示更好的体验解决方案
查看>>
ts编译安装,vs code监听
查看>>
vue3.0运行项目warning Insert `·` prettier/prettier
查看>>
win10 使用苹果耳机没有声音解决方案
查看>>
vue 添加页面表单添加编辑删除功能
查看>>
jq点击图片展示预览效果
查看>>
jq选项卡切换数据加载,更新select2 的值,触发查询功能
查看>>
前端Vue项目解决跨域问题
查看>>
element-ui开始日期结束日期范围选择
查看>>
javascript判断常用浏览器版本和类型兼容处理
查看>>
Vue适配移动端配置px2rem,自动将px转rem
查看>>
小程序配置px2rem
查看>>
react配置px2rem(react-create-app的基础上)
查看>>
Vue手机端适配安装postcss-px2rem,lib-flexible自动px转rem
查看>>