SEATTLE—With the Xamarin tooling built in to Visual Studio, iOS and
Android developers can already use a PC for a big part of their dev
process by using the Visual Studio IDE for writing their code. For iOS
development, however, there has always been an extra complication: the
actual software building and deployment had to take place on a Mac.
Visual Studio remotely controls the Apple machine to do this work, so
although developers can stay inside the Visual Studio environment they
know and love, they still need a Mac on their local network.
Xamarin Live Player, announced today, takes the Mac out of the
develop/deploy/debug cycle. With Live Player, iOS apps can be deployed
directly onto an iPhone or other iDevice from a PC running Visual
Studio, where the code can then be tested and debugged. This means that
the Mac is no longer needed for that core development cycle.
The final build and submission to the App Store will still require a
Mac, so you can't go without an Apple system entirely, but what this
means is that if you want to develop, as many of us do, on a laptop and
aren't on the same network as your Mac, you can.
Live Player also supports Android, though this is obviously less of a
big deal since direct development and deployment from a PC is already
standard for Android.
Microsoft believes its Live Player system is entirely compatible with
Apple's rules and regulations for App Store apps. Behind the scenes,
the Live Player includes an interpreter for .NET code. This means that
running an app through Live Player is slower than it would be if
natively built on a Mac, but that's not such a big deal for many aspects
of user interface development.
For those of us who are Mac users anyway, yesterday saw the release of Visual Studio for Mac.
Visual Studio for Mac is a different codebase from Visual Studio on
Windows, but the two products share things like the compiler and build
infrastructure, enabling projects to be shared and co-developed between
Mac and PC with no conversion or other hurdles to contend with.
Microsoft is also working to better align the various versions of
.NET and the XAML user interface development language across its
platforms. Later this year, the UWP version of .NET will be updated to
support .NET Standard 2.0. Microsoft is also unifying the XAML used for
cross-platform Xamarin Forms with that used for UWP. The new XAML, XAML
Standard, will allow XAML to be shared (and copy/pasted, the best kind
of code reuse) between UWP and Xamarin Forms apps.
Finally, Microsoft is continuing to embrace Linux developers and
toolchains on Windows. The current Windows Subsystem for Linux (WSL)
comes out of the box with support for Ubuntu; later this year, Microsoft
is adding official support for a SUSE userland and a Fedora userland.
It'll even be possible to install all three side by side, giving your
Windows machine three different Linux personalities simultaneously. The
installation of WSL is also simpler, with the three Linux environments
all being installed from the Windows Store.
Source: https://arstechnica.com/information-technology/2017/05/xamarin-live-player-almost-takes-the-mac-out-of-ios-development/
Xamarin Cross Platform App Development
News, Tips, Tutorials, for Cross Platform (android, iOS and Windows phone) App develpment using Xamarin platform
Categories
- Android (4)
- Android API level 23 marshmallow (3)
- Azure Mobile Apps (1)
- Learning Tools (1)
- News (5)
- Themeing (2)
- Tips & Tricks (2)
- Xamarin Tips & Tricks (4)
- Xamarin.Forms (3)
Sunday, May 14, 2017
Tuesday, August 2, 2016
.NET Standard Library Support for Xamarin
Today, we are extremely pleased to release support for .NET Standard Libraries for all Xamarin applications. This includes creating and consuming local .NET Standard Libraries, but also adding .NET Standard Libraries from NuGet directly to your Xamarin apps. It’s now easier than ever to share code across all .NET platforms, including the recently introduced .NET Core and ASP.NET Core platforms.


As you can see, it targets the Standard library. Xamarin Studio and Visual Studio will simply add the reference to the netstandard folder when the NuGet is installed:

In Visual Studio, File->New Project and select the standard Portable Class Library (PCL) template located in the “Visual C#” section.

This PCL now needs to be upgraded to target the .NET Standard Library, which can be found in the projects properties.

This will change the project type and the APIs that the project can access. netstandard currently has seven versions of API coverage. Below is a useful chart to guide you through what platforms support which APIs. This can be adjusted any time in the project properties, similar to how you can change the

Finally, simply add the new .NET Standard Library to any Xamarin project just like any other reference!
The ability to create .NET Standard Libraries in Xamarin Studio on macOS will be available in the future, but today we are pleased to release Xamarin Studio 6.0.2 which supports consuming and compiling these libraries.
What is .NET Standard?
The .NET Standard Library is a formal specification of .NET APIs that are intended to be available on all .NET runtimes. You can think of it as a simplified, yet expanded, Portable Class Library. It is a single library with a uniform API for all .NET Platforms including .NET Core. You just create a single .NET Standard Library and use it from any runtime that supports .NET Standard Platform.
Consuming .NET Standard NuGets & Assemblies
A lot of libraries have recently added .NET Standard support, enabling them to support .NET Core applications. It’s now possible to add a NuGet to Xamarin applications that supports .NET Standard in both Xamarin Studio and Visual Studio. For instance, here’s the preview release of Windows Azure Storage that supports .NET Standard 1.6:
As you can see, it targets the Standard library. Xamarin Studio and Visual Studio will simply add the reference to the netstandard folder when the NuGet is installed:

Getting Started with .NET Standard
To create or consume .NET Standard libraries in your Xamarin applications, ensure that you’re running Visual Studio 2015 Update 3 and are updated to Xamarin 4.1.2 for Visual Studio in the Stable release channel.In Visual Studio, File->New Project and select the standard Portable Class Library (PCL) template located in the “Visual C#” section.

This PCL now needs to be upgraded to target the .NET Standard Library, which can be found in the projects properties.

This will change the project type and the APIs that the project can access. netstandard currently has seven versions of API coverage. Below is a useful chart to guide you through what platforms support which APIs. This can be adjusted any time in the project properties, similar to how you can change the
Profile
of a PCL after creating it.
Finally, simply add the new .NET Standard Library to any Xamarin project just like any other reference!
The ability to create .NET Standard Libraries in Xamarin Studio on macOS will be available in the future, but today we are pleased to release Xamarin Studio 6.0.2 which supports consuming and compiling these libraries.
Friday, May 20, 2016
Realm launches new mobile database, made specifically for Microsoft’s Xamarin
Since Microsoft acquired Xamarin earlier this year and made it
available for free along with Visual Studio following Build 2016,
developers can now leverage both solutions to build apps for all major platforms.
But if this combo was not enough to ease the work the work of .NET and
C# developers, mobile database platform Realm has just announced Realm Xamarin, a new edition of their database built specifically for the Xamarin framework.
If you’re not familiar with it, Realm is a popular database solution already used by developers such as Twitter, Starbucks, Cisco, Walmart, Google, Amazon, eBay and more. After launching for Java, Objective‑C, and Swift in 2014 and for React Native earlier in 2016, the new Xamarin support is great news for developers who already rely on the Microsoft framework to write their apps. Realm shared additional technical details on their blog post today:
Source: http://www.winbeta.org/news/realm-launches-new-mobile-database-made-specifically-microsofts-xamarin
If you’re not familiar with it, Realm is a popular database solution already used by developers such as Twitter, Starbucks, Cisco, Walmart, Google, Amazon, eBay and more. After launching for Java, Objective‑C, and Swift in 2014 and for React Native earlier in 2016, the new Xamarin support is great news for developers who already rely on the Microsoft framework to write their apps. Realm shared additional technical details on their blog post today:
Realm Xamarin brings the modern design & simplicity you expect from Realm, and will allow you to target both iOS and Android with the same codebase. Like the other editions of Realm, it is designed from the ground up to enable reactive app development, with live objects, change events, and support for unidirectional data flows.Realm Xamarin is already available on GitHub, and the team is asking developers to provide feedback on bugs and feature requests. Furthermore, Realm shares that we can “expect the API to improve significantly over the next few weeks, especially as we polish advanced features like migrations and queries.”
Please note the Realm file format is also completely cross-platform, allowing data to be shared across iOS & Android easily. We currently support Xamarin.iOS and Xamarin.Android, and look forward to supporting Xamarin.Mac in the future, as well as UWP and Unity.
Source: http://www.winbeta.org/news/realm-launches-new-mobile-database-made-specifically-microsofts-xamarin
Saturday, April 16, 2016
Following Xamarin acquisition, Microsoft will kill its RoboVM service in April 2017

