Ruby - Руководство по Tk

Введение

Стандартный графический интерфейс пользователя (GUI) для Ruby - Tk. Tk начинался как графический интерфейс для языка сценариев Tcl, разработанный Джоном Остерхаутом.

Tk уникален тем, что является единственным кроссплатформенным графическим интерфейсом. Tk работает в Windows, Mac и Linux и обеспечивает естественный внешний вид в каждой операционной системе.

Базовый компонент приложения на основе Tk называется виджетом. Компонент также иногда называют окном, поскольку в Tk «окно» и «виджет» часто используются как синонимы.

Приложения Tk следуют иерархии виджетов, в которой любое количество виджетов может быть размещено внутри другого виджета, а эти виджеты - внутри другого виджета, до бесконечности. Главный виджет в программе Tk называется корневым виджетом и может быть создан путем создания нового экземпляра класса TkRoot.

  • Большинство приложений на основе Tk следуют одному и тому же циклу: создают виджеты, помещают их в интерфейс и, наконец, связывают события, связанные с каждым виджетом, с методом.

  • Есть три менеджера геометрии; place, grid и pack , которые отвечают за управление размером и расположением каждого из виджетов в интерфейсе.

Установка

Привязки Ruby Tk распространяются с Ruby, но Tk устанавливается отдельно. Пользователи Windows могут загрузить установку Tk одним щелчком мыши из ActiveTcl ActiveState .

Пользователям Mac и Linux может не потребоваться его установка, потому что велика вероятность, что он уже установлен вместе с ОС, но если нет, вы можете загрузить готовые пакеты или получить исходный код из Tcl Developer Xchange .

Простое приложение Tk

Типичная структура программ Ruby / Tk - это создание основного или root window (экземпляр TkRoot), добавьте в него виджеты для создания пользовательского интерфейса, а затем запустите основной цикл событий, вызвав Tk.mainloop.

Традиционный Hello, World! пример для Ruby / Tk выглядит примерно так -

require 'tk'

root = TkRoot.new { title "Hello, World!" }
TkLabel.new(root) do
   text 'Hello, World!'
   pack { padx 15 ; pady 15; side 'left' }
end
Tk.mainloop

Здесь после загрузки модуля расширения tk мы создаем фрейм корневого уровня с помощью TkRoot.new . Затем мы делаем виджет TkLabel дочерним по отношению к корневому фрейму, устанавливая несколько параметров для метки. Наконец, мы упаковываем корневой фрейм и входим в основной цикл событий графического интерфейса.

Если вы запустите этот скрипт, он даст следующий результат:

Классы виджетов Ruby / Tk

Существует список различных классов Ruby / Tk, которые можно использовать для создания желаемого графического интерфейса с использованием Ruby / Tk.

  • TkFrame Создает и управляет виджетами фреймов.

  • TkButton Создает виджеты кнопок и управляет ими.

  • TkLabel Создает виджеты меток и управляет ими.

  • TkEntry Создает виджеты входа и управляет ими.

  • TkCheckButton Создает виджеты с флажками и управляет ими.

  • TkRadioButton Создает и манипулирует виджетами радиокнопок.

  • TkListbox Создает и манипулирует виджетами списка.

  • TkComboBox Создает и управляет виджетами списка.

  • TkMenu Создает и управляет виджетами меню.

  • TkMenubutton Создает и манипулирует виджетами меню .

  • Tk.messageBox Создает диалоговое окно сообщения и управляет им.

  • TkScrollbar Создает и управляет виджетами полосы прокрутки.

  • TkCanvas Создает и управляет виджетами холста.

  • TkScale Создает масштабные виджеты и управляет ими.

  • TkText Создает текстовые виджеты и управляет ими.

  • TkToplevel Создает виджеты верхнего уровня и управляет ими.

  • TkSpinbox Создает и управляет виджетами Spinbox.

  • TkProgressBar Создает виджеты индикатора выполнения и управляет ими.

  • Диалоговое окно Создание и управление виджетами диалогового окна.

  • Tk :: Tile :: Notebook Отображение нескольких окон в ограниченном пространстве с использованием метафоры записной книжки.

  • Tk :: Tile :: Paned Отображает несколько подокон, расположенных вертикально или горизонтально.

  • Tk :: Tile :: Separator Отображает горизонтальную или вертикальную разделительную полосу.

  • Шрифт, цвета и изображения Ruby / Tk Общие сведения о шрифтах, цветах и ​​изображениях Ruby / Tk

Стандартные варианты конфигурации

Все виджеты имеют несколько различных параметров конфигурации, которые обычно управляют тем, как они отображаются или как ведут себя. Доступные параметры, конечно же, зависят от класса виджета.

Вот список всех стандартных параметров конфигурации, которые могут быть применимы к любому виджету Ruby / Tk.

Sr.No. Опции и описание
1

activebackground => Строка

Задает цвет фона для использования при рисовании активных элементов. Элемент активен, если курсор мыши расположен над элементом и нажатие кнопки мыши вызовет какое-либо действие. Вы можете использовать такие названия цветов, как «красный», «синий», «розовый», «желтый» и т. Д.

2

activeborderwidth => Целое число

Задает неотрицательное значение, указывающее ширину трехмерной границы, нарисованной вокруг активных элементов.

3

activeforeground => Строка

Задает цвет переднего плана для использования при рисовании активных элементов.

4

anchor => Строка

Определяет, как информация в виджете (например, текст или растровое изображение) должна отображаться в виджете. Должно быть одно из значенийn, ne, e, se, s, sw, w, nw, или же center. Например,nw означает отображение информации таким образом, чтобы ее верхний левый угол находился в верхнем левом углу виджета.

5

background or bg => Строка

Задает нормальный цвет фона для использования при отображении виджета.

6

bitmap => Растровое изображение

Задает растровое изображение для отображения в виджете. На точный способ отображения растрового изображения могут влиять другие параметры, такие как привязка или выравнивание.

7

borderwidth or bd => Целое число

Определяет неотрицательное значение, указывающее ширину трехмерной границы, которая будет рисоваться за пределами виджета.

8

compound => Строка

Указывает, должен ли виджет отображать текст и растровые изображения / изображения одновременно, и если да, то где растровое изображение / изображение должно быть размещено относительно текста. Должно быть одно из значенийnone, bottom, top, left, right, или же center.

9

cursor => Строка

Задает курсор мыши, который будет использоваться для виджета. Возможные значения: «часы», «стрелка» и т. Д.

10

disabledforeground => Строка

Задает цвет переднего плана для использования при рисовании отключенного элемента.

11

exportselection => Логическое

Определяет, должно ли выделение в виджете также быть выделением X. Значение может иметь любое изtrue, false, 0, 1, yes, или же no. Если выбор экспортируется, то выбор в виджете отменяет выбор текущего X выбора, выбор вне виджета отменяет выбор любого виджета, и виджет будет отвечать на запросы извлечения выбора, когда он имеет выбор.

12

font => Строка

Задает шрифт, используемый при рисовании текста внутри виджета.

13

foreground or fg => Строка

Задает нормальный цвет переднего плана для использования при отображении виджета.

14

highlightbackground => Строка

Задает цвет для отображения в области выделения обхода, когда виджет не имеет фокуса ввода.

15

highlightcolor => Строка

Задает цвет, который будет использоваться для выделенного прямоугольника обхода, который рисуется вокруг виджета, когда он имеет фокус ввода.

16

highlightthickness => Целое число

Задает неотрицательное значение, указывающее ширину выделенного прямоугольника для рисования за пределами виджета, когда он имеет фокус ввода.

17

image => Изображение

Задает изображение для отображения в виджете, которое должно быть создано с помощью создания изображения. Обычно, если указан параметр изображения, он переопределяет другие параметры, которые определяют растровое изображение или текстовое значение для отображения в виджете; параметр изображения может быть сброшен на пустую строку, чтобы повторно включить отображение растрового изображения или текста.

18

jump => Строка

Для виджетов с ползунком, который можно перетаскивать для настройки значения, например полос прокрутки и масштабов, этот параметр определяет, когда будут делаться уведомления об изменениях значения. Значение параметра должно быть логическим. Если значение равно false, обновления выполняются непрерывно при перемещении ползунка. Если значение истинно, обновления задерживаются до тех пор, пока кнопка мыши не будет отпущена для завершения перетаскивания; в этот момент делается одно уведомление.

19

justify => Строка

Когда в виджете отображается несколько строк текста, этот параметр определяет, как строки выстраиваются друг с другом. Должен быть одним изleft, center, или же right. Left означает, что все левые края линий совпадают, center означает, что центры линий выровнены, а right означает, что правые края линий совпадают.

20

offset => Строка

Задает смещение плиток (см. Также tileвариант). Может иметь два разных форматаoffset x,y или же offset side, где сторона может быть n, ne, e, se, s, sw, w, nw, или же center.

