Differences Between: [Versions 310 and 311] [Versions 310 and 400] [Versions 310 and 401] [Versions 310 and 402] [Versions 310 and 403]
(no description)
Author: | Nicola Asuni |
File Size: | 2654 lines (96 kb) |
Included or required: | 0 times |
Referenced: | 0 times |
Includes or requires: | 0 files |
TCPDF_FONTS:: (25 methods):
addTTFfont()
_getTTFtableChecksum()
_getTrueTypeFontSubset()
_putfontwidths()
updateCIDtoGIDmap()
_getfontpath()
getFontFullPath()
getFontRefSize()
unichr()
unichrUnicode()
unichrASCII()
arrUTF8ToUTF16BE()
UTF8ArrayToUniArray()
UTF8ArrSubString()
UniArrSubString()
UTF8ArrToLatin1Arr()
UTF8ArrToLatin1()
uniord()
getUniord()
UTF8StringToArray()
UTF8ToLatin1()
UTF8ToUTF16BE()
utf8StrRev()
utf8StrArrRev()
utf8Bidi()
Class: TCPDF_FONTS - X-Ref
addTTFfont($fontfile, $fonttype='', $enc='', $flags=32, $outpath='', $platid=3, $encid=1, $addcbbox=false, $link=false) X-Ref |
Convert and add the selected TrueType or Type1 font to the fonts folder (that must be writeable). param: $fontfile (string) Font file (full path). param: $fonttype (string) Font type. Leave empty for autodetect mode. Valid values are: TrueTypeUnicode, TrueType, Type1, CID0JP = CID-0 Japanese, CID0KR = CID-0 Korean, CID0CS = CID-0 Chinese Simplified, CID0CT = CID-0 Chinese Traditional. param: $enc (string) Name of the encoding table to use. Leave empty for default mode. Omit this parameter for TrueType Unicode and symbolic fonts like Symbol or ZapfDingBats. param: $flags (int) Unsigned 32-bit integer containing flags specifying various characteristics of the font (PDF32000:2008 - 9.8.2 Font Descriptor Flags): +1 for fixed font; +4 for symbol or +32 for non-symbol; +64 for italic. Fixed and Italic mode are generally autodetected so you have to set it to 32 = non-symbolic font (default) or 4 = symbolic font. param: $outpath (string) Output path for generated font files (must be writeable by the web server). Leave empty for default font folder. param: $platid (int) Platform ID for CMAP table to extract (when building a Unicode font for Windows this value should be 3, for Macintosh should be 1). param: $encid (int) Encoding ID for CMAP table to extract (when building a Unicode font for Windows this value should be 1, for Macintosh should be 0). When Platform ID is 3, legal values for Encoding ID are: 0=Symbol, 1=Unicode, 2=ShiftJIS, 3=PRC, 4=Big5, 5=Wansung, 6=Johab, 7=Reserved, 8=Reserved, 9=Reserved, 10=UCS-4. param: $addcbbox (boolean) If true includes the character bounding box information on the php font file. param: $link (boolean) If true link to system font instead of copying the font data (not transportable) - Note: do not work with Type1 fonts. author: Nicola Asuni return: (string) TCPDF font name or boolean false in case of error. |
_getTTFtableChecksum($table, $length) X-Ref |
Returs the checksum of a TTF table. param: $table (string) table to check param: $length (int) length of table in bytes author: Nicola Asuni return: int checksum |
_getTrueTypeFontSubset($font, $subsetchars) X-Ref |
Returns a subset of the TrueType font data without the unused glyphs. param: $font (string) TrueType font data. param: $subsetchars (array) Array of used characters (the glyphs to keep). author: Nicola Asuni return: (string) A subset of TrueType font data without the unused glyphs. |
_putfontwidths($font, $cidoffset=0) X-Ref |
Outputs font widths param: $font (array) font data param: $cidoffset (int) offset for CID values author: Nicola Asuni return: PDF command string for font widths |
updateCIDtoGIDmap($map, $cid, $gid) X-Ref |
Update the CIDToGIDMap string with a new value. param: $map (string) CIDToGIDMap. param: $cid (int) CID value. param: $gid (int) GID value. author: Nicola Asuni return: (string) CIDToGIDMap. |
_getfontpath() X-Ref |
Return fonts path return: string |
getFontFullPath($file, $fontdir=false) X-Ref |
Return font full path param: $file (string) Font file name. param: $fontdir (string) Font directory (set to false fto search on default directories) author: Nicola Asuni return: string Font full path or empty string |
getFontRefSize($size, $refsize=12) X-Ref |
Get a reference font size. param: $size (string) String containing font size value. param: $refsize (float) Reference font size in points. return: float value in points |
unichr($c, $unicode=true) X-Ref |
Returns the unicode caracter specified by the value param: $c (int) UTF-8 value param: $unicode (boolean) True if we are in unicode mode, false otherwise. return: Returns the specified character. |
unichrUnicode($c) X-Ref |
Returns the unicode caracter specified by UTF-8 value param: $c (int) UTF-8 value return: Returns the specified character. |
unichrASCII($c) X-Ref |
Returns the unicode caracter specified by ASCII value param: $c (int) UTF-8 value return: Returns the specified character. |
arrUTF8ToUTF16BE($unicode, $setbom=false) X-Ref |
Converts array of UTF-8 characters to UTF16-BE string.<br> Based on: http://www.faqs.org/rfcs/rfc2781.html <pre> Encoding UTF-16: Encoding of a single character from an ISO 10646 character value to UTF-16 proceeds as follows. Let U be the character number, no greater than 0x10FFFF. 1) If U < 0x10000, encode U as a 16-bit unsigned integer and terminate. 2) Let U' = U - 0x10000. Because U is less than or equal to 0x10FFFF, U' must be less than or equal to 0xFFFFF. That is, U' can be represented in 20 bits. 3) Initialize two 16-bit unsigned integers, W1 and W2, to 0xD800 and 0xDC00, respectively. These integers each have 10 bits free to encode the character value, for a total of 20 bits. 4) Assign the 10 high-order bits of the 20-bit U' to the 10 low-order bits of W1 and the 10 low-order bits of U' to the 10 low-order bits of W2. Terminate. Graphically, steps 2 through 4 look like: U' = yyyyyyyyyyxxxxxxxxxx W1 = 110110yyyyyyyyyy W2 = 110111xxxxxxxxxx </pre> param: $unicode (array) array containing UTF-8 unicode values param: $setbom (boolean) if true set the Byte Order Mark (BOM = 0xFEFF) author: Nicola Asuni return: string |
UTF8ArrayToUniArray($ta, $isunicode=true) X-Ref |
Convert an array of UTF8 values to array of unicode characters param: $ta (array) The input array of UTF8 values. param: $isunicode (boolean) True for Unicode mode, false otherwise. return: Return array of unicode characters |
UTF8ArrSubString($strarr, $start='', $end='', $unicode=true) X-Ref |
Extract a slice of the $strarr array and return it as string. param: $strarr (string) The input array of characters. param: $start (int) the starting element of $strarr. param: $end (int) first element that will not be returned. param: $unicode (boolean) True if we are in unicode mode, false otherwise. return: Return part of a string |
UniArrSubString($uniarr, $start='', $end='') X-Ref |
Extract a slice of the $uniarr array and return it as string. param: $uniarr (string) The input array of characters. param: $start (int) the starting element of $strarr. param: $end (int) first element that will not be returned. return: Return part of a string |
UTF8ArrToLatin1Arr($unicode) X-Ref |
Converts UTF-8 characters array to array of Latin1 characters array<br> param: $unicode (array) array containing UTF-8 unicode values author: Nicola Asuni return: array |
UTF8ArrToLatin1($unicode) X-Ref |
Converts UTF-8 characters array to array of Latin1 string<br> param: $unicode (array) array containing UTF-8 unicode values author: Nicola Asuni return: array |
uniord($uch) X-Ref |
Converts UTF-8 character to integer value.<br> Uses the getUniord() method if the value is not cached. param: $uch (string) character string to process. return: integer Unicode value |
getUniord($uch) X-Ref |
Converts UTF-8 character to integer value.<br> Invalid byte sequences will be replaced with 0xFFFD (replacement character)<br> Based on: http://www.faqs.org/rfcs/rfc3629.html <pre> Char. number range | UTF-8 octet sequence (hexadecimal) | (binary) --------------------+----------------------------------------------- 0000 0000-0000 007F | 0xxxxxxx 0000 0080-0000 07FF | 110xxxxx 10xxxxxx 0000 0800-0000 FFFF | 1110xxxx 10xxxxxx 10xxxxxx 0001 0000-0010 FFFF | 11110xxx 10xxxxxx 10xxxxxx 10xxxxxx --------------------------------------------------------------------- ABFN notation: --------------------------------------------------------------------- UTF8-octets = *( UTF8-char ) UTF8-char = UTF8-1 / UTF8-2 / UTF8-3 / UTF8-4 UTF8-1 = %x00-7F UTF8-2 = %xC2-DF UTF8-tail UTF8-3 = %xE0 %xA0-BF UTF8-tail / %xE1-EC 2( UTF8-tail ) / %xED %x80-9F UTF8-tail / %xEE-EF 2( UTF8-tail ) UTF8-4 = %xF0 %x90-BF 2( UTF8-tail ) / %xF1-F3 3( UTF8-tail ) / %xF4 %x80-8F 2( UTF8-tail ) UTF8-tail = %x80-BF --------------------------------------------------------------------- </pre> param: $uch (string) character string to process. author: Nicola Asuni return: integer Unicode value |
UTF8StringToArray($str, $isunicode=true, &$currentfont) X-Ref |
Converts UTF-8 strings to codepoints array.<br> Invalid byte sequences will be replaced with 0xFFFD (replacement character)<br> param: $str (string) string to process. param: $isunicode (boolean) True when the documetn is in Unicode mode, false otherwise. param: $currentfont (array) Reference to current font array. author: Nicola Asuni return: array containing codepoints (UTF-8 characters values) |
UTF8ToLatin1($str, $isunicode=true, &$currentfont) X-Ref |
Converts UTF-8 strings to Latin1 when using the standard 14 core fonts.<br> param: $str (string) string to process. param: $isunicode (boolean) True when the documetn is in Unicode mode, false otherwise. param: $currentfont (array) Reference to current font array. return: string |
UTF8ToUTF16BE($str, $setbom=false, $isunicode=true, &$currentfont) X-Ref |
Converts UTF-8 strings to UTF16-BE.<br> param: $str (string) string to process. param: $setbom (boolean) if true set the Byte Order Mark (BOM = 0xFEFF) param: $isunicode (boolean) True when the documetn is in Unicode mode, false otherwise. param: $currentfont (array) Reference to current font array. author: Nicola Asuni return: string |
utf8StrRev($str, $setbom=false, $forcertl=false, $isunicode=true, &$currentfont) X-Ref |
Reverse the RLT substrings using the Bidirectional Algorithm (http://unicode.org/reports/tr9/). param: $str (string) string to manipulate. param: $setbom (bool) if true set the Byte Order Mark (BOM = 0xFEFF) param: $forcertl (bool) if true forces RTL text direction param: $isunicode (boolean) True if the document is in Unicode mode, false otherwise. param: $currentfont (array) Reference to current font array. author: Nicola Asuni return: string |
utf8StrArrRev($arr, $str='', $setbom=false, $forcertl=false, $isunicode=true, &$currentfont) X-Ref |
Reverse the RLT substrings array using the Bidirectional Algorithm (http://unicode.org/reports/tr9/). param: $arr (array) array of unicode values. param: $str (string) string to manipulate (or empty value). param: $setbom (bool) if true set the Byte Order Mark (BOM = 0xFEFF) param: $forcertl (bool) if true forces RTL text direction param: $isunicode (boolean) True if the document is in Unicode mode, false otherwise. param: $currentfont (array) Reference to current font array. author: Nicola Asuni return: string |
utf8Bidi($ta, $str='', $forcertl=false, $isunicode=true, &$currentfont) X-Ref |
Reverse the RLT substrings using the Bidirectional Algorithm (http://unicode.org/reports/tr9/). param: $ta (array) array of characters composing the string. param: $str (string) string to process param: $forcertl (bool) if 'R' forces RTL, if 'L' forces LTR param: $isunicode (boolean) True if the document is in Unicode mode, false otherwise. param: $currentfont (array) Reference to current font array. author: Nicola Asuni return: array of unicode chars |