Diskuze: WPF - jak opakovat obrázek pro pozadí dokud nevyplní celý grid
V předchozím kvízu, Test znalostí C# .NET online, jsme si ověřili nabyté zkušenosti z kurzu.
Člen
Zobrazeno 8 zpráv z 8.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Test znalostí C# .NET online, jsme si ověřili nabyté zkušenosti z kurzu.
Co si pod tím máme představit?
Nějaká ukázka by nebyla na škodu.
<Grid.Background>
<ImageBrush ImageSource="bcktext1.png" TileMode="Tile" Stretch="None" />
</Grid.Background>
Mám texturu 100x100. Moje wpf okno je 650x600.
Když nastavím texturu pozadí pomocí tohohle:
<Grid.Background>
<ImageBrush ImageSource="bcktext1.png"/>
</Grid.Background>
vypadá to tak jak přiložený soubor.
A já potřebuji, aby se ten obrázek neroztahoval, ale pouze pořád dokola
opakoval. V css je to
background-repeat: repeat;
.
Dá se toho nějak docílit ve WPF ?
Když to nastavím takhle dopadne to jako obrázek v příloze. Tudíž se to neopakuje, ale zobrazí se to jenom jednou uprostřed.
Nijak hezky to bohužel nejde. Tady je kód:
int rx = (int) Math.Ceiling(DragBoardBgGrid.ActualWidth/400.0);
int ry = (int) Math.Ceiling(DragBoardBgGrid.ActualHeight/400.0);
for (int x = 0; x < rx; x++)
{
DragboardBgGrid.ColumnDefinitions.Add(new ColumnDefinition {Width = new GridLength(400)});
}
for (int y = 0; y < ry; y++)
{
DragboardBgGrid.RowDefinitions.Add(new RowDefinition {Height = new GridLength(400)});
}
for (int x = 0; x < rx; x++)
{
for (int y = 0; y < ry; y++)
{
Image bgImage = new Image
{
Source = new BitmapImage(new Uri("Images/grid_bg.png", UriKind.Relative))
};
DragboardBgGrid.Children.Add(bgImage);
Grid.SetColumn(bgImage, x);
Grid.SetRow(bgImage, y);
}
}
DragboardBgGrid je Grid, co vložíš pod cílový element.
Zobrazeno 8 zpráv z 8.