swift UI专项训练40 用swift实现打电话和发短信功能

简介:    今天来讲一下如何让我们的APP可以访问系统的短信和电话功能。首先来说短信功能,比较简单,跟之前的做法差别不大,要使用UIApplication,它是一个单例。

   今天来讲一下如何让我们的APP可以访问系统的短信和电话功能。首先来说短信功能,比较简单,跟之前的做法差别不大,要使用UIApplication,它是一个单例。我们的功能是点击一个按钮,然后拨通一个内置的电话,需要在button的action中加入如下语句:

   @IBAction func phoneBtn(sender:UIButton){
       // var url1 = NSURL(string: "tel://"+canguanArray[0].tel)
        var url1 = NSURL(string: "tel://10086")
        UIApplication.sharedApplication().openURL(url1!)
    }

tel关键字代表电话,跟之前oc上的做法差不多,如果要拨打的电话是传值获得的,参考注释中的写法。除了tel关键字,还有sms关键字:

        var url1 = NSURL(string: "sms://10086")

这样的话是打开了10086的短信界面,如果我们要打开一个浏览器界面,使用下面代码:

 var url1 = NSURL(string: "http://blog.csdn.net/cg1991130")

不过使用这种方法发短信不能设置短信的内容,只能设置收信人。如果我们想要自定义发短信的内容的话,使用下面的方法:

首先在vc中导入头文件:

import MessageUI

之后让vc继承MFMessageCompose的代理:

class CaipinDetailViewController: UIViewController,MFMessageComposeViewControllerDelegate 
func canSendText() -> Bool{
    return MFMessageComposeViewController.canSendText()
    }//用来指示一条消息能否从用户处发送
    func configuredMessageComposeViewController() -> MFMessageComposeViewController{
    let messageComposeVC = MFMessageComposeViewController()
        messageComposeVC.messageComposeDelegate = self
        messageComposeVC.body = "HI! \(caipinArray[0].rest) 的 \(caipinArray[0].name) 味道很不错,邀你共享 -来自SoFun的邀请"
        return messageComposeVC
        
    }
     func messageComposeViewController(controller: MFMessageComposeViewController!, didFinishWithResult result: MessageComposeResult) {
        controller.dismissViewControllerAnimated(true, completion: nil)
    }

然后在按钮的action方法中加入以下代码:

   @IBAction func share(sender: UIButton) {
        let shareView = ShareViewController()
        self.presentViewController(shareView, animated: true, completion: nil)
    }
    @IBAction func message(sender: UIButton) {
        if self.canSendText(){
        let messageVC = self.configuredMessageComposeViewController()
          presentViewController(messageVC, animated: true, completion: nil)
        } else {
        let errorAlert = UIAlertView(title: "不能发送", message: "你的设备没有短信功能", delegate: self, cancelButtonTitle: "取消")
        }

        
    }

我们在真机上测试一下,效果图:




目录
相关文章
|
3月前
|
前端开发
使用element-ui中的table时,当有多选又有翻页功能时,点击翻页后之前选中的数据丢失
使用element-ui中的table时,当有多选又有翻页功能时,点击翻页后之前选中的数据丢失
|
28天前
|
前端开发
element ui实现多层级复杂表单的操作(添加与回显)之回显功能实现
element ui实现多层级复杂表单的操作(添加与回显)之回显功能实现
12 0
|
28天前
|
JSON 数据格式
element ui实现多层级复杂表单的操作(添加与回显)之添加功能实现
element ui实现多层级复杂表单的操作(添加与回显)之添加功能实现
12 0
|
28天前
element-ui实现表格单选的功能
element-ui实现表格单选的功能
12 0
|
6月前
|
JavaScript
vue + element-ui + vue-clipboard2 实现文字复制粘贴功能与提示
1、在所在项目下安装插件 ```js npm install vue-clipboard2 --save ``` 2、在所在项目的index.js注入vue-clipboard2 ```js import VueClipboard from 'vue-clipboard2' Vue.use(VueClipboard) ``` 3、使用 ```html <div> <el-button size="mini" type="primary" icon="el-icon-copy-document" round class="copy-btn" v-clipboard:copy="要
68 2
|
6月前
|
API
SAP UI5 里一个功能的 compatibility version 是什么含义?
SAP UI5 里一个功能的 compatibility version 是什么含义?
50 0
|
4月前
|
JavaScript
Vue + Element UI 实现复制当前行数据功能(复制到新增页面组件值不能更新等问题解决)
# 1、需求 使用Vue + Element UI 实现在列表的操作栏新增一个复制按钮,复制当前行的数据可以打开新增弹窗后亦可以跳转到新增页面,本文实现为跳转到新增页面。 # 2、实现 ## 1)列表页 index.vue ```html <el-table> <!-- 其他列 --> <el-table-column label="操作" width="150"> <template slot-scope="scope"> <el-button icon="el-icon-copy-document" title="复制" @click="toCopyNew(scope
72 0
|
5月前
Element UI 重置表单功能
Element UI 重置表单功能
|
6月前
|
存储 移动开发 开发框架
关于 SAP UI5 应用附件上传的病毒扫描功能 virus scan profile
关于 SAP UI5 应用附件上传的病毒扫描功能 virus scan profile
79 1
|
6月前
|
API 容器
sap.m.Table 和 sap. ui.table.Table 两个控件的功能对比
sap.m.Table 和 sap. ui.table.Table 两个控件的功能对比
45 0

热门文章

最新文章

相关课程

更多