📄 c554.html
字号:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN"><HTML><HEAD><TITLE>按钮构件</TITLE><METANAME="GENERATOR"CONTENT="Modular DocBook HTML Stylesheet Version 1.76b+"><LINKREL="HOME"TITLE="GTK+ 2.0 教程"HREF="book1.html"><LINKREL="PREVIOUS"TITLE="无窗口构件"HREF="x546.html"><LINKREL="NEXT"TITLE="开关按钮 Toggle Buttons"HREF="x583.html"></HEAD><BODYCLASS="CHAPTER"BGCOLOR="#FFFFFF"TEXT="#000000"LINK="#0000FF"VLINK="#840084"ALINK="#0000FF"><DIVCLASS="NAVHEADER"><TABLESUMMARY="Header navigation table"WIDTH="100%"BORDER="0"CELLPADDING="0"CELLSPACING="0"><TR><THCOLSPAN="3"ALIGN="center">GTK+ 2.0 教程</TH></TR><TR><TDWIDTH="10%"ALIGN="left"VALIGN="bottom"><AHREF="x546.html"ACCESSKEY="P"><<< Previous</A></TD><TDWIDTH="80%"ALIGN="center"VALIGN="bottom"></TD><TDWIDTH="10%"ALIGN="right"VALIGN="bottom"><AHREF="x583.html"ACCESSKEY="N">Next >>></A></TD></TR></TABLE><HRALIGN="LEFT"WIDTH="100%"></DIV><DIVCLASS="CHAPTER"><H1><ANAME="CH-BUTTONWIDGET">按钮构件</H1><DIVCLASS="SECT1"><H1CLASS="SECT1"><ANAME="SEC-NORMALBUTTONS">一般按钮 Normal Buttons</H1><P>在前面我们见到得最多的就是按钮构件了。它们十分简单。创建按钮有好几种方法。你可以用 gtk_button_new_with_label() 或 gtk_button_new_with_mnemonic() 来创建一个带标签的按钮,用 gtk_button_new_from_stock() 来从一个原料(stock)项创建一个包含图像和文本的按钮,或者用 gtk_button_new() 创建一个空白按钮。接着你可以决定把一个标签或位图(pixmap)组装到这个新创建的按钮里。要这样做,创建一个新的盒,然后用常见的 gtk_box_pack_start() 把你的对象组装到盒里,再用 gtk_container_add() 把盒组装到按钮里。</P><P>这里是一个用函数 gtk_button_new() 去创建一个带图像和标签的按钮的示例。我把创建盒的代码分离了出来,这样你可以在你自己的程序中使用它。后面还有更多使用图像的示例。</P><P><SPANCLASS="INLINEMEDIAOBJECT"><IMGSRC="images/buttons.png"></SPAN></P><TABLEBORDER="0"BGCOLOR="#E0E0E0"WIDTH="100%"><TR><TD><PRECLASS="PROGRAMLISTING"> #include <stdlib.h>#include <gtk/gtk.h>/* 创建一个新的横向盒,它包含一个图像和一个标签,并返回这个盒。*/GtkWidget *xpm_label_box( gchar *xpm_filename, gchar *label_text ){ GtkWidget *box; GtkWidget *label; GtkWidget *image; /* 为图像和标签创建盒 */ box = gtk_hbox_new (FALSE, 0); gtk_container_set_border_width (GTK_CONTAINER (box), 2); /* 创建一个图像 */ image = gtk_image_new_from_file (xpm_filename); /* 为按钮创建一个标签 */ label = gtk_label_new (label_text); /* 把图像和标签组装到盒子里 */ gtk_box_pack_start (GTK_BOX (box), image, FALSE, FALSE, 3); gtk_box_pack_start (GTK_BOX (box), label, FALSE, FALSE, 3); gtk_widget_show (image); gtk_widget_show (label); return box;}/* 我们常见的回调函数 */void callback( GtkWidget *widget, gpointer data ){ g_print ("Hello again - %s was pressed\n", (char *) data);}int main( int argc, char *argv[] ){ /* GtkWidget 是构件的存储类型 */ GtkWidget *window; GtkWidget *button; GtkWidget *box; gtk_init (&argc, &argv); /* 创建一个新窗口 */ window = gtk_window_new (GTK_WINDOW_TOPLEVEL); gtk_window_set_title (GTK_WINDOW (window), "Pixmap'd Buttons!"); /* 对所有的窗口做这一步是一个好主意。*/ g_signal_connect (G_OBJECT (window), "destroy", G_CALLBACK (gtk_main_quit), NULL); g_signal_connect (G_OBJECT (window), "delete_event", G_CALLBACK (gtk_main_quit), NULL); /* 设置窗口边框的宽度。*/ gtk_container_set_border_width (GTK_CONTAINER (window), 10); /* 创建一个新的按钮 */ button = gtk_button_new (); /* 连接按钮的 "clicked" 信号到我们的回调 */ g_signal_connect (G_OBJECT (button), "clicked", G_CALLBACK (callback), (gpointer) "cool button"); /* 调用我们的创建盒的函数 */ box = xpm_label_box ("info.xpm", "cool button"); /* 组装和显示所有的构件 */ gtk_widget_show (box); gtk_container_add (GTK_CONTAINER (button), box); gtk_widget_show (button); gtk_container_add (GTK_CONTAINER (window), button); gtk_widget_show (window); /* 停在这里,等待事件发生。 */ gtk_main (); return 0;}</PRE></TD></TR></TABLE><P>函数 xpm_label_box() 可用于组装图像和标签到任何可以作为容器的构件里。</P><P>按钮构件有如下信号:</P><P></P><UL><LI><P><TTCLASS="LITERAL">pressed</TT> --- 当鼠标键在按钮构件里按下时发出</P></LI><LI><P><TTCLASS="LITERAL">released</TT> --- 当鼠标键在按钮构件里释放时发出</P></LI><LI><P><TTCLASS="LITERAL">clicked</TT> --- 当鼠标键在按钮构件里按下并接着在按钮构件里释放时发出</P></LI><LI><P><TTCLASS="LITERAL">enter</TT> --- 当鼠标光标进入按钮构件时发出</P></LI><LI><P><TTCLASS="LITERAL">leave</TT> --- 当鼠标光标离开按钮构件时发出</P></LI></UL></DIV></DIV><DIVCLASS="NAVFOOTER"><HRALIGN="LEFT"WIDTH="100%"><TABLESUMMARY="Footer navigation table"WIDTH="100%"BORDER="0"CELLPADDING="0"CELLSPACING="0"><TR><TDWIDTH="33%"ALIGN="left"VALIGN="top"><AHREF="x546.html"ACCESSKEY="P"><<< Previous</A></TD><TDWIDTH="34%"ALIGN="center"VALIGN="top"><AHREF="book1.html"ACCESSKEY="H">Home</A></TD><TDWIDTH="33%"ALIGN="right"VALIGN="top"><AHREF="x583.html"ACCESSKEY="N">Next >>></A></TD></TR><TR><TDWIDTH="33%"ALIGN="left"VALIGN="top">无窗口构件</TD><TDWIDTH="34%"ALIGN="center"VALIGN="top"> </TD><TDWIDTH="33%"ALIGN="right"VALIGN="top">开关按钮 Toggle Buttons</TD></TR></TABLE></DIV></BODY></HTML>
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -