我是RDLC报告功能的新手,我希望从SQL数据库中的产品数据生成标签。当用户打开此产品/部件时,他们会看到相关信息。当用户单击一个按钮时,这将打开报告,该报告将把参数传递给报告以生成标签。

Dim myparam As ReportParameter
Dim testParameter As New List(Of ReportParameter)
myparam = New ReportParameter("PartID", "Test")
testParameter.Add(myparam)
myparam = New ReportParameter("MRPID", "Test MRP")
testParameter.Add(myparam)
myparam = New ReportParameter("PartName", "Test Name")
testParameter.Add(myparam)
ReportViewer1.LocalReport.SetParameters(testParameter)
Dim writer As New BarcodeWriter
writer.Format = BarcodeFormat.CODE_128
PictureBox1.Image = writer.Write(MRPID)
Me.ReportViewer1.RefreshReport()正如您所看到的,我正在使用XLing生成我的条形码,我已经成功地使用了上面看到的3行代码。但是,我不知道如何传递这个参数,或者在运行时在报告中生成这个参数。条形码将从MRPID ie(TV001232)生成。我知道这部分是错误的"writer.Write( MRPID )“,但我将参数值替换为MRPID,这样您就可以理解我想要实现的是什么。
发布于 2020-06-17 17:10:21
首先使用以下命令将您的图像转换为Base64字符串:
Public Function ImageToBase64(ByVal image As Image, ByVal format As System.Drawing.Imaging.ImageFormat) As String
Dim base64String As String = ""
Using ms As New System.IO.MemoryStream()
image.Save(ms, format)
Dim imageBytes As Byte() = ms.ToArray()
base64String = Convert.ToBase64String(imageBytes)
End Using
Return base64String
End Function所以这就是:
myparam = New ReportParameter("MRPID", "Test MRP")
testParameter.Add(myparam)应该是这样的:
Dim writer As New BarcodeWriter
writer.Format = BarcodeFormat.CODE_128
myparam = New ReportParameter("MRPID", ImageToBase64(writer.Write(MRPID),<THE IMAGE FORMAT OF YOUR IMAGE>))
testParameter.Add(myparam)然后,在您的报告中设置以下内容:
MIMEType = select the correct MIME type from the dropdown list
Source = Database
Value = <Expression>在表达式窗口中:
=System.Convert.FromBase64String(Parameters!MRPID.Value)https://stackoverflow.com/questions/62410268
复制相似问题