彩票走势图

使用ActiveReports创建动态区段报表

原创|使用教程|编辑:郝浩|2013-08-07 09:37:57.000|阅读 345 次

概述:报表控件ActiveReports的最新7版本提供了更多更广泛的API,让Visual Basic和C#开发者可以完整掌控报表流程引擎,以适应各种复杂报表开发的需求。

# 慧都年终大促·界面/图表报表/文档/IDE等千款热门软控件火热促销中 >>

  报表控件ActiveReports的最新7版本提供了更多更广泛的API,让Visual Basic和C#开发者可以完整掌控报表流程引擎,以适应各种复杂报表开发的需求。

  它主要提供的事件和属性类型有:

  • 数据检索
  • 数据转换
  • 布局
  • 渲染

  完善的API意味着开发人员实现在运行时创建报表,一般的报表工具都将报表设计和报表分开运行扯淡,而ActiveReports却可以通过API实现运行时的报表创建,让一些报表的一些动态功能能够实现。接下来就以如何创建动态区段报表为例,说一下灵活运用API的方法。首先看一下最终创建报表的效果:

使用ActiveReports创建动态区段报表

  简单的说一下创建步骤:

  1. 创建一个报表实例
  2. 动态的添加区段和控件
  3. 修改报表区段和控件的相关细节
  4. 给报表指派设置数据源
  5. 将报表绑定到数据源

  下段代码就能完成所有步骤:

private void Form1_Load(object sender, EventArgs e)
{
   rpt = new SectionReport();
 
   //Adding Page Header/Footer sections
   rpt.Sections.InsertPageHF();
   rpt.Sections[0].BackColor = Color.LightGray;
 
   //Adding Detail section
   rpt.Sections.Insert(1, new Detail());
   rpt.Sections[1].BackColor = Color.PeachPuff;
   rpt.Sections[1].Height = 1.5f;
 
   //Adding label to display first column's name
   GrapeCity.ActiveReports.SectionReportModel.Label lblCategoryID = new GrapeCity.ActiveReports.SectionReportModel.Label();
   lblCategoryID.Location = new PointF(0, 0.05F);
   lblCategoryID.Text = "Category ID";
   lblCategoryID.Alignment = GrapeCity.ActiveReports.Document.Section.TextAlignment.Center;
   lblCategoryID.Font = new System.Drawing.Font("Arial", 10, FontStyle.Bold);
   rpt.Sections[0].Controls.Add(lblCategoryID);
 
   //Adding label to display second column's name
   GrapeCity.ActiveReports.SectionReportModel.Label lblCategoryName = new GrapeCity.ActiveReports.SectionReportModel.Label();
   lblCategoryName.Location = new PointF(1.459f, 0.05f);
   lblCategoryName.Size = new SizeF(1.094f,0.2f);
   lblCategoryName.Text = "Category Name";
   lblCategoryName.Font = new System.Drawing.Font("Arial", 10, FontStyle.Bold);
   rpt.Sections[0].Controls.Add(lblCategoryName);
 
   //Adding label to display third column's name
   GrapeCity.ActiveReports.SectionReportModel.Label lblDescription = new GrapeCity.ActiveReports.SectionReportModel.Label();
   lblDescription.Location = new PointF(3.114f, 0.05f);
   lblDescription.Text = "Description";
   lblDescription.Font = new System.Drawing.Font("Arial", 10, FontStyle.Bold);
   rpt.Sections[0].Controls.Add(lblDescription);
 
   //Adding label to display fourth column's name
   GrapeCity.ActiveReports.SectionReportModel.Label lblPicture = new GrapeCity.ActiveReports.SectionReportModel.Label();
   lblPicture.Location = new PointF(5.219f, 0.05f);
   lblPicture.Alignment = GrapeCity.ActiveReports.Document.Section.TextAlignment.Center;
   lblPicture.Text = "Picture";
   lblPicture.Font = new System.Drawing.Font("Arial", 10, FontStyle.Bold);
   rpt.Sections[0].Controls.Add(lblPicture);
 
   //Adding Textbox to display first column's records
   GrapeCity.ActiveReports.SectionReportModel.TextBox txtCategoryID = new GrapeCity.ActiveReports.SectionReportModel.TextBox();
   txtCategoryID.Location = new PointF(0,0);
   txtCategoryID.Alignment = GrapeCity.ActiveReports.Document.Section.TextAlignment.Center;
   rpt.Sections[1].Controls.Add(txtCategoryID);
 
   //Adding Textbox to display second column's records
   GrapeCity.ActiveReports.SectionReportModel.TextBox txtCategoryName = new GrapeCity.ActiveReports.SectionReportModel.TextBox();
   txtCategoryName.Location = new PointF(1.459f,0);
   rpt.Sections[1].Controls.Add(txtCategoryName);
 
   //Adding Textbox to display third column's records
   GrapeCity.ActiveReports.SectionReportModel.TextBox txtDescription = new GrapeCity.ActiveReports.SectionReportModel.TextBox();
   txtDescription.Location = new PointF(3.114f,0);
   rpt.Sections[1].Controls.Add(txtDescription);
 
   //Adding Picture control to display image
   GrapeCity.ActiveReports.SectionReportModel.Picture picture = new Picture();
   picture.Location = new PointF(5.219f,0);
   rpt.Sections[1].Controls.Add(picture);
 
   // Setting report's data source
   conn = new OleDbConnection(@"Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:\Users\stduser\Documents\ComponentOne Samples\ActiveReports Developer 7\Data\NWIND.mdb;Persist Security Info=False");
   System.Data.OleDb.OleDbCommand cmd = new System.Data.OleDb.OleDbCommand("SELECT * FROM Categories", conn);
   conn.Open();
   reader = cmd.ExecuteReader();
   rpt.DataSource = reader;
 
   // Assigning DataField properties of controls in the detail section
   txtCategoryID.DataField = "CategoryID";
   txtCategoryName.DataField = "CategoryName";
   txtDescription.DataField = "Description";
   picture.DataField = "Picture";
   reader.Close();
   conn.Close();
}

标签:

本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@capbkgr.cn

文章转载自:慧都控件网

为你推荐

  • 推荐视频
  • 推荐活动
  • 推荐产品
  • 推荐文章
  • 慧都慧问
扫码咨询


添加微信 立即咨询

电话咨询

客服热线
023-68661681

TOP