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.
Files changed (370) hide show
  1. data/README.md +235 -32
  2. data/Rakefile +20 -49
  3. data/ext/audio.c +68 -0
  4. data/ext/audio_source.c +197 -0
  5. data/ext/buffer_renderer.c +130 -0
  6. data/ext/color.c +179 -0
  7. data/ext/drawable.c +446 -0
  8. data/ext/event.c +337 -0
  9. data/ext/extconf.rb +80 -6
  10. data/ext/font.c +97 -0
  11. data/ext/gl.c +114 -0
  12. data/ext/gl_buffer.c +224 -0
  13. data/ext/gl_index_buffer.c +202 -0
  14. data/ext/gl_int_array.c +139 -0
  15. data/ext/gl_vertex.c +157 -0
  16. data/ext/image.c +263 -0
  17. data/ext/image_target.c +84 -0
  18. data/ext/input.c +53 -0
  19. data/ext/matrix.c +374 -0
  20. data/ext/music.c +113 -0
  21. data/ext/polygon.c +426 -0
  22. data/ext/ray.c +59 -0
  23. data/ext/ray.h +168 -0
  24. data/ext/rect.c +255 -0
  25. data/ext/say.h +31 -0
  26. data/ext/say_all.h +77 -0
  27. data/ext/say_arial.h +14689 -0
  28. data/ext/say_array.c +124 -0
  29. data/ext/say_array.h +34 -0
  30. data/ext/say_audio.c +64 -0
  31. data/ext/say_audio.h +170 -0
  32. data/ext/say_audio_context.c +40 -0
  33. data/ext/say_audio_source.c +96 -0
  34. data/ext/say_basic_type.c +17 -0
  35. data/ext/say_basic_type.h +47 -0
  36. data/ext/say_buffer.c +277 -0
  37. data/ext/say_buffer.h +37 -0
  38. data/ext/say_buffer_renderer.c +121 -0
  39. data/ext/say_buffer_renderer.h +33 -0
  40. data/ext/say_buffer_slice.c +247 -0
  41. data/ext/say_buffer_slice.h +29 -0
  42. data/ext/say_clean_up.c +14 -0
  43. data/ext/say_context.c +163 -0
  44. data/ext/say_context.h +26 -0
  45. data/ext/say_drawable.c +350 -0
  46. data/ext/say_drawable.h +100 -0
  47. data/ext/say_error.c +27 -0
  48. data/ext/say_event.h +213 -0
  49. data/ext/say_font.c +335 -0
  50. data/ext/say_font.h +51 -0
  51. data/ext/say_image.c +283 -0
  52. data/ext/say_image.h +52 -0
  53. data/ext/say_image_target.c +134 -0
  54. data/ext/say_image_target.h +25 -0
  55. data/ext/say_imp.h +70 -0
  56. data/ext/say_index_buffer.c +90 -0
  57. data/ext/say_index_buffer.h +29 -0
  58. data/ext/say_index_buffer_slice.c +227 -0
  59. data/ext/say_index_buffer_slice.h +28 -0
  60. data/ext/say_input.c +35 -0
  61. data/ext/say_matrix.c +314 -0
  62. data/ext/say_matrix.h +55 -0
  63. data/ext/say_music.c +225 -0
  64. data/ext/say_osx.h +62 -0
  65. data/ext/say_osx_context.h +98 -0
  66. data/ext/say_osx_window.h +766 -0
  67. data/ext/say_polygon.c +358 -0
  68. data/ext/say_polygon.h +62 -0
  69. data/ext/say_renderer.c +42 -0
  70. data/ext/say_renderer.h +22 -0
  71. data/ext/say_shader.c +375 -0
  72. data/ext/say_shader.h +91 -0
  73. data/ext/say_sound.c +67 -0
  74. data/ext/say_sound_buffer.c +96 -0
  75. data/ext/say_sprite.c +273 -0
  76. data/ext/say_sprite.h +53 -0
  77. data/ext/say_string.c +9 -0
  78. data/ext/say_table.c +86 -0
  79. data/ext/say_table.h +24 -0
  80. data/ext/say_target.c +264 -0
  81. data/ext/say_target.h +67 -0
  82. data/ext/say_text.c +441 -0
  83. data/ext/say_text.h +56 -0
  84. data/ext/say_thread.c +46 -0
  85. data/ext/say_thread.h +39 -0
  86. data/ext/say_thread_variable.c +44 -0
  87. data/ext/say_utf.c +62 -0
  88. data/ext/say_vertex_type.c +113 -0
  89. data/ext/say_vertex_type.h +40 -0
  90. data/ext/say_vfile.c +57 -0
  91. data/ext/say_view.c +150 -0
  92. data/ext/say_view.h +44 -0
  93. data/ext/say_win.h +24 -0
  94. data/ext/say_win_context.h +91 -0
  95. data/ext/say_win_window.h +670 -0
  96. data/ext/say_window.c +155 -0
  97. data/ext/say_window.h +43 -0
  98. data/ext/say_x11.h +41 -0
  99. data/ext/say_x11_context.h +96 -0
  100. data/ext/say_x11_window.h +818 -0
  101. data/ext/shader.c +302 -0
  102. data/ext/sound.c +118 -0
  103. data/ext/sound_buffer.c +75 -0
  104. data/ext/sprite.c +241 -0
  105. data/ext/stb_image.h +4971 -0
  106. data/ext/stb_image_write.h +511 -0
  107. data/ext/target.c +184 -0
  108. data/ext/text.c +162 -0
  109. data/ext/utils.c +10 -0
  110. data/ext/vector.c +261 -0
  111. data/ext/vendor/freetype/bin/freetype6.dll +0 -0
  112. data/ext/vendor/freetype/bin/zlib1.dll +0 -0
  113. data/ext/vendor/freetype/include/freetype2/freetype/config/ftconfig.h +350 -0
  114. data/ext/vendor/freetype/include/freetype2/freetype/config/ftheader.h +729 -0
  115. data/ext/vendor/freetype/include/freetype2/freetype/config/ftmodule.h +22 -0
  116. data/ext/vendor/freetype/include/freetype2/freetype/config/ftoption.h +695 -0
  117. data/ext/vendor/freetype/include/freetype2/freetype/config/ftstdlib.h +180 -0
  118. data/ext/vendor/freetype/include/freetype2/freetype/freetype.h +3434 -0
  119. data/ext/vendor/freetype/include/freetype2/freetype/ftbbox.h +94 -0
  120. data/ext/vendor/freetype/include/freetype2/freetype/ftbdf.h +200 -0
  121. data/ext/vendor/freetype/include/freetype2/freetype/ftbitmap.h +206 -0
  122. data/ext/vendor/freetype/include/freetype2/freetype/ftcache.h +1110 -0
  123. data/ext/vendor/freetype/include/freetype2/freetype/ftchapters.h +100 -0
  124. data/ext/vendor/freetype/include/freetype2/freetype/fterrdef.h +239 -0
  125. data/ext/vendor/freetype/include/freetype2/freetype/fterrors.h +206 -0
  126. data/ext/vendor/freetype/include/freetype2/freetype/ftgasp.h +113 -0
  127. data/ext/vendor/freetype/include/freetype2/freetype/ftglyph.h +575 -0
  128. data/ext/vendor/freetype/include/freetype2/freetype/ftgxval.h +358 -0
  129. data/ext/vendor/freetype/include/freetype2/freetype/ftgzip.h +102 -0
  130. data/ext/vendor/freetype/include/freetype2/freetype/ftimage.h +1237 -0
  131. data/ext/vendor/freetype/include/freetype2/freetype/ftincrem.h +331 -0
  132. data/ext/vendor/freetype/include/freetype2/freetype/ftlcdfil.h +166 -0
  133. data/ext/vendor/freetype/include/freetype2/freetype/ftlist.h +273 -0
  134. data/ext/vendor/freetype/include/freetype2/freetype/ftlzw.h +99 -0
  135. data/ext/vendor/freetype/include/freetype2/freetype/ftmac.h +272 -0
  136. data/ext/vendor/freetype/include/freetype2/freetype/ftmm.h +378 -0
  137. data/ext/vendor/freetype/include/freetype2/freetype/ftmodapi.h +406 -0
  138. data/ext/vendor/freetype/include/freetype2/freetype/ftmoderr.h +155 -0
  139. data/ext/vendor/freetype/include/freetype2/freetype/ftotval.h +198 -0
  140. data/ext/vendor/freetype/include/freetype2/freetype/ftoutln.h +526 -0
  141. data/ext/vendor/freetype/include/freetype2/freetype/ftpfr.h +172 -0
  142. data/ext/vendor/freetype/include/freetype2/freetype/ftrender.h +229 -0
  143. data/ext/vendor/freetype/include/freetype2/freetype/ftsizes.h +159 -0
  144. data/ext/vendor/freetype/include/freetype2/freetype/ftsnames.h +170 -0
  145. data/ext/vendor/freetype/include/freetype2/freetype/ftstroke.h +716 -0
  146. data/ext/vendor/freetype/include/freetype2/freetype/ftsynth.h +73 -0
  147. data/ext/vendor/freetype/include/freetype2/freetype/ftsystem.h +346 -0
  148. data/ext/vendor/freetype/include/freetype2/freetype/fttrigon.h +350 -0
  149. data/ext/vendor/freetype/include/freetype2/freetype/fttypes.h +583 -0
  150. data/ext/vendor/freetype/include/freetype2/freetype/ftwinfnt.h +263 -0
  151. data/ext/vendor/freetype/include/freetype2/freetype/ftxf86.h +80 -0
  152. data/ext/vendor/freetype/include/freetype2/freetype/t1tables.h +450 -0
  153. data/ext/vendor/freetype/include/freetype2/freetype/ttnameid.h +1132 -0
  154. data/ext/vendor/freetype/include/freetype2/freetype/tttables.h +756 -0
  155. data/ext/vendor/freetype/include/freetype2/freetype/tttags.h +99 -0
  156. data/ext/vendor/freetype/include/freetype2/freetype/ttunpat.h +59 -0
  157. data/ext/vendor/freetype/include/ft2build.h +61 -0
  158. data/ext/vendor/freetype/lib/freetype-bcc.lib +0 -0
  159. data/ext/vendor/freetype/lib/freetype6.def +249 -0
  160. data/ext/vendor/freetype/lib/libfreetype.dll.a +0 -0
  161. data/ext/vendor/freetype/lib/tmp.freetype.lib +0 -0
  162. data/ext/vendor/glew/LICENSE.txt +73 -0
  163. data/ext/vendor/glew/README.txt +18 -0
  164. data/ext/vendor/glew/include/GL/glew.h +15507 -0
  165. data/ext/vendor/glew/include/GL/glxew.h +1568 -0
  166. data/ext/vendor/glew/include/GL/wglew.h +1361 -0
  167. data/ext/vendor/glew/lib/glew32.dll +0 -0
  168. data/ext/vendor/glew/lib/glew32mx.dll +0 -0
  169. data/ext/vendor/glew/lib/libglew32.a +0 -0
  170. data/ext/vendor/glew/lib/libglew32.dll.a +0 -0
  171. data/ext/vendor/glew/lib/libglew32mx.a +0 -0
  172. data/ext/vendor/glew/lib/libglew32mx.dll.a +0 -0
  173. data/ext/vendor/openal/COPYING +484 -0
  174. data/ext/vendor/openal/Win32/soft_oal.dll +0 -0
  175. data/ext/vendor/openal/include/AL/al.h +724 -0
  176. data/ext/vendor/openal/include/AL/alc.h +277 -0
  177. data/ext/vendor/openal/include/AL/alext.h +165 -0
  178. data/ext/vendor/openal/include/AL/efx-creative.h +3 -0
  179. data/ext/vendor/openal/include/AL/efx.h +758 -0
  180. data/ext/vendor/openal/lib/libOpenAL32.dll.a +0 -0
  181. data/ext/vendor/sndfile/bin/libsndfile-1.dll +0 -0
  182. data/ext/vendor/sndfile/include/sndfile.h +666 -0
  183. data/ext/vendor/sndfile/include/sndfile.hh +422 -0
  184. data/ext/vendor/sndfile/lib/libsndfile-1.def +41 -0
  185. data/ext/vendor/sndfile/lib/libsndfile-1.lib +0 -0
  186. data/ext/vertex.c +96 -0
  187. data/ext/view.c +131 -0
  188. data/ext/window.c +183 -0
  189. data/lib/ray/animation.rb +248 -0
  190. data/lib/ray/animation/block_animation.rb +36 -0
  191. data/lib/ray/animation/circular_motion.rb +57 -0
  192. data/lib/ray/animation/color_variation.rb +102 -0
  193. data/lib/ray/animation/combination.rb +71 -0
  194. data/lib/ray/animation/float_variation.rb +76 -0
  195. data/lib/ray/animation/sequence.rb +65 -0
  196. data/lib/ray/animation/sprite_animation.rb +68 -0
  197. data/lib/ray/animation/vector_variation.rb +111 -0
  198. data/lib/ray/animation_list.rb +50 -0
  199. data/lib/ray/audio.rb +4 -7
  200. data/lib/ray/buffer_renderer.rb +9 -0
  201. data/lib/ray/color.rb +41 -6
  202. data/lib/ray/drawable.rb +34 -9
  203. data/lib/ray/dsl.rb +6 -0
  204. data/lib/ray/dsl/event.rb +1 -1
  205. data/lib/ray/dsl/event_listener.rb +14 -10
  206. data/lib/ray/dsl/event_raiser.rb +5 -2
  207. data/lib/ray/dsl/event_runner.rb +4 -10
  208. data/lib/ray/dsl/event_translator.rb +67 -99
  209. data/lib/ray/dsl/handler.rb +1 -1
  210. data/lib/ray/dsl/matcher.rb +40 -27
  211. data/lib/ray/event.rb +22 -0
  212. data/lib/ray/font.rb +0 -42
  213. data/lib/ray/font_set.rb +3 -7
  214. data/lib/ray/game.rb +33 -73
  215. data/lib/ray/gl/int_array.rb +24 -0
  216. data/lib/ray/gl/vertex.rb +106 -0
  217. data/lib/ray/helper.rb +25 -11
  218. data/lib/ray/image.rb +9 -154
  219. data/lib/ray/image_set.rb +3 -8
  220. data/lib/ray/image_target.rb +12 -0
  221. data/lib/ray/matrix.rb +90 -0
  222. data/lib/ray/music.rb +12 -0
  223. data/lib/ray/polygon.rb +77 -0
  224. data/lib/ray/ray.rb +45 -13
  225. data/lib/ray/rect.rb +14 -3
  226. data/lib/ray/resource_set.rb +18 -35
  227. data/lib/ray/scene.rb +43 -81
  228. data/lib/ray/scene_list.rb +12 -5
  229. data/lib/ray/shader.rb +82 -0
  230. data/lib/ray/sound.rb +18 -0
  231. data/lib/ray/sound_buffer.rb +6 -0
  232. data/lib/ray/sound_buffer_set.rb +32 -0
  233. data/lib/ray/sprite.rb +111 -97
  234. data/lib/ray/target.rb +18 -0
  235. data/lib/ray/text.rb +80 -58
  236. data/lib/ray/text_helper.rb +21 -27
  237. data/lib/ray/turtle.rb +49 -38
  238. data/lib/ray/vector.rb +76 -1
  239. data/lib/ray/vertex.rb +24 -0
  240. data/lib/ray/view.rb +47 -0
  241. data/lib/ray/window.rb +23 -0
  242. data/samples/_media/Beep.wav +0 -0
  243. data/samples/_media/CptnRuby Gem.png +0 -0
  244. data/samples/_media/CptnRuby Map.txt +25 -0
  245. data/samples/_media/CptnRuby Tileset.png +0 -0
  246. data/samples/_media/CptnRuby.png +0 -0
  247. data/samples/_media/Space.png +0 -0
  248. data/samples/_media/Star.png +0 -0
  249. data/samples/_media/Starfighter.png +0 -0
  250. data/samples/animation/chain.rb +33 -0
  251. data/samples/animation/circle.rb +38 -0
  252. data/samples/animation/color.rb +18 -0
  253. data/samples/animation/rotation.rb +17 -0
  254. data/samples/animation/sequence.rb +33 -0
  255. data/samples/animation/shader.rb +65 -0
  256. data/samples/animation/sprite_motion.rb +103 -0
  257. data/samples/animation/translation.rb +23 -0
  258. data/samples/audio/spacial.rb +25 -11
  259. data/samples/buffer/buffer.rb +28 -0
  260. data/samples/buffer/index_buffer.rb +36 -0
  261. data/samples/buffer/renderer.rb +27 -0
  262. data/samples/cptn_ruby/cptn_ruby.rb +279 -0
  263. data/samples/hello_world/hello.rb +2 -2
  264. data/samples/hello_world/hello_dsl.rb +3 -3
  265. data/samples/hello_world/text.rb +2 -2
  266. data/samples/opengl/cube.rb +124 -0
  267. data/samples/opengl/image.rb +36 -16
  268. data/samples/opengl/obj_loader.rb +99 -0
  269. data/samples/opengl/opengl.rb +24 -18
  270. data/samples/opengl/shader.rb +36 -26
  271. data/samples/pong/pong.rb +41 -39
  272. data/samples/{run_scene.rb → scenes/run_scene.rb} +21 -7
  273. data/samples/shaders/geometry.rb +98 -0
  274. data/samples/shaders/scene.rb +19 -12
  275. data/samples/shaders/shaders.rb +34 -17
  276. data/samples/shaders/shape.rb +12 -7
  277. data/samples/sokoban/level_1 +11 -7
  278. data/samples/sokoban/sokoban.rb +36 -63
  279. data/samples/starfighter/starfighter.rb +159 -0
  280. data/samples/test/actual_scene.rb +3 -3
  281. data/samples/test/scene_riot.rb +4 -4
  282. data/samples/test/scene_spec.rb +3 -3
  283. data/samples/test/scene_test_unit.rb +1 -1
  284. data/samples/turtle/byzantium.rb +10 -5
  285. data/samples/turtle/hilbert.rb +16 -11
  286. data/samples/turtle/koch.rb +16 -11
  287. data/samples/turtle/mandala.rb +43 -38
  288. data/samples/turtle/tree.rb +13 -8
  289. data/samples/view/resize.rb +26 -0
  290. data/samples/view/view.rb +35 -0
  291. data/samples/window/all_events.rb +44 -0
  292. data/samples/window/change_title.rb +16 -0
  293. data/samples/window/fullscreen.rb +18 -0
  294. data/samples/window/get_pixel.rb +29 -0
  295. data/samples/window/icon.rb +88 -0
  296. data/samples/window/input.rb +27 -0
  297. data/samples/window/no_border.rb +16 -0
  298. data/samples/window/resize.rb +24 -0
  299. data/test/animation/color_variation_test.rb +64 -0
  300. data/test/animation/combination_test.rb +35 -0
  301. data/test/animation/float_variation_test.rb +75 -0
  302. data/test/animation/vector_variation_test.rb +123 -0
  303. data/test/animation_list_test.rb +122 -0
  304. data/test/animation_test.rb +83 -0
  305. data/test/audio_test.rb +88 -33
  306. data/test/buffer_renderer_test.rb +38 -0
  307. data/test/color_test.rb +31 -22
  308. data/test/drawable_test.rb +207 -7
  309. data/test/dsl_test.rb +25 -7
  310. data/test/font_test.rb +6 -40
  311. data/test/game_test.rb +76 -0
  312. data/test/gl_buffer_test.rb +26 -0
  313. data/test/gl_index_buffer_test.rb +17 -0
  314. data/test/gl_vertex_test.rb +117 -0
  315. data/test/helpers.rb +45 -5
  316. data/test/image_target_test.rb +19 -0
  317. data/test/image_test.rb +73 -53
  318. data/test/int_array_test.rb +64 -0
  319. data/test/matrix_test.rb +134 -0
  320. data/test/polygon_test.rb +126 -0
  321. data/test/rect_test.rb +6 -8
  322. data/test/res/frag.c +14 -0
  323. data/test/res/frag3d.c +10 -0
  324. data/test/res/frag_gray.c +17 -0
  325. data/test/res/frag_light3d.c +20 -0
  326. data/test/res/light3d.c +20 -0
  327. data/test/res/sprite.png +0 -0
  328. data/test/res/teapot.obj +12831 -0
  329. data/test/res/vert.c +17 -0
  330. data/test/res/vertex3d.c +14 -0
  331. data/test/resource_set_test.rb +8 -45
  332. data/test/run_all.rb +1 -1
  333. data/test/scene_list_test.rb +79 -0
  334. data/test/scene_test.rb +168 -0
  335. data/test/shader_test.rb +58 -0
  336. data/test/sprite_test.rb +46 -41
  337. data/test/target_test.rb +34 -0
  338. data/test/text_test.rb +20 -31
  339. data/test/turtle_test.rb +35 -20
  340. data/test/vector_test.rb +61 -19
  341. data/test/vertex_test.rb +43 -0
  342. data/test/view_test.rb +61 -0
  343. metadata +347 -126
  344. data/.yardopts +0 -4
  345. data/VERSION +0 -1
  346. data/ext/audio.cpp +0 -723
  347. data/ext/color.cpp +0 -159
  348. data/ext/drawable.cpp +0 -91
  349. data/ext/event.cpp +0 -460
  350. data/ext/font.cpp +0 -190
  351. data/ext/image.cpp +0 -733
  352. data/ext/input.cpp +0 -74
  353. data/ext/ray.cpp +0 -168
  354. data/ext/ray.hpp +0 -356
  355. data/ext/rect.cpp +0 -245
  356. data/ext/shader.cpp +0 -169
  357. data/ext/shape.cpp +0 -409
  358. data/ext/sprite.cpp +0 -306
  359. data/ext/text.cpp +0 -181
  360. data/ext/vector.cpp +0 -215
  361. data/guide.md +0 -619
  362. data/lib/ray/input.rb +0 -10
  363. data/lib/ray/music_set.rb +0 -37
  364. data/lib/ray/rmagick.rb +0 -41
  365. data/lib/ray/shape.rb +0 -132
  366. data/lib/ray/sound_set.rb +0 -37
  367. data/samples/opengl/binding.rb +0 -38
  368. data/test/ray_test.rb +0 -25
  369. data/test/shape_test.rb +0 -101
  370. 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: */