prawn 2.1.0 → 2.4.0
Sign up to get free protection for your applications and to get access to all the features.
- 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 +9 -41
- data/lib/prawn.rb +37 -49
- data/lib/prawn/document.rb +193 -141
- data/lib/prawn/document/bounding_box.rb +50 -30
- data/lib/prawn/document/column_box.rb +7 -7
- data/lib/prawn/document/internals.rb +8 -6
- data/lib/prawn/document/span.rb +22 -16
- data/lib/prawn/encoding.rb +69 -68
- data/lib/prawn/errors.rb +12 -7
- data/lib/prawn/font.rb +104 -69
- data/lib/prawn/font_metric_cache.rb +20 -13
- data/lib/prawn/{font → fonts}/afm.rb +108 -72
- 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 +126 -81
- data/lib/prawn/graphics.rb +119 -81
- data/lib/prawn/graphics/blend_mode.rb +9 -8
- data/lib/prawn/graphics/cap_style.rb +3 -3
- data/lib/prawn/graphics/color.rb +43 -39
- data/lib/prawn/graphics/dash.rb +23 -11
- data/lib/prawn/graphics/join_style.rb +9 -3
- data/lib/prawn/graphics/patterns.rb +204 -102
- data/lib/prawn/graphics/transformation.rb +15 -9
- data/lib/prawn/graphics/transparency.rb +17 -13
- data/lib/prawn/grid.rb +84 -48
- data/lib/prawn/image_handler.rb +5 -5
- data/lib/prawn/images.rb +60 -49
- data/lib/prawn/images/image.rb +2 -1
- data/lib/prawn/images/jpg.rb +31 -22
- data/lib/prawn/images/png.rb +67 -63
- data/lib/prawn/measurement_extensions.rb +10 -9
- data/lib/prawn/measurements.rb +19 -15
- data/lib/prawn/outline.rb +98 -77
- data/lib/prawn/repeater.rb +15 -11
- data/lib/prawn/security.rb +93 -70
- 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 +76 -60
- data/lib/prawn/text/box.rb +18 -14
- data/lib/prawn/text/formatted.rb +5 -5
- data/lib/prawn/text/formatted/arranger.rb +80 -40
- data/lib/prawn/text/formatted/box.rb +140 -101
- data/lib/prawn/text/formatted/fragment.rb +11 -14
- data/lib/prawn/text/formatted/line_wrap.rb +128 -67
- data/lib/prawn/text/formatted/parser.rb +147 -123
- data/lib/prawn/text/formatted/wrap.rb +48 -32
- data/lib/prawn/transformation_stack.rb +7 -5
- 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 +7 -8
- 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 +7 -8
- data/manual/bounding_box/creation.rb +6 -7
- data/manual/bounding_box/indentation.rb +14 -15
- data/manual/bounding_box/nesting.rb +25 -18
- 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 +15 -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 +18 -15
- data/manual/example_helper.rb +5 -4
- data/manual/graphics/blend_mode.rb +12 -9
- 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 +5 -6
- data/manual/graphics/fill_rules.rb +10 -10
- data/manual/graphics/gradients.rb +27 -21
- data/manual/graphics/graphics.rb +48 -40
- data/manual/graphics/helper.rb +19 -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 +3 -4
- data/manual/graphics/stroke_cap.rb +6 -7
- data/manual/graphics/stroke_dash.rb +15 -16
- data/manual/graphics/stroke_join.rb +5 -6
- data/manual/graphics/translate.rb +10 -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 +10 -11
- 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 +16 -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 +21 -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 +10 -8
- data/manual/text/formatted_callbacks.rb +33 -24
- data/manual/text/formatted_text.rb +36 -25
- data/manual/text/free_flowing_text.rb +22 -23
- 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 +12 -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 +33 -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 +20 -19
- data/manual/text/utf8.rb +11 -12
- data/manual/text/win_ansi_charset.rb +27 -25
- data/prawn.gemspec +41 -34
- data/spec/extensions/encoding_helpers.rb +3 -3
- data/spec/prawn/document/bounding_box_spec.rb +550 -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 +44 -0
- data/spec/prawn/document_spec.rb +805 -0
- data/spec/prawn/font_metric_cache_spec.rb +54 -0
- data/spec/prawn/font_spec.rb +544 -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 +872 -0
- data/spec/prawn/graphics_stroke_styles_spec.rb +229 -0
- data/spec/{image_handler_spec.rb → prawn/image_handler_spec.rb} +14 -14
- data/spec/prawn/images/jpg_spec.rb +20 -0
- data/spec/prawn/images/png_spec.rb +283 -0
- data/spec/prawn/images_spec.rb +229 -0
- data/spec/prawn/measurements_extensions_spec.rb +24 -0
- data/spec/prawn/outline_spec.rb +512 -0
- data/spec/prawn/repeater_spec.rb +166 -0
- data/spec/prawn/soft_mask_spec.rb +74 -0
- data/spec/prawn/stamp_spec.rb +173 -0
- data/spec/prawn/text/box_spec.rb +1110 -0
- data/spec/prawn/text/formatted/arranger_spec.rb +466 -0
- data/spec/prawn/text/formatted/box_spec.rb +849 -0
- data/spec/prawn/text/formatted/fragment_spec.rb +343 -0
- data/spec/prawn/text/formatted/line_wrap_spec.rb +495 -0
- data/spec/prawn/text/formatted/parser_spec.rb +697 -0
- data/spec/prawn/text_draw_text_spec.rb +150 -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/{transformation_stack_spec.rb → prawn/transformation_stack_spec.rb} +22 -19
- data/spec/prawn/view_spec.rb +63 -0
- data/spec/prawn_manual_spec.rb +35 -0
- data/spec/spec_helper.rb +18 -19
- metadata +102 -222
- metadata.gz.sig +0 -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/blend_modes_bottom_layer.jpg +0 -0
- data/data/images/blend_modes_top_layer.jpg +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/indexed_transparency.png +0 -0
- data/data/images/indexed_transparency_alpha.dat +0 -0
- data/data/images/indexed_transparency_color.dat +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/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_spec.rb +0 -35
- data/spec/annotations_spec.rb +0 -67
- data/spec/blend_mode_spec.rb +0 -71
- 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 -738
- data/spec/font_metric_cache_spec.rb +0 -52
- data/spec/font_spec.rb +0 -475
- data/spec/formatted_text_arranger_spec.rb +0 -452
- data/spec/formatted_text_box_spec.rb +0 -716
- data/spec/formatted_text_fragment_spec.rb +0 -299
- data/spec/graphics_spec.rb +0 -705
- data/spec/grid_spec.rb +0 -95
- 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 -257
- 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 -1042
- data/spec/text_rendering_mode_spec.rb +0 -45
- data/spec/text_spacing_spec.rb +0 -93
- data/spec/text_spec.rb +0 -543
- 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
|
# 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,16 +9,15 @@
|
|
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
|
18
17
|
canvas do
|
19
|
-
fill_circle [bounds.left, bounds.top],
|
20
|
-
fill_circle [bounds.right, bounds.top],
|
18
|
+
fill_circle [bounds.left, bounds.top], 30
|
19
|
+
fill_circle [bounds.right, bounds.top], 30
|
21
20
|
fill_circle [bounds.right, bounds.bottom], 30
|
22
|
-
fill_circle [0, 0],
|
21
|
+
fill_circle [0, 0], 30
|
23
22
|
end
|
24
23
|
end
|
@@ -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,16 +1,15 @@
|
|
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
|
6
|
-
# coordinates are relative to the
|
6
|
+
# coordinates are relative to the outer bounding box.
|
7
7
|
#
|
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
|
@@ -1,19 +1,18 @@
|
|
1
|
-
#
|
2
|
-
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
3
|
# This example is mostly just for fun, and shows how nested bounding boxes
|
4
4
|
# can simplify calculations. See the "Bounding Box" section of the manual
|
5
5
|
# for more basic uses.
|
6
|
-
|
7
|
-
|
8
|
-
%w[.. example_helper]))
|
6
|
+
|
7
|
+
require_relative '../example_helper'
|
9
8
|
|
10
9
|
filename = File.basename(__FILE__).gsub('.rb', '.pdf')
|
11
10
|
Prawn::ManualBuilder::Example.generate(filename) do
|
12
|
-
def combine(
|
11
|
+
def combine(horizontal_span, vertical_span)
|
13
12
|
output = []
|
14
|
-
|
15
|
-
|
16
|
-
output += [[
|
13
|
+
horizontal_span.each do |x|
|
14
|
+
vertical_span.each do |y|
|
15
|
+
output += [[x, y]]
|
17
16
|
end
|
18
17
|
end
|
19
18
|
output
|
@@ -22,10 +21,12 @@ Prawn::ManualBuilder::Example.generate(filename) do
|
|
22
21
|
def recurse_bounding_box(max_depth = 4, depth = 1)
|
23
22
|
width = (bounds.width - 15) / 2
|
24
23
|
height = (bounds.height - 15) / 2
|
25
|
-
left_top_corners = combine(
|
26
|
-
|
24
|
+
left_top_corners = combine(
|
25
|
+
[5, bounds.right - width - 5],
|
26
|
+
[bounds.top - 5, height + 5]
|
27
|
+
)
|
27
28
|
left_top_corners.each do |lt|
|
28
|
-
bounding_box(lt, :
|
29
|
+
bounding_box(lt, width: width, height: height) do
|
29
30
|
stroke_bounds
|
30
31
|
recurse_bounding_box(max_depth, depth + 1) if depth < max_depth
|
31
32
|
end
|
@@ -33,7 +34,7 @@ Prawn::ManualBuilder::Example.generate(filename) do
|
|
33
34
|
end
|
34
35
|
|
35
36
|
# Set up a bbox from the dashed line to the bottom of the page
|
36
|
-
bounding_box([0, cursor], :
|
37
|
+
bounding_box([0, cursor], width: bounds.width, height: cursor) do
|
37
38
|
recurse_bounding_box
|
38
39
|
end
|
39
40
|
end
|