(转)VS2010结合水晶报表做条码标签打印功能
本文转载自:http://blog.sina.com.cn/s/blog_552ca1400100y6dd.html
先来个功能效果图:



大家都知道VS2005和VS2008软件本身是包含水晶报表插件的,而新版本的VS2010去掉了SAP水晶报表的插件,想要在VS2010中使用水晶报表首先要下载SAP的插件CRforVS_13_0.exe,我这下载的是13版本的。
下载完成后安装,现在就可以在VS2010里面使用了,哈哈。
1、准备工作,条码实现
具体如何实现条码,这里不再赘述,详细请参考:http://www.cnblogs.com/qidian10/archive/2011/07/16/2108144.html
我这里准备好生成图片的地址:http://localhost:5950/CodeBar.aspx?code={0}
2、在VS2010中创建一个水晶报表
文件-新建-项目-CrystalRepost应用程序

你可根据向导自己添加必要的数据源等信息,或者建立空白的报表,后面再添加一样的。
我这里新建的水晶报表名称为:FLCodeBar.rpt
报表数据库字段配置中,添加一个表,用到简单的5个测试字段(就一句sql)
select top 10 SMSITE,SMITNO,SMALSU,SMPUPR,SMREMK from PSMINF
3、在水晶报表中设置页面格式,5cm*5cm
条码标签的大小是5cm*5cm的,所以首先设置页面:右键报表空白区域--->设置---->页面

4、拖入显示字段,从节点专家中隐藏报表头、页眉、报表尾部、页脚,只保留详细资料
从数据库字段中拖入需要显示到标签中的字段,排版

5、水晶报表中显示图片,条码图片
首先右键报表空白区域--->插入---->图片(先找一个本机的图片)
调整图片的大小为合适的大小
由于我们的条码是动态的,所以我们这里还要给图片动态的路径
右键图片--->设置对象格式--->图片标签--->单击最下面,图形位置右侧的按钮,弹出公式工作室


我们在右下角的编辑框中输入如下内容"http://localhost:5950/CodeBar.aspx?code="&{PSMINF.SMITNO}
这个地址就是我们第一步实现产生条码图的地址,最后的PSMINF.SMITNO的参数代表绑定数据库的那个字段。
还有一个不得不提的是,这里的图片路径不能写成死的,因为发布到IIS后,域名localhost:5950肯定会变的,所以这里需要用参数来代替(蓝色框),然后参数由调用程序提供。
如何创建参数,见下面。
6、水晶报表中建立参数,供程序调用
在字段资源管理器中,邮件参数字段,新建一个静态参数,如下图,然后我们才能在第5步骤中,成功保存图片路径

7、万事具备,只欠东风在Web中使用我们的水晶报表
我们需要动态绑定报表的数据源。
新建一个web应用程序,将做好的数据报表rpt文件拷贝到网站的合适目录。
创建好web后,需要引用水晶报表的dll,如下:

我们在Default.aspx中拖入CrystalReportViewer控件
并设定相关属性,去掉不必显示的东西。
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Default.aspx.cs" Inherits="WebApplication1._Default" %>
<%@ Register assembly="CrystalDecisions.Web, Version=13.0.2000.0, Culture=neutral, PublicKeyToken=692fbea5521e1304" namespace="CrystalDecisions.Web" tagprefix="CR" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title></title>
</head>
<body>
<form id="form1" runat="server">
<div>
<CR:CrystalReportViewer ID="CrystalReportViewer1" runat="server"
AutoDataBind="true" HasCrystalLogo="False" HasSearchButton="False"
HasToggleGroupTreeButton="False" ToolPanelView="None"
HasToggleParameterPanelButton="False" />
</div>
</form>
</body>
</html>
8、在Web的Default.aspx页面写入调用方法
protected void Page_Load(object sender, EventArgs e)
{
CJ.CJ_DevelopHelper.SqlConn_Str = "server=localhost;uid=sa;pwd=ovenjackchain;database=plmass;";
CJ.CJ_DevelopHelper.SqlStr = "select top 10 SMSITE,SMITNO,SMALSU,SMPUPR,SMREMK from PSMINF";
DataTable dt = CJ.CJ_DevelopHelper.SQL_ReturnDateTable;//获取数据源
ReportDocument rpt = new ReportDocument();
rpt.Load(Server.MapPath("/FLCodeBar.rpt"));
rpt.SetDataSource(dt);
ParameterFields t = new ParameterFields();
AddParameter("PlmWebIp", "localhost:5950", t); //PlmWebIp是报表中的参数名字,即图片的Domain,这可以灵活设置(暂时写死)
CrystalReportViewer1.ParameterFieldInfo = t;//添加参数
CrystalReportViewer1.ReportSource = rpt;
}
//msdn给水晶报表添加参数的方法
private ParameterFields AddParameter(string paramName, string paramValue,ParameterFields paramFields)
{
ParameterField paramField = new ParameterField();
ParameterDiscreteValue paramDiscreteValue = new ParameterDiscreteValue();
ParameterValues paramValues = new ParameterValues();
paramField.ParameterFieldName = paramName;
paramDiscreteValue.Value = paramValue;
paramValues.Add(paramDiscreteValue);
paramField.CurrentValues = paramValues;
paramFields.Add(paramField);
return paramFields;
}
9、收工,回顾
案例中主要用到一下知识点:
1.VS2010集成水晶报表
2.水晶报表页面设置
3.水晶报表图片设置
4.水晶报表图片的动态url设置
5.水晶报表参数设置,和程序动态赋值等
6.水晶报表的动态数据源绑定
PS:条码生成的程序已上传至我的微云->演示程序
(转)VS2010结合水晶报表做条码标签打印功能的更多相关文章
- [转]VS2010中水晶报表安装应用及实例
基本分类如下:第一部分:VS2010简介VS2010是微软的提供的一套完整的开发环境,功能也是相当的大微软宣布了下一代开发工具和平台的正式名称,分别称为“Visual Studio Team Syst ...
- VS2010中水晶报表应用及实例
原文:VS2010中水晶报表应用及实例 基本分类如下:第一部分:VS2010简介VS2010是微软的提供的一套完整的开发环境,功能也是相当的大微软宣布了下一代开发工具和平台的正式名称,分别称为“Vis ...
- Vs2010中水晶报表引用及打包
原文:Vs2010中水晶报表引用及打包 转自:http://yunhaifeiwu.iteye.com/blog/1172283 Vs2010中水晶报表引用 在sap官网中下载支持vs 2010中的水 ...
- VS2010与水晶报表V13的打包集成小结
感谢孟子E章提供的技术咨询. 系统配置: Windows 7 + VS2010 , WinForm + DotNet4 + 水晶报表 这里说的打包集成,指的用VS2010的制作的安装包,在安装的时候可 ...
- 关于vs2010下水晶报表的使用入门
关于vs2010下使用水晶报表了解情况记录如下: 1.首先vs2010不再自带水晶报表控件了,需要下载安装vs2010配套的水晶报表控件:CRforVS_13_0.这个控件安装很简单,基本上都选择默认 ...
- VS2010中水晶报表插件下载安装方法
Visual Studio 2010默认不带水晶报表,需要安装一个水晶报表插件,首先下载此插件: http://downloads.businessobjects.com/akdlm/cr4vs201 ...
- VS2015安装水晶报表
最近在做一个打印功能,本来是不想用水晶报表的.想直接用微软原生的报表rdlc完成,但是整了一个上午老是打印乱码,且网上找资料找也找不出. 无奈放弃,然后就想到用水晶报表了,以前用过水晶报表,不过一直都 ...
- 水晶报表Crystal 无效索引
这几天项目用到水晶报表做报表打印,没有前辈指导,都自己摸着石头过河,真是痛并快乐着.其实水晶报表还是挺好用的,对初学者也并不难(我就是初学者).昨天遇到一个问题:无效索引 ……开始以为是报表设置的问题 ...
- 水晶报表中"已达到系统管理员配置的最大报表处理作业数限制"错误的处理
错误描述:用水晶报表做报表时当多次打开报表后会经常会出现"已达到系统管理员配置的最大报表处理作业数限制. "的错误. 1.自身的问题:用完CrystalDecisions.Crys ...
随机推荐
- [BZOJ4569] [Luogu 3295] [SCOI2016]萌萌哒(并查集+倍增)
[BZOJ4569] [Luogu 3295] [SCOI2016]萌萌哒(并查集+倍增) 题面 有一个n位的十进制数a(无前导0),给出m条限制,每条限制\((l_1,r_1,l_2,r_2)(保证 ...
- 背包问题: HDU1114Piggy-Bank
Piggy-Bank Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total ...
- 理解 JavaScript 闭包
这是本系列的第 4 篇文章. 作为 JS 初学者,第一次接触闭包的概念是因为写出了类似下面的代码: for (var i = 0; i < helpText.length; i++) { var ...
- bak文件恢复成 SQL2005 数据库 的全程讲解
经常会碰到客户给我们发的是一个bak的数据库备份文件,而不是一个数据库.这就需要我们把这数据文件还原成数据库的形式. 如将demo.bak数据库恢复到mssql2005下 打开SQL2005,打开后就 ...
- python中的面向对象和面向过程
一.面向对象和面向过程 一.什么是面向过程 核心是过程二字:面向过程是一种流水线的工作流程,是先做什么在做什么 二.什么是面向对象 核心 是对象二字:是一种编程思想,上帝思维,一切皆对象,编程中负责调 ...
- visual studio 2013 生成依赖项关系图出错
开始是说无法连接到sql服务器,我安装卸载localdb http://www.microsoft.com/zh-cn/download/details.aspx?id=29062 下载 CHS\x6 ...
- select case语句 is和to用法
在select case 语句中可以使用关系运算符大于>小于<等于=等关系运算符,需要用关键字IS和TO.用个例子来说明: Private Sub Command1_Click() Dim ...
- vue 之 双向绑定原理
一.实现双向绑定 详细版: 前端MVVM实现双向数据绑定的做法大致有如下三种: 1.发布者-订阅者模式(backbone.js) 思路:使用自定义的data属性在HTML代码中指明绑定.所有绑定起来的 ...
- 关于sass、scss、less的概念性知识汇总
这篇文章主要解答以下几个问题,供前端开发者的新手参考. 1.什么是Sass和Less? 2.为什么要使用CSS预处理器? 3.Sass和Less的比较 4.为什么选择使用Sass而不是Less? 什么 ...
- 2018微信小程序开发遇到的坑
第一个坑:wx.showModal(OBJECT) wx.showModal在安卓手机里,如果点击遮罩的话会关闭弹窗,不会有任何回调.而苹果的情况下则是点击遮罩不会有任何反应. 这样会有什么问题呢? ...