21 год

orient => Строка

Для виджетов, которые могут располагаться с горизонтальной или вертикальной ориентацией, например полос прокрутки, этот параметр указывает, какую ориентацию следует использовать. Должно быть либоhorizontal или же vertical или сокращение одного из них.

22

padx => Целое число

Задает неотрицательное значение, показывающее, сколько дополнительного места следует запросить для виджета в направлении X.

23

pady => Целое число

Задает неотрицательное значение, указывающее, сколько дополнительного места следует запрашивать для виджета в направлении Y.

24

relief => Целое число

Задает желаемый для виджета трехмерный эффект. Допустимые значения:raised, sunken, flat, ridge, и groove.

25

repeatdelay => Целое число

Определяет количество миллисекунд, в течение которых кнопка или клавиша должны удерживаться нажатой, прежде чем они начнут автоповтор. Используется, например, для стрелок вверх и вниз на полосах прокрутки.

26

repeatinterval => Целое число

Используется вместе с repeatdelay: после начала автоповтора эта опция определяет количество миллисекунд между автоповторами

27

selectbackground => Строка

Задает цвет фона для использования при отображении выбранных элементов.

28

selectborderwidth => Целое число

Определяет неотрицательное значение, указывающее ширину трехмерной границы для обводки выбранных элементов.

29

selectforeground => Строка

Задает цвет переднего плана для использования при отображении выбранных элементов.

30

setgrid => Логическое

Задает логическое значение, определяющее, управляет ли этот виджет сеткой изменения размера для своего окна верхнего уровня. Эта опция обычно используется в текстовых виджетах, где информация в виджете имеет естественный размер (размер символа), и имеет смысл, чтобы размеры окна были целыми числами этих единиц.

31 год

takefocus => Целое число

Предоставляет информацию, используемую при перемещении фокуса из окна в окно с помощью обхода клавиатуры (например, Tab и Shift-Tab). Перед установкой фокуса на окно сценарии обхода сначала проверяют, доступно ли окно для просмотра (оно и все его предки отображаются); в противном случае окно пропускается. Значение 0 означает, что это окно следует полностью пропускать при обходе клавиатуры. 1 означает, что это окно всегда должно получать фокус ввода.

32

text => Строка

Задает строку, отображаемую внутри виджета. Способ отображения строки зависит от конкретного виджета и может определяться другими параметрами, такими какanchor или же justify.

33

textvariable => Переменная

Задает имя переменной. Значение переменной - это текстовая строка, отображаемая внутри виджета; если значение переменной изменится, виджет автоматически обновится, чтобы отразить новое значение. Способ отображения строки в виджете зависит от конкретного виджета и может определяться другими параметрами, такими какanchor или же justify.

34

tile => Изображение

Задает изображение, используемое для отображения виджета. Если изображение является пустой строкой, отображается нормальный цвет фона.

35 год

troughcolor => Строка

Задает цвет, который будет использоваться для прямоугольных желобов в виджетах, таких как полосы прокрутки и шкалы.

36

troughtile => Изображение

Указывает изображение, используемое для отображения в прямоугольных областях желоба в виджетах, таких как полосы прокрутки и шкалы.

37

underline => Целое число

Задает целочисленный индекс символа, который нужно подчеркнуть в виджете. Этот параметр используется привязками по умолчанию для реализации обхода клавиатуры для кнопок меню и пунктов меню. 0 соответствует первому символу текста, отображаемому в виджете, 1 - следующему символу и так далее.

38

wraplength => Целое число

Для виджетов, которые могут выполнять перенос слов, этот параметр определяет максимальную длину строки.

39

xscrollcommand => функция

Задает обратный вызов, используемый для взаимодействия с горизонтальными полосами прокрутки.

40

yscrollcommand => функция

Задает обратный вызов, используемый для взаимодействия с вертикальными полосами прокрутки.

Управление геометрией Ruby / Tk

Geometry Management занимается размещением различных виджетов в соответствии с требованиями. Управление геометрией в Tk основано на концепции главных и подчиненных виджетов.

Мастер - это виджет, обычно окно верхнего уровня или фрейм, который будет содержать другие виджеты, которые называются подчиненными. Вы можете думать о диспетчере геометрии как о берут под контроль главный виджет и решая, что будет отображаться внутри.

