WPF 自定义容器控件的布局

看项目代码的时候遇到的一种界面设计,关于自定义容器控件和附加属性的,之前没遇到过。

看下面这段Xaml代码:

每一个ListBox里面有一个附加属性:

其中ui:Form是我的自定义容器控件:

cs 复制代码
 public class Form : ItemsControl
 {
     static Form()
     {
         DefaultStyleKeyProperty.OverrideMetadata(typeof(Form), new FrameworkPropertyMetadata(typeof(Form)));
         IsTabStopProperty.OverrideMetadata(typeof(Form), new FrameworkPropertyMetadata(false));
     }
     //确定Item是否是(或者是否可以作为)其自己的Container
     protected override bool IsItemItsOwnContainerOverride(object item)
     {
         return item is FormItem || item is FormHeader || item is Form;
     }

     //用于返回Item的Container
     //即如果Item的类型不是FormItem,就将它作使用FormItem包装起来
     protected override DependencyObject GetContainerForItemOverride()
     {
         return new FormItem();
     }
 }

界面效果是下面这样:

红色框起来的是LIstBox,黄色框的是Label。

我很疑惑这些Label控件是怎么来的。

经过我的寻找:

我发现这种样式是针对FormItem的,FormItem也是自定义的控件,并且在自定义容器控件Form中有涉及到:

cs 复制代码
protected override DependencyObject GetContainerForItemOverride()
{
         return new FormItem();
}

查阅了相关资料,明白了其中缘由:

如果ItemsControl的Items内容不是对应的子元素控件,ItemsControl会创建对应的子元素控件作为容器再把Item放进去

上面GetContainerForItemOverride的作用就是在ListBox和TextBox外包裹一个FormItem控件;

也可以理解为虽然在Xaml中代码没有写上FormItem控件,但是在容器控件CS代码中有写;

在界面的视觉树中可以体现:

结构与FormItem定义的样式相同。

相关推荐
逆境不可逃2 小时前
深入理解 SingleFlight:从单机到分布式的请求合并方案全解析
分布式·wpf
TDengine (老段)3 小时前
TDengine 逻辑计划生成 — 从 AST 到关系代数算子树
大数据·数据库·物联网·wpf·时序数据库·tdengine·涛思数据
小二·1 天前
微服务架构设计与实践
微服务·架构·wpf
暖馒1 天前
WPF-Prism学习入门步骤记录
学习·wpf
baivfhpwxf20231 天前
雷赛(Leadshine)EtherCAT 数字 I/O 模块(如 EMC-E5064-8)的状态指示灯(I/O 状态)说明
c#·wpf
故渊at2 天前
第二板块:Android 四大组件标准化学理 | 第十二篇:四大组件全景总结与系统服务(System Server)架构
android·架构·wpf·四大组件·system service
伶俜662 天前
# [特殊字符] 零基础学 ArkUI 数据持久化(专题三):5 种存储方案深度对比
学习·华为·wpf·harmonyos
IT策士2 天前
Redis 从入门到精通:数据结构String 与键管理
数据结构·redis·wpf
AC赳赳老秦2 天前
技术文章素材收集自动化:用 OpenClaw 自动爬取行业资讯、技术热点、优质文章
运维·开发语言·python·自动化·wpf·deepseek·openclaw