Windows 8 Store Apps- App bar with C# and XAML Implementation
Windows 8 Store Apps- App bar with C# and XAML
Today am going explain you Implementation of App bar in windows 8 store Apps with C# and XAML
Today am going explain you Implementation of App bar in windows 8 store Apps with C# and XAML
Step 1: Open VS2012 and select New Project from File Menu.
Step 2: Select template type as Windows Store under Visual C#.
Step 3: Open MainPag.Xaml and place below lines inside <Page> and outside <Grid>. I am creating three buttons in AppBar and each have Click event associated with it.
<Page.BottomAppBar>
<AppBar x:Name="bottomAppBar" Padding="10,0,10,0">
<Grid>
<StackPanel Orientation="Horizontal" HorizontalAlignment="Left">
<Button Style="{StaticResource OpenFileAppBarButtonStyle}" Click="Open_Click"/>
</StackPanel>
<StackPanel Orientation="Horizontal" HorizontalAlignment="Right">
<Button Style="{StaticResource PlayAppBarButtonStyle}" Click="Play_Click"/>
<Button Style="{StaticResource PauseAppBarButtonStyle}" Click="Pause_Click"/>
</StackPanel>
</Grid>
</AppBar></Page.BottomAppBar>
<AppBar x:Name="bottomAppBar" Padding="10,0,10,0">
<Grid>
<StackPanel Orientation="Horizontal" HorizontalAlignment="Left">
<Button Style="{StaticResource OpenFileAppBarButtonStyle}" Click="Open_Click"/>
</StackPanel>
<StackPanel Orientation="Horizontal" HorizontalAlignment="Right">
<Button Style="{StaticResource PlayAppBarButtonStyle}" Click="Play_Click"/>
<Button Style="{StaticResource PauseAppBarButtonStyle}" Click="Pause_Click"/>
</StackPanel>
</Grid>
</AppBar></Page.BottomAppBar>
You will get "The resource <Style Name> can not be resolved error.
Step 4: Open StandardStyles.Xaml under Common folder.
Scroll down to StandardStyles.Xaml and you will get huge chunk of Xaml is commented. The commented lines are style of the AppBar.
Step 5: As I am using OpenFileAppBarButtonStyle, PlayAppBarButtonStyle and PauseAppBarButtonStyle styles, take out these three styles out of commented section.
<Style x:Key="OpenFileAppBarButtonStyle" TargetType="ButtonBase" BasedOn="{StaticResourceAppBarButtonStyle}">
<Setter Property="AutomationProperties.AutomationId" Value="OpenFileAppBarButton"/>
<Setter Property="AutomationProperties.Name" Value="Open File"/>
<Setter Property="Content" Value=""/></Style>
<Setter Property="AutomationProperties.AutomationId" Value="OpenFileAppBarButton"/>
<Setter Property="AutomationProperties.Name" Value="Open File"/>
<Setter Property="Content" Value=""/></Style>
<Style x:Key="PlayAppBarButtonStyle" TargetType="ButtonBase" BasedOn="{StaticResource AppBarButtonStyle}">
<Setter Property="AutomationProperties.AutomationId" Value="PlayAppBarButton"/>
<Setter Property="AutomationProperties.Name" Value="Play"/>
<Setter Property="Content" Value=""/></Style>
<Setter Property="AutomationProperties.AutomationId" Value="PlayAppBarButton"/>
<Setter Property="AutomationProperties.Name" Value="Play"/>
<Setter Property="Content" Value=""/></Style>
<Style x:Key="PauseAppBarButtonStyle" TargetType="ButtonBase" BasedOn="{StaticResource AppBarButtonStyle}">
<Setter Property="AutomationProperties.AutomationId" Value="PauseAppBarButton"/>
<Setter Property="AutomationProperties.Name" Value="Pause"/>
<Setter Property="Content" Value=""/></Style>
<Setter Property="AutomationProperties.AutomationId" Value="PauseAppBarButton"/>
<Setter Property="AutomationProperties.Name" Value="Pause"/>
<Setter Property="Content" Value=""/></Style>
Step 6: Add a textblock inside <Grid> of MainPage.Xaml.
<TextBlock x:Name="Action" FontSize="40"></TextBlock>
Step 7: Open MainPage.Xaml.cs and place below code. Below are three events which will be triggered on click of Button in Application Bar.
private void Open_Click(object sender, RoutedEventArgs e)
{
Action.Text = "Open File button of application bar clicked.";
}
{
Action.Text = "Open File button of application bar clicked.";
}
private void Play_Click(object sender, RoutedEventArgs e)
{
Action.Text = "Play button of application bar clicked.";
}
{
Action.Text = "Play button of application bar clicked.";
}
private void Pause_Click(object sender, RoutedEventArgs e)
{
Action.Text = "Pause button of application bar clicked.";
}
{
Action.Text = "Pause button of application bar clicked.";
}
Step 8: Now run the application and you will get AppBar as shown below and on click of Button the corresponding event will be triggered. You will also notice the AppBar hides on click of any place outside the AppBar.
Step 9: Setter property of Style discussed in Step 5 had AutomationProperties.AutomationId which has value attribute, it is used to show text just below image icon. There is another property Content, it is used to show the icon of the button.
Let's change the value of AutomationProperties.AutomationId Setter from "Open File" to "Open" and also change the value of AutomationProperties.Name value from "" to "" of OpenFileAppBarButtonStyle. Now run the application again.
You will notice the icon and text of left button of AppBar is changed. The same behavior of hiding AppBar on click of any where outside AppBar continues.
Step 10: Let's add a button inside <Grid> of MainPage.Xaml. I will talk about it later.
<Button x:Name="makeSticky" Click="makeSticky_Click_1" Content="Make AppBar sticky"></Button>
Step 11: Place below code in MainPage.Xaml.cs.
private void makeSticky_Click_1(object sender, RoutedEventArgs e)
{
Action.Text = "Clicking on screen won't hide the app bar.";
bottomAppBar.IsSticky = true;
}
{
Action.Text = "Clicking on screen won't hide the app bar.";
bottomAppBar.IsSticky = true;
}
Step 12: Now run the application again. Click on Make AppBar sticky and open AppBar again. Now click on any place on the screen outside AppBar won't hind the AppBar.
Step 13: There are lot of events in AppBar but two important events are Open and Closed. Add Open and close event handler like any one way shown below.
From CodeBehind (MainPage.Xaml.cs)
public MainPage()
{
this.InitializeComponent();
bottomAppBar.Opened += bottomAppBar_Opened;
bottomAppBar.Closed += bottomAppBar_Closed;
}
{
this.InitializeComponent();
bottomAppBar.Opened += bottomAppBar_Opened;
bottomAppBar.Closed += bottomAppBar_Closed;
}
Or
From Xaml (MainPage.Xaml)
<AppBar x:Name="bottomAppBar" Padding="10,0,10,0" Closed="bottomAppBar_Closed"Opened="bottomAppBar_Opened"></AppBar>
Step 14: Add below event handler in MainPage.Xaml.cs.
void bottomAppBar_Closed(object sender, object e)
{
Action.Text = "Application Bar closed.";
}
{
Action.Text = "Application Bar closed.";
}
void bottomAppBar_Opened(object sender, object e)
{
Action.Text = "Application Bar opened.";
}
{
Action.Text = "Application Bar opened.";
}
Step 15: Now run the application and you will notice corresponding event is getting triggered on Closed and Opened of AppBar.
This ends the article of creating AppBar using C# and Xaml.
Labels:
Win8MetroApps