wxruby 1.9.6-x86-mingw32

Sign up to get free protection for your applications and to get access to all the features.
Files changed (236) hide show
  1. data/LICENSE +53 -0
  2. data/README +297 -0
  3. data/lib/wx/accessors.rb +52 -0
  4. data/lib/wx/classes/acceleratortable.rb +28 -0
  5. data/lib/wx/classes/animation.rb +18 -0
  6. data/lib/wx/classes/app.rb +45 -0
  7. data/lib/wx/classes/artprovider.rb +31 -0
  8. data/lib/wx/classes/bitmap.rb +28 -0
  9. data/lib/wx/classes/busycursor.rb +12 -0
  10. data/lib/wx/classes/checklistbox.rb +45 -0
  11. data/lib/wx/classes/choice.rb +4 -0
  12. data/lib/wx/classes/clientdc.rb +13 -0
  13. data/lib/wx/classes/clipboard.rb +16 -0
  14. data/lib/wx/classes/colour.rb +47 -0
  15. data/lib/wx/classes/combobox.rb +4 -0
  16. data/lib/wx/classes/commandevent.rb +7 -0
  17. data/lib/wx/classes/controlwithitems.rb +10 -0
  18. data/lib/wx/classes/dc.rb +57 -0
  19. data/lib/wx/classes/event.rb +5 -0
  20. data/lib/wx/classes/evthandler.rb +921 -0
  21. data/lib/wx/classes/font.rb +118 -0
  22. data/lib/wx/classes/functions.rb +44 -0
  23. data/lib/wx/classes/gauge.rb +12 -0
  24. data/lib/wx/classes/grid.rb +138 -0
  25. data/lib/wx/classes/helpcontroller.rb +5 -0
  26. data/lib/wx/classes/htmlhelpcontroller.rb +5 -0
  27. data/lib/wx/classes/htmlwindow.rb +14 -0
  28. data/lib/wx/classes/icon.rb +21 -0
  29. data/lib/wx/classes/iconbundle.rb +3 -0
  30. data/lib/wx/classes/image.rb +31 -0
  31. data/lib/wx/classes/imagelist.rb +3 -0
  32. data/lib/wx/classes/listbox.rb +4 -0
  33. data/lib/wx/classes/listctrl.rb +21 -0
  34. data/lib/wx/classes/locale.rb +28 -0
  35. data/lib/wx/classes/mediactrl.rb +22 -0
  36. data/lib/wx/classes/menu.rb +62 -0
  37. data/lib/wx/classes/menuitem.rb +7 -0
  38. data/lib/wx/classes/object.rb +7 -0
  39. data/lib/wx/classes/paintdc.rb +12 -0
  40. data/lib/wx/classes/point.rb +48 -0
  41. data/lib/wx/classes/previewframe.rb +13 -0
  42. data/lib/wx/classes/rect.rb +10 -0
  43. data/lib/wx/classes/size.rb +49 -0
  44. data/lib/wx/classes/sound.rb +23 -0
  45. data/lib/wx/classes/styledtextctrl.rb +92 -0
  46. data/lib/wx/classes/textctrl.rb +14 -0
  47. data/lib/wx/classes/texturlevent.rb +6 -0
  48. data/lib/wx/classes/timer.rb +94 -0
  49. data/lib/wx/classes/toolbartool.rb +4 -0
  50. data/lib/wx/classes/treectrl.rb +44 -0
  51. data/lib/wx/classes/window.rb +82 -0
  52. data/lib/wx/classes/xmlresource.rb +37 -0
  53. data/lib/wx/keyword_ctors.rb +222 -0
  54. data/lib/wx/keyword_defs.rb +492 -0
  55. data/lib/wx/version.rb +3 -0
  56. data/lib/wx.rb +42 -0
  57. data/lib/wxruby2.so +0 -0
  58. data/samples/SAMPLES-LICENSE.TXT +18 -0
  59. data/samples/aui/aui.rb +1356 -0
  60. data/samples/bigdemo/About.rbw +39 -0
  61. data/samples/bigdemo/ColorPanel.rbw +23 -0
  62. data/samples/bigdemo/GridSimple.rbw +78 -0
  63. data/samples/bigdemo/MDIDemo.rbw +57 -0
  64. data/samples/bigdemo/PopupMenu.rbw +149 -0
  65. data/samples/bigdemo/ShapedWindow.rbw +131 -0
  66. data/samples/bigdemo/Sizers.rbw +543 -0
  67. data/samples/bigdemo/bigdemo.rb +823 -0
  68. data/samples/bigdemo/demoTemplate.rbw +33 -0
  69. data/samples/bigdemo/helpfile.htb +0 -0
  70. data/samples/bigdemo/icons/Test 015.jpg +0 -0
  71. data/samples/bigdemo/icons/Test 015.png +0 -0
  72. data/samples/bigdemo/icons/choice.bmp +0 -0
  73. data/samples/bigdemo/icons/choice.xpm +27 -0
  74. data/samples/bigdemo/icons/combo.bmp +0 -0
  75. data/samples/bigdemo/icons/combo.xpm +27 -0
  76. data/samples/bigdemo/icons/copy.xpm +25 -0
  77. data/samples/bigdemo/icons/cut.xpm +24 -0
  78. data/samples/bigdemo/icons/gauge.bmp +0 -0
  79. data/samples/bigdemo/icons/gauge.xpm +27 -0
  80. data/samples/bigdemo/icons/help.xpm +25 -0
  81. data/samples/bigdemo/icons/list.bmp +0 -0
  82. data/samples/bigdemo/icons/list.xpm +27 -0
  83. data/samples/bigdemo/icons/mondrian.ico +0 -0
  84. data/samples/bigdemo/icons/mondrian.xpm +44 -0
  85. data/samples/bigdemo/icons/new.xpm +24 -0
  86. data/samples/bigdemo/icons/ogl.ico +0 -0
  87. data/samples/bigdemo/icons/ogl.xpm +45 -0
  88. data/samples/bigdemo/icons/open.xpm +26 -0
  89. data/samples/bigdemo/icons/paste.bmp +0 -0
  90. data/samples/bigdemo/icons/paste.xpm +38 -0
  91. data/samples/bigdemo/icons/pointy.png +0 -0
  92. data/samples/bigdemo/icons/preview.xpm +26 -0
  93. data/samples/bigdemo/icons/print.xpm +26 -0
  94. data/samples/bigdemo/icons/radio.bmp +0 -0
  95. data/samples/bigdemo/icons/radio.xpm +27 -0
  96. data/samples/bigdemo/icons/robert.xpm +415 -0
  97. data/samples/bigdemo/icons/ruby.png +0 -0
  98. data/samples/bigdemo/icons/sashtest.ico +0 -0
  99. data/samples/bigdemo/icons/save.xpm +25 -0
  100. data/samples/bigdemo/icons/smiles.bmp +0 -0
  101. data/samples/bigdemo/icons/smiles.xpm +39 -0
  102. data/samples/bigdemo/icons/smiley.ico +0 -0
  103. data/samples/bigdemo/icons/smiley.xpm +42 -0
  104. data/samples/bigdemo/icons/stattext.xpm +24 -0
  105. data/samples/bigdemo/icons/test2.bmp +0 -0
  106. data/samples/bigdemo/icons/test2.png +0 -0
  107. data/samples/bigdemo/icons/test2.xpm +79 -0
  108. data/samples/bigdemo/icons/text.bmp +0 -0
  109. data/samples/bigdemo/icons/text.xpm +27 -0
  110. data/samples/bigdemo/icons/tog1.bmp +0 -0
  111. data/samples/bigdemo/icons/tog1.xpm +38 -0
  112. data/samples/bigdemo/icons/tog2.bmp +0 -0
  113. data/samples/bigdemo/icons/tog2.xpm +38 -0
  114. data/samples/bigdemo/icons/wxwin.ico +0 -0
  115. data/samples/bigdemo/icons/wxwin16x16.png +0 -0
  116. data/samples/bigdemo/icons/wxwin16x16.xpm +25 -0
  117. data/samples/bigdemo/icons/wxwin32x32.png +0 -0
  118. data/samples/bigdemo/icons/wxwin48x48.png +0 -0
  119. data/samples/bigdemo/run.rb +90 -0
  120. data/samples/bigdemo/tips.txt +7 -0
  121. data/samples/bigdemo/utils.rb +12 -0
  122. data/samples/bigdemo/wxArtProvider.rbw +281 -0
  123. data/samples/bigdemo/wxBitmapButton.rbw +65 -0
  124. data/samples/bigdemo/wxButton.rbw +64 -0
  125. data/samples/bigdemo/wxCalendarCtrl.rbw +60 -0
  126. data/samples/bigdemo/wxCheckBox.rbw +50 -0
  127. data/samples/bigdemo/wxCheckListBox.rbw +75 -0
  128. data/samples/bigdemo/wxChoice.rbw +47 -0
  129. data/samples/bigdemo/wxChoicebook.rbw +78 -0
  130. data/samples/bigdemo/wxColourDialog.rbw +31 -0
  131. data/samples/bigdemo/wxComboBox.rbw +77 -0
  132. data/samples/bigdemo/wxCursor.rbw +136 -0
  133. data/samples/bigdemo/wxDialog.rbw +74 -0
  134. data/samples/bigdemo/wxDirDialog.rbw +29 -0
  135. data/samples/bigdemo/wxDragImage.rbw +70 -0
  136. data/samples/bigdemo/wxFileDialog.rbw +37 -0
  137. data/samples/bigdemo/wxFileDialog_Save.rbw +35 -0
  138. data/samples/bigdemo/wxFindReplaceDialog.rbw +82 -0
  139. data/samples/bigdemo/wxFontDialog.rbw +173 -0
  140. data/samples/bigdemo/wxFrame.rbw +53 -0
  141. data/samples/bigdemo/wxGauge.rbw +71 -0
  142. data/samples/bigdemo/wxGenericDirCtrl.rbw +74 -0
  143. data/samples/bigdemo/wxGrid.rbw +66 -0
  144. data/samples/bigdemo/wxHtmlHelpController.rbw +52 -0
  145. data/samples/bigdemo/wxListBox.rbw +140 -0
  146. data/samples/bigdemo/wxListCtrl_virtual.rbw +107 -0
  147. data/samples/bigdemo/wxMDIWindows.rbw +50 -0
  148. data/samples/bigdemo/wxMenu.rbw +236 -0
  149. data/samples/bigdemo/wxMessageDialog.rbw +27 -0
  150. data/samples/bigdemo/wxMiniFrame.rbw +70 -0
  151. data/samples/bigdemo/wxMultipleChoiceDialog.rbw +32 -0
  152. data/samples/bigdemo/wxNotebook.rbw +136 -0
  153. data/samples/bigdemo/wxProgressDialog.rbw +43 -0
  154. data/samples/bigdemo/wxRadioBox.rbw +72 -0
  155. data/samples/bigdemo/wxRadioButton.rbw +125 -0
  156. data/samples/bigdemo/wxSashWindow.rbw +141 -0
  157. data/samples/bigdemo/wxScrolledMessageDialog.rbw +57 -0
  158. data/samples/bigdemo/wxScrolledWindow.rbw +199 -0
  159. data/samples/bigdemo/wxSingleChoiceDialog.rbw +33 -0
  160. data/samples/bigdemo/wxSlider.rbw +42 -0
  161. data/samples/bigdemo/wxSpinButton.rbw +50 -0
  162. data/samples/bigdemo/wxSpinCtrl.rbw +51 -0
  163. data/samples/bigdemo/wxSplitterWindow.rbw +63 -0
  164. data/samples/bigdemo/wxStaticBitmap.rbw +51 -0
  165. data/samples/bigdemo/wxStaticText.rbw +55 -0
  166. data/samples/bigdemo/wxStatusBar.rbw +126 -0
  167. data/samples/bigdemo/wxTextCtrl.rbw +149 -0
  168. data/samples/bigdemo/wxTextEntryDialog.rbw +31 -0
  169. data/samples/bigdemo/wxToggleButton.rbw +49 -0
  170. data/samples/bigdemo/wxToolBar.rbw +131 -0
  171. data/samples/bigdemo/wxTreeCtrl.rbw +190 -0
  172. data/samples/calendar/calendar.rb +271 -0
  173. data/samples/caret/caret.rb +282 -0
  174. data/samples/caret/mondrian.xpm +44 -0
  175. data/samples/controls/controls.rb +1136 -0
  176. data/samples/controls/get_item_sample.rb +87 -0
  177. data/samples/controls/icons/choice.xpm +27 -0
  178. data/samples/controls/icons/combo.xpm +27 -0
  179. data/samples/controls/icons/gauge.xpm +27 -0
  180. data/samples/controls/icons/list.xpm +27 -0
  181. data/samples/controls/icons/radio.xpm +27 -0
  182. data/samples/controls/icons/stattext.xpm +24 -0
  183. data/samples/controls/icons/text.xpm +27 -0
  184. data/samples/controls/mondrian.ico +0 -0
  185. data/samples/controls/mondrian.xpm +44 -0
  186. data/samples/controls/test2.bmp +0 -0
  187. data/samples/dialogs/dialogs.rb +723 -0
  188. data/samples/dialogs/tips.txt +18 -0
  189. data/samples/drawing/graphics_drawing.rb +235 -0
  190. data/samples/drawing/images.rb +37 -0
  191. data/samples/drawing/paperclip.png +0 -0
  192. data/samples/etc/activation.rb +102 -0
  193. data/samples/etc/choice.rb +67 -0
  194. data/samples/etc/miniframe.rb +79 -0
  195. data/samples/etc/sash.rb +130 -0
  196. data/samples/etc/scrollwin.rb +110 -0
  197. data/samples/etc/system_settings.rb +252 -0
  198. data/samples/etc/threaded.rb +72 -0
  199. data/samples/etc/wizard.rb +74 -0
  200. data/samples/event/event.rb +182 -0
  201. data/samples/grid/grid.rb +198 -0
  202. data/samples/grid/gridtablebase.rb +134 -0
  203. data/samples/html/html.rb +262 -0
  204. data/samples/listbook/listbook.rb +174 -0
  205. data/samples/listbook/listbook.xrc +370 -0
  206. data/samples/mdi/mdi.rb +82 -0
  207. data/samples/media/mediactrl.rb +167 -0
  208. data/samples/minimal/minimal.rb +77 -0
  209. data/samples/minimal/mondrian.ico +0 -0
  210. data/samples/minimal/mondrian.png +0 -0
  211. data/samples/minimal/nothing.rb +16 -0
  212. data/samples/opengl/cube.rb +117 -0
  213. data/samples/printing/mondrian.ico +0 -0
  214. data/samples/printing/mondrian.xpm +44 -0
  215. data/samples/printing/printing.rb +310 -0
  216. data/samples/sockets/SocketPackets.rb +27 -0
  217. data/samples/sockets/res/message-new.png +0 -0
  218. data/samples/sockets/res/user.png +0 -0
  219. data/samples/sockets/wxClient.rb +395 -0
  220. data/samples/sockets/wxServer.rb +422 -0
  221. data/samples/sockets/wxSocketGUI.rb +97 -0
  222. data/samples/text/mondrian.ico +0 -0
  223. data/samples/text/mondrian.xpm +44 -0
  224. data/samples/text/scintilla.rb +169 -0
  225. data/samples/text/textctrl.rb +113 -0
  226. data/samples/text/unicode.rb +242 -0
  227. data/samples/text/utf8.txt +15 -0
  228. data/samples/treectrl/icon1.xpm +79 -0
  229. data/samples/treectrl/icon2.xpm +53 -0
  230. data/samples/treectrl/icon3.xpm +79 -0
  231. data/samples/treectrl/icon4.xpm +43 -0
  232. data/samples/treectrl/icon5.xpm +79 -0
  233. data/samples/treectrl/treectrl.rb +1174 -0
  234. data/samples/xrc/samples.xrc +46 -0
  235. data/samples/xrc/xrc_sample.rb +96 -0
  236. metadata +313 -0
