prawn 0.12.0 → 0.13.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/COPYING +2 -2
- data/Gemfile +18 -0
- data/LICENSE +1 -1
- data/README.md +17 -4
- data/Rakefile +18 -22
- data/data/images/indexed_color.dat +0 -0
- data/data/images/indexed_color.png +0 -0
- data/data/pdfs/nested_pages.pdf +13 -13
- data/lib/pdf/core.rb +35 -0
- data/lib/{prawn → pdf}/core/annotations.rb +6 -7
- data/lib/{prawn → pdf}/core/byte_string.rb +1 -1
- data/lib/{prawn → pdf}/core/destinations.rb +23 -23
- data/lib/{prawn → pdf}/core/document_state.rb +8 -8
- data/lib/pdf/core/filter_list.rb +51 -0
- data/lib/pdf/core/filters.rb +36 -0
- data/lib/pdf/core/graphics_state.rb +68 -0
- data/lib/{prawn → pdf}/core/literal_string.rb +1 -1
- data/lib/{prawn → pdf}/core/name_tree.rb +14 -2
- data/lib/{prawn → pdf}/core/object_store.rb +80 -24
- data/lib/pdf/core/outline.rb +315 -0
- data/lib/{prawn → pdf}/core/page.rb +23 -26
- data/lib/{prawn/document → pdf/core}/page_geometry.rb +11 -21
- data/lib/{prawn → pdf}/core/pdf_object.rb +48 -32
- data/lib/{prawn → pdf}/core/reference.rb +35 -44
- data/lib/pdf/core/stream.rb +98 -0
- data/lib/{prawn → pdf}/core/text.rb +24 -17
- data/lib/prawn.rb +95 -17
- data/lib/prawn/compatibility.rb +66 -26
- data/lib/prawn/document.rb +48 -30
- data/lib/prawn/document/bounding_box.rb +3 -3
- data/lib/prawn/document/column_box.rb +46 -8
- data/lib/prawn/document/graphics_state.rb +10 -73
- data/lib/prawn/document/internals.rb +24 -23
- data/lib/prawn/document/snapshot.rb +6 -7
- data/lib/prawn/document/span.rb +10 -10
- data/lib/prawn/encoding.rb +7 -7
- data/lib/prawn/errors.rb +18 -29
- data/lib/prawn/font.rb +64 -28
- data/lib/prawn/font/afm.rb +32 -74
- data/lib/prawn/font/dfont.rb +2 -2
- data/lib/prawn/font/ttf.rb +28 -57
- data/lib/prawn/font_metric_cache.rb +45 -0
- data/lib/prawn/graphics.rb +307 -41
- data/lib/prawn/graphics/cap_style.rb +3 -3
- data/lib/prawn/graphics/color.rb +12 -5
- data/lib/prawn/graphics/dash.rb +52 -31
- data/lib/prawn/graphics/join_style.rb +7 -7
- data/lib/prawn/graphics/patterns.rb +137 -0
- data/lib/prawn/graphics/transformation.rb +9 -9
- data/lib/prawn/graphics/transparency.rb +1 -1
- data/lib/prawn/image_handler.rb +30 -0
- data/lib/prawn/images.rb +86 -105
- data/lib/prawn/images/image.rb +48 -0
- data/lib/prawn/images/jpg.rb +14 -10
- data/lib/prawn/images/png.rb +50 -37
- data/lib/prawn/layout.rb +2 -2
- data/lib/prawn/layout/grid.rb +51 -51
- data/lib/prawn/measurement_extensions.rb +5 -5
- data/lib/prawn/measurements.rb +25 -21
- data/lib/prawn/outline.rb +4 -308
- data/lib/prawn/repeater.rb +8 -8
- data/lib/prawn/security.rb +50 -36
- data/lib/prawn/soft_mask.rb +94 -0
- data/lib/prawn/stamp.rb +3 -3
- data/lib/prawn/table.rb +292 -118
- data/lib/prawn/table/cell.rb +272 -45
- data/lib/prawn/table/cell/image.rb +70 -0
- data/lib/prawn/table/cell/in_table.rb +2 -2
- data/lib/prawn/table/cell/span_dummy.rb +92 -0
- data/lib/prawn/table/cell/subtable.rb +2 -2
- data/lib/prawn/table/cell/text.rb +42 -24
- data/lib/prawn/table/cells.rb +137 -48
- data/lib/prawn/text.rb +35 -23
- data/lib/prawn/text/box.rb +18 -5
- data/lib/prawn/text/formatted.rb +5 -4
- data/lib/prawn/text/formatted/arranger.rb +292 -0
- data/lib/prawn/text/formatted/box.rb +52 -13
- data/lib/prawn/text/formatted/fragment.rb +37 -22
- data/lib/prawn/text/formatted/line_wrap.rb +286 -0
- data/lib/prawn/text/formatted/parser.rb +14 -6
- data/lib/prawn/text/formatted/wrap.rb +151 -0
- data/lib/prawn/utilities.rb +44 -0
- 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 +31 -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/example_file.rb +116 -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 +28 -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 +35 -0
- data/manual/manual/foreword.rb +85 -0
- data/manual/manual/how_to_read_this_manual.rb +41 -0
- data/manual/manual/manual.rb +35 -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/templates/full_template.rb +25 -0
- data/manual/templates/page_template.rb +48 -0
- data/manual/templates/templates.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 +29 -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 +18 -12
- data/spec/acceptance/png.rb +23 -0
- data/spec/annotations_spec.rb +16 -32
- data/spec/bounding_box_spec.rb +128 -15
- data/spec/cell_spec.rb +169 -38
- data/spec/column_box_spec.rb +33 -0
- data/spec/destinations_spec.rb +5 -5
- data/spec/document_spec.rb +150 -104
- data/spec/extensions/encoding_helpers.rb +10 -0
- data/spec/extensions/mocha.rb +1 -0
- data/spec/filters_spec.rb +34 -0
- data/spec/font_metric_cache_spec.rb +52 -0
- data/spec/font_spec.rb +183 -97
- data/spec/formatted_text_arranger_spec.rb +43 -43
- data/spec/formatted_text_box_spec.rb +30 -20
- data/spec/formatted_text_fragment_spec.rb +8 -8
- data/spec/graphics_spec.rb +158 -69
- data/spec/grid_spec.rb +15 -15
- data/spec/image_handler_spec.rb +42 -0
- data/spec/images_spec.rb +49 -24
- data/spec/inline_formatted_text_parser_spec.rb +73 -19
- data/spec/jpg_spec.rb +4 -4
- data/spec/line_wrap_spec.rb +26 -26
- data/spec/measurement_units_spec.rb +6 -6
- data/spec/name_tree_spec.rb +21 -21
- data/spec/object_store_spec.rb +39 -39
- data/spec/outline_spec.rb +93 -53
- data/spec/pdf_object_spec.rb +88 -86
- data/spec/png_spec.rb +31 -28
- data/spec/reference_spec.rb +32 -32
- data/spec/repeater_spec.rb +25 -11
- data/spec/security_spec.rb +44 -12
- data/spec/snapshot_spec.rb +8 -9
- data/spec/soft_mask_spec.rb +117 -0
- data/spec/span_spec.rb +10 -15
- data/spec/spec_helper.rb +25 -8
- data/spec/stamp_spec.rb +29 -30
- data/spec/stream_spec.rb +58 -0
- data/spec/stroke_styles_spec.rb +36 -18
- data/spec/table/span_dummy_spec.rb +17 -0
- data/spec/table_spec.rb +697 -105
- data/spec/template_spec.rb +108 -54
- data/spec/text_at_spec.rb +18 -17
- data/spec/text_box_spec.rb +111 -62
- data/spec/text_rendering_mode_spec.rb +5 -5
- data/spec/text_spacing_spec.rb +4 -4
- data/spec/text_spec.rb +57 -49
- data/spec/transparency_spec.rb +5 -5
- metadata +421 -213
- 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/rails.dat +0 -0
- data/data/images/rails.png +0 -0
- data/examples/bounding_box/russian_boxes.rb +0 -37
- data/examples/example_helper.rb +0 -11
- data/examples/general/context_sensitive_headers.rb +0 -38
- data/examples/graphics/cmyk.rb +0 -13
- data/examples/graphics/gradient.rb +0 -23
- data/examples/graphics/png_types.rb +0 -23
- data/examples/graphics/remote_images.rb +0 -13
- data/examples/m17n/full_win_ansi_character_list.rb +0 -20
- data/examples/m17n/sjis.rb +0 -29
- data/examples/table/bill.rb +0 -54
- data/examples/table/header.rb +0 -15
- data/examples/text/font_calculations.rb +0 -92
- data/examples/text/hyphenation.rb +0 -45
- data/examples/text/indent_paragraphs.rb +0 -24
- data/lib/prawn/core.rb +0 -85
- data/lib/prawn/core/text/formatted/arranger.rb +0 -294
- data/lib/prawn/core/text/formatted/line_wrap.rb +0 -273
- data/lib/prawn/core/text/formatted/wrap.rb +0 -153
- data/lib/prawn/graphics/gradient.rb +0 -84
- data/lib/prawn/security/arcfour.rb +0 -51
@@ -0,0 +1,37 @@
|
|
1
|
+
# encoding: utf-8
|
2
|
+
#
|
3
|
+
# You have already seen how to set the text color using both inline formatting
|
4
|
+
# and the format text methods. There is another way by using the graphics
|
5
|
+
# methods <code>fill_color</code> and <code>stroke_color</code>.
|
6
|
+
#
|
7
|
+
# When reading the graphics reference you learned about fill and stroke. If you
|
8
|
+
# haven't read it before, read it now before continuing.
|
9
|
+
#
|
10
|
+
# Text can be rendered by
|
11
|
+
# being filled (the default mode) or just stroked or both filled and stroked.
|
12
|
+
# This can be set using the <code>text_rendering_mode</code> method or the
|
13
|
+
# <code>:mode</code> option on the text methods.
|
14
|
+
#
|
15
|
+
require File.expand_path(File.join(File.dirname(__FILE__),
|
16
|
+
%w[.. example_helper]))
|
17
|
+
|
18
|
+
filename = File.basename(__FILE__).gsub('.rb', '.pdf')
|
19
|
+
Prawn::Example.generate(filename) do
|
20
|
+
fill_color "00ff00"
|
21
|
+
stroke_color "0000ff"
|
22
|
+
|
23
|
+
font_size(40) do
|
24
|
+
# normal rendering mode: fill
|
25
|
+
text "This text is filled with green."
|
26
|
+
move_down 20
|
27
|
+
|
28
|
+
# inline rendering mode: stroke
|
29
|
+
text "This text is stroked with blue", :mode => :stroke
|
30
|
+
move_down 20
|
31
|
+
|
32
|
+
# block rendering mode: fill and stroke
|
33
|
+
text_rendering_mode(:fill_stroke) do
|
34
|
+
text "This text is filled with green and stroked with blue"
|
35
|
+
end
|
36
|
+
end
|
37
|
+
end
|
@@ -0,0 +1,43 @@
|
|
1
|
+
# encoding: utf-8
|
2
|
+
#
|
3
|
+
# Prawn can be used with right-to-left text. The direction can be set
|
4
|
+
# document-wide, on particular text, or on a text-box. Setting the direction to
|
5
|
+
# <code>:rtl</code> automatically changes the default alignment to
|
6
|
+
# <code>:right</code>
|
7
|
+
#
|
8
|
+
# You can even override direction on an individual fragment. The one caveat is
|
9
|
+
# that two fragments going against the main direction cannot be placed next to
|
10
|
+
# each other without appearing in the wrong order.
|
11
|
+
#
|
12
|
+
require File.expand_path(File.join(File.dirname(__FILE__),
|
13
|
+
%w[.. example_helper]))
|
14
|
+
|
15
|
+
filename = File.basename(__FILE__).gsub('.rb', '.pdf')
|
16
|
+
Prawn::Example.generate(filename) do
|
17
|
+
# set the direction document-wide
|
18
|
+
self.text_direction = :rtl
|
19
|
+
|
20
|
+
font("#{Prawn::DATADIR}/fonts/gkai00mp.ttf", :size => 16) do
|
21
|
+
long_text = "写个小爬虫把你的页面上的关键信息顺次爬下来也不是什么难事写个小爬虫把你的页面上的关键信息顺次爬下来也不是什么难事写个小爬虫把你的页面上的关键信息顺次爬下来也不是什么难事写个小"
|
22
|
+
text long_text
|
23
|
+
move_down 20
|
24
|
+
|
25
|
+
text "You can override the document direction.", :direction => :ltr
|
26
|
+
move_down 20
|
27
|
+
|
28
|
+
formatted_text [{ :text => "更可怕的是,同质化竞争对手可以按照" },
|
29
|
+
{ :text => "URL", :direction => :ltr },
|
30
|
+
{ :text => "中后面这个" },
|
31
|
+
{ :text => "ID", :direction => :ltr },
|
32
|
+
{ :text => "来遍历您的" },
|
33
|
+
{ :text => "DB", :direction => :ltr },
|
34
|
+
{ :text => "中的内容,写个小爬虫把你的页面上的关键信息顺次爬下来也不是什么难事,这样的话,你就非常被动了。" }]
|
35
|
+
move_down 20
|
36
|
+
|
37
|
+
formatted_text [{ :text => "更可怕的是,同质化竞争对手可以按照" },
|
38
|
+
{ :text => "this", :direction => :ltr },
|
39
|
+
{ :text => "won't", :direction => :ltr, :size => 24 },
|
40
|
+
{ :text => "work", :direction => :ltr },
|
41
|
+
{ :text => "中的内容,写个小爬虫把你的页面上的关键信息顺次爬下来也不是什么难事" }]
|
42
|
+
end
|
43
|
+
end
|
@@ -0,0 +1,43 @@
|
|
1
|
+
# encoding: utf-8
|
2
|
+
#
|
3
|
+
# Rotating text is best avoided on free flowing text, so this example
|
4
|
+
# will only use the <code>text_box</code> method as we can have much more
|
5
|
+
# control over its output.
|
6
|
+
#
|
7
|
+
# To rotate text all we need to do is use the <code>:rotate</code> option
|
8
|
+
# passing an angle in degrees and an optional <code>:rotate_around</code> to
|
9
|
+
# indicate the origin of the rotation (the default is <code>:upper_left</code>).
|
10
|
+
#
|
11
|
+
require File.expand_path(File.join(File.dirname(__FILE__),
|
12
|
+
%w[.. example_helper]))
|
13
|
+
|
14
|
+
filename = File.basename(__FILE__).gsub('.rb', '.pdf')
|
15
|
+
Prawn::Example.generate(filename) do
|
16
|
+
width = 100
|
17
|
+
height = 60
|
18
|
+
angle = 30
|
19
|
+
x = 200
|
20
|
+
y = cursor - 30
|
21
|
+
|
22
|
+
stroke_rectangle [0, y], width, height
|
23
|
+
text_box("This text was not rotated",
|
24
|
+
:at => [0, y], :width => width, :height => height)
|
25
|
+
|
26
|
+
stroke_rectangle [0, y - 100], width, height
|
27
|
+
text_box("This text was rotated around the center",
|
28
|
+
:at => [0, y - 100], :width => width, :height => height,
|
29
|
+
:rotate => angle, :rotate_around => :center)
|
30
|
+
|
31
|
+
[:lower_left, :upper_left,
|
32
|
+
:lower_right, :upper_right].each_with_index do |corner, index|
|
33
|
+
|
34
|
+
y = y - 100 if index == 2
|
35
|
+
stroke_rectangle [x + (index % 2) * 200, y], width, height
|
36
|
+
text_box("This text was rotated around the #{corner} corner.",
|
37
|
+
:at => [x + (index % 2) * 200, y],
|
38
|
+
:width => width,
|
39
|
+
:height => height,
|
40
|
+
:rotate => angle,
|
41
|
+
:rotate_around => corner)
|
42
|
+
end
|
43
|
+
end
|
@@ -0,0 +1,37 @@
|
|
1
|
+
# encoding: utf-8
|
2
|
+
#
|
3
|
+
# The PDF format has some built-in font support. If you want to use other fonts
|
4
|
+
# in Prawn you need to embed the font file.
|
5
|
+
#
|
6
|
+
# Doing this for a single font is extremely simple. Remember the Styling font
|
7
|
+
# example? Another use of the <code>font</code> method is to provide a font file
|
8
|
+
# path and the font will be embedded in the document and set as the current
|
9
|
+
# font.
|
10
|
+
#
|
11
|
+
# This is reasonable if a font is used only once, but, if a font used several
|
12
|
+
# times, providing the path each time it is used becomes cumbersome. The example
|
13
|
+
# on the next page shows a better way to deal with fonts which are used several
|
14
|
+
# times in a document.
|
15
|
+
#
|
16
|
+
require File.expand_path(File.join(File.dirname(__FILE__),
|
17
|
+
%w[.. example_helper]))
|
18
|
+
|
19
|
+
filename = File.basename(__FILE__).gsub('.rb', '.pdf')
|
20
|
+
Prawn::Example.generate(filename) do
|
21
|
+
# Using a TTF font file
|
22
|
+
font("#{Prawn::DATADIR}/fonts/Chalkboard.ttf") do
|
23
|
+
text "Written with the Chalkboard TTF font."
|
24
|
+
end
|
25
|
+
move_down 20
|
26
|
+
|
27
|
+
text "Written with the default font."
|
28
|
+
move_down 20
|
29
|
+
|
30
|
+
# Using an DFONT font file
|
31
|
+
font("#{Prawn::DATADIR}/fonts/Action Man.dfont") do
|
32
|
+
text "Written with the Action Man DFONT font"
|
33
|
+
end
|
34
|
+
move_down 20
|
35
|
+
|
36
|
+
text "Written with the default font once more."
|
37
|
+
end
|
data/manual/text/text.rb
ADDED
@@ -0,0 +1,75 @@
|
|
1
|
+
# encoding: utf-8
|
2
|
+
#
|
3
|
+
# Examples for text rendering.
|
4
|
+
#
|
5
|
+
require File.expand_path(File.join(File.dirname(__FILE__),
|
6
|
+
%w[.. example_helper]))
|
7
|
+
|
8
|
+
Prawn::Example.generate("text.pdf", :page_size => "FOLIO") do
|
9
|
+
|
10
|
+
package "text" do |p|
|
11
|
+
|
12
|
+
p.section "Basics" do |s|
|
13
|
+
s.example "free_flowing_text"
|
14
|
+
s.example "positioned_text"
|
15
|
+
s.example "text_box_overflow"
|
16
|
+
s.example "text_box_excess"
|
17
|
+
s.example "group"
|
18
|
+
s.example "column_box"
|
19
|
+
end
|
20
|
+
|
21
|
+
p.section "Styling" do |s|
|
22
|
+
s.example "font"
|
23
|
+
s.example "font_size"
|
24
|
+
s.example "font_style"
|
25
|
+
s.example "color"
|
26
|
+
s.example "alignment"
|
27
|
+
s.example "leading"
|
28
|
+
s.example "kerning_and_character_spacing"
|
29
|
+
s.example "paragraph_indentation"
|
30
|
+
s.example "rotation"
|
31
|
+
end
|
32
|
+
|
33
|
+
p.section "Advanced Styling" do |s|
|
34
|
+
s.example "inline"
|
35
|
+
s.example "formatted_text"
|
36
|
+
s.example "formatted_callbacks"
|
37
|
+
s.example "rendering_and_color"
|
38
|
+
s.example "text_box_extensions"
|
39
|
+
end
|
40
|
+
|
41
|
+
p.section "External Fonts" do |s|
|
42
|
+
s.example "single_usage"
|
43
|
+
s.example "registering_families"
|
44
|
+
end
|
45
|
+
|
46
|
+
p.section "M17n" do |s|
|
47
|
+
s.example "utf8"
|
48
|
+
s.example "line_wrapping"
|
49
|
+
s.example "right_to_left_text"
|
50
|
+
s.example "fallback_fonts"
|
51
|
+
s.example "win_ansi_charset"
|
52
|
+
end
|
53
|
+
|
54
|
+
p.intro do
|
55
|
+
prose("This is probably the feature people will use the most. There is no shortage of options when it comes to text. You'll be hard pressed to find a use case that is not covered by one of the text methods and configurable options.
|
56
|
+
|
57
|
+
The examples show:")
|
58
|
+
|
59
|
+
list( "Text that flows from page to page automatically starting new pages when necessary",
|
60
|
+
"How to use text boxes and place them on specific positions",
|
61
|
+
"What to do when a text box is too small to fit its content",
|
62
|
+
"How to proceed when you want to prevent paragraphs from splitting between pages",
|
63
|
+
"Flowing text in columns",
|
64
|
+
"How to change the text style configuring font, size, alignment and many other settings",
|
65
|
+
"How to style specific portions of a text with inline styling and formatted text",
|
66
|
+
"How to define formatted callbacks to reuse common styling definitions",
|
67
|
+
"How to use the different rendering modes available for the text methods",
|
68
|
+
"How to create your custom text box extensions",
|
69
|
+
"How to use external fonts on your pdfs",
|
70
|
+
"What happens when rendering text in different languages"
|
71
|
+
)
|
72
|
+
end
|
73
|
+
|
74
|
+
end
|
75
|
+
end
|
@@ -0,0 +1,32 @@
|
|
1
|
+
# encoding: utf-8
|
2
|
+
#
|
3
|
+
# Whenever the <code>text_box</code> method truncates text, this truncated bit
|
4
|
+
# is not lost, it is the method return value and we can take advantage of that.
|
5
|
+
#
|
6
|
+
# We just need to take some precautions.
|
7
|
+
#
|
8
|
+
# This example renders as much of the text as will fit in a larger font inside
|
9
|
+
# one text_box and then proceeds to render the remaining text in the default
|
10
|
+
# size in a second text_box.
|
11
|
+
#
|
12
|
+
require File.expand_path(File.join(File.dirname(__FILE__),
|
13
|
+
%w[.. example_helper]))
|
14
|
+
|
15
|
+
filename = File.basename(__FILE__).gsub('.rb', '.pdf')
|
16
|
+
Prawn::Example.generate(filename) do
|
17
|
+
string = "This is the beginning of the text. It will be cut somewhere and " +
|
18
|
+
"the rest of the text will procede to be rendered this time by " +
|
19
|
+
"calling another method." + " . " * 50
|
20
|
+
|
21
|
+
y_position = cursor - 20
|
22
|
+
excess_text = text_box string,
|
23
|
+
:width => 300,
|
24
|
+
:height => 50,
|
25
|
+
:overflow => :truncate,
|
26
|
+
:at => [100, y_position],
|
27
|
+
:size => 18
|
28
|
+
|
29
|
+
text_box excess_text,
|
30
|
+
:width => 300,
|
31
|
+
:at => [100, y_position - 100]
|
32
|
+
end
|
@@ -0,0 +1,45 @@
|
|
1
|
+
# encoding: utf-8
|
2
|
+
#
|
3
|
+
# We've already seen one way of using text boxes with the <code>text_box</code>
|
4
|
+
# method. Turns out this method is just a convenience for using the
|
5
|
+
# <code>Prawn::Text::Box</code> class as it creates a new object and call
|
6
|
+
# <code>render</code> on it.
|
7
|
+
#
|
8
|
+
# Knowing that any extensions we add to <code>Prawn::Text::Box</code> will take
|
9
|
+
# effect when we use the <code>text_box</code> method. To add an extension all
|
10
|
+
# we need to do is append the <code>Prawn::Text::Box.extensions</code> array
|
11
|
+
# with a module.
|
12
|
+
#
|
13
|
+
require File.expand_path(File.join(File.dirname(__FILE__),
|
14
|
+
%w[.. example_helper]))
|
15
|
+
|
16
|
+
filename = File.basename(__FILE__).gsub('.rb', '.pdf')
|
17
|
+
Prawn::Example.generate(filename) do
|
18
|
+
module TriangleBox
|
19
|
+
def available_width
|
20
|
+
height + 25
|
21
|
+
end
|
22
|
+
end
|
23
|
+
|
24
|
+
y_position = cursor - 10
|
25
|
+
width = 100
|
26
|
+
height = 100
|
27
|
+
|
28
|
+
Prawn::Text::Box.extensions << TriangleBox
|
29
|
+
stroke_rectangle([0, y_position], width, height)
|
30
|
+
text_box("A" * 100,
|
31
|
+
:at => [0, y_position],
|
32
|
+
:width => width,
|
33
|
+
:height => height)
|
34
|
+
|
35
|
+
Prawn::Text::Formatted::Box.extensions << TriangleBox
|
36
|
+
stroke_rectangle([200, y_position], width, height)
|
37
|
+
formatted_text_box([:text => "A" * 100, :color => "009900"],
|
38
|
+
:at => [200, y_position],
|
39
|
+
:width => width,
|
40
|
+
:height => height)
|
41
|
+
|
42
|
+
# Here we clear the extensions array
|
43
|
+
Prawn::Text::Box.extensions.clear
|
44
|
+
Prawn::Text::Formatted::Box.extensions.clear
|
45
|
+
end
|
@@ -0,0 +1,44 @@
|
|
1
|
+
# encoding: utf-8
|
2
|
+
#
|
3
|
+
# The <code>text_box</code> method accepts both <code>:width</code> and
|
4
|
+
# <code>:height</code> options. So what happens if the text doesn't fit the box?
|
5
|
+
#
|
6
|
+
# The default behavior is to truncate the text but this can be changed with
|
7
|
+
# the <code>:overflow</code> option. Available modes are <code>:expand</code>
|
8
|
+
# (the box will increase to fit the text) and <code>:shrink_to_fit</code>
|
9
|
+
# (the text font size will be shrunk to fit).
|
10
|
+
#
|
11
|
+
# If <code>:shrink_to_fit</code> mode is used with the
|
12
|
+
# <code>:min_font_size</code> option set. The font size will not be reduced to
|
13
|
+
# less than the value provided even if it means truncating some text.
|
14
|
+
#
|
15
|
+
require File.expand_path(File.join(File.dirname(__FILE__),
|
16
|
+
%w[.. example_helper]))
|
17
|
+
|
18
|
+
filename = File.basename(__FILE__).gsub('.rb', '.pdf')
|
19
|
+
Prawn::Example.generate(filename) do
|
20
|
+
string = "This is the sample text used for the text boxes. See how it " +
|
21
|
+
"behave with the various overflow options used."
|
22
|
+
|
23
|
+
text string
|
24
|
+
|
25
|
+
y_position = cursor - 20
|
26
|
+
[:truncate, :expand, :shrink_to_fit].each_with_index do |mode, i|
|
27
|
+
text_box string, :at => [i * 150, y_position],
|
28
|
+
:width => 100, :height => 50,
|
29
|
+
:overflow => mode
|
30
|
+
end
|
31
|
+
|
32
|
+
string = "If the box is too small for the text, :shrink_to_fit " +
|
33
|
+
"can render the text in a really small font size."
|
34
|
+
|
35
|
+
move_down 120
|
36
|
+
text string
|
37
|
+
y_position = cursor - 20
|
38
|
+
[nil, 8, 10, 12].each_with_index do |value, index|
|
39
|
+
text_box string, :at => [index * 150, y_position],
|
40
|
+
:width => 50, :height => 50,
|
41
|
+
:overflow => :shrink_to_fit,
|
42
|
+
:min_font_size => value
|
43
|
+
end
|
44
|
+
end
|
data/manual/text/utf8.rb
ADDED
@@ -0,0 +1,28 @@
|
|
1
|
+
# encoding: utf-8
|
2
|
+
#
|
3
|
+
# Multilingualization isn't much of a problem on Prawn as its default encoding
|
4
|
+
# is UTF-8. The only thing you need to worry about is if the font support the
|
5
|
+
# glyphs of your language.
|
6
|
+
#
|
7
|
+
require File.expand_path(File.join(File.dirname(__FILE__),
|
8
|
+
%w[.. example_helper]))
|
9
|
+
|
10
|
+
filename = File.basename(__FILE__).gsub('.rb', '.pdf')
|
11
|
+
Prawn::Example.generate(filename) do
|
12
|
+
text "Take this example, a simple Euro sign:"
|
13
|
+
text "€", :size => 32
|
14
|
+
move_down 20
|
15
|
+
|
16
|
+
text "Seems ok. Now let's try something more complex:"
|
17
|
+
text "ὕαλον ϕαγεῖν δύναμαι· τοῦτο οὔ με βλάπτει."
|
18
|
+
move_down 20
|
19
|
+
|
20
|
+
text "Looks like the current font (#{font.inspect}) doesn't support those."
|
21
|
+
text "Let's try them with another font."
|
22
|
+
move_down 20
|
23
|
+
|
24
|
+
font("#{Prawn::DATADIR}/fonts/DejaVuSans.ttf") do
|
25
|
+
text "ὕαλον ϕαγεῖν δύναμαι· τοῦτο οὔ με βλάπτει."
|
26
|
+
text "There you go."
|
27
|
+
end
|
28
|
+
end
|
@@ -7,18 +7,22 @@
|
|
7
7
|
require File.expand_path(File.join(File.dirname(__FILE__),
|
8
8
|
%w[.. example_helper]))
|
9
9
|
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
@skip_encoding = true
|
10
|
+
filename = File.basename(__FILE__).gsub('.rb', '.pdf')
|
11
|
+
Prawn::Example.generate(filename) do
|
12
|
+
FONT_SIZE = 9.5
|
14
13
|
|
15
14
|
x = 0
|
16
15
|
y = bounds.top
|
17
16
|
|
18
|
-
fields = [[20, :right], [8, :left], [12, :center], [30, :right], [8, :left],
|
17
|
+
fields = [[20, :right], [8, :left], [12, :center], [30, :right], [8, :left],
|
18
|
+
[0, :left]]
|
19
19
|
|
20
20
|
font "Helvetica", :size => FONT_SIZE
|
21
21
|
|
22
|
+
move_down 30
|
23
|
+
text "(See next page for WinAnsi table)", :align => :center
|
24
|
+
start_new_page
|
25
|
+
|
22
26
|
Prawn::Encoding::WinAnsi::CHARACTERS.each_with_index do |name, index|
|
23
27
|
next if name == ".notdef"
|
24
28
|
y -= FONT_SIZE
|
@@ -32,21 +36,21 @@ Prawn::Document.generate("win-ansi.pdf") do
|
|
32
36
|
char = index.chr
|
33
37
|
|
34
38
|
width = 1000 * width_of(char, :size => FONT_SIZE) / FONT_SIZE
|
35
|
-
size
|
39
|
+
size = "%d" % width
|
36
40
|
|
37
41
|
data = [code, nil, char, size, nil, name]
|
38
|
-
dx
|
42
|
+
dx = x
|
39
43
|
fields.zip(data).each do |(total_width, align), field|
|
40
44
|
if field
|
41
45
|
width = width_of(field, :size => FONT_SIZE)
|
42
46
|
|
43
47
|
case align
|
44
|
-
when :left
|
45
|
-
when :right
|
48
|
+
when :left then offset = 0
|
49
|
+
when :right then offset = total_width - width
|
46
50
|
when :center then offset = (total_width - width)/2
|
47
51
|
end
|
48
52
|
|
49
|
-
|
53
|
+
text_box(field, :at => [dx + offset, y], :skip_encoding => true)
|
50
54
|
end
|
51
55
|
|
52
56
|
dx += total_width
|