但是我怎么把报表宽度加大呢?不要笑我哦
解决方案 »
- 如何在数组里使用vbcr
- 金蝶的这个界面是用activebar实现的吗,谁知道那个主菜单和左边的导航栏中间的,是不是图片,怎么加进去的?
- excel中的value函数在VB中能用什么函数代替吗?
- run-time error 10014问题
- 请回答了保存控件属性这个问题的songyaowu(不以分多而蹭之;不以分少而不答;习惯不结贴者拒之)兄来这里接分
- msHflexgrid
- 数据更改问题,在线急等!!!!!!!!!!
- 一个Update不能够更新数据库中的数据?奇怪...
- 打开一个工程时,某一个窗口老是加载不上是怎么回事?
- 我写了一个网络的黑白棋游戏,点对点方式,附带聊天功能谁要请进。
- 实时错误'453',找不到 DLL 入口点 Shell_NotifyIconA in shell32.dll
- adodc控件如何使用sqlserver7中的存储过程?
or http://microinfo.top263.net
提供: Data Report 使用技巧只 需 在 Windows9x的 开 始 目 录 中 选 择 设 置 打 印 机 , 然 后 选 中 你 使 用 的 打 印 机 , 修 改 其 属 性 中 纸 张 大 小 及 打 印 方 向 即 可 解 决 问 题 。 程序解决横向打印:
方 法 1: 装VB6SP4,DataReport新添了Orientation属性
参 考 :微 软 的 Knowledge Base的 文 章:“Q197915 PRB Report Width is Larger than the Paper Width”
Q253555 - FIX Error Message Report Width Is Larger Than the Paper Width on Exporting Data Report.htm
方 法 2:
用 一 个 CommonDialog:
Private Sub Command1_Click()
CommonDialog1.Flags = cdlPDPrintSetup
CommonDialog1.CancelError = True
On Error GoTo ErrorHandle:
CommonDialog1.ShowPrinter '必 须 Show出 来 且 "确 定 "才 能 修 改 纸 方 向
'Me.Refresh
'Command1.Refresh
On Error GoTo 0
DataReport1.Show vbModal
ErrorHandle:
End Sub
下 载 例 程 rptdemo.zip。
方 法 3: 引 用 PageSet.Dll(参 考 :微 软 的 Knowledge Base的 文 章:“Q198901 Sample PageSet_exe Programmatically Changes Default Printer Orientation” 并 下 载 PageSet.exe,或 orientation.zip。
但 有 时 报 出 "报 表 宽 度 大 于 纸 的 宽 度 "的 错 误 。 (参 考 :微 软 的 Knowledge Base的 文 章:“Q197915 PRB Report Width is Larger than the Paper Width” (我 认 为 没 什 么 用 ,不 知 所 云 ))
该 方 法 并 未 真 正 将 Printer改 方 向 (即 :Printer.Width与 Printer.Height并 未 交 换 ),因 此 我 建 议 :
Private Sub DataReport_Initialize()
Const ErrX = 0 '误 差 经 验 值
Dim adoRecordset As New ADODB.Recordset
adoRecordset.Fields.Append "Fld1", adVariant, , adFldIsNullable + adFldMayBeNull
adoRecordset.Open
Set Me.DataSource = adoRecordset
'下 一 句 非 常 关 键 重 要 ,可 以 极 大 地 减 少 "报 表 宽 度 大 于 纸 的 宽 度 "的 错 误 !
'当 Form1.Option1.Value为 真 时 "横 打 ",否 则 "纵 打 "
Me.ReportWidth = IIf(Form1.Option1.Value, MyMax(Printer.Width, Printer.Height),
MyMin(Printer.Width, Printer.Height)) - Me.LeftMargin - Me.RightMargin-ErrX
End Sub
Private Function MyMax(a As Long, b As Long) As Long
MyMax = IIf(a > b, a, b)
End Function
Private Function MyMin(a As Long, b As Long) As Long
MyMin = IIf(a < b, a, b)
End Function
这 样 就 可 以 极 大 地 减 少 "报 表 宽 度 大 于 纸 的 宽 度 "的 错 误 !
注 :"横 打 "即 :打 印 以 纸 的 宽 边 作 顶 部 。 "纵 打 "即 :打 印 以 纸 的 窄 边 作 顶 部 。