MFMessageCompose 和 MFMailComposeViewController的使用方法
使用MFMessageComposeViewCOntroller发短信
应用想自己提供界面让用户输入短信收件人地址、短信内容、主体、附件等短信内容,则可使用MFMessageComposeViewController来发送短信,它也是一个视图控制器,继承UINavigationController.
MFMessageComposeViewController提供了如下类方法判断iOS设备是否支持发送短信.
+ canSendText: |
该iOS设备是否支持发送文本短信. |
|
+ canSendAttachments: |
该iOS设备是否支持发送带附件的短信 |
|
+ canSendSubject: |
该iOS设备是否支持发送带标题的短信 |
|
程序使用MFMessageComposeViewController的类方法进行判断之后,接下来就可按如下步骤发送短信. |
||
1 |
创建MFMessageComposeViewController对象 |
|
2 |
为MFMessageComposeViewController设置recipients(接受NSArray作为属性值,用于设置多个收件人号码)、subject(设置短信主题)、body(设置短信内容)、attachments(接受NSArray作为属性值,用于设置多个附件)等属性 |
|
3 |
为MFMessageComposeViewController设置messageComposeDelegate,该属性值必须是一个实现MFMessageComposeViewControllerDelegate协议的对象.该协议中定义了一个必须实现的messageComposeViewComtroller:didFinishWithResult:方法,该方法负责处理短信的发送结果. |
|
代 码 片 段 |
@interface LCViewController()<MFMessageComposeViewControllerDelegate> @end @implementation LCViewController - (void)viewDidLoad { [super viewDidLoad]; } - (IBAction)send:(id)sender { NSString* destStr = self.destField.text; NSString* contentStr = self.contentField.text; if(destStr != nil && destStr.length> && contentStr != nil && destStr.length > ) { // 如果能发送文本信息 if([MFMessageComposeViewController canSendText]) { // 创建MFMessageComposeViewController对象 MFMessageComposeViewController *picker = [[MFMessageComposeViewController alloc] init]; // 为MFMessageComposeViewController对象指定messageComposeDelegate picker.messageComposeDelegate = self; picker.navigationBar.tintColor = [UIColor blackColor]; // 设置收件人,此处可通过NSArray集合指定多个收件人 picker.recipients = [NSArray arrayWithObject:destStr]; // 设置短信内容 picker.body = contenStr; /* 如果运营商支持,picker还支持指定subjecy(主题)和attachments(附件) 也可用addAttachmentURL:withAlternateFilename:或addAttachmentData:typeIdentifier:filename:方法添加附件 */ // 显示MFMessageComposeViewController控制器 [self persentViewController:picker animated:YES completion:nil]; } } } // MFMessageComposeViewControllerDelegate协议中的方法,负责处理短信的发送结果 - (void)messageComposeViewController:(MFMessageComposeViewController*)controller didFinishWithResult:(MessageComposeResult)result { switch(result) { case MessageComposeResultCancelled: [self showAlert:@”结果: 短信被取消发送”]; break; case MessageComposeResultSent: [self showAlert:@”结果: 发送成功”]; break; case MessageComposeResultFailed: [self showAlert:@”结果: 发送失败”]; break; default: [self showAlert:@”结果: 没有发送短信”]; break; } [self dismissViewControllerAnimated:YES completion:nil]; } - (void)showAlert:(NSString *)msg { [[[UIAlertView alloc] initWithTitle:@”发送结果” message:msg delegate:nil cancelButtonTitle:@”确 定” otherButtonTitles:nil] show]; } @end 创建了一个MFMessageComposeViewController对象,并为该对象设置了recipents(收件人)、body(短信内容),并将该视图控制器本身设为它的messageComposeDelegate,因此该视图控制器类实现了MFMessageComposeViewControllerDelegate协议,并实现该协议中的方法----该方法负责处理发送短信的结果。 |
|
使用MFMailComposeViewController发送邮件
MFMailComposeViewController与MFMessageComposeViewController的用法非常相似,只是功能不同而已------MFMailComposeViewController用于发送邮件。
MFMailComposeViewController提供了如下类方法判断iOS设备是否支持发送邮件。
+ canSendMail: 该iOS设备是否支持发送邮件.
程序使用MFMailComposeViewController的类方法进行判断之后,接下来就可按如下步骤发送邮件.
- 创建MFMailComposeViewController对象
- 为MFMailComposeViewController设置toRecipients: (接受NSArray作为属性值,用于设置多个收件人地址)、ccRecipients:(接受NSArray作为属性值,用于设置多个抄送人地址)、bccRecipients:(接收NSArray作为属性值,用于设置多个密送人地址)、subject(设置邮件主题),还可通过setMessageBody:isHTML:方法设置邮件正文,通过addAttachmentData:mimeType:filename:方法添加附件.
- 为MFMailComposeViewController设置mailComposeDelegate,该属性值必须是一个实现MFMailComposeViewControllerDelegate协议的对象.该协议中定义了一个必须实现的mailComposeController:didFinishWithResult:error:方法,该方法负责处理邮件的发送结果.
代 码 片 段 |
@interface LCViewController()<MFMailComposeViewControllerDelegate> @end @implementation LCViewController -(void)viewDidLoad { [super viewDidLoad]; } -(IBAction)sendMail:(id)sender { // 获取界面上用户输入的内容 NSString* toStr = self.toField.text;// 收件人地址 NSString* ccStr = self.ccField.text;// 抄送人地址 NSString* bccStr = self.bccField.text;// 密送人地址 NSString* subjectStr = self.subjectField.text;// 邮件主题 NSString* contentStr = self.contentField.text;// 邮件正文 if(toStr != nil && toStr.length > && subjectStr != nil && subjectStr.length > && contentStr != nil && contentStr.length > ) { // 如果能发送邮件 if([MFMailComposeViewController canSendMail]) { // 创建MFMailComposeViewController对象 MFMailComposeViewController *picker = [[MFMailComposeViewController alloc] init]; // 为 MFMailComposeViewController对象指定mailComposeDelegate picker.mailComposeDelegate = self; picker.navigationBar.tintColor = [UIColor blackColor]; // 设置收件人,此处可通过NSArray集合指定多个收件人 picker.toRecipients = [NSArray arrayWithObject:toStr]; if(ccStr != nil && ccStr.length > ) { // 设置抄送人,此处可通过NSArray集合指定多个抄送人 picker.ccRecipients = [NSArray arrayWithObject:ccStr]; } if(bccStr != nil && bccStr.length > ) { // 设置密送人,此处可用过NSArray集合指定多个密送人 picker.bccRecipients = [NSArray arrayWithObject:bccStr]; } // 设置邮件主题 picker.subject = subjectStr; // 设置邮件正文 [picker setMessageBody:contentStr isHTML:NO]; // 显示MFMailComposeViewController控制器 [self persentViewController:picker animated:YES completion:nil]; } } } -(IBAction)finishEdit:(id)sender { [sender resignFirstResponder]; } -(void)mailComposeController:(MFMailComposeViewController*)controller didFinishWithResult:(MFMailComposeResult)result error:(NSError*)error { switch(result) { case MFMailComposeResultCancelled: [self showAlert:@”结果: 邮件被取消发送”]; break; case MFMailComposeResultSent: [self showAlert:@”结果: 发送成功”]; break; case MFMailComposeResultFailed: [self showAlert:@”结果: 发送失败”]; break; case MFMailComposeResultSaved: [self showAlert:@”结果: 邮件被保存了”]; break; } [self dismissViewControllerAnimated:YES completion:nil]; } -(void)showAlert:(NSString *)msg { [ [ [ UIAlertView alloc] initWithTitle:@”发送结果” message:msg delegate:nil cancelButtonTitle:@”确定” otherButtonTitles:nil] show]; } @end // 上面程序中的粗体字代码创建了一个MFMailComposeViewController对象,并为该对象设置了toRecipients(收件人地址)、ccRecipients(抄送人地址)、bccRecipients(密送人地址),还调用了setMessageBody:contentStr isHTML:方法设置邮件正文,并将该视图控制器本身设为它的mailComposeDelegate,因此该视图控制器类实现MFMailComposeViewControllerDelegate协议,并实现了该协议中的方法----该方法负责处理发送邮件的结果。 // 编译、运行该程序(必须在真机中运行,模拟器不支持),在程序界面中输入收件人地址、抄送地址、密送人地址、邮件主题、邮件正文,然后单击“发送”按钮,将可以看到如下图所示的界面 |