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

WPF常見(jiàn)布局面板用法及介紹

 更新時(shí)間:2022年01月25日 10:47:48   作者:痕跡g  
本文詳細(xì)講解了WPF常見(jiàn)布局面板用法及介紹,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

常見(jiàn)的幾個(gè)布局面板

1.StackPanel面板

StackPanel面板能夠簡(jiǎn)單根據(jù)單行或者單列進(jìn)行元素排列, StackPanel 默認(rèn)的布局方向?yàn)榇怪狈较?Vertical), 由Orientation屬性控制。

Orientation屬性:

用戶控制布局方向是垂直還是橫向排列。分別有兩個(gè)值可選:Vertical、Horizontal

示例代碼:

<StackPanel Orientation="Vertical">
    <Button>button1</Button>
    <Button>button2</Button>
    <Button>button3</Button>
</StackPanel>

效果圖(如上面所述 StackPanel面板Orientation屬性默認(rèn)為Vertical):

設(shè)置 Orientation="Horizontal" 時(shí), 控件布局方向則為橫向, 效果圖。

默認(rèn)情況下, StackPanel面板中的元素都會(huì)根據(jù)StackPanel的大小而改變, StackPanel面板指定了Width和Height值。

布局屬性:

VerticalAlignment當(dāng)垂直方向有額外的空間, 可以選擇Top、Center、Bottom、Stretch進(jìn)行設(shè)置布局
HorizontalAlignment當(dāng)水平方向有額外的空間, 可以選擇Center、Left、Right、Stretcj進(jìn)行設(shè)置布局
Margin

相對(duì)控件的4個(gè)邊、設(shè)置邊距,可以單獨(dú)設(shè)置各個(gè)邊距,也可以統(tǒng)一設(shè)置一個(gè)邊距

類似:Margin="1 2 3 4" 或 Margin="1"

【VerticalAlignment/HorizontalAlignment】屬性:

為了能夠看到效果, 通常預(yù)留控件額外的空間, 示例, 默認(rèn)的StackPanel面板中添加幾組按鈕, 剩下的白色區(qū)域?yàn)轭~外的空間。

這個(gè)時(shí)候, 針對(duì)StackPanel面板設(shè)置VerticalAlignment屬性為Center, 此時(shí)所有的子元素被居中顯示,額外的空間被均分。

注:而B(niǎo)ottom、Top、Stretch 則分別表示整體元素居下,居上、整體伸展。

默認(rèn)情況下, StackPanel面板的VerticalAlignment、HorizontalAlignment 默認(rèn)屬性均為 Stretch

<!-- StackPanel -->
<StackPanel VerticalAlignment="Center">
    <Button>button1</Button>
    <Button>button2</Button>
    <Button>button3</Button>
</StackPanel>

效果圖:

Margin(邊距)屬性:

正如前人書中所說(shuō), 一個(gè)設(shè)計(jì)良好窗口不止是包含元素、還應(yīng)當(dāng)在元素之間包含一定的額外空間。所以這個(gè)時(shí)候Margin屬性派上用場(chǎng)。

以上的示例圖中, 均沒(méi)有設(shè)置Margin屬性, 所以會(huì)看到的是, 每個(gè)元素之間都緊貼。

當(dāng)設(shè)置邊距時(shí), 可以統(tǒng)一設(shè)置元素所有邊的距離, 如下所示:

<!-- StackPanel -->
   <StackPanel>
       <Button Margin="3">button1</Button>
       <Button Margin="3">button2</Button>
       <Button Margin="3">button3</Button>
   </StackPanel>

另外一種,則是分別對(duì)元素的邊: 左、上、右、下的順序設(shè)置邊距, 如下所示:

<!-- StackPanel -->
   <StackPanel>
       <Button Margin="3 6 3 3">button1</Button>
       <Button Margin="3">button2</Button>
       <Button Margin="3">button3</Button>
   </StackPanel>

2.WarpPanel面板

