iOS_开发_Send_Mail

本文介绍了如何在iOS应用中使用MFMailComposeViewController接口,在不退出程序的情况下集成邮件发送功能。详细步骤包括引入框架、导入头文件、实现委托方法、检查邮件账户设置、初始化控制器并配置邮件内容。
  1. MFMailComposeViewController

MFMailComposeViewController是在IOS3.0新增的一个接口,它在MessageUI.framework中。通过调用MFMailComposeViewController,可以把邮件发送窗口集成到我们的应用里,发送邮件就不需要退出程序了。MFMailComposeViewController的使用方法:

  • 1.项目中引入MessageUI.framework;
  • 2.在使用的文件中导入MFMailComposeViewController.h头文件;
  • 3.实现MFMailComposeViewControllerDelegate,处理邮件发送事件;
  • 4.调出邮件发送窗口前先使用MFMailComposeViewController里的“+ (BOOL)canSendMail”方法检查用户是否设置了邮件账户;
  • 5.初始化MFMailComposeViewController,构造邮件体
  1. #import    
  2. #import    
  3. @interface ViewController UIViewController    
  4. @end   
  1. #pragma mark 在应用内发送邮件   
  2. //激活邮件功能   
  3. (void)sendMailInApp   
  4. {   
  5.     Class mailClass (NSClassFromString(@"MFMailComposeViewController"));    
  6.     if (!mailClass) {   
  7.         [self alertWithMessage:@"当前系统版本不支持应用内发送邮件功能,您可以使用mailto方法代替"];   
  8.         return;   
  9.     }   
  10.     if (![mailClass canSendMail]) {   
  11.         [self alertWithMessage:@"用户没有设置邮件账户"];   
  12.         return;   
  13.     }   
  14.     [self displayMailPicker];   
  15. }   
  16.   
  17. //调出邮件发送窗口   
  18. (void)displayMailPicker   
  19. {   
  20.     MFMailComposeViewController *mailPicker [[MFMailComposeViewController alloc] init];     
  21.     mailPicker.mailComposeDelegate self;       
  22.     //设置主题     
  23.     [mailPicker setSubject: @"eMail主题"];     
  24.     //添加收件人   
  25.     NSArray *toRecipients [NSArray arrayWithObject: @"first@example.com"];   
  26.     [mailPicker setToRecipients: toRecipients];     
  27.     //添加抄送   
  28.     NSArray *ccRecipients [NSArray arrayWithObjects:@"second@example.com"@"third@example.com"nil];     
  29.     [mailPicker setCcRecipients:ccRecipients];         
  30.     //添加密送   
  31.     NSArray *bccRecipients [NSArray arrayWithObjects:@"fourth@example.com"nil];     
  32.     [mailPicker setBccRecipients:bccRecipients];     
  33.        
  34.     // 添加一张图片     
  35.     UIImage *addPic [UIImage imageNamed: @"Icon@2x.png"];     
  36.     NSData *imageData UIImagePNGRepresentation(addPic);            // png        
  37.     //关于mimeType:http://www.iana.org/assignments/media-types/index.html   
  38.     [mailPicker addAttachmentData: imageData mimeType: @"" fileName: @"Icon.png"];     
  39.     
  40.     //添加一个pdf附件   
  41.     NSString *file [self fullBundlePathFromRelativePath:@"高质量C++编程指南.pdf"];   
  42.     NSData *pdf [NSData dataWithContentsOfFile:file];   
  43.     [mailPicker addAttachmentData: pdf mimeType: @"" fileName: @"高质量C++编程指南.pdf"];     
  44.   //添加一个视频
  45.     NSString *path=[NSString stringWithFormat:@"%@/Documents/%@",NSHomeDirectory(),@"20121219.avi"];

        NSData *video = [NSData dataWithContentsOfFile:path];

        [mailPicker addAttachmentData:video mimeType: @"" fileName:@"20121219.avi"];

  46.     NSString *emailBody @"eMail 正文"    
  47.     [mailPicker setMessageBody:emailBody isHTML:YES];     
  48.     [self presentModalViewController: mailPicker animated:YES];     
  49.     [mailPicker release];     
  50. }   
  51. #pragma mark 实现 MFMailComposeViewControllerDelegate    
  52. (void)mailComposeController:(MFMailComposeViewController *)controller didFinishWithResult:(MFMailComposeResult)result error:(NSError *)error   
  53. {    //关闭邮件发送窗口   
  54.     [self dismissModalViewControllerAnimated:YES];   
  55.     NSString *msg;     
  56.     switch (result)     
  57.         case MFMailComposeResultCancelled:     
  58.             msg @"用户取消编辑邮件"    
  59.             break    
  60.         case MFMailComposeResultSaved    
  61.             msg @"用户成功保存邮件"    
  62.             break    
  63.         case MFMailComposeResultSent:     
  64.             msg @"用户点击发送,将邮件放到队列中,还没发送"    
  65.             break    
  66.         case MFMailComposeResultFailed:     
  67.             msg @"用户试图保存或者发送邮件失败"    
  68.             break    
  69.         default    
  70.             msg @"";   
  71.             break    
  72.         
  73.     [self alertWithMessage:msg];   
  74. }   
