Sha256: ae459b90b83e76237bfb88f5aeab6c57ede1e9a8eac45b8b13f2c7e678f2738d
Contents?: true
Size: 1.45 KB
Versions: 4
Compression:
Stored size: 1.45 KB
Contents
# coding: utf-8 require 'afm' require 'pdf/reader/synchronized_cache' class PDF::Reader module WidthCalculator # Type1 fonts can be one of 14 "built in" standard fonts. In these cases, # the reader is expected to have it's own copy of the font metrics. # see Section 9.6.2.2, PDF 32000-1:2008, pp 256 class BuiltIn def initialize(font) @font = font @@all_metrics ||= PDF::Reader::SynchronizedCache.new metrics_path = File.join(File.dirname(__FILE__), "..","afm","#{font.basefont}.afm") if File.file?(metrics_path) @metrics = @@all_metrics[metrics_path] ||= AFM::Font.new(metrics_path) else raise ArgumentError, "No built-in metrics for #{font.basefont}" end end def glyph_width(code_point) return 0 if code_point.nil? || code_point < 0 m = @metrics.char_metrics_by_code[code_point] if m.nil? names = @font.encoding.int_to_name(code_point) m = names.map { |name| @metrics.char_metrics[name.to_s] }.compact.first end if m m[:wx] elsif @font.widths[code_point - 1] @font.widths[code_point - 1] elsif control_character?(code_point) 0 else 0 end end private def control_character?(code_point) @font.encoding.int_to_name(code_point).first.to_s[/\Acontrol..\Z/] end end end end
Version data entries
4 entries across 4 versions & 1 rubygems