| 
									
										
										
										
											2012-02-08 21:17:39 +00:00
										 |  |  | <?php | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * PHPExcel | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2013-05-14 11:20:28 +00:00
										 |  |  |  * Copyright (c) 2006 - 2013 PHPExcel | 
					
						
							| 
									
										
										
										
											2012-02-08 21:17:39 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * 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 | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @category	PHPExcel | 
					
						
							|  |  |  |  * @package		PHPExcel_Chart | 
					
						
							| 
									
										
										
										
											2013-05-14 11:20:28 +00:00
										 |  |  |  * @copyright	Copyright (c) 2006 - 2013 PHPExcel (http://www.codeplex.com/PHPExcel) | 
					
						
							| 
									
										
										
										
											2012-02-08 21:17:39 +00:00
										 |  |  |  * @license		http://www.gnu.org/licenses/old-licenses/lgpl-2.1.txt	LGPL | 
					
						
							|  |  |  |  * @version		##VERSION##, ##DATE##
 | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * PHPExcel_Chart_Legend | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @category	PHPExcel | 
					
						
							|  |  |  |  * @package		PHPExcel_Chart | 
					
						
							| 
									
										
										
										
											2013-05-14 11:20:28 +00:00
										 |  |  |  * @copyright	Copyright (c) 2006 - 2013 PHPExcel (http://www.codeplex.com/PHPExcel) | 
					
						
							| 
									
										
										
										
											2012-02-08 21:17:39 +00:00
										 |  |  |  */ | 
					
						
							|  |  |  | class PHPExcel_Chart_Legend | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	/** Legend positions */ | 
					
						
							|  |  |  | 	const xlLegendPositionBottom	= -4107;	//	Below the chart.
 | 
					
						
							|  |  |  | 	const xlLegendPositionCorner	= 2;		//	In the upper right-hand corner of the chart border.
 | 
					
						
							|  |  |  | 	const xlLegendPositionCustom	= -4161;	//	A custom position.
 | 
					
						
							|  |  |  | 	const xlLegendPositionLeft		= -4131;	//	Left of the chart.
 | 
					
						
							|  |  |  | 	const xlLegendPositionRight		= -4152;	//	Right of the chart.
 | 
					
						
							|  |  |  | 	const xlLegendPositionTop		= -4160;	//	Above the chart.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	const POSITION_RIGHT	= 'r'; | 
					
						
							|  |  |  | 	const POSITION_LEFT		= 'l'; | 
					
						
							|  |  |  | 	const POSITION_BOTTOM	= 'b'; | 
					
						
							|  |  |  | 	const POSITION_TOP		= 't'; | 
					
						
							|  |  |  | 	const POSITION_TOPRIGHT	= 'tr'; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-24 12:34:57 +00:00
										 |  |  | 	private static $_positionXLref = array( self::xlLegendPositionBottom	=> self::POSITION_BOTTOM, | 
					
						
							|  |  |  | 											self::xlLegendPositionCorner	=> self::POSITION_TOPRIGHT, | 
					
						
							|  |  |  | 											self::xlLegendPositionCustom	=> '??', | 
					
						
							|  |  |  | 											self::xlLegendPositionLeft		=> self::POSITION_LEFT, | 
					
						
							|  |  |  | 											self::xlLegendPositionRight		=> self::POSITION_RIGHT, | 
					
						
							|  |  |  | 											self::xlLegendPositionTop		=> self::POSITION_TOP | 
					
						
							|  |  |  | 										  ); | 
					
						
							| 
									
										
										
										
											2012-02-08 21:17:39 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/** | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * Legend position | 
					
						
							| 
									
										
										
										
											2012-02-08 21:17:39 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * @var	string | 
					
						
							| 
									
										
										
										
											2012-02-08 21:17:39 +00:00
										 |  |  | 	 */ | 
					
						
							|  |  |  | 	private $_position = self::POSITION_RIGHT; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/** | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * Allow overlay of other elements? | 
					
						
							| 
									
										
										
										
											2012-02-08 21:17:39 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * @var	boolean | 
					
						
							| 
									
										
										
										
											2012-02-08 21:17:39 +00:00
										 |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2012-06-24 12:34:57 +00:00
										 |  |  | 	private $_overlay = TRUE; | 
					
						
							| 
									
										
										
										
											2012-02-08 21:17:39 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/** | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * Legend Layout | 
					
						
							| 
									
										
										
										
											2012-02-08 21:17:39 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * @var	PHPExcel_Chart_Layout | 
					
						
							| 
									
										
										
										
											2012-02-08 21:17:39 +00:00
										 |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2012-06-24 12:34:57 +00:00
										 |  |  | 	private $_layout = NULL; | 
					
						
							| 
									
										
										
										
											2012-02-08 21:17:39 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/** | 
					
						
							|  |  |  | 	 *	Create a new PHPExcel_Chart_Legend | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2012-06-24 12:34:57 +00:00
										 |  |  | 	public function __construct($position = self::POSITION_RIGHT, PHPExcel_Chart_Layout $layout = NULL, $overlay = FALSE) | 
					
						
							| 
									
										
										
										
											2012-02-08 21:17:39 +00:00
										 |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2012-06-24 12:34:57 +00:00
										 |  |  | 		$this->setPosition($position); | 
					
						
							| 
									
										
										
										
											2012-02-08 21:17:39 +00:00
										 |  |  | 		$this->_layout = $layout; | 
					
						
							| 
									
										
										
										
											2012-06-24 12:34:57 +00:00
										 |  |  | 		$this->setOverlay($overlay); | 
					
						
							| 
									
										
										
										
											2012-02-08 21:17:39 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/** | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * Get legend position as an excel string value | 
					
						
							| 
									
										
										
										
											2012-02-08 21:17:39 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * @return	string | 
					
						
							| 
									
										
										
										
											2012-02-08 21:17:39 +00:00
										 |  |  | 	 */ | 
					
						
							|  |  |  | 	public function getPosition() { | 
					
						
							|  |  |  | 		return $this->_position; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/** | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * Get legend position using an excel string value | 
					
						
							| 
									
										
										
										
											2012-02-08 21:17:39 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * @param	string	$position | 
					
						
							| 
									
										
										
										
											2012-02-08 21:17:39 +00:00
										 |  |  | 	 */ | 
					
						
							|  |  |  | 	public function setPosition($position = self::POSITION_RIGHT) { | 
					
						
							| 
									
										
										
										
											2012-06-24 12:34:57 +00:00
										 |  |  | 		if (!in_array($position,self::$_positionXLref)) { | 
					
						
							| 
									
										
										
										
											2012-02-08 21:17:39 +00:00
										 |  |  | 			return false; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		$this->_position = $position; | 
					
						
							|  |  |  | 		return true; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/** | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * Get legend position as an Excel internal numeric value | 
					
						
							| 
									
										
										
										
											2012-02-08 21:17:39 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * @return	number | 
					
						
							| 
									
										
										
										
											2012-02-08 21:17:39 +00:00
										 |  |  | 	 */ | 
					
						
							|  |  |  | 	public function getPositionXL() { | 
					
						
							| 
									
										
										
										
											2012-06-24 12:34:57 +00:00
										 |  |  | 		return array_search($this->_position,self::$_positionXLref); | 
					
						
							| 
									
										
										
										
											2012-02-08 21:17:39 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/** | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * Set legend position using an Excel internal numeric value | 
					
						
							| 
									
										
										
										
											2012-02-08 21:17:39 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * @param	number	$positionXL | 
					
						
							| 
									
										
										
										
											2012-02-08 21:17:39 +00:00
										 |  |  | 	 */ | 
					
						
							|  |  |  | 	public function setPositionXL($positionXL = self::xlLegendPositionRight) { | 
					
						
							| 
									
										
										
										
											2012-06-24 12:34:57 +00:00
										 |  |  | 		if (!array_key_exists($positionXL,self::$_positionXLref)) { | 
					
						
							| 
									
										
										
										
											2012-02-08 21:17:39 +00:00
										 |  |  | 			return false; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-24 12:34:57 +00:00
										 |  |  | 		$this->_position = self::$_positionXLref[$positionXL]; | 
					
						
							| 
									
										
										
										
											2012-02-08 21:17:39 +00:00
										 |  |  | 		return true; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/** | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * Get allow overlay of other elements? | 
					
						
							| 
									
										
										
										
											2012-02-08 21:17:39 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * @return	boolean | 
					
						
							| 
									
										
										
										
											2012-02-08 21:17:39 +00:00
										 |  |  | 	 */ | 
					
						
							|  |  |  | 	public function getOverlay() { | 
					
						
							|  |  |  | 		return $this->_overlay; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/** | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * Set allow overlay of other elements? | 
					
						
							| 
									
										
										
										
											2012-02-08 21:17:39 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-06-24 12:34:57 +00:00
										 |  |  | 	 * @param	boolean	$overlay | 
					
						
							|  |  |  | 	 * @return	boolean | 
					
						
							| 
									
										
										
										
											2012-02-08 21:17:39 +00:00
										 |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2012-06-24 12:34:57 +00:00
										 |  |  | 	public function setOverlay($overlay = FALSE) { | 
					
						
							|  |  |  | 		if (!is_bool($overlay)) { | 
					
						
							|  |  |  | 			return false; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		$this->_overlay = $overlay; | 
					
						
							|  |  |  | 		return true; | 
					
						
							| 
									
										
										
										
											2012-02-08 21:17:39 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/** | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * Get Layout | 
					
						
							| 
									
										
										
										
											2012-02-08 21:17:39 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * @return PHPExcel_Chart_Layout | 
					
						
							| 
									
										
										
										
											2012-02-08 21:17:39 +00:00
										 |  |  | 	 */ | 
					
						
							|  |  |  | 	public function getLayout() { | 
					
						
							|  |  |  | 		return $this->_layout; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } |