Boxes
The HexaPDF::Layout::Box class is used as the basis for all document layout features.
While it is possible to use boxes in this manual way, the preferred way is to use them through the Composer class.
This example shows the basic properties that are available for all boxes, like paddings, borders and and background color. It is also possible to use the underlay and overlay callbacks with boxes.
- Usage:
ruby boxes.rb
- Resulting PDF:
- boxes.pdf
- Preview:
Code
require 'hexapdf'
doc = HexaPDF::Document.new
annotate_box = lambda do |canvas, box|
text = ""
canvas.font("Times", size: 6).leading(7)
if (data = box.style.padding)
text << "Padding (TRBL): #{data.top}, #{data.right}, #{data.bottom}, #{data.left}\n"
end
unless box.style.border.none?
data = box.style.border.width
text << "Border Width (TRBL): #{data.top}, #{data.right}, #{data.bottom}, #{data.left}\n"
data = box.style.border.color
text << "Border Color (TRBL):\n* #{data.top}\n* #{data.right}\n* #{data.bottom}\n* #{data.left}\n"
data = box.style.border.style
text << "Border Style (TRBL):\n* #{data.top}\n* #{data.right}\n* #{data.bottom}\n* #{data.left}\n"
end
canvas.line_width(0.1).rectangle(0, 0, box.content_width, box.content_height).stroke
canvas.text(text, at: [0, box.content_height - 10])
end
canvas = doc.pages.add.canvas
[[1, "hp-blue-light"], [5, "hp-teal-light"],
[15, "hp-orange-light"]].each_with_index do |(width, color), row|
color = canvas.color_from_specification([color])
[:solid, :dashed, :dashed_round, :dotted].each_with_index do |style, column|
box = HexaPDF::Layout::Box.create(
width: 100, height: 100, content_box: true,
border: {width: width, style: style},
background_color: color.components.map {|c| c + 0.2 * column },
&annotate_box)
box.draw(canvas, 20 + 140 * column, 700 - 150 * row)
end
end
# The whole kitchen sink
box = HexaPDF::Layout::Box.create(
width: 470, height: 200, content_box: true,
padding: [20, 5, 10, 15],
border: {width: [20, 40, 30, 15],
color: ["hp-blue", "hp-orange", "hp-teal", "hp-blue-light"],
style: [:solid, :dashed, :dashed_round, :dotted]},
background_color: "hp-orange-light2",
underlays: [
lambda do |canv, _|
canv.stroke_color([255, 0, 0]).line_width(10).line_cap_style(:butt).
line(0, 0, box.width, box.height).line(0, box.height, box.width, 0).
stroke
end
],
overlays: [
lambda do |canv, _|
canv.stroke_color("hp-blue-dark").line_width(5).
rectangle(10, 10, box.width - 20, box.height - 20).stroke
end
],
&annotate_box)
box.draw(canvas, 20, 100)
doc.write("boxes.pdf", optimize: true)