gosu 0.8.6-x86-mingw32 → 0.8.7-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 (51) hide show
  1. checksums.yaml +4 -4
  2. data/Gosu/Audio.hpp +171 -171
  3. data/Gosu/Bitmap.hpp +96 -96
  4. data/Gosu/Color.hpp +204 -204
  5. data/Gosu/Directories.hpp +36 -36
  6. data/Gosu/Font.hpp +83 -83
  7. data/Gosu/Gosu.hpp +34 -34
  8. data/Gosu/Graphics.hpp +115 -115
  9. data/Gosu/GraphicsBase.hpp +110 -110
  10. data/Gosu/IO.hpp +269 -269
  11. data/Gosu/Image.hpp +122 -122
  12. data/Gosu/ImageData.hpp +61 -61
  13. data/Gosu/Input.hpp +149 -149
  14. data/Gosu/Inspection.hpp +14 -14
  15. data/Gosu/Math.hpp +135 -135
  16. data/Gosu/Platform.hpp +93 -93
  17. data/Gosu/Sockets.hpp +156 -156
  18. data/Gosu/TR1.hpp +56 -56
  19. data/Gosu/Text.hpp +71 -71
  20. data/Gosu/TextInput.hpp +70 -70
  21. data/Gosu/Utility.hpp +28 -28
  22. data/Gosu/Version.hpp +19 -19
  23. data/Gosu/Window.hpp +145 -145
  24. data/examples/ChipmunkIntegration.rb +275 -275
  25. data/examples/CptnRuby.rb +223 -223
  26. data/examples/GosuZen.rb +68 -68
  27. data/examples/MoreChipmunkAndRMagick.rb +155 -155
  28. data/examples/OpenGLIntegration.rb +225 -225
  29. data/examples/RMagickIntegration.rb +417 -417
  30. data/examples/TextInput.rb +154 -154
  31. data/examples/Tutorial.rb +130 -130
  32. data/examples/media/Beep.wav +0 -0
  33. data/examples/media/CptnRuby Map.txt b/data/examples/media/CptnRuby → Map.txt +0 -0
  34. data/examples/media/Explosion.wav +0 -0
  35. data/examples/media/Landscape.svg +9 -9
  36. data/examples/media/Space.png +0 -0
  37. data/examples/media/Star.png +0 -0
  38. data/examples/media/Starfighter.bmp +0 -0
  39. data/lib/1.8/gosu.so +0 -0
  40. data/lib/1.9/gosu.so +0 -0
  41. data/lib/2.0/gosu.so +0 -0
  42. data/lib/2.1/gosu.so +0 -0
  43. data/lib/FreeImage.dll +0 -0
  44. data/lib/OpenAL32.dll +0 -0
  45. data/lib/gosu.rb +19 -16
  46. data/lib/gosu/patches.rb +81 -81
  47. data/lib/gosu/preview.rb +143 -139
  48. data/lib/gosu/run.rb +11 -11
  49. data/lib/gosu/swig_patches.rb +60 -60
  50. data/lib/gosu/zen.rb +89 -89
  51. metadata +5 -5
@@ -1,154 +1,154 @@
1
- # This example demonstrates the use of the TextInput functionality.
2
- # One can tab through, or click into the text fields and change it's contents.
3
-
4
- # At its most basic form, you only need to create a new TextInput instance and
5
- # set the text_input attribute of your window to it. Until you set this
6
- # attribute to nil again, the TextInput object will build a text that can be
7
- # accessed via TextInput#text.
8
-
9
- # The TextInput object also maintains the position of the caret as the index
10
- # of the character that it's left to via the caret_pos attribute. Furthermore,
11
- # if there is a selection, the selection_start attribute yields its beginning,
12
- # using the same indexing scheme. If there is no selection, selection_start
13
- # is equal to caret_pos.
14
-
15
- # A TextInput object is purely abstract, though; drawing the input field is left
16
- # to the user. In this case, we are subclassing TextInput to add this code.
17
- # As with most of Gosu, how this is handled is completely left open; the scheme
18
- # presented here is not mandatory! Gosu only aims to provide enough code for
19
- # games (or intermediate UI toolkits) to be built upon it.
20
-
21
- require 'rubygems'
22
- require 'gosu'
23
-
24
- class TextField < Gosu::TextInput
25
- # Some constants that define our appearance.
26
- INACTIVE_COLOR = 0xcc666666
27
- ACTIVE_COLOR = 0xccff6666
28
- SELECTION_COLOR = 0xcc0000ff
29
- CARET_COLOR = 0xffffffff
30
- PADDING = 5
31
-
32
- attr_reader :x, :y
33
-
34
- def initialize(window, font, x, y)
35
- # TextInput's constructor doesn't expect any arguments.
36
- super()
37
-
38
- @window, @font, @x, @y = window, font, x, y
39
-
40
- # Start with a self-explanatory text in each field.
41
- self.text = "Click to change text"
42
- end
43
-
44
- # Example filter method. You can truncate the text to employ a length limit (watch out
45
- # with Ruby 1.8 and UTF-8!), limit the text to certain characters etc.
46
- def filter text
47
- text.upcase
48
- end
49
-
50
- def draw
51
- # Depending on whether this is the currently selected input or not, change the
52
- # background's color.
53
- if @window.text_input == self then
54
- background_color = ACTIVE_COLOR
55
- else
56
- background_color = INACTIVE_COLOR
57
- end
58
- @window.draw_quad(x - PADDING, y - PADDING, background_color,
59
- x + width + PADDING, y - PADDING, background_color,
60
- x - PADDING, y + height + PADDING, background_color,
61
- x + width + PADDING, y + height + PADDING, background_color, 0)
62
-
63
- # Calculate the position of the caret and the selection start.
64
- pos_x = x + @font.text_width(self.text[0...self.caret_pos])
65
- sel_x = x + @font.text_width(self.text[0...self.selection_start])
66
-
67
- # Draw the selection background, if any; if not, sel_x and pos_x will be
68
- # the same value, making this quad empty.
69
- @window.draw_quad(sel_x, y, SELECTION_COLOR,
70
- pos_x, y, SELECTION_COLOR,
71
- sel_x, y + height, SELECTION_COLOR,
72
- pos_x, y + height, SELECTION_COLOR, 0)
73
-
74
- # Draw the caret; again, only if this is the currently selected field.
75
- if @window.text_input == self then
76
- @window.draw_line(pos_x, y, CARET_COLOR,
77
- pos_x, y + height, CARET_COLOR, 0)
78
- end
79
-
80
- # Finally, draw the text itself!
81
- @font.draw(self.text, x, y, 0)
82
- end
83
-
84
- # This text field grows with the text that's being entered.
85
- # (Usually one would use clip_to and scroll around on the text field.)
86
- def width
87
- @font.text_width(self.text)
88
- end
89
-
90
- def height
91
- @font.height
92
- end
93
-
94
- # Hit-test for selecting a text field with the mouse.
95
- def under_point?(mouse_x, mouse_y)
96
- mouse_x > x - PADDING and mouse_x < x + width + PADDING and
97
- mouse_y > y - PADDING and mouse_y < y + height + PADDING
98
- end
99
-
100
- # Tries to move the caret to the position specifies by mouse_x
101
- def move_caret(mouse_x)
102
- # Test character by character
103
- 1.upto(self.text.length) do |i|
104
- if mouse_x < x + @font.text_width(text[0...i]) then
105
- self.caret_pos = self.selection_start = i - 1;
106
- return
107
- end
108
- end
109
- # Default case: user must have clicked the right edge
110
- self.caret_pos = self.selection_start = self.text.length
111
- end
112
- end
113
-
114
- class TextInputWindow < Gosu::Window
115
- def initialize
116
- super(300, 200, false)
117
- self.caption = "Text Input Example"
118
-
119
- font = Gosu::Font.new(self, Gosu::default_font_name, 20)
120
-
121
- # Set up an array of three text fields.
122
- @text_fields = Array.new(3) { |index| TextField.new(self, font, 50, 30 + index * 50) }
123
-
124
- @cursor = Gosu::Image.new(self, "media/Cursor.png", false)
125
- end
126
-
127
- def draw
128
- @text_fields.each { |tf| tf.draw }
129
- @cursor.draw(mouse_x, mouse_y, 0)
130
- end
131
-
132
- def button_down(id)
133
- if id == Gosu::KbTab then
134
- # Tab key will not be 'eaten' by text fields; use for switching through
135
- # text fields.
136
- index = @text_fields.index(self.text_input) || -1
137
- self.text_input = @text_fields[(index + 1) % @text_fields.size]
138
- elsif id == Gosu::KbEscape then
139
- # Escape key will not be 'eaten' by text fields; use for deselecting.
140
- if self.text_input then
141
- self.text_input = nil
142
- else
143
- close
144
- end
145
- elsif id == Gosu::MsLeft then
146
- # Mouse click: Select text field based on mouse position.
147
- self.text_input = @text_fields.find { |tf| tf.under_point?(mouse_x, mouse_y) }
148
- # Advanced: Move caret to clicked position
149
- self.text_input.move_caret(mouse_x) unless self.text_input.nil?
150
- end
151
- end
152
- end
153
-
154
- TextInputWindow.new.show
1
+ # This example demonstrates the use of the TextInput functionality.
2
+ # One can tab through, or click into the text fields and change it's contents.
3
+
4
+ # At its most basic form, you only need to create a new TextInput instance and
5
+ # set the text_input attribute of your window to it. Until you set this
6
+ # attribute to nil again, the TextInput object will build a text that can be
7
+ # accessed via TextInput#text.
8
+
9
+ # The TextInput object also maintains the position of the caret as the index
10
+ # of the character that it's left to via the caret_pos attribute. Furthermore,
11
+ # if there is a selection, the selection_start attribute yields its beginning,
12
+ # using the same indexing scheme. If there is no selection, selection_start
13
+ # is equal to caret_pos.
14
+
15
+ # A TextInput object is purely abstract, though; drawing the input field is left
16
+ # to the user. In this case, we are subclassing TextInput to add this code.
17
+ # As with most of Gosu, how this is handled is completely left open; the scheme
18
+ # presented here is not mandatory! Gosu only aims to provide enough code for
19
+ # games (or intermediate UI toolkits) to be built upon it.
20
+
21
+ require 'rubygems'
22
+ require 'gosu'
23
+
24
+ class TextField < Gosu::TextInput
25
+ # Some constants that define our appearance.
26
+ INACTIVE_COLOR = 0xcc666666
27
+ ACTIVE_COLOR = 0xccff6666
28
+ SELECTION_COLOR = 0xcc0000ff
29
+ CARET_COLOR = 0xffffffff
30
+ PADDING = 5
31
+
32
+ attr_reader :x, :y
33
+
34
+ def initialize(window, font, x, y)
35
+ # TextInput's constructor doesn't expect any arguments.
36
+ super()
37
+
38
+ @window, @font, @x, @y = window, font, x, y
39
+
40
+ # Start with a self-explanatory text in each field.
41
+ self.text = "Click to change text"
42
+ end
43
+
44
+ # Example filter method. You can truncate the text to employ a length limit (watch out
45
+ # with Ruby 1.8 and UTF-8!), limit the text to certain characters etc.
46
+ def filter text
47
+ text.upcase
48
+ end
49
+
50
+ def draw
51
+ # Depending on whether this is the currently selected input or not, change the
52
+ # background's color.
53
+ if @window.text_input == self then
54
+ background_color = ACTIVE_COLOR
55
+ else
56
+ background_color = INACTIVE_COLOR
57
+ end
58
+ @window.draw_quad(x - PADDING, y - PADDING, background_color,
59
+ x + width + PADDING, y - PADDING, background_color,
60
+ x - PADDING, y + height + PADDING, background_color,
61
+ x + width + PADDING, y + height + PADDING, background_color, 0)
62
+
63
+ # Calculate the position of the caret and the selection start.
64
+ pos_x = x + @font.text_width(self.text[0...self.caret_pos])
65
+ sel_x = x + @font.text_width(self.text[0...self.selection_start])
66
+
67
+ # Draw the selection background, if any; if not, sel_x and pos_x will be
68
+ # the same value, making this quad empty.
69
+ @window.draw_quad(sel_x, y, SELECTION_COLOR,
70
+ pos_x, y, SELECTION_COLOR,
71
+ sel_x, y + height, SELECTION_COLOR,
72
+ pos_x, y + height, SELECTION_COLOR, 0)
73
+
74
+ # Draw the caret; again, only if this is the currently selected field.
75
+ if @window.text_input == self then
76
+ @window.draw_line(pos_x, y, CARET_COLOR,
77
+ pos_x, y + height, CARET_COLOR, 0)
78
+ end
79
+
80
+ # Finally, draw the text itself!
81
+ @font.draw(self.text, x, y, 0)
82
+ end
83
+
84
+ # This text field grows with the text that's being entered.
85
+ # (Usually one would use clip_to and scroll around on the text field.)
86
+ def width
87
+ @font.text_width(self.text)
88
+ end
89
+
90
+ def height
91
+ @font.height
92
+ end
93
+
94
+ # Hit-test for selecting a text field with the mouse.
95
+ def under_point?(mouse_x, mouse_y)
96
+ mouse_x > x - PADDING and mouse_x < x + width + PADDING and
97
+ mouse_y > y - PADDING and mouse_y < y + height + PADDING
98
+ end
99
+
100
+ # Tries to move the caret to the position specifies by mouse_x
101
+ def move_caret(mouse_x)
102
+ # Test character by character
103
+ 1.upto(self.text.length) do |i|
104
+ if mouse_x < x + @font.text_width(text[0...i]) then
105
+ self.caret_pos = self.selection_start = i - 1;
106
+ return
107
+ end
108
+ end
109
+ # Default case: user must have clicked the right edge
110
+ self.caret_pos = self.selection_start = self.text.length
111
+ end
112
+ end
113
+
114
+ class TextInputWindow < Gosu::Window
115
+ def initialize
116
+ super(300, 200, false)
117
+ self.caption = "Text Input Example"
118
+
119
+ font = Gosu::Font.new(self, Gosu::default_font_name, 20)
120
+
121
+ # Set up an array of three text fields.
122
+ @text_fields = Array.new(3) { |index| TextField.new(self, font, 50, 30 + index * 50) }
123
+
124
+ @cursor = Gosu::Image.new(self, "media/Cursor.png", false)
125
+ end
126
+
127
+ def draw
128
+ @text_fields.each { |tf| tf.draw }
129
+ @cursor.draw(mouse_x, mouse_y, 0)
130
+ end
131
+
132
+ def button_down(id)
133
+ if id == Gosu::KbTab then
134
+ # Tab key will not be 'eaten' by text fields; use for switching through
135
+ # text fields.
136
+ index = @text_fields.index(self.text_input) || -1
137
+ self.text_input = @text_fields[(index + 1) % @text_fields.size]
138
+ elsif id == Gosu::KbEscape then
139
+ # Escape key will not be 'eaten' by text fields; use for deselecting.
140
+ if self.text_input then
141
+ self.text_input = nil
142
+ else
143
+ close
144
+ end
145
+ elsif id == Gosu::MsLeft then
146
+ # Mouse click: Select text field based on mouse position.
147
+ self.text_input = @text_fields.find { |tf| tf.under_point?(mouse_x, mouse_y) }
148
+ # Advanced: Move caret to clicked position
149
+ self.text_input.move_caret(mouse_x) unless self.text_input.nil?
150
+ end
151
+ end
152
+ end
153
+
154
+ TextInputWindow.new.show
@@ -1,131 +1,131 @@
1
- require 'rubygems'
2
- require 'gosu'
3
-
4
- module ZOrder
5
- Background, Stars, Player, UI = *0..3
6
- end
7
-
8
- class Player
9
- attr_reader :score
10
-
11
- def initialize(window)
12
- @image = Gosu::Image.new(window, "media/Starfighter.bmp", false)
13
- @beep = Gosu::Sample.new(window, "media/Beep.wav")
14
- @x = @y = @vel_x = @vel_y = @angle = 0.0
15
- @score = 0
16
- end
17
-
18
- def warp(x, y)
19
- @x, @y = x, y
20
- end
21
-
22
- def turn_left
23
- @angle -= 4.5
24
- end
25
-
26
- def turn_right
27
- @angle += 4.5
28
- end
29
-
30
- def accelerate
31
- @vel_x += Gosu::offset_x(@angle, 0.5)
32
- @vel_y += Gosu::offset_y(@angle, 0.5)
33
- end
34
-
35
- def move
36
- @x += @vel_x
37
- @y += @vel_y
38
- @x %= 640
39
- @y %= 480
40
-
41
- @vel_x *= 0.95
42
- @vel_y *= 0.95
43
- end
44
-
45
- def draw
46
- @image.draw_rot(@x, @y, ZOrder::Player, @angle)
47
- end
48
-
49
- def collect_stars(stars)
50
- stars.reject! do |star|
51
- if Gosu::distance(@x, @y, star.x, star.y) < 35 then
52
- @score += 10
53
- @beep.play
54
- true
55
- else
56
- false
57
- end
58
- end
59
- end
60
- end
61
-
62
- class Star
63
- attr_reader :x, :y
64
-
65
- def initialize(animation)
66
- @animation = animation
67
- @color = Gosu::Color.new(0xff000000)
68
- @color.red = rand(256 - 40) + 40
69
- @color.green = rand(256 - 40) + 40
70
- @color.blue = rand(256 - 40) + 40
71
- @x = rand * 640
72
- @y = rand * 480
73
- end
74
-
75
- def draw
76
- img = @animation[Gosu::milliseconds / 100 % @animation.size]
77
- img.draw(@x - img.width / 2.0, @y - img.height / 2.0,
78
- ZOrder::Stars, 1, 1, @color, :add)
79
- end
80
- end
81
-
82
- class GameWindow < Gosu::Window
83
- def initialize
84
- super(640, 480, false)
85
- self.caption = "Gosu Tutorial Game"
86
-
87
- @background_image = Gosu::Image.new(self, "media/Space.png", true)
88
-
89
- @player = Player.new(self)
90
- @player.warp(320, 240)
91
-
92
- @star_anim = Gosu::Image::load_tiles(self, "media/Star.png", 25, 25, false)
93
- @stars = Array.new
94
-
95
- @font = Gosu::Font.new(self, Gosu::default_font_name, 20)
96
- end
97
-
98
- def update
99
- if button_down? Gosu::KbLeft or button_down? Gosu::GpLeft then
100
- @player.turn_left
101
- end
102
- if button_down? Gosu::KbRight or button_down? Gosu::GpRight then
103
- @player.turn_right
104
- end
105
- if button_down? Gosu::KbUp or button_down? Gosu::GpButton0 then
106
- @player.accelerate
107
- end
108
- @player.move
109
- @player.collect_stars(@stars)
110
-
111
- if rand(100) < 4 and @stars.size < 25 then
112
- @stars.push(Star.new(@star_anim))
113
- end
114
- end
115
-
116
- def draw
117
- @background_image.draw(0, 0, ZOrder::Background)
118
- @player.draw
119
- @stars.each { |star| star.draw }
120
- @font.draw("Score: #{@player.score}", 10, 10, ZOrder::UI, 1.0, 1.0, 0xffffff00)
121
- end
122
-
123
- def button_down(id)
124
- if id == Gosu::KbEscape then
125
- close
126
- end
127
- end
128
- end
129
-
130
- window = GameWindow.new
1
+ require 'rubygems'
2
+ require 'gosu'
3
+
4
+ module ZOrder
5
+ Background, Stars, Player, UI = *0..3
6
+ end
7
+
8
+ class Player
9
+ attr_reader :score
10
+
11
+ def initialize(window)
12
+ @image = Gosu::Image.new(window, "media/Starfighter.bmp", false)
13
+ @beep = Gosu::Sample.new(window, "media/Beep.wav")
14
+ @x = @y = @vel_x = @vel_y = @angle = 0.0
15
+ @score = 0
16
+ end
17
+
18
+ def warp(x, y)
19
+ @x, @y = x, y
20
+ end
21
+
22
+ def turn_left
23
+ @angle -= 4.5
24
+ end
25
+
26
+ def turn_right
27
+ @angle += 4.5
28
+ end
29
+
30
+ def accelerate
31
+ @vel_x += Gosu::offset_x(@angle, 0.5)
32
+ @vel_y += Gosu::offset_y(@angle, 0.5)
33
+ end
34
+
35
+ def move
36
+ @x += @vel_x
37
+ @y += @vel_y
38
+ @x %= 640
39
+ @y %= 480
40
+
41
+ @vel_x *= 0.95
42
+ @vel_y *= 0.95
43
+ end
44
+
45
+ def draw
46
+ @image.draw_rot(@x, @y, ZOrder::Player, @angle)
47
+ end
48
+
49
+ def collect_stars(stars)
50
+ stars.reject! do |star|
51
+ if Gosu::distance(@x, @y, star.x, star.y) < 35 then
52
+ @score += 10
53
+ @beep.play
54
+ true
55
+ else
56
+ false
57
+ end
58
+ end
59
+ end
60
+ end
61
+
62
+ class Star
63
+ attr_reader :x, :y
64
+
65
+ def initialize(animation)
66
+ @animation = animation
67
+ @color = Gosu::Color.new(0xff000000)
68
+ @color.red = rand(256 - 40) + 40
69
+ @color.green = rand(256 - 40) + 40
70
+ @color.blue = rand(256 - 40) + 40
71
+ @x = rand * 640
72
+ @y = rand * 480
73
+ end
74
+
75
+ def draw
76
+ img = @animation[Gosu::milliseconds / 100 % @animation.size]
77
+ img.draw(@x - img.width / 2.0, @y - img.height / 2.0,
78
+ ZOrder::Stars, 1, 1, @color, :add)
79
+ end
80
+ end
81
+
82
+ class GameWindow < Gosu::Window
83
+ def initialize
84
+ super(640, 480, false)
85
+ self.caption = "Gosu Tutorial Game"
86
+
87
+ @background_image = Gosu::Image.new(self, "media/Space.png", true)
88
+
89
+ @player = Player.new(self)
90
+ @player.warp(320, 240)
91
+
92
+ @star_anim = Gosu::Image::load_tiles(self, "media/Star.png", 25, 25, false)
93
+ @stars = Array.new
94
+
95
+ @font = Gosu::Font.new(self, Gosu::default_font_name, 20)
96
+ end
97
+
98
+ def update
99
+ if button_down? Gosu::KbLeft or button_down? Gosu::GpLeft then
100
+ @player.turn_left
101
+ end
102
+ if button_down? Gosu::KbRight or button_down? Gosu::GpRight then
103
+ @player.turn_right
104
+ end
105
+ if button_down? Gosu::KbUp or button_down? Gosu::GpButton0 then
106
+ @player.accelerate
107
+ end
108
+ @player.move
109
+ @player.collect_stars(@stars)
110
+
111
+ if rand(100) < 4 and @stars.size < 25 then
112
+ @stars.push(Star.new(@star_anim))
113
+ end
114
+ end
115
+
116
+ def draw
117
+ @background_image.draw(0, 0, ZOrder::Background)
118
+ @player.draw
119
+ @stars.each { |star| star.draw }
120
+ @font.draw("Score: #{@player.score}", 10, 10, ZOrder::UI, 1.0, 1.0, 0xffffff00)
121
+ end
122
+
123
+ def button_down(id)
124
+ if id == Gosu::KbEscape then
125
+ close
126
+ end
127
+ end
128
+ end
129
+
130
+ window = GameWindow.new
131
131
  window.show