Source for file Drawing.php
Documentation is available at Drawing.php
* Copyright (c) 2006 - 2010 PHPExcel
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
* @package PHPExcel_Shared
* @copyright Copyright (c) 2006 - 2010 PHPExcel (http://www.codeplex.com/PHPExcel)
* @license http://www.gnu.org/licenses/old-licenses/lgpl-2.1.txt LGPL
* @version 1.7.3c, 2010-06-01
* PHPExcel_Shared_Drawing
* @package PHPExcel_Shared
* @copyright Copyright (c) 2006 - 2010 PHPExcel (http://www.codeplex.com/PHPExcel)
* @param int $pValue Value in pixels
* @return int Value in EMU
return round($pValue * 9525);
* @param int $pValue Value in EMU
* @return int Value in pixels
return round($pValue / 9525);
* Convert pixels to column width. Exact algorithm not known.
* By inspection of a real Excel file using Calibri 11, one finds 1000px ~ 142.85546875
* This gives a conversion factor of 7. Also, we assume that pixels and font size are proportional.
* @param int $pValue Value in pixels
* @param PHPExcel_Style_Font $pDefaultFont Default font of the workbook
* @return int Value in cell dimension
$name = $pDefaultFont->getName();
$size = $pDefaultFont->getSize();
// Exact width can be determined
* PHPExcel_Shared_Font::$defaultColumnWidths[$name][$size]['width']
/ PHPExcel_Shared_Font::$defaultColumnWidths[$name][$size]['px'];
// We don't have data for this particular font and size, use approximation by
// extrapolating from Calibri 11
* PHPExcel_Shared_Font::$defaultColumnWidths['Calibri'][11]['width']
/ PHPExcel_Shared_Font::$defaultColumnWidths['Calibri'][11]['px'] / $size;
* Convert column width from (intrinsic) Excel units to pixels
* @param float $pValue Value in cell dimension
* @param PHPExcel_Style_Font $pDefaultFont Default font of the workbook
* @return int Value in pixels
$name = $pDefaultFont->getName();
$size = $pDefaultFont->getSize();
if (isset (PHPExcel_Shared_Font::$defaultColumnWidths[$name][$size])) {
// Exact width can be determined
* PHPExcel_Shared_Font::$defaultColumnWidths[$name][$size]['px']
/ PHPExcel_Shared_Font::$defaultColumnWidths[$name][$size]['width'];
// We don't have data for this particular font and size, use approximation by
// extrapolating from Calibri 11
$colWidth = $pValue * $size
* PHPExcel_Shared_Font::$defaultColumnWidths['Calibri'][11]['px']
/ PHPExcel_Shared_Font::$defaultColumnWidths['Calibri'][11]['width'] / 11;
// Round pixels to closest integer
$colWidth = (int) round($colWidth);
* Convert pixels to points
* @param int $pValue Value in pixels
* @return int Value in points
return $pValue * 0.67777777;
* Convert points to pixels
* @param int $pValue Value in points
* @return int Value in pixels
return (int) ceil($pValue * 1.333333333);
* Convert degrees to angle
* @param int $pValue Degrees
return (int) round($pValue * 60000);
* Convert angle to degrees
* @param int $pValue Angle
return round($pValue / 60000);
* Create a new image from file. By alexander at alexauto dot nl
* @link http://www.php.net/manual/en/function.imagecreatefromwbmp.php#86214
* @param string $filename Path to Windows DIB (BMP) image
// Load the image into a string
$file = fopen($p_sFile,"rb");
while(!feof($file)&& ($read<> ""))
$read .= fread($file,1024);
// Structure: http://www.fastgraph.com/help/bmp_header_format.html
if (substr($header,0,4)== "424d")
// Cut it in parts of 2 bytes
$width = hexdec($header_parts[19]. $header_parts[18]);
// Get the height 4 bytes
$height = hexdec($header_parts[23]. $header_parts[22]);
// Unset the header params
// Define starting X and Y
// Grab the body from the image
// Calculate if padding at the end-line is needed
// Divided by two to keep overview.
$body_size = (strlen($body)/ 2);
$header_size = ($width* $height);
// Use end-line padding? Only when needed
$usePadding = ($body_size> ($header_size* 3)+ 4);
// Using a for-loop with index-calculation instaid of str_split to avoid large memory consumption
// Calculate the next DWORD-position in the body
for ($i= 0;$i< $body_size;$i+= 3)
// Calculate line-ending and padding
// If padding needed, ignore image-padding
// Shift i to the ending of the current 32-bit-block
// Reset horizontal position
// Raise the height-position (bottom-up)
// Reached the image-height? Break the for-loop
// Calculation of the RGB-pixel (defined as BGR in image-data)
// Define $i_pos as absolute position in the body
$r = hexdec($body[$i_pos+ 4]. $body[$i_pos+ 5]);
$g = hexdec($body[$i_pos+ 2]. $body[$i_pos+ 3]);
$b = hexdec($body[$i_pos]. $body[$i_pos+ 1]);
// Calculate and draw the pixel
// Raise the horizontal position
// Unset the body / free the memory
|