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,155 @@
|
|
1
|
+
/***************************************************************************/
|
2
|
+
/* */
|
3
|
+
/* ftmoderr.h */
|
4
|
+
/* */
|
5
|
+
/* FreeType module error offsets (specification). */
|
6
|
+
/* */
|
7
|
+
/* Copyright 2001, 2002, 2003, 2004, 2005 by */
|
8
|
+
/* David Turner, Robert Wilhelm, and Werner Lemberg. */
|
9
|
+
/* */
|
10
|
+
/* This file is part of the FreeType project, and may only be used, */
|
11
|
+
/* modified, and distributed under the terms of the FreeType project */
|
12
|
+
/* license, LICENSE.TXT. By continuing to use, modify, or distribute */
|
13
|
+
/* this file you indicate that you have read the license and */
|
14
|
+
/* understand and accept it fully. */
|
15
|
+
/* */
|
16
|
+
/***************************************************************************/
|
17
|
+
|
18
|
+
|
19
|
+
/*************************************************************************/
|
20
|
+
/* */
|
21
|
+
/* This file is used to define the FreeType module error offsets. */
|
22
|
+
/* */
|
23
|
+
/* The lower byte gives the error code, the higher byte gives the */
|
24
|
+
/* module. The base module has error offset 0. For example, the error */
|
25
|
+
/* `FT_Err_Invalid_File_Format' has value 0x003, the error */
|
26
|
+
/* `TT_Err_Invalid_File_Format' has value 0x1103, the error */
|
27
|
+
/* `T1_Err_Invalid_File_Format' has value 0x1203, etc. */
|
28
|
+
/* */
|
29
|
+
/* Undefine the macro FT_CONFIG_OPTION_USE_MODULE_ERRORS in ftoption.h */
|
30
|
+
/* to make the higher byte always zero (disabling the module error */
|
31
|
+
/* mechanism). */
|
32
|
+
/* */
|
33
|
+
/* It can also be used to create a module error message table easily */
|
34
|
+
/* with something like */
|
35
|
+
/* */
|
36
|
+
/* { */
|
37
|
+
/* #undef __FTMODERR_H__ */
|
38
|
+
/* #define FT_MODERRDEF( e, v, s ) { FT_Mod_Err_ ## e, s }, */
|
39
|
+
/* #define FT_MODERR_START_LIST { */
|
40
|
+
/* #define FT_MODERR_END_LIST { 0, 0 } }; */
|
41
|
+
/* */
|
42
|
+
/* const struct */
|
43
|
+
/* { */
|
44
|
+
/* int mod_err_offset; */
|
45
|
+
/* const char* mod_err_msg */
|
46
|
+
/* } ft_mod_errors[] = */
|
47
|
+
/* */
|
48
|
+
/* #include FT_MODULE_ERRORS_H */
|
49
|
+
/* } */
|
50
|
+
/* */
|
51
|
+
/* To use such a table, all errors must be ANDed with 0xFF00 to remove */
|
52
|
+
/* the error code. */
|
53
|
+
/* */
|
54
|
+
/*************************************************************************/
|
55
|
+
|
56
|
+
|
57
|
+
#ifndef __FTMODERR_H__
|
58
|
+
#define __FTMODERR_H__
|
59
|
+
|
60
|
+
|
61
|
+
/*******************************************************************/
|
62
|
+
/*******************************************************************/
|
63
|
+
/***** *****/
|
64
|
+
/***** SETUP MACROS *****/
|
65
|
+
/***** *****/
|
66
|
+
/*******************************************************************/
|
67
|
+
/*******************************************************************/
|
68
|
+
|
69
|
+
|
70
|
+
#undef FT_NEED_EXTERN_C
|
71
|
+
|
72
|
+
#ifndef FT_MODERRDEF
|
73
|
+
|
74
|
+
#ifdef FT_CONFIG_OPTION_USE_MODULE_ERRORS
|
75
|
+
#define FT_MODERRDEF( e, v, s ) FT_Mod_Err_ ## e = v,
|
76
|
+
#else
|
77
|
+
#define FT_MODERRDEF( e, v, s ) FT_Mod_Err_ ## e = 0,
|
78
|
+
#endif
|
79
|
+
|
80
|
+
#define FT_MODERR_START_LIST enum {
|
81
|
+
#define FT_MODERR_END_LIST FT_Mod_Err_Max };
|
82
|
+
|
83
|
+
#ifdef __cplusplus
|
84
|
+
#define FT_NEED_EXTERN_C
|
85
|
+
extern "C" {
|
86
|
+
#endif
|
87
|
+
|
88
|
+
#endif /* !FT_MODERRDEF */
|
89
|
+
|
90
|
+
|
91
|
+
/*******************************************************************/
|
92
|
+
/*******************************************************************/
|
93
|
+
/***** *****/
|
94
|
+
/***** LIST MODULE ERROR BASES *****/
|
95
|
+
/***** *****/
|
96
|
+
/*******************************************************************/
|
97
|
+
/*******************************************************************/
|
98
|
+
|
99
|
+
|
100
|
+
#ifdef FT_MODERR_START_LIST
|
101
|
+
FT_MODERR_START_LIST
|
102
|
+
#endif
|
103
|
+
|
104
|
+
|
105
|
+
FT_MODERRDEF( Base, 0x000, "base module" )
|
106
|
+
FT_MODERRDEF( Autofit, 0x100, "autofitter module" )
|
107
|
+
FT_MODERRDEF( BDF, 0x200, "BDF module" )
|
108
|
+
FT_MODERRDEF( Cache, 0x300, "cache module" )
|
109
|
+
FT_MODERRDEF( CFF, 0x400, "CFF module" )
|
110
|
+
FT_MODERRDEF( CID, 0x500, "CID module" )
|
111
|
+
FT_MODERRDEF( Gzip, 0x600, "Gzip module" )
|
112
|
+
FT_MODERRDEF( LZW, 0x700, "LZW module" )
|
113
|
+
FT_MODERRDEF( OTvalid, 0x800, "OpenType validation module" )
|
114
|
+
FT_MODERRDEF( PCF, 0x900, "PCF module" )
|
115
|
+
FT_MODERRDEF( PFR, 0xA00, "PFR module" )
|
116
|
+
FT_MODERRDEF( PSaux, 0xB00, "PS auxiliary module" )
|
117
|
+
FT_MODERRDEF( PShinter, 0xC00, "PS hinter module" )
|
118
|
+
FT_MODERRDEF( PSnames, 0xD00, "PS names module" )
|
119
|
+
FT_MODERRDEF( Raster, 0xE00, "raster module" )
|
120
|
+
FT_MODERRDEF( SFNT, 0xF00, "SFNT module" )
|
121
|
+
FT_MODERRDEF( Smooth, 0x1000, "smooth raster module" )
|
122
|
+
FT_MODERRDEF( TrueType, 0x1100, "TrueType module" )
|
123
|
+
FT_MODERRDEF( Type1, 0x1200, "Type 1 module" )
|
124
|
+
FT_MODERRDEF( Type42, 0x1300, "Type 42 module" )
|
125
|
+
FT_MODERRDEF( Winfonts, 0x1400, "Windows FON/FNT module" )
|
126
|
+
|
127
|
+
|
128
|
+
#ifdef FT_MODERR_END_LIST
|
129
|
+
FT_MODERR_END_LIST
|
130
|
+
#endif
|
131
|
+
|
132
|
+
|
133
|
+
/*******************************************************************/
|
134
|
+
/*******************************************************************/
|
135
|
+
/***** *****/
|
136
|
+
/***** CLEANUP *****/
|
137
|
+
/***** *****/
|
138
|
+
/*******************************************************************/
|
139
|
+
/*******************************************************************/
|
140
|
+
|
141
|
+
|
142
|
+
#ifdef FT_NEED_EXTERN_C
|
143
|
+
}
|
144
|
+
#endif
|
145
|
+
|
146
|
+
#undef FT_MODERR_START_LIST
|
147
|
+
#undef FT_MODERR_END_LIST
|
148
|
+
#undef FT_MODERRDEF
|
149
|
+
#undef FT_NEED_EXTERN_C
|
150
|
+
|
151
|
+
|
152
|
+
#endif /* __FTMODERR_H__ */
|
153
|
+
|
154
|
+
|
155
|
+
/* END */
|
@@ -0,0 +1,198 @@
|
|
1
|
+
/***************************************************************************/
|
2
|
+
/* */
|
3
|
+
/* ftotval.h */
|
4
|
+
/* */
|
5
|
+
/* FreeType API for validating OpenType tables (specification). */
|
6
|
+
/* */
|
7
|
+
/* Copyright 2004, 2005, 2006 by */
|
8
|
+
/* David Turner, Robert Wilhelm, and Werner Lemberg. */
|
9
|
+
/* */
|
10
|
+
/* This file is part of the FreeType project, and may only be used, */
|
11
|
+
/* modified, and distributed under the terms of the FreeType project */
|
12
|
+
/* license, LICENSE.TXT. By continuing to use, modify, or distribute */
|
13
|
+
/* this file you indicate that you have read the license and */
|
14
|
+
/* understand and accept it fully. */
|
15
|
+
/* */
|
16
|
+
/***************************************************************************/
|
17
|
+
|
18
|
+
|
19
|
+
/***************************************************************************/
|
20
|
+
/* */
|
21
|
+
/* */
|
22
|
+
/* Warning: This module might be moved to a different library in the */
|
23
|
+
/* future to avoid a tight dependency between FreeType and the */
|
24
|
+
/* OpenType specification. */
|
25
|
+
/* */
|
26
|
+
/* */
|
27
|
+
/***************************************************************************/
|
28
|
+
|
29
|
+
|
30
|
+
#ifndef __FTOTVAL_H__
|
31
|
+
#define __FTOTVAL_H__
|
32
|
+
|
33
|
+
#include <ft2build.h>
|
34
|
+
#include FT_FREETYPE_H
|
35
|
+
|
36
|
+
#ifdef FREETYPE_H
|
37
|
+
#error "freetype.h of FreeType 1 has been loaded!"
|
38
|
+
#error "Please fix the directory search order for header files"
|
39
|
+
#error "so that freetype.h of FreeType 2 is found first."
|
40
|
+
#endif
|
41
|
+
|
42
|
+
|
43
|
+
FT_BEGIN_HEADER
|
44
|
+
|
45
|
+
|
46
|
+
/*************************************************************************/
|
47
|
+
/* */
|
48
|
+
/* <Section> */
|
49
|
+
/* ot_validation */
|
50
|
+
/* */
|
51
|
+
/* <Title> */
|
52
|
+
/* OpenType Validation */
|
53
|
+
/* */
|
54
|
+
/* <Abstract> */
|
55
|
+
/* An API to validate OpenType tables. */
|
56
|
+
/* */
|
57
|
+
/* <Description> */
|
58
|
+
/* This section contains the declaration of functions to validate */
|
59
|
+
/* some OpenType tables (BASE, GDEF, GPOS, GSUB, JSTF). */
|
60
|
+
/* */
|
61
|
+
/*************************************************************************/
|
62
|
+
|
63
|
+
|
64
|
+
/**********************************************************************
|
65
|
+
*
|
66
|
+
* @enum:
|
67
|
+
* FT_VALIDATE_OTXXX
|
68
|
+
*
|
69
|
+
* @description:
|
70
|
+
* A list of bit-field constants used with @FT_OpenType_Validate to
|
71
|
+
* indicate which OpenType tables should be validated.
|
72
|
+
*
|
73
|
+
* @values:
|
74
|
+
* FT_VALIDATE_BASE ::
|
75
|
+
* Validate BASE table.
|
76
|
+
*
|
77
|
+
* FT_VALIDATE_GDEF ::
|
78
|
+
* Validate GDEF table.
|
79
|
+
*
|
80
|
+
* FT_VALIDATE_GPOS ::
|
81
|
+
* Validate GPOS table.
|
82
|
+
*
|
83
|
+
* FT_VALIDATE_GSUB ::
|
84
|
+
* Validate GSUB table.
|
85
|
+
*
|
86
|
+
* FT_VALIDATE_JSTF ::
|
87
|
+
* Validate JSTF table.
|
88
|
+
*
|
89
|
+
* FT_VALIDATE_OT ::
|
90
|
+
* Validate all OpenType tables (BASE, GDEF, GPOS, GSUB, JSTF).
|
91
|
+
*
|
92
|
+
*/
|
93
|
+
#define FT_VALIDATE_BASE 0x0100
|
94
|
+
#define FT_VALIDATE_GDEF 0x0200
|
95
|
+
#define FT_VALIDATE_GPOS 0x0400
|
96
|
+
#define FT_VALIDATE_GSUB 0x0800
|
97
|
+
#define FT_VALIDATE_JSTF 0x1000
|
98
|
+
|
99
|
+
#define FT_VALIDATE_OT FT_VALIDATE_BASE | \
|
100
|
+
FT_VALIDATE_GDEF | \
|
101
|
+
FT_VALIDATE_GPOS | \
|
102
|
+
FT_VALIDATE_GSUB | \
|
103
|
+
FT_VALIDATE_JSTF
|
104
|
+
|
105
|
+
/* */
|
106
|
+
|
107
|
+
/**********************************************************************
|
108
|
+
*
|
109
|
+
* @function:
|
110
|
+
* FT_OpenType_Validate
|
111
|
+
*
|
112
|
+
* @description:
|
113
|
+
* Validate various OpenType tables to assure that all offsets and
|
114
|
+
* indices are valid. The idea is that a higher-level library which
|
115
|
+
* actually does the text layout can access those tables without
|
116
|
+
* error checking (which can be quite time consuming).
|
117
|
+
*
|
118
|
+
* @input:
|
119
|
+
* face ::
|
120
|
+
* A handle to the input face.
|
121
|
+
*
|
122
|
+
* validation_flags ::
|
123
|
+
* A bit field which specifies the tables to be validated. See
|
124
|
+
* @FT_VALIDATE_OTXXX for possible values.
|
125
|
+
*
|
126
|
+
* @output:
|
127
|
+
* BASE_table ::
|
128
|
+
* A pointer to the BASE table.
|
129
|
+
*
|
130
|
+
* GDEF_table ::
|
131
|
+
* A pointer to the GDEF table.
|
132
|
+
*
|
133
|
+
* GPOS_table ::
|
134
|
+
* A pointer to the GPOS table.
|
135
|
+
*
|
136
|
+
* GSUB_table ::
|
137
|
+
* A pointer to the GSUB table.
|
138
|
+
*
|
139
|
+
* JSTF_table ::
|
140
|
+
* A pointer to the JSTF table.
|
141
|
+
*
|
142
|
+
* @return:
|
143
|
+
* FreeType error code. 0 means success.
|
144
|
+
*
|
145
|
+
* @note:
|
146
|
+
* This function only works with OpenType fonts, returning an error
|
147
|
+
* otherwise.
|
148
|
+
*
|
149
|
+
* After use, the application should deallocate the five tables with
|
150
|
+
* @FT_OpenType_Free. A NULL value indicates that the table either
|
151
|
+
* doesn't exist in the font, or the application hasn't asked for
|
152
|
+
* validation.
|
153
|
+
*/
|
154
|
+
FT_EXPORT( FT_Error )
|
155
|
+
FT_OpenType_Validate( FT_Face face,
|
156
|
+
FT_UInt validation_flags,
|
157
|
+
FT_Bytes *BASE_table,
|
158
|
+
FT_Bytes *GDEF_table,
|
159
|
+
FT_Bytes *GPOS_table,
|
160
|
+
FT_Bytes *GSUB_table,
|
161
|
+
FT_Bytes *JSTF_table );
|
162
|
+
|
163
|
+
/* */
|
164
|
+
|
165
|
+
/**********************************************************************
|
166
|
+
*
|
167
|
+
* @function:
|
168
|
+
* FT_OpenType_Free
|
169
|
+
*
|
170
|
+
* @description:
|
171
|
+
* Free the buffer allocated by OpenType validator.
|
172
|
+
*
|
173
|
+
* @input:
|
174
|
+
* face ::
|
175
|
+
* A handle to the input face.
|
176
|
+
*
|
177
|
+
* table ::
|
178
|
+
* The pointer to the buffer that is allocated by
|
179
|
+
* @FT_OpenType_Validate.
|
180
|
+
*
|
181
|
+
* @note:
|
182
|
+
* This function must be used to free the buffer allocated by
|
183
|
+
* @FT_OpenType_Validate only.
|
184
|
+
*/
|
185
|
+
FT_EXPORT( void )
|
186
|
+
FT_OpenType_Free( FT_Face face,
|
187
|
+
FT_Bytes table );
|
188
|
+
|
189
|
+
|
190
|
+
/* */
|
191
|
+
|
192
|
+
|
193
|
+
FT_END_HEADER
|
194
|
+
|
195
|
+
#endif /* __FTOTVAL_H__ */
|
196
|
+
|
197
|
+
|
198
|
+
/* END */
|
@@ -0,0 +1,526 @@
|
|
1
|
+
/***************************************************************************/
|
2
|
+
/* */
|
3
|
+
/* ftoutln.h */
|
4
|
+
/* */
|
5
|
+
/* Support for the FT_Outline type used to store glyph shapes of */
|
6
|
+
/* most scalable font formats (specification). */
|
7
|
+
/* */
|
8
|
+
/* Copyright 1996-2001, 2002, 2003, 2005, 2006, 2007 by */
|
9
|
+
/* David Turner, Robert Wilhelm, and Werner Lemberg. */
|
10
|
+
/* */
|
11
|
+
/* This file is part of the FreeType project, and may only be used, */
|
12
|
+
/* modified, and distributed under the terms of the FreeType project */
|
13
|
+
/* license, LICENSE.TXT. By continuing to use, modify, or distribute */
|
14
|
+
/* this file you indicate that you have read the license and */
|
15
|
+
/* understand and accept it fully. */
|
16
|
+
/* */
|
17
|
+
/***************************************************************************/
|
18
|
+
|
19
|
+
|
20
|
+
#ifndef __FTOUTLN_H__
|
21
|
+
#define __FTOUTLN_H__
|
22
|
+
|
23
|
+
|
24
|
+
#include <ft2build.h>
|
25
|
+
#include FT_FREETYPE_H
|
26
|
+
|
27
|
+
#ifdef FREETYPE_H
|
28
|
+
#error "freetype.h of FreeType 1 has been loaded!"
|
29
|
+
#error "Please fix the directory search order for header files"
|
30
|
+
#error "so that freetype.h of FreeType 2 is found first."
|
31
|
+
#endif
|
32
|
+
|
33
|
+
|
34
|
+
FT_BEGIN_HEADER
|
35
|
+
|
36
|
+
|
37
|
+
/*************************************************************************/
|
38
|
+
/* */
|
39
|
+
/* <Section> */
|
40
|
+
/* outline_processing */
|
41
|
+
/* */
|
42
|
+
/* <Title> */
|
43
|
+
/* Outline Processing */
|
44
|
+
/* */
|
45
|
+
/* <Abstract> */
|
46
|
+
/* Functions to create, transform, and render vectorial glyph images. */
|
47
|
+
/* */
|
48
|
+
/* <Description> */
|
49
|
+
/* This section contains routines used to create and destroy scalable */
|
50
|
+
/* glyph images known as `outlines'. These can also be measured, */
|
51
|
+
/* transformed, and converted into bitmaps and pixmaps. */
|
52
|
+
/* */
|
53
|
+
/* <Order> */
|
54
|
+
/* FT_Outline */
|
55
|
+
/* FT_OUTLINE_FLAGS */
|
56
|
+
/* FT_Outline_New */
|
57
|
+
/* FT_Outline_Done */
|
58
|
+
/* FT_Outline_Copy */
|
59
|
+
/* FT_Outline_Translate */
|
60
|
+
/* FT_Outline_Transform */
|
61
|
+
/* FT_Outline_Embolden */
|
62
|
+
/* FT_Outline_Reverse */
|
63
|
+
/* FT_Outline_Check */
|
64
|
+
/* */
|
65
|
+
/* FT_Outline_Get_CBox */
|
66
|
+
/* FT_Outline_Get_BBox */
|
67
|
+
/* */
|
68
|
+
/* FT_Outline_Get_Bitmap */
|
69
|
+
/* FT_Outline_Render */
|
70
|
+
/* */
|
71
|
+
/* FT_Outline_Decompose */
|
72
|
+
/* FT_Outline_Funcs */
|
73
|
+
/* FT_Outline_MoveTo_Func */
|
74
|
+
/* FT_Outline_LineTo_Func */
|
75
|
+
/* FT_Outline_ConicTo_Func */
|
76
|
+
/* FT_Outline_CubicTo_Func */
|
77
|
+
/* */
|
78
|
+
/*************************************************************************/
|
79
|
+
|
80
|
+
|
81
|
+
/*************************************************************************/
|
82
|
+
/* */
|
83
|
+
/* <Function> */
|
84
|
+
/* FT_Outline_Decompose */
|
85
|
+
/* */
|
86
|
+
/* <Description> */
|
87
|
+
/* Walks over an outline's structure to decompose it into individual */
|
88
|
+
/* segments and Bézier arcs. This function is also able to emit */
|
89
|
+
/* `move to' and `close to' operations to indicate the start and end */
|
90
|
+
/* of new contours in the outline. */
|
91
|
+
/* */
|
92
|
+
/* <Input> */
|
93
|
+
/* outline :: A pointer to the source target. */
|
94
|
+
/* */
|
95
|
+
/* func_interface :: A table of `emitters', i.e,. function pointers */
|
96
|
+
/* called during decomposition to indicate path */
|
97
|
+
/* operations. */
|
98
|
+
/* */
|
99
|
+
/* <InOut> */
|
100
|
+
/* user :: A typeless pointer which is passed to each */
|
101
|
+
/* emitter during the decomposition. It can be */
|
102
|
+
/* used to store the state during the */
|
103
|
+
/* decomposition. */
|
104
|
+
/* */
|
105
|
+
/* <Return> */
|
106
|
+
/* FreeType error code. 0 means success. */
|
107
|
+
/* */
|
108
|
+
FT_EXPORT( FT_Error )
|
109
|
+
FT_Outline_Decompose( FT_Outline* outline,
|
110
|
+
const FT_Outline_Funcs* func_interface,
|
111
|
+
void* user );
|
112
|
+
|
113
|
+
|
114
|
+
/*************************************************************************/
|
115
|
+
/* */
|
116
|
+
/* <Function> */
|
117
|
+
/* FT_Outline_New */
|
118
|
+
/* */
|
119
|
+
/* <Description> */
|
120
|
+
/* Creates a new outline of a given size. */
|
121
|
+
/* */
|
122
|
+
/* <Input> */
|
123
|
+
/* library :: A handle to the library object from where the */
|
124
|
+
/* outline is allocated. Note however that the new */
|
125
|
+
/* outline will *not* necessarily be *freed*, when */
|
126
|
+
/* destroying the library, by @FT_Done_FreeType. */
|
127
|
+
/* */
|
128
|
+
/* numPoints :: The maximal number of points within the outline. */
|
129
|
+
/* */
|
130
|
+
/* numContours :: The maximal number of contours within the outline. */
|
131
|
+
/* */
|
132
|
+
/* <Output> */
|
133
|
+
/* anoutline :: A handle to the new outline. NULL in case of */
|
134
|
+
/* error. */
|
135
|
+
/* */
|
136
|
+
/* <Return> */
|
137
|
+
/* FreeType error code. 0 means success. */
|
138
|
+
/* */
|
139
|
+
/* <Note> */
|
140
|
+
/* The reason why this function takes a `library' parameter is simply */
|
141
|
+
/* to use the library's memory allocator. */
|
142
|
+
/* */
|
143
|
+
FT_EXPORT( FT_Error )
|
144
|
+
FT_Outline_New( FT_Library library,
|
145
|
+
FT_UInt numPoints,
|
146
|
+
FT_Int numContours,
|
147
|
+
FT_Outline *anoutline );
|
148
|
+
|
149
|
+
|
150
|
+
FT_EXPORT( FT_Error )
|
151
|
+
FT_Outline_New_Internal( FT_Memory memory,
|
152
|
+
FT_UInt numPoints,
|
153
|
+
FT_Int numContours,
|
154
|
+
FT_Outline *anoutline );
|
155
|
+
|
156
|
+
|
157
|
+
/*************************************************************************/
|
158
|
+
/* */
|
159
|
+
/* <Function> */
|
160
|
+
/* FT_Outline_Done */
|
161
|
+
/* */
|
162
|
+
/* <Description> */
|
163
|
+
/* Destroys an outline created with @FT_Outline_New. */
|
164
|
+
/* */
|
165
|
+
/* <Input> */
|
166
|
+
/* library :: A handle of the library object used to allocate the */
|
167
|
+
/* outline. */
|
168
|
+
/* */
|
169
|
+
/* outline :: A pointer to the outline object to be discarded. */
|
170
|
+
/* */
|
171
|
+
/* <Return> */
|
172
|
+
/* FreeType error code. 0 means success. */
|
173
|
+
/* */
|
174
|
+
/* <Note> */
|
175
|
+
/* If the outline's `owner' field is not set, only the outline */
|
176
|
+
/* descriptor will be released. */
|
177
|
+
/* */
|
178
|
+
/* The reason why this function takes an `library' parameter is */
|
179
|
+
/* simply to use ft_mem_free(). */
|
180
|
+
/* */
|
181
|
+
FT_EXPORT( FT_Error )
|
182
|
+
FT_Outline_Done( FT_Library library,
|
183
|
+
FT_Outline* outline );
|
184
|
+
|
185
|
+
|
186
|
+
FT_EXPORT( FT_Error )
|
187
|
+
FT_Outline_Done_Internal( FT_Memory memory,
|
188
|
+
FT_Outline* outline );
|
189
|
+
|
190
|
+
|
191
|
+
/*************************************************************************/
|
192
|
+
/* */
|
193
|
+
/* <Function> */
|
194
|
+
/* FT_Outline_Check */
|
195
|
+
/* */
|
196
|
+
/* <Description> */
|
197
|
+
/* Check the contents of an outline descriptor. */
|
198
|
+
/* */
|
199
|
+
/* <Input> */
|
200
|
+
/* outline :: A handle to a source outline. */
|
201
|
+
/* */
|
202
|
+
/* <Return> */
|
203
|
+
/* FreeType error code. 0 means success. */
|
204
|
+
/* */
|
205
|
+
FT_EXPORT( FT_Error )
|
206
|
+
FT_Outline_Check( FT_Outline* outline );
|
207
|
+
|
208
|
+
|
209
|
+
/*************************************************************************/
|
210
|
+
/* */
|
211
|
+
/* <Function> */
|
212
|
+
/* FT_Outline_Get_CBox */
|
213
|
+
/* */
|
214
|
+
/* <Description> */
|
215
|
+
/* Returns an outline's `control box'. The control box encloses all */
|
216
|
+
/* the outline's points, including Bézier control points. Though it */
|
217
|
+
/* coincides with the exact bounding box for most glyphs, it can be */
|
218
|
+
/* slightly larger in some situations (like when rotating an outline */
|
219
|
+
/* which contains Bézier outside arcs). */
|
220
|
+
/* */
|
221
|
+
/* Computing the control box is very fast, while getting the bounding */
|
222
|
+
/* box can take much more time as it needs to walk over all segments */
|
223
|
+
/* and arcs in the outline. To get the latter, you can use the */
|
224
|
+
/* `ftbbox' component which is dedicated to this single task. */
|
225
|
+
/* */
|
226
|
+
/* <Input> */
|
227
|
+
/* outline :: A pointer to the source outline descriptor. */
|
228
|
+
/* */
|
229
|
+
/* <Output> */
|
230
|
+
/* acbox :: The outline's control box. */
|
231
|
+
/* */
|
232
|
+
FT_EXPORT( void )
|
233
|
+
FT_Outline_Get_CBox( const FT_Outline* outline,
|
234
|
+
FT_BBox *acbox );
|
235
|
+
|
236
|
+
|
237
|
+
/*************************************************************************/
|
238
|
+
/* */
|
239
|
+
/* <Function> */
|
240
|
+
/* FT_Outline_Translate */
|
241
|
+
/* */
|
242
|
+
/* <Description> */
|
243
|
+
/* Applies a simple translation to the points of an outline. */
|
244
|
+
/* */
|
245
|
+
/* <InOut> */
|
246
|
+
/* outline :: A pointer to the target outline descriptor. */
|
247
|
+
/* */
|
248
|
+
/* <Input> */
|
249
|
+
/* xOffset :: The horizontal offset. */
|
250
|
+
/* */
|
251
|
+
/* yOffset :: The vertical offset. */
|
252
|
+
/* */
|
253
|
+
FT_EXPORT( void )
|
254
|
+
FT_Outline_Translate( const FT_Outline* outline,
|
255
|
+
FT_Pos xOffset,
|
256
|
+
FT_Pos yOffset );
|
257
|
+
|
258
|
+
|
259
|
+
/*************************************************************************/
|
260
|
+
/* */
|
261
|
+
/* <Function> */
|
262
|
+
/* FT_Outline_Copy */
|
263
|
+
/* */
|
264
|
+
/* <Description> */
|
265
|
+
/* Copies an outline into another one. Both objects must have the */
|
266
|
+
/* same sizes (number of points & number of contours) when this */
|
267
|
+
/* function is called. */
|
268
|
+
/* */
|
269
|
+
/* <Input> */
|
270
|
+
/* source :: A handle to the source outline. */
|
271
|
+
/* */
|
272
|
+
/* <Output> */
|
273
|
+
/* target :: A handle to the target outline. */
|
274
|
+
/* */
|
275
|
+
/* <Return> */
|
276
|
+
/* FreeType error code. 0 means success. */
|
277
|
+
/* */
|
278
|
+
FT_EXPORT( FT_Error )
|
279
|
+
FT_Outline_Copy( const FT_Outline* source,
|
280
|
+
FT_Outline *target );
|
281
|
+
|
282
|
+
|
283
|
+
/*************************************************************************/
|
284
|
+
/* */
|
285
|
+
/* <Function> */
|
286
|
+
/* FT_Outline_Transform */
|
287
|
+
/* */
|
288
|
+
/* <Description> */
|
289
|
+
/* Applies a simple 2x2 matrix to all of an outline's points. Useful */
|
290
|
+
/* for applying rotations, slanting, flipping, etc. */
|
291
|
+
/* */
|
292
|
+
/* <InOut> */
|
293
|
+
/* outline :: A pointer to the target outline descriptor. */
|
294
|
+
/* */
|
295
|
+
/* <Input> */
|
296
|
+
/* matrix :: A pointer to the transformation matrix. */
|
297
|
+
/* */
|
298
|
+
/* <Note> */
|
299
|
+
/* You can use @FT_Outline_Translate if you need to translate the */
|
300
|
+
/* outline's points. */
|
301
|
+
/* */
|
302
|
+
FT_EXPORT( void )
|
303
|
+
FT_Outline_Transform( const FT_Outline* outline,
|
304
|
+
const FT_Matrix* matrix );
|
305
|
+
|
306
|
+
|
307
|
+
/*************************************************************************/
|
308
|
+
/* */
|
309
|
+
/* <Function> */
|
310
|
+
/* FT_Outline_Embolden */
|
311
|
+
/* */
|
312
|
+
/* <Description> */
|
313
|
+
/* Emboldens an outline. The new outline will be at most 4 times */
|
314
|
+
/* `strength' pixels wider and higher. You may think of the left and */
|
315
|
+
/* bottom borders as unchanged. */
|
316
|
+
/* */
|
317
|
+
/* Negative `strength' values to reduce the outline thickness are */
|
318
|
+
/* possible also. */
|
319
|
+
/* */
|
320
|
+
/* <InOut> */
|
321
|
+
/* outline :: A handle to the target outline. */
|
322
|
+
/* */
|
323
|
+
/* <Input> */
|
324
|
+
/* strength :: How strong the glyph is emboldened. Expressed in */
|
325
|
+
/* 26.6 pixel format. */
|
326
|
+
/* */
|
327
|
+
/* <Return> */
|
328
|
+
/* FreeType error code. 0 means success. */
|
329
|
+
/* */
|
330
|
+
/* <Note> */
|
331
|
+
/* The used algorithm to increase or decrease the thickness of the */
|
332
|
+
/* glyph doesn't change the number of points; this means that certain */
|
333
|
+
/* situations like acute angles or intersections are sometimes */
|
334
|
+
/* handled incorrectly. */
|
335
|
+
/* */
|
336
|
+
/* Example call: */
|
337
|
+
/* */
|
338
|
+
/* { */
|
339
|
+
/* FT_Load_Glyph( face, index, FT_LOAD_DEFAULT ); */
|
340
|
+
/* if ( face->slot->format == FT_GLYPH_FORMAT_OUTLINE ) */
|
341
|
+
/* FT_Outline_Embolden( &face->slot->outline, strength ); */
|
342
|
+
/* } */
|
343
|
+
/* */
|
344
|
+
FT_EXPORT( FT_Error )
|
345
|
+
FT_Outline_Embolden( FT_Outline* outline,
|
346
|
+
FT_Pos strength );
|
347
|
+
|
348
|
+
|
349
|
+
/*************************************************************************/
|
350
|
+
/* */
|
351
|
+
/* <Function> */
|
352
|
+
/* FT_Outline_Reverse */
|
353
|
+
/* */
|
354
|
+
/* <Description> */
|
355
|
+
/* Reverses the drawing direction of an outline. This is used to */
|
356
|
+
/* ensure consistent fill conventions for mirrored glyphs. */
|
357
|
+
/* */
|
358
|
+
/* <InOut> */
|
359
|
+
/* outline :: A pointer to the target outline descriptor. */
|
360
|
+
/* */
|
361
|
+
/* <Note> */
|
362
|
+
/* This functions toggles the bit flag @FT_OUTLINE_REVERSE_FILL in */
|
363
|
+
/* the outline's `flags' field. */
|
364
|
+
/* */
|
365
|
+
/* It shouldn't be used by a normal client application, unless it */
|
366
|
+
/* knows what it is doing. */
|
367
|
+
/* */
|
368
|
+
FT_EXPORT( void )
|
369
|
+
FT_Outline_Reverse( FT_Outline* outline );
|
370
|
+
|
371
|
+
|
372
|
+
/*************************************************************************/
|
373
|
+
/* */
|
374
|
+
/* <Function> */
|
375
|
+
/* FT_Outline_Get_Bitmap */
|
376
|
+
/* */
|
377
|
+
/* <Description> */
|
378
|
+
/* Renders an outline within a bitmap. The outline's image is simply */
|
379
|
+
/* OR-ed to the target bitmap. */
|
380
|
+
/* */
|
381
|
+
/* <Input> */
|
382
|
+
/* library :: A handle to a FreeType library object. */
|
383
|
+
/* */
|
384
|
+
/* outline :: A pointer to the source outline descriptor. */
|
385
|
+
/* */
|
386
|
+
/* <InOut> */
|
387
|
+
/* abitmap :: A pointer to the target bitmap descriptor. */
|
388
|
+
/* */
|
389
|
+
/* <Return> */
|
390
|
+
/* FreeType error code. 0 means success. */
|
391
|
+
/* */
|
392
|
+
/* <Note> */
|
393
|
+
/* This function does NOT CREATE the bitmap, it only renders an */
|
394
|
+
/* outline image within the one you pass to it! */
|
395
|
+
/* */
|
396
|
+
/* It will use the raster corresponding to the default glyph format. */
|
397
|
+
/* */
|
398
|
+
FT_EXPORT( FT_Error )
|
399
|
+
FT_Outline_Get_Bitmap( FT_Library library,
|
400
|
+
FT_Outline* outline,
|
401
|
+
const FT_Bitmap *abitmap );
|
402
|
+
|
403
|
+
|
404
|
+
/*************************************************************************/
|
405
|
+
/* */
|
406
|
+
/* <Function> */
|
407
|
+
/* FT_Outline_Render */
|
408
|
+
/* */
|
409
|
+
/* <Description> */
|
410
|
+
/* Renders an outline within a bitmap using the current scan-convert. */
|
411
|
+
/* This functions uses an @FT_Raster_Params structure as an argument, */
|
412
|
+
/* allowing advanced features like direct composition, translucency, */
|
413
|
+
/* etc. */
|
414
|
+
/* */
|
415
|
+
/* <Input> */
|
416
|
+
/* library :: A handle to a FreeType library object. */
|
417
|
+
/* */
|
418
|
+
/* outline :: A pointer to the source outline descriptor. */
|
419
|
+
/* */
|
420
|
+
/* <InOut> */
|
421
|
+
/* params :: A pointer to an @FT_Raster_Params structure used to */
|
422
|
+
/* describe the rendering operation. */
|
423
|
+
/* */
|
424
|
+
/* <Return> */
|
425
|
+
/* FreeType error code. 0 means success. */
|
426
|
+
/* */
|
427
|
+
/* <Note> */
|
428
|
+
/* You should know what you are doing and how @FT_Raster_Params works */
|
429
|
+
/* to use this function. */
|
430
|
+
/* */
|
431
|
+
/* The field `params.source' will be set to `outline' before the scan */
|
432
|
+
/* converter is called, which means that the value you give to it is */
|
433
|
+
/* actually ignored. */
|
434
|
+
/* */
|
435
|
+
FT_EXPORT( FT_Error )
|
436
|
+
FT_Outline_Render( FT_Library library,
|
437
|
+
FT_Outline* outline,
|
438
|
+
FT_Raster_Params* params );
|
439
|
+
|
440
|
+
|
441
|
+
/**************************************************************************
|
442
|
+
*
|
443
|
+
* @enum:
|
444
|
+
* FT_Orientation
|
445
|
+
*
|
446
|
+
* @description:
|
447
|
+
* A list of values used to describe an outline's contour orientation.
|
448
|
+
*
|
449
|
+
* The TrueType and Postscript specifications use different conventions
|
450
|
+
* to determine whether outline contours should be filled or unfilled.
|
451
|
+
*
|
452
|
+
* @values:
|
453
|
+
* FT_ORIENTATION_TRUETYPE ::
|
454
|
+
* According to the TrueType specification, clockwise contours must
|
455
|
+
* be filled, and counter-clockwise ones must be unfilled.
|
456
|
+
*
|
457
|
+
* FT_ORIENTATION_POSTSCRIPT ::
|
458
|
+
* According to the Postscript specification, counter-clockwise contours
|
459
|
+
* must be filled, and clockwise ones must be unfilled.
|
460
|
+
*
|
461
|
+
* FT_ORIENTATION_FILL_RIGHT ::
|
462
|
+
* This is identical to @FT_ORIENTATION_TRUETYPE, but is used to
|
463
|
+
* remember that in TrueType, everything that is to the right of
|
464
|
+
* the drawing direction of a contour must be filled.
|
465
|
+
*
|
466
|
+
* FT_ORIENTATION_FILL_LEFT ::
|
467
|
+
* This is identical to @FT_ORIENTATION_POSTSCRIPT, but is used to
|
468
|
+
* remember that in Postscript, everything that is to the left of
|
469
|
+
* the drawing direction of a contour must be filled.
|
470
|
+
*
|
471
|
+
* FT_ORIENTATION_NONE ::
|
472
|
+
* The orientation cannot be determined. That is, different parts of
|
473
|
+
* the glyph have different orientation.
|
474
|
+
*
|
475
|
+
*/
|
476
|
+
typedef enum
|
477
|
+
{
|
478
|
+
FT_ORIENTATION_TRUETYPE = 0,
|
479
|
+
FT_ORIENTATION_POSTSCRIPT = 1,
|
480
|
+
FT_ORIENTATION_FILL_RIGHT = FT_ORIENTATION_TRUETYPE,
|
481
|
+
FT_ORIENTATION_FILL_LEFT = FT_ORIENTATION_POSTSCRIPT,
|
482
|
+
FT_ORIENTATION_NONE
|
483
|
+
|
484
|
+
} FT_Orientation;
|
485
|
+
|
486
|
+
|
487
|
+
/**************************************************************************
|
488
|
+
*
|
489
|
+
* @function:
|
490
|
+
* FT_Outline_Get_Orientation
|
491
|
+
*
|
492
|
+
* @description:
|
493
|
+
* This function analyzes a glyph outline and tries to compute its
|
494
|
+
* fill orientation (see @FT_Orientation). This is done by computing
|
495
|
+
* the direction of each global horizontal and/or vertical extrema
|
496
|
+
* within the outline.
|
497
|
+
*
|
498
|
+
* Note that this will return @FT_ORIENTATION_TRUETYPE for empty
|
499
|
+
* outlines.
|
500
|
+
*
|
501
|
+
* @input:
|
502
|
+
* outline ::
|
503
|
+
* A handle to the source outline.
|
504
|
+
*
|
505
|
+
* @return:
|
506
|
+
* The orientation.
|
507
|
+
*
|
508
|
+
*/
|
509
|
+
FT_EXPORT( FT_Orientation )
|
510
|
+
FT_Outline_Get_Orientation( FT_Outline* outline );
|
511
|
+
|
512
|
+
|
513
|
+
/* */
|
514
|
+
|
515
|
+
|
516
|
+
FT_END_HEADER
|
517
|
+
|
518
|
+
#endif /* __FTOUTLN_H__ */
|
519
|
+
|
520
|
+
|
521
|
+
/* END */
|
522
|
+
|
523
|
+
|
524
|
+
/* Local Variables: */
|
525
|
+
/* coding: utf-8 */
|
526
|
+
/* End: */
|