在 OpenOffice Calc 中以编程方式更改打印区域

Posted

技术标签:

【中文标题】在 OpenOffice Calc 中以编程方式更改打印区域【英文标题】:Changing programmatically print area in OpenOffice Calc 【发布时间】:2017-05-29 19:55:53 【问题描述】:

我正在使用 vb6 动态创建一个 Calc 文档。打印时,我需要在每页中重复 1 行和 1 列。

这是代码:

 Dim mPrintOptions(2) As Object
 Dim OO_Dispatcher As Object
 Set OO_Dispatcher = oServiceManager.createInstance("com.sun.star.frame.DispatchHelper")
 Set mPrintOptions(0) = MakePropertyValue(oServiceManager, "PrintArea", "")
 Set mPrintOptions(1) = MakePropertyValue(oServiceManager, "PrintRepeatRow", "$A$2")
 Set mPrintOptions(2) = MakePropertyValue(oServiceManager, "PrintRepeatCol", "$A$1")

 OO_Dispatcher.executeDispatch oDeskTop, ".uno:ChangePrintArea", "", 0, mPrintOptions

我有这段代码在保存的文档中创建一个宏。

服务管理器和桌面对象是先前实例化的。文档创建得很好,但是当我将它发送到打印机时,它不会重复我上面指定的行和列。

【问题讨论】:

【参考方案1】:

我在这里找到了我的解决方案:

https://wiki.openoffice.org/wiki/ES/Manuales/GuiaAOO/TemasAvanzados/Macros/StarBasic/TrabajandoConCalc/Imprimiendo

我的代码终于变成了这样:

Dim OO_TitulosR As Object
Dim OO_ActiveSheet As Object
Set OO_TitulosR = OO_Document.Bridge_getStruct("com.sun.star.table.CellRangeAddress")
Set OO_ActiveSheet = OO_Document.getCurrentController.getActiveSheet
OO_TitulosR.StartColumn = 0
OO_TitulosR.EndColumn = 0
OO_TitulosR.StartRow = 1
OO_TitulosR.EndRow = 1
OO_ActiveSheet.setTitleColumns OO_TitulosR
OO_ActiveSheet.setTitleRows OO_TitulosR

【讨论】:

以上是关于在 OpenOffice Calc 中以编程方式更改打印区域的主要内容,如果未能解决你的问题,请参考以下文章

如何使用 .NET 从 OpenOffice.org Writer 文档中以编程方式提取宏?

Apache Openoffice Calc 编程

Openoffice Calc - 更改文本大小写

使用 c# 在 OpenOffice calc 中的超链接

将 OpenOffice Calc 文件导出为 PDF 时如何处理打印区域?

OpenOffice calc 中的行号列