ActiveReports 9实战教程(3): 图文并茂的报表形式

基于上面2节内容,我们搭建了AR9的开发环境,配置好了数据源。在本节,我们以官方提供的3个中文图文并茂的报表来展示AR9的功能,并通过实战的方式一一分享。

以往做报表相关的工作时,最害怕的是报表的UI设计工作,当遇到一个布局非常复杂的报表,往往会花上两、三时间才能完成报表的UI设计工作。造成这一问题的原因除了报表本身比较复杂之外,其中一个主要原因就是报表设计器没有提供足够多的功能来辅助报表的UI设计工作。
      ActiveReports 是一个非常容易使用控件,可有一些功能却经常被遗忘---例如AR报表的配置菜单。

当我们打开ActiveReports报表设计画面时(如双击*.rdl、*.rpx、*.rdlx),我们最关心的可能是工具箱和属性窗口,而没有注意到VS菜单栏上面的 报表菜单选项,报表菜单总共有6个菜单项,保存报表报表报表到服务器加载报表从服务器加载报表数据源设置等。接下来就主要谈一谈设置菜单项。

1、可选的标尺单位

ActiveReports提供了Inches(英寸)和Centimeters(厘米)两种标尺单位,我们可以根据自己的需要来选择适合于自己的标尺单位,从而省去了繁琐的长度换算工作。(备注:默认单位是英寸)

2、可选的对齐方式

ActiveReports 提供了SnapLines(按边线对齐)和Snap to Grid(按表格对齐)两种对齐方式。当选择SnapLines时,可以根据对齐辅助线来判断控件之间的相对位置关系;当选择Snap to Grid时,通过鼠标移动控件的最小单位是一个单元格的距离,而且可以根据单元格的数量来判断控件的正确位置。

3、可选的网格间距

当选择Show Grid(显示网格)时,在报表的设计视图中会显示网格,而且网格数量是可以调整的。选择合适的标尺单位和网格数量能为我们判断空间的位置带来便利,比如:标尺单位选择Centimeters(厘米),网格数量设置为10*10,此时相邻网格之间的距离恰好是1mm。

了解报表布局后,下面我们通过3个官方提供的demo进行实战操练。

报表实战1:常规报表--数据清单--客户清单

本实例,通过组合使用AR报表的Lable、TextBox控件,来实现表格展现客户数据。

Step 1: 新建一个 rptCustomerList.rpx 报表文件

Step 2: 新建数据源

Step 3:设计PageHeader(报表头)

依次拖入AR9的Label控件,修改显示的文字、并调整背景色。

在Pageheader左上角,添加TextBox,按照下面截图修改汇总算法--可实现对当前页面用户信息进行汇总。

 

Step 4 设计Detail(报表数据区域)

设计Detail区域,可通过Step 3的办法,从AR9工具箱拖入TextBox控件,修改DataField字段内容。

这里我们使用一个AR报表设计的小技巧直接从报表资源管理器中选择字段拖入Detail区域

Step 5 设计PageFooter区域

至此,我们通过上面的实战步骤,完成了客户清单报表。

小技巧:通过报表设计器下面的设计器、脚本、预览可方便的实现报表设计、预览效果,效率非常高。

快速验证一下效果吧:

怎么和官网的不一样呢?

呵呵,请在脚本中添加如下脚本,用于修改行变色:

int RowNo = 0;
public void detail_Format()
{
    if ((RowNo % 2) == 1)
    {
        this.detail.BackColor = Color.Gainsboro;
    }
    else
    {
        this.detail.BackColor = Color.Transparent;
    }

    RowNo++;
}

public void ActiveReport_ReportStart()
{
    rpt.Document.Printer.PrinterName = "";
}

报表实战2:常规报表--图表报表--常规图表

本实例中,通过用报表控件Chart展示图表数据,更直观。

Step 1:新建rptSalesByRegion.rdlx报表

Step 2:新建数据源

Step 3:添加Chart报表控件

选择显示为柱形图--堆积图,通过选中Chart后再单击属性对话框。

Step 4: 填充Chart数据

还可以通过选择Chart后,单击图表数据进行修改:序列(系列)、类别分组、序列分组数据填充操作。

在这个例子中,我们分别按照如下数据进行操作:

  • 拖动“销售量”到序列数据区域
  • 拖动“类别名称”到X轴数据区域
  • 拖动“货主地区”到序列分组区域

Step 5: 预览运行效果

报表实战3:常规报表--条形码--国航机票

在这个实例中,我们通过条形码和AR9新出的圆角设计进行一个类似国航机票的报表实战。

Step 1:新建 rptFlightBarcode.rdlx 报表和数据源

添加报表、数据源,请参加本文的第1个例子,用到的数据源SQL:

select 航班信息.* from 航班信息 order by ID;

Step 2:设计报表的背景图

添加一个嵌入式的图像

添加Image报表控件,并设置国航机票的背景图片。

Step 3:添加条形码

上面添加了Image控件后,我们来添加条形码控件。

配置条形码属性

  • LayerName:设置为Layer1。我们为了方便管理,数据控件统一放在Layer1层。
  • Symbology:设置为Ansi39类型条形码。
  • Value:         设置条形码数据,可指定当前机票的ID号。

备注: ActiveReports 提供的Barcode控件支持37种条码格式,其中包括:Code39码、Code25码、ITF25码、Matrix25码、UPC-A码、UPC-E码、EAN-13码、EAN-8码等一维条码和PDF417等二维条码。

Step 4:添加数据区域

添加完背景图片、条形码后,开始拖动数据字段填充乘客、出发点等数据信息。

有时候设计报表,在多个层之间控制非常不方便,明明选中了,但是报表就是无法编辑数据。

这里给大家分享一个AR9新增的小技巧:在AR报表中,多个图层直接切换可见性、是否选中,请通过在VS工具栏空白处单击右键,选择ActiveReports 9:

然后激活图层管理---层列表 V9:

Step 5: 运行完整的demo效果:

官方提供的完整demo和中文数据库文件下载地址

为了方便共享和交流,还可通过[email protected]进行Watch。

时间: 2024-08-27 18:28:06

ActiveReports 9实战教程(3): 图文并茂的报表形式的相关文章

ActiveReports 9实战教程(1): 手把手搭建好开发环境Visual Studio 2013 社区版

ActiveReports9刚刚公布3天.微软就公布了 Visual Studio Community 2013 开发环境. Visual Studio Community 2013 提供完整功能的 IDE ,可开发 Windows.Android 和 iOS 应用.支持:C++, Python, HTML5, JavaScript, 和 C#,VB, F# 语言的开发.提供设计器.编辑器.调试器和诊断工具. 最牛逼的在于你全然能够免费使用该工具: 能够正大光明的免费使用visual studi

ActiveReports 9实战教程(2): 准备数据源(设计时、运行时)

在上讲中<ActiveReports 9实战教程(1): 手把手搭建环境Visual Studio 2013 社区版>,我们已经结合Visual Studio 2013搭建好了ActiveReports 9的开发环境,并完成了一个Hello World的RDL报表. 在本文,我们通过配置数据源进行报表实战,做过报表开发的报表达人知道,报表中的数据源分设计时数据源和运行时数据源. 如何理解呢? 这2类数据源,表结构是一样的,用途不一样: 1 设计时数据源,用于研发内部.报表小组进行配置.测试报表

ActiveReports 9实战教程(1): 手把手搭建环境Visual Studio 2013 社区版

ActiveReports 9刚刚发布3天,微软就发布了 Visual Studio Community 2013 开发环境. Visual Studio Community 2013 提供完整功能的 IDE ,可开发 Windows.Android 和 iOS 应用.支持:C++, Python, HTML5, JavaScript, 和 C#,VB, F# 语言的开发,提供设计器.编辑器.调试器和诊断工具. 最牛逼的在于你完全可以免费使用该工具: 可以正大光明的免费使用visual stud

