255 lines
11 KiB
Plaintext
255 lines
11 KiB
Plaintext
Mi az a wpf?
|
|
|
|
A windows presentation foundation a windows forms utódnak tekinthető asztali alkalmazások fejlesztése terén.
|
|
Bár a wpf számos téren eltér a tradicionálisnak tekinthető windows forms hoz képest, mégis több olyan elvre támaszkodik, amely már meglévő asztali keretrendszerek alapját képezi.
|
|
Az egyyik legnagyobb és egyben legfontosabb különbség, hogy az alkalmazás megjelenéséért felelős kód elkülönül az alkalmazás funkcióit leíró kódtol.
|
|
|
|
Szakítva a Winformos hagyományokkal, a WPF alapjául szolgáló grafikus technológia a GDI/GDI+ helyett már a DirectX.
|
|
A directx közvetlenül elérésének köszönhetően tetszőleges típusú felhasználói felületet hozhatunk létre.
|
|
Tervezhető akár komplex háromdimenziós grafika, de üzleti alkalmazások esetében is kiaknázhatók a gazdag grafikai hatások.
|
|
A hardveres gyorsításnak köszönhetően a DirectX a grafikai rendelés során amennyire lehetséges tehermentesíteni ....
|
|
|
|
WPF nek a grafikai elemei már nem raszteresek, hanem vektoralapúak.
|
|
Ebből következően az egyes elemek tetszőlegesen átméretezhetőek.
|
|
További nagy előnye hogy a vektor alapú képek kevesebb helyet foglalnak a raszteres elemekhez képest.
|
|
ugyanakkor meg kell említeni, hogy a wpf továbbra is támogatja a raszter grafikát.
|
|
|
|
wpf jellemzői
|
|
dokumentumok és nyomtatás
|
|
biztonság, hozzáférhetőség és lokalizáció
|
|
együttműködést kínál a következővel windows űrlaptervező
|
|
a direct3d grafikus alkalmazásokban használják, ahol a teljesítmány fontos
|
|
GPU-t használ megjelenítéshez
|
|
a vektor alapú grafika lehetővé teszi az átméretezést minőségromlás nélkül
|
|
A WPF támogatja a lebegőpontos logikai pixelrendszert és a 32 bites ARGB színt
|
|
stílusok és vezérlősablonok újradefiniálása
|
|
nemzetközi betűtípusok építése összetett betűtípusokból
|
|
a wpf szövegmegjelenítés segít a cleartype technológia előnyeinek kihazsnálásában
|
|
lehetővé teszi az előre rendelt szöveg gyorsítótárazási technikájának használatát a videómemóriában
|
|
erőforrás alapú megközelítés minden vezérléshez
|
|
a bemutató időzítőit a wpf inicializálja és kezeli
|
|
|
|
A videó és az animáció közötti kapcsolat szintén támogatott
|
|
a wpfben a stílus olyan tulajdonságok halamza, amelyeket a vizuális megjelenítéshez használt tartalomra kell alkalmazni.
|
|
a wpf sablonjai segítenek a dokumentumok UI érékének megváltoztatásában
|
|
a parancsok az események elvontabb és lazábban kapcsolt változatai
|
|
a wpf parancsok támogatása csökkenti a megírandó kód mennyiségét
|
|
|
|
|
|
A wpf többrétegű architektúrájának legelső szintjén a PresentationFramework.dll található.
|
|
Ezt használjuk fejlesztés közben, itt vannak implementálva a küéomvüző vezérlők .
|
|
|
|
PresentationFramework.dll számára az alaposztályokat (UIElement, Visual) a PresentationCore.dll biztosítja.
|
|
Ezekből az osztályból származnak többek között a formák (shape) és a vezérlők (controls).
|
|
A windowsvase.dll a wpf alapvető működéséhez szükséges objektumosztályokat tartalmazza (DispatcherObject, DependencyObject).
|
|
|
|
A WPF névterek a System.Windows névtérben helyezkednek el.
|
|
|
|
System.Object
|
|
A WPF összes osztálya a System.Objectből származik.
|
|
A WPF legfontosabb komponensei a PresentationFramework, PresentationCore és a milcore, tartalmazzák a wpf legfontosabb kódrészleteit.
|
|
Ezek köüzül a milcore az egyetlen nem menedzselt kódban írt komponens.
|
|
|
|
XAML
|
|
|
|
(eXtensible Application Markup Language) egy XML alapú dekleratív jelölőnyelv, amely a .NET keretrendszer modelljébe illeszkedve leegyszerűsíti a grafikus felhasználói felület kialakítását.
|
|
XAML dekleratív nyelv nyelvtani szabályrendszere nagyn egyszerű.
|
|
Általános tervezési alapelve, hogy a XAML dokumentumot definiál a .NET osztály egy példánya.
|
|
|
|
XAML nyelv hasznlatának előnyei
|
|
|
|
AZ XAML elválasztja a front-end megjelenítést a háttér logikától
|
|
|
|
Az XAML a legegyszerűbb módszer a felhasználói felületek ábrázolására
|
|
|
|
A XAML hatékonyan dolgozik az eszközökkel
|
|
|
|
|
|
|
|
Külső és belső margók
|
|
Margin
|
|
|
|
GRID
|
|
<Grid ShowGridLines="True">
|
|
<Grid.RowDefinitions>
|
|
<RowDefinition />
|
|
<RowDefinition />
|
|
<RowDefinition />
|
|
</Grid.RowDefinitions>
|
|
<Grid.ColumnDefinitions>
|
|
<ColumnDefinition />
|
|
<ColumnDefinition />
|
|
</Grid.ColumnDefinitions>
|
|
</Grid>
|
|
|
|
igatítások
|
|
Az egyes gyerekelemeket természetesen függőlegesen és vízszintesen is igazíthatjuk.
|
|
HorizontalAlignment - vízszintes igazítás
|
|
VerticalAlignment
|
|
|
|
horizontal értékei: left center right stretch
|
|
|
|
vertical: top bottom center stretch
|
|
|
|
StackPanel
|
|
Alapértelmezés szerint a benne elhelyezett elemeket egymás alá rendezve listaszerűen jeleníti meg.
|
|
|
|
<Grid>
|
|
<StackPanel Width="200" Orientation="Horizontal">
|
|
<Button Height="20" Content="button 1" Margin="10"></Button>
|
|
<Button Height="20" Content="button 2" Margin="10"></Button>
|
|
<Button Height="20" Content="button 3" Margin="10"></Button>
|
|
</StackPanel>
|
|
</Grid>
|
|
|
|
Wrappanel
|
|
elemek egymás mellett vagy alatt való megjelenítésére alkalmas.
|
|
Amennyiben egy elem nem fér el a sorba, akkor az automatikusan a kövibe kerül.
|
|
|
|
<Grid Width="200" Height="200">
|
|
<WrapPanel>
|
|
<Ellipse Fill="Red" Height="40" Width="40"></Ellipse>
|
|
<Ellipse Fill="Red" Height="40" Width="40"></Ellipse>
|
|
<Ellipse Fill="Red" Height="40" Width="40"></Ellipse>
|
|
<Ellipse Fill="Red" Height="40" Width="40"></Ellipse>
|
|
<Ellipse Fill="Red" Height="40" Width="40"></Ellipse>
|
|
<Ellipse Fill="Red" Height="40" Width="40"></Ellipse>
|
|
<Ellipse Fill="Red" Height="40" Width="40"></Ellipse>
|
|
<Ellipse Fill="Red" Height="40" Width="40"></Ellipse>
|
|
</WrapPanel>
|
|
</Grid>
|
|
|
|
DockPanel
|
|
A DockPanel a StackPanel hez és a wrappanelhez képest már összetettebb elrendezések kialakításához használható.
|
|
Használható akár a Grid vezérlőt lecserélve gyökérelemként is.
|
|
<Grid>
|
|
<DockPanel LastChildFill="True">
|
|
<Button Content="Dock=Top" DockPanel.Dock="Top" Background="Beige"></Button>
|
|
<Button Content="Dock=Right" DockPanel.Dock="Right" Background="Gold"></Button>
|
|
<Button Content="Dock=Left" Background="Beige"></Button>
|
|
<Button Content="Dock=Bottom" DockPanel.Dock="Bottom" Background="Beige"></Button>
|
|
<Image Source="cat.png" Stretch="Fill"></Image>
|
|
</DockPanel>
|
|
</Grid>
|
|
|
|
GridSplitter
|
|
A gridsplitter rácsfelosztó vezétlő használatával lehetővé válik a program futása közben a rács sorainak és oszlopainak.
|
|
A Grid vezérlőben azon sorok,illetve oszlopok közé kell elhelyeznünk, amelyeket szeretnénk átméretezhetővé tenni.
|
|
|
|
A ResizeDirection tulajdonsággal állíthatjuk be, hogy sorokat, vagy oszlopokat szeretnénk átéretezni, a resizevehavior segítségével pedig a pontos működést tudjuk beállítani.
|
|
|
|
ResizeBehavior tulajdonság
|
|
|
|
BasedOnAlignment (igazítás alapja)
|
|
CurrentAndNext (aktuális és következő)
|
|
PreviousAndCurrent (előző és aktuális)
|
|
|
|
|
|
Canvas
|
|
A canvas pixel pontosan megadott elrendezést tesz lehetővé, ideális fix méretű alkalmazások elkészítéséhez.
|
|
A Canvas-on elhelyezett elemek poziciojat a Top-Left és a Bottom-Right tulajdonságok beállításával tehetjük meg.
|
|
|
|
|
|
Vezérlők
|
|
A következő vezérlők a ContentControl osztályból származnak.
|
|
Tartalmaznak egy speciális beágyazott elemet
|
|
(Content tulajdonság), amely valójában objektum típusú,
|
|
tehát tetszőleges tartalom elhelyezhető benne.
|
|
|
|
Button
|
|
|
|
|
|
Label
|
|
|
|
A label vezérlő egyike a wpf legegyszerűbb vezérlőinek. Az eddigi példáinkban is sokszor előfordultak.
|
|
A következő példában a Target tulajdonságot kihasználva, futás alatt az alt+n billentyűkombináció lenyomásával a textBox1-re helyeződik át a fókusz.
|
|
|
|
<StackPanel Orientation="Horizontal" HorizontalAlignment="Center" VerticalAlignment="Center">
|
|
<Label Content="_Név:" Target="{Binding ElementName=textBox1}"></Label>
|
|
<TextBox x:Name="textBox1" Width="300" Height="30"></TextBox>
|
|
</StackPanel>
|
|
|
|
CheckBox és RadioButton
|
|
|
|
Az adatbevitel nem csal szöveges adatok bevitelét tartalmazhatja, hanem lehetőség van kiválasztható értékek egyszerű bevitelére is.
|
|
A lehetőségek kiválasztása az alábbi két vezérlő segítségével valósítható meg:
|
|
CheckBox (jelölőnégyzet)
|
|
RadioButton (választógomb)
|
|
|
|
A checkbox és a radiobutton is az ButtonBase osztály leszármazottjai.
|
|
<StackPanel Orientation="Vertical" HorizontalAlignment="Center" VerticalAlignment="Bottom">
|
|
<TextBlock Text="Neme: "></TextBlock>
|
|
<TextBlock Text="Neme: "></TextBlock>
|
|
|
|
<RadioButton GroupName="Nem" Content="Nő"></RadioButton>
|
|
<RadioButton GroupName="Nem" Content="Férfi"></RadioButton>
|
|
<Separator></Separator>
|
|
<TextBlock Text="Kedvenc évszak: "></TextBlock>
|
|
<RadioButton GroupName="Evszak" Content="Tavasz" IsChecked="True"></RadioButton>
|
|
<RadioButton GroupName="Evszak" Content="Nyár"></RadioButton>
|
|
<RadioButton GroupName="Evszak" Content="Ősz"></RadioButton>
|
|
<RadioButton GroupName="Evszak" Content="Tél"></RadioButton>
|
|
</StackPanel>
|
|
|
|
CheckBox
|
|
A jelölőnégyzetek egy vagy több egymástól független beállítás közötti választást tesz lehetővé.
|
|
A választógomboktól eltérően, amelyekben ......
|
|
|
|
<StackPanel>
|
|
<TextBlock Text="Válassza ki az alábi listából a kedvenc tantárgyait:"></TextBlock>
|
|
<CheckBox Content="Informatika"></CheckBox>
|
|
<CheckBox Content="Fizika" IsChecked="True" IsEnabled="False"></CheckBox>
|
|
<CheckBox Content="Matematika"></CheckBox>
|
|
<CheckBox Content="Kémia"></CheckBox>
|
|
|
|
<Button x:Name="Nyomogomb" Content="Bezár" Margin="200 200 200 200" Click="Nyomogomb_Click"></Button>
|
|
</StackPanel>
|
|
|
|
TextBox
|
|
Szöveg bevitelére és megjelenítésére alkalmas eszköz.
|
|
|
|
<TextBox Text="Ide várom a választ"></TextBox>
|
|
|
|
Amennyiben csak a szöveg megjelenítésére szeretnénk használni, az IsReadOnly tulajdonságot állítsuk true ra.
|
|
|
|
Autómatikus tördelés: TextWrapping="Wrap"
|
|
|
|
Scrollbar mindig látszódjon: VerticalScrollBarVisibility="Visible"
|
|
|
|
TextBlock
|
|
Ez a vezérlő szöveg megjelenítésére alkalmas.
|
|
Az alábbi szintaxisokkal hozhatjuk létre.
|
|
Kis mennyiségű szöveget jelenít meg, vagy akár formázott tartalmat.
|
|
Ez a vezérlő nem támogatja a gyorsbillentyűket.
|
|
|
|
|
|
Lista alapú vezérlők
|
|
ListBox
|
|
A Listbox vezérlővel alapértelmezés szerint egy elem kiválasztására van lehetőség.
|
|
<ListBox x:Name="Lista" SelectionMode="Extended">
|
|
<ListBoxItem>Alma</ListBoxItem>
|
|
<ListBoxItem>Körte</ListBoxItem>
|
|
<ListBoxItem>Barack</ListBoxItem>
|
|
<ListBoxItem>Szőlő</ListBoxItem>
|
|
</ListBox>
|
|
|
|
fontosabb tulajdonságai
|
|
SelectedIndex return item index
|
|
SelectedItem return item-name
|
|
IsSelected return bool
|
|
|
|
Single
|
|
Multiple több elem kiválasztása
|
|
Extended több elem kiválasztása, de a ctrl gomb nyomvatartása mellett lehetőságet nyújt nem egymás alatt lévő listaelemek kiválasztására.
|
|
|
|
Az események és tulajdonságok progamozása a Mainwindow.xaml.cs fájlban
|
|
|
|
Vezérlők definiálása a XAML ben: először hozz létre vezérlőket a xaml fájlban, például gombokat címkéket szövegmezőket.
|
|
|
|
Az események és tulajdonságok programozása a kódban:
|
|
A vezérlők ....
|
|
|
|
|
|
|
|
|