Sha256: af4830c6999959a6a78eeb26078475775f5913613a930c99d603f469e4826172

Contents?: true

Size: 1.38 KB

Versions: 2

Compression:

Stored size: 1.38 KB

Contents

# encoding: utf-8
#
# 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 File.expand_path(File.join(File.dirname(__FILE__),
                                   %w[.. 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 => ["Times-Roman", "Kai"])
  end
  move_down 20

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

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
prawn-2.1.0 manual/text/fallback_fonts.rb
prawn-2.0.2 manual/text/fallback_fonts.rb