Pdf/Cmap.php
Zend Framework
LICENSE
This source file is subject to the new BSD license that is bundled
with this package in the file LICENSE.txt.
It is also available through the world-wide-web at this URL:
http://framework.zend.com/license/new-bsd
If you did not receive a copy of the license and are unable to
obtain it through the world-wide-web, please send an email
to license@zend.com so we can send you a copy immediately.
- Category
- Zend
         
    
- Copyright
- Copyright (c) 2005-2014 Zend Technologies USA Inc. (http://www.zend.com)
         
    
- License
- New BSD License
         
    
- Package
- Zend_Pdf
         
    
- Subpackage
- Fonts
         
    
- Version
- $Id$
         
    
Package: Zend_Pdf\FontsAbstract helper class for {@link Zend_Pdf_Resource_Font} which manages font
character maps.
Defines the public interface for concrete subclasses which are responsible
for mapping Unicode characters to the font's glyph numbers. Also provides
shared utility methods.
Cmap objects should ordinarily be obtained through the factory method
{@link cmapWithTypeData()}.
The supported character map types are those found in the OpenType spec. For
additional detail on the internal binary format of these tables, see:
 - {@link http://developer.apple.com/textfonts/TTRefMan/RM06/Chap6cmap.html}
 
- {@link http://www.microsoft.com/OpenType/OTSpec/cmap.htm}
 
- {@link http://partners.adobe.com/public/developer/opentype/index_cmap.html}
- Children
- \Zend_Pdf_Cmap_ByteEncoding
- \Zend_Pdf_Cmap_TrimmedTable
- \Zend_Pdf_Cmap_SegmentToDelta
- Copyright
- Copyright (c) 2005-2014 Zend Technologies USA Inc. (http://www.zend.com)
         
    
- License
- New BSD License
         
    
- Todo
- Write code for Zend_Pdf_FontCmap_HighByteMapping class.
         
    
- Todo
- Write code for Zend_Pdf_FontCmap_MixedCoverage class.
         
    
- Todo
- Write code for Zend_Pdf_FontCmap_TrimmedArray class.
         
    
- Todo
- Write code for Zend_Pdf_FontCmap_SegmentedCoverage class.
         
    
Constants
Methods



 __construct(string $cmapData) : void
__construct(string $cmapData) : voidabstractObject constructor
 Parses the raw binary table data. Throws an exception if the table is
malformed.
Parameters| Name | Type | Description | 
|---|
| $cmapData | string | Raw binary cmap table data. | 
|---|
Throws


 _extractInt2( $data, integer $index) : integer
_extractInt2( $data, integer $index) : integerExtracts a signed 2-byte integer from a string.
Integers are always big-endian. Throws an exception if the index is out
of range.
Parameters| Name | Type | Description | 
|---|
| $data |  |  | 
|---|
| $index | integer | Position in string of integer. | 
|---|
ReturnsThrows


 _extractUInt2( $data, integer $index) : integer
_extractUInt2( $data, integer $index) : integerExtracts an unsigned 2-byte integer from a string.
Integers are always big-endian. Throws an exception if the index is out
of range.
Parameters| Name | Type | Description | 
|---|
| $data |  |  | 
|---|
| $index | integer | Position in string of integer. | 
|---|
ReturnsThrows


 _extractUInt4( $data, integer $index) : integer
_extractUInt4( $data, integer $index) : integerExtracts an unsigned 4-byte integer from a string.
Integers are always big-endian. Throws an exception if the index is out
of range.
NOTE: If you ask for a 4-byte unsigned integer on a 32-bit machine, the
resulting value WILL BE SIGNED because PHP uses signed integers internally
for everything. To guarantee portability, be sure to use bitwise or
similar operators on large integers!
Parameters| Name | Type | Description | 
|---|
| $data |  |  | 
|---|
| $index | integer | Position in string of integer. | 
|---|
ReturnsThrows


 cmapWithTypeData(integer $cmapType, mixed $cmapData) : \Zend_Pdf_Cmap
cmapWithTypeData(integer $cmapType, mixed $cmapData) : \Zend_Pdf_CmapstaticInstantiates the appropriate concrete subclass based on the type of cmap
table and returns the instance.
 The cmap type must be one of the following values:
 - {@link Zend_Pdf_Cmap::TYPE_BYTE_ENCODING}
 
- {@link Zend_Pdf_Cmap::TYPE_BYTE_ENCODING_STATIC}
 
- {@link Zend_Pdf_Cmap::TYPE_HIGH_BYTE_MAPPING}
 
- {@link Zend_Pdf_Cmap::TYPE_SEGMENT_TO_DELTA}
 
- {@link Zend_Pdf_Cmap::TYPE_TRIMMED_TABLE}
 
- {@link Zend_Pdf_Cmap::TYPE_MIXED_COVERAGE}
 
- {@link Zend_Pdf_Cmap::TYPE_TRIMMED_ARRAY}
 
- {@link Zend_Pdf_Cmap::TYPE_SEGMENTED_COVERAGE}
Throws an exception if the table type is invalid or the cmap table data
cannot be validated.
| Name | Type | Description | 
|---|
| $cmapType | integer | Type of cmap. | 
|---|
| $cmapData | mixed | Cmap table data. Usually a string or array. | 
|---|
ReturnsThrows


 getCoveredCharacters() : array
getCoveredCharacters() : arrayabstractReturns an array containing the Unicode characters that have entries in
this character map.
 Returns| Type | Description | 
|---|
| array | Unicode character codes. | 
 


 glyphNumberForCharacter(integer $characterCode) : integer
glyphNumberForCharacter(integer $characterCode) : integerabstractReturns the glyph number corresponding to the Unicode character.
 If a particular character doesn't exist in this font, the special 'missing
character glyph' will be substituted.
See also {@link glyphNumbersForCharacters()} which is optimized for bulk
operations.
Parameters| Name | Type | Description | 
|---|
| $characterCode | integer | Unicode character code (code point). | 
|---|
Returns| Type | Description | 
|---|
| integer | Glyph number. | 



 glyphNumbersForCharacters(array $characterCodes) : array
glyphNumbersForCharacters(array $characterCodes) : arrayabstractReturns an array of glyph numbers corresponding to the Unicode characters.
 If a particular character doesn't exist in this font, the special 'missing
character glyph' will be substituted.
See also {@link glyphNumberForCharacter()}.
Parameters| Name | Type | Description | 
|---|
| $characterCodes | array | Array of Unicode character codes (code points). | 
|---|
Returns| Type | Description | 
|---|
| array | Array of glyph numbers. |