prawn 0.11.1 → 0.15.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/.yardopts +10 -0
- data/COPYING +2 -2
- data/GPLv2 +340 -0
- data/GPLv3 +674 -0
- data/Gemfile +11 -0
- data/LICENSE +1 -1
- data/Rakefile +29 -38
- data/data/images/16bit.alpha +0 -0
- data/data/images/16bit.color +0 -0
- data/data/images/dice.alpha +0 -0
- data/data/images/dice.color +0 -0
- data/data/images/indexed_color.dat +0 -0
- data/data/images/indexed_color.png +0 -0
- data/data/images/page_white_text.alpha +0 -0
- data/data/images/page_white_text.color +0 -0
- data/data/pdfs/nested_pages.pdf +13 -13
- data/lib/prawn/document/bounding_box.rb +87 -12
- data/lib/prawn/document/column_box.rb +57 -28
- data/lib/prawn/document/graphics_state.rb +11 -74
- data/lib/prawn/document/internals.rb +25 -23
- data/lib/prawn/document/snapshot.rb +11 -8
- data/lib/prawn/document/span.rb +12 -10
- data/lib/prawn/document.rb +250 -194
- data/lib/prawn/encoding.rb +9 -10
- data/lib/prawn/errors.rb +18 -29
- data/lib/prawn/font/afm.rb +52 -41
- data/lib/prawn/font/dfont.rb +4 -3
- data/lib/prawn/font/ttf.rb +44 -48
- data/lib/prawn/font.rb +138 -88
- data/lib/prawn/font_metric_cache.rb +47 -0
- data/lib/prawn/graphics/cap_style.rb +4 -3
- data/lib/prawn/graphics/color.rb +13 -5
- data/lib/prawn/graphics/dash.rb +53 -31
- data/lib/prawn/graphics/join_style.rb +9 -7
- data/lib/prawn/graphics/patterns.rb +138 -0
- data/lib/prawn/graphics/transformation.rb +10 -9
- data/lib/prawn/graphics/transparency.rb +3 -1
- data/lib/prawn/graphics.rb +316 -61
- data/lib/prawn/image_handler.rb +36 -0
- data/lib/prawn/images/image.rb +49 -0
- data/lib/prawn/images/jpg.rb +21 -15
- data/lib/prawn/images/png.rb +62 -119
- data/lib/prawn/images.rb +89 -108
- data/lib/prawn/layout/grid.rb +66 -54
- data/lib/prawn/layout.rb +10 -15
- data/lib/prawn/measurement_extensions.rb +10 -6
- data/lib/prawn/measurements.rb +27 -21
- data/lib/prawn/outline.rb +6 -308
- data/lib/prawn/repeater.rb +11 -9
- data/lib/prawn/security/arcfour.rb +1 -0
- data/lib/prawn/security.rb +55 -33
- data/lib/prawn/soft_mask.rb +96 -0
- data/lib/prawn/stamp.rb +5 -3
- data/lib/prawn/table/cell/image.rb +69 -0
- data/lib/prawn/table/cell/in_table.rb +4 -2
- data/lib/prawn/table/cell/span_dummy.rb +93 -0
- data/lib/prawn/table/cell/subtable.rb +2 -2
- data/lib/prawn/table/cell/text.rb +44 -26
- data/lib/prawn/table/cell.rb +302 -50
- data/lib/prawn/table/cells.rb +147 -49
- data/lib/prawn/table/column_width_calculator.rb +61 -0
- data/lib/prawn/table.rb +297 -118
- data/lib/prawn/text/box.rb +21 -5
- data/lib/prawn/text/formatted/arranger.rb +290 -0
- data/lib/prawn/text/formatted/box.rb +103 -59
- data/lib/prawn/text/formatted/fragment.rb +34 -23
- data/lib/prawn/text/formatted/line_wrap.rb +266 -0
- data/lib/prawn/text/formatted/parser.rb +15 -5
- data/lib/prawn/text/formatted/wrap.rb +150 -0
- data/lib/prawn/text/formatted.rb +5 -4
- data/lib/prawn/text.rb +38 -24
- data/lib/prawn/utilities.rb +46 -0
- data/lib/prawn.rb +85 -20
- data/manual/basic_concepts/adding_pages.rb +27 -0
- data/manual/basic_concepts/basic_concepts.rb +34 -0
- data/manual/basic_concepts/creation.rb +39 -0
- data/manual/basic_concepts/cursor.rb +33 -0
- data/manual/basic_concepts/measurement.rb +25 -0
- data/manual/basic_concepts/origin.rb +38 -0
- data/manual/basic_concepts/other_cursor_helpers.rb +40 -0
- data/manual/bounding_box/bounding_box.rb +39 -0
- data/manual/bounding_box/bounds.rb +49 -0
- data/manual/bounding_box/canvas.rb +24 -0
- data/manual/bounding_box/creation.rb +23 -0
- data/manual/bounding_box/indentation.rb +46 -0
- data/manual/bounding_box/nesting.rb +45 -0
- data/manual/bounding_box/russian_boxes.rb +40 -0
- data/manual/bounding_box/stretchy.rb +31 -0
- data/manual/document_and_page_options/background.rb +27 -0
- data/manual/document_and_page_options/document_and_page_options.rb +32 -0
- data/manual/document_and_page_options/metadata.rb +23 -0
- data/manual/document_and_page_options/page_margins.rb +38 -0
- data/manual/document_and_page_options/page_size.rb +34 -0
- data/manual/document_and_page_options/print_scaling.rb +20 -0
- data/manual/example_file.rb +111 -0
- data/manual/example_helper.rb +411 -0
- data/manual/example_package.rb +53 -0
- data/manual/example_section.rb +46 -0
- data/manual/graphics/circle_and_ellipse.rb +22 -0
- data/manual/graphics/color.rb +24 -0
- data/manual/graphics/common_lines.rb +30 -0
- data/manual/graphics/fill_and_stroke.rb +42 -0
- data/manual/graphics/fill_rules.rb +37 -0
- data/manual/graphics/gradients.rb +37 -0
- data/manual/graphics/graphics.rb +58 -0
- data/manual/graphics/helper.rb +24 -0
- data/manual/graphics/line_width.rb +35 -0
- data/manual/graphics/lines_and_curves.rb +41 -0
- data/manual/graphics/polygon.rb +29 -0
- data/manual/graphics/rectangle.rb +21 -0
- data/manual/graphics/rotate.rb +28 -0
- data/manual/graphics/scale.rb +41 -0
- data/manual/graphics/soft_masks.rb +46 -0
- data/manual/graphics/stroke_cap.rb +31 -0
- data/manual/graphics/stroke_dash.rb +48 -0
- data/manual/graphics/stroke_join.rb +30 -0
- data/manual/graphics/translate.rb +29 -0
- data/manual/graphics/transparency.rb +35 -0
- data/manual/images/absolute_position.rb +23 -0
- data/manual/images/fit.rb +21 -0
- data/manual/images/horizontal.rb +25 -0
- data/manual/images/images.rb +40 -0
- data/manual/images/plain_image.rb +18 -0
- data/manual/images/scale.rb +22 -0
- data/manual/images/vertical.rb +28 -0
- data/manual/images/width_and_height.rb +25 -0
- data/manual/layout/boxes.rb +27 -0
- data/manual/layout/content.rb +25 -0
- data/manual/layout/layout.rb +28 -0
- data/manual/layout/simple_grid.rb +23 -0
- data/manual/manual/cover.rb +36 -0
- data/manual/manual/foreword.rb +85 -0
- data/manual/manual/how_to_read_this_manual.rb +41 -0
- data/manual/manual/manual.rb +34 -0
- data/manual/outline/add_subsection_to.rb +61 -0
- data/manual/outline/insert_section_after.rb +47 -0
- data/manual/outline/outline.rb +32 -0
- data/manual/outline/sections_and_pages.rb +67 -0
- data/manual/repeatable_content/page_numbering.rb +54 -0
- data/manual/repeatable_content/repeatable_content.rb +31 -0
- data/manual/repeatable_content/repeater.rb +55 -0
- data/manual/repeatable_content/stamp.rb +41 -0
- data/manual/security/encryption.rb +31 -0
- data/manual/security/permissions.rb +38 -0
- data/manual/security/security.rb +28 -0
- data/manual/syntax_highlight.rb +52 -0
- data/manual/table/basic_block.rb +53 -0
- data/manual/table/before_rendering_page.rb +26 -0
- data/manual/table/cell_border_lines.rb +24 -0
- data/manual/table/cell_borders_and_bg.rb +31 -0
- data/manual/table/cell_dimensions.rb +30 -0
- data/manual/table/cell_text.rb +38 -0
- data/manual/table/column_widths.rb +30 -0
- data/manual/table/content_and_subtables.rb +39 -0
- data/manual/table/creation.rb +27 -0
- data/manual/table/filtering.rb +36 -0
- data/manual/table/flow_and_header.rb +17 -0
- data/manual/table/image_cells.rb +33 -0
- data/manual/table/position.rb +29 -0
- data/manual/table/row_colors.rb +20 -0
- data/manual/table/span.rb +30 -0
- data/manual/table/style.rb +22 -0
- data/manual/table/table.rb +52 -0
- data/manual/table/width.rb +27 -0
- data/manual/text/alignment.rb +44 -0
- data/manual/text/color.rb +24 -0
- data/manual/text/column_box.rb +32 -0
- data/manual/text/fallback_fonts.rb +37 -0
- data/manual/text/font.rb +41 -0
- data/manual/text/font_size.rb +45 -0
- data/manual/text/font_style.rb +23 -0
- data/manual/text/formatted_callbacks.rb +60 -0
- data/manual/text/formatted_text.rb +54 -0
- data/manual/text/free_flowing_text.rb +51 -0
- data/manual/text/group.rb +31 -0
- data/manual/text/inline.rb +43 -0
- data/manual/text/kerning_and_character_spacing.rb +39 -0
- data/manual/text/leading.rb +25 -0
- data/manual/text/line_wrapping.rb +41 -0
- data/manual/text/paragraph_indentation.rb +26 -0
- data/manual/text/positioned_text.rb +38 -0
- data/manual/text/registering_families.rb +48 -0
- data/manual/text/rendering_and_color.rb +37 -0
- data/manual/text/right_to_left_text.rb +43 -0
- data/manual/text/rotation.rb +43 -0
- data/manual/text/single_usage.rb +37 -0
- data/manual/text/text.rb +75 -0
- data/manual/text/text_box_excess.rb +32 -0
- data/manual/text/text_box_extensions.rb +45 -0
- data/manual/text/text_box_overflow.rb +44 -0
- data/manual/text/utf8.rb +28 -0
- data/{examples/m17n → manual/text}/win_ansi_charset.rb +14 -10
- data/prawn.gemspec +27 -17
- data/spec/acceptance/png.rb +23 -0
- data/spec/annotations_spec.rb +16 -32
- data/spec/bounding_box_spec.rb +284 -2
- data/spec/cell_spec.rb +169 -38
- data/spec/column_box_spec.rb +65 -0
- data/spec/data/curves.pdf +66 -0
- data/spec/destinations_spec.rb +5 -5
- data/spec/document_spec.rb +212 -113
- data/spec/extensions/encoding_helpers.rb +9 -0
- data/spec/extensions/mocha.rb +2 -3
- data/spec/font_metric_cache_spec.rb +52 -0
- data/spec/font_spec.rb +205 -95
- data/spec/formatted_text_arranger_spec.rb +43 -43
- data/spec/formatted_text_box_spec.rb +63 -24
- data/spec/formatted_text_fragment_spec.rb +8 -8
- data/spec/graphics_spec.rb +175 -68
- data/spec/grid_spec.rb +26 -15
- data/spec/image_handler_spec.rb +54 -0
- data/spec/images_spec.rb +58 -30
- data/spec/inline_formatted_text_parser_spec.rb +73 -19
- data/spec/jpg_spec.rb +4 -4
- data/spec/line_wrap_spec.rb +28 -28
- data/spec/measurement_units_spec.rb +6 -6
- data/spec/object_store_spec.rb +17 -106
- data/spec/outline_spec.rb +103 -63
- data/spec/png_spec.rb +25 -25
- data/spec/reference_spec.rb +8 -65
- data/spec/repeater_spec.rb +25 -11
- data/spec/security_spec.rb +44 -12
- data/spec/snapshot_spec.rb +38 -6
- data/spec/soft_mask_spec.rb +117 -0
- data/spec/span_spec.rb +10 -15
- data/spec/spec_helper.rb +32 -8
- data/spec/stamp_spec.rb +29 -30
- data/spec/stroke_styles_spec.rb +36 -18
- data/spec/table/span_dummy_spec.rb +17 -0
- data/spec/table_spec.rb +850 -104
- data/spec/text_at_spec.rb +19 -33
- data/spec/text_box_spec.rb +117 -64
- data/spec/text_rendering_mode_spec.rb +5 -5
- data/spec/text_spacing_spec.rb +20 -2
- data/spec/text_spec.rb +111 -59
- data/spec/transparency_spec.rb +5 -5
- metadata +477 -328
- data/HACKING +0 -50
- data/README +0 -141
- data/data/fonts/Action Man.dfont +0 -0
- data/data/fonts/Activa.ttf +0 -0
- data/data/fonts/Chalkboard.ttf +0 -0
- data/data/fonts/DejaVuSans.ttf +0 -0
- data/data/fonts/Dustismo_Roman.ttf +0 -0
- data/data/fonts/comicsans.ttf +0 -0
- data/data/fonts/gkai00mp.ttf +0 -0
- data/data/images/16bit.dat +0 -0
- data/data/images/dice.dat +0 -0
- data/data/images/page_white_text.dat +0 -0
- data/data/images/rails.dat +0 -0
- data/data/images/rails.png +0 -0
- data/examples/bounding_box/bounding_boxes.rb +0 -44
- data/examples/bounding_box/indentation.rb +0 -35
- data/examples/bounding_box/russian_boxes.rb +0 -37
- data/examples/bounding_box/stretched_nesting.rb +0 -68
- data/examples/example_helper.rb +0 -8
- data/examples/general/background.rb +0 -24
- data/examples/general/canvas.rb +0 -16
- data/examples/general/context_sensitive_headers.rb +0 -38
- data/examples/general/float.rb +0 -12
- data/examples/general/margin.rb +0 -37
- data/examples/general/measurement_units.rb +0 -52
- data/examples/general/metadata-info.rb +0 -17
- data/examples/general/multi_page_layout.rb +0 -19
- data/examples/general/outlines.rb +0 -67
- data/examples/general/page_geometry.rb +0 -32
- data/examples/general/page_numbering.rb +0 -40
- data/examples/general/page_templates.rb +0 -20
- data/examples/general/repeaters.rb +0 -48
- data/examples/general/stamp.rb +0 -42
- data/examples/general/templates.rb +0 -14
- data/examples/graphics/basic_images.rb +0 -24
- data/examples/graphics/cmyk.rb +0 -13
- data/examples/graphics/curves.rb +0 -12
- data/examples/graphics/gradient.rb +0 -23
- data/examples/graphics/hexagon.rb +0 -14
- data/examples/graphics/image_fit.rb +0 -16
- data/examples/graphics/image_flow.rb +0 -38
- data/examples/graphics/image_position.rb +0 -18
- data/examples/graphics/line.rb +0 -33
- data/examples/graphics/png_types.rb +0 -23
- data/examples/graphics/polygons.rb +0 -17
- data/examples/graphics/remote_images.rb +0 -13
- data/examples/graphics/rounded_polygons.rb +0 -20
- data/examples/graphics/rounded_rectangle.rb +0 -21
- data/examples/graphics/ruport_style_helpers.rb +0 -20
- data/examples/graphics/stroke_bounds.rb +0 -21
- data/examples/graphics/stroke_cap_and_join.rb +0 -46
- data/examples/graphics/stroke_dash.rb +0 -43
- data/examples/graphics/transformations.rb +0 -53
- data/examples/graphics/transparency.rb +0 -27
- data/examples/grid/bounding_boxes.rb +0 -22
- data/examples/grid/column_gutter_grid.rb +0 -21
- data/examples/grid/multi_boxes.rb +0 -52
- data/examples/grid/show_grid.rb +0 -14
- data/examples/grid/simple_grid.rb +0 -21
- data/examples/m17n/chinese_text_wrapping.rb +0 -18
- data/examples/m17n/euro.rb +0 -16
- data/examples/m17n/full_win_ansi_character_list.rb +0 -20
- data/examples/m17n/sjis.rb +0 -29
- data/examples/m17n/utf8.rb +0 -14
- data/examples/security/hello_foo.rb +0 -9
- data/examples/table/bill.rb +0 -54
- data/examples/table/borders.rb +0 -25
- data/examples/table/cell.rb +0 -13
- data/examples/table/checkerboard.rb +0 -23
- data/examples/table/header.rb +0 -15
- data/examples/table/inline_format_table.rb +0 -13
- data/examples/table/multi_page_table.rb +0 -10
- data/examples/table/simple_table.rb +0 -25
- data/examples/table/subtable.rb +0 -13
- data/examples/table/widths.rb +0 -21
- data/examples/text/alignment.rb +0 -19
- data/examples/text/character_spacing.rb +0 -13
- data/examples/text/dfont.rb +0 -49
- data/examples/text/family_based_styling.rb +0 -25
- data/examples/text/font_calculations.rb +0 -92
- data/examples/text/font_size.rb +0 -34
- data/examples/text/hyphenation.rb +0 -45
- data/examples/text/indent_paragraphs.rb +0 -24
- data/examples/text/inline_format.rb +0 -104
- data/examples/text/kerning.rb +0 -31
- data/examples/text/rendering_mode.rb +0 -21
- data/examples/text/rotated.rb +0 -99
- data/examples/text/shaped_text_box.rb +0 -32
- data/examples/text/simple_text.rb +0 -18
- data/examples/text/simple_text_ttf.rb +0 -18
- data/examples/text/span.rb +0 -30
- data/examples/text/text_box.rb +0 -90
- data/examples/text/text_box_returning_excess.rb +0 -52
- data/examples/text/text_flow.rb +0 -68
- data/lib/prawn/compatibility.rb +0 -51
- data/lib/prawn/core/annotations.rb +0 -61
- data/lib/prawn/core/byte_string.rb +0 -9
- data/lib/prawn/core/destinations.rb +0 -90
- data/lib/prawn/core/document_state.rb +0 -78
- data/lib/prawn/core/literal_string.rb +0 -16
- data/lib/prawn/core/name_tree.rb +0 -165
- data/lib/prawn/core/object_store.rb +0 -264
- data/lib/prawn/core/page.rb +0 -213
- data/lib/prawn/core/pdf_object.rb +0 -108
- data/lib/prawn/core/reference.rb +0 -112
- data/lib/prawn/core/text/formatted/arranger.rb +0 -293
- data/lib/prawn/core/text/formatted/line_wrap.rb +0 -272
- data/lib/prawn/core/text/formatted/wrap.rb +0 -149
- data/lib/prawn/core/text.rb +0 -268
- data/lib/prawn/core.rb +0 -85
- data/lib/prawn/document/page_geometry.rb +0 -136
- data/lib/prawn/graphics/gradient.rb +0 -84
- data/spec/name_tree_spec.rb +0 -112
- data/spec/pdf_object_spec.rb +0 -170
- 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
|
-
|
data/data/fonts/Action Man.dfont
DELETED
Binary file
|
data/data/fonts/Activa.ttf
DELETED
Binary file
|
data/data/fonts/Chalkboard.ttf
DELETED
Binary file
|
data/data/fonts/DejaVuSans.ttf
DELETED
Binary file
|
Binary file
|
data/data/fonts/comicsans.ttf
DELETED
Binary file
|
data/data/fonts/gkai00mp.ttf
DELETED
Binary file
|
data/data/images/16bit.dat
DELETED
Binary file
|
data/data/images/dice.dat
DELETED
Binary file
|
Binary file
|
data/data/images/rails.dat
DELETED
Binary file
|
data/data/images/rails.png
DELETED
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
|
data/examples/example_helper.rb
DELETED
@@ -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
|
data/examples/general/canvas.rb
DELETED
@@ -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
|
-
|
data/examples/general/float.rb
DELETED
@@ -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
|
data/examples/general/margin.rb
DELETED
@@ -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
|