Difference between revisions of "Documentation/BASIC Guide/Working With Forms"

From Apache OpenOffice Wiki
Jump to: navigation, search
(Accessing the View of Control Element Forms)
(Accessing the Shape Object of Control Element Forms)
Line 126: Line 126:
 
The method for accessing the shape objects of a control element also uses the corresponding drawing level of the document. To determine a special control element, all drawing elements of the drawing level must be searched through.
 
The method for accessing the shape objects of a control element also uses the corresponding drawing level of the document. To determine a special control element, all drawing elements of the drawing level must be searched through.
  
 +
<source lang="vb">
 
  Dim Doc As Object
 
  Dim Doc As Object
 
  Dim Shape as Object
 
  Dim Shape as Object
Line 140: Line 141:
 
   End If
 
   End If
 
  Next
 
  Next
 +
</source>
  
 
The example checks all drawing elements to determine whether they support the <tt>com.sun.star.drawing.XControlShape</tt> interface needed for control element forms. If this is the case, the <tt>Control.Name</tt> property then checks whether the name of the control element is <tt>MyListBox</tt>. If this is true, the function ends the search.
 
The example checks all drawing elements to determine whether they support the <tt>com.sun.star.drawing.XControlShape</tt> interface needed for control element forms. If this is the case, the <tt>Control.Name</tt> property then checks whether the name of the control element is <tt>MyListBox</tt>. If this is true, the function ends the search.
Line 152: Line 154:
 
The following example shows how the position and size of a control element can be set using the associated shape object:
 
The following example shows how the position and size of a control element can be set using the associated shape object:
  
 +
<source lang="vb">
 
  Dim Shape As Object
 
  Dim Shape As Object
 
   
 
   
Line 161: Line 164:
 
  Shape.Size = Size
 
  Shape.Size = Size
 
  Shape.Position = Point
 
  Shape.Position = Point
 +
</source>
  
 
The <tt>shape</tt> object of the control element must already be known if the code is to function. If this is not the case, it must be determined using the preceding code.
 
The <tt>shape</tt> object of the control element must already be known if the code is to function. If this is not the case, it must be determined using the preceding code.
 
  
 
{{PDL1}}
 
{{PDL1}}

Revision as of 14:12, 13 March 2008


Apache OpenOffice forms may contain text fields, list boxes, radio buttons, and a range of other control elements, which are inserted directly in a text or spreadsheet. The Form FunctionsToolbar is used for editing forms.

A Apache OpenOffice form may adopt one of two modes: the draft mode and the display mode. In draft mode, the position of control elements can be changed and their properties can be edited using a properties window.

The Form Functions Toolbar is also used to switch between modes.

Determining Object Forms

Apache OpenOffice positions the control elements of a form at drawing object level. The actual object form can be accessed through the Forms list at drawing level. The objects are accessed as follows in text documents:

 Dim Doc As Object
 Dim DrawPage As Object
 Dim Form As Object
 
 Doc = StarDesktop.CurrentComponent
 DrawPage = Doc.DrawPage
 Form = DrawPage.Forms.GetByIndex(0)

The GetByIndex method returns the form with the index number 0.

When working with spreadsheets, an intermediate stage is needed the Sheets list because the drawing levels are not located directly in the document but in the individual sheets:

 Dim Doc As Object
 Dim Sheet As Object
 Dim DrawPage As Object
 Dim Form As Object
 
 Doc = StarDesktop.CurrentComponent
 Sheet = Doc.Sheets.GetByIndex(0)
 DrawPage = Sheet.DrawPage
 Form = DrawPage.Forms.GetByIndex(0)

As is already suggested by the GetByIndex method name, a document may contain several forms. This is useful, for example, if the contents of different databases are displayed within one document, or if a 1:n database relationship is displayed within a form. The option of creating sub-forms is also provided for this purpose.

The Three Aspects of a Control Element Form

A control element of a form has three aspects:

  • First, there is the Model of the control element. This is the key object for the Apache OpenOffice Basic-programmer when working with control element forms.
  • The counterpart to this is the View of the control element, which administers the display information.
  • Since control element forms within the documents are administered like a special drawing element, there is also a Shape object which reflects the drawing element-specific properties of the control element (in particular its position and size).

