Text Layouter - Alignment
The HexaPDF::Layout::TextLayouter class can be used to easily lay out text inside a rectangular area, with various horizontal and vertical alignment options.
It is not advised to use the TextLayouter
class directly but instead via the
HexaPDF::Layout::TextBox class and the general document layout
functionality.
The text can be aligned horizontally by setting HexaPDF::Layout::Style#text_align and vertically by HexaPDF::Layout::Style#text_valign. In this example, a sample text is laid out in all possible combinations.
- Usage:
ruby text_layouter_alignment.rb
- Resulting PDF:
- text_layouter_alignment.pdf
- Preview:
Code
require 'hexapdf'
sample_text = "Lorem ipsum dolor sit amet, consectetur adipiscing elit,
sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut
enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut
aliquip ex ea commodo consequat. at".tr("\n", ' ')
doc = HexaPDF::Document.new
canvas = doc.pages.add.canvas
canvas.font("Times", size: 10, variant: :bold)
width = 100
height = 150
y_base = 800
tf = doc.layout.text_fragments(sample_text, font: doc.fonts.add("Times"))
tl = HexaPDF::Layout::TextLayouter.new
[:left, :center, :right, :justify].each_with_index do |align, x_index|
x = x_index * (width + 20) + 70
canvas.text(align.to_s, at: [x + 40, y_base + 15])
[:top, :center, :bottom].each_with_index do |valign, y_index|
y = y_base - (height + 30) * y_index
canvas.text(valign.to_s, at: [20, y - height / 2]) if x_index == 0
tl.style.text_align(align).text_valign(valign)
tl.fit(tf, width, height).draw(canvas, x, y)
canvas.stroke_color("hp-blue-dark").rectangle(x, y, width, -height).stroke
end
end
doc.write("text_layouter_alignment.pdf", optimize: true)