向大家求助,如何设计打印报表,使打出的报表类似存款单据,一定重谢

ozarkgirl 2001-11-19 11:14:39
如何设计这样的报表,如果方便请您给出相应的代码,一定重谢一定给分~~谢谢
...全文
233 15 打赏 收藏 转发到动态 举报
写回复
用AI写文章
15 条回复
切换为时间正序
请发表友善的回复…
发表回复
Richard2001 2001-11-20
  • 打赏
  • 举报
回复
没有吧?!我都通过了才给你的。
你新建个工程,把PictureBox名改为Pic,再试试。
ozarkgirl 2001-11-20
  • 打赏
  • 举报
回复
打印可以就是一个表格,如果预览他报错说:“编译错误:ByRef参数类型不符”
Richard2001 2001-11-20
  • 打赏
  • 举报
回复
你在打印机上打印出来与你的预览对比一下吧。
Richard2001 2001-11-20
  • 打赏
  • 举报
回复
可以做个简单的预览和打印功能:
你在Form中间加一个PictureBox,设Appearance=0,大小比例与一张打印纸相似。
再加两个按钮:“预览“(Preview)和“打印“(Print)按钮。

Sub SetData(obj As Object)
If TypeOf obj Is Picture Then
obj.Cls
End If

On Error GoTo exit_data

Dim CX, CY, i, curY, curX
Dim StepRow, lColor, adjRowHeight, iBottomRight

lColor = obj.ForeColor
'首行显示公司名称
CX = 4
obj.Font.Bold = False
obj.Font.Size = 9
obj.CurrentY = CX
obj.CurrentX = obj.Width / 2 - obj.TextWidth("地球")
'obj.ForeColor = RGB(256, 0, 0)
obj.Print "地球公司"
StepRow = obj.TextHeight("A")
'标题
CX = CX + StepRow
obj.Font.Bold = True
obj.Font.Size = 2 * 9
obj.CurrentY = CX
obj.CurrentX = obj.Width / 2 - obj.TextWidth("存款")
obj.ForeColor = RGB(256, 0, 0) '红色
obj.Print "存款单据"
StepRow = obj.TextHeight("A")
'首部信息第一行
obj.ForeColor = lColor '恢复
CX = CX + StepRow
obj.Font.Bold = False
obj.Font.Size = 9
obj.CurrentY = CX: obj.CurrentX = 150
obj.Print "左"
obj.CurrentY = CX: obj.CurrentX = obj.Width / 2 - obj.TextWidth("中") / 2
obj.Print "中"
obj.CurrentY = CX: obj.CurrentX = obj.ScaleWidth - 150 - obj.TextWidth("右")
obj.Print "右"


'=================画行线=================
curY = CX + StepRow: curX = 150

For i = 1 To 5
If i = 1 Then
obj.DrawWidth = 2
Else
obj.DrawWidth = 1
End If
obj.Line (curX, curY)-(obj.ScaleWidth - 150, curY)
iBottomRight = curY
'~~~~~
adjRowHeight = obj.TextHeight("A") + 3
curY = curY + adjRowHeight + 4
Next

'=============画竖线=================
curY = CX + StepRow: curX = 150
For i = 1 To 2
obj.DrawWidth = 1
obj.Line (curX, curY)-(curX, iBottomRight)
curX = curX + obj.Width / 2 - obj.TextWidth("中") / 2
Next
obj.Line (obj.ScaleWidth - 150, curY)-(obj.ScaleWidth - 150, iBottomRight)

'==============打印数据==================
Dim str
str = "打印数据"
curY = CX + StepRow + ((adjRowHeight + 4) / 2) - obj.TextHeight("A") / 2
curX = (150 + obj.Width / 2) / 2 - obj.TextWidth(str) / 2
obj.CurrentY = curY
obj.CurrentX = curX
obj.Print str

'...

Exit Sub

exit_data:
MsgBox Error
Exit Sub
End Sub

Private Sub Preview_Click()
SetData Pic
End Sub

Private Sub Print_Click()
SetData Printer
Printer.EndDoc
End Sub

ozarkgirl 2001-11-20
  • 打赏
  • 举报
回复
实在是太感谢了Richard2001,谢谢你:)
ozarkgirl 2001-11-20
  • 打赏
  • 举报
回复
实在是太感谢了Richard2001,谢谢你:)
Richard2001 2001-11-20
  • 打赏
  • 举报
回复
等一下。我给你例子。
ozarkgirl 2001-11-20
  • 打赏
  • 举报
回复
那我可不可以这样呢?先创建一个窗体,在窗体上面布置好以后,用Me.PrintForm来打印这个窗体,打印时能否去掉窗体框(就是那个渐变的色条)呢?
sunny1204 2001-11-20
  • 打赏
  • 举报
回复
可以用ActiveReport 2.0

还可以用Printer对象里面的Line方法Print
ozarkgirl 2001-11-20
  • 打赏
  • 举报
回复
哇赛~~~Richard2001你好厉害啊~~~那我要是画个矩形呢?线的长度怎样标出呢?能否插入图片?您就高抬贵手,多给我些代码吧~~~~~谢谢,谢谢您了
Richard2001 2001-11-20
  • 打赏
  • 举报
回复
VB就可以做。
如:
Printer.Line ... '画线
Printer.Print "报表" '打印字符串
...
ozarkgirl 2001-11-20
  • 打赏
  • 举报
回复
怎么做啊?那什么做啊?需要什么工具?谢谢richard2001,请您在指点指点~~谢谢:)
Richard2001 2001-11-20
  • 打赏
  • 举报
回复
自己做个打印控件吧。
Richard2001 2001-11-20
  • 打赏
  • 举报
回复
我的程序不打印图片。只是个例子。
打印内容及格式要你自己写。
ozarkgirl 2001-11-20
  • 打赏
  • 举报
回复
首先在此感谢richerd2001预览没问题了,那张图片成为了背景底图,可时打印出来还是什么都没有啊?我用的是黑白激光打印机,谢谢赐教
一、应用场景与出发点 同一个系统中,为了解决不同的客户可能需要设计不同的单据打印模板,实现此方法可能是: 1、设计不同的自带RDLC报表文件,根据当前客户加载不同的报表打印 2、GDI+绘图 和 打印组件 ,不同的客户创建不同的绘图XML格式的模板内容 3、其他第三方组件 主要对比一下前两种方法,第一种方法不好之处在于,不灵活,开发者必须地每个客户制订一个报表,不推荐采用。第二种方法,修改对应的模板内容就可以了, 模板内容可以是Xml文件,也可以是存放在数据库中的Xml格式字符串。推荐采用这种方法。然后这种方法的也有一个棘手问题 :如何让用户快速、方便地设计打印模板,本示例就是为了解决这个问题。 二、实现思路与原理 功能概要:设计一个界面,支持用户自由添加 要打印的项,文本,直线,图片 等,并且可以方便改变打印项的 字体、颜色、粗细、位置,设计时支持效果预览。 技术要点:GDI+绘图、拖动控件、XML解析、自定义控件 三、相关类介绍 绘图工具类:DrawHelper 实现 xml格式模板 与 打印项 之间进行互相转换,在目标画板中绘制 拖动工具类:WinHelper 实现控件的鼠标拖动,键盘移动 自定义控件:用于显示文字的文本框 TextBoxExt、用于显示直线的标签 LabelExt 主窗体代码:用于用户操作,添加,删除,编辑,打印项 详细介绍请参照我的博文:http://de.cel.blog.163.com/blog/static/51451236201472215450939/
本DataGridView打印控件和.NET打印控件5.5版(含报表模板设计组件)2014年2月8日修改完成,完全免费,在.NET2.0及以上环境下都可以使用(VB打印、C#打印都是可以的),有帮助文档与使用实例。 与上一版本的5.4版相比,新控件5.5版的主要更改如下: 1、对控件进行了完善,DGVPrint、VB2008Print、EasyReport组件的打印预览速度有较大的提升; 2、VB2008Print与EasyReport添加了二维码打印的功能,该功能使用开源的Zxing.NET实现; 3、添加了DrawDGVEx函数,一方面可以以DGVprint对象中的参数在VB2008Print组件中打印,另一方面提供了并排打印多个表格的重载函数; 4、DGVPrint组件添加了报表头与报表尾内容的设置属性和参数; 5、DGVPrint与VB2008Print组件在以工资条方式打印表格时,添加了是否自动换行续打的功能(即,如果工资条列太多在一行中打印不下时,可以指定自动换行续打); 6、修改了EasyReport组件的设计界面,每个区域的属性放在属性窗口中显示; 7、EasyReport组件添加了简单的多栏打印支持功能; 8、VB2008Print组件添加了PrintDGVFixedWidth函数,方便将DataGridView按指定宽度进行打印; 9、去掉了网页打印功能(因为在IE11下没法使用,所以干脆去掉),去掉了打印RDLC报表的功能; 10、其他一些完善,比如在导出Excel时,如果Columheader不可见,则不导出;解决了快速导出Excel时部分特殊列没有表格线问题(比如是数值列,但使用了%等格式);VB2008Print组件添加了PageScale可以指定打印时的缩放比例等等。 本控件特色: 1、强大的DataGridView打印功能,不仅可以以多种形式(普通打印、分栏打印、跨页打印、工资条打印打印DGV表格,基本上能完全按DGV控件本身设置的格式如字体、字号、背景颜色、前景颜色、单元格对齐方式等打印出来,文字图像都可以打印,而且是完全根据表格当前的显示顺序进行打印的,基本上做到了所见即所得的打印。 2、报表设计功能。报表模板设计组件EasyReport与WebEasyReport组件可以设计普通报表、分组报表、套打模板等,分别以DataGridView为数据源。控件的位置以毫米为计量单位,定位准确,很适合套打单据设计。 3、强大的图表打印功能。5.2版控件新增了一个Chartlet的组件,使用非常方便,可以生成柱形图、饼图、折线图等多种图形,而且可以设置2D或3D效果,既可以在打印控件中打印出来,也可以在Graphics对象中显示。 4、分组汇总打印DataGridVeiw功能,每组还可以自动换新页打印,还可以自动增加行号。 5、强大的文本打印输出功能,控件提供多个文本打印重载函数,打印文本时,如果需要,控件会自动换行和换页打印输出。还增加了以指定行间距及字符间距打印文本的功能,可以用固定行距,也可以用单倍或多倍行距打印文本。 6、强大的绘图功能,基本上.NET的GDI+的绘图函数(如直线、矩形、路径、多边形、曲线等)都有,只有个别函数的名称有点区别。 7、支持同一文档多种版面格式打印类似于Word中的节的功能):对同一份文档,不同的页面可以设置不同的格式(纸张大小、纸张方向、页边 距),只需要在新增一页时在NewPage方法中指定要使用的页面格式即可,使用非常简单。 8、报表文件保存功能。本控件允许将当前打印预览的内容保存为报表文件,以后使用本控件重新打开该报表文件即可重现原来保存报表时的打印内容。 9、Excel导出功能,可以将DataGridView和GridView导出为Excel文件,5.2版控件还增加了不依赖Office的导出Excel功能,而且速度非常快,5.4版还增加了合并单元格的导出功能。 10、打印DataGridView时的打印方案保存与读取功能。可以将当前打印参数保存为打印方案文件,或者从保存的打印方案文件中读取打印参数。 11、水印打印功能。根据需要,可以在页面中打印或不打印以半透明空心文字打印水印。 12、强大的容器控件打印功能(DrawPanel函数)。借助该函数,您只需要在您的容器控件中设计好要打印的内容及打印内容的相对位置,控件轻松帮你打印出来(如果超过一页,控件会自动换页续打)。 13、特殊文字效果打印功能。控件具有打印浮雕文字、阴影文字、空心文字、块文字的功能。 14、页眉页脚中既可打印文字,也可打印图像,或者即打印图像又打印输出文字。 15、图像与图标打印输出功能。 16、多表头(跨行跨列的复杂表头)打印功能,多表头组件支持多表头显示与打印、单元格内容的合并显示、打印与导出。 17、自定义纸张支持功能。 18、纸张背景图片设置打印功能。 19、.NET4.0支持功能(是单独的一个文件) 20、直接打印窗口中的TreeView控件功能 21、打印窗口中的ListView功能。 22、RichTextBox控件的RTF文本打印功能。 23、斜线表头打印功能(5.4版新增)。 24、二维码打印功能(5.5版本增加)。 我将持续改进该控件,并将不断推出控件的新版本,要查看或下载控件的升级版本,请登陆网站:http://myyouping.download.csdn.net/ 。具体使用方法请参见帮助文件与实例文件,如有疑问或好的建议,请与我联系: 邮箱:myyouping@139.com Q Q:479781502
(一)编码设置:1.初始设置:可是设置商品编码、供货商编码和部门编码的级长。2.往来单位编码:可以设置并管理供货商、销售货商档案,档案信息包括客户(部门)名称、地址、联系人、联系电话、邮政编码、银行帐号、纳税号等信息。3.辅助编码: 设置部门挡案,包括部门编码、部门名称、部门类别、简码和电话。4.商品编码: 档案信息包括货品名称、编号、计量单位、销售价。5.备注字典:记录备注信息。6.期初余额:设置仓库和部门的期初余额数。 (二)单据处理:1.填制入库单:货品及客户选择方便快捷,允许多仓库同时入库,不限制每笔入库单货物笔数,金额自动计算,随时可以打印单据。2.填制入库退货单:在入库后可以进行退货操作,随时可以打印单据。3.填制出库单:货品及客户选择方便快捷,允许多仓库同时出库,不限制每笔出库单货物笔数,随时可以打印单据。4.填制出库退库单:货品及客户选择方便快捷,允许多仓库同时退库,不限制每笔入库单货物笔数,随时可以打印单据。5.填制调拨单:商品在不同部门之间流动的单据,不限制每笔货物的数量,随时可以打印单据。6.填制销售单:货品及客户选择方便快捷,不限制每笔销售单货物笔数,随时可以打印单据。7.填制销售退货单:管理销售后的退货管理,随时可以打印单据。8.填制暂估入库单:管理价格不确定的商品的入库,随时可以打印单据。9.单据审核:审核所有填制的单据。10.记帐:对所有已审核的单据登记入帐。11.结帐:对一定时期的帐的总结。 (三)数据查询:1.单据查询:可以随时查询各种货品出入库情况,货品可以分类统计,条理清析。可以查询单个仓库库存,也可以查询所有仓库库存汇总数据,自动打印库存明细及库存汇总报表报表数据可以自动转换为EXCEL数据格式。2.单据汇总:可以随时查询一段时期内的入库或出库的情况,报表数据可以自动转换为EXCEL数据格式。3.帐本查询:可以按商品的分类查询一段时期内的入库、出库和结余数量,并可以随时打印,各种报表可以自动转换为EXCEL数据格式。4.收发结存:可以按仓库或商品的分类查询一段时期内的商品的入库、出库和结余情况,并可以随时打印,各种报表可以自动转换为EXCEL数据格式。5.商品明细:可以按不同时间段查询某仓库中某商品的出库和入库情况,可以随时打印,各种报表可以自动转换为EXCEL数据格式。6.部门领用:可以随时按部门的不同查询一段时期内的领用商品的总的数量,并可以随时打印,各种报表可以自动转换为EXCEL数据格式。7.年终结转:把本年度的部门编码、期末余额等结转到下一年。8.商品库存:可以按仓库不同查询某段时期中现存的商品数量,可以随时打印,各种报表可以自动转换为EXCEL数据格式。 (四)销售处理:1.部门销售汇总表:可以随时按部门的不同查询一段时期内的销售商品的总的数量金额,并可以随时打印,各种报表可以自动转换为EXCEL数据格式。2.部门商品日销售:可以随时按部门的不同查询每天的销售商品的总的数量金额,并可以随时打印,各种报表可以自动转换为EXCEL数据格式。3.部门商品结存表:可以按部门分类查询一段时期内的商品的领入、销售和结余情况,并可以随时打印,各种报表可以自动转换为EXCEL数据格式。 4.销售利润:查询一段时期某部门的销售利润,并可以随时打印。 (五)系统管理:1. 操作权限设置:设置多名软件操作员及登录密码, 为每名操作员设置操作权限 2.操作员口令变更:改变操作员的口令。3.操作员日志:记录每个操作员的工作情况。4.数据备份:可以随时将数据备份到磁盘保存 。 5.数据校验:重新计算所有的单据。

807

社区成员

发帖
与我相关
我的任务
社区描述
VB 多媒体
社区管理员
  • 多媒体
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