的背景
在.NET Windows窗体(2.0)中,单选按钮按容器控件自动分组,无论它是Form,Panel还是GroupBox.
这意味着当您选择一个单选按钮时,同一容器中的每个其他单选按钮都会自动更改为未选中状态.
现在,考虑以下表单布局:
MUST HAVE NICE TO HAVE DESCRIPTION --------- ------------ ----------------------------------------------- [ ] [ ] The gizmo works [ ] [ ] The gizmo works beautifully [ ] [ ] The gizmo works amazingly and makes you breakfast [ ] [ ] The gizmo comes with a pony
每个'[ ]'
都是一个单选按钮.
要求用户在第一列中选择所需的答案,并在第2列中选择可选的(最佳案例答案).
如您所见,单选按钮应按列分组:选择其中一个无线电应清除列的其余部分,但在另一列中应无效.
问题
基本上问题是这是一个动态生成的形式.
布局中的行数是动态的,它是从可配置的表单定义加载的.
描述文本直到运行时才知道,并且长度变化很大(有些可能只有几个单词,有些可能只有几十行).
布局无法重新设计.这是因为(非技术性)用户对该表格的纸质版本的熟悉程度已经使用了多年.这个表格也会打印出来,即使我在表单上更改了输入系统,这意味着要编写另一个版本,以便使用"旧"布局进行打印.
我尝试过但没有奏效
我首先尝试使用三个面板(每列一个)实现动态生成的布局,因此自动单选按钮分组可以正常工作.它确实如此.
但是与单选按钮和它的文本之间的水平对齐相关的布局问题正在扼杀我.直到运行时才会知道文本的大小,文本行可能会换行(有时每个项目会有几次).有时它会正确对齐,有时却不对齐.我即将开始调试这个,但我在想是否可能更改这个三面板实现是一个更好的选择.
我想做什么
我想通过使用TableLayoutPanel
三列来重新设计布局,以简化对齐相关的问题,但这意味着我不能使用自动单选按钮分组容器"功能".
编辑:
正如Gerrie建议的那样,其他布局选项是将每一行实现为用户控件并使用流布局面板.
这意味着,我可能想要使用控件进行布局,但不能使用单选按钮分组.
尽管使用水平用户控件,我仍需要获得垂直单选按钮组
/编辑
我想问的是什么
我需要有关如何手动控制单选按钮分组的指针和建议.RadioButton
如果需要,我真的不介意继承类.
具体来说,是否存在任何"规范"或已知的子类化'RadioButton'或者一直到Win32 API的方式,以便每次检查控件时(通过使用鼠标,键盘输入,空格键和任何其他方式)我无法知道选择它们)我可以捕获事件并手动更新表单上每个其他控件的状态,并且自动分组功能众所周知是"去激活"?我担心实现也与容器有关,我可能也被迫继承Panel?.
分组"魔术"如何在Windows窗体中运行?
我发现谷歌搜索实现自定义单选按钮组或"单选按钮列表"的每个解决方案都是以某种方式使用集合的容器.可以避免容器吗?如果是这样,怎么样?
我发现一个时间解决方案(读:凌乱的黑客)是我将每个单选按钮放在自己的小面板中.因此,任何一个之间都没有任何分组.我正在听每个按钮checked
事件并相应地更新相应的事件.
我仍然认为拥有那么多面板太过分了,如果有人有更清洁的解决方案,我很乐意听到它.
(好的,很抱歉回答我自己的问题.你知道,当你花时间解释一些事情时,你会开始看到问题,这是另一回事.)