1<?xml version="1.0" encoding="UTF-8"?> 2<!DOCTYPE script:module PUBLIC "-//OpenOffice.org//DTD OfficeDocument 1.0//EN" "module.dtd"> 3<script:module xmlns:script="http://openoffice.org/2000/script" script:name="sc_ScPageObj" script:language="StarBasic"> 4 5'************************************************************************* 6' 7' DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. 8' 9' Copyright 2000, 2010 Oracle and/or its affiliates. 10' 11' OpenOffice.org - a multi-platform office productivity suite 12' 13' This file is part of OpenOffice.org. 14' 15' OpenOffice.org is free software: you can redistribute it and/or modify 16' it under the terms of the GNU Lesser General Public License version 3 17' only, as published by the Free Software Foundation. 18' 19' OpenOffice.org is distributed in the hope that it will be useful, 20' but WITHOUT ANY WARRANTY; without even the implied warranty of 21' MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 22' GNU Lesser General Public License version 3 for more details 23' (a copy is included in the LICENSE file that accompanied this code). 24' 25' You should have received a copy of the GNU Lesser General Public License 26' version 3 along with OpenOffice.org. If not, see 27' <http://www.openoffice.org/license.html> 28' for a copy of the LGPLv3 License. 29' 30'************************************************************************* 31***** 32'************************************************************************* 33 34 35 36' Be sure that all variables are dimensioned: 37option explicit 38 39 40' REQUIRED VARIABLES for interface/service tests: 41 42' "com::sun::star::drawing::XShapes" needs the following Global variables: 43Global oXShapeInstance As Object 44 45' "com::sun::star::drawing::XShapeGrouper" needs the following Global variables: 46Global oGrouperCollection As Object 47 48 49Sub CreateObj() 50 51'************************************************************************* 52' COMPONENT: 53' sc.ScPageObj 54'************************************************************************* 55On Error Goto ErrHndl 56 57 Dim bOK As Boolean 58 Dim oDP as Object 59 bOK = true 60 61 oDoc = utils.createDocument("scalc", cObjectName) 62 oGrouperCollection = createUNOService("com.sun.star.drawing.ShapeCollection") 63 64 oDP = oDoc.getDrawPages() 65 66 oDP.insertNewByIndex(0) 67 oDP.insertNewByIndex(1) 68 69 oObj = oDP.getByIndex(0) 70 addShape(oObj,1) 71 addShape(oObj,2) 72 addShape(oObj,3) 73 addShape(oObj,4) 74 75 oXShapeInstance = oDoc.createInstance("com.sun.star.drawing.RectangleShape") 76 oGrouperCollection.Add(oObj.getByIndex(2)) 77 oGrouperCollection.Add(oObj.getByIndex(3)) 78 79Exit Sub 80ErrHndl: 81 Test.Exception() 82End Sub 83 84Function addShape(oPage as Object, no as Integer) As Object 85On Error Goto ErrHndl 86 Dim aPoint As New com.sun.star.awt.Point 87 Dim aSize As New com.sun.star.awt.Size 88 Dim oShape As Object 89 Dim servNames As Variant 90 91 aPoint.x = 1000 * no 92 aPoint.y = 1000 * no 93 aSize.Width = 2000 94 aSize.Height = 1000 95 oShape = oDoc.createInstance("com.sun.star.drawing.RectangleShape") 96 oShape.Size = aSize 97 oShape.Position = aPoint 98 99 oPage.add(oShape) 100 101 addShapeToDrawDoc() = oShape 102Exit Function 103ErrHndl: 104 Test.Exception() 105End Function 106 107</script:module> 108