prawn 2.0.2 → 2.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +5 -5
- checksums.yaml.gz.sig +0 -0
- data.tar.gz.sig +0 -0
- data/GPLv2 +20 -21
- data/Gemfile +3 -9
- data/Rakefile +20 -23
- data/lib/prawn.rb +37 -49
- data/lib/prawn/document.rb +181 -133
- data/lib/prawn/document/bounding_box.rb +41 -29
- data/lib/prawn/document/column_box.rb +7 -7
- data/lib/prawn/document/internals.rb +18 -8
- data/lib/prawn/document/span.rb +21 -16
- data/lib/prawn/encoding.rb +69 -68
- data/lib/prawn/errors.rb +12 -7
- data/lib/prawn/font.rb +115 -69
- data/lib/prawn/font_metric_cache.rb +14 -8
- data/lib/prawn/{font → fonts}/afm.rb +102 -68
- data/lib/prawn/{font → fonts}/dfont.rb +5 -11
- data/lib/prawn/fonts/otf.rb +11 -0
- data/lib/prawn/fonts/ttc.rb +36 -0
- data/lib/prawn/{font → fonts}/ttf.rb +87 -68
- data/lib/prawn/graphics.rb +120 -80
- data/lib/prawn/graphics/blend_mode.rb +65 -0
- data/lib/prawn/graphics/cap_style.rb +3 -3
- data/lib/prawn/graphics/color.rb +27 -25
- data/lib/prawn/graphics/dash.rb +23 -11
- data/lib/prawn/graphics/join_style.rb +9 -3
- data/lib/prawn/graphics/patterns.rb +197 -67
- data/lib/prawn/graphics/transformation.rb +17 -8
- data/lib/prawn/graphics/transparency.rb +17 -13
- data/lib/prawn/grid.rb +48 -47
- data/lib/prawn/image_handler.rb +5 -5
- data/lib/prawn/images.rb +39 -30
- data/lib/prawn/images/image.rb +2 -1
- data/lib/prawn/images/jpg.rb +28 -22
- data/lib/prawn/images/png.rb +107 -66
- data/lib/prawn/measurement_extensions.rb +10 -9
- data/lib/prawn/measurements.rb +19 -15
- data/lib/prawn/outline.rb +97 -77
- data/lib/prawn/repeater.rb +14 -10
- data/lib/prawn/security.rb +81 -61
- data/lib/prawn/security/arcfour.rb +2 -2
- data/lib/prawn/soft_mask.rb +26 -26
- data/lib/prawn/stamp.rb +20 -13
- data/lib/prawn/text.rb +68 -52
- data/lib/prawn/text/box.rb +11 -8
- data/lib/prawn/text/formatted.rb +5 -5
- data/lib/prawn/text/formatted/arranger.rb +78 -49
- data/lib/prawn/text/formatted/box.rb +134 -100
- data/lib/prawn/text/formatted/fragment.rb +11 -14
- data/lib/prawn/text/formatted/line_wrap.rb +121 -63
- data/lib/prawn/text/formatted/parser.rb +139 -117
- data/lib/prawn/text/formatted/wrap.rb +43 -31
- data/lib/prawn/transformation_stack.rb +44 -0
- data/lib/prawn/utilities.rb +7 -22
- data/lib/prawn/version.rb +2 -2
- data/lib/prawn/view.rb +17 -7
- data/manual/basic_concepts/adding_pages.rb +6 -7
- data/manual/basic_concepts/basic_concepts.rb +31 -22
- data/manual/basic_concepts/creation.rb +10 -11
- data/manual/basic_concepts/cursor.rb +4 -5
- data/manual/basic_concepts/measurement.rb +6 -7
- data/manual/basic_concepts/origin.rb +5 -6
- data/manual/basic_concepts/other_cursor_helpers.rb +11 -12
- data/manual/basic_concepts/view.rb +22 -16
- data/manual/bounding_box/bounding_box.rb +29 -24
- data/manual/bounding_box/bounds.rb +11 -12
- data/manual/bounding_box/canvas.rb +4 -5
- data/manual/bounding_box/creation.rb +6 -7
- data/manual/bounding_box/indentation.rb +14 -15
- data/manual/bounding_box/nesting.rb +24 -17
- data/manual/bounding_box/russian_boxes.rb +14 -13
- data/manual/bounding_box/stretchy.rb +12 -13
- data/manual/contents.rb +28 -22
- data/manual/cover.rb +33 -28
- data/manual/document_and_page_options/background.rb +11 -13
- data/manual/document_and_page_options/document_and_page_options.rb +25 -20
- data/manual/document_and_page_options/metadata.rb +18 -16
- data/manual/document_and_page_options/page_margins.rb +18 -20
- data/manual/document_and_page_options/page_size.rb +13 -12
- data/manual/document_and_page_options/print_scaling.rb +17 -15
- data/manual/example_helper.rb +5 -4
- data/manual/graphics/blend_mode.rb +52 -0
- data/manual/graphics/circle_and_ellipse.rb +4 -5
- data/manual/graphics/color.rb +7 -9
- data/manual/graphics/common_lines.rb +7 -8
- data/manual/graphics/fill_and_stroke.rb +4 -5
- data/manual/graphics/fill_rules.rb +9 -10
- data/manual/graphics/gradients.rb +27 -21
- data/manual/graphics/graphics.rb +48 -39
- data/manual/graphics/helper.rb +12 -9
- data/manual/graphics/line_width.rb +8 -7
- data/manual/graphics/lines_and_curves.rb +7 -8
- data/manual/graphics/polygon.rb +6 -8
- data/manual/graphics/rectangle.rb +4 -5
- data/manual/graphics/rotate.rb +6 -7
- data/manual/graphics/scale.rb +14 -15
- data/manual/graphics/soft_masks.rb +4 -5
- data/manual/graphics/stroke_cap.rb +6 -7
- data/manual/graphics/stroke_dash.rb +11 -12
- data/manual/graphics/stroke_join.rb +5 -6
- data/manual/graphics/translate.rb +9 -10
- data/manual/graphics/transparency.rb +7 -8
- data/manual/how_to_read_this_manual.rb +6 -6
- data/manual/images/absolute_position.rb +6 -7
- data/manual/images/fit.rb +7 -8
- data/manual/images/horizontal.rb +9 -10
- data/manual/images/images.rb +28 -24
- data/manual/images/plain_image.rb +5 -6
- data/manual/images/scale.rb +9 -10
- data/manual/images/vertical.rb +13 -14
- data/manual/images/width_and_height.rb +10 -11
- data/manual/layout/boxes.rb +5 -6
- data/manual/layout/content.rb +7 -8
- data/manual/layout/layout.rb +18 -16
- data/manual/layout/simple_grid.rb +6 -7
- data/manual/outline/add_subsection_to.rb +20 -21
- data/manual/outline/insert_section_after.rb +15 -16
- data/manual/outline/outline.rb +21 -17
- data/manual/outline/sections_and_pages.rb +17 -18
- data/manual/repeatable_content/alternate_page_numbering.rb +21 -17
- data/manual/repeatable_content/page_numbering.rb +17 -16
- data/manual/repeatable_content/repeatable_content.rb +25 -19
- data/manual/repeatable_content/repeater.rb +14 -15
- data/manual/repeatable_content/stamp.rb +14 -15
- data/manual/security/encryption.rb +9 -10
- data/manual/security/permissions.rb +19 -14
- data/manual/security/security.rb +19 -16
- data/manual/table.rb +3 -3
- data/manual/text/alignment.rb +16 -17
- data/manual/text/color.rb +12 -11
- data/manual/text/column_box.rb +9 -10
- data/manual/text/fallback_fonts.rb +25 -21
- data/manual/text/font.rb +11 -12
- data/manual/text/font_size.rb +13 -14
- data/manual/text/font_style.rb +7 -8
- data/manual/text/formatted_callbacks.rb +25 -21
- data/manual/text/formatted_text.rb +33 -25
- data/manual/text/free_flowing_text.rb +20 -21
- data/manual/text/inline.rb +18 -19
- data/manual/text/kerning_and_character_spacing.rb +14 -15
- data/manual/text/leading.rb +7 -8
- data/manual/text/line_wrapping.rb +37 -18
- data/manual/text/paragraph_indentation.rb +13 -14
- data/manual/text/positioned_text.rb +15 -16
- data/manual/text/registering_families.rb +20 -21
- data/manual/text/rendering_and_color.rb +9 -10
- data/manual/text/right_to_left_text.rb +26 -19
- data/manual/text/rotation.rb +28 -23
- data/manual/text/single_usage.rb +8 -9
- data/manual/text/text.rb +57 -52
- data/manual/text/text_box_excess.rb +20 -17
- data/manual/text/text_box_extensions.rb +18 -15
- data/manual/text/text_box_overflow.rb +18 -19
- data/manual/text/utf8.rb +11 -12
- data/manual/text/win_ansi_charset.rb +21 -19
- data/prawn.gemspec +45 -33
- data/spec/extensions/encoding_helpers.rb +3 -3
- data/spec/prawn/document/bounding_box_spec.rb +546 -0
- data/spec/prawn/document/column_box_spec.rb +75 -0
- data/spec/prawn/document/security_spec.rb +176 -0
- data/spec/prawn/document_annotations_spec.rb +76 -0
- data/spec/prawn/document_destinations_spec.rb +15 -0
- data/spec/prawn/document_grid_spec.rb +99 -0
- data/spec/prawn/document_reference_spec.rb +27 -0
- data/spec/prawn/document_span_spec.rb +36 -0
- data/spec/prawn/document_spec.rb +802 -0
- data/spec/prawn/font_metric_cache_spec.rb +54 -0
- data/spec/prawn/font_spec.rb +542 -0
- data/spec/prawn/graphics/blend_mode_spec.rb +63 -0
- data/spec/prawn/graphics/transparency_spec.rb +81 -0
- data/spec/prawn/graphics_spec.rb +837 -0
- data/spec/prawn/graphics_stroke_styles_spec.rb +229 -0
- data/spec/prawn/image_handler_spec.rb +53 -0
- data/spec/prawn/images/jpg_spec.rb +20 -0
- data/spec/prawn/images/png_spec.rb +283 -0
- data/spec/prawn/images_spec.rb +224 -0
- data/spec/prawn/measurements_extensions_spec.rb +24 -0
- data/spec/prawn/outline_spec.rb +412 -0
- data/spec/prawn/repeater_spec.rb +165 -0
- data/spec/prawn/soft_mask_spec.rb +74 -0
- data/spec/prawn/stamp_spec.rb +172 -0
- data/spec/prawn/text/box_spec.rb +1112 -0
- data/spec/prawn/text/formatted/arranger_spec.rb +466 -0
- data/spec/prawn/text/formatted/box_spec.rb +846 -0
- data/spec/prawn/text/formatted/fragment_spec.rb +343 -0
- data/spec/prawn/text/formatted/line_wrap_spec.rb +494 -0
- data/spec/prawn/text/formatted/parser_spec.rb +697 -0
- data/spec/prawn/text_draw_text_spec.rb +149 -0
- data/spec/prawn/text_rendering_mode_spec.rb +48 -0
- data/spec/prawn/text_spacing_spec.rb +95 -0
- data/spec/prawn/text_spec.rb +603 -0
- data/spec/prawn/text_with_inline_formatting_spec.rb +35 -0
- data/spec/prawn/transformation_stack_spec.rb +66 -0
- data/spec/prawn/view_spec.rb +63 -0
- data/spec/prawn_manual_spec.rb +35 -0
- data/spec/spec_helper.rb +19 -23
- metadata +145 -185
- metadata.gz.sig +4 -0
- data/data/images/16bit.alpha +0 -0
- data/data/images/16bit.color +0 -0
- data/data/images/16bit.png +0 -0
- data/data/images/arrow.png +0 -0
- data/data/images/arrow2.png +0 -0
- data/data/images/dice.alpha +0 -0
- data/data/images/dice.color +0 -0
- data/data/images/dice.png +0 -0
- data/data/images/dice_interlaced.png +0 -0
- data/data/images/fractal.jpg +0 -0
- data/data/images/indexed_color.dat +0 -0
- data/data/images/indexed_color.png +0 -0
- data/data/images/letterhead.jpg +0 -0
- data/data/images/license.md +0 -8
- data/data/images/page_white_text.alpha +0 -0
- data/data/images/page_white_text.color +0 -0
- data/data/images/page_white_text.png +0 -0
- data/data/images/pal_bk.png +0 -0
- data/data/images/pigs.jpg +0 -0
- data/data/images/prawn.png +0 -0
- data/data/images/ruport.png +0 -0
- data/data/images/ruport_data.dat +0 -0
- data/data/images/ruport_transparent.png +0 -0
- data/data/images/ruport_type0.png +0 -0
- data/data/images/stef.jpg +0 -0
- data/data/images/tru256.bmp +0 -0
- data/data/images/web-links.dat +0 -1
- data/data/images/web-links.png +0 -0
- data/data/pdfs/complex_template.pdf +0 -0
- data/data/pdfs/contains_ttf_font.pdf +0 -0
- data/data/pdfs/encrypted.pdf +0 -0
- data/data/pdfs/form.pdf +1 -819
- data/data/pdfs/hexagon.pdf +0 -61
- data/data/pdfs/indirect_reference.pdf +0 -86
- data/data/pdfs/multipage_template.pdf +0 -127
- data/data/pdfs/nested_pages.pdf +0 -118
- data/data/pdfs/page_without_mediabox.pdf +0 -193
- data/data/pdfs/resources_as_indirect_object.pdf +0 -83
- data/data/pdfs/two_hexagons.pdf +0 -90
- data/data/pdfs/version_1_6.pdf +0 -61
- data/data/shift_jis_text.txt +0 -1
- data/spec/acceptance/png.rb +0 -24
- data/spec/annotations_spec.rb +0 -67
- data/spec/bounding_box_spec.rb +0 -501
- data/spec/column_box_spec.rb +0 -59
- data/spec/destinations_spec.rb +0 -13
- data/spec/document_spec.rb +0 -742
- data/spec/extensions/mocha.rb +0 -45
- data/spec/font_metric_cache_spec.rb +0 -52
- data/spec/font_spec.rb +0 -475
- data/spec/formatted_text_arranger_spec.rb +0 -423
- data/spec/formatted_text_box_spec.rb +0 -716
- data/spec/formatted_text_fragment_spec.rb +0 -299
- data/spec/graphics_spec.rb +0 -666
- data/spec/grid_spec.rb +0 -95
- data/spec/image_handler_spec.rb +0 -53
- data/spec/images_spec.rb +0 -167
- data/spec/inline_formatted_text_parser_spec.rb +0 -568
- data/spec/jpg_spec.rb +0 -23
- data/spec/line_wrap_spec.rb +0 -366
- data/spec/measurement_units_spec.rb +0 -22
- data/spec/outline_spec.rb +0 -409
- data/spec/png_spec.rb +0 -235
- data/spec/reference_spec.rb +0 -25
- data/spec/repeater_spec.rb +0 -154
- data/spec/security_spec.rb +0 -151
- data/spec/soft_mask_spec.rb +0 -78
- data/spec/span_spec.rb +0 -43
- data/spec/stamp_spec.rb +0 -179
- data/spec/stroke_styles_spec.rb +0 -208
- data/spec/text_at_spec.rb +0 -142
- data/spec/text_box_spec.rb +0 -1038
- data/spec/text_rendering_mode_spec.rb +0 -45
- data/spec/text_spacing_spec.rb +0 -93
- data/spec/text_spec.rb +0 -549
- data/spec/text_with_inline_formatting_spec.rb +0 -35
- data/spec/transparency_spec.rb +0 -91
- data/spec/view_spec.rb +0 -42
@@ -1,5 +1,5 @@
|
|
1
|
-
#
|
2
|
-
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
3
|
# The base unit in Prawn is the PDF Point. One PDF Point is equal to 1/72 of
|
4
4
|
# an inch.
|
5
5
|
#
|
@@ -10,15 +10,14 @@
|
|
10
10
|
# Just <code>require "prawn/measurement_extensions"</code> and it will mix some
|
11
11
|
# helpers onto <code>Numeric</code> for converting common measurement units to
|
12
12
|
# PDF Points.
|
13
|
-
|
14
|
-
|
15
|
-
%w[.. example_helper]))
|
13
|
+
|
14
|
+
require_relative '../example_helper'
|
16
15
|
|
17
16
|
filename = File.basename(__FILE__).gsub('.rb', '.pdf')
|
18
17
|
Prawn::ManualBuilder::Example.generate(filename) do
|
19
|
-
require
|
18
|
+
require 'prawn/measurement_extensions'
|
20
19
|
|
21
|
-
[
|
20
|
+
%i[mm cm dm m in yd ft].each do |measurement|
|
22
21
|
text "1 #{measurement} in PDF Points: #{1.send(measurement)} pt"
|
23
22
|
move_down 5.mm
|
24
23
|
end
|
@@ -1,5 +1,5 @@
|
|
1
|
-
#
|
2
|
-
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
3
|
# This is the most important concept you need to learn about Prawn:
|
4
4
|
#
|
5
5
|
# PDF documents have the origin <code>[0,0]</code> at the bottom-left corner of
|
@@ -21,9 +21,8 @@
|
|
21
21
|
#
|
22
22
|
# The following snippet strokes a circle on the margin box origin. Then strokes
|
23
23
|
# the boundaries of a bounding box and a circle on its origin.
|
24
|
-
|
25
|
-
|
26
|
-
%w[.. example_helper]))
|
24
|
+
|
25
|
+
require_relative '../example_helper'
|
27
26
|
|
28
27
|
filename = File.basename(__FILE__).gsub('.rb', '.pdf')
|
29
28
|
Prawn::ManualBuilder::Example.generate(filename) do
|
@@ -31,7 +30,7 @@ Prawn::ManualBuilder::Example.generate(filename) do
|
|
31
30
|
|
32
31
|
stroke_circle [0, 0], 10
|
33
32
|
|
34
|
-
bounding_box([100, 300], :
|
33
|
+
bounding_box([100, 300], width: 300, height: 200) do
|
35
34
|
stroke_bounds
|
36
35
|
stroke_circle [0, 0], 10
|
37
36
|
end
|
@@ -1,5 +1,5 @@
|
|
1
|
-
#
|
2
|
-
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
3
|
# Another group of helpers for changing the cursor position are the pad methods.
|
4
4
|
# They accept a numeric value and a block. <code>pad</code> will use the numeric
|
5
5
|
# value to move the cursor down both before and after the block content.
|
@@ -8,33 +8,32 @@
|
|
8
8
|
#
|
9
9
|
# <code>float</code> is a method for not changing the cursor. Pass it a block
|
10
10
|
# and the cursor will remain on the same place when the block returns.
|
11
|
-
|
12
|
-
|
13
|
-
%w[.. example_helper]))
|
11
|
+
|
12
|
+
require_relative '../example_helper'
|
14
13
|
|
15
14
|
filename = File.basename(__FILE__).gsub('.rb', '.pdf')
|
16
15
|
Prawn::ManualBuilder::Example.generate(filename) do
|
17
16
|
stroke_horizontal_rule
|
18
|
-
pad(20) { text
|
17
|
+
pad(20) { text 'Text padded both before and after.' }
|
19
18
|
|
20
19
|
stroke_horizontal_rule
|
21
|
-
pad_top(20) { text
|
20
|
+
pad_top(20) { text 'Text padded on the top.' }
|
22
21
|
|
23
22
|
stroke_horizontal_rule
|
24
|
-
pad_bottom(20) { text
|
23
|
+
pad_bottom(20) { text 'Text padded on the bottom.' }
|
25
24
|
|
26
25
|
stroke_horizontal_rule
|
27
26
|
move_down 30
|
28
27
|
|
29
|
-
text
|
28
|
+
text 'Text written before the float block.'
|
30
29
|
|
31
30
|
float do
|
32
31
|
move_down 30
|
33
|
-
bounding_box([0, cursor], :
|
34
|
-
text
|
32
|
+
bounding_box([0, cursor], width: 200) do
|
33
|
+
text 'Text written inside the float block.'
|
35
34
|
stroke_bounds
|
36
35
|
end
|
37
36
|
end
|
38
37
|
|
39
|
-
text
|
38
|
+
text 'Text written after the float block.'
|
40
39
|
end
|
@@ -1,20 +1,26 @@
|
|
1
|
-
#
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
# The recommended way to extend Prawn's functionality is to include the
|
4
|
+
# <code>Prawn::View</code> mixin in your own class, which will make all
|
5
|
+
# <code>Prawn::Document</code> methods available to your custom objects.
|
2
6
|
#
|
3
|
-
#
|
4
|
-
#
|
5
|
-
#
|
7
|
+
# This approach is preferred over inheriting from
|
8
|
+
# <code>Prawn::Document</code>, as your state will be kept completely separate
|
9
|
+
# from <code>Prawn::Document</code>'s, thus avoiding accidental method
|
10
|
+
# collisions.
|
6
11
|
#
|
7
|
-
#
|
8
|
-
#
|
9
|
-
#
|
12
|
+
# Note that <code>Prawn::View</code> lazily instantiates a
|
13
|
+
# <code>Prawn::Document</code> with default initialization settings, such as
|
14
|
+
# page size, layout, margins, etc.
|
10
15
|
#
|
11
|
-
#
|
12
|
-
# you
|
13
|
-
#
|
14
|
-
#
|
15
|
-
#
|
16
|
+
# By defining your own <code>document</code> method, as shown in the example,
|
17
|
+
# you will be able to override those settings and initialize a
|
18
|
+
# <code>Prawn::Document</code> to your heart's content. This method will be
|
19
|
+
# called repeatedly by <code>Prawn::View</code>, so be sure to memoize the
|
20
|
+
# object by assigning it to an instance variable via the <code>||=</code>
|
21
|
+
# operator.
|
16
22
|
|
17
|
-
require_relative
|
23
|
+
require_relative '../example_helper'
|
18
24
|
|
19
25
|
class Greeter
|
20
26
|
include Prawn::View
|
@@ -28,15 +34,15 @@ class Greeter
|
|
28
34
|
end
|
29
35
|
|
30
36
|
def say_goodbye
|
31
|
-
font(
|
37
|
+
font('Courier') do
|
32
38
|
text "Goodbye, #{@name}!"
|
33
39
|
end
|
34
40
|
end
|
35
41
|
end
|
36
42
|
|
37
|
-
greeter = Greeter.new(
|
43
|
+
greeter = Greeter.new('Gregory')
|
38
44
|
|
39
45
|
greeter.say_hello
|
40
46
|
greeter.say_goodbye
|
41
47
|
|
42
|
-
greeter.save_as(
|
48
|
+
greeter.save_as('greetings.pdf')
|
@@ -1,36 +1,41 @@
|
|
1
|
-
#
|
2
|
-
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
3
|
# Examples for bounding boxes.
|
4
|
-
#
|
5
|
-
require File.expand_path(File.join(File.dirname(__FILE__),
|
6
|
-
%w[.. example_helper]))
|
7
4
|
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
5
|
+
require_relative '../example_helper'
|
6
|
+
|
7
|
+
filename = File.basename(__FILE__).gsub('.rb', '.pdf')
|
8
|
+
Prawn::ManualBuilder::Example.generate(filename, page_size: 'FOLIO') do
|
9
|
+
package 'bounding_box' do |p|
|
10
|
+
p.section 'Basics' do |s|
|
11
|
+
s.example 'creation'
|
12
|
+
s.example 'bounds'
|
13
13
|
end
|
14
14
|
|
15
|
-
p.section
|
16
|
-
s.example
|
17
|
-
s.example
|
18
|
-
s.example
|
19
|
-
s.example
|
20
|
-
s.example
|
15
|
+
p.section 'Advanced' do |s|
|
16
|
+
s.example 'stretchy'
|
17
|
+
s.example 'nesting'
|
18
|
+
s.example 'indentation'
|
19
|
+
s.example 'canvas'
|
20
|
+
s.example 'russian_boxes'
|
21
21
|
end
|
22
22
|
|
23
23
|
p.intro do
|
24
|
-
prose
|
24
|
+
prose <<-TEXT
|
25
|
+
Bounding boxes are the basic containers for structuring the content
|
26
|
+
flow. Even being low level building blocks sometimes their simplicity is
|
27
|
+
very welcome.
|
25
28
|
|
26
|
-
|
29
|
+
The examples show:
|
30
|
+
TEXT
|
27
31
|
|
28
|
-
list(
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
32
|
+
list(
|
33
|
+
'How to create bounding boxes with specific dimensions',
|
34
|
+
'How to inspect the current bounding box for its coordinates',
|
35
|
+
'Stretchy bounding boxes',
|
36
|
+
'Nested bounding boxes',
|
37
|
+
'Indent blocks'
|
38
|
+
)
|
34
39
|
end
|
35
40
|
end
|
36
41
|
end
|
@@ -1,5 +1,5 @@
|
|
1
|
-
#
|
2
|
-
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
3
|
# The <code>bounds</code> method returns the current bounding box. This is
|
4
4
|
# useful because the <code>Prawn::BoundingBox</code> exposes some nice boundary
|
5
5
|
# helpers.
|
@@ -16,9 +16,8 @@
|
|
16
16
|
#
|
17
17
|
# The following snippet shows the boundaries for the margin box side by side
|
18
18
|
# with the boundaries for a custom bounding box.
|
19
|
-
|
20
|
-
|
21
|
-
%w[.. example_helper]))
|
19
|
+
|
20
|
+
require_relative '../example_helper'
|
22
21
|
|
23
22
|
filename = File.basename(__FILE__).gsub('.rb', '.pdf')
|
24
23
|
Prawn::ManualBuilder::Example.generate(filename) do
|
@@ -30,18 +29,18 @@ Prawn::ManualBuilder::Example.generate(filename) do
|
|
30
29
|
|
31
30
|
move_down 10
|
32
31
|
|
33
|
-
text "absolute top: #{
|
34
|
-
text "absolute bottom: #{
|
35
|
-
text "absolute left: #{
|
36
|
-
text "absolute right: #{
|
32
|
+
text "absolute top: #{bounds.absolute_top.to_f.round(2)}"
|
33
|
+
text "absolute bottom: #{bounds.absolute_bottom.to_f.round(2)}"
|
34
|
+
text "absolute left: #{bounds.absolute_left.to_f.round(2)}"
|
35
|
+
text "absolute right: #{bounds.absolute_right.to_f.round(2)}"
|
37
36
|
end
|
38
37
|
|
39
|
-
text
|
38
|
+
text 'Margin box bounds:'
|
40
39
|
move_down 5
|
41
40
|
print_coordinates
|
42
41
|
|
43
|
-
bounding_box([250, cursor + 140], :
|
44
|
-
text
|
42
|
+
bounding_box([250, cursor + 140], width: 200, height: 150) do
|
43
|
+
text 'This bounding box bounds:'
|
45
44
|
move_down 5
|
46
45
|
print_coordinates
|
47
46
|
transparent(0.5) { stroke_bounds }
|
@@ -1,5 +1,5 @@
|
|
1
|
-
#
|
2
|
-
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
3
|
# The origin example already mentions that a new document already comes with
|
4
4
|
# a margin box whose bottom left corner is used as the origin for calculating
|
5
5
|
# coordinates.
|
@@ -9,9 +9,8 @@
|
|
9
9
|
# box mapped to the absolute coordinates and evaluating the code inside it.
|
10
10
|
#
|
11
11
|
# The following snippet draws a circle on each of the four absolute corners.
|
12
|
-
|
13
|
-
|
14
|
-
%w[.. example_helper]))
|
12
|
+
|
13
|
+
require_relative '../example_helper'
|
15
14
|
|
16
15
|
filename = File.basename(__FILE__).gsub('.rb', '.pdf')
|
17
16
|
Prawn::ManualBuilder::Example.generate(filename) do
|
@@ -1,5 +1,5 @@
|
|
1
|
-
#
|
2
|
-
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
3
|
# If you've read the basic concepts examples you probably know that the origin
|
4
4
|
# of a page is on the bottom left corner and that the content flows from top to
|
5
5
|
# bottom.
|
@@ -9,14 +9,13 @@
|
|
9
9
|
# A bounding box can be created with the <code>bounding_box</code> method. Just
|
10
10
|
# provide the top left corner, a required <code>:width</code> option and an
|
11
11
|
# optional <code>:height</code>.
|
12
|
-
|
13
|
-
|
14
|
-
%w[.. example_helper]))
|
12
|
+
|
13
|
+
require_relative '../example_helper'
|
15
14
|
|
16
15
|
filename = File.basename(__FILE__).gsub('.rb', '.pdf')
|
17
16
|
Prawn::ManualBuilder::Example.generate(filename) do
|
18
|
-
bounding_box([200, cursor - 100], :
|
19
|
-
text
|
17
|
+
bounding_box([200, cursor - 100], width: 200, height: 100) do
|
18
|
+
text 'Just your regular bounding box'
|
20
19
|
|
21
20
|
transparent(0.5) { stroke_bounds }
|
22
21
|
end
|
@@ -1,43 +1,42 @@
|
|
1
|
-
#
|
2
|
-
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
3
|
# Sometimes you just need to indent a portion of the contents of a bounding box,
|
4
4
|
# and using a nested bounding box is pure overkill. The <code>indent</code>
|
5
5
|
# method is what you might need.
|
6
6
|
#
|
7
7
|
# Just provide a number for it to indent all content generated inside the
|
8
8
|
# block.
|
9
|
-
|
10
|
-
|
11
|
-
%w[.. example_helper]))
|
9
|
+
|
10
|
+
require_relative '../example_helper'
|
12
11
|
|
13
12
|
filename = File.basename(__FILE__).gsub('.rb', '.pdf')
|
14
13
|
Prawn::ManualBuilder::Example.generate(filename) do
|
15
|
-
text
|
14
|
+
text 'No indentation on the margin box.'
|
16
15
|
indent(20) do
|
17
|
-
text
|
16
|
+
text 'Some indentation inside an indent block.'
|
18
17
|
end
|
19
18
|
move_down 20
|
20
19
|
|
21
|
-
bounding_box([50, cursor], :
|
20
|
+
bounding_box([50, cursor], width: 400, height: cursor) do
|
22
21
|
transparent(0.5) { stroke_bounds }
|
23
22
|
|
24
23
|
move_down 10
|
25
|
-
text
|
24
|
+
text 'No indentation inside this bounding box.'
|
26
25
|
indent(40) do
|
27
|
-
text
|
26
|
+
text 'Inside an indent block. And so is this horizontal line:'
|
28
27
|
|
29
28
|
stroke_horizontal_rule
|
30
29
|
end
|
31
30
|
move_down 10
|
32
|
-
text
|
31
|
+
text 'No indentation'
|
33
32
|
|
34
33
|
move_down 20
|
35
34
|
indent(60) do
|
36
|
-
text
|
35
|
+
text 'Another indent block.'
|
37
36
|
|
38
|
-
bounding_box([0, cursor], :
|
39
|
-
text
|
40
|
-
|
37
|
+
bounding_box([0, cursor], width: 200) do
|
38
|
+
text 'Note that this bounding box coordinates are relative to the ' \
|
39
|
+
'indent block'
|
41
40
|
|
42
41
|
transparent(0.5) { stroke_bounds }
|
43
42
|
end
|
@@ -1,5 +1,5 @@
|
|
1
|
-
#
|
2
|
-
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
3
|
# Normally when we provide the top left corner of a bounding box we
|
4
4
|
# express the coordinates relative to the margin box. This is not the
|
5
5
|
# case when we have nested bounding boxes. Once nested the inner bounding box
|
@@ -8,9 +8,8 @@
|
|
8
8
|
# This example shows some nested bounding boxes with fixed and stretchy heights.
|
9
9
|
# Note how the <code>cursor</code> method returns coordinates relative to
|
10
10
|
# the current bounding box.
|
11
|
-
|
12
|
-
|
13
|
-
%w[.. example_helper]))
|
11
|
+
|
12
|
+
require_relative '../example_helper'
|
14
13
|
|
15
14
|
filename = File.basename(__FILE__).gsub('.rb', '.pdf')
|
16
15
|
Prawn::ManualBuilder::Example.generate(filename) do
|
@@ -20,26 +19,34 @@ Prawn::ManualBuilder::Example.generate(filename) do
|
|
20
19
|
end
|
21
20
|
|
22
21
|
gap = 20
|
23
|
-
bounding_box([50, cursor], :
|
24
|
-
box_content(
|
22
|
+
bounding_box([50, cursor], width: 400, height: 200) do
|
23
|
+
box_content('Fixed height')
|
25
24
|
|
26
|
-
bounding_box([gap, cursor - gap], :
|
27
|
-
text
|
25
|
+
bounding_box([gap, cursor - gap], width: 300) do
|
26
|
+
text 'Stretchy height'
|
28
27
|
|
29
|
-
bounding_box([gap, bounds.top - gap], :
|
30
|
-
text
|
31
|
-
transparent(0.5)
|
28
|
+
bounding_box([gap, bounds.top - gap], width: 100) do
|
29
|
+
text 'Stretchy height'
|
30
|
+
transparent(0.5) do
|
31
|
+
dash(1)
|
32
|
+
stroke_bounds
|
33
|
+
undash
|
34
|
+
end
|
32
35
|
end
|
33
36
|
|
34
|
-
bounding_box([gap * 7, bounds.top - gap], :
|
35
|
-
box_content(
|
37
|
+
bounding_box([gap * 7, bounds.top - gap], width: 100, height: 50) do
|
38
|
+
box_content('Fixed height')
|
36
39
|
end
|
37
40
|
|
38
|
-
transparent(0.5)
|
41
|
+
transparent(0.5) do
|
42
|
+
dash(1)
|
43
|
+
stroke_bounds
|
44
|
+
undash
|
45
|
+
end
|
39
46
|
end
|
40
47
|
|
41
|
-
bounding_box([gap, cursor - gap], :
|
42
|
-
box_content(
|
48
|
+
bounding_box([gap, cursor - gap], width: 300, height: 50) do
|
49
|
+
box_content('Fixed height')
|
43
50
|
end
|
44
51
|
end
|
45
52
|
end
|