Effettuare una chiamata a livello di codice


138

Come posso effettuare una telefonata a livello di programmazione su iPhone? Ho provato il seguente codice ma non è successo nulla:

NSString *phoneNumber = mymobileNO.titleLabel.text;
[[UIApplication sharedApplication] openURL:[NSURL URLWithString:phoneNumber]];

2
Per il codice rapido puoi seguire questa risposta stackoverflow.com/a/29869456/3950397
Sahil Kapoor,

Risposte:


189

Probabilmente il valore mymobileNO.titleLabel.text non include lo schema tel: //

Il tuo codice dovrebbe apparire così:

NSString *phoneNumber = [@"tel://" stringByAppendingString:mymobileNO.titleLabel.text];
[[UIApplication sharedApplication] openURL:[NSURL URLWithString:phoneNumber]];

3
Non è possibile che torniamo all'applicazione originale con questo approccio.
Artem Oboturov,

4
Penso che l'approccio di Mellon sia migliore in quanto richiede prima all'utente, quindi torna alla tua app dopo la chiamata. Assicurati di usare canOpenURL: e il fallback al prompt tel: poiché telprompt non è ufficiale e potrebbe essere rimosso in una futura versione di iOS.
joel.d

Come posso effettuare una telefonata da Apple Watch.
Ahad Khan,

1
Posso attivare l'altoparlante in modo programmatico per le chiamate originate in questo modo in iOS?
uniruddh,

anche tel: 1234567890 funziona anche come dire: // 1234567890 funziona
Durai Amuthan.H

218

Per tornare all'app originale puoi usare telprompt: // invece di tel: // - Il prompt tell richiederà prima all'utente, ma al termine della chiamata tornerà alla tua app:

NSString *phoneNumber = [@"telprompt://" stringByAppendingString:mymobileNO.titleLabel.text];
[[UIApplication sharedApplication] openURL:[NSURL URLWithString:phoneNumber]];

9
Ho una domanda: le app che usano telprompt: // saranno rifiutate da Apple?
Smeegol,

7
So che questo è vecchio ma ho trovato un paio di persone che sostenevano che le loro app fossero state approvate utilizzando telprompt: "Ho inviato la mia app che utilizza telprompt con un'applicazione condivisa senza uiwebkit ed è stata approvata con successo da Apple. Risposta 19 gennaio 2013 Pablo Alejandro Junge "
Mark McCorkle,

1
telprompt: // non è documentato e pertanto non dovrebbe mai essere invocato. Le cose potrebbero essere cambiate, ad esempio Apple potrebbe decidere che un determinato schema URL è qualcosa di cui hanno bisogno esclusivamente o che semplicemente non desiderano consentire, quindi la tua app si romperà.
DevC,

@DevC: qual è l'alternativa alla funzione di chiamata telefonica nella nostra app?
BaSha,

@BaSha tel://non usaretelprompt://
DevC

24

Unendo le risposte di @Cristian Radu e @Craig Mellon e il commento di @ joel.d, dovresti fare:

NSURL *urlOption1 = [NSURL URLWithString:[@"telprompt://" stringByAppendingString:phone]];
NSURL *urlOption2 = [NSURL URLWithString:[@"tel://" stringByAppendingString:phone]];
NSURL *targetURL = nil;

if ([UIApplication.sharedApplication canOpenURL:urlOption1]) {
    targetURL = urlOption1;
} else if ([UIApplication.sharedApplication canOpenURL:urlOption2]) {
    targetURL = urlOption2;
}

if (targetURL) {
    if (@available(iOS 10.0, *)) {
        [UIApplication.sharedApplication openURL:targetURL options:@{} completionHandler:nil];
    } else {
#pragma clang diagnostic push
#pragma clang diagnostic ignored "-Wdeprecated-declarations"
        [UIApplication.sharedApplication openURL:targetURL];
#pragma clang diagnostic pop
    }
} 

Questo tenterà innanzitutto di utilizzare l'URL "telprompt: //" e, in caso contrario, utilizzerà l'URL "tel: //". Se entrambi falliscono, stai provando a effettuare una chiamata su un iPad o iPod Touch.

