listbox
Команда создает и управляет примитивами окон со списками.
СИНТАКСИС
listbox имяПути ?параметры?
СТАНДАРТНЫЕ ПАРАМЕТРЫ
- -background
- -borderwidth
- -cursor
- -font
- -foreground
- -height
- -highlightbackground
- -highlightthickness
- -relief
- -selectbackground
- -selectborderwidth
- -setgrid
- -takefocus
- -width
- -xscrollcommand
Подробное описание этих параметров приведено в разделе options.
ДОПОЛНИТЕЛЬНЫЕ ПАРАМЕТРЫ ПРИМИТИВА
Имя параметра: | -height |
Имя в Базе: | height |
Класс в Базе: | Height |
Задает желаемую высоту окна (число строчек текста в нем). Если
значение параметра неположительно, то высота окна выбирается
таким образом, чтобы в нем помещались все элементы списка.
Имя параметра: | -selectmode |
Имя в Базе: | selectMode |
Класс в Базе: | SelectMode |
Задает один из нескольких стилей управления выделением. Параметр может принимать произвольное значение, однако привязки по умолчанию предполагают, что его значение является одним из следующих: single, browse, multiple или listbox. По умолчанию параметр имеет значение browse.
Имя параметра: | -width |
Имя в Базе: | width |
Класс в Базе: | Width |
Задает желаемую ширину окна (число символов в строчке текста в
нем). Если ширина символа в данном шрифте непостоянна, то для
перевода числа символов в единицы экрана используется ширина
символа "0". Если значение параметра неположительно, то ширина
окна выбирается таким образом, чтобы в нем помещались все
элементы списка.
ОПИСАНИЕ
Команда listbox создает новое окно (задаваемое
аргументом имяПути) и превращает его в примитив окна со
списком. Детали изображения кнопки, такие как ее цвет, шрифт,
текст и объемный вид, задаются с помощью описанных выше
дополнительных параметров. Команда listbox
возвращает аргумент имяПути. В момент выполнения этой
команды не должно существовать окна с именем имяПути,
но должен существовать его предок.
Окно со списком представляет собой примитив, в котором
выводятся строки элементы списка по одному на строчку окна. С
помощью описываемых ниже команд примитива в список можно
добавлять новые элементы или удалять элементы оттуда. Кроме
того, можно выделить один или несколько элементов, как описано
ниже. Экспорт выделенного текста (см. описание параметра
exportSelection) осуществляется по стандартному
протоколу X11 для выделений; выделения в поле ввода имеют тип
STRING. Значение строки выделения составляется
из выделенных элементов, разделенных символами перехода на новую
строчку.
Все элементы списка не обязательно выводятся в окне со списком
одновременно. Содержимое окна можно поменять с помощью
описываемых ниже команд. Окна со списком поддерживают прокрутку
в обоих направлениях с помощью стандартных параметров
xScrollCommand и
yScrollCommand. Кроме того, возможно
сканирование окон (см. описание ниже).
ИНДЕКСЫ
Аргументами многих команд примитива окна со списком служат
индексы. Индекс задает положение конкретного элемента в окне со
списком. Он может иметь один из следующих видов:
- число
- Задает номер элемента в списке. Первый элемент имеет номер
0.
- active
- Задает элемент, на котором расположен курсор списка. Если
примитив находится в фокусе клавиатуры, то этот элемент
подчеркивается. Он устанавливается командой примитива
activate.
- anchor
- Задает опорную точку выделения, которую устанавливает
команда примитива selection anchor.
- end
- Указывает конец списка. Для большинства команд это последний
элемент списка, однако некоторые команды, такие как
index и insert считают его элементом,
следующим непосредственно за последним элементом списка.
- @x,y
- Указывает элемент, накрывающий точку в окне со списком с
координатами (x,y) (заданными в пикселях). Если
заданная точка не накрывается ни одним элементом, то указывает
элемент, ближайший к этой точке.
Аргументы с именами индекс, первый и
последний в описываемых ниже командах примитива
представляют собой индексы в одной из описанных выше форм.
КОМАНДА ПРИМИТИВА
Команда listbox создает новую команду Tcl с
именем имяПути. С помощью этой команды можно выполнять
различные операции над примитивом. Ее общий вид
имяПути параметр ?арг арг ...?
Параметр и аргументы уточняют поведение
команды. Примитивы окна со списком допускает следующие формы
команды:
- имяПути activate индекс
- Делает активным элемент, указанный аргументом
индекс. Если значение аргумента индекс
выходит за пределы списка, то активным становится элемент,
ближайший к указанному. Если окно со списком находится в
фокусе ввода, то активный элемент в нем выделен
подчеркиванием, а доступ к нему осуществляется через индекс
active.
- имяПути bbox индекс
- Возвращает список из четырех элементов, описывающий клетку,
занимаемую текстом в элементе, указанном параметром
индекс. Первые два элемента списка задают x- и
y-координаты верхнего левого угла клетки (в пикселях по
отношению к примитиву), последние два элемента ширину и высоту
области (в пикселях). Если на экране не видна никакая часть
элемента или если индекс указывает на несуществующий элемент,
то команда возвращает пустую строку. Если же на экране видна
хотя бы часть элемента, то результатом выполнения команды
служит описание всей области, занимаемой элементом (в том
числе и его невидимой частью).
- имяПути cget параметр
- Возвращает текущее значение параметра конфигурации с именем
параметр. Параметр может быть любым из параметров команды
listbox.
- имяПути configure
?параметр? ?значение параметр значение ...?
- Запрашивает значения параметров конфигурации примитива или
изменяет их. Если параметр не указан, то возвращает
список, содержащий значения всех допустимых в
имениПути параметров (формат списка описан в
Tk_ConfigureInfo). Если параметр
задан, а его новое значение нет, то команда
возвращает часть полного списка, относящуюся к указанному
параметру. Если заданы одна или несколько пар
параметр-значение, то указанным параметрам примитива
присваиваются новые значения. В этом случае команда возвращает
пустую строку. Параметр может быть любым из параметров команды
listbox.
- имяПути curselection
- Возвращает список, состоящий из числовых значений индекса
всех выделенных элементов. Если ни один из элементов не выделен,
то возвращает пустую строку.
- имяПути delete первый
?последний?
- Удаляет один или несколько элементов списка. Аргумент
первый является индексом первого, а аргумент
последний индексом последнего удаляемого элемента. По
умолчанию значение аргумента последний совпадает со значением
аргумента первый, т.е. удаляется один элемент.
- имяПути get первый
?последний?
- Если аргумент последний не задан, то возвращает
содержимое элемента списка, заданного аргументом
первый (или пустую строку, если первый указывает на
несуществующий элемент). Если аргумент последний задан, то
команда возвращает список, элементами которого являются все
элементы окна между первым и последним
(включая оба эти элемента). Значением каждого из аргументов
первый и последний может быть любое допустимое значение
индекса.
- имяПути index индекс
- Команда возвращает числовое значение индекса, заданного
аргументом индекс. Если аргумент индекс
имеет значение end, то возвращаемое значение
равно числу элементов в списке (а не индексу последнего
элемента).
- имяПути insert индекс
?элемент элемент ...
- Вставляет элементы непосредственно перед элементом, на
который указывает аргумент индекс. Если аргумент
индекс имеет значение end,
то новые элементы вставляются в конец списка. Команда
возвращает пустую строку.
- имяПути nearest y
- По заданному значению y-координаты в окне со списком
возвращает индекс ближайшего к этому значению (видимого)
элемента списка.
- имяПути scan параметр
аргументы
Осуществляет сканирование окна со списком. В зависимости от
значения параметра может иметь две различные формы:
- имяПути scan mark x y
- Запоминает значение координаты x и текущее состояние
окна со списком; используется в сочетании с последующими
командами scan dragto. Обычно эта команда
связана с нажатием клавиши "Мыши" на
примитиве. Возвращает пустую строку.
- имяПути scan dragto x y
- Вычисляет разность между значением своих аргумента
x и y и значениями аргументов x
и y последней выполненной на данном примитиве
команды scan mark. Затем переносит
изображение примитива на расстояние, в 10 раз превышающее
вычисленную разность. Команда обычно связана с событиями
движения "Мыши" в примитиве и используется для
скоростного перетаскивания списка в окне. Возвращает
пустую строку.
- имяПути see индекс
- Выравнивает список в окне так, чтобы элемент с индексом
индекс оказался видимым. Если этот элемент уже
является видимым, то команда не производит никаких
действий. Если указанный элемент находится возле края окна, то
при прокрутке списка элемент оказывается возле того же края; в
противном случае указанный элемент выводится в центре
окна.
- имяПути selection параметр
аргумент
Производит размещение выделения в окне со
списком. Команда может иметь одну из описанных ниже
форм.
- имяПути selection anchor
индекс
- Устанавливает опорную точку выделения на элемент,
указанный аргументом индекс. Если индекс
указывает на несуществующий элемент, то опорным становится
элемент, ближайший к указанному. Опорная точка выделения
является фиксированным концом выделения при движении
"Мыши" с нажатой клавишей. На опорную точку выделения
указывает индекс anchor.
- имяПути selection clear
первый ?последний?
- Отменяет выделение элементов между первым и
последним. Вне этого интервала выделение не
изменяется.
- имяПути selection includes
индекс
- Возвращает "1", если элемент, указанный
аргументом индекс, выделен, и "0" в противном
случае.
- имяПути selection set
первый ?последний?
- Выделяет все элементы в промежутке между первым и
последним; на выделение вне указанного интервала команда
влияния не оказывает.
- имяПути xview аргументы
Используется для запроса горизонтального положения
информации, выведенной в окне примитива, и изменения этого
положения. Команда может иметь одну из следующих форм:
- имяПути xview
- Возвращает список, состоящий из двух элементов. Каждый
из элементов списка представляет собой вещественное число,
заключенное между нулем и единицей; эта пара чисел
описывает видимый в окне горизонтальный интервал. Так,
например, если первое число равно "2", а второе
"6", то 20% текста в окне со списком оказывается
невидимой слева от окна, в окне выводится 40% информации,
и еще 40% оказывается невидимой справа от окна. Те же
значения передаются полосе прокрутки через параметр
-xscrollcommand.
- имяПути xview индекс
- Переносит строку в поле ввода так, что самым левым
символом в окне становится символ, положение которого
указано аргументом индекс. Положения символов определяются
исходя из ширины символа 0.
- имяПути xview moveto
число
- Передвигает область видимости так, что слева от окна
остается невидимой часть текста списка, указанная
аргументом число. Число должно быть
заключено между "0" и "1".
- имяПути xview scroll
количество что
- Сдвигает выводимый в окне текст вправо или влево в
соответствии со значениями аргументов. Количество
должно быть целым числом, аргумент что может
принимать значения units или
pages или быть сокращением одного из этих
слов. Если аргумент что принимает значение
units, то сдвиг происходит на
количество символов средней ширины (ширины
символов 0). Если значением аргумента
что является pages, то сдвиг
осуществляется на количество полных экранов. Если
количество отрицательно, то видимые символы
сдвигаются вправо, в противном случае влево.
- имяПути yview аргументы
Используется для запроса вертикального положения
информации, выведенной в окне примитива, и изменения этого
положения. Команда может иметь одну из следующих форм:
- имяПути yview
- Возвращает список, состоящий из двух элементов. Каждый
из элементов списка представляет собой вещественное число,
заключенное между нулем и единицей. Первый элемент списка
задает положение в списке первого видимого в окне элемента
(например, значение "0.5" указывает на середину
списка). Второй элемент указывает положение в списке
элемента, следующего непосредственно за последним видимым
в окне. Те же значения передаются полосе прокрутки через
параметр -xscrollcommand.
- имяПути yview индекс
- Переносит содержимое окна со списком таким образом,
чтобы элемент, заданный аргументом индекс, оказался в
первой строчке окна.
- имяПути yview moveto
число
- Переносит содержимое окна со списком таким образом,
чтобы элемент, заданный аргументом число,
оказался в первой строчке окна. Число должно быть
заключено между 0 и 1. 0 указывает на первый
элемент в списке, 0.33 указывает на элемент, отстоящий от
начала списка на одну треть, и т.д.
- имяПути yview scroll
количество что
- Сдвигает выводимый в окне текст вверх или вниз в
соответствии со значениями аргументов. Количество
должно быть целым числом, аргумент что может
принимать значения units или
pages или быть сокращением одного из этих
слов. Если аргумент что принимает значение
units, то сдвиг происходит на
количество строчек. Если значением аргумента
что является pages, то сдвиг
осуществляется на количество полных экранов. Если
количество отрицательно, то видимые символы
сдвигаются вниз, в противном случае вверх.
ПАРАМЕТРЫ ПО УМОЛЧАНИЮ
При создании окна со списком Tk автоматически создает параметры
класса, определяющие его поведение по умолчанию. Поведение окна
со списком в значительной степени определяется значением
параметра selectMode, задающим один из четырех
режимов работы с выделением.
В режиме выделения single или
browse допустимо выделение не более одного
элемента. В обоих режимах щелчок клавишей 1 "Мыши" на
элементе приводит к его выделению и отмене всех остальных
выделений. В режиме browse выделенный элемент
можно также перетащить с помощью клавиши 1 "Мыши".
В режимах выделения multiple или extended можно одновременно
выделить несколько элементов, не обязательно идущих в списке
подряд. В режиме multiple щелчок клавиши 1 "Мыши" на
элементе переключает состояние его выделенности, не влияя на
выделение остальных элементов. В режиме extended нажатие клавиши
на элементе выделяет его, отменяет выделение всех остальных
элементов и устанавливает опорную точку выделения на элемент под
курсором "Мыши"; если при этом тащить "Мышь"
с нажатой клавишей 1, то выделение
распространится на все элементы между опорным и элементом,
находящимся под сдвинувшимся курсором "Мыши".
В большинстве случаев для одиночных выделений используется режим browse, а для кратных режим extended; остальные режимы оказываются полезными в некоторых особых ситуациях.
Помимо описанного выше поведения привязки по умолчанию задают следующие дополнительные характеристики поведения примитива:
В режиме extended выделенную область можно
изменить нажатием клавиши 1 при нажатой клавише
Shift; при этом выделенной становится вся
область между опорной точкой и элементом под курсором
"Мыши".
В режиме extended нажатие клавиши 1 при
нажатой клавише Control начинает выполнение
операции переключения: опорная точка устанавливается на элемент
под курсором "Мыши", а состояние его выделения
меняется на противоположное. Выделение остальных элементов не
изменяется. Если тащить "Мышь" с нажатой клавишей 1,
то состояние выделения всех элементов между опорной точкой и
курсором "Мыши" меняется на состояние выделения
опорного элемента; выделение остальных элементов не
изменяется.
Если "Мышь" сдвигается с окна со списком при нажатой
клавише 1, то информация в окне прокручивается в противоположном
направлении. Прокрутка продолжается до тех пор, пока либо
"Мышь" не вернется в область окна, либо будет
достигнут конец списка.
Для прокрутки можно использовать клавишу 2
"Мыши". Если ее нажать и протащить "Мышь" по
списку, то содержимое списка будет прокручиваться в направлении
движения "Мыши".
При нажатии на клавиши Up или
Down курсор окна (активный элемент)
передвигается на одну строчку вверх или вниз. В режиме
browse или extended новый
активный элемент оказывается выделенным, а выделение всех
остальных элементов отменяется. В режиме
extended новый активный элемент становится
опорной точкой выделения.
В режиме extended клавиши
Shift-Up и Shift-Down
передвигают курсор окна на одну строчку вверх или вниз и
расширяют область выделения новым активным элементом подобно
тому, как это делает клавиша 1 "Мыши".
Нажатие на клавиши Left или
Right приводит к перемещению курсора ввода на
ширину символа 0 влево или вправо.
Нажатие на клавиши Control-Left и
Control-Right приводит к прокрутке списка на
ширину окна, также, как и нажатие на клавиши
Control-Prior и
Control-Next.
Нажатие
на клавиши Prior и Next
приводит к прокрутке списка на одну страницу (на высоту окна)
вверх или вниз.
Нажатие на клавиши Home и End
прокручивает список горизонтально до его левого или правого края
соответственно.
Нажатие на клавиши Control-Home устанавливает
курсор окна на первый элемент списка, выделяет этот элемент и
отменяет выделение всех остальных элементов.
Нажатие на клавиши Control-End устанавливает
курсор окна на последний элемент списка, выделяет этот элемент и
отменяет выделение всех остальных элементов.
В режиме extended нажатие на клавиши
Control-Shift-Home расширяет выделение до
первого элемента в списке, а на клавиши
Control-Shift-End до последнего элемента в
списке.
В режиме multiple нажатие на клавиши
Control-Shift-Home устанавливает курсор окна на
первый элемента в списке, а на клавиши
Control-Shift-End на последний элемент в
списке.
Клавиши пробела и Select
выделяют активный элемент (курсор окна), как если бы на этом
элементе была нажата клавиша1 "Мыши".
В режиме
extended нажатие на клавиши
Control-Shift-пробел и
Shift-Select расширяет выделение до активного
элемента, как если бы на этом элементе была нажата клавиша
1 "Мыши" при нажатой клавише
Shift.
В режиме extended нажатие на клавиши
Escape отменяет самое последнее выделение и
восстанавливает предыдущее состояние выделение всех элементов в
области выделения.
Control-/ выделяет все элементы окна.
Control-\ приводит к отмене текущего
выделения (за исключением режима browse, где
эта команда не приводит ни к какому результату).
Клавиша F16, на многих станциях Sun
обозначенная Copy, (или
Meta-w) копирует выделение в примитиве в
карман.
Определяя новые параметры для отдельных примитивов или
переопределяя параметры класса, поведение окна со списком можно
изменить.