Wiki Ubuntu-it

Indice
Partecipa
FAQ
Wiki Blog
------------------
Ubuntu-it.org
Forum
Chiedi
Chat
Cerca
Planet
  • Pagina non alterabile
  • Informazioni
  • Allegati
  • Differenze per "Fcm/Edizione/GruppoC5"
Differenze tra le versioni 70 e 85 (in 15 versioni)
Versione 70 del 04/03/2012 15.21.36
Dimensione: 21870
Autore: MarcoBuono
Commento:
Versione 85 del 14/02/2013 14.06.51
Dimensione: 31772
Commento:
Le cancellazioni sono segnalate in questo modo. Le aggiunte sono segnalate in questo modo.
Linea 1: Linea 1:
## page was renamed from Fcm/Edizione/HowTo6
#acl GruppoAdmin:admin,read,write,revert GruppoOperatori:admin,read,write,revert GruppoEditori:read,write,revert CristianoLuinetti:admin,read,write,revert MarcoBuono:admin,read,write,revert AldoLatino:admin,read,write,revert PaoloGarbin:admin,read,write,revert GruppoFcm:read,write,revert -All:read -Known:read
#acl GruppoAdmin:admin,read,write,revert GruppoOperatori:admin,read,write,revert GruppoEditori:read,write,revert GruppoFcm:read,write,revert palombo:admin,read,write,revert new.life:admin,read,write,revert paolettopn:admin,read,write,revert Known:read All:read
Linea 4: Linea 4:
= Testo inglese =

LibreOffice Part 23: Base Form Enhancements with Macros

by Elmer Perry

For the previous four parts of this series, we have slowly built a database document using LibreOffice's Base module. We have a database with forms to enter our data, and queries and reports for extracting the data. We now have a usable document for recording our book library. However, our current design has one flaw we need to overcome. If we need to enter a new author or media type while we are in the books form, we have to close the book form and open one of the others. If we could enter new authors and media types directly from the books form, it would behave more like an application and make data entry even easier. We can accomplish this through a few short macros.
The LibreOffice Basic language is very similar to other Basic languages, such as Visual Basic for Applications. To manipulate the underlying LibreOffice document, we access the Uno framework controlling the document. The Uno framework is quite complex, but I will explain, as best I can, the properties and objects we will use. The goal is not to teach you how to write LibreOffice macros, but how you can use them.
Macro Security and Options

While macros allow us to do cool things in our documents, they can also cause problems. Some people use macros to compromise other people's systems, therefore, we need to take a few minutes to talk about macro security. Whether you are running LibreOffice on Linux, Mac, or Windows, malicious code in a macro can compromise your data and possibly your entire system.

Macro security in LibreOffice is simple. Tools > Options opens the Options dialog for LibreOffice. Under LibreOffice, select Security. Click on the Macro Security button to pop up the macro security options. You have four options. Never use the Low security option – it will run macros without asking you. I recommend the Medium security level. With this level, you are prompted whether to run the macros when you open a document containing macros. The High and Very High options require a certificate or folder you designate as trusted. While this is great, I believe nothing trumps the instincts of the user. You usually know whether you were expecting a document to contain macros. When in doubt, click No. Click OK to save your choice and OK to close the options dialog.
Now, on to the fun stuff.
The Macros

We will write four macros for our database document. Three will deal with opening forms, and the last will update the list boxes for authors and media types. The general idea behind macros is to accomplish tasks that are not built into the program, or to simplify complex tasks. Our macros really accomplish both, as we will simplify the tasks of adding authors and media types and provide functionality not built into the program.
Before we can begin to write our macros, we need a container to hold them. Macros are contained in a module. Modules can live in the program itself or within a document. Since our macros are specific to our database file, we will embed them in the document. Macros embedded in a document are available only when the document is loaded. Macros contained in the program are available as long as the program is running.
Tools > Macros > Organize Macros > LibreOffice Basic. The LibreOffice Basic Macros dialog pops up. Select book.odb from the Macro from-list. Click the New button. A dialog pops up asking you for a name for the module. Name it FormCalls. Click OK. This brings up the LibreOffice macro editor. The macro comes with a default main subroutine. We will not use this subroutine. Highlight Sub main and End Sub and press the backspace key to delete them.
Our first macro is a generalized subroutine for opening a form. A generalized subroutine is written for reuse. We will call this routine twice from other routines we write. Type this subroutine into the editor:
{{{
Sub OpenAForm (FormName as String)
 Dim GetForm as Object
 GetForm = ThisDatabaseDocument.FormDocuments.GetByName(FormName)
 GetForm.Open
End Sub
}}}
The first line of the subroutine is called the signature. The signature determines how the subroutine is called. A signature starts with the keyword Sub, which defines this call as a subroutine. Next, the name of the subroutine. In our case, OpenAForm is the name of the subroutine. Finally in the parenthesis, we have the arguments used when calling this subroutine. In our case, we have a variable named FormName which is a type String. In the second line of the subroutine, Dim is another keyword. Dim initializes a variable as a type, and, optionally, a value. We define a variable named GetForm as a type Object. The third line assigns a value to the variable GetForm through a chain of commands in the Uno framework. ThisDatabaseDocument refers to the currently open database document. In our case, book.odb. FormDocuments is a collection of all the forms in the document. Finally, GetByName retrieves a specific form object from the collection. Notice, we pass the variable FormName from the signature to this method. Once the call is complete, the variable GetForm is the object of the form name passed to the subroutine. The fourth line calls the Open method of the form. On the fifth line, we tell Basic this is the end of the subroutine with the command End Sub.
We will call the OpenAform subroutine twice. Once to open the authors form, and once to open the media form. Add these two subroutines to your editor:
{{{
Sub OpenAuthorsForm(oEv As Object)
 OpenAForm("Authors")
End Sub

Sub OpenMediaForm(oEv As Object)
 OpenAForm("Media")
End Sub
}}}
The signature on these two subroutines are a little different. Since we will call them from a control within a form, we need to pass the object making the call as an argument, even though we do not use it. The argument oEv is a reference to the object making the call. We will use this to our advantage later, in the last subroutine, but here we do it because it is required. These two subroutines are pretty simple. We just make a call to OpenAForm passing the name of the form we want to open, Authors or Media.
The final subroutine deals with our problem of refreshing the data in the list boxes for authors and media when we add authors or media using the two subroutines above:
{{{
Sub ListRefresh(oEv as Object)
 oEv.source.model.Refresh
End Sub
}}}
Once again, since we will call this subroutine from a control, we need a reference to the control making the call. However, this time we will actually use the object. This subroutine makes a method call to the underlying model of the list box and refreshes the data in the list, thus updating our list of authors or media types.
Save your module and close the Basic editor.

Making Connections to Macros

At this point, our macros do nothing. We need to connect them to objects in our form to activate them when needed. First, we will connect the open form subroutines to buttons in our form, and then we will connect the ListRefresh to the list boxes.
In the database pane, click on Forms. Right-click the Books form and select edit. Add two push buttons to the form, one under the Authors table and another under the Media table. Right-click the button under the Authors table and select Control to bring up the buttons properties dialog. On the General tab, change the name to AddAuthors and the Label to Add Authors. On the Events tab, click the ellipses (…) button next to Execute Action – which brings up the Assign Action dialog. Click the Macro button to bring up the Macro Selector dialog. In the tree list under Library, select book.odb > Standard > FormCalls. Select OpenAuthorsForm from the Macro Name list and click OK. Click OK to close the Assign Action dialog. Close the buttons properties dialog.
Do the same with the button under the Media table, only name it AddMedia, make the label Add Media Type, and assign the macro OpenMediaForm to the Execute Action event.
Finally, we need to add the refresh subroutine to our list boxes. Right-click the Authors column in the authors table and select Column. On the Events tab, click the ellipse (…) button beside “When receiving focus”. In the Assign Action button, use the Macro button to assign the ListRefresh macro to the action. This will cause the list to update data from the Authors table when you click on a list box in the column.
Do the same for the Media column in the media table.
Save your changes to the Books form and close it.

Testing Your Changes

Any time we make changes to our forms, we will want to test them and make sure we got everything right, especially in cases where we have used macros. One simple typo could cause things to not work. Double-click the Books form to open it. Add a new book with an author and media type you have not added already. Click the Add Authors button to make sure it opens the form. Add some authors. Close the Authors form. Click on the authors dropdown list box and verify that the authors you added are there. Do the same test with the Add Media Type button and listbox.
Final Thoughts and References

Again, I would like to emphasize that writing macros in LibreOffice Basic is complex. Documentation is pretty sparse, but it is out there. If you are interested in taking up the challenge, here are some references to get you started:
LibreOffice Basic Guide: http://wiki.documentfoundation.org/images/d/dd/BasicGuide_OOo3.2.0.odt
Andrew Pitonyak's OpenOffice Macro Information: http://www.pitonyak.org/oo.php
You can find the macros used in this How-To on pastebin.com at http://pastebin.com/MU2Ztizi
Next time, we will move on to another part of the LibreOffice suite and explore the Math module.
Linea 7: Linea 74:
Nel mio ultimo articolo, ho parlato della creazione di stili in Calcc di LibreOffice. Questo mese vi mostrerò come preparare, analizzare e stampare il foglio di calcolo. Aggiungeremo intestazioni e piè di pagina al nostro foglio, utilizzeremo l'anteprima di stampa per esaminare come sarà il nostro foglio quando lo si stamperà, rivedere la finestra di dialogo di stampa e come influisce sulle ultime pagine stampate.

Rinominare i fogli

Quando si crea un nuovo file di foglio di calcolo, la pagina di lavoro predefinita inizia con tre fogli denominati Foglio1, Foglio2 e Foglio3. È possibile utilizzare questi nomi in altri posti nello stesso foglio, e noi li useremo per creare l'intestazione e il piè di pagina per il nostro foglio di calcolo di bilancio. Tuttavia i nomi predefiniti non danno molte informazioni, quindi li rinomineremo. I nomi trovano posto in schede schede nella finestra del programma in basso. Per rinominare un foglio fare clic destro sulla scheda e selezionare Rinomina foglio dal menu a comparsa. Verrà quindi visualizzata la finestra di dialogo Rinomina foglio. Digitate un nome significativo per il foglio, per esempio, "24 Febbraio 2012" e fate clic su OK.

Intestazioni e piè di pagina

Le intestazioni e i piè di pagina ci permettono di creare coerenza tra le pagine. Così facendo, se il foglio di lavoro cresce e si modifica, le celle vengono trascinate anche nelle parti nuove. Utilizzando le impostazioni di pagina è possibile creare lo stesso look per pagine multiple.
Aprire la finestra di dialogo delle impostazioni, Formato>Pagina. Fare clic sulla scheda Intestazione. Qui è possibile regolare i margini, la larghezza e l'altezza della zona interessata dall'intestazione. Consiglio di spuntare la casella di controllo Adatta altezza, altrimenti la vostra intestazione potrebbe risultare tagliata. Fare clic sul pulsante Modifica per aprire la finestra di dialogo dell'area di intestazione. Noterete che l'intestazione è divisa in tre aree, sinistra, centro e destra. Nella parte bassa noterete una barra degli strumenti. La barra degli strumenti consente di inserire i segnaposto nell'intestazione e formattare il testo. Per il foglio della contabilità metteremo qualcosa in ciascuna delle aree. Nell'area a sinistra scriveremo "Contabilità 2012". Nell'area centro inseriremo il nome del nostro foglio. Per inserire il nome del foglio, fate clic nella zona centrale ed eliminate qualsiasi contenuto già esistente e poi fate clic sul terzo pulsante della barra degli strumenti. l'operazione inserisce il nome che avete dato al foglio. Per la zona di destra, provvederemo ad inserire la data corrente. Fate clic nell'area di destra ed eliminate qualsiasi contenuto esistente. Il penultimo pulsante della barra degli strumenti inserirà la data corrente. Per cambiare il font, la dimensione, il colore, ecc, del testo evidenziate il testo in una qualsiasi delle aree e fate clic sul primo pulsante della barra degli strumenti. Questo fa comparire una finestra di dialogo dei caratteri, in cui è possibile modificare gli attributi del testo. Fate clic sul pulsante OK quando avrete terminaoto di modificare l'intestazione.

Si potrebbe voler anche separare la nostra intestazione dal resto del foglio con un bordo o un colore di sfondo. Possiamo farlo facendo clic sul pulsante Avanzate nella scheda Intestazione nella finestra di dialogo della pagina. Per il mio foglio ho appena inserito una linea da 0.50 pt in fondo.

La scheda piè di pagina è uguale alla scheda Intestazione, ma cerchiamo di mettere un po' di informazioni diverse nelle tre aree. Nella scheda Piè di pagina fate clic sul pulsante Modifica. Nella zona a sinistra inserite il nome del foglio utilizzando il terzo pulsante sulla barra degli strumenti come abbiamo fatto con l'area centrale dell'intestazione. Nella zona centrale, eliminate il contenuto presente e digitate la parola 'Pagina' e uno spazio. Fate clic sul quarto pulsante nella barra degli strumenti. Questo crea un segnaposto per il numero di pagina. Questo segnaposto viene incrementato per ogni pagina del foglio. Nell'area di destra, fate clic sull'ultimo pulsante della barra degli strumenti per inserire un segnaposto dell'ora corrente. Questo stamperà l'ora in cui si stampa il foglio. Avere la data e l'ora correnti sul foglio può rivelarsi utile quando si ha a che fare con revisioni e si ha bisogno di sapere qual è la più aggiornata. Come per l'intestazione, siamo in grado di modificare gli attributi del testo, mettendo in evidenza il testo che desiderate modificare facendo clic sul primo pulsante della barra degli strumenti. Fate clic su OK quando avete finito la modifica.
 
Per separare il piè di pagina dal resto del documento, si può utilizzare il pulsante Altro per creare un bordo o colore di sfondo. Io ho usato un bordo di 0.50 pt sulla parte superiore.

Nella nostra impostazione abbiamo usato tutti i pulsanti della finestra di dialogo relativa all'intestazione/piè di pagina ad eccezione di due. Il secondo pulsante inserisce il nome del file della cartella di lavoro mentre il quinto inserisce il numero totale di pagine.

Abbiamo finito di modificare l'impostazione della pagina. Fate clic su OK per chiudere la finestra di dialogo Imposta pagina.

Anteprima pagina

L'anteprima della pagina ci permette di effettuare le regolazioni finali per il nostro foglio prima della stampa. Con l'anteprima possiamo essere sicuri che tutto si adatti alla pagina nel modo desiderato ed che i dati vengano mostrati come previsto.

Per aprire l'anteprima della pagina, vai su File>Anteprima. La finestra corrente viene sostituita dalla finestra di anteprima della pagina. È possibile effettuare alcuni adeguamenti mentre si è in modalità di anteprima.

Il cursore che trovate nella barra degli strumenti è il fattore di scala. Ciò consente di rendere le celle più grandi o più piccole in modo da adattarle alla pagina nel modo desiderato. È possibile aumentare le dimensioni facendo clic sul segno più (+) o ridurrle facendo clic sul segno meno (-). È inoltre possibile fare clic e trascinare la maniglia di regolazione.

Il pulsante Formato pagina mostra la finestra di dialogo Stile di pagina. Qui puoi cambiare i margini di pagina globali, il colore di sfondo e fare le correzioni e modifiche all'intestazione e al piè di pagina. Due cose che non abbiamo ancora citato sono l'allineamento della tabella e l'ordine di stampa. Allineamento della tabella si trova nella scheda Pagina. Consente di centrare la tabella orizzontalmente, verticalmente o in entrambi i sensi. La scheda Foglio controlla l'ordine delle pagine ovvero come le celle vengono stampate sulla pagina. Ciò consente di rendere la vostra impaginazione dei dati con l'ordine e le modalità desiderate. Se si dispone di più colonne che possono stare su una pagina è possibile modificarle dall'impostazione di base a quella sinistra-destra e poi giù. È anche possibile impostare il numero di pagina all'inizio se necessitate di qualcosa di diverso da 1. È anche possibile specificare cosa stampare e cosa no. Infine è possibile anche qui regolare manualmente la scala.
 
L'anteprima della pagina mostra dei pulsanti per andare avanti e indietro nella pagina e saltare alla prima pagina o l'ultima pagina. Ci sono anche i pulsanti di zoom in/out per un esaminare più attentamente la pagina.
Il pulsante Margini dà la possibilità di regolare la pagina, l'intestazione, il piè di pagina e i margini delle colonne. Fate clic sul pulsante Margini per attivare la modalità margini. Le linee tratteggiate permettono di regolare manualmente i margini della pagina, dell'intestazione e del piè di pagina. I marcatori neri nella parte superiore consentono di regolare la larghezza delle colonne. Fate clic sul pulsante Margini per uscire dalla modalità margini.

Il tasto Chiudi anteprima esce dalla modalità di anteprima.

Stampa

Finalmente abbiamo completato tutta la nostra preparazione ed è il momento di stampare il nostro foglio. File>Stampa apre la finestra di dialogo della stampa. Nella scheda Generale è possibile selezionare la stampante. Fate clic sul pulsante Proprietà per le impostazioni specifiche della la stampante. È possibile scegliere di stampare solo i fogli selezionati, tutti i fogli o le celle selezionate. È inoltre possibile specificare se volete stampare tutte le pagine o solo le pagine selezionate. Se non avete voglia di riordinare le pagine dopo la stampa è anche possibile scegliere di stampare con l'ordine invertito. Si ha la possibilità di stampare più copie e di fascicolarle.
Nella scheda LibreOffice Calc è possibile scegliere di stampare o non stampare le pagine vuote. La scheda Layout di pagina dà opzioni per la stampa di più pagine su un foglio di carta, in quale ordine stamparle e se mettere un bordo intorno alla pagina. Nella scheda Opzioni, è possibile scegliere di stampare il tutto in un file PostScript e, se si stampano più copie, se farlo come un unico lavoro o multipli lavori di stampa.

Dopo aver impostato tutto, fate clic su Stampa.

Potrebbe sembrare eccessivo per un singolo documento ma è necessario considerare sempre la frequenza con cui si intende utilizzare e modificare il documento. Se si utilizza il foglio spesso, come in un bilancio, una volta che l'intestazione e il piè di pagina vengono impostati, non dovrete mai più cambiarle. Considerando la riusabilità del documento si riduce il tempo di impostazione iniziale la prossima volta che lo si utilizza.
 
Il prossimo mese vedremo alcuni suggerimenti rapidi e dei trucchi per lavorare con fogli di calcolo in Calc.
======

Rapido parere

Staccate, spegnete e otterrete le cose fatte

By Allan Smithie

Ho spento Internet oggi. Non intendo dire 'tutto internet'. Intedo dire il mio accesso ad esso. Ho staccato il router.

Ho anche spento il mio lettore musicale e ho lasciato il cellulare in un'altra stanza.

Poi è successo qualcosa di mistico.
Concentrazione.

Io amo Internet. Ne sono probabilmente dipendente. È una risorsa enorme per informazione e ricerca senza precedenti, educativo nonchè una risorsa per l'intrattenimento, ma ogni tanto devo chiudere tutto fuori proprio per fare le cose.

Spegnere la TV, radio, iPod, Xbox, PSP e Wii. Chiudere i browser (entrambi), chiudere la stanza di chat, l'IRC, AIM, Facepunch, Twiddle e tutto ciò che è in esecuzione. Il controllo dei fatti può aspettare. Contrariamente a ciò che si crede, lo stato non deve essere aggiornato in tempo reale. Sarà tutto ancora lì. Dopo che avrete FATTO QUALCOSA.
Nelle precedenti quattro parti di questa serie abbiamo lentamente creato un documento di database usando il componente Base di LibreOffice. Abbiamo un database con i formulari per inserire i dati e con query e report per estrarli. Possiamo ora usare il documento per registrare i libri della nostra libreria. Comunque, l'attuale progettazone ha un difetto che dobbiamo superare. Se dobbiamo inserire un nuovo autore o media mentre siamo nel formulario di inserimento libri, siamo costretti a chiudere quest'ultimo per aprire uno degli altri due. Se potessimo inserire nuovi autori e media direttamente dal formulario libri, si comporterebbe più come una applicazione, rendendo ancora più facile l'inserimento dei dati. Possiamo raggiungere tale obiettivo attraverso poche brevi macro.
Il linguaggio Basic di LibreOffice è molto simili al Basic di altri linguaggi quali Visual Basic for Applications. Per manipolare il documento in parola, accediamo al framework UNO che controlla il documento. Il framework UNO è piuttosto complesso, ma vi spiegherò, meglio che posso, le proprietà e gli oggetti che useremo. L'obiettivo non è di insegnarvi come scrivere le macro LibreOffice, ma come poterle usare.
Opzioni di Sicurezza delle Macro
Sebbene le macro ci permettono di fare cose fantastiche nei documenti, possono anche causare problemi. Alcune persone le usano per compromettere i sistemi degli altri, perciò dobbiamo prenderci alcuni minuti per parlare della sicurezza delle macro. Sia che si esegua LibreOffice su Linux, che su Mac o Windows, il codice maligno in una macro può compromettere i propri dati e forse l'intero sistema.
In LibreOffice la sicurezza delle macro è semplice. In Strumenti > Opzioni si apre la finestra Opzioni per LibreOffice. Nella scheda LibreOffice selezionare Sicurezza. Fare clic sul pulsante 'Sicurezza delle macro...' per far apparire le opzioni sulla sicurezza delle macro. Ci sono quattro opzioni. Non usare mai l'opzione 'Basso', avvia le macro senza chiedercelo. Raccomando il livello 'Medio'. Con tale livello ci verrà richiesto se avviare le macro quando si apre un documento che le contiene. Le opzioni 'Alto' e 'Molto alto' richiedono un certificato o una cartella designata come affidabile. Sebbene è una gran cosa, credo che nulla batta l'istinto dell'utente. Generalmente sappiamo di aspettarci che un documento contenga o meno delle macro. Nel dubbio, fare clic su No. Fare clic su OK per salvare le scelte e nuovamente OK per chiudere la finestra.
Ora, addentriamoci nelle cose divertenti.
Le Macro
Scriveremo quattro macro per il nostro documento di database. Tre avranno a che fare con l'apertura dei formulari e l'ultimo aggiornerà le caselle di scelta per autori e media. L'idea di massima dietro alle macro è di svolgere i compiti che non sono integrati nel programma, o di semplificare i lavori complessi. Le nostre macro svolgeranno effettivamente entrambe le cose, poiché semplificheremo il compito di aggiungere autori e media e forniremo funzionalità non integrate nel programma.
Prima di poter iniziare a scrivere le macro, ci serve un contenitore per tenerle. Le macro sono contenute in un modulo. I moduli possono esistere nel programma stesso o all'interno del documento. Poiché le nostre macro sono specifiche per il nostro file di database, le integreremo nel documento. Le macro integrate nel documento sono disponibili soltanto quando viene caricato il documento stesso. Quelle contenute nel programma sono disponibili fintanto che il programma è in esecuzione.
Strumenti > Macro > Organizza macro > LibreOffice Basic farà apparire la finestra Macro LibreOffice Basic. Selezionare libri.odb dalla lista 'Macro da'. Fare clic sul pulsante 'Nuovo'. Comparirà una finestra di dialogo nella quale inserire il nome del modulo. Chiamarlo 'FormCalls' e premere OK. Ciò vi porterà all'editor per le macro di LibreOffice. La macro è fornita di una funzione principale predefinita. Non la useremo. Evidenziare Sub main e End Sub e premere il tasto backspace (←) per cancellarli.
La nostra prima macro è una funzione generalizzata per aprire un modulo. Una funzione generalizzata è scritta per il riuso. Richiameremo questa routine un paio di volte da altre routine che scriveremo. Digitare questa funzione nell'editor:
Sub OpenAForm (FormName as String)
    Dim GetForm as Object
    GetForm = ThisDatabaseDocument.FormDocuments.GetByName(FormName)
    GetForm.Open
End Sub
La prima riga della funzione è chiamata la firma. Essa determina il modo in cui chiamare la funzione stessa. La firma inizia con la parola chiave Sub, che definisce questa chiamata come funzione. Segue il nome della funzione. Nel nostro caso, è 'OpenAForm'. Infine, tra le parentesi, ci sono i parametri usati quando si chiama questa funzione. Nel nostro caso abbiamo una variabile di nome FormName che è di tipo String. Nella seconda riga, Dim è un'altra parola chiave che inizializza una variabile assegnandogli una tipologia e, opzionalmente, un valore. Definiamo la variabile di nome GetForm come tipo Object. Nella terza riga viene assegnato un valore alla variabile GetForm attraverso una catena di comandi nel framework UNO. ThisDatabaseDocument si riferisce all'attuale documento di database aperto, nel nostro caso book.odb. FormDocuments è la collezione di tutti i formulari nel documento. Infine, GetByName recupera uno specifico oggetto formulario dalla collezione. Notare il passaggio della variabile FormName dalla firma a questo metodo. Una volta che la chiamata è completa, la variabile GetForm è l'oggetto con il nome del formulario passato alla funzione. La quarta riga chiama il metodo Open del modulo. Nella quinta riga diciamo a Basic che qui termina la funzione, con il comando End Sub.
Richiameremo la funzione OpenAForm un paio di volte. Una per aprire il formulario Autori e l'altra per aprire quello Media. Aggiungere queste due funzioni nell'editor:
Sub OpenAuthorsForm(oEv As Object)
    OpenAForm("Autori")
End Sub
Sub OpenMediaForm(oEv As Object)
    OpenAForm("Media")
End Sub
                                   
La firma di queste due funzioni è leggermente diversa. Poiché le invocheremo da un controllo all'interno del formulario, dovremo passargli come argomento l'oggetto che effettua la chiamata, anche se non lo usiamo. L'argomento oEv è un riferimento all'oggetto che effettua la chiamata. Lo useremo più tardi a nostro vantaggio, nell'ultima funzione, qui lo facciamo perché è necessario. Queste due funzioni sono abbastanza semplici. Effettuiamo solo una chiamata a OpenAForm passandogli il nome del formulario che vogliamo aprire, Autori o Media.
L'ultima funzione affronta il problema di ricaricare i dati nelle caselle di scelta per autori e media quando li aggiungiamo utilizzando le due funzioni di cui sopra:
Sub ListRefresh(oEv as Object)
        oEv.source.model.Refresh
End Sub
Di nuovo, dato che chiameremo questa funzione da un controllo, c'è bisogno di un riferimento al controllo che effettui la chiamata. Comunque, questa volta useremo effettivamente l'oggetto. Questa funzione fa una chiamata di metodo al modello di base della casella di scelta e rinnova i dati nella lista, quindi aggiorna la nostra lista di autori e media.
Salvare il modulo e chiudere l'editor Basic.
Effettuare Connessioni alle Macro
A questo punto, le macro non fanno nulla. Dobbiamo connetterle agli oggetti nei formulari per attivarle quando necessario. Innanzitutto, collegheremo ai pulsanti dei nostri formulari le funzioni che aprono i moduli e poi collegheremo la funzione ListRefresh alle caselle di scelta.
Fare clic su Formulari nel pannello Database. Clic con il tasto destro sul modulo Libri e selezionare Modifica. Aggiungere due pulsanti al modulo, uno sotto alla tabella Autori e l'altro sotto la tabella Media. Fare clic con il tasto destro sul pulsante sotto la tabella Autori e selezionare 'Campo di controllo...' per aprire le finestra delle proprietà del pulsante. Sulla scheda Generale, cambiare il nome in AddAuthors e la didascalia in 'Aggiungi Autori'. Sulla scheda Eventi, premere il pulsante ellittico (...) vicino a 'Eseguire Azione', che farà apparire la finestra 'Azione assegnata'. Premere il pulsante 'Macro...' per aprire la finestra 'Selettore Macro'. Nell'elenco ad albero sotto 'Libreria', selezionare libro.odb > Standard > FormCalls. Selezionare OpenAuthorsForm dalla lista 'Nome macro' e premere OK. Premere ancora OK per chiudere la finestra 'Assegna Azione'. Chiudere le finestra Proprietà del pulsante.
Fare la stessa cosa con il pulsante sotto la tabella Media, solo che il nome è AddMedia, la didascalia è 'Aggiungi Media' e si deve assegnare la macro OpenMediaForm all'evento Esegui azione.
Infine, si deve aggiungere la funzione ListRefresh alle caselle di scelta. Fare clic con il tasto destro sulla colonna Autori nella tabella autori e selezionare 'Colonna'. Sulla scheda Eventi, premere il pulsante ellittico (...) accanto a 'Al ricevimento del punto focale'. Usare il pulsante Macro, sotto ad 'Assegna:', per assegnare la macro ListRefresh all'azione. Questo farà si che la lista aggiorni i dati dalla tabella Autori quando si fa clic su una casella di riepilogo nella colonna.
Fare la stessa cosa per la colonna Media nella tabella media.
Salvare i cambiamenti al modulo Libri e chiuderlo.
Verificare i cambiamenti
Ogni volta che effettuiamo dei cambiamenti ai nostri moduli, vorremmo verificarli per assicurarci che tutto sia corretto, specialmente nei casi in cui abbiamo utilizzato le macro. Un semplice errore di battitura potrebbe essere causa di malfunzionamenti. Fare doppio clic sul formulario Libri per aprirlo. Aggiungere un nuovo libro, un autore e un tipo di media non già presenti. Premere il pulsante 'Aggiungi Autori' per assicurarsi che apra il formulario. Aggiungere alcuni autori. Chiudere il formulario autori. Fare clic sulla casella a comparsa autori e verificare che ci siano gli autori aggiunti. Effettuare la stessa verifica con il pulsante 'Aggiungi Media' e la casella a comparsa.
Conclusioni e Riferimenti
Vorrei nuovamente enfatizzare il concetto che scrivere macro in LibreOffice Basic è complesso. La documentazione è abbastanza sparsa, ma è la fuori. Se siete interessati a raccogliere la sfida, qui ci sono alcuni riferimenti per iniziare:
LibreOffice Basic Guide: http://wiki.documentfoundation.org/images/d/dd/BasicGuide_OOo3.2.0.odt
Informazioni di Andrew Pitonyak su OpenOffice Macro: http://www.pitonyak.org/oo.php
Potete trovare le macro usate in questo tutorial su pastebin.com presso: http://pastebin.com/MU2Ztizi
La prossima volta ci sposteremo su un'altra parte della suite LibreOffice ed esploreremo il componente Math.
Linea 76: Linea 125:
Linea 79: Linea 127:
Nel mio ultimo articolo, ho parlato della creazione di stili in Calcc di LibreOffice. Questo mese vi mostrerò come preparare, analizzare e stampare il foglio di calcolo. Aggiungeremo intestazioni e piè di pagina al nostro foglio, utilizzeremo l'anteprima di stampa per esaminare come sarà il nostro foglio quando lo si stamperà, rivedere la finestra di dialogo di stampa e come influisce sulle ultime pagine stampate.

Rinominare i fogli

Quando si crea un nuovo file di foglio di calcolo, la pagina di lavoro predefinita inizia con tre fogli denominati Foglio1, Foglio2 e Foglio3. È possibile utilizzare questi nomi in altri posti nello stesso foglio, e noi li useremo per creare l'intestazione e il piè di pagina per il nostro foglio di calcolo di bilancio. Tuttavia i nomi predefiniti non danno molte informazioni, quindi li rinomineremo. I nomi trovano posto in schede schede nella finestra del programma in basso. Per rinominare un foglio fare clic destro sulla scheda e selezionare Rinomina foglio dal menu a comparsa. Verrà quindi visualizzata la finestra di dialogo Rinomina foglio. Digitate un nome significativo per il foglio, per esempio, "24 Febbraio 2012" e fate clic su OK.

Intestazioni e piè di pagina

Le intestazioni e i piè di pagina ci permettono di creare coerenza tra le pagine. Così facendo, se il foglio di lavoro cresce e si modifica, le celle vengono trascinate anche nelle parti nuove. Utilizzando le impostazioni di pagina è possibile creare lo stesso look per pagine multiple.
Aprire la finestra di dialogo delle impostazioni, Formato>Pagina. Fare clic sulla scheda Intestazione. Qui è possibile regolare i margini, la larghezza e l'altezza della zona interessata dall'intestazione. Consiglio di spuntare la casella di controllo Adatta altezza, altrimenti la vostra intestazione potrebbe risultare tagliata. Fare clic sul pulsante Modifica per aprire la finestra di dialogo dell'area di intestazione. Noterete che l'intestazione è divisa in tre aree, sinistra, centro e destra. Nella parte bassa noterete una barra degli strumenti. La barra degli strumenti consente di inserire i segnaposto nell'intestazione e formattare il testo. Per il foglio della contabilità metteremo qualcosa in ciascuna delle aree. Nell'area a sinistra scriveremo "Contabilità 2012". Nell'area centro inseriremo il nome del nostro foglio. Per inserire il nome del foglio, fate clic nella zona centrale ed eliminate qualsiasi contenuto già esistente e poi fate clic sul terzo pulsante della barra degli strumenti. l'operazione inserisce il nome che avete dato al foglio. Per la zona di destra, provvederemo ad inserire la data corrente. Fate clic nell'area di destra ed eliminate qualsiasi contenuto esistente. Il penultimo pulsante della barra degli strumenti inserirà la data corrente. Per cambiare il font, la dimensione, il colore, ecc, del testo evidenziate il testo in una qualsiasi delle aree e fate clic sul primo pulsante della barra degli strumenti. Questo fa comparire una finestra di dialogo dei caratteri, in cui è possibile modificare gli attributi del testo. Fate clic sul pulsante OK quando avrete terminaoto di modificare l'intestazione.

Si potrebbe voler anche separare la nostra intestazione dal resto del foglio con un bordo o un colore di sfondo. Possiamo farlo facendo clic sul pulsante Avanzate nella scheda Intestazione nella finestra di dialogo della pagina. Per il mio foglio ho appena inserito una linea da 0.50 pt in fondo.

La scheda piè di pagina è uguale alla scheda Intestazione, ma cerchiamo di mettere un po' di informazioni diverse nelle tre aree. Nella scheda Piè di pagina fate clic sul pulsante Modifica. Nella zona a sinistra inserite il nome del foglio utilizzando il terzo pulsante sulla barra degli strumenti come abbiamo fatto con l'area centrale dell'intestazione. Nella zona centrale, eliminate il contenuto presente e digitate la parola 'Pagina' e uno spazio. Fate clic sul quarto pulsante nella barra degli strumenti. Questo crea un segnaposto per il numero di pagina. Questo segnaposto viene incrementato per ogni pagina del foglio. Nell'area di destra, fate clic sull'ultimo pulsante della barra degli strumenti per inserire un segnaposto dell'ora corrente. Questo stamperà l'ora in cui si stampa il foglio. Avere la data e l'ora correnti sul foglio può rivelarsi utile quando si ha a che fare con revisioni e si ha bisogno di sapere qual è la più aggiornata. Come per l'intestazione, siamo in grado di modificare gli attributi del testo, mettendo in evidenza il testo che desiderate modificare facendo clic sul primo pulsante della barra degli strumenti. Fate clic su OK quando avete finito la modifica.
 
Per separare il piè di pagina dal resto del documento, si può utilizzare il pulsante Altro per creare un bordo o colore di sfondo. Io ho usato un bordo di 0.50 pt sulla parte superiore.

Nella nostra impostazione abbiamo usato tutti i pulsanti della finestra di dialogo relativa all'intestazione/piè di pagina ad eccezione di due. Il secondo pulsante inserisce il nome del file della cartella di lavoro mentre il quinto inserisce il numero totale di pagine.

Abbiamo finito di modificare l'impostazione della pagina. Fate clic su OK per chiudere la finestra di dialogo Imposta pagina.

Anteprima pagina

L'anteprima della pagina ci permette di effettuare le regolazioni finali per il nostro foglio prima della stampa. Con l'anteprima possiamo essere sicuri che tutto si adatti alla pagina nel modo desiderato ed che i dati vengano mostrati come previsto.

Per aprire l'anteprima della pagina, vai su File>Anteprima. La finestra corrente viene sostituita dalla finestra di anteprima della pagina. È possibile effettuare alcuni adeguamenti mentre si è in modalità di anteprima.

Il cursore che trovate nella barra degli strumenti è il fattore di scala. Ciò consente di rendere le celle più grandi o più piccole in modo da adattarle alla pagina nel modo desiderato. È possibile aumentare le dimensioni facendo clic sul segno più (+) o ridurrle facendo clic sul segno meno (-). È inoltre possibile fare clic e trascinare la maniglia di regolazione.

Il pulsante Formato pagina mostra la finestra di dialogo Stile di pagina. Qui puoi cambiare i margini di pagina globali, il colore di sfondo e fare le correzioni e modifiche all'intestazione e al piè di pagina. Due cose che non abbiamo ancora citato sono l'allineamento della tabella e l'ordine di stampa. Allineamento della tabella si trova nella scheda Pagina. Consente di centrare la tabella orizzontalmente, verticalmente o in entrambi i sensi. La scheda Foglio controlla l'ordine delle pagine ovvero come le celle vengono stampate sulla pagina. Ciò consente di rendere la vostra impaginazione dei dati con l'ordine e le modalità desiderate. Se si dispone di più colonne che possono stare su una pagina è possibile modificarle dall'impostazione di base a quella sinistra-destra e poi giù. È anche possibile impostare il numero di pagina all'inizio se necessitate di qualcosa di diverso da 1. È anche possibile specificare cosa stampare e cosa no. Infine è possibile anche qui regolare manualmente la scala.
 
L'anteprima della pagina mostra dei pulsanti per andare avanti e indietro nella pagina e saltare alla prima pagina o l'ultima pagina. Ci sono anche i pulsanti di zoom in/out per un esaminare più attentamente la pagina.
Il pulsante Margini dà la possibilità di regolare la pagina, l'intestazione, il piè di pagina e i margini delle colonne. Fate clic sul pulsante Margini per attivare la modalità margini. Le linee tratteggiate permettono di regolare manualmente i margini della pagina, dell'intestazione e del piè di pagina. I marcatori neri nella parte superiore consentono di regolare la larghezza delle colonne. Fate clic sul pulsante Margini per uscire dalla modalità margini.

Il tasto Chiudi anteprima esce dalla modalità di anteprima.

Stampa

Finalmente abbiamo completato tutta la nostra preparazione ed è il momento di stampare il nostro foglio. File>Stampa apre la finestra di dialogo della stampa. Nella scheda Generale è possibile selezionare la stampante. Fate clic sul pulsante Proprietà per le impostazioni specifiche della la stampante. È possibile scegliere di stampare solo i fogli selezionati, tutti i fogli o le celle selezionate. È inoltre possibile specificare se volete stampare tutte le pagine o solo le pagine selezionate. Se non avete voglia di riordinare le pagine dopo la stampa è anche possibile scegliere di stampare con l'ordine invertito. Si ha la possibilità di stampare più copie e di fascicolarle.
Nella scheda LibreOffice Calc è possibile scegliere di stampare o non stampare le pagine vuote. La scheda Layout di pagina dà opzioni per la stampa di più pagine su un foglio di carta, in quale ordine stamparle e se mettere un bordo intorno alla pagina. Nella scheda Opzioni, è possibile scegliere di stampare il tutto in un file PostScript e, se si stampano più copie, se farlo come un unico lavoro o multipli lavori di stampa.

Dopo aver impostato tutto, fate clic su Stampa.

Potrebbe sembrare eccessivo per un singolo documento ma è necessario considerare sempre la frequenza con cui si intende utilizzare e modificare il documento. Se si utilizza il foglio spesso, come in un bilancio, una volta che l'intestazione e il piè di pagina vengono impostati, non dovrete mai più cambiarle. Considerando la riusabilità del documento si riduce il tempo di impostazione iniziale la prossima volta che lo si utilizza.
 
Il prossimo mese vedremo alcuni suggerimenti rapidi e dei trucchi per lavorare con fogli di calcolo in Calc.
======

Rapido parere

Staccate, spegnete e otterrete le cose fatte

By Allan Smithie

Ho spento Internet oggi. Non intendo dire 'tutto internet'. Intedo dire il mio accesso ad esso. Ho staccato il router.

Ho anche spento il mio lettore musicale e ho lasciato il cellulare in un'altra stanza.

Poi è successo qualcosa di mistico.
Concentrazione.

Io amo Internet. Ne sono probabilmente dipendente. È una risorsa enorme per informazione e ricerca senza precedenti, educativo nonchè una risorsa per l'intrattenimento, ma ogni tanto devo chiudere tutto fuori proprio per fare le cose.

Spegnere la TV, radio, iPod, Xbox, PSP e Wii. Chiudere i browser (entrambi), chiudere la stanza di chat, l'IRC, AIM, Facepunch, Twiddle e tutto ciò che è in esecuzione. Il controllo dei fatti può aspettare. Contrariamente a ciò che si crede, lo stato non deve essere aggiornato in tempo reale. Sarà tutto ancora lì. Dopo che avrete FATTO QUALCOSA.
Nelle precedenti quattro parti di questa serie abbiamo lentamente creato un documento di database usando il componente Base di LibreOffice. Abbiamo un database con i formulari per inserire i dati e con query e report per estrarli. Possiamo ora usare il documento per registrare i libri della nostra libreria. Comunque, l'attuale progettazone ha un difetto che dobbiamo superare. Se dobbiamo inserire un nuovo autore o media mentre siamo nel formulario di inserimento libri, siamo costretti a chiudere quest'ultimo per aprire uno degli altri due. Se potessimo inserire nuovi autori e media direttamente dal formulario libri, si comporterebbe più come una applicazione, rendendo ancora più facile l'inserimento dei dati. Possiamo raggiungere tale obiettivo attraverso poche brevi macro.
Il linguaggio Basic di LibreOffice è molto simili al Basic di altri linguaggi quali Visual Basic for Applications. Per manipolare il documento in parola, accediamo al framework UNO che controlla il documento. Il framework UNO è piuttosto complesso, ma vi spiegherò, meglio che posso, le proprietà e gli oggetti che useremo. L'obiettivo non è di insegnarvi come scrivere le macro LibreOffice, ma come poterle usare.
Opzioni di Sicurezza delle Macro
Sebbene le macro ci permettono di fare cose fantastiche nei documenti, possono anche causare problemi. Alcune persone le usano per compromettere i sistemi degli altri, perciò dobbiamo prenderci alcuni minuti per parlare della sicurezza delle macro. Sia che si esegua LibreOffice su Linux, che su Mac o Windows, il codice maligno in una macro può compromettere i propri dati e forse l'intero sistema.
In LibreOffice la sicurezza delle macro è semplice. In Strumenti > Opzioni si apre la finestra Opzioni per LibreOffice. Nella scheda LibreOffice selezionare Sicurezza. Fare clic sul pulsante 'Sicurezza delle macro...' per far apparire le opzioni sulla sicurezza delle macro. Ci sono quattro opzioni. Non usare mai l'opzione 'Basso', avvia le macro senza chiedercelo. Raccomando il livello 'Medio'. Con tale livello ci verrà richiesto se avviare le macro quando si apre un documento che le contiene. Le opzioni 'Alto' e 'Molto alto' richiedono un certificato o una cartella designata come affidabile. Sebbene è una gran cosa, credo che nulla batta l'istinto dell'utente. Generalmente sappiamo di aspettarci che un documento contenga o meno delle macro. Nel dubbio, fare clic su No. Fare clic su OK per salvare le scelte e nuovamente OK per chiudere la finestra.
Ora, addentriamoci nelle cose divertenti.
Le Macro
Scriveremo quattro macro per il nostro documento di database. Tre avranno a che fare con l'apertura dei formulari e l'ultimo aggiornerà le caselle di scelta per autori e media. L'idea di massima dietro alle macro è di svolgere i compiti che non sono integrati nel programma, o di semplificare i lavori complessi. Le nostre macro svolgeranno effettivamente entrambe le cose, poiché semplificheremo il compito di aggiungere autori e media e forniremo funzionalità non integrate nel programma.
Prima di poter iniziare a scrivere le macro, ci serve un contenitore per tenerle. Le macro sono contenute in un modulo. I moduli possono esistere nel programma stesso o all'interno del documento. Poiché le nostre macro sono specifiche per il nostro file di database, le integreremo nel documento. Le macro integrate nel documento sono disponibili soltanto quando viene caricato il documento stesso. Quelle contenute nel programma sono disponibili fintanto che il programma è in esecuzione.
Strumenti > Macro > Organizza macro > LibreOffice Basic farà apparire la finestra Macro LibreOffice Basic. Selezionare libri.odb dalla lista 'Macro da'. Fare clic sul pulsante 'Nuovo'. Comparirà una finestra di dialogo nella quale inserire il nome del modulo. Chiamarlo 'FormCalls' e premere OK. Ciò vi porterà all'editor per le macro di LibreOffice. La macro è fornita di una funzione principale predefinita. Non la useremo. Evidenziare Sub main e End Sub e premere il tasto backspace (←) per cancellarli.
La nostra prima macro è una funzione generalizzata per aprire un modulo. Una funzione generalizzata è scritta per il riuso. Richiameremo questa routine un paio di volte da altre routine che scriveremo. Digitare questa funzione nell'editor:
Sub OpenAForm (FormName as String)
    Dim GetForm as Object
    GetForm = ThisDatabaseDocument.FormDocuments.GetByName(FormName)
    GetForm.Open
End Sub
La prima riga della funzione è chiamata la firma. Essa determina il modo in cui chiamare la funzione stessa. La firma inizia con la parola chiave Sub, che definisce questa chiamata come funzione. Segue il nome della funzione. Nel nostro caso, è 'OpenAForm'. Infine, tra le parentesi, ci sono i parametri usati quando si chiama questa funzione. Nel nostro caso abbiamo una variabile di nome FormName che è di tipo String. Nella seconda riga, Dim è un'altra parola chiave che inizializza una variabile assegnandogli una tipologia e, opzionalmente, un valore. Definiamo la variabile di nome GetForm come tipo Object. Nella terza riga viene assegnato un valore alla variabile GetForm attraverso una catena di comandi nel framework UNO. ThisDatabaseDocument si riferisce all'attuale documento di database aperto, nel nostro caso book.odb. FormDocuments è la collezione di tutti i formulari nel documento. Infine, GetByName recupera uno specifico oggetto formulario dalla collezione. Notare il passaggio della variabile FormName dalla firma a questo metodo. Una volta che la chiamata è completa, la variabile GetForm è l'oggetto con il nome del formulario passato alla funzione. La quarta riga chiama il metodo Open del modulo. Nella quinta riga diciamo a Basic che qui termina la funzione, con il comando End Sub.
Richiameremo la funzione OpenAForm un paio di volte. Una per aprire il formulario Autori e l'altra per aprire quello Media. Aggiungere queste due funzioni nell'editor:
Sub OpenAuthorsForm(oEv As Object)
    OpenAForm("Autori")
End Sub
Sub OpenMediaForm(oEv As Object)
    OpenAForm("Media")
End Sub
                                   
La firma di queste due funzioni è leggermente diversa. Poiché le invocheremo da un controllo all'interno del formulario, dovremo passargli come argomento l'oggetto che effettua la chiamata, anche se non lo usiamo. L'argomento oEv è un riferimento all'oggetto che effettua la chiamata. Lo useremo più tardi a nostro vantaggio, nell'ultima funzione, qui lo facciamo perché è necessario. Queste due funzioni sono abbastanza semplici. Effettuiamo solo una chiamata a OpenAForm passandogli il nome del formulario che vogliamo aprire, Autori o Media.
L'ultima funzione affronta il problema di ricaricare i dati nelle caselle di scelta per autori e media quando li aggiungiamo utilizzando le due funzioni di cui sopra:
Sub ListRefresh(oEv as Object)
        oEv.source.model.Refresh
End Sub
Di nuovo, dato che chiameremo questa funzione da un controllo, c'è bisogno di un riferimento al controllo che effettui la chiamata. Comunque, questa volta useremo effettivamente l'oggetto. Questa funzione fa una chiamata di metodo al modello di base della casella di scelta e rinnova i dati nella lista, quindi aggiorna la nostra lista di autori e media.
Salvare il modulo e chiudere l'editor Basic.
Effettuare Connessioni alle Macro
A questo punto, le macro non fanno nulla. Dobbiamo connetterle agli oggetti nei formulari per attivarle quando necessario. Innanzitutto, collegheremo ai pulsanti dei nostri formulari le funzioni che aprono i moduli e poi collegheremo la funzione ListRefresh alle caselle di scelta.
Fare clic su Formulari nel pannello Database. Clic con il tasto destro sul modulo Libri e selezionare Modifica. Aggiungere due pulsanti al modulo, uno sotto alla tabella Autori e l'altro sotto la tabella Media. Fare clic con il tasto destro sul pulsante sotto la tabella Autori e selezionare 'Campo di controllo...' per aprire le finestra delle proprietà del pulsante. Sulla scheda Generale, cambiare il nome in AddAuthors e la didascalia in 'Aggiungi Autori'. Sulla scheda Eventi, premere il pulsante ellittico (...) vicino a 'Eseguire Azione', che farà apparire la finestra 'Azione assegnata'. Premere il pulsante 'Macro...' per aprire la finestra 'Selettore Macro'. Nell'elenco ad albero sotto 'Libreria', selezionare libro.odb > Standard > FormCalls. Selezionare OpenAuthorsForm dalla lista 'Nome macro' e premere OK. Premere ancora OK per chiudere la finestra 'Assegna Azione'. Chiudere le finestra Proprietà del pulsante.
Fare la stessa cosa con il pulsante sotto la tabella Media, solo che il nome è AddMedia, la didascalia è 'Aggiungi Media' e si deve assegnare la macro OpenMediaForm all'evento Esegui azione.
Infine, si deve aggiungere la funzione ListRefresh alle caselle di scelta. Fare clic con il tasto destro sulla colonna Autori nella tabella autori e selezionare 'Colonna'. Sulla scheda Eventi, premere il pulsante ellittico (...) accanto a 'Al ricevimento del punto focale'. Usare il pulsante Macro, sotto ad 'Assegna:', per assegnare la macro ListRefresh all'azione. Questo farà si che la lista aggiorni i dati dalla tabella Autori quando si fa clic su una casella di riepilogo nella colonna.
Fare la stessa cosa per la colonna Media nella tabella media.
Salvare i cambiamenti al modulo Libri e chiuderlo.
Verificare i cambiamenti
Ogni volta che effettuiamo dei cambiamenti ai nostri moduli, vorremmo verificarli per assicurarci che tutto sia corretto, specialmente nei casi in cui abbiamo utilizzato le macro. Un semplice errore di battitura potrebbe essere causa di malfunzionamenti. Fare doppio clic sul formulario Libri per aprirlo. Aggiungere un nuovo libro, un autore e un tipo di media non già presenti. Premere il pulsante 'Aggiungi Autori' per assicurarsi che apra il formulario. Aggiungere alcuni autori. Chiudere il formulario autori. Fare clic sulla casella a comparsa autori e verificare che ci siano gli autori aggiunti. Effettuare la stessa verifica con il pulsante 'Aggiungi Media' e la casella a comparsa.
Conclusioni e Riferimenti
Vorrei nuovamente enfatizzare il concetto che scrivere macro in LibreOffice Basic è complesso. La documentazione è abbastanza sparsa, ma è la fuori. Se siete interessati a raccogliere la sfida, qui ci sono alcuni riferimenti per iniziare:
LibreOffice Basic Guide: http://wiki.documentfoundation.org/images/d/dd/BasicGuide_OOo3.2.0.odt
Informazioni di Andrew Pitonyak su OpenOffice Macro: http://www.pitonyak.org/oo.php
Potete trovare le macro usate in questo tutorial su pastebin.com presso: http://pastebin.com/MU2Ztizi
La prossima volta ci sposteremo su un'altra parte della suite LibreOffice ed esploreremo il componente Math.
Linea 146: Linea 176:

