wxruby 1.9.2-i386-mswin32 → 1.9.3-i386-mswin32

Sign up to get free protection for your applications and to get access to all the features.
Files changed (149) hide show
  1. data/LICENSE +53 -53
  2. data/README +299 -299
  3. data/lib/wx/classes/app.rb +6 -0
  4. data/lib/wx/classes/checklistbox.rb +45 -30
  5. data/lib/wx/classes/clipboard.rb +16 -0
  6. data/lib/wx/classes/event.rb +5 -0
  7. data/lib/wx/classes/evthandler.rb +20 -10
  8. data/lib/wx/classes/grid.rb +38 -39
  9. data/lib/wx/classes/listctrl.rb +12 -0
  10. data/lib/wx/classes/mediactrl.rb +22 -0
  11. data/lib/wx/classes/menu.rb +6 -6
  12. data/lib/wx/classes/sound.rb +23 -0
  13. data/lib/wx/classes/styledtextctrl.rb +2 -2
  14. data/lib/wx/classes/treectrl.rb +26 -0
  15. data/lib/wx/keyword_ctors.rb +19 -5
  16. data/lib/wx/keyword_defs.rb +20 -0
  17. data/lib/wx/version.rb +1 -1
  18. data/lib/wx.rb +42 -42
  19. data/lib/wxruby2.exp +0 -0
  20. data/lib/wxruby2.lib +0 -0
  21. data/lib/wxruby2.so +0 -0
  22. data/samples/SAMPLES-LICENSE.TXT +17 -17
  23. data/samples/aui/aui.rb +8 -1
  24. data/samples/bigdemo/About.rbw +39 -39
  25. data/samples/bigdemo/ColorPanel.rbw +25 -25
  26. data/samples/bigdemo/GridSimple.rbw +80 -80
  27. data/samples/bigdemo/MDIDemo.rbw +59 -59
  28. data/samples/bigdemo/PopupMenu.rbw +151 -151
  29. data/samples/bigdemo/Sizers.rbw +545 -545
  30. data/samples/bigdemo/bigdemo.rb +826 -826
  31. data/samples/bigdemo/demoTemplate.rbw +37 -37
  32. data/samples/bigdemo/icons/choice.xpm +27 -27
  33. data/samples/bigdemo/icons/combo.xpm +27 -27
  34. data/samples/bigdemo/icons/copy.xpm +25 -25
  35. data/samples/bigdemo/icons/cut.xpm +24 -24
  36. data/samples/bigdemo/icons/gauge.xpm +27 -27
  37. data/samples/bigdemo/icons/help.xpm +25 -25
  38. data/samples/bigdemo/icons/list.xpm +27 -27
  39. data/samples/bigdemo/icons/mondrian.xpm +44 -44
  40. data/samples/bigdemo/icons/new.xpm +24 -24
  41. data/samples/bigdemo/icons/ogl.ico +0 -0
  42. data/samples/bigdemo/icons/ogl.xpm +45 -45
  43. data/samples/bigdemo/icons/open.xpm +26 -26
  44. data/samples/bigdemo/icons/paste.xpm +38 -38
  45. data/samples/bigdemo/icons/preview.xpm +26 -26
  46. data/samples/bigdemo/icons/print.xpm +26 -26
  47. data/samples/bigdemo/icons/radio.xpm +27 -27
  48. data/samples/bigdemo/icons/robert.xpm +415 -415
  49. data/samples/bigdemo/icons/save.xpm +25 -25
  50. data/samples/bigdemo/icons/smiles.xpm +39 -39
  51. data/samples/bigdemo/icons/smiley.xpm +42 -42
  52. data/samples/bigdemo/icons/stattext.xpm +24 -24
  53. data/samples/bigdemo/icons/test2.bmp +0 -0
  54. data/samples/bigdemo/icons/test2.xpm +79 -79
  55. data/samples/bigdemo/icons/text.xpm +27 -27
  56. data/samples/bigdemo/icons/tog1.xpm +38 -38
  57. data/samples/bigdemo/icons/tog2.xpm +38 -38
  58. data/samples/bigdemo/icons/wxwin16x16.xpm +25 -25
  59. data/samples/bigdemo/tips.txt +7 -7
  60. data/samples/bigdemo/utils.rb +11 -11
  61. data/samples/bigdemo/wxButton.rbw +66 -66
  62. data/samples/bigdemo/wxCalendarCtrl.rbw +72 -72
  63. data/samples/bigdemo/wxCheckBox.rbw +52 -52
  64. data/samples/bigdemo/wxCheckListBox.rbw +77 -77
  65. data/samples/bigdemo/wxChoice.rbw +49 -49
  66. data/samples/bigdemo/wxColourDialog.rbw +34 -34
  67. data/samples/bigdemo/wxComboBox.rbw +79 -79
  68. data/samples/bigdemo/wxDialog.rbw +92 -92
  69. data/samples/bigdemo/wxDirDialog.rbw +32 -32
  70. data/samples/bigdemo/wxFileDialog.rbw +39 -39
  71. data/samples/bigdemo/wxFileDialog_Save.rbw +38 -38
  72. data/samples/bigdemo/wxFindReplaceDialog.rbw +85 -85
  73. data/samples/bigdemo/wxFontDialog.rbw +176 -176
  74. data/samples/bigdemo/wxFrame.rbw +55 -55
  75. data/samples/bigdemo/wxGauge.rbw +73 -73
  76. data/samples/bigdemo/wxGrid.rbw +68 -68
  77. data/samples/bigdemo/wxListBox.rbw +142 -142
  78. data/samples/bigdemo/wxListCtrl_virtual.rbw +109 -109
  79. data/samples/bigdemo/wxMDIWindows.rbw +52 -52
  80. data/samples/bigdemo/wxMenu.rbw +238 -238
  81. data/samples/bigdemo/wxMessageDialog.rbw +30 -30
  82. data/samples/bigdemo/wxMultipleChoiceDialog.rbw +34 -34
  83. data/samples/bigdemo/wxNotebook.rbw +138 -138
  84. data/samples/bigdemo/wxProgressDialog.rbw +45 -45
  85. data/samples/bigdemo/wxRadioBox.rbw +74 -74
  86. data/samples/bigdemo/wxRadioButton.rbw +127 -127
  87. data/samples/bigdemo/wxSashWindow.rbw +94 -104
  88. data/samples/bigdemo/wxScrolledMessageDialog.rbw +59 -59
  89. data/samples/bigdemo/wxScrolledWindow.rbw +201 -201
  90. data/samples/bigdemo/wxSingleChoiceDialog.rbw +35 -35
  91. data/samples/bigdemo/wxSlider.rbw +44 -44
  92. data/samples/bigdemo/wxSpinButton.rbw +52 -52
  93. data/samples/bigdemo/wxSpinCtrl.rbw +53 -53
  94. data/samples/bigdemo/wxSplitterWindow.rbw +65 -65
  95. data/samples/bigdemo/wxStaticBitmap.rbw +53 -53
  96. data/samples/bigdemo/wxStaticText.rbw +57 -57
  97. data/samples/bigdemo/wxStatusBar.rbw +128 -128
  98. data/samples/bigdemo/wxTextCtrl.rbw +151 -151
  99. data/samples/bigdemo/wxTextEntryDialog.rbw +34 -34
  100. data/samples/bigdemo/wxToggleButton.rbw +51 -51
  101. data/samples/bigdemo/wxToolBar.rbw +133 -133
  102. data/samples/bigdemo/wxTreeCtrl.rbw +192 -192
  103. data/samples/calendar/calendar.rb +275 -275
  104. data/samples/caret/caret.rb +286 -286
  105. data/samples/caret/mondrian.xpm +44 -44
  106. data/samples/controls/controls.rb +1140 -1140
  107. data/samples/controls/get_item_sample.rb +87 -87
  108. data/samples/controls/icons/choice.xpm +27 -27
  109. data/samples/controls/icons/combo.xpm +27 -27
  110. data/samples/controls/icons/gauge.xpm +27 -27
  111. data/samples/controls/icons/list.xpm +27 -27
  112. data/samples/controls/icons/radio.xpm +27 -27
  113. data/samples/controls/icons/stattext.xpm +24 -24
  114. data/samples/controls/icons/text.xpm +27 -27
  115. data/samples/controls/mondrian.xpm +44 -44
  116. data/samples/dialogs/dialogs.rb +724 -724
  117. data/samples/dialogs/tips.txt +18 -18
  118. data/samples/drawing/graphics_drawing.rb +232 -0
  119. data/samples/{images → drawing}/images.rb +48 -48
  120. data/samples/{images → drawing}/paperclip.png +0 -0
  121. data/samples/etc/activation.rb +108 -108
  122. data/samples/etc/choice.rb +72 -72
  123. data/samples/etc/miniframe.rb +84 -84
  124. data/samples/etc/sash.rb +135 -135
  125. data/samples/etc/scrollwin.rb +116 -116
  126. data/samples/etc/system_settings.rb +258 -258
  127. data/samples/etc/wizard.rb +79 -79
  128. data/samples/grid/grid.rb +1 -0
  129. data/samples/listbook/listbook.rb +181 -181
  130. data/samples/listbook/listbook.xrc +370 -370
  131. data/samples/mdi/mdi.rb +87 -87
  132. data/samples/media/mediactrl.rb +173 -0
  133. data/samples/minimal/minimal.rb +85 -85
  134. data/samples/minimal/nothing.rb +21 -21
  135. data/samples/opengl/cube.rb +123 -0
  136. data/samples/sockets/SocketPackets.rb +27 -0
  137. data/samples/sockets/res/message-new.png +0 -0
  138. data/samples/sockets/res/user.png +0 -0
  139. data/samples/sockets/wxClient.rb +395 -0
  140. data/samples/sockets/wxServer.rb +422 -0
  141. data/samples/sockets/wxSocketGUI.rb +97 -0
  142. data/samples/text/textctrl.rb +124 -124
  143. data/samples/text/unicode.rb +238 -238
  144. data/samples/text/utf8.txt +14 -14
  145. data/samples/treectrl/treectrl.rb +1180 -1181
  146. data/samples/xrc/samples.xrc +46 -46
  147. data/samples/xrc/xrc_sample.rb +107 -107
  148. metadata +26 -9
  149. data/samples/images/Thumbs.db +0 -0
@@ -1,18 +1,18 @@
1
- Startup tips are documented in the "Startup tips overview" section of wxWindows documentation.
2
- These tips are being read from the tips.txt text file in this directory. Each line of the file contains a single tip.
3
- If you close and open this tips dialog, you will notice that the tip numbers start at the point you were at when you closed the dialog last time. This allows easy cycling through the entire list of tips, instead of always showing the initial tips over and over.
4
- Often you will want to save to the application's wxConfig, the last tip that the user saw, as well as whether they want to see tips on startup.
5
- Comments in the tips file have a # as the first character. Comments are automatically skipped over. See the tips.txt file in this directory for the example.
6
- # This line is a comment since it started with a #, and is skipped.
7
- Blank lines in the tip file are also automatically skipped over. Lines with only spaces are also considered empty.
8
- The next line in this tip file is empty, so it will be automatically skipped.
9
-
10
- The next line in this tip file is just empty spaces, so it is considered empty too, and is also automatically skipped.
11
-
12
- You can easily add translations to your startup tips via the usual gettext methods by wrapping a string in a gettext macro, which is _(""). See next tip for example.
13
- _("This tip is marked as a translatable string by wrapping it inside the usual gettext macro, so it can be collected by gettext and added to a translation catalog. Your application can then use this catalog and serve out a translated version of the tip.")
14
- Translatable strings must strictly begin with _(", not _( " or wxGetTranslation(" or something else.
15
- If you are using gettext translatable strings, don't forget to escape to replace any " characters within the tip with a \" instead
16
- _("This is a translatable tip with the quoted words \"Escape me\" properly escaped.")
17
- If you have very specialized needs, you can derive your own wxTipProvider and use that instead.
18
- If you want to modify the tip content at runtime for purposes other than translation (for example, variable expansion), one easy option is to use a custom tip provider derived from wxFileTipProvider. Your custom tip provider would contain a single virtual function to override: PreprocessTip().
1
+ Startup tips are documented in the "Startup tips overview" section of wxWindows documentation.
2
+ These tips are being read from the tips.txt text file in this directory. Each line of the file contains a single tip.
3
+ If you close and open this tips dialog, you will notice that the tip numbers start at the point you were at when you closed the dialog last time. This allows easy cycling through the entire list of tips, instead of always showing the initial tips over and over.
4
+ Often you will want to save to the application's wxConfig, the last tip that the user saw, as well as whether they want to see tips on startup.
5
+ Comments in the tips file have a # as the first character. Comments are automatically skipped over. See the tips.txt file in this directory for the example.
6
+ # This line is a comment since it started with a #, and is skipped.
7
+ Blank lines in the tip file are also automatically skipped over. Lines with only spaces are also considered empty.
8
+ The next line in this tip file is empty, so it will be automatically skipped.
9
+
10
+ The next line in this tip file is just empty spaces, so it is considered empty too, and is also automatically skipped.
11
+
12
+ You can easily add translations to your startup tips via the usual gettext methods by wrapping a string in a gettext macro, which is _(""). See next tip for example.
13
+ _("This tip is marked as a translatable string by wrapping it inside the usual gettext macro, so it can be collected by gettext and added to a translation catalog. Your application can then use this catalog and serve out a translated version of the tip.")
14
+ Translatable strings must strictly begin with _(", not _( " or wxGetTranslation(" or something else.
15
+ If you are using gettext translatable strings, don't forget to escape to replace any " characters within the tip with a \" instead
16
+ _("This is a translatable tip with the quoted words \"Escape me\" properly escaped.")
17
+ If you have very specialized needs, you can derive your own wxTipProvider and use that instead.
18
+ If you want to modify the tip content at runtime for purposes other than translation (for example, variable expansion), one easy option is to use a custom tip provider derived from wxFileTipProvider. Your custom tip provider would contain a single virtual function to override: PreprocessTip().
@@ -0,0 +1,232 @@
1
+ begin
2
+ require 'wx'
3
+ rescue LoadError => no_wx_err
4
+ begin
5
+ require 'rubygems'
6
+ rescue LoadError
7
+ raise no_wx_err
8
+ end
9
+ end
10
+
11
+ class GfxInfo
12
+ attr_accessor :font, :w, :h, :x, :y, :x_axis, :y_axis, :txt, :rotation
13
+ def initialize()
14
+ @font = nil
15
+ @w = 0
16
+ @h = 0
17
+ @x = 0
18
+ @y = 0
19
+ @x_axis = 0
20
+ @y_axis = 0
21
+ @txt = ""
22
+ @rotation = 0
23
+ end
24
+
25
+ def move(max_x,max_y,max_sp)
26
+ @x += @x_axis
27
+ @y += @y_axis
28
+ if @x <= 0
29
+ @x_axis = rand(max_sp)
30
+ @x = 0
31
+ elsif (@x+@w) >= max_x
32
+ @x_axis = (rand(max_sp)*-1)
33
+ @x = max_x - @w
34
+ end
35
+ if @y <= 0
36
+ @y_axis = rand(max_sp)
37
+ @y = 0
38
+ elsif (@y+@h) >= max_y
39
+ @y_axis = (rand(max_sp)*-1)
40
+ @y = max_y - @h
41
+ end
42
+ end
43
+
44
+ def rotate(run)
45
+ @rotation += run
46
+ if @rotation > 360
47
+ @rotation = 0
48
+ end
49
+ end
50
+
51
+ def draw(gdc)
52
+ gdc.set_font(font)
53
+ gdc.draw_text(txt,x,y,rotation)
54
+ end
55
+
56
+ def [](symbol)
57
+ self.__send__(symbol,*[])
58
+ end
59
+
60
+ def []=(symbol,val)
61
+ self.__send__((symbol.to_s + "=").to_sym,*[val])
62
+ end
63
+ end
64
+
65
+
66
+ class GraphicsWindow < Wx::Window
67
+ # Create Needed Brushes and Pens
68
+ RED_BRUSH = Wx::Brush.new
69
+ GREEN_BRUSH = Wx::Brush.new
70
+ BLUE_BRUSH = Wx::Brush.new
71
+ RED_PEN = Wx::Pen.new
72
+ GREEN_PEN = Wx::Pen.new
73
+ BLUE_PEN = Wx::Pen.new
74
+
75
+ # Instance Methods to keep track of toggle for corner, rect, and counter for frames per second
76
+ attr_accessor :corner, :rect, :fps
77
+
78
+ def initialize(parent)
79
+ super(parent)
80
+ # Create the font we'll use to create our pre-defined fonts for the painting
81
+ @font = Wx::Font.new(18,Wx::FONTFAMILY_TELETYPE,
82
+ Wx::FONTSTYLE_NORMAL,Wx::FONTWEIGHT_NORMAL)
83
+ # Setup the actual data to be stored in Brushes and Pens
84
+ RED_BRUSH.set_colour(Wx::RED)
85
+ RED_PEN.set_colour(Wx::RED)
86
+ GREEN_BRUSH.set_colour(Wx::GREEN)
87
+ GREEN_PEN.set_colour(Wx::GREEN)
88
+ BLUE_BRUSH.set_colour(Wx::BLUE)
89
+ BLUE_PEN.set_colour(Wx::BLUE)
90
+ # Create our Animation Timer
91
+ @timer = Wx::Timer.new(self,1000)
92
+ @fps = 0
93
+ # Set it to run every 25 milliseconds, you can set this value higher, to get
94
+ # higher frame rates, however, it may cause non-responsiveness of normal
95
+ # gui controls.
96
+ @timer.start(25)
97
+ # Setup the event Handler to do the drawing on this window.
98
+ evt_paint :on_paint
99
+ evt_timer 1000, :animate
100
+ end
101
+
102
+ def create_resources(gdc)
103
+ # Create our Resource Class for holding the Text to be displayed
104
+ @rtxt = GfxInfo.new()
105
+ @gtxt = GfxInfo.new()
106
+ @btxt = GfxInfo.new()
107
+ # Store our fonts, and strings into the classes
108
+ @rtxt[:font] = gdc.create_font(@font,Wx::RED); @rtxt[:txt] = "This is a red string"
109
+ @gtxt[:font] = gdc.create_font(@font,Wx::GREEN); @gtxt[:txt] = "This is a green string"
110
+ @btxt[:font] = gdc.create_font(@font,Wx::BLUE); @btxt[:txt] = "This is a blue string"
111
+ # Create the GraphicsContext resources. For some reason, unable to utilize
112
+ # GraphicsContext#create(wxWindow) to create these resources in initialize().
113
+ @rbrush = gdc.create_brush(RED_BRUSH)
114
+ @gbrush = gdc.create_brush(GREEN_BRUSH)
115
+ @bbrush = gdc.create_brush(BLUE_BRUSH)
116
+ @rpen = gdc.create_pen(RED_PEN)
117
+ @gpen = gdc.create_pen(GREEN_PEN)
118
+ @bpen = gdc.create_pen(BLUE_PEN)
119
+ end
120
+
121
+ def get_extents(gdc)
122
+ # Since we need a GDC and the text to get the extents, we do this in a
123
+ # separate method, though we should be able to do it with create_resources()
124
+ width,height,*garbage = gdc.get_text_extent(@rtxt[:txt])
125
+ @rtxt[:w] = width.to_i; @rtxt[:h] = height.to_i
126
+ width,height,*garbage = gdc.get_text_extent(@gtxt[:txt])
127
+ @gtxt[:w] = width.to_i; @gtxt[:h] = height.to_i
128
+ width,height,*garbage = gdc.get_text_extent(@btxt[:txt])
129
+ @btxt[:w] = width.to_i; @btxt[:h] = height.to_i
130
+ end
131
+
132
+ def setup_positions()
133
+ # Setup our initial positions for drawing.
134
+ @rtxt[:x] = @rtxt[:y] = 0
135
+ size = self.get_client_size()
136
+ pos_x = (size.width / 2) #- (@gtxt[:w] / 2)
137
+ pos_y = (size.height / 2) #- (@gtxt[:h] / 2)
138
+ @gtxt[:x] = pos_x
139
+ @gtxt[:y] = pos_y
140
+ @btxt[:x] = (size.width - @btxt[:w])
141
+ @btxt[:y] = (size.height - @btxt[:h])
142
+ end
143
+
144
+ def animate()
145
+ # This routine manily animates the Text, which is also is handled by the
146
+ # GfxInfo class as well. Mainly in #rotate and #move.
147
+ rect = self.get_client_size()
148
+ @rtxt.move(rect.width,rect.height,8) unless @rtxt.nil?
149
+ @gtxt.rotate(-0.01) unless @gtxt.nil?
150
+ @btxt.move(rect.width,rect.height,5) unless @btxt.nil?
151
+ # We're now ready to draw our stuff to the window
152
+ refresh()
153
+ end
154
+
155
+ def on_paint
156
+ # We do our drawing now
157
+ rect = self.get_client_size
158
+ paint do |dc|
159
+ gdc = Wx::GraphicsContext.create(dc)
160
+ unless !@rtxt.nil?
161
+ create_resources(gdc)
162
+ end
163
+
164
+ unless !(@rtxt[:w] == 0)
165
+ gdc.set_font(@rtxt[:font])
166
+ get_extents(gdc)
167
+ setup_positions()
168
+ end
169
+ @rtxt.draw(gdc)
170
+ @gtxt.draw(gdc)
171
+ @btxt.draw(gdc)
172
+ # Draw our rectangles, if they are checked
173
+ 15.times do
174
+ pen = gdc.create_pen(Wx::Pen.new(Wx::Colour.new(rand(256),rand(256),rand(256),rand(256))))
175
+ if @corner.is_checked
176
+ x = rand(rect.width)
177
+ y = rand(rect.height)
178
+ gdc.set_pen(pen)
179
+ gdc.draw_rectangle(x,y,x,1)
180
+ gdc.draw_rectangle(x,y,1,y)
181
+ end
182
+ if @rect.is_checked
183
+ x = rand(rect.width)
184
+ y = rand(rect.height)
185
+ w = rand(rect.width)
186
+ h = rand(rect.height)
187
+ w + x > rect.width ? (w -= x; w -= rand(150)) : 0
188
+ h + y > rect.height ? (h -= y; h -= rand(150)) : 0
189
+ gdc.set_pen(pen)
190
+ gdc.draw_rectangle(x,y,w,h)
191
+ end
192
+ end
193
+ end
194
+ @fps += 1
195
+ end
196
+ end
197
+
198
+ class GraphicsFrame < Wx::Frame
199
+ def initialize()
200
+ super(nil,:title=>"Graphics Context example",:size=>[500,400])
201
+ hbox = Wx::BoxSizer.new(Wx::VERTICAL)
202
+ @win = GraphicsWindow.new(self)
203
+ hbox.add(@win,1,Wx::EXPAND|Wx::ALL)
204
+ grid = Wx::GridSizer.new(2,2)
205
+ cb_rect = Wx::CheckBox.new(self,:label=>"Draw Rectangles")
206
+ cb_corner = Wx::CheckBox.new(self,:label=>"Draw Corners")
207
+ create_status_bar()
208
+ get_status_bar.set_status_text("FPS: 0")
209
+ grid.add(cb_rect)
210
+ grid.add(cb_corner)
211
+ @win.rect = cb_rect
212
+ @win.corner = cb_corner
213
+ hbox.add(grid)
214
+ set_sizer(hbox)
215
+ @timer = Wx::Timer.new(self,2000)
216
+ evt_timer(2000, :fps_display)
217
+ @timer.start(1000)
218
+ end
219
+
220
+ def fps_display()
221
+ get_status_bar.set_status_text("FPS: #{@win.fps}")
222
+ @win.fps = 0
223
+ end
224
+ end
225
+
226
+ class GraphicsApp < Wx::App
227
+ def on_init()
228
+ GraphicsFrame.new.show
229
+ end
230
+ end
231
+
232
+ GraphicsApp.new.main_loop()
@@ -1,48 +1,48 @@
1
- #!/usr/bin/env ruby
2
- # wxRuby2 Sample Code. Copyright (c) 2004-2006 Kevin B. Smith
3
- # Freely reusable code: see SAMPLES-LICENSE.TXT for details
4
-
5
- begin
6
- require 'wx'
7
- rescue LoadError => no_wx_err
8
- begin
9
- require 'rubygems'
10
- require 'wx'
11
- rescue LoadError
12
- raise no_wx_err
13
- end
14
- end
15
-
16
- # This sample demonstrates how to draw an image from a file onto a
17
- # window. This one uses a small PNG file, but other formats such as JPEG
18
- # are supported - see documentation for more details.
19
-
20
- class MyFrame < Wx::Frame
21
- def initialize(title)
22
- super(nil, -1, title)
23
- evt_paint { on_paint }
24
-
25
- img_file = File.join( File.dirname(__FILE__), 'paperclip.png')
26
- # first load the image into an Image object
27
- image = Wx::Image.new(img_file)
28
- # then create a Bitmap suitable for drawing
29
- @bitmap = Wx::Bitmap.new(image)
30
- end
31
-
32
- def on_paint
33
- paint do | dc |
34
- dc.clear
35
- dc.draw_bitmap(@bitmap, 0, 0, false)
36
- end
37
- end
38
- end
39
-
40
- class ImagesApp < Wx::App
41
- def on_init
42
- frame = MyFrame.new("Simple Image Demo")
43
- frame.show
44
- end
45
- end
46
-
47
- a = ImagesApp.new
48
- a.main_loop()
1
+ #!/usr/bin/env ruby
2
+ # wxRuby2 Sample Code. Copyright (c) 2004-2006 Kevin B. Smith
3
+ # Freely reusable code: see SAMPLES-LICENSE.TXT for details
4
+
5
+ begin
6
+ require 'wx'
7
+ rescue LoadError => no_wx_err
8
+ begin
9
+ require 'rubygems'
10
+ require 'wx'
11
+ rescue LoadError
12
+ raise no_wx_err
13
+ end
14
+ end
15
+
16
+ # This sample demonstrates how to draw an image from a file onto a
17
+ # window. This one uses a small PNG file, but other formats such as JPEG
18
+ # are supported - see documentation for more details.
19
+
20
+ class MyFrame < Wx::Frame
21
+ def initialize(title)
22
+ super(nil, -1, title)
23
+ evt_paint { on_paint }
24
+
25
+ img_file = File.join( File.dirname(__FILE__), 'paperclip.png')
26
+ # first load the image into an Image object
27
+ image = Wx::Image.new(img_file)
28
+ # then create a Bitmap suitable for drawing
29
+ @bitmap = Wx::Bitmap.new(image)
30
+ end
31
+
32
+ def on_paint
33
+ paint do | dc |
34
+ dc.clear
35
+ dc.draw_bitmap(@bitmap, 0, 0, false)
36
+ end
37
+ end
38
+ end
39
+
40
+ class ImagesApp < Wx::App
41
+ def on_init
42
+ frame = MyFrame.new("Simple Image Demo")
43
+ frame.show
44
+ end
45
+ end
46
+
47
+ a = ImagesApp.new
48
+ a.main_loop()
File without changes
@@ -1,108 +1,108 @@
1
- #!/usr/bin/env ruby
2
- # wxRuby2 Sample Code. Copyright (c) 2004-2006 Kevin B. Smith
3
- # Freely reusable code: see SAMPLES-LICENSE.TXT for details
4
-
5
- begin
6
- require 'wx'
7
- rescue LoadError => no_wx_err
8
- begin
9
- require 'rubygems'
10
- require 'wx'
11
- rescue LoadError
12
- raise no_wx_err
13
- end
14
- end
15
-
16
- # This sample demonstrates the use of Activate Events. These are
17
- # generated when a frame becomes active or inactive. This is typically
18
- # indicated by a frame's titlebar changing colour, and a widget within
19
- # the frame gainin focus. An event is also generated when a whole wxRuby
20
- # app starts or stops being the current focussed desktop application.
21
-
22
- class MinimalFrame < Wx::Frame
23
- def initialize(title, pos, size, style = Wx::DEFAULT_FRAME_STYLE)
24
- super(nil, -1, title, pos, size, style)
25
-
26
-
27
- menuFile = Wx::Menu.new()
28
- helpMenu = Wx::Menu.new()
29
- helpMenu.append(Wx::ID_ABOUT, "&About...\tF1", "Show about dialog")
30
- menuFile.append(Wx::ID_EXIT, "E&xit\tAlt-X", "Quit this program")
31
- menuBar = Wx::MenuBar.new()
32
- menuBar.append(menuFile, "&File")
33
- menuBar.append(helpMenu, "&Help")
34
- set_menu_bar(menuBar)
35
-
36
- create_status_bar(2)
37
- set_status_text("Welcome to wxRuby!")
38
-
39
- evt_menu(Wx::ID_EXIT) { on_quit }
40
- evt_menu(Wx::ID_ABOUT) { on_about }
41
-
42
- evt_activate { | e | on_activate(e) }
43
- evt_iconize { | e | on_iconize(e) }
44
- end
45
-
46
-
47
- def on_iconize(event)
48
- if event.iconized
49
- puts "Frame '#{get_title}' was iconized"
50
- else
51
- puts "Frame '#{get_title}' was restored"
52
- end
53
- end
54
-
55
- def on_activate(event)
56
- if event.get_active
57
- puts "Frame '#{get_title}' became activated"
58
- set_status_text 'Active'
59
- else
60
- puts "Frame '#{get_title}' became deactivated"
61
- set_status_text 'Inactive'
62
- end
63
- event.skip # important
64
- end
65
-
66
- def on_quit
67
- Wx::get_app.close_all
68
- end
69
-
70
- def on_about
71
- msg = sprintf("This is the About dialog of the activate sample.\n" \
72
- "Welcome to wxRuby, version %s", Wx::WXRUBY_VERSION)
73
- Wx::message_box(msg, "About Activate", Wx::OK|Wx::ICON_INFORMATION, self)
74
- end
75
- end
76
-
77
- class RbApp < Wx::App
78
- def on_init
79
- @frame_1 = MinimalFrame.new("Tall window",
80
- Wx::Point.new(50, 50),
81
- Wx::Size.new(150, 240))
82
- @frame_2 = MinimalFrame.new("Wide window",
83
- Wx::Point.new(100, 100),
84
- Wx::Size.new(300, 180))
85
- evt_activate_app { | e | on_activate_app(e) }
86
- @frame_1.show()
87
- @frame_2.show()
88
-
89
- end
90
-
91
- def on_activate_app(event)
92
- if event.get_active
93
- puts "The app became active"
94
- else
95
- puts "The app became inactive"
96
- end
97
- event.skip # important
98
- end
99
-
100
- def close_all
101
- @frame_1.close(true)
102
- @frame_2.close(true)
103
- end
104
- end
105
-
106
- app = RbApp.new
107
- app.main_loop()
108
-
1
+ #!/usr/bin/env ruby
2
+ # wxRuby2 Sample Code. Copyright (c) 2004-2006 Kevin B. Smith
3
+ # Freely reusable code: see SAMPLES-LICENSE.TXT for details
4
+
5
+ begin
6
+ require 'wx'
7
+ rescue LoadError => no_wx_err
8
+ begin
9
+ require 'rubygems'
10
+ require 'wx'
11
+ rescue LoadError
12
+ raise no_wx_err
13
+ end
14
+ end
15
+
16
+ # This sample demonstrates the use of Activate Events. These are
17
+ # generated when a frame becomes active or inactive. This is typically
18
+ # indicated by a frame's titlebar changing colour, and a widget within
19
+ # the frame gainin focus. An event is also generated when a whole wxRuby
20
+ # app starts or stops being the current focussed desktop application.
21
+
22
+ class MinimalFrame < Wx::Frame
23
+ def initialize(title, pos, size, style = Wx::DEFAULT_FRAME_STYLE)
24
+ super(nil, -1, title, pos, size, style)
25
+
26
+
27
+ menuFile = Wx::Menu.new()
28
+ helpMenu = Wx::Menu.new()
29
+ helpMenu.append(Wx::ID_ABOUT, "&About...\tF1", "Show about dialog")
30
+ menuFile.append(Wx::ID_EXIT, "E&xit\tAlt-X", "Quit this program")
31
+ menuBar = Wx::MenuBar.new()
32
+ menuBar.append(menuFile, "&File")
33
+ menuBar.append(helpMenu, "&Help")
34
+ set_menu_bar(menuBar)
35
+
36
+ create_status_bar(2)
37
+ set_status_text("Welcome to wxRuby!")
38
+
39
+ evt_menu(Wx::ID_EXIT) { on_quit }
40
+ evt_menu(Wx::ID_ABOUT) { on_about }
41
+
42
+ evt_activate { | e | on_activate(e) }
43
+ evt_iconize { | e | on_iconize(e) }
44
+ end
45
+
46
+
47
+ def on_iconize(event)
48
+ if event.iconized
49
+ puts "Frame '#{get_title}' was iconized"
50
+ else
51
+ puts "Frame '#{get_title}' was restored"
52
+ end
53
+ end
54
+
55
+ def on_activate(event)
56
+ if event.get_active
57
+ puts "Frame '#{get_title}' became activated"
58
+ set_status_text 'Active'
59
+ else
60
+ puts "Frame '#{get_title}' became deactivated"
61
+ set_status_text 'Inactive'
62
+ end
63
+ event.skip # important
64
+ end
65
+
66
+ def on_quit
67
+ Wx::get_app.close_all
68
+ end
69
+
70
+ def on_about
71
+ msg = sprintf("This is the About dialog of the activate sample.\n" \
72
+ "Welcome to wxRuby, version %s", Wx::WXRUBY_VERSION)
73
+ Wx::message_box(msg, "About Activate", Wx::OK|Wx::ICON_INFORMATION, self)
74
+ end
75
+ end
76
+
77
+ class RbApp < Wx::App
78
+ def on_init
79
+ @frame_1 = MinimalFrame.new("Tall window",
80
+ Wx::Point.new(50, 50),
81
+ Wx::Size.new(150, 240))
82
+ @frame_2 = MinimalFrame.new("Wide window",
83
+ Wx::Point.new(100, 100),
84
+ Wx::Size.new(300, 180))
85
+ evt_activate_app { | e | on_activate_app(e) }
86
+ @frame_1.show()
87
+ @frame_2.show()
88
+
89
+ end
90
+
91
+ def on_activate_app(event)
92
+ if event.get_active
93
+ puts "The app became active"
94
+ else
95
+ puts "The app became inactive"
96
+ end
97
+ event.skip # important
98
+ end
99
+
100
+ def close_all
101
+ @frame_1.close(true)
102
+ @frame_2.close(true)
103
+ end
104
+ end
105
+
106
+ app = RbApp.new
107
+ app.main_loop()
108
+