× Aktuálně z oboru

Vychází Game Ready ovladače pro Far Cry 5 [ clanek/2018040603-vychazi-game-ready-ovladace-pro-far-cry-5/ ]
Celá zprávička [ clanek/2018040603-vychazi-game-ready-ovladace-pro-far-cry-5/ ]

Silverlight 2 Digg klient - 4. díl

[ http://programujte.com/profil/9617-jakub-kottnauer/ ]Google [ https://plus.google.com/+JakubKottnauer?rel=author ]       [ http://programujte.com/profil/118-zdenek-lehocky/ ]Google [ ?rel=author ]       6. 4. 2009       11 284×

Tentokrát se naučíme pracovat s elementy Style, které nám umožňují používat jednotný vzhled napříč celou aplikací.

Existence elementu Style je novinkou ve WPF a Silverlightu, tento mechanismus nám umožňuje vzít hodnoty jednotlivých vlastností, uložit je pod Style element a tento vzhled pak můžeme libovolně používat. Koncept je podobný obyčejným CSS stylům, ale provedení se liší (u XAML stylů používáme, jak jinak, syntaxi XML).

Pro naší aplikaci si styly deklarujeme uvnitř App.xaml stylu, díky tomu je budeme moci využít v které části Digg klienta. Začněme třeba nápisem Digg klient:

<Border Grid.Column="0" CornerRadius="10" Background="#FFDEDEDE" Margin="0,0,5,0">
    <TextBlock Text="Digg klient" Foreground="#FF14517B" Margin="10,3,0,0" FontSize="15" />
</Border>

Jak sami vidíte, nápis se skládá z „rámečku“ (Border), který definuje zaoblené rohy a bílou barvu, a ze samotného textu reprezentovaného TextBlockem. Pro demonstraci možností elementu Style si nyní tyto dvě definice vzhledu přesuneme do souboru App.xaml a z Page.xaml na ně jen odkážeme. „Nový“ App.xaml bude vypadat takto:

<Application xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
             xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" 
             x:Class="DiggKlient.App"
             >
    <Application.Resources>
        
        <Style x:Key="TitleBorder" TargetType="Border">
            <Setter Property="CornerRadius" Value="10" />
            <Setter Property="Background" Value="#FFDEDEDE" />
            <Setter Property="Margin" Value="0,0,5,0" />
            <Setter Property="Grid.Column" Value="0" />
        </Style>
        
        <Style x:Key="TitleText" TargetType="TextBlock">
            <Setter Property="Foreground" Value="#FF14517B" />
            <Setter Property="Margin" Value="10,3,0,0" />
        </Style>
        
    </Application.Resources>
</Application>

V elementu Style definujeme jméno stylu (x:Key) a typ prvků, na které ho můžeme aplikovat (TargetType). Jednotlivé Settery pak nastavují odpovídající vlastnosti. Teď už jen musíme nově definované styly napojit na prvky v Page.xaml. K tomu slouží tzv. „markup extensions“, ty ohraničují složené závorky, které uvidíte v kódu níže. Bez nich by kompilátor nevěděl, že slovy „StaticResource TitleBorder“ nemyslíme nějaký text, ale že tím odkazujeme na právě definovaný styl:

<Border Style="{StaticResource TitleBorder}">
    <TextBlock Text="Digg klient" Style="{StaticResource TitleText}" />
</Border>

Pokud postup zopakujeme pro všechny ostatní prvky uvnitř Page.xaml, bude nám odměnou tento krásně čistý kód:

<UserControl xmlns:data="clr-namespace:System.Windows.Controls;assembly=System.Windows.Controls.Data"  x:Class="DiggKlient.Page"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" >

    <Grid Style="{StaticResource TopGrid}">
        <Grid.RowDefinitions>
            <RowDefinition Height="40" />
            <RowDefinition Height="*" />
        </Grid.RowDefinitions>

        <Grid Style="{StaticResource Header}">
            <Grid.ColumnDefinitions>
                <ColumnDefinition Width="*" />
                <ColumnDefinition Width="200" />
                <ColumnDefinition Width="50" />
            </Grid.ColumnDefinitions>

            <Border Style="{StaticResource TitleBorder}">
                <TextBlock Text="Digg klient" Style="{StaticResource TitleText}" />
            </Border>

            <TextBox x:Name="TopicTB" Style="{StaticResource SearchBox}" />
            <Button x:Name="SearchBtn" 
                    Content="Hledat" 
                    Click="SearchBtn_Click"
                    Style="{StaticResource SearchButton}" />

        </Grid>
        
<data:DataGrid x:Name="StoriesList" Style="{StaticResource StoriesList}" />
    </Grid>

</UserControl>

Dnes jsme si ukázali, že Style elementy nám nejen dokážou odstranit většinou překážející obecné definice vzhledu a díky tomu se můžeme soustředit jen na to, čím se jednotlivé prvky liší, ale také díky nim můžeme snadno používat jeden motiv na několika místech aplikace.

V příštím díle upravíme zobrazování dat, aby se nám místo nudné tabulky ukazovalo i něco živějšího.

Zdroj: http://weblogs.asp.net/scottgu/pages/silverlight-tutorial-part-4-using-style-elements-to-better-encapsulate-look-and-feel.aspx

Článek stažen z webu Programujte.com [ http://programujte.com/clanek/2009030600-silverlight-2-digg-klient-4-dil/ ].