前言
在開發App中,經常會使用到點擊撥打用戶電話功能,短信功能可能會比較少見,其實在iOS中提供了接口,讓我們調用。下面就讓我們快速的了解這兩個功能。
1.打電話功能
- 第一種是用UIWebView加載電話,這種是合法的,可以上App Store的。在實際開發中,本人一直使用此方法。 代碼如下:
UIWebView*callWebview =[[UIWebView alloc] init];
NSURL *telURL =[NSURL URLWithString:@"tel:10010"];
[callWebview loadRequest:[NSURLRequest requestWithURL:telURL]];
//記得添加到view上
[self.view addSubview:callWebview];
- 第二種是私有方法,網上查資料說是不能上App Store的(自己沒試過)。
[[UIApplication sharedApplication] openURL:[NSURL URLWithString:@"telprompt://10010"]];
2.短信功能
- 第一種最簡單是使用openURL:
[[UIApplication sharedApplication]openURL:[NSURL URLWithString:@"sms://10010"]];//發短信
此方法雖然方便,但是上面無法指定短信內容,iOS4.0新加入了MFMessageComposeViewController和MFMessageComposeViewControllerDelegate,提供了發送短信的接口,可以像發送郵件那樣不用跳出程序來發送短信.
- 第二種MFMessageComposeViewController:
MFMessageComposeViewController提供了操作界面使用前必須檢查canSendText方法,若返回NO則不應將這個controller展現出來,而應該提示用戶不支持發送短信功能. messageComposeDelegate :代理,處理發送結果 recipients :收信人<列表,支持群發> body :短信內容
Frameworks中要引入MessageUI.framework
#import <MessageUI/MessageUI.h>
添加協議:<MFMessageComposeViewControllerDelegate>
#import <MessageUI/MessageUI.h>
@interface DemoViewController : UIViewController <MFMessageComposeViewControllerDelegate>
@end
同時實現協議MFMessageComposeViewControllerDelegate
- (void)showMessageView
{
if( [MFMessageComposeViewController canSendText] ){
MFMessageComposeViewController * controller = [[MFMessageComposeViewController alloc]init]; //autorelease];
controller.recipients = [NSArray arrayWithObject:@"10010"];
controller.body = @"測試發短信";
controller.messageComposeDelegate = self;
[self presentModalViewController:controller animated:YES];
[[[[controller viewControllers] lastObject] navigationItem] setTitle:@"測試短信"];//修改短信界面標題
}else{
[self alertWithTitle:@"提示信息" msg:@"設備沒有短信功能"];
}
}
//MFMessageComposeViewControllerDelegate
- (void)messageComposeViewController:(MFMessageComposeViewController *)controller didFinishWithResult:(MessageComposeResult)result{
[controller dismissModalViewControllerAnimated:NO];//關鍵的一句 不能為YES
switch ( result ) {
case MessageComposeResultCancelled:
[self alertWithTitle:@"提示信息" msg:@"發送取消"];
break;
case MessageComposeResultFailed:// send failed
[self alertWithTitle:@"提示信息" msg:@"發送成功"];
break;
case MessageComposeResultSent:
[self alertWithTitle:@"提示信息" msg:@"發送失敗"];
break;
default:
break;
}
}
- (void) alertWithTitle:(NSString *)title msg:(NSString *)msg {
UIAlertView *alert = [[UIAlertView alloc] initWithTitle:title
message:msg
delegate:self
cancelButtonTitle:nil
otherButtonTitles:@"確定", nil];
[alert show];
}
}