Do you not need to stop and catch your breath? No? Well then, let's proceed with your fourth lesson — your first Script-Fu Script.
Una delle operazioni più comuni che si intraprendono in GIMP è la creazione di un rettangolo con del testo per una pagina web, un logo o altro. Tuttavia quando si comincia non si sa quanto far grande l'immagine iniziale. Non si sa quanto spazio occuperà il testo con il font e la dimensione del font che si desidera.
This problem can be solved and automated with Script-Fu.
Si creerà quindi uno script, intitolato Text Box, che crea un'immagine delle dimensioni corrette per contenere una linea di testo immessa dall'utente. Si consentirà inoltre all'utente di scegliere il font, la dimensione del font e il colore del testo.
Finora abbiamo lavorato nella console Script-Fu. Ora, tuttavia, passeremo alla modifica dei file di script. I file di script dovrebbero essere file di testo semplice, modificabili in un editor di testo o di codice. Il nome che si dà non è così importante, se non per poter riconoscere lo script. Si consiglia di assegnare al file di script l'estensione «.scm».
Where you place your scripts is a matter of preference. In GIMP's folder preferences you can see in which folders GIMP looks for scripts. It is also possible to add a new folder there. The folder where GIMP stores its own scripts is usually not the best choice for your scripts, but for the rest feel free to choose what suits you best.
Ogni script Script-Fu definisce almeno una funzione che è la funzione principale dello script. Questa è la funzione dove si fa il lavoro.
Ogni script deve registrarsi nel database delle procedure per poter risultare accessibile a GIMP.
Si definisca dapprima la funzione principale:
(define (script-fu-text-box inText inFont inFontSize inTextColor))
Here, we've defined a new function called
script-fu-text-box that
takes four parameters, which will later correspond to some text, a
font, the font size, and the text's color. The function is currently
empty and thus does nothing. So far, so good — nothing new,
nothing fancy.
Le convenzioni sui nomi di Scheme sembrano dare la preferenza a lettere minuscole con trattini, convenzione seguita nel dare il nome alla funzione. Tuttavia ci si è allontanati dalla convenzione con gli argomenti. Si sono preferiti nomi più descrittivi per argomenti e variabili e quindi si è aggiunto il prefisso "in" agli argomenti in modo da distinguerli rapidamente come argomenti passati allo script piuttosto che creati al suo interno. Si è usato il prefisso "the" per variabili definite all'interno dello script.
Fa parte di una convenzione di GIMP di denominare le funzioni degli script script-fu-abc, poiché quando vengono elencate nel database delle procedure sono tutte raggruppate sotto il prefisso script-fu. Ciò aiuta anche a distinguerle dai plug-in.
Reistrare ora la funzione in GIMP. Ciò si ottiene richiamando la funzione script-fu-register. Quando GIMP legge uno script, esegue questa funzione che registra lo script nel database delle procedure. Si può posizionare questa funzione in ogni parte dello script, ma di solito la si posiziona alla fine, dopo tutto il codice.
Ecco il listato per registrare questa funzione (si chiariranno a breve gli argomenti):
(script-fu-register
"script-fu-text-box" ;function name
"Text Box" ;menu label
"Creates a simple text box, sized to fit\
around the user's choice of text,\
font, font size, and color." ;description
"Michael Terry" ;author
"copyright 1997, Michael Terry;\
2009, the GIMP Documentation Team" ;copyright notice
"October 27, 1997" ;date created
"" ;image type that the script works on
SF-STRING "Text" "Text Box" ;a string variable
SF-FONT "Font" "Charter" ;a font variable
SF-ADJUSTMENT "Font size" '(50 1 1000 1 10 0 1)
;a spin-button
SF-COLOR "Color" '(0 0 0) ;color variable
)
(script-fu-menu-register "script-fu-text-box" "<Image>/Filters/Tutorial")
Salvare queste funzioni in un file di testo con suffisso .scm in una sottocartella della propria cartella degli script, con lo stesso nome del file script, poi riavviare GIMP. Il nuovo script apparirà come → → .
Se si invoca questo nuovo script naturalmente non succede nulla, ma si possono osservare le richieste di parametri definite quando si registra lo script (ulteriori informazioni più avanti).
Infine, se si richiama il Navigatore di procedure ( → ), si noterà che lo script ora appare nel database.
Per registrare lo script in GIMP si richiama la funzione script-fu-register, passando i sette parametri richiesti e aggiungendo gli argomenti dello script insieme con una descrizione e un valore predefinito per ciascun argomento.
Gli argomenti richiesti
Il nome della funzione definita. Questa è la funzione che viene chiamata quando si invoca lo script (il punto di entrata). È obbligatoria perché si possono definire altre funzioni all'interno dello stesso file e GIMP deve sapere quale tra queste funzioni richiamare. Nell'esempio si è definita solo una funzione, text-box, che è stata registrata.
L'etichetta di menu è il nome che verrà visualizzato nel menu. Per specificare la posizione, vedere Sezione 3.4.9, «Registrare la posizione di menu».
Una descrizione dello script che viene visualizzata nel Navigatore delle procedure.
Un nome autore (l'autore dello script).
Informazioni sul Copyright.
La data di creazione dello script o quella della sua ultima revisione.
The types of images the script works on. This may be any of the following: RGB, RGBA, GRAY, GRAYA, INDEXED, INDEXEDA. Or it may be none at all — in our case, we're creating an image, and thus don't need to define the type of image on which we work.
Dopo aver elencato gli argomenti necessari occorre elencare gli argomenti che corrispondono a quelli necessari al nostro script. Quando si elencano questi argomenti si danno indicazioni sui loro tipi, questo serve per la finestra di dialogo che compare quando l'utente seleziona lo script. Si deve anche fornire un valore predefinito.
Questa sezione del processo di registrazione ha il seguente formato:
|
Tipo argomento |
Descrizione |
Esempio |
|---|---|---|
|
|
Se lo script opera su un'immagine già aperta, questo dovrebbe essere il primo argomento dopo quelli richiesti. GIMP passa un riferimento all'immagine in questo parametro. |
3 |
|
|
Se lo script opera su un'immagine aperta questo dovrebbe essere il secondo argomento dopo |
17 |
|
|
Accetta stringhe. |
"Del testo" |
|
|
Indica che questo argomento richiede un colore. |
'(0 102 255) |
|
|
Viene mostrata una casella di scelta per richiedere un valore booleano. |
TRUE o FALSE (vero o falso) |
|
Nota |
|---|---|
|
Beside the above parameter types there are more types for the
interactive mode, each of them will create a widget in the control
dialog. You will find a list of these parameters with descriptions and
examples in the test script
|
|
Tipo argomento |
Descrizione |
||||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|
|
Crea un widget di regolazione nella finestra di dialogo. SF-ADJUSTMENT "etichetta" '(valore inferiore superiore passo_inc pagina_inc cifre tipo) Elenco argomenti del widget
|