與StackPanel面板類型, WarpPanel面板也是以行或列的形式進(jìn)行元素排列, 默認(rèn)情況下, WarpPanel面板的Orientation屬性則為Horizontal,元素以橫向進(jìn)行排列。

注意:與StackPanel面板不同的是, WarpPanel默認(rèn)情況下, 所有元素均不會(huì)被拉伸。這里要強(qiáng)調(diào)的一點(diǎn): StackPanel中, 元素會(huì)根據(jù)Orientation屬性進(jìn)行拉伸,

1.當(dāng)Orientation="Horizontal"時(shí), 元素被垂直拉伸

2.當(dāng)Orientation="Vertical"時(shí), 元素被水平拉伸

示例圖:

同樣的, WarpPanel面板具備StackPanel的屬性。區(qū)別則在于上面的不同。

3.DockPanel面板

用過(guò)winform的小伙伴應(yīng)該都知道, 在winform中, 幾乎所有的空間都具備Dock停靠屬性, 可以針對(duì)元素進(jìn)行單獨(dú)設(shè)置Dock定位。然而在WPF中, 這點(diǎn)顯然是不具備的。

所以對(duì)于靈活的WPF來(lái)說(shuō), DockPanel面板具備了這個(gè)能力。凡是包含在DockPanel面板中的子元素, 都會(huì)具備Dock附加屬性。

下圖所示, 對(duì)DockPanel進(jìn)行簡(jiǎn)單的添加元素設(shè)置Dock屬性:

示例代碼:

<DockPanel>
    <Button DockPanel.Dock="Top">button1</Button>
    <Button DockPanel.Dock="Right" >button2</Button>
    <Button DockPanel.Dock="Left">button3</Button>
</DockPanel>

注意:DockPanel的LastChildFill屬性, 主要用于設(shè)置DockPanel中最后一個(gè)元素的會(huì)具備填充效果。如上圖的button3元素

LastChildFill 字面意思則可以理解, 最后一個(gè)元素是否填充。通過(guò)設(shè)置true/false,

效果圖(LastChildFill="false") :

<DockPanel <strong>LastChildFill="False"</strong>>
       <Button DockPanel.Dock="Top">button1</Button>
       <Button DockPanel.Dock="Right" >button2</Button>
       <Button DockPanel.Dock="Left">button3</Button>
   </DockPanel>

4.Grid面板

Grid面板類型HTML中的table表格, 為了能夠讓元素或內(nèi)容按照規(guī)定的位置排列, 首先得定義足夠得行和列。

注意: Grid中定義得Row與Column屬性默認(rèn)在元素中都是從0開(kāi)始索引, 在下面示例中,為了演示都進(jìn)行了添加(如果在程序中,位置已經(jīng)確定, 可以默認(rèn)不加)。

定義行與列( RowDefinitions/ColumnDefinitions)

<Grid>
  <strong>  <!-- 下面分別定義了2行 2列 --></strong>
    <Grid.RowDefinitions>
        <RowDefinition/>
        <RowDefinition/>
    </Grid.RowDefinitions>
 
    <Grid.ColumnDefinitions>
        <ColumnDefinition/>
        <ColumnDefinition/>
    </Grid.ColumnDefinitions>
</Grid>

添加元素:

下面為Grid定義得2行2列基礎(chǔ)上添加4個(gè)按鈕, 下圖所示:

代碼所示:

<Grid>
        <!-- 下面分別定義了2行 2列 -->
        <Grid.RowDefinitions>
            <RowDefinition/>
            <RowDefinition/>
        </Grid.RowDefinitions>
 
        <Grid.ColumnDefinitions>
            <ColumnDefinition/>
            <ColumnDefinition/>
        </Grid.ColumnDefinitions>
 
        <Button Grid.Column="0" Grid.Row="0">左上</Button>
        <Button Grid.Column="1" Grid.Row="0">右上</Button>
        <Button Grid.Column="0" Grid.Row="1">左下</Button>
        <Button Grid.Column="1" Grid.Row="1">右下</Button>
    </Grid>

