Windows 8 uygulamalarında sık kullanılan özelliklerin Application Bar sayesinde hızlı erişilmesini sağlayabilirsiniz.
Hemen yeni bir Visual Studio 2011 açarak geliştirmeye başlıyoruz;
Öncelikle Yeni Proje oluşturma dialog kutusunda Windows Metro Style grubunda yer alan Application proje şablonunu seçelim ve projemize bir isim verelim (bu örnekte benim kullandığım isim, Windows8ApplicationBar)
Proje oluşturulduğunda MainPage.xaml dosyasının içeriği;
<UserControl x:Class=”Windows8ApplicationBar.MainPage” xmlns=”http://schemas.microsoft.com/winfx/2006/xaml/presentation” xmlns:x=”http://schemas.microsoft.com/winfx/2006/xaml” xmlns:d=”http://schemas.microsoft.com/expression/blend/2008” xmlns:mc=”http://schemas.openxmlformats.org/markup-compatibility/2006” mc:Ignorable=”d” d:DesignHeight=”768” d:DesignWidth=”1366”>
<Grid x:Name="LayoutRoot" Background="#FF0C0C0C">
</Grid>
</UserControl></pre>
İlk önce uygulamamızın altına hizalanacak bir Application Bar oluşturalım. Bunun için Grid‘in içerisine ApplicationBar elementinden bir tane ekliyoruz;
<ApplicationBar VerticalAlignment="Bottom"> <Button Content="Çıkış" x:Name="btnCikis" /> </ApplicationBar>
ApplicationBar elementi içerisine eklediğimiz Button elementi sayesinde uygulamamızın altına Çıkış butonu içeren bir Application Bar oluşturmuş olduk.
ApplicationBar elementinin VerticalAlignment özelliği, oluşturulacak Application Bar‘ın ekranda nereye konumlandırılacağını belirliyor.
VerticalAlignment özelliğine verebileceğiniz değerler;
Çıkış butonuna basıldığında uygulamanın kapanması için, butonun Click olayını bir method’a bağlamamız lazım. Çıkış butonunu şu şekilde güncelliyoruz;
<Button Content="Çıkış" x:Name="btnCikis" Click="btnCikis_Click" />
MainPage.xaml.cs dosyasına da btnCikis_Click method’unu yazmamız gerekiyor;
private void btnCikis_Click(object sender, RoutedEventArgs e) { Application.Current.Exit(); }
Bu haliyle uygulamamızı bir çalıştıralım;
Application Bar‘ı açmak için, uygulamanın herhangi bir yerinde mouse’un sağ tuşuna basıyoruz;
Ekranın altında beliren Application Bar‘daki Çıkış butonuna tıklarsak uygulamamız kapanır.
Internet Explorer‘ın Windows 8 için geliştirilen versiyonu (IE 10) aynı anda iki Application Bar kullanacak şekilde yazılmış. Bir Application Bar ekranın altında belirirken, diğeri ekranın üstünde beliriyor.
Biz de uygulamamıza ikinci bir Application Bar ekleyebiliriz. İkinci ekleyeceğimiz Application Bar, ekranın üstüne konumlansın;
<ApplicationBar VerticalAlignment="Top"></ApplicationBar>
Yeni eklediğimiz Application Bar‘ın birden fazla nesne içerebilmesi için, kapsayıcı olarak bir StackPanel ekliyoruz. StackPanel içerisine ekleyeceğimiz nesnelerin yan yana dizilmesi için, Orientation özelliğini Horizontal olarak belirlememiz gerekiyor. Orientation özelliğine verebileceğimiz değerler;
StackPanel‘in içerisine bir Button, bir TextBox ve bir Button daha ekliyoruz;
<Button x:Name="btnAyarlar"> <Button.Content> <StackPanel Orientation="Horizontal"> <Image Width="20" Height="20" Source="Images/SmallLogo.png" /> <TextBlock Text="Ayarlar" Margin="5,0,0,0" /> </StackPanel> </Button.Content> </Button> <TextBox Margin="15,0,0,0" Width="150" x:Name="txtAranan" /> <Button x:Name="btnAra" Content="Ara" />
İlk eklediğimiz Button‘un bir görsele de sahip olabilmesi için, Content’ine bir Image, bir de TextBlock ekliyoruz.
Image‘ın Source özelliğine, proje’nin Images dizininden bir görsel seçiyoruz; (SmallLogo.png)
Örnek uygulamanın XAML kodları’nın tamamı;
<UserControl x:Class="Windows8ApplicationBar.MainPage" xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:d="http://schemas.microsoft.com/expression/blend/2008" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" mc:Ignorable="d" d:DesignHeight="768" d:DesignWidth="1366"> <Grid x:Name="LayoutRoot" Background="#FF0C0C0C"> <ApplicationBar VerticalAlignment="Top"> <StackPanel Orientation="Horizontal"> <Button x:Name="btnAyarlar"> <Button.Content> <StackPanel Orientation="Horizontal"> <Image Width="20" Height="20" Source="Images/SmallLogo.png" /> <TextBlock Text="Ayarlar" Margin="5,0,0,0" /> </StackPanel> </Button.Content> </Button> <TextBox Margin="15,0,0,0" Width="150" x:Name="txtAranan" /> <Button x:Name="btnAra" Content="Ara" /> </StackPanel> </ApplicationBar> <ApplicationBar VerticalAlignment="Bottom"> <StackPanel Orientation="Horizontal"> <Button Content="Çıkış" x:Name="btnCikis" Click="btnCikis_Click" /> </StackPanel> </ApplicationBar> </Grid> </UserControl>
Senior Software Engineer, @Microsoft
Ada ve Ege'nin babası ;)
Makale Adedi: 484