ray 0.1.0.pre1 → 0.1.0
Sign up to get free protection for your applications and to get access to all the features.
- data/README.md +235 -32
- data/Rakefile +20 -49
- data/ext/audio.c +68 -0
- data/ext/audio_source.c +197 -0
- data/ext/buffer_renderer.c +130 -0
- data/ext/color.c +179 -0
- data/ext/drawable.c +446 -0
- data/ext/event.c +337 -0
- data/ext/extconf.rb +80 -6
- data/ext/font.c +97 -0
- data/ext/gl.c +114 -0
- data/ext/gl_buffer.c +224 -0
- data/ext/gl_index_buffer.c +202 -0
- data/ext/gl_int_array.c +139 -0
- data/ext/gl_vertex.c +157 -0
- data/ext/image.c +263 -0
- data/ext/image_target.c +84 -0
- data/ext/input.c +53 -0
- data/ext/matrix.c +374 -0
- data/ext/music.c +113 -0
- data/ext/polygon.c +426 -0
- data/ext/ray.c +59 -0
- data/ext/ray.h +168 -0
- data/ext/rect.c +255 -0
- data/ext/say.h +31 -0
- data/ext/say_all.h +77 -0
- data/ext/say_arial.h +14689 -0
- data/ext/say_array.c +124 -0
- data/ext/say_array.h +34 -0
- data/ext/say_audio.c +64 -0
- data/ext/say_audio.h +170 -0
- data/ext/say_audio_context.c +40 -0
- data/ext/say_audio_source.c +96 -0
- data/ext/say_basic_type.c +17 -0
- data/ext/say_basic_type.h +47 -0
- data/ext/say_buffer.c +277 -0
- data/ext/say_buffer.h +37 -0
- data/ext/say_buffer_renderer.c +121 -0
- data/ext/say_buffer_renderer.h +33 -0
- data/ext/say_buffer_slice.c +247 -0
- data/ext/say_buffer_slice.h +29 -0
- data/ext/say_clean_up.c +14 -0
- data/ext/say_context.c +163 -0
- data/ext/say_context.h +26 -0
- data/ext/say_drawable.c +350 -0
- data/ext/say_drawable.h +100 -0
- data/ext/say_error.c +27 -0
- data/ext/say_event.h +213 -0
- data/ext/say_font.c +335 -0
- data/ext/say_font.h +51 -0
- data/ext/say_image.c +283 -0
- data/ext/say_image.h +52 -0
- data/ext/say_image_target.c +134 -0
- data/ext/say_image_target.h +25 -0
- data/ext/say_imp.h +70 -0
- data/ext/say_index_buffer.c +90 -0
- data/ext/say_index_buffer.h +29 -0
- data/ext/say_index_buffer_slice.c +227 -0
- data/ext/say_index_buffer_slice.h +28 -0
- data/ext/say_input.c +35 -0
- data/ext/say_matrix.c +314 -0
- data/ext/say_matrix.h +55 -0
- data/ext/say_music.c +225 -0
- data/ext/say_osx.h +62 -0
- data/ext/say_osx_context.h +98 -0
- data/ext/say_osx_window.h +766 -0
- data/ext/say_polygon.c +358 -0
- data/ext/say_polygon.h +62 -0
- data/ext/say_renderer.c +42 -0
- data/ext/say_renderer.h +22 -0
- data/ext/say_shader.c +375 -0
- data/ext/say_shader.h +91 -0
- data/ext/say_sound.c +67 -0
- data/ext/say_sound_buffer.c +96 -0
- data/ext/say_sprite.c +273 -0
- data/ext/say_sprite.h +53 -0
- data/ext/say_string.c +9 -0
- data/ext/say_table.c +86 -0
- data/ext/say_table.h +24 -0
- data/ext/say_target.c +264 -0
- data/ext/say_target.h +67 -0
- data/ext/say_text.c +441 -0
- data/ext/say_text.h +56 -0
- data/ext/say_thread.c +46 -0
- data/ext/say_thread.h +39 -0
- data/ext/say_thread_variable.c +44 -0
- data/ext/say_utf.c +62 -0
- data/ext/say_vertex_type.c +113 -0
- data/ext/say_vertex_type.h +40 -0
- data/ext/say_vfile.c +57 -0
- data/ext/say_view.c +150 -0
- data/ext/say_view.h +44 -0
- data/ext/say_win.h +24 -0
- data/ext/say_win_context.h +91 -0
- data/ext/say_win_window.h +670 -0
- data/ext/say_window.c +155 -0
- data/ext/say_window.h +43 -0
- data/ext/say_x11.h +41 -0
- data/ext/say_x11_context.h +96 -0
- data/ext/say_x11_window.h +818 -0
- data/ext/shader.c +302 -0
- data/ext/sound.c +118 -0
- data/ext/sound_buffer.c +75 -0
- data/ext/sprite.c +241 -0
- data/ext/stb_image.h +4971 -0
- data/ext/stb_image_write.h +511 -0
- data/ext/target.c +184 -0
- data/ext/text.c +162 -0
- data/ext/utils.c +10 -0
- data/ext/vector.c +261 -0
- data/ext/vendor/freetype/bin/freetype6.dll +0 -0
- data/ext/vendor/freetype/bin/zlib1.dll +0 -0
- data/ext/vendor/freetype/include/freetype2/freetype/config/ftconfig.h +350 -0
- data/ext/vendor/freetype/include/freetype2/freetype/config/ftheader.h +729 -0
- data/ext/vendor/freetype/include/freetype2/freetype/config/ftmodule.h +22 -0
- data/ext/vendor/freetype/include/freetype2/freetype/config/ftoption.h +695 -0
- data/ext/vendor/freetype/include/freetype2/freetype/config/ftstdlib.h +180 -0
- data/ext/vendor/freetype/include/freetype2/freetype/freetype.h +3434 -0
- data/ext/vendor/freetype/include/freetype2/freetype/ftbbox.h +94 -0
- data/ext/vendor/freetype/include/freetype2/freetype/ftbdf.h +200 -0
- data/ext/vendor/freetype/include/freetype2/freetype/ftbitmap.h +206 -0
- data/ext/vendor/freetype/include/freetype2/freetype/ftcache.h +1110 -0
- data/ext/vendor/freetype/include/freetype2/freetype/ftchapters.h +100 -0
- data/ext/vendor/freetype/include/freetype2/freetype/fterrdef.h +239 -0
- data/ext/vendor/freetype/include/freetype2/freetype/fterrors.h +206 -0
- data/ext/vendor/freetype/include/freetype2/freetype/ftgasp.h +113 -0
- data/ext/vendor/freetype/include/freetype2/freetype/ftglyph.h +575 -0
- data/ext/vendor/freetype/include/freetype2/freetype/ftgxval.h +358 -0
- data/ext/vendor/freetype/include/freetype2/freetype/ftgzip.h +102 -0
- data/ext/vendor/freetype/include/freetype2/freetype/ftimage.h +1237 -0
- data/ext/vendor/freetype/include/freetype2/freetype/ftincrem.h +331 -0
- data/ext/vendor/freetype/include/freetype2/freetype/ftlcdfil.h +166 -0
- data/ext/vendor/freetype/include/freetype2/freetype/ftlist.h +273 -0
- data/ext/vendor/freetype/include/freetype2/freetype/ftlzw.h +99 -0
- data/ext/vendor/freetype/include/freetype2/freetype/ftmac.h +272 -0
- data/ext/vendor/freetype/include/freetype2/freetype/ftmm.h +378 -0
- data/ext/vendor/freetype/include/freetype2/freetype/ftmodapi.h +406 -0
- data/ext/vendor/freetype/include/freetype2/freetype/ftmoderr.h +155 -0
- data/ext/vendor/freetype/include/freetype2/freetype/ftotval.h +198 -0
- data/ext/vendor/freetype/include/freetype2/freetype/ftoutln.h +526 -0
- data/ext/vendor/freetype/include/freetype2/freetype/ftpfr.h +172 -0
- data/ext/vendor/freetype/include/freetype2/freetype/ftrender.h +229 -0
- data/ext/vendor/freetype/include/freetype2/freetype/ftsizes.h +159 -0
- data/ext/vendor/freetype/include/freetype2/freetype/ftsnames.h +170 -0
- data/ext/vendor/freetype/include/freetype2/freetype/ftstroke.h +716 -0
- data/ext/vendor/freetype/include/freetype2/freetype/ftsynth.h +73 -0
- data/ext/vendor/freetype/include/freetype2/freetype/ftsystem.h +346 -0
- data/ext/vendor/freetype/include/freetype2/freetype/fttrigon.h +350 -0
- data/ext/vendor/freetype/include/freetype2/freetype/fttypes.h +583 -0
- data/ext/vendor/freetype/include/freetype2/freetype/ftwinfnt.h +263 -0
- data/ext/vendor/freetype/include/freetype2/freetype/ftxf86.h +80 -0
- data/ext/vendor/freetype/include/freetype2/freetype/t1tables.h +450 -0
- data/ext/vendor/freetype/include/freetype2/freetype/ttnameid.h +1132 -0
- data/ext/vendor/freetype/include/freetype2/freetype/tttables.h +756 -0
- data/ext/vendor/freetype/include/freetype2/freetype/tttags.h +99 -0
- data/ext/vendor/freetype/include/freetype2/freetype/ttunpat.h +59 -0
- data/ext/vendor/freetype/include/ft2build.h +61 -0
- data/ext/vendor/freetype/lib/freetype-bcc.lib +0 -0
- data/ext/vendor/freetype/lib/freetype6.def +249 -0
- data/ext/vendor/freetype/lib/libfreetype.dll.a +0 -0
- data/ext/vendor/freetype/lib/tmp.freetype.lib +0 -0
- data/ext/vendor/glew/LICENSE.txt +73 -0
- data/ext/vendor/glew/README.txt +18 -0
- data/ext/vendor/glew/include/GL/glew.h +15507 -0
- data/ext/vendor/glew/include/GL/glxew.h +1568 -0
- data/ext/vendor/glew/include/GL/wglew.h +1361 -0
- data/ext/vendor/glew/lib/glew32.dll +0 -0
- data/ext/vendor/glew/lib/glew32mx.dll +0 -0
- data/ext/vendor/glew/lib/libglew32.a +0 -0
- data/ext/vendor/glew/lib/libglew32.dll.a +0 -0
- data/ext/vendor/glew/lib/libglew32mx.a +0 -0
- data/ext/vendor/glew/lib/libglew32mx.dll.a +0 -0
- data/ext/vendor/openal/COPYING +484 -0
- data/ext/vendor/openal/Win32/soft_oal.dll +0 -0
- data/ext/vendor/openal/include/AL/al.h +724 -0
- data/ext/vendor/openal/include/AL/alc.h +277 -0
- data/ext/vendor/openal/include/AL/alext.h +165 -0
- data/ext/vendor/openal/include/AL/efx-creative.h +3 -0
- data/ext/vendor/openal/include/AL/efx.h +758 -0
- data/ext/vendor/openal/lib/libOpenAL32.dll.a +0 -0
- data/ext/vendor/sndfile/bin/libsndfile-1.dll +0 -0
- data/ext/vendor/sndfile/include/sndfile.h +666 -0
- data/ext/vendor/sndfile/include/sndfile.hh +422 -0
- data/ext/vendor/sndfile/lib/libsndfile-1.def +41 -0
- data/ext/vendor/sndfile/lib/libsndfile-1.lib +0 -0
- data/ext/vertex.c +96 -0
- data/ext/view.c +131 -0
- data/ext/window.c +183 -0
- data/lib/ray/animation.rb +248 -0
- data/lib/ray/animation/block_animation.rb +36 -0
- data/lib/ray/animation/circular_motion.rb +57 -0
- data/lib/ray/animation/color_variation.rb +102 -0
- data/lib/ray/animation/combination.rb +71 -0
- data/lib/ray/animation/float_variation.rb +76 -0
- data/lib/ray/animation/sequence.rb +65 -0
- data/lib/ray/animation/sprite_animation.rb +68 -0
- data/lib/ray/animation/vector_variation.rb +111 -0
- data/lib/ray/animation_list.rb +50 -0
- data/lib/ray/audio.rb +4 -7
- data/lib/ray/buffer_renderer.rb +9 -0
- data/lib/ray/color.rb +41 -6
- data/lib/ray/drawable.rb +34 -9
- data/lib/ray/dsl.rb +6 -0
- data/lib/ray/dsl/event.rb +1 -1
- data/lib/ray/dsl/event_listener.rb +14 -10
- data/lib/ray/dsl/event_raiser.rb +5 -2
- data/lib/ray/dsl/event_runner.rb +4 -10
- data/lib/ray/dsl/event_translator.rb +67 -99
- data/lib/ray/dsl/handler.rb +1 -1
- data/lib/ray/dsl/matcher.rb +40 -27
- data/lib/ray/event.rb +22 -0
- data/lib/ray/font.rb +0 -42
- data/lib/ray/font_set.rb +3 -7
- data/lib/ray/game.rb +33 -73
- data/lib/ray/gl/int_array.rb +24 -0
- data/lib/ray/gl/vertex.rb +106 -0
- data/lib/ray/helper.rb +25 -11
- data/lib/ray/image.rb +9 -154
- data/lib/ray/image_set.rb +3 -8
- data/lib/ray/image_target.rb +12 -0
- data/lib/ray/matrix.rb +90 -0
- data/lib/ray/music.rb +12 -0
- data/lib/ray/polygon.rb +77 -0
- data/lib/ray/ray.rb +45 -13
- data/lib/ray/rect.rb +14 -3
- data/lib/ray/resource_set.rb +18 -35
- data/lib/ray/scene.rb +43 -81
- data/lib/ray/scene_list.rb +12 -5
- data/lib/ray/shader.rb +82 -0
- data/lib/ray/sound.rb +18 -0
- data/lib/ray/sound_buffer.rb +6 -0
- data/lib/ray/sound_buffer_set.rb +32 -0
- data/lib/ray/sprite.rb +111 -97
- data/lib/ray/target.rb +18 -0
- data/lib/ray/text.rb +80 -58
- data/lib/ray/text_helper.rb +21 -27
- data/lib/ray/turtle.rb +49 -38
- data/lib/ray/vector.rb +76 -1
- data/lib/ray/vertex.rb +24 -0
- data/lib/ray/view.rb +47 -0
- data/lib/ray/window.rb +23 -0
- data/samples/_media/Beep.wav +0 -0
- data/samples/_media/CptnRuby Gem.png +0 -0
- data/samples/_media/CptnRuby Map.txt +25 -0
- data/samples/_media/CptnRuby Tileset.png +0 -0
- data/samples/_media/CptnRuby.png +0 -0
- data/samples/_media/Space.png +0 -0
- data/samples/_media/Star.png +0 -0
- data/samples/_media/Starfighter.png +0 -0
- data/samples/animation/chain.rb +33 -0
- data/samples/animation/circle.rb +38 -0
- data/samples/animation/color.rb +18 -0
- data/samples/animation/rotation.rb +17 -0
- data/samples/animation/sequence.rb +33 -0
- data/samples/animation/shader.rb +65 -0
- data/samples/animation/sprite_motion.rb +103 -0
- data/samples/animation/translation.rb +23 -0
- data/samples/audio/spacial.rb +25 -11
- data/samples/buffer/buffer.rb +28 -0
- data/samples/buffer/index_buffer.rb +36 -0
- data/samples/buffer/renderer.rb +27 -0
- data/samples/cptn_ruby/cptn_ruby.rb +279 -0
- data/samples/hello_world/hello.rb +2 -2
- data/samples/hello_world/hello_dsl.rb +3 -3
- data/samples/hello_world/text.rb +2 -2
- data/samples/opengl/cube.rb +124 -0
- data/samples/opengl/image.rb +36 -16
- data/samples/opengl/obj_loader.rb +99 -0
- data/samples/opengl/opengl.rb +24 -18
- data/samples/opengl/shader.rb +36 -26
- data/samples/pong/pong.rb +41 -39
- data/samples/{run_scene.rb → scenes/run_scene.rb} +21 -7
- data/samples/shaders/geometry.rb +98 -0
- data/samples/shaders/scene.rb +19 -12
- data/samples/shaders/shaders.rb +34 -17
- data/samples/shaders/shape.rb +12 -7
- data/samples/sokoban/level_1 +11 -7
- data/samples/sokoban/sokoban.rb +36 -63
- data/samples/starfighter/starfighter.rb +159 -0
- data/samples/test/actual_scene.rb +3 -3
- data/samples/test/scene_riot.rb +4 -4
- data/samples/test/scene_spec.rb +3 -3
- data/samples/test/scene_test_unit.rb +1 -1
- data/samples/turtle/byzantium.rb +10 -5
- data/samples/turtle/hilbert.rb +16 -11
- data/samples/turtle/koch.rb +16 -11
- data/samples/turtle/mandala.rb +43 -38
- data/samples/turtle/tree.rb +13 -8
- data/samples/view/resize.rb +26 -0
- data/samples/view/view.rb +35 -0
- data/samples/window/all_events.rb +44 -0
- data/samples/window/change_title.rb +16 -0
- data/samples/window/fullscreen.rb +18 -0
- data/samples/window/get_pixel.rb +29 -0
- data/samples/window/icon.rb +88 -0
- data/samples/window/input.rb +27 -0
- data/samples/window/no_border.rb +16 -0
- data/samples/window/resize.rb +24 -0
- data/test/animation/color_variation_test.rb +64 -0
- data/test/animation/combination_test.rb +35 -0
- data/test/animation/float_variation_test.rb +75 -0
- data/test/animation/vector_variation_test.rb +123 -0
- data/test/animation_list_test.rb +122 -0
- data/test/animation_test.rb +83 -0
- data/test/audio_test.rb +88 -33
- data/test/buffer_renderer_test.rb +38 -0
- data/test/color_test.rb +31 -22
- data/test/drawable_test.rb +207 -7
- data/test/dsl_test.rb +25 -7
- data/test/font_test.rb +6 -40
- data/test/game_test.rb +76 -0
- data/test/gl_buffer_test.rb +26 -0
- data/test/gl_index_buffer_test.rb +17 -0
- data/test/gl_vertex_test.rb +117 -0
- data/test/helpers.rb +45 -5
- data/test/image_target_test.rb +19 -0
- data/test/image_test.rb +73 -53
- data/test/int_array_test.rb +64 -0
- data/test/matrix_test.rb +134 -0
- data/test/polygon_test.rb +126 -0
- data/test/rect_test.rb +6 -8
- data/test/res/frag.c +14 -0
- data/test/res/frag3d.c +10 -0
- data/test/res/frag_gray.c +17 -0
- data/test/res/frag_light3d.c +20 -0
- data/test/res/light3d.c +20 -0
- data/test/res/sprite.png +0 -0
- data/test/res/teapot.obj +12831 -0
- data/test/res/vert.c +17 -0
- data/test/res/vertex3d.c +14 -0
- data/test/resource_set_test.rb +8 -45
- data/test/run_all.rb +1 -1
- data/test/scene_list_test.rb +79 -0
- data/test/scene_test.rb +168 -0
- data/test/shader_test.rb +58 -0
- data/test/sprite_test.rb +46 -41
- data/test/target_test.rb +34 -0
- data/test/text_test.rb +20 -31
- data/test/turtle_test.rb +35 -20
- data/test/vector_test.rb +61 -19
- data/test/vertex_test.rb +43 -0
- data/test/view_test.rb +61 -0
- metadata +347 -126
- data/.yardopts +0 -4
- data/VERSION +0 -1
- data/ext/audio.cpp +0 -723
- data/ext/color.cpp +0 -159
- data/ext/drawable.cpp +0 -91
- data/ext/event.cpp +0 -460
- data/ext/font.cpp +0 -190
- data/ext/image.cpp +0 -733
- data/ext/input.cpp +0 -74
- data/ext/ray.cpp +0 -168
- data/ext/ray.hpp +0 -356
- data/ext/rect.cpp +0 -245
- data/ext/shader.cpp +0 -169
- data/ext/shape.cpp +0 -409
- data/ext/sprite.cpp +0 -306
- data/ext/text.cpp +0 -181
- data/ext/vector.cpp +0 -215
- data/guide.md +0 -619
- data/lib/ray/input.rb +0 -10
- data/lib/ray/music_set.rb +0 -37
- data/lib/ray/rmagick.rb +0 -41
- data/lib/ray/shape.rb +0 -132
- data/lib/ray/sound_set.rb +0 -37
- data/samples/opengl/binding.rb +0 -38
- data/test/ray_test.rb +0 -25
- data/test/shape_test.rb +0 -101
- data/yard_ext.rb +0 -63
@@ -0,0 +1,19 @@
|
|
1
|
+
require File.expand_path(File.dirname(__FILE__)) + '/helpers.rb'
|
2
|
+
|
3
|
+
context "an image target" do
|
4
|
+
img = Ray::Image.new [50, 50]
|
5
|
+
setup { Ray::ImageTarget.new img }
|
6
|
+
|
7
|
+
asserts(:size).equals Ray::Vector2[50, 50]
|
8
|
+
|
9
|
+
context "after draw & update" do
|
10
|
+
hookup do
|
11
|
+
topic.clear Ray::Color.red
|
12
|
+
topic.update
|
13
|
+
end
|
14
|
+
|
15
|
+
asserts("color of image") { img[0, 0] }.equals Ray::Color.red
|
16
|
+
end
|
17
|
+
end if Ray::ImageTarget.available?
|
18
|
+
|
19
|
+
run_tests if __FILE__ == $0
|
data/test/image_test.rb
CHANGED
@@ -3,80 +3,100 @@ require File.expand_path(File.dirname(__FILE__)) + '/helpers.rb'
|
|
3
3
|
context Ray::Image do
|
4
4
|
setup { Ray::Image }
|
5
5
|
|
6
|
-
|
7
|
-
|
6
|
+
asserts(:new, path_of("pop.wav")).raises_kind_of RuntimeError
|
7
|
+
asserts(:new, path_of("thing.png")).raises_kind_of RuntimeError
|
8
8
|
|
9
|
-
|
10
|
-
asserts(:h).equals(70)
|
11
|
-
end
|
12
|
-
|
13
|
-
denies("creating from a file") {
|
14
|
-
topic.new(path_of("aqua.bmp"))
|
15
|
-
}.raises(RuntimeError)
|
9
|
+
asserts(:new, [0, 0]).raises_kind_of Exception
|
16
10
|
|
17
|
-
asserts(
|
18
|
-
|
19
|
-
|
11
|
+
asserts(:new, StringIO.new(File.read(path_of("pop.wav")))).
|
12
|
+
raises_kind_of RuntimeError
|
13
|
+
end
|
20
14
|
|
21
|
-
|
22
|
-
|
23
|
-
}.raises(RuntimeError)
|
15
|
+
context "an image loaded from a file" do
|
16
|
+
setup { Ray::Image.new path_of("sprite.png") }
|
24
17
|
|
25
|
-
asserts(
|
26
|
-
|
27
|
-
|
18
|
+
asserts(:width).equals 128
|
19
|
+
asserts(:height).equals 192
|
20
|
+
asserts(:size).equals Ray::Vector2[128, 192]
|
28
21
|
|
29
|
-
|
30
|
-
|
31
|
-
b = topic.new(:w => 10, :h => 10).fill(Ray::Color.red).update
|
22
|
+
asserts(:[], 128, 100).nil
|
23
|
+
asserts(:[], 100, 192).nil
|
32
24
|
|
33
|
-
|
34
|
-
|
25
|
+
asserts(:[]=, 128, 100, Ray::Color.green).raises_kind_of RangeError
|
26
|
+
asserts(:[]=, 100, 192, Ray::Color.green).raises_kind_of RangeError
|
35
27
|
|
36
|
-
|
37
|
-
|
28
|
+
context "after changing a pixel" do
|
29
|
+
hookup { topic[0, 10] = Ray::Color.green }
|
30
|
+
asserts(:[], 0, 10).equals Ray::Color.green
|
31
|
+
denies(:[], 1, 10).equals Ray::Color.green
|
38
32
|
end
|
39
33
|
end
|
40
34
|
|
41
|
-
context "an image" do
|
42
|
-
setup {
|
35
|
+
context "an image loaded from an IO" do
|
36
|
+
setup { open(path_of("sprite.png"), "rb") { |io| Ray::Image.new(io) } }
|
43
37
|
|
44
|
-
asserts(:
|
45
|
-
|
46
|
-
asserts(
|
38
|
+
asserts(:width).equals 128
|
39
|
+
asserts(:height).equals 192
|
40
|
+
asserts(:size).equals Ray::Vector2[128, 192]
|
41
|
+
end
|
47
42
|
|
48
|
-
|
49
|
-
|
43
|
+
context "an image created from a size" do
|
44
|
+
setup { Ray::Image.new [64, 128] }
|
50
45
|
|
51
|
-
asserts(
|
52
|
-
|
53
|
-
|
46
|
+
asserts(:width).equals 64
|
47
|
+
asserts(:height).equals 128
|
48
|
+
asserts(:size).equals Ray::Vector2[64, 128]
|
54
49
|
|
55
|
-
|
56
|
-
|
57
|
-
|
50
|
+
asserts(:tex_rect, [0, 0, 64, 128]).equals Ray::Rect[0, 0, 1, 1]
|
51
|
+
asserts(:tex_rect, [0, 0, 32, 128]).equals Ray::Rect[0, 0, 0.5, 1]
|
52
|
+
asserts(:tex_rect, [0, 0, 64, 64]).equals Ray::Rect[0, 0, 1, 0.5]
|
53
|
+
asserts(:tex_rect, [32, 32, 32, 32]).equals Ray::Rect[0.5, 0.25, 0.5, 0.25]
|
58
54
|
|
59
|
-
|
60
|
-
topic[5, 5] = Ray::Color.red
|
61
|
-
}.raises(RuntimeError)
|
55
|
+
denies :smooth?
|
62
56
|
|
63
|
-
context "after
|
64
|
-
hookup { topic.
|
65
|
-
asserts
|
57
|
+
context "after enabling smoothing" do
|
58
|
+
hookup { topic.smooth = true }
|
59
|
+
asserts :smooth?
|
66
60
|
end
|
61
|
+
end
|
67
62
|
|
68
|
-
|
63
|
+
context "an image copy" do
|
64
|
+
setup do
|
65
|
+
img = Ray::Image.new [2, 2]
|
66
|
+
img[0, 0] = Ray::Color.red
|
67
|
+
img[0, 1] = Ray::Color.green
|
68
|
+
img[1, 0] = Ray::Color.blue
|
69
|
+
img[1, 1] = Ray::Color.white
|
69
70
|
|
70
|
-
|
71
|
-
hookup { topic.clip([5, 5, 3, 3]) }
|
72
|
-
asserts(:clip).equals(Ray::Rect.new(5, 5, 3, 3))
|
71
|
+
img.dup
|
73
72
|
end
|
74
73
|
|
75
|
-
asserts(
|
76
|
-
|
77
|
-
|
78
|
-
|
79
|
-
|
74
|
+
asserts(:size).equals Ray::Vector2[2, 2]
|
75
|
+
|
76
|
+
asserts(:[], 0, 0).equals Ray::Color.red
|
77
|
+
asserts(:[], 0, 1).equals Ray::Color.green
|
78
|
+
asserts(:[], 1, 0).equals Ray::Color.blue
|
79
|
+
asserts(:[], 1, 1).equals Ray::Color.white
|
80
|
+
|
81
|
+
context "saved and loaded again" do
|
82
|
+
path = path_of("test_save.png")
|
83
|
+
|
84
|
+
setup do
|
85
|
+
topic.write path
|
86
|
+
Ray::Image.new path
|
87
|
+
end
|
88
|
+
|
89
|
+
asserts(:size).equals Ray::Vector2[2, 2]
|
90
|
+
|
91
|
+
asserts(:[], 0, 0).equals Ray::Color.red
|
92
|
+
asserts(:[], 0, 1).equals Ray::Color.green
|
93
|
+
asserts(:[], 1, 0).equals Ray::Color.blue
|
94
|
+
asserts(:[], 1, 1).equals Ray::Color.white
|
95
|
+
|
96
|
+
teardown do
|
97
|
+
File.delete path if File.exist? path
|
98
|
+
end
|
99
|
+
end
|
80
100
|
end
|
81
101
|
|
82
102
|
run_tests if __FILE__ == $0
|
@@ -0,0 +1,64 @@
|
|
1
|
+
require File.expand_path(File.dirname(__FILE__)) + '/helpers.rb'
|
2
|
+
|
3
|
+
context "an int array" do
|
4
|
+
setup { Ray::GL::IntArray.new }
|
5
|
+
|
6
|
+
asserts(:[], 0).nil
|
7
|
+
asserts(:size).equals 0
|
8
|
+
|
9
|
+
context "with new elements" do
|
10
|
+
hookup { topic << 3 << 0 << 1 }
|
11
|
+
|
12
|
+
asserts(:[], 0).equals 3
|
13
|
+
asserts(:[], 1).equals 0
|
14
|
+
asserts(:[], 2).equals 1
|
15
|
+
asserts(:[], 3).nil
|
16
|
+
|
17
|
+
asserts(:size).equals 3
|
18
|
+
asserts(:to_a).equals [3, 0, 1]
|
19
|
+
|
20
|
+
context "one of which was changed" do
|
21
|
+
hookup { topic[1] = 2 }
|
22
|
+
|
23
|
+
asserts(:[], 0).equals 3
|
24
|
+
asserts(:[], 1).equals 2
|
25
|
+
asserts(:[], 2).equals 1
|
26
|
+
asserts(:[], 3).nil
|
27
|
+
|
28
|
+
asserts(:size).equals 3
|
29
|
+
asserts(:to_a).equals [3, 2, 1]
|
30
|
+
end
|
31
|
+
|
32
|
+
context "but cleared" do
|
33
|
+
hookup { topic.clear }
|
34
|
+
|
35
|
+
asserts(:to_a).equals []
|
36
|
+
asserts(:size).equals 0
|
37
|
+
end
|
38
|
+
|
39
|
+
context "copied" do
|
40
|
+
setup { topic.dup }
|
41
|
+
|
42
|
+
asserts(:size).equals 3
|
43
|
+
asserts(:to_a).equals [3, 0, 1]
|
44
|
+
end
|
45
|
+
end
|
46
|
+
|
47
|
+
context "resized with []=" do
|
48
|
+
hookup { topic[1] = 5 }
|
49
|
+
|
50
|
+
asserts(:[], 0).equals 0
|
51
|
+
asserts(:[], 1).equals 5
|
52
|
+
asserts(:[], 2).nil
|
53
|
+
|
54
|
+
asserts(:size).equals 2
|
55
|
+
asserts(:to_a).equals [0, 5]
|
56
|
+
end
|
57
|
+
end
|
58
|
+
|
59
|
+
context "an int array created with values" do
|
60
|
+
setup { Ray::GL::IntArray.new 0, 5, 4 }
|
61
|
+
asserts(:to_a).equals [0, 5, 4]
|
62
|
+
end
|
63
|
+
|
64
|
+
run_tests if __FILE__ == $0
|
data/test/matrix_test.rb
ADDED
@@ -0,0 +1,134 @@
|
|
1
|
+
require File.expand_path(File.dirname(__FILE__)) + '/helpers.rb'
|
2
|
+
|
3
|
+
context "a matrix" do
|
4
|
+
setup { Ray::Matrix.new }
|
5
|
+
|
6
|
+
asserts(:content).equals {
|
7
|
+
[1, 0, 0, 0,
|
8
|
+
0, 1, 0, 0,
|
9
|
+
0, 0, 1, 0,
|
10
|
+
0, 0, 0, 1]
|
11
|
+
}
|
12
|
+
|
13
|
+
asserts_topic.equals Ray::Matrix.new
|
14
|
+
|
15
|
+
asserts(:[], 4, 0).raises_kind_of RangeError
|
16
|
+
asserts(:[], 0, 5).raises_kind_of RangeError
|
17
|
+
|
18
|
+
asserts(:[]=, 4, 0, 1).raises_kind_of RangeError
|
19
|
+
asserts(:[]=, 0, 5, 1).raises_kind_of RangeError
|
20
|
+
|
21
|
+
context "after changing a single element" do
|
22
|
+
hookup { topic[2, 2] = 10 }
|
23
|
+
|
24
|
+
asserts(:[], 2, 2).equals 10
|
25
|
+
denies(:[], 2, 3).equals 10
|
26
|
+
|
27
|
+
asserts(:content).equals {
|
28
|
+
[1, 0, 0, 0,
|
29
|
+
0, 1, 0, 0,
|
30
|
+
0, 0, 10, 0,
|
31
|
+
0, 0, 0, 1]
|
32
|
+
}
|
33
|
+
end
|
34
|
+
|
35
|
+
context "after changing its whole content" do
|
36
|
+
new_content = (1..16).to_a
|
37
|
+
|
38
|
+
hookup { topic.content = new_content }
|
39
|
+
|
40
|
+
asserts(:content).equals new_content
|
41
|
+
asserts_topic.equals Ray::Matrix.new(new_content)
|
42
|
+
|
43
|
+
asserts(:hash).equals Ray::Matrix.new(new_content).hash
|
44
|
+
asserts(:eql?, Ray::Matrix.new(new_content))
|
45
|
+
|
46
|
+
asserts(:dup).equals { topic }
|
47
|
+
|
48
|
+
context "after reset" do
|
49
|
+
hookup { topic.reset }
|
50
|
+
|
51
|
+
asserts(:content).equals {
|
52
|
+
[1, 0, 0, 0,
|
53
|
+
0, 1, 0, 0,
|
54
|
+
0, 0, 1, 0,
|
55
|
+
0, 0, 0, 1]
|
56
|
+
}
|
57
|
+
end
|
58
|
+
|
59
|
+
context "multiplied by another matrix" do
|
60
|
+
hookup do
|
61
|
+
other = [2, 0, 0, 0,
|
62
|
+
0, 2, 0, 0,
|
63
|
+
0, 0, 2, 0,
|
64
|
+
0, 0, 0, 2]
|
65
|
+
|
66
|
+
topic.multiply_by! Ray::Matrix.new(other)
|
67
|
+
end
|
68
|
+
|
69
|
+
asserts(:content).equals((1..16).map { |n| n * 2 })
|
70
|
+
end
|
71
|
+
end
|
72
|
+
|
73
|
+
asserts(:content=, (1..17).to_a).raises_kind_of ArgumentError
|
74
|
+
asserts(:content=, (1..15).to_a).raises_kind_of ArgumentError
|
75
|
+
end
|
76
|
+
|
77
|
+
context "a matrix created with Matrix.[]" do
|
78
|
+
setup { Ray::Matrix[*(1..16)] }
|
79
|
+
asserts(:content).equals((1..16).to_a)
|
80
|
+
end
|
81
|
+
|
82
|
+
context "a translation matrix" do
|
83
|
+
vector = Ray::Vector3[1, 2, 3]
|
84
|
+
|
85
|
+
setup { Ray::Matrix.translation(vector) }
|
86
|
+
asserts(:transform, -vector).equals Ray::Vector3[0, 0, 0]
|
87
|
+
end
|
88
|
+
|
89
|
+
context "a rotation matrix" do
|
90
|
+
setup { Ray::Matrix.rotation(90, [0, 0, 1]) }
|
91
|
+
|
92
|
+
asserts(:transform, [0, 0, 0]).almost_equals Ray::Vector3[0, 0, 0]
|
93
|
+
asserts(:transform, [10, 0, 0]).almost_equals(Ray::Vector3[0, 10, 0], 1e-6)
|
94
|
+
end
|
95
|
+
|
96
|
+
context "a scaling matrix" do
|
97
|
+
setup { Ray::Matrix.scale [10, 5, 1] }
|
98
|
+
|
99
|
+
asserts(:transform, [0, 0, 0]).equals Ray::Vector3[0, 0, 0]
|
100
|
+
asserts(:transform, [10, 10, 0]).equals Ray::Vector3[100, 50, 0]
|
101
|
+
end
|
102
|
+
|
103
|
+
context "an orthogonal projection" do
|
104
|
+
setup { Ray::Matrix.orthogonal(0, 100, 100, 0, 1, -1) }
|
105
|
+
|
106
|
+
asserts(:transform, [0, 0, 0]).equals Ray::Vector3[-1, 1, 0]
|
107
|
+
asserts(:transform, [100, 100, 0.5]).
|
108
|
+
almost_equals Ray::Vector3[1, -1, 0.5], 1e-6
|
109
|
+
end
|
110
|
+
|
111
|
+
context "a rotation then a translation" do
|
112
|
+
setup { Ray::Matrix.rotation(-90, [0, 0, 1]).translate([10, 10, 0]) }
|
113
|
+
asserts(:transform, [0, 0, 0]).equals Ray::Vector3[10, -10, 0]
|
114
|
+
end
|
115
|
+
|
116
|
+
context "a translation then a rotation" do
|
117
|
+
setup { Ray::Matrix.translation([10, 10, 0]).rotate(-90, [0, 0, 1]) }
|
118
|
+
asserts(:transform, [0, 0, 0]).equals Ray::Vector3[10, 10, 0]
|
119
|
+
end
|
120
|
+
|
121
|
+
context "any transformation" do
|
122
|
+
setup { Ray::Matrix.rotation(90, [0, 0, 1]).scale([2, 3, 4]) }
|
123
|
+
|
124
|
+
asserts "inverse matrix reverts transformations" do
|
125
|
+
point = topic.transform [10, 20, 30]
|
126
|
+
(topic.inverse.transform(point) - [10, 20, 30]).to_a.all? do |n|
|
127
|
+
n.abs < 1e-5
|
128
|
+
end
|
129
|
+
end
|
130
|
+
|
131
|
+
asserts(:untransform, [1, 2, 3]).equals { topic.inverse.transform [1, 2, 3] }
|
132
|
+
end
|
133
|
+
|
134
|
+
run_tests if __FILE__ == $0
|
@@ -0,0 +1,126 @@
|
|
1
|
+
require File.expand_path(File.dirname(__FILE__)) + '/helpers.rb'
|
2
|
+
|
3
|
+
context "a polygon" do
|
4
|
+
setup { Ray::Polygon.new }
|
5
|
+
|
6
|
+
asserts(:size).equals 0
|
7
|
+
asserts(:outline_width).equals 1
|
8
|
+
|
9
|
+
asserts :filled?
|
10
|
+
denies :outlined?
|
11
|
+
|
12
|
+
asserts(:pos_of, 0).nil
|
13
|
+
asserts(:color_of, 0).nil
|
14
|
+
asserts(:outline_of, 0).nil
|
15
|
+
|
16
|
+
asserts(:set_pos_of, 0, [0, 0]).raises_kind_of ArgumentError
|
17
|
+
asserts(:set_color_of, 0, Ray::Color.white).raises_kind_of ArgumentError
|
18
|
+
asserts(:set_outline_of, 0, Ray::Color.none).raises_kind_of ArgumentError
|
19
|
+
|
20
|
+
context "after adding a point" do
|
21
|
+
hookup { topic.add_point [1, 2], Ray::Color.green, Ray::Color.red }
|
22
|
+
asserts(:size).equals 1
|
23
|
+
|
24
|
+
asserts(:pos_of, 0).equals Ray::Vector2[1, 2]
|
25
|
+
asserts(:color_of, 0).equals Ray::Color.green
|
26
|
+
asserts(:outline_of, 0).equals Ray::Color.red
|
27
|
+
end
|
28
|
+
|
29
|
+
context "after resize" do
|
30
|
+
hookup { topic.resize 10 }
|
31
|
+
asserts(:size).equals 10
|
32
|
+
|
33
|
+
context "after changing a point" do
|
34
|
+
id = 3
|
35
|
+
|
36
|
+
hookup do
|
37
|
+
topic.set_pos_of(id, [3, 4])
|
38
|
+
topic.set_color_of(id, Ray::Color.yellow)
|
39
|
+
topic.set_outline_of(id, Ray::Color.cyan)
|
40
|
+
end
|
41
|
+
|
42
|
+
asserts(:pos_of, id).equals Ray::Vector2[3, 4]
|
43
|
+
asserts(:color_of, id).equals Ray::Color.yellow
|
44
|
+
asserts(:outline_of, id).equals Ray::Color.cyan
|
45
|
+
end
|
46
|
+
|
47
|
+
context "after changing all the colors" do
|
48
|
+
hookup do
|
49
|
+
topic.color = Ray::Color.cyan
|
50
|
+
topic.outline = Ray::Color.yellow
|
51
|
+
end
|
52
|
+
|
53
|
+
0.upto(9) do |n|
|
54
|
+
asserts(:color_of, n).equals Ray::Color.cyan
|
55
|
+
asserts(:outline_of, n).equals Ray::Color.yellow
|
56
|
+
end
|
57
|
+
end
|
58
|
+
end
|
59
|
+
|
60
|
+
context "after changing the outline width" do
|
61
|
+
hookup { topic.outline_width = 3 }
|
62
|
+
asserts(:outline_width).equals 3
|
63
|
+
end
|
64
|
+
|
65
|
+
context "after disabling filling" do
|
66
|
+
hookup { topic.filled = false }
|
67
|
+
denies :filled?
|
68
|
+
end
|
69
|
+
|
70
|
+
context "after enabling outline" do
|
71
|
+
hookup { topic.outlined = true }
|
72
|
+
asserts :outlined?
|
73
|
+
end
|
74
|
+
|
75
|
+
context "copied after several changes" do
|
76
|
+
setup do
|
77
|
+
topic.filled = false
|
78
|
+
topic.outlined = true
|
79
|
+
|
80
|
+
topic.resize 10
|
81
|
+
topic.set_color_of(3, Ray::Color.green)
|
82
|
+
|
83
|
+
topic.pos = [1, 3]
|
84
|
+
topic.angle = 45
|
85
|
+
|
86
|
+
topic.dup
|
87
|
+
end
|
88
|
+
|
89
|
+
denies :filled?
|
90
|
+
asserts :outlined?
|
91
|
+
|
92
|
+
asserts(:size).equals 10
|
93
|
+
|
94
|
+
asserts(:color_of, 3).equals Ray::Color.green
|
95
|
+
|
96
|
+
asserts(:pos).equals Ray::Vector2[1, 3]
|
97
|
+
asserts(:angle).equals 45
|
98
|
+
end
|
99
|
+
end
|
100
|
+
|
101
|
+
context "a polygon point" do
|
102
|
+
setup do
|
103
|
+
poly = Ray::Polygon.new 1 do |p|
|
104
|
+
p.pos = [10, 15]
|
105
|
+
p.color = Ray::Color.new(1, 2, 3)
|
106
|
+
p.outline = Ray::Color.new(4, 5, 6)
|
107
|
+
end
|
108
|
+
|
109
|
+
poly[0]
|
110
|
+
end
|
111
|
+
|
112
|
+
asserts(:pos).equals Ray::Vector2[10, 15]
|
113
|
+
asserts(:color).equals Ray::Color.new(1, 2, 3)
|
114
|
+
asserts(:outline).equals Ray::Color.new(4, 5, 6)
|
115
|
+
|
116
|
+
asserts(:id).equals 0
|
117
|
+
|
118
|
+
asserts("first position, color, and outline of the shape") {
|
119
|
+
poly = topic.polygon
|
120
|
+
[poly.pos_of(0), poly.color_of(0), poly.outline_of(0)]
|
121
|
+
}.equals([Ray::Vector2[10, 15],
|
122
|
+
Ray::Color.new(1, 2, 3),
|
123
|
+
Ray::Color.new(4, 5, 6)])
|
124
|
+
end
|
125
|
+
|
126
|
+
run_tests if __FILE__ == $0
|