Testo inglese

LibreOffice Part 23: Base Form Enhancements with Macros

by Elmer Perry

For the previous four parts of this series, we have slowly built a database document using LibreOffice's Base module. We have a database with forms to enter our data, and queries and reports for extracting the data. We now have a usable document for recording our book library. However, our current design has one flaw we need to overcome. If we need to enter a new author or media type while we are in the books form, we have to close the book form and open one of the others. If we could enter new authors and media types directly from the books form, it would behave more like an application and make data entry even easier. We can accomplish this through a few short macros. The LibreOffice Basic language is very similar to other Basic languages, such as Visual Basic for Applications. To manipulate the underlying LibreOffice document, we access the Uno framework controlling the document. The Uno framework is quite complex, but I will explain, as best I can, the properties and objects we will use. The goal is not to teach you how to write LibreOffice macros, but how you can use them. Macro Security and Options

While macros allow us to do cool things in our documents, they can also cause problems. Some people use macros to compromise other people's systems, therefore, we need to take a few minutes to talk about macro security. Whether you are running LibreOffice on Linux, Mac, or Windows, malicious code in a macro can compromise your data and possibly your entire system.

Macro security in LibreOffice is simple. Tools > Options opens the Options dialog for LibreOffice. Under LibreOffice, select Security. Click on the Macro Security button to pop up the macro security options. You have four options. Never use the Low security option – it will run macros without asking you. I recommend the Medium security level. With this level, you are prompted whether to run the macros when you open a document containing macros. The High and Very High options require a certificate or folder you designate as trusted. While this is great, I believe nothing trumps the instincts of the user. You usually know whether you were expecting a document to contain macros. When in doubt, click No. Click OK to save your choice and OK to close the options dialog. Now, on to the fun stuff. The Macros

We will write four macros for our database document. Three will deal with opening forms, and the last will update the list boxes for authors and media types. The general idea behind macros is to accomplish tasks that are not built into the program, or to simplify complex tasks. Our macros really accomplish both, as we will simplify the tasks of adding authors and media types and provide functionality not built into the program. Before we can begin to write our macros, we need a container to hold them. Macros are contained in a module. Modules can live in the program itself or within a document. Since our macros are specific to our database file, we will embed them in the document. Macros embedded in a document are available only when the document is loaded. Macros contained in the program are available as long as the program is running. Tools > Macros > Organize Macros > LibreOffice Basic. The LibreOffice Basic Macros dialog pops up. Select book.odb from the Macro from-list. Click the New button. A dialog pops up asking you for a name for the module. Name it FormCalls. Click OK. This brings up the LibreOffice macro editor. The macro comes with a default main subroutine. We will not use this subroutine. Highlight Sub main and End Sub and press the backspace key to delete them. Our first macro is a generalized subroutine for opening a form. A generalized subroutine is written for reuse. We will call this routine twice from other routines we write. Type this subroutine into the editor:

Sub OpenAForm (FormName as String)
        Dim GetForm as Object
        GetForm = ThisDatabaseDocument.FormDocuments.GetByName(FormName)
        GetForm.Open
End Sub

The first line of the subroutine is called the signature. The signature determines how the subroutine is called. A signature starts with the keyword Sub, which defines this call as a subroutine. Next, the name of the subroutine. In our case, OpenAForm is the name of the subroutine. Finally in the parenthesis, we have the arguments used when calling this subroutine. In our case, we have a variable named FormName which is a type String. In the second line of the subroutine, Dim is another keyword. Dim initializes a variable as a type, and, optionally, a value. We define a variable named GetForm as a type Object. The third line assigns a value to the variable GetForm through a chain of commands in the Uno framework. ThisDatabaseDocument refers to the currently open database document. In our case, book.odb. FormDocuments is a collection of all the forms in the document. Finally, GetByName retrieves a specific form object from the collection. Notice, we pass the variable FormName from the signature to this method. Once the call is complete, the variable GetForm is the object of the form name passed to the subroutine. The fourth line calls the Open method of the form. On the fifth line, we tell Basic this is the end of the subroutine with the command End Sub. We will call the OpenAform subroutine twice. Once to open the authors form, and once to open the media form. Add these two subroutines to your editor:

Sub OpenAuthorsForm(oEv As Object)
        OpenAForm("Authors")
End Sub

Sub OpenMediaForm(oEv As Object)
        OpenAForm("Media")
End Sub

The signature on these two subroutines are a little different. Since we will call them from a control within a form, we need to pass the object making the call as an argument, even though we do not use it. The argument oEv is a reference to the object making the call. We will use this to our advantage later, in the last subroutine, but here we do it because it is required. These two subroutines are pretty simple. We just make a call to OpenAForm passing the name of the form we want to open, Authors or Media. The final subroutine deals with our problem of refreshing the data in the list boxes for authors and media when we add authors or media using the two subroutines above:

Sub ListRefresh(oEv as Object)
        oEv.source.model.Refresh
End Sub

Once again, since we will call this subroutine from a control, we need a reference to the control making the call. However, this time we will actually use the object. This subroutine makes a method call to the underlying model of the list box and refreshes the data in the list, thus updating our list of authors or media types. Save your module and close the Basic editor.

Making Connections to Macros

At this point, our macros do nothing. We need to connect them to objects in our form to activate them when needed. First, we will connect the open form subroutines to buttons in our form, and then we will connect the ListRefresh to the list boxes. In the database pane, click on Forms. Right-click the Books form and select edit. Add two push buttons to the form, one under the Authors table and another under the Media table. Right-click the button under the Authors table and select Control to bring up the buttons properties dialog. On the General tab, change the name to AddAuthors and the Label to Add Authors. On the Events tab, click the ellipses (…) button next to Execute Action – which brings up the Assign Action dialog. Click the Macro button to bring up the Macro Selector dialog. In the tree list under Library, select book.odb > Standard > FormCalls. Select OpenAuthorsForm from the Macro Name list and click OK. Click OK to close the Assign Action dialog. Close the buttons properties dialog. Do the same with the button under the Media table, only name it AddMedia, make the label Add Media Type, and assign the macro OpenMediaForm to the Execute Action event. Finally, we need to add the refresh subroutine to our list boxes. Right-click the Authors column in the authors table and select Column. On the Events tab, click the ellipse (…) button beside “When receiving focus”. In the Assign Action button, use the Macro button to assign the ListRefresh macro to the action. This will cause the list to update data from the Authors table when you click on a list box in the column. Do the same for the Media column in the media table. Save your changes to the Books form and close it.

Testing Your Changes

Any time we make changes to our forms, we will want to test them and make sure we got everything right, especially in cases where we have used macros. One simple typo could cause things to not work. Double-click the Books form to open it. Add a new book with an author and media type you have not added already. Click the Add Authors button to make sure it opens the form. Add some authors. Close the Authors form. Click on the authors dropdown list box and verify that the authors you added are there. Do the same test with the Add Media Type button and listbox. Final Thoughts and References

Again, I would like to emphasize that writing macros in LibreOffice Basic is complex. Documentation is pretty sparse, but it is out there. If you are interested in taking up the challenge, here are some references to get you started: LibreOffice Basic Guide: http://wiki.documentfoundation.org/images/d/dd/BasicGuide_OOo3.2.0.odt Andrew Pitonyak's OpenOffice Macro Information: http://www.pitonyak.org/oo.php You can find the macros used in this How-To on pastebin.com at http://pastebin.com/MU2Ztizi Next time, we will move on to another part of the LibreOffice suite and explore the Math module.

Traduzione italiana

Nelle precedenti quattro parti di questa serie abbiamo lentamente creato un documento di database usando il componente Base di LibreOffice. Abbiamo un database con i formulari per inserire i dati e con query e report per estrarli. Possiamo ora usare il documento per registrare i libri della nostra libreria. Comunque, l'attuale progettazone ha un difetto che dobbiamo superare. Se dobbiamo inserire un nuovo autore o media mentre siamo nel formulario di inserimento libri, siamo costretti a chiudere quest'ultimo per aprire uno degli altri due. Se potessimo inserire nuovi autori e media direttamente dal formulario libri, si comporterebbe più come una applicazione, rendendo ancora più facile l'inserimento dei dati. Possiamo raggiungere tale obiettivo attraverso poche brevi macro. Il linguaggio Basic di LibreOffice è molto simili al Basic di altri linguaggi quali Visual Basic for Applications. Per manipolare il documento in parola, accediamo al framework UNO che controlla il documento. Il framework UNO è piuttosto complesso, ma vi spiegherò, meglio che posso, le proprietà e gli oggetti che useremo. L'obiettivo non è di insegnarvi come scrivere le macro LibreOffice, ma come poterle usare. Opzioni di Sicurezza delle Macro Sebbene le macro ci permettono di fare cose fantastiche nei documenti, possono anche causare problemi. Alcune persone le usano per compromettere i sistemi degli altri, perciò dobbiamo prenderci alcuni minuti per parlare della sicurezza delle macro. Sia che si esegua LibreOffice su Linux, che su Mac o Windows, il codice maligno in una macro può compromettere i propri dati e forse l'intero sistema. In LibreOffice la sicurezza delle macro è semplice. In Strumenti > Opzioni si apre la finestra Opzioni per LibreOffice. Nella scheda LibreOffice selezionare Sicurezza. Fare clic sul pulsante 'Sicurezza delle macro...' per far apparire le opzioni sulla sicurezza delle macro. Ci sono quattro opzioni. Non usare mai l'opzione 'Basso', avvia le macro senza chiedercelo. Raccomando il livello 'Medio'. Con tale livello ci verrà richiesto se avviare le macro quando si apre un documento che le contiene. Le opzioni 'Alto' e 'Molto alto' richiedono un certificato o una cartella designata come affidabile. Sebbene è una gran cosa, credo che nulla batta l'istinto dell'utente. Generalmente sappiamo di aspettarci che un documento contenga o meno delle macro. Nel dubbio, fare clic su No. Fare clic su OK per salvare le scelte e nuovamente OK per chiudere la finestra. Ora, addentriamoci nelle cose divertenti. Le Macro Scriveremo quattro macro per il nostro documento di database. Tre avranno a che fare con l'apertura dei formulari e l'ultimo aggiornerà le caselle di scelta per autori e media. L'idea di massima dietro alle macro è di svolgere i compiti che non sono integrati nel programma, o di semplificare i lavori complessi. Le nostre macro svolgeranno effettivamente entrambe le cose, poiché semplificheremo il compito di aggiungere autori e media e forniremo funzionalità non integrate nel programma. Prima di poter iniziare a scrivere le macro, ci serve un contenitore per tenerle. Le macro sono contenute in un modulo. I moduli possono esistere nel programma stesso o all'interno del documento. Poiché le nostre macro sono specifiche per il nostro file di database, le integreremo nel documento. Le macro integrate nel documento sono disponibili soltanto quando viene caricato il documento stesso. Quelle contenute nel programma sono disponibili fintanto che il programma è in esecuzione. Strumenti > Macro > Organizza macro > LibreOffice Basic farà apparire la finestra Macro LibreOffice Basic. Selezionare libri.odb dalla lista 'Macro da'. Fare clic sul pulsante 'Nuovo'. Comparirà una finestra di dialogo nella quale inserire il nome del modulo. Chiamarlo 'FormCalls' e premere OK. Ciò vi porterà all'editor per le macro di LibreOffice. La macro è fornita di una funzione principale predefinita. Non la useremo. Evidenziare Sub main e End Sub e premere il tasto backspace (←) per cancellarli. La nostra prima macro è una funzione generalizzata per aprire un modulo. Una funzione generalizzata è scritta per il riuso. Richiameremo questa routine un paio di volte da altre routine che scriveremo. Digitare questa funzione nell'editor: Sub OpenAForm (FormName as String)

End Sub La prima riga della funzione è chiamata la firma. Essa determina il modo in cui chiamare la funzione stessa. La firma inizia con la parola chiave Sub, che definisce questa chiamata come funzione. Segue il nome della funzione. Nel nostro caso, è 'OpenAForm'. Infine, tra le parentesi, ci sono i parametri usati quando si chiama questa funzione. Nel nostro caso abbiamo una variabile di nome FormName che è di tipo String. Nella seconda riga, Dim è un'altra parola chiave che inizializza una variabile assegnandogli una tipologia e, opzionalmente, un valore. Definiamo la variabile di nome GetForm come tipo Object. Nella terza riga viene assegnato un valore alla variabile GetForm attraverso una catena di comandi nel framework UNO. ThisDatabaseDocument si riferisce all'attuale documento di database aperto, nel nostro caso book.odb. FormDocuments è la collezione di tutti i formulari nel documento. Infine, GetByName recupera uno specifico oggetto formulario dalla collezione. Notare il passaggio della variabile FormName dalla firma a questo metodo. Una volta che la chiamata è completa, la variabile GetForm è l'oggetto con il nome del formulario passato alla funzione. La quarta riga chiama il metodo Open del modulo. Nella quinta riga diciamo a Basic che qui termina la funzione, con il comando End Sub. Richiameremo la funzione OpenAForm un paio di volte. Una per aprire il formulario Autori e l'altra per aprire quello Media. Aggiungere queste due funzioni nell'editor: Sub OpenAuthorsForm(oEv As Object)

  • OpenAForm("Autori")

End Sub Sub OpenMediaForm(oEv As Object)

  • OpenAForm("Media")

End Sub

La firma di queste due funzioni è leggermente diversa. Poiché le invocheremo da un controllo all'interno del formulario, dovremo passargli come argomento l'oggetto che effettua la chiamata, anche se non lo usiamo. L'argomento oEv è un riferimento all'oggetto che effettua la chiamata. Lo useremo più tardi a nostro vantaggio, nell'ultima funzione, qui lo facciamo perché è necessario. Queste due funzioni sono abbastanza semplici. Effettuiamo solo una chiamata a OpenAForm passandogli il nome del formulario che vogliamo aprire, Autori o Media. L'ultima funzione affronta il problema di ricaricare i dati nelle caselle di scelta per autori e media quando li aggiungiamo utilizzando le due funzioni di cui sopra: Sub ListRefresh(oEv as Object)

  • oEv.source.model.Refresh

End Sub Di nuovo, dato che chiameremo questa funzione da un controllo, c'è bisogno di un riferimento al controllo che effettui la chiamata. Comunque, questa volta useremo effettivamente l'oggetto. Questa funzione fa una chiamata di metodo al modello di base della casella di scelta e rinnova i dati nella lista, quindi aggiorna la nostra lista di autori e media. Salvare il modulo e chiudere l'editor Basic. Effettuare Connessioni alle Macro A questo punto, le macro non fanno nulla. Dobbiamo connetterle agli oggetti nei formulari per attivarle quando necessario. Innanzitutto, collegheremo ai pulsanti dei nostri formulari le funzioni che aprono i moduli e poi collegheremo la funzione ListRefresh alle caselle di scelta. Fare clic su Formulari nel pannello Database. Clic con il tasto destro sul modulo Libri e selezionare Modifica. Aggiungere due pulsanti al modulo, uno sotto alla tabella Autori e l'altro sotto la tabella Media. Fare clic con il tasto destro sul pulsante sotto la tabella Autori e selezionare 'Campo di controllo...' per aprire le finestra delle proprietà del pulsante. Sulla scheda Generale, cambiare il nome in AddAuthors e la didascalia in 'Aggiungi Autori'. Sulla scheda Eventi, premere il pulsante ellittico (...) vicino a 'Eseguire Azione', che farà apparire la finestra 'Azione assegnata'. Premere il pulsante 'Macro...' per aprire la finestra 'Selettore Macro'. Nell'elenco ad albero sotto 'Libreria', selezionare libro.odb > Standard > FormCalls. Selezionare OpenAuthorsForm dalla lista 'Nome macro' e premere OK. Premere ancora OK per chiudere la finestra 'Assegna Azione'. Chiudere le finestra Proprietà del pulsante. Fare la stessa cosa con il pulsante sotto la tabella Media, solo che il nome è AddMedia, la didascalia è 'Aggiungi Media' e si deve assegnare la macro OpenMediaForm all'evento Esegui azione. Infine, si deve aggiungere la funzione ListRefresh alle caselle di scelta. Fare clic con il tasto destro sulla colonna Autori nella tabella autori e selezionare 'Colonna'. Sulla scheda Eventi, premere il pulsante ellittico (...) accanto a 'Al ricevimento del punto focale'. Usare il pulsante Macro, sotto ad 'Assegna:', per assegnare la macro ListRefresh all'azione. Questo farà si che la lista aggiorni i dati dalla tabella Autori quando si fa clic su una casella di riepilogo nella colonna. Fare la stessa cosa per la colonna Media nella tabella media. Salvare i cambiamenti al modulo Libri e chiuderlo. Verificare i cambiamenti Ogni volta che effettuiamo dei cambiamenti ai nostri moduli, vorremmo verificarli per assicurarci che tutto sia corretto, specialmente nei casi in cui abbiamo utilizzato le macro. Un semplice errore di battitura potrebbe essere causa di malfunzionamenti. Fare doppio clic sul formulario Libri per aprirlo. Aggiungere un nuovo libro, un autore e un tipo di media non già presenti. Premere il pulsante 'Aggiungi Autori' per assicurarsi che apra il formulario. Aggiungere alcuni autori. Chiudere il formulario autori. Fare clic sulla casella a comparsa autori e verificare che ci siano gli autori aggiunti. Effettuare la stessa verifica con il pulsante 'Aggiungi Media' e la casella a comparsa. Conclusioni e Riferimenti Vorrei nuovamente enfatizzare il concetto che scrivere macro in LibreOffice Basic è complesso. La documentazione è abbastanza sparsa, ma è la fuori. Se siete interessati a raccogliere la sfida, qui ci sono alcuni riferimenti per iniziare: LibreOffice Basic Guide: http://wiki.documentfoundation.org/images/d/dd/BasicGuide_OOo3.2.0.odt Informazioni di Andrew Pitonyak su OpenOffice Macro: http://www.pitonyak.org/oo.php Potete trovare le macro usate in questo tutorial su pastebin.com presso: http://pastebin.com/MU2Ztizi La prossima volta ci sposteremo su un'altra parte della suite LibreOffice ed esploreremo il componente Math.

Note alla traduzione

Revisione

Nelle precedenti quattro parti di questa serie abbiamo lentamente creato un documento di database usando il componente Base di LibreOffice. Abbiamo un database con i formulari per inserire i dati e con query e report per estrarli. Possiamo ora usare il documento per registrare i libri della nostra libreria. Comunque, l'attuale progettazone ha un difetto che dobbiamo superare. Se dobbiamo inserire un nuovo autore o media mentre siamo nel formulario di inserimento libri, siamo costretti a chiudere quest'ultimo per aprire uno degli altri due. Se potessimo inserire nuovi autori e media direttamente dal formulario libri, si comporterebbe più come una applicazione, rendendo ancora più facile l'inserimento dei dati. Possiamo raggiungere tale obiettivo attraverso poche brevi macro. Il linguaggio Basic di LibreOffice è molto simili al Basic di altri linguaggi quali Visual Basic for Applications. Per manipolare il documento in parola, accediamo al framework UNO che controlla il documento. Il framework UNO è piuttosto complesso, ma vi spiegherò, meglio che posso, le proprietà e gli oggetti che useremo. L'obiettivo non è di insegnarvi come scrivere le macro LibreOffice, ma come poterle usare. Opzioni di Sicurezza delle Macro Sebbene le macro ci permettono di fare cose fantastiche nei documenti, possono anche causare problemi. Alcune persone le usano per compromettere i sistemi degli altri, perciò dobbiamo prenderci alcuni minuti per parlare della sicurezza delle macro. Sia che si esegua LibreOffice su Linux, che su Mac o Windows, il codice maligno in una macro può compromettere i propri dati e forse l'intero sistema. In LibreOffice la sicurezza delle macro è semplice. In Strumenti > Opzioni si apre la finestra Opzioni per LibreOffice. Nella scheda LibreOffice selezionare Sicurezza. Fare clic sul pulsante 'Sicurezza delle macro...' per far apparire le opzioni sulla sicurezza delle macro. Ci sono quattro opzioni. Non usare mai l'opzione 'Basso', avvia le macro senza chiedercelo. Raccomando il livello 'Medio'. Con tale livello ci verrà richiesto se avviare le macro quando si apre un documento che le contiene. Le opzioni 'Alto' e 'Molto alto' richiedono un certificato o una cartella designata come affidabile. Sebbene è una gran cosa, credo che nulla batta l'istinto dell'utente. Generalmente sappiamo di aspettarci che un documento contenga o meno delle macro. Nel dubbio, fare clic su No. Fare clic su OK per salvare le scelte e nuovamente OK per chiudere la finestra. Ora, addentriamoci nelle cose divertenti. Le Macro Scriveremo quattro macro per il nostro documento di database. Tre avranno a che fare con l'apertura dei formulari e l'ultimo aggiornerà le caselle di scelta per autori e media. L'idea di massima dietro alle macro è di svolgere i compiti che non sono integrati nel programma, o di semplificare i lavori complessi. Le nostre macro svolgeranno effettivamente entrambe le cose, poiché semplificheremo il compito di aggiungere autori e media e forniremo funzionalità non integrate nel programma. Prima di poter iniziare a scrivere le macro, ci serve un contenitore per tenerle. Le macro sono contenute in un modulo. I moduli possono esistere nel programma stesso o all'interno del documento. Poiché le nostre macro sono specifiche per il nostro file di database, le integreremo nel documento. Le macro integrate nel documento sono disponibili soltanto quando viene caricato il documento stesso. Quelle contenute nel programma sono disponibili fintanto che il programma è in esecuzione. Strumenti > Macro > Organizza macro > LibreOffice Basic farà apparire la finestra Macro LibreOffice Basic. Selezionare libri.odb dalla lista 'Macro da'. Fare clic sul pulsante 'Nuovo'. Comparirà una finestra di dialogo nella quale inserire il nome del modulo. Chiamarlo 'FormCalls' e premere OK. Ciò vi porterà all'editor per le macro di LibreOffice. La macro è fornita di una funzione principale predefinita. Non la useremo. Evidenziare Sub main e End Sub e premere il tasto backspace (←) per cancellarli. La nostra prima macro è una funzione generalizzata per aprire un modulo. Una funzione generalizzata è scritta per il riuso. Richiameremo questa routine un paio di volte da altre routine che scriveremo. Digitare questa funzione nell'editor: Sub OpenAForm (FormName as String)

End Sub La prima riga della funzione è chiamata la firma. Essa determina il modo in cui chiamare la funzione stessa. La firma inizia con la parola chiave Sub, che definisce questa chiamata come funzione. Segue il nome della funzione. Nel nostro caso, è 'OpenAForm'. Infine, tra le parentesi, ci sono i parametri usati quando si chiama questa funzione. Nel nostro caso abbiamo una variabile di nome FormName che è di tipo String. Nella seconda riga, Dim è un'altra parola chiave che inizializza una variabile assegnandogli una tipologia e, opzionalmente, un valore. Definiamo la variabile di nome GetForm come tipo Object. Nella terza riga viene assegnato un valore alla variabile GetForm attraverso una catena di comandi nel framework UNO. ThisDatabaseDocument si riferisce all'attuale documento di database aperto, nel nostro caso book.odb. FormDocuments è la collezione di tutti i formulari nel documento. Infine, GetByName recupera uno specifico oggetto formulario dalla collezione. Notare il passaggio della variabile FormName dalla firma a questo metodo. Una volta che la chiamata è completa, la variabile GetForm è l'oggetto con il nome del formulario passato alla funzione. La quarta riga chiama il metodo Open del modulo. Nella quinta riga diciamo a Basic che qui termina la funzione, con il comando End Sub. Richiameremo la funzione OpenAForm un paio di volte. Una per aprire il formulario Autori e l'altra per aprire quello Media. Aggiungere queste due funzioni nell'editor: Sub OpenAuthorsForm(oEv As Object)

  • OpenAForm("Autori")

End Sub Sub OpenMediaForm(oEv As Object)

  • OpenAForm("Media")

End Sub

La firma di queste due funzioni è leggermente diversa. Poiché le invocheremo da un controllo all'interno del formulario, dovremo passargli come argomento l'oggetto che effettua la chiamata, anche se non lo usiamo. L'argomento oEv è un riferimento all'oggetto che effettua la chiamata. Lo useremo più tardi a nostro vantaggio, nell'ultima funzione, qui lo facciamo perché è necessario. Queste due funzioni sono abbastanza semplici. Effettuiamo solo una chiamata a OpenAForm passandogli il nome del formulario che vogliamo aprire, Autori o Media. L'ultima funzione affronta il problema di ricaricare i dati nelle caselle di scelta per autori e media quando li aggiungiamo utilizzando le due funzioni di cui sopra: Sub ListRefresh(oEv as Object)

  • oEv.source.model.Refresh

End Sub Di nuovo, dato che chiameremo questa funzione da un controllo, c'è bisogno di un riferimento al controllo che effettui la chiamata. Comunque, questa volta useremo effettivamente l'oggetto. Questa funzione fa una chiamata di metodo al modello di base della casella di scelta e rinnova i dati nella lista, quindi aggiorna la nostra lista di autori e media. Salvare il modulo e chiudere l'editor Basic. Effettuare Connessioni alle Macro A questo punto, le macro non fanno nulla. Dobbiamo connetterle agli oggetti nei formulari per attivarle quando necessario. Innanzitutto, collegheremo ai pulsanti dei nostri formulari le funzioni che aprono i moduli e poi collegheremo la funzione ListRefresh alle caselle di scelta. Fare clic su Formulari nel pannello Database. Clic con il tasto destro sul modulo Libri e selezionare Modifica. Aggiungere due pulsanti al modulo, uno sotto alla tabella Autori e l'altro sotto la tabella Media. Fare clic con il tasto destro sul pulsante sotto la tabella Autori e selezionare 'Campo di controllo...' per aprire le finestra delle proprietà del pulsante. Sulla scheda Generale, cambiare il nome in AddAuthors e la didascalia in 'Aggiungi Autori'. Sulla scheda Eventi, premere il pulsante ellittico (...) vicino a 'Eseguire Azione', che farà apparire la finestra 'Azione assegnata'. Premere il pulsante 'Macro...' per aprire la finestra 'Selettore Macro'. Nell'elenco ad albero sotto 'Libreria', selezionare libro.odb > Standard > FormCalls. Selezionare OpenAuthorsForm dalla lista 'Nome macro' e premere OK. Premere ancora OK per chiudere la finestra 'Assegna Azione'. Chiudere le finestra Proprietà del pulsante. Fare la stessa cosa con il pulsante sotto la tabella Media, solo che il nome è AddMedia, la didascalia è 'Aggiungi Media' e si deve assegnare la macro OpenMediaForm all'evento Esegui azione. Infine, si deve aggiungere la funzione ListRefresh alle caselle di scelta. Fare clic con il tasto destro sulla colonna Autori nella tabella autori e selezionare 'Colonna'. Sulla scheda Eventi, premere il pulsante ellittico (...) accanto a 'Al ricevimento del punto focale'. Usare il pulsante Macro, sotto ad 'Assegna:', per assegnare la macro ListRefresh all'azione. Questo farà si che la lista aggiorni i dati dalla tabella Autori quando si fa clic su una casella di riepilogo nella colonna. Fare la stessa cosa per la colonna Media nella tabella media. Salvare i cambiamenti al modulo Libri e chiuderlo. Verificare i cambiamenti Ogni volta che effettuiamo dei cambiamenti ai nostri moduli, vorremmo verificarli per assicurarci che tutto sia corretto, specialmente nei casi in cui abbiamo utilizzato le macro. Un semplice errore di battitura potrebbe essere causa di malfunzionamenti. Fare doppio clic sul formulario Libri per aprirlo. Aggiungere un nuovo libro, un autore e un tipo di media non già presenti. Premere il pulsante 'Aggiungi Autori' per assicurarsi che apra il formulario. Aggiungere alcuni autori. Chiudere il formulario autori. Fare clic sulla casella a comparsa autori e verificare che ci siano gli autori aggiunti. Effettuare la stessa verifica con il pulsante 'Aggiungi Media' e la casella a comparsa. Conclusioni e Riferimenti Vorrei nuovamente enfatizzare il concetto che scrivere macro in LibreOffice Basic è complesso. La documentazione è abbastanza sparsa, ma è la fuori. Se siete interessati a raccogliere la sfida, qui ci sono alcuni riferimenti per iniziare: LibreOffice Basic Guide: http://wiki.documentfoundation.org/images/d/dd/BasicGuide_OOo3.2.0.odt Informazioni di Andrew Pitonyak su OpenOffice Macro: http://www.pitonyak.org/oo.php Potete trovare le macro usate in questo tutorial su pastebin.com presso: http://pastebin.com/MU2Ztizi La prossima volta ci sposteremo su un'altra parte della suite LibreOffice ed esploreremo il componente Math.

Note alla revisione

Errata Corrige


CategoryComunitaFcm