TLDR:从背景中检测呼叫结束事件
请参阅以下问题的更新:

是否可以使用Swift从后台状态来检测/获取IOS 10中的呼叫状态.在早期版本中有一个CORE Telephony api,但现在似乎已经不推荐了.

我看到了CallKit Api,但是它表示它是基于VOIP的呼叫.我需要获得正常的CDMA / GSM呼叫的状态,而不是基于VOIP的呼叫,并且当呼叫结束时,只是通知服务器.我不需要访问可能是隐私问题的任何数据点,只需要一个事件,当通话结束,然后我的应用程序将是一个后台应用程序将启动.而已.任何指针如何做到这一点?

更新:使用CallKit Api我能够获得呼叫状态,尽管不能区分voip和正常的GSM呼叫.我可以一起工作我也可以通过以下方式获得本地通知.

func application(_ application: UIApplication,didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool {
        // Override point for customization after application launch.
        application.beginBackgroundTask(withName: "showN",expirationHandler:nil)
        return true
    }

extension AppDelegate: CXCallObserverDelegate {
       func callObserver(_ callObserver: CXCallObserver,callChanged call: CXCall) {
        if call.hasEnded == true {
            print("disconnected")
            let trigger = UNTimeIntervalNotificationTrigger(timeInterval:60,repeats:false)
            let identifier = "MyCalllocalnotification"
            let request = UNNotificationRequest(identifier: identifier,content: content,trigger: trigger)
            center.add(request,withCompletionHandler: { (error) in
                if let error = error{
                    print(error)
                }
            })
            Timer.scheduledTimer(timeInterval: 0.5,target: self,selector: #selector(AppDelegate.showN),userInfo: nil,repeats: false)
            print("Done")
        }
        if call.isOutgoing == true && call.hasConnected == false {
            print("Dialing")
        }
        if call.isOutgoing == false && call.hasConnected == false && call.hasEnded == false {
            print("Incoming")
        }
        if call.hasConnected == true && call.hasEnded == false {
            print("Connected")
        }
    }
}

并且函数showN为:

func showN(){
        let identifier = "MyCalllocalnotification"
        let trigger = UNTimeIntervalNotificationTrigger(timeInterval:1,repeats:false)
        let request = UNNotificationRequest(identifier: identifier,trigger: trigger)
        center.add(request,withCompletionHandler: { (error) in
            if let error = error{
                print(error)
            }
        })

但是(如预期的那样),当应用程序在后台长时间(超过3分钟)或屏幕被锁定时,这不起作用.我觉得我几乎在那里,但缺少一些东西.也认为这不是一个正确的方式来做到这一点,或者必须有一个更好的(迅速/ IOS标准)的方法来做到这一点.请推荐已经失去了50个赏金点:)

解决方法

“可以在IOS 10中使用Swift从后台状态检测/获取呼叫状态的事件”

是.

您的应用程序的背景状态只是暂停停止的方式.当这种情况发生时,系统将停止您的代码尝试反应的所有进程.

苹果做这个很好的理由.它们不是用户没有使用的应用程序在设备上使用电池.如果没有这样做,你的iPhone电池会很快耗尽.所以为了执行这个操作,所有保持在后台状态的应用程序将最终被暂停.那当然,除非你以几种不同的方式配置你的应用程序.

1)Background Executions

这看起来你可能已经在应用程序中做了.但这将允许您的应用程序执行任何长时间运行的任务,可能尚未完成或需要扩展一点.如你所知,这些后台任务允许运行的时间有限制.您的应用程序暂停时不会执行.它将使您的应用程序在后台状态长达3分钟,以完成其工作.一旦完成,您的应用程序将立即进入暂停状态.

2)Background Modes

使您的应用程序最可靠的方式将保持在后台状态,即在项目配置中启用能够指示您的应用程序利用有效背景模式的功能.我的应用程序Sublam这样做.它是一个音乐播放器应用程序,可以增强iTunes中的音乐,使其最佳.如果用户只能在应用程序处于前台时才听音乐,那将是非常烦人的.几乎保持囚犯,永远不能离开或音乐会停止.我启用了背景模式,使我的应用程序在后台远离可怕的挂起状态.这样我的应用程序可以处理用户输入来更改歌曲,暂停,播放或任何我的应用程序需要做出的其他动作.

您的应用程序将需要符合有效的后台模式,以确保它保持在后台状态,并能够对任何来电进行响应.否则,CXCallObserverDelegate方法将不会执行.

“我需要获得正常CDMA / GSM通话的状态,而不是基于VOIP的呼叫”

正如Mukund和Raza所说,你不能使用CallKit来确定这些信息.希望这将成为未来CallKit的一个新功能.但是到目前为止,这个功能不被支持.

