主頁 > .NET開發 > WPF 的內部世界(控制元件與布局)

WPF 的內部世界(控制元件與布局)

2020-12-13 06:02:17 .NET開發

目錄

一、控制元件與布局

前言

為什么要寫WPF呢?

我一開始算是比較抵觸WPF的,因為用的人少嗎,感覺都是表單應用能和Winform有什么區別,可是我錯了,非常感謝我的講師,給我推薦劉鐵猛的《深入淺出WPF》,讓我了解到了WPF的魅力——資料驅動UI ,

所以,這么優秀的框架,我想寫下來,都知道WPF開發人員非常少,以至于大部分教程視頻都是10年前的,我記錄下來,不是為了什么,是真的喜歡WPF,那種“怪誕不經”的感覺,

一、UI布局

俗話說:“人靠衣裝馬靠鞍”

什么意思呢?意思是人穿上一身得體的衣服,就會顯得分外精神;馬備上一副講究的鞍韉,就會顯得特別駿美,指衣服對人體的形象美有極大的影響,出自《薛仁貴征爾》

那么,我們把這句話引入到WPF中

  • WPF作為專門的用戶界面技術,布局的功能是它的核心功能之一,友好的用戶界面和良好的用戶體驗離不開設計精良的布局,
  • WPF設計師作業量最大的倆部分就是布局和影片,布局是靜態的,影片是動態的,用戶體驗就是用 戶在這動靜之中與軟體功能產生互動時的感受,
  • 也就是說,布局就是WPF的衣服!

二、控制元件

"我老生涯鷗水相依,他舊風流鴻塞荒投,”

意思是野生動物和野生環境鷗水相依,不可分離

那么到WPF中呢? 一個頁面的布局,顯示,都是由一個個控制元件組成的,控制元件們離不開WPF這個賴以生存的環境,組成了一幅幅美麗生動的畫面(布局),

在開始學習這些布局元素前,我們要知道每個布局元素都有自己的特點,我們要靈活使用,切莫不要無所不用其極,要合理搭配,

(就像生態環境一樣,要合理搭配,否則就會出現“生物入侵”這種“偷雞不成蝕把米”的行為,加重了生態環境的負擔,破壞)

1、 控制元件的分類

粗略而言,日常作業中我們打交道最多的控制元件無外乎6類,即:

  • 1、布局控制元件:可以容納多個控制元件或嵌套其他布局控制元件,用于UI上組織和排列控制元件,如:StackPanel,Grid,Dock,WrapPanel,,Canvas;
  • 2、內容控制元件:只能容納一個其他控制元件或布局控制元件作為它的內容,如:Button,Window;
  • 3、帶標題的內容控制元件:相當于一個內容控制元件,但可以加一個標題,如:Group Box,TabItem;
  • 4、條目控制元件:可以顯示一列資料,一般情況下這列資料的型別相同,如ListBox,ComboBox;
  • 5、帶標題的條目控制元件:相當于給一個條目控制元件加上一個標題顯示區,如:TreeViewItem,MenuItem,往往用于顯示層級資料;
  • 6、特殊的內容控制元件:比如TextBox容納的是字串,TeztBlock可以容納可自由控制格式的文本,Image容納圖片型別資料……這類的控制元件相對比較獨立,

至于,為什么這么分類呢,其實我們只需要細細體會一下,就明白了,實在不行,你從工具列拖出來,看著它的樣子,在看著我的話,“什么?你還不懂”………………………………作者卒

好,我們不對這些控制元件做太多詳細介紹,我們主要介紹布局控制元件,其他相信屬性可以參考下面:
WPF 基本控制元件使用介紹:https://blog.csdn.net/niewq/article/details/50244227

三、布局控制元件

好了,終于來到我們的重點了, WPF為我們提供了5中布局方式,他們的特點各不相同,可以相互嵌套,讓我們來認識一下吧,

  • 1、Grid :串列布局
  • 2、StackPanel :堆疊面板布局
  • 3、WrapPanel : 流布局面板(當元素水平對齊,內容超過寬度時,自動換行;當元素垂直對齊,內容超過高度時,自動換列)
  • 4、DockPanel:停靠面板
  • 5、Canvas:坐標面板

1、Grid串列布局

Grid一詞譯為“網格;格子,柵格”
沒錯,它就像一個網格一樣把我們的頁面分割成一塊又一塊,


我們在表單放置了2個TextBlock和2個TextBox,想實作登錄視窗的樣式,可是不進人意,他們都重疊在了一起,

為什么都重疊在了一起呢?

因為,我們沒有對Grid這個容器做相關調整,他現在是一個一行一列的“大格子”,在一個各自當然就重疊了,除非去設定Magin屬性,當然我們想要實作的并不是這種效果,

