glade.pas 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164
  1. program glade_test;
  2. {$mode objfpc} {$H+}
  3. {$IFDEF GTK2_0}{$FATAL this demo needs gtk 2.4}{$ENDIF}
  4. {$IFDEF GTK2_2}{$FATAL this demo needs gtk 2.4}{$ENDIF}
  5. uses
  6. cmem, { because of: ... ld.so: dl-minimal.c: 134: realloc: Assertion `ptr == alloc_last_block' failed! }
  7. Glib2, Gdk2, Gtk2, LibGlade2;
  8. procedure open_callback (widget : PGtkWidget;
  9. data : gpointer); cdecl; forward;
  10. function delete_event (widget: PGtkWidget;
  11. event : PGdkEvent;
  12. data : gpointer): gboolean;cdecl; forward;
  13. procedure show_glade_file (filename : Pgchar);
  14. var
  15. xml : PGladeXML;
  16. fatal_mask : TGLogLevelFlags;
  17. toplevel : PGtkWidget;
  18. open : PGtkWidget;
  19. exit : PGtkWidget;
  20. begin
  21. fatal_mask := g_log_set_always_fatal (G_LOG_FATAL_MASK);
  22. g_log_set_always_fatal (fatal_mask or G_LOG_LEVEL_WARNING or G_LOG_LEVEL_CRITICAL);
  23. if filename <> NULL then begin
  24. { read the glade xml file }
  25. xml := glade_xml_new (filename, NULL, NULL);
  26. { get the pointers to the widgets }
  27. toplevel := glade_xml_get_widget (xml, 'MainWindow');
  28. exit := glade_xml_get_widget (xml, 'exit');
  29. open := glade_xml_get_widget (xml, 'open');
  30. { If the widgets where found in the xml code... }
  31. { ... connect the signals to the buttons }
  32. if open <> NULL then
  33. g_signal_connect (G_OBJECT (open), 'clicked',
  34. G_CALLBACK (@open_callback), toplevel);
  35. if exit <> NULL then
  36. g_signal_connect (G_OBJECT (exit), 'clicked',
  37. G_CALLBACK (@delete_event), NULL);
  38. { and show them all }
  39. if toplevel <> NULL then
  40. gtk_widget_show_all (toplevel);
  41. g_object_unref (G_OBJECT (xml));
  42. end; { filename }
  43. end;
  44. procedure open_callback (widget : PGtkWidget;
  45. data : gpointer); cdecl;
  46. var
  47. dialog : PGtkWidget;
  48. window : PGtkWindow;
  49. action : gint;
  50. filename : Pgchar;
  51. filter : PGtkFileFilter;
  52. begin
  53. { Get a pointer to the main window }
  54. window := GTK_WINDOW (data);
  55. { create the filechooser dialog }
  56. dialog := gtk_file_chooser_dialog_new ('Open Glade XML',
  57. window,
  58. GTK_FILE_CHOOSER_ACTION_OPEN,
  59. GTK_STOCK_OPEN, [GTK_RESPONSE_ACCEPT,
  60. GTK_STOCK_CANCEL, GTK_RESPONSE_CANCEL,
  61. NULL]);
  62. filter := gtk_file_filter_new; { creates a new GtkFileFilter }
  63. gtk_file_filter_add_pattern (filter, '*.glade'); { and allow only *.glade files }
  64. { We now use this filter to display only *.glade files in the filechooser }
  65. gtk_file_chooser_add_filter ( GTK_FILE_CHOOSER(dialog), filter);
  66. if gtk_dialog_run (GTK_DIALOG (dialog)) = GTK_RESPONSE_ACCEPT then
  67. begin
  68. { get selected file }
  69. filename := gtk_file_chooser_get_filename (GTK_FILE_CHOOSER (dialog));
  70. { and do something with it }
  71. show_glade_file (filename);
  72. g_free (filename);
  73. end;
  74. gtk_widget_destroy (dialog);
  75. end;
  76. function delete_event (widget: PGtkWidget;
  77. event : PGdkEvent;
  78. data : gpointer): gboolean;cdecl;
  79. begin
  80. gtk_main_quit;
  81. delete_event := FALSE;
  82. end;
  83. var
  84. window,
  85. button,
  86. box1 : PGtkWidget; (* GtkWidget is the storage type for widgets *)
  87. begin
  88. gtk_init (@argc, @argv);
  89. window := gtk_window_new (GTK_WINDOW_TOPLEVEL);
  90. gtk_window_set_title (GTK_WINDOW (window), 'GtkFileChooser and LibGlade Demo');
  91. g_signal_connect (G_OBJECT (window), 'delete_event',
  92. G_CALLBACK (@delete_event), NULL);
  93. gtk_container_set_border_width (GTK_CONTAINER (window), 10);
  94. box1 := gtk_hbox_new (FALSE, 0);
  95. (* Put the box into the main window. *)
  96. gtk_container_add (GTK_CONTAINER (window), box1);
  97. button := gtk_button_new_from_stock (GTK_STOCK_OPEN);
  98. g_signal_connect (G_OBJECT (button), 'clicked',
  99. G_CALLBACK (@open_callback), window);
  100. gtk_box_pack_start (GTK_BOX(box1), button, TRUE, TRUE, 10);
  101. (* Always remember this step, this tells GTK that our preparation for
  102. * this button is complete, and it can now be displayed. *)
  103. gtk_widget_show (button);
  104. gtk_widget_show (box1);
  105. gtk_widget_show (window);
  106. gtk_main ();
  107. end.