欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

WPF開發(fā)之UniformGrid和ItemsControl的應(yīng)用詳解

 更新時間:2024年01月31日 09:48:29   作者:老碼識途呀  
為了簡化開發(fā),WPF提供了UniformGrid布局和ItemsControl容器,本文以一個簡單的小例子,簡述如何在WPF開發(fā)中應(yīng)用UniformGrid和ItemsControl實(shí)現(xiàn)均勻的布局,希望對大家有所幫助

在日常開發(fā)中,有些布局非常具有規(guī)律性,比如相同的列寬,行高,均勻的排列等,為了簡化開發(fā),WPF提供了UniformGrid布局和ItemsControl容器,本文以一個簡單的小例子,簡述,如何在WPF開發(fā)中應(yīng)用UniformGrid和ItemsControl實(shí)現(xiàn)均勻的布局,僅供學(xué)習(xí)分享使用,如有不足之處,還請指正。

什么是UniformGrid

在WPF開發(fā)中,提供了一種Grid網(wǎng)格布局,此布局應(yīng)用靈活,形式多樣,在使用之前,需要定義行,列,設(shè)置高度,寬度等內(nèi)容,使用相對復(fù)雜。為了簡化布局,針對具有等寬,等高的布局,提供了一種更加簡化的布局容器UniformGrid。

UniformGrid【統(tǒng)一布局】,提供一種在網(wǎng)格(網(wǎng)格中的所有單元格都具有相同的大小)中排列內(nèi)容的方法。

UniformGrid常用屬性

UniformGird中同一行中,列等寬,同一列中,行等高。常用屬性為:

  • Margin:獲取或設(shè)置元素的外邊距。
  • Name:元素的標(biāo)識名稱;
  • Opacity:透明度
  • Width/Height:寬度和高度;
  • Visibility:該元素可見性;
  • Rows:獲取或設(shè)置網(wǎng)格中的行數(shù);
  • Columns:獲取或設(shè)置網(wǎng)格中的列數(shù);
  • FirstColumn    獲取或設(shè)置網(wǎng)格第一行中前導(dǎo)空白單元格的數(shù)量,必須小于屬性的值 Columns;

注意:UniformGrid相當(dāng)于簡化版的Gird,但并不是Grid的子類,而是和Grid同級,都繼承于與Panel類。

UniformGrid示例

UniformGrid中如果不設(shè)置子元素的控件大小,會根據(jù)容器的大小和行列數(shù)自動填充。如下所示:

<UniformGrid Columns="4" Margin="5">
    <Button Content="按鈕1" Margin="2"></Button>
    <Button Content="按鈕2" Margin="2"></Button>
    <Button Content="按鈕3" Margin="2"></Button>
    <Button Content="按鈕4" Margin="2"></Button>
    <Button Content="按鈕5" Margin="2"></Button>
    <Button Content="按鈕6" Margin="2"></Button>
</UniformGrid>

關(guān)于UniformGrid,有以下幾點(diǎn)需要注意:

如果設(shè)置了Columns,沒有設(shè)置Rows,則會根據(jù)元素個數(shù)和列數(shù)自動計(jì)算行數(shù)。

如果設(shè)置了Rows,沒有設(shè)置Columns,則會根據(jù)元素個數(shù)和行數(shù)自動計(jì)算列數(shù)。

如果Rows,Columns都沒有設(shè)置,則會根據(jù)元素個數(shù)自動匹配,建議至少設(shè)置一個,否則可能與預(yù)期的布局不符。

如果沒有設(shè)置容器中元素的大下,則自動填充;如果設(shè)置了容器中元素的大小,且小于容器為該元素分配的平均大小,則以元素為準(zhǔn),其他以空白填充;如果設(shè)置了元素大小,且元素的大小大于容器為該元素分配的平均大小,則多余部分會隱藏,只顯示能夠顯示的那部分。

什么是ItemsControl

ItemsControl條目控件,用于顯示數(shù)據(jù)項(xiàng)集合,它允許按照自定義方式呈現(xiàn)任何類型的對象,可以在其中使用不同的布局和面板來展示數(shù)據(jù)。ItemsControl非常靈活,可以滿足各種需求。

ItemsControl涉及知識點(diǎn)

ItemsControl的常用知識點(diǎn)如下:

  • ItemTemplate,是DataTemplate類型,可以通過ItemTemplate設(shè)置條目項(xiàng)的呈現(xiàn)方式。
  • ItemsPanel,是ItemsPanelTemplate類型,可以通過ItemsPanel設(shè)置容器中各個條目項(xiàng)的布局方式。
  • ItemsSource,可以通過綁定數(shù)據(jù)源為ItemsControl設(shè)置內(nèi)容。
  • Items,條目列表,如果設(shè)置了ItemsSource,則此屬性不生效

ItemsControl示例

以下示例以文本的形式,展示了每一個條目項(xiàng),且默認(rèn)元素以橫向排列。如下所示:

<ItemsControl ItemsSource="{Binding Customers}">
    <ItemsControl.ItemTemplate>
        <DataTemplate>
            <TextBlock Text="{Binding Name}" />
        </DataTemplate>
    </ItemsControl.ItemTemplate>
    <ItemsControl.ItemsPanel>
        <ItemsPanelTemplate>
            <StackPanel />
        </ItemsPanelTemplate>
    </ItemsControl.ItemsPanel>
</ItemsControl>

ItemsControl和UniformGrid結(jié)合

