昨天发表了Devexpress XtraReports系列第六篇[原创]Devexpress XtraReports 系列 6 创建并排报表,今天我们继续。

今天的主题是创建Drill-Down报表。

首先我们来看看最后实现的效果。Demo最后附上。点击隐藏明细,会把明细收缩,点击显示明细会把明细显示出来。

接下来开始讲解如何一步一步做出这个报表:

第一步,创建如上窗体,拉入控件SimpleButton,DocumentViewer,SplitContainerControl,LabelControl,TextEdit,GroupControl,简单布局我就不多说了,跟上篇一样的布局 ,详见:http://www.cnblogs.com/lhmlyx2723356/p/3286101.html

提示一点:DocumentViewer控件一开始是没有打印工具栏的,以前12.几的版本,添加打印工具栏是拖入PrintSystem控件,但是13.1.5我发现没有了,后来在官网找到了答案。控件12.几的控件PrintControl, PringBarManager, PrintRibbonController都集成到了DocumentViewer ,详情请参考http://www.devexpress.com/Support/Center/Question/Details/Q504260

那13.1.5如何添加打印工具栏呢?如图:选中DocumentViewer控件右上角的三角符号,点击红色区域中的其中一项都可以创建打印工具栏。

第二步,创建一个DrillDown报表文件。如图:

第三步,我们利用数据库做一张简单的表并输入一些测试值。如图:

第四步,数据库表,布局都做好了,接下来我们就来处理相对应的事件了。输入文本框的值,点击按钮把查询出来的数据源绑定到报表中

a,修改报表文件的构造函数,让它在实例化的时候可以接收数据源。

public DrillDrownRpt(DataSet ds)//修改构造函数 {
    InitializeComponent();
    Bind(ds);
}

private void Bind(DataSet ds)
{
    this.DataSource = ds;
    this.DataMember = "Dept";
    DetailReport.DataMember = "RelationColumn";
    DetailReport.DataSource = ds;

//把dept_id属性绑定到lblShowHide的Tag属性,当点击lblShowHide(显示明细/隐藏明细是)时,可以根据dept_id去判断显示隐藏明细情况。
    this.lblShowHide.DataBindings.Add("Tag", ds, "Dept.dept_id");

this.xrLabel3.DataBindings.Add("Text", ds, "Dept.dept_name");
    this.xrTableCell1.DataBindings.Add("Text", ds, "RelationColumn.user_id");
    this.xrTableCell2.DataBindings.Add("Text", ds, "RelationColumn.username");
}

const string sShowDetail = "显示明细";
const string sHideDetail = "隐藏明细";
ArrayList expandedValues = new ArrayList();

//判断是否存在部门ID

bool ShouldShowDetail(int catID)
{
    return expandedValues.Contains(catID);
}

//根据lblShowHide的Tag属性去判断lblShowHide显示文本是显示明细还是隐藏明细

private void lblShowHide_BeforePrint(object sender, System.Drawing.Printing.PrintEventArgs e)
{
    XRLabel label = (XRLabel)sender;

//(int)label.Tag返回的是dept_id,调用ShouldShowDetail 方法,如果true则让lblShowHide显示隐藏明细。反之,显示显示明细

if (ShouldShowDetail((int)label.Tag))

{
        label.Text = sHideDetail;
    }
    else
    {
        label.Text = sShowDetail;
    }
}

private void DetailReport_BeforePrint(object sender, System.Drawing.Printing.PrintEventArgs e)
{
    e.Cancel = !ShouldShowDetail((int)GetCurrentColumnValue("dept_id"));
}

//鼠标移动到lblShowHide时,鼠标样式变成手形

private void lblShowHide_PreviewMouseMove(object sender, PreviewMouseEventArgs e)
{
    Cursor.Current = Cursors.Hand;
}

private void lblShowHide_PreviewClick(object sender, PreviewMouseEventArgs e)
{
    int index = (int)e.Brick.Value;
    bool showDetail = ShouldShowDetail(index);
    if (showDetail)
    {
        expandedValues.Remove(index);
    }
    else
    {
        expandedValues.Add(index);
    }
    CreateDocument();
}

b,获取数据源

private DataSet BindRpt()
      {
          DataSet ds = new DataSet();
          try
          {
              //连接数据源,给DrillDrownRpt绑定数据源,包含两个数据表
              SqlConnection con = new SqlConnection("Data Source=(local);Integrated Security=SSPI;Initial Catalog=DxReports");
              SqlDataAdapter adapter;
              con.Open();
              adapter = new SqlDataAdapter("SELECT * FROM Dept", con);
              adapter.Fill(ds, "Dept");
              adapter = new SqlDataAdapter("select  * from  Users", con);
              adapter.Fill(ds, "User");
              con.Close();

//给数据集建立主外键关系
              DataColumn ParentColumn = ds.Tables["Dept"].Columns["dept_id"];
              DataColumn ChildColumn = ds.Tables["User"].Columns["dept_id"];
              DataRelation Rel = new DataRelation("RelationColumn", ParentColumn, ChildColumn);
              ds.Relations.Add(Rel);
          }
          catch (Exception ex)
          {
              throw ex;
          }
          return ds;
      }

c,单击按钮,绑定数据到报表中

private void btnShowReport_Click(object sender, EventArgs e)
{
    DataSet ds = BindRpt();
    DrillDrownRpt Rpt = new DrillDrownRpt(ds);
    this.documentViewer1.DocumentSource = Rpt;
    Rpt.CreateDocument();
}

到此,报表就向下钻取报表就完成了。

希望对初学者有点帮助。谢谢。

Demo地址:http://yunpan.cn/QXzZnfJVPHQ7I  访问密码 4a86

最新文章

  1. 使用sql server 链接服务器
  2. UIKit框架之UIGestureRecognizer
  3. easyUI-combotree的本地数据导入
  4. iBatis.net入门指南
  5. BZOJ-1834 网络扩容 最小费用最大流+最大流+乱搞
  6. 用 Java 实现断点续传 (HTTP)
  7. Excel导入数据(97--2003版本)的ExcelHelper
  8. ToString函数用法
  9. 百度背景画面切换效果,js做
  10. Web 应用性能提升 10 倍的 10 个建议
  11. 启动tomcat的时候,服务器暂停到装载mysql驱动文件的原因
  12. .NET 并行(多核)编程系列之五 Task执行和异常处理
  13. css代码初始化
  14. android使用百度地图最新sdk5.0后后代码混淆时,地图无法显示闪退问题
  15. PL/SQl编程 基本语法
  16. css的简单学习笔记
  17. servlet生命周期和工作原理
  18. ftp服务器搭建流程详解
  19. notepad++查看二进制文件
  20. C#Winfrom数据库读取日期(年月日格式转换)

热门文章

  1. Cocos2d-x 开发手记
  2. 51nod1406 与查询
  3. Codeforces 475 B Strongly Connected City【DFS】
  4. IOS中UICollectionView和UICollectionViewController的用法
  5. POJ 2395 Out of Hay 草荒 (MST,Kruscal,最小瓶颈树)
  6. HDU 5340 Three Palindromes (Manacher)
  7. Google Code Pretiffy 代码 着色 高亮 开源 javascript(JS)库
  8. php 二维数组的排序
  9. LA 2995 Image Is Everything 立方体成像 World Final 2004
  10. Error accessing PRODUCT_USER_PROFILE