根据下面的代码,我可以从我的SQL server表中收集我存储的图像,并在每个目录下放置一个CheckBox,目的是使用这些CheckBoxes来选择它们上面的图像,并使用另一个用户控件(即,用于从DB中删除它们或将它们复制到另一个目录的按钮).I尝试创建一个事件处理程序,但以我的c#知识水平无法实现。为了更好地理解,我恳请您提供解决方案和指导。
private void button4_Click(object sender, EventArgs e)
{
PictureBox[] pba = new PictureBox[100];
SqlConnection con4 = new SqlConnection(DBHandler.GetConnectionString());
SqlCommand cmd4 = new SqlCommand("ReadAllImage", con4);
cmd4.CommandType = CommandType.StoredProcedure;
SqlDataAdapter da2 = new SqlDataAdapter(cmd4);
DataSet dt2 = new DataSet("ImageData");
da2.SelectCommand = cmd4;
da2.Fill(dt2);
int a = comboBox1.Items.Count;
byte[] xdata = new byte[0];
CheckBox[] chckbx = new CheckBox[400];
for (var i = 0; i < a; i++)
{
DataRow myRow2 = null;
if (myRow2 == null)
{
myRow2 = dt2.Tables[0].Rows[i];
xdata = (byte[])myRow2["ImageData"];
MemoryStream stream2 = new MemoryStream(xdata);
PictureBox npb = new PictureBox();
npb.Size = new Size(60, 60);
int b = i / 5;
npb.Location = new Point(420 + (i % 5) * 70, 20 + (90 * b));
npb.Image = Image.FromStream(stream2);
npb.SizeMode = PictureBoxSizeMode.StretchImage;
pba[i] = npb;
this.Controls.Add(pba[i]);
CheckBox chckbxx = new CheckBox();
chckbxx.Location = new Point(420 + (i % 5) * 70, 80 + (90 * b));
chckbxx.AutoSize = true;
chckbx[i] = chckbxx;
this.Controls.Add(chckbx[i]);
}

我运行代码后的示例输出。我想使用如图所示的chekckboxes。实际上,我成功地创建了它们,但无法使它们与上面的图像相关。
发布于 2015-07-22 20:05:06
创建一个包含图像和复选框的自定义控件。那么两者始终是联系在一起的:逻辑上和编程上。
自定义控件示例:https://msdn.microsoft.com/en-us/library/ff723977%28v=expression.40%29.aspx
http://www.codeproject.com/Articles/2016/Writing-your-Custom-Control-step-by-step
https://stackoverflow.com/questions/31562478
复制相似问题