Versione rapida:

let phone = mymobileNO.titleLabel.text
let phoneUrl = URL(string: "telprompt://\(phone)"
let phoneFallbackUrl = URL(string: "tel://\(phone)"
if(phoneUrl != nil && UIApplication.shared.canOpenUrl(phoneUrl!)) {
  UIApplication.shared.open(phoneUrl!, options:[String:Any]()) { (success) in
    if(!success) {
      // Show an error message: Failed opening the url
    }
  }
} else if(phoneFallbackUrl != nil && UIApplication.shared.canOpenUrl(phoneFallbackUrl!)) {
  UIApplication.shared.open(phoneFallbackUrl!, options:[String:Any]()) { (success) in
    if(!success) {
      // Show an error message: Failed opening the url
    }
  }
} else {
    // Show an error message: Your device can not do phone calls.
}

10

Le risposte qui funzionano perfettamente. Sto solo convertendo la risposta di Craig Mellon a Swift. Se qualcuno viene alla ricerca di una risposta rapida, questo li aiuterà.

 var phoneNumber: String = "telprompt://".stringByAppendingString(titleLabel.text!) // titleLabel.text has the phone number.
        UIApplication.sharedApplication().openURL(NSURL(string:phoneNumber)!)

puoi anche usare tel: // al posto di telprompt: //
Shivaay,

let phoneNumber: String = "telprompt: // (titleLabel.text)" UIApplication.shared.openURL (URL (string: phoneNumber)!)
tspentzas

8

Se stai usando Xamarin per sviluppare un'applicazione iOS, ecco l'equivalente C # per effettuare una chiamata all'interno della tua applicazione:

string phoneNumber = "1231231234";
NSUrl url = new NSUrl(string.Format(@"telprompt://{0}", phoneNumber));
UIApplication.SharedApplication.OpenUrl(url);

6

Swift 3

let phoneNumber: String = "tel://3124235234"
UIApplication.shared.openURL(URL(string: phoneNumber)!)

4

In Swift 3.0,

static func callToNumber(number:String) {

        let phoneFallback = "telprompt://\(number)"
        let fallbackURl = URL(string:phoneFallback)!

        let phone = "tel://\(number)"
        let url = URL(string:phone)!

        let shared = UIApplication.shared

        if(shared.canOpenURL(fallbackURl)){
            shared.openURL(fallbackURl)
        }else if (shared.canOpenURL(url)){
            shared.openURL(url)
        }else{
            print("unable to open url for call")
        }

    }

3

L'equivalente Java RoboVM:

public void dial(String number)
{
  NSURL url = new NSURL("tel://" + number);
  UIApplication.getSharedApplication().openURL(url);
}

3

Ho provato l'opzione Swift 3 sopra, ma non ha funzionato. Penso che sia necessario quanto segue se si deve eseguire su iOS 10+ su Swift 3:

Swift 3 (iOS 10+):

let phoneNumber = mymobileNO.titleLabel.text       
UIApplication.shared.open(URL(string: phoneNumber)!, options: [:], completionHandler: nil)

1
let phone = "tel://\("1234567890")";
let url:NSURL = NSURL(string:phone)!;
UIApplication.sharedApplication().openURL(url);

1

veloce

if let url = NSURL(string: "tel://\(number)"), 
    UIApplication.sharedApplication().canOpenURL(url) {
        UIApplication.shared.open(url, options: [:], completionHandler: nil)
}

0

'openURL:' è deprecato: prima deprecato in iOS 10.0 - Utilizzare openURL: opzioni: completamentoHandler: invece

nell'uso di Objective-c iOS 10+:

NSString *phoneNumber = [@"tel://" stringByAppendingString:mymobileNO.titleLabel.text];
[[UIApplication sharedApplication] openURL:[NSURL URLWithString:phoneNumber] options:@{} completionHandler:nil];
Utilizzando il nostro sito, riconosci di aver letto e compreso le nostre Informativa sui cookie e Informativa sulla privacy.
Licensed under cc by-sa 3.0 with attribution required.