ActiveReports 9实战教程(1): 手把手搭建环境Visual Studio 2013

ActiveReports 9刚刚发布3天,微软就发布了 Visual Studio Community 2013 开发环境. Visual Studio Community 2013 提供完整功能的 IDE ,可开发 Windows.Android 和 iOS 应用.支持:C++, Python, HTML5, JavaScript, 和 C#,VB, F# 语言的开发,提供设计器.编辑器.调试器和诊断工具. 最牛逼的在于你完全可以免费使用该工具: 可以正大光明的免费使用visual stud

ActiveReports 报表应用教程 (2)---清单类报表

原文:ActiveReports 报表应用教程 (2)---清单类报表 在大多报表系统中都有清单类报表的身影,比如:客户清单.商品信息清单.设备清单.物品采购清单.记账凭证.货品发货清单.员工清单等等.清单类报表看视乎比较简单,但是,由清单类报表演变而来的报表类型却十分丰富,在清单类报表中可以加入数据统计.数据分栏.数据分组,以及交互式报表和数据可视化功能. 本文将展示两种布局的清单类报表,表格式清单报表和自由布局清单报表.   1.表格式清单报表--客户信息清单 在客户信息清单报表中以表格形式

ActiveReports 报表应用教程 (4)---分栏报表

原文:ActiveReports 报表应用教程 (4)---分栏报表 在 ActiveReports 中可以实现分栏报表布局样式,可以设置横向分栏.纵向分栏,同时进行分栏和分组设置,统计分栏分组的小计.合计等.在商业报表系统中常见的分栏报表有商品标签.员工工卡.条码打印等.本文主要讲解如何在 ActiveReports 中实现横向分栏.纵向分栏和分组分栏报表. 1.横向分栏报表 1.1.在 ASP.NET 应用程序中添加一个名为 rptAcrossDown.cs 的 ActiveReports

基于Servlet+JDBC+Bootstrap+MySQL+AJAX权限管理系统项目实战教程

项目简介 权限系统一直以来是我们应用系统不可缺少的一个部分,若每个应用系统都重新对系统的权限进行设计,以满足不同系统用户的需求,将会浪费我们不少宝贵时间,所以花时间来设计一个相对通用的权限系统是很有意义的.     本系统的设计目标是对应用系统的所有资源进行权限控制,比如应用系统的功能菜单.各个界面等进行权限的操控.技术介绍 · Servlet3.0 Servlet 3.0 作为JavaEE6 规范体系中一员,随着JavaEE6规范一起发布.该版本在前一版本(Servlet2.5)的基础上提供了

【ASP.NET实战教程】ASP.NET实战教程大集合,各种项目实战集合

[ASP.NET实战教程]ASP.NET实战教程大集合,各种项目实战集合,希望大家可以好好学习教程中,有的比较老了,但是一直很经典!!!!论坛中很多小伙伴说.net没有实战教程学习,所以小编连夜搜集整理出一些比较好的教程,望君好好珍惜,资源不易,且保持,且珍惜直接上资源截图: 下载地址[回复可见]:http://www.fu83.cn/thread-282-1-1.html 感觉文章写的好,一定要回复 推荐哦!!!

室内设计 3Dsmax2012教程 效果图实例提高教程 室内设计实战教程 欧式效果图制作实例教程

热门推荐电脑办公计算机基础知识教程 Excel2010基础教程 Word2010基础教程 PPT2010基础教程 五笔打字视频教程 Excel函数应用教程 Excel VBA基础教程 WPS2013表格教程 更多>平面设计PhotoshopCS5教程 CorelDRAW X5视频教程 Photoshop商业修图教程 Illustrator CS6视频教程 更多>室内设计3Dsmax2012教程 效果图实例提高教程 室内设计实战教程 欧式效果图制作实例教程 AutoCAD2014室内设计 Aut