(转)VS2010结合水晶报表做条码标签打印功能

2024-03-02 08:50

本文主要是介绍(转)VS2010结合水晶报表做条码标签打印功能,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

VS2010结合水晶报表做条码标签打印功能

  (2012-02-25 11:39:01)
转载
标签: 

vs2010

 

水晶报表

 

条码

 

标签

 

打印

 

杂谈

分类: VS2010

先来个功能效果图:

VS2010结合水晶报表做条码标签打印功能

  大家都知道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, stringparamValue,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.水晶报表的动态数据源绑定

博客声明本站部分内容转自网络,如果侵害到您的权利,请及时联系我
转载请注明出处: http://www.cnblogs.com/qidian10
Mail:ovenjackchain@gmail.com;QQ:710782046

这篇关于(转)VS2010结合水晶报表做条码标签打印功能的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/765563

相关文章

Spring Boot 结合 WxJava 实现文章上传微信公众号草稿箱与群发

《SpringBoot结合WxJava实现文章上传微信公众号草稿箱与群发》本文将详细介绍如何使用SpringBoot框架结合WxJava开发工具包,实现文章上传到微信公众号草稿箱以及群发功能,... 目录一、项目环境准备1.1 开发环境1.2 微信公众号准备二、Spring Boot 项目搭建2.1 创建

nginx -t、nginx -s stop 和 nginx -s reload 命令的详细解析(结合应用场景)

《nginx-t、nginx-sstop和nginx-sreload命令的详细解析(结合应用场景)》本文解析Nginx的-t、-sstop、-sreload命令,分别用于配置语法检... 以下是关于 nginx -t、nginx -s stop 和 nginx -s reload 命令的详细解析,结合实际应

SpringBoot结合Docker进行容器化处理指南

《SpringBoot结合Docker进行容器化处理指南》在当今快速发展的软件工程领域,SpringBoot和Docker已经成为现代Java开发者的必备工具,本文将深入讲解如何将一个SpringBo... 目录前言一、为什么选择 Spring Bootjavascript + docker1. 快速部署与

Qt使用QSqlDatabase连接MySQL实现增删改查功能

《Qt使用QSqlDatabase连接MySQL实现增删改查功能》这篇文章主要为大家详细介绍了Qt如何使用QSqlDatabase连接MySQL实现增删改查功能,文中的示例代码讲解详细,感兴趣的小伙伴... 目录一、创建数据表二、连接mysql数据库三、封装成一个完整的轻量级 ORM 风格类3.1 表结构

mysql表操作与查询功能详解

《mysql表操作与查询功能详解》本文系统讲解MySQL表操作与查询,涵盖创建、修改、复制表语法,基本查询结构及WHERE、GROUPBY等子句,本文结合实例代码给大家介绍的非常详细,感兴趣的朋友跟随... 目录01.表的操作1.1表操作概览1.2创建表1.3修改表1.4复制表02.基本查询操作2.1 SE

Python中re模块结合正则表达式的实际应用案例

《Python中re模块结合正则表达式的实际应用案例》Python中的re模块是用于处理正则表达式的强大工具,正则表达式是一种用来匹配字符串的模式,它可以在文本中搜索和匹配特定的字符串模式,这篇文章主... 目录前言re模块常用函数一、查看文本中是否包含 A 或 B 字符串二、替换多个关键词为统一格式三、提

Golang如何用gorm实现分页的功能

《Golang如何用gorm实现分页的功能》:本文主要介绍Golang如何用gorm实现分页的功能方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录背景go库下载初始化数据【1】建表【2】插入数据【3】查看数据4、代码示例【1】gorm结构体定义【2】分页结构体

Java Web实现类似Excel表格锁定功能实战教程

《JavaWeb实现类似Excel表格锁定功能实战教程》本文将详细介绍通过创建特定div元素并利用CSS布局和JavaScript事件监听来实现类似Excel的锁定行和列效果的方法,感兴趣的朋友跟随... 目录1. 模拟Excel表格锁定功能2. 创建3个div元素实现表格锁定2.1 div元素布局设计2.

HTML中meta标签的常见使用案例(示例详解)

《HTML中meta标签的常见使用案例(示例详解)》HTMLmeta标签用于提供文档元数据,涵盖字符编码、SEO优化、社交媒体集成、移动设备适配、浏览器控制及安全隐私设置,优化页面显示与搜索引擎索引... 目录html中meta标签的常见使用案例一、基础功能二、搜索引擎优化(seo)三、社交媒体集成四、移动

HTML input 标签示例详解

《HTMLinput标签示例详解》input标签主要用于接收用户的输入,随type属性值的不同,变换其具体功能,本文通过实例图文并茂的形式给大家介绍HTMLinput标签,感兴趣的朋友一... 目录通用属性输入框单行文本输入框 text密码输入框 password数字输入框 number电子邮件输入编程框