'************************************************************************* ' ' DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. ' ' Copyright 2008 by Sun Microsystems, Inc. ' ' OpenOffice.org - a multi-platform office productivity suite ' ' $RCSfile: forms_OHiddenModel.xba,v $ ' ' $Revision: 1.3 $ ' ' This file is part of OpenOffice.org. ' ' OpenOffice.org is free software: you can redistribute it and/or modify ' it under the terms of the GNU Lesser General Public License version 3 ' only, as published by the Free Software Foundation. ' ' OpenOffice.org is distributed in the hope that it will be useful, ' but WITHOUT ANY WARRANTY; without even the implied warranty of ' MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ' GNU Lesser General Public License version 3 for more details ' (a copy is included in the LICENSE file that accompanied this code). ' ' You should have received a copy of the GNU Lesser General Public License ' version 3 along with OpenOffice.org. If not, see ' ' for a copy of the LGPLv3 License. ' '************************************************************************* '************************************************************************* ' Be sure that all variables are dimensioned: option explicit ' REQUIRED VARIABLES for interface/service tests: ' for XComponent Global oComponentInstance As Object ' for XPersistObject Global oPersistInstance As Object Sub CreateObj() '************************************************************************* ' COMPONENT: ' forms.OHiddenModel '************************************************************************* On Error Goto ErrHndl Dim bOK As Boolean Dim oDrawPage As Object, oForm As Object bOK = true oDoc = utils.createDocument("swriter", cObjectName) addHiddenControl() addHiddenControl() addHiddenControl() addHiddenControl() addHiddenControl() 'get control from document oDrawPage = oDoc.DrawPage oForm = oDrawPage.Forms.getByIndex(0) 'for xComponent oComponentInstance = oForm.getByIndex(1) oPersistInstance = oForm.getByIndex(2) oObj = oForm.getByIndex(oForm.count - 1) Exit Sub ErrHndl: Test.Exception() End Sub Sub addHiddenControl() Dim oDrawPage as Object Dim oForm as Object, oForms as Object Dim oControl as Object, oControlShape as Object oDrawPage = oDoc.DrawPage oControlShape = oDoc.createInstance("com.sun.star.drawing.ControlShape") oControl = oDoc.createInstance("com.sun.star.form.component.HiddenControl") oForm = oDoc.createInstance("com.sun.star.form.component.Form") oforms = oDrawPage.Forms if oForms.count = 0 then oForm.Name = "Form1" oForms.insertbyindex(0,oForm) endif oForm = oForms.getByIndex(0) oForm.insertByIndex(oForm.count,oControl) End Sub