FastReport自定义数据源及ListView控件的使用
##1、想批量生成一堆物资信息卡,效果如下图所示,fastreport可以一下全部生成,并且发现不用单独写东西,
##2、发现FastReport官方给出的Demo.exe很友好,基本可以满足要求,想尝试修改tree树,直接加载自定义的报表,通过ILSpy查看Demo源码,发现tree的数据源是Demos\Reports\reports.xml,修改reports.xml,基本满足要求,不用再动手开发
-
<?xml version="1.0" encoding="utf-8"?> <Reports> <FolderName="Definition"> <ReportFile="wz_barcode_one.frx"/> <ReportFile="wz_barcode_all.frx"/> </Folder> <FolderName="General"> <ReportFile="Simple List.frx"/>
##3、想继续完善,做的友好点,实现如下效果,用ListView显示数据,根据用户选择,在打印数据,发现了两个难点
###3.1 自定义用户数据源的问题,网上百般查找和测试都无用,官方文档、Demo也一一看了,可能在软件中能实现,直接通过FastRepost来自定义数据源吗,真是难。后来在官网上终于发现了有这个一个 FRNetProgrammerManual-en.pdf 这个文档中 看到一个 Passing custom SQL的功能,最终经过测试,代码如下,做报表,只要能自定义数据源,我想一切都不是问题了。
-
try{ TableDataSource dts =Report.GetDataSource("####")asTableDataSource; dts.SelectCommand="SELECT * FROM ### where WZID in ("+ss+")"; // MessageBox.Show(dts.SelectCommand.ToString()); dts.Init(); //不能少 关键 } catch(Exception ee){ MessageBox.Show(ee.Message.ToString()); return; }
###3.2 关于ListView的使用,TextBox,grid,ComboBox,DataSelector都试了一遍,发现这些控件都是FastReport自带的过滤控件只要绑定数据列,就能实现过滤,唯独ListView没这功能,也是各种测试都无果,后来只要定义了两个数据源,一个数据源用来绑定ListView,一个用来绑定报表,至于绑定绑定报表的功能在这就起到数据字段的功能,最后通过自定义sql来决定数据源。
###3.3 关于ListView的使用 不知道Fastreport是不是抽风,控件的click事件均能生成和保存,但是其他事件比如ItemChecked,初始的时候设置了,结果运行一次之后,事件值被自动清空了,不知道什么原因,后来通过Form1_Load,强制注册可解决
-
privatevoidForm1_Load(object sender,EventArgs e){ lv_BaseWZinfo.ItemChecked+= lv_BaseWZinfo_ItemChecked
###3.4 关于控件的DialogResult值的问题,发现只有设置为Ok时,才能在点击button时跳转至报表,如果设置为None,click事件会触发,但不会显示报表,设置为OK,不选择任何东西也会跳转至报表,最后折中通过默认将button的DialogResult设置为None,发生选中时触发为OK
-
privatevoid lv_BaseWZinfo_ItemChecked(object sender,ItemCheckedEventArgs e) { if(e.Item.Checked){ btnOk.DialogResult=DialogResult.OK; } }
###3.5 有想进一步改造Demo的可以通过ILSpy反编译一下,进行修改