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

 
Hledat
Moderní platforma pro vytvoření vašeho nového webu – Wix.com.
Nyní už můžete mít web zdarma.
Vytvořte si vlastní webové stránky. Snadno, rychle a levně přes Saywebpage.com
Vybavení pro Laser Game
Spuštěn Filmový magazín
Laser Game Brno
Laser Game Ostrava

Silverlight 2 Digg klient - 4. díl

Google       Google       6. 4. 2009       9 732×

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

Reklama
Reklama

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 Jak na push notifikace pro backend vývojáře

Jak na push notifikace pro backend vývojáře

Obě hlavní mobilní platformy, tedy Android i iOS, podporují posílání zpráv z backendu do mobilního zařízení formou push notifikace. V 99% případů se jedná o jedinou správnou cestu, jak aplikaci ze serveru poslat nějaká data - spolehlivé a rychlé push notifikace optimalizované na spotřebu baterie. Tento článek se věnuje pouze službě Firebase Cloud Messaging, která je vlastněná Googlem

Reklama
Reklama
Obrázek ke článku Předvídání extrémních výkyvů počasí v Evropě bude přesnější díky novému počítači Atos BullSequana

Předvídání extrémních výkyvů počasí v Evropě bude přesnější díky novému počítači Atos BullSequana

Předpověď na 15 dní dopředu s přesným rozlišením 10 km dokáže superpočítač zpracovat za méně než hodinu. Společnost Atos, světový lídr v oblasti digitální transformace, dodá Evropskému středisku pro střednědobé předpovědi počasí (ECMWF) nový superpočítač BullSequana XH2000, který je jedním z nejsilnějších meteorologických superpočítačů na světě. 

Obrázek ke článku 18+ věcí, které by měl dobrý iOS vývojář zvládat

18+ věcí, které by měl dobrý iOS vývojář zvládat

Začátky jsou vždy v každém oboru nejtěžší a hodně času zabere se vůbec v tématu zorientovat. Jinak tomu není i pří vývoji na iOS zařízení. Proto jsme vytvořili článek pro ty, kteří své znalosti teprve budují. Tento krátký dokument shrnuje, co potřebuje každý iOSák znát.

Obrázek ke článku V přechodu na DVB-T2 tápou především senioři. Přeladit jim pomáhají vnoučata, zapojí se i stát

V přechodu na DVB-T2 tápou především senioři. Přeladit jim pomáhají vnoučata, zapojí se i stát

Už na konci měsíce může zůstat část Čechů bez televizního signálu. Vypínání stávající sítě začne již 27. listopadu v Praze a středních Čechách a do poloviny roku 2020 čeká přechod na nový standard pozemního digitálního televizního vysílání DVB-T2 celou republiku. K naladění nového televizního vysílání musí řada lidí nakoupit modernější zařízení, upravit antény nebo přejít na kabelové či internetové vysílání. 

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