在IOS 10(Swift 3,Xcode 8)中检测GSM呼叫状态,并从Background状态检测通知的更多相关文章

  1. HTML5自定义视频播放器源码

    这篇文章主要介绍了HTML5自定义视频播放器源码,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下

  2. HTML5自定义mp3播放器源码

    这篇文章主要介绍了HTML5自定义mp3播放器源码,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下

  3. html5自定义video标签的海报与播放按钮功能

    这篇文章主要介绍了html5自定义video标签的海报与播放按钮功能,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下

  4. CSS中实现动画效果-附案例

    这篇文章主要介绍了 CSS中实现动画效果并附上案例代码及实现效果,就是CSS动画样式处理,动画声明需要使用@keyframes name,后面的name是人为定义的动画名称,下面我们来看看文章的具体实现内容吧,需要的小伙伴可以参考一下

  5. h5页面背景图很长要有滚动条滑动效果的实现

    这篇文章主要介绍了h5页面背景图很长要有滚动条滑动效果的实现,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  6. html5借用repeating-linear-gradient实现一把刻度尺(ruler)

    这篇文章主要介绍了html5借用repeating-linear-gradient实现一把刻度尺,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

  7. 如何在Canvas中添加事件的方法示例

    这篇文章主要介绍了如何在Canvas中添加事件的方法示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

  8. HTML5自定义元素播放焦点图动画的实现

    这篇文章主要介绍了HTML5自定义元素播放焦点图动画的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

  9. 有关HTML5页面在iPhoneX适配问题

    这篇文章主要介绍了有关HTML5页面在iPhoneX适配问题,需要的朋友可以参考下

  10. html5简介及新增功能介绍

    这篇文章主要介绍了html5简介及新增功能介绍,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

随机推荐

  1. iOS实现拖拽View跟随手指浮动效果

    这篇文章主要为大家详细介绍了iOS实现拖拽View跟随手指浮动,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  2. iOS – genstrings:无法连接到输出目录en.lproj

    使用我桌面上的项目文件夹,我启动终端输入:cd然后将我的项目文件夹拖到终端,它给了我路径.然后我将这行代码粘贴到终端中找.-name*.m|xargsgenstrings-oen.lproj我在终端中收到此错误消息:genstrings:无法连接到输出目录en.lproj它多次打印这行,然后说我的项目是一个目录的路径?没有.strings文件.对我做错了什么的想法?

  3. iOS 7 UIButtonBarItem图像没有色调

    如何确保按钮图标采用全局色调?解决方法只是想将其转换为根注释,以便为“回答”复选标记提供更好的上下文,并提供更好的格式.我能想出这个!

  4. ios – 在自定义相机层的AVFoundation中自动对焦和自动曝光

    为AVFoundation定制图层相机创建精确的自动对焦和曝光的最佳方法是什么?

  5. ios – Xcode找不到Alamofire,错误:没有这样的模块’Alamofire’

    我正在尝试按照github(https://github.com/Alamofire/Alamofire#cocoapods)指令将Alamofire包含在我的Swift项目中.我创建了一个新项目,导航到项目目录并运行此命令sudogeminstallcocoapods.然后我面临以下错误:搜索后我设法通过运行此命令安装cocoapodssudogeminstall-n/usr/local/bin

  6. ios – 在没有iPhone6s或更新的情况下测试ARKit

    我在决定下载Xcode9之前.我想玩新的框架–ARKit.我知道要用ARKit运行app我需要一个带有A9芯片或更新版本的设备.不幸的是我有一个较旧的.我的问题是已经下载了新Xcode的人.在我的情况下有可能运行ARKit应用程序吗?那个或其他任何模拟器?任何想法或我将不得不购买新设备?解决方法任何iOS11设备都可以使用ARKit,但是具有高质量AR体验的全球跟踪功能需要使用A9或更高版本处理器的设备.使用iOS11测试版更新您的设备是必要的.

  7. 将iOS应用移植到Android

    我们制作了一个具有2000个目标c类的退出大型iOS应用程序.我想知道有一个最佳实践指南将其移植到Android?此外,由于我们的应用程序大量使用UINavigation和UIView控制器,我想知道在Android上有类似的模型和实现.谢谢到目前为止,guenter解决方法老实说,我认为你正在计划的只是制作难以维护的糟糕代码.我意识到这听起来像很多工作,但从长远来看它会更容易,我只是将应用程序的概念“移植”到android并从头开始编写.

  8. ios – 在Swift中覆盖Objective C类方法

    我是Swift的初学者,我正在尝试在Swift项目中使用JSONModel.我想从JSONModel覆盖方法keyMapper,但我没有找到如何覆盖模型类中的Objective-C类方法.该方法的签名是:我怎样才能做到这一点?解决方法您可以像覆盖实例方法一样执行此操作,但使用class关键字除外:

  9. ios – 在WKWebView中获取链接URL

    我想在WKWebView中获取tapped链接的url.链接采用自定义格式,可触发应用中的某些操作.例如HTTP://我的网站/帮助#深层链接对讲.我这样使用KVO:这在第一次点击链接时效果很好.但是,如果我连续两次点击相同的链接,它将不报告链接点击.是否有解决方法来解决这个问题,以便我可以检测每个点击并获取链接?任何关于这个的指针都会很棒!解决方法像这样更改addobserver在observeValue函数中,您可以获得两个值

  10. ios – 在Swift的UIView中找到UILabel

    我正在尝试在我的UIViewControllers的超级视图中找到我的UILabels.这是我的代码:这是在Objective-C中推荐的方式,但是在Swift中我只得到UIViews和CALayer.我肯定在提供给这个方法的视图中有UILabel.我错过了什么?我的UIViewController中的调用:解决方法使用函数式编程概念可以更轻松地实现这一目标.

返回
顶部