在报表中显示图片有几种方式,第一种是:这个图片是个固定的(图片文件或者资源),例如,用其作为一个背景、标题、Logo之类;第二种是:保存在数据库中或者通过程序生成的一个内存中的图片,这个也叫动态图片,每次显示的内容是不同的,例如我们要显示一个字段的条形码图形。
因为第一种是很好实现,直接在【报表】->【潜入图像】中潜入进去,然后在要显示的图像框的Value属性中选择你潜入的图像名就可以了。具体方法可以网上查询。第二种关于动态图像的相对复杂一些。这里就以条形码为例,假如数据库中一个字段A,接着要绘出A的Code128码。首先需要Code128 码的编码规则绘制一个Code128码的Bitmap资源对象出来,当然该对象也可以直接通过.NET方法绘制出来。可以要在rdlc报表上绘制出来,就需要做一下转换。
首先,把Bitmap对象转化为字节数组。
private byte[] bmpToBytes(Bitmap bitmap)
{
MemoryStream ms = null;
try
{
ms = new MemoryStream();
Bitmap.Save(ms, ImageFormat.Bmp);
byte[] byteImage = new Byte[ms.Length];
byteImage = ms.ToArray();
return byteImage;
}
catch (ArgumentNullException ex)
{
throw ex;
}
finally
{
ms.Close();
}
}
然后把上面方法返回的字节数组转码成Base64类型的字符串。转化后放入到报表的数据集中。代码如下:
byte[] imgBytes = bmpToBytes(bmp);//(此为上述方法,bmp为实现绘制好的Bitmap对象或通过别的方式转化为来的Bitmap对象)
string strB64 = Convert.ToBase64String(imgBytes);
ReportParameter rpTest = new ReportParameter("RPTest", strB64);//(rpTest为定义的报表参数变量,RPTest为在【报表】->【报表参数】中添加的参数。
this.reportViewer1.LocalReport.SetParameters(new ReportParameter[] {rpTest});//设置本地报表参数属性,reportViewer1为报表控件。
在报表rdlc中。在报表主体中拖放一个image控件。设置其Source为database,value=System.Convert.FromBase64String(Parameters!RPTest.Value)// 关键之处。