使用以下代码,我根据在组合框中选择的屏幕数量动态创建和显示图片框,如下图所示:
这似乎很好用,但是当我扩展应用程序大小时,问题就来了,然后图片框无法正确扩展,如下图所示:
扩大应用程序:
减小应用程序的大小:
private void CreatePictureBoxes(int num)
{
panelCameras.Controls.Clear();
int spacing = 2;
int numRows = (int)Math.Ceiling((double)num / 2);
int pbWidth = (panelCameras.ClientSize.Width - (3 * spacing)) / 2;
int pbHeight = (panelCameras.ClientSize.Height - ((numRows + 1) * spacing)) / numRows;
if (num == 1)
{
pbWidth = panelCameras.ClientSize.Width - (2 * spacing);
pbHeight = panelCameras.ClientSize.Height - (2 * spacing);
}
else if (num == 2)
{
pbWidth = (panelCameras.ClientSize.Width - (2 * spacing)) / 2;
pbHeight = panelCameras.ClientSize.Height - (2 * spacing);
}
for (int i = 0; i < num; i++)
{
PictureBox pb = new PictureBox();
pb.BackColor = Color.Black;
pb.SizeMode = PictureBoxSizeMode.StretchImage;
pb.Dock = DockStyle.None;
pb.Anchor = AnchorStyles.None;
pb.Location = new Point((i % 2) * (pbWidth + spacing) + spacing, (i / 2) * (pbHeight + spacing) + spacing);
Label lbl = new Label();
lbl.Text = (i + 1).ToString();
lbl.ForeColor = Color.White;
lbl.AutoSize = false;
lbl.Dock = DockStyle.Fill;
lbl.TextAlign = ContentAlignment.MiddleCenter;
pb.Controls.Add(lbl);
panelCameras.Controls.Add(pb);
pb.Size = new Size(pbWidth, pbHeight);
pb.Dock = DockStyle.None;
pb.Anchor = AnchorStyles.Top | AnchorStyles.Left | AnchorStyles.Right | AnchorStyles.Bottom;
}
}
解决此问题的最佳尝试是创建一个额外的方法来处理应用程序的扩展,并在
CreatePictureBoxes
方法结束时调用它:
private void pb_Resize(object sender, EventArgs e)
{
PictureBox? pb = sender as PictureBox ?? null;
if (pb != null)
{
int spacing = 10;
int numRows = (int)Math.Ceiling((double)panelCameras.Controls.Count / 2);
int pbWidth = (panelCameras.ClientSize.Width - (3 * spacing)) / 2;
int pbHeight = (panelCameras.ClientSize.Height - ((numRows + 1) * spacing)) / numRows;
if (panelCameras.Controls.Count == 1)
{
pbWidth = panelCameras.ClientSize.Width - (2 * spacing);
pbHeight = panelCameras.ClientSize.Height - (2 * spacing);
}
else if (panelCameras.Controls.Count == 2)
{
pbWidth = (panelCameras.ClientSize.Width - (2 * spacing)) / 2;
pbHeight = panelCameras.ClientSize.Height - (2 * spacing);
}
pb.Size = new Size(pbWidth, pbHeight);
pb.Location = new Point((pb.TabIndex % 2) * (pbWidth + spacing) + spacing, (pb.TabIndex / 2) * (pbHeight + spacing) + spacing);
}
}
这在某种程度上奏效了,但我相信会导致更多问题,我认为这不是一个好方法。
有人知道我如何处理与应用程序大小相关的图片框大小吗?
提前致谢!
我会把面板的创建和布局分开,像这样:
public Form1()
{
InitializeComponent();
// ...
panelCameras.Layout += panelCameras_Layout;
}
private void CreatePictureBoxes(int num)
{
panelCameras.Controls.Clear();
for (int i = 0; i < num; i++)
{
PictureBox pb = new PictureBox();
pb.BackColor = Color.Black;
pb.SizeMode = PictureBoxSizeMode.StretchImage;
pb.Dock = DockStyle.None;
pb.Anchor = AnchorStyles.None;
Label lbl = new Label();
lbl.Text = (i + 1).ToString();
lbl.ForeColor = Color.White;
lbl.AutoSize = false;
lbl.Dock = DockStyle.Fill;
lbl.TextAlign = ContentAlignment.MiddleCenter;
pb.Controls.Add(lbl);
panelCameras.Controls.Add(pb);
}
}
protected void panelCameras_Layout(object? sender, LayoutEventArgs levent)
{
var num = panelCameras.Controls.Count;
for (var i = 0; i < num; ++i)
{
int spacing = 2;
int numRows = (int)Math.Ceiling((double)num / 2);
int pbWidth = (panelCameras.ClientSize.Width - (3 * spacing)) / 2;
int pbHeight = (panelCameras.ClientSize.Height - ((numRows + 1) * spacing)) / numRows;
if (num == 1)
{
pbWidth = panelCameras.ClientSize.Width - (2 * spacing);
pbHeight = panelCameras.ClientSize.Height - (2 * spacing);
}
else if (num == 2)
{
pbWidth = (panelCameras.ClientSize.Width - (2 * spacing)) / 2;
pbHeight = panelCameras.ClientSize.Height - (2 * spacing);
}
var pb = panelCameras.Controls[i];
pb.Location = new Point((i % 2) * (pbWidth + spacing) + spacing, (i / 2) * (pbHeight + spacing) + spacing);
pb.Size = new Size(pbWidth, pbHeight);
}
}
请注意,我从 CreatePictureBoxes 中删除了设置大小和位置,并且还删除了更改锚点样式!