Search

Drop Down MenusCSS Drop Down MenuPure CSS Dropdown Menu

Thursday, March 29, 2018

Building video Indexer Xamarin Mobile Application Using Cognitive Service


Introduction:
Microsoft introduced the public preview of Video Indexer as a part of Cognitive Service. Previously, we used
Video API but now it's replaced with Video Indexer. Video Indexer automatically extracts the metadata and
builds intelligent innovative AI applications based on Video and Audio.
In this article, I will show how to integrate Video Indexer embeddable widgets into the mobile application.
Create Video Indexer Account:
The implementing Video Indexer into the application, you must have to create account and upload your video
using my previous article as a reference .
Video Indexer supports embedding two types of widgets into your Mobile application
  1. Cognitive Insights – its Includes all visual insights that were extracted from video indexer.

  2. Player -its enable you to stream the video.

Embedding Video:
I will show below steps for how to get embedding source from video indexer portal
Step 1: Login to Video Indexer Portal using Microsoft, google or Azure Active directory account
Step 2: Select your video, whichever need to integrate to the application.
Step 3: Click the "embed" button that appears below the video.
Step 4: After click on “embed” button, Select the widget you want to embed with the desired options.
(player/insights)
Step 6: You can copy the embed codes from embed popups and start implement into your application for
Public videos. If you want to embed a Private video, you have to pass an access token in the iframe src
attribute as a query string .
Create Xamarin / Web Application:
Let's start with creating a new Xamarin Forms Project using Visual Studio. Open Run - Type “Devenev.Exe
and enter - New Project (Ctrl+Shift+N) - select Blank Xaml App (Xamarin.Forms) template.
It will automatically create multiple projects, like .NET Standard, Android, iOS, and UWP.
Implement Cognitive Insights Widget:
Cognitive insights widget contains all the visual insights that were extracted from the video after the indexing
process such as people appearances, top keywords, sentiment analysis, transcript, translate, and search.
Let we start implement into the Xamarin Application.
You can add webview control inside the content page as per below xaml design
<?xml version="1.0" encoding="utf-8" ?>
<ContentPage xmlns="http://xamarin.com/schemas/2014/forms"
            xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
            xmlns:local="clr-namespace:VideoIndexer"
            :Class="VideoIndexer.MainPage">
   <WebView x:Name="browser"  WidthRequest="1280" HeightRequest="780"></WebView>

</ContentPage>

You can use your cognitive insights widget code from c# code as a htmlwebviewsource .
You can specify the query string for whatever widgets need to display ( <url>?widgets=people&title=myInsights)
public MainPage()
{
InitializeComponent();
          // var browser = new WebView();
           var htmlSource = new HtmlWebViewSource();
           htmlSource.Html = @"<html><head><script src='https://breakdown.blob.
core.windows.net/public/vb.widgets.mediator.js'></script></head>
<body><iframe width='580' height='780' src='https://www.videoindexer.ai/embed/
insights/9123e16b12' frameborder='0' allowfullscreen></iframe>
</body></html> ";
           browser.Source = htmlSource;
       }
You can deploy the application, the output look like below
Implement Video Insights Widget:
The video player widget is a customized Media Player that except of providing video streaming,
contains extra features such as playback speed and closed captions. Refer below code for video insight
wedge implementation
public MainPage()
{
InitializeComponent();
          // var browser = new WebView();
           var htmlSource = new HtmlWebViewSource();
           htmlSource.Html = @"<html><head><script src='https://breakdown.blob.
core.windows.net/public/
vb.widgets.mediator.js'></script></head>
<body><iframe width='1280' height='720' src='https://www.videoindexer.ai/embed/
player/9123e16b12'
frameborder='0' allowfullscreen></iframe>
</body></html> ";
           browser.Source = htmlSource;
       }

Implement Video and Cognitive Insights Widget:
Copy the player and cognitive insights embed code and also include javascript communication file
for communicate with each other widget
 var htmlSource = new HtmlWebViewSource();
           htmlSource.Html = @"<html><head><script src='https://breakdown.
blob.core.windows.net/public/
vb.widgets.mediator.js'></script></head>
<body><iframe width='1280' height='720' src='https://www.videoindexer.
ai/embed/player/9123e16b12'
frameborder='0' allowfullscreen></iframe>
<iframe width = '1280' height = '780' src = 'https://www.videoindexer.
ai/embed/insights/9123e16b12/?
widgets=people&title=myInsights' frameborder = '0' allowfullscreen ></iframe >
</body></html> ";
           browser.Source = htmlSource;
Summary
In this article, we learned how to sign in to Video Indexer and integrate Video Indexer embeddable
widgets into the mobile cross-platform application. If you have any questions/feedback/ issues,
please write in the comments box.
MSDN Source Code

Building Xamarin Mobile Application with Bing AutoSuggest using Cognitive Services

