В этом четвёртом уроке мы напишем первый сценарий Script-Fu
Создание текста для веб-страницы, логотипа — довольно часто используемая операция в GIMP. Однако трудно предугадать, какого размера нужно создать исходное изображение, чтобы весь текст поместился без лишнего места с указанным шрифтом и размером.
Такую задачу довольно легко решить и автоматизировать с помощью Script-Fu.
Мы создадим сценарий под названием Text Box который создаст изображение с правильным размером для текста, введённого пользователем. Пользователь также может указать шрифт, размер шрифта и цвет текста.
До сих пор мы работали в консоли Script-Fu. Теперь же перейдём к редактированию файлов сценариев. Файлы сценариев должны быть простыми текстовыми файлами, которые можно редактировать в текстовом или кодовом редакторе. Имя, которое вы зададите файлу, не так важно, главное, чтобы вы могли его узнать. Файлу сценария следует задать расширение «.scm».
Место хранения сценариев выбираете по своему усмотрению. В настройках папок GIMP можно увидеть, в каких папках GIMP ищет сценарии. Там же можно добавить новую папку. Папка, в которой GIMP хранит собственные сценарии, обычно не является лучшим выбором для ваших сценариев, но в остальном можно выбрать то, что вам больше подходит.
Каждый сценарий Script-Fu определяет по крайней мере одну функцию, которая служит главной функцией сценария. Здесь и совершается главная работа.
Каждый сценарий должен зарегистрироваться с базой процедур, чтобы можно было получить к нему доступ из GIMP.
Мы создадим сначала главную функцию:
(define (script-fu-text-box inText inFont inFontSize inTextColor))
Здесь мы определили функцию с названием script-fu-text-box
, которая берёт четыре параметра. Эти параметры позже соотнесутся с текстом, шрифтом, размером и цветом. Функция сейчас пустая и ничего не делает. Пока ничего нового.
В основном Scheme придерживается маленьких букв с чёрточками для создания названий объектов. Мы следовали этому принципу для названия функции, но не параметров. Для параметров мы выбрали описательные названия с приставкой «in», указывающая, что эти переменные были даны функции, а не декларированы в самой функции или сценарии, для которых мы будем использовать приставку «the».
Согласно своему порядку, GIMP именует пользовательские сценарные функции по типу script-fu-abc
, поскольку, когда они присутствуют в процедурной базе данных, они показываются в списке Script-Fu при запросе списка функций. Также, такой порядок наименования помогает отличать их от расширений.
Теперь мы зарегистрируем функцию с GIMP. Это делается вызовом функции script-fu-register
. Когда GIMP читает текст сценария, он вызывает эту функцию, и она зарегистрирует нашу функцию в базе процедур. Вызвать эту функцию можно в любом месте сценария, но мы возьмём за правило вызывать её в конце сценария.
Вот исходный код для регистрации функции (параметры будут описаны ниже):
(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")
Сохраните эти функции в файле с расширением .scm
в подкаталоге вашего каталога сценариев с тем же именем, что и у вашего файла сценария, и перезапустите GIMP. Новый сценарий появится в меню → → .
Если вы вызовите этот сценарий, он естественно ничего не сделает, но вы увидите все запросы, созданные во время регистрации сценария. Об этом ниже.
И наконец, если вы вызовете просмотрщик процедур (
→ ), вы увидите там свой новый сценарий.Чтобы зарегистрировать сценарий с GIMP, нужно вызвать функцию script-fu-register
, заполнить семь необходимых параметров, добавить параметры сценария с описанием и значением по умолчанию для каждого.
Необходимые параметры
Название нашей функции. Эта функция вызывается при запуске нашего сценария (точка входа в наш сценарий). Этот параметр необходим, потому что можно создать много функций в сценарии, и GIMP должен знать, какая функция главная. В нашем примере мы декларируем только одну функцию, text-box, которую мы и регистрируем.
Метка меню — это имя, которое будет показано в меню. Чтобы указать расположение, см. Раздел 3.4.9, «Регистрация расположения в меню».
Описание сценария покажется в просмотрщике процедур.
Ваше имя (автор сценария).
Информация об Авторском праве.
Дата создания сценария или его последнего изменения.
Типы изображений, с которыми этот сценарий работает. Может быть любой из: RGB, RGBA, GRAY, GRAYA, INDEXED, INDEXEDA, или вообще никакой. В нашем случае мы создаём изображение, поэтому тип изображения можно не указывать.
После объявления списка необходимых параметров нужно указать параметры, которые соответствуют параметрам сценария. При объявлении списка параметров, мы даём подсказку об их типах. Это делается для диалога параметров, который появится при вызове нашего сценария. Мы также предоставляем значения по умолчанию.
Эта часть процесса регистрации имеет следующий формат:
Тип параметра |
Описание |
Пример |
---|---|---|
|
Если ваш сценарий работает с открытым изображением, этот параметр должен быть первым после необходимых параметров. GIMP вставит ссылку на изображение в этот параметр. |
3 |
|
Если ваш сценарий работает с открытым изображением, этот параметр должен быть вторым параметром, сразу после параметра |
17 |
|
Принимает строки. |
"Некий текст" |
|
Указывает на то, что этот параметр требует значение цвета. |
'(0 102 255) |
|
Принимает логическое значение. Обычно показывается в виде галочки. |
TRUE или FALSE |
![]() |
Примечание |
---|---|
Кроме типов параметров, описанных выше, есть больше типов для интерактивного режима, каждый из которых создаст компонент введения значения в диалоге. Список этих параметров с их описанием и примерами их использования находятся в тестовом сценарии |
Тип параметра |
Описание |
||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|
Создаёт компонент изменения в диалоге. SF-ADJUSTMENT "название" '(value lower upper step_inc page_inc digits type) Список параметров компонента
|
||||||||||||||||
|
Создаёт кнопку цвета в диалоге. SF-COLOR "название" '(красный зелёный синий) или SF-COLOR "название" "цвет" Список параметров компонента
|
||||||||||||||||
|
Создаёт в диалоге компонент выбора шрифта. Возвращает название шрифта как строку. Есть две функции, которые облегчают работу с этим параметром: gimp-text-fontname image drawable x-pos y-pos text border antialias size unit font) (gimp-text-get-extents-fontname text size unit font) где font — название шрифта. Размер, указанный в названии шрифта, не принимается во внимание. Он используется только в выборщике шрифта. Поэтому его нужно установить на какое-либо полезное значение, например 24 точек. SF-FONT "название" "название шрифта" Список параметров компонента
|
||||||||||||||||
|
Компонент, созданный этим параметром, содержит несколько элементов. Во-первых, окно просмотра, которое при нажатии на нём вызовет диалог просмотра. Во-вторых, кнопку с названием "...". Эта кнопка вызывает диалог выбора кисти, где каждое свойство кисти можно изменить. SF-BRUSH "Кисть" '("Circle (03)" 100 44 0) В этом случае появится диалог выбора кисти с выбранной кистью Circle (03), непрозрачностью 100, промежутком 44 и в нормальном режиме рисования (значение 0). Если эту кисть не изменить, то значение, которое получит функция, будет '("Circle (03)" 100 44 0). |
||||||||||||||||
|
Компонент, созданный этим параметром, содержит несколько элементов. Во-первых, окно просмотра, которое при нажатии на нём вызовет диалог просмотра. Во-вторых, кнопку с названием "...". Эта кнопка вызывает диалог выбора шаблона. SF-PATTERN "Шаблон" "Maple Leaves" Возвращаемым значением при вызове сценария будет строка, содержащая название шаблона. Если выбранный по умолчанию шаблон не был изменён, то эта строка будет содержать "Maple Leaves". |
||||||||||||||||
|
Созданный компонент-кнопка в диалоге будет показывать выбранный градиент. При нажатии кнопки появится диалог выбора градиента. SF-GRADIENT "Градиент" "Deep Sea" Возвращаемым значением при вызове сценария будет строка, содержащая название градиента. Если выбранный по умолчанию градиент не был изменён, то эта строка будет содержать "Deep Sea". |
||||||||||||||||
|
Созданный компонент-кнопка в диалоге будет показывать название выбранной палитры. При нажатии на кнопку появится диалог выбора палитры. SF-PALETTE "Палитра" "Named Colors" Возвращаемым значением при вызове сценария будет строка, содержащая название палитры. Если выбранная по умолчанию палитра не была изменена, то эта строка будет содержать "Named Colors". |
||||||||||||||||
|
Созданный компонент-кнопка в диалоге будет показывать название файла. При нажатии кнопки появится диалог выбора файла. SF-FILENAME "название" (string-append "" gimp-data-directory "/scripts/beavis.jpg") Возвращаемым значением при вызове сценария будет строка, содержащая путь к файлу. |
||||||||||||||||
|
Этот параметр может пригодиться только в интерактивном режиме. Очень похож на SF-FILENAME, но созданный компонент ввода позволяет выбрать папку вместо файла. SF-DIRNAME "название" "/var/tmp/images" Возвращаемым значением при вызове сценария будет строка, содержащая путь к папке. |
||||||||||||||||
|
Этот параметр создаёт раскрывающийся список с элементами из данного с параметром списка. Первая запись выбрана по умолчанию. SF-OPTION "название" '("запись1" "запись2") Возвращаемым значением при вызове сценария будет порядковый номер выбранной записи. У первой записи порядковый номер 0. |
||||||||||||||||
|
Этот параметр создаст виджет в диалоговом окне управления. Виджет представляет собой выпадающий список со всеми значениями данного перечислимого типа. Это должно быть имя зарегистрированного перечислимого типа без префикса «Gimp». Второй параметр указывает значение по умолчанию, используя псевдоним значения перечислимого типа. SF-ENUM "Interpolation" '("InterpolationType" "linear") Возвращаемым значением при вызове сценария будет выбранное значение перечислимого типа. |
После регистрации сценария необходимо указать GIMP, где он должен находиться в меню.
Оптимальное расположение сценария зависит от его функции. Большинство сценариев находится в меню
и .Для текущего сценария, который создаёт новое изображение, мы выбираем подменю script-fu-menu-register
. Таким образом, мы зарегистрировали наш сценарий Text Box здесь: → → .
Любое подменю, которое вы укажете в своём сценарии и которое ещё не существует, будет автоматически создано GIMP.