发短信的功能对于一个需要渠道扩展的app来说,必不可少。但是,当第一次看到这个需求时,我却一脸懵逼,因为之前并没有接触过,出于对未知事物的恐惧,被分配做这个任务的时候其实我是拒绝的,但是,没办法谁让我是小兵一个呢,只能硬着头皮强上了。在查阅了一番资料之后,发现这个功能做起来其实非常简单,不到十分钟就可以解决。下面我们就来聊一下如何实现这个功能。
首先,我们来介绍一个最为简单的方法,只需要一行代码就可以搞定,代码如下:
1
|
[[uiapplication sharedapplication] openurl:[nsurl urlwithstring:@ "sms://800888" ]];
|
但是,这段代码虽然简单,缺陷却也明显,这段代码属于程序外部调用,也就是跳出app程序本身,利用手机短信功能发送短信,在发送短信页面点击取消按钮时,回到的是手机短信功能页面,而不是app程序。而且,此方法也不能传入默认的短信文本,需要自己手动输入,很可能无法满足需求。所以:
我们需要知道的一点是,苹果官方在发送短信功能方面有一个框架,叫做messageui,此框架可以解决上述一切问题,而且轻松方便容易实现,下面我们就来介绍一下这个框架的使用:
在吃大餐之前,让我们先来几道前菜:
导入框架:messageui.framework
2.导入头文件:#import <messageui/messageui.h>
3.添加协议:<mfmessagecomposeviewcontrollerdelegate>
添加完协议之后,我们首先想到的就是实现协议方法,可是还不能急,我们还得检测一下设备是否可以发送短信。如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
|
- ( void )showsmspicker:(id)sender
{
/**
您必须检查当前设备是否可以在尝试创建一个mfmessagecomposeviewcontroller的实例之前发送短信
。 如果设备无法发送短信,
[[mfmessagecomposeviewcontroller alloc] init]将返回nil。 您的应用程式用一个空视图控制器调用
-presentviewcontroller时会导致崩溃。
**/
if ([mfmessagecomposeviewcontroller cansendtext])
// the device can send email.
{
[self displaysmscomposersheet];
}
else
// the device can not send email.
{
self.feedbackmsg.hidden = no;
self.feedbackmsg.text = @ "device not configured to send sms." ;
}
}
- ( void )displaysmscomposersheet
{
mfmessagecomposeviewcontroller *picker = [[mfmessagecomposeviewcontroller alloc] init];
picker.messagecomposedelegate = self;
//您可以指定一个或多个预配置的收件人。 用户有从消息编辑器视图中删除或添加收件人的选项控制器
//您可以指定将出现在消息编辑器视图控制器中的初始消息文本。
picker.recipients = @[@ "phone number here" ]; //发短信的手机号码的数组,数组中是一个即单发,多个即群发。
picker.body = @ "hello from california!" ; //短信主体内容
[self presentviewcontroller:picker animated:yes completion:null];
}
|
检测是否可以发送短信,还是需要有一个触发事件的,代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
- ( void )viewdidload {
[super viewdidload];
// do any additional setup after loading the view, typically from a nib.
uibutton * button = [[uibutton alloc]initwithframe:cgrectmake(140, 100, 100, 100)];
button.backgroundcolor = [uicolor blackcolor];
[button settitle:@ "发送短信" forstate:uicontrolstatenormal];
[button settitlecolor:[uicolor whitecolor] forstate:uicontrolstatenormal];
[button addtarget:self action:@selector(showsmspicker:) forcontrolevents:uicontroleventtouchupinside];
[self.view addsubview:button];
uilabel * feedbackmsg = [[uilabel alloc]initwithframe:cgrectmake(10, 300, self.view.frame.size.width -20, 30)];
feedbackmsg.textalignment = nstextalignmentcenter;
[self.view addsubview:feedbackmsg];
self.feedbackmsg = feedbackmsg;
}
|
嗯,到了实现协议方法的时候了:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
|
// -------------------------------------------------------------------------------
// messagecomposeviewcontroller:didfinishwithresult:
// dismisses the message composition interface when users tap cancel or send.
// proceeds to update the feedback message field with the result of the
// operation.
// 当用户点击取消或发送时,关闭消息组合界面。
// 收到更新反馈消息字段的结果操作。
// -------------------------------------------------------------------------------
- ( void )messagecomposeviewcontroller:(mfmessagecomposeviewcontroller *)controller
didfinishwithresult:(messagecomposeresult)result
{
self.feedbackmsg.hidden = no;
// notifies users about errors associated with the interface
// 通知用户与界面相关的错误
switch (result)
{
case messagecomposeresultcancelled: //取消
self.feedbackmsg.text = @ "result: sms sending canceled" ;
break ;
case messagecomposeresultsent: //发送
self.feedbackmsg.text = @ "result: sms sent" ;
break ;
case messagecomposeresultfailed: //失败
self.feedbackmsg.text = @ "result: sms sending failed" ;
break ;
default : //默认
self.feedbackmsg.text = @ "result: sms not sent" ;
break ;
}
[self dismissviewcontrolleranimated:yes completion:null];
}
|
demo运行结果如下:
至此,我们的发送短信功能就实现了,是不是很简单!但是,当年也是怂过啊,所以,特写此文,以纪念当年怂过的日子。
参考文章
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:http://www.jianshu.com/p/0c661ac22ba3?utm_source=tuicool&utm_medium=referral