Building Xamarin Mobile Application with Bing AutoSuggest using Cognitive Services
Introduction:
The Bing Autosuggest API returns a list of suggested queries based on the user enters in the search box.
Display the suggestions in the search box's drop-down list. The suggested terms are based on suggested
queries that other users have searched on and user intent.
In this article, I will show how to generate Bing Search subscription key and integrate into the Xamarin
application
Register Bing Search in Azure Portal:
You need to create an Azure account and generate subscription key for implement to the application .
Step 1:  Sign in to Azure portal .
Step 2: Create On “+ Create a resource “> Under Azure Marketplace, select AI + Cognitive Services
and discover the list of available APIs. > Select “ Bing Search v7 APIs”
Step 3: on the create page, Provide the name, pricing, resource group a click on Create
Step 4:  wait for few seconds, After the Cognitive Services account is successfully deployed,
click the notification or tile in the dashboard to view the account information.
You can copy the Endpoint URL in the Overview section and keys in the
Keys section to start making API calls in our Xamarin applications.
Create Xamarin Application with Bing AutoSuggest :
Let's start with creating a new Xamarin Forms Project using Visual Studio. Open Run -
Type “Devenev.Exe” and enter - New Project (Ctrl+Shift+N) - select Blank Xaml App (
Xamarin.Forms) template.
https://lh4.googleusercontent.com/3700JMuOS2-PsW3d7bcg4tHvikptOS945dr6721F-HhLS4ZpQ6BPlSsWI6xZD3U8Uo4rqnYHu0PHS5PLd0qzdVaNH2dAz5af7o_SVg0IWsaZqGaU4NcmMdNmouwzvFkG1pSBldMhQkL0O8L2LA
It will automatically create multiple projects, like .NET Standard, Android, iOS, and UWP.
Install Newtonsoft.Json :
Bing Autosuggest will return Json object value so make sure you have added the Newtonsoft
JSON NuGet Package to your all project. Right Click on Solution > Manage Nuget Package >
Install Newtonsoft Json
Install Microsoft.Csharp :
This steps is optional, if you get Error  "Microsoft.CSharp.RuntimeBinder.Binder.Convert"
not found by the compiler for dynamic type so adding a reference as Microsoft.CSharp to the project ,
this issue will get resolve .
Design View:
After successfully install above two nuget package. Let start design UI design from Dot Standard /PCL project.
In PCL Project > Open MainPage.Xaml page and add design Entry and list view control in Xaml
<?xml version="1.0" encoding="utf-8" ?>
<ContentPage xmlns="http://xamarin.com/schemas/2014/forms"
            xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
            xmlns:local="clr-namespace:XamarinBingAutoSuggest"
            :Class="XamarinBingAutoSuggest.MainPage">

   <StackLayout>
       <Entry x:Name="entrysearch" Placeholder="Type Your text"
 TextChanged="OnTextChangesEvent" />
       <ListView x:Name="lstautosug" BackgroundColor="Azure"  
SelectedItem="{Binding Source={x:Reference entrysearch},
Path=Text}"></ListView>
   </StackLayout>

</ContentPage>


Configure the project:
Open the MainPage.xaml.cs file from PCL project > replace your subscription key and End url
 private string AutoSuggestionEndPoint = "https://api.cognitive.microsoft.com/
bing/v7.0/suggestions";
       public HttpClient AutoSuggestionClient
       {
           get;
           set;
       }
       public MainPage()
{
InitializeComponent();
           AutoSuggestionClient = new HttpClient();
           AutoSuggestionClient.DefaultRequestHeaders.Add("Ocp-Apim-Subscription-Key",
"<Key>");
       }


Get and Parse Json Data:
HttpClient class provides a base class for get/Post the HTTP requests/responses from a URL.
It is a supported async feature of .NET framework. HttpClient is able to process multiple concurrent requests.
The following code showing get all Json data using Bing suggestions API url and Parse the json and binding
into the list view for autocomplete
private async void OnTextChangesEvent(object sender, TextChangedEventArgs e)
       {
           try
           {
               if(entrysearch!=null)
               lstautosug.ItemsSource = await GetAutoSuggestResults(this.entrysearch.Text);
           }
           catch (HttpRequestException)
           {
               
           }

       }
       public async  Task<List<string>> GetAutoSuggestResults(string query)
       {
           List<string> suggestions = new List<string>();
           string market = "en-US";
           var result = await AutoSuggestionClient.GetAsync(string.Format("{0}/
?q={1}&mkt={2}", AutoSuggestionEndPoint,
WebUtility.UrlEncode(query), market));
           result.EnsureSuccessStatusCode();
           var json = await result.Content.ReadAsStringAsync();
           dynamic data = JObject.Parse(json);
           if (data.suggestionGroups != null && data.suggestionGroups.Count >
0 && data.suggestionGroups[0].
searchSuggestions != null)
           {
               for (int i = 0; i < data.suggestionGroups[0].searchSuggestions.Count; i++)
               {
                   suggestions.Add(data.suggestionGroups[0].searchSuggestions[i].displayText.Value);
               }
           }
           return suggestions;
       }


Run the Application:
We have completed the coding now start run the application so you can select the platform iOS,Android ,
Windows and Click on Run (f5) the application .
You can find the source code at C# Corner attachment and Github XamarinBingAutoSuggest repository
as Microsoft-Cognitive-Service.









Summary

In this article, you learned about how to generate Bing Autosuggest subscription key and integrate
into the Xamarin application .If you have any questions/ feedback/ issues, please write in the comment box.