prawn 0.13.0 → 2.4.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/.yardopts +10 -0
- data/GPLv2 +20 -21
- data/Gemfile +3 -16
- data/Rakefile +17 -39
- data/lib/prawn/document/bounding_box.rb +85 -42
- data/lib/prawn/document/column_box.rb +21 -11
- data/lib/prawn/document/internals.rb +40 -147
- data/lib/prawn/document/span.rb +25 -17
- data/lib/prawn/document.rb +286 -245
- data/lib/prawn/encoding.rb +68 -101
- data/lib/prawn/errors.rb +47 -43
- data/lib/prawn/font.rb +204 -155
- data/lib/prawn/font_metric_cache.rb +25 -21
- data/lib/prawn/fonts/afm.rb +292 -0
- data/lib/prawn/{font → fonts}/dfont.rb +7 -13
- data/lib/prawn/fonts/otf.rb +11 -0
- data/lib/prawn/fonts/ttc.rb +36 -0
- data/lib/prawn/{font → fonts}/ttf.rb +142 -80
- data/lib/prawn/graphics/blend_mode.rb +65 -0
- data/lib/prawn/graphics/cap_style.rb +6 -5
- data/lib/prawn/graphics/color.rb +47 -44
- data/lib/prawn/graphics/dash.rb +30 -13
- data/lib/prawn/graphics/join_style.rb +13 -6
- data/lib/prawn/graphics/patterns.rb +221 -90
- data/lib/prawn/graphics/transformation.rb +21 -12
- data/lib/prawn/graphics/transparency.rb +21 -17
- data/lib/prawn/graphics.rb +155 -128
- data/lib/prawn/{layout/grid.rb → grid.rb} +110 -47
- data/lib/prawn/image_handler.rb +16 -2
- data/lib/prawn/images/image.rb +4 -2
- data/lib/prawn/images/jpg.rb +39 -30
- data/lib/prawn/images/png.rb +132 -169
- data/lib/prawn/images.rb +70 -62
- data/lib/prawn/measurement_extensions.rb +15 -10
- data/lib/prawn/measurements.rb +22 -23
- data/lib/prawn/outline.rb +301 -13
- data/lib/prawn/repeater.rb +19 -17
- data/lib/prawn/security/arcfour.rb +54 -0
- data/lib/prawn/security.rb +108 -86
- data/lib/prawn/soft_mask.rb +40 -41
- data/lib/prawn/stamp.rb +29 -12
- data/lib/prawn/text/box.rb +27 -29
- data/lib/prawn/text/formatted/arranger.rb +110 -67
- data/lib/prawn/text/formatted/box.rb +233 -165
- data/lib/prawn/text/formatted/fragment.rb +27 -27
- data/lib/prawn/text/formatted/line_wrap.rb +137 -97
- data/lib/prawn/text/formatted/parser.rb +149 -127
- data/lib/prawn/text/formatted/wrap.rb +57 -37
- data/lib/prawn/text/formatted.rb +6 -4
- data/lib/prawn/text.rb +105 -73
- data/lib/prawn/transformation_stack.rb +44 -0
- data/lib/prawn/utilities.rb +11 -21
- data/lib/prawn/version.rb +5 -0
- data/lib/prawn/view.rb +101 -0
- data/lib/prawn.rb +42 -68
- data/{data/images/fractal.jpg → manual/absolute_position.pdf} +0 -0
- data/manual/basic_concepts/adding_pages.rb +9 -10
- data/manual/basic_concepts/basic_concepts.rb +33 -24
- data/manual/basic_concepts/creation.rb +10 -11
- data/manual/basic_concepts/cursor.rb +9 -10
- data/manual/basic_concepts/measurement.rb +10 -11
- data/manual/basic_concepts/origin.rb +8 -9
- data/manual/basic_concepts/other_cursor_helpers.rb +17 -18
- data/manual/basic_concepts/view.rb +48 -0
- data/manual/bounding_box/bounding_box.rb +31 -29
- data/manual/bounding_box/bounds.rb +17 -18
- data/manual/bounding_box/canvas.rb +8 -9
- data/manual/bounding_box/creation.rb +8 -9
- data/manual/bounding_box/indentation.rb +22 -23
- data/manual/bounding_box/nesting.rb +32 -25
- data/manual/bounding_box/russian_boxes.rb +19 -19
- data/manual/bounding_box/stretchy.rb +18 -20
- data/manual/contents.rb +35 -0
- data/manual/cover.rb +43 -0
- data/manual/document_and_page_options/background.rb +16 -14
- data/manual/document_and_page_options/document_and_page_options.rb +26 -23
- data/manual/document_and_page_options/metadata.rb +21 -19
- data/manual/document_and_page_options/page_margins.rb +20 -22
- data/manual/document_and_page_options/page_size.rb +15 -15
- data/manual/document_and_page_options/print_scaling.rb +23 -0
- data/manual/example_helper.rb +5 -408
- data/manual/graphics/blend_mode.rb +52 -0
- data/manual/graphics/circle_and_ellipse.rb +8 -9
- data/manual/graphics/color.rb +11 -13
- data/manual/graphics/common_lines.rb +13 -12
- data/manual/graphics/fill_and_stroke.rb +10 -11
- data/manual/graphics/fill_rules.rb +13 -12
- data/manual/graphics/gradients.rb +28 -22
- data/manual/graphics/graphics.rb +52 -46
- data/manual/graphics/helper.rb +20 -10
- data/manual/graphics/line_width.rb +13 -12
- data/manual/graphics/lines_and_curves.rb +13 -14
- data/manual/graphics/polygon.rb +10 -12
- data/manual/graphics/rectangle.rb +7 -8
- data/manual/graphics/rotate.rb +9 -12
- data/manual/graphics/scale.rb +19 -18
- data/manual/graphics/soft_masks.rb +5 -7
- data/manual/graphics/stroke_cap.rb +10 -11
- data/manual/graphics/stroke_dash.rb +16 -17
- data/manual/graphics/stroke_join.rb +10 -11
- data/manual/graphics/translate.rb +13 -13
- data/manual/graphics/transparency.rb +11 -13
- data/manual/{manual/how_to_read_this_manual.rb → how_to_read_this_manual.rb} +23 -25
- data/manual/images/absolute_position.rb +9 -10
- data/manual/images/fit.rb +9 -10
- data/manual/images/horizontal.rb +13 -14
- data/manual/images/images.rb +31 -30
- data/manual/images/plain_image.rb +6 -7
- data/manual/images/scale.rb +12 -13
- data/manual/images/vertical.rb +19 -17
- data/manual/images/width_and_height.rb +13 -14
- data/manual/layout/boxes.rb +14 -15
- data/manual/layout/content.rb +12 -13
- data/manual/layout/layout.rb +19 -20
- data/manual/layout/simple_grid.rb +8 -9
- data/manual/outline/add_subsection_to.rb +26 -27
- data/manual/outline/insert_section_after.rb +19 -20
- data/manual/outline/outline.rb +23 -22
- data/manual/outline/sections_and_pages.rb +24 -25
- data/manual/repeatable_content/alternate_page_numbering.rb +36 -0
- data/manual/repeatable_content/page_numbering.rb +20 -19
- data/manual/repeatable_content/repeatable_content.rb +26 -22
- data/manual/repeatable_content/repeater.rb +18 -19
- data/manual/repeatable_content/stamp.rb +18 -19
- data/manual/security/encryption.rb +8 -11
- data/manual/security/permissions.rb +20 -15
- data/manual/security/security.rb +20 -20
- data/manual/table.rb +16 -0
- data/manual/text/alignment.rb +17 -18
- data/manual/text/color.rb +13 -13
- data/manual/text/column_box.rb +10 -12
- data/manual/text/fallback_fonts.rb +29 -25
- data/manual/text/font.rb +17 -18
- data/manual/text/font_size.rb +21 -22
- data/manual/text/font_style.rb +12 -10
- data/manual/text/formatted_callbacks.rb +36 -26
- data/manual/text/formatted_text.rb +41 -34
- data/manual/text/free_flowing_text.rb +28 -29
- data/manual/text/inline.rb +23 -26
- data/manual/text/kerning_and_character_spacing.rb +20 -21
- data/manual/text/leading.rb +10 -11
- data/manual/text/line_wrapping.rb +40 -21
- data/manual/text/paragraph_indentation.rb +17 -12
- data/manual/text/positioned_text.rb +19 -20
- data/manual/text/registering_families.rb +33 -30
- data/manual/text/rendering_and_color.rb +11 -12
- data/manual/text/right_to_left_text.rb +31 -20
- data/manual/text/rotation.rb +36 -27
- data/manual/text/single_usage.rb +13 -14
- data/manual/text/text.rb +62 -62
- data/manual/text/text_box_excess.rb +22 -19
- data/manual/text/text_box_extensions.rb +21 -18
- data/manual/text/text_box_overflow.rb +28 -21
- data/manual/text/utf8.rb +16 -17
- data/manual/text/win_ansi_charset.rb +29 -26
- data/prawn.gemspec +45 -43
- data/spec/extensions/encoding_helpers.rb +4 -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/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 +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/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 +22 -21
- data.tar.gz.sig +0 -0
- metadata +168 -307
- metadata.gz.sig +0 -0
- data/README.md +0 -109
- data/data/encodings/win_ansi.txt +0 -29
- data/data/images/16bit.alpha +0 -0
- data/data/images/16bit.dat +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/barcode_issue.png +0 -0
- data/data/images/dice.alpha +0 -0
- data/data/images/dice.dat +0 -0
- data/data/images/dice.png +0 -0
- data/data/images/dice_interlaced.png +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/page_white_text.alpha +0 -0
- data/data/images/page_white_text.dat +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/lib/pdf/core/annotations.rb +0 -60
- data/lib/pdf/core/byte_string.rb +0 -9
- data/lib/pdf/core/destinations.rb +0 -90
- data/lib/pdf/core/document_state.rb +0 -78
- data/lib/pdf/core/filter_list.rb +0 -51
- data/lib/pdf/core/filters.rb +0 -36
- data/lib/pdf/core/graphics_state.rb +0 -68
- data/lib/pdf/core/literal_string.rb +0 -16
- data/lib/pdf/core/name_tree.rb +0 -177
- data/lib/pdf/core/object_store.rb +0 -320
- data/lib/pdf/core/outline.rb +0 -315
- data/lib/pdf/core/page.rb +0 -212
- data/lib/pdf/core/page_geometry.rb +0 -126
- data/lib/pdf/core/pdf_object.rb +0 -124
- data/lib/pdf/core/reference.rb +0 -103
- data/lib/pdf/core/stream.rb +0 -98
- data/lib/pdf/core/text.rb +0 -275
- data/lib/pdf/core.rb +0 -35
- data/lib/prawn/compatibility.rb +0 -91
- data/lib/prawn/document/graphics_state.rb +0 -73
- data/lib/prawn/document/snapshot.rb +0 -89
- data/lib/prawn/font/afm.rb +0 -203
- data/lib/prawn/layout.rb +0 -20
- data/lib/prawn/table/cell/image.rb +0 -70
- data/lib/prawn/table/cell/in_table.rb +0 -27
- data/lib/prawn/table/cell/span_dummy.rb +0 -92
- data/lib/prawn/table/cell/subtable.rb +0 -65
- data/lib/prawn/table/cell/text.rb +0 -153
- data/lib/prawn/table/cell.rb +0 -770
- data/lib/prawn/table/cells.rb +0 -295
- data/lib/prawn/table.rb +0 -643
- data/manual/example_file.rb +0 -116
- data/manual/example_package.rb +0 -53
- data/manual/example_section.rb +0 -46
- data/manual/manual/cover.rb +0 -35
- data/manual/manual/foreword.rb +0 -85
- data/manual/manual/manual.rb +0 -35
- data/manual/syntax_highlight.rb +0 -52
- data/manual/table/basic_block.rb +0 -53
- data/manual/table/before_rendering_page.rb +0 -26
- data/manual/table/cell_border_lines.rb +0 -24
- data/manual/table/cell_borders_and_bg.rb +0 -31
- data/manual/table/cell_dimensions.rb +0 -30
- data/manual/table/cell_text.rb +0 -38
- data/manual/table/column_widths.rb +0 -30
- data/manual/table/content_and_subtables.rb +0 -39
- data/manual/table/creation.rb +0 -27
- data/manual/table/filtering.rb +0 -36
- data/manual/table/flow_and_header.rb +0 -17
- data/manual/table/image_cells.rb +0 -33
- data/manual/table/position.rb +0 -29
- data/manual/table/row_colors.rb +0 -20
- data/manual/table/span.rb +0 -30
- data/manual/table/style.rb +0 -22
- data/manual/table/table.rb +0 -52
- data/manual/table/width.rb +0 -27
- data/manual/templates/full_template.rb +0 -25
- data/manual/templates/page_template.rb +0 -48
- data/manual/templates/templates.rb +0 -27
- data/manual/text/group.rb +0 -29
- data/spec/acceptance/png.rb +0 -23
- data/spec/annotations_spec.rb +0 -74
- data/spec/bounding_box_spec.rb +0 -493
- data/spec/cell_spec.rb +0 -628
- data/spec/column_box_spec.rb +0 -33
- data/spec/destinations_spec.rb +0 -15
- data/spec/document_spec.rb +0 -761
- data/spec/extensions/mocha.rb +0 -44
- data/spec/filters_spec.rb +0 -34
- data/spec/font_metric_cache_spec.rb +0 -52
- data/spec/font_spec.rb +0 -464
- data/spec/formatted_text_arranger_spec.rb +0 -421
- data/spec/formatted_text_box_spec.rb +0 -650
- data/spec/formatted_text_fragment_spec.rb +0 -298
- data/spec/graphics_spec.rb +0 -651
- data/spec/grid_spec.rb +0 -85
- data/spec/image_handler_spec.rb +0 -42
- data/spec/images_spec.rb +0 -157
- data/spec/inline_formatted_text_parser_spec.rb +0 -564
- data/spec/jpg_spec.rb +0 -25
- data/spec/line_wrap_spec.rb +0 -333
- data/spec/measurement_units_spec.rb +0 -23
- data/spec/name_tree_spec.rb +0 -112
- data/spec/object_store_spec.rb +0 -170
- data/spec/outline_spec.rb +0 -448
- data/spec/pdf_object_spec.rb +0 -172
- data/spec/png_spec.rb +0 -240
- data/spec/reference_spec.rb +0 -82
- data/spec/repeater_spec.rb +0 -158
- data/spec/security_spec.rb +0 -158
- data/spec/snapshot_spec.rb +0 -186
- data/spec/soft_mask_spec.rb +0 -117
- data/spec/span_spec.rb +0 -44
- data/spec/stamp_spec.rb +0 -158
- data/spec/stream_spec.rb +0 -58
- data/spec/stroke_styles_spec.rb +0 -211
- data/spec/table/span_dummy_spec.rb +0 -17
- data/spec/table_spec.rb +0 -1355
- data/spec/template_spec.rb +0 -351
- data/spec/text_at_spec.rb +0 -130
- data/spec/text_box_spec.rb +0 -1030
- data/spec/text_rendering_mode_spec.rb +0 -45
- data/spec/text_spacing_spec.rb +0 -93
- data/spec/text_spec.rb +0 -425
- data/spec/text_with_inline_formatting_spec.rb +0 -35
- data/spec/transparency_spec.rb +0 -89
@@ -1,37 +1,43 @@
|
|
1
|
-
#
|
2
|
-
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
3
|
# Note that because of the way PDF renders radial gradients in order to get
|
4
4
|
# solid fill your start circle must be fully inside your end circle.
|
5
5
|
# Otherwise you will get triangle fill like illustrated in the example below.
|
6
6
|
|
7
|
-
|
8
|
-
%w[.. example_helper]))
|
7
|
+
require_relative '../example_helper'
|
9
8
|
|
10
9
|
filename = File.basename(__FILE__).gsub('.rb', '.pdf')
|
11
|
-
Prawn::Example.generate(filename) do
|
12
|
-
stroke_axis
|
10
|
+
Prawn::ManualBuilder::Example.generate(filename) do
|
13
11
|
self.line_width = 10
|
14
12
|
|
15
|
-
|
16
|
-
|
13
|
+
# Linear Gradients
|
14
|
+
fill_gradient [0, 250], [100, 150], 'ff0000', '0000ff'
|
15
|
+
fill_rectangle [0, 250], 100, 100
|
16
|
+
|
17
|
+
stroke_gradient [150, 150], [250, 250], '00ffff', 'ffff00'
|
18
|
+
stroke_rectangle [150, 250], 100, 100
|
17
19
|
|
18
|
-
|
19
|
-
|
20
|
+
fill_gradient [300, 250], [400, 150], 'ff0000', '0000ff'
|
21
|
+
stroke_gradient [300, 150], [400, 250], '00ffff', 'ffff00'
|
22
|
+
fill_and_stroke_rectangle [300, 250], 100, 100
|
20
23
|
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
+
rotate 45, origin: [500, 200] do
|
25
|
+
stops = { 0 => 'ff0000', 0.6 => '999900', 0.8 => '00cc00', 1 => '4444ff' }
|
26
|
+
fill_gradient from: [460, 240], to: [540, 160], stops: stops
|
27
|
+
fill_rectangle [460, 240], 80, 80
|
28
|
+
end
|
24
29
|
|
25
|
-
|
26
|
-
|
30
|
+
# Radial gradients
|
31
|
+
fill_gradient [50, 50], 0, [50, 50], 70.71, 'ff0000', '0000ff'
|
32
|
+
fill_rectangle [0, 100], 100, 100
|
27
33
|
|
28
|
-
stroke_gradient [
|
29
|
-
stroke_rectangle [
|
34
|
+
stroke_gradient [200, 50], 45, [200, 50], 70.71, '00ffff', 'ffff00'
|
35
|
+
stroke_rectangle [150, 100], 100, 100
|
30
36
|
|
31
|
-
stroke_gradient [
|
32
|
-
fill_gradient [
|
33
|
-
fill_and_stroke_rectangle [
|
37
|
+
stroke_gradient [350, 50], 45, [350, 50], 70.71, '00ffff', 'ffff00'
|
38
|
+
fill_gradient [350, 50], 0, [350, 50], 70.71, 'ff0000', '0000ff'
|
39
|
+
fill_and_stroke_rectangle [300, 100], 100, 100
|
34
40
|
|
35
|
-
fill_gradient [500,
|
36
|
-
fill_rectangle [
|
41
|
+
fill_gradient [500, 100], 50, [500, 0], 0, 'ff0000', '0000ff'
|
42
|
+
fill_rectangle [450, 100], 100, 100
|
37
43
|
end
|
data/manual/graphics/graphics.rb
CHANGED
@@ -1,58 +1,64 @@
|
|
1
|
-
#
|
2
|
-
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
3
|
# Examples for the Graphics package.
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
Prawn::Example.generate(
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
s.example "helper"
|
14
|
-
s.example "fill_and_stroke"
|
4
|
+
|
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 'graphics' do |p|
|
10
|
+
p.section 'Basics' do |s|
|
11
|
+
s.example 'helper'
|
12
|
+
s.example 'fill_and_stroke'
|
15
13
|
end
|
16
|
-
|
17
|
-
p.section
|
18
|
-
s.example
|
19
|
-
s.example
|
20
|
-
s.example
|
21
|
-
s.example
|
22
|
-
s.example
|
14
|
+
|
15
|
+
p.section 'Shapes' do |s|
|
16
|
+
s.example 'lines_and_curves'
|
17
|
+
s.example 'common_lines'
|
18
|
+
s.example 'rectangle'
|
19
|
+
s.example 'polygon'
|
20
|
+
s.example 'circle_and_ellipse'
|
23
21
|
end
|
24
|
-
|
25
|
-
p.section
|
26
|
-
s.example
|
27
|
-
s.example
|
28
|
-
s.example
|
29
|
-
s.example
|
30
|
-
s.example
|
31
|
-
s.example
|
32
|
-
s.example
|
33
|
-
s.example
|
34
|
-
s.example
|
22
|
+
|
23
|
+
p.section 'Fill and Stroke settings' do |s|
|
24
|
+
s.example 'line_width'
|
25
|
+
s.example 'stroke_cap'
|
26
|
+
s.example 'stroke_join'
|
27
|
+
s.example 'stroke_dash'
|
28
|
+
s.example 'color'
|
29
|
+
s.example 'gradients'
|
30
|
+
s.example 'transparency'
|
31
|
+
s.example 'soft_masks'
|
32
|
+
s.example 'blend_mode'
|
33
|
+
s.example 'fill_rules'
|
35
34
|
end
|
36
|
-
|
37
|
-
p.section
|
38
|
-
s.example
|
39
|
-
s.example
|
40
|
-
s.example
|
35
|
+
|
36
|
+
p.section 'Transformations' do |s|
|
37
|
+
s.example 'rotate'
|
38
|
+
s.example 'translate'
|
39
|
+
s.example 'scale'
|
41
40
|
end
|
42
|
-
|
41
|
+
|
43
42
|
p.intro do
|
44
|
-
prose
|
43
|
+
prose <<-TEXT
|
44
|
+
Here we show all the drawing methods provided by Prawn. Use them to draw
|
45
|
+
the most beautiful imaginable things.
|
45
46
|
|
46
|
-
|
47
|
+
Most of the content that you'll add to your pdf document will use the
|
48
|
+
graphics package. Even text is rendered on a page just like a rectangle
|
49
|
+
so even if you never use any of the shapes described here you should at
|
50
|
+
least read the basic examples.
|
47
51
|
|
48
|
-
|
52
|
+
The examples show:
|
53
|
+
TEXT
|
49
54
|
|
50
|
-
list(
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
|
55
|
+
list(
|
56
|
+
'All the possible ways that you can fill or stroke shapes on a page',
|
57
|
+
'How to draw all the shapes that Prawn has to offer from a measly '\
|
58
|
+
'line to a mighty polygon or ellipse',
|
59
|
+
'The configuration options for stroking lines and filling shapes',
|
60
|
+
'How to apply transformations to your drawing space'
|
61
|
+
)
|
55
62
|
end
|
56
|
-
|
57
63
|
end
|
58
64
|
end
|
data/manual/graphics/helper.rb
CHANGED
@@ -1,5 +1,5 @@
|
|
1
|
-
#
|
2
|
-
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
3
|
# To produce this manual we use the <code>stroke_axis</code> helper method
|
4
4
|
# within the examples.
|
5
5
|
#
|
@@ -10,15 +10,25 @@
|
|
10
10
|
# Note that the examples define a custom <code>:height</code> option so that
|
11
11
|
# only the example canvas is used (as seen with the output of the first line of
|
12
12
|
# the example code).
|
13
|
-
|
14
|
-
|
15
|
-
%w[.. example_helper]))
|
13
|
+
|
14
|
+
require_relative '../example_helper'
|
16
15
|
|
17
16
|
filename = File.basename(__FILE__).gsub('.rb', '.pdf')
|
18
|
-
Prawn::Example.generate(filename) do
|
17
|
+
Prawn::ManualBuilder::Example.generate(filename) do
|
19
18
|
stroke_axis
|
20
|
-
stroke_axis(
|
21
|
-
|
22
|
-
|
23
|
-
|
19
|
+
stroke_axis(
|
20
|
+
at: [70, 70],
|
21
|
+
height: 200,
|
22
|
+
step_length: 50,
|
23
|
+
negative_axes_length: 5,
|
24
|
+
color: '0000FF'
|
25
|
+
)
|
26
|
+
stroke_axis(
|
27
|
+
at: [140, 140],
|
28
|
+
width: 200,
|
29
|
+
height: cursor.to_i - 140,
|
30
|
+
step_length: 20,
|
31
|
+
negative_axes_length: 40,
|
32
|
+
color: 'FF0000'
|
33
|
+
)
|
24
34
|
end
|
@@ -1,5 +1,5 @@
|
|
1
|
-
#
|
2
|
-
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
3
|
# The <code>line_width=</code> method sets the stroke width for subsequent
|
4
4
|
# stroke calls.
|
5
5
|
#
|
@@ -7,29 +7,30 @@
|
|
7
7
|
# assignment is a local temporary, rather than a setter method, if you are using
|
8
8
|
# the block call to <code>Prawn::Document.generate</code> without passing params
|
9
9
|
# you will need to call <code>line_width</code> on self.
|
10
|
-
|
11
|
-
|
12
|
-
|
10
|
+
|
11
|
+
# rubocop: disable Lint/UselessAssignment
|
12
|
+
require_relative '../example_helper'
|
13
13
|
|
14
14
|
filename = File.basename(__FILE__).gsub('.rb', '.pdf')
|
15
|
-
Prawn::Example.generate(filename) do
|
15
|
+
Prawn::ManualBuilder::Example.generate(filename) do
|
16
16
|
stroke_axis
|
17
|
-
|
17
|
+
|
18
18
|
y = 250
|
19
|
-
|
19
|
+
|
20
20
|
3.times do |i|
|
21
21
|
case i
|
22
|
-
when 0 then line_width = 10
|
22
|
+
when 0 then line_width = 10 # This call will have no effect
|
23
23
|
when 1 then self.line_width = 10
|
24
24
|
when 2 then self.line_width = 25
|
25
25
|
end
|
26
|
-
|
26
|
+
|
27
27
|
stroke do
|
28
|
-
horizontal_line 50, 150, :
|
28
|
+
horizontal_line 50, 150, at: y
|
29
29
|
rectangle [275, y + 25], 50, 50
|
30
30
|
circle [500, y], 25
|
31
31
|
end
|
32
|
-
|
32
|
+
|
33
33
|
y -= 100
|
34
34
|
end
|
35
35
|
end
|
36
|
+
# rubocop: enable Lint/UselessAssignment
|
@@ -1,5 +1,5 @@
|
|
1
|
-
#
|
2
|
-
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
3
|
# Prawn supports drawing both lines and curves starting either at the current
|
4
4
|
# position, or from a specified starting position.
|
5
5
|
#
|
@@ -14,28 +14,27 @@
|
|
14
14
|
#
|
15
15
|
# Both curve methods define a Bezier curve bounded by two aditional points
|
16
16
|
# provided as the <code>:bounds</code> param.
|
17
|
-
|
18
|
-
|
19
|
-
%w[.. example_helper]))
|
17
|
+
|
18
|
+
require_relative '../example_helper'
|
20
19
|
|
21
20
|
filename = File.basename(__FILE__).gsub('.rb', '.pdf')
|
22
|
-
Prawn::Example.generate(filename) do
|
21
|
+
Prawn::ManualBuilder::Example.generate(filename) do
|
23
22
|
stroke_axis
|
24
|
-
|
23
|
+
|
25
24
|
# line_to and curve_to
|
26
25
|
stroke do
|
27
26
|
move_to 0, 0
|
28
|
-
|
27
|
+
|
29
28
|
line_to 100, 100
|
30
29
|
line_to 0, 100
|
31
|
-
|
32
|
-
curve_to [150, 250], :
|
33
|
-
curve_to [200, 0],
|
30
|
+
|
31
|
+
curve_to [150, 250], bounds: [[20, 200], [120, 200]]
|
32
|
+
curve_to [200, 0], bounds: [[150, 200], [450, 10]]
|
34
33
|
end
|
35
|
-
|
34
|
+
|
36
35
|
# line and curve
|
37
36
|
stroke do
|
38
|
-
line [300,200], [400,50]
|
39
|
-
curve [500, 0], [400, 200], :
|
37
|
+
line [300, 200], [400, 50]
|
38
|
+
curve [500, 0], [400, 200], bounds: [[600, 300], [300, 390]]
|
40
39
|
end
|
41
40
|
end
|
data/manual/graphics/polygon.rb
CHANGED
@@ -1,29 +1,27 @@
|
|
1
|
-
#
|
2
|
-
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
3
|
# Drawing polygons in Prawn is easy, just pass a sequence of points to one of
|
4
4
|
# the polygon family of methods.
|
5
5
|
#
|
6
6
|
# Just like <code>rounded_rectangle</code> we also have
|
7
7
|
# <code>rounded_polygon</code>. The only difference is the radius param comes
|
8
8
|
# before the polygon points.
|
9
|
-
|
10
|
-
|
11
|
-
%w[.. example_helper]))
|
9
|
+
|
10
|
+
require_relative '../example_helper'
|
12
11
|
|
13
12
|
filename = File.basename(__FILE__).gsub('.rb', '.pdf')
|
14
|
-
Prawn::Example.generate(filename) do
|
13
|
+
Prawn::ManualBuilder::Example.generate(filename) do
|
15
14
|
stroke_axis
|
16
15
|
|
17
16
|
# Triangle
|
18
17
|
stroke_polygon [50, 200], [50, 300], [150, 300]
|
19
|
-
|
18
|
+
|
20
19
|
# Hexagon
|
21
|
-
fill_polygon [50, 150], [150, 200], [250, 150],
|
22
|
-
|
23
|
-
|
20
|
+
fill_polygon [50, 150], [150, 200], [250, 150], [250, 50], [150, 0], [50, 50]
|
21
|
+
|
24
22
|
# Pentagram
|
25
23
|
pentagon_points = [500, 100], [430, 5], [319, 41], [319, 159], [430, 195]
|
26
|
-
pentagram_points = [0, 2, 4, 1, 3].map{ |i| pentagon_points[i] }
|
27
|
-
|
24
|
+
pentagram_points = [0, 2, 4, 1, 3].map { |i| pentagon_points[i] }
|
25
|
+
|
28
26
|
stroke_rounded_polygon(20, *pentagram_points)
|
29
27
|
end
|
@@ -1,21 +1,20 @@
|
|
1
|
-
#
|
2
|
-
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
3
|
# To draw a rectangle, just provide the upper-left corner, width and height to
|
4
4
|
# the <code>rectangle</code> method.
|
5
5
|
#
|
6
6
|
# There's also <code>rounded_rectangle</code>. Just provide an additional radius
|
7
7
|
# value for the rounded corners.
|
8
|
-
|
9
|
-
|
10
|
-
%w[.. example_helper]))
|
8
|
+
|
9
|
+
require_relative '../example_helper'
|
11
10
|
|
12
11
|
filename = File.basename(__FILE__).gsub('.rb', '.pdf')
|
13
|
-
Prawn::Example.generate(filename) do
|
12
|
+
Prawn::ManualBuilder::Example.generate(filename) do
|
14
13
|
stroke_axis
|
15
|
-
|
14
|
+
|
16
15
|
stroke do
|
17
16
|
rectangle [100, 300], 100, 200
|
18
|
-
|
17
|
+
|
19
18
|
rounded_rectangle [300, 300], 100, 200, 20
|
20
19
|
end
|
21
20
|
end
|
data/manual/graphics/rotate.rb
CHANGED
@@ -1,5 +1,5 @@
|
|
1
|
-
#
|
2
|
-
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
3
|
# This transformation is used to rotate the user space. Give it an angle
|
4
4
|
# and an <code>:origin</code> point about which to rotate and a block.
|
5
5
|
# Everything inside the block will be drawn with the rotated coordinates.
|
@@ -7,22 +7,19 @@
|
|
7
7
|
# The angle is in degrees.
|
8
8
|
#
|
9
9
|
# If you omit the <code>:origin</code> option the page origin will be used.
|
10
|
-
|
11
|
-
|
12
|
-
%w[.. example_helper]))
|
10
|
+
|
11
|
+
require_relative '../example_helper'
|
13
12
|
|
14
13
|
filename = File.basename(__FILE__).gsub('.rb', '.pdf')
|
15
|
-
Prawn::Example.generate(filename) do
|
14
|
+
Prawn::ManualBuilder::Example.generate(filename) do
|
16
15
|
stroke_axis
|
17
|
-
|
16
|
+
|
18
17
|
fill_circle [250, 200], 2
|
19
|
-
|
18
|
+
|
20
19
|
12.times do |i|
|
21
|
-
|
22
|
-
rotate(i * 30, :origin => [250, 200]) do
|
23
|
-
|
20
|
+
rotate(i * 30, origin: [250, 200]) do
|
24
21
|
stroke_rectangle [350, 225], 100, 50
|
25
|
-
draw_text "Rotated #{i * 30}°", :
|
22
|
+
draw_text "Rotated #{i * 30}°", size: 10, at: [360, 205]
|
26
23
|
end
|
27
24
|
end
|
28
25
|
end
|
data/manual/graphics/scale.rb
CHANGED
@@ -1,41 +1,42 @@
|
|
1
|
-
#
|
2
|
-
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
3
|
# This transformation is used to scale the user space. Give it an scale factor
|
4
4
|
# and an <code>:origin</code> point and everything inside the block will be
|
5
5
|
# scaled using the origin point as reference.
|
6
6
|
#
|
7
7
|
# If you omit the <code>:origin</code> option the page origin will be used.
|
8
|
-
|
9
|
-
|
10
|
-
%w[.. example_helper]))
|
8
|
+
|
9
|
+
require_relative '../example_helper'
|
11
10
|
|
12
11
|
filename = File.basename(__FILE__).gsub('.rb', '.pdf')
|
13
|
-
Prawn::Example.generate(filename) do
|
12
|
+
Prawn::ManualBuilder::Example.generate(filename) do
|
14
13
|
stroke_axis
|
15
|
-
|
14
|
+
|
16
15
|
width = 100
|
17
16
|
height = 50
|
18
|
-
|
17
|
+
|
19
18
|
x = 50
|
20
19
|
y = 200
|
21
20
|
|
22
21
|
stroke_rectangle [x, y], width, height
|
23
|
-
text_box
|
24
|
-
|
25
|
-
scale(2, :
|
22
|
+
text_box 'reference rectangle', at: [x + 10, y - 10], width: width - 20
|
23
|
+
|
24
|
+
scale(2, origin: [x, y]) do
|
26
25
|
stroke_rectangle [x, y], width, height
|
27
|
-
text_box
|
28
|
-
|
26
|
+
text_box 'rectangle scaled from upper-left corner',
|
27
|
+
at: [x, y - height - 5],
|
28
|
+
width: width
|
29
29
|
end
|
30
30
|
|
31
31
|
x = 350
|
32
32
|
|
33
33
|
stroke_rectangle [x, y], width, height
|
34
|
-
text_box
|
35
|
-
|
36
|
-
scale(2, :
|
34
|
+
text_box 'reference rectangle', at: [x + 10, y - 10], width: width - 20
|
35
|
+
|
36
|
+
scale(2, origin: [x + width / 2, y - height / 2]) do
|
37
37
|
stroke_rectangle [x, y], width, height
|
38
|
-
text_box
|
39
|
-
|
38
|
+
text_box 'rectangle scaled from center',
|
39
|
+
at: [x, y - height - 5],
|
40
|
+
width: width
|
40
41
|
end
|
41
42
|
end
|
@@ -1,6 +1,6 @@
|
|
1
|
-
#
|
2
|
-
|
3
|
-
# Soft masks are
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
# Soft masks are used for more complex alpha channel manipulations. You can use
|
4
4
|
# arbitrary drawing functions for creation of soft masks. The resulting alpha
|
5
5
|
# channel is made of greyscale version of the drawing (luminosity channel to be
|
6
6
|
# precise). So while you can use any combination of colors for soft masks it's
|
@@ -11,11 +11,10 @@
|
|
11
11
|
# only to a part of page you need to enclose drawing instructions in
|
12
12
|
# <code>save_graphics_state</code> block.
|
13
13
|
|
14
|
-
|
15
|
-
%w[.. example_helper]))
|
14
|
+
require_relative '../example_helper'
|
16
15
|
|
17
16
|
filename = File.basename(__FILE__).gsub('.rb', '.pdf')
|
18
|
-
Prawn::Example.generate(filename) do
|
17
|
+
Prawn::ManualBuilder::Example.generate(filename) do
|
19
18
|
save_graphics_state do
|
20
19
|
soft_mask do
|
21
20
|
0.upto 15 do |i|
|
@@ -42,5 +41,4 @@ Prawn::Example.generate(filename) do
|
|
42
41
|
fill_color '61bb46'
|
43
42
|
fill_rectangle [0, 160], 600, 20
|
44
43
|
end
|
45
|
-
|
46
44
|
end
|
@@ -1,5 +1,5 @@
|
|
1
|
-
#
|
2
|
-
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
3
|
# The cap style defines how the edge of a line or curve will be drawn. There are
|
4
4
|
# three types: <code>:butt</code> (the default), <code>:round</code> and
|
5
5
|
# <code>:projecting_square</code>
|
@@ -11,21 +11,20 @@
|
|
11
11
|
#
|
12
12
|
# Just like <code>line_width=</code> the <code>cap_style=</code> method needs an
|
13
13
|
# explicit receiver to work.
|
14
|
-
|
15
|
-
|
16
|
-
%w[.. example_helper]))
|
14
|
+
|
15
|
+
require_relative '../example_helper'
|
17
16
|
|
18
17
|
filename = File.basename(__FILE__).gsub('.rb', '.pdf')
|
19
|
-
Prawn::Example.generate(filename) do
|
18
|
+
Prawn::ManualBuilder::Example.generate(filename) do
|
20
19
|
stroke_axis
|
21
|
-
|
20
|
+
|
22
21
|
self.line_width = 25
|
23
22
|
|
24
|
-
[
|
23
|
+
%i[butt round projecting_square].each_with_index do |cap, i|
|
25
24
|
self.cap_style = cap
|
26
|
-
|
27
|
-
y = 250 - i*100
|
28
|
-
stroke_horizontal_line 100, 300, :
|
25
|
+
|
26
|
+
y = 250 - i * 100
|
27
|
+
stroke_horizontal_line 100, 300, at: y
|
29
28
|
stroke_circle [400, y], 15
|
30
29
|
end
|
31
30
|
end
|
@@ -1,5 +1,5 @@
|
|
1
|
-
#
|
2
|
-
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
3
|
# This sets the dashed pattern for lines and curves. The (dash) length defines
|
4
4
|
# how long each dash will be.
|
5
5
|
#
|
@@ -12,37 +12,36 @@
|
|
12
12
|
# Complex dash patterns can be specified by using an array with alternating
|
13
13
|
# dash/gap lengths for the first parameter (note that the <code>:space</code>
|
14
14
|
# option is ignored in this case).
|
15
|
-
|
16
|
-
|
17
|
-
%w[.. example_helper]))
|
15
|
+
|
16
|
+
require_relative '../example_helper'
|
18
17
|
|
19
18
|
filename = File.basename(__FILE__).gsub('.rb', '.pdf')
|
20
|
-
Prawn::Example.generate(filename) do
|
19
|
+
Prawn::ManualBuilder::Example.generate(filename) do
|
21
20
|
stroke_axis
|
22
21
|
|
23
|
-
dash([1, 2, 3, 2, 1, 5], :
|
24
|
-
stroke_horizontal_line 50, 500, :
|
22
|
+
dash([1, 2, 3, 2, 1, 5], phase: 6)
|
23
|
+
stroke_horizontal_line 50, 500, at: 230
|
25
24
|
dash([1, 2, 3, 4, 5, 6, 7, 8])
|
26
|
-
stroke_horizontal_line 50, 500, :
|
25
|
+
stroke_horizontal_line 50, 500, at: 220
|
27
26
|
|
28
27
|
base_y = 210
|
29
28
|
|
30
29
|
24.times do |i|
|
31
30
|
length = (i / 4) + 1
|
32
|
-
space = length
|
33
|
-
phase = 0
|
31
|
+
space = length # space between dashes same length as dash
|
32
|
+
phase = 0 # start with dash
|
34
33
|
|
35
34
|
case i % 4
|
36
35
|
when 0 then base_y -= 5
|
37
|
-
when 1 then phase = length
|
38
|
-
when 2 then space = length * 0.5
|
36
|
+
when 1 then phase = length # start with space between dashes
|
37
|
+
when 2 then space = length * 0.5 # space between dashes half as long as dash
|
39
38
|
when 3
|
40
|
-
space = length * 0.5
|
41
|
-
phase = length
|
39
|
+
space = length * 0.5 # space between dashes half as long as dash
|
40
|
+
phase = length # start with space between dashes
|
42
41
|
end
|
43
42
|
base_y -= 5
|
44
43
|
|
45
|
-
dash(length, :
|
46
|
-
stroke_horizontal_line 50, 500, :
|
44
|
+
dash(length, space: space, phase: phase)
|
45
|
+
stroke_horizontal_line 50, 500, at: base_y - (2 * i)
|
47
46
|
end
|
48
47
|
end
|
@@ -1,25 +1,24 @@
|
|
1
|
-
#
|
2
|
-
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
3
|
# The join style defines how the intersection between two lines is drawn. There
|
4
4
|
# are three types: <code>:miter</code> (the default), <code>:round</code> and
|
5
5
|
# <code>:bevel</code>
|
6
6
|
#
|
7
7
|
# Just like <code>cap_style</code>, the difference between styles is better
|
8
8
|
# seen with thicker lines.
|
9
|
-
|
10
|
-
|
11
|
-
%w[.. example_helper]))
|
9
|
+
|
10
|
+
require_relative '../example_helper'
|
12
11
|
|
13
12
|
filename = File.basename(__FILE__).gsub('.rb', '.pdf')
|
14
|
-
Prawn::Example.generate(filename) do
|
13
|
+
Prawn::ManualBuilder::Example.generate(filename) do
|
15
14
|
stroke_axis
|
16
|
-
|
15
|
+
|
17
16
|
self.line_width = 25
|
18
|
-
|
19
|
-
[
|
17
|
+
|
18
|
+
%i[miter round bevel].each_with_index do |style, i|
|
20
19
|
self.join_style = style
|
21
|
-
|
22
|
-
y = 200 - i*100
|
20
|
+
|
21
|
+
y = 200 - i * 100
|
23
22
|
stroke do
|
24
23
|
move_to(100, y)
|
25
24
|
line_to(200, y + 100)
|