Менеджер геометрии запросит у каждого подчиненного виджета его естественный размер или размер, который в идеале он хотел бы отображать. Затем он берет эту информацию и объединяет ее с любыми параметрами, предоставленными программой, когда он просит диспетчер геометрии управлять этим конкретным подчиненным виджетом.

Есть три менеджера геометрии: размещение, сетка и упаковка , которые отвечают за управление размером и расположением каждого из виджетов в интерфейсе.

  • сетка Диспетчер геометрии, который размещает виджеты в сетке.

  • pack Менеджер геометрии, который упаковывает края полости.

  • place Диспетчер геометрии для фиксированного размещения или размещения резиновых листов.

Обработка событий Ruby / Tk

Ruby / Tk поддерживает цикл обработки событий , который получает события от операционной системы. Это такие вещи, как нажатие кнопок, нажатия клавиш, движение мыши, изменение размера окна и т. Д.

Ruby / Tk позаботится об управлении этим циклом событий за вас. Он определит, к какому виджету относится событие (нажал ли пользователь эту кнопку? Была ли нажата клавиша, какое текстовое поле было в фокусе?), И соответствующим образом отправит его. Отдельные виджеты знают, как реагировать на события, поэтому, например, кнопка может менять цвет, когда мышь перемещается по ней, и возвращаться обратно, когда мышь уходит.

На более высоком уровне Ruby / Tk вызывает обратные вызовы в вашей программе, чтобы указать, что с виджетом произошло что-то важное. В любом случае вы можете предоставить блок кода или объект Ruby Proc, который указывает, как приложение реагирует на событие или обратный вызов.

Давайте посмотрим, как использовать метод bind для связывания основных событий оконной системы с процедурами Ruby, которые их обрабатывают. Простейшая форма связывания принимает в качестве входных данных строку, указывающую имя события и блок кода, который Tk использует для обработки события.

Например, чтобы поймать событие ButtonRelease для первой кнопки мыши на некотором виджете, вы должны написать:

someWidget.bind('ButtonRelease-1') {
   ....code block to handle this event...
}

Название события может включать дополнительные модификаторы и детали. Модификатор - это строка типа Shift , Control или Alt , указывающая, что была нажата одна из клавиш-модификаторов.

Так, например, чтобы поймать событие, которое генерируется, когда пользователь удерживает клавишу Ctrl и щелкает правой кнопкой мыши.

someWidget.bind('Control-ButtonPress-3', proc { puts "Ouch!" })

Многие виджеты Ruby / Tk могут запускать обратные вызовы, когда пользователь активирует их, и вы можете использовать обратный вызов команды, чтобы указать, что определенный блок кода или процедура вызывается, когда это происходит. Как было показано ранее, вы можете указать процедуру обратного вызова команды при создании виджета -

helpButton = TkButton.new(buttonFrame) {
   text "Help"
   command proc { showHelp }
}

Или вы можете назначить его позже, используя командный метод виджета -

helpButton.command proc { showHelp }

Поскольку метод команды принимает либо процедуры, либо блоки кода, вы также можете написать предыдущий пример кода как -

helpButton = TkButton.new(buttonFrame) {
   text "Help"
   command { showHelp }
}
Sr.No. Тег и описание события
1

"1" (one)

Щелкнул левой кнопкой мыши.

2

"ButtonPress-1"

Щелкнул левой кнопкой мыши.

3

"Enter"

Переместили мышь внутрь.

4

"Leave"

Переместила мышь наружу.

5

"Double-1"

Дважды щелкнул.

6

"B3-Motion"

Перетащите правую кнопку из одного положения в другое.

7

Control-ButtonPress-3

Правая кнопка нажата вместе с клавишей Ctrl .

8

Alt-ButtonPress-1

Кнопка Let нажимается вместе с клавишей Alt .

Метод настройки

Метод configure может использоваться для установки и получения любых значений конфигурации виджета. Например, чтобы изменить ширину кнопки, вы можете в любое время вызвать метод конфигурации следующим образом:

require "tk"

button = TkButton.new {
   text 'Hello World!'
   pack
}
button.configure('activebackground', 'blue')
Tk.mainloop

Чтобы получить значение для текущего виджета, просто укажите его без значения следующим образом:

color = button.configure('activebackground')

Вы также можете вызвать configure без каких-либо опций, что даст вам список всех опций и их значений.

Метод cget

Для простого получения значения параметра configure возвращает больше информации, чем вы обычно хотите. Метод cget возвращает только текущее значение.

color = button.cget('activebackground')