Телефонный звонок с swift не работает с определенными номерами - PullRequest
0 голосов
/ 30 декабря 2018

Последние несколько часов я отчаянно пытался позвонить с помощью swift, когда я вызываю эту функцию.

    func callPhone(phoneNumber: String){
        guard let url = URL(string:"telprompt:\(phoneNumber)") else {
             print("failed to load url, phone number: \(phoneNumber)")

             return
        }
        UIApplication.shared.open(url)
    }

По какой-то причине это не работает, я везде исследовал онлайн ивсе еще не мог найти проблему, почему это не сработало.Некоторые числа иногда будут работать, например, если я попробую "123456789", это будет работать.но если я попробую другой номер, это не сработает;Оператор let let не работает, и URL будет пустым.Пожалуйста, помогите мне.Любая обратная связь будет принята с благодарностью.

Редактировать: Итак, я узнал, когда она не работает, но я не уверен, как ее решить.Это не работает, когда я получаю номер телефона с карты Apple, но когда я жестко кодирую номер телефона, это работает.Вот мой полный код:

import UIKit
import MapKit
import CoreLocation

class ViewController: UIViewController, CLLocationManagerDelegate, MKMapViewDelegate {

@IBOutlet weak var map: MKMapView!
let locationManager = CLLocationManager()
let regionMeters : Double = 10000

override func viewDidLoad() {
    super.viewDidLoad()

    map.delegate = self
    locationManager.delegate = self
    locationManager.desiredAccuracy = kCLLocationAccuracyBest
    locationManager.requestWhenInUseAuthorization()
    locationManager.startUpdatingLocation()
    map.showsUserLocation = true
    if let location = locationManager.location?.coordinate {
        let region = MKCoordinateRegion.init(center: location, latitudinalMeters: regionMeters, longitudinalMeters: regionMeters)

        map.setRegion(region, animated: true)
    }
    searchLocations(search: "Restaurant")

}
func mapView(_ mapView: MKMapView, viewFor annotation: MKAnnotation) -> MKAnnotationView? {
    let identifier = "Place"
        var annotationView = mapView.dequeueReusableAnnotationView(withIdentifier: identifier)

        if annotationView == nil {

            annotationView = MKMarkerAnnotationView(annotation: annotation, reuseIdentifier: identifier)
            annotationView!.canShowCallout = true

            let btn = UIButton(type: .contactAdd)

            annotationView!.rightCalloutAccessoryView = btn
        } else {
            annotationView!.annotation = annotation
        }

        return annotationView
}
func mapView(_ mapView: MKMapView, annotationView view: MKAnnotationView, calloutAccessoryControlTapped control: UIControl) {

    let subtitle = view.annotation?.subtitle as! String
    let splitted = subtitle.components(separatedBy: "+")
    let number = splitted.last as! String
    let trimmedNumber : String = number.components(separatedBy: [" ", "-", "(", ")"]).joined()
    CallOnPhone(phoneNumber: trimmedNumber)

}
func searchLocations(search : String){
    let searchRequest = MKLocalSearch.Request()
    searchRequest.naturalLanguageQuery = search
    searchRequest.region = map.region

    let activeSearch = MKLocalSearch(request: searchRequest)
    activeSearch.start { (response, err) in
        if response == nil {
            print("no request")
        } else {
            for item in (response?.mapItems)!{
                let annotation = MKPointAnnotation()
                annotation.title = item.name

                if let phone = item.phoneNumber {
                    annotation.subtitle = "Phone Number: \(phone as String)"
                }

                annotation.coordinate = item.placemark.coordinate
                self.map.addAnnotation(annotation)
            }



        }
    }
}

@objc func CallOnPhone(phoneNumber: String){
    let newStringPhone = phoneNumber.replacingOccurrences(of: " ", with: "", options: .literal, range: nil)
    print(newStringPhone)
    if newStringPhone != ""{
        if let url = URL(string: "tel://\(newStringPhone)"), UIApplication.shared.canOpenURL(url) {
            if #available(iOS 10, *) {
                UIApplication.shared.open(url)
            } else {
                UIApplication.shared.openURL(url)
            }
        }
    }

}

}

Спасибо,

Ответы [ 2 ]

0 голосов
/ 20 июня 2019

Попробуйте обрезать номер телефона.

let myphone:String = phoneNumber.trimmingCharacters(in:.whitespacesAndNewlines)

Полный код:

if let url = URL(string: "tel://\(myphone)"),UIApplication.shared.canOpenURL(url) {
        if #available(iOS 10, *) {
            UIApplication.shared.open(url, options: [:], completionHandler:nil)
        } else {
            UIApplication.shared.openURL(url)
        }
    } else {
        Util.shared.showToast(message: "Can't make call from this device", view: self.view)
    }
0 голосов
/ 30 декабря 2018

Ниже кода показано, как звонить по номеру при нажатии кнопки.Также удаляет пробел, если в фонене есть пробелы.

var phoneNumber = "Phone Number: 1234567"
var finalNumber = ""

let number = phoneNumber.split(separator: ":")
let tempNum = "\(number.last ?? "")"
print(tempNum)
let trimmedNumber : String = tempNum.components(separatedBy: [" ", "-", "(", ")"]).joined()
print(trimmedNumber)
finalNumber = trimmedNumber
print(finalNumber)

btn_Call.addTarget(self, action: #selector(CallOnPhone), for: .touchUpInside)

@objc func CallOnPhone(sender:UIButton){
    let newStringPhone = finalNumber.replacingOccurrences(of: " ", with: "", options: .literal, range: nil)
    print(newStringPhone)
    if newStringPhone != ""{
        if let url = URL(string: "tel://\(newStringPhone)"), UIApplication.shared.canOpenURL(url) {
            if #available(iOS 10, *) {
                UIApplication.shared.open(url)
            } else {
                UIApplication.shared.openURL(url)
            }
        }
    }

}

screenshot from iphone

...