以文本方式查看主题 - Foxtable(狐表) (http://foxtable.net/bbs/index.asp) -- 专家坐堂 (http://foxtable.net/bbs/list.asp?boardid=2) ---- [建议][求助]关于横纵向打印,官方是不是给个最终的解决方案 (http://foxtable.net/bbs/dispbbs.asp?boardid=2&id=71739) |
-- 作者:huangfanzi -- 发布时间:2015/7/17 9:52:00 -- [建议][求助]关于横纵向打印,官方是不是给个最终的解决方案 前二天测试打印用窗口做的入库单,用的是针打,用的是哪种二等分纸,即宽度241,高度139.7,打印预览中显示正常,但在预览中打印会方向反掉,最终我用的方案就是直接打印 今天在做窗口模式的合同时,用的是A4纸,横向打印的,直接打印会变成纵向,用预览中的打印又正常了,在直接打印的代码中,我用了这二种代码的各种组合,如:Doc.PageSetting.Landscape = True及doc.AutoRotate = False,但均告失败,打出来的死活是给向的。 虽然我可以取消直接打印代码用预览打印,但老是这么猜谜语一样的编代码,程序的执行结果不受控制实在让我揪心,打印是非常重要的功能,官方能好好的测试改善一下吗? 以下是我合同打印的代码: _PrintForm.Page.LeftMargin = CDbl(e.Form.Controls("NumericComboBox1").text) \'设置左边距 _PrintForm.Page.RightMargin = CDbl(e.Form.Controls("NumericComboBox2").text) \'设置右边距 _PrintForm.Page.TopMargin = CDbl(e.Form.Controls("NumericComboBox3").text) \'设置上边距 _PrintForm.Page.BottomMargin = CDbl(e.Form.Controls("NumericComboBox4").text) \'设置下边距 _PrintForm.Page.Landscape = True \'横向打印 Dim doc As PrintDoc = _PrintForm.GernatePrintDoc() For Each c As object In Doc.Body.Children \'自动合并合计行的单元格 If c.Gettype.Name Like "*Table*" Then Dim t As prt.RenderTable = c For i As Integer = 0 To t.Rows.Count - 1 If t.Cells(i, 2).Text = Nothing AndAlso t.Cells(i, 1).Text <> Nothing Then For n As Integer =1 To t.Cols.Count - 1 \'表的目录树占用了最左列导致实际列数从1开始,而不是0 If t.Cells(i,n).Text = Nothing AndAlso t.Cells(i,n+1).Text <> Nothing Then t.Cells(i, 1).SpanCols = n Exit For End If Next End If Next End If Next Dim rx As New prt.RenderTable rx.Cells(0,0).Text = _CompanyName \'调用在全局代码中设置的全局变量 rx.Cells(1,0).Text = _DocumentType \'调用打开本窗口时赋值的全局变量 rx.Cols(0).Style.TextAlignHorz = prt.AlignHorzEnum.Center \'设置居中 rx.CellStyle.Spacing.Bottom = 0.5 \'底端内容缩进0.5毫米 rx.Cells(0,0).Style.FontSize = 16 \'设置字体大小 rx.Cells(1,0).Style.FontSize = 14 \'设置字体大小 Doc.PageHeader = rx \'作为页眉使用 doc.PageSetting.Width = CDbl(e.Form.Controls("NumericComboBox5").text) \'纸张宽度为XX毫米 doc.PageSetting.Height = CDbl(e.Form.Controls("NumericComboBox6").text) \'纸张高度为XX毫米 doc.AutoRotate = False \'禁止自动旋转打印内容 If e.Form.Controls("ComboBox_打印机").value = "" Then Else Doc.PrinterName =e.Form.Controls("ComboBox_打印机").value End If \'doc.Print doc.Preview() \'预览 [此贴子已经被作者于2015/7/17 9:52:08编辑过]
|
-- 作者:大红袍 -- 发布时间:2015/7/17 10:09:00 -- foxtable的打印是有各种各样的问题。
一般情况,你可以去打印机那里设置打印机横向纵向打印 |
-- 作者:andy123 -- 发布时间:2015/8/17 17:23:00 -- 顶一下 好好的一下午,又被横向,纵向的问题给废了调来调去,还是搞不好, 同样的窗口,只改变一下纸张设置,打印出来的表线宽都不一样,这是闹哪样啊 真的是打败了
|
-- 作者:大红袍 -- 发布时间:2015/8/17 17:26:00 -- 表线宽?表的线宽可以自己控制的啊。
http://www.foxtable.com/help/topics/1200.htm
|
-- 作者:lsy -- 发布时间:2015/8/17 18:42:00 -- 打印预览里的的线宽,真是奇丑,实际打印效果还过得去。 |