Disclaimer: This article is written based on Windows 10 Tech Preview – Build 10041. Things might change completely in the future.
In an earlier post, I showed how to use a StateTrigger to adapt parts of your UI to a specific device family (Device families are: Windows Desktop, Windows Mobile, XBox, IoT etc).
However if you want to do major differences in your UI, that’s probably not the most efficient way. Windows 10 comes with a nice trick to use completely different XAML files based on the device family you’re running on.
Let’s first create a new blank UAP project, and add the following XAML to the main <Grid> on MainPage.xaml
<Grid Background="{ThemeResource ApplicationPageBackgroundThemeBrush}">
<TextBlock Text="Hello Windows Desktop"
HorizontalAlignment="Center"
VerticalAlignment="Center"
/>
</Grid>
When you run this on Desktop,you not surprisingly get this:
data:image/s3,"s3://crabby-images/f0c75/f0c75c81f7afb6e15a9d3c2ec71107b7cc9f4858" alt="image image"
And also not surprising you get this on Windows Phone:
data:image/s3,"s3://crabby-images/722dc/722dc6458f751c5e106b514328b4d481ec9e7cdd" alt="image image"
Now what we want to do is override the MainPage.xaml for Windows Phone and display a more correct message.
First create a new folder called DeviceFamily-[family] where [family] is ‘Mobile’:
data:image/s3,"s3://crabby-images/5210e/5210e7ad0290228488ac6ad15e48460cada87468" alt="image image"
Right-click this folder and choose “Add new item”
data:image/s3,"s3://crabby-images/fb5e6/fb5e6bf750d7a007dc31b33d4067f4216821011c" alt="image image"
Pick “Xaml View” and change the name to “MainPage.xaml” This page is similar to a blank page; but is for overriding specific XAML pages – ie it doesn’t include the code behind, which you already have.
Now add the new TextBlock to this page with a more device family specific message:
<Grid Background="{ThemeResource ApplicationPageBackgroundThemeBrush}">
<TextBlock Text="Hello Windows Phone"
HorizontalAlignment="Center"
VerticalAlignment="Center" />
</Grid>
Because this XAML file ii in the DeviceFamily-Mobile, when running on Windows mobile, this XAML will be used instead of the default MainPage.xaml defined in the root of the project
data:image/s3,"s3://crabby-images/62fe6/62fe69e674e6afe45d1e61b6aff000bdf7d1d0c9" alt="image image"
So this method enables you to completely override the UI and adapt for the device family and maintain the same code-behind.