ActiveReports 7中提供了两种报表类型SectionReport和PageReport,在PageReport中提供了Table等控件可以非常方便地对报表中数据进行排序操作,不过在SectionReport中没有提供这种支持排序的控件,下面我们就来看看在SectionReport中如何实现数据的排序操作。
在SectionReport中实现数据排序,主要是借助TextBox的HyperLink属性,以及Viewer控件的HyperLink事件。
首先创建我们需要的报表,在VS中添加新项目,选择【ActiveReports 7 Section Report(code-based)】
如何在报表的设计界面添加三列数据,在三个列头的右边分别添加一个TextBox控件,并设置HyperLink属性
然后添加报表ReportStart事件的处理逻辑:
- private void SectionReport1_ReportStart(object sender, EventArgs e)
- {
- OleDBDataSource ds = new OleDBDataSource();
- ds.ConnectionString = @"Provider=Microsoft.Jet.OLEDB.4.0;Data Source=App_Data\\Reels.mdb;Persist Security Info=False";
- ds.SQL = "SELECT * FROM Product order by " + Column + " " + Sort;
- ((TextBox)pageHeader.Controls["txt" + Column + "Sort"]).Text = (Sort == "Asc") ? "▲" : "▼";
- ((TextBox)pageHeader.Controls["txt" + Column + "Sort"]).HyperLink = Column + ":" + Sort;
- this.DataSource = ds;
- }
复制代码
在Form1上添加ActiveReports 7的报表浏览控件Viewer,并添加Viewer的HyperLink事件处理逻辑:
- private void viewer1_HyperLink(object sender, GrapeCity.ActiveReports.Viewer.Win.HyperLinkEventArgs e)
- {
- SectionReport1 rpt = new SectionReport1();
- rpt.Column = e.HyperLink.Split(':')[0];
- rpt.Sort = (e.HyperLink.Split(':')[1] == "Asc") ? "Desc" : "Asc";
- rpt.Run();
- viewer1.LoadDocument(rpt.Document);
- }
复制代码
运行程序,点击各列中的排序按钮:
源码下载:VS2010 + ActiveReports 7
|