wxruby 1.9.6-x86-mingw32

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
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()