How to call a phone number from ios app? [duplicate] - ios

This question already has answers here:
What’s the correct URL for placing a call on an iPhone?
(5 answers)
Closed 9 years ago.
I'm trying to call a phone number from ios app using:
It's not working, although the method gets called:
-(IBAction)callPhone:(id)sender {
NSString *phoneCallNum = [NSString stringWithFormat:#"tel://%#",listingPhoneNumber ];
[[UIApplication sharedApplication] openURL:[NSURL URLWithString:phoneCallNum]];
NSLog(#"phone btn touch %#", phoneCallNum);
}
NSLog output: phone btn touch tel://+39 0668806972

your code is correct. did you check in real device. this function will not work in simulator.
try this also,
NSString *phNo = #"+919876543210";
NSURL *phoneUrl = [NSURL URLWithString:[NSString stringWithFormat:#"telprompt:%#",phNo]];
if ([[UIApplication sharedApplication] canOpenURL:phoneUrl]) {
[[UIApplication sharedApplication] openURL:phoneUrl];
} else
{
calert = [[UIAlertView alloc]initWithTitle:#"Alert" message:#"Call facility is not available!!!" delegate:nil cancelButtonTitle:#"ok" otherButtonTitles:nil, nil];
[calert show];
}
** Swift 3 version**
if let url = URL(string: "telprompt:\(phoneNumber)") {
if UIApplication.shared.canOpenURL(url) {
UIApplication.shared.open(call, options: []) { result in
// do something with result
}
}
}

Telephony does not work on simulators/iPod/iPad, you will require to run the app on an iPhone with active sim card.
Also the URL scheme to invoke the telephony application is tel:<phone_number>. Refer Apple docs.
Ideally, you should check if the device is having the telephony module and then perform the openURL: call. Use this code to perform the check,
if([[UIApplication sharedApplication] canOpenURL:callUrl]) {
[[UIApplication sharedApplication] openURL:callUrl];
}
else {
//Show error message to user, etc.
}

Use following method to make call:
NSString *phoneNumber = [#"tel://" stringByAppendingString:number];
[[UIApplication sharedApplication] openURL:[NSURL URLWithString:phoneNumber]];

You can try like below.
NSString *phoneNumber = [#"tel://" stringByAppendingString:Number];
[[UIApplication sharedApplication] openURL:[NSURL URLWithString:phoneNumber]];
Hope it helps you.

NSString *phoneNumber = [#"tel://" stringByAppendingString:#"9414481799"];
[[UIApplication sharedApplication] openURL:[NSURL URLWithString:phoneNumber]];
This will only run on device.

Related

How to jump to system setting's location service on iOS10?

Before I asked this question I had try:
Use [[UIApplication sharedApplication] openURL:[NSURL URLWithString:#"prefs:root=Privacy&path=LOCATION"]];It's work fine on iOS8 and iOS9,but there is nothing happen on iOS10.
Use [[UIApplication sharedApplication] openURL:[NSURL URLWithString:UIApplicationOpenSettingsURLString]];It's work fine on iOS8 and iOS9,too.However,on iOS10,when the app jump to system setting, the system setting exit immediately.
Use [[UIApplication sharedApplication]openURL:url options:#{}completionHandler:nil];It's crashed on iOS8 and iOS9,also,exit immediately on iOS10.
The question is can our app jump to system setting on iOS10? If yes.How?And for [[UIApplication sharedApplication]openURL:url options:#{}completionHandler:nil];what's the optionsmeans?We must code something for the options?
For some time now, apps have only been permitted to open their own settings pane in the settings app. There have been various settings URLs that have worked in the past, but recently Apple has been rejecting apps that use these URLS.
You can open your own application's settings:
if let url = URL(string:UIApplicationOpenSettingsURLString) {
UIApplication.shared.open(url, options: [:], completionHandler: nil)
}
Or in Objective-C
NSURL *url = [NSURL URLWithString:UIApplicationOpenSettingsURLString];
if (url != nil) {
[[UIApplication sharedApplication] openURL:url options:[NSDictionary new] completionHandler:nil];
}
If you are targeting version of iOS earlier than 10 then you may prefer to use the older, deprecated, but still functional method:
NSURL *url = [NSURL URLWithString:UIApplicationOpenSettingsURLString];
if (url != nil) {
#pragma clang diagnostic push
#pragma clang diagnostic ignored "-Wdeprecated-declarations"
[[UIApplication sharedApplication] openURL:url];
#pragma clang diagnostic pop
}
Note:I use this method for a long time and everyting goes well,but today(2018-9-14),I had been rejected.
Here is my previous answer,do not use this method forever:
CGFloat systemVersion = [[UIDevice currentDevice].systemVersion floatValue];
if (systemVersion < 10) {
[[UIApplication sharedApplication] openURL:[NSURL URLWithString:#"App-Prefs:root=Privacy&path=LOCATION"]];
}else{
[[UIApplication sharedApplication]openURL:[NSURL URLWithString:#"App-Prefs:root=Privacy&path=LOCATION"]
options:[NSDictionary dictionary]
completionHandler:nil];
}
Now I use this way:
if (#available(iOS 10.0, *)) {
[[UIApplication sharedApplication] openURL:[NSURL URLWithString:UIApplicationOpenSettingsURLString] options:[NSDictionary dictionary] completionHandler:nil];
} else {
[[UIApplication sharedApplication] openURL:[NSURL URLWithString:UIApplicationOpenSettingsURLString]];
}
Note :- this solution will not be useful for ios10 onwards
Dont forget to add URL schemes :-
Go to Project settings --> Info --> URL Types --> Add New URL Schemes-->URL Schemes = prefs
after that Use this url :-
let settingUrl = URL(string: "App-Prefs:root=Privacy&path=LOCATION")
And open using :-
if #available(iOS 10.0, *) {
UIApplication.shared.open(settingUrl) {
(isOpen:Bool) in
if !isOpen {
debugPrint("Error opening:\(settingUrl.absoluteString)")
// show error
}
}
}else{
if UIApplication.shared.canOpenURL(settingUrl) {
UIApplication.shared.open(settingUrl, completionHandler: { (success) in
print("Settings opened: \(success)") // Prints true
})
}
}
Enjoy :)..this worked for me.
Thanks to this guy. I figure out this URL Scheme Prefs:root=Privacy&path=LOCATION is only available in Today Widget, but no use in containing app.
In Today Widget, you can try this:
[self.extensionContext openURL:[NSURL URLWithString:#"Prefs:root=Privacy&path=LOCATION"] completionHandler:nil];
More about system URL Schemes, you can see here.
This all I got. Hope it will help you.
You can also open your app's setting center by opening"App-Prefs:root=your app bundle id". This will be easy for user to change setting for your app.
This works for me. iOS7 ~ iOS11
But if you are uing the iOS11, you can only jump to the app's setting page 😥
NSURL *url1 = [NSURL URLWithString:#"App-Prefs:root=Privacy&path=LOCATION"];
NSURL *url2 = [NSURL URLWithString:UIApplicationOpenSettingsURLString];
if (#available(iOS 11.0, *)) {
if ([[UIApplication sharedApplication] canOpenURL:url2]){
[[UIApplication sharedApplication] openURL:url2 options:#{} completionHandler:nil];
}
} else {
if ([[UIApplication sharedApplication] canOpenURL:url1]){
if (#available(iOS 10.0, *)) {
[[UIApplication sharedApplication] openURL:url1 options:#{} completionHandler:nil];
} else {
[[UIApplication sharedApplication] openURL:url1];
}
}
}

Call is not going from my ios app to Skype

Hi i am new for Ios app in my project i have added the facility for user make call from ios app to skype
for this i have installed skype in my device and when i made call call from my app call not going
What I have tried so far is the following:
NSString * userNameString = #"sarithasai";
NSString* urlString = [NSString stringWithFormat:#";skype://%#?call", userNameString];
[[UIApplication sharedApplication] openURL:[NSURL URLWithString:urlString]];
According to the Skype URI tutorial: iOS apps by MSDN your schema is wrong. You should probably use the following instead:
NSString *urlString = [NSString stringWithFormat:#"skype:%#?call", userNameString];
Note that you should check wether or not Skype is installed beforehand which is mentioned in the linked article as well.
To start a chat use the schema
skype:user?chat
To start a video call use
skype:user?call&video=true
Try this code,
BOOL installed = [[UIApplication sharedApplication] canOpenURL:[NSURL URLWithString:#"skype:"]];
if(installed)
{
[[UIApplication sharedApplication] openURL:[NSURL URLWithString:[NSString stringWithFormat:#"skype:%#?call", userNameString]]];
}
else
{
[[UIApplication sharedApplication] openURL:[NSURL URLWithString:#"http://itunes.com/apps/skype/skype"]];
}
for more detail follow here.

How to open WhatsApp programmatically and then get back to my app?

In my app I need to send links via WhatsApp. So this is how I do that:
NSString* link = (NSString *)CFBridgingRelease(CFURLCreateStringByAddingPercentEscapes(NULL,
(CFStringRef)resource.shareURL.absoluteString,
NULL,
CFSTR("!*'();:#&=+$,/?%#[]"),
kCFStringEncodingUTF8));
NSString * urlWhats = [NSString stringWithFormat:#"whatsapp://send?text=%#", link];
NSURL * whatsappURL = [NSURL URLWithString:urlWhats];
if ([[UIApplication sharedApplication] canOpenURL: whatsappURL]) {
[[UIApplication sharedApplication] openURL: whatsappURL];
} else {
UIAlertView * alert = [[UIAlertView alloc] initWithTitle:#"Unknown error"
message:#"Can't open Whatsapp"
delegate:nil
cancelButtonTitle:#"OK"
otherButtonTitles:nil];
[alert show];
}
But the problem is that it doesn't return automatically to my app after the message is sent. User needs to get back to the app manually. So how do I make it return to my app? Is it even possible?
It's not possible. The only theoretic way for this to work would be to send URI for your app to be opened by whatsapp in their completion handler. However, whatsapp scheme doesn't support such things so there is no way to force it to open your app after it has sent the message.

Custom URL link for linked in app

I am trying to open, linkedin app from my ios app. It is getting opened but with the user's home page. I want it to open with some profile. How can i send the profile id or name with custom url.
try this:
NSString *actionUrl = #"linkedin://#profile/52458178";
NSString *actionUrlWeb = #"http://www.linkedin.com/in/chetankedawat";
BOOL canOpenURL = [[UIApplication sharedApplication] canOpenURL:[NSURL URLWithString:actionUrl]];
if (canOpenURL){
[[UIApplication sharedApplication] openURL:[NSURL URLWithString:actionUrl]];
} else {
[[UIApplication sharedApplication] openURL:[NSURL URLWithString:actionUrlWeb]];
}

Initiate phone call from app with area code (prefix)

In my code, I have this snippet to make a phone call with dialing prefix (basically, a "call me" button) :
[[UIApplication sharedApplication] openURL:[NSURL URLWithString:#"telprompt://+0000000000"]];
if(SYSTEM_VERSION_LESS_THAN(#"7.0")) {
[[UIApplication sharedApplication] openURL:[NSURL URLWithString:#"tel:+0000000000"]];
}
I wonder if the iPhone will hide the dialing prefix when it's unnecessary (?).
Thanks,
For those interested, I found a easy way, using NSLocale currentLocale:
// Get the current locale.
NSLocale *currentLocale = [NSLocale currentLocale];
// Get country code, e.g. ES (Spain), FR (France), etc.
NSString *countryCode = [currentLocale objectForKey:NSLocaleCountryCode];
if ([countryCode isEqualToString:#"FR"]){
[[UIApplication sharedApplication] openURL:[NSURL URLWithString:#"telprompt://0000000000"]];
}
else {
[[UIApplication sharedApplication] openURL:[NSURL URLWithString:#"telprompt://+33000000000"]];
}
if(SYSTEM_VERSION_LESS_THAN(#"7.0")) {
if ([countryCode isEqualToString:#"FR"]){
[[UIApplication sharedApplication] openURL:[NSURL URLWithString:#"tel://0000000000"]];
}
else {
[[UIApplication sharedApplication] openURL:[NSURL URLWithString:#"tel:+ 33000000000"]];
}
}
Works deliciously.
Second answer to my own question :
according to this post, mobile Country code doesn't change when roaming : Does CTCarrier mobileNetworkCode change when roaming?
Best way is therefore :
{
CTTelephonyNetworkInfo *info = [CTTelephonyNetworkInfo new];
CTCarrier *carrier = info.subscriberCellularProvider;
NSLog(#"country code is: %#", carrier.mobileCountryCode);
// Get mobile network code
if ([carrier.mobileCountryCode isEqualToString:#"208"]){
[[UIApplication sharedApplication]
openURL:[NSURL URLWithString:#"telprompt://0000000000"]];
}
else {
[[UIApplication sharedApplication]
openURL:[NSURL URLWithString:#"telprompt://+33000000000"]];
}
if(SYSTEM_VERSION_LESS_THAN(#"7.0")) {
if ([carrier.mobileCountryCode isEqualToString:#"208"]){
[[UIApplication sharedApplication]
openURL:[NSURL URLWithString:#"tel://0000000000"]];
}
else {
[[UIApplication sharedApplication] openURL:[NSURL URLWithString:#"tel:+33000000000"]];
}
}
}
Works fine too.

Resources