Sha256: af3431b7103b0fef9d4a63bf73931774835f51849c1661268766fb14b586b4bd

Contents?: true

Size: 1.25 KB

Versions: 2

Compression:

Stored size: 1.25 KB

Contents

# frozen_string_literal: true

# Prawn enables the declaration of fallback fonts for those glyphs that may not
# be present in the desired font. Use the <code>:fallback_fonts</code> option
# with any of the text or text box methods, or set fallback_fonts document-wide.

require_relative '../example_helper'

filename = File.basename(__FILE__).gsub('.rb', '.pdf')
Prawn::ManualBuilder::Example.generate(filename) do
  file = "#{Prawn::DATADIR}/fonts/gkai00mp.ttf"
  font_families['Kai'] = {
    normal: { file: file, font: 'Kai' }
  }

  file = "#{Prawn::DATADIR}/fonts/Panic+Sans.dfont"
  font_families['Panic Sans'] = {
    normal: { file: file, font: 'PanicSans' }
  }

  font('Panic Sans') do
    text(
      'When fallback fonts are included, each glyph will be rendered ' \
      'using the first font that includes the glyph, starting with the ' \
      'current font and then moving through the fallback fonts from left ' \
      'to right.' \
      "\n\n" \
      "hello ƒ 你好\n再见 ƒ goodbye",
      fallback_fonts: %w[Times-Roman Kai]
    )
  end
  move_down 20

  formatted_text(
    [
      { text: 'Fallback fonts can even override' },
      { text: 'fragment fonts (你好)', font: 'Times-Roman' }
    ],
    fallback_fonts: %w[Times-Roman Kai]
  )
end

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
prawn-2.4.0 manual/text/fallback_fonts.rb
prawn-2.3.0 manual/text/fallback_fonts.rb