所以,我們通過設定

  • 列<Grid.ColumnDefinitions></Grid.ColumnDefinitions>
  • 行<Grid.RowDefinitions></Grid.RowDefinitions>

“分割Grid”

我們可以通過添加ColumnDefinitions節點和RowDefinitions節點 ,來確定把我們的“Grid分割成幾個格子”,

如圖,分割成了四個格子:

通過看設計視窗,我們也會發現,Grid被線條分割成了四塊:

唉?不對啊,為什么我們的控制元件還重疊的呢?是因為我們沒有去設定他們處于哪個格子,接下載,我們設定一下,

確定位置,與合并單元格

當我們的容器處于Grid布局容器里時,會增加附加屬性:

  • 行所在位置: Grid.Row="0"
  • 列所在位置: Grid.Column="0"

默認不設定,值為0 ,所以才會出現重疊的情況,來我們調整一下位置,

好了,一切恢復正常了,在增加一個按鈕,登錄怎么能沒有按鈕呢!

通過設定

  • 行單元格合并: Grid.RowSpan="1"
  • 列單元格合并: Grid.ColumnSpan="1"

默認值位1,合并幾個就寫幾,
經過稍作修改,我們的界面變成了這樣:

額……長得有點丑,我們添加些屬性來調整一下,

設定寬高

我們通過對ColumnDefinition的Width來設定寬和RowDefinition的Height來設定高

Width和Height支持像素,比例,以及自適應

  • 像素: 直接用數字表示即可
  • 比例: 以*做單位
  • 自適應: 設定值位 auto

好,我們來運用上面的知識,調整一下我們的視圖:

總結

好,我們來總結一下上面的寬高:

  • 首先我們對Grid的列經行了比例設定1:3(*,3*),當我們拉動表單大小時,會發現它們的大小是等比例變化的,
  • 其次,對Grid的行設定了倆個固定高度,我們可以發現無論表單怎么變化他們的高度是不變的,
  • 最后一行設定了自適應,我刻意把按鈕的高度設為100,我們可以看到表格最后一行也為100,可以知道auto是根據內容來自適應的,

2、StackPanel堆疊面板

大家都對“堆疊”倆個詞不陌生吧,堆疊面板就好像容器在“排隊”一樣,我們把Window下的Grid 換位StackPanel,來體驗一下吧,

設定方向


我們在StackPanel里放置了很多按鈕,發現他們就像排隊一樣,一個接一個,水平方向,如果你不喜歡這樣,當然是可以改方向的啦!

通過設定Orientation

  • 水平對齊: Orientation="Horizontal"
  • 垂直對齊: Orientation="Vertical"(默認)


對于內部元素自身,也可以選擇對其對齊方式

  • HorizontalAlignment="left" Center,right
  • VerticalAlignment="Top" Bottom,Center,Stretch

3、WrapPanel 流動布局

當元素水平對齊,內容超過寬度時,自動換行;當元素垂直對齊,內容超過高度時,自動換列)

它可能和上面的長得像,其實是不一樣的,當StackPanel的內部子元素數量超出寬度(高度)會溢位表單,而流動布局會自動換行,常用于動態資料生成,

這就不做詳細介紹了,屬性都和上面的一樣,

4、DockPanel 停靠布局

做過winfrom開發的朋友,都知道一個Docl屬性吧,那么我們的Dock布局也是這個道理,我們來實踐一下,

在DockPanel的容器里的控制元件,會增加一個附加屬性DockPanel.Dock

  • DockPanel.Dock="Top"
  • DockPanel.Dock="Bottom"
  • DockPanel.Dock="Left"
  • DockPanel.Dock="Right"

分別是上下左右停靠,要注意的是控制元件會隨著設定的先后順序,具有不同的寬高(或大小),默認最后一個停靠控制元件的大小占剩下界面的全部

仔細看左 和 右 ,你就會知道我說的注意項,新停靠的控制元件占剩余頁面的所有區域,

5、Canvas 坐標布局

好吧,這個真的就相當于winform的布局了, 設定坐標,確定控制元件的位置,

在Canvas容器里的控制元件,會增加附加屬性

  • 距離視窗上方: Canvas.Top="20"
  • 距離視窗左方:Canvas.Left="100"
  • 距離視窗下方:Canvas.Bottom="20"
  • 距離視窗右方:Canvas.Right="0"

四、綜合小案例