注意:盡管一個(gè)單元格中, 允許放置多個(gè)元素, 通常來(lái)說(shuō)這沒(méi)有什么意義。如上所示, 每個(gè)元素都明確了對(duì)應(yīng)單元格中。

Grid與WarpPanel和StackPanel面板等容器不同得區(qū)別在于, Grid需要顯式定義行與列來(lái)放置元素。而相對(duì)于其他容器,則會(huì)隱式創(chuàng)建行與列。

調(diào)整行和列:

Grid面板支持3種設(shè)置尺寸的方式:

硬編碼尺寸 width="xxx" / height="xxx"
自動(dòng)設(shè)置尺寸 width="auto" / height="auto"
按比例設(shè)置尺寸 width="*" / height="2*"

例如, 下面的代碼演示了三種設(shè)置尺寸的方式:

<Grid>
       <!-- 下面分別定義了2行 2列 -->
       <Grid.RowDefinitions>
           <RowDefinition Height="Auto" />
           <RowDefinition Height="100"/>
       </Grid.RowDefinitions>
 
       <Grid.ColumnDefinitions>
           <ColumnDefinition Width="*"/>
           <ColumnDefinition Width="2*"/>
       </Grid.ColumnDefinitions>
 
       <Button Grid.Column="0" Grid.Row="0">左上</Button>
       <Button Grid.Column="1" Grid.Row="0">右上</Button>
       <Button Grid.Column="0" Grid.Row="1">左下</Button>
       <Button Grid.Column="1" Grid.Row="1">右下</Button>
   </Grid>

實(shí)際的顯示效果可以看到, 第一列width="*" 為第二列的1/2, 第一行設(shè)置的自適應(yīng)高度, 而第二行則是硬編碼的高度 100

注意: 當(dāng)使用Grid進(jìn)行按比例設(shè)置列或者行時(shí), 如果Grid寬度為奇數(shù)像素, 那么被分割的行列像素帶小數(shù), 當(dāng)改列包含形狀元素、邊框、圖像, 那么顯示內(nèi)容可能是模糊的,

如果這個(gè)問(wèn)題影響布局, 則只需要將Grid的UseLayoutRounding屬性設(shè)置為True即可。

跨行與跨列:

處于Grid中的任意元素, 都具有兩個(gè)附加屬性, 分別為 RowSpan與 ColumnSpan。像這種跨行跨列在web應(yīng)用中十分常見(jiàn)。

下面的示例中演示了如何針對(duì)元素進(jìn)行跨列顯示:

5.UniformGrid面板

與Grid相反, UniformGrid并不遵循Grid的眾多原則, 無(wú)論是顯式聲明行和列, 還有其附加屬性。反而, 通過(guò)簡(jiǎn)單的設(shè)置

Rows和Columns屬性來(lái)設(shè)定其尺寸。每個(gè)單元格都被均勻分配, 關(guān)鍵一點(diǎn), 所有元素最后都根據(jù)其定義的先后順序放置在

單元格中。

示例代碼如下:

<UniformGrid Rows="2" Columns="2">
    <Button>button1</Button>
    <Button>button2</Button>
    <Button>button3</Button>
    <Button>button4</Button>
</UniformGrid>

6.Canvas面板

Canvas面板允許使用精準(zhǔn)的坐標(biāo)放置元素, 為了在Canvas面板中定位一個(gè)元素, 需要設(shè)置Canvas.Left 和 Canvas.Top屬性。

Code:通過(guò)設(shè)置元素的附加屬性 Canvas.Left 、Top、Right、Bottom 等進(jìn)行元素定位

<Canvas>
        <Button Canvas.Left="100" Canvas.Top="50">button1</Button>
        <Button Canvas.Left="100" Canvas.Top="80">button2</Button>
    </Canvas>

