| 2388 | jpm | 1 | <?php
 | 
        
           |  |  | 2 | /**
 | 
        
           |  |  | 3 |  * PHPExcel
 | 
        
           |  |  | 4 |  *
 | 
        
           |  |  | 5 |  * Copyright (c) 2006 - 2013 PHPExcel
 | 
        
           |  |  | 6 |  *
 | 
        
           |  |  | 7 |  * This library is free software; you can redistribute it and/or
 | 
        
           |  |  | 8 |  * modify it under the terms of the GNU Lesser General Public
 | 
        
           |  |  | 9 |  * License as published by the Free Software Foundation; either
 | 
        
           |  |  | 10 |  * version 2.1 of the License, or (at your option) any later version.
 | 
        
           |  |  | 11 |  *
 | 
        
           |  |  | 12 |  * This library is distributed in the hope that it will be useful,
 | 
        
           |  |  | 13 |  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 | 
        
           |  |  | 14 |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 | 
        
           |  |  | 15 |  * Lesser General Public License for more details.
 | 
        
           |  |  | 16 |  *
 | 
        
           |  |  | 17 |  * You should have received a copy of the GNU Lesser General Public
 | 
        
           |  |  | 18 |  * License along with this library; if not, write to the Free Software
 | 
        
           |  |  | 19 |  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA
 | 
        
           |  |  | 20 |  *
 | 
        
           |  |  | 21 |  * @category   PHPExcel
 | 
        
           |  |  | 22 |  * @package    PHPExcel_Writer_Excel5
 | 
        
           |  |  | 23 |  * @copyright  Copyright (c) 2006 - 2013 PHPExcel (http://www.codeplex.com/PHPExcel)
 | 
        
           |  |  | 24 |  * @license    http://www.gnu.org/licenses/old-licenses/lgpl-2.1.txt	LGPL
 | 
        
           |  |  | 25 |  * @version    ##VERSION##, ##DATE##
 | 
        
           |  |  | 26 |  */
 | 
        
           |  |  | 27 |   | 
        
           |  |  | 28 | // Original file header of PEAR::Spreadsheet_Excel_Writer_Format (used as the base for this class):
 | 
        
           |  |  | 29 | // -----------------------------------------------------------------------------------------
 | 
        
           |  |  | 30 | // /*
 | 
        
           |  |  | 31 | // *  Module written/ported by Xavier Noguer <xnoguer@rezebra.com>
 | 
        
           |  |  | 32 | // *
 | 
        
           |  |  | 33 | // *  The majority of this is _NOT_ my code.  I simply ported it from the
 | 
        
           |  |  | 34 | // *  PERL Spreadsheet::WriteExcel module.
 | 
        
           |  |  | 35 | // *
 | 
        
           |  |  | 36 | // *  The author of the Spreadsheet::WriteExcel module is John McNamara
 | 
        
           |  |  | 37 | // *  <jmcnamara@cpan.org>
 | 
        
           |  |  | 38 | // *
 | 
        
           |  |  | 39 | // *  I _DO_ maintain this code, and John McNamara has nothing to do with the
 | 
        
           |  |  | 40 | // *  porting of this code to PHP.  Any questions directly related to this
 | 
        
           |  |  | 41 | // *  class library should be directed to me.
 | 
        
           |  |  | 42 | // *
 | 
        
           |  |  | 43 | // *  License Information:
 | 
        
           |  |  | 44 | // *
 | 
        
           |  |  | 45 | // *    Spreadsheet_Excel_Writer:  A library for generating Excel Spreadsheets
 | 
        
           |  |  | 46 | // *    Copyright (c) 2002-2003 Xavier Noguer xnoguer@rezebra.com
 | 
        
           |  |  | 47 | // *
 | 
        
           |  |  | 48 | // *    This library is free software; you can redistribute it and/or
 | 
        
           |  |  | 49 | // *    modify it under the terms of the GNU Lesser General Public
 | 
        
           |  |  | 50 | // *    License as published by the Free Software Foundation; either
 | 
        
           |  |  | 51 | // *    version 2.1 of the License, or (at your option) any later version.
 | 
        
           |  |  | 52 | // *
 | 
        
           |  |  | 53 | // *    This library is distributed in the hope that it will be useful,
 | 
        
           |  |  | 54 | // *    but WITHOUT ANY WARRANTY; without even the implied warranty of
 | 
        
           |  |  | 55 | // *    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 | 
        
           |  |  | 56 | // *    Lesser General Public License for more details.
 | 
        
           |  |  | 57 | // *
 | 
        
           |  |  | 58 | // *    You should have received a copy of the GNU Lesser General Public
 | 
        
           |  |  | 59 | // *    License along with this library; if not, write to the Free Software
 | 
        
           |  |  | 60 | // *    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 | 
        
           |  |  | 61 | // */
 | 
        
           |  |  | 62 |   | 
        
           |  |  | 63 |   | 
        
           |  |  | 64 | /**
 | 
        
           |  |  | 65 |  * PHPExcel_Writer_Excel5_Xf
 | 
        
           |  |  | 66 |  *
 | 
        
           |  |  | 67 |  * @category   PHPExcel
 | 
        
           |  |  | 68 |  * @package    PHPExcel_Writer_Excel5
 | 
        
           |  |  | 69 |  * @copyright  Copyright (c) 2006 - 2013 PHPExcel (http://www.codeplex.com/PHPExcel)
 | 
        
           |  |  | 70 |  */
 | 
        
           |  |  | 71 | class PHPExcel_Writer_Excel5_Xf
 | 
        
           |  |  | 72 | {
 | 
        
           |  |  | 73 |     /**
 | 
        
           |  |  | 74 | 	 * Style XF or a cell XF ?
 | 
        
           |  |  | 75 | 	 *
 | 
        
           |  |  | 76 | 	 * @var boolean
 | 
        
           |  |  | 77 | 	 */
 | 
        
           |  |  | 78 | 	private $_isStyleXf;
 | 
        
           |  |  | 79 |   | 
        
           |  |  | 80 | 	/**
 | 
        
           |  |  | 81 | 	 * Index to the FONT record. Index 4 does not exist
 | 
        
           |  |  | 82 | 	 * @var integer
 | 
        
           |  |  | 83 | 	 */
 | 
        
           |  |  | 84 | 	private $_fontIndex;
 | 
        
           |  |  | 85 |   | 
        
           |  |  | 86 | 	/**
 | 
        
           |  |  | 87 | 	 * An index (2 bytes) to a FORMAT record (number format).
 | 
        
           |  |  | 88 | 	 * @var integer
 | 
        
           |  |  | 89 | 	 */
 | 
        
           |  |  | 90 | 	public $_numberFormatIndex;
 | 
        
           |  |  | 91 |   | 
        
           |  |  | 92 | 	/**
 | 
        
           |  |  | 93 | 	 * 1 bit, apparently not used.
 | 
        
           |  |  | 94 | 	 * @var integer
 | 
        
           |  |  | 95 | 	 */
 | 
        
           |  |  | 96 | 	public $_text_justlast;
 | 
        
           |  |  | 97 |   | 
        
           |  |  | 98 | 	/**
 | 
        
           |  |  | 99 | 	 * The cell's foreground color.
 | 
        
           |  |  | 100 | 	 * @var integer
 | 
        
           |  |  | 101 | 	 */
 | 
        
           |  |  | 102 | 	public $_fg_color;
 | 
        
           |  |  | 103 |   | 
        
           |  |  | 104 | 	/**
 | 
        
           |  |  | 105 | 	 * The cell's background color.
 | 
        
           |  |  | 106 | 	 * @var integer
 | 
        
           |  |  | 107 | 	 */
 | 
        
           |  |  | 108 | 	public $_bg_color;
 | 
        
           |  |  | 109 |   | 
        
           |  |  | 110 | 	/**
 | 
        
           |  |  | 111 | 	 * Color of the bottom border of the cell.
 | 
        
           |  |  | 112 | 	 * @var integer
 | 
        
           |  |  | 113 | 	 */
 | 
        
           |  |  | 114 | 	public $_bottom_color;
 | 
        
           |  |  | 115 |   | 
        
           |  |  | 116 | 	/**
 | 
        
           |  |  | 117 | 	 * Color of the top border of the cell.
 | 
        
           |  |  | 118 | 	 * @var integer
 | 
        
           |  |  | 119 | 	 */
 | 
        
           |  |  | 120 | 	public $_top_color;
 | 
        
           |  |  | 121 |   | 
        
           |  |  | 122 | 	/**
 | 
        
           |  |  | 123 | 	* Color of the left border of the cell.
 | 
        
           |  |  | 124 | 	* @var integer
 | 
        
           |  |  | 125 | 	*/
 | 
        
           |  |  | 126 | 	public $_left_color;
 | 
        
           |  |  | 127 |   | 
        
           |  |  | 128 | 	/**
 | 
        
           |  |  | 129 | 	 * Color of the right border of the cell.
 | 
        
           |  |  | 130 | 	 * @var integer
 | 
        
           |  |  | 131 | 	 */
 | 
        
           |  |  | 132 | 	public $_right_color;
 | 
        
           |  |  | 133 |   | 
        
           |  |  | 134 | 	/**
 | 
        
           |  |  | 135 | 	 * Constructor
 | 
        
           |  |  | 136 | 	 *
 | 
        
           |  |  | 137 | 	 * @access public
 | 
        
           |  |  | 138 | 	 * @param PHPExcel_Style	The XF format
 | 
        
           |  |  | 139 | 	 */
 | 
        
           |  |  | 140 | 	public function __construct(PHPExcel_Style $style = null)
 | 
        
           |  |  | 141 | 	{
 | 
        
           |  |  | 142 | 		$this->_isStyleXf =     false;
 | 
        
           |  |  | 143 | 		$this->_fontIndex      = 0;
 | 
        
           |  |  | 144 |   | 
        
           |  |  | 145 | 		$this->_numberFormatIndex     = 0;
 | 
        
           |  |  | 146 |   | 
        
           |  |  | 147 | 		$this->_text_justlast  = 0;
 | 
        
           |  |  | 148 |   | 
        
           |  |  | 149 | 		$this->_fg_color       = 0x40;
 | 
        
           |  |  | 150 | 		$this->_bg_color       = 0x41;
 | 
        
           |  |  | 151 |   | 
        
           |  |  | 152 | 		$this->_diag           = 0;
 | 
        
           |  |  | 153 |   | 
        
           |  |  | 154 | 		$this->_bottom_color   = 0x40;
 | 
        
           |  |  | 155 | 		$this->_top_color      = 0x40;
 | 
        
           |  |  | 156 | 		$this->_left_color     = 0x40;
 | 
        
           |  |  | 157 | 		$this->_right_color    = 0x40;
 | 
        
           |  |  | 158 | 		$this->_diag_color     = 0x40;
 | 
        
           |  |  | 159 | 		$this->_style = $style;
 | 
        
           |  |  | 160 |   | 
        
           |  |  | 161 | 	}
 | 
        
           |  |  | 162 |   | 
        
           |  |  | 163 |   | 
        
           |  |  | 164 | 	/**
 | 
        
           |  |  | 165 | 	 * Generate an Excel BIFF XF record (style or cell).
 | 
        
           |  |  | 166 | 	 *
 | 
        
           |  |  | 167 | 	 * @return string The XF record
 | 
        
           |  |  | 168 | 	 */
 | 
        
           |  |  | 169 | 	function writeXf()
 | 
        
           |  |  | 170 | 	{
 | 
        
           |  |  | 171 | 		// Set the type of the XF record and some of the attributes.
 | 
        
           |  |  | 172 | 		if ($this->_isStyleXf) {
 | 
        
           |  |  | 173 | 			$style = 0xFFF5;
 | 
        
           |  |  | 174 | 		} else {
 | 
        
           |  |  | 175 | 			$style   = self::_mapLocked($this->_style->getProtection()->getLocked());
 | 
        
           |  |  | 176 | 			$style  |= self::_mapHidden($this->_style->getProtection()->getHidden()) << 1;
 | 
        
           |  |  | 177 | 		}
 | 
        
           |  |  | 178 |   | 
        
           |  |  | 179 | 		// Flags to indicate if attributes have been set.
 | 
        
           |  |  | 180 | 		$atr_num     = ($this->_numberFormatIndex != 0)?1:0;
 | 
        
           |  |  | 181 | 		$atr_fnt     = ($this->_fontIndex != 0)?1:0;
 | 
        
           |  |  | 182 | 		$atr_alc     = ((int) $this->_style->getAlignment()->getWrapText())?1:0;
 | 
        
           |  |  | 183 | 		$atr_bdr     = (self::_mapBorderStyle($this->_style->getBorders()->getBottom()->getBorderStyle())   ||
 | 
        
           |  |  | 184 | 						self::_mapBorderStyle($this->_style->getBorders()->getTop()->getBorderStyle())      ||
 | 
        
           |  |  | 185 | 						self::_mapBorderStyle($this->_style->getBorders()->getLeft()->getBorderStyle())     ||
 | 
        
           |  |  | 186 | 						self::_mapBorderStyle($this->_style->getBorders()->getRight()->getBorderStyle()))?1:0;
 | 
        
           |  |  | 187 | 		$atr_pat     = (($this->_fg_color != 0x40) ||
 | 
        
           |  |  | 188 | 						($this->_bg_color != 0x41) ||
 | 
        
           |  |  | 189 | 						self::_mapFillType($this->_style->getFill()->getFillType()))?1:0;
 | 
        
           |  |  | 190 | 		$atr_prot    = self::_mapLocked($this->_style->getProtection()->getLocked())
 | 
        
           |  |  | 191 | 						| self::_mapHidden($this->_style->getProtection()->getHidden());
 | 
        
           |  |  | 192 |   | 
        
           |  |  | 193 | 		// Zero the default border colour if the border has not been set.
 | 
        
           |  |  | 194 | 		if (self::_mapBorderStyle($this->_style->getBorders()->getBottom()->getBorderStyle()) == 0) {
 | 
        
           |  |  | 195 | 			$this->_bottom_color = 0;
 | 
        
           |  |  | 196 | 		}
 | 
        
           |  |  | 197 | 		if (self::_mapBorderStyle($this->_style->getBorders()->getTop()->getBorderStyle())  == 0) {
 | 
        
           |  |  | 198 | 			$this->_top_color = 0;
 | 
        
           |  |  | 199 | 		}
 | 
        
           |  |  | 200 | 		if (self::_mapBorderStyle($this->_style->getBorders()->getRight()->getBorderStyle()) == 0) {
 | 
        
           |  |  | 201 | 			$this->_right_color = 0;
 | 
        
           |  |  | 202 | 		}
 | 
        
           |  |  | 203 | 		if (self::_mapBorderStyle($this->_style->getBorders()->getLeft()->getBorderStyle()) == 0) {
 | 
        
           |  |  | 204 | 			$this->_left_color = 0;
 | 
        
           |  |  | 205 | 		}
 | 
        
           |  |  | 206 | 		if (self::_mapBorderStyle($this->_style->getBorders()->getDiagonal()->getBorderStyle()) == 0) {
 | 
        
           |  |  | 207 | 			$this->_diag_color = 0;
 | 
        
           |  |  | 208 | 		}
 | 
        
           |  |  | 209 |   | 
        
           |  |  | 210 | 		$record         = 0x00E0;              // Record identifier
 | 
        
           |  |  | 211 | 		$length         = 0x0014;              // Number of bytes to follow
 | 
        
           |  |  | 212 |   | 
        
           |  |  | 213 | 		$ifnt           = $this->_fontIndex;   // Index to FONT record
 | 
        
           |  |  | 214 | 		$ifmt           = $this->_numberFormatIndex;  // Index to FORMAT record
 | 
        
           |  |  | 215 |   | 
        
           |  |  | 216 | 		$align          = $this->_mapHAlign($this->_style->getAlignment()->getHorizontal());       // Alignment
 | 
        
           |  |  | 217 | 		$align         |= (int) $this->_style->getAlignment()->getWrapText()     << 3;
 | 
        
           |  |  | 218 | 		$align         |= self::_mapVAlign($this->_style->getAlignment()->getVertical())  << 4;
 | 
        
           |  |  | 219 | 		$align         |= $this->_text_justlast << 7;
 | 
        
           |  |  | 220 |   | 
        
           |  |  | 221 | 		$used_attrib    = $atr_num              << 2;
 | 
        
           |  |  | 222 | 		$used_attrib   |= $atr_fnt              << 3;
 | 
        
           |  |  | 223 | 		$used_attrib   |= $atr_alc              << 4;
 | 
        
           |  |  | 224 | 		$used_attrib   |= $atr_bdr              << 5;
 | 
        
           |  |  | 225 | 		$used_attrib   |= $atr_pat              << 6;
 | 
        
           |  |  | 226 | 		$used_attrib   |= $atr_prot             << 7;
 | 
        
           |  |  | 227 |   | 
        
           |  |  | 228 | 		$icv            = $this->_fg_color;      // fg and bg pattern colors
 | 
        
           |  |  | 229 | 		$icv           |= $this->_bg_color      << 7;
 | 
        
           |  |  | 230 |   | 
        
           |  |  | 231 | 		$border1        = self::_mapBorderStyle($this->_style->getBorders()->getLeft()->getBorderStyle());          // Border line style and color
 | 
        
           |  |  | 232 | 		$border1       |= self::_mapBorderStyle($this->_style->getBorders()->getRight()->getBorderStyle())         << 4;
 | 
        
           |  |  | 233 | 		$border1       |= self::_mapBorderStyle($this->_style->getBorders()->getTop()->getBorderStyle())           << 8;
 | 
        
           |  |  | 234 | 		$border1       |= self::_mapBorderStyle($this->_style->getBorders()->getBottom()->getBorderStyle())        << 12;
 | 
        
           |  |  | 235 | 		$border1       |= $this->_left_color    << 16;
 | 
        
           |  |  | 236 | 		$border1       |= $this->_right_color   << 23;
 | 
        
           |  |  | 237 |   | 
        
           |  |  | 238 | 		$diagonalDirection = $this->_style->getBorders()->getDiagonalDirection();
 | 
        
           |  |  | 239 | 		$diag_tl_to_rb = $diagonalDirection == PHPExcel_Style_Borders::DIAGONAL_BOTH
 | 
        
           |  |  | 240 | 							|| $diagonalDirection == PHPExcel_Style_Borders::DIAGONAL_DOWN;
 | 
        
           |  |  | 241 | 		$diag_tr_to_lb = $diagonalDirection == PHPExcel_Style_Borders::DIAGONAL_BOTH
 | 
        
           |  |  | 242 | 							|| $diagonalDirection == PHPExcel_Style_Borders::DIAGONAL_UP;
 | 
        
           |  |  | 243 | 		$border1       |= $diag_tl_to_rb        << 30;
 | 
        
           |  |  | 244 | 		$border1       |= $diag_tr_to_lb        << 31;
 | 
        
           |  |  | 245 |   | 
        
           |  |  | 246 | 		$border2        = $this->_top_color;    // Border color
 | 
        
           |  |  | 247 | 		$border2       |= $this->_bottom_color   << 7;
 | 
        
           |  |  | 248 | 		$border2       |= $this->_diag_color     << 14;
 | 
        
           |  |  | 249 | 		$border2       |= self::_mapBorderStyle($this->_style->getBorders()->getDiagonal()->getBorderStyle())           << 21;
 | 
        
           |  |  | 250 | 		$border2       |= self::_mapFillType($this->_style->getFill()->getFillType())        << 26;
 | 
        
           |  |  | 251 |   | 
        
           |  |  | 252 | 		$header      = pack("vv",       $record, $length);
 | 
        
           |  |  | 253 |   | 
        
           |  |  | 254 | 		//BIFF8 options: identation, shrinkToFit and  text direction
 | 
        
           |  |  | 255 | 		$biff8_options  = $this->_style->getAlignment()->getIndent();
 | 
        
           |  |  | 256 | 		$biff8_options |= (int) $this->_style->getAlignment()->getShrinkToFit() << 4;
 | 
        
           |  |  | 257 |   | 
        
           |  |  | 258 | 		$data  = pack("vvvC", $ifnt, $ifmt, $style, $align);
 | 
        
           |  |  | 259 | 		$data .= pack("CCC"
 | 
        
           |  |  | 260 | 			, self::_mapTextRotation($this->_style->getAlignment()->getTextRotation())
 | 
        
           |  |  | 261 | 			, $biff8_options
 | 
        
           |  |  | 262 | 			, $used_attrib
 | 
        
           |  |  | 263 | 			);
 | 
        
           |  |  | 264 | 		$data .= pack("VVv", $border1, $border2, $icv);
 | 
        
           |  |  | 265 |   | 
        
           |  |  | 266 | 		return($header . $data);
 | 
        
           |  |  | 267 | 	}
 | 
        
           |  |  | 268 |   | 
        
           |  |  | 269 | 	/**
 | 
        
           |  |  | 270 | 	 * Is this a style XF ?
 | 
        
           |  |  | 271 | 	 *
 | 
        
           |  |  | 272 | 	 * @param boolean $value
 | 
        
           |  |  | 273 | 	 */
 | 
        
           |  |  | 274 | 	public function setIsStyleXf($value)
 | 
        
           |  |  | 275 | 	{
 | 
        
           |  |  | 276 | 		$this->_isStyleXf = $value;
 | 
        
           |  |  | 277 | 	}
 | 
        
           |  |  | 278 |   | 
        
           |  |  | 279 | 	/**
 | 
        
           |  |  | 280 | 	 * Sets the cell's bottom border color
 | 
        
           |  |  | 281 | 	 *
 | 
        
           |  |  | 282 | 	 * @access public
 | 
        
           |  |  | 283 | 	 * @param int $colorIndex Color index
 | 
        
           |  |  | 284 | 	 */
 | 
        
           |  |  | 285 | 	function setBottomColor($colorIndex)
 | 
        
           |  |  | 286 | 	{
 | 
        
           |  |  | 287 | 		$this->_bottom_color = $colorIndex;
 | 
        
           |  |  | 288 | 	}
 | 
        
           |  |  | 289 |   | 
        
           |  |  | 290 | 	/**
 | 
        
           |  |  | 291 | 	 * Sets the cell's top border color
 | 
        
           |  |  | 292 | 	 *
 | 
        
           |  |  | 293 | 	 * @access public
 | 
        
           |  |  | 294 | 	 * @param int $colorIndex Color index
 | 
        
           |  |  | 295 | 	 */
 | 
        
           |  |  | 296 | 	function setTopColor($colorIndex)
 | 
        
           |  |  | 297 | 	{
 | 
        
           |  |  | 298 | 		$this->_top_color = $colorIndex;
 | 
        
           |  |  | 299 | 	}
 | 
        
           |  |  | 300 |   | 
        
           |  |  | 301 | 	/**
 | 
        
           |  |  | 302 | 	 * Sets the cell's left border color
 | 
        
           |  |  | 303 | 	 *
 | 
        
           |  |  | 304 | 	 * @access public
 | 
        
           |  |  | 305 | 	 * @param int $colorIndex Color index
 | 
        
           |  |  | 306 | 	 */
 | 
        
           |  |  | 307 | 	function setLeftColor($colorIndex)
 | 
        
           |  |  | 308 | 	{
 | 
        
           |  |  | 309 | 		$this->_left_color = $colorIndex;
 | 
        
           |  |  | 310 | 	}
 | 
        
           |  |  | 311 |   | 
        
           |  |  | 312 | 	/**
 | 
        
           |  |  | 313 | 	 * Sets the cell's right border color
 | 
        
           |  |  | 314 | 	 *
 | 
        
           |  |  | 315 | 	 * @access public
 | 
        
           |  |  | 316 | 	 * @param int $colorIndex Color index
 | 
        
           |  |  | 317 | 	 */
 | 
        
           |  |  | 318 | 	function setRightColor($colorIndex)
 | 
        
           |  |  | 319 | 	{
 | 
        
           |  |  | 320 | 		$this->_right_color = $colorIndex;
 | 
        
           |  |  | 321 | 	}
 | 
        
           |  |  | 322 |   | 
        
           |  |  | 323 | 	/**
 | 
        
           |  |  | 324 | 	 * Sets the cell's diagonal border color
 | 
        
           |  |  | 325 | 	 *
 | 
        
           |  |  | 326 | 	 * @access public
 | 
        
           |  |  | 327 | 	 * @param int $colorIndex Color index
 | 
        
           |  |  | 328 | 	 */
 | 
        
           |  |  | 329 | 	function setDiagColor($colorIndex)
 | 
        
           |  |  | 330 | 	{
 | 
        
           |  |  | 331 | 		$this->_diag_color = $colorIndex;
 | 
        
           |  |  | 332 | 	}
 | 
        
           |  |  | 333 |   | 
        
           |  |  | 334 |   | 
        
           |  |  | 335 | 	/**
 | 
        
           |  |  | 336 | 	 * Sets the cell's foreground color
 | 
        
           |  |  | 337 | 	 *
 | 
        
           |  |  | 338 | 	 * @access public
 | 
        
           |  |  | 339 | 	 * @param int $colorIndex Color index
 | 
        
           |  |  | 340 | 	 */
 | 
        
           |  |  | 341 | 	function setFgColor($colorIndex)
 | 
        
           |  |  | 342 | 	{
 | 
        
           |  |  | 343 | 		$this->_fg_color = $colorIndex;
 | 
        
           |  |  | 344 | 	}
 | 
        
           |  |  | 345 |   | 
        
           |  |  | 346 | 	/**
 | 
        
           |  |  | 347 | 	 * Sets the cell's background color
 | 
        
           |  |  | 348 | 	 *
 | 
        
           |  |  | 349 | 	 * @access public
 | 
        
           |  |  | 350 | 	 * @param int $colorIndex Color index
 | 
        
           |  |  | 351 | 	 */
 | 
        
           |  |  | 352 | 	function setBgColor($colorIndex)
 | 
        
           |  |  | 353 | 	{
 | 
        
           |  |  | 354 | 		$this->_bg_color = $colorIndex;
 | 
        
           |  |  | 355 | 	}
 | 
        
           |  |  | 356 |   | 
        
           |  |  | 357 | 	/**
 | 
        
           |  |  | 358 | 	 * Sets the index to the number format record
 | 
        
           |  |  | 359 | 	 * It can be date, time, currency, etc...
 | 
        
           |  |  | 360 | 	 *
 | 
        
           |  |  | 361 | 	 * @access public
 | 
        
           |  |  | 362 | 	 * @param integer $numberFormatIndex Index to format record
 | 
        
           |  |  | 363 | 	 */
 | 
        
           |  |  | 364 | 	function setNumberFormatIndex($numberFormatIndex)
 | 
        
           |  |  | 365 | 	{
 | 
        
           |  |  | 366 | 		$this->_numberFormatIndex = $numberFormatIndex;
 | 
        
           |  |  | 367 | 	}
 | 
        
           |  |  | 368 |   | 
        
           |  |  | 369 | 	/**
 | 
        
           |  |  | 370 | 	 * Set the font index.
 | 
        
           |  |  | 371 | 	 *
 | 
        
           |  |  | 372 | 	 * @param int $value Font index, note that value 4 does not exist
 | 
        
           |  |  | 373 | 	 */
 | 
        
           |  |  | 374 | 	public function setFontIndex($value)
 | 
        
           |  |  | 375 | 	{
 | 
        
           |  |  | 376 | 		$this->_fontIndex = $value;
 | 
        
           |  |  | 377 | 	}
 | 
        
           |  |  | 378 |   | 
        
           |  |  | 379 | 	/**
 | 
        
           |  |  | 380 | 	 * Map of BIFF2-BIFF8 codes for border styles
 | 
        
           |  |  | 381 | 	 * @static	array of int
 | 
        
           |  |  | 382 | 	 *
 | 
        
           |  |  | 383 | 	 */
 | 
        
           |  |  | 384 | 	private static $_mapBorderStyle = array	( PHPExcel_Style_Border::BORDER_NONE				=> 0x00,
 | 
        
           |  |  | 385 | 											  PHPExcel_Style_Border::BORDER_THIN				=> 0x01,
 | 
        
           |  |  | 386 | 											  PHPExcel_Style_Border::BORDER_MEDIUM				=> 0x02,
 | 
        
           |  |  | 387 | 											  PHPExcel_Style_Border::BORDER_DASHED				=> 0x03,
 | 
        
           |  |  | 388 | 											  PHPExcel_Style_Border::BORDER_DOTTED				=> 0x04,
 | 
        
           |  |  | 389 | 											  PHPExcel_Style_Border::BORDER_THICK				=> 0x05,
 | 
        
           |  |  | 390 | 											  PHPExcel_Style_Border::BORDER_DOUBLE				=> 0x06,
 | 
        
           |  |  | 391 | 											  PHPExcel_Style_Border::BORDER_HAIR				=> 0x07,
 | 
        
           |  |  | 392 | 											  PHPExcel_Style_Border::BORDER_MEDIUMDASHED		=> 0x08,
 | 
        
           |  |  | 393 | 											  PHPExcel_Style_Border::BORDER_DASHDOT				=> 0x09,
 | 
        
           |  |  | 394 | 											  PHPExcel_Style_Border::BORDER_MEDIUMDASHDOT		=> 0x0A,
 | 
        
           |  |  | 395 | 											  PHPExcel_Style_Border::BORDER_DASHDOTDOT			=> 0x0B,
 | 
        
           |  |  | 396 | 											  PHPExcel_Style_Border::BORDER_MEDIUMDASHDOTDOT	=> 0x0C,
 | 
        
           |  |  | 397 | 											  PHPExcel_Style_Border::BORDER_SLANTDASHDOT		=> 0x0D,
 | 
        
           |  |  | 398 | 											);
 | 
        
           |  |  | 399 |   | 
        
           |  |  | 400 | 	/**
 | 
        
           |  |  | 401 | 	 * Map border style
 | 
        
           |  |  | 402 | 	 *
 | 
        
           |  |  | 403 | 	 * @param string $borderStyle
 | 
        
           |  |  | 404 | 	 * @return int
 | 
        
           |  |  | 405 | 	 */
 | 
        
           |  |  | 406 | 	private static function _mapBorderStyle($borderStyle) {
 | 
        
           |  |  | 407 | 		if (isset(self::$_mapBorderStyle[$borderStyle]))
 | 
        
           |  |  | 408 | 			return self::$_mapBorderStyle[$borderStyle];
 | 
        
           |  |  | 409 | 		return 0x00;
 | 
        
           |  |  | 410 | 	}
 | 
        
           |  |  | 411 |   | 
        
           |  |  | 412 | 	/**
 | 
        
           |  |  | 413 | 	 * Map of BIFF2-BIFF8 codes for fill types
 | 
        
           |  |  | 414 | 	 * @static	array of int
 | 
        
           |  |  | 415 | 	 *
 | 
        
           |  |  | 416 | 	 */
 | 
        
           |  |  | 417 | 	private static $_mapFillType = array( PHPExcel_Style_Fill::FILL_NONE					=> 0x00,
 | 
        
           |  |  | 418 | 										  PHPExcel_Style_Fill::FILL_SOLID					=> 0x01,
 | 
        
           |  |  | 419 | 										  PHPExcel_Style_Fill::FILL_PATTERN_MEDIUMGRAY		=> 0x02,
 | 
        
           |  |  | 420 | 										  PHPExcel_Style_Fill::FILL_PATTERN_DARKGRAY		=> 0x03,
 | 
        
           |  |  | 421 | 										  PHPExcel_Style_Fill::FILL_PATTERN_LIGHTGRAY		=> 0x04,
 | 
        
           |  |  | 422 | 										  PHPExcel_Style_Fill::FILL_PATTERN_DARKHORIZONTAL	=> 0x05,
 | 
        
           |  |  | 423 | 										  PHPExcel_Style_Fill::FILL_PATTERN_DARKVERTICAL	=> 0x06,
 | 
        
           |  |  | 424 | 										  PHPExcel_Style_Fill::FILL_PATTERN_DARKDOWN		=> 0x07,
 | 
        
           |  |  | 425 | 										  PHPExcel_Style_Fill::FILL_PATTERN_DARKUP			=> 0x08,
 | 
        
           |  |  | 426 | 										  PHPExcel_Style_Fill::FILL_PATTERN_DARKGRID		=> 0x09,
 | 
        
           |  |  | 427 | 										  PHPExcel_Style_Fill::FILL_PATTERN_DARKTRELLIS		=> 0x0A,
 | 
        
           |  |  | 428 | 										  PHPExcel_Style_Fill::FILL_PATTERN_LIGHTHORIZONTAL	=> 0x0B,
 | 
        
           |  |  | 429 | 										  PHPExcel_Style_Fill::FILL_PATTERN_LIGHTVERTICAL	=> 0x0C,
 | 
        
           |  |  | 430 | 										  PHPExcel_Style_Fill::FILL_PATTERN_LIGHTDOWN		=> 0x0D,
 | 
        
           |  |  | 431 | 										  PHPExcel_Style_Fill::FILL_PATTERN_LIGHTUP			=> 0x0E,
 | 
        
           |  |  | 432 | 										  PHPExcel_Style_Fill::FILL_PATTERN_LIGHTGRID		=> 0x0F,
 | 
        
           |  |  | 433 | 										  PHPExcel_Style_Fill::FILL_PATTERN_LIGHTTRELLIS	=> 0x10,
 | 
        
           |  |  | 434 | 										  PHPExcel_Style_Fill::FILL_PATTERN_GRAY125			=> 0x11,
 | 
        
           |  |  | 435 | 										  PHPExcel_Style_Fill::FILL_PATTERN_GRAY0625		=> 0x12,
 | 
        
           |  |  | 436 | 										  PHPExcel_Style_Fill::FILL_GRADIENT_LINEAR			=> 0x00,	// does not exist in BIFF8
 | 
        
           |  |  | 437 | 										  PHPExcel_Style_Fill::FILL_GRADIENT_PATH			=> 0x00,	// does not exist in BIFF8
 | 
        
           |  |  | 438 | 										);
 | 
        
           |  |  | 439 | 	/**
 | 
        
           |  |  | 440 | 	 * Map fill type
 | 
        
           |  |  | 441 | 	 *
 | 
        
           |  |  | 442 | 	 * @param string $fillType
 | 
        
           |  |  | 443 | 	 * @return int
 | 
        
           |  |  | 444 | 	 */
 | 
        
           |  |  | 445 | 	private static function _mapFillType($fillType) {
 | 
        
           |  |  | 446 | 		if (isset(self::$_mapFillType[$fillType]))
 | 
        
           |  |  | 447 | 			return self::$_mapFillType[$fillType];
 | 
        
           |  |  | 448 | 		return 0x00;
 | 
        
           |  |  | 449 | 	}
 | 
        
           |  |  | 450 |   | 
        
           |  |  | 451 | 	/**
 | 
        
           |  |  | 452 | 	 * Map of BIFF2-BIFF8 codes for horizontal alignment
 | 
        
           |  |  | 453 | 	 * @static	array of int
 | 
        
           |  |  | 454 | 	 *
 | 
        
           |  |  | 455 | 	 */
 | 
        
           |  |  | 456 | 	private static $_mapHAlign = array( PHPExcel_Style_Alignment::HORIZONTAL_GENERAL			=> 0,
 | 
        
           |  |  | 457 | 										PHPExcel_Style_Alignment::HORIZONTAL_LEFT				=> 1,
 | 
        
           |  |  | 458 | 										PHPExcel_Style_Alignment::HORIZONTAL_CENTER				=> 2,
 | 
        
           |  |  | 459 | 										PHPExcel_Style_Alignment::HORIZONTAL_RIGHT				=> 3,
 | 
        
           |  |  | 460 | 										PHPExcel_Style_Alignment::HORIZONTAL_JUSTIFY			=> 5,
 | 
        
           |  |  | 461 | 										PHPExcel_Style_Alignment::HORIZONTAL_CENTER_CONTINUOUS	=> 6,
 | 
        
           |  |  | 462 | 									  );
 | 
        
           |  |  | 463 | 	/**
 | 
        
           |  |  | 464 | 	 * Map to BIFF2-BIFF8 codes for horizontal alignment
 | 
        
           |  |  | 465 | 	 *
 | 
        
           |  |  | 466 | 	 * @param string $hAlign
 | 
        
           |  |  | 467 | 	 * @return int
 | 
        
           |  |  | 468 | 	 */
 | 
        
           |  |  | 469 | 	private function _mapHAlign($hAlign)
 | 
        
           |  |  | 470 | 	{
 | 
        
           |  |  | 471 | 		if (isset(self::$_mapHAlign[$hAlign]))
 | 
        
           |  |  | 472 | 			return self::$_mapHAlign[$hAlign];
 | 
        
           |  |  | 473 | 		return 0;
 | 
        
           |  |  | 474 | 	}
 | 
        
           |  |  | 475 |   | 
        
           |  |  | 476 | 	/**
 | 
        
           |  |  | 477 | 	 * Map of BIFF2-BIFF8 codes for vertical alignment
 | 
        
           |  |  | 478 | 	 * @static	array of int
 | 
        
           |  |  | 479 | 	 *
 | 
        
           |  |  | 480 | 	 */
 | 
        
           |  |  | 481 | 	private static $_mapVAlign = array( PHPExcel_Style_Alignment::VERTICAL_TOP		=> 0,
 | 
        
           |  |  | 482 | 										PHPExcel_Style_Alignment::VERTICAL_CENTER	=> 1,
 | 
        
           |  |  | 483 | 										PHPExcel_Style_Alignment::VERTICAL_BOTTOM	=> 2,
 | 
        
           |  |  | 484 | 										PHPExcel_Style_Alignment::VERTICAL_JUSTIFY	=> 3,
 | 
        
           |  |  | 485 | 									  );
 | 
        
           |  |  | 486 | 	/**
 | 
        
           |  |  | 487 | 	 * Map to BIFF2-BIFF8 codes for vertical alignment
 | 
        
           |  |  | 488 | 	 *
 | 
        
           |  |  | 489 | 	 * @param string $vAlign
 | 
        
           |  |  | 490 | 	 * @return int
 | 
        
           |  |  | 491 | 	 */
 | 
        
           |  |  | 492 | 	private static function _mapVAlign($vAlign) {
 | 
        
           |  |  | 493 | 		if (isset(self::$_mapVAlign[$vAlign]))
 | 
        
           |  |  | 494 | 			return self::$_mapVAlign[$vAlign];
 | 
        
           |  |  | 495 | 		return 2;
 | 
        
           |  |  | 496 | 	}
 | 
        
           |  |  | 497 |   | 
        
           |  |  | 498 | 	/**
 | 
        
           |  |  | 499 | 	 * Map to BIFF8 codes for text rotation angle
 | 
        
           |  |  | 500 | 	 *
 | 
        
           |  |  | 501 | 	 * @param int $textRotation
 | 
        
           |  |  | 502 | 	 * @return int
 | 
        
           |  |  | 503 | 	 */
 | 
        
           |  |  | 504 | 	private static function _mapTextRotation($textRotation) {
 | 
        
           |  |  | 505 | 		if ($textRotation >= 0) {
 | 
        
           |  |  | 506 | 			return $textRotation;
 | 
        
           |  |  | 507 | 		}
 | 
        
           |  |  | 508 | 		if ($textRotation == -165) {
 | 
        
           |  |  | 509 | 			return 255;
 | 
        
           |  |  | 510 | 		}
 | 
        
           |  |  | 511 | 		if ($textRotation < 0) {
 | 
        
           |  |  | 512 | 			return 90 - $textRotation;
 | 
        
           |  |  | 513 | 		}
 | 
        
           |  |  | 514 | 	}
 | 
        
           |  |  | 515 |   | 
        
           |  |  | 516 | 	/**
 | 
        
           |  |  | 517 | 	 * Map locked
 | 
        
           |  |  | 518 | 	 *
 | 
        
           |  |  | 519 | 	 * @param string
 | 
        
           |  |  | 520 | 	 * @return int
 | 
        
           |  |  | 521 | 	 */
 | 
        
           |  |  | 522 | 	private static function _mapLocked($locked) {
 | 
        
           |  |  | 523 | 		switch ($locked) {
 | 
        
           |  |  | 524 | 			case PHPExcel_Style_Protection::PROTECTION_INHERIT:		return 1;
 | 
        
           |  |  | 525 | 			case PHPExcel_Style_Protection::PROTECTION_PROTECTED:	return 1;
 | 
        
           |  |  | 526 | 			case PHPExcel_Style_Protection::PROTECTION_UNPROTECTED:	return 0;
 | 
        
           |  |  | 527 | 			default:												return 1;
 | 
        
           |  |  | 528 | 		}
 | 
        
           |  |  | 529 | 	}
 | 
        
           |  |  | 530 |   | 
        
           |  |  | 531 | 	/**
 | 
        
           |  |  | 532 | 	 * Map hidden
 | 
        
           |  |  | 533 | 	 *
 | 
        
           |  |  | 534 | 	 * @param string
 | 
        
           |  |  | 535 | 	 * @return int
 | 
        
           |  |  | 536 | 	 */
 | 
        
           |  |  | 537 | 	private static function _mapHidden($hidden) {
 | 
        
           |  |  | 538 | 		switch ($hidden) {
 | 
        
           |  |  | 539 | 			case PHPExcel_Style_Protection::PROTECTION_INHERIT:		return 0;
 | 
        
           |  |  | 540 | 			case PHPExcel_Style_Protection::PROTECTION_PROTECTED:	return 1;
 | 
        
           |  |  | 541 | 			case PHPExcel_Style_Protection::PROTECTION_UNPROTECTED:	return 0;
 | 
        
           |  |  | 542 | 			default:												return 0;
 | 
        
           |  |  | 543 | 		}
 | 
        
           |  |  | 544 | 	}
 | 
        
           |  |  | 545 |   | 
        
           |  |  | 546 | }
 |