Чтение онлайн

на главную - закладки

Жанры

Язык программирования Python
Шрифт:

Здесь <space> обозначает пробел, а <less> - знак меньше. <Left>, <Right>, <Up>, <Down> - стрелки. <Prior>, <Next> - это PageUp и PageDown. Остальные клавиши более или менее соответствуют надписям на стандартной клавиатуре.

Примечание:

Следует заметить, что Shift_L, в отличие от Shift, нельзя использовать как модификатор.

В конкретной среде комбинации, означающие что–то особенное в системе, могут не дойти до графического приложения. Например, известный всем Ctrl–Alt–Del.

Следующая

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

Листинг

from Tkinter import *

tk = Tk # основное окно приложения

txt = Text(tk) # текстовый виджет, принадлежащий окну tk

txt.pack # располагается менеджером pack

# функция обработки события

def event_info(event):

txt.delete(«1.0», END) # удаляется с начала до конца текста

for k in dir(event): # цикл по атрибутам события

if k[0] != "_": # берутся только неслужебные атрибуты

# готовится описание атрибута события

ev = "%15s: %s\n» % (k, repr(getattr(event, k)))

txt.insert(END, ev) # добавляется в конец текста

# привязывается виджету txt функция event_info для обработки событий,

# соответствующих шаблону <KeyPress>

txt.bind("<KeyPress>", event_info)

tk.mainloop # главный цикл обработки событий

При нажатии клавиши Esc в окне можно увидеть примерно следующее:

Листинг

char: '\x1b'

delta: 9

height: 0

keycode: 9

keysym: 'Escape'

keysym_num: 65307

num: 9

send_event: False

serial: 159

state: 0

time: — 1072960858

type: '2'

widget: <Tkinter.Text instance at 0x401e268c>

width: 0

x: 83

x_root: 448

y: 44

y_root: 306

Следует объяснить некоторые из этих атрибутов:

char Нажатый символ (для некоторых событий - ??)

height, width Высота и ширина.

focus Был ли в момент события фокус у окна?

keycode Код символа (скан–код клавиатуры).

keysym Символическое имя клавиши.

serial Серийный номер события. Увеличивается по мере возникновения событий.

time Время возникновения события. Все время увеличивается.

widget Виджет, в котором возникло событие.

x, y Координаты указателя в виджете во время события.

x_root, y_root Координаты указателя на экране во время события.

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

Создание и конфигурирование виджета

Создание виджета происходит вызовом конструктора соответствующего

класса. Вызов конструктора имеет следующий синтаксис:

Листинг

Widget([master[, option=value, …]])

Здесь Widget — класс виджета, master — виджет–хозяин, option и value — конфигурационная опция и ее значение (таких пар может быть несколько).

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

Листинг

widget.config(option=value, …)

widget[«option»] = value

value = widget[«option»]

widget.keys

В случае, когда имя свойства совпадает с ключевым словом языка Python, принято использовать после имени одиночное подчеркивание. Так, свойство class нужно задавать как class_, а to как to_.

Изменять конфигурацию виджета можно в любой момент. Это изменение прорисуется на экране по возвращении в цикл обработки событий или при явном вызове update_idletasks.

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

Листинг

from Tkinter import *

tk = Tk

tv = StringVar

Label(tk,

textvariable=tv,

relief=«groove»,

borderwidth=3,

font=(«Courier», 20, «bold»),

justify=LEFT,

width=50,

padx=10,

pady=20,

takefocus=False,

).pack

Entry(tk,

textvariable=tv,

takefocus=True,

).pack

tv.set(«123»)

tk.mainloop

В результате на экране можно увидеть:

Виджеты конфигурируются прямо при создании. Более того, виджеты не связываются с именами, их только располагают внутри виджета–окна. В данном примере использованы свойства textvariable (текстовая переменная), relief (рельеф), borderwidth (ширина границы), justify (выравнивание), width (ширина, в знакоместах), padx и pady (прослойка в пикселях между содержимым и границами виджета), takefocus (возможность принять фокус при нажатии клавиши Tab), font (шрифт, один из способов его задания). Эти свойства достаточно типичны для многих виджетов, хотя иногда единицы измерения могут отличаться, например, для виджета Canvas ширина задается в пикселях, а не в знакоместах.

В следующем примере демонстрируются возможности по назначению цветов фону, переднему плану (тексту), выделению виджета (подсветка границы) в активном состоянии и при отсутствии фокуса:

Листинг

from Tkinter import *

tk = Tk

tv = StringVar

Entry(tk,

textvariable=tv,

takefocus=True,

borderwidth=10,

).pack

mycolor1 = "#%02X%02X%02X» % (200, 200, 20)

Entry(tk,

textvariable=tv,

takefocus=True,

borderwidth=10,

Поделиться:
Популярные книги

Моя на одну ночь

Тоцка Тала
Любовные романы:
современные любовные романы
короткие любовные романы
5.50
рейтинг книги
Моя на одну ночь

Черный Маг Императора 8

Герда Александр
8. Черный маг императора
Фантастика:
юмористическое фэнтези
попаданцы
аниме
5.00
рейтинг книги
Черный Маг Императора 8

Измена. Отбор для предателя

Лаврова Алиса
1. Отбор для предателя
Фантастика:
фэнтези
5.00
рейтинг книги
Измена. Отбор для предателя

Кодекс Крови. Книга II

Борзых М.
2. РОС: Кодекс Крови
Фантастика:
фэнтези
попаданцы
аниме
5.00
рейтинг книги
Кодекс Крови. Книга II

Шаг в бездну

Муравьёв Константин Николаевич
3. Перешагнуть пропасть
Фантастика:
фэнтези
космическая фантастика
7.89
рейтинг книги
Шаг в бездну

Часовая битва

Щерба Наталья Васильевна
6. Часодеи
Детские:
детская фантастика
9.38
рейтинг книги
Часовая битва

Вечная Война. Книга II

Винокуров Юрий
2. Вечная война.
Фантастика:
юмористическая фантастика
космическая фантастика
8.37
рейтинг книги
Вечная Война. Книга II

Хроники странного королевства. Вторжение. (Дилогия)

Панкеева Оксана Петровна
110. В одном томе
Фантастика:
фэнтези
9.38
рейтинг книги
Хроники странного королевства. Вторжение. (Дилогия)

Часовой ключ

Щерба Наталья Васильевна
1. Часодеи
Фантастика:
фэнтези
9.36
рейтинг книги
Часовой ключ

Инвестиго, из медика в маги

Рэд Илья
1. Инвестиго
Фантастика:
фэнтези
городское фэнтези
попаданцы
5.00
рейтинг книги
Инвестиго, из медика в маги

Кротовский, может, хватит?

Парсиев Дмитрий
3. РОС: Изнанка Империи
Фантастика:
попаданцы
альтернативная история
аниме
7.50
рейтинг книги
Кротовский, может, хватит?

Драконий подарок

Суббота Светлана
1. Королевская академия Драко
Любовные романы:
любовно-фантастические романы
7.30
рейтинг книги
Драконий подарок

Очешуеть! Я - жена дракона?!

Амеличева Елена
Фантастика:
юмористическая фантастика
5.43
рейтинг книги
Очешуеть! Я - жена дракона?!

Идеальный мир для Лекаря 9

Сапфир Олег
9. Лекарь
Фантастика:
боевая фантастика
юмористическое фэнтези
6.00
рейтинг книги
Идеальный мир для Лекаря 9