到此這篇關(guān)于WPF常見(jiàn)布局面板用法及介紹的文章就介紹到這了。希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • asp.net中通過(guò)ALinq讓Mysql操作變得如此簡(jiǎn)單

    asp.net中通過(guò)ALinq讓Mysql操作變得如此簡(jiǎn)單

    當(dāng)大家已經(jīng)習(xí)慣了使用.net 去操作SQL Server,有多少人曾經(jīng)嘗試過(guò)使用.net 去操作Mysql數(shù)據(jù)庫(kù)!在.net 的光環(huán)下,Mysql是顯得如此微不足道!但是Mysql的開(kāi)源又是如此具有誘惑。
    2011-07-07
  • asp.net數(shù)據(jù)驗(yàn)證控件

    asp.net數(shù)據(jù)驗(yàn)證控件

    ASP.NET不僅把窗體的驗(yàn)證作為服務(wù)器控件引入,還使這些控件智能化。如果瀏覽器支持JavaScript,而ASP.NET可以發(fā)送JavaScript,驗(yàn)證就在客戶端進(jìn)行;如果客戶機(jī)不支持用于驗(yàn)證的JavaScript,這些JavaScript就被忽略,驗(yàn)證就在服務(wù)器上進(jìn)行。
    2015-11-11
  • jQuery+Asp.Net實(shí)現(xiàn)省市二級(jí)聯(lián)動(dòng)功能的方法

    jQuery+Asp.Net實(shí)現(xiàn)省市二級(jí)聯(lián)動(dòng)功能的方法

    這篇文章主要介紹了jQuery+Asp.Net實(shí)現(xiàn)省市二級(jí)聯(lián)動(dòng)功能的方法,涉及asp.net數(shù)據(jù)庫(kù)讀取與字符串轉(zhuǎn)換相關(guān)操作技巧,需要的朋友可以參考下
    2017-05-05
  • 去除HTML標(biāo)簽刪除HTML示例代碼

    去除HTML標(biāo)簽刪除HTML示例代碼

    這篇文章主要介紹了如何去除HTML標(biāo)簽、刪除HTML。示例中使用到了一個(gè)正則,直接使用就可以了
    2014-06-06
  • .Net Core庫(kù)類項(xiàng)目跨項(xiàng)目讀取配置文件的方法

    .Net Core庫(kù)類項(xiàng)目跨項(xiàng)目讀取配置文件的方法

    這篇文章主要介紹了.Net Core庫(kù)類項(xiàng)目跨項(xiàng)目讀取配置文件的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2019-03-03
  • asp.net SqlDataAdapter對(duì)象使用札記

    asp.net SqlDataAdapter對(duì)象使用札記

    如果 DataAdapter 遇到多個(gè)結(jié)果集,它將在 DataSet 中創(chuàng)建多個(gè)表。將向這些表提供遞增的默認(rèn)名稱 TableN,以表示 Table0 的“Table”為第一個(gè)表名。
    2009-04-04
  • AJAX JavaScript反射機(jī)制的介紹

    AJAX JavaScript反射機(jī)制的介紹

    反射機(jī)制指的是程序在運(yùn)行時(shí)能夠獲取自身的信息。例如一個(gè)對(duì)象能夠在運(yùn)行時(shí)知道自己有哪些方法和屬性。
    2013-03-03
  • C# FTP,GetResponse(),遠(yuǎn)程服務(wù)器返回錯(cuò)誤

    C# FTP,GetResponse(),遠(yuǎn)程服務(wù)器返回錯(cuò)誤

    C# FTP,GetResponse(),遠(yuǎn)程服務(wù)器返回錯(cuò)誤:(550) 文件不可用(例如,未找到文件,無(wú)法訪問(wèn)文件)
    2009-06-06
  • 利用IIS調(diào)試ASP.NET網(wǎng)站程序的完整步驟

    利用IIS調(diào)試ASP.NET網(wǎng)站程序的完整步驟

    這篇文章主要給大家介紹了關(guān)于利用IIS調(diào)試ASP.NET網(wǎng)站程序的完整步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2018-11-11
  • ASP.NET數(shù)據(jù)庫(kù)編程之Access連接失敗

    ASP.NET數(shù)據(jù)庫(kù)編程之Access連接失敗

    ASP.NET數(shù)據(jù)庫(kù)編程之Access連接失敗...
    2006-09-09

最新評(píng)論