我正在以编程方式为数组/列表中的每个元素创建单选按钮,并将它们放在窗体中。
现在每个新的单选按钮都放在前一个按钮下面。我怎样才能设法在例如4/5单选按钮?新列应显示在上一个单选按钮的右侧。
到目前为止,这是我的代码:
for (int i = 0; i < startShapes.Count; i++)
{
RadioButton rdb = new RadioButton();
rdb.Text = startShapes.Values.ElementAt(i).Equals("") ? startShapes.Keys.ElementAt(i) : startShapes.Values.ElementAt(i);
rdb.Size = new Size(100, 30);
this.Controls.Add(rdb);
rdb.Location = new Point(45, 70 + 35 * i);
rdb.CheckedChanged += (s, ee) =>
{
var r = s as RadioButton;
if (r.Checked)
this.selectedString = r.Text;
};
}
答案 0 :(得分:1)
如何使用TableLayoutPanel?
Dictionary<string, string> startShapes = new Dictionary<string, string>();
for(int i=0;i<20;i++)
startShapes.Add("Shape " +i, "Shape " +i);
int row = 0;
int col = 0;
tableLayoutPanel1.RowStyles.Clear();
tableLayoutPanel1.ColumnStyles.Clear();
tableLayoutPanel1.ColumnStyles.Add(new ColumnStyle(SizeType.AutoSize));
tableLayoutPanel1.RowCount= 0;
tableLayoutPanel1.ColumnCount = 1;
foreach (var kvp in startShapes)
{
tableLayoutPanel1.RowStyles.Add(new RowStyle(SizeType.AutoSize));
tableLayoutPanel1.RowCount++;
RadioButton rdb = new RadioButton();
rdb.Text = string.IsNullOrEmpty(kvp.Value) ? kvp.Key : kvp.Value;
rdb.Size = new Size(100, 30);
rdb.CheckedChanged += (s, ee) =>
{
var r = s as RadioButton;
if (r.Checked)
this.selectedString = r.Text;
};
tableLayoutPanel1.Controls.Add(rdb, col, row);
row++;
if (row == 5)
{
col++;
row = 0;
tableLayoutPanel1.ColumnStyles.Add(new ColumnStyle(SizeType.AutoSize));
tableLayoutPanel1.ColumnCount++;
}
}
如果你真的需要你的解决方案:
int left = 45;
int idx = 0;
for (int i = 0; i < startShapes.Count; i++)
{
RadioButton rdb = new RadioButton();
rdb.Text = startShapes.Values.ElementAt(i).Equals("") ? startShapes.Keys.ElementAt(i) : startShapes.Values.ElementAt(i);
rdb.Size = new Size(100, 30);
this.Controls.Add(rdb);
rdb.Location = new Point(left, 70 + 35 * idx++);
if (idx == 5)
{
idx = 0; // reset row
left += rdb.Width + 5; // move to next column
}
rdb.CheckedChanged += (s, ee) =>
{
var r = s as RadioButton;
if (r.Checked)
this.selectedString = r.Text;
};
}