Microsoft will stop operating the RoboVM service for turning Java-based applications into native mobile apps for iOS and Android. After April 30, 2017, developers’ subscriptions to the service will not work.
The news comes two months after Microsoft announced that it had bought Xamarin, a startup whose software converts C# code into mobile app code. Xamarin itself said it had bought RoboVM in October.
“Over the past few weeks, we’ve been working with the teams at Xamarin and Microsoft to assess the technology and business conditions of RoboVM to determine the path forward for the products,” RoboVM cofounder and CEO Henric Müller wrote yesterday on the RoboVM blog. “After looking at the complete landscape for mobile development with Java, the decision has been made to wind down development of RoboVM.”
This is a bit startling, given that it really hasn’t been that long since RoboVM was feeling optimistic about how much impact it would gain from being acquired by Xamarin.
“Xamarin’s market-leading position in enterprise mobility means that we will be able to scale our reach and enable mobile success for millions of developers,” Müller was quoted as saying in the statement on Xamarin’s purchase of RoboVM.
Microsoft’s decision to end RoboVM is also surprising because Microsoft has been doing more and more to support cross-platform app development, with Xamarin serving as one example.
Fortunately for Java enterprise developers, there are a number of alternatives, although Müller specifically called out the open-source libGDX library. RoboVM itself suspended open-source development last year.
Source: https://venturebeat.com/2017/04/05/how-to-force-windows-10-to-download-the-creators-update/
Saturday, March 5, 2016
Easy App Theming with Xamarin.Forms
Beautiful user interfaces sell mobile apps, and designing a successful user experience for your app is a great first step for success. But what about all of the little details that combine to create a fantastic design, such as colors and fonts? Even if you create what you believe to be the perfect design, users will often find something to dislike about it.
Why not let the user decide exactly how they would like their app to look? Many popular apps have taken this approach. Tweetbot has light and dark modes and the ability to change fonts to find the one that works best on the eyes during late-night Twitter sessions. Slack takes user customization to the next level by allowing users to customize the entire theme of the app through hexadecimal color values. Properly supporting theming also brings some tangible benefits to code, such as minimizing duplicated hardcoded values throughout apps to increase code maintainability.
Xamarin.Forms allows you to take advantage of styling to build beautiful, customizable UIs for iOS, Android, and Windows. In this blog post, we’re going to take a look at how to add theming to MonkeyTweet, a minimalistic (we mean it!) Twitter client, by replicating Tweetbot’s light and dark mode as well as Slack’s customizable theming.
Introduction to Resources
Resources allow you to share common definitions throughout an app to help you reduce hardcoded values in your code, resulting in massively increased code maintainability. Instead of having to alter every value in your app when a theme changes, you only have to change one: the resource.
In the code below, you can see several duplicated values that could be extremely tedious to replace and are ideal candidates for using resources:
1
2
<Label Text="First Name" BackgroundColor="White" TextColor="Blue" FontSize="24" /> <Label Text="First Name" BackgroundColor="White" TextColor="Blue" FontSize="24" />
<Entry BackgroundColor="White" TextColor="Blue" />
Resources are grouped together and stored in a ResourceDictionary, a key-value store that is optimized for use with a user interface. Because a ResourceDictionary is a key-value store, you must supply the XAML keyword x:Key for each resource defined:
1
2
3
<Color x:Key="backgroundColor">#33302E</Color>
<Color x:Key="textColor">White</Color>
<x:Double x:Key="fontSize">24</x:Double>
You can define a ResourceDictionary at both the page and app-level, depending on the particular scope needed for the resource at hand. If a particular resource will be shared among multiple pages, it’s best to define it at the app-level in App.xaml to avoid duplication, as we do below with the MonkeyTweet app:
1
2
3
4
5
6
7
8
9
10
11
<Application
xmlns="http://xamarin.com/schemas/2014/forms"
xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
x:Class="MonkeyTweet.App">
<Application.Resources>
<ResourceDictionary>
<Color x:Key="backgroundColor">#33302E</Color>
<Color x:Key="textColor">White</Color>
</ResourceDictionary>
</Application.Resources>
</Application>
Now that we have defined reusable resources in our application ResourceDictionary, how do we reference these values in XAML? Let’s take a look at the two main types of resources, StaticResource and DynamicResource, and how we can utilize them to add a light and dark mode to MonkeyTweet.
Static Resources
The StaticResource markup extension allows us to reference predefined resources, but have one key limitation: resources from the dictionary are only fetched one time during control instantiation and cannot be altered at runtime. The syntax is very similar to that for bindings; just set the property’s value to “{StaticResource Resource_Name}”. Let’s update our ViewCell to use the resources we defined:
1
2
<Label Text="{Binding Name}" FontSize="Medium" FontAttributes = "Bold" TextColor = "{StaticResource textColor}" LineBreakMode="NoWrap"/>
<Label Text="{Binding Text}" FontSize="Small" LineBreakMode="WordWrap" TextColor = "{StaticResource textColor}"/>
Dynamic Resources
StaticResources are a great way to reduce duplicated values, but what we need is the ability to alter the resource dictionary at runtime (and have those resource updates reflected where referenced). DynamicResource should be used for dictionary keys associated with values that might change during runtime. Additionally, unlike static resources, dynamic resources don’t generate a runtime exception if the resource is invalid and will simply use the default property value.
We want MonkeyTweet’s user interface to be able to switch between light and dark modes at runtime, so DynamicResource is perfect for this situation. All we need to do is change StaticResources to DynamicResources. Updating our resources on-the-fly is super easy as well:
1
2
App.Current.Resources ["backgroundColor"] = Color.White;
App.Current.Resources ["textColor"] = Color.Black;
Users can now switch between a light and dark theme with the click of a button:
Monkey Tweet with a dark and light theme applied via dynamic resources.
Introduction to Styles
When building a user interface and theming an app, you may find yourself repeatedly configuring controls in a similar way. For example, all controls that display text may use the same font, font attributes, and size. Styles are a collection of property-value pairs called Setters. Rather than having to repeatedly set each of these properties to a particular resource, you can create a style, and then simply set the Style property to handle the theming for you.
Building Custom Styles
To define a style, we can take advantage of the application-wide resource dictionary to make this style available to all controls. Just like resources, each style must contain a unique key and target class name for the style. A style is made up of one or more Setters, where a property name and value for that property must be supplied. The TargetType property defines which controls the theme can apply to; you can even set this to VisualElement to have the style apply to all subclasses of VisualElement. Setters can even take advantage of resources to further increase maintainability.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
<Application
xmlns="http://xamarin.com/schemas/2014/forms"
xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
x:Class="MonkeyTweet.App">
<Application.Resources>
<ResourceDictionary>
<Color x:Key="backgroundColor">#33302E</Color>
<Color x:Key="textColor">White</Color>
<Style x:Key="labelStyle" TargetType="Label">
<Setter Property="TextColor" Value="{DynamicResource textColor}" />
</Style>
<Style x:Key="backgroundStyle" TargetType="VisualElement">
<Setter Property="BackgroundColor" Value="{DynamicResource backgroundColor}" />
</Style>
</ResourceDictionary>
</Application.Resources>
</Application>
We can apply this style by setting the Style property of a control to the name of the style’s unique key. All properties from the style will be applied to the control. If a property is explicitly defined on the control that is also part of a referenced style, the property set explicitly will override the value in the style.
1
<Label Text="{Binding Name}" Style="{DynamicResource labelStyle}" FontSize="Medium" FontAttributes = "Bold" LineBreakMode="NoWrap"/>
Our style is a dynamic resource behind the scenes, so they can be altered at runtime. I’ve created a custom page that allows users to enter their own hexadecimal colors to theme MonkeyTweet thanks to Xamarin.Forms resources and styles:
Feb 03, 2016 15:34
Conclusion
In this blog post, we took a look at theming applications with the Xamarin.Forms’ styles by theming our MonkeyTweet application to have a customizable, user-defined theme. We only just scratched the surface of styling; there are lots of other cool things you can do with styling, including style inheritance, implicit styling, platform-specific styling, and prebuilt styles. Be sure to download the MonkeyTweet application to apply your own theme and see just how easy it is to build beautiful, themed UIs with Xamarin.Forms!
Why not let the user decide exactly how they would like their app to look? Many popular apps have taken this approach. Tweetbot has light and dark modes and the ability to change fonts to find the one that works best on the eyes during late-night Twitter sessions. Slack takes user customization to the next level by allowing users to customize the entire theme of the app through hexadecimal color values. Properly supporting theming also brings some tangible benefits to code, such as minimizing duplicated hardcoded values throughout apps to increase code maintainability.
Xamarin.Forms allows you to take advantage of styling to build beautiful, customizable UIs for iOS, Android, and Windows. In this blog post, we’re going to take a look at how to add theming to MonkeyTweet, a minimalistic (we mean it!) Twitter client, by replicating Tweetbot’s light and dark mode as well as Slack’s customizable theming.
Introduction to Resources
Resources allow you to share common definitions throughout an app to help you reduce hardcoded values in your code, resulting in massively increased code maintainability. Instead of having to alter every value in your app when a theme changes, you only have to change one: the resource.
In the code below, you can see several duplicated values that could be extremely tedious to replace and are ideal candidates for using resources:
1
2
<Label Text="First Name" BackgroundColor="White" TextColor="Blue" FontSize="24" /> <Label Text="First Name" BackgroundColor="White" TextColor="Blue" FontSize="24" />
<Entry BackgroundColor="White" TextColor="Blue" />
Resources are grouped together and stored in a ResourceDictionary, a key-value store that is optimized for use with a user interface. Because a ResourceDictionary is a key-value store, you must supply the XAML keyword x:Key for each resource defined:
1
2
3
<Color x:Key="backgroundColor">#33302E</Color>
<Color x:Key="textColor">White</Color>
<x:Double x:Key="fontSize">24</x:Double>
You can define a ResourceDictionary at both the page and app-level, depending on the particular scope needed for the resource at hand. If a particular resource will be shared among multiple pages, it’s best to define it at the app-level in App.xaml to avoid duplication, as we do below with the MonkeyTweet app:
1
2
3
4
5
6
7
8
9
10
11
<Application
xmlns="http://xamarin.com/schemas/2014/forms"
xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
x:Class="MonkeyTweet.App">
<Application.Resources>
<ResourceDictionary>
<Color x:Key="backgroundColor">#33302E</Color>
<Color x:Key="textColor">White</Color>
</ResourceDictionary>
</Application.Resources>
</Application>
Now that we have defined reusable resources in our application ResourceDictionary, how do we reference these values in XAML? Let’s take a look at the two main types of resources, StaticResource and DynamicResource, and how we can utilize them to add a light and dark mode to MonkeyTweet.
Static Resources
The StaticResource markup extension allows us to reference predefined resources, but have one key limitation: resources from the dictionary are only fetched one time during control instantiation and cannot be altered at runtime. The syntax is very similar to that for bindings; just set the property’s value to “{StaticResource Resource_Name}”. Let’s update our ViewCell to use the resources we defined:
1
2
<Label Text="{Binding Name}" FontSize="Medium" FontAttributes = "Bold" TextColor = "{StaticResource textColor}" LineBreakMode="NoWrap"/>
<Label Text="{Binding Text}" FontSize="Small" LineBreakMode="WordWrap" TextColor = "{StaticResource textColor}"/>
Dynamic Resources
StaticResources are a great way to reduce duplicated values, but what we need is the ability to alter the resource dictionary at runtime (and have those resource updates reflected where referenced). DynamicResource should be used for dictionary keys associated with values that might change during runtime. Additionally, unlike static resources, dynamic resources don’t generate a runtime exception if the resource is invalid and will simply use the default property value.
We want MonkeyTweet’s user interface to be able to switch between light and dark modes at runtime, so DynamicResource is perfect for this situation. All we need to do is change StaticResources to DynamicResources. Updating our resources on-the-fly is super easy as well:
1
2
App.Current.Resources ["backgroundColor"] = Color.White;
App.Current.Resources ["textColor"] = Color.Black;
Users can now switch between a light and dark theme with the click of a button:
Monkey Tweet with a dark and light theme applied via dynamic resources.
Introduction to Styles
When building a user interface and theming an app, you may find yourself repeatedly configuring controls in a similar way. For example, all controls that display text may use the same font, font attributes, and size. Styles are a collection of property-value pairs called Setters. Rather than having to repeatedly set each of these properties to a particular resource, you can create a style, and then simply set the Style property to handle the theming for you.
Building Custom Styles
To define a style, we can take advantage of the application-wide resource dictionary to make this style available to all controls. Just like resources, each style must contain a unique key and target class name for the style. A style is made up of one or more Setters, where a property name and value for that property must be supplied. The TargetType property defines which controls the theme can apply to; you can even set this to VisualElement to have the style apply to all subclasses of VisualElement. Setters can even take advantage of resources to further increase maintainability.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
<Application
xmlns="http://xamarin.com/schemas/2014/forms"
xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
x:Class="MonkeyTweet.App">
<Application.Resources>
<ResourceDictionary>
<Color x:Key="backgroundColor">#33302E</Color>
<Color x:Key="textColor">White</Color>
<Style x:Key="labelStyle" TargetType="Label">
<Setter Property="TextColor" Value="{DynamicResource textColor}" />
</Style>
<Style x:Key="backgroundStyle" TargetType="VisualElement">
<Setter Property="BackgroundColor" Value="{DynamicResource backgroundColor}" />
</Style>
</ResourceDictionary>
</Application.Resources>
</Application>
We can apply this style by setting the Style property of a control to the name of the style’s unique key. All properties from the style will be applied to the control. If a property is explicitly defined on the control that is also part of a referenced style, the property set explicitly will override the value in the style.
1
<Label Text="{Binding Name}" Style="{DynamicResource labelStyle}" FontSize="Medium" FontAttributes = "Bold" LineBreakMode="NoWrap"/>
Our style is a dynamic resource behind the scenes, so they can be altered at runtime. I’ve created a custom page that allows users to enter their own hexadecimal colors to theme MonkeyTweet thanks to Xamarin.Forms resources and styles:
Feb 03, 2016 15:34
Conclusion
In this blog post, we took a look at theming applications with the Xamarin.Forms’ styles by theming our MonkeyTweet application to have a customizable, user-defined theme. We only just scratched the surface of styling; there are lots of other cool things you can do with styling, including style inheritance, implicit styling, platform-specific styling, and prebuilt styles. Be sure to download the MonkeyTweet application to apply your own theme and see just how easy it is to build beautiful, themed UIs with Xamarin.Forms!
Getting Started with Azure Mobile Apps’ Easy Tables
Every front end needs a great backend. This is true now more than ever in today’s connected world, where it’s extremely important to have your data with you at all times, even if you are disconnected from the internet. There are tons of great solutions available for Xamarin developers including Couchbase, Parse, Amazon, Oracle, and, of course, Microsoft Azure.
In the past, we looked at the brand new Azure Mobile Apps, which gives you a full .NET backend providing complete control over how data is stored and retrieved for your mobile apps. What if you need a backend right now with minimal setup? That is where Azure Mobile Apps’ brand new Easy Tables come in. How easy are Easy Tables? So easy that you can add backend data storage to your app in as little as 15 minutes! The best part is that if you’ve used any Azure Mobile Services or Azure Mobile Apps, you’ll feel right at home.