如果都看完的話,我們來做一個小案例吧,

    <Grid>
        <Grid.ColumnDefinitions>
            <ColumnDefinition Width="*"></ColumnDefinition>
            <ColumnDefinition Width="4*"></ColumnDefinition>
        </Grid.ColumnDefinitions>
        <Grid.RowDefinitions>
            <RowDefinition Height="auto"></RowDefinition>
            <RowDefinition></RowDefinition>
        </Grid.RowDefinitions>
        <StackPanel Grid.RowSpan="2" Grid.Column="0">
            <Button  Height="50">新建StackPanel</Button>
            <Button  Height="50">保存StackPanel</Button>
            <Button  Height="50">增加StackPanel</Button>
            <Button  Height="50">匯入StackPanel</Button>
            <Button  Height="50">匯出StackPanel</Button>
            <Button  Height="50">關閉StackPanel</Button>
        </StackPanel>
        <DockPanel Grid.Row="0" Grid.Column="1">
            <TextBlock DockPanel.Dock="Top" HorizontalAlignment="Center">我是DockPanel</TextBlock>
            <WrapPanel>
                <Button Width="200">WrapPanel</Button>
                <Button Width="200">WrapPanel</Button>
                <Button Width="200">WrapPanel</Button>
                <Button Width="200">放不下啦WrapPanel</Button>
                <Button Width="200">WrapPanel</Button>
            </WrapPanel>
        </DockPanel>
        <Canvas Grid.Row="1" Grid.Column="1">
            <TextBlock Canvas.Top="100" Canvas.Left="100">Canvas賬號:</TextBlock>
            <TextBox Canvas.Top="100" Canvas.Left="200">Canvas請輸入賬號:</TextBox>
            <TextBlock Canvas.Top="130" Canvas.Left="100">Canvas密碼:</TextBlock>
            <TextBox Canvas.Top="130" Canvas.Left="200">Canvas請輸入密碼:</TextBox>
        </Canvas>
    </Grid>

結束語 “不要用不公平掩飾你不努力的樣子”

轉載請註明出處,本文鏈接:https://www.uj5u.com/net/233732.html

標籤:.NET技术

上一篇:Layui事件監聽(表單和資料表格)

下一篇:WPF 的內部世界(Binding)

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • WebAPI簡介

    Web體系結構: 有三個核心:資源(resource),URL(統一資源識別符號)和表示 他們的關系是這樣的:一個資源由一個URL進行標識,HTTP客戶端使用URL定位資源,表示是從資源回傳資料,媒體型別是資源回傳的資料格式。 接下來我們說下HTTP. HTTP協議的系統是一種無狀態的方式,使用請求/ ......

    uj5u.com 2020-09-09 22:07:47 more
  • asp.net core 3.1 入口:Program.cs中的Main函式

    本文分析Program.cs 中Main()函式中代碼的運行順序分析asp.net core程式的啟動,重點不是剖析原始碼,而是理清程式開始時執行的順序。到呼叫了哪些實體,哪些法方。asp.net core 3.1 的程式入口在專案Program.cs檔案里,如下。ususing System; us ......

    uj5u.com 2020-09-09 22:07:49 more
  • asp.net網站作為websocket服務端的應用該如何寫

    最近被websocket的一個問題困擾了很久,有一個需求是在web網站中搭建websocket服務。客戶端通過網頁與服務器建立連接,然后服務器根據ip給客戶端網頁發送資訊。 其實,這個需求并不難,只是剛開始對websocket的內容不太了解。上網搜索了一下,有通過asp.net core 實作的、有 ......

    uj5u.com 2020-09-09 22:08:02 more
  • ASP.NET 開源匯入匯出庫Magicodes.IE Docker中使用

    Magicodes.IE在Docker中使用 更新歷史 2019.02.13 【Nuget】版本更新到2.0.2 【匯入】修復單列匯入的Bug,單元測驗“OneColumnImporter_Test”。問題見(https://github.com/dotnetcore/Magicodes.IE/is ......

    uj5u.com 2020-09-09 22:08:05 more
  • 在webform中使用ajax

    如果你用過Asp.net webform, 說明你也算是.NET 開發的老兵了。WEBform應該是2011 2013左右,當時還用visual studio 2005、 visual studio 2008。后來基本都用的是MVC。 如果是新開發的專案,估計沒人會用webform技術。但是有些舊版 ......

    uj5u.com 2020-09-09 22:08:50 more
  • iis添加asp.net網站,訪問提示:由于擴展配置問題而無法提供您請求的

    今天在iis服務器配置asp.net網站,遇到一個問題,記錄一下: 問題:由于擴展配置問題而無法提供您請求的頁面。如果該頁面是腳本,請添加處理程式。如果應下載檔案,請添加 MIME 映射。 WindowServer2012服務器,添加角色安裝完.netframework和iis之后,運行aspx頁面 ......

    uj5u.com 2020-09-09 22:10:00 more
  • WebAPI-處理架構

    帶著問題去思考,大家好! 問題1:HTTP請求和回傳相應的HTTP回應資訊之間發生了什么? 1:首先是最底層,托管層,位于WebAPI和底層HTTP堆疊之間 2:其次是 訊息處理程式管道層,這里比如日志和快取。OWIN的參考是將訊息處理程式管道的一些功能下移到堆疊下端的OWIN中間件了。 3:控制器處理 ......

    uj5u.com 2020-09-09 22:11:13 more
  • 微信門戶開發框架-使用指導說明書

    微信門戶應用管理系統,采用基于 MVC + Bootstrap + Ajax + Enterprise Library的技術路線,界面層采用Boostrap + Metronic組合的前端框架,資料訪問層支持Oracle、SQLServer、MySQL、PostgreSQL等資料庫。框架以MVC5,... ......

    uj5u.com 2020-09-09 22:15:18 more
  • WebAPI-HTTP編程模型

    帶著問題去思考,大家好!它是什么?它包含什么?它能干什么? 訊息 HTTP編程模型的核心就是訊息抽象,表示為:HttPRequestMessage,HttpResponseMessage.用于客戶端和服務端之間交換請求和回應訊息。 HttpMethod類包含了一組靜態屬性: private stat ......

    uj5u.com 2020-09-09 22:15:23 more
  • 部署WebApi隨筆

    一、跨域 NuGet參考Microsoft.AspNet.WebApi.Cors WebApiConfig.cs中配置: // Web API 配置和服務 config.EnableCors(new EnableCorsAttribute("*", "*", "*")); 二、清除默認回傳XML格式 ......

    uj5u.com 2020-09-09 22:15:48 more
最新发布
  • C#多執行緒學習(二) 如何操縱一個執行緒

    <a href="https://www.cnblogs.com/x-zhi/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/2943582/20220801082530.png" alt="" /></...

    uj5u.com 2023-04-19 09:17:20 more
  • C#多執行緒學習(二) 如何操縱一個執行緒

    C#多執行緒學習(二) 如何操縱一個執行緒 執行緒學習第一篇:C#多執行緒學習(一) 多執行緒的相關概念 下面我們就動手來創建一個執行緒,使用Thread類創建執行緒時,只需提供執行緒入口即可。(執行緒入口使程式知道該讓這個執行緒干什么事) 在C#中,執行緒入口是通過ThreadStart代理(delegate)來提供的 ......

    uj5u.com 2023-04-19 09:16:49 more
  • 記一次 .NET某醫療器械清洗系統 卡死分析

    <a href="https://www.cnblogs.com/huangxincheng/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/214741/20200614104537.png" alt="" /&g...

    uj5u.com 2023-04-18 08:39:04 more
  • 記一次 .NET某醫療器械清洗系統 卡死分析

    一:背景 1. 講故事 前段時間協助訓練營里的一位朋友分析了一個程式卡死的問題,回過頭來看這個案例比較經典,這篇稍微整理一下供后來者少踩坑吧。 二:WinDbg 分析 1. 為什么會卡死 因為是表單程式,理所當然就是看主執行緒此時正在做什么? 可以用 ~0s ; k 看一下便知。 0:000> k # ......

    uj5u.com 2023-04-18 08:33:10 more
  • SignalR, No Connection with that ID,IIS

    <a href="https://www.cnblogs.com/smartstar/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/u36196.jpg" alt="" /></a>...

    uj5u.com 2023-03-30 17:21:52 more
  • 一次對pool的誤用導致的.net頻繁gc的診斷分析

    <a href="https://www.cnblogs.com/dotnet-diagnostic/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/3115652/20230225090434.png" alt=""...

    uj5u.com 2023-03-28 10:15:33 more
  • 一次對pool的誤用導致的.net頻繁gc的診斷分析

    <a href="https://www.cnblogs.com/dotnet-diagnostic/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/3115652/20230225090434.png" alt=""...

    uj5u.com 2023-03-28 10:13:31 more
  • C#遍歷指定檔案夾中所有檔案的3種方法

    <a href="https://www.cnblogs.com/xbhp/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/957602/20230310105611.png" alt="" /></a&...

    uj5u.com 2023-03-27 14:46:55 more
  • C#/VB.NET:如何將PDF轉為PDF/A

    <a href="https://www.cnblogs.com/Carina-baby/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/2859233/20220427162558.png" alt="" />...

    uj5u.com 2023-03-27 14:46:35 more
  • 武裝你的WEBAPI-OData聚合查詢

    <a href="https://www.cnblogs.com/podolski/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/616093/20140323000327.png" alt="" /><...

    uj5u.com 2023-03-27 14:46:16 more