WPF进阶技巧和实战02-布局
窗体
- 无边框
窗体无边框(最大化及标题位置)WindowStyle="None"
窗体透明 AllowsTransparency="True",必须设置窗体无边框,否则报错
SizeToContent属性,窗体大小可以根据内容自动调整,多语言版本时一般会使用
我习惯性的设置Window窗体的样式如下:
<Border Margin="5" Background="#EEE" CornerRadius="5" MouseLeftButtonDown="Border_MouseLeftButtonDown">
<Border.Effect>
<DropShadowEffect BlurRadius="10" Direction="0" Opacity="0.3" ShadowDepth="0" Color="Gray" />
</Border.Effect>
<Grid Margin="10" />
</Border>
这里有个知识点需要强调一下:
Border的属性Background="{x:Null}" 和Background="Transparent" 的区别,前者设置之后,会导致无法获取到Border的一些事件,所以一般都会使用后者,特殊场景除外。
- 异形窗口
关键属性Clip:根据集合图形进行窗口剪切
<Window.Clip>
<RectangleGeometry Rect="20,20,100,50" />
<!--<EllipseGeometry RadiusX="80" RadiusY="40" Center="50,50"/>-->
</Window.Clip>
也可使用PathGeometry实现各种自定义形状的异形窗体创建
布局原则
- 不使用显示的方式设定元素的尺寸(常见的就是在多语言版本软件切换时)
- 不使用坐标定位置
- 布局容器的子元素共享可用空间
- 可嵌套容器
布局过程
布局过程包括两个阶段:测量(measure)阶段和排列(arrange)阶段。测量阶段,容器遍历所有子元素,并询问子元素他们期望的尺寸。排列阶段,容器在合适的位置放置子元素。
布局容器
- Border:装饰控件,不是严格意义上的布局控件。同类型的还有Viewbox(对布局内的子控件进行等比缩放)
- StackPanel:实现单行或者单列展示子控件
- DockPanel:具有停靠功能,给子控件增加了附加属性(停靠方式,依次设置子控件布局)
- WrapPanel:唯一一个不能被Grid替代的布局控件,先行后列/先列后行的形式进行布局(会换行)
- Grid:布局应用最广的控件,可以设置行列网格也可以不设置,将子控件包裹起来形成一个整体,为子控件增加附加属性(用来设置行列位置)
- UniformGrid:直接通过属性定义行列数量 Rows="4" Columns="3",子元素按照行列自动填充。如果不设置行列属性,会按照n*n的形式进行自动布局行列
- Canvas:在业务界面使用比较少,一般在做鼠标操作比较多的界面中或者自定义控件中比较常用,通过使用精确的坐标来放置元素。
- InkCanvas:支持笔画输入等操作,不属于布局控件
所有布局容器都继承自Panel抽象类。3个公有属性
名称 | 说明 |
---|---|
Backgroud | 面板背景着色的画刷。如果想接收鼠标事件,就必须将该属性设置为非空值(如果既想接收鼠标事件,又不希望显示固定颜色的背景,那就设置透明即可) |
Children | 该属性是在面板中存储的条目集合(每个条目可以包含更多的子条目) |
IsItemHost | 如果面板用于显示与ItemsControl控件关联的项,该属性值就是true。在大多数情况下,设置不需要知道列表控件使用后台面板来管理它所包含的条目的布局。但是如果希望创建自定义列表,以不同方式放置子元素(按照平铺方式显示图像的ListBox控件),这个属性就很重要了。 |
如果需要创建自己的布局容器,就需要使用这几个公有属性,还需要重写继承自FrameworkElement类的两个方法:
protected override Size MeasureOverride(Size constraint)
protected override Size ArrangeOverride(Size arrangeSize)
来修改当前子元素面板处理测量阶段和排列阶段的方式。
扩展布局容器
- TabPanel
- ToolbarPanel、ToolbarOverflowPanel
- VirtualizingStackPanel(能够改善性能,大数据量展示的时候。ListBox内部使用了,ItemsControl没有)
特殊容器
- ScrollViewer-无法全部呈现时,使用滚动进行封装。
继承自ContextControl(内部职能放置一个对象),所以使用布局控件包裹整个展示内容。LineUp()-LineDown()
PageUp()-PageDown()
ScrollToEnd()-ScrollToHome()-ScrollToVerticalOffset()
ScrollToLeftEnd()-ScrollToRightEnd()-ScrollToHorizontalOffset()
- HeaderedContentControl
- GroupBox
- TabItem
- Expander
WPF进阶技巧和实战02-布局的更多相关文章
- WPF进阶技巧和实战03-控件(3-文本控件及列表控件)
系列文章链接 WPF进阶技巧和实战01-小技巧 WPF进阶技巧和实战02-布局 WPF进阶技巧和实战03-控件(1-控件及内容控件) WPF进阶技巧和实战03-控件(2-特殊容器) WPF进阶技巧和实 ...
- WPF进阶技巧和实战03-控件(4-基于范围的控件及日期控件)
系列文章链接 WPF进阶技巧和实战01-小技巧 WPF进阶技巧和实战02-布局 WPF进阶技巧和实战03-控件(1-控件及内容控件) WPF进阶技巧和实战03-控件(2-特殊容器) WPF进阶技巧和实 ...
- WPF进阶技巧和实战07--自定义元素02
在01节中,研究了如何开发自定义控件,下节开始考虑更特殊的选择:派生自定义面板以及构建自定义绘图 创建自定义面板 创建自定义面板是一种比较常见的自定义控件开发子集,面板可以驻留一个或多个子元素,并且实 ...
- WPF进阶技巧和实战03-控件(5-列表、树、网格02)
数据模板 样式提供了基本的格式化能力,但是不管如何修改ListBoxItem,他都不能够展示功能更强大的元素组合,因为了每个ListBoxItem只支持单个绑定字段(通过DisplayMemberPa ...
- WPF进阶技巧和实战08-依赖属性与绑定02
将元素绑定在一起 数据绑定最简单的形式是:源对象是WPF元素而且源属性是依赖项属性.依赖项属性内置了更改通知支持,当源对象中改变依赖项属性时,会立即更新目标对象的绑定属性. 元素绑定到元素也是经常使用 ...
- WPF进阶技巧和实战08-依赖属性与绑定01
依赖项属性 定义依赖项属性 注意:只能为依赖对象(继承自DependencyObject的类)添加依赖项属性.WPF中的元素基本上都继承自DependencyObject类. 静态字段 名称约定(属性 ...
- WPF进阶技巧和实战07--自定义元素01
完善和扩展标准控件的方法: 样式:可使用样式方便地重用控件属性的集合,甚至可以使用触发器应用效果 内容控件:所有继承自ContentControl类的控件都支持嵌套的内容.使用内容控件,可以快速创建聚 ...
- WPF进阶技巧和实战06-控件模板
逻辑树和可视化树 System.Windows.LogicalTreeHelper System.Windows.Media.VisualTreeHelper 逻辑树类(LogicalTreeHelp ...
- WPF进阶技巧和实战03-控件(1-控件及内容控件)
所有控件都继承自System.Windows.Controls.Control类,这个类添加一些基本结构: 设置控件内容对齐方式 (HorizontalContentAlignment,Vertica ...
- WPF进阶技巧和实战01-小技巧
Svg在WPF中的使用 方法1:拷贝svg中的部分代码转换成Geometry(作为Path的Data使用) 在vs或者直接打开svg,看到如下代码: <?xml version="1. ...
随机推荐
- [转]C# 互操作性入门系列(一):C#中互操作性介绍
传送门 C#互操作系列文章: C# 互操作性入门系列(一):C#中互操作性介绍 C# 互操作性入门系列(二):使用平台调用调用Win32 函数 C# 互操作性入门系列(三):平台调用中的数据封送处理 ...
- CentOS8安装jdk1.8
安装方法 CentOS8上使用 yum 直接安装,环境变量自动配置好 查看是否已安装 看到下面结果,说明已经安装配置 jdk [root@iZ2ze8crquorxf6c7l0eluZ ~]# jav ...
- 2018.7.31-2018.8.2记:关于maven
maven的使用,用得好,则省力省事,但是用不好则会造成一堆莫名其妙的错误,maven在使用的时候,jar包下载异常终止尤为需要注意,很容易就终止了,并且会出现一些下载出空jar包的情况,即:jar包 ...
- IDEA 创建Maven Web工程
一.Maven环境搭建 二.Maven常用命令 mvn clean 清除生成的target文件 mvn install 生成target文件 mvn clean install 相当于先删除targe ...
- 高德地图&兴趣点(poi)
<!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title&g ...
- Linux系统的高级网络配置(bond、team、网桥)
1.bond接口 Red Hat Enterprise Linux 允许管理员使用 bonding 内核模块和称为通道绑定接口的特殊网络接口将多个网络接口绑定 到一个通道.根据选择的绑定模式 , 通道 ...
- SQL Server数据表设计编辑后无法保存处理办法
关于使用 SQL Server 企业管理器,表[设计]界面,修改数据表字段或类型无法保存的问题处理过程: 使用SQL Server数据库的你是否遇到过每次数据库编辑工具内点击设计修改表字段或类型要保存 ...
- Robot Framework(7)- DateTime 测试库常用的关键字列表
如果你还想从头学起Robot Framework,可以看看这个系列的文章哦! https://www.cnblogs.com/poloyy/category/1770899.html 前言 所有关键字 ...
- Docker入门之container篇
启动 启动容器有两种方式,一种是基于镜像新建一个容器并启动,另外一个是将在终止状态(stopped)的容 器重新启动. 因为 Docker 的容器实在太轻量级了,很多时候用户都是随时删除和新创建容器. ...
- LayoutControl控件使用
因默认外边距过大需要将外边距缩小用以下代码实现layoutControlGroup1.Padding = DevExpress.XtraLayout.Utils.Padding.Empty;是否允许只 ...