Sha256: 772a78c16ff3f9832c9fd5e4d52dc67f1dad6aec7f5b90a105e85b1e3c1473d2

Contents?: true

Size: 1.72 KB

Versions: 1

Compression:

Stored size: 1.72 KB

Contents

# frozen_string_literal: true

# The <code>text_box</code> method accepts both <code>:width</code> and
# <code>:height</code> options. So what happens if the text doesn't fit the box?
#
# The default behavior is to truncate the text but this can be changed with
# the <code>:overflow</code> option. Available modes are <code>:expand</code>
# (the box will increase to fit the text) and <code>:shrink_to_fit</code>
# (the text font size will be shrunk to fit).
#
# If <code>:shrink_to_fit</code> mode is used with the
# <code>:min_font_size</code> option set, the font size will not be reduced to
# less than the value provided even if it means truncating some text.
#
# If the <code>:disable_wrap_by_char</code> is set to <code>true</code>
# then any text wrapping done while using the <code>:shrink_to_fit</code>
# mode will not break up the middle of words.

require_relative '../example_helper'

filename = File.basename(__FILE__).gsub('.rb', '.pdf')
Prawn::ManualBuilder::Example.generate(filename) do
  string = 'This is the sample text used for the text boxes. See how it ' \
    'behave with the various overflow options used.'

  text string

  y_position = cursor - 20
  %i[truncate expand shrink_to_fit].each_with_index do |mode, i|
    text_box string,
      at: [i * 150, y_position],
      width: 100,
      height: 50,
      overflow: mode
  end

  string = 'If the box is too small for the text, :shrink_to_fit ' \
    'can render the text in a really small font size.'

  move_down 120
  text string
  y_position = cursor - 20
  [nil, 8, 10, 12].each_with_index do |value, index|
    text_box string,
      at: [index * 150, y_position],
      width: 50,
      height: 50,
      overflow: :shrink_to_fit,
      min_font_size: value
  end
end

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
prawn-2.4.0 manual/text/text_box_overflow.rb