1cdf0e10cSrcweir<?xml version="1.0" encoding="UTF-8"?> 2cdf0e10cSrcweir<!DOCTYPE script:module PUBLIC "-//OpenOffice.org//DTD OfficeDocument 1.0//EN" "module.dtd"> 3cdf0e10cSrcweir<script:module xmlns:script="http://openoffice.org/2000/script" script:name="view_XPrintable" script:language="StarBasic"> 4cdf0e10cSrcweir 5cdf0e10cSrcweir 6cdf0e10cSrcweir'************************************************************************* 7cdf0e10cSrcweir' 8*3709053cSAndrew Rist' Licensed to the Apache Software Foundation (ASF) under one 9*3709053cSAndrew Rist' or more contributor license agreements. See the NOTICE file 10*3709053cSAndrew Rist' distributed with this work for additional information 11*3709053cSAndrew Rist' regarding copyright ownership. The ASF licenses this file 12*3709053cSAndrew Rist' to you under the Apache License, Version 2.0 (the 13*3709053cSAndrew Rist' "License"); you may not use this file except in compliance 14*3709053cSAndrew Rist' with the License. You may obtain a copy of the License at 15*3709053cSAndrew Rist' 16*3709053cSAndrew Rist' http://www.apache.org/licenses/LICENSE-2.0 17*3709053cSAndrew Rist' 18*3709053cSAndrew Rist' Unless required by applicable law or agreed to in writing, 19*3709053cSAndrew Rist' software distributed under the License is distributed on an 20*3709053cSAndrew Rist' "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 21*3709053cSAndrew Rist' KIND, either express or implied. See the License for the 22*3709053cSAndrew Rist' specific language governing permissions and limitations 23*3709053cSAndrew Rist' under the License. 24cdf0e10cSrcweir' 25cdf0e10cSrcweir'************************************************************************* 26cdf0e10cSrcweir 27cdf0e10cSrcweir 28cdf0e10cSrcweir 29*3709053cSAndrew Rist 30*3709053cSAndrew Rist 31cdf0e10cSrcweir' Be sure that all variables are dimensioned: 32cdf0e10cSrcweiroption explicit 33cdf0e10cSrcweir 34cdf0e10cSrcweir 35cdf0e10cSrcweir 36cdf0e10cSrcweirSub RunTest() 37cdf0e10cSrcweir 38cdf0e10cSrcweir'************************************************************************* 39cdf0e10cSrcweir' INTERFACE: 40cdf0e10cSrcweir' com.sun.star.view.XPrintable 41cdf0e10cSrcweir'************************************************************************* 42cdf0e10cSrcweirOn Error Goto ErrHndl 43cdf0e10cSrcweir Dim bOK As Boolean 44cdf0e10cSrcweir Dim sFileName, sFileUrl As String 45cdf0e10cSrcweir Dim aPrintingOptions(1) As New com.sun.star.beans.PropertyValue 46cdf0e10cSrcweir Dim aPrinterProps As Variant 47cdf0e10cSrcweir Dim i As Integer 48cdf0e10cSrcweir 49cdf0e10cSrcweir Test.StartMethod("getPrinter()") 50cdf0e10cSrcweir bOK = true 51cdf0e10cSrcweir aPrinterProps = oObj.getPrinter() 52cdf0e10cSrcweir bOK = bOK AND (ubound(aPrinterProps) > 0) 53cdf0e10cSrcweir Test.MethodTested("getPrinter()", bOK) 54cdf0e10cSrcweir 55cdf0e10cSrcweir 56cdf0e10cSrcweir Test.StartMethod("print()") 57cdf0e10cSrcweir bOK = true 58cdf0e10cSrcweir 59cdf0e10cSrcweir sFileUrl = utils.getTempFileURL("/XPrintable.prt", true) 60cdf0e10cSrcweir sFileName = utils.URL2Path(sFileUrl) 61cdf0e10cSrcweir 62cdf0e10cSrcweir aPrintingOptions(0).Name = "FileName" 63cdf0e10cSrcweir aPrintingOptions(0).Value = sFileName 64cdf0e10cSrcweir aPrintingOptions(0).State = com.sun.star.beans.PropertyState.DEFAULT_VALUE 65cdf0e10cSrcweir 66cdf0e10cSrcweir aPrintingOptions(1).Name = "Wait" 67cdf0e10cSrcweir aPrintingOptions(1).Value = true 68cdf0e10cSrcweir oObj.Print(aPrintingOptions()) 69cdf0e10cSrcweir 70cdf0e10cSrcweir ' without waiting Office can hang on setPrinter() call. 71cdf0e10cSrcweir wait(500) 72cdf0e10cSrcweir 73cdf0e10cSrcweir bOK = bOK AND FileExists(sFileName) 74cdf0e10cSrcweir Test.MethodTested("print()", bOK) 75cdf0e10cSrcweir 76cdf0e10cSrcweir Test.StartMethod("setPrinter()") 77cdf0e10cSrcweir bOK = true 78cdf0e10cSrcweir Dim iPaperFormat As Integer 79cdf0e10cSrcweir Dim iNewPaperFormat As Integer 80cdf0e10cSrcweir 81cdf0e10cSrcweir for i = 0 to ubound(aPrinterProps()) 82cdf0e10cSrcweir if (aPrinterProps(i).Name = "PaperFormat") then 83cdf0e10cSrcweir iPaperFormat = aPrinterProps(i).Value 84cdf0e10cSrcweir exit for 85cdf0e10cSrcweir endif 86cdf0e10cSrcweir next i 87cdf0e10cSrcweir 88cdf0e10cSrcweir if (iPaperFormat = com.sun.star.view.PaperFormat.A4) then 89cdf0e10cSrcweir iNewPaperFormat = com.sun.star.view.PaperFormat.LETTER 90cdf0e10cSrcweir else 91cdf0e10cSrcweir iNewPaperFormat = com.sun.star.view.PaperFormat.A4 92cdf0e10cSrcweir endif 93cdf0e10cSrcweir 94cdf0e10cSrcweir aPrinterProps(i).Value = iNewPaperFormat 95cdf0e10cSrcweir 96cdf0e10cSrcweir oObj.setPrinter(aPrinterProps()) 97cdf0e10cSrcweir 98cdf0e10cSrcweir aPrinterProps() = oObj.getPrinter() 99cdf0e10cSrcweir 100cdf0e10cSrcweir for i = 0 to ubound(aPrinterProps()) 101cdf0e10cSrcweir if (aPrinterProps(i).Name = "PaperFormat") then 102cdf0e10cSrcweir bOK = bOK AND (aPrinterProps(i).Value = iNewPaperFormat) 103cdf0e10cSrcweir exit for 104cdf0e10cSrcweir endif 105cdf0e10cSrcweir next i 106cdf0e10cSrcweir Test.MethodTested("setPrinter()", bOK) 107cdf0e10cSrcweir 108cdf0e10cSrcweirExit Sub 109cdf0e10cSrcweirErrHndl: 110cdf0e10cSrcweir Test.Exception() 111cdf0e10cSrcweir bOK = false 112cdf0e10cSrcweir resume next 113cdf0e10cSrcweirEnd Sub 114cdf0e10cSrcweir</script:module> 115