微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

RDLC加载动态图片和文本的方法

RDLC是。NET自带的报表工具,一般在水晶报表中完成的功能它都有了,而且比水晶报表好用,为什么这样说?因为有三点,第一,水晶报表的图像缩放非常麻烦,转个弯勉强可以解决,RDLC非常方便,第二,水晶报表的图像打印是有损的,如果追求图像质量,建议放弃CRY REPORT,选择RDLC,RDLC打印图片时无损,你可以这样测试,同一个图(BMP),用画图,水晶,CRY各打一张对比就知道了。第三,水晶报表无法打印8位灰度图,这个医学领域常用的格式CRY却显得无能为力,正常能选图的程序,就是选不了8位图,RDLC中可以。以下是VBNET及CSNET 中的动态图片及文本的方法

过程和方法VB和CS一样,代码不一样而已:

1。解决方案资源管理器中要有FORM1,Report1.rdlc(什么?没这个文件?也不知怎么加?晕,解决方案资源管理器,右键,添加,新建项,常用项,REPORTINT,报表(别选CRYSTAL报表,选它就是用水晶报表做了),添加,即有REPORT1.RDLC这个文件

2。双击REPORT1。RDLC文件,主菜单中选 报表,报表参数,按两次添加后参数列中分别添加了REPORT_ParaMETER_0,REPORT_ParaMETER_1这两个参数,点确定,

REPORT1。RDLC设计界面上双击文本框,双击图像,这样就增加了两个控件文件与图像,选文本框,属性中有项叫VALUE的,下拉箭头,表达式,在“=”号后面加上parameters!Report_Parameter_0.Value,图像框的表达式雷同,但参数为=parameters!Report_Parameter_1.Value

3。双击FORM1,看到界面后在工具列上加一个叫MicrosoftReportViewer的容器(通常位于报表列中),右上角即时弹出与RDLC关联的选择,请选择REPORT1.RDLC,双击MicrosoftReportViewer这控件添加代码

'''''VB代码

ReportViewer1.LocalReport.EnableExternalImages = True
Dim params(1) As ReportParameter
params(0) = New ReportParameter("Report_Parameter_0","file:///c:/qq.jpg")‘注意路径全部要用"/"代替"\",这个函数可以‘Replace ("c:\a\bc\123","\","/")不知OPENFILEDIALOG控件有无直接返回URL的路径的,有请告知我,QQ182226947,这样就不用函数转换了。

params(1) = New ReportParameter("Report_Parameter_1","aa")


Me.ReportViewer1.LocalReport.SetParameters(params)
Me.ReportViewer1.RefreshReport()

/////C#代码

reportViewer1.LocalReport.EnableExternalImages=true;
ReportParameter params1;
ReportParameter params2;
params1 = new ReportParameter("Report_Parameter_0","abc");//Report_Parameter_0这个是双击REPORT1。RDLC后在菜单,报表,报表参数中添加

params2=new ReportParameter("Report_Parameter_1","file:///c:/qq.jpg");//路径全部用”/“

reportViewer1.LocalReport.SetParameters(new ReportParameter[]{params1});
reportViewer1.LocalReport.SetParameters(new ReportParameter[]{params2});

以上代码均测试通过。你也可以下载我的代码形式的演示

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Format[$] ( expr [ , fmt ] ) format 返回变体型 format$ 强制返回为文本 -------------------------------- 数字类型的格式化 --------------------------------     固定格式参数:     General Number 普通数字,如可以用来去掉千位分隔号     format$("100,1
VB6或者ASP 格式化时间为 MM/dd/yyyy 格式,竟然没有好的办法, Format 或者FormatDateTime 竟然结果和系统设置的区域语言的日期和时间格式相关。意思是尽管你用诸如 Format(Now, "MM/dd/yyyy"),如果系统的设置格式区域语言的日期和时间格式分隔符是"-",那他还会显示为 MM-dd-yyyy     只有拼凑: <%response.write
在项目中添加如下代码:新建窗口来显示异常信息。 Namespace My ‘全局错误处理,新的解决方案直接添加本ApplicationEvents.vb 到工程即可 ‘添加后还需要一个From用来显示错误。如果到这步还不会则需要先打好基础啦 ‘======================================================== ‘以下事件
转了这一篇文章,原来一直想用C#做k3的插件开发,vb没有C#用的爽呀,这篇文章写与2011年,看来我以前没有认真去找这个方法呀。 https://blog.csdn.net/chzjxgd/article/details/6176325 金蝶K3 BOS的插件官方是用VB6编写的,如果  能用.Net下的语言工具开发BOS插件是一件很愉快的事情,其中缘由不言而喻,而本文则是个人首创,实现在了用V
Sub 分列() ‘以空格为分隔符,连续空格只算1个。对所选中的单元格进行处理 Dim m As Range, tmpStr As String, s As String Dim x As Integer, y As Integer, subStr As String If MsgBox("确定要分列处理吗?请确定分列的数据会覆盖它后面的单元格!", _
  窗体代码 1 Private Sub Text1_OLEDragDrop(Data As DataObject, Effect As Long, Button As Integer, Shift As Integer, X As Single, Y As Single) 2 Dim path As String, hash As String 3 For Each fil
  Imports MySql.Data.MySqlClient Public Class Form1 ‘ GLOBAL DECLARATIONS Dim conString As String = "Server=localhost;Database=net2;Uid=root;Pwd=123456;" Dim con As New MySqlConnection
‘導入命名空間 Imports ADODB Imports Microsoft.Office.Interop   Private Sub A1() Dim Sql As String Dim Cnn As New ADODB.Connection Dim Rs As New ADODB.Recordset Dim S As String   S = "Provider=OraOLEDB.Oracl
Imports System.IO Imports System.Threading Imports System.Diagnostics Public Class Form1 Dim A(254) As String    Function ping(ByVal IP As Integer) As String Dim IPAddress As String IPAddress = "10.0.
VB运行EXE程序,并等待其运行结束 参考:https://blog.csdn.net/useway/article/details/5494084 Private Declare Function WaitForSingleObject Lib "kernel32" (ByVal hHandle As Long, ByVal dwMilliseconds As Long) As Long Pr