内容概要:本文系统阐述了企业新闻发稿在生成式引擎优化(GEO)时代下的全渠道策略与效果评估体系,涵盖当前企业传播面临的预算、资源、内容与效果评估四大挑战,并深入分析2025年新闻发稿行业五大趋势,包括AI驱动的智能化转型、精准化传播、首发内容价值提升、内容资产化及数据可视化。文章重点解析央媒、地方官媒、综合门户和自媒体四类媒体资源的特性、传播优势与发稿策略,提出基于内容适配性、时间节奏、话题设计的策略制定方法,并构建涵盖品牌价值、销售转化与GEO优化的多维评估框架。此外,结合“传声港”工具实操指南,提供AI智能投放、效果监测、自媒体管理与舆情应对的全流程解决方案,并针对科技、消费、B2B、区域品牌四大行业推出定制化发稿方案。; 适合人群:企业市场/公关负责人、品牌传播管理者、数字营销从业者及中小企业决策者,具备一定媒体传播经验并希望提升发稿效率与ROI的专业人士。; 使用场景及目标:①制定科学的新闻发稿策略,实现从“流量思维”向“价值思维”转型;②构建央媒定调、门户扩散、自媒体互动的立体化传播矩阵;③利用AI工具实现精准投放与GEO优化,提升品牌在AI搜索中的权威性与可见性;④通过数据驱动评估体系量化品牌影响力与销售转化效果。; 阅读建议:建议结合文中提供的实操清单、案例分析与工具指南进行系统学习,重点关注媒体适配性策略与GEO评估指标,在实际发稿中分阶段试点“AI+全渠道”组合策略,并定期复盘优化,以实现品牌传播的长期复利效应。
【EI复现】基于主从博弈的新型城镇配电系统产消者竞价策略【IEEE33节点】(Matlab代码实现)内容概要:本文介绍了基于主从博弈理论的新型城镇配电系统中产消者竞价策略的研究,结合IEEE33节点系统进行建模与仿真分析,采用Matlab代码实现。研究聚焦于产消者(兼具发电与用电能力的主体)在配电系统中的竞价行为,运用主从博弈模型刻画配电公司与产消者之间的交互关系,通过优化算法求解均衡策略,实现利益最大化与系统运行效率提升。文中详细阐述了模型构建、博弈机制设计、求解算法实现及仿真结果分析,复现了EI期刊级别的研究成果,适用于电力市场机制设计与智能配电网优化领域。; 适合人群:具备电力系统基础知识和Matlab编程能力,从事电力市场、智能电网、能源优化等相关领域的研究生、科研人员及工程技术人员。; 使用场景及目标:①学习主从博弈在电力系统中的建模方法;②掌握产消者参与电力竞价的策略优化技术;③复现EI级别论文的仿真流程与结果分析;④开展配电网经济调度与市场机制设计的相关课题研究。; 阅读建议:建议读者结合提供的Matlab代码,深入理解博弈模型的数学表达与程序实现细节,重点关注目标函数构建、约束条件处理及算法收敛性分析,可进一步拓展至多主体博弈或多时间尺度优化场景。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值