SFDocuments.FormDocument service

The FormDocument service allows to access form documents stored in Collabora Office Base documents.

Egy Base dokumentumban a meglévő űrlapdokumentumok a felhasználói felületen a Nézet - Űrlapok menüpont kiválasztásával tekinthetők meg. Minden űrlapdokumentum egy vagy több űrlapból állhat, beleértve a fő űrlapot és más alűrlapokat.

This service inherits methods and properties from the Document service and is often used alongside the Base and Database services.

tip

Refer to the Document service to learn more about methods and properties that can be used to manage Collabora Office documents.


Service invocation

Before using the FormDocument service the ScriptForge library needs to be loaded or imported:

note

• Basic macros require to load ScriptForge library using the following statement:
GlobalScope.BasicLibraries.loadLibrary("ScriptForge")

• Python scripts require an import from scriptforge module:
from scriptforge import CreateScriptService


A Basic nyelvben

A FormDocument service instance can be created by calling the method OpenFormDocument that exists both in the Base and Database services.

Az alábbi példa a UI szolgáltatást használja egy Base dokumentum megnyitásához, majd egy űrlapdokumentum lekérdezéséhez. Ebben a példában mind a Base dokumentum, mind az űrlap dokumentum megnyílik és megjelenik a képernyőn.


    Dim ui As Object, oBase As Object, oFormDoc As Object
    ui = CreateScriptService("UI")
    oBase = ui.OpenBaseDocument("C:\Documents\MyDatabase.odb")
    oFormDoc = oBase.OpenFormDocument("MyFormDocument")
    ' ...
    oFormDoc.CloseDocument()
  

The following example uses the Database service to open the form document. In this case, the Base file will not be opened and only the form document will be shown.


    Dim oDatabase As Object, oFormDoc As Object
    oDatabase = CreateScriptService("Database", "C:\Documents\MyDatabase.odb")
    oFormDoc = oDatabase.OpenFormDocument("MyFormDocument")
  
note

Calling OpenFormDocument for a form document that is already open will activate the document window and bring it to focus.


A Python nyelvben

The examples above can be translated to Python as follows:


    ui = CreateScriptService("UI")
    baseDoc = ui.OpenBaseDocument("C:\Documents\MyDatabase.odb")
    formDoc = baseDoc.OpenFormDocument("MyFormDocument")
    # ...
    formDoc.CloseDocument()
  

    database = CreateScriptService("Database", "C:\Documents\MyDatabase.odb")
    formDoc = database.OpenFormDocument("MyFormDocument")
  

List of Methods in the FormDocument Service

CloseDocument

Forms

PrintOut


CloseDocument

Closes the form document referred to by the FormDocument instance. Returns True if the form document was successfully closed.

Szintaxis:

svc.CloseDocument(): bool

Példa:

A Basic nyelvben

    oFormDoc.CloseDocument()
  
A Python nyelvben

    formDoc.CloseDocument()
  

Forms

Returns either an array with the names of the main forms contained in the form document or a Form service instance referring to a specific form.

Call this method without arguments to obtain a zero-based string array with the names of all forms contained in the form document.

Provide a form name or index as argument to obtain a Form service instance corresponding to the specified form.

note

A form document has at least one main form. More complex form documents may be composed of more than one form and sub-forms.


Szintaxis:

svc.Forms(): str[0..*]

svc.Forms(form: str): svc

svc.Forms(form: int): svc

Paraméterek:

űrlap: Ez az argumentum lehet egy karakterlánc, amely egy, az űrlapdokumentumban létező űrlap nevét tartalmazza, vagy a visszaadandó űrlap nulla alapú indexe. Ha ez az argumentum nem konkrét, akkor egy tömb adódik vissza az összes elérhető űrlap nevével.

Példa:

A Basic nyelvben

The following example checks if the form document contains a form named "MainForm":


    arrForms = oFormDoc.Forms()
    If SF_Array.Contains(arrForms, "MainForm") Then
        ' ...
    End If
  

The example below retrieves the form named "MainForm" and moves it to the last record:


    Dim oForm As Object
    oForm = oFormDoc.Forms("MainForm")
    oForm.MoveLast()
  
A Python nyelvben

    arrForms = formDoc.Forms()
    if "MainForm" in arrForms:
        # ...
  

    form = formDoc.Forms("MainForm")
    form.MoveLast()
  
tip

To learn more about form methods and properties, refer to the Form service help page.


PrintOut

This method sends the contents form document to the default printer or to the printer defined by the SetPrinter() method.

Returns True if the document was successfully sent to the printer.

Szintaxis:

svc.PrintOut(pages: str = "", copies: int = 1, printbackground: bool = true, printblankpages: bool = false, printevenpages: bool = true, printoddpages: bool = true, printimages: bool = true): bool

Paraméterek:

oldalak: A nyomtatandó oldalak karakterlánc formájában. Ezt az argumentumot ugyanúgy kell megadni, mint a felhasználói felületen (lásd Fájl - Nyomtatás párbeszédablak). Példa: "1-4;10;15-18". Az alapértelmezett érték egy üres karakterlánc "", amely az összes oldal kinyomtatását eredményezi.

copies: The number of copies to be printed (Default = 1).

printbackground: specifies whether the background image should be printed (Default = True).

printblankpages: specifies whether blank pages should be printed (Default = False).

printevenpages: specifies whether even pages should be printed (Default = True).

printoddpages: specifies whether odd pages should be printed (Default = True).

printimages: specifies whether images should be printed (Default = True).

Példa:

A Basic nyelvben

    oFormDoc.PrintOut("1-4", Copies := 2, PrintBackground := False)
  
A Python nyelvben

    formDoc.PrintOut("1-4", copies = 2, printbackground = False)
  
warning

All ScriptForge Basic routines or identifiers that are prefixed with an underscore character "_" are reserved for internal use. They are not meant be used in Basic macros or Python scripts.


Támogasson minket!