**开发中经常会调用手机功能,今天来汇总一下,若有不足欢迎大家指出,下面分别介绍如下功能 : **
- 电话
- 短信
- 邮件
- 通讯录
- 定位
- 跳转应用
- 跳转App Store
- 打开其他文件
电话
调用电话有下图两种不同样式,相同的是,通话结束后均会返回你原界面
1- 直接跳至拨号界面
2- 先弹框提示,用户确认后再跳至拨号界面
- 直接跳至拨号界面
NSURL *url = [NSURL URLWithString:@"tel://10000000"];
[[UIApplication sharedApplication] openURL:url];
- 弹框提示有两种实现方式
1- UIApplication打开URL
NSURL *url = [NSURL URLWithString:@"telprompt://10000000"];
[[UIApplication sharedApplication] openURL:url];
2- UIWebView加载URL
//WebView若只实现打电话功能,可以不设置尺寸,以防挡住其他
UIWebView *_web;
_web= [[UIWebView alloc] initWithFrame:CGRectZero];
//在需要调用的地方调用
[_web loadRequest:[NSURLRequest requestWithURL:[NSURL URLWithString:@"tel://10000000"]]];
短信
短信一般是服务器发
短信样式一样,都是直接跳至短信编辑界面,有两种实现方式
1- UIApplication打开URL方式
跳至短信编辑页面后,用户手动编辑短信内容,完成后返回短信列表界面
缺点: 不能指定短信内容,不能自动回到原应用程序
2- MFMessageComposeViewController方式
和方式1比:
可以提前编辑好短信内容,跳至短信编辑界面时带有内容
可以群发
完成后可以返回原应用程序
- UIApplication打开URL方式
NSURL *url = [NSURL URLWithString:@"sms://100000"];
[[UIApplication sharedApplication] openURL:url];
- MFMessageComposeViewController方式
1.导入框架并实现协议
#import <MessageUI/MessageUI.h>
@interface ViewController ()<MFMessageComposeViewControllerDelegate>
2.编辑短信内容,群发对象,设置代理并弹出短信界面
MFMessageComposeViewController *messageVC = [[MFMessageComposeViewController alloc] init];
messageVC.body = @"你好,我是亲爱的大倩倩";
messageVC.recipients = @[@"000000",@"111111",@"222222"];
messageVC.messageComposeDelegate = self;
[self presentViewController:messageVC animated:YES completion:nil];
3.实现代理:短信发完后的回调,在此方法中设置返回原应用程序
参数1: 短信控制器
参数2:短信发送结果
- (void)messageComposeViewController:(MFMessageComposeViewController *)controller didFinishWithResult:(MessageComposeResult)result
{
[controller dismissViewControllerAnimated:YES completion:nil];
NSString *messageResult;
if (result == MessageComposeResultCancelled)
messageResult = @"短信取消发送";
else if(result == MessageComposeResultSent)
messageResult = @"短信已发送";
else
messageResult = @"短信发送失败!";
UIAlertController *alertController = [UIAlertController alertControllerWithTitle:messageResult message:nil preferredStyle:UIAlertControllerStyleAlert];
UIAlertAction *myAction = [UIAlertAction actionWithTitle:@"我知道了" style:UIAlertActionStyleCancel handler:nil];
[alertController addAction:myAction];
[self presentViewController:alertController animated:YES completion:nil];
}
邮件
邮件有两种实现方式:
1- UIApplication打开URL方式
不可提前编辑,发送后不会回到原应用程序
2- MFMailComposeViewController方式
可提前编辑,可群发,可带图片,附件,视频等,发送后退回原应用程序
- 用自带的邮件客户端(你绑定的邮箱是什么则发件人就是谁),发送完成后不会返回原应用程序
NSURL *url = [NSURL URLWithString:@"mailto://0000000@qq.com"];
[[UIApplication sharedApplication] openURL:url];
- MFMailComposeViewController方式
1.导入框架并实现协议
#import <MessageUI/MessageUI.h>
@interface ViewController ()<MFMailComposeViewControllerDelegate>
//在触发发送邮件的方法中设置2,3,4步
2.先判断是否开启了邮箱权限
if (![MFMailComposeViewController canSendMail])
{
UIAlertController *alertController = [UIAlertController alertControllerWithTitle:@"不能发送邮件" message:@"请检查邮箱设置" preferredStyle:UIAlertControllerStyleAlert];
UIAlertAction *myAction = [UIAlertAction actionWithTitle:@"我知道了" style:UIAlertActionStyleCancel handler:nil];
[alertController addAction:myAction];
[self presentViewController:alertController animated:YES completion:nil];
return;
}
3.声明MFMailComposeViewController对象,设置代理及其他属性
MFMailComposeViewController *mailVC = [[MFMailComposeViewController alloc] init];
mailVC.mailComposeDelegate = self;
//设置收件人
[mailVC setToRecipients:@[@"000000@qq.com",@"111111@qq.com"]];
// //添加抄送及密送
// NSArray *ccRecipients = [NSArray arrayWithObjects:@"second@example.com", @"third@example.com", nil];
// [mailVC setCcRecipients:ccRecipients];
// NSArray *bccRecipients = [NSArray arrayWithObjects:@"fourth@example.com", nil];
// [mailVC setBccRecipients:bccRecipients];
//设置主题
[mailVC setSubject:@"全体通知"];
//添加邮件正文
[mailVC setMessageBody:@"今天16:00办公室停电,大家提前下班吧" isHTML:NO];
//添加照片
UIImage *addPic = [UIImage imageNamed:@"icon_star_full@2x.png"];
NSData *imageData = UIImagePNGRepresentation(addPic);
[mailVC addAttachmentData:imageData mimeType:@"" fileName:@"icon_star_full.png"];
//还可以添加pdf文件及视频
4.跳转界面
[self presentViewController:mailVC animated:YES completion:nil];
5.实现代理
- (void)mailComposeController:(MFMailComposeViewController *)controller didFinishWithResult:(MFMailComposeResult)result error:(NSError *)error
{
[controller dismissViewControllerAnimated:YES completion:nil];
NSString *mailResult;
switch (result)
{
case MFMailComposeResultCancelled:
mailResult = @"用户取消编辑邮件";
break;
case MFMailComposeResultSaved:
mailResult = @"用户成功保存邮件";
break;
case MFMailComposeResultSent:
mailResult = @"用户点击发送,将邮件放到队列中,还没发送";
break;
case MFMailComposeResultFailed:
mailResult = @"用户试图保存或者发送邮件失败";
break;
default:
mailResult = @"";
break;
}
UIAlertController *alertController = [UIAlertController alertControllerWithTitle:mailResult message:nil preferredStyle:UIAlertControllerStyleAlert];
UIAlertAction *myAction = [UIAlertAction actionWithTitle:@"我知道了" style:UIAlertActionStyleCancel handler:nil];
[alertController addAction:myAction];
[self presentViewController:alertController animated:YES completion:nil];
}
邮件这个按钮要打开,不然无法发送
QQ网页版收到的邮件如下图:
通讯录
使用AddressBook和AddressBookUI框架实现
1- 导入框架
AddressBook.framework和AddressBookUI.framework
2- 导入头文件
#import <AddressBook/AddressBook.h>
#import <AddressBookUI/AddressBookUI.h>,
3- 实现协议并跳转通讯录界面
@interface ViewController ()<ABPeoplePickerNavigationControllerDelegate, UINavigationControllerDelegate>
//在按钮点击事件中跳转
ABPeoplePickerNavigationController *peopleVC = [[ABPeoplePickerNavigationController alloc] init];
peopleVC.peoplePickerDelegate = self;
[self presentViewController:peopleVC animated:YES completion:nil];
4- 有很多代理方法,不一一阐述了
定位
使用CLLocationManager来实现定位
1- 导入CoreLocation.framework框架
2- 导入头文件,实现协议
#import <CoreLocation/CoreLocation.h>
@interface ViewController ()<CLLocationManagerDelegate>
3- iOS8以上需要在Info.Plist文件中添加如下配置
(1)NSLocationAlwaysUsageDescription
(2)NSLocationWhenInUseUsageDescription
4- 声明CLLocationManager对象,开启定位
@property (nonatomic, strong) CLLocationManager *locationManager;
- (void)viewDidLoad
{
_locationManager=[[CLLocationManager alloc] init];
_locationManager.delegate=self;
//多少米定位一次
// _locationManager.desiredAccuracy = 0;
// _locationManager.distanceFilter = 500;
//初次打开时会有弹框提示,是否允许定位
if ([_locationManager respondsToSelector:@selector(requestWhenInUseAuthorization)])
{
[_locationManager requestWhenInUseAuthorization];
}
//开启定位
[_locationManager startUpdatingLocation];
}
5- 实现代理方法,会返给你地理位置信息,需要自己解码
1.声明字典,用于接收解码后的信息
@interface ViewController ()<CLLocationManagerDelegate>
{
NSDictionary *_addressDic;
}
2.实现代理
#pragma mark - 位置信息更新后,获取经纬度的代理方法
- (void)locationManager:(CLLocationManager *)manager didUpdateLocations:(NSArray<CLLocation *> *)locations
{
NSLog(@"定位成功");
CLLocation *location = [locations lastObject];
CLLocationCoordinate2D coordinate2D = location.coordinate;
NSLog(@"经纬度为----%f----%f",coordinate2D.latitude,coordinate2D.longitude);
[_locationManager stopUpdatingLocation];
// 反编码对象
CLGeocoder *geocoder = [[CLGeocoder alloc] init];
[geocoder reverseGeocodeLocation:location completionHandler:^(NSArray<CLPlacemark *> * _Nullable placemarks, NSError * _Nullable error)
{
CLPlacemark *placemark = [placemarks lastObject];
_addressDic = placemark.addressDictionary;
NSLog(@"地理位置信息:%@",_addressDic);
NSString *cityStr = _addressDic[@"City"];
NSLog(@"city:%@",_addressDic[@"City"]);
NSArray *arr = [cityStr componentsSeparatedByString:@"市"];
cityStr = [arr firstObject];
NSLog(@"截取的值为:%@",cityStr);
}];
}
跳转应用
使用UIApplication打开URL的方法
跳转应用就是在应用A中,某些操作后跳转至应用B,拿我的两个现有的应用举例,一个应用名字为"手机功能",就是写这篇文章的Demo,另一个应用名字为"FQMusicPlayer",现在实现点击"手机功能"界面中的button时,跳转至"FQMusicPlayer"
1- 需要配置"FQMusicPlayer"的url地址
2- "手机功能"跳至这个url地址即可
- 配置地址
可以直接配置如下图所示,跳转时跳至@"fq:"即可
也可配置下图,跳转时需要跳转@"fq://iOS.cn"
- 跳转url
NSURL *url = [NSURL URLWithString:@"fq://iOS.cn"];
[[UIApplication sharedApplication] openURL:url];
**备注 : **如果跳转时,是新打开"FQMusicPlayer",会调用didFinishLaunchingWithOptions方法,若它之前在后台运行,不会调用此方法
如果一个应用被另外一个应用打开,会调用下面的代理方法,可以在该方法中可以实现两个应用之间数据的传递
-(BOOL)application:(UIApplication *)application openURL:(NSURL *)url sourceApplication:(NSString *)sourceApplication annotation:(id)annotation
{
NSLog(@"%@,%@",url,sourceApplication);
return YES;
}
跳转至App Store
使用UIApplication打开URL方法
1- 首先拿到你要跳转的App Store地址(url),例如我们现在跳转至节奏大师,它的地址是https://itunes.apple.com/cn/app/jie-zou-da-shi/id493901993?mt=8
2- 将 http:// 替换为 itms:// 或者 itms-apps://,再调用代码即可
NSString *str = @"itms://itunes.apple.com/cn/app/jie-zou-da-shi/id493901993?mt=8";
[[UIApplication sharedApplication] openURL:[NSURL URLWithString:str]];
打开其它文件
拿pdf举例
- 若是远程访问的资源,可以用两方式打开:
1- UIApplication打开URL,会跳转Safari浏览器浏览网页
2- UIWebView打开URL,需要设置UIWebView的frame,内容在UIWebView上显示
拿百度网址举例吧,没找到远程的pdf文件
1.UIApplication打开URL
NSURL *url = [NSURL URLWithString:@"http://www.baidu.com"];
[[UIApplication sharedApplication] openURL:url];
2.UIWebView打开URL
NSURL *targetURL = [NSURL URLWithString:@"http://www.baidu.com"];
NSURLRequest *request = [NSURLRequest requestWithURL:targetURL];
[_web loadRequest:request];
访问网址还需要配置下图
- 若是访问本地的pdf文件(沙盒中),pdf文件是要可读的啊,不然不显示的
1- 若是真机,将文件直接拖进来
2- 若是模拟器,打印你的沙盒路径,打开Finder,command + shift + G,将文件放进去即可
NSString *path = [[NSBundle mainBundle] pathForResource:@"Swift" ofType:@"pdf"];
NSURL *url =[NSURL fileURLWithPath:path];
NSURLRequest*request =[NSURLRequest requestWithURL:url];
[_web loadRequest:request];