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="sd_SdDrawPage" script:language="StarBasic"> 4 5 6'************************************************************************* 7' 8' DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. 9' 10' Copyright 2000, 2010 Oracle and/or its affiliates. 11' 12' OpenOffice.org - a multi-platform office productivity suite 13' 14' This file is part of OpenOffice.org. 15' 16' OpenOffice.org is free software: you can redistribute it and/or modify 17' it under the terms of the GNU Lesser General Public License version 3 18' only, as published by the Free Software Foundation. 19' 20' OpenOffice.org is distributed in the hope that it will be useful, 21' but WITHOUT ANY WARRANTY; without even the implied warranty of 22' MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 23' GNU Lesser General Public License version 3 for more details 24' (a copy is included in the LICENSE file that accompanied this code). 25' 26' You should have received a copy of the GNU Lesser General Public License 27' version 3 along with OpenOffice.org. If not, see 28' <http://www.openoffice.org/license.html> 29' for a copy of the LGPLv3 License. 30' 31'************************************************************************* 32***** 33'************************************************************************* 34 35 36 37 38' REQUIRED VARIABLES for interface/service tests: 39Global oXShapeInstance As Object 40Global oGrouperCollection AS Object 41Global oCombinerCollection As Object 42Global oBinderCollection As Object 43 44 45Sub CreateObj() 46 47'************************************************************************* 48' COMPONENT: 49' sd.SdDrawPage 50'************************************************************************* 51On Error Goto ErrHndl 52 53 Dim bOK As Boolean 54 bOK = true 55 56 oDoc = utils.createDocument("sdraw", cObjectName) 57 58 oXShapeInstance = oDoc.createInstance("com.sun.star.drawing.RectangleShape") 59 60 oObj = oDoc.DrawPages.getByIndex(0) 61 oGrouperCollection = createUNOService("com.sun.star.drawing.ShapeCollection") 62 oCombinerCollection = createUNOService("com.sun.star.drawing.ShapeCollection") 63 oBinderCollection = createUNOService("com.sun.star.drawing.ShapeCollection") 64 65 addShape(oObj, 1000, 1000) 66 addShape(oObj, 5000, 5000) 67 addShape(oObj, 2000, 2000) 68 addShape(oObj, 3000, 3000) 69 addShape(oObj, 4000, 4000) 70 addShape(oObj, 5000, 5000) 71 addShape(oObj, 6000, 6000) 72 addShape(oObj, 7000, 7000) 73 74 oGrouperCollection.Add(oObj.getByIndex(0)) 75 oGrouperCollection.Add(oObj.getByIndex(1)) 76 oCombinerCollection.Add(oObj.getByIndex(2)) 77 oCombinerCollection.Add(oObj.getByIndex(3)) 78 oBinderCollection.Add(oObj.getByIndex(4)) 79 oBinderCollection.Add(oObj.getByIndex(5)) 80 81 82Exit Sub 83ErrHndl: 84 Test.Exception() 85End Sub 86 87sub AddShape(oPage as Object, nPosX as Integer, nPosY as Integer) 88 Dim aPoint As New com.sun.star.awt.Point 89 Dim aSize As New com.sun.star.awt.Size 90 Dim oRectangleShape As Object 91 92 aPoint.x = nPosX 93 aPoint.y = nPosY 94 aSize.Width = 10000 95 aSize.Height = 10000 96 oRectangleShape = oDoc.createInstance("com.sun.star.drawing.RectangleShape") 97 oRectangleShape.Size = aSize 98 oRectangleShape.Position = aPoint 99 oRectangleShape.FillColor = RGB(255, 0, 0) 100 oPage.add(oRectangleShape) 101End Sub 102 103Sub DisposeObj() 104 if hasUnoInterfaces(oDoc, "com.sun.star.lang.XComponent") then 105 oDoc.Dispose() 106 end if 107End Sub 108</script:module> 109