1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61
|
# coding: utf-8
#
require 'forwardable'
class PDF::Reader
# A Hash-like object that wraps the array of glyph widths in a CID font
# and gives us a nice way to query it for specific widths.
#
# there are two ways to calculate a cidfont_glyph_width, that are defined
# in Section 9.7.4.3 PDF 32000-1:2008 pp 271, the differences are remarked
# on below. because of these difference that may be contained within the
# same array, it is a bit difficult to parse this array.
class CidWidths
extend Forwardable
# Graphics State Operators
def_delegators :@widths, :[], :fetch
def initialize(default, array)
@widths = parse_array(default, array.dup)
end
private
def parse_array(default, array)
widths = Hash.new(default)
params = []
while array.size > 0
params << array.shift
if params.size == 2 && params.last.is_a?(Array)
widths.merge! parse_first_form(params.first, params.last)
params = []
elsif params.size == 3
widths.merge! parse_second_form(params[0], params[1], params[2])
params = []
end
end
widths
end
# this is the form 10 [234 63 234 346 47 234] where width of index 10 is
# 234, index 11 is 63, etc
def parse_first_form(first, widths)
widths.inject({}) { |accum, glyph_width|
accum[first + accum.size] = glyph_width
accum
}
end
# this is the form 10 20 123 where all index between 10 and 20 have width 123
def parse_second_form(first, final, width)
(first..final).inject({}) { |accum, index|
accum[index] = width
accum
}
end
end
end
|