[LinuxFocus-icon]
<--  | Домой  | Карта  | Индекс  | Поиск

Новости | Архивы | Ссылки | Про LF
[an error occurred while processing this directive]
Ozcan Gungor
автор Özcan Güngör
<ozcangungor(at)netscape.net>

Об авторе:
На данный момент я нахожусь на армейской службе в качестве администратора Linux и Oracle и веб-программиста.

Перевод на Русский:
Yuri Slobodyanyuk <yurisk(at)inbox.ru>

Содержание:

 

Программирование ГПИ с использованием GTK - часть 3

GTK

Резюме:

В этой серии статей мы узнаем, как создавать программы графического пользовательского интерфейса (ГПИ) с помощью GTK.Я не знаю, насколько затянется эта серия. Чтобы понять эти статьи вам необходимы следующие знания о языке программирования C:

  • Переменные
  • Функции
  • Указатели
рекомендую прочитать предыдущие статьи:
Програмирование ГПИ с использованием GTK - часть 1.,
Програмирование ГПИ с использованием GTK - часть 2. .
Эта статья немного короче остальных так как автор служит в армии.

_________________ _________________ _________________

 

Toggle кнопка.

Эта кнопка выглядит как обычная кнопка но имеет два состояния: "нажата" или нет. Для создания кнопки 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 (так же известная как 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);
}
 

Label (метка)

Метки позволяют Вам расположить любой текст в любом месте окна.
Для создания метки используйте следующую функцию:

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.

 

ToolTips (всплывающая подсказка)

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

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);
   }
Любые замечания и комментарии принимаются.  

Страница отзывов

У каждой заметки есть страница отзывов. На этой странице вы можете оставить свой комментарий или просмотреть комментарии других читателей
 talkback page 

<--, перейти к начальной странице выпуска

Webpages maintained by the LinuxFocus Editor team
© Özcan Güngör, FDL
LinuxFocus.org
Translation information:
tr --> -- : Özcan Güngör <ozcangungor(at)netscape.net>
en --> tr: Özcan Güngör <ozcangungor(at)netscape.net>
en --> ru: Yuri Slobodyanyuk <yurisk(at)inbox.ru>

2004-04-28, generated by lfparser version 2.43