| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | <?php | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * PHPExcel | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2013-12-31 18:36:33 +00:00
										 |  |  |  * Copyright (c) 2006 - 2014 PHPExcel | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +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_Worksheet | 
					
						
							| 
									
										
										
										
											2013-12-31 18:36:33 +00:00
										 |  |  |  * @copyright  Copyright (c) 2006 - 2014 PHPExcel (http://www.codeplex.com/PHPExcel) | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  |  * @license    http://www.gnu.org/licenses/old-licenses/lgpl-2.1.txt	LGPL | 
					
						
							|  |  |  |  * @version    ##VERSION##, ##DATE##
 | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * PHPExcel_Worksheet_SheetView | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @category   PHPExcel | 
					
						
							|  |  |  |  * @package    PHPExcel_Worksheet | 
					
						
							| 
									
										
										
										
											2013-12-31 18:36:33 +00:00
										 |  |  |  * @copyright  Copyright (c) 2006 - 2014 PHPExcel (http://www.codeplex.com/PHPExcel) | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  |  */ | 
					
						
							|  |  |  | class PHPExcel_Worksheet_SheetView | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-08-09 01:13:05 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-09 11:35:04 +00:00
										 |  |  | 	/* Sheet View types */ | 
					
						
							|  |  |  | 	const SHEETVIEW_NORMAL				= 'normal'; | 
					
						
							|  |  |  | 	const SHEETVIEW_PAGE_LAYOUT			= 'pageLayout'; | 
					
						
							|  |  |  | 	const SHEETVIEW_PAGE_BREAK_PREVIEW	= 'pageBreakPreview'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	private static $_sheetViewTypes = array( | 
					
						
							|  |  |  | 		self::SHEETVIEW_NORMAL, | 
					
						
							|  |  |  | 		self::SHEETVIEW_PAGE_LAYOUT, | 
					
						
							|  |  |  | 		self::SHEETVIEW_PAGE_BREAK_PREVIEW, | 
					
						
							|  |  |  | 	); | 
					
						
							| 
									
										
										
										
											2012-08-09 01:13:05 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	/** | 
					
						
							|  |  |  | 	 * ZoomScale | 
					
						
							| 
									
										
										
										
											2010-12-09 12:07:50 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 * Valid values range from 10 to 400. | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 * @var int | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2010-12-09 12:07:50 +00:00
										 |  |  | 	private $_zoomScale			= 100; | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/** | 
					
						
							|  |  |  | 	 * ZoomScaleNormal | 
					
						
							| 
									
										
										
										
											2010-12-09 12:07:50 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 * Valid values range from 10 to 400. | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 * @var int | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2010-12-09 12:07:50 +00:00
										 |  |  | 	private $_zoomScaleNormal	= 100; | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-09 01:13:05 +00:00
										 |  |  | 	/** | 
					
						
							|  |  |  | 	 * View | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 * Valid values range from 10 to 400. | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 * @var string | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2012-08-09 11:35:04 +00:00
										 |  |  | 	private $_sheetviewType		= self::SHEETVIEW_NORMAL; | 
					
						
							| 
									
										
										
										
											2012-08-09 01:13:05 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Create a new PHPExcel_Worksheet_SheetView | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function __construct() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/** | 
					
						
							|  |  |  | 	 * Get ZoomScale | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 * @return int | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	public function getZoomScale() { | 
					
						
							|  |  |  | 		return $this->_zoomScale; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/** | 
					
						
							|  |  |  | 	 * Set ZoomScale | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 * Valid values range from 10 to 400. | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 * @param 	int 	$pValue | 
					
						
							| 
									
										
										
										
											2013-01-15 21:42:28 +00:00
										 |  |  | 	 * @throws 	PHPExcel_Exception | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 * @return PHPExcel_Worksheet_SheetView | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	public function setZoomScale($pValue = 100) { | 
					
						
							|  |  |  | 		// Microsoft Office Excel 2007 only allows setting a scale between 10 and 400 via the user interface,
 | 
					
						
							|  |  |  | 		// but it is apparently still able to handle any scale >= 1
 | 
					
						
							|  |  |  | 		if (($pValue >= 1) || is_null($pValue)) { | 
					
						
							|  |  |  | 			$this->_zoomScale = $pValue; | 
					
						
							|  |  |  | 		} else { | 
					
						
							| 
									
										
										
										
											2013-01-15 21:42:28 +00:00
										 |  |  | 			throw new PHPExcel_Exception("Scale must be greater than or equal to 1."); | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		return $this; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2010-12-09 12:07:50 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	/** | 
					
						
							|  |  |  | 	 * Get ZoomScaleNormal | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 * @return int | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	public function getZoomScaleNormal() { | 
					
						
							|  |  |  | 		return $this->_zoomScaleNormal; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/** | 
					
						
							|  |  |  | 	 * Set ZoomScale | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 * Valid values range from 10 to 400. | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 * @param 	int 	$pValue | 
					
						
							| 
									
										
										
										
											2013-01-15 21:42:28 +00:00
										 |  |  | 	 * @throws 	PHPExcel_Exception | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 * @return PHPExcel_Worksheet_SheetView | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	public function setZoomScaleNormal($pValue = 100) { | 
					
						
							|  |  |  | 		if (($pValue >= 1) || is_null($pValue)) { | 
					
						
							|  |  |  | 			$this->_zoomScaleNormal = $pValue; | 
					
						
							|  |  |  | 		} else { | 
					
						
							| 
									
										
										
										
											2013-01-15 21:42:28 +00:00
										 |  |  | 			throw new PHPExcel_Exception("Scale must be greater than or equal to 1."); | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		return $this; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-09 01:13:05 +00:00
										 |  |  | 	/** | 
					
						
							|  |  |  | 	 * Get View | 
					
						
							|  |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-08-09 11:35:04 +00:00
										 |  |  | 	 * @return string | 
					
						
							| 
									
										
										
										
											2012-08-09 01:13:05 +00:00
										 |  |  | 	 */ | 
					
						
							|  |  |  | 	public function getView() { | 
					
						
							| 
									
										
										
										
											2012-08-09 11:35:04 +00:00
										 |  |  | 		return $this->_sheetviewType; | 
					
						
							| 
									
										
										
										
											2012-08-09 01:13:05 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/** | 
					
						
							|  |  |  | 	 * Set View | 
					
						
							|  |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-08-09 11:35:04 +00:00
										 |  |  | 	 * Valid values are | 
					
						
							|  |  |  | 	 *		'normal'			self::SHEETVIEW_NORMAL | 
					
						
							|  |  |  | 	 *		'pageLayout'		self::SHEETVIEW_PAGE_LAYOUT | 
					
						
							|  |  |  | 	 *		'pageBreakPreview'	self::SHEETVIEW_PAGE_BREAK_PREVIEW | 
					
						
							| 
									
										
										
										
											2012-08-09 01:13:05 +00:00
										 |  |  | 	 * | 
					
						
							|  |  |  | 	 * @param 	string 	$pValue | 
					
						
							| 
									
										
										
										
											2013-01-15 21:42:28 +00:00
										 |  |  | 	 * @throws 	PHPExcel_Exception | 
					
						
							| 
									
										
										
										
											2012-08-09 01:13:05 +00:00
										 |  |  | 	 * @return PHPExcel_Worksheet_SheetView | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2012-08-09 11:35:04 +00:00
										 |  |  | 	public function setView($pValue = NULL) { | 
					
						
							|  |  |  | 		//	MS Excel 2007 allows setting the view to 'normal', 'pageLayout' or 'pageBreakPreview'
 | 
					
						
							|  |  |  | 		//		via the user interface
 | 
					
						
							|  |  |  | 		if ($pValue === NULL) | 
					
						
							|  |  |  | 			$pValue = self::SHEETVIEW_NORMAL; | 
					
						
							|  |  |  | 		if (in_array($pValue, self::$_sheetViewTypes)) { | 
					
						
							|  |  |  | 			$this->_sheetviewType = $pValue; | 
					
						
							| 
									
										
										
										
											2012-08-09 01:13:05 +00:00
										 |  |  | 		} else { | 
					
						
							| 
									
										
										
										
											2013-01-15 21:42:28 +00:00
										 |  |  | 			throw new PHPExcel_Exception("Invalid sheetview layout type."); | 
					
						
							| 
									
										
										
										
											2012-08-09 01:13:05 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2012-08-09 11:35:04 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-09 01:13:05 +00:00
										 |  |  | 		return $this; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	/** | 
					
						
							|  |  |  | 	 * Implement PHP __clone to create a deep clone, not just a shallow copy. | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	public function __clone() { | 
					
						
							|  |  |  | 		$vars = get_object_vars($this); | 
					
						
							|  |  |  | 		foreach ($vars as $key => $value) { | 
					
						
							|  |  |  | 			if (is_object($value)) { | 
					
						
							|  |  |  | 				$this->$key = clone $value; | 
					
						
							|  |  |  | 			} else { | 
					
						
							|  |  |  | 				$this->$key = $value; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } |