亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? gtk_tut-9.html

?? GTK development guide
?? HTML
?? 第 1 頁 / 共 5 頁
字號(hào):
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 3.2 Final//EN">
<HTML>
<HEAD>
 <META NAME="GENERATOR" CONTENT="SGML-Tools 1.0.7">
 <TITLE>GTK v1.2 Tutorial: Miscellaneous Widgets</TITLE>
 <LINK HREF="gtk_tut-10.html" REL=next>
 <LINK HREF="gtk_tut-8.html" REL=previous>
 <LINK HREF="gtk_tut.html#toc9" REL=contents>
</HEAD>
<BODY TEXT="#CCCCCC" BGCOLOR="#000000" LINK="#33cc00" VLINK="#009900" ALINK="#FF0000">
<A HREF="gtk_tut-10.html">Next</A>
<A HREF="gtk_tut-8.html">Previous</A>
<A HREF="gtk_tut.html#toc9">Contents</A>
<HR>
<H2><A NAME="s9">9. Miscellaneous Widgets</A></H2>

<H2><A NAME="ss9.1">9.1 Labels</A>
</H2>

<P>Labels are used a lot in GTK, and are relatively simple. Labels emit
no signals as they do not have an associated X window. If you need to
catch signals, or do clipping, place it inside a 
<A HREF="gtk_tut-10.html#sec_EventBox">EventBox</A> widget or a Button widget.
<P>To create a new label, use:
<P>
<BLOCKQUOTE><CODE>
<PRE>
GtkWidget *gtk_label_new( char *str );
</PRE>
</CODE></BLOCKQUOTE>
<P>The sole argument is the string you wish the label to display.
<P>To change the label's text after creation, use the function:
<P>
<BLOCKQUOTE><CODE>
<PRE>
void gtk_label_set_text( GtkLabel *label,
                         char     *str );
</PRE>
</CODE></BLOCKQUOTE>
<P>The first argument is the label you created previously (cast
using the <CODE>GTK_LABEL()</CODE> macro), and the second is the new string.
<P>The space needed for the new string will be automatically adjusted if
needed. You can produce multi-line labels by putting line breaks in
the label string.
<P>To retrieve the current string, use:
<P>
<BLOCKQUOTE><CODE>
<PRE>
void gtk_label_get( GtkLabel  *label,
                    char     **str );
</PRE>
</CODE></BLOCKQUOTE>
<P>The first argument is the label you've created, and the second,
the return for the string. Do not free the return string, as it is
used internally by GTK.
<P>The label text can be justified using:
<P>
<BLOCKQUOTE><CODE>
<PRE>
void gtk_label_set_justify( GtkLabel         *label,
                            GtkJustification  jtype );
</PRE>
</CODE></BLOCKQUOTE>
<P>Values for <CODE>jtype</CODE> are:
<BLOCKQUOTE><CODE>
<PRE>
  GTK_JUSTIFY_LEFT
  GTK_JUSTIFY_RIGHT
  GTK_JUSTIFY_CENTER (the default)
  GTK_JUSTIFY_FILL
</PRE>
</CODE></BLOCKQUOTE>
<P>The label widget is also capable of line wrapping the text
automatically. This can be activated using:
<P>
<BLOCKQUOTE><CODE>
<PRE>
void gtk_label_set_line_wrap (GtkLabel *label,
                              gboolean  wrap);
</PRE>
</CODE></BLOCKQUOTE>
<P>The <CODE>wrap</CODE> argument takes a TRUE or FALSE value.
<P>If you want your label underlined, then you can set a pattern on the
label:
<P>
<BLOCKQUOTE><CODE>
<PRE>
void       gtk_label_set_pattern   (GtkLabel          *label,
                                    const gchar       *pattern);
</PRE>
</CODE></BLOCKQUOTE>
<P>The pattern argument indicates how the underlining should look. It
consists of a string of underscore and space characters. An underscore
indicates that the corresponding character in the label should be
underlined. For example, the string 
<PRE>
"__     __"
</PRE>
 would underline the
first two characters and eight and ninth characters.
<P>Below is a short example to illustrate these functions. This example
makes use of the Frame widget to better demonstrate the label
styles. You can ignore this for now as the 
<A HREF="gtk_tut-10.html#sec_Frames">Frame</A> widget is explained later on.
<P>
<BLOCKQUOTE><CODE>
<PRE>
/* example-start label label.c */

#include &lt;gtk/gtk.h>

int main( int   argc,
          char *argv[] )
{
  static GtkWidget *window = NULL;
  GtkWidget *hbox;
  GtkWidget *vbox;
  GtkWidget *frame;
  GtkWidget *label;

  /* Initialise GTK */
  gtk_init(&amp;argc, &amp;argv);

  window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
  gtk_signal_connect (GTK_OBJECT (window), "destroy",
                      GTK_SIGNAL_FUNC(gtk_main_quit),
                      NULL);

  gtk_window_set_title (GTK_WINDOW (window), "Label");
  vbox = gtk_vbox_new (FALSE, 5);
  hbox = gtk_hbox_new (FALSE, 5);
  gtk_container_add (GTK_CONTAINER (window), hbox);
  gtk_box_pack_start (GTK_BOX (hbox), vbox, FALSE, FALSE, 0);
  gtk_container_set_border_width (GTK_CONTAINER (window), 5);
  
  frame = gtk_frame_new ("Normal Label");
  label = gtk_label_new ("This is a Normal label");
  gtk_container_add (GTK_CONTAINER (frame), label);
  gtk_box_pack_start (GTK_BOX (vbox), frame, FALSE, FALSE, 0);
  
  frame = gtk_frame_new ("Multi-line Label");
  label = gtk_label_new ("This is a Multi-line label.\nSecond line\n" \
                         "Third line");
  gtk_container_add (GTK_CONTAINER (frame), label);
  gtk_box_pack_start (GTK_BOX (vbox), frame, FALSE, FALSE, 0);
  
  frame = gtk_frame_new ("Left Justified Label");
  label = gtk_label_new ("This is a Left-Justified\n" \
                         "Multi-line label.\nThird      line");
  gtk_label_set_justify (GTK_LABEL (label), GTK_JUSTIFY_LEFT);
  gtk_container_add (GTK_CONTAINER (frame), label);
  gtk_box_pack_start (GTK_BOX (vbox), frame, FALSE, FALSE, 0);
  
  frame = gtk_frame_new ("Right Justified Label");
  label = gtk_label_new ("This is a Right-Justified\nMulti-line label.\n" \
                         "Fourth line, (j/k)");
  gtk_label_set_justify (GTK_LABEL (label), GTK_JUSTIFY_RIGHT);
  gtk_container_add (GTK_CONTAINER (frame), label);
  gtk_box_pack_start (GTK_BOX (vbox), frame, FALSE, FALSE, 0);

  vbox = gtk_vbox_new (FALSE, 5);
  gtk_box_pack_start (GTK_BOX (hbox), vbox, FALSE, FALSE, 0);
  frame = gtk_frame_new ("Line wrapped label");
  label = gtk_label_new ("This is an example of a line-wrapped label.  It " \
                         "should not be taking up the entire             " /* big space to test spacing */\
                         "width allocated to it, but automatically " \
                         "wraps the words to fit.  " \
                         "The time has come, for all good men, to come to " \
                         "the aid of their party.  " \
                         "The sixth sheik's six sheep's sick.\n" \
                         "     It supports multiple paragraphs correctly, " \
                         "and  correctly   adds "\
                         "many          extra  spaces. ");
  gtk_label_set_line_wrap (GTK_LABEL (label), TRUE);
  gtk_container_add (GTK_CONTAINER (frame), label);
  gtk_box_pack_start (GTK_BOX (vbox), frame, FALSE, FALSE, 0);
  
  frame = gtk_frame_new ("Filled, wrapped label");
  label = gtk_label_new ("This is an example of a line-wrapped, filled label.  " \
                         "It should be taking "\
                         "up the entire              width allocated to it.  " \
                         "Here is a sentence to prove "\
                         "my point.  Here is another sentence. "\
                         "Here comes the sun, do de do de do.\n"\
                         "    This is a new paragraph.\n"\
                         "    This is another newer, longer, better " \
                         "paragraph.  It is coming to an end, "\
                         "unfortunately.");
  gtk_label_set_justify (GTK_LABEL (label), GTK_JUSTIFY_FILL);
  gtk_label_set_line_wrap (GTK_LABEL (label), TRUE);
  gtk_container_add (GTK_CONTAINER (frame), label);
  gtk_box_pack_start (GTK_BOX (vbox), frame, FALSE, FALSE, 0);
  
  frame = gtk_frame_new ("Underlined label");
  label = gtk_label_new ("This label is underlined!\n"
                         "This one is underlined in quite a funky fashion");
  gtk_label_set_justify (GTK_LABEL (label), GTK_JUSTIFY_LEFT);
  gtk_label_set_pattern (GTK_LABEL (label),
                         "_________________________ _ _________ _ ______     __ _______ ___");
  gtk_container_add (GTK_CONTAINER (frame), label);
  gtk_box_pack_start (GTK_BOX (vbox), frame, FALSE, FALSE, 0);
  
  gtk_widget_show_all (window);

  gtk_main ();
  
  return(0);
}
/* example-end */
</PRE>
</CODE></BLOCKQUOTE>
<P>
<H2><A NAME="ss9.2">9.2 Arrows</A>
</H2>

<P>The Arrow widget draws an arrowhead, facing in a number of possible
directions and having a number of possible styles. It can be very
useful when placed on a button in many applications. Like the Label
widget, it emits no signals.
<P>There are only two functions for manipulating an Arrow widget:
<P>
<BLOCKQUOTE><CODE>
<PRE>
GtkWidget *gtk_arrow_new( GtkArrowType   arrow_type,
                          GtkShadowType  shadow_type );

void gtk_arrow_set( GtkArrow      *arrow,
                    GtkArrowType   arrow_type,
                    GtkShadowType  shadow_type );
</PRE>
</CODE></BLOCKQUOTE>
<P>The first creates a new arrow widget with the indicated type and
appearance. The second allows these values to be altered
retrospectively. The <CODE>arrow_type</CODE> argument may take one of the
following values:
<P>
<BLOCKQUOTE><CODE>
<PRE>
  GTK_ARROW_UP
  GTK_ARROW_DOWN
  GTK_ARROW_LEFT
  GTK_ARROW_RIGHT
</PRE>
</CODE></BLOCKQUOTE>
<P>These values obviously indicate the direction in which the arrow will
point. The <CODE>shadow_type</CODE> argument may take one of these values:
<P>
<BLOCKQUOTE><CODE>
<PRE>
  GTK_SHADOW_IN
  GTK_SHADOW_OUT (the default)
  GTK_SHADOW_ETCHED_IN
  GTK_SHADOW_ETCHED_OUT
</PRE>
</CODE></BLOCKQUOTE>
<P>Here's a brief example to illustrate their use.
<P>
<BLOCKQUOTE><CODE>
<PRE>
/* example-start arrow arrow.c */

#include &lt;gtk/gtk.h>

/* Create an Arrow widget with the specified parameters
 * and pack it into a button */
GtkWidget *create_arrow_button( GtkArrowType  arrow_type,
                                GtkShadowType shadow_type )
{
  GtkWidget *button;
  GtkWidget *arrow;

  button = gtk_button_new();
  arrow = gtk_arrow_new (arrow_type, shadow_type);

  gtk_container_add (GTK_CONTAINER (button), arrow);
  
  gtk_widget_show(button);
  gtk_widget_show(arrow);

  return(button);
}

int main( int   argc,
          char *argv[] )
{
  /* GtkWidget is the storage type for widgets */
  GtkWidget *window;
  GtkWidget *button;
  GtkWidget *box;

  /* Initialize the toolkit */
  gtk_init (&amp;argc, &amp;argv);

  /* Create a new window */
  window = gtk_window_new (GTK_WINDOW_TOPLEVEL);

  gtk_window_set_title (GTK_WINDOW (window), "Arrow Buttons");

  /* It's a good idea to do this for all windows. */
  gtk_signal_connect (GTK_OBJECT (window), "destroy",
                      GTK_SIGNAL_FUNC (gtk_main_quit), NULL);

  /* Sets the border width of the window. */
  gtk_container_set_border_width (GTK_CONTAINER (window), 10);

  /* Create a box to hold the arrows/buttons */
  box = gtk_hbox_new (FALSE, 0);
  gtk_container_set_border_width (GTK_CONTAINER (box), 2);
  gtk_container_add (GTK_CONTAINER (window), box);

  /* Pack and show all our widgets */
  gtk_widget_show(box);

  button = create_arrow_button(GTK_ARROW_UP, GTK_SHADOW_IN);
  gtk_box_pack_start (GTK_BOX (box), button, FALSE, FALSE, 3);

  button = create_arrow_button(GTK_ARROW_DOWN, GTK_SHADOW_OUT);
  gtk_box_pack_start (GTK_BOX (box), button, FALSE, FALSE, 3);
  
  button = create_arrow_button(GTK_ARROW_LEFT, GTK_SHADOW_ETCHED_IN);
  gtk_box_pack_start (GTK_BOX (box), button, FALSE, FALSE, 3);
  
  button = create_arrow_button(GTK_ARROW_RIGHT, GTK_SHADOW_ETCHED_OUT);
  gtk_box_pack_start (GTK_BOX (box), button, FALSE, FALSE, 3);
  
  gtk_widget_show (window);
  
  /* Rest in gtk_main and wait for the fun to begin! */
  gtk_main ();
  
  return(0);
}
/* example-end */
</PRE>
</CODE></BLOCKQUOTE>
<P>
<H2><A NAME="ss9.3">9.3 The Tooltips Object</A>
</H2>

<P>These are the little text strings that pop up when you leave your
pointer over a button or other widget for a few seconds. They are easy
to use, so I will just explain them without giving an example. If you
want to see some code, take a look at the testgtk.c program
distributed with GTK.
<P>Widgets that do not receive events (widgets that do not have their
own window) will not work with tooltips.
<P>The first call you will use creates a new tooltip. You only need to do
this once for a set of tooltips as the <CODE>GtkTooltips</CODE> object this
function returns can be used to create multiple tooltips.
<P>
<BLOCKQUOTE><CODE>
<PRE>
GtkTooltips *gtk_tooltips_new( void );
</PRE>
</CODE></BLOCKQUOTE>
<P>Once you have created a new tooltip, and the widget you wish to use it
on, simply use this call to set it:
<P>
<BLOCKQUOTE><CODE>
<PRE>
void gtk_tooltips_set_tip( GtkTooltips *tooltips,
                           GtkWidget   *widget,
                           const gchar *tip_text,
                           const gchar *tip_private );

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
高清免费成人av| 日本高清不卡一区| 亚洲高清在线视频| youjizz久久| 欧美色偷偷大香| 亚洲欧洲综合另类| 欧美一级在线观看| 欧美精品九九99久久| 日韩理论片在线| 丁香婷婷综合网| 久久久久久一二三区| 日本少妇一区二区| 欧美亚洲动漫另类| 亚洲国产你懂的| 欧美在线播放高清精品| 亚洲精品欧美在线| 一本一本久久a久久精品综合麻豆 一本一道波多野结衣一区二区 | 制服视频三区第一页精品| 欧美日韩国产高清一区二区| 欧美本精品男人aⅴ天堂| 综合电影一区二区三区| 美女诱惑一区二区| 91丝袜呻吟高潮美腿白嫩在线观看| 日韩一区和二区| 一区二区三区在线观看视频| 国产毛片一区二区| 欧美一区二区不卡视频| 一区二区国产视频| 国产成人精品网址| 日韩美女一区二区三区四区| 亚洲一区二区三区四区不卡| 色呦呦日韩精品| 最新久久zyz资源站| 福利视频网站一区二区三区| 精品国产一区二区亚洲人成毛片 | 丁香一区二区三区| 久久久久国产精品厨房| 国内成人免费视频| 精品精品欲导航| 国产一区二区三区香蕉| 久久久亚洲欧洲日产国码αv| 免费看黄色91| 欧美xxxx在线观看| 国产白丝精品91爽爽久久| 中文字幕欧美区| 欧洲国产伦久久久久久久| 亚洲综合在线第一页| 欧美久久一二区| 激情成人综合网| 一区二区中文视频| 欧美性受xxxx黑人xyx| 蜜桃久久久久久久| 中文在线资源观看网站视频免费不卡| 国产黄人亚洲片| 亚洲一区二区在线免费看| 欧美日韩国产精品成人| 蜜桃视频在线一区| 中文字幕一区二区日韩精品绯色| 欧美性生活影院| 国产在线观看免费一区| 亚洲人快播电影网| 欧美大黄免费观看| 欧美在线免费播放| 国产成人综合自拍| 蜜桃传媒麻豆第一区在线观看| 久久久久久综合| 日韩精品最新网址| 欧美日韩中文字幕精品| 成人免费电影视频| 国产综合色在线| 国产成人啪免费观看软件| 秋霞国产午夜精品免费视频| 亚洲丝袜美腿综合| 国产精品视频在线看| 精品久久人人做人人爰| 制服丝袜激情欧洲亚洲| 色婷婷亚洲综合| 色综合天天综合网国产成人综合天| 精品系列免费在线观看| 久久国产精品区| 免费成人在线网站| 日韩电影网1区2区| 麻豆国产欧美一区二区三区| 亚洲风情在线资源站| 天天综合日日夜夜精品| 日本aⅴ免费视频一区二区三区| 亚洲色图19p| 午夜一区二区三区视频| 人禽交欧美网站| 国产久卡久卡久卡久卡视频精品| 久久99国产精品久久| 高清不卡一二三区| 色婷婷亚洲综合| 欧美va亚洲va在线观看蝴蝶网| 精品国精品国产| 亚洲欧美日韩国产手机在线| 亚洲一区在线观看网站| 午夜精品久久久久久久蜜桃app| 免费国产亚洲视频| 不卡av在线免费观看| 欧美日韩精品欧美日韩精品| 欧美v国产在线一区二区三区| 久久精品日韩一区二区三区| 国产精品久久久久9999吃药| 性做久久久久久久免费看| 久久av资源站| 欧美三级电影一区| 久久精品一区二区三区四区| 亚洲一区二区视频在线| 国产精品影视网| 国产精品免费久久| 免费在线视频一区| 91麻豆国产精品久久| 欧美xxxx老人做受| 亚洲高清免费在线| 91视频91自| 亚洲国产岛国毛片在线| 久久精品国产精品亚洲综合| 欧美午夜一区二区三区免费大片| 国产精品私人自拍| 国产不卡视频在线观看| 欧美成人精品3d动漫h| 免费在线看一区| 884aa四虎影成人精品一区| 亚洲一区二区精品3399| 在线区一区二视频| 国产精品二区一区二区aⅴ污介绍| 国产一区二区在线观看视频| 日韩一区二区三区视频在线| 天天操天天综合网| 欧美日韩精品一二三区| 亚洲成精国产精品女| 欧美色综合网站| 性做久久久久久| 日韩一级高清毛片| 激情六月婷婷综合| 国产日产欧美精品一区二区三区| 极品少妇一区二区| 国产精品久久777777| 91黄视频在线观看| 秋霞影院一区二区| 国产嫩草影院久久久久| 一本色道久久综合狠狠躁的推荐 | 色综合久久99| 日韩高清一区二区| 久久精品一区二区三区四区| 91蜜桃视频在线| 久久91精品国产91久久小草| 欧美国产激情一区二区三区蜜月 | 国产精品视频麻豆| 国产欧美精品一区aⅴ影院| 日本高清不卡视频| 国产一区二区看久久| 亚洲一区二区成人在线观看| 久久一区二区三区国产精品| 99国产麻豆精品| 久久精品国产亚洲一区二区三区| 欧美国产日韩在线观看| 欧美剧在线免费观看网站| 北条麻妃国产九九精品视频| 免费成人在线视频观看| 亚洲综合男人的天堂| 中文字幕亚洲精品在线观看| 欧美精品一区二区在线播放| 欧美久久久一区| 欧美性生活久久| 在线一区二区三区| 99在线精品免费| av高清久久久| 99久久久无码国产精品| 成人av网站在线观看| 国产成人自拍网| 懂色av一区二区三区免费看| 狠狠狠色丁香婷婷综合久久五月| 午夜视频在线观看一区| 亚洲激情网站免费观看| 亚洲美女在线一区| 亚洲乱码精品一二三四区日韩在线 | 亚洲精品在线免费播放| 2021中文字幕一区亚洲| 26uuu成人网一区二区三区| 精品国产一区二区三区忘忧草| 亚洲精品一区二区三区99| 亚洲精品一区二区三区香蕉| 欧美高清在线精品一区| 国产精品久久久久久久久动漫 | 精品蜜桃在线看| 欧美韩国一区二区| 亚洲精品成a人| 美女一区二区三区在线观看| 国产一区二区三区四区五区美女| 国产成人综合视频| 欧美私模裸体表演在线观看| 日韩一级片在线播放| 国产精品国产三级国产aⅴ原创| 国产精品人妖ts系列视频| 日韩中文字幕区一区有砖一区| 国产91丝袜在线播放0| 欧美日韩一区小说| 国产三级一区二区|