@@ -0,0 +1,110 @@
1
+ #!/usr/bin/env ruby
2
+ # wxRuby2 Sample Code. Copyright (c) 2004-2008 wxRuby development team
3
+ # Freely reusable code: see SAMPLES-LICENSE.TXT for details
4
+ begin
5
+ require 'rubygems'
6
+ rescue LoadError
7
+ end
8
+ require 'wx'
9
+
10
+ # Example demonstrating the use of Wx::ScrolledWindow and the
11
+ # ScrollWinEvents
12
+
13
+ class ScrollFrame < Wx::Frame
14
+ def initialize(title)
15
+ super(nil, -1, 'Thumb Scrolling Test',
16
+ Wx::DEFAULT_POSITION, Wx::Size.new(400, 300),
17
+ Wx::SYSTEM_MENU|Wx::CAPTION|Wx::RESIZE_BORDER|
18
+ Wx::MAXIMIZE_BOX|Wx::MINIMIZE_BOX|Wx::CLOSE_BOX)
19
+
20
+ @scroll_win = Wx::ScrolledWindow.new(self, -1)
21
+ # Set the interior size (pixels) of the scrolling window
22
+ @scroll_win.set_virtual_size(1000, 1500)
23
+ # Set the number of pixels moved per 'line' / click on the scrollbars
24
+ @scroll_win.set_scroll_rate(5, 5)
25
+
26
+ @button = Wx::Button.new(@scroll_win, -1, 'Press Me',
27
+ Wx::Point.new(200,200),
28
+ Wx::Size.new(125, 20))
29
+
30
+ # NOTE that all ScrollWin event hooks do not take an id - i.e. they
31
+ # are only generated from the originating Window itself - in this
32
+ # case, the ScrollWindow. So, we need to do:
33
+ # @scroll_win.evt_scrollwin_xxx { ...
34
+ # AND NOT
35
+ # evt_scrollwin_xxx(@scroll_win.get_id) { ...
36
+ @scroll_win.evt_scrollwin_linedown() { | e | on_line(e, 'down') }
37
+ @scroll_win.evt_scrollwin_lineup() { | e | on_line(e,'up') }
38
+
39
+ @scroll_win.evt_scrollwin_thumbtrack() { | e | on_thumb(e, 'track') }
40
+ @scroll_win.evt_scrollwin_thumbrelease() { | e | on_thumb(e, 'release') }
41
+
42
+ @scroll_win.evt_scrollwin_pagedown() { | e | on_page(e, 'down') }
43
+ @scroll_win.evt_scrollwin_pageup() { | e | on_page(e, 'up') }
44
+
45
+ # not sure how these are meant to be generated
46
+ @scroll_win.evt_scrollwin_top() { | e | on_top(e) }
47
+ @scroll_win.evt_scrollwin_bottom() { | e | on_bottom(e) }
48
+ @scroll_win.evt_scrollwin { | e | p e }
49
+ end
50
+
51
+ # Handle scrolling by page - typically done by clicking on the
52
+ # scrollbar itself, above or below the thumb position
53
+ # +direction+ is either 'up' (= left, if dealing with a horizontal
54
+ # scrollbar) or 'down' (= right) - WxRuby generates different events
55
+ # for these.
56
+ def on_page(event, direction)
57
+ pos = event.get_position
58
+ orient = event.get_orientation == Wx::VERTICAL ? 'VERTICAL' : 'HORIZONTAL'
59
+ puts "#{orient} scrollbar page #{direction} @ #{pos}"
60
+ event.skip() # allow default scrolling action
61
+ end
62
+
63
+
64
+ # Handle scrolling by line - typically done by clicking the up/down
65
+ # (or left/right) scroll buttons at the end of the scrollbar.
66
+ # +direction+ is either 'up' (= left, if dealing with a horizontal
67
+ # scrollbar) or 'down' (= right)
68
+ def on_line(event, direction)
69
+ orient = event.get_orientation == Wx::VERTICAL ? 'VERTICAL' : 'HORIZONTAL'
70
+ pos = event.get_position
71
+ puts "#{orient} scrollbar line #{direction} @ #{pos}"
72
+ event.skip() # allow default action
73
+ end
74
+
75
+ # Handle scrolling done by click-dragging the 'thumb' within a scrollbar.
76
+ # +action+ contains either 'track' for thumbtrack drag events, or 'release'
77
+ # for thumb-release
78
+ def on_thumb(event, action)
79
+ pos = event.get_position
80
+ if event.get_orientation == Wx::VERTICAL
81
+ puts "VERTICAL thumb #{action} @ #{pos}"
82
+ else
83
+ puts "HORIZONTAL thumb #{action} @ #{pos}"
84
+ end
85
+ event.skip()
86
+ end
87
+
88
+ # (Assuming this should be triggered when the End key is pressed)?
89
+ def on_bottom(event)
90
+ puts "bottom"
91
+ end
92
+
93
+
94
+ # (Assuming this should be triggered when the Home/Begin key is pressed)?
95
+ def on_top(event)
96
+ puts "top"
97
+ end
98
+
99
+ end
100
+
101
+ class ScrollingApp < Wx::App
102
+ def on_init
103
+ frame = ScrollFrame.new('')
104
+ frame.show(TRUE)
105
+ end
106
+ end
107
+
108
+ app = ScrollingApp.new
109
+ app.main_loop()
110
+
@@ -0,0 +1,252 @@
1
+ #!/usr/bin/env ruby
2
+ # wxRuby2 Sample Code. Copyright (c) 2004-2008 wxRuby development team
3
+ # Freely reusable code: see SAMPLES-LICENSE.TXT for details
4
+ begin
5
+ require 'rubygems'
6
+ rescue LoadError
7
+ end
8
+ require 'wx'
9
+
10
+ # This example lists the various system settings that WxRuby knows
11
+ # about. To use it, run it and use the 'View' menu to list the different
12
+ # groups of settings available.
13
+
14
+ # A class to display system settings in a spreadsheet-like table.
15
+ class SystemSettingsTable < Wx::Grid
16
+ def initialize(parent)
17
+ super(parent, -1)
18
+ max_length = [ COLOURS.length, FONTS.length, METRICS.length ].max
19
+ create_grid( max_length, 3)
20
+
21
+ set_row_label_size(0)
22
+ set_row_label_alignment(Wx::ALIGN_RIGHT, Wx::ALIGN_CENTRE)
23
+
24
+ set_col_label_value(0, 'Name')
25
+ set_col_size(0, 200)
26
+ set_col_label_value(1, 'Value')
27
+ set_col_size(1, 100)
28
+ set_col_label_value(2, 'Description')
29
+ set_col_size(2, 300)
30
+ end
31
+
32
+ # blank out all row labels from +from_row+ to the end of the grid.
33
+ def tidy_row_labels(from_row = 0)
34
+ from_row.upto( get_number_rows - 1 ) do | row |
35
+ set_row_label_value(row, '')
36
+ end
37
+ end
38
+
39
+ # display a settings constant name +const+, its value +value+ and a
40
+ # text description +desc+ of that setting in the row +row+
41
+ def list(row, const, val, desc)
42
+ set_cell_value(row, 0, const)
43
+ set_cell_value(row, 1, val.to_s() )
44
+ set_cell_value(row, 2, desc)
45
+ end
46
+
47
+ # List the elements of the system's colour scheme, giving each one's
48
+ # Wx constant name, its RGB value in hex, and the description of how it
49
+ # is used.
50
+ def list_colours
51
+ clear_grid()
52
+ COLOURS.each_with_index do | item, i |
53
+ constant_name, description = *item
54
+ const = Wx::const_get(constant_name)
55
+ # obtain a Wx::Colour object for the named constantb
56
+ colour = Wx::SystemSettings.get_colour(const)
57
+ colour_hex = '#%02X%02X%02X' %
58
+ [ colour.red, colour.green, colour.blue ]
59
+ list( i, constant_name, colour_hex, description )
60
+ end
61
+ tidy_row_labels(COLOURS.length)
62
+ end
63
+
64
+ # List the standard system fonts, giving each one's Wx contant name,
65
+ # the font's platform descriptor, and a description of its use.
66
+ def list_fonts
67
+ clear_grid()
68
+ FONTS.each_with_index do | item, i |
69
+ constant_name, description = *item
70
+ const = Wx::const_get(constant_name)
71
+ # obtain a standard system font
72
+ font = Wx::SystemSettings.get_font(const)
73
+ font_desc = "%s %ipt" %
74
+ [ font.get_face_name, font.get_point_size ]
75
+ list( i, constant_name, font_desc, description )
76
+ end
77
+ tidy_row_labels(FONTS.length)
78
+ end
79
+
80
+ # List various standard measurements of GUI elements and areas, such as
81
+ # the size of the screen, cursor, icons and window borders. For each
82
+ # one, the WxRuby constant name, the value (usually in pixels), and a
83
+ # short description of its use is given.
84
+ #
85
+ # Not all metrics are implemented in Wx on all platforms; undefined
86
+ # values are shown as '-1'.
87
+ def list_metrics
88
+ clear_grid()
89
+ METRICS.each_with_index do | item, i |
90
+ constant_name, description = *item
91
+ const = Wx::const_get(constant_name)
92
+ # obtain a standard system metric
93
+ metric = Wx::SystemSettings.get_metric(const)
94
+ list( i, constant_name, metric, description )
95
+ end
96
+ tidy_row_labels(METRICS.length)
97
+ end
98
+
99
+ # copied from WxWidgets 2.6.2 documentation
100
+ COLOURS = [
101
+ [ 'SYS_COLOUR_SCROLLBAR', 'The scrollbar grey area.' ],
102
+ [ 'SYS_COLOUR_BACKGROUND', 'The desktop colour.' ],
103
+ [ 'SYS_COLOUR_ACTIVECAPTION', 'Active window caption.' ],
104
+ [ 'SYS_COLOUR_INACTIVECAPTION', 'Inactive window caption.' ],
105
+ [ 'SYS_COLOUR_MENU', 'Menu background.' ],
106
+ [ 'SYS_COLOUR_WINDOW', 'Window background.' ],
107
+ [ 'SYS_COLOUR_WINDOWFRAME', 'Window frame.' ],
108
+ [ 'SYS_COLOUR_MENUTEXT', 'Menu text.' ],
109
+ [ 'SYS_COLOUR_WINDOWTEXT', 'Text in windows.' ],
110
+ [ 'SYS_COLOUR_CAPTIONTEXT', 'Text in caption, size box and scrollbar arrow box.' ],
111
+ [ 'SYS_COLOUR_ACTIVEBORDER', 'Active window border.' ],
112
+ [ 'SYS_COLOUR_INACTIVEBORDER', 'Inactive window border.' ],
113
+ [ 'SYS_COLOUR_APPWORKSPACE', 'Background colour MDI applications.' ],
114
+ [ 'SYS_COLOUR_HIGHLIGHT', 'Item(s) selected in a control.' ],
115
+ [ 'SYS_COLOUR_HIGHLIGHTTEXT', 'Text of item(s) selected in a control.' ],
116
+ [ 'SYS_COLOUR_BTNFACE', 'Face shading on push buttons.' ],
117
+ [ 'SYS_COLOUR_BTNSHADOW', 'Edge shading on push buttons.' ],
118
+ [ 'SYS_COLOUR_GRAYTEXT', 'Greyed (disabled) text.' ],
119
+ [ 'SYS_COLOUR_BTNTEXT', 'Text on push buttons.' ],
120
+ [ 'SYS_COLOUR_INACTIVECAPTIONTEXT', 'Colour of text in active captions.' ],
121
+ [ 'SYS_COLOUR_BTNHIGHLIGHT', 'Highlight colour for buttons (same as wxSYS_COLOUR_3DHILIGHT).' ],
122
+ [ 'SYS_COLOUR_3DDKSHADOW', 'Dark shadow for three-dimensional display elements.' ],
123
+ [ 'SYS_COLOUR_3DLIGHT', 'Light colour for three-dimensional display elements.' ],
124
+ [ 'SYS_COLOUR_INFOTEXT', 'Text colour for tooltip controls.' ],
125
+ [ 'SYS_COLOUR_INFOBK', 'Background colour for tooltip controls.' ],
126
+ [ 'SYS_COLOUR_DESKTOP', 'Same as wxSYS_COLOUR_BACKGROUND.' ],
127
+ [ 'SYS_COLOUR_3DFACE', 'Same as wxSYS_COLOUR_BTNFACE.' ],
128
+ [ 'SYS_COLOUR_3DSHADOW', 'Same as wxSYS_COLOUR_BTNSHADOW.' ],
129
+ [ 'SYS_COLOUR_3DHIGHLIGHT', 'Same as wxSYS_COLOUR_BTNHIGHLIGHT.' ],
130
+ [ 'SYS_COLOUR_3DHILIGHT', 'Same as wxSYS_COLOUR_BTNHIGHLIGHT.' ],
131
+ [ 'SYS_COLOUR_BTNHILIGHT', 'Same as wxSYS_COLOUR_BTNHIGHLIGHT.' ]
132
+ ]
133
+
134
+ # copied from WxWidgets 2.6.2 documentation
135
+ FONTS = [
136
+ [ 'SYS_OEM_FIXED_FONT', 'Original equipment manufacturer dependent fixed-pitch font.' ],
137
+ [ 'SYS_ANSI_FIXED_FONT', 'Windows fixed-pitch font.' ],
138
+ [ 'SYS_ANSI_VAR_FONT', 'Windows variable-pitch (proportional) font.' ],
139
+ [ 'SYS_SYSTEM_FONT', 'System font.' ],
140
+ [ 'SYS_DEVICE_DEFAULT_FONT', 'Device-dependent font (Windows NT only).' ],
141
+ [ 'SYS_DEFAULT_GUI_FONT', 'Default font for user interface objects such as menus and dialog boxes.' ]
142
+ ]
143
+
144
+ # copied from WxWidgets 2.6.2 documentation
145
+ METRICS = [
146
+ [ 'SYS_MOUSE_BUTTONS', 'Number of buttons on mouse, or zero if no mouse was installed.' ],
147
+ [ 'SYS_BORDER_X', 'Width of single border.' ],
148
+ [ 'SYS_BORDER_Y', 'Height of single border.' ],
149
+ [ 'SYS_CURSOR_X', 'Width of cursor.' ],
150
+ [ 'SYS_CURSOR_Y', 'Height of cursor.' ],
151
+ [ 'SYS_DCLICK_X', 'Width in pixels of rectangle within which two successive mouse clicks must fall to generate a double-click.' ],
152
+ [ 'SYS_DCLICK_Y', 'Height in pixels of rectangle within which two successive mouse clicks must fall to generate a double-click.' ],
153
+ [ 'SYS_DRAG_X', 'Width in pixels of a rectangle centered on a drag point to allow for limited movement of the mouse pointer before a drag operation begins.' ],
154
+ [ 'SYS_DRAG_Y', 'Height in pixels of a rectangle centered on a drag point to allow for limited movement of the mouse pointer before a drag operation begins.' ],
155
+ [ 'SYS_EDGE_X', 'Width of a 3D border, in pixels.' ],
156
+ [ 'SYS_EDGE_Y', 'Height of a 3D border, in pixels.' ],
157
+ [ 'SYS_HSCROLL_ARROW_X', 'Width of arrow bitmap on horizontal scrollbar.' ],
158
+ [ 'SYS_HSCROLL_ARROW_Y', 'Height of arrow bitmap on horizontal scrollbar.' ],
159
+ [ 'SYS_HTHUMB_X', 'Width of horizontal scrollbar thumb.' ],
160
+ [ 'SYS_ICON_X', 'The default width of an icon.' ],
161
+ [ 'SYS_ICON_Y', 'The default height of an icon.' ],
162
+ [ 'SYS_ICONSPACING_X', 'Width of a grid cell for items in large icon view, in pixels. Each item fits into a rectangle of this size when arranged.' ],
163
+ [ 'SYS_ICONSPACING_Y', 'Height of a grid cell for items in large icon view, in pixels. Each item fits into a rectangle of this size when arranged.' ],
164
+ [ 'SYS_WINDOWMIN_X', 'Minimum width of a window.' ],
165
+ [ 'SYS_WINDOWMIN_Y', 'Minimum height of a window.' ],
166
+ [ 'SYS_SCREEN_X', 'Width of the screen in pixels.' ],
167
+ [ 'SYS_SCREEN_Y', 'Height of the screen in pixels.' ],
168
+ [ 'SYS_FRAMESIZE_X', 'Width of the window frame for a wxTHICK_FRAME window.' ],
169
+ [ 'SYS_FRAMESIZE_Y', 'Height of the window frame for a wxTHICK_FRAME window.' ],
170
+ [ 'SYS_SMALLICON_X', 'Recommended width of a small icon (in window captions, and small icon view).' ],
171
+ [ 'SYS_SMALLICON_Y', 'Recommended height of a small icon (in window captions, and small icon view).' ],
172
+ [ 'SYS_HSCROLL_Y', 'Height of horizontal scrollbar in pixels.' ],
173
+ [ 'SYS_VSCROLL_X', 'Width of vertical scrollbar in pixels.' ],
174
+ [ 'SYS_VSCROLL_ARROW_X', 'Width of arrow bitmap on a vertical scrollbar.' ],
175
+ [ 'SYS_VSCROLL_ARROW_Y', 'Height of arrow bitmap on a vertical scrollbar.' ],
176
+ [ 'SYS_VTHUMB_Y', 'Height of vertical scrollbar thumb.' ],
177
+ [ 'SYS_CAPTION_Y', 'Height of normal caption area.' ],
178
+ [ 'SYS_MENU_Y', 'Height of single-line menu bar.' ],
179
+ [ 'SYS_NETWORK_PRESENT', '1 if there is a network present, 0 otherwise.' ],
180
+ [ 'SYS_PENWINDOWS_PRESENT', '1 if PenWindows is installed, 0 otherwise.' ],
181
+ [ 'SYS_SHOW_SOUNDS', 'Non-zero if the user requires an application to present information visually in situations where it would otherwise present the information only in audible form; zero otherwise.' ],
182
+ [ 'SYS_SWAP_BUTTONS', 'Non-zero if the meanings of the left and right mouse buttons are swapped; zero otherwise.' ]
183
+ ]
184
+ end
185
+
186
+
187
+ # A simple frame that just shows a table with the System Settings in it.
188
+ class SettingsFrame < Wx::Frame
189
+
190
+ def initialize(title, pos = Wx::DEFAULT_POSITION, size = Wx::DEFAULT_SIZE)
191
+ super(nil, -1, title, pos, size)
192
+ sizer = Wx::BoxSizer.new(Wx::HORIZONTAL)
193
+ @table = SystemSettingsTable.new(self)
194
+ sizer.add(@table, 1, Wx::ADJUST_MINSIZE|Wx::GROW|Wx::ALL, 2)
195
+ self.set_sizer(sizer)
196
+ construct_menus()
197
+ @table.list_colours()
198
+ end
199
+
200
+ ID_SHOW_COLOURS = 1
201
+ ID_SHOW_FONTS = 2
202
+ ID_SHOW_METRICS = 3
203
+ def construct_menus()
204
+ menu_bar = Wx::MenuBar.new()
205
+
206
+ menu_file = Wx::Menu.new()
207
+ menu_file.append(Wx::ID_EXIT, "E&xit\tAlt-X", "Quit this program")
208
+ menu_bar.append(menu_file, "&File")
209
+ evt_menu(Wx::ID_EXIT) { on_quit() }
210
+
211
+ menu_view = Wx::Menu.new()
212
+ menu_view.append(ID_SHOW_COLOURS,
213
+ "Show &Colours", "Show system colours")
214
+ evt_menu(ID_SHOW_COLOURS) { @table.list_colours() }
215
+ menu_view.append(ID_SHOW_FONTS,
216
+ "Show &Fonts", "Show system fonts")
217
+ evt_menu(ID_SHOW_FONTS) { @table.list_fonts() }
218
+ menu_view.append(ID_SHOW_METRICS,
219
+ "Show &Metrics", "Show system metrics")
220
+ evt_menu(ID_SHOW_METRICS) { @table.list_metrics() }
221
+ menu_bar.append(menu_view, "&View")
222
+
223
+ menu_help = Wx::Menu.new()
224
+ menu_help.append(Wx::ID_ABOUT, "&About...\tF1", "Show about dialog")
225
+ evt_menu(Wx::ID_ABOUT) { on_about() }
226
+ menu_bar.append(menu_help, "&Help")
227
+
228
+ set_menu_bar(menu_bar)
229
+ end
230
+
231
+ def on_quit()
232
+ close(TRUE)
233
+ end
234
+
235
+ def on_about()
236
+ msg = sprintf("This is the About dialog of the minimal sample.\n" \
237
+ "Welcome to %s", Wx::VERSION_STRING)
238
+ Wx::message_box(msg, "About Minimal", Wx::OK|Wx::ICON_INFORMATION, self)
239
+ end
240
+ end
241
+
242
+ class MyApp < Wx::App
243
+ def on_init()
244
+ frame = SettingsFrame.new("System Settings",
245
+ Wx::DEFAULT_POSITION,
246
+ Wx::Size.new(600, 400) )
247
+ frame.show(TRUE)
248
+ end
249
+ end
250
+
251
+ # run the app
252
+ MyApp.new.main_loop()
@@ -0,0 +1,72 @@
1
+ #!/usr/bin/env ruby
2
+ # wxRuby2 Sample Code. Copyright (c) 2004-2008 wxRuby development team
3
+ # Freely reusable code: see SAMPLES-LICENSE.TXT for details
4
+ begin
5
+ require 'rubygems'
6
+ rescue LoadError
7
+ end
8
+ require 'wx'
9
+
10
+ # This simple sample demonstrates how to use Ruby 1.8's lightweight
11
+ # (green) threads to execute non-GUI code in parallel with a wxRuby
12
+ # GUI. This strategy is useful in a number of situations:
13
+ #
14
+ # * To keep the GUI responsive whilst computationally intensive
15
+ # operations are carried out in the background
16
+ # * To keep the GUI responsive while waiting for networking operations
17
+ # to complete
18
+ #
19
+ # The basic problem is that, as with other Ruby GUI toolkits, non-GUI
20
+ # threads will not, by default, get allocated time to run while Ruby is
21
+ # busy in Wx code - the main wxRuby event loop. Strategies to deal with
22
+ # this include using non-blocking IO, and, more generically, using
23
+ # wxRuby's Timer class to explicitly allocate time for non-GUI threads
24
+ # to run. The latter technique is shown here.
25
+
26
+ # This frame shows a set of progress bars which monitor progress of
27
+ # long-running tasks. In this example, this long-running task is
28
+ # emulated by simply sleep-ing for random periods, but could equally be
29
+ # downloading from a socket or parsing a file.
30
+ class ProgressFrame < Wx::Frame
31
+ STEPS = 20
32
+ def initialize
33
+ super(nil, :title => 'Threading demo')
34
+ @gauges = []
35
+ panel = Wx::Panel.new(self)
36
+ sizer = Wx::BoxSizer.new(Wx::VERTICAL)
37
+ # show ten gauges
38
+ 10.times do
39
+ gauge = Wx::Gauge.new(panel, :range => STEPS)
40
+ # For each gauge, start a new thread in which the task runs
41
+ Thread.new do
42
+ # The long-running task
43
+ STEPS.times do | i |
44
+ sleep rand(100) / 50.0
45
+ # Update the main GUI
46
+ gauge.value = i + 1
47
+ end
48
+ end
49
+ @gauges << gauge
50
+ sizer.add(gauge, 0, Wx::GROW|Wx::ALL, 2)
51
+ end
52
+ panel.sizer = sizer
53
+ sizer.fit(panel)
54
+ end
55
+ end
56
+
57
+ # This app class creates a frame, and, importantly, a timer to allow
58
+ class GaugeApp < Wx::App
59
+ # Get a guaranteed-unique id
60
+ THREAD_TIMER_ID = Wx::ID_HIGHEST + 1
61
+ def on_init
62
+ # Create a global application timer that passes control to other
63
+ # ruby threads. The timer will run every 1/40 second (25ms). Higher
64
+ # values will make the other threads run more often, but will
65
+ # eventually degrade the responsiveness of the GUI.
66
+ Wx::Timer.every(25) { Thread.pass }
67
+ prog = ProgressFrame.new
68
+ prog.show
69
+ end
70
+ end
71
+
72
+ GaugeApp.new.main_loop
@@ -0,0 +1,74 @@
1
+ #!/usr/bin/env ruby
2
+ # wxRuby2 Sample Code. Copyright (c) 2004-2008 wxRuby development team
3
+ # Freely reusable code: see SAMPLES-LICENSE.TXT for details
4
+ begin
5
+ require 'rubygems'
6
+ rescue LoadError
7
+ end
8
+ require 'wx'
9
+
10
+
11
+ class MyFrame < Wx::Frame
12
+ def initialize(title, pos, size)
13
+ super(nil, :title => title, :position => pos, :size => size)
14
+
15
+ menuFile = Wx::Menu.new
16
+ helpMenu = Wx::Menu.new
17
+ helpMenu.append(Wx::ID_ABOUT, "&About...\tF1", "Show about dialog")
18
+ menuFile.append(Wx::ID_EXIT, "E&xit\tAlt-X", "Quit this program")
19
+ menuBar = Wx::MenuBar.new
20
+ menuBar.append(menuFile, "&File")
21
+ menuBar.append(helpMenu, "&Help")
22
+ self.menu_bar = menuBar
23
+
24
+ create_status_bar(1)
25
+ self.status_text = "Welcome to wxRuby!"
26
+ s = Wx::StaticText.new(self, :label => 'The Wizard has completed')
27
+ evt_menu Wx::ID_EXIT, :on_quit
28
+ evt_menu Wx::ID_ABOUT, :on_about
29
+
30
+ w = Wx::Wizard.new(self, :title => 'The WxRuby Wizard')
31
+ p1 = Wx::WizardPageSimple.new(w)
32
+ s = Wx::StaticText.new(p1, :label => 'This is the first page')
33
+
34
+ p2 = Wx::WizardPageSimple.new(w, p1)
35
+ p1.set_next(p2)
36
+ s = Wx::StaticText.new(p2, :label => 'This is the second page')
37
+
38
+ p3 = Wx::WizardPageSimple.new(w, p2)
39
+ p2.set_next(p3)
40
+ s = Wx::StaticText.new(p3, :label => 'This is the final page')
41
+
42
+ evt_wizard_page_changed(w) { p "page changed" }
43
+ evt_wizard_page_changing(w) { p "page changing" }
44
+ evt_wizard_help(w) { p "wizard help" }
45
+ evt_wizard_cancel(w) { p "wizard cancelled" }
46
+ evt_wizard_finished(w) { p "wizard finished" }
47
+
48
+ w.run_wizard(p1)
49
+ end
50
+
51
+ def on_quit
52
+ close(true)
53
+ end
54
+
55
+ def on_about
56
+ msg = sprintf("This is the About dialog of the wizard sample.\n" \
57
+ "Welcome to %s", Wx::VERSION_STRING)
58
+ Wx::message_box(msg, "About Wizard", Wx::OK|Wx::ICON_INFORMATION, self)
59
+ end
60
+ end
61
+
62
+ class RbApp < Wx::App
63
+ def on_init
64
+ frame = MyFrame.new("Wizard wxRuby App",
65
+ Wx::Point.new(50, 50),
66
+ Wx::Size.new(450, 340))
67
+ frame.show(true)
68
+
69
+ end
70
+ end
71
+
72
+ app = RbApp.new
73
+ app.main_loop()
74
+
@@ -0,0 +1,182 @@
1
+ #!/usr/bin/env ruby
2
+ # wxRuby2 Sample Code. Copyright (c) 2004-2008 wxRuby development team
3
+ # Freely reusable code: see SAMPLES-LICENSE.TXT for details
4
+ begin
5
+ require 'rubygems'
6
+ rescue LoadError
7
+ end
8
+ require 'wx'
9
+
10
+ # This sample demonstrates how to dynamically connect and disconnect
11
+ # event handlers, and how to create custom event types and listeners
12
+ # associated with user-defined control classes.
13
+
14
+ # A custom type of event associated with a target control. Note that for
15
+ # user-defined controls, the associated event should inherit from
16
+ # Wx::CommandEvent rather than Wx::Event.
17
+ class TargetHitEvent < Wx::CommandEvent
18
+ # Create a new unique constant identifier, associate this class
19
+ # with events of that identifier, and create a shortcut 'evt_target'
20
+ # method for setting up this handler.
21
+ EVT_HIT_TARGET = Wx::EvtHandler.register_class(self, nil, 'evt_target', 1)
22
+
23
+ def initialize(target, score, distance)
24
+ # The constant id is the arg to super
25
+ super(EVT_HIT_TARGET)
26
+ # client_data should be used to store any information associated
27
+ # with the event.
28
+ self.client_data = { :score => score, :distance => distance }
29
+ self.id = target.get_id
30
+ end
31
+
32
+ # Returns the points score associated with this event
33
+ def score
34
+ client_data[:score]
35
+ end
36
+
37
+ # Returns the distance (in pixels) from the centre of the target
38
+ def distance
39
+ client_data[:distance]
40
+ end
41
+ end
42
+
43
+ # An example of a simple user-written control, which displays a
44
+ # "bulls-eye" like target, and sends events with a score and distance
45
+ class TargetControl < Wx::Window
46
+ TargetCircle = Struct.new(:radius, :score, :brush)
47
+
48
+ def initialize(parent, *args)
49
+ super(parent, *args)
50
+
51
+ # Set up the scores and sizes of the rings
52
+ @radii = [
53
+ TargetCircle[ 0.1, 20, Wx::RED_BRUSH ],
54
+ TargetCircle[ 0.25, 10, Wx::BLUE_BRUSH ],
55
+ TargetCircle[ 0.4, 5, Wx::GREEN_BRUSH ] ]
56
+ evt_paint { | e | on_paint(e) }
57
+ evt_left_down { | e | on_left_down(e) }
58
+ end
59
+
60
+ # What point is at the centre (assuming this control is always square)
61
+ def centre_point
62
+ size.width / 2
63
+ end
64
+
65
+ # Called whenever the target is repainted, draws a series of
66
+ # concentric circles
67
+ def on_paint(evt)
68
+ paint do | dc |
69
+ dc.clear
70
+ @radii.reverse_each do | circ |
71
+ dc.brush = circ.brush
72
+ dc.draw_circle(centre_point, centre_point,
73
+ ( size.width * circ.radius).to_i )
74
+ end
75
+ end
76
+ end
77
+
78
+ # Test if the target was hit, and generate a TargetHitEvent if so
79
+ def on_left_down(evt)
80
+ # quick bit of pythagoras...
81
+ distance = Math.sqrt( ( evt.x - centre_point ) ** 2 +
82
+ ( evt.y - centre_point ) ** 2 )
83
+ # See which target ring, if any, was hit by the event
84
+ @radii.each do | circ |
85
+ if distance < ( size.width * circ.radius)
86
+ # Create an instance of the event
87
+ evt = TargetHitEvent.new(self, circ.score, distance)
88
+ # This sends the event for processing by listeners
89
+ event_handler.process_event(evt)
90
+ break
91
+ end
92
+ end
93
+ end
94
+ end
95
+
96
+ # Container frame for the target control
97
+ class TargetFrame < Wx::Frame
98
+ def initialize(title)
99
+ super(nil, :title => title, :size => [300, 300])
100
+ @tgt = TargetControl.new(self)
101
+ # This user-defined event handling method was set up by
102
+ # EvtHandler.register_class, above
103
+ evt_target(@tgt.get_id) { | e | on_target(e) }
104
+ @listening = true
105
+ evt_size { | e | on_size(e) }
106
+ setup_menus
107
+ create_status_bar
108
+ end
109
+
110
+ # What's done when the target is hit
111
+ def on_target(evt)
112
+ msg = "Target hit for score %i, %.2f pixels from centre" %
113
+ [ evt.score, evt.distance ]
114
+ self.status_text = msg
115
+ end
116
+
117
+ # Keep the target centred and square
118
+ def on_size(evt)
119
+ smaller = [ evt.size.width, evt.size.height ].min
120
+ @tgt.centre
121
+ @tgt.size = Wx::Size.new(smaller, smaller)
122
+ @tgt.refresh
123
+ end
124
+
125
+ # Toggle whether or not we are listening for events from the bulls-eye
126
+ # target
127
+ def on_toggle_connect
128
+ if @listening
129
+ # Remove :evt_target event handler for the @tgt
130
+ disconnect(@tgt.get_id, Wx::ID_ANY, :evt_target)
131
+ menu_bar.check(TOGGLE_LISTEN, false)
132
+ self.status_text = "Ignoring target events"
133
+ @listening = false
134
+ else
135
+ # Restore evt_target event handler for the @tgt
136
+ evt_target(@tgt.get_id) { | e | on_target(e) }
137
+ menu_bar.check(TOGGLE_LISTEN, true)
138
+ self.status_text = ''
139
+ @listening = true
140
+ end
141
+ end
142
+
143
+ def on_about
144
+ msg = sprintf("This is the About dialog of the event handling sample.\n" \
145
+ "Welcome to wxRuby, version %s", Wx::WXRUBY_VERSION)
146
+
147
+ about_dlg = Wx::MessageDialog.new( self, msg, 'About Event Handling',
148
+ Wx::OK|Wx::ICON_INFORMATION )
149
+ about_dlg.show_modal
150
+
151
+ end
152
+
153
+ TOGGLE_LISTEN = 1001
154
+ def setup_menus
155
+ menu_file = Wx::Menu.new
156
+ menu_help = Wx::Menu.new
157
+ menu_help.append(Wx::ID_ABOUT, "&About...\tF1", "Show about dialog")
158
+ evt_menu(Wx::ID_ABOUT) { on_about }
159
+ menu_file.append(Wx::ID_EXIT, "E&xit\tAlt-X", "Quit this program")
160
+ evt_menu(Wx::ID_EXIT) { self.close }
161
+ menu_file.append_check_item(TOGGLE_LISTEN, "L&isten for events",
162
+ "Toggle listening for target events")
163
+ evt_menu(TOGGLE_LISTEN) { on_toggle_connect }
164
+
165
+ menu_bar = Wx::MenuBar.new
166
+ menu_bar.append(menu_file, "&File")
167
+ menu_bar.append(menu_help, "&Help")
168
+
169
+ self.menu_bar = menu_bar
170
+ menu_bar.check(TOGGLE_LISTEN, true)
171
+ end
172
+ end
173
+
174
+ class TargetApp < Wx::App
175
+ def on_init
176
+ TargetFrame.new("Event Handling Sample").show
177
+ return true
178
+ end
179
+ end
180
+
181
+ a = TargetApp.new
182
+ a.main_loop()