prawn 0.11.1 → 0.15.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (353) hide show
  1. checksums.yaml +7 -0
  2. data/.yardopts +10 -0
  3. data/COPYING +2 -2
  4. data/GPLv2 +340 -0
  5. data/GPLv3 +674 -0
  6. data/Gemfile +11 -0
  7. data/LICENSE +1 -1
  8. data/Rakefile +29 -38
  9. data/data/images/16bit.alpha +0 -0
  10. data/data/images/16bit.color +0 -0
  11. data/data/images/dice.alpha +0 -0
  12. data/data/images/dice.color +0 -0
  13. data/data/images/indexed_color.dat +0 -0
  14. data/data/images/indexed_color.png +0 -0
  15. data/data/images/page_white_text.alpha +0 -0
  16. data/data/images/page_white_text.color +0 -0
  17. data/data/pdfs/nested_pages.pdf +13 -13
  18. data/lib/prawn/document/bounding_box.rb +87 -12
  19. data/lib/prawn/document/column_box.rb +57 -28
  20. data/lib/prawn/document/graphics_state.rb +11 -74
  21. data/lib/prawn/document/internals.rb +25 -23
  22. data/lib/prawn/document/snapshot.rb +11 -8
  23. data/lib/prawn/document/span.rb +12 -10
  24. data/lib/prawn/document.rb +250 -194
  25. data/lib/prawn/encoding.rb +9 -10
  26. data/lib/prawn/errors.rb +18 -29
  27. data/lib/prawn/font/afm.rb +52 -41
  28. data/lib/prawn/font/dfont.rb +4 -3
  29. data/lib/prawn/font/ttf.rb +44 -48
  30. data/lib/prawn/font.rb +138 -88
  31. data/lib/prawn/font_metric_cache.rb +47 -0
  32. data/lib/prawn/graphics/cap_style.rb +4 -3
  33. data/lib/prawn/graphics/color.rb +13 -5
  34. data/lib/prawn/graphics/dash.rb +53 -31
  35. data/lib/prawn/graphics/join_style.rb +9 -7
  36. data/lib/prawn/graphics/patterns.rb +138 -0
  37. data/lib/prawn/graphics/transformation.rb +10 -9
  38. data/lib/prawn/graphics/transparency.rb +3 -1
  39. data/lib/prawn/graphics.rb +316 -61
  40. data/lib/prawn/image_handler.rb +36 -0
  41. data/lib/prawn/images/image.rb +49 -0
  42. data/lib/prawn/images/jpg.rb +21 -15
  43. data/lib/prawn/images/png.rb +62 -119
  44. data/lib/prawn/images.rb +89 -108
  45. data/lib/prawn/layout/grid.rb +66 -54
  46. data/lib/prawn/layout.rb +10 -15
  47. data/lib/prawn/measurement_extensions.rb +10 -6
  48. data/lib/prawn/measurements.rb +27 -21
  49. data/lib/prawn/outline.rb +6 -308
  50. data/lib/prawn/repeater.rb +11 -9
  51. data/lib/prawn/security/arcfour.rb +1 -0
  52. data/lib/prawn/security.rb +55 -33
  53. data/lib/prawn/soft_mask.rb +96 -0
  54. data/lib/prawn/stamp.rb +5 -3
  55. data/lib/prawn/table/cell/image.rb +69 -0
  56. data/lib/prawn/table/cell/in_table.rb +4 -2
  57. data/lib/prawn/table/cell/span_dummy.rb +93 -0
  58. data/lib/prawn/table/cell/subtable.rb +2 -2
  59. data/lib/prawn/table/cell/text.rb +44 -26
  60. data/lib/prawn/table/cell.rb +302 -50
  61. data/lib/prawn/table/cells.rb +147 -49
  62. data/lib/prawn/table/column_width_calculator.rb +61 -0
  63. data/lib/prawn/table.rb +297 -118
  64. data/lib/prawn/text/box.rb +21 -5
  65. data/lib/prawn/text/formatted/arranger.rb +290 -0
  66. data/lib/prawn/text/formatted/box.rb +103 -59
  67. data/lib/prawn/text/formatted/fragment.rb +34 -23
  68. data/lib/prawn/text/formatted/line_wrap.rb +266 -0
  69. data/lib/prawn/text/formatted/parser.rb +15 -5
  70. data/lib/prawn/text/formatted/wrap.rb +150 -0
  71. data/lib/prawn/text/formatted.rb +5 -4
  72. data/lib/prawn/text.rb +38 -24
  73. data/lib/prawn/utilities.rb +46 -0
  74. data/lib/prawn.rb +85 -20
  75. data/manual/basic_concepts/adding_pages.rb +27 -0
  76. data/manual/basic_concepts/basic_concepts.rb +34 -0
  77. data/manual/basic_concepts/creation.rb +39 -0
  78. data/manual/basic_concepts/cursor.rb +33 -0
  79. data/manual/basic_concepts/measurement.rb +25 -0
  80. data/manual/basic_concepts/origin.rb +38 -0
  81. data/manual/basic_concepts/other_cursor_helpers.rb +40 -0
  82. data/manual/bounding_box/bounding_box.rb +39 -0
  83. data/manual/bounding_box/bounds.rb +49 -0
  84. data/manual/bounding_box/canvas.rb +24 -0
  85. data/manual/bounding_box/creation.rb +23 -0
  86. data/manual/bounding_box/indentation.rb +46 -0
  87. data/manual/bounding_box/nesting.rb +45 -0
  88. data/manual/bounding_box/russian_boxes.rb +40 -0
  89. data/manual/bounding_box/stretchy.rb +31 -0
  90. data/manual/document_and_page_options/background.rb +27 -0
  91. data/manual/document_and_page_options/document_and_page_options.rb +32 -0
  92. data/manual/document_and_page_options/metadata.rb +23 -0
  93. data/manual/document_and_page_options/page_margins.rb +38 -0
  94. data/manual/document_and_page_options/page_size.rb +34 -0
  95. data/manual/document_and_page_options/print_scaling.rb +20 -0
  96. data/manual/example_file.rb +111 -0
  97. data/manual/example_helper.rb +411 -0
  98. data/manual/example_package.rb +53 -0
  99. data/manual/example_section.rb +46 -0
  100. data/manual/graphics/circle_and_ellipse.rb +22 -0
  101. data/manual/graphics/color.rb +24 -0
  102. data/manual/graphics/common_lines.rb +30 -0
  103. data/manual/graphics/fill_and_stroke.rb +42 -0
  104. data/manual/graphics/fill_rules.rb +37 -0
  105. data/manual/graphics/gradients.rb +37 -0
  106. data/manual/graphics/graphics.rb +58 -0
  107. data/manual/graphics/helper.rb +24 -0
  108. data/manual/graphics/line_width.rb +35 -0
  109. data/manual/graphics/lines_and_curves.rb +41 -0
  110. data/manual/graphics/polygon.rb +29 -0
  111. data/manual/graphics/rectangle.rb +21 -0
  112. data/manual/graphics/rotate.rb +28 -0
  113. data/manual/graphics/scale.rb +41 -0
  114. data/manual/graphics/soft_masks.rb +46 -0
  115. data/manual/graphics/stroke_cap.rb +31 -0
  116. data/manual/graphics/stroke_dash.rb +48 -0
  117. data/manual/graphics/stroke_join.rb +30 -0
  118. data/manual/graphics/translate.rb +29 -0
  119. data/manual/graphics/transparency.rb +35 -0
  120. data/manual/images/absolute_position.rb +23 -0
  121. data/manual/images/fit.rb +21 -0
  122. data/manual/images/horizontal.rb +25 -0
  123. data/manual/images/images.rb +40 -0
  124. data/manual/images/plain_image.rb +18 -0
  125. data/manual/images/scale.rb +22 -0
  126. data/manual/images/vertical.rb +28 -0
  127. data/manual/images/width_and_height.rb +25 -0
  128. data/manual/layout/boxes.rb +27 -0
  129. data/manual/layout/content.rb +25 -0
  130. data/manual/layout/layout.rb +28 -0
  131. data/manual/layout/simple_grid.rb +23 -0
  132. data/manual/manual/cover.rb +36 -0
  133. data/manual/manual/foreword.rb +85 -0
  134. data/manual/manual/how_to_read_this_manual.rb +41 -0
  135. data/manual/manual/manual.rb +34 -0
  136. data/manual/outline/add_subsection_to.rb +61 -0
  137. data/manual/outline/insert_section_after.rb +47 -0
  138. data/manual/outline/outline.rb +32 -0
  139. data/manual/outline/sections_and_pages.rb +67 -0
  140. data/manual/repeatable_content/page_numbering.rb +54 -0
  141. data/manual/repeatable_content/repeatable_content.rb +31 -0
  142. data/manual/repeatable_content/repeater.rb +55 -0
  143. data/manual/repeatable_content/stamp.rb +41 -0
  144. data/manual/security/encryption.rb +31 -0
  145. data/manual/security/permissions.rb +38 -0
  146. data/manual/security/security.rb +28 -0
  147. data/manual/syntax_highlight.rb +52 -0
  148. data/manual/table/basic_block.rb +53 -0
  149. data/manual/table/before_rendering_page.rb +26 -0
  150. data/manual/table/cell_border_lines.rb +24 -0
  151. data/manual/table/cell_borders_and_bg.rb +31 -0
  152. data/manual/table/cell_dimensions.rb +30 -0
  153. data/manual/table/cell_text.rb +38 -0
  154. data/manual/table/column_widths.rb +30 -0
  155. data/manual/table/content_and_subtables.rb +39 -0
  156. data/manual/table/creation.rb +27 -0
  157. data/manual/table/filtering.rb +36 -0
  158. data/manual/table/flow_and_header.rb +17 -0
  159. data/manual/table/image_cells.rb +33 -0
  160. data/manual/table/position.rb +29 -0
  161. data/manual/table/row_colors.rb +20 -0
  162. data/manual/table/span.rb +30 -0
  163. data/manual/table/style.rb +22 -0
  164. data/manual/table/table.rb +52 -0
  165. data/manual/table/width.rb +27 -0
  166. data/manual/text/alignment.rb +44 -0
  167. data/manual/text/color.rb +24 -0
  168. data/manual/text/column_box.rb +32 -0
  169. data/manual/text/fallback_fonts.rb +37 -0
  170. data/manual/text/font.rb +41 -0
  171. data/manual/text/font_size.rb +45 -0
  172. data/manual/text/font_style.rb +23 -0
  173. data/manual/text/formatted_callbacks.rb +60 -0
  174. data/manual/text/formatted_text.rb +54 -0
  175. data/manual/text/free_flowing_text.rb +51 -0
  176. data/manual/text/group.rb +31 -0
  177. data/manual/text/inline.rb +43 -0
  178. data/manual/text/kerning_and_character_spacing.rb +39 -0
  179. data/manual/text/leading.rb +25 -0
  180. data/manual/text/line_wrapping.rb +41 -0
  181. data/manual/text/paragraph_indentation.rb +26 -0
  182. data/manual/text/positioned_text.rb +38 -0
  183. data/manual/text/registering_families.rb +48 -0
  184. data/manual/text/rendering_and_color.rb +37 -0
  185. data/manual/text/right_to_left_text.rb +43 -0
  186. data/manual/text/rotation.rb +43 -0
  187. data/manual/text/single_usage.rb +37 -0
  188. data/manual/text/text.rb +75 -0
  189. data/manual/text/text_box_excess.rb +32 -0
  190. data/manual/text/text_box_extensions.rb +45 -0
  191. data/manual/text/text_box_overflow.rb +44 -0
  192. data/manual/text/utf8.rb +28 -0
  193. data/{examples/m17n → manual/text}/win_ansi_charset.rb +14 -10
  194. data/prawn.gemspec +27 -17
  195. data/spec/acceptance/png.rb +23 -0
  196. data/spec/annotations_spec.rb +16 -32
  197. data/spec/bounding_box_spec.rb +284 -2
  198. data/spec/cell_spec.rb +169 -38
  199. data/spec/column_box_spec.rb +65 -0
  200. data/spec/data/curves.pdf +66 -0
  201. data/spec/destinations_spec.rb +5 -5
  202. data/spec/document_spec.rb +212 -113
  203. data/spec/extensions/encoding_helpers.rb +9 -0
  204. data/spec/extensions/mocha.rb +2 -3
  205. data/spec/font_metric_cache_spec.rb +52 -0
  206. data/spec/font_spec.rb +205 -95
  207. data/spec/formatted_text_arranger_spec.rb +43 -43
  208. data/spec/formatted_text_box_spec.rb +63 -24
  209. data/spec/formatted_text_fragment_spec.rb +8 -8
  210. data/spec/graphics_spec.rb +175 -68
  211. data/spec/grid_spec.rb +26 -15
  212. data/spec/image_handler_spec.rb +54 -0
  213. data/spec/images_spec.rb +58 -30
  214. data/spec/inline_formatted_text_parser_spec.rb +73 -19
  215. data/spec/jpg_spec.rb +4 -4
  216. data/spec/line_wrap_spec.rb +28 -28
  217. data/spec/measurement_units_spec.rb +6 -6
  218. data/spec/object_store_spec.rb +17 -106
  219. data/spec/outline_spec.rb +103 -63
  220. data/spec/png_spec.rb +25 -25
  221. data/spec/reference_spec.rb +8 -65
  222. data/spec/repeater_spec.rb +25 -11
  223. data/spec/security_spec.rb +44 -12
  224. data/spec/snapshot_spec.rb +38 -6
  225. data/spec/soft_mask_spec.rb +117 -0
  226. data/spec/span_spec.rb +10 -15
  227. data/spec/spec_helper.rb +32 -8
  228. data/spec/stamp_spec.rb +29 -30
  229. data/spec/stroke_styles_spec.rb +36 -18
  230. data/spec/table/span_dummy_spec.rb +17 -0
  231. data/spec/table_spec.rb +850 -104
  232. data/spec/text_at_spec.rb +19 -33
  233. data/spec/text_box_spec.rb +117 -64
  234. data/spec/text_rendering_mode_spec.rb +5 -5
  235. data/spec/text_spacing_spec.rb +20 -2
  236. data/spec/text_spec.rb +111 -59
  237. data/spec/transparency_spec.rb +5 -5
  238. metadata +477 -328
  239. data/HACKING +0 -50
  240. data/README +0 -141
  241. data/data/fonts/Action Man.dfont +0 -0
  242. data/data/fonts/Activa.ttf +0 -0
  243. data/data/fonts/Chalkboard.ttf +0 -0
  244. data/data/fonts/DejaVuSans.ttf +0 -0
  245. data/data/fonts/Dustismo_Roman.ttf +0 -0
  246. data/data/fonts/comicsans.ttf +0 -0
  247. data/data/fonts/gkai00mp.ttf +0 -0
  248. data/data/images/16bit.dat +0 -0
  249. data/data/images/dice.dat +0 -0
  250. data/data/images/page_white_text.dat +0 -0
  251. data/data/images/rails.dat +0 -0
  252. data/data/images/rails.png +0 -0
  253. data/examples/bounding_box/bounding_boxes.rb +0 -44
  254. data/examples/bounding_box/indentation.rb +0 -35
  255. data/examples/bounding_box/russian_boxes.rb +0 -37
  256. data/examples/bounding_box/stretched_nesting.rb +0 -68
  257. data/examples/example_helper.rb +0 -8
  258. data/examples/general/background.rb +0 -24
  259. data/examples/general/canvas.rb +0 -16
  260. data/examples/general/context_sensitive_headers.rb +0 -38
  261. data/examples/general/float.rb +0 -12
  262. data/examples/general/margin.rb +0 -37
  263. data/examples/general/measurement_units.rb +0 -52
  264. data/examples/general/metadata-info.rb +0 -17
  265. data/examples/general/multi_page_layout.rb +0 -19
  266. data/examples/general/outlines.rb +0 -67
  267. data/examples/general/page_geometry.rb +0 -32
  268. data/examples/general/page_numbering.rb +0 -40
  269. data/examples/general/page_templates.rb +0 -20
  270. data/examples/general/repeaters.rb +0 -48
  271. data/examples/general/stamp.rb +0 -42
  272. data/examples/general/templates.rb +0 -14
  273. data/examples/graphics/basic_images.rb +0 -24
  274. data/examples/graphics/cmyk.rb +0 -13
  275. data/examples/graphics/curves.rb +0 -12
  276. data/examples/graphics/gradient.rb +0 -23
  277. data/examples/graphics/hexagon.rb +0 -14
  278. data/examples/graphics/image_fit.rb +0 -16
  279. data/examples/graphics/image_flow.rb +0 -38
  280. data/examples/graphics/image_position.rb +0 -18
  281. data/examples/graphics/line.rb +0 -33
  282. data/examples/graphics/png_types.rb +0 -23
  283. data/examples/graphics/polygons.rb +0 -17
  284. data/examples/graphics/remote_images.rb +0 -13
  285. data/examples/graphics/rounded_polygons.rb +0 -20
  286. data/examples/graphics/rounded_rectangle.rb +0 -21
  287. data/examples/graphics/ruport_style_helpers.rb +0 -20
  288. data/examples/graphics/stroke_bounds.rb +0 -21
  289. data/examples/graphics/stroke_cap_and_join.rb +0 -46
  290. data/examples/graphics/stroke_dash.rb +0 -43
  291. data/examples/graphics/transformations.rb +0 -53
  292. data/examples/graphics/transparency.rb +0 -27
  293. data/examples/grid/bounding_boxes.rb +0 -22
  294. data/examples/grid/column_gutter_grid.rb +0 -21
  295. data/examples/grid/multi_boxes.rb +0 -52
  296. data/examples/grid/show_grid.rb +0 -14
  297. data/examples/grid/simple_grid.rb +0 -21
  298. data/examples/m17n/chinese_text_wrapping.rb +0 -18
  299. data/examples/m17n/euro.rb +0 -16
  300. data/examples/m17n/full_win_ansi_character_list.rb +0 -20
  301. data/examples/m17n/sjis.rb +0 -29
  302. data/examples/m17n/utf8.rb +0 -14
  303. data/examples/security/hello_foo.rb +0 -9
  304. data/examples/table/bill.rb +0 -54
  305. data/examples/table/borders.rb +0 -25
  306. data/examples/table/cell.rb +0 -13
  307. data/examples/table/checkerboard.rb +0 -23
  308. data/examples/table/header.rb +0 -15
  309. data/examples/table/inline_format_table.rb +0 -13
  310. data/examples/table/multi_page_table.rb +0 -10
  311. data/examples/table/simple_table.rb +0 -25
  312. data/examples/table/subtable.rb +0 -13
  313. data/examples/table/widths.rb +0 -21
  314. data/examples/text/alignment.rb +0 -19
  315. data/examples/text/character_spacing.rb +0 -13
  316. data/examples/text/dfont.rb +0 -49
  317. data/examples/text/family_based_styling.rb +0 -25
  318. data/examples/text/font_calculations.rb +0 -92
  319. data/examples/text/font_size.rb +0 -34
  320. data/examples/text/hyphenation.rb +0 -45
  321. data/examples/text/indent_paragraphs.rb +0 -24
  322. data/examples/text/inline_format.rb +0 -104
  323. data/examples/text/kerning.rb +0 -31
  324. data/examples/text/rendering_mode.rb +0 -21
  325. data/examples/text/rotated.rb +0 -99
  326. data/examples/text/shaped_text_box.rb +0 -32
  327. data/examples/text/simple_text.rb +0 -18
  328. data/examples/text/simple_text_ttf.rb +0 -18
  329. data/examples/text/span.rb +0 -30
  330. data/examples/text/text_box.rb +0 -90
  331. data/examples/text/text_box_returning_excess.rb +0 -52
  332. data/examples/text/text_flow.rb +0 -68
  333. data/lib/prawn/compatibility.rb +0 -51
  334. data/lib/prawn/core/annotations.rb +0 -61
  335. data/lib/prawn/core/byte_string.rb +0 -9
  336. data/lib/prawn/core/destinations.rb +0 -90
  337. data/lib/prawn/core/document_state.rb +0 -78
  338. data/lib/prawn/core/literal_string.rb +0 -16
  339. data/lib/prawn/core/name_tree.rb +0 -165
  340. data/lib/prawn/core/object_store.rb +0 -264
  341. data/lib/prawn/core/page.rb +0 -213
  342. data/lib/prawn/core/pdf_object.rb +0 -108
  343. data/lib/prawn/core/reference.rb +0 -112
  344. data/lib/prawn/core/text/formatted/arranger.rb +0 -293
  345. data/lib/prawn/core/text/formatted/line_wrap.rb +0 -272
  346. data/lib/prawn/core/text/formatted/wrap.rb +0 -149
  347. data/lib/prawn/core/text.rb +0 -268
  348. data/lib/prawn/core.rb +0 -85
  349. data/lib/prawn/document/page_geometry.rb +0 -136
  350. data/lib/prawn/graphics/gradient.rb +0 -84
  351. data/spec/name_tree_spec.rb +0 -112
  352. data/spec/pdf_object_spec.rb +0 -170
  353. data/spec/template_spec.rb +0 -291
data/HACKING DELETED
@@ -1,50 +0,0 @@
1
- = Hacking on Prawn
2
-
3
- While we hope to have more extensive documentation for contributors in time, for
4
- now, here is the bare minimum to get you up and running
5
-
6
- == NOTES
7
-
8
- Install test-spec, pdf-reader, and mocha from RubyGems
9
-
10
- Be sure to load in the necessary git submodules as well:
11
-
12
- git submodule init
13
- git submodule update
14
-
15
- If you are running on Ruby 1.9, you will need Test::Unit 1.2.3:
16
-
17
- gem install test-unit -v 1.2.3
18
-
19
- == Patch process
20
-
21
- 1. File a ticket in the bug tracker describing a defect or feature
22
-
23
- http://github.com/sandal/prawn/issues
24
-
25
- 2. Fork us on Github, make your changes. Bug fixes or tiny enhancements can
26
- be done on your master branch, everything else should be done on its own topic
27
- branch.
28
-
29
- 3. Post a comment to the ticket telling us where your fork is, and what
30
- patches we should be looking at.
31
-
32
- If you are working on a ticket that has already been created, skip step 1.
33
-
34
- All feature enhancements should come with an example in the examples/ dir,
35
- and preferably, some specs.
36
-
37
- All bug reports should have a reproducible example in bugs/ and preferably,
38
- some specs.
39
-
40
- == Support
41
-
42
- Find us in #prawn on irc.freenode.net
43
- <sandal> - Gregory Brown
44
- <yob> - James Healy
45
- <bluejade> - Daniel Nelson
46
- <bradediger> - Brad Ediger
47
- <jonsgreen> - Jonathan Greenberg
48
-
49
- Otherwise, use the mailing list:
50
- http://groups.google.com/group/prawn-ruby
data/README DELETED
@@ -1,141 +0,0 @@
1
- = Prawn: Fast, Nimble PDF Generation For Ruby
2
-
3
- Prawn is a PDF writing library for Ruby designed to be tiny, fast, and nimble,
4
- just like the majestic sea creature.
5
-
6
- Development on this library was initially made possible thanks to
7
- the many people who donated to the Ruby Mendicant project:
8
- http://rubymendicant.wikidot.com
9
-
10
- The project is currently maintained by Gregory Brown, with lots of help from
11
- Prawn's core developers and the community.
12
-
13
- == Quick Start
14
-
15
- Getting started with Prawn can be as simple as:
16
-
17
- require 'prawn'
18
- pdf = Prawn::Document.new
19
- pdf.text("Prawn Rocks")
20
- pdf.render_file('prawn.pdf')
21
-
22
- But prawn can do a lot more:
23
-
24
- ===Any page size you can think of
25
-
26
- Prawn::Document.new('A0')
27
-
28
- ...gives you an _really_ big page.
29
-
30
- Prawn::Document.new(:page_size => [11.32, 8.49],
31
- :page_layout => :portrait)
32
-
33
- ...giving you a postage stamp.
34
-
35
- {Learn more}[link:classes/Prawn/Document.html]
36
-
37
- ===Multiple Font Handling with UTF-8 Support
38
-
39
- pdf.text("Prawn Rocks")
40
- pdf.font("/myfont.ttf")
41
- pdf.text("Prawn still rocks in a different font")
42
-
43
- ...allowing you to use any font you want.
44
-
45
- {Learn more}[link:classes/Prawn/Font.html]
46
-
47
- ===Drawing graphics directly into the page
48
-
49
- Simple shapes:
50
-
51
- pdf.stroke do
52
- pdf.circle_at [100,100], :radius => 25
53
- pdf.rectangle [300,300], 100, 200
54
- end
55
-
56
- (note, you need to stroke the path to put "ink" there)
57
-
58
- {Learn more}[link:classes/Prawn/Graphics.html]
59
-
60
- ===Embedding JPEG and PNG Images Natively
61
-
62
- Reading an image directly from a file:
63
-
64
- prawn_logo = "#{Prawn::BASEDIR}/data/images/prawn_logo.png"
65
- pdf.image prawn_logo, :at => [50,450], :width => 450
66
-
67
- Or reading it from an IO stream:
68
-
69
- require "open-uri"
70
- pdf.image open("http://prawn.majesticseacreature.com/media/prawn_logo.png")
71
-
72
- {Learn more}[link:classes/Prawn/Images.html]
73
-
74
- ===Measurement Conversion Tools for Your Sanity
75
-
76
- Prawn deals exclusively in PDF points... which work out to about 2.83464567mm...
77
- don't try and do it in your head, instead, let Prawn help you:
78
-
79
- require "prawn/measurement_extensions"
80
-
81
- Prawn::Document.generate(:page_layout => :portrait,
82
- :left_margin => 10.mm, # different
83
- :right_margin => 1.cm, # units
84
- :top_margin => 0.1.dm, # work
85
- :bottom_margin => 0.01.m, # well
86
- :page_size => 'A4') do
87
- text "Prawn Rocks"
88
- end
89
-
90
- {Learn more}[link:classes/Prawn/Measurements.html]
91
-
92
- ===Document Security, Permissions, and Encryption
93
-
94
- See examples/security/ for example code, such as this:
95
-
96
- require 'prawn/security'
97
-
98
- Prawn::Document.generate("hello_foo.pdf") do
99
- text "Hello, world!"
100
- encrypt_document :user_password => 'foo', :owner_password => 'bar',
101
- :permissions => { :print_document => false }
102
- end
103
-
104
- This creates a document that requires the password 'foo' to be opened,
105
- and cannot be printed without entering the owner password 'bar'.
106
-
107
- If you want to prohibit most anyone from performing a certain activity, you can
108
- pass :owner_password => :random to generate a probably-unguessable owner
109
- password.
110
-
111
- == Resources
112
-
113
- === Examples:
114
-
115
- http://github.com/sandal/prawn/tree/stable/examples
116
-
117
- === Bug Tracker:
118
-
119
- http://github.com/sandal/prawn/issues
120
-
121
- === Source Code:
122
-
123
- http://github.com/sandal/prawn
124
-
125
- === Mailing List:
126
-
127
- http://groups.google.com/group/prawn-ruby
128
-
129
- === IRC:
130
-
131
- Find us in #prawn on irc.freenode.net
132
- Gregory Brown: <sandal>
133
- James Healy: <yob>
134
- Brad Ediger: <bradediger>
135
- Daniel Nelson: <bluejade>
136
- Jonathan Greenberg: <jonsgreen>
137
-
138
- == Notes to Developers:
139
-
140
- See HACKING file for details on getting set up with a local build.
141
-
Binary file
Binary file
Binary file
Binary file
Binary file
Binary file
Binary file
Binary file
data/data/images/dice.dat DELETED
Binary file
Binary file
Binary file
Binary file
@@ -1,44 +0,0 @@
1
- # encoding: utf-8
2
- #
3
- # This example demonstrates the basic functionality of Prawn's bounding boxes.
4
- # Note that top level bounding boxes are positioned relative to the margin_box.
5
- #
6
- require File.expand_path(File.join(File.dirname(__FILE__),
7
- %w[.. example_helper]))
8
-
9
- Prawn::Document.generate("bounding_boxes.pdf") do
10
-
11
- # Generates a box with a top-left of [100,600] and a top-right of [300,600]
12
- # The box automatically expands as the cursor moves down the page. Notice
13
- # that the final coordinates are outlined by a top and bottom line drawn
14
- # relatively using calculations from +bounds+.
15
- #
16
- bounding_box [100,600], :width => 200 do
17
- move_down 10
18
- text "The rain in spain falls mainly on the plains " * 5
19
- move_down 20
20
- stroke do
21
- line bounds.top_left, bounds.top_right
22
- line bounds.bottom_left, bounds.bottom_right
23
- end
24
- end
25
-
26
- # Generates a bounding box from [100, cursor], [300, cursor - 200],
27
- # where cursor is the current y position.
28
- #
29
- bounding_box [100,cursor], :width => 200, :height => 200 do
30
- stroke do
31
- circle [100,100], 100
32
- line bounds.top_left, bounds.bottom_right
33
- line bounds.top_right, bounds.bottom_left
34
- end
35
-
36
- # Generates a nested bonding box and strokes its boundaries. Note that
37
- # this box is anchored relative to its parent bounding box, not the
38
- # margin_box
39
- bounding_box [50,150], :width => 100, :height => 100 do
40
- stroke_bounds
41
- end
42
- end
43
-
44
- end
@@ -1,35 +0,0 @@
1
- # encoding: utf-8
2
- #
3
- # This example demonstrates the basic functionality of Prawn's bounding boxes.
4
- # Note that top level bounding boxes are positioned relative to the margin_box.
5
- #
6
- require File.expand_path(File.join(File.dirname(__FILE__),
7
- %w[.. example_helper]))
8
-
9
- Prawn::Document.generate("indentation.pdf") do
10
-
11
- text "No indentation"
12
- indent(20) do
13
- text "Some indentation"
14
- # Generates a box with a top-left of [100,600] and a top-right of [300,600]
15
- # The box automatically expands as the cursor moves down the page. Notice
16
- # that the final coordinates are outlined by a top and bottom line drawn
17
- # relatively using calculations from +bounds+.
18
- #
19
- bounding_box [100,600], :width => 200 do
20
- text "A little more indentation"
21
- indent(20) do
22
- text "And some more indentation"
23
- indent(20) do
24
- text "And some deeper indentation"
25
- end
26
- end
27
- end
28
- text "Some indentation"
29
- end
30
- indent(10) do
31
- text "A bit of indentation"
32
- end
33
-
34
- text "No indentation"
35
- end
@@ -1,37 +0,0 @@
1
- # encoding: utf-8
2
- #
3
- # This example is mostly just for fun, and shows how nested bounding boxes
4
- # can simplify calculations. See the other files in examples/bounding_box
5
- # for more basic uses.
6
-
7
- require File.expand_path(File.join(File.dirname(__FILE__),
8
- %w[.. example_helper]))
9
-
10
- class Array
11
- def combine(arr)
12
- output = []
13
- self.each do |i1|
14
- arr.each do |i2|
15
- output += [[i1,i2]]
16
- end
17
- end
18
- output
19
- end
20
- end
21
-
22
- def recurse_bounding_box(pdf, max_depth=5, depth=1)
23
- box = pdf.bounds
24
- width = (box.width-15)/2
25
- height = (box.height-15)/2
26
- left_top_corners = [5, box.right-width-5].combine [box.top-5, height+5]
27
- left_top_corners.each do |lt|
28
- pdf.bounding_box(lt, :width=>width, :height=>height) do
29
- pdf.stroke_bounds
30
- recurse_bounding_box(pdf, max_depth, depth+1) if depth<max_depth
31
- end
32
- end
33
- end
34
-
35
- Prawn::Document.generate("russian_boxes.pdf") do |pdf|
36
- recurse_bounding_box(pdf)
37
- end
@@ -1,68 +0,0 @@
1
- # encoding: utf-8
2
- #
3
- # This example demonstrates how nested bounding boxes work when the outer box is
4
- # stretchy and includes several inner boxes of different sizes.
5
-
6
- require File.expand_path(File.join(File.dirname(__FILE__),
7
- %w[.. example_helper]))
8
-
9
- Prawn::Document.generate("stretched_nesting.pdf", :page_layout => :landscape) do
10
-
11
- def stroke_dashed_bounds
12
- dash(1)
13
- stroke_bounds
14
- undash
15
- end
16
-
17
- bounding_box [100,400], :width => 500 do
18
-
19
- bounding_box [0, bounds.top], :width => 200, :height => 100 do
20
- stroke_bounds
21
- end
22
-
23
- bounding_box [200, bounds.top], :width => 150 do
24
- indent(5) do
25
- text "This box is longest, so it stretches the parent box. \n"*5
26
- end
27
- end
28
-
29
- bounding_box [350, bounds.top], :width => 150 do
30
- text "I AM SANTA CLAUS!!!"
31
- end
32
-
33
- stroke_dashed_bounds
34
-
35
- end
36
-
37
- bounding_box [100, 250], :width => 500 do
38
-
39
- bounding_box [0, bounds.top], :width => 100, :height => 100 do
40
- text "1"
41
- stroke_bounds
42
- end
43
-
44
- bounding_box [125, bounds.top], :width => 50, :height => 25 do
45
- text "2"
46
- stroke_bounds
47
- end
48
-
49
- bounding_box [200, bounds.top - 50], :width => 50, :height => 125 do
50
- text "3"
51
- stroke_bounds
52
- end
53
-
54
- bounding_box [350, bounds.top - 100], :width => 20, :height => 20 do
55
- text "4"
56
- stroke_bounds
57
- end
58
-
59
- bounding_box [400, bounds.height - 150], :width => 100, :height => 100 do
60
- text "5"
61
- stroke_bounds
62
- end
63
-
64
- stroke_dashed_bounds
65
-
66
- end
67
-
68
- end
@@ -1,8 +0,0 @@
1
- $LOAD_PATH.unshift(File.join(File.dirname(__FILE__), '..', 'lib'))
2
- require 'rubygems'
3
- require 'prawn'
4
- require 'prawn/security'
5
- require "prawn/layout"
6
-
7
-
8
- Prawn.debug = true
@@ -1,24 +0,0 @@
1
- # encoding: utf-8
2
- #
3
- # This example demonstrates the use of the new :background option when
4
- # generating a new Document. Image is assumed to be pre-fit for your page
5
- # size, and will not be rescaled.
6
- #
7
- require File.expand_path(File.join(File.dirname(__FILE__),
8
- %w[.. example_helper]))
9
-
10
- img = "#{Prawn::BASEDIR}/data/images/letterhead.jpg"
11
-
12
- Prawn::Document.generate("background.pdf", :background => img, :margin => 100) do
13
- text "My report caption", :size => 18, :align => :right
14
-
15
- move_down font.height * 2
16
-
17
- text "Here is my text explaning this report. " * 20,
18
- :size => 12, :align => :left, :leading => 2
19
-
20
- move_down font.height
21
-
22
- text "I'm using a soft background. " * 40,
23
- :size => 12, :align => :left, :leading => 2
24
- end
@@ -1,16 +0,0 @@
1
- # encoding: utf-8
2
- #
3
- # Demonstrates how to enable absolute positioning in Prawn by temporarily
4
- # removing the margin_box via Document#canvas()
5
- #
6
- require File.expand_path(File.join(File.dirname(__FILE__),
7
- %w[.. example_helper]))
8
-
9
- Prawn::Document.generate("canvas.pdf") do
10
- canvas do
11
- text "This text should appear at the absolute top left"
12
-
13
- # stroke a line to show that the relative coordinates are the same as absolute
14
- stroke_line [bounds.left,bounds.bottom], [bounds.right,bounds.top]
15
- end
16
- end
@@ -1,38 +0,0 @@
1
- require File.expand_path(File.join(File.dirname(__FILE__),
2
- %w[.. example_helper]))
3
-
4
- # Ex. Generate a roster of meeting attendees given a set of meetings.
5
- # Attendees for a meeting may overflow to accross page boundaries but
6
- # each meeting starts on a separate page. Each page for any given
7
- # meeting will have the heading for that meeting.
8
-
9
- #dummying up some meetings
10
- meetings = []
11
- 5.times do |i|
12
- meetings << "Meeting number #{i}"
13
- end
14
-
15
- Prawn::Document.generate('context_sensitive_headers.pdf', :margin => [100, 100], :skip_page_creation => true) do
16
- meetings.each_with_index do |meeting,i|
17
-
18
- create_stamp(meeting.to_s) do
19
- canvas do
20
- text_box("header for #{meeting}",
21
- :at => [bounds.left + 50, bounds.top - 20],
22
- :height => 50,
23
- :width => margin_box.width)
24
- end
25
- end
26
- on_page_create { stamp(meeting.to_s) }
27
-
28
- start_new_page
29
-
30
- #simulate some meetings with content over multiple pages
31
- (15 + 20*i).times do |i|
32
- text "#{meeting} attendee #{i}"
33
- end
34
-
35
- end
36
-
37
- end
38
-
@@ -1,12 +0,0 @@
1
- require File.expand_path(File.join(File.dirname(__FILE__),
2
- %w[.. example_helper]))
3
-
4
- Prawn::Document.generate('float.pdf') do
5
- float do
6
- bounding_box [bounds.width / 2.0, bounds.top], :width => 100 do
7
- text "Hello world. " * 50
8
- end
9
- end
10
-
11
- text "Hello world again"
12
- end
@@ -1,37 +0,0 @@
1
- # encoding: utf-8
2
- #
3
- # This demonstrates the Prawn options for document and page margin, similar to CSS shorthand.
4
- #
5
- require File.expand_path(File.join(File.dirname(__FILE__),
6
- %w[.. example_helper]))
7
-
8
- LOREM = ("Lorem ipsum dolor sit amet, consectetur adipisicing elit, "+
9
- "sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. "+
10
- "Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris "+
11
- "nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in "+
12
- "reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla "+
13
- "pariatur. Excepteur sint occaecat cupidatat non proident, sunt in " +
14
- "culpa qui officia deserunt mollit anim id est laborum. ") * 20
15
-
16
- Prawn::Document.generate("margin.pdf", :margin => 100) do |pdf|
17
-
18
- pdf.text "100 on all sides", :style => :bold
19
- pdf.text LOREM
20
-
21
- pdf.start_new_page(:margin => 100, :left_margin => 0)
22
- pdf.text "100 on all sides but 0 on the left", :style => :bold
23
- pdf.text LOREM
24
-
25
- pdf.start_new_page(:margin => [100, 0])
26
- pdf.text "100 top and bottom, 0 left and right.", :style => :bold
27
- pdf.text LOREM
28
-
29
- pdf.start_new_page(:margin => [100, 0, 50])
30
- pdf.text "100 top, 0 left and right, 50 bottom.", :style => :bold
31
- pdf.text LOREM
32
-
33
- pdf.start_new_page(:margin => [0, 50, 100, 150])
34
- pdf.text "0 top, 50 right, 100 bottom, 150 left.", :style => :bold
35
- pdf.text LOREM
36
-
37
- end
@@ -1,52 +0,0 @@
1
- # encoding: utf-8
2
- #
3
- # Generates a ruler and also demonstrates prawn/measurement_extensions.
4
- # It's better to run this example and examine its output than to worry about
5
- # its particular implementation, though some might find that interesting as
6
- # well.
7
- #
8
- require File.expand_path(File.join(File.dirname(__FILE__),
9
- %w[.. example_helper]))
10
-
11
- require "prawn/measurement_extensions"
12
-
13
- # this makes the following units available (Millimeters, Centimeters, Decimeters, Meters, Inches, Foot, Yards, Points)
14
- # Methodname is the common abbravation for the unit (mm, cm, dm, m, in, ft, yd, pt)
15
- # Usage: '10.mm'.
16
- # This converts 10mm to PDF points, which Prawn uses internally.
17
-
18
- pdf = Prawn::Document.new(
19
- :page_size => "A4",
20
- :left_margin => 10.mm, # different
21
- :right_margin => 1.cm, # units
22
- :top_margin => 0.1.dm, # work
23
- :bottom_margin => 0.01.m) # well
24
-
25
- pdf.font_size = 6
26
- pdf.line_width = 0.05
27
-
28
- units_long = %w[Millimeters Centimeters Decimeters Inches Foot Points]
29
- units = %w[mm cm dm in ft pt]
30
- offset_multiplier = 2.cm
31
- temp = "Units\n"
32
-
33
- units.each_with_index do |unit, unit_index| #iterate through all units that make sense to display on a sheet of paper
34
- one_unit_in_pt = eval "1.#{unit}" # calc the width of one unit
35
- temp << "1#{unit} => #{one_unit_in_pt}pt\n" #puts converted unit in points
36
-
37
- offset = offset_multiplier * unit_index
38
- pdf.draw_text units[unit_index], :at => [offset + 0.5.mm, pdf.bounds.top - 2.mm]
39
-
40
- pdf.stroke_line(offset, pdf.bounds.top, offset, pdf.bounds.bottom)
41
-
42
- 0.upto(((pdf.bounds.height - 5.mm) / one_unit_in_pt).to_i) do |i| # checks, how many strokes can be drawn
43
- pdf.stroke_line(offset, i * one_unit_in_pt, (i % 5 == 0 ? 6.mm : 3.mm) + offset, i * one_unit_in_pt) # every fifth stroke is twice as large like on a real ruler
44
- pdf.draw_text "#{i}#{unit}", :at => [7.mm + offset, i * one_unit_in_pt] unless unit == "mm" && i % 5 != 0 || unit == "pt" && i % 10 != 0 # avoid text too close to each other
45
- end
46
- end
47
-
48
- pdf.text_box temp,
49
- :width => 5.cm, :height => pdf.font.height * units_long.length,
50
- :at => [offset_multiplier * units_long.length, pdf.bounds.top]
51
-
52
- pdf.render_file "measurement_units.pdf"
@@ -1,17 +0,0 @@
1
- # encoding: utf-8
2
- #
3
- # Demonstrates how to set metadata properties via the info option
4
- # It allows one to specify no standard properties
5
- #
6
- require File.expand_path(File.join(File.dirname(__FILE__),
7
- %w[.. example_helper]))
8
-
9
- Prawn::Document.generate "metadata-info.pdf",
10
- :info => {
11
- :Title => "My title", :Author => "John Doe", :Subject => "My Subject",
12
- :Keywords => "test metadata ruby pdf dry", :Creator => "ACME Soft App",
13
- :Producer => "Prawn", :CreationDate => Time.now, :Grok => "Test Property"
14
- } do
15
- text "This is a test of setting metadata properties via the info option"
16
- text "It allows one to specify no standard properties like 'Grok'"
17
- end
@@ -1,19 +0,0 @@
1
- # encoding: utf-8
2
- #
3
- # This demonstrates that Prawn can modify page size, margins and layout for
4
- # each individual page, via Document#start_new_page()
5
- #
6
- require File.expand_path(File.join(File.dirname(__FILE__),
7
- %w[.. example_helper]))
8
-
9
- Prawn::Document.generate("multi-layout.pdf", :page_layout => :landscape) do |pdf|
10
- pdf.text "This is on a landscaped page"
11
- pdf.start_new_page(:layout => :portrait)
12
- pdf.text "This is on a portrait page"
13
- pdf.start_new_page(:size => "LEGAL")
14
- pdf.text "This is on legal paper size"
15
- pdf.start_new_page(:left_margin => 150, :right_margin => 150)
16
- pdf.text "This page has very wide left and right margins, causing a squeeze"
17
- pdf.start_new_page(:margin => 300, :right_margin => 0)
18
- pdf.text "This page has even wider margins on all sides except for the right side, where it's 0"
19
- end