Accessing the Model of Control Element Forms

The models of the control elements of a form are available through the GetByName method of the Object form:

 Dim Doc As Object
 Dim Form As Object
 Dim Ctl As Object
 
 Doc = StarDesktop.CurrentComponent
 Form = Doc.DrawPage.Forms.GetByIndex(0)
 Ctl = Form.getByName("MyListBox")

The example determines the model of the MyListBox control element, which is located in the first form of the text document currently open.

If you is not sure of the form of a control element, you can use the option for searching through all forms for the control element required:

 Dim Doc As Object
 Dim Forms As Object
 Dim Form As Object
 Dim Ctl As Object
 Dim I as Integer
 
 Doc = StarDesktop.CurrentComponent
 Forms = Doc.Drawpage.Forms
 
 For I = 0 To Forms.Count - 1
   Form = Forms.GetbyIndex(I)
   If Form.HasByName("MyListBox") Then
     Ctl = Form.GetbyName("MyListBox")
     Exit Function
   End If
 Next I

The example uses the HasByName method to check all forms of a text document to determine whether they contain a control element model called MyListBox. If a corresponding model is found, then a reference to this is saved in the Ctl variable and the search is terminated.

Accessing the View of Control Element Forms

To access the view of a control element form, the associated model is first needed. The view of the control element can then be determined with the assistance of the model and using the document controller.

 Dim Doc As Object
 Dim DocCrl As Object
 Dim Forms As Object
 Dim Form As Object
 Dim Ctl As Object
 Dim CtlView As Object
 Dim I as Integer
 
 Doc = StarDesktop.CurrentComponent
 DocCrl = Doc.getCurrentControler()
 Forms = Doc.Drawpage.Forms
 
 For I = 0 To Forms.Count - 1
   Form = Forms.GetbyIndex(I)
   If Form.HasByName("MyListBox") Then
     Ctl = Form.GetbyName("MyListBox")
     CtlView = DocCrl.GetControl(Ctl)
     Exit Function
   End If
 Next I

The code listed in the example is very similar to the code listed in the previous example for determining a control element model. It uses not only the Doc document object but also the DocCrl document controller object which makes reference to the current document window. With the help of this controller object and the model of the control element, it then uses the GetControl method to determine the view (CtlView variable) of the control element form.

Accessing the Shape Object of Control Element Forms

The method for accessing the shape objects of a control element also uses the corresponding drawing level of the document. To determine a special control element, all drawing elements of the drawing level must be searched through.

 Dim Doc As Object
 Dim Shape as Object
 Dim I as integer
 
 Doc = StarDesktop.CurrentComponent
 
 For i = 0 to Doc.DrawPage.Count - 1
   Shape = Doc.DrawPage(i)
   If HasUnoInterfaces(Shape, "com.sun.star.drawing.XControlShape") Then
     If Shape.Control.Name = "MyListBox" Then
       Exit Function
     End If
   End If
 Next

The example checks all drawing elements to determine whether they support the com.sun.star.drawing.XControlShape interface needed for control element forms. If this is the case, the Control.Name property then checks whether the name of the control element is MyListBox. If this is true, the function ends the search.

Determining the Size and Position of Control Elements

As already mentioned, the size and position of control elements can be determined using the associated shape object. The control element shape, like all other shape objects, provides the Size and Position properties for this purpose:

Size (struct)
size of control element (com.sun.star.awt.Size data structure).
Position (struct)
position of control element (com.sun.star.awt.Point data structure).

The following example shows how the position and size of a control element can be set using the associated shape object:

 Dim Shape As Object
 
 Point.x = 1000
 Point.y = 1000
 Size.Width = 10000
 Size.Height = 10000
 
 Shape.Size = Size
 Shape.Position = Point

The shape object of the control element must already be known if the code is to function. If this is not the case, it must be determined using the preceding code.

Content on this page is licensed under the Public Documentation License (PDL).
Personal tools