When selecting Mobile App in Azure, you will need to configure the service name (this is the URL where your backend web app/ASP.NET website will live), configure your subscription, and set your resource group and plan. I call Seattle home, so I’ve selected the default West US locations:

Give Azure a few minutes to deploy your mobile app, and once deployed, the Azure portal will bring you directly to the configuration screen with the settings tab open. All of the settings we’ll adjust can be found under the Mobile section:


Make sure that you keep Allow azure services to access server checked for your mobile app to allow services to properly connect to the database server. Also, be sure to keep your password in a secure place as you may need it in the future.
Click OK on all open blades and Azure will begin to create the database for us on the fly. To see the progress of database creation live, click on the notifications button in the upper-righthand corner:

When the data connection is created, it will appear in the Mobile Apps data connections blade, which means it’s time to set up the data that will go in the new database.


Since we already setup the database, the only thing left to do is Initialize the app.

After a few moments, the app will be fully initialized so we can add our first table of the database named CupOfCoffee. If you are adding Azure Mobile Apps to an existing application, this table name should match the class name of the data you with to store. The beautiful part of Easy Tables is that it will automatically update and add the columns in the table dynamically based on the data we pass in. For this example, I’ll simply allow full anonymous access to the table, however it is possible to add authentication with Facebook, Twitter, Google, Microsoft, and other OAuth login providers.


