Silverlight 2 Digg klient - 4. díl
 x   TIP: Přetáhni ikonu na hlavní panel pro připnutí webu

Silverlight 2 Digg klient - 4. dílSilverlight 2 Digg klient - 4. díl

 

Silverlight 2 Digg klient - 4. díl

Google       Google       6. 4. 2009       11 451×

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

×Odeslání článku na tvůj Kindle

Zadej svůj Kindle e-mail a my ti pošleme článek na tvůj Kindle.
Musíš mít povolený příjem obsahu do svého Kindle z naší e-mailové adresy kindle@programujte.com.

E-mailová adresa (např. novak@kindle.com):

TIP: Pokud chceš dostávat naše články každé ráno do svého Kindle, koukni do sekce Články do Kindle.

Hlasování bylo ukončeno    
0 hlasů
Google
Jakub studuje informatiku na FIT ČVUT, jeho oblíbenou platformou je .NET.
Web     Twitter     Facebook     LinkedIn    

Nové články

Obrázek ke článku Stavebnice umělé inteligence 1

Stavebnice umělé inteligence 1

Článek popisuje první část stavebnice umělé inteligence. Obsahuje lineární a plošnou optimalizaci.  Demo verzi je možné použít pro výuku i zájmovou činnost. Profesionální verze je určena pro vývojáře, kteří chtějí integrovat popsané moduly do svých systémů.

Obrázek ke článku Hybridní inteligentní systémy 2

Hybridní inteligentní systémy 2

V technické praxi využíváme často kombinaci různých disciplín umělé inteligence a klasických výpočtů. Takovým systémům říkáme hybridní systémy. V tomto článku se zmíním o určitém typu hybridního systému, který je užitečný ve velmi složitých výrobních procesech.

Obrázek ke článku Jak vést kvalitně tým v IT oboru: Naprogramujte si ty správné manažerské kvality

Jak vést kvalitně tým v IT oboru: Naprogramujte si ty správné manažerské kvality

Vedení týmu v oboru informačních technologií se nijak zvlášť neliší od jiných oborů. Přesto však IT manažeři čelí výzvě v podobě velmi rychlého rozvoje a tím i rostoucími nároky na své lidi. Udržet pozornost, motivaci a efektivitu týmu vyžaduje opravdu pevné manažerské základy a zároveň otevřenost a flexibilitu pro stále nové výzvy.

Obrázek ke článku Síla týmů se na home office může vytrácet. Odborníci radí, jak z pracovních omezení vytěžit maximum

Síla týmů se na home office může vytrácet. Odborníci radí, jak z pracovních omezení vytěžit maximum

Za poslední rok se podoba práce zaměstnanců změnila k nepoznání. Především plošné zavedení home office, které mělo být zpočátku jen dočasným opatřením, je pro mnohé už více než rok každodenní realitou. Co ale dělat, když se při práci z domova ztrácí motivace, zaměstnanci přestávají komunikovat a dříve fungující tým se rozpadá na skupinu solitérů? Odborníci na personalistiku dali dohromady několik rad, jak udržet tým v chodu, i když pracovní podmínky nejsou ideální.

Hostujeme u Českého hostingu       ISSN 1801-1586       ⇡ Nahoru Webtea.cz logo © 20032024 Programujte.com
Zasadilo a pěstuje Webtea.cz, šéfredaktor Lukáš Churý