iOS--富文本推送NotificationContentExtension


title: iOS10富文本推送–NotificationContentExtension
date: 2017-07-18 14:46:39
tags: 原创分享

NotificationContentExtension文件

根据以下ContentExtension Info.plist文件中的配置决定category的设置,两者必须一致
ContentExtension Info.plist

宏定义采用下列代码:

//推送相关设置
#define Action_Category_Identifier_Image @"Image_Category" //图片类别标识符
#define Action_Category_Identifier_Audio @"Audio_Category" //音频类别标识符
#define Action_Category_Identifier_Movie @"Movie_Category" //视频类别标识符
#define Action_Identifier_Image_Confirm @"imageConfirmAction"  //图片确认按钮
#define Action_Identifier_Image_Concel  @"imageConcelAction"   //图片取消按钮
#define Action_Identifier_Audio_Confirm @"audioConfirmAction"  //音频确认按钮
#define Action_Identifier_Audio_Concel  @"audioConcelAction"   //音频取消按钮
#define Action_Identifier_Movie_Confirm @"movieConfirmAction"  //视频确认按钮
#define Action_Identifier_Movie_Concel  @"movieConcelAction"   //视频取消按钮
#define Action_Title_Image_Confirm @"查看"  //图片确认按钮标题
#define Action_Title_Image_Concel  @"忽略"  //图片取消按钮标题
#define Action_Title_Audio_Confirm @"查看"  //音频确认按钮标题
#define Action_Title_Audio_Concel  @"忽略"  //音频取消按钮标题
#define Action_Title_Movie_Confirm @"查看"  //视频确认按钮标题
#define Action_Title_Movie_Concel  @"忽略"  //视频取消按钮标题

采用的是自定义布局,注意如果想使用这个布局的话,
你必须提前在service里面设置好categoryIdentifier,它的值是你plist文件里面的任何一个

@interface NotificationViewController () <UNNotificationContentExtension>
@property (nonatomic, strong)UIImageView *imageView;
@property (nonatomic,strong)UILabel *label;
@end

LazyLoad

-(UIImageView *)imageView{
    if (_imageView == nil) {
        _imageView = [[UIImageView alloc] init];
        _imageView.contentMode = UIViewContentModeScaleAspectFit;
    }
    return _imageView;
}

AddView

- (void)viewDidLoad {
    [super viewDidLoad];
    [self.view addSubview:self.imageView];
    // Do any required interface initialization here.
}

取出多媒体资料并展示到视图上,下面为image

- (void)didReceiveNotification:(UNNotification *)notification {
    NSLog(@"notification.request.content.userInfo%@",notification.request.content.userInfo);
    UNNotificationContent * content = notification.request.content;
    CGFloat widthTime = 2;
    if ([UIScreen mainScreen].bounds.size.width>375) {
        widthTime = 3.0;
    }
    UIImage *image = nil;
    if (content.attachments.count) {
        UNNotificationAttachment * attachment_img = content.attachments[0];
        if (attachment_img.URL.startAccessingSecurityScopedResource) {
            image = [UIImage imageWithContentsOfFile:attachment_img.URL.path];
            self.imageView.image = image;
        }
    }
    self.imageView.frame = self.view.frame;
    self.label.text = notification.request.content.body;
}

响应相关Action

-(void)didReceiveNotificationResponse:(UNNotificationResponse *)response completionHandler:(void (^)(UNNotificationContentExtensionResponseOption))completion{
    UNNotificationContent *content = [response.notification.request.content mutableCopy];
    NSString *category =  content.categoryIdentifier;
    NSString *actionIdentifier = [response.actionIdentifier copy];
   if ([category isEqualToString:Action_Category_Identifier_Image]) {
        if ([actionIdentifier isEqualToString:Action_Identifier_Image_Confirm]) {
            completion(UNNotificationContentExtensionResponseOptionDismissAndForwardAction);
        }else{
            completion(UNNotificationContentExtensionResponseOptionDismiss);
        }
    }else if ([category isEqualToString:Action_Category_Identifier_Audio]){
        if ([actionIdentifier isEqualToString:Action_Identifier_Audio_Confirm]) {
            completion(UNNotificationContentExtensionResponseOptionDismissAndForwardAction);
        }else{
            completion(UNNotificationContentExtensionResponseOptionDismiss);
        }
    }else{
        if ([actionIdentifier isEqualToString:Action_Identifier_Movie_Confirm]) {
            completion(UNNotificationContentExtensionResponseOptionDismissAndForwardAction);
        }else{
            completion(UNNotificationContentExtensionResponseOptionDismiss);
        }
    }

}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

卟败灬筱龙

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值