Dim doc As New PrintDoc '定义一个报表
Dim rt As prt.RenderTable'定义一个表格对象
Dim tb As Table = Tables("订单表.订单明细")
Dim tbl As Table = Tables("订单表")
doc.PageSetting.Width = 241 '纸张宽度为200毫米
doc.PageSetting.Height = 93 '纸张高度为170毫米
doc.AutoRotate = False '如果纸张的宽度超过高度,要加上这行代码
doc.PageSetting.TopMargin= 5
doc.PageSetting.BottomMargin =5
doc.PageSetting.LeftMargin= 5
doc.PageSetting.RightMargin =5
'设置主标题
rt = New prt.RenderTable
rt.BreakBefore = prt.BreakEnum.Page '另起一页再打印
rt.Style.GridLines.All = New prt.Linedef '设置网格线
rt.CellStyle.Spacing.All = 1 '内容距离网格线1毫米
rt.Cells(0,0).text = "高福食品销售出库单"
rt.Cells(0,0).SpanCols = 6 '合并第一行全部单元格,用于显示主标题
rt.Cells(0,0).Style.TextAlignHorz = prt.AlignHorzEnum.Center '主标题居中
rt.Cells(0,0).Style.Font = New Font("宋体", 16, FontStyle.Bold) '设置主标题字体
'设置副标题
rt.Cells(1,0).text = "客户名称:" & tbl.Current("客户名称") '通过左边空格数量来调整副标题位置
rt.Cells(1,0).Spancols = 2 '合并地二行全部单元格,用于显示副标题
rt.Cells(1,0).Style.Borders.Right = New prt.LineDef("0mm", Color.white)
rt.Cells(1,2).text = "出库日期:" & tbl.current("出库日期") '通过左边空格数量来调整副标题位置
rt.Cells(1,2).Spancols = 2 '合并地二行全部单元格,用于显示副标题
rt.Cells(1,2).Style.Borders.Right = New prt.LineDef("0mm", Color.white)
rt.Cells(1,4).text = "出库单号:" & tbl.Current("订单编号") '通过左边空格数量来调整副标题位置
rt.Cells(1,4).Spancols = 2
rt.Rows(0).Style.Borders.All = New prt.LineDef("0mm", Color.white) '去掉第一行的网格线
rt.Rows(1).Style.Borders.All = New prt.LineDef("0mm", Color.white)'去掉第二行的网格线
rt.Rows(1).Style.Borders.Bottom = New prt.Linedef '恢复第二行底端的网格线
rt.Rows(1).Height = 8 '设置第二行的高度,拉开和表格主体的距离.
rt.RowGroups(0,1).Style.TextAlignVert = prt.AlignVertEnum.Center '第一行内容垂直居中
rt.RowGroups(0,3).Header = prt.TableHeaderEnum.All '将第一行作为表头.
rt.RowGroups(3,1).DataBinding.DataSource = BindTables("订单表.订单明细") '将第二行绑定到订单表
Dim ColNames As String() = New String(){"产品名称", "规格","单位", "价格","数量","金额"}
For c As Integer = 0 To Colnames.Length -1
rt.Cells(2,c).Text = ColNames(c)
rt.Cols(c).Width = tb.Cols(ColNames(c)).PrintWidth
rt.Cells(3, c).Text = "[Fields!" & ColNames(c) & ".Value]" '设置绑定表达式
Next
rt.cells(rt.Rows.count,0).text= "金额合计:" & tbl.Current("订单金额") & "元"
rt.cells(rt.Rows.count-1,0).SpanCols= 6
rt.cells(rt.Rows.count-1,0).Style.TextAlignHorz = prt.AlignHorzEnum.right
doc.Body.Children.Add(rt)
Doc.Preview
此主题相关图片如下:打印首选项的设置.png
data:image/s3,"s3://crabby-images/55c6d/55c6d3ce6846b2663da480ebe7688c933f898756" alt="dvubb 图片点击可在新窗口打开查看"
代码 没有问题 a4 纸能正常打印,,但针式就不行了。搞不明白
此主题相关图片如下:实际打印效果.jpg
data:image/s3,"s3://crabby-images/04e29/04e292d7fa75c50cbf8e44c7306545d5860e715b" alt="dvubb 图片点击可在新窗口打开查看"