保持按钮不可见,直到单击RadioButton c#
本文关键字:单击 RadioButton 按钮 | 更新日期: 2023-09-27 18:28:21
我试图强迫用户在被允许移动下一个之前选择一个拉比按钮。我让"下一步"按钮不可见,但我有大约10个单选按钮,如果其中任何一个被选中,都必须进行验证。根据定义,只能选中一个单选按钮。我的代码看起来像这样:
b1.Text = "Next";
b1.Parent = fpn1;
fpn1.Controls.Add(b1);
b1.Dock = DockStyle.Bottom;
b1.BackColor = Color.LightGray;
b1.Visible = false;
RadioButton rb;
while (b1.Visible == false)
{
MessageBox.Show("LOOOL");
//Thread.Sleep(5000);
rb = fpn1.Controls.OfType<RadioButton>()
.FirstOrDefault(r => r.Checked);
if (rb != null)
{
b1.Visible = true;
}
}
因此,当我的单选按钮都没有被点击时,b1是不可见的。问题是…这将进入一个无限循环。用户甚至不能再选择任何按钮,因为页面无法加载。有四处走走的想法吗?
我还能做些什么来获得想要的结果?
无限循环非常擅长阻止应用程序执行任何操作。从本质上讲,你是在逆向思考。你在想:
保持按钮不可见,直到出现问题。
为什么?一旦你让按钮不可见,它就会一直保持这种状态,直到你改变它。所以,相反,你可以这样想:
当发生事件时,使按钮可见。
在这种情况下,"发生了一些事情"是用户更改单选按钮的值。所以你想要一个事件的处理程序:
private void radioButton_CheckedChanged(Object sender, EventArgs e)
{
// your logic here
}
您可以使用表单设计器将此函数分配给各种单选按钮的所有CheckedChanged
事件,因此它们都使用相同的处理程序。
那么"你的逻辑"是什么呢?好吧,真的,这取决于你。听起来你想等到选择了几个不同的单选按钮分组?所以你可以在此基础上构建一些条件。在高层,语义上看起来是这样的:
if (allRadioButtonsSelected())
b1.Visible = true;
如果你的代码行符合你的要求:
rb = fpn1.Controls.OfType<RadioButton>().FirstOrDefault(r => r.Checked)
那么你甚至可以使用
if (fpn1.Controls.OfType<RadioButton>().FirstOrDefault(r => r.Checked) != null)
b1.Visible = true;
虽然它并不是完全听起来像是你想要的,因为它会告诉你是否只选中了一个单选按钮。但我可能在这方面误解了你,所以这取决于你。
关键是,在检查是否发生了什么事情时,不要一直循环和阻塞线程。因为当你阻塞线程时,它永远不会发生。相反,使用事件处理程序在事件发生时对其作出响应。
您阻塞了线程,这就是它没有加载的原因。我看不出为什么你需要一个循环,因为当用户点击单选按钮时,你可以引发一个事件。然后在处理事件时,将可见性设置为true。