Blog Post

Azure Communication Services Blog
3 MIN READ

Introducing Azure Communication Services UI Library to Xamarin & .NET MAUI

joshlai_microsoft's avatar
Feb 28, 2023

Introducing Azure Communication Services UI Library to Xamarin & .NET MAUI 

Azure Communication Services provides Calling Composite experiences on mobile platforms, a library that makes it easy for developers to include a calling experience into their application. With a goal of empowering more mobile developers worldwide; the Azure Communication Services team is excited to share that we have created a .NET MAUI and Xamarin sample to showcase how to introduce calling capabilities into your current applications.  

 

What is the UI Library 

The Azure Communication Services UI library offers Composites, that takes only a couple lines of code to add and configure. These composites are end-to-end to integrate into your existing applications. Our UI libraries provide an out of the box experience; it takes care of connecting to the call, and it sets up the user's participation in the call behind the scenes. They also provide developers with an experience that is fully accessible and localizable for their target audience.  

 

If you want to learn more about the Azure Communication Services UI Library, please visit the UI Library documentation on the Learn platform. 

 

What is .NET MAUI  

Introducing MAUI: .NET Multi-platform App UI (.NET MAUI) | .NET (microsoft.com) 

Many developers are already familiar with Xamarin.Forms, but last year Microsoft introduced us to .NET MAUI. .NET MAUI is open-source and is the next evolution of Xamarin.Forms. Using .NET MAUI, developers can create apps that can run on Android, iOS, macOS, and Windows from a single shared codebase.  

 

Getting Started 

 

Using the Samples 

The samples will walk you through steps on how developers can create a binding for iOS and Android platforms. These binding libraries allow your cross-platform application to consume a third-party native library. 

 

The great thing about our sample repo is that developers can just dive into our repo and take our bindings as is and include them in their project.  

 

Developers can check out the contents on bindings. There is a pre-built proxy library that bridges the Swift interface to Objective-C already, feel free to copy and edit these to your needs.  There is also a helpful script developers can use to build the FATFrameworks for the bindings.  

 

The way .NET MAUI and Xamarin need to build bindings is the same so the implementation should be the same regardless of which one you are using.  

 

iOS bindings have the solution that builds the `.dll` that can be used in your application. In your applications `.csproj` you can add our newly created binding `.dll` under the references folder.  

 

Learn more about creating iOS bindings here: Walkthrough: Bind an iOS Swift library - Xamarin | Microsoft Docs 

 

The contents of Android bindings have multiple folders in it. Each contains their own solution and `csproj`. Developers can reference these `csproj` directly in their solution or use the `.dll` files they generated in their own application. Let's not forget to include AzureCommunicationCalling `.aar` as an AndroidAarLibrary build item. 

 

Learn more about creating Android bindings here: Binding an .AAR - Xamarin | Microsoft Docs 

 

Now that the binding libraries are included, we can update the source code of the app and use the new public apis.  

 

 

Finally! Your app now can launch the UI Composite. We now have an audio and video experience embedded into the app.  

 

Of course, you can always just run our sample solution in the repo, play around and see how things work. You will notice you can launch the experience and it will be identical to how you expect native behavior to be.  

 

Check out our samples to learn more!  

 

.NET MAUI Azure-Samples/communication-services-ui-library-maui: UI sample library on how to create .NET MAUI bindings (github.com) 

Xamarin Azure-Samples/communication-services-ui-library-xamarin: UI sample library on how to create Xamarin bindings (github.com)

Updated Mar 10, 2023
Version 2.0
  • Allan83's avatar
    Allan83
    Copper Contributor

    For God sake, what is that? did you see the code before writing this article? Also, who wants that rigid UI? we want to be able to work with CallClient and Agent and so on. this composite thing rendering on it's own window with it's pre-defined controls!! seriously? 

     

    Another thing is that, yeah, we can Bind Jar! thanks. that is not what people are looking for. we want C# library that works on MAUI. simply, C# code that makes me consume the ACS and render it wherver I want using MAUI.

  • Neha_mazik's avatar
    Neha_mazik
    Copper Contributor

    Why is it have to be so complex ! , can we please implement ACS UI Library in MAUI using C# and required NuGet packages in the project.

  • ruwill's avatar
    ruwill
    Copper Contributor

    Love having access to the UI Library in Xamarin and MAUI!!!  I agree with Neha_mazik though, instead of having too include .csproj files into the solution or manually paste bindings into a project, developers would much rather add a nuget package for this library.  Typically, in Xamarin (and I assume the same to be true with MAUI), the nuget package documentation that comes with the nuget package has a link to a site (typically the repo) that explains the simple steps for how to consume the library and also any initialization code that needs to be added and where that code should be pasted in.  The link to the documentation is part of the nuget package and can be see in the Nuget Package Manager in you this case might point to this forums post.  For Xamarin, those instructions will tell developers that they need to add nuget packages in the shared project and in every platform project and that's how the bindings will become available for Xamarin devs.  It works like this for all plugins that have implementation that need to access platform specific things like the microphone.  The instructions will also tell the dev what permissions they need to configure for each project.

     

    Anyway, awesome work and looking forward to give this a try in an Android app that will be making calls to agents in Teams!

     

    -Russ

  • obehimary's avatar
    obehimary
    Copper Contributor

    Thanks for this. Please how can one use the chat composite on .Net maui? do you have an article or sample project on Github explaining this? Kindly share

  • shahjahanluni0's avatar
    shahjahanluni0
    Copper Contributor

    Is there any solution how to use bindings properly with custom project? Any source availble which guide properly?