For Android, add the following to the OnCreate method of your MainActivity:
Notice the model has a UTC DateTime that will be stored in the backend, but also has two helper properties for a display date and time. They are marked with a JsonIgnore property and will not be persisted in the database.
Now from my mobile app I can simply create my AzureDataService and start querying and adding coffees through the day, all in under 70 lines of code.

Source: https://blog.xamarin.com/getting-started-azure-mobile-apps-easy-tables/?utm_source=newsletter&utm_medium=email&utm_content=easy-tables&utm_campaign=march2016&mkt_tok=3RkMMJWWfF9wsRolu6%2FAZKXonjHpfsX56eUrX6G%2Bi4kz2EFye%2BLIHETpodcMT8tmN6%2BTFAwTG5toziV8R7nCKc1q1c0QXBfr

In the past, we looked at the brand new Azure Mobile Apps, which gives you a full .NET backend providing complete control over how data is stored and retrieved for your mobile apps. What if you need a backend right now with minimal setup? That is where Azure Mobile Apps’ brand new Easy Tables come in. How easy are Easy Tables? So easy that you can add backend data storage to your app in as little as 15 minutes! The best part is that if you’ve used any Azure Mobile Services or Azure Mobile Apps, you’ll feel right at home.
Keeping Track of Coffee Consumption
If you follow me on social media or have seen me present, then you know I love coffee; I’m drinking one as I type this! That’s why I thought that for this post I would build a cross-platform app to help me keep track of just how many coffees I’m consuming each day. I call it “Coffee Cups”, and we’ll be building it throughout this post. Here’s the final version in action:Creating a New Azure Mobile App
Inside of the Azure portal, simply select New -> Web + Mobile -> Mobile App, which is the starting point to configure your Azure Mobile App backend.
When selecting Mobile App in Azure, you will need to configure the service name (this is the URL where your backend web app/ASP.NET website will live), configure your subscription, and set your resource group and plan. I call Seattle home, so I’ve selected the default West US locations:

Give Azure a few minutes to deploy your mobile app, and once deployed, the Azure portal will bring you directly to the configuration screen with the settings tab open. All of the settings we’ll adjust can be found under the Mobile section:

Add Data Connection
We can’t have a backend for our mobile apps without a database. Under the Data Connections section, select Add, and then configure a new SQL database as I’ve done below:
Make sure that you keep Allow azure services to access server checked for your mobile app to allow services to properly connect to the database server. Also, be sure to keep your password in a secure place as you may need it in the future.
Click OK on all open blades and Azure will begin to create the database for us on the fly. To see the progress of database creation live, click on the notifications button in the upper-righthand corner:

When the data connection is created, it will appear in the Mobile Apps data connections blade, which means it’s time to set up the data that will go in the new database.

Adding a New Table
Under Mobile settings is a new section called Easy Tables, which enable us to easily set up and control the data coming to and from the iOS and Android apps. Select the Easy Tables section, and we’ll be prompted with a big blue warning asking us to configure Easy Tables/Easy APIs:
Since we already setup the database, the only thing left to do is Initialize the app.

After a few moments, the app will be fully initialized so we can add our first table of the database named CupOfCoffee. If you are adding Azure Mobile Apps to an existing application, this table name should match the class name of the data you with to store. The beautiful part of Easy Tables is that it will automatically update and add the columns in the table dynamically based on the data we pass in. For this example, I’ll simply allow full anonymous access to the table, however it is possible to add authentication with Facebook, Twitter, Google, Microsoft, and other OAuth login providers.

Adding Sync to Mobile Apps
With our backend fully set up on Azure, it’s now time to integrate the Azure Mobile SDK into your mobile apps. The first step is to add the Azure Mobile Apps NuGet package that’s named Azure Mobile SQLiteStore. This package sits on top and includes the Mobile Services Client SDK to connect to our backend and adds full online/offline synchronization and should be added to all application projects. For example CoffeeCups is written using Xamarin.Forms, so I added the NuGet to my PCL, iOS, Android, and Windows projects:
Initialize the Azure Mobile Client
Add the Azure Mobile Client SDK initialization code in the platform projects. For iOS, the following code must be added to the FinishedLaunching method of the AppDelegate class:
1
2
|
Microsoft.WindowsAzure.MobileServices.CurrentPlatform.Init();
SQLitePCL.CurrentPlatform.Init();
|
1
|
Microsoft.WindowsAzure.MobileServices.CurrentPlatform.Init();
|
The Data Model
It’s now time to create the data model that we’ll use locally to display information, but also save in our Azure Mobile App backend. It should have the same name as the table that we created earlier. There are two string properties required to ensure the Mobile Apps SDK can assign a unique identifier and version in case any modifications are made to the data. Here is what the CupOfCoffee model looks like:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
public class CupOfCoffee
{
[Newtonsoft.Json.JsonProperty("Id")]
public string Id { get; set; }
[Microsoft.WindowsAzure.MobileServices.Version]
public string AzureVersion { get; set; }
public DateTime DateUtc { get; set; }
public bool MadeAtHome{ get; set; }
[Newtonsoft.Json.JsonIgnore]
public string DateDisplay { get { return DateUtc.ToLocalTime().ToString("d"); } }
[Newtonsoft.Json.JsonIgnore]
public string TimeDisplay { get { return DateUtc.ToLocalTime().ToString("t"); } }
}
|
Accessing Mobile App Data
It’s now time to use the Mobile App SDK to create a MobileServiceClient that will enable us to perform create, read, update, and delete (CRUD) operations that will be stored locally and synchronized with our backend. All of this logic will be housed in a single class, which for this app is called “AzureDataService” and has a MobileServiceClient and a single IMobileServiceSyncTable. Additionally, it has four methods to Initialize the service, get all coffees, add a coffee, and synchronize the data with the backend:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
public class AzureDataService
{
public MobileServiceClient MobileService { get; set; }
IMobileServiceSyncTable coffeeTable;
public async Task Initialize()
{
}
public async Task<IEnumerable> GetCoffees()
{
}
public async Task AddCoffee(bool madeAtHome)
{
}
public async Task SyncCoffee()
{
}
}
|
Creating the Service and Table
Before we can get or add any of the data we must create the MobileServiceClient and the SyncTable. This is done by passing in the URL of the Azure Mobile App and specifying the file in which to store the local database:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
public async Task Intialize()
{
//Create our client
MobileService = new MobileServiceClient("https://coffeecups.azurewebsites.net");
const string path = "syncstore.db";
//setup our local sqlite store and intialize our table
var store = new MobileServiceSQLiteStore(path);
store.DefineTable();
await MobileService.SyncContext.InitializeAsync(store, new MobileServiceSyncHandler());
//Get our sync table that will call out to azure
coffeeTable = MobileService.GetSyncTable();
}
|
Synchronize Data
Mobile devices often lose connectivity, so it’s vital that our app continue to function properly even in low or no connectivity environments. Azure makes this extremely easy; with just a few lines of code, Azure automatically syncs our local database and the backend when connectivity is reestablished:
1
2
3
4
5
6
|
public async Task SyncCoffee()
{
//pull down all latest changes and then push current coffees up
await coffeeTable.PullAsync("allCoffees", coffeeTable.CreateQuery());
await MobileService.SyncContext.PushAsync();
}
|
Retrieving Data
The IMobileServiceSyncTable offers a very nice asynchronous and LINQ queryable API to get data from our backend. This can be done to grab all of the data or filter it down by a property, such as an Id. In this instance, we’ll simply synchronize our local data with the backend before fetching all cups of coffee, sorted by the date:
1
2
3
4
5
|
public async Task<IEnumerable> GetCoffees()
{
await SyncCoffee();
return await coffeeTable.OrderBy(c => c.DateUtc).ToEnumerableAsync();
}
|
Inserting Data
In addition to getting all of the latest data, we can insert, update, and even delete data that will be kept in sync between devices.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
public async Task AddCoffee(bool madeAtHome)
{
//create and insert coffee
var coffee = new CupOfCoffee
{
DateUtc = DateTime.UtcNow,
MadeAtHome = madeAtHome
};
await coffeeTable.InsertAsync(coffee);
//Synchronize coffee
await SyncCoffee();
}
|

