一起学习水晶报表之拉模式【Winform中实现报表显示数据】(课程4)

本文主要是介绍一起学习水晶报表之拉模式【Winform中实现报表显示数据】(课程4),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前面的章节是实现了在ASP.NET中的网页中报表数据显示,接下来,我们将尝试从WinForm应用程序研究,看看水晶报表在Winform中如何运用的。

我们前面说过,水晶报表的rpt报表模板可以在专用软件上面先设计好,然后再导入到VS中运用。这里为了方便,我们就不那样干了,直接在VS上面进行画报表。当然其中的报表rpt模板也是通用的,因此我们可以完全将刚才那个报表模板完全拷贝过来到Winform中直接使用。

但是这里需要注意的是,我们直接拷贝过来,比如是通过拖动的方式,如图所示。那么就要注意了,需要更改一些代码,如命名空间等才能正确使用,否则报错。

步骤如下:(我这里是为了演示方便了,大家可以灵活变动哈)


【1】这里我在同一解决方案目录下,建立一个Winform项目,并且设置其为【设置启动项目】。

【2】在上面的ASP.NET的web项目中直接拖动报表文件CrystalReport1.rpt到刚才建立的Winform项目中。但是这样拖动,就会把报表模板下的cs文件也拖过来了,但是不能用,如图:

出现这个情况的原因是:

(1)拖动相当于复制粘贴,原封不动地将代码拷贝了过来,显然ASP.NET项目和Winform是存在差别的,因此需要修改后台代码

(2)从错误提示可以看出,该Winform项目并没有引入对应的命名空间,也就是说还没有应用对用的水晶报表控件,需要修改。

【3】那么我们先把水晶报表显示控件拖到Winform项目的窗口中,如图:


看到了吧,在winform里面它就没有那个绑定数据源的控件,只有这个Viewer控件。因此我们需要书写后台代码绑定到这个控件才能显示。

【4】好的这样就可以看了:


咦,看来VS2010版还是比较智能和强大的,不同VS2008,当我们拖动报表或者其他文件到该项目的时候,VS2010是可以自动修改命名空间的。注意了如果您拖动的时候,发现还是不对,这个时候,你就要手动修改后台的代码,修改为统一(一样)的命名空间了。

【注意】最好您顺手将报表的模板文件和对应的cs文件复制到对应的启动目录【bin】>>【Debug】下:如图



如果没有按照以方法将两个报表模板拷贝到bin目录下,那么改变报表的模板属性也是可以的。


将【复制到输出目录】更改为:<始终复制>


【5】手动添加crystalReportViewer1_Load的后台代码,如下:在视图设计器中,选中【报表空间】>>【右键】》》【属性】>>添加事件[Load]

(1)引入命名空间:

using CrystalDecisions.CrystalReports.Engine;
using CrystalDecisions.Shared;

(2)添加代码:

private void crystalReportViewer1_Load(object sender, EventArgs e)
        {
            ReportDocument rptDoc = new ReportDocument();
            rptDoc.Load(Application.StartupPath + "\\CrystalReport1.rpt");
//Application.StartupPath表示启动路径,也就是编译目录下的【bin】>>[Debug]


            TableLogOnInfo logInfo = new TableLogOnInfo();
            logInfo.ConnectionInfo.ServerName = @"127.0.0.1";
            logInfo.ConnectionInfo.UserID = "sa";
            logInfo.ConnectionInfo.Password = "admin@123456";
            logInfo.ConnectionInfo.DatabaseName = "北风贸易";


            for (int i = 0; i < rptDoc.Database.Tables.Count; i++)
            {
                rptDoc.Database.Tables[i].ApplyLogOnInfo(logInfo);
            }

            crystalReportViewer1.ReportSource = rptDoc;
        }

【6】编译,运行成功。如图:





这篇关于一起学习水晶报表之拉模式【Winform中实现报表显示数据】(课程4)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/976854

相关文章

Spring定时任务之fixedRateString的实现示例

《Spring定时任务之fixedRateString的实现示例》本文主要介绍了Spring定时任务之fixedRateString的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有... 目录从毫秒到 Duration:为何要改变?核心:Java.time.Duration.parse

Python进行word模板内容替换的实现示例

《Python进行word模板内容替换的实现示例》本文介绍了使用Python自动化处理Word模板文档的常用方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友... 目录技术背景与需求场景核心工具库介绍1.获取你的word模板内容2.正常文本内容的替换3.表格内容的

Java中实现对象的拷贝案例讲解

《Java中实现对象的拷贝案例讲解》Java对象拷贝分为浅拷贝(复制值及引用地址)和深拷贝(递归复制所有引用对象),常用方法包括Object.clone()、序列化及JSON转换,需处理循环引用问题,... 目录对象的拷贝简介浅拷贝和深拷贝浅拷贝深拷贝深拷贝和循环引用总结对象的拷贝简介对象的拷贝,把一个

linux部署NFS和autofs自动挂载实现过程

《linux部署NFS和autofs自动挂载实现过程》文章介绍了NFS(网络文件系统)和Autofs的原理与配置,NFS通过RPC实现跨系统文件共享,需配置/etc/exports和nfs.conf,... 目录(一)NFS1. 什么是NFS2.NFS守护进程3.RPC服务4. 原理5. 部署5.1安装NF

Python实现自动化删除Word文档超链接的实用技巧

《Python实现自动化删除Word文档超链接的实用技巧》在日常工作中,我们经常需要处理各种Word文档,本文将深入探讨如何利用Python,特别是借助一个功能强大的库,高效移除Word文档中的超链接... 目录为什么需要移除Word文档超链接准备工作:环境搭建与库安装核心实现:使用python移除超链接的

python库pydantic数据验证和设置管理库的用途

《python库pydantic数据验证和设置管理库的用途》pydantic是一个用于数据验证和设置管理的Python库,它主要利用Python类型注解来定义数据模型的结构和验证规则,本文给大家介绍p... 目录主要特点和用途:Field数值验证参数总结pydantic 是一个让你能够 confidentl

Python Excel 通用筛选函数的实现

《PythonExcel通用筛选函数的实现》本文主要介绍了PythonExcel通用筛选函数的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 目录案例目的示例数据假定数据来源是字典优化:通用CSV数据处理函数使用说明使用示例注意事项案例目的第一

C#使用SendMessage实现进程间通信的示例代码

《C#使用SendMessage实现进程间通信的示例代码》在软件开发中,进程间通信(IPC)是关键技术之一,C#通过调用WindowsAPI的SendMessage函数实现这一功能,本文将通过实例介绍... 目录第一章:SendMessage的底层原理揭秘第二章:构建跨进程通信桥梁2.1 定义通信协议2.2

JAVA实现亿级千万级数据顺序导出的示例代码

《JAVA实现亿级千万级数据顺序导出的示例代码》本文主要介绍了JAVA实现亿级千万级数据顺序导出的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 前提:主要考虑控制内存占用空间,避免出现同时导出,导致主程序OOM问题。实现思路:A.启用线程池

Python实现中文大写金额转阿拉伯数字

《Python实现中文大写金额转阿拉伯数字》在财务票据中,中文大写金额被广泛使用以防止篡改,但在数据处理时,我们需要将其转换为阿拉伯数字形式,下面我们就来看看如何使用Python实现这一转换吧... 目录一、核心思路拆解二、中文数字解析实现三、大单位分割策略四、元角分综合处理五、测试验证六、全部代码在财务票