結(jié)合ItemsControl【數(shù)據(jù)綁定,條目項(xiàng)自定義設(shè)置】和UniformGrid【等高,等寬】各自的優(yōu)點(diǎn),創(chuàng)建一個圖片列表。具體步驟如下:

  • 自動識別文件夾中的圖片,然后將數(shù)據(jù)源綁定到ItemsControl中進(jìn)行呈現(xiàn)。
  • ItemsControl中的條目項(xiàng)中展示圖片縮略圖和名稱,且條目項(xiàng)中的圖片等比縮放。
  • 條目布局采用UniformGrid,且每行顯示5張圖。
  • 圖片較多時,要有滾動條,所以需要設(shè)置ScrollViewer。

在Xaml中,頁面布局如下所示:

<ScrollViewer VerticalScrollBarVisibility="Auto">
    <ItemsControl ItemsSource="{Binding ImageItems}" Background="#eeeeee">
        <ItemsControl.ItemsPanel>
            <ItemsPanelTemplate>
                <UniformGrid Columns="5"></UniformGrid>
            </ItemsPanelTemplate>
        </ItemsControl.ItemsPanel>
        <ItemsControl.ItemTemplate>
            <DataTemplate>
                <StackPanel Orientation="Vertical" Margin="3">
                    <Image Source="{Binding ImagePath}" Stretch="Uniform"></Image>
                    <TextBlock Text="{Binding ImageName}" HorizontalAlignment="Center" VerticalAlignment="Bottom"></TextBlock>
                </StackPanel>
 
            </DataTemplate>
        </ItemsControl.ItemTemplate>
    </ItemsControl>
</ScrollViewer>

其中ItemsSource屬性用于綁定數(shù)據(jù)源,在ViewModel層進(jìn)行構(gòu)造,如下所示:

public class MainWindowViewModel
{
    public ObservableCollection<ImageItem> ImageItems { get; set; }
 
    public MainWindowViewModel()
    {
        ImageItems = new ObservableCollection<ImageItem>();
        for(int i = 0; i < 8; i++)
        {
            for(int j = 0; j < 5; j++)
            {
                var imageName = $"{i+1}.{j+1}.jpg";
                var imagePath = Path.Combine(Environment.CurrentDirectory, "imgs", imageName);
                ImageItems.Add(new ImageItem(){ImageName = imageName,ImagePath = imagePath});
            }
        }
    }
}

運(yùn)行示例如下所示:

到此這篇關(guān)于WPF開發(fā)之UniformGrid和ItemsControl的應(yīng)用詳解的文章就介紹到這了,更多相關(guān)WPF UniformGrid ItemsControl內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C#中+=是什么意思及+=的用法

    C#中+=是什么意思及+=的用法

    這篇文章主要介紹了C#中+=是什么意思及+=的用法說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • C#委托與事件原理及實(shí)例解析

    C#委托與事件原理及實(shí)例解析

    這篇文章主要介紹了C#委托與事件原理及實(shí)例解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-12-12
  • c# 實(shí)現(xiàn)位圖算法(BitMap)

    c# 實(shí)現(xiàn)位圖算法(BitMap)

    這篇文章主要介紹了c# 如何實(shí)現(xiàn)位圖算法(BitMap),文中講解非常細(xì)致,幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下
    2020-07-07
  • C#?單例模式的多種實(shí)現(xiàn)方式

    C#?單例模式的多種實(shí)現(xiàn)方式

    單例模式是一種確保類只有一個實(shí)例的設(shè)計(jì)模式,主要用于提供全局訪問點(diǎn),C#中實(shí)現(xiàn)單例的方法多樣,包括餓漢式和懶漢式,各有優(yōu)缺點(diǎn),此外,單例模式不僅提高代碼可重用性和可讀性,還增強(qiáng)了系統(tǒng)的可維護(hù)性
    2024-11-11
  • C#面向?qū)ο笤O(shè)計(jì)原則之組合/聚合復(fù)用原則

    C#面向?qū)ο笤O(shè)計(jì)原則之組合/聚合復(fù)用原則

    這篇文章介紹了C#面向?qū)ο笤O(shè)計(jì)原則之組合/聚合復(fù)用原則,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-03-03
  • C#實(shí)現(xiàn)撲克游戲(21點(diǎn))的示例代碼

    C#實(shí)現(xiàn)撲克游戲(21點(diǎn))的示例代碼

    21點(diǎn)又名黑杰克,該游戲由2到6個人玩,使用除大小王之外的52張牌,游戲者的目標(biāo)是使手中的牌的點(diǎn)數(shù)之和不超過21點(diǎn)且盡量大。本文將用C#實(shí)現(xiàn)這一經(jīng)典游戲,需要的可以參考一下
    2022-08-08
  • C#制作簡易的屏保

    C#制作簡易的屏保

    這篇文章主要為大家詳細(xì)介紹了C#制作簡易的屏保的相關(guān)資料,C#如何制作屏保的過程,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-01-01
  • 提示出現(xiàn)unresolved external symbol _main的解決方法

    提示出現(xiàn)unresolved external symbol _main的解決方法

    提示出現(xiàn)unresolved external symbol _main的解決方法...
    2007-11-11
  • C#定時器Timer實(shí)現(xiàn)精確到1-2毫秒以內(nèi)

    C#定時器Timer實(shí)現(xiàn)精確到1-2毫秒以內(nèi)

    最近在排查項(xiàng)目OTA的一個問題,觸發(fā)了一毫秒或者2毫秒執(zhí)行一次進(jìn)程間通信的,導(dǎo)致通信阻塞的問題,這樣就需要用到模擬觸發(fā)1ms或者2ms觸發(fā)事件,所以本文給大家介紹了C#?定時器?Timer?如何精確到?1-2?毫秒以內(nèi),需要的朋友可以參考下
    2024-12-12
  • C#獲取CPU編號的方法

    C#獲取CPU編號的方法

    這篇文章主要介紹了C#獲取CPU編號的方法,實(shí)例分析了C#獲取硬件信息的相關(guān)技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-07-07

最新評論