Code to Launch the Phone Dialer in Xamarin.Forms
When we code to start a voice call, we must be aware of Dependency Service in Xamarin.Forms.
DependencyService in Xamarin.Forms provides access to the native functionality and some platform-specific implementations of the iOS, Android and Windows Phone SDKs from your PCL or Shared Project.
To start a voice call there are some platform-specific implementations and permissions.
1. The following is the procedure to implement the voice call in Xamarin.Forms. Let's create a ContentPage with an entry and a button as HomePage.cs.
data:image/s3,"s3://crabby-images/b7018/b70186e0f7fce4732e28d484d5295a269af61479" alt="HomePage"
2. Create an interface IPhoneCall.cs in the shared code that shows the functionality that we intend to implement.
data:image/s3,"s3://crabby-images/36a15/36a152d05c8e3b303598d84b9cfd7014b1e06016" alt="IPhoneCall"
3. The Interface must be implemented in each platform-specific application project.
DependencyService in Xamarin.Forms provides access to the native functionality and some platform-specific implementations of the iOS, Android and Windows Phone SDKs from your PCL or Shared Project.
To start a voice call there are some platform-specific implementations and permissions.
1. The following is the procedure to implement the voice call in Xamarin.Forms. Let's create a ContentPage with an entry and a button as HomePage.cs.
2. Create an interface IPhoneCall.cs in the shared code that shows the functionality that we intend to implement.
3. The Interface must be implemented in each platform-specific application project.
Android implementation: Before implementing the interface in Android don't forget to set some permissions in AndroidManifest.xml. These permissions are necessary for invoking a voice call in Android.
data:image/s3,"s3://crabby-images/def6a/def6a4702c6eefce2d21976c3c7a6404aa1e07aa" alt="Android implementation"
After setting the permissions we must implement the interface using a small classPhoneCall_Droid.cs.
data:image/s3,"s3://crabby-images/212e5/212e5f255dfbc8112540e54eee8cc6f5f4d0e3bf" alt="PhoneCall Droid"
iOS implementation: implementing for iOS create a call named as PhoneCall_iOS.cs.
*iOS implementation
Windows Phone implementation: Windows Phone has a simple API to invoke the dialer, the only caveat is to remember to tick the ID_CAP_PHONEDIALER capability in the WMAppManifest.xml, otherwise access to the dialer APIs are blocked.
data:image/s3,"s3://crabby-images/44b9a/44b9ab095c755886ad15d7aa6c5426d7e0c67047" alt="ID"
The implementation is only two lines of code as in the following:
data:image/s3,"s3://crabby-images/48f3d/48f3d2b7049c5dcad33cf39105631f44e6bf9f6f" alt="implementation"
4. We had completed implementing the interface and registering each specific platform. Now we can write DependencyService to get an instance of the interfaces.
data:image/s3,"s3://crabby-images/a0f14/a0f1428df002b975660969185605a594d269ad29" alt="DependencyService"
After setting the permissions we must implement the interface using a small classPhoneCall_Droid.cs.
iOS implementation: implementing for iOS create a call named as PhoneCall_iOS.cs.
*iOS implementation
Windows Phone implementation: Windows Phone has a simple API to invoke the dialer, the only caveat is to remember to tick the ID_CAP_PHONEDIALER capability in the WMAppManifest.xml, otherwise access to the dialer APIs are blocked.
The implementation is only two lines of code as in the following:
4. We had completed implementing the interface and registering each specific platform. Now we can write DependencyService to get an instance of the interfaces.
HAPPY CODING (-_-)