WPF 是数据核心、主动的,UI 从属数据并表达数据、是被动的;
不再是 UI 驱动数据,而是数据驱动 UI;
控件、数据内容、行为(控件响应用户操作执行自己的方法或以事件的形式通知应用程序);
1)控件是数据和行为的载体;
2)所以关注控件时应该关注抽象的数据和行为而不是具体的形象,
3)比如符合"能展示内容并相应用户单击"这一抽象概念的 UI 元素都可以是 Button,而具体的样子完全可以通过 Style 和 Template 决定,checkbox 也不是因为有个 box 可以 check 才叫 checkbox。
布局控件:Grid、StackPanel、DockPanel、WarpPanel 等 Panel 的子类;
内容控件:只能容纳一个其他控件或布局控件作为它的内容。如 Window、Button 等 ContentControl 的子类;
带标题的内容控件:GroupBox、TabItem 等 HeaderedContentControl 的子类;
条目控件:显示一列数据,一般这列数据之间的类型一致;ListBox、ComboBox 等 ItemsControl 的子类;
带标题的条目控件:TreeViewItem、MenuItem 等 HeaderedContentControl 的子类;
特殊内容控件:TextBox、TextBlock、Image
graph LR
DependencyObject-->Dispatcher
Visual-->DependencyObject
UIElement-->Visual
FrameworkElement-->UIElement
Panel-->FrameworkElement
Control-->FrameworkElement
TextBlock-->FrameworkElement
Image-->FrameworkElement
ContentControl-->Control
HeaderedContentControl-->ContentControl
ItemsControl-->Control
HeaderedItemsControl-->ItemsControl
TextBox-->Control
可视树:因为 WPF 有Content 的概念,使控件与控件之间可以存在包含关系,以窗体为根,整个 WPF 的 UI 才形成树形结构。
不同控件的内容属性名称不一:Content、Child、Items、Children、Text;
Button.Content、StackPanel.Children、ListBox.Items。
内容属性:Content
常用:
Button、Window、Label、UserControl、
ListBoxItem、ListViewItem、ComboBoxItem、
RadioButton、ToggleButton、CheckBox、
ToolTip、ScrollViewer、ContentControl;
不常用:
ButtonBase、GroupItem、RepeatButton、StatusBarItem、NavigationWindow、Frame、GridViewColumnHeader
内容属性:Items 或 ItemsSource
每种 ItemsControl 都对应有自己的条目容器 Item Container,如 ListBox 的 Item Container 是 ListBoxItem,关键词:包装机制
常用:
ListBox、ListView、ComboBox、Menu、ContextMenu、ItemsControl、TabControl、TreeView、StatusBar
不常用:
MenuBase、Selector(ListBox、ComboBox、TabControl 等的父类)
ItemsContorl
Item Container
ComboBox
ComboBoxItem
ListBox
ListBoxItem
ListView
ListViewItem
TabControl
TabItem
Menu
MenuItem
ContextMenu
MenuItem
TreeView
TreeViewItem
StatusBar
StatusBarItem
内容属性:Items 或 ItemsSource、Header
常用:
MenuItem、TreeViewItem、ToolBar
内容属性: Child
起 UI 装饰作用
常用:
Border、ViewBox
不常用:
ButtonChrome、ListBoxChrome、BulletDecorator、InkPresenter、AdornerDecorator、ClassicBorderDecorator、SystemDropShadowChome
Path、Polygon、Polyline 等 Shape 子类;
Stroke 设置边线、Fill 设置填充;
无内容属性;
用于 2D 图形绘制。
Path:
起点命令 M,终点命令 Z(让头尾相连)
直线 L,水平直线 H,垂直直线 V,曲线 C、Q、S、T
椭圆 A
内容属性:Children
常用:
Grid、StackPanel、DockPanel、WrapPanel、Canvas
不常用:
UniformGrid(Grid 简化版,定义几行几列,每个单元格大小一致)、TabPanel、ToolBarOverflowPanel、ToolBarPanel、VirtualizingPanel、VirtualizingStackPanel
Grid 共享尺寸属性 SharedSizeGroup 运用:
1)将父级 Grid 的 Grid.IsSharedSizeScope 设置为 true;
2)两个 Grid 各自某一行或某一列的 SharedSizeGroup 设置为同一个字符串,那么这两行或这两列就可以共享空间。
<Grid x:Name="toolboxLayerGrid" Visibility="Collapsed">
<Grid.ColumnDefinitions>
<ColumnDefinition />
<ColumnDefinition Width="Auto" SharedSizeGroup="ToolboxGroup" />
</Grid.ColumnDefinitions><GridSplitter Grid.Column="1" Width="3" HorizontalAlignment="Left" />
<Grid x:Name="toolboxGrid" Grid.Column="1" Margin="3,0,0,0">
</Grid>
</Grid>
toolboxLayerGrid.Visibility = System.Windows.Visibility.Visible;
toolboxLayerGrid.SetValue(Grid.ZIndexProperty, 2);
layer0Grid.ColumnDefinitions.Add(new ColumnDefinition { SharedSizeGroup = "ToolboxGroup" });
Grid 宽高接受的尺寸单位:Pixel(像素,默认单位)、Inch(英寸=96 piexl)、Centimeter(厘米=96/2.54 pixel)、Point(=96/72 pixel)
如果把两个元素放在 Grid 的同一个单元格内,则后书写的元素将在先书写的元素之上,可以通过 Panel.ZIndex 值调整,值越大,越靠上。默认为 1.
手机扫一扫
移动阅读更方便
你可能感兴趣的文章