 
 
    В этой серии статей мы узнаем, как создавать программы графического пользовательского интерфейса (ГПИ) с помощью GTK.Я не знаю, насколько затянется эта серия. Чтобы понять эти статьи вам необходимы следующие знания о языке программирования C:
 
 
    Эта кнопка выглядит как обычная кнопка но имеет два состояния: "нажата" или нет. Для создания кнопки toggle может быть использована одна из следующих функций:
GtkWidget *toggle=gtk_toggle_button_new(void); GtkWidget *toggle=gtk_toggle_button_new_with_label(const gchar *label);
Первая функция создает toggle кнопку без текстовой метки в то время как
 вторая функция  создает ее со строкой текста label в ней..
     Вы можете задать состояние кнопки следующей функцией:
    
gtk_toggle_button_set_active (GtkToggleButton *toggle_button, 
                              gboolean is_active);
    где toggle_button это кнопка состояние которой хотите изменить и is_active желаемое состояние (0 или 1). Когда оно 0 - кнопка не в "нажатом" состоянии; когда же 1 то кнопка в "нажатом" состоянии..
Чтобы узнать состояние кнопки испльзуется следующая функция:
gboolean gtk_toggle_button_get_active(GtkToggleButton *button);
Событие "toggled" (изменение состояния) может быть привязано к кнопке "toggle".
Ниже приведен пример:
#include <gtk/gtk.h>
void togg(GtkWidget *widget, gpointer *data){
   if (gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(data)))
    g_print("State is 1\n");
   else
    g_print("State is 0\n");
}
int main( int argc,char *argv[] )
   {
   
   GtkWidget *window;
   GtkWidget *button;
   gtk_init (&argc, &argv);
   /* Create a new window */
   window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
   gtk_window_set_title (GTK_WINDOW (window), "Toggle Button");
   /* Connect destroy event to the window. */
   gtk_signal_connect (GTK_OBJECT (window), "destroy",
                       GTK_SIGNAL_FUNC(gtk_main_quit), NULL);
   
   /* Creates a toggle button */ 
   button=gtk_toggle_button_new_with_label("I'm a toggle button");
   
   /* Add the button to window */
   gtk_container_add(GTK_CONTAINER(window),button);
   /* Connect "toggled" event to the button */ 
   gtk_signal_connect (GTK_OBJECT (button), "toggled",
                       GTK_SIGNAL_FUNC(togg),(gpointer *)button);
   gtk_widget_show(button);
   gtk_widget_show (window);
   
   gtk_main ();
   return(0);
}
    Кнопка check (так же известная как check box) это подкласс кнопки toggle. 
Она может быть
 испльзована для выбора каких-либо вариантов.
    Для создания кнопки check  используется следующая функция:
GtkWidget* gtk_check_button_new (void); GtkWidget* gtk_check_button_new_with_label (const gchar *label);
Пояснения тут такие же как для кнопки toggle.
Пример:
#include <gtk/gtk.h>
void togg(GtkWidget *widget, gpointer *data){
   if (gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(data)))
       g_print("State is 1\n");
   else
    g_print("State is 0\n");
}
int main( int argc,char *argv[] )
{
    GtkWidget *window;
    GtkWidget *button;
    gtk_init (&argc, &argv);
    
    /* Create a new window */
    window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
    gtk_window_set_title (GTK_WINDOW (window), "Check Button");
    /* Connect destroy event to the window. */
    gtk_signal_connect (GTK_OBJECT (window), "destroy",
                        GTK_SIGNAL_FUNC(gtk_main_quit), NULL);
   
    /* Creates a check button */ 
    button=gtk_check_button_new_with_label("I'm a check button");
   
    /* Add the button to window */
    gtk_container_add(GTK_CONTAINER(window),button);
    /* Connect "toggled" event to the button */ 
    gtk_signal_connect (GTK_OBJECT (button), "toggled",
                        GTK_SIGNAL_FUNC(togg), (gpointer *)button);
    gtk_widget_show(button);
    gtk_widget_show (window);
   
    gtk_main ();
    return(0);
}
    Метки позволяют Вам расположить любой текст в любом месте окна.
     Для создания метки используйте следующую функцию:
GtkWidget* gtk_label_new(const gchar *text);
С функцией
gtk_label_set_text(GtkLabel *label, gchar *text);
Вы можете изменить текст на метке в любое время.
gtk_label_set_justify(GtkLabel *label, GtkJustification jtype);
Функция gtk_label_set_justify используется для выравнивания текста на метке. jtype может быть :
gtk_label_set_line_wrap (GtkLabel *label,gboolean wrap);
позволяет тексту быть разбитым на части для переноса на следующую строку если не вмещается на одной.Когда wrap равно 1 текст будет продолжен на следующую строку, в противном случае этого не произойдет.
gtk_label_get(GtkLabel *label, gchar **str)
используется чтобы поместить текст метки в переменную str.
ToolTip это текст-подсказка появляющийся когда курсор мышки находится над объектом.Например Вы можете задать текст-подсказку "послать информацию" для кнопки и этот текст появится когда мышка над ней.
Чтобы это сделать сначала нужно создать объект GtkToolTips:
GtkToolTips* gtk_tooltips_new();
и теперь для привязки текста-подсказки:
gtk_tooltips_set_tip(GtkTooltips *tooltips, GtkWidget *widget, 
                     const gchar *tip_text,const gchar *tip_private);
    Небольшой пример:
#include <gtk/gtk.h>
int main( int argc,char *argv[] )
{
    GtkWidget *window;
    GtkWidget *button;
    GtkTooltips *tip;
    
    gtk_init (&argc, &argv);
    /* Create a new window */
    window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
    gtk_window_set_title (GTK_WINDOW (window), "Tooltips");
    /* Connect destroy event to the window. */
    gtk_signal_connect (GTK_OBJECT (window), "destroy",
                        GTK_SIGNAL_FUNC (gtk_main_quit), NULL);
    /* Creates a button */
    button=gtk_button_new_with_label("I'm a Button");
    /* Add the button to window */
    gtk_container_add(GTK_CONTAINER(window),button);
    /* Creates a tooltips*/
    tip=gtk_tooltips_new();
    /* Attache this tooltips to button with text*/
    gtk_tooltips_set_tip(tip, button, "Click me!",NULL);
    gtk_widget_show(button);
    gtk_widget_show (window);
    gtk_main ();
    return(0);
}
    Еще несколько функций:
gtk_tooltips_enable (GtkTooltips *tooltips);
Активирует текст-подсказку.
gtk_tooltips_disable (GtkTooltips *tooltips);
Деактивирует текст-подсказку.
Чтобы получить любую информацию касающуюся текст-подсказкок объекта.
GtkTooltipsData* gtk_tooltips_get_data(GtkWidget *widget);
GtkTooltipsData это структура следующего вида:
struct _GtkTooltipsData
{
   GtkTooltips *tooltips;
   GtkWidget *widget;
   gchar *tip_text;
   gchar *tip_private;
   GdkFont *font;
   gint width;
   GList *row;
};
    Чтобы определить время появления текст-подсказки:
gtk_tooltips_set_delay (GtkTooltips *tip, guint delay)
Combo Box это объект-окно объединенный с выпадающим списком в котором можно редактировать текст.
Он может быть создан с помощью:
GtkWidget *gtk_combo_new();
и нам нужен список возможных вариантов задаваемый с помощью структуры GList:
GList *glist=NULL;
сами возможные варинты для выбора вносятся в список так:
GList *g_list_append(GList *list, gchar *option);
Далее созданный список должен быть добавлен в Combo Box:
gtk_combo_set_popdown_strings(GtkCombo *combo, GList *List);
Теперь Combo Box готов.Прочитать выбранный вариант можно используя:
gchar *gtk_entry_get_text(GtkEntry *entry);
entry это GTK_ENTRY(GTK_COMBO(combo)->entry)) в этом случае.
gtk_combo_set_use_arrows(GtkCombo *combo,gint val);
Эта функция используется чтобы активировать\деактивировать клавиши вверх\вниз на клавиатуре используемые для изменения значения в Combo Box. Когда val равно 0 эти клавиши не функционируют и наоборот в противоположном случае. Но когда значение в Combo Box отлично от значений находящихся в списке эти клавиши не функционируют..
gtk_combo_set_use_arrows_always(GtkCombo *combo,gint val);
Эта функция аналогична gtk_combo_set_use_arrows но когда значение в Combo Box отлично от значений находящихся в списке эти клавиши функционируют..
gtk_combo_set_value_in_list(GtkCombo *combo, gboolean val, 
                             gboolean ok_if_empty);
    Когда val равно 1 Вы можете ввести значение из списка.Когда ok_if_empty равно 1 значение может быть пустым (отсутствовать). .
#include <gtk/gtk.h>
void act(GtkWidget *widget, gpointer *data){ 
   g_print((gchar *)data);
}
int main( int argc,char *argv[] ) {
   GtkWidget *window;
   GtkWidget *combo;
   GtkWidget *button;
   GtkWidget *box;
   GList *list=NULL; 
   list=g_list_append(list,"Slackware");
   list=g_list_append(list,"RedHat");
   list=g_list_append(list,"SuSE");
   gtk_init (&argc, &argv); 
   
   /* Create a new window */
   window = gtk_window_new (GTK_WINDOW_TOPLEVEL); 
   gtk_window_set_title (GTK_WINDOW (window), "Combo Box");
   
   /* Connect destroy event to the window. */
   gtk_signal_connect (GTK_OBJECT (window), "destroy",
                       GTK_SIGNAL_FUNC(gtk_main_quit), NULL); 
   
   /* Create a new horizontal box */
   box=gtk_hbox_new(1,0);
   gtk_container_add(GTK_CONTAINER(window),box);
   
   /* Creates a combo box */ 
   combo=gtk_combo_new();
   /* Sets the list */
   gtk_combo_set_popdown_strings(GTK_COMBO(combo),list);
   /* Enables up/down keys change the value. */
   gtk_combo_set_use_arrows_always(GTK_COMBO(combo),1);
   gtk_box_pack_start(GTK_BOX(box), combo,1,1,1); 
   button=gtk_button_new_with_label("Write it");
   gtk_signal_connect(GTK_OBJECT(button),"clicked",GTK_SIGNAL_FUNC(act), 
             gtk_entry_get_text(GTK_ENTRY(GTK_COMBO(combo)->entry)));
   gtk_box_pack_start(GTK_BOX(box), button,1,1,1);
   gtk_widget_show(box);
   gtk_widget_show(combo);
   gtk_widget_show(button); 
   gtk_widget_show (window);
   
   gtk_main ();
   return(0);
   }
   Любые замечания и комментарии принимаются.