Learn More
In this post we’ve covered setting up the basic Azure Mobile App’s Easy Tables to perform CRUD and sync operations from our mobiles apps. In addition to this, you have full access to the service code and can customize it right from the portal (using the edit script option in Easy Tables and even custom scripts with Easy APIs). Be sure to check out all of the additional services provided by Azure Mobile App Services such as authentication and push notifications on the Azure portal. You can try out Azure Mobile Apps by downloading this Coffee Cups sample from my GitHub or by testing pre-built samples\ apps on the Try App Services page.Source: https://blog.xamarin.com/getting-started-azure-mobile-apps-easy-tables/?utm_source=newsletter&utm_medium=email&utm_content=easy-tables&utm_campaign=march2016&mkt_tok=3RkMMJWWfF9wsRolu6%2FAZKXonjHpfsX56eUrX6G%2Bi4kz2EFye%2BLIHETpodcMT8tmN6%2BTFAwTG5toziV8R7nCKc1q1c0QXBfr
Thursday, February 25, 2016
Xamarin acquisition amplifies Microsoft's comprehensive mobile development strategy
Yesterday Microsoft announced that it is acquiring Xamarin. Terms were not disclosed. This move makes Microsoft a must-consider option throughout the stack when it comes to mobile development. For those not familiar with Xamarin, here's what Microsoft is getting:
Cross-platform native mobile app development, in C#. Xamarin's origins include Mono (remember that?), and it represents the expansion of the .Net runtime to other platforms, including iOS and Android. Developers write C# code that will be natively compiled to these devices, which runs at similar speed as apps written in Objective-C, Swift, or Java.
Automated acceptance testing for mobile apps. Xamarin develops and maintains the Calabash open source project for mobile acceptance testing. We've seen growing popularity of Calabash amongst enterprise mobile dev teams, especially Global SIs, like those we reviewed in last year's Enterprise Mobile App Services Forrester Waves.
A device cloud for system and performance testing. The Xamarin Test Cloud automates app testing on more than 2000 real devices in the cloud. We expect to see this service folded into Azure in short order, with a low cost on-demand model to compete with Amazon Device Farm, Google Cloud Test Lab, and PerfectoMobile.
On device analytics to measure mobile apps. Measuring apps is just as important as building them. While the importance of analytic instrumentation is still a work in progress for many enterprise developers, experienced mobile devs get it. Xamarin Insights provides a basic working set of technical and engagement level measures for mobile app dev teams.
See also: Microsoft is buying mobile tool vendor Xamarin
At Forrester we've been expecting this acquisition for a while -- it just makes too much sense for both parties and their customers. Here's why:
Building apps twice is once too often for enterprise development shops. We still get regular inquiries from clients on "Native vs Web. vs. Cross-platform". And many of these requests come from clients that have already made significant investments in one strategy or the other. The bottom line: very few mobile dev shops are comfortable with their current status quo. Everyone wants native look and feel and speed, but without multiple code bases to maintain. Xamarin gives Microsoft a strong cross-platform front-end development approach that allows mobile teams to have their cake and eat it too.
Xamarin's biggest sales objection is now removed. In our (frequent) conversations with clients about Xamarin, a recurring question pops up: "Should we trust this highly strategic technology decision to a small vendor?" In the past six months we've seen mainstream buyers become less concerned about this objection as Xamarin has stood up enterprise mobile app case studies, but today's acquisition removes that concern entirely.
Microsoft gets a better front end development story. Microsoft is well on its way to building a strong mobile infrastructure services portfolio on the back of the Azure public cloud. But the front-end message was a bit jumbled between native + Xamarin or Microsoft's first class Apache Cordova tools. We think this acquisition makes the cross platform approach the preferred one for Microsoft, although it does not signal Microsoft's move away from the web -- Cordova remains an option for app development, and TypeScript is the underlying technology behind AngularJS 2.0, the latest version of the dominant web development framework.
Xamarin is a solid cross-platform mobile app development play if you already have in house .Net skills or have invested in the Visual Studio set of development and application lifecycle tools. The next shoe to drop will be the existing Xamarin partnerships with IBM, Kony, Oracle and SAP. We don't think this acquisition will exclude these prior partners from leveraging Xamarin from a technology perspective; but we also wouldn't be surprised if it altered the attractiveness of the relationship to these firms.
We've previously written about how Satya Nadella has righted Microsoft's ship over the past two years. Now the company is making a strong move to be the development platform of choice for all mobile platforms, not just for Windows 10. Azure now supports multiple languages for back-end cloud development, including NodeJS. Development tooling is *much* more accessible by all audiences, both .Net shops and otherwise thanks to VS Code and lighter-weight Visual Studio development suite offerings.
Microsoft has established a strong set of digital application platform services and developers are responding. This acquisition is yet another sign of the new cross-platform, public-cloud focused Microsoft. We don't expect it will be the last.
Source: http://www.zdnet.com/article/xamarin-acquisition-amplifies-microsofts-comprehensive-mobile-development-strategy/
Cross-platform native mobile app development, in C#. Xamarin's origins include Mono (remember that?), and it represents the expansion of the .Net runtime to other platforms, including iOS and Android. Developers write C# code that will be natively compiled to these devices, which runs at similar speed as apps written in Objective-C, Swift, or Java.
Automated acceptance testing for mobile apps. Xamarin develops and maintains the Calabash open source project for mobile acceptance testing. We've seen growing popularity of Calabash amongst enterprise mobile dev teams, especially Global SIs, like those we reviewed in last year's Enterprise Mobile App Services Forrester Waves.
A device cloud for system and performance testing. The Xamarin Test Cloud automates app testing on more than 2000 real devices in the cloud. We expect to see this service folded into Azure in short order, with a low cost on-demand model to compete with Amazon Device Farm, Google Cloud Test Lab, and PerfectoMobile.
On device analytics to measure mobile apps. Measuring apps is just as important as building them. While the importance of analytic instrumentation is still a work in progress for many enterprise developers, experienced mobile devs get it. Xamarin Insights provides a basic working set of technical and engagement level measures for mobile app dev teams.
See also: Microsoft is buying mobile tool vendor Xamarin
At Forrester we've been expecting this acquisition for a while -- it just makes too much sense for both parties and their customers. Here's why:
Building apps twice is once too often for enterprise development shops. We still get regular inquiries from clients on "Native vs Web. vs. Cross-platform". And many of these requests come from clients that have already made significant investments in one strategy or the other. The bottom line: very few mobile dev shops are comfortable with their current status quo. Everyone wants native look and feel and speed, but without multiple code bases to maintain. Xamarin gives Microsoft a strong cross-platform front-end development approach that allows mobile teams to have their cake and eat it too.
Xamarin's biggest sales objection is now removed. In our (frequent) conversations with clients about Xamarin, a recurring question pops up: "Should we trust this highly strategic technology decision to a small vendor?" In the past six months we've seen mainstream buyers become less concerned about this objection as Xamarin has stood up enterprise mobile app case studies, but today's acquisition removes that concern entirely.
Microsoft gets a better front end development story. Microsoft is well on its way to building a strong mobile infrastructure services portfolio on the back of the Azure public cloud. But the front-end message was a bit jumbled between native + Xamarin or Microsoft's first class Apache Cordova tools. We think this acquisition makes the cross platform approach the preferred one for Microsoft, although it does not signal Microsoft's move away from the web -- Cordova remains an option for app development, and TypeScript is the underlying technology behind AngularJS 2.0, the latest version of the dominant web development framework.
Xamarin is a solid cross-platform mobile app development play if you already have in house .Net skills or have invested in the Visual Studio set of development and application lifecycle tools. The next shoe to drop will be the existing Xamarin partnerships with IBM, Kony, Oracle and SAP. We don't think this acquisition will exclude these prior partners from leveraging Xamarin from a technology perspective; but we also wouldn't be surprised if it altered the attractiveness of the relationship to these firms.
We've previously written about how Satya Nadella has righted Microsoft's ship over the past two years. Now the company is making a strong move to be the development platform of choice for all mobile platforms, not just for Windows 10. Azure now supports multiple languages for back-end cloud development, including NodeJS. Development tooling is *much* more accessible by all audiences, both .Net shops and otherwise thanks to VS Code and lighter-weight Visual Studio development suite offerings.
Microsoft has established a strong set of digital application platform services and developers are responding. This acquisition is yet another sign of the new cross-platform, public-cloud focused Microsoft. We don't expect it will be the last.
Source: http://www.zdnet.com/article/xamarin-acquisition-amplifies-microsofts-comprehensive-mobile-development-strategy/
Subscribe to:
Posts (Atom)