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. ...
随机推荐
- win10下安装mysql5.7-建议安装-自定义位置
所需文件: 文件名字:mysql-installer-community-5.7.13.0.msi 开始安装: 01:勾选: 02:选择下一步 03:选择Custom安装 04:选择下一步 05:选择 ...
- C++笔记(11) 智能指针
1. 设计思想 智能指针是行为类似于指针的类对象,但这种对象还有其他功能.首先,看下面的函数: void remodel(std::string & str) { std::string * ...
- js日期处理多少/月/天以前
var date = new Date(); var year = date.getFullYear(); var month = (date.getMonth() + 1) > 10 ? da ...
- 阿里云服务器,http免费转https详细教程
1.搜ssl证书,点击立即购买 2.这里我们选择免费证书,点击右边立即购买,去支付 购买完成之后,申请证书状态会显示在审核中,不过很快的,几分钟就申请成功了,以下就是我申请成功的界面,因为我服务器用的 ...
- JS中原型与原型链
一. 普通对象与函数对象 JavaScript 中,万物皆对象!但对象也是有区别的.分为普通对象和函数对象,Object .Function等 是 JS 自带的函数对象.下面举例说明. var o1 ...
- tomcat漏洞总结
描述 Tomcat是Apache 软件基金会(Apache Software Foundation)的Jakarta 项目中的一个核心项目,由Apache.Sun 和其他一些公司及个人共同开发而成.由 ...
- Django——实现最基础的评论功能(只有一级评论)
我对评论功能的理解: --------(1)数据库建一个评论的表 --------(2)前端建一个提交评论的form表单 --------(3)表单提交评论内容后写入到数据库评论表中 -------- ...
- noip模拟29
这次终于是早上考试了 早上考试手感不错,这次刷新了以前的最高排名- %%%cyh巨佬 \(rk1\) %%%CT巨佬 \(t2\) 90 纵观前几,似乎我 \(t3\) 是最低的-- 总计挂分10分, ...
- Winform EF CodeFist方式连接数据库
直接生成ado.net 实体数据模型挺方便的,但只有一步步的手写代码才能更好的理解EF,在学习asp.net core过程中手写代码已经明白了怎么回事,但实现过程有些麻烦不知道如何记录,但Winfor ...
- FastAPI(2)- 快速入门
安装 FastAPI pip install fastapi # 将来需要将应用程序部署到生产环境可以安装 uvicorn 作为服务器 pip install uvicorn 最简单的代码栗子 fro ...