复合构件之消息对话框

代码;

复制代码
#include <gtk-2.0/gtk/gtk.h>
static void font_dialog_response(GtkFontSelectionDialog *dialog,
                                       gint response,
                                       gpointer data)
                                        	// 处理字体选择对话框按钮按下事件
{
   gchar *font;
   GtkWidget *message;
   switch (response) {
   case (GTK_RESPONSE_APPLY):
   case (GTK_RESPONSE_OK):		// 当gtk-apply或gtk-ok按钮按下时处理
      font = gtk_font_selection_dialog_get_font_name(dialog);
       								// 获取字体选择对话框所选择字体名
      message = gtk_message_dialog_new(NULL,
                                              GTK_DIALOG_MODAL,
                                              GTK_MESSAGE_INFO,
                                              GTK_BUTTONS_OK,
                                              font);	// 创建一个新对话框显示字体名
      gtk_window_set_title(GTK_WINDOW(message),"所选择字体");
      gtk_dialog_run(GTK_DIALOG(message));
      gtk_widget_destroy(message);
      g_free(font);
      break;
   default:
      gtk_widget_destroy(GTK_WIDGET(dialog));	// 删除字体选择对话框
   }
   if (response == GTK_RESPONSE_OK)
      gtk_widget_destroy(GTK_WIDGET(dialog));
   gtk_main_quit();								// 退出GTK+主循环
}
int main(int argc, char *argv[]) {
   gtk_init(&argc, &argv);
   GtkWidget *dialog;
   dialog = gtk_font_selection_dialog_new ("请选择字体");
   												// 创建字体选择对话框
   gtk_font_selection_dialog_set_font_name(GTK_FONT_SELECTION_DIALOG 	(dialog),
                                         "Sans Bold Italic 12");
                                          	// 设置对话框字体名
   gtk_font_selection_dialog_set_preview_text (  GTK_FONT_SELECTION_DIALOG (dialog),
                                           "感受GTK+开发的乐趣");
                                            	// 设置字体预览文本
   g_signal_connect(G_OBJECT (dialog), "response",
                        G_CALLBACK (font_dialog_response),
	                        NULL);				// 监听对话框中按钮按下事件
   gtk_widget_show_all(dialog);
   gtk_main();
   return 0;
}

编译运行

相关推荐
资深前端外卖员几秒前
【nodejs高可用】前端APM应用监控方案 + 落地
前端·后端
牙痛不能吃糖,哭几秒前
C++面试复习日记(8)2025.4.25,malloc,free和new,delete的区别
开发语言·c++
OhBonsai几秒前
Shader 图像处理1_ToneMap技术处理过曝
前端
突头小恐龙1 分钟前
Chrome devTools - Lighthouse
前端·javascript·chrome
谦谦橘子1 分钟前
手写tiny webpack,理解webpack原理
前端·javascript·webpack
土豆12503 分钟前
Tailwind CSS 精通指南:提升效率、可维护性与最佳实践
前端·css
花生了什么树lll3 分钟前
面试中被问到过的前端八股(四)
前端·面试
zqlcoding3 分钟前
使用el-table表格动态渲染表头数据之后,导致设置fixed的列渲染出现问题
前端·javascript·vue.js
健康的猪4 分钟前
golang的cgo的一点小心得
开发语言·后端·golang
爱吃的强哥15 分钟前
vue3 使用 vite 管理多个项目,实现各子项目独立运行,独立打包
前端·javascript·vue.js