+---- GtkBin
+---- GtkWindow
Существуют десятки вызовов API
GtkWindow
, но далее приведены функции, заслуживающие особого внимания.
<b>GtkWidget* gtk_window_new(GtkWindowType type);</b>
<b>void gtk_window_set_title(GtkWindow *window, const gchar *title);</b>
<b>void gtk_window_set_position(GtkWindow *window, GtkWindowPosition position);</b>
<b>void gtk_window_set_default_size(GtkWindow *window, gint width, gint height);</b>
<b>void gtk_window_resize(GtkWindow *window, gint width, gint height);</b>
<b>void gtk_window_set_resizable(GtkWindow *window, gboolean resizable);</b>
<b>void gtk_window_present(GtkWindow *window);</b>
<b>void gtk_window_maximize(GtkWindow *window);</b>
<b>void gtk_window_unmaximize(GtkWindow *window);</b>
Как вы видели, функция
gtk_window_new
создает в памяти новое пустое окно. Заголовок окна не задан и размер и местоположение окна не определены. Обычно вы будете заполнять окно виджетами и задавать меню и панель инструментов перед выводом окна на экран с помощью вызова функции
gtk_widget_show
.
Функция
gtk_window_set_title
изменяет текст полосы заголовка, информируя оконный менеджер запроса.
Примечание
Поскольку за отображение оформления окна отвечает оконный менеджер, а не библиотека GTK+, шрифт, цвет и размер текста зависят от вашего выбора оконного менеджера.
Функция
gtk_window_setposition
управляет начальным местоположением на экране. Параметр
position
может принимать пять значений, перечисленных в табл. 16.2.
Таблица 16.2
Параметр position
| Описание |
GTK_WIN_POS_NONE
| Окно располагается по усмотрению оконного менеджера |
GTK_WIN_POS_CENTER
| Окно центрируется на экране |
GTK_WIN_POS_MOUSE
| Расположение окна задаётся указателем мыши |
GTK_WIN_POS_CENTER_ALWAYS
| Окно остается отцентрированным независимо от его размера |
GTK_WIN_POS_CENTER_ON_PARENT
| Окно центрируется относительно родительского окна (удобно для диалоговых окон) |
Функция
gtk_window_set_default_size
задает окно на экране в единицах отображения GTK+. Явное задание размера окна гарантирует, что содержимое окна не будет закрыто чем-либо или скрыто. Для того чтобы изменить размеры окна после его вывода на экран, можно воспользоваться функцией
gtk_window_resize
. По умолчанию пользователь может изменить размеры окна, перемещая обычным способом его границу мышью. Если вы хотите помешать этому, можно вызвать функцию
gtk_window_set_resizeable
, приравненную FALSE.
Для того чтобы убедиться в том, что ваше окно присутствует на экране и видно пользователю, т.е. не свернуто или скрыто, подойдет функция
gtk_window_present
. Она полезна для диалоговых окон, т.к. позволяет убедиться в том, что окна не свернуты, когда вам нужен какой-либо пользовательский ввод. В противном случае, для раскрытия окна на весь экран и его сворачивания у вас есть функции
gtk_window_maximize
и
gtk_window_minimize
.
GtkEntry
GtkEntry
— виджет однострочного текстового поля, который обычно применяется для ввода простых текстовых данных, например, адреса электронной почты, имени пользователя или имени узла сети. Существуют вызовы API, позволяющие задать как считывание введенного текста, так и его максимальную длину в символах, а также другие параметры, управляющие местоположением текста и его выделением.
GtkWidget
+----GtkEntry
Можно настроить
GtkEntry
на отображение звездочек (или любого другого определенного пользователем символа) на месте набранных буквенно-цифровых символов, что очень удобно для ввода паролей, когда вы не хотите, чтобы кто-то заглядывал через ваше плечо и читал текст.
Мы опишем большинство самых полезных функций виджета
GtkEntry
:
<b>GtkWidget* gtk_entry_new(void);</b>
<b>GtkWidget* gtk_entry_new_with_max_length(gint max);</b>
<b>void gtk_entry_set_max_length(GtkEntry *entry, gint max);</b>
<b>G_CONST_RETURN gchar* gtk_entry_get_text(GtkEntry *entry);</b>
<b>void gtk_entry_set_text(GtkEntry *entry, const gchar *text);</b>
<b>void gtk_entry_append_text(GtkEntry *entry, const gchar *text);</b>
<b>void gtk_entry_prepend_text(GtkEntry* entry, const gchar *text);</b>
<b>void gtk_entry_set_visibility(GtkEntry *entry, gboolean visible);</b>
<b>void gtk_entry_set_invisible_char(GtkEntry *entry, gchar invch);</b>
<b>void gtk_entry_set_editable(GtkEntry *entry, gboolean editable);</b>
Вы можете создать
GtkEntry
с помощью функции
gtk_entry_new
или при вводе текста фиксированной длины с помощью функции
gtk_entry_new_with_max_length
. Ограничение ввода определенной длиной текста избавляет вас от проверки корректности длины ввода и, возможно, необходимости информировать пользователя о том, что текст слишком длинный.
Для получения содержимого виджета
GtkEntry
вызывайте функцию
gtk_entry_get_text
, которая возвращает указатель
const char
, внутренний по отношению к
GtkEntry
(
G_CONST_RETURN
— макрос, определенный в библиотеке GLib). Если вы хотите изменить текст или передать его в функцию, которая может его модифицировать, следует скопировать строку с помощью, например, функции
strcpy
.