用printer对象打印表格

    技术2022-05-11  104

              用printer对象打印表格

       用msflexgrid控件显示的表格,要将它打印出来,最简单的方法是用printform方法,然而这只适合于数据正好能被屏幕显示的,即数据量少的,而且这种打印效果很差。而用printer对象进行打印编程,虽然麻烦点,但效果却是相当不错的,你可以自定义打印格式,打印页数,表格的粗细,字体大小等。实际上用printer对象进行打印编程是比较简单的。

    下面我就用一实例来说明:

    打印的内容是一张数据表,这里就只有两列数据,包括标题,副标题。(用A4纸打印)

    假设数据处在C_DataArray(),和R_DataArray()中C_Name与R_Name分别为两数据项的字段名

    Public Sub Printtable()'初始化

    Dim printer1 as Printer

    Dim pageheaderDim pagefooterDim pageleftDim pagerightDim usewidthDim useheightDim i, j, k As IntegerDim word As StringDim startxDim startyDim startyline             ‘ 用来纪录打印竖线的起点

    Dim endyline              ’ 用来纪录打印竖线的末点

    设置页面参数

    pageheader = 25pagefooter = 25pageleft = 20pageright = 20

     With printer1    .PaperSize = 9    .ScaleMode = 6    .FontBold = True    .ScaleLeft = -20    .ScaleTop = -25    .ScaleWidth = 210                                        '设置为A4纸    .ScaleHeight = 297    usewidth = .ScaleWidth - 40    useheight = .ScaleHeight - 50    .CurrentX = 0    .CurrentY = 0    .DrawWidth = 5End With'打印标题With printer1    .FontSize = 20    .CurrentX = (usewidth - .TextWidth(DataTitle)) / 2    .CurrentY = pageheader + .ScaleTopEnd With    printer1.Print DataTitle    '打印副标题   printer1.FontSize = 15    word = DataTitle2    printer1.CurrentX = usewidth - printer1.TextWidth(word)    printer1.Print word     '打印第一条线  Line方法不能用在with ....end with里

    printer1.CurrentX = pageleft + printer1.ScaleLeftstartyline = printer1.CurrentY'线宽

    printer1.Line -((printer1.ScaleLeft + printer1.ScaleWidth - pageleft), printer1.CurrentY)printer1.FontSize = 10'printer1.Print vbLfprinter1.CurrentY = printer1.CurrentY + 1'打印第一个字段名starty = printer1.CurrentYprinter1.CurrentX = ((printer1.ScaleWidth - 40) / 2 - printer1.TextWidth(C_Name)) / 2

    printer1.Print C_Name

    '打印第二个字段名printer1.CurrentX = usewidth / 2 + ((usewidth / 2 - printer1.TextWidth(R_Name)) / 2)printer1.CurrentY = startyprinter1.Print R_Nameprinter1.CurrentY = printer1.CurrentY + 1

    '打印数据和横线,rownum为数据行数

    For i = 1 To rownum'判断是否该页已打满    If printer1.CurrentY >= useheight Then

        '打印横线    printer1.CurrentX = printer1.ScaleLeft + pageleft    printer1.Line -((printer1.ScaleLeft + printer1.ScaleWidth - pageleft), printer1.CurrentY)    printer1.CurrentY = printer1.CurrentY + 1                 '打印三条竖线        endyline = printer1.CurrentY        printer1.Line (0, startyline)-(0, endyline)        printer1.Line (usewidth / 2, startyline)-(usewidth / 2, endyline)        printer1.Line (usewidth, startyline)-(usewidth, endyline)               '打印页号       With printer1        .CurrentX = (.ScaleWidth - .TextWidth(.Page)) / 2 - pageleft        .CurrentY = useheight + 3       End With        printer1.Print printer1.Page        printer1.NewPage       With printer1            .CurrentX = pageleft + .ScaleLeft            .CurrentY = pageheader + .ScaleTop            startyline = .CurrentY       End With            End If        '打印一行数据    printer1.CurrentX = ((printer1.ScaleWidth - 40) / 2 - printer1.TextWidth(C_DataArray(i))) / 2    starty = printer1.CurrentY    printer1.Print C_DataArray(i)    printer1.CurrentX = (printer1.ScaleWidth - 40) / 2 + ((printer1.ScaleWidth - 40) / 2 - printer1.TextWidth(R_DataArray(i) )) / 2    printer1.CurrentY = starty    printer1.Print R_DataArray(i)    printer1.CurrentY = printer1.CurrentY + 1    Next i       '打印最后一条横线    printer1.CurrentX = printer1.ScaleLeft + pageleft    printer1.Line -((printer1.ScaleLeft + printer1.ScaleWidth - pageleft), printer1.CurrentY)    endyline = printer1.CurrentY'打印三条竖线        printer1.Line (0, startyline)-(0, endyline)        printer1.Line (usewidth / 2, startyline)-(usewidth / 2, endyline)        printer1.Line (usewidth, startyline)-(usewidth, endyline)            '打印页号       With printer1        .CurrentX = (.ScaleWidth - .TextWidth(.Page)) / 2 - pageleft        .CurrentY = useheight + 3       End With        printer1.Print printer1.Page       printer1